| Mohammad Banikazemi | 729236c | 2014-02-05 14:45:04 -0500 | [diff] [blame] | 1 | # Neutron IBM SDN-VE plugin | 
 | 2 | # --------------------------- | 
 | 3 |  | 
 | 4 | # Save trace setting | 
| Dean Troyer | e3a9160 | 2014-03-28 12:40:56 -0500 | [diff] [blame] | 5 | IBM_XTRACE=$(set +o | grep xtrace) | 
| Mohammad Banikazemi | 729236c | 2014-02-05 14:45:04 -0500 | [diff] [blame] | 6 | set +o xtrace | 
 | 7 |  | 
 | 8 | source $TOP_DIR/lib/neutron_plugins/ovs_base | 
 | 9 |  | 
 | 10 | function neutron_plugin_install_agent_packages { | 
 | 11 |     _neutron_ovs_base_install_agent_packages | 
 | 12 | } | 
 | 13 |  | 
 | 14 | function _neutron_interface_setup { | 
 | 15 |     # Setup one interface on the integration bridge if needed | 
 | 16 |     # The plugin agent to be used if more than one interface is used | 
 | 17 |     local bridge=$1 | 
 | 18 |     local interface=$2 | 
 | 19 |     sudo ovs-vsctl --no-wait -- --may-exist add-port $bridge $interface | 
 | 20 | } | 
 | 21 |  | 
 | 22 | function neutron_setup_integration_bridge { | 
 | 23 |     # Setup integration bridge if needed | 
 | 24 |     if [[ "$SDNVE_INTEGRATION_BRIDGE" != "" ]]; then | 
 | 25 |         neutron_ovs_base_cleanup | 
 | 26 |         _neutron_ovs_base_setup_bridge $SDNVE_INTEGRATION_BRIDGE | 
 | 27 |         if [[ "$SDNVE_INTERFACE_MAPPINGS" != "" ]]; then | 
 | 28 |             interfaces=(${SDNVE_INTERFACE_MAPPINGS//[,:]/ }) | 
 | 29 |             _neutron_interface_setup $SDNVE_INTEGRATION_BRIDGE ${interfaces[1]} | 
 | 30 |         fi | 
 | 31 |     fi | 
 | 32 |  | 
 | 33 |     # Set controller to SDNVE controller (1st of list) if exists | 
 | 34 |     if [[ "$SDNVE_CONTROLLER_IPS" != "" ]]; then | 
 | 35 |         # Get the first controller | 
 | 36 |         controllers=(${SDNVE_CONTROLLER_IPS//[\[,\]]/ }) | 
 | 37 |         SDNVE_IP=${controllers[0]} | 
 | 38 |         sudo ovs-vsctl set-controller $SDNVE_INTEGRATION_BRIDGE tcp:$SDNVE_IP | 
 | 39 |     fi | 
 | 40 | } | 
 | 41 |  | 
 | 42 | function neutron_plugin_create_nova_conf { | 
 | 43 |     NOVA_VIF_DRIVER=${NOVA_VIF_DRIVER:-"nova.virt.libvirt.vif.LibvirtGenericVIFDriver"} | 
 | 44 |     # if n-cpu is enabled, then setup integration bridge | 
 | 45 |     if is_service_enabled n-cpu; then | 
 | 46 |         neutron_setup_integration_bridge | 
 | 47 |     fi | 
 | 48 | } | 
 | 49 |  | 
 | 50 | function is_neutron_ovs_base_plugin { | 
 | 51 |     if [[ "$SDNVE_INTEGRATION_BRIDGE" != "" ]]; then | 
 | 52 |         # Yes, we use OVS. | 
 | 53 |         return 0 | 
 | 54 |     else | 
 | 55 |         # No, we do not use OVS. | 
 | 56 |         return 1 | 
 | 57 |     fi | 
 | 58 | } | 
 | 59 |  | 
 | 60 | function neutron_plugin_configure_common { | 
 | 61 |     Q_PLUGIN_CONF_PATH=etc/neutron/plugins/ibm | 
 | 62 |     Q_PLUGIN_CONF_FILENAME=sdnve_neutron_plugin.ini | 
 | 63 |     Q_DB_NAME="sdnve_neutron" | 
 | 64 |     Q_PLUGIN_CLASS="neutron.plugins.ibm.sdnve_neutron_plugin.SdnvePluginV2" | 
 | 65 | } | 
 | 66 |  | 
 | 67 | function neutron_plugin_configure_service { | 
 | 68 |     # Define extra "SDNVE" configuration options when q-svc is configured | 
 | 69 |  | 
 | 70 |     iniset /$Q_PLUGIN_CONF_FILE securitygroup firewall_driver neutron.agent.firewall.NoopFirewallDriver | 
 | 71 |  | 
 | 72 |     if [[ "$SDNVE_CONTROLLER_IPS" != "" ]]; then | 
 | 73 |         iniset /$Q_PLUGIN_CONF_FILE sdnve controller_ips $SDNVE_CONTROLLER_IPS | 
 | 74 |     fi | 
 | 75 |  | 
 | 76 |     if [[ "$SDNVE_INTEGRATION_BRIDGE" != "" ]]; then | 
 | 77 |         iniset /$Q_PLUGIN_CONF_FILE sdnve integration_bridge $SDNVE_INTEGRATION_BRIDGE | 
 | 78 |     fi | 
 | 79 |  | 
 | 80 |     if [[ "$SDNVE_RESET_BRIDGE" != "" ]]; then | 
 | 81 |         iniset /$Q_PLUGIN_CONF_FILE sdnve reset_bridge $SDNVE_RESET_BRIDGE | 
 | 82 |     fi | 
 | 83 |  | 
 | 84 |     if [[ "$SDNVE_OUT_OF_BAND" != "" ]]; then | 
 | 85 |         iniset /$Q_PLUGIN_CONF_FILE sdnve out_of_band $SDNVE_OUT_OF_BAND | 
 | 86 |     fi | 
 | 87 |  | 
 | 88 |     if [[ "$SDNVE_INTERFACE_MAPPINGS" != "" ]]; then | 
 | 89 |         iniset /$Q_PLUGIN_CONF_FILE sdnve interface_mappings $SDNVE_INTERFACE_MAPPINGS | 
 | 90 |     fi | 
 | 91 |  | 
 | 92 |     if [[ "$SDNVE_FAKE_CONTROLLER" != "" ]]; then | 
 | 93 |         iniset /$Q_PLUGIN_CONF_FILE sdnve use_fake_controller $SDNVE_FAKE_CONTROLLER | 
 | 94 |     fi | 
 | 95 |  | 
 | 96 |  | 
 | 97 |     iniset $NEUTRON_CONF DEFAULT notification_driver neutron.openstack.common.notifier.no_op_notifier | 
 | 98 |  | 
 | 99 | } | 
 | 100 |  | 
 | 101 | function neutron_plugin_configure_plugin_agent { | 
 | 102 |     AGENT_BINARY="$NEUTRON_BIN_DIR/neutron-ibm-agent" | 
 | 103 | } | 
 | 104 |  | 
 | 105 | function neutron_plugin_configure_debug_command { | 
 | 106 |     : | 
 | 107 | } | 
 | 108 |  | 
 | 109 | function neutron_plugin_setup_interface_driver { | 
 | 110 |     return 0 | 
 | 111 | } | 
 | 112 |  | 
 | 113 | function has_neutron_plugin_security_group { | 
 | 114 |     # Does not support Security Groups | 
 | 115 |     return 1 | 
 | 116 | } | 
 | 117 |  | 
 | 118 | function neutron_ovs_base_cleanup { | 
 | 119 |     if [[ "$SDNVE_RESET_BRIDGE" != False ]]; then | 
 | 120 |         # remove all OVS ports that look like Neutron created ports | 
 | 121 |         for port in $(sudo ovs-vsctl list port | grep -o -e tap[0-9a-f\-]* -e q[rg]-[0-9a-f\-]*); do | 
 | 122 |             sudo ovs-vsctl del-port ${port} | 
 | 123 |         done | 
 | 124 |  | 
 | 125 |         # remove integration bridge created by Neutron | 
 | 126 |         for bridge in $(sudo ovs-vsctl list-br | grep -o -e ${SDNVE_INTEGRATION_BRIDGE}); do | 
 | 127 |             sudo ovs-vsctl del-br ${bridge} | 
 | 128 |         done | 
 | 129 |     fi | 
 | 130 | } | 
 | 131 |  | 
 | 132 | # Restore xtrace | 
| Dean Troyer | e3a9160 | 2014-03-28 12:40:56 -0500 | [diff] [blame] | 133 | $IBM_XTRACE |