]> git.donarmstrong.com Git - dsa-puppet.git/blobdiff - 3rdparty/modules/nova/manifests/network/neutron.pp
try again, with puppetforge modules, correctly included now
[dsa-puppet.git] / 3rdparty / modules / nova / manifests / network / neutron.pp
diff --git a/3rdparty/modules/nova/manifests/network/neutron.pp b/3rdparty/modules/nova/manifests/network/neutron.pp
new file mode 100644 (file)
index 0000000..f9cc997
--- /dev/null
@@ -0,0 +1,141 @@
+# == 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 }
+  }
+
+}