puppet-neutron/manifests/plugins/ml2/cisco/nexus_switch.pp

140 lines
5.1 KiB
Puppet

# == Define: neutron::plugins::ml2::cisco::nexus_switch
#
# Defined type to configure the Cisco Nexus Switch parameters
# for use by the ML2 Mech Driver for Cisco Nexus Switches.
#
# More info available here:
# http://networking-cisco.readthedocs.io
#
#
# neutron::plugins::ml2::cisco::nexus_switch used by
# neutron::plugins::ml2::cisco::nexus
#
# === Parameters:
# [*username*]
# (required) The username for logging into the switch to manage it.
#
# [*password*]
# (required) The password for logging into the switch to manage it.
#
# [*ip_address*]
# (required) The IP address of the switch.
#
# [*servers*]
# (required) A hash of server names (key) mapped to the switch's
# interfaces (value). For each host connected to a port on the
# switch, specify the hostname and the Nexus physical port/s
# (interface/s) it is connected to. The values in the hash can
# be a comma separated list of interfaces mapped to the server.
#
# Hash Format:
#
# {
# <hostname1> => {"ports" => "<interfaceID1>,<interfaceID2>, ..."},
# <hostname2> => {"ports" => "<interfaceID1>,<interfaceID2>, ..."},
# }
#
# Interface ID format options:
# "<intf_type>:<position>"
# Valid intf_type's are 'ethernet' and 'port-channel'.
# The default setting for <intf_type:> is 'ethernet' and need not be
# added to this setting.
#
# Example:
# {
# 'control1' => {"ports" => 'ethernet:1/1'},
# 'control2' => {"ports" => 'ethernet:1/2'},
# 'compute1' => {"ports" => '1/3,1/4'}
# }
#
# [*switchname*]
# (required) An identifier for the switch--ie. hostname or IP
# address of the switch.
#
# [*nve_src_intf*]
# (optional) Only valid if VXLAN overlay is configured and
# vxlan_global_config is set to True.
#
# The NVE source interface is a loopback interface that is configured on
# the switch with valid /32 IP address. This /32 IP address must be known
# by the transient devices in the transport network and the remote VTEPs.
# This is accomplished by advertising it through a dynamic routing protocol
# in the transport network. (NB: If no nve_src_intf is defined then a
# default setting of 0 (creates "loopback0") will be used.)
#
# Defaults to $::os_service_default.
#
# [*physnet*]
# (optional) Only valid if VXLAN overlay is configured.
# The physical network name defined in the network_vlan_ranges variable
# (defined under the ml2_type_vlan section) that this switch is controlling.
# The configured 'physnet' is the physical network domain that is connected
# to this switch. The vlan ranges defined in network_vlan_ranges for a
# a physical network are allocated dynamically and are unique per physical
# network. These dynamic vlans may be reused across physical networks.
#
# Defaults to $::os_service_default.
#
# [*vpc_pool*]
# (optional) Required for Baremetal deployments and Port-Channel creation
# is needed. This defines the pool of port-channel ids which are
# available for port-channel creation.
#
# [*intfcfg_portchannel*]
# (optional) For use with Baremetal deployments and custom port-channel
# configuration is required during port-channel creation.
#
# [*https_verify*]
# (optional) Set to True when certification authority (CA) file is in
# the Operating System repository or is a locally defined file whose
# name is provided in https_local_certificate. Set to False
# to skip https certification checking thus making the connection
# insecure. Getting a certificate and setting https_verify to True
# is strongly advised for production to prevent man-in-the-middle
# attacks. Be advised the default will change from False to True
# in future releases.
#
# [*https_local_certificate*]
# (optional) Configure a local certificate file to present in https
# requests. For experimental purpose when an official certificate
# from a Trusted Certificate Authority is not yet available.
#
# DEPRECATED
# [*ssh_port*]
# (optional) This configuration item is deprecated.
# The SSH port to use when connecting to the switch.
# Defaults to $::os_service_default
#
define neutron::plugins::ml2::cisco::nexus_switch(
$username,
$password,
$ip_address,
$servers,
$switchname = $title,
$ssh_port = $::os_service_default,
$nve_src_intf = $::os_service_default,
$physnet = $::os_service_default,
$vpc_pool = $::os_service_default,
$intfcfg_portchannel = $::os_service_default,
$https_verify = $::os_service_default,
$https_local_certificate = $::os_service_default
) {
include ::neutron::deps
$section = "ML2_MECH_CISCO_NEXUS:${ip_address}"
$port_mappings = template('neutron/nexus_switch_port_mappings.erb')
neutron_plugin_ml2 {
"${section}/username": value => $username;
"${section}/password": value => $password, secret => true;
"${section}/nve_src_intf": value => $nve_src_intf;
"${section}/physnet": value => $physnet;
"${section}/vpc_pool": value => $vpc_pool;
"${section}/intfcfg_portchannel": value => $intfcfg_portchannel;
"${section}/https_verify": value => $https_verify;
"${section}/https_local_certificate": value => $https_local_certificate;
#DEPRECATED ARGS
"${section}/ssh_port": value => $ssh_port;
}
}