8d7c0d548d
The usage doc stated that plug and unplug accept a single argument of type `os_vif.objects.VIF`, which isn't a thing, and then went on to give an example showing that they take two. The usage doc and the plug and unplug docstrings also listed various objects at the wrong paths (e.g. the `instance_info` param being of type `os_vif.objects.InstanceInfo`, which also isn't a thing). Fixed up the usage doc to list both arguments and correct the references in the sample code; and fixed the plug/unplug docstrings to list the proper paths to classes: os_vif.objects.vif.VIFBase and os_vif.objects.instance_info.InstanceInfo. Made everything in `single backticks` into a proper rst ``literal``. Change-Id: I400838bbe9663917fe2c64f52975b77a370405b4
148 lines
5.4 KiB
Python
148 lines
5.4 KiB
Python
# 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 oslo_log import log as logging
|
|
from stevedore import extension
|
|
|
|
import os_vif.exception
|
|
import os_vif.i18n
|
|
import os_vif.objects
|
|
|
|
_EXT_MANAGER = None
|
|
LOG = logging.getLogger(__name__)
|
|
|
|
|
|
def initialize(reset=False):
|
|
"""
|
|
Loads all os_vif plugins and initializes them with a dictionary of
|
|
configuration options. These configuration options are passed as-is
|
|
to the individual VIF plugins that are loaded via stevedore.
|
|
|
|
:param reset: Recreate and load the VIF plugin extensions.
|
|
|
|
"""
|
|
global _EXT_MANAGER
|
|
if _EXT_MANAGER is None:
|
|
os_vif.objects.register_all()
|
|
|
|
if reset or (_EXT_MANAGER is None):
|
|
_EXT_MANAGER = extension.ExtensionManager(namespace='os_vif',
|
|
invoke_on_load=False)
|
|
loaded_plugins = []
|
|
for plugin_name in _EXT_MANAGER.names():
|
|
cls = _EXT_MANAGER[plugin_name].plugin
|
|
obj = cls.load(plugin_name)
|
|
LOG.debug(("Loaded VIF plugin class '%(cls)s' "
|
|
"with name '%(plugin_name)s'"),
|
|
{'cls': cls, 'plugin_name': plugin_name})
|
|
loaded_plugins.append(plugin_name)
|
|
_EXT_MANAGER[plugin_name].obj = obj
|
|
LOG.info("Loaded VIF plugins: %s", ", ".join(loaded_plugins))
|
|
|
|
|
|
def plug(vif, instance_info):
|
|
"""
|
|
Given a model of a VIF, perform operations to plug the VIF properly.
|
|
|
|
:param vif: Instance of a subclass of ``os_vif.objects.vif.VIFBase``.
|
|
:param instance_info: ``os_vif.objects.instance_info.InstanceInfo`` object.
|
|
:raises ``exception.LibraryNotInitialized`` if the user of the library
|
|
did not call ``os_vif.initialize(**config)`` before trying to
|
|
plug a VIF.
|
|
:raises ``exception.NoMatchingPlugin`` if there is no plugin for the
|
|
type of VIF supplied.
|
|
:raises ``exception.PlugException`` if anything fails during unplug
|
|
operations.
|
|
"""
|
|
if _EXT_MANAGER is None:
|
|
raise os_vif.exception.LibraryNotInitialized()
|
|
|
|
plugin_name = vif.plugin
|
|
try:
|
|
plugin = _EXT_MANAGER[plugin_name].obj
|
|
except KeyError:
|
|
raise os_vif.exception.NoMatchingPlugin(plugin_name=plugin_name)
|
|
|
|
try:
|
|
LOG.debug("Plugging vif %s", vif)
|
|
plugin.plug(vif, instance_info)
|
|
LOG.info("Successfully plugged vif %s", vif)
|
|
except Exception as err:
|
|
LOG.error("Failed to plug vif %(vif)s",
|
|
{"vif": vif}, exc_info=True)
|
|
raise os_vif.exception.PlugException(vif=vif, err=err)
|
|
|
|
|
|
def unplug(vif, instance_info):
|
|
"""
|
|
Given a model of a VIF, perform operations to unplug the VIF properly.
|
|
|
|
:param vif: Instance of a subclass of `os_vif.objects.vif.VIFBase`.
|
|
:param instance_info: `os_vif.objects.instance_info.InstanceInfo` object.
|
|
:raises `exception.LibraryNotInitialized` if the user of the library
|
|
did not call os_vif.initialize(**config) before trying to
|
|
plug a VIF.
|
|
:raises `exception.NoMatchingPlugin` if there is no plugin for the
|
|
type of VIF supplied.
|
|
:raises `exception.UnplugException` if anything fails during unplug
|
|
operations.
|
|
"""
|
|
if _EXT_MANAGER is None:
|
|
raise os_vif.exception.LibraryNotInitialized()
|
|
|
|
plugin_name = vif.plugin
|
|
try:
|
|
plugin = _EXT_MANAGER[plugin_name].obj
|
|
except KeyError:
|
|
raise os_vif.exception.NoMatchingPlugin(plugin_name=plugin_name)
|
|
|
|
try:
|
|
LOG.debug("Unplugging vif %s", vif)
|
|
plugin.unplug(vif, instance_info)
|
|
LOG.info("Successfully unplugged vif %s", vif)
|
|
except Exception as err:
|
|
LOG.error("Failed to unplug vif %(vif)s",
|
|
{"vif": vif}, exc_info=True)
|
|
raise os_vif.exception.UnplugException(vif=vif, err=err)
|
|
|
|
|
|
def host_info(permitted_vif_type_names=None):
|
|
"""
|
|
:param permitted_vif_type_names: list of VIF object names
|
|
|
|
Get information about the host platform configuration to be
|
|
provided to the network manager. This will include information
|
|
about what plugins are installed in the host
|
|
|
|
If permitted_vif_type_names is not None, the returned HostInfo
|
|
will be filtered such that it only includes plugins which
|
|
support one of the listed VIF types. This allows the caller
|
|
to filter out impls which are not compatible with the current
|
|
usage configuration. For example, to remove VIFVHostUser if
|
|
the guest does not support shared memory.
|
|
|
|
:returns: a os_vif.host_info.HostInfo class instance
|
|
"""
|
|
|
|
if _EXT_MANAGER is None:
|
|
raise os_vif.exception.LibraryNotInitialized()
|
|
|
|
plugins = [
|
|
_EXT_MANAGER[name].obj.describe()
|
|
for name in sorted(_EXT_MANAGER.names())
|
|
]
|
|
|
|
info = os_vif.objects.host_info.HostInfo(plugin_info=plugins)
|
|
if permitted_vif_type_names is not None:
|
|
info.filter_vif_types(permitted_vif_type_names)
|
|
return info
|