This change condenses the directory structure to something more similar to what we had before while producing similar packages. It also introduces version.py which allows us to get the version from git tags (or a fallback version if not available). Fixes lp bug 889336 Fixes lp bug 888795 Change-Id: I86136bd9dbabb5eb1f8366ed665ed9b54f695124
196 lines
7.3 KiB
Python
196 lines
7.3 KiB
Python
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
|
#
|
|
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
#
|
|
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
|
# @author: Edgar Magana, Cisco Systems, Inc.
|
|
#
|
|
"""
|
|
PlugIn for Nexus OS driver
|
|
"""
|
|
import logging
|
|
|
|
from quantum.common import exceptions as exc
|
|
from quantum.common import utils
|
|
from quantum.plugins.cisco.common import cisco_constants as const
|
|
from quantum.plugins.cisco.common import cisco_credentials as cred
|
|
from quantum.plugins.cisco.db import api as db
|
|
from quantum.plugins.cisco.db import l2network_db as cdb
|
|
from quantum.plugins.cisco.db import nexus_db as nxos_db
|
|
from quantum.plugins.cisco.l2device_plugin_base import L2DevicePluginBase
|
|
from quantum.plugins.cisco.nexus import cisco_nexus_configuration as conf
|
|
|
|
LOG = logging.getLogger(__name__)
|
|
|
|
|
|
class NexusPlugin(L2DevicePluginBase):
|
|
"""
|
|
Nexus PLugIn Main Class
|
|
"""
|
|
_networks = {}
|
|
|
|
def __init__(self):
|
|
"""
|
|
Extracts the configuration parameters from the configuration file
|
|
"""
|
|
self._client = utils.import_object(conf.NEXUS_DRIVER)
|
|
LOG.debug("Loaded driver %s\n" % conf.NEXUS_DRIVER)
|
|
self._nexus_ip = conf.NEXUS_IP_ADDRESS
|
|
self._nexus_username = cred.Store.getUsername(conf.NEXUS_IP_ADDRESS)
|
|
self._nexus_password = cred.Store.getPassword(conf.NEXUS_IP_ADDRESS)
|
|
self._nexus_first_port = conf.NEXUS_FIRST_PORT
|
|
self._nexus_second_port = conf.NEXUS_SECOND_PORT
|
|
self._nexus_ssh_port = conf.NEXUS_SSH_PORT
|
|
|
|
def get_all_networks(self, tenant_id):
|
|
"""
|
|
Returns a dictionary containing all
|
|
<network_uuid, network_name> for
|
|
the specified tenant.
|
|
"""
|
|
LOG.debug("NexusPlugin:get_all_networks() called\n")
|
|
return self._networks.values()
|
|
|
|
def create_network(self, tenant_id, net_name, net_id, vlan_name, vlan_id,
|
|
**kwargs):
|
|
"""
|
|
Create a VLAN in the switch, and configure the appropriate interfaces
|
|
for this VLAN
|
|
"""
|
|
LOG.debug("NexusPlugin:create_network() called\n")
|
|
self._client.create_vlan(vlan_name, str(vlan_id), self._nexus_ip,
|
|
self._nexus_username, self._nexus_password,
|
|
self._nexus_first_port, self._nexus_second_port,
|
|
self._nexus_ssh_port)
|
|
nxos_db.add_nexusport_binding(self._nexus_first_port, str(vlan_id))
|
|
nxos_db.add_nexusport_binding(self._nexus_second_port, str(vlan_id))
|
|
|
|
new_net_dict = {const.NET_ID: net_id,
|
|
const.NET_NAME: net_name,
|
|
const.NET_PORTS: {},
|
|
const.NET_VLAN_NAME: vlan_name,
|
|
const.NET_VLAN_ID: vlan_id}
|
|
self._networks[net_id] = new_net_dict
|
|
return new_net_dict
|
|
|
|
def delete_network(self, tenant_id, net_id, **kwargs):
|
|
"""
|
|
Deletes a VLAN in the switch, and removes the VLAN configuration
|
|
from the relevant interfaces
|
|
"""
|
|
LOG.debug("NexusPlugin:delete_network() called\n")
|
|
vlan_id = self._get_vlan_id_for_network(tenant_id, net_id)
|
|
ports_id = nxos_db.get_nexusport_binding(vlan_id)
|
|
LOG.debug("NexusPlugin: Interfaces to be disassociated: %s" % ports_id)
|
|
nxos_db.remove_nexusport_binding(vlan_id)
|
|
net = self._get_network(tenant_id, net_id)
|
|
if net:
|
|
self._client.delete_vlan(str(vlan_id), self._nexus_ip,
|
|
self._nexus_username, self._nexus_password,
|
|
self._nexus_first_port, self._nexus_second_port,
|
|
self._nexus_ssh_port)
|
|
return net
|
|
# Network not found
|
|
raise exc.NetworkNotFound(net_id=net_id)
|
|
|
|
def get_network_details(self, tenant_id, net_id, **kwargs):
|
|
"""
|
|
Returns the details of a particular network
|
|
"""
|
|
LOG.debug("NexusPlugin:get_network_details() called\n")
|
|
network = self._get_network(tenant_id, net_id)
|
|
return network
|
|
|
|
def update_network(self, tenant_id, net_id, **kwargs):
|
|
"""
|
|
Updates the properties of a particular
|
|
Virtual Network.
|
|
"""
|
|
LOG.debug("NexusPlugin:update_network() called\n")
|
|
network = self._get_network(tenant_id, net_id)
|
|
network[const.NET_NAME] = kwargs["name"]
|
|
return network
|
|
|
|
def get_all_ports(self, tenant_id, net_id, **kwargs):
|
|
"""
|
|
This is probably not applicable to the Nexus plugin.
|
|
Delete if not required.
|
|
"""
|
|
LOG.debug("NexusPlugin:get_all_ports() called\n")
|
|
|
|
def create_port(self, tenant_id, net_id, port_state, port_id, **kwargs):
|
|
"""
|
|
This is probably not applicable to the Nexus plugin.
|
|
Delete if not required.
|
|
"""
|
|
LOG.debug("NexusPlugin:create_port() called\n")
|
|
|
|
def delete_port(self, tenant_id, net_id, port_id, **kwargs):
|
|
"""
|
|
This is probably not applicable to the Nexus plugin.
|
|
Delete if not required.
|
|
"""
|
|
LOG.debug("NexusPlugin:delete_port() called\n")
|
|
|
|
def update_port(self, tenant_id, net_id, port_id, port_state, **kwargs):
|
|
"""
|
|
This is probably not applicable to the Nexus plugin.
|
|
Delete if not required.
|
|
"""
|
|
LOG.debug("NexusPlugin:update_port() called\n")
|
|
|
|
def get_port_details(self, tenant_id, net_id, port_id, **kwargs):
|
|
"""
|
|
This is probably not applicable to the Nexus plugin.
|
|
Delete if not required.
|
|
"""
|
|
LOG.debug("NexusPlugin:get_port_details() called\n")
|
|
|
|
def plug_interface(self, tenant_id, net_id, port_id, remote_interface_id,
|
|
**kwargs):
|
|
"""
|
|
This is probably not applicable to the Nexus plugin.
|
|
Delete if not required.
|
|
"""
|
|
LOG.debug("NexusPlugin:plug_interface() called\n")
|
|
|
|
def unplug_interface(self, tenant_id, net_id, port_id, **kwargs):
|
|
"""
|
|
This is probably not applicable to the Nexus plugin.
|
|
Delete if not required.
|
|
"""
|
|
LOG.debug("NexusPlugin:unplug_interface() called\n")
|
|
|
|
def _get_vlan_id_for_network(self, tenant_id, network_id):
|
|
"""
|
|
Obtain the VLAN ID given the Network ID
|
|
"""
|
|
net = self._get_network(tenant_id, network_id)
|
|
vlan_id = net[const.NET_VLAN_ID]
|
|
return vlan_id
|
|
|
|
def _get_network(self, tenant_id, network_id):
|
|
"""
|
|
Gets the NETWORK ID
|
|
"""
|
|
network = db.network_get(network_id)
|
|
if not network:
|
|
raise exc.NetworkNotFound(net_id=network_id)
|
|
vlan = cdb.get_vlan_binding(network_id)
|
|
return {const.NET_ID: network_id, const.NET_NAME: network.name,
|
|
const.NET_PORTS: network.ports,
|
|
const.NET_VLAN_NAME: vlan.vlan_name,
|
|
const.NET_VLAN_ID: vlan.vlan_id}
|