2013-09-20 04:05:51 +08:00
|
|
|
# Copyright 2012 OpenStack Foundation
|
2012-05-17 14:33:43 -07:00
|
|
|
# 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.
|
|
|
|
|
2014-11-24 15:12:39 +01:00
|
|
|
import warnings
|
|
|
|
|
2016-10-21 15:57:39 +08:00
|
|
|
from oslo_utils import importutils
|
|
|
|
|
2012-05-17 14:33:43 -07:00
|
|
|
from glanceclient.common import utils
|
|
|
|
|
|
|
|
|
2014-11-25 13:25:12 +10:00
|
|
|
def Client(version=None, endpoint=None, session=None, *args, **kwargs):
|
2014-10-08 10:25:33 +11:00
|
|
|
"""Client for the OpenStack Images API.
|
|
|
|
|
|
|
|
Generic client for the OpenStack Images API. See version classes
|
|
|
|
for specific details.
|
|
|
|
|
2014-11-25 13:25:12 +10:00
|
|
|
:param string version: The version of API to use.
|
2016-06-14 06:57:02 +04:00
|
|
|
:param session: A keystoneauth1 session that should be used for transport.
|
|
|
|
:type session: keystoneauth1.session.Session
|
2014-10-08 10:25:33 +11:00
|
|
|
"""
|
2014-11-25 13:25:12 +10:00
|
|
|
# FIXME(jamielennox): Add a deprecation warning if no session is passed.
|
|
|
|
# Leaving it as an option until we can ensure nothing break when we switch.
|
|
|
|
if session:
|
|
|
|
if endpoint:
|
|
|
|
kwargs.setdefault('endpoint_override', endpoint)
|
|
|
|
|
|
|
|
if not version:
|
|
|
|
__, version = utils.strip_version(endpoint)
|
|
|
|
|
|
|
|
if not version:
|
|
|
|
msg = ("You must provide a client version when using session")
|
|
|
|
raise RuntimeError(msg)
|
|
|
|
|
|
|
|
else:
|
|
|
|
if version is not None:
|
|
|
|
warnings.warn(("`version` keyword is being deprecated. Please pass"
|
|
|
|
" the version as part of the URL. "
|
|
|
|
"http://$HOST:$PORT/v$VERSION_NUMBER"),
|
|
|
|
DeprecationWarning)
|
|
|
|
|
|
|
|
endpoint, url_version = utils.strip_version(endpoint)
|
|
|
|
version = version or url_version
|
|
|
|
|
|
|
|
if not version:
|
|
|
|
msg = ("Please provide either the version or an url with the form "
|
|
|
|
"http://$HOST:$PORT/v$VERSION_NUMBER")
|
|
|
|
raise RuntimeError(msg)
|
|
|
|
|
2016-10-21 15:57:39 +08:00
|
|
|
module = importutils.import_versioned_module('glanceclient', int(version),
|
|
|
|
'client')
|
2012-05-17 14:33:43 -07:00
|
|
|
client_class = getattr(module, 'Client')
|
2014-11-25 13:25:12 +10:00
|
|
|
return client_class(endpoint, *args, session=session, **kwargs)
|