2012-09-11 11:20:16 -05:00
|
|
|
# Copyright 2011 Nebula, Inc.
|
|
|
|
# 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.
|
|
|
|
import json
|
|
|
|
import logging
|
|
|
|
|
|
|
|
from keystoneclient.v2_0 import client
|
2012-09-11 11:40:25 -05:00
|
|
|
from keystoneclient.v3 import endpoints
|
2012-09-11 12:32:01 -05:00
|
|
|
from keystoneclient.v3 import domains
|
2012-09-11 11:44:05 -05:00
|
|
|
from keystoneclient.v3 import policies
|
2012-09-11 11:22:30 -05:00
|
|
|
from keystoneclient.v3 import services
|
2012-09-11 11:20:16 -05:00
|
|
|
|
|
|
|
|
|
|
|
_logger = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
class Client(client.Client):
|
|
|
|
"""Client for the OpenStack Identity API v3.
|
|
|
|
|
|
|
|
:param string username: Username for authentication. (optional)
|
|
|
|
:param string password: Password for authentication. (optional)
|
|
|
|
:param string token: Token for authentication. (optional)
|
|
|
|
:param string tenant_name: Tenant id. (optional)
|
|
|
|
:param string tenant_id: Tenant name. (optional)
|
|
|
|
:param string auth_url: Keystone service endpoint for authorization.
|
|
|
|
:param string region_name: Name of a region to select when choosing an
|
|
|
|
endpoint from the service catalog.
|
|
|
|
:param string endpoint: A user-supplied endpoint URL for the keystone
|
|
|
|
service. Lazy-authentication is possible for API
|
|
|
|
service calls if endpoint is set at
|
|
|
|
instantiation.(optional)
|
|
|
|
:param integer timeout: Allows customization of the timeout for client
|
|
|
|
http requests. (optional)
|
|
|
|
|
|
|
|
Example::
|
|
|
|
|
|
|
|
>>> from keystoneclient.v3 import client
|
|
|
|
>>> keystone = client.Client(username=USER,
|
|
|
|
password=PASS,
|
|
|
|
tenant_name=TENANT_NAME,
|
|
|
|
auth_url=KEYSTONE_URL)
|
|
|
|
>>> keystone.tenants.list()
|
|
|
|
...
|
|
|
|
>>> user = keystone.users.get(USER_ID)
|
|
|
|
>>> user.delete()
|
|
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
def __init__(self, endpoint=None, **kwargs):
|
|
|
|
""" Initialize a new client for the Keystone v2.0 API. """
|
|
|
|
super(Client, self).__init__(endpoint=endpoint, **kwargs)
|
|
|
|
|
2012-09-11 11:40:25 -05:00
|
|
|
self.endpoints = endpoints.EndpointManager(self)
|
2012-09-11 12:32:01 -05:00
|
|
|
self.domains = domains.DomainManager(self)
|
2012-09-11 11:44:05 -05:00
|
|
|
self.policies = policies.PolicyManager(self)
|
2012-09-11 11:22:30 -05:00
|
|
|
self.services = services.ServiceManager(self)
|
|
|
|
|
2012-09-11 11:20:16 -05:00
|
|
|
# NOTE(gabriel): If we have a pre-defined endpoint then we can
|
|
|
|
# get away with lazy auth. Otherwise auth immediately.
|
|
|
|
if endpoint:
|
|
|
|
self.management_url = endpoint
|
|
|
|
else:
|
|
|
|
self.authenticate()
|
|
|
|
|
|
|
|
def serialize(self, entity):
|
|
|
|
return json.dumps(entity, sort_keys=True)
|