 f4e6f12a71
			
		
	
	f4e6f12a71
	
	
	
		
			
			We are removing Python 2.6 support from the Keystone libraries. Change-Id: I1c7a79edd41a73946c9d77bfb8cd2075e2500760 Closes-Bug: 1519449
		
			
				
	
	
		
			79 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			79 lines
		
	
	
		
			2.3 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.
 | |
| 
 | |
| """The python bindings for the OpenStack Identity (Keystone) project.
 | |
| 
 | |
| A Client object will allow you to communicate with the Identity server. The
 | |
| recommended way to get a Client object is to use
 | |
| :py:func:`keystoneclient.client.Client()`. :py:func:`~.Client()` uses version
 | |
| discovery to create a V3 or V2 client depending on what versions the Identity
 | |
| server supports and what version is requested.
 | |
| 
 | |
| Identity V2 and V3 clients can also be created directly. See
 | |
| :py:class:`keystoneclient.v3.client.Client` for the V3 client and
 | |
| :py:class:`keystoneclient.v2_0.client.Client` for the V2 client.
 | |
| 
 | |
| """
 | |
| 
 | |
| import importlib
 | |
| import sys
 | |
| 
 | |
| import pbr.version
 | |
| 
 | |
| 
 | |
| __version__ = pbr.version.VersionInfo('python-keystoneclient').version_string()
 | |
| 
 | |
| __all__ = (
 | |
|     # Modules
 | |
|     'generic',
 | |
|     'v2_0',
 | |
|     'v3',
 | |
| 
 | |
|     # Packages
 | |
|     'access',
 | |
|     'client',
 | |
|     'exceptions',
 | |
|     'httpclient',
 | |
|     'service_catalog',
 | |
| )
 | |
| 
 | |
| 
 | |
| class _LazyImporter(object):
 | |
|     def __init__(self, module):
 | |
|         self._module = module
 | |
| 
 | |
|     def __getattr__(self, name):
 | |
|         # NB: this is only called until the import has been done.
 | |
|         # These submodules are part of the API without explicit importing, but
 | |
|         # expensive to load, so we load them on-demand rather than up-front.
 | |
|         lazy_submodules = [
 | |
|             'access',
 | |
|             'client',
 | |
|             'exceptions',
 | |
|             'generic',
 | |
|             'httpclient',
 | |
|             'service_catalog',
 | |
|             'v2_0',
 | |
|             'v3',
 | |
|         ]
 | |
|         if name in lazy_submodules:
 | |
|             return importlib.import_module('keystoneclient.%s' % name)
 | |
| 
 | |
|         # Return module attributes like __all__ etc.
 | |
|         return getattr(self._module, name)
 | |
| 
 | |
| 
 | |
| sys.modules[__name__] = _LazyImporter(sys.modules[__name__])
 |