Order/Secret capitalized factory methods disappear and are replaced by more appropriate get/create methods in their respective managers, to match the revised Container code. The higher level REST functions for get/get_raw/post/delete become private so that the namespace for developers using the client is much cleaner. For example, nothing is visible in the top level client object besides the manager classes for container/secret/order and nothing is visible inside the manager classes besides the appropriate get/create/delete methods (or other applicable functions). Internally, the barbican_cli code uses at least one private property from ContainerManager, but it is assumed to be OK since it is within the same "package", and the code will be maintained simultaneously. Change-Id: I89525506f3be26b77421a5b8efa49bb645169aaf
57 lines
1.7 KiB
Python
57 lines
1.7 KiB
Python
# Copyright (c) 2013 Rackspace, Inc.
|
|
#
|
|
# 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.
|
|
"""
|
|
Base utilities to build API operation managers.
|
|
"""
|
|
import six
|
|
import uuid
|
|
|
|
|
|
def filter_empty_keys(dictionary):
|
|
return dict(((k, v) for k, v in dictionary.items() if v))
|
|
|
|
|
|
def validate_ref(ref, entity):
|
|
try:
|
|
# Split out the UUID from the ref URL
|
|
url = six.moves.urllib.parse.urlparse(ref)
|
|
parts = url.path.rstrip('/').split('/')
|
|
# Attempt to load the UUID with uuid, which will raise if invalid
|
|
uuid.UUID(parts[-1])
|
|
except:
|
|
raise ValueError('{0} incorrectly specified.'.format(entity))
|
|
|
|
|
|
class ImmutableException(Exception):
|
|
def __init__(self, attribute=None):
|
|
message = "This object is immutable!"
|
|
super(ImmutableException, self).__init__(message)
|
|
|
|
|
|
class BaseEntityManager(object):
|
|
def __init__(self, api, entity):
|
|
self._api = api
|
|
self._entity = entity
|
|
|
|
def total(self):
|
|
"""
|
|
Returns the total number of entities stored in Barbican.
|
|
"""
|
|
href = '{0}/{1}'.format(self._api._base_url, self._entity)
|
|
params = {'limit': 0, 'offset': 0}
|
|
resp = self._api._get(href, params)
|
|
|
|
return resp['total']
|