Source code for pycadf.credential

# Copyright (c) 2013 IBM Corporation
#
# 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.

from pycadf import cadftype
from pycadf import utils

TYPE_URI_CRED = cadftype.CADF_VERSION_1_0_0 + 'credential'

CRED_KEYNAME_TYPE = "type"
CRED_KEYNAME_TOKEN = "token"

CRED_KEYNAMES = [CRED_KEYNAME_TYPE,
                 CRED_KEYNAME_TOKEN]


FED_CRED_KEYNAME_IDENTITY_PROVIDER = "identity_provider"
FED_CRED_KEYNAME_USER = "user"
FED_CRED_KEYNAME_GROUPS = "groups"

FED_CRED_KEYNAMES = CRED_KEYNAMES + [FED_CRED_KEYNAME_IDENTITY_PROVIDER,
                                     FED_CRED_KEYNAME_USER,
                                     FED_CRED_KEYNAME_GROUPS]


[docs] class Credential(cadftype.CADFAbstractType): type = cadftype.ValidatorDescriptor(CRED_KEYNAME_TYPE, lambda x: isinstance(x, str)) token = cadftype.ValidatorDescriptor(CRED_KEYNAME_TOKEN, lambda x: isinstance(x, str)) def __init__(self, token, type=None): """Create Credential data type :param token: identity or security token :param type: type of credential (ie. identity token) """ # Credential.token setattr(self, CRED_KEYNAME_TOKEN, utils.mask_value(token)) # Credential.type if type is not None: setattr(self, CRED_KEYNAME_TYPE, type) # TODO(mrutkows): validate this cadf:Credential type against schema
[docs] def is_valid(self): """Validation to ensure Credential required attributes are set.""" # TODO(mrutkows): validate specific attribute type/format return self._isset(CRED_KEYNAME_TOKEN)
[docs] class FederatedCredential(Credential): identity_provider = cadftype.ValidatorDescriptor( FED_CRED_KEYNAME_IDENTITY_PROVIDER, lambda x: isinstance(x, str)) user = cadftype.ValidatorDescriptor( FED_CRED_KEYNAME_USER, lambda x: isinstance(x, str)) groups = cadftype.ValidatorDescriptor( FED_CRED_KEYNAME_GROUPS, lambda x: isinstance(x, list)) def __init__(self, token, type, identity_provider, user, groups): super(FederatedCredential, self).__init__( token=token, type=type) # FederatedCredential.identity_provider setattr(self, FED_CRED_KEYNAME_IDENTITY_PROVIDER, identity_provider) # FederatedCredential.user setattr(self, FED_CRED_KEYNAME_USER, user) # FederatedCredential.groups setattr(self, FED_CRED_KEYNAME_GROUPS, groups)
[docs] def is_valid(self): """Validation to ensure Credential required attributes are set.""" return ( super(FederatedCredential, self).is_valid() and self._isset(CRED_KEYNAME_TYPE) and self._isset(FED_CRED_KEYNAME_IDENTITY_PROVIDER) and self._isset(FED_CRED_KEYNAME_USER) and self._isset(FED_CRED_KEYNAME_GROUPS))