| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 1 | # Neutron Modular Layer 2 plugin | 
| Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 2 | # ------------------------------ | 
 | 3 |  | 
 | 4 | # Save trace setting | 
 | 5 | MY_XTRACE=$(set +o | grep xtrace) | 
 | 6 | set +o xtrace | 
 | 7 |  | 
| Kyle Mestery | b772659 | 2013-07-19 14:26:53 +0000 | [diff] [blame] | 8 | # Enable this to simply and quickly enable tunneling with ML2. | 
 | 9 | # Select either 'gre', 'vxlan', or '(gre vxlan)' | 
 | 10 | Q_ML2_TENANT_NETWORK_TYPE=${Q_ML2_TENANT_NETWORK_TYPE:-} | 
 | 11 | # This has to be set here since the agent will set this in the config file | 
 | 12 | if [[ "$Q_ML2_TENANT_NETWORK_TYPE" != "" ]]; then | 
| Kyle Mestery | 061d525 | 2013-09-09 08:52:19 +0000 | [diff] [blame^] | 13 |     Q_AGENT_EXTRA_AGENT_OPTS+=(tunnel_types=$Q_ML2_TENANT_NETWORK_TYPE) | 
| Kyle Mestery | b772659 | 2013-07-19 14:26:53 +0000 | [diff] [blame] | 14 | elif [[ "$ENABLE_TENANT_TUNNELS" = "True" ]]; then | 
| Kyle Mestery | 061d525 | 2013-09-09 08:52:19 +0000 | [diff] [blame^] | 15 |     Q_AGENT_EXTRA_AGENT_OPTS+=(tunnel_types=gre) | 
| Kyle Mestery | b772659 | 2013-07-19 14:26:53 +0000 | [diff] [blame] | 16 | fi | 
 | 17 |  | 
| Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 18 | # Default openvswitch L2 agent | 
 | 19 | Q_AGENT=${Q_AGENT:-openvswitch} | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 20 | source $TOP_DIR/lib/neutron_plugins/${Q_AGENT}_agent | 
| Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 21 |  | 
| Kyle Mestery | b772659 | 2013-07-19 14:26:53 +0000 | [diff] [blame] | 22 | # List of MechanismDrivers to load | 
| Kyle Mestery | 3ea28ec | 2013-08-05 12:24:32 +0000 | [diff] [blame] | 23 | Q_ML2_PLUGIN_MECHANISM_DRIVERS=${Q_ML2_PLUGIN_MECHANISM_DRIVERS:-} | 
| Kyle Mestery | b772659 | 2013-07-19 14:26:53 +0000 | [diff] [blame] | 24 | # List of Type Drivers to load | 
 | 25 | Q_ML2_PLUGIN_TYPE_DRIVERS=${Q_ML2_PLUGIN_TYPE_DRIVERS:-local,flat,vlan,gre,vxlan} | 
 | 26 | # Default GRE TypeDriver options | 
 | 27 | Q_ML2_PLUGIN_GRE_TYPE_OPTIONS=${Q_ML2_PLUGIN_GRE_TYPE_OPTIONS:-tunnel_id_ranges=$TENANT_TUNNEL_RANGES} | 
 | 28 | # Default VXLAN TypeDriver options | 
 | 29 | Q_ML2_PLUGIN_VXLAN_TYPE_OPTIONS=${Q_ML2_PLUGIN_VXLAN_TYPE_OPTIONS:-vni_ranges=1001:2000} | 
 | 30 | # Default VLAN TypeDriver options | 
 | 31 | Q_ML2_PLUGIN_VLAN_TYPE_OPTIONS=${Q_ML2_PLUGIN_VLAN_TYPE_OPTIONS:-} | 
 | 32 |  | 
 | 33 | function populate_ml2_config() { | 
 | 34 |     OPTS=$1 | 
 | 35 |     CONF=$2 | 
 | 36 |     SECTION=$3 | 
 | 37 |  | 
 | 38 |     for I in "${OPTS[@]}"; do | 
 | 39 |         # Replace the first '=' with ' ' for iniset syntax | 
 | 40 |         iniset $CONF $SECTION ${I/=/ } | 
 | 41 |     done | 
 | 42 | } | 
 | 43 |  | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 44 | function neutron_plugin_configure_common() { | 
 | 45 |     Q_PLUGIN_CONF_PATH=etc/neutron/plugins/ml2 | 
| Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 46 |     Q_PLUGIN_CONF_FILENAME=ml2_conf.ini | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 47 |     Q_DB_NAME="neutron_ml2" | 
 | 48 |     Q_PLUGIN_CLASS="neutron.plugins.ml2.plugin.Ml2Plugin" | 
| Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 49 | } | 
 | 50 |  | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 51 | function neutron_plugin_configure_service() { | 
| Kyle Mestery | b772659 | 2013-07-19 14:26:53 +0000 | [diff] [blame] | 52 |     if [[ "$Q_ML2_TENANT_NETWORK_TYPE" != "" ]]; then | 
| Kyle Mestery | 061d525 | 2013-09-09 08:52:19 +0000 | [diff] [blame^] | 53 |         Q_SRV_EXTRA_OPTS+=(tenant_network_types=$Q_ML2_TENANT_NETWORK_TYPE) | 
| Kyle Mestery | b772659 | 2013-07-19 14:26:53 +0000 | [diff] [blame] | 54 |     elif [[ "$ENABLE_TENANT_TUNNELS" = "True" ]]; then | 
 | 55 |         # This assumes you want a simple configuration, and will overwrite | 
 | 56 |         # Q_SRV_EXTRA_OPTS if set in addition to ENABLE_TENANT_TUNNELS. | 
| Kyle Mestery | 061d525 | 2013-09-09 08:52:19 +0000 | [diff] [blame^] | 57 |         Q_SRV_EXTRA_OPTS+=(tenant_network_types=gre) | 
| Kyle Mestery | b772659 | 2013-07-19 14:26:53 +0000 | [diff] [blame] | 58 |         Q_ML2_PLUGIN_GRE_TYPE_OPTIONS=(tunnel_id_ranges=$TENANT_TUNNEL_RANGES) | 
| Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 59 |     elif [[ "$ENABLE_TENANT_VLANS" = "True" ]]; then | 
| Kyle Mestery | 061d525 | 2013-09-09 08:52:19 +0000 | [diff] [blame^] | 60 |         Q_SRV_EXTRA_OPTS+=(tenant_network_types=vlan) | 
| Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 61 |     else | 
 | 62 |         echo "WARNING - The ml2 plugin is using local tenant networks, with no connectivity between hosts." | 
 | 63 |     fi | 
 | 64 |  | 
| Kyle Mestery | b772659 | 2013-07-19 14:26:53 +0000 | [diff] [blame] | 65 |     # Allow for overrding VLAN configuration (for example, to configure provider | 
 | 66 |     # VLANs) by first checking if Q_ML2_PLUGIN_VLAN_TYPE_OPTIONS is set. | 
 | 67 |     if [ "$Q_ML2_PLUGIN_VLAN_TYPE_OPTIONS" == "" ]; then | 
 | 68 |         if [[ "$ML2_VLAN_RANGES" = "" ]] && [[ "$PHYSICAL_NETWORK" != "" ]]; then | 
 | 69 |             ML2_VLAN_RANGES=$PHYSICAL_NETWORK | 
 | 70 |             if [[ "$TENANT_VLAN_RANGE" != "" ]]; then | 
 | 71 |                 ML2_VLAN_RANGES=$ML2_VLAN_RANGES:$TENANT_VLAN_RANGE | 
 | 72 |             fi | 
| Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 73 |         fi | 
| Kyle Mestery | b772659 | 2013-07-19 14:26:53 +0000 | [diff] [blame] | 74 |         if [[ "$ML2_VLAN_RANGES" != "" ]]; then | 
 | 75 |             Q_ML2_PLUGIN_VLAN_TYPE_OPTIONS=(network_vlan_ranges=$ML2_VLAN_RANGES) | 
 | 76 |         fi | 
| Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 77 |     fi | 
 | 78 |  | 
 | 79 |     # REVISIT(rkukura): Setting firewall_driver here for | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 80 |     # neutron.agent.securitygroups_rpc.is_firewall_enabled() which is | 
| Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 81 |     # used in the server, in case no L2 agent is configured on the | 
 | 82 |     # server's node. If an L2 agent is configured, this will get | 
 | 83 |     # overridden with the correct driver. The ml2 plugin should | 
 | 84 |     # instead use its own config variable to indicate whether security | 
 | 85 |     # groups is enabled, and that will need to be set here instead. | 
 | 86 |     if [[ "$Q_USE_SECGROUP" == "True" ]]; then | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 87 |         iniset /$Q_PLUGIN_CONF_FILE SECURITYGROUP firewall_driver neutron.agent.not.a.real.FirewallDriver | 
| Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 88 |     else | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 89 |         iniset /$Q_PLUGIN_CONF_FILE SECURITYGROUP firewall_driver neutron.agent.firewall.NoopFirewallDriver | 
| Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 90 |     fi | 
 | 91 |  | 
| Kyle Mestery | b772659 | 2013-07-19 14:26:53 +0000 | [diff] [blame] | 92 |     # Since we enable the tunnel TypeDrivers, also enable a local_ip | 
 | 93 |     iniset /$Q_PLUGIN_CONF_FILE ovs local_ip $HOST_IP | 
 | 94 |  | 
| Kyle Mestery | 3ea28ec | 2013-08-05 12:24:32 +0000 | [diff] [blame] | 95 |     populate_ml2_config mechanism_drivers=$Q_ML2_PLUGIN_MECHANISM_DRIVERS /$Q_PLUGIN_CONF_FILE ml2 | 
 | 96 |  | 
| Kyle Mestery | b772659 | 2013-07-19 14:26:53 +0000 | [diff] [blame] | 97 |     populate_ml2_config type_drivers=$Q_ML2_PLUGIN_TYPE_DRIVERS /$Q_PLUGIN_CONF_FILE ml2 | 
 | 98 |  | 
 | 99 |     populate_ml2_config $Q_SRV_EXTRA_OPTS /$Q_PLUGIN_CONF_FILE ml2 | 
 | 100 |  | 
 | 101 |     populate_ml2_config $Q_ML2_PLUGIN_GRE_TYPE_OPTIONS /$Q_PLUGIN_CONF_FILE ml2_type_gre | 
 | 102 |  | 
 | 103 |     populate_ml2_config $Q_ML2_PLUGIN_VXLAN_TYPE_OPTIONS /$Q_PLUGIN_CONF_FILE ml2_type_vxlan | 
 | 104 |  | 
 | 105 |     if [ "$Q_ML2_PLUGIN_VLAN_TYPE_OPTIONS" != "" ]; then | 
 | 106 |         populate_ml2_config $Q_ML2_PLUGIN_VLAN_TYPE_OPTIONS /$Q_PLUGIN_CONF_FILE ml2_type_vlan | 
 | 107 |     fi | 
| Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 108 | } | 
 | 109 |  | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 110 | function has_neutron_plugin_security_group() { | 
| Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 111 |     return 0 | 
 | 112 | } | 
 | 113 |  | 
 | 114 | # Restore xtrace | 
 | 115 | $MY_XTRACE |