Remove ClientManager._service_catalog
Anything that needs a service catalog can get it directly from auth_ref.service_catalog, no need to carry the extra attribute. ClientManager.get_endpoint_for_service_type() reamins the proper method to get an endpoint for clients that still need one directly. Change-Id: I809091c9c71d08f29606d7fd8b500898ff2cb8ae
This commit is contained in:
parent
0de67016c7
commit
2166d7d3af
@ -66,7 +66,6 @@ class ClientManager(object):
|
||||
self._auth_params = auth.build_auth_params(auth_options)
|
||||
self._region_name = auth_options.os_region_name
|
||||
self._api_version = api_version
|
||||
self._service_catalog = None
|
||||
self.timing = auth_options.timing
|
||||
|
||||
# For compatibility until all clients can be updated
|
||||
@ -104,7 +103,6 @@ class ClientManager(object):
|
||||
if 'token' not in self._auth_params:
|
||||
LOG.debug("Get service catalog")
|
||||
self.auth_ref = self.auth.get_auth_ref(self.session)
|
||||
self._service_catalog = self.auth_ref.service_catalog
|
||||
|
||||
return
|
||||
|
||||
@ -112,12 +110,14 @@ class ClientManager(object):
|
||||
"""Return the endpoint URL for the service type."""
|
||||
# See if we are using password flow auth, i.e. we have a
|
||||
# service catalog to select endpoints from
|
||||
if self._service_catalog:
|
||||
endpoint = self._service_catalog.url_for(
|
||||
service_type=service_type, region_name=region_name)
|
||||
if self.auth_ref:
|
||||
endpoint = self.auth_ref.service_catalog.url_for(
|
||||
service_type=service_type,
|
||||
region_name=region_name,
|
||||
)
|
||||
else:
|
||||
# Hope we were given the correct URL.
|
||||
endpoint = self._auth_url or self._url
|
||||
# Get the passed endpoint directly from the auth plugin
|
||||
endpoint = self.auth.get_endpoint(self.session)
|
||||
return endpoint
|
||||
|
||||
|
||||
|
@ -44,27 +44,11 @@ def make_client(instance):
|
||||
API_VERSIONS)
|
||||
LOG.debug('Instantiating identity client: %s', identity_client)
|
||||
|
||||
# TODO(dtroyer): Something doesn't like the session.auth when using
|
||||
# token auth, chase that down.
|
||||
if instance._url:
|
||||
LOG.debug('Using service token auth')
|
||||
client = identity_client(
|
||||
endpoint=instance._url,
|
||||
token=instance._auth_params['token'],
|
||||
cacert=instance._cacert,
|
||||
insecure=instance._insecure
|
||||
)
|
||||
else:
|
||||
LOG.debug('Using auth plugin: %s' % instance._auth_plugin)
|
||||
client = identity_client(
|
||||
session=instance.session,
|
||||
cacert=instance._cacert,
|
||||
)
|
||||
|
||||
# TODO(dtroyer): the identity v2 role commands use this yet, fix that
|
||||
# so we can remove it
|
||||
if not instance._url:
|
||||
instance.auth_ref = instance.auth.get_auth_ref(instance.session)
|
||||
return client
|
||||
|
||||
|
||||
|
@ -141,9 +141,10 @@ class ShowService(show.ShowOne):
|
||||
def take_action(self, parsed_args):
|
||||
self.log.debug('take_action(%s)', parsed_args)
|
||||
identity_client = self.app.client_manager.identity
|
||||
auth_ref = self.app.client_manager.auth_ref
|
||||
|
||||
if parsed_args.catalog:
|
||||
endpoints = identity_client.service_catalog.get_endpoints(
|
||||
endpoints = auth_ref.service_catalog.get_endpoints(
|
||||
service_type=parsed_args.service)
|
||||
for (service, service_endpoints) in six.iteritems(endpoints):
|
||||
if service_endpoints:
|
||||
|
@ -40,11 +40,13 @@ def make_client(instance):
|
||||
API_VERSIONS)
|
||||
LOG.debug('Instantiating image client: %s', image_client)
|
||||
|
||||
if not instance._url:
|
||||
instance._url = instance.get_endpoint_for_service_type(API_NAME)
|
||||
endpoint = instance.get_endpoint_for_service_type(
|
||||
API_NAME,
|
||||
region_name=instance._region_name,
|
||||
)
|
||||
|
||||
return image_client(
|
||||
instance._url,
|
||||
endpoint,
|
||||
token=instance.auth.get_token(instance.session),
|
||||
cacert=instance._cacert,
|
||||
insecure=instance._insecure,
|
||||
|
@ -34,16 +34,18 @@ def make_client(instance):
|
||||
API_VERSIONS)
|
||||
LOG.debug('Instantiating network client: %s', network_client)
|
||||
|
||||
if not instance._url:
|
||||
instance._url = instance.get_endpoint_for_service_type(
|
||||
"network", region_name=instance._region_name)
|
||||
endpoint = instance.get_endpoint_for_service_type(
|
||||
API_NAME,
|
||||
region_name=instance._region_name,
|
||||
)
|
||||
|
||||
return network_client(
|
||||
username=instance._username,
|
||||
tenant_name=instance._project_name,
|
||||
password=instance._password,
|
||||
region_name=instance._region_name,
|
||||
auth_url=instance._auth_url,
|
||||
endpoint_url=instance._url,
|
||||
endpoint_url=endpoint,
|
||||
token=instance.auth.get_token(instance.session),
|
||||
insecure=instance._insecure,
|
||||
ca_cert=instance._cacert,
|
||||
|
@ -33,10 +33,10 @@ API_VERSIONS = {
|
||||
def make_client(instance):
|
||||
"""Returns an object-store API client."""
|
||||
|
||||
if instance._url:
|
||||
endpoint = instance._url
|
||||
else:
|
||||
endpoint = instance.get_endpoint_for_service_type("object-store")
|
||||
endpoint = instance.get_endpoint_for_service_type(
|
||||
'object-store',
|
||||
region_name=instance._region_name,
|
||||
)
|
||||
|
||||
client = object_store_v1.APIv1(
|
||||
session=instance.session,
|
||||
|
@ -157,7 +157,7 @@ class TestClientManager(utils.TestCase):
|
||||
)
|
||||
self.assertEqual(
|
||||
dir(SERVICE_CATALOG),
|
||||
dir(client_manager._service_catalog),
|
||||
dir(client_manager.auth_ref.service_catalog),
|
||||
)
|
||||
|
||||
def stub_auth(self, json=None, url=None, verb=None, **kwargs):
|
||||
|
Loading…
Reference in New Issue
Block a user