
keystoneauth1 is the new auth-only library for getting keystone Sessions, which is lighter-weight and does not require the entire keystoneclient library. It also handles all of the keystone version discover and plugin selection so that code doesn't have to live in neutronclient. Additionally, use os-client-config to process options and get the Session from keystoneauth1. This adds support for reading clouds.yaml files and supporting the OS_CLOUD env var for selecting named clouds from a list of them. This is a step towards bug#1503428 but is not the whole picture. Remove the auth tests - since they are covered inside of ksa. Closes-Bug: #1507384 Change-Id: Ic4f9fd8f231c33513fd74da58ab1b4a3fb00d9f4
120 lines
4.0 KiB
Python
120 lines
4.0 KiB
Python
# Copyright 2012 OpenStack Foundation.
|
|
# 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.
|
|
#
|
|
|
|
"""Manage access to the clients, including authenticating when needed.
|
|
"""
|
|
|
|
import logging
|
|
|
|
from neutronclient import client
|
|
from neutronclient.neutron import client as neutron_client
|
|
|
|
|
|
LOG = logging.getLogger(__name__)
|
|
|
|
|
|
class ClientCache(object):
|
|
"""Descriptor class for caching created client handles."""
|
|
|
|
def __init__(self, factory):
|
|
self.factory = factory
|
|
self._handle = None
|
|
|
|
def __get__(self, instance, owner):
|
|
# Tell the ClientManager to login to keystone
|
|
if self._handle is None:
|
|
self._handle = self.factory(instance)
|
|
return self._handle
|
|
|
|
|
|
class ClientManager(object):
|
|
"""Manages access to API clients, including authentication."""
|
|
neutron = ClientCache(neutron_client.make_client)
|
|
# Provide support for old quantum commands (for example
|
|
# in stable versions)
|
|
quantum = neutron
|
|
|
|
def __init__(self, token=None, url=None,
|
|
auth_url=None,
|
|
endpoint_type=None,
|
|
tenant_name=None,
|
|
tenant_id=None,
|
|
username=None,
|
|
user_id=None,
|
|
password=None,
|
|
region_name=None,
|
|
api_version=None,
|
|
auth_strategy=None,
|
|
insecure=False,
|
|
ca_cert=None,
|
|
log_credentials=False,
|
|
service_type=None,
|
|
service_name=None,
|
|
timeout=None,
|
|
retries=0,
|
|
raise_errors=True,
|
|
session=None,
|
|
auth=None,
|
|
):
|
|
self._token = token
|
|
self._url = url
|
|
self._auth_url = auth_url
|
|
self._service_type = service_type
|
|
self._service_name = service_name
|
|
self._endpoint_type = endpoint_type
|
|
self._tenant_name = tenant_name
|
|
self._tenant_id = tenant_id
|
|
self._username = username
|
|
self._user_id = user_id
|
|
self._password = password
|
|
self._region_name = region_name
|
|
self._api_version = api_version
|
|
self._service_catalog = None
|
|
self._auth_strategy = auth_strategy
|
|
self._insecure = insecure
|
|
self._ca_cert = ca_cert
|
|
self._log_credentials = log_credentials
|
|
self._timeout = timeout
|
|
self._retries = retries
|
|
self._raise_errors = raise_errors
|
|
self._session = session
|
|
self._auth = auth
|
|
return
|
|
|
|
def initialize(self):
|
|
if not self._url:
|
|
httpclient = client.construct_http_client(
|
|
username=self._username,
|
|
user_id=self._user_id,
|
|
tenant_name=self._tenant_name,
|
|
tenant_id=self._tenant_id,
|
|
password=self._password,
|
|
region_name=self._region_name,
|
|
auth_url=self._auth_url,
|
|
service_type=self._service_type,
|
|
service_name=self._service_name,
|
|
endpoint_type=self._endpoint_type,
|
|
insecure=self._insecure,
|
|
ca_cert=self._ca_cert,
|
|
timeout=self._timeout,
|
|
session=self._session,
|
|
auth=self._auth,
|
|
log_credentials=self._log_credentials)
|
|
httpclient.authenticate()
|
|
# Populate other password flow attributes
|
|
self._token = httpclient.auth_token
|
|
self._url = httpclient.endpoint_url
|