Move clientmanager to osc_lib

Remove unneeded plugin bits and fix imports

Change-Id: I0f5b17b30437b99869d22ea2ef9c6432efaeb628
This commit is contained in:
Dean Troyer 2016-05-10 14:57:04 -05:00
parent 742c28d9fa
commit 30f6d2add8
4 changed files with 9 additions and 59 deletions

View File

@ -17,23 +17,22 @@
import copy import copy
import logging import logging
import pkg_resources
import sys import sys
from openstackclient.api import auth
from oslo_utils import strutils from oslo_utils import strutils
import requests import requests
import six import six
from openstackclient.api import auth from osc_lib import exceptions
from openstackclient.common import exceptions from osc_lib import session as osc_session
from openstackclient.common import session as osc_session
LOG = logging.getLogger(__name__) LOG = logging.getLogger(__name__)
PLUGIN_MODULES = [] PLUGIN_MODULES = []
USER_AGENT = 'python-openstackclient' USER_AGENT = 'osc-lib'
class ClientCache(object): class ClientCache(object):
@ -59,9 +58,6 @@ class ClientCache(object):
class ClientManager(object): class ClientManager(object):
"""Manages access to API clients, including authentication.""" """Manages access to API clients, including authentication."""
# A simple incrementing version for the plugin to know what is available
PLUGIN_INTERFACE_VERSION = "2"
def __getattr__(self, name): def __getattr__(self, name):
# this is for the auth-related parameters. # this is for the auth-related parameters.
if name in ['_' + o.replace('-', '_') if name in ['_' + o.replace('-', '_')
@ -276,48 +272,3 @@ class ClientManager(object):
def get_configuration(self): def get_configuration(self):
return copy.deepcopy(self._cli_options.config) return copy.deepcopy(self._cli_options.config)
# Plugin Support
def get_plugin_modules(group):
"""Find plugin entry points"""
mod_list = []
for ep in pkg_resources.iter_entry_points(group):
LOG.debug('Found plugin %r', ep.name)
__import__(ep.module_name)
module = sys.modules[ep.module_name]
mod_list.append(module)
init_func = getattr(module, 'Initialize', None)
if init_func:
init_func('x')
# Add the plugin to the ClientManager
setattr(
ClientManager,
module.API_NAME,
ClientCache(
getattr(sys.modules[ep.module_name], 'make_client', None)
),
)
return mod_list
def build_plugin_option_parser(parser):
"""Add plugin options to the parser"""
# Loop through extensions to get parser additions
for mod in PLUGIN_MODULES:
parser = mod.build_option_parser(parser)
return parser
# # Get list of base plugin modules
# PLUGIN_MODULES = get_plugin_modules(
# 'openstack.cli.base',
# )
# # Append list of external plugin modules
# PLUGIN_MODULES.extend(get_plugin_modules(
# 'openstack.cli.extension',
# ))

View File

@ -15,17 +15,16 @@
import json as jsonutils import json as jsonutils
import mock import mock
from requests_mock.contrib import fixture
from keystoneclient.auth.identity import v2 as auth_v2 from keystoneclient.auth.identity import v2 as auth_v2
from keystoneclient import service_catalog from keystoneclient import service_catalog
from openstackclient.api import auth from openstackclient.api import auth
from openstackclient.common import clientmanager from requests_mock.contrib import fixture
from openstackclient.common import exceptions as exc
from openstackclient.tests import fakes
from openstackclient.tests import utils
from osc_lib import clientmanager
from osc_lib import exceptions as exc
from osc_lib.tests import fakes
from osc_lib.tests import utils
API_VERSION = {"identity": "2.0"} API_VERSION = {"identity": "2.0"}