TVD: l2gw support

Creating a wrapper driver for l2gw for hte TVD plugin
This driver choose the actual driver based on the project id.

Change-Id: I2edda8c780b7e14b36e3033108186ad63dd0449e
This commit is contained in:
Adit Sarfaty 2017-12-20 14:26:55 +02:00
parent 3a1a47a70b
commit 0a779b4389
4 changed files with 176 additions and 5 deletions

View File

@ -0,0 +1,157 @@
# Copyright 2015 VMware, 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.
from networking_l2gw.db.l2gateway import l2gateway_db
from neutron_lib import exceptions as n_exc
from neutron_lib.plugins import directory
from oslo_log import log as logging
from vmware_nsx.db import db as nsx_db
from vmware_nsx.extensions import projectpluginmap
from vmware_nsx.services.l2gateway.nsx_v import driver as v_driver
from vmware_nsx.services.l2gateway.nsx_v3 import driver as t_driver
LOG = logging.getLogger(__name__)
class NsxTvdL2GatewayDriver(l2gateway_db.L2GatewayMixin):
"""Class to handle API calls for L2 gateway and NSX-TVD plugin wrapper."""
def __init__(self, plugin):
super(NsxTvdL2GatewayDriver, self).__init__()
self._plugin = plugin
# supported drivers:
self.drivers = {}
try:
self.drivers[projectpluginmap.NsxPlugins.NSX_T] = (
t_driver.NsxV3Driver(plugin))
except Exception:
LOG.warning("NsxTvdL2GatewayDriver failed to initialize the NSX-T "
"driver")
self.drivers[projectpluginmap.NsxPlugins.NSX_T] = None
try:
self.drivers[projectpluginmap.NsxPlugins.NSX_V] = (
v_driver.NsxvL2GatewayDriver(plugin))
except Exception:
LOG.warning("NsxTvdL2GatewayDriver failed to initialize the NSX-V "
"driver")
self.drivers[projectpluginmap.NsxPlugins.NSX_V] = None
def _get_driver_for_project(self, context, project):
"""Get the l2gw driver by the plugin of the project"""
mapping = nsx_db.get_project_plugin_mapping(
context.session, project)
if mapping:
plugin_type = mapping['plugin']
else:
msg = _("Couldn't find the plugin project %s is using") % project
raise n_exc.InvalidInput(error_message=msg)
if plugin_type not in self.drivers:
msg = (_("Project %(project)s with plugin %(plugin)s has no "
"support for L2GW") % {'project': project,
'plugin': plugin_type})
raise n_exc.InvalidInput(error_message=msg)
# make sure the core plugin is supported
core_plugin = directory.get_plugin()
if not core_plugin.get_plugin_by_type(plugin_type):
msg = (_("Plugin %(plugin)s for project %(project)s is not "
"supported by the core plugin") % {'project': project,
'plugin': plugin_type})
raise n_exc.InvalidInput(error_message=msg)
return self.drivers[plugin_type]
def create_l2_gateway(self, context, l2_gateway):
d = self._get_driver_for_project(
context, l2_gateway['l2_gateway']['tenant_id'])
return d.create_l2_gateway(context, l2_gateway)
def create_l2_gateway_precommit(self, context, l2_gateway):
# Not implemented by any of the plugins
pass
def create_l2_gateway_postcommit(self, context, l2_gateway):
# Not implemented by any of the plugins
pass
def update_l2_gateway(self, context, l2_gateway):
# Not implemented by any of the plugins
pass
def update_l2_gateway_precommit(self, context, l2_gateway):
# Not implemented by any of the plugins
pass
def update_l2_gateway_postcommit(self, context, l2_gateway):
# Not implemented by any of the plugins
pass
def create_l2_gateway_connection(self, context, l2_gateway_connection):
d = self._get_driver_for_project(
context,
l2_gateway_connection['l2_gateway_connection']['tenant_id'])
return d.create_l2_gateway_connection(context, l2_gateway_connection)
def create_l2_gateway_connection_precommit(self, contex, gw_connection):
# Not implemented by any of the plugins
pass
def create_l2_gateway_connection_postcommit(self, context, gw_connection):
d = self._get_driver_for_project(context, gw_connection['tenant_id'])
return d.create_l2_gateway_connection_postcommit(
context, gw_connection)
def _get_gw_connection_driver(self, context, l2gw_connection_id):
l2gw_conn = self._plugin._get_l2_gateway_connection(
context, l2gw_connection_id)
return self._get_driver_for_project(context, l2gw_conn.tenant_id)
def delete_l2_gateway_connection(self, context, l2_gateway_connection_id):
d = self._get_gw_connection_driver(context, l2_gateway_connection_id)
return d.delete_l2_gateway_connection(
context, l2_gateway_connection_id)
def delete_l2_gateway_connection_precommit(self, context,
l2_gateway_connection):
# Not implemented by any of the plugins
pass
def delete_l2_gateway_connection_postcommit(self, context,
l2_gateway_connection_id):
# Not implemented by any of the plugins
#Note(asarfaty): in postcommit the l2_gateway_connection was already
# deleted so we cannot decide on the plugin by the project of the
# connection.
pass
def delete_l2_gateway(self, context, l2_gateway_id):
l2gw = self._plugin._get_l2_gateway(context, l2_gateway_id)
d = self._get_driver_for_project(
context, l2gw['tenant_id'])
return d.delete_l2_gateway(context, l2_gateway_id)
def delete_l2_gateway_precommit(self, context, l2_gateway):
# Not implemented by any of the plugins
pass
def delete_l2_gateway_postcommit(self, context, l2_gateway):
# Not implemented by any of the plugins
#Note(asarfaty): in postcommit the l2_gateway was already deleted
# so we cannot decide on the plugin by the project of the gw.
pass

