+++ /dev/null
-# == Class: nova::network::neutron
-#
-# Configures Nova network to use Neutron.
-#
-# === Parameters:
-#
-# [*neutron_admin_password*]
-# (required) Password for connecting to Neutron network services in
-# admin context through the OpenStack Identity service.
-#
-# [*neutron_auth_strategy*]
-# (optional) Should be kept as default 'keystone' for all production deployments.
-# Defaults to 'keystone'
-#
-# [*neutron_url*]
-# (optional) URL for connecting to the Neutron networking service.
-# Defaults to 'http://127.0.0.1:9696'
-#
-# [*neutron_url_timeout*]
-# (optional) Timeout value for connecting to neutron in seconds.
-# Defaults to '30'
-#
-# [*neutron_admin_tenant_name*]
-# (optional) Tenant name for connecting to Neutron network services in
-# admin context through the OpenStack Identity service.
-# Defaults to 'services'
-#
-# [*neutron_default_tenant_id*]
-# (optional) Default tenant id when creating neutron networks
-# Defaults to 'default'
-#
-# [*neutron_region_name*]
-# (optional) Region name for connecting to neutron in admin context
-# through the OpenStack Identity service.
-# Defaults to 'RegionOne'
-#
-# [*neutron_admin_username*]
-# (optional) Username for connecting to Neutron network services in admin context
-# through the OpenStack Identity service.
-# Defaults to 'neutron'
-#
-# [*neutron_ovs_bridge*]
-# (optional) Name of Integration Bridge used by Open vSwitch
-# Defaults to 'br-int'
-#
-# [*neutron_extension_sync_interval*]
-# (optional) Number of seconds before querying neutron for extensions
-# Defaults to '600'
-#
-# [*neutron_ca_certificates_file*]
-# (optional) Location of ca certicates file to use for neutronclient requests.
-# Defaults to 'None'
-#
-# [*neutron_admin_auth_url*]
-# (optional) Points to the OpenStack Identity server IP and port.
-# This is the Identity (keystone) admin API server IP and port value,
-# and not the Identity service API IP and port.
-# Defaults to 'http://127.0.0.1:35357/v2.0'
-#
-# [*network_api_class*]
-# (optional) The full class name of the network API class.
-# The default configures Nova to use Neutron for the network API.
-# Defaults to 'nova.network.neutronv2.api.API'
-#
-# [*security_group_api*]
-# (optional) The full class name of the security API class.
-# The default configures Nova to use Neutron for security groups.
-# Set to 'nova' to use standard Nova security groups.
-# Defaults to 'neutron'
-#
-# [*firewall_driver*]
-# (optional) Firewall driver.
-# This prevents nova from maintaining a firewall so it does not interfere
-# with Neutron's. Set to 'nova.virt.firewall.IptablesFirewallDriver'
-# to re-enable the Nova firewall.
-# Defaults to 'nova.virt.firewall.NoopFirewallDriver'
-#
-# [*vif_plugging_is_fatal*]
-# (optional) Fail to boot instance if vif plugging fails.
-# This prevents nova from booting an instance if vif plugging notification
-# is not received from neutron.
-# Defaults to 'True'
-#
-# [*vif_plugging_timeout*]
-# (optional) Number of seconds to wait for neutron vif plugging events.
-# Set to '0' and vif_plugging_is_fatal to 'False' if vif plugging
-# notification is not being used.
-# Defaults to '300'
-#
-# [*dhcp_domain*]
-# (optional) domain to use for building the hostnames
-# Defaults to 'novalocal'
-#
-class nova::network::neutron (
- $neutron_admin_password,
- $neutron_auth_strategy = 'keystone',
- $neutron_url = 'http://127.0.0.1:9696',
- $neutron_url_timeout = '30',
- $neutron_admin_tenant_name = 'services',
- $neutron_default_tenant_id = 'default',
- $neutron_region_name = 'RegionOne',
- $neutron_admin_username = 'neutron',
- $neutron_admin_auth_url = 'http://127.0.0.1:35357/v2.0',
- $neutron_ovs_bridge = 'br-int',
- $neutron_extension_sync_interval = '600',
- $neutron_ca_certificates_file = undef,
- $network_api_class = 'nova.network.neutronv2.api.API',
- $security_group_api = 'neutron',
- $firewall_driver = 'nova.virt.firewall.NoopFirewallDriver',
- $vif_plugging_is_fatal = true,
- $vif_plugging_timeout = '300',
- $dhcp_domain = 'novalocal',
-) {
-
- nova_config {
- 'DEFAULT/dhcp_domain': value => $dhcp_domain;
- 'DEFAULT/firewall_driver': value => $firewall_driver;
- 'DEFAULT/network_api_class': value => $network_api_class;
- 'DEFAULT/security_group_api': value => $security_group_api;
- 'DEFAULT/vif_plugging_is_fatal': value => $vif_plugging_is_fatal;
- 'DEFAULT/vif_plugging_timeout': value => $vif_plugging_timeout;
- 'neutron/auth_strategy': value => $neutron_auth_strategy;
- 'neutron/url': value => $neutron_url;
- 'neutron/url_timeout': value => $neutron_url_timeout;
- 'neutron/admin_tenant_name': value => $neutron_admin_tenant_name;
- 'neutron/default_tenant_id': value => $neutron_default_tenant_id;
- 'neutron/region_name': value => $neutron_region_name;
- 'neutron/admin_username': value => $neutron_admin_username;
- 'neutron/admin_password': value => $neutron_admin_password, secret => true;
- 'neutron/admin_auth_url': value => $neutron_admin_auth_url;
- 'neutron/ovs_bridge': value => $neutron_ovs_bridge;
- 'neutron/extension_sync_interval': value => $neutron_extension_sync_interval;
- }
-
- if ! $neutron_ca_certificates_file {
- nova_config { 'neutron/ca_certificates_file': ensure => absent }
- } else {
- nova_config { 'neutron/ca_certificates_file': value => $neutron_ca_certificates_file }
- }
-
-}