61 lines
1.9 KiB
Python
61 lines
1.9 KiB
Python
|
from data import model
|
||
|
|
||
|
from config_app.config_endpoints.api.superuser_models_interface import (SuperuserDataInterface, User, ServiceKey,
|
||
|
Approval)
|
||
|
|
||
|
|
||
|
def _create_user(user):
|
||
|
if user is None:
|
||
|
return None
|
||
|
return User(user.username, user.email, user.verified, user.enabled, user.robot)
|
||
|
|
||
|
|
||
|
def _create_key(key):
|
||
|
approval = None
|
||
|
if key.approval is not None:
|
||
|
approval = Approval(_create_user(key.approval.approver), key.approval.approval_type,
|
||
|
key.approval.approved_date,
|
||
|
key.approval.notes)
|
||
|
|
||
|
return ServiceKey(key.name, key.kid, key.service, key.jwk, key.metadata, key.created_date,
|
||
|
key.expiration_date,
|
||
|
key.rotation_duration, approval)
|
||
|
|
||
|
|
||
|
class ServiceKeyDoesNotExist(Exception):
|
||
|
pass
|
||
|
|
||
|
|
||
|
class ServiceKeyAlreadyApproved(Exception):
|
||
|
pass
|
||
|
|
||
|
|
||
|
class PreOCIModel(SuperuserDataInterface):
|
||
|
"""
|
||
|
PreOCIModel implements the data model for the SuperUser using a database schema
|
||
|
before it was changed to support the OCI specification.
|
||
|
"""
|
||
|
|
||
|
def list_all_service_keys(self):
|
||
|
keys = model.service_keys.list_all_keys()
|
||
|
return [_create_key(key) for key in keys]
|
||
|
|
||
|
def approve_service_key(self, kid, approval_type, notes=''):
|
||
|
try:
|
||
|
key = model.service_keys.approve_service_key(kid, approval_type, notes=notes)
|
||
|
return _create_key(key)
|
||
|
except model.ServiceKeyDoesNotExist:
|
||
|
raise ServiceKeyDoesNotExist
|
||
|
except model.ServiceKeyAlreadyApproved:
|
||
|
raise ServiceKeyAlreadyApproved
|
||
|
|
||
|
def generate_service_key(self, service, expiration_date, kid=None, name='', metadata=None,
|
||
|
rotation_duration=None):
|
||
|
(private_key, key) = model.service_keys.generate_service_key(service, expiration_date,
|
||
|
metadata=metadata, name=name)
|
||
|
|
||
|
return private_key, key.kid
|
||
|
|
||
|
|
||
|
pre_oci_model = PreOCIModel()
|