View File

@ -28,6 +28,7 @@ from vmware_nsx.common import exceptions as nsx_exc
from vmware_nsx.common import nsxv_constants from vmware_nsx.common import nsxv_constants
from vmware_nsx.db import db as nsx_db from vmware_nsx.db import db as nsx_db
from vmware_nsx.db import nsxv_db from vmware_nsx.db import nsxv_db
from vmware_nsx.extensions import projectpluginmap
from vmware_nsx.plugins.nsx_v import availability_zones as nsx_az from vmware_nsx.plugins.nsx_v import availability_zones as nsx_az
from vmware_nsx.plugins.nsx_v.vshield.common import exceptions from vmware_nsx.plugins.nsx_v.vshield.common import exceptions
@ -41,10 +42,16 @@ class NsxvL2GatewayDriver(l2gateway_db.L2GatewayMixin):
def __init__(self, plugin): def __init__(self, plugin):
super(NsxvL2GatewayDriver, self).__init__() super(NsxvL2GatewayDriver, self).__init__()
self._plugin = plugin self._plugin = plugin
self.__core_plugin = None
@property @property
def _core_plugin(self): def _core_plugin(self):
return directory.get_plugin() if not self.__core_plugin:
self.__core_plugin = directory.get_plugin()
if self.__core_plugin.is_tvd_plugin():
self.__core_plugin = self.__core_plugin.get_plugin_by_type(
projectpluginmap.NsxPlugins.NSX_V)
return self.__core_plugin
@property @property
def _nsxv(self): def _nsxv(self):

View File

@ -36,6 +36,7 @@ from neutron_lib.plugins import directory
from vmware_nsx._i18n import _ from vmware_nsx._i18n import _
from vmware_nsx.common import utils as nsx_utils from vmware_nsx.common import utils as nsx_utils
from vmware_nsx.db import db as nsx_db from vmware_nsx.db import db as nsx_db
from vmware_nsx.extensions import projectpluginmap
from vmware_nsxlib.v3 import exceptions as nsxlib_exc from vmware_nsxlib.v3 import exceptions as nsxlib_exc
from vmware_nsxlib.v3 import nsx_constants from vmware_nsxlib.v3 import nsx_constants
@ -56,10 +57,16 @@ class NsxV3Driver(l2gateway_db.L2GatewayMixin):
self.subscribe_callback_notifications() self.subscribe_callback_notifications()
LOG.debug("Initialization complete for NSXv3 driver for " LOG.debug("Initialization complete for NSXv3 driver for "
"L2 gateway service plugin.") "L2 gateway service plugin.")
self.__core_plugin = None
@property @property
def _core_plugin(self): def _core_plugin(self):
return directory.get_plugin() if not self.__core_plugin:
self.__core_plugin = directory.get_plugin()
if self.__core_plugin.is_tvd_plugin():
self.__core_plugin = self.__core_plugin.get_plugin_by_type(
projectpluginmap.NsxPlugins.NSX_T)
return self.__core_plugin
def subscribe_callback_notifications(self): def subscribe_callback_notifications(self):
registry.subscribe(self._prevent_l2gw_port_delete, resources.PORT, registry.subscribe(self._prevent_l2gw_port_delete, resources.PORT,
@ -289,13 +296,13 @@ class NsxV3Driver(l2gateway_db.L2GatewayMixin):
gw_connection['id']) gw_connection['id'])
return gw_connection return gw_connection
def delete_l2_gateway_connection(self, context, gw_connection): def delete_l2_gateway_connection_postcommit(self, context, gw_connection):
pass pass
def delete_l2_gateway_connection_precommit(self, context, gw_connection): def delete_l2_gateway_connection_precommit(self, context, gw_connection):
pass pass
def delete_l2_gateway_connection_postcommit(self, context, gw_connection): def delete_l2_gateway_connection(self, context, gw_connection):
"""Delete a L2 gateway connection.""" """Delete a L2 gateway connection."""
conn_mapping = nsx_db.get_l2gw_connection_mapping( conn_mapping = nsx_db.get_l2gw_connection_mapping(
session=context.session, session=context.session,
@ -312,7 +319,7 @@ class NsxV3Driver(l2gateway_db.L2GatewayMixin):
"backend due to exc: %(exc)s", "backend due to exc: %(exc)s",
{'id': bridge_endpoint_id, 'exc': e}) {'id': bridge_endpoint_id, 'exc': e})
raise l2gw_exc.L2GatewayServiceDriverError( raise l2gw_exc.L2GatewayServiceDriverError(
method='delete_l2_gateway_connection_postcommit') method='delete_l2_gateway_connection')
def prevent_l2gw_port_deletion(self, context, port_id): def prevent_l2gw_port_deletion(self, context, port_id):
"""Prevent core plugin from deleting L2 gateway port.""" """Prevent core plugin from deleting L2 gateway port."""