73d64f2cc1
In some cases, the parameter will not passed as an array but as a string, causing conversion error when generating the matching list Force array parameter conversion to cover all cases Change-Id: I4290bb1dbb96ea0d57e6ad8c6a686c2bf103c907 Closes-Bug: #1866206
191 lines
5.5 KiB
Puppet
191 lines
5.5 KiB
Puppet
# == Class: neutron::agents::ml2::linuxbridge
|
|
#
|
|
# Setups Linuxbridge Neutron agent for ML2 plugin.
|
|
#
|
|
# === Parameters
|
|
#
|
|
# [*package_ensure*]
|
|
# (optional) Package ensure state.
|
|
# Defaults to 'present'.
|
|
#
|
|
# [*enabled*]
|
|
# (required) Whether or not to enable the agent.
|
|
# Defaults to true.
|
|
#
|
|
# [*manage_service*]
|
|
# (optional) Whether to start/stop the service
|
|
# Defaults to true
|
|
#
|
|
# [*tunnel_types*]
|
|
# (optional) List of types of tunnels to use when utilizing tunnels.
|
|
# Supported tunnel types are: vxlan.
|
|
# Defaults to an empty list.
|
|
#
|
|
# [*local_ip*]
|
|
# (optional) Local IP address to use for VXLAN endpoints.
|
|
# Required when enabling tunneling.
|
|
# Defaults to false.
|
|
#
|
|
# [*vxlan_group*]
|
|
# (optional) Multicast group for vxlan interface. If unset, disables VXLAN
|
|
# multicast mode. Should be an Multicast IP (v4 or v6) address.
|
|
# Default to '224.0.0.1'.
|
|
#
|
|
# [*vxlan_ttl*]
|
|
# (optional) TTL for vxlan interface protocol packets..
|
|
# Default to undef.
|
|
#
|
|
# [*vxlan_tos*]
|
|
# (optional) TOS for vxlan interface protocol packets..
|
|
# Defaults to undef.
|
|
#
|
|
# [*polling_interval*]
|
|
# (optional) The number of seconds the agent will wait between
|
|
# polling for local device changes.
|
|
# Defaults to 2.
|
|
#
|
|
# [*l2_population*]
|
|
# (optional) Extension to use alongside ml2 plugin's l2population
|
|
# mechanism driver. It enables the plugin to populate VXLAN forwarding table.
|
|
# Defaults to false.
|
|
#
|
|
# [*physical_interface_mappings*]
|
|
# (optional) List of <physical_network>:<physical_interface>
|
|
# tuples mapping physical network names to agent's node-specific physical
|
|
# network interfaces. Defaults to empty list.
|
|
#
|
|
# [*bridge_mappings*]
|
|
# (optional) List of <physical_network>:<bridge>
|
|
# Defaults to empty list
|
|
#
|
|
# [*firewall_driver*]
|
|
# (optional) Firewall driver for realizing neutron security group function.
|
|
# Defaults to 'iptables'.
|
|
#
|
|
# [*purge_config*]
|
|
# (optional) Whether to set only the specified config options
|
|
# in the linuxbridge config.
|
|
# Defaults to false.
|
|
#
|
|
class neutron::agents::ml2::linuxbridge (
|
|
$package_ensure = 'present',
|
|
$enabled = true,
|
|
$manage_service = true,
|
|
$tunnel_types = [],
|
|
$local_ip = false,
|
|
$vxlan_group = $::os_service_default,
|
|
$vxlan_ttl = $::os_service_default,
|
|
$vxlan_tos = $::os_service_default,
|
|
$polling_interval = $::os_service_default,
|
|
$l2_population = $::os_service_default,
|
|
$physical_interface_mappings = [],
|
|
$bridge_mappings = [],
|
|
$firewall_driver = 'iptables',
|
|
$purge_config = false,
|
|
) {
|
|
|
|
validate_legacy(Array, 'validate_array', $tunnel_types)
|
|
validate_legacy(Array, 'validate_array', $physical_interface_mappings)
|
|
validate_legacy(Array, 'validate_array', $bridge_mappings)
|
|
|
|
include neutron::deps
|
|
include neutron::params
|
|
|
|
resources { 'neutron_agent_linuxbridge':
|
|
purge => $purge_config,
|
|
}
|
|
|
|
if ('vxlan' in $tunnel_types) {
|
|
|
|
if ! $local_ip {
|
|
fail('The local_ip parameter is required when vxlan tunneling is enabled')
|
|
}
|
|
|
|
neutron_agent_linuxbridge {
|
|
'vxlan/ttl': value => $vxlan_ttl;
|
|
'vxlan/vxlan_group': value => $vxlan_group;
|
|
'vxlan/tos': value => $vxlan_tos;
|
|
'vxlan/local_ip': value => $local_ip;
|
|
'vxlan/l2_population': value => $l2_population;
|
|
}
|
|
} else {
|
|
neutron_agent_linuxbridge {
|
|
'vxlan/enable_vxlan': value => false;
|
|
'vxlan/local_ip': ensure => absent;
|
|
}
|
|
}
|
|
|
|
if size($tunnel_types) > 0 {
|
|
neutron_agent_linuxbridge {
|
|
'agent/tunnel_types': value => join($tunnel_types, ',');
|
|
}
|
|
} else {
|
|
neutron_agent_linuxbridge {
|
|
'agent/tunnel_types': ensure => absent;
|
|
}
|
|
}
|
|
|
|
if size($bridge_mappings) > 0 {
|
|
neutron_agent_linuxbridge {
|
|
'linux_bridge/bridge_mappings': value => join(any2array($bridge_mappings), ',');
|
|
}
|
|
} else {
|
|
neutron_agent_linuxbridge {
|
|
'linux_bridge/bridge_mappings': ensure => absent;
|
|
}
|
|
}
|
|
|
|
neutron_agent_linuxbridge {
|
|
'agent/polling_interval': value => $polling_interval;
|
|
'linux_bridge/physical_interface_mappings': value => join($physical_interface_mappings, ',');
|
|
}
|
|
|
|
if $firewall_driver {
|
|
neutron_agent_linuxbridge { 'securitygroup/firewall_driver': value => $firewall_driver }
|
|
} else {
|
|
neutron_agent_linuxbridge { 'securitygroup/firewall_driver': ensure => absent }
|
|
}
|
|
|
|
if $::neutron::params::linuxbridge_agent_package {
|
|
package { 'neutron-plugin-linuxbridge-agent':
|
|
ensure => $package_ensure,
|
|
name => $::neutron::params::linuxbridge_agent_package,
|
|
tag => ['openstack', 'neutron-package'],
|
|
}
|
|
} else {
|
|
# Some platforms (RedHat) do not provide a separate
|
|
# neutron plugin linuxbridge agent package.
|
|
if ! defined(Package['neutron-plugin-linuxbridge-agent']) {
|
|
package { 'neutron-plugin-linuxbridge-agent':
|
|
ensure => $package_ensure,
|
|
name => $::neutron::params::linuxbridge_server_package,
|
|
tag => ['openstack', 'neutron-package'],
|
|
}
|
|
}
|
|
}
|
|
|
|
if $manage_service {
|
|
if $enabled {
|
|
$service_ensure = 'running'
|
|
} else {
|
|
$service_ensure = 'stopped'
|
|
}
|
|
}
|
|
|
|
if $::neutron::default_transport_url {
|
|
$linuxbridge_agent_subscribe = [
|
|
Neutron_config['DEFAULT/transport_url']
|
|
]
|
|
} else {
|
|
$linuxbridge_agent_subscribe = undef
|
|
}
|
|
|
|
service { 'neutron-plugin-linuxbridge-agent':
|
|
ensure => $service_ensure,
|
|
name => $::neutron::params::linuxbridge_agent_service,
|
|
enable => $enabled,
|
|
tag => 'neutron-service',
|
|
subscribe => $linuxbridge_agent_subscribe,
|
|
}
|
|
}
|