2013-08-27 16:57:30 -05:00
|
|
|
# Copyright 2012-2013 OpenStack Foundation
|
2012-05-10 14:58:16 -05:00
|
|
|
#
|
2013-01-24 12:00:30 -06:00
|
|
|
# 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
|
2012-05-10 14:58:16 -05:00
|
|
|
#
|
2013-01-24 12:00:30 -06:00
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
2012-05-10 14:58:16 -05:00
|
|
|
#
|
2013-01-24 12:00:30 -06:00
|
|
|
# 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.
|
2012-05-10 14:58:16 -05:00
|
|
|
#
|
|
|
|
|
2012-05-04 12:28:35 -05:00
|
|
|
import logging
|
|
|
|
|
2013-07-12 15:49:03 -05:00
|
|
|
from keystoneclient.v2_0 import client as identity_client_v2_0
|
2012-05-10 15:47:59 -05:00
|
|
|
from openstackclient.common import utils
|
2012-05-04 12:28:35 -05:00
|
|
|
|
2013-01-31 13:31:41 -06:00
|
|
|
|
2012-05-04 12:28:35 -05:00
|
|
|
LOG = logging.getLogger(__name__)
|
|
|
|
|
2013-11-20 18:02:09 -06:00
|
|
|
DEFAULT_IDENTITY_API_VERSION = '2.0'
|
|
|
|
API_VERSION_OPTION = 'os_identity_api_version'
|
2012-05-10 16:25:31 -05:00
|
|
|
API_NAME = 'identity'
|
2012-05-10 15:47:59 -05:00
|
|
|
API_VERSIONS = {
|
2013-07-12 15:49:03 -05:00
|
|
|
'2.0': 'openstackclient.identity.client.IdentityClientv2_0',
|
2013-01-17 22:11:05 -05:00
|
|
|
'3': 'keystoneclient.v3.client.Client',
|
2012-05-10 15:47:59 -05:00
|
|
|
}
|
|
|
|
|
2014-08-22 17:26:07 -05:00
|
|
|
# Translate our API version to auth plugin version prefix
|
|
|
|
AUTH_VERSIONS = {
|
|
|
|
'2.0': 'v2',
|
|
|
|
'3': 'v3',
|
|
|
|
}
|
|
|
|
|
2012-05-10 15:47:59 -05:00
|
|
|
|
2012-05-04 12:28:35 -05:00
|
|
|
def make_client(instance):
|
2013-01-31 13:31:41 -06:00
|
|
|
"""Returns an identity service client."""
|
2012-05-10 16:25:31 -05:00
|
|
|
identity_client = utils.get_client_class(
|
|
|
|
API_NAME,
|
|
|
|
instance._api_version[API_NAME],
|
2013-01-31 13:31:41 -06:00
|
|
|
API_VERSIONS)
|
2014-07-08 01:44:55 -05:00
|
|
|
LOG.debug('Instantiating identity client: %s', identity_client)
|
2014-07-08 01:44:55 -05:00
|
|
|
|
2014-08-22 17:26:07 -05:00
|
|
|
# TODO(dtroyer): Something doesn't like the session.auth when using
|
|
|
|
# token auth, chase that down.
|
2012-05-09 17:15:43 -05:00
|
|
|
if instance._url:
|
2014-07-08 01:44:55 -05:00
|
|
|
LOG.debug('Using token auth')
|
2012-05-10 15:47:59 -05:00
|
|
|
client = identity_client(
|
2012-05-09 17:15:43 -05:00
|
|
|
endpoint=instance._url,
|
2014-02-26 13:26:45 +10:00
|
|
|
token=instance._token,
|
|
|
|
cacert=instance._cacert,
|
|
|
|
insecure=instance._insecure,
|
2014-06-30 19:12:27 +02:00
|
|
|
trust_id=instance._trust_id,
|
2014-02-26 13:26:45 +10:00
|
|
|
)
|
2012-05-09 17:15:43 -05:00
|
|
|
else:
|
2014-07-08 01:44:55 -05:00
|
|
|
LOG.debug('Using password auth')
|
2012-05-10 15:47:59 -05:00
|
|
|
client = identity_client(
|
2014-08-22 17:26:07 -05:00
|
|
|
session=instance.session,
|
2013-10-07 12:23:00 -05:00
|
|
|
cacert=instance._cacert,
|
|
|
|
)
|
2014-08-08 17:38:44 -05:00
|
|
|
|
2014-08-22 17:26:07 -05:00
|
|
|
# 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)
|
2014-08-08 17:38:44 -05:00
|
|
|
|
2012-05-04 12:28:35 -05:00
|
|
|
return client
|
2013-07-12 15:49:03 -05:00
|
|
|
|
|
|
|
|
2014-08-27 23:25:44 -05:00
|
|
|
def build_option_parser(parser):
|
|
|
|
"""Hook to add global options"""
|
|
|
|
parser.add_argument(
|
|
|
|
'--os-identity-api-version',
|
|
|
|
metavar='<identity-api-version>',
|
|
|
|
default=utils.env(
|
|
|
|
'OS_IDENTITY_API_VERSION',
|
|
|
|
default=DEFAULT_IDENTITY_API_VERSION),
|
|
|
|
help='Identity API version, default=' +
|
|
|
|
DEFAULT_IDENTITY_API_VERSION +
|
|
|
|
' (Env: OS_IDENTITY_API_VERSION)')
|
|
|
|
parser.add_argument(
|
|
|
|
'--os-trust-id',
|
|
|
|
metavar='<trust-id>',
|
|
|
|
default=utils.env('OS_TRUST_ID'),
|
|
|
|
help='Trust ID to use when authenticating. '
|
|
|
|
'This can only be used with Keystone v3 API '
|
|
|
|
'(Env: OS_TRUST_ID)')
|
|
|
|
return parser
|
|
|
|
|
|
|
|
|
2013-07-12 15:49:03 -05:00
|
|
|
class IdentityClientv2_0(identity_client_v2_0.Client):
|
|
|
|
"""Tweak the earlier client class to deal with some changes"""
|
|
|
|
def __getattr__(self, name):
|
|
|
|
# Map v3 'projects' back to v2 'tenants'
|
|
|
|
if name == "projects":
|
|
|
|
return self.tenants
|
|
|
|
else:
|
2014-02-11 15:44:54 +01:00
|
|
|
raise AttributeError(name)
|