Apply black formatter to dcdbsync

This commit applies the Black format to the `dcdbsync`
files to ensure that it adheres to the Black code style guidelines.

Test Plan:
PASS: Success in stx-distcloud-tox-black

Story: 2011149
Task: 50443

Change-Id: I10596ee3def785fcff04c67e63552aeb304b07bb
Signed-off-by: Hugo Brito <hugo.brito@windriver.com>
This commit is contained in:
Hugo Brito 2024-06-26 14:20:25 -03:00 committed by Hugo Nicodemos
parent 83dbf64aca
commit 686abd1cbc
23 changed files with 779 additions and 618 deletions

View File

@ -12,7 +12,7 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
# #
# Copyright (c) 2019 Wind River Systems, Inc. # Copyright (c) 2019, 2024 Wind River Systems, Inc.
# #
# SPDX-License-Identifier: Apache-2.0 # SPDX-License-Identifier: Apache-2.0
# #
@ -20,4 +20,4 @@
import pbr.version import pbr.version
__version__ = pbr.version.VersionInfo('distributedcloud').version_string() __version__ = pbr.version.VersionInfo("distributedcloud").version_string()

View File

@ -26,6 +26,7 @@ import logging as std_logging
import sys import sys
import eventlet import eventlet
eventlet.monkey_patch(os=False) eventlet.monkey_patch(os=False)
# pylint: disable=wrong-import-position # pylint: disable=wrong-import-position
@ -38,11 +39,12 @@ from dcdbsync.api import api_config # noqa: E402
from dcdbsync.api import app # noqa: E402 from dcdbsync.api import app # noqa: E402
from dcdbsync.common import config # noqa: E402 from dcdbsync.common import config # noqa: E402
from dcdbsync.common import messaging # noqa: E402 from dcdbsync.common import messaging # noqa: E402
# pylint: enable=wrong-import-position # pylint: enable=wrong-import-position
CONF = cfg.CONF CONF = cfg.CONF
config.register_options() config.register_options()
LOG = logging.getLogger('dcdbsync.api') LOG = logging.getLogger("dcdbsync.api")
def main(): def main():
@ -58,8 +60,10 @@ def main():
LOG.warning("Wrong worker number, worker = %(workers)s", workers) LOG.warning("Wrong worker number, worker = %(workers)s", workers)
workers = 1 workers = 1
LOG.info("Server on http://%(host)s:%(port)s with %(workers)s", LOG.info(
{'host': host, 'port': port, 'workers': workers}) "Server on http://%(host)s:%(port)s with %(workers)s",
{"host": host, "port": port, "workers": workers},
)
messaging.setup() messaging.setup()
systemd.notify_once() systemd.notify_once()
service = wsgi.Server(CONF, "DCDBsync", application, host, port) service = wsgi.Server(CONF, "DCDBsync", application, host, port)
@ -73,5 +77,5 @@ def main():
app.wait() app.wait()
if __name__ == '__main__': if __name__ == "__main__":
main() main()

View File

@ -11,7 +11,7 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
# #
# Copyright (c) 2019 Wind River Systems, Inc. # Copyright (c) 2019, 2024 Wind River Systems, Inc.
# #
# SPDX-License-Identifier: Apache-2.0 # SPDX-License-Identifier: Apache-2.0
# #
@ -23,94 +23,88 @@ from oslo_config import cfg
from oslo_utils import importutils from oslo_utils import importutils
# Ensure keystonemiddleware options are imported # Ensure keystonemiddleware options are imported
importutils.import_module('keystonemiddleware.auth_token') importutils.import_module("keystonemiddleware.auth_token")
# OpenStack credentials used for Endpoint Cache # OpenStack credentials used for Endpoint Cache
# We need to register the below non-standard config # We need to register the below non-standard config
# options to dbsync engine # options to dbsync engine
keystone_opts = [ keystone_opts = [
cfg.StrOpt('username', cfg.StrOpt("username", help="Username of account"),
help='Username of account'), cfg.StrOpt("password", help="Password of account"),
cfg.StrOpt('password', cfg.StrOpt("project_name", help="Tenant name of account"),
help='Password of account'), cfg.StrOpt(
cfg.StrOpt('project_name', "user_domain_name", default="Default", help="User domain name of account"
help='Tenant name of account'), ),
cfg.StrOpt('user_domain_name', cfg.StrOpt(
default='Default', "project_domain_name", default="Default", help="Project domain name of account"
help='User domain name of account'), ),
cfg.StrOpt('project_domain_name',
default='Default',
help='Project domain name of account'),
] ]
# Pecan_opts # Pecan_opts
pecan_opts = [ pecan_opts = [
cfg.StrOpt( cfg.StrOpt(
'root', "root",
default='dcdbsync.api.controllers.root.RootController', default="dcdbsync.api.controllers.root.RootController",
help='Pecan root controller' help="Pecan root controller",
), ),
cfg.ListOpt( cfg.ListOpt(
'modules', "modules",
default=["dcdbsync.api"], default=["dcdbsync.api"],
help='A list of modules where pecan will search for applications.' help="A list of modules where pecan will search for applications.",
), ),
cfg.BoolOpt( cfg.BoolOpt(
'debug', "debug",
default=False, default=False,
help='Enables the ability to display tracebacks in the browser and' help=(
'interactively debug during development.' "Enables the ability to display tracebacks in the browser and "
"interactively debug during development.",
),
), ),
cfg.BoolOpt( cfg.BoolOpt(
'auth_enable', "auth_enable", default=True, help="Enables user authentication in pecan."
default=True, ),
help='Enables user authentication in pecan.'
)
] ]
# OpenStack credentials used for Endpoint Cache # OpenStack credentials used for Endpoint Cache
cache_opts = [ cache_opts = [
cfg.StrOpt('auth_uri', cfg.StrOpt("auth_uri", help="Keystone authorization url"),
help='Keystone authorization url'), cfg.StrOpt("identity_uri", help="Keystone service url"),
cfg.StrOpt('identity_uri', cfg.StrOpt(
help='Keystone service url'), "admin_username",
cfg.StrOpt('admin_username', help="Username of admin account, needed when auto_refresh_endpoint set to True",
help='Username of admin account, needed when' ),
' auto_refresh_endpoint set to True'), cfg.StrOpt(
cfg.StrOpt('admin_password', "admin_password",
help='Password of admin account, needed when' help="Password of admin account, needed when auto_refresh_endpoint set to True",
' auto_refresh_endpoint set to True'), ),
cfg.StrOpt('admin_tenant', cfg.StrOpt(
help='Tenant name of admin account, needed when' "admin_tenant",
' auto_refresh_endpoint set to True'), help="Tenant of admin account, needed when auto_refresh_endpoint set to True",
cfg.StrOpt('admin_user_domain_name', ),
default='Default', cfg.StrOpt(
help='User domain name of admin account, needed when' "admin_user_domain_name",
' auto_refresh_endpoint set to True'), default="Default",
cfg.StrOpt('admin_project_domain_name', help="User domain of admin, needed when auto_refresh_endpoint set to True",
default='Default', ),
help='Project domain name of admin account, needed when' cfg.StrOpt(
' auto_refresh_endpoint set to True') "admin_project_domain_name",
default="Default",
help="Project domain of admin, needed when auto_refresh_endpoint set to True",
),
] ]
common_opts = [ common_opts = [
cfg.IntOpt('workers', default=1, cfg.IntOpt("workers", default=1, help="number of workers"),
help='number of workers'), cfg.StrOpt("host", default="localhost", help="hostname of the machine"),
cfg.StrOpt('host',
default='localhost',
help='hostname of the machine')
] ]
keystone_opt_group = cfg.OptGroup(name='keystone_authtoken', keystone_opt_group = cfg.OptGroup(name="keystone_authtoken", title="Keystone options")
title='Keystone options')
# The group stores the pecan configurations. # The group stores the pecan configurations.
pecan_group = cfg.OptGroup(name='pecan', pecan_group = cfg.OptGroup(name="pecan", title="Pecan options")
title='Pecan options')
cache_opt_group = cfg.OptGroup(name='cache', cache_opt_group = cfg.OptGroup(name="cache", title="OpenStack Credentials")
title='OpenStack Credentials')
def list_opts(): def list_opts():

View File

@ -10,22 +10,21 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
# #
# Copyright (c) 2019-2022 Wind River Systems, Inc. # Copyright (c) 2019-2022, 2024 Wind River Systems, Inc.
# #
# SPDX-License-Identifier: Apache-2.0 # SPDX-License-Identifier: Apache-2.0
# #
import pecan
from pecan import hooks
from oslo_context import context as base_context from oslo_context import context as base_context
from oslo_utils import encodeutils from oslo_utils import encodeutils
import pecan
from pecan import hooks
from dcdbsync.api.policies import base as base_policy from dcdbsync.api.policies import base as base_policy
from dcdbsync.api import policy from dcdbsync.api import policy
from dcdbsync.db.identity import api as db_api from dcdbsync.db.identity import api as db_api
ALLOWED_WITHOUT_AUTH = '/' ALLOWED_WITHOUT_AUTH = "/"
class RequestContext(base_context.RequestContext): class RequestContext(base_context.RequestContext):
@ -35,24 +34,47 @@ class RequestContext(base_context.RequestContext):
the system, as well as additional request information. the system, as well as additional request information.
""" """
def __init__(self, auth_token=None, user=None, project=None, def __init__(
domain=None, user_domain=None, project_domain=None, self,
is_admin=None, read_only=False, show_deleted=False, auth_token=None,
request_id=None, auth_url=None, trusts=None, user=None,
user_name=None, project_name=None, domain_name=None, project=None,
user_domain_name=None, project_domain_name=None, domain=None,
auth_token_info=None, region_name=None, roles=None, user_domain=None,
password=None, **kwargs): project_domain=None,
is_admin=None,
read_only=False,
show_deleted=False,
request_id=None,
auth_url=None,
trusts=None,
user_name=None,
project_name=None,
domain_name=None,
user_domain_name=None,
project_domain_name=None,
auth_token_info=None,
region_name=None,
roles=None,
password=None,
**kwargs
):
# Initializer of request context. # Initializer of request context.
# We still have 'tenant' param because oslo_context still use it. # We still have 'tenant' param because oslo_context still use it.
# pylint: disable=E1123 # pylint: disable=E1123
super(RequestContext, self).__init__( super(RequestContext, self).__init__(
auth_token=auth_token, user=user, tenant=project, auth_token=auth_token,
domain=domain, user_domain=user_domain, user=user,
project_domain=project_domain, roles=roles, tenant=project,
read_only=read_only, show_deleted=show_deleted, domain=domain,
request_id=request_id) user_domain=user_domain,
project_domain=project_domain,
roles=roles,
read_only=read_only,
show_deleted=show_deleted,
request_id=request_id,
)
# request_id might be a byte array # request_id might be a byte array
self.request_id = encodeutils.safe_decode(self.request_id) self.request_id = encodeutils.safe_decode(self.request_id)
@ -80,8 +102,8 @@ class RequestContext(base_context.RequestContext):
# Check user is admin or not # Check user is admin or not
if is_admin is None: if is_admin is None:
self.is_admin = policy.authorize( self.is_admin = policy.authorize(
base_policy.ADMIN_IN_SYSTEM_PROJECTS, {}, self.to_dict(), base_policy.ADMIN_IN_SYSTEM_PROJECTS, {}, self.to_dict(), do_raise=False
do_raise=False) )
else: else:
self.is_admin = is_admin self.is_admin = is_admin
@ -93,26 +115,26 @@ class RequestContext(base_context.RequestContext):
def to_dict(self): def to_dict(self):
return { return {
'auth_url': self.auth_url, "auth_url": self.auth_url,
'auth_token': self.auth_token, "auth_token": self.auth_token,
'auth_token_info': self.auth_token_info, "auth_token_info": self.auth_token_info,
'user': self.user, "user": self.user,
'user_name': self.user_name, "user_name": self.user_name,
'user_domain': self.user_domain, "user_domain": self.user_domain,
'user_domain_name': self.user_domain_name, "user_domain_name": self.user_domain_name,
'project': self.project, "project": self.project,
'project_name': self.project_name, "project_name": self.project_name,
'project_domain': self.project_domain, "project_domain": self.project_domain,
'project_domain_name': self.project_domain_name, "project_domain_name": self.project_domain_name,
'domain': self.domain, "domain": self.domain,
'domain_name': self.domain_name, "domain_name": self.domain_name,
'trusts': self.trusts, "trusts": self.trusts,
'region_name': self.region_name, "region_name": self.region_name,
'roles': self.roles, "roles": self.roles,
'show_deleted': self.show_deleted, "show_deleted": self.show_deleted,
'is_admin': self.is_admin, "is_admin": self.is_admin,
'request_id': self.request_id, "request_id": self.request_id,
'password': self.password, "password": self.password,
} }
@classmethod @classmethod
@ -135,14 +157,13 @@ class AuthHook(hooks.PecanHook):
if state.request.path == ALLOWED_WITHOUT_AUTH: if state.request.path == ALLOWED_WITHOUT_AUTH:
return return
req = state.request req = state.request
identity_status = req.headers.get('X-Identity-Status') identity_status = req.headers.get("X-Identity-Status")
service_identity_status = req.headers.get('X-Service-Identity-Status') service_identity_status = req.headers.get("X-Service-Identity-Status")
if (identity_status == 'Confirmed' or if identity_status == "Confirmed" or service_identity_status == "Confirmed":
service_identity_status == 'Confirmed'):
return return
if req.headers.get('X-Auth-Token'): if req.headers.get("X-Auth-Token"):
msg = 'Auth token is invalid: %s' % req.headers['X-Auth-Token'] msg = "Auth token is invalid: %s" % req.headers["X-Auth-Token"]
else: else:
msg = 'Authentication required' msg = "Authentication required"
msg = "Failed to validate access token: %s" % str(msg) msg = "Failed to validate access token: %s" % str(msg)
pecan.abort(status_code=401, detail=msg) pecan.abort(status_code=401, detail=msg)

View File

@ -86,10 +86,11 @@ class RoleNotFound(NotFound):
class ProjectRoleAssignmentNotFound(NotFound): class ProjectRoleAssignmentNotFound(NotFound):
message = _("Project role assignment with id" message = _(
" %(project_role_assignment_id)s doesn't exist.") "Project role assignment with id "
"%(project_role_assignment_id)s doesn't exist."
)
class RevokeEventNotFound(NotFound): class RevokeEventNotFound(NotFound):
message = _("Token revocation event with id %(revoke_event_id)s" message = _("Token revocation event with id %(revoke_event_id)s doesn't exist.")
" doesn't exist.")

View File

@ -12,14 +12,14 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
# #
# Copyright (c) 2019 Wind River Systems, Inc. # Copyright (c) 2019, 2024 Wind River Systems, Inc.
# #
# SPDX-License-Identifier: Apache-2.0 # SPDX-License-Identifier: Apache-2.0
# #
import oslo_i18n import oslo_i18n
_translators = oslo_i18n.TranslatorFactory(domain='dbsync') _translators = oslo_i18n.TranslatorFactory(domain="dbsync")
# The primary translation function using the well-known name "_" # The primary translation function using the well-known name "_"
_ = _translators.primary _ = _translators.primary

View File

@ -10,13 +10,12 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
# #
# Copyright (c) 2019 Wind River Systems, Inc. # Copyright (c) 2019, 2024 Wind River Systems, Inc.
# #
# SPDX-License-Identifier: Apache-2.0 # SPDX-License-Identifier: Apache-2.0
# #
import eventlet import eventlet
from oslo_config import cfg from oslo_config import cfg
import oslo_messaging import oslo_messaging
from oslo_serialization import jsonutils from oslo_serialization import jsonutils
@ -66,11 +65,12 @@ def setup(url=None, optional=False):
eventlet.monkey_patch(time=True) eventlet.monkey_patch(time=True)
if not TRANSPORT: if not TRANSPORT:
oslo_messaging.set_transport_defaults('dcdbsync') oslo_messaging.set_transport_defaults("dcdbsync")
exmods = ['dcdbsync.common.exception'] exmods = ["dcdbsync.common.exception"]
try: try:
TRANSPORT = oslo_messaging.get_transport( TRANSPORT = oslo_messaging.get_transport(
cfg.CONF, url, allowed_remote_exmods=exmods) cfg.CONF, url, allowed_remote_exmods=exmods
)
except oslo_messaging.InvalidTransportURL as e: except oslo_messaging.InvalidTransportURL as e:
TRANSPORT = None TRANSPORT = None
if not optional or e.url: if not optional or e.url:
@ -92,17 +92,16 @@ def cleanup():
def get_rpc_server(target, endpoint): def get_rpc_server(target, endpoint):
"""Return a configured oslo_messaging rpc server.""" """Return a configured oslo_messaging rpc server."""
serializer = RequestContextSerializer(JsonPayloadSerializer()) serializer = RequestContextSerializer(JsonPayloadSerializer())
return oslo_messaging.get_rpc_server(TRANSPORT, target, [endpoint], return oslo_messaging.get_rpc_server(
executor='eventlet', TRANSPORT, target, [endpoint], executor="eventlet", serializer=serializer
serializer=serializer) )
def get_rpc_client(**kwargs): def get_rpc_client(**kwargs):
"""Return a configured oslo_messaging RPCClient.""" """Return a configured oslo_messaging RPCClient."""
target = oslo_messaging.Target(**kwargs) target = oslo_messaging.Target(**kwargs)
serializer = RequestContextSerializer(JsonPayloadSerializer()) serializer = RequestContextSerializer(JsonPayloadSerializer())
return oslo_messaging.RPCClient(TRANSPORT, target, return oslo_messaging.RPCClient(TRANSPORT, target, serializer=serializer)
serializer=serializer)
def get_notifier(publisher_id): def get_notifier(publisher_id):

View File

@ -12,7 +12,7 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
# #
# Copyright (c) 2019 Wind River Systems, Inc. # Copyright (c) 2019, 2024 Wind River Systems, Inc.
# #
# SPDX-License-Identifier: Apache-2.0 # SPDX-License-Identifier: Apache-2.0
# #
@ -23,7 +23,7 @@ DBSYNC_VENDOR = "Wind River Systems"
DBSYNC_PRODUCT = "Distributed Cloud DBsync Agent" DBSYNC_PRODUCT = "Distributed Cloud DBsync Agent"
DBSYNC_PACKAGE = None # OS distro package version suffix DBSYNC_PACKAGE = None # OS distro package version suffix
version_info = pbr.version.VersionInfo('distributedcloud') version_info = pbr.version.VersionInfo("distributedcloud")
version_string = version_info.version_string version_string = version_info.version_string

View File

@ -13,7 +13,7 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
# #
# Copyright (c) 2019-2021 Wind River Systems, Inc. # Copyright (c) 2019-2021, 2024 Wind River Systems, Inc.
# #
# SPDX-License-Identifier: Apache-2.0 # SPDX-License-Identifier: Apache-2.0
# #
@ -30,7 +30,7 @@ from oslo_db import api
CONF = cfg.CONF CONF = cfg.CONF
_BACKEND_MAPPING = {'sqlalchemy': 'dcdbsync.db.identity.sqlalchemy.api'} _BACKEND_MAPPING = {"sqlalchemy": "dcdbsync.db.identity.sqlalchemy.api"}
IMPL = api.DBAPI.from_config(CONF, backend_mapping=_BACKEND_MAPPING) IMPL = api.DBAPI.from_config(CONF, backend_mapping=_BACKEND_MAPPING)
@ -49,6 +49,7 @@ def get_session():
################### ###################
def user_get_all(context): def user_get_all(context):
"""Retrieve all users.""" """Retrieve all users."""
return IMPL.user_get_all(context) return IMPL.user_get_all(context)
@ -75,6 +76,7 @@ def user_update(context, user_ref, payload):
################### ###################
def group_get_all(context): def group_get_all(context):
"""Retrieve all groups.""" """Retrieve all groups."""
return IMPL.group_get_all(context) return IMPL.group_get_all(context)
@ -101,6 +103,7 @@ def group_update(context, group_ref, payload):
################### ###################
def project_get_all(context): def project_get_all(context):
"""Retrieve all projects.""" """Retrieve all projects."""
return IMPL.project_get_all(context) return IMPL.project_get_all(context)
@ -127,6 +130,7 @@ def project_update(context, project_ref, payload):
################### ###################
def role_get_all(context): def role_get_all(context):
"""Retrieve all roles.""" """Retrieve all roles."""
return IMPL.role_get_all(context) return IMPL.role_get_all(context)
@ -153,6 +157,7 @@ def role_update(context, role_ref, payload):
################### ###################
def revoke_event_get_all(context): def revoke_event_get_all(context):
"""Retrieve all token revocation events.""" """Retrieve all token revocation events."""
return IMPL.revoke_event_get_all(context) return IMPL.revoke_event_get_all(context)

View File

@ -53,6 +53,7 @@ def _get_context():
global _CONTEXT global _CONTEXT
if _CONTEXT is None: if _CONTEXT is None:
import threading import threading
_CONTEXT = threading.local() _CONTEXT = threading.local()
return _CONTEXT return _CONTEXT
@ -65,11 +66,7 @@ class TableRegistry(object):
try: try:
table = self.metadata.tables[tablename] table = self.metadata.tables[tablename]
except KeyError: except KeyError:
table = Table( table = Table(tablename, self.metadata, autoload_with=connection)
tablename,
self.metadata,
autoload_with=connection
)
return table return table
@ -155,9 +152,8 @@ def get_backend():
def is_admin_context(context): def is_admin_context(context):
"""Indicate if the request context is an administrator.""" """Indicate if the request context is an administrator."""
if not context: if not context:
LOG.warning(_('Use of empty request context is deprecated'), LOG.warning(_("Use of empty request context is deprecated"), DeprecationWarning)
DeprecationWarning) raise Exception("die")
raise Exception('die')
return context.is_admin return context.is_admin
@ -177,6 +173,7 @@ def require_admin_context(f):
The first argument to the wrapped function must be the context. The first argument to the wrapped function must be the context.
""" """
def wrapper(*args, **kwargs): def wrapper(*args, **kwargs):
if not is_admin_context(args[0]): if not is_admin_context(args[0]):
raise exception.AdminRequired() raise exception.AdminRequired()
@ -194,6 +191,7 @@ def require_context(f):
The first argument to the wrapped function must be the context. The first argument to the wrapped function must be the context.
""" """
def wrapper(*args, **kwargs): def wrapper(*args, **kwargs):
if not is_admin_context(args[0]) and not is_user_context(args[0]): if not is_admin_context(args[0]) and not is_user_context(args[0]):
raise exception.NotAuthorized() raise exception.NotAuthorized()
@ -208,27 +206,33 @@ def require_context(f):
################### ###################
@require_context @require_context
def user_get_all(context): def user_get_all(context):
result = [] result = []
with get_read_connection() as conn: with get_read_connection() as conn:
# user table # user table
users = query(conn, 'user') users = query(conn, "user")
# local_user table # local_user table
local_users = query(conn, 'local_user') local_users = query(conn, "local_user")
# password table # password table
passwords = query(conn, 'password') passwords = query(conn, "password")
for local_user in local_users: for local_user in local_users:
user = {'user': user for user in users if user['id'] user = {"user": user for user in users if user["id"] == local_user["user_id"]}
== local_user['user_id']} user_passwords = {
user_passwords = {'password': [password for password in passwords "password": [
if password['local_user_id'] == password
local_user['id']]} for password in passwords
user_consolidated = dict(list({'local_user': local_user}.items()) + if password["local_user_id"] == local_user["id"]
list(user.items()) + ]
list(user_passwords.items())) }
user_consolidated = dict(
list({"local_user": local_user}.items())
+ list(user.items())
+ list(user_passwords.items())
)
result.append(user_consolidated) result.append(user_consolidated)
return result return result
@ -240,113 +244,111 @@ def user_get(context, user_id):
with get_read_connection() as conn: with get_read_connection() as conn:
# user table # user table
users = query(conn, 'user', 'id', user_id) users = query(conn, "user", "id", user_id)
if not users: if not users:
raise exception.UserNotFound(user_id=user_id) raise exception.UserNotFound(user_id=user_id)
result['user'] = users[0] result["user"] = users[0]
# local_user table # local_user table
local_users = query(conn, 'local_user', 'user_id', user_id) local_users = query(conn, "local_user", "user_id", user_id)
if not local_users: if not local_users:
raise exception.UserNotFound(user_id=user_id) raise exception.UserNotFound(user_id=user_id)
result['local_user'] = local_users[0] result["local_user"] = local_users[0]
# password table # password table
result['password'] = [] result["password"] = []
if result['local_user']: if result["local_user"]:
result['password'] = query(conn, 'password', result["password"] = query(
'local_user_id', conn, "password", "local_user_id", result["local_user"].get("id")
result['local_user'].get('id')) )
return result return result
@require_admin_context @require_admin_context
def user_create(context, payload): def user_create(context, payload):
users = [payload['user']] users = [payload["user"]]
local_users = [payload['local_user']] local_users = [payload["local_user"]]
passwords = payload['password'] passwords = payload["password"]
with get_write_connection() as conn: with get_write_connection() as conn:
insert(conn, 'user', users) insert(conn, "user", users)
# ignore auto generated id # ignore auto generated id
for local_user in local_users: for local_user in local_users:
local_user.pop('id', None) local_user.pop("id", None)
insert(conn, 'local_user', local_users) insert(conn, "local_user", local_users)
inserted_local_users = query(conn, 'local_user', 'user_id', inserted_local_users = query(
payload['local_user']['user_id']) conn, "local_user", "user_id", payload["local_user"]["user_id"]
)
if not inserted_local_users: if not inserted_local_users:
raise exception.UserNotFound(user_id=payload['local_user'] raise exception.UserNotFound(user_id=payload["local_user"]["user_id"])
['user_id'])
for password in passwords: for password in passwords:
# ignore auto generated id # ignore auto generated id
password.pop('id', None) password.pop("id", None)
password['local_user_id'] = inserted_local_users[0]['id'] password["local_user_id"] = inserted_local_users[0]["id"]
insert(conn, 'password', passwords) insert(conn, "password", passwords)
return user_get(context, payload['user']['id']) return user_get(context, payload["user"]["id"])
@require_admin_context @require_admin_context
def user_update(context, user_id, payload): def user_update(context, user_id, payload):
with get_write_connection() as conn: with get_write_connection() as conn:
# user table # user table
table = 'user' table = "user"
new_user_id = user_id new_user_id = user_id
if table in payload: if table in payload:
user_options = [] user_options = []
user = payload[table] user = payload[table]
new_user_id = user.get('id') new_user_id = user.get("id")
if user_id != new_user_id: if user_id != new_user_id:
# Delete the user_option record referencing to the old user_id # Delete the user_option record referencing to the old user_id
# to avoid the foreign key constraint violation when we update # to avoid the foreign key constraint violation when we update
# the user table in the next step. # the user table in the next step.
user_options = query(conn, 'user_option', 'user_id', user_id) user_options = query(conn, "user_option", "user_id", user_id)
delete(conn, 'user_option', 'user_id', user_id) delete(conn, "user_option", "user_id", user_id)
else: else:
user.pop('id', None) user.pop("id", None)
update(conn, table, 'id', user_id, user) update(conn, table, "id", user_id, user)
if user_options: if user_options:
for user_option in user_options: for user_option in user_options:
user_option['user_id'] = new_user_id user_option["user_id"] = new_user_id
insert(conn, 'user_option', user_option) insert(conn, "user_option", user_option)
# local_user table # local_user table
table = 'local_user' table = "local_user"
if table in payload: if table in payload:
local_user = payload[table] local_user = payload[table]
# ignore auto generated id # ignore auto generated id
local_user.pop('id', None) local_user.pop("id", None)
update(conn, table, 'user_id', user_id, local_user) update(conn, table, "user_id", user_id, local_user)
updated_local_users = query(conn, table, 'user_id', updated_local_users = query(conn, table, "user_id", new_user_id)
new_user_id)
if not updated_local_users: if not updated_local_users:
raise exception.UserNotFound(user_id=payload[table]['user_id']) raise exception.UserNotFound(user_id=payload[table]["user_id"])
# password table # password table
table = 'password' table = "password"
if table in payload: if table in payload:
delete(conn, table, 'local_user_id', delete(conn, table, "local_user_id", updated_local_users[0]["id"])
updated_local_users[0]['id'])
passwords = payload[table] passwords = payload[table]
for password in passwords: for password in passwords:
# ignore auto generated ids # ignore auto generated ids
password.pop('id', None) password.pop("id", None)
password['local_user_id'] = \ password["local_user_id"] = updated_local_users[0]["id"]
updated_local_users[0]['id']
insert(conn, table, password) insert(conn, table, password)
# Need to update the actor_id in assignment and system_assignment # Need to update the actor_id in assignment and system_assignment
# along with the user_id in user_group_membership tables if the # along with the user_id in user_group_membership tables if the
# user id is updated # user id is updated
if user_id != new_user_id: if user_id != new_user_id:
assignment = {'actor_id': new_user_id} assignment = {"actor_id": new_user_id}
user_group_membership = {'user_id': new_user_id} user_group_membership = {"user_id": new_user_id}
update(conn, 'assignment', 'actor_id', user_id, assignment) update(conn, "assignment", "actor_id", user_id, assignment)
update(conn, 'system_assignment', 'actor_id', user_id, assignment) update(conn, "system_assignment", "actor_id", user_id, assignment)
update(conn, 'user_group_membership', 'user_id', update(
user_id, user_group_membership) conn, "user_group_membership", "user_id", user_id, user_group_membership
)
return user_get(context, new_user_id) return user_get(context, new_user_id)
@ -357,24 +359,28 @@ def user_update(context, user_id, payload):
################### ###################
@require_context @require_context
def group_get_all(context): def group_get_all(context):
result = [] result = []
with get_read_connection() as conn: with get_read_connection() as conn:
# groups table # groups table
groups = query(conn, 'group') groups = query(conn, "group")
# user_group_membership table # user_group_membership table
user_group_memberships = query(conn, 'user_group_membership') user_group_memberships = query(conn, "user_group_membership")
for group in groups: for group in groups:
local_user_id_list = [membership['user_id'] for membership local_user_id_list = [
in user_group_memberships if membership["user_id"]
membership['group_id'] == group['id']] for membership in user_group_memberships
if membership["group_id"] == group["id"]
]
local_user_id_list.sort() local_user_id_list.sort()
local_user_ids = {'local_user_ids': local_user_id_list} local_user_ids = {"local_user_ids": local_user_id_list}
group_consolidated = dict(list({'group': group}.items()) + group_consolidated = dict(
list(local_user_ids.items())) list({"group": group}.items()) + list(local_user_ids.items())
)
result.append(group_consolidated) result.append(group_consolidated)
return result return result
@ -388,59 +394,62 @@ def group_get(context, group_id):
local_user_id_list = [] local_user_id_list = []
# group table # group table
group = query(conn, 'group', 'id', group_id) group = query(conn, "group", "id", group_id)
if not group: if not group:
raise exception.GroupNotFound(group_id=group_id) raise exception.GroupNotFound(group_id=group_id)
result['group'] = group[0] result["group"] = group[0]
# user_group_membership table # user_group_membership table
user_group_memberships = query(conn, 'user_group_membership', user_group_memberships = query(
'group_id', group_id) conn, "user_group_membership", "group_id", group_id
)
for user_group_membership in user_group_memberships: for user_group_membership in user_group_memberships:
local_user = query(conn, 'local_user', 'user_id', local_user = query(
user_group_membership.get('user_id')) conn, "local_user", "user_id", user_group_membership.get("user_id")
)
if not local_user: if not local_user:
raise exception.UserNotFound(user_id=user_group_membership.get( raise exception.UserNotFound(
'user_id')) user_id=user_group_membership.get("user_id")
local_user_id_list.append(local_user[0]['user_id']) )
local_user_id_list.append(local_user[0]["user_id"])
result['local_user_ids'] = local_user_id_list result["local_user_ids"] = local_user_id_list
return result return result
@require_admin_context @require_admin_context
def group_create(context, payload): def group_create(context, payload):
group = payload['group'] group = payload["group"]
local_user_ids = payload['local_user_ids'] local_user_ids = payload["local_user_ids"]
with get_write_connection() as conn: with get_write_connection() as conn:
insert(conn, 'group', group) insert(conn, "group", group)
for local_user_id in local_user_ids: for local_user_id in local_user_ids:
user_group_membership = {'user_id': local_user_id, user_group_membership = {"user_id": local_user_id, "group_id": group["id"]}
'group_id': group['id']} insert(conn, "user_group_membership", user_group_membership)
insert(conn, 'user_group_membership', user_group_membership)
return group_get(context, payload['group']['id']) return group_get(context, payload["group"]["id"])
@require_admin_context @require_admin_context
def group_update(context, group_id, payload): def group_update(context, group_id, payload):
with get_write_connection() as conn: with get_write_connection() as conn:
new_group_id = group_id new_group_id = group_id
if 'group' in payload and 'local_user_ids' in payload: if "group" in payload and "local_user_ids" in payload:
group = payload['group'] group = payload["group"]
new_group_id = group.get('id') new_group_id = group.get("id")
# local_user_id_list is a sorted list of user IDs that # local_user_id_list is a sorted list of user IDs that
# belong to this group # belong to this group
local_user_id_list = payload['local_user_ids'] local_user_id_list = payload["local_user_ids"]
user_group_memberships = query(conn, 'user_group_membership', user_group_memberships = query(
'group_id', group_id) conn, "user_group_membership", "group_id", group_id
)
existing_user_list = [ existing_user_list = [
user_group_membership['user_id'] for user_group_membership in user_group_membership["user_id"]
user_group_memberships for user_group_membership in user_group_memberships
] ]
existing_user_list.sort() existing_user_list.sort()
deleted = False deleted = False
@ -449,24 +458,23 @@ def group_update(context, group_id, payload):
# before updating group if groups IDs are different. # before updating group if groups IDs are different.
# Alternatively, if there is a discrepency in the user group memberships, # Alternatively, if there is a discrepency in the user group memberships,
# delete and re-create them # delete and re-create them
if (group_id != new_group_id) or ( if (group_id != new_group_id) or (local_user_id_list != existing_user_list):
local_user_id_list != existing_user_list): delete(conn, "user_group_membership", "group_id", group_id)
delete(conn, 'user_group_membership', 'group_id', group_id)
deleted = True deleted = True
# Update group table # Update group table
update(conn, 'group', 'id', group_id, group) update(conn, "group", "id", group_id, group)
if deleted: if deleted:
for local_user_id in local_user_id_list: for local_user_id in local_user_id_list:
item = {'user_id': local_user_id, 'group_id': new_group_id} item = {"user_id": local_user_id, "group_id": new_group_id}
insert(conn, 'user_group_membership', item) insert(conn, "user_group_membership", item)
# Need to update the actor_id in assignment and system_assignment # Need to update the actor_id in assignment and system_assignment
# tables if the group id is updated # tables if the group id is updated
if group_id != new_group_id: if group_id != new_group_id:
assignment = {'actor_id': new_group_id} assignment = {"actor_id": new_group_id}
update(conn, 'assignment', 'actor_id', group_id, assignment) update(conn, "assignment", "actor_id", group_id, assignment)
update(conn, 'system_assignment', 'actor_id', group_id, assignment) update(conn, "system_assignment", "actor_id", group_id, assignment)
return group_get(context, new_group_id) return group_get(context, new_group_id)
@ -477,16 +485,17 @@ def group_update(context, group_id, payload):
################### ###################
@require_context @require_context
def project_get_all(context): def project_get_all(context):
result = [] result = []
with get_read_connection() as conn: with get_read_connection() as conn:
# project table # project table
projects = query(conn, 'project') projects = query(conn, "project")
for project in projects: for project in projects:
project_consolidated = {'project': project} project_consolidated = {"project": project}
result.append(project_consolidated) result.append(project_consolidated)
return result return result
@ -498,29 +507,29 @@ def project_get(context, project_id):
with get_read_connection() as conn: with get_read_connection() as conn:
# project table # project table
projects = query(conn, 'project', 'id', project_id) projects = query(conn, "project", "id", project_id)
if not projects: if not projects:
raise exception.ProjectNotFound(project_id=project_id) raise exception.ProjectNotFound(project_id=project_id)
result['project'] = projects[0] result["project"] = projects[0]
return result return result
@require_admin_context @require_admin_context
def project_create(context, payload): def project_create(context, payload):
projects = [payload['project']] projects = [payload["project"]]
with get_write_connection() as conn: with get_write_connection() as conn:
insert(conn, 'project', projects) insert(conn, "project", projects)
return project_get(context, payload['project']['id']) return project_get(context, payload["project"]["id"])
@require_admin_context @require_admin_context
def project_update(context, project_id, payload): def project_update(context, project_id, payload):
with get_write_connection() as conn: with get_write_connection() as conn:
# project table # project table
table = 'project' table = "project"
new_project_id = project_id new_project_id = project_id
if table in payload: if table in payload:
domain_ref_projects = [] domain_ref_projects = []
@ -528,53 +537,51 @@ def project_update(context, project_id, payload):
domain_ref_users = [] domain_ref_users = []
domain_ref_local_users = [] domain_ref_local_users = []
project = payload[table] project = payload[table]
new_project_id = project.get('id') new_project_id = project.get("id")
if project_id != new_project_id: if project_id != new_project_id:
domain_ref_projects = query(conn, 'project', 'domain_id', domain_ref_projects = query(conn, "project", "domain_id", project_id)
project_id) delete(conn, "project", "domain_id", project_id)
delete(conn, 'project', 'domain_id', project_id) parent_ref_projects = query(conn, "project", "parent_id", project_id)
parent_ref_projects = query(conn, 'project', 'parent_id', delete(conn, "project", "parent_id", project_id)
project_id)
delete(conn, 'project', 'parent_id', project_id)
# For user table: CONSTRAINT `user_ibfk_1` # For user table: CONSTRAINT `user_ibfk_1`
# FOREIGN KEY(`domain_id`) REFERENCES `project`(`id`) # FOREIGN KEY(`domain_id`) REFERENCES `project`(`id`)
domain_ref_users = query(conn, 'user', 'domain_id', domain_ref_users = query(conn, "user", "domain_id", project_id)
project_id) domain_ref_local_users = query(
domain_ref_local_users = query(conn, 'local_user', conn, "local_user", "domain_id", project_id
'domain_id', project_id) )
delete(conn, 'user', 'domain_id', project_id) delete(conn, "user", "domain_id", project_id)
# Update project table # Update project table
update(conn, table, 'id', project_id, project) update(conn, table, "id", project_id, project)
# Update saved records from project table and insert them back # Update saved records from project table and insert them back
if domain_ref_projects: if domain_ref_projects:
for domain_ref_project in domain_ref_projects: for domain_ref_project in domain_ref_projects:
domain_ref_project['domain_id'] = new_project_id domain_ref_project["domain_id"] = new_project_id
if domain_ref_project['parent_id'] == project_id: if domain_ref_project["parent_id"] == project_id:
domain_ref_project['parent_id'] = new_project_id domain_ref_project["parent_id"] = new_project_id
insert(conn, 'project', domain_ref_projects) insert(conn, "project", domain_ref_projects)
if parent_ref_projects: if parent_ref_projects:
for parent_ref_project in parent_ref_projects: for parent_ref_project in parent_ref_projects:
parent_ref_project['parent_id'] = new_project_id parent_ref_project["parent_id"] = new_project_id
if parent_ref_project['domain_id'] == project_id: if parent_ref_project["domain_id"] == project_id:
parent_ref_project['domain_id'] = new_project_id parent_ref_project["domain_id"] = new_project_id
insert(conn, 'project', parent_ref_projects) insert(conn, "project", parent_ref_projects)
if domain_ref_users: if domain_ref_users:
for domain_ref_user in domain_ref_users: for domain_ref_user in domain_ref_users:
domain_ref_user['domain_id'] = new_project_id domain_ref_user["domain_id"] = new_project_id
insert(conn, 'user', domain_ref_users) insert(conn, "user", domain_ref_users)
if domain_ref_local_users: if domain_ref_local_users:
for domain_ref_local_user in domain_ref_local_users: for domain_ref_local_user in domain_ref_local_users:
domain_ref_local_user['domain_id'] = new_project_id domain_ref_local_user["domain_id"] = new_project_id
insert(conn, 'local_user', domain_ref_local_users) insert(conn, "local_user", domain_ref_local_users)
# Need to update the target_id in assignment table # Need to update the target_id in assignment table
# if the project id is updated # if the project id is updated
if project_id != new_project_id: if project_id != new_project_id:
table = 'assignment' table = "assignment"
assignment = {'target_id': new_project_id} assignment = {"target_id": new_project_id}
update(conn, table, 'target_id', project_id, assignment) update(conn, table, "target_id", project_id, assignment)
return project_get(context, new_project_id) return project_get(context, new_project_id)
@ -585,16 +592,17 @@ def project_update(context, project_id, payload):
################### ###################
@require_context @require_context
def role_get_all(context): def role_get_all(context):
result = [] result = []
with get_read_connection() as conn: with get_read_connection() as conn:
# role table # role table
roles = query(conn, 'role') roles = query(conn, "role")
for role in roles: for role in roles:
role_consolidated = {'role': role} role_consolidated = {"role": role}
result.append(role_consolidated) result.append(role_consolidated)
return result return result
@ -606,77 +614,75 @@ def role_get(context, role_id):
with get_read_connection() as conn: with get_read_connection() as conn:
# role table # role table
roles = query(conn, 'role', 'id', role_id) roles = query(conn, "role", "id", role_id)
if not roles: if not roles:
raise exception.RoleNotFound(role_id=role_id) raise exception.RoleNotFound(role_id=role_id)
result['role'] = roles[0] result["role"] = roles[0]
return result return result
@require_admin_context @require_admin_context
def role_create(context, payload): def role_create(context, payload):
roles = [payload['role']] roles = [payload["role"]]
with get_write_connection() as conn: with get_write_connection() as conn:
insert(conn, 'role', roles) insert(conn, "role", roles)
return role_get(context, payload['role']['id']) return role_get(context, payload["role"]["id"])
@require_admin_context @require_admin_context
def role_update(context, role_id, payload): def role_update(context, role_id, payload):
with get_write_connection() as conn: with get_write_connection() as conn:
# role table # role table
table = 'role' table = "role"
new_role_id = role_id new_role_id = role_id
if table in payload: if table in payload:
prior_roles = [] prior_roles = []
implied_roles = [] implied_roles = []
role_options = [] role_options = []
role = payload[table] role = payload[table]
new_role_id = role.get('id') new_role_id = role.get("id")
if role_id != new_role_id: if role_id != new_role_id:
# implied_role table has foreign key references to role table. # implied_role table has foreign key references to role table.
# The foreign key references are on DELETE CASCADE only. To # The foreign key references are on DELETE CASCADE only. To
# avoid foreign key constraints violation, save these records # avoid foreign key constraints violation, save these records
# from implied_role table, delete them, update role table, # from implied_role table, delete them, update role table,
# update and insert them back after role table is updated. # update and insert them back after role table is updated.
prior_roles = query(conn, 'implied_role', 'prior_role_id', prior_roles = query(conn, "implied_role", "prior_role_id", role_id)
role_id) delete(conn, "implied_role", "prior_role_id", role_id)
delete(conn, 'implied_role', 'prior_role_id', role_id) implied_roles = query(conn, "implied_role", "implied_role_id", role_id)
implied_roles = query(conn, 'implied_role', 'implied_role_id', delete(conn, "implied_role", "implied_role_id", role_id)
role_id)
delete(conn, 'implied_role', 'implied_role_id', role_id)
# Delete the role_option record referencing to the old role_id # Delete the role_option record referencing to the old role_id
# to avoid the foreign key constraint violation when we update # to avoid the foreign key constraint violation when we update
# the role table in the next step. # the role table in the next step.
role_options = query(conn, 'role_option', 'role_id', role_id) role_options = query(conn, "role_option", "role_id", role_id)
delete(conn, 'role_option', 'role_id', role_id) delete(conn, "role_option", "role_id", role_id)
else: else:
role.pop('id', None) role.pop("id", None)
# Update role table # Update role table
update(conn, table, 'id', role_id, role) update(conn, table, "id", role_id, role)
# Update saved records from implied_role table and insert them back # Update saved records from implied_role table and insert them back
if prior_roles: if prior_roles:
for prior_role in prior_roles: for prior_role in prior_roles:
prior_role['prior_role_id'] = new_role_id prior_role["prior_role_id"] = new_role_id
insert(conn, 'implied_role', prior_roles) insert(conn, "implied_role", prior_roles)
if implied_roles: if implied_roles:
for implied_role in implied_roles: for implied_role in implied_roles:
implied_role['implied_role_id'] = new_role_id implied_role["implied_role_id"] = new_role_id
insert(conn, 'implied_role', implied_roles) insert(conn, "implied_role", implied_roles)
if role_options: if role_options:
for role_option in role_options: for role_option in role_options:
role_option['role_id'] = new_role_id role_option["role_id"] = new_role_id
insert(conn, 'role_option', role_option) insert(conn, "role_option", role_option)
# Need to update the role_id in assignment and system_assignment tables # Need to update the role_id in assignment and system_assignment tables
# if the role id is updated # if the role id is updated
if role_id != new_role_id: if role_id != new_role_id:
assignment = {'role_id': new_role_id} assignment = {"role_id": new_role_id}
update(conn, 'assignment', 'role_id', role_id, assignment) update(conn, "assignment", "role_id", role_id, assignment)
update(conn, 'system_assignment', 'role_id', role_id, assignment) update(conn, "system_assignment", "role_id", role_id, assignment)
return role_get(context, new_role_id) return role_get(context, new_role_id)
@ -687,16 +693,17 @@ def role_update(context, role_id, payload):
################################## ##################################
@require_context @require_context
def revoke_event_get_all(context): def revoke_event_get_all(context):
result = [] result = []
with get_read_connection() as conn: with get_read_connection() as conn:
# revocation_event table # revocation_event table
revoke_events = query(conn, 'revocation_event') revoke_events = query(conn, "revocation_event")
for revoke_event in revoke_events: for revoke_event in revoke_events:
revoke_event_consolidated = {'revocation_event': revoke_event} revoke_event_consolidated = {"revocation_event": revoke_event}
result.append(revoke_event_consolidated) result.append(revoke_event_consolidated)
return result return result
@ -708,11 +715,10 @@ def revoke_event_get_by_audit(context, audit_id):
with get_read_connection() as conn: with get_read_connection() as conn:
# revocation_event table # revocation_event table
revoke_events = query(conn, 'revocation_event', 'audit_id', revoke_events = query(conn, "revocation_event", "audit_id", audit_id)
audit_id)
if not revoke_events: if not revoke_events:
raise exception.RevokeEventNotFound() raise exception.RevokeEventNotFound()
result['revocation_event'] = revoke_events[0] result["revocation_event"] = revoke_events[0]
return result return result
@ -723,48 +729,49 @@ def revoke_event_get_by_user(context, user_id, issued_before):
with get_read_connection() as conn: with get_read_connection() as conn:
# revocation_event table # revocation_event table
events = query(conn, 'revocation_event', 'user_id', user_id) events = query(conn, "revocation_event", "user_id", user_id)
revoke_events = [event for event in events if revoke_events = [
str(event['issued_before']) == issued_before] event for event in events if str(event["issued_before"]) == issued_before
]
if not revoke_events: if not revoke_events:
raise exception.RevokeEventNotFound() raise exception.RevokeEventNotFound()
result['revocation_event'] = revoke_events[0] result["revocation_event"] = revoke_events[0]
return result return result
@require_admin_context @require_admin_context
def revoke_event_create(context, payload): def revoke_event_create(context, payload):
revoke_event = payload['revocation_event'] revoke_event = payload["revocation_event"]
# ignore auto generated id # ignore auto generated id
revoke_event.pop('id', None) revoke_event.pop("id", None)
revoke_events = [revoke_event] revoke_events = [revoke_event]
with get_write_connection() as conn: with get_write_connection() as conn:
insert(conn, 'revocation_event', revoke_events) insert(conn, "revocation_event", revoke_events)
result = {} result = {}
if revoke_event.get('audit_id') is not None: if revoke_event.get("audit_id") is not None:
result = revoke_event_get_by_audit(context, result = revoke_event_get_by_audit(context, revoke_event.get("audit_id"))
revoke_event.get('audit_id')) elif (revoke_event.get("user_id") is not None) and (
elif (revoke_event.get('user_id') is not None) and \ revoke_event.get("issued_before") is not None
(revoke_event.get('issued_before') is not None): ):
result = revoke_event_get_by_user(context, result = revoke_event_get_by_user(
revoke_event.get('user_id'), context, revoke_event.get("user_id"), revoke_event.get("issued_before")
revoke_event.get('issued_before')) )
return result return result
@require_admin_context @require_admin_context
def revoke_event_delete_by_audit(context, audit_id): def revoke_event_delete_by_audit(context, audit_id):
with get_write_connection() as conn: with get_write_connection() as conn:
delete(conn, 'revocation_event', 'audit_id', audit_id) delete(conn, "revocation_event", "audit_id", audit_id)
@require_admin_context @require_admin_context
def revoke_event_delete_by_user(context, user_id, issued_before): def revoke_event_delete_by_user(context, user_id, issued_before):
result = revoke_event_get_by_user(context, user_id, issued_before) result = revoke_event_get_by_user(context, user_id, issued_before)
event_id = result['revocation_event']['id'] event_id = result["revocation_event"]["id"]
with get_write_connection() as conn: with get_write_connection() as conn:
delete(conn, 'revocation_event', 'id', event_id) delete(conn, "revocation_event", "id", event_id)

View File

@ -13,7 +13,7 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
# #
# Copyright (c) 2019, 2022 Wind River Systems, Inc. # Copyright (c) 2019, 2022, 2024 Wind River Systems, Inc.
# #
# SPDX-License-Identifier: Apache-2.0 # SPDX-License-Identifier: Apache-2.0
# #
@ -50,8 +50,8 @@ class LazyPluggable(object):
return getattr(backend, key) return getattr(backend, key)
IMPL = LazyPluggable('backend', sqlalchemy='dcdbsync.db.sqlalchemy.api') IMPL = LazyPluggable("backend", sqlalchemy="dcdbsync.db.sqlalchemy.api")
def purge_deleted(age, granularity='days'): def purge_deleted(age, granularity="days"):
IMPL.purge_deleted(age, granularity) IMPL.purge_deleted(age, granularity)

View File

@ -26,7 +26,7 @@ from dcdbsync.dbsyncclient import exceptions
class Resource(object): class Resource(object):
# This will be overridden by the actual resource # This will be overridden by the actual resource
resource_name = 'Something' resource_name = "Something"
class ResourceManager(object): class ResourceManager(object):
@ -40,9 +40,11 @@ class ResourceManager(object):
resource = [] resource = []
for json_object in json_objects: for json_object in json_objects:
for resource_data in json_object: for resource_data in json_object:
resource.append(self.resource_class( # pylint: disable=E1102 resource.append(
self, resource_data, self.resource_class( # pylint: disable=E1102
json_object[resource_data])) self, resource_data, json_object[resource_data]
)
)
return resource return resource
def _list(self, url, response_key=None): def _list(self, url, response_key=None):
@ -75,11 +77,15 @@ class ResourceManager(object):
json_objects = [json_response_key[item] for item in json_response_key] json_objects = [json_response_key[item] for item in json_response_key]
resource = [] resource = []
for json_object in json_objects: for json_object in json_objects:
for values in json_object.get('usage').keys(): for values in json_object.get("usage").keys():
resource.append(self.resource_class( # pylint: disable=E1102 resource.append(
self, values, self.resource_class( # pylint: disable=E1102
json_object['limits'][values], self,
json_object['usage'][values])) values,
json_object["limits"][values],
json_object["usage"][values],
)
)
return resource return resource
def _delete(self, url): def _delete(self, url):
@ -89,23 +95,24 @@ class ResourceManager(object):
def _raise_api_exception(self, resp): def _raise_api_exception(self, resp):
error_html = resp.content error_html = resp.content
soup = BeautifulSoup(error_html, 'html.parser') soup = BeautifulSoup(error_html, "html.parser")
# Get the raw html with get_text, strip out the blank lines on # Get the raw html with get_text, strip out the blank lines on
# front and back, then get rid of the 2 lines of error code number # front and back, then get rid of the 2 lines of error code number
# and error code explanation so that we are left with just the # and error code explanation so that we are left with just the
# meaningful error text. # meaningful error text.
try: try:
error_msg = soup.body.get_text().lstrip().rstrip().split('\n')[2] error_msg = soup.body.get_text().lstrip().rstrip().split("\n")[2]
except Exception: except Exception:
error_msg = resp.content error_msg = resp.content
raise exceptions.APIException(error_code=resp.status_code, raise exceptions.APIException(
error_message=error_msg) error_code=resp.status_code, error_message=error_msg
)
def get_json(response): def get_json(response):
"""Get JSON representation of response.""" """Get JSON representation of response."""
json_field_or_function = getattr(response, 'json', None) json_field_or_function = getattr(response, "json", None)
if callable(json_field_or_function): if callable(json_field_or_function):
return response.json() return response.json()
else: else:

View File

@ -20,14 +20,28 @@
from dcdbsync.dbsyncclient.v1 import client as client_v1 from dcdbsync.dbsyncclient.v1 import client as client_v1
def Client(dbsync_agent_url=None, username=None, api_key=None, def Client(
project_name=None, auth_url=None, project_id=None, dbsync_agent_url=None,
endpoint_type='publicURL', service_type='dcorch-dbsync', username=None,
auth_token=None, user_id=None, cacert=None, insecure=False, api_key=None,
profile=None, auth_type='keystone', client_id=None, project_name=None,
client_secret=None, session=None, **kwargs): auth_url=None,
project_id=None,
endpoint_type="publicURL",
service_type="dcorch-dbsync",
auth_token=None,
user_id=None,
cacert=None,
insecure=False,
profile=None,
auth_type="keystone",
client_id=None,
client_secret=None,
session=None,
**kwargs
):
if dbsync_agent_url and not isinstance(dbsync_agent_url, str): if dbsync_agent_url and not isinstance(dbsync_agent_url, str):
raise RuntimeError('DC DBsync agent url should be a string.') raise RuntimeError("DC DBsync agent url should be a string.")
return client_v1.Client( return client_v1.Client(
dbsync_agent_url=dbsync_agent_url, dbsync_agent_url=dbsync_agent_url,

View File

@ -12,7 +12,7 @@
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
# #
# Copyright (c) 2019-2020 Wind River Systems, Inc. # Copyright (c) 2019-2020, 2024 Wind River Systems, Inc.
# #
# SPDX-License-Identifier: Apache-2.0 # SPDX-License-Identifier: Apache-2.0
# #
@ -24,6 +24,7 @@ class DBsyncClientException(Exception):
To correctly use this class, inherit from it and define To correctly use this class, inherit from it and define
a 'message' and 'code' properties. a 'message' and 'code' properties.
""" """
message = "An unknown exception occurred" message = "An unknown exception occurred"
code = "UNKNOWN_EXCEPTION" code = "UNKNOWN_EXCEPTION"
@ -33,7 +34,8 @@ class DBsyncClientException(Exception):
def __init__(self, message=message): def __init__(self, message=message):
self.message = message self.message = message
super(DBsyncClientException, self).__init__( super(DBsyncClientException, self).__init__(
'%s: %s' % (self.code, self.message)) "%s: %s" % (self.code, self.message)
)
class IllegalArgumentException(DBsyncClientException): class IllegalArgumentException(DBsyncClientException):

View File

@ -36,16 +36,23 @@ LOG = logging.getLogger(__name__)
def log_request(func): def log_request(func):
def decorator(self, *args, **kwargs): def decorator(self, *args, **kwargs):
resp = func(self, *args, **kwargs) resp = func(self, *args, **kwargs)
LOG.debug("HTTP %s %s %d" % (resp.request.method, resp.url, LOG.debug("HTTP %s %s %d" % (resp.request.method, resp.url, resp.status_code))
resp.status_code))
return resp return resp
return decorator return decorator
class HTTPClient(object): class HTTPClient(object):
def __init__(self, base_url, token=None, project_id=None, user_id=None, def __init__(
cacert=None, insecure=False, request_timeout=None): self,
base_url,
token=None,
project_id=None,
user_id=None,
cacert=None,
insecure=False,
request_timeout=None,
):
self.base_url = base_url self.base_url = base_url
self.token = token self.token = token
self.project_id = project_id self.project_id = project_id
@ -53,117 +60,117 @@ class HTTPClient(object):
self.ssl_options = {} self.ssl_options = {}
self.request_timeout = request_timeout self.request_timeout = request_timeout
if self.base_url.startswith('https'): if self.base_url.startswith("https"):
if cacert and not os.path.exists(cacert): if cacert and not os.path.exists(cacert):
raise ValueError('Unable to locate cacert file ' raise ValueError("Unable to locate cacert file at %s." % cacert)
'at %s.' % cacert)
if cacert and insecure: if cacert and insecure:
LOG.warning('Client is set to not verify even though ' LOG.warning(
'cacert is provided.') "Client is set to not verify even though cacert is provided."
)
self.ssl_options['verify'] = not insecure self.ssl_options["verify"] = not insecure
self.ssl_options['cert'] = cacert self.ssl_options["cert"] = cacert
@log_request @log_request
def get(self, url, headers=None): def get(self, url, headers=None):
options = self._get_request_options('get', headers) options = self._get_request_options("get", headers)
try: try:
url = self.base_url + url url = self.base_url + url
timeout = self.request_timeout timeout = self.request_timeout
return requests.get(url, timeout=timeout, **options) return requests.get(url, timeout=timeout, **options)
except requests.exceptions.Timeout: except requests.exceptions.Timeout:
msg = 'Request to %s timed out' % url msg = "Request to %s timed out" % url
raise exceptions.ConnectTimeout(msg) raise exceptions.ConnectTimeout(msg)
except requests.exceptions.ConnectionError as e: except requests.exceptions.ConnectionError as e:
msg = 'Unable to establish connection to %s: %s' % (url, e) msg = "Unable to establish connection to %s: %s" % (url, e)
raise exceptions.ConnectFailure(msg) raise exceptions.ConnectFailure(msg)
except requests.exceptions.RequestException as e: except requests.exceptions.RequestException as e:
msg = 'Unexpected exception for %s: %s' % (url, e) msg = "Unexpected exception for %s: %s" % (url, e)
raise exceptions.UnknownConnectionError(msg) raise exceptions.UnknownConnectionError(msg)
@log_request @log_request
def post(self, url, body, headers=None): def post(self, url, body, headers=None):
options = self._get_request_options('post', headers) options = self._get_request_options("post", headers)
try: try:
url = self.base_url + url url = self.base_url + url
timeout = self.request_timeout timeout = self.request_timeout
return requests.post(url, body, timeout=timeout, **options) return requests.post(url, body, timeout=timeout, **options)
except requests.exceptions.Timeout: except requests.exceptions.Timeout:
msg = 'Request to %s timed out' % url msg = "Request to %s timed out" % url
raise exceptions.ConnectTimeout(msg) raise exceptions.ConnectTimeout(msg)
except requests.exceptions.ConnectionError as e: except requests.exceptions.ConnectionError as e:
msg = 'Unable to establish connection to %s: %s' % (url, e) msg = "Unable to establish connection to %s: %s" % (url, e)
raise exceptions.ConnectFailure(msg) raise exceptions.ConnectFailure(msg)
except requests.exceptions.RequestException as e: except requests.exceptions.RequestException as e:
msg = 'Unexpected exception for %s: %s' % (url, e) msg = "Unexpected exception for %s: %s" % (url, e)
raise exceptions.UnknownConnectionError(msg) raise exceptions.UnknownConnectionError(msg)
@log_request @log_request
def put(self, url, body, headers=None): def put(self, url, body, headers=None):
options = self._get_request_options('put', headers) options = self._get_request_options("put", headers)
try: try:
url = self.base_url + url url = self.base_url + url
timeout = self.request_timeout timeout = self.request_timeout
return requests.put(url, body, timeout=timeout, **options) return requests.put(url, body, timeout=timeout, **options)
except requests.exceptions.Timeout: except requests.exceptions.Timeout:
msg = 'Request to %s timed out' % url msg = "Request to %s timed out" % url
raise exceptions.ConnectTimeout(msg) raise exceptions.ConnectTimeout(msg)
except requests.exceptions.ConnectionError as e: except requests.exceptions.ConnectionError as e:
msg = 'Unable to establish connection to %s: %s' % (url, e) msg = "Unable to establish connection to %s: %s" % (url, e)
raise exceptions.ConnectFailure(msg) raise exceptions.ConnectFailure(msg)
except requests.exceptions.RequestException as e: except requests.exceptions.RequestException as e:
msg = 'Unexpected exception for %s: %s' % (url, e) msg = "Unexpected exception for %s: %s" % (url, e)
raise exceptions.UnknownConnectionError(msg) raise exceptions.UnknownConnectionError(msg)
@log_request @log_request
def patch(self, url, body, headers=None): def patch(self, url, body, headers=None):
options = self._get_request_options('patch', headers) options = self._get_request_options("patch", headers)
try: try:
url = self.base_url + url url = self.base_url + url
timeout = self.request_timeout timeout = self.request_timeout
return requests.patch(url, body, timeout=timeout, **options) return requests.patch(url, body, timeout=timeout, **options)
except requests.exceptions.Timeout: except requests.exceptions.Timeout:
msg = 'Request to %s timed out' % url msg = "Request to %s timed out" % url
raise exceptions.ConnectTimeout(msg) raise exceptions.ConnectTimeout(msg)
except requests.exceptions.ConnectionError as e: except requests.exceptions.ConnectionError as e:
msg = 'Unable to establish connection to %s: %s' % (url, e) msg = "Unable to establish connection to %s: %s" % (url, e)
raise exceptions.ConnectFailure(msg) raise exceptions.ConnectFailure(msg)
except requests.exceptions.RequestException as e: except requests.exceptions.RequestException as e:
msg = 'Unexpected exception for %s: %s' % (url, e) msg = "Unexpected exception for %s: %s" % (url, e)
raise exceptions.UnknownConnectionError(msg) raise exceptions.UnknownConnectionError(msg)
@log_request @log_request
def delete(self, url, headers=None): def delete(self, url, headers=None):
options = self._get_request_options('delete', headers) options = self._get_request_options("delete", headers)
try: try:
url = self.base_url + url url = self.base_url + url
timeout = self.request_timeout timeout = self.request_timeout
return requests.delete(url, timeout=timeout, **options) return requests.delete(url, timeout=timeout, **options)
except requests.exceptions.Timeout: except requests.exceptions.Timeout:
msg = 'Request to %s timed out' % url msg = "Request to %s timed out" % url
raise exceptions.ConnectTimeout(msg) raise exceptions.ConnectTimeout(msg)
except requests.exceptions.ConnectionError as e: except requests.exceptions.ConnectionError as e:
msg = 'Unable to establish connection to %s: %s' % (url, e) msg = "Unable to establish connection to %s: %s" % (url, e)
raise exceptions.ConnectFailure(msg) raise exceptions.ConnectFailure(msg)
except requests.exceptions.RequestException as e: except requests.exceptions.RequestException as e:
msg = 'Unexpected exception for %s: %s' % (url, e) msg = "Unexpected exception for %s: %s" % (url, e)
raise exceptions.UnknownConnectionError(msg) raise exceptions.UnknownConnectionError(msg)
def _get_request_options(self, method, headers): def _get_request_options(self, method, headers):
headers = self._update_headers(headers) headers = self._update_headers(headers)
if method in ['post', 'put', 'patch']: if method in ["post", "put", "patch"]:
content_type = headers.get('content-type', 'application/json') content_type = headers.get("content-type", "application/json")
headers['content-type'] = content_type headers["content-type"] = content_type
options = copy.deepcopy(self.ssl_options) options = copy.deepcopy(self.ssl_options)
options['headers'] = headers options["headers"] = headers
return options return options
@ -171,17 +178,17 @@ class HTTPClient(object):
if not headers: if not headers:
headers = {} headers = {}
token = headers.get('x-auth-token', self.token) token = headers.get("x-auth-token", self.token)
if token: if token:
headers['x-auth-token'] = token headers["x-auth-token"] = token
project_id = headers.get('X-Project-Id', self.project_id) project_id = headers.get("X-Project-Id", self.project_id)
if project_id: if project_id:
headers['X-Project-Id'] = project_id headers["X-Project-Id"] = project_id
user_id = headers.get('X-User-Id', self.user_id) user_id = headers.get("X-User-Id", self.user_id)
if user_id: if user_id:
headers['X-User-Id'] = user_id headers["X-User-Id"] = user_id
# Add headers for osprofiler. # Add headers for osprofiler.
if osprofiler_web: if osprofiler_web:

View File

@ -28,8 +28,7 @@ from dcdbsync.dbsyncclient.v1.identity import identity_group_manager as igm
from dcdbsync.dbsyncclient.v1.identity import identity_user_manager as ium from dcdbsync.dbsyncclient.v1.identity import identity_user_manager as ium
from dcdbsync.dbsyncclient.v1.identity import project_manager as pm from dcdbsync.dbsyncclient.v1.identity import project_manager as pm
from dcdbsync.dbsyncclient.v1.identity import role_manager as rm from dcdbsync.dbsyncclient.v1.identity import role_manager as rm
from dcdbsync.dbsyncclient.v1.identity \ from dcdbsync.dbsyncclient.v1.identity import token_revoke_event_manager as trem
import token_revoke_event_manager as trem
osprofiler_profiler = importutils.try_import("osprofiler.profiler") osprofiler_profiler = importutils.try_import("osprofiler.profiler")
@ -41,20 +40,34 @@ _DEFAULT_REQUEST_TIMEOUT = 15
class Client(object): class Client(object):
"""Class where the communication from KB to Keystone happens.""" """Class where the communication from KB to Keystone happens."""
def __init__(self, dbsync_agent_url=None, username=None, api_key=None, def __init__(
project_name=None, auth_url=None, project_id=None, self,
endpoint_type='publicURL', service_type='dcorch-dbsync', dbsync_agent_url=None,
auth_token=None, user_id=None, cacert=None, insecure=False, username=None,
profile=None, auth_type='keystone', client_id=None, api_key=None,
client_secret=None, session=None, **kwargs): project_name=None,
auth_url=None,
project_id=None,
endpoint_type="publicURL",
service_type="dcorch-dbsync",
auth_token=None,
user_id=None,
cacert=None,
insecure=False,
profile=None,
auth_type="keystone",
client_id=None,
client_secret=None,
session=None,
**kwargs
):
"""Communicates with Keystone to fetch necessary values.""" """Communicates with Keystone to fetch necessary values."""
if dbsync_agent_url and not isinstance(dbsync_agent_url, str): if dbsync_agent_url and not isinstance(dbsync_agent_url, str):
raise RuntimeError('DC DBsync agent url should be a string.') raise RuntimeError("DC DBsync agent url should be a string.")
if auth_url or session: if auth_url or session:
if auth_type == 'keystone': if auth_type == "keystone":
(dbsync_agent_url, auth_token, project_id, user_id) = ( (dbsync_agent_url, auth_token, project_id, user_id) = authenticate(
authenticate(
dbsync_agent_url, dbsync_agent_url,
username, username,
api_key, api_key,
@ -70,11 +83,10 @@ class Client(object):
insecure, insecure,
**kwargs **kwargs
) )
)
else: else:
raise RuntimeError( raise RuntimeError(
'Invalid authentication type [value=%s, valid_values=%s]' "Invalid authentication type [value=%s, valid_values=%s]"
% (auth_type, 'keystone') % (auth_type, "keystone")
) )
if not dbsync_agent_url: if not dbsync_agent_url:
@ -103,8 +115,7 @@ class Client(object):
# update to get a new token # update to get a new token
def update(self, session=None): def update(self, session=None):
if session: if session:
(dbsync_agent_url, auth_token, project_id, user_id) = ( (dbsync_agent_url, auth_token, project_id, user_id) = authenticate(
authenticate(
auth_url=session.auth.auth_url, auth_url=session.auth.auth_url,
username=session.auth._username, username=session.auth._username,
api_key=session.auth._password, api_key=session.auth._password,
@ -112,30 +123,36 @@ class Client(object):
user_domain_name=session.auth._user_domain_name, user_domain_name=session.auth._user_domain_name,
project_domain_name=session.auth._project_domain_name, project_domain_name=session.auth._project_domain_name,
) )
)
self.http_client.token = auth_token self.http_client.token = auth_token
def authenticate(dbsync_agent_url=None, username=None, def authenticate(
api_key=None, project_name=None, auth_url=None, dbsync_agent_url=None,
project_id=None, endpoint_type='internalURL', username=None,
service_type='dcorch-dbsync', auth_token=None, user_id=None, api_key=None,
session=None, cacert=None, insecure=False, **kwargs): project_name=None,
auth_url=None,
project_id=None,
endpoint_type="internalURL",
service_type="dcorch-dbsync",
auth_token=None,
user_id=None,
session=None,
cacert=None,
insecure=False,
**kwargs
):
"""Get token, project_id, user_id and Endpoint.""" """Get token, project_id, user_id and Endpoint."""
if project_name and project_id: if project_name and project_id:
raise RuntimeError( raise RuntimeError("Only project name or project id should be set")
'Only project name or project id should be set'
)
if username and user_id: if username and user_id:
raise RuntimeError( raise RuntimeError("Only user name or user id should be set")
'Only user name or user id should be set' user_domain_name = kwargs.get("user_domain_name")
) user_domain_id = kwargs.get("user_domain_id")
user_domain_name = kwargs.get('user_domain_name') project_domain_name = kwargs.get("project_domain_name")
user_domain_id = kwargs.get('user_domain_id') project_domain_id = kwargs.get("project_domain_id")
project_domain_name = kwargs.get('project_domain_name')
project_domain_id = kwargs.get('project_domain_id')
if session is None: if session is None:
if auth_token: if auth_token:
@ -159,11 +176,14 @@ def authenticate(dbsync_agent_url=None, username=None,
user_domain_name=user_domain_name, user_domain_name=user_domain_name,
user_domain_id=user_domain_id, user_domain_id=user_domain_id,
project_domain_name=project_domain_name, project_domain_name=project_domain_name,
project_domain_id=project_domain_id) project_domain_id=project_domain_id,
)
else: else:
raise RuntimeError('You must either provide a valid token or' raise RuntimeError(
'a password (api_key) and a user.') "You must either provide a valid token or a password (api_key) "
"and a user."
)
if auth: if auth:
session = ks_session.Session(auth=auth) session = ks_session.Session(auth=auth)
@ -173,7 +193,7 @@ def authenticate(dbsync_agent_url=None, username=None,
user_id = session.get_user_id() user_id = session.get_user_id()
if not dbsync_agent_url: if not dbsync_agent_url:
dbsync_agent_url = session.get_endpoint( dbsync_agent_url = session.get_endpoint(
service_type=service_type, service_type=service_type, interface=endpoint_type
interface=endpoint_type) )
return dbsync_agent_url, token, project_id, user_id return dbsync_agent_url, token, project_id, user_id

View File

@ -13,7 +13,7 @@
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
# #
# Copyright (c) 2019-2021 Wind River Systems, Inc. # Copyright (c) 2019-2021, 2024 Wind River Systems, Inc.
# #
# SPDX-License-Identifier: Apache-2.0 # SPDX-License-Identifier: Apache-2.0
# #
@ -25,10 +25,11 @@ from dcdbsync.dbsyncclient import exceptions
class Group(base.Resource): class Group(base.Resource):
resource_name = 'group' resource_name = "group"
def __init__(self, manager, id, domain_id, name, def __init__(
description, local_user_ids, extra={}): self, manager, id, domain_id, name, description, local_user_ids, extra={}
):
self.manager = manager self.manager = manager
self.id = id self.id = id
self.domain_id = domain_id self.domain_id = domain_id
@ -39,10 +40,15 @@ class Group(base.Resource):
def info(self): def info(self):
resource_info = dict() resource_info = dict()
resource_info.update({self.resource_name: resource_info.update(
{'name': self.name, {
'id': self.id, self.resource_name: {
'domain_id': self.domain_id}}) "name": self.name,
"id": self.id,
"domain_id": self.domain_id,
}
}
)
return resource_info return resource_info
@ -55,7 +61,7 @@ class identity_group_manager(base.ResourceManager):
# Unauthorized request # Unauthorized request
if resp.status_code == 401: if resp.status_code == 401:
raise exceptions.Unauthorized('Unauthorized request.') raise exceptions.Unauthorized("Unauthorized request.")
if resp.status_code != 201: if resp.status_code != 201:
self._raise_api_exception(resp) self._raise_api_exception(resp)
@ -68,7 +74,7 @@ class identity_group_manager(base.ResourceManager):
# Unauthorized # Unauthorized
if resp.status_code == 401: if resp.status_code == 401:
raise exceptions.Unauthorized('Unauthorized request') raise exceptions.Unauthorized("Unauthorized request")
if resp.status_code != 200: if resp.status_code != 200:
self._raise_api_exception(resp) self._raise_api_exception(resp)
@ -79,12 +85,13 @@ class identity_group_manager(base.ResourceManager):
for json_object in json_objects: for json_object in json_objects:
group = Group( group = Group(
self, self,
id=json_object['group']['id'], id=json_object["group"]["id"],
domain_id=json_object['group']['domain_id'], domain_id=json_object["group"]["domain_id"],
name=json_object['group']['name'], name=json_object["group"]["name"],
extra=json_object['group']['extra'], extra=json_object["group"]["extra"],
description=json_object['group']['description'], description=json_object["group"]["description"],
local_user_ids=json_object['local_user_ids']) local_user_ids=json_object["local_user_ids"],
)
groups.append(group) groups.append(group)
@ -95,7 +102,7 @@ class identity_group_manager(base.ResourceManager):
# Unauthorized request # Unauthorized request
if resp.status_code == 401: if resp.status_code == 401:
raise exceptions.Unauthorized('Unauthorized request.') raise exceptions.Unauthorized("Unauthorized request.")
if resp.status_code != 200: if resp.status_code != 200:
self._raise_api_exception(resp) self._raise_api_exception(resp)
@ -108,7 +115,7 @@ class identity_group_manager(base.ResourceManager):
# Unauthorized request # Unauthorized request
if resp.status_code == 401: if resp.status_code == 401:
raise exceptions.Unauthorized('Unauthorized request.') raise exceptions.Unauthorized("Unauthorized request.")
if resp.status_code != 200: if resp.status_code != 200:
self._raise_api_exception(resp) self._raise_api_exception(resp)
@ -117,17 +124,17 @@ class identity_group_manager(base.ResourceManager):
return json_object return json_object
def add_group(self, data): def add_group(self, data):
url = '/identity/groups/' url = "/identity/groups/"
return self.group_create(url, data) return self.group_create(url, data)
def list_groups(self): def list_groups(self):
url = '/identity/groups/' url = "/identity/groups/"
return self.group_list(url) return self.group_list(url)
def group_detail(self, group_ref): def group_detail(self, group_ref):
url = '/identity/groups/%s' % group_ref url = "/identity/groups/%s" % group_ref
return self._group_detail(url) return self._group_detail(url)
def update_group(self, group_ref, data): def update_group(self, group_ref, data):
url = '/identity/groups/%s' % group_ref url = "/identity/groups/%s" % group_ref
return self._group_update(url, data) return self._group_update(url, data)

View File

@ -13,7 +13,7 @@
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
# #
# Copyright (c) 2019 Wind River Systems, Inc. # Copyright (c) 2019, 2024 Wind River Systems, Inc.
# #
# SPDX-License-Identifier: Apache-2.0 # SPDX-License-Identifier: Apache-2.0
# #
@ -25,11 +25,20 @@ from dcdbsync.dbsyncclient import exceptions
class Password(base.Resource): class Password(base.Resource):
resource_name = 'password' resource_name = "password"
def __init__(self, manager, id, local_user_id, self_service, def __init__(
password_hash, created_at, created_at_int, expires_at, self,
expires_at_int): manager,
id,
local_user_id,
self_service,
password_hash,
created_at,
created_at_int,
expires_at,
expires_at_int,
):
self.manager = manager self.manager = manager
self.id = id self.id = id
# Foreign key to local_user.id # Foreign key to local_user.id
@ -43,11 +52,19 @@ class Password(base.Resource):
class LocalUser(base.Resource): class LocalUser(base.Resource):
resource_name = 'localUser' resource_name = "localUser"
def __init__(self, manager, id, domain_id, name, user_id, def __init__(
failed_auth_count, failed_auth_at, self,
passwords=[]): manager,
id,
domain_id,
name,
user_id,
failed_auth_count,
failed_auth_at,
passwords=[],
):
self.manager = manager self.manager = manager
self.id = id self.id = id
self.domain_id = domain_id self.domain_id = domain_id
@ -59,11 +76,20 @@ class LocalUser(base.Resource):
class User(base.Resource): class User(base.Resource):
resource_name = 'user' resource_name = "user"
def __init__(self, manager, id, domain_id, default_project_id, def __init__(
enabled, created_at, last_active_at, local_user, self,
extra={}): manager,
id,
domain_id,
default_project_id,
enabled,
created_at,
last_active_at,
local_user,
extra={},
):
self.manager = manager self.manager = manager
self.id = id self.id = id
self.domain_id = domain_id self.domain_id = domain_id
@ -76,10 +102,15 @@ class User(base.Resource):
def info(self): def info(self):
resource_info = dict() resource_info = dict()
resource_info.update({self.resource_name: resource_info.update(
{'name': self.local_user.name, {
'id': self.id, self.resource_name: {
'domain_id': self.domain_id}}) "name": self.local_user.name,
"id": self.id,
"domain_id": self.domain_id,
}
}
)
return resource_info return resource_info
@ -92,7 +123,7 @@ class identity_user_manager(base.ResourceManager):
# Unauthorized request # Unauthorized request
if resp.status_code == 401: if resp.status_code == 401:
raise exceptions.Unauthorized('Unauthorized request.') raise exceptions.Unauthorized("Unauthorized request.")
if resp.status_code != 201: if resp.status_code != 201:
self._raise_api_exception(resp) self._raise_api_exception(resp)
@ -105,7 +136,7 @@ class identity_user_manager(base.ResourceManager):
# Unauthorized request # Unauthorized request
if resp.status_code == 401: if resp.status_code == 401:
raise exceptions.Unauthorized('Unauthorized request.') raise exceptions.Unauthorized("Unauthorized request.")
if resp.status_code != 200: if resp.status_code != 200:
self._raise_api_exception(resp) self._raise_api_exception(resp)
@ -115,43 +146,45 @@ class identity_user_manager(base.ResourceManager):
users = [] users = []
for json_object in json_objects: for json_object in json_objects:
passwords = [] passwords = []
for object in json_object['password']: for object in json_object["password"]:
# skip empty password # skip empty password
if not object: if not object:
continue continue
password = Password( password = Password(
self, self,
id=object['id'], id=object["id"],
local_user_id=object['local_user_id'], local_user_id=object["local_user_id"],
self_service=object['self_service'], self_service=object["self_service"],
password_hash=object['password_hash'], password_hash=object["password_hash"],
created_at=object['created_at'], created_at=object["created_at"],
created_at_int=object['created_at_int'], created_at_int=object["created_at_int"],
expires_at=object['expires_at'], expires_at=object["expires_at"],
expires_at_int=object['expires_at_int']) expires_at_int=object["expires_at_int"],
)
passwords.append(password) passwords.append(password)
local_user = LocalUser( local_user = LocalUser(
self, self,
id=json_object['local_user']['id'], id=json_object["local_user"]["id"],
domain_id=json_object['local_user']['domain_id'], domain_id=json_object["local_user"]["domain_id"],
name=json_object['local_user']['name'], name=json_object["local_user"]["name"],
user_id=json_object['local_user']['user_id'], user_id=json_object["local_user"]["user_id"],
failed_auth_count=json_object['local_user'][ failed_auth_count=json_object["local_user"]["failed_auth_count"],
'failed_auth_count'], failed_auth_at=json_object["local_user"]["failed_auth_at"],
failed_auth_at=json_object['local_user']['failed_auth_at'], passwords=passwords,
passwords=passwords) )
user = User( user = User(
self, self,
id=json_object['user']['id'], id=json_object["user"]["id"],
domain_id=json_object['user']['domain_id'], domain_id=json_object["user"]["domain_id"],
default_project_id=json_object['user']['default_project_id'], default_project_id=json_object["user"]["default_project_id"],
enabled=json_object['user']['enabled'], enabled=json_object["user"]["enabled"],
created_at=json_object['user']['created_at'], created_at=json_object["user"]["created_at"],
last_active_at=json_object['user']['last_active_at'], last_active_at=json_object["user"]["last_active_at"],
extra=json_object['user']['extra'], extra=json_object["user"]["extra"],
local_user=local_user) local_user=local_user,
)
users.append(user) users.append(user)
@ -162,7 +195,7 @@ class identity_user_manager(base.ResourceManager):
# Unauthorized request # Unauthorized request
if resp.status_code == 401: if resp.status_code == 401:
raise exceptions.Unauthorized('Unauthorized request.') raise exceptions.Unauthorized("Unauthorized request.")
if resp.status_code != 200: if resp.status_code != 200:
self._raise_api_exception(resp) self._raise_api_exception(resp)
@ -175,7 +208,7 @@ class identity_user_manager(base.ResourceManager):
# Unauthorized request # Unauthorized request
if resp.status_code == 401: if resp.status_code == 401:
raise exceptions.Unauthorized('Unauthorized request.') raise exceptions.Unauthorized("Unauthorized request.")
if resp.status_code != 200: if resp.status_code != 200:
self._raise_api_exception(resp) self._raise_api_exception(resp)
@ -184,17 +217,17 @@ class identity_user_manager(base.ResourceManager):
return json_object return json_object
def add_user(self, data): def add_user(self, data):
url = '/identity/users/' url = "/identity/users/"
return self.user_create(url, data) return self.user_create(url, data)
def list_users(self): def list_users(self):
url = '/identity/users/' url = "/identity/users/"
return self.users_list(url) return self.users_list(url)
def user_detail(self, user_ref): def user_detail(self, user_ref):
url = '/identity/users/%s' % user_ref url = "/identity/users/%s" % user_ref
return self._user_detail(url) return self._user_detail(url)
def update_user(self, user_ref, data): def update_user(self, user_ref, data):
url = '/identity/users/%s' % user_ref url = "/identity/users/%s" % user_ref
return self._user_update(url, data) return self._user_update(url, data)

View File

@ -13,7 +13,7 @@
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
# #
# Copyright (c) 2019 Wind River Systems, Inc. # Copyright (c) 2019, 2024 Wind River Systems, Inc.
# #
# SPDX-License-Identifier: Apache-2.0 # SPDX-License-Identifier: Apache-2.0
# #
@ -25,11 +25,20 @@ from dcdbsync.dbsyncclient import exceptions
class Project(base.Resource): class Project(base.Resource):
resource_name = 'project' resource_name = "project"
def __init__(self, manager, id, domain_id, name, def __init__(
enabled, parent_id, is_domain, extra={}, self,
description=""): manager,
id,
domain_id,
name,
enabled,
parent_id,
is_domain,
extra={},
description="",
):
self.manager = manager self.manager = manager
self.id = id self.id = id
self.domain_id = domain_id self.domain_id = domain_id
@ -42,10 +51,15 @@ class Project(base.Resource):
def info(self): def info(self):
resource_info = dict() resource_info = dict()
resource_info.update({self.resource_name: resource_info.update(
{'name': self.name, {
'id': self.id, self.resource_name: {
'domain_id': self.domain_id}}) "name": self.name,
"id": self.id,
"domain_id": self.domain_id,
}
}
)
return resource_info return resource_info
@ -57,7 +71,7 @@ class project_manager(base.ResourceManager):
# Unauthorized # Unauthorized
if resp.status_code == 401: if resp.status_code == 401:
raise exceptions.Unauthorized('Unauthorized request') raise exceptions.Unauthorized("Unauthorized request")
if resp.status_code != 201: if resp.status_code != 201:
self._raise_api_exception(resp) self._raise_api_exception(resp)
@ -70,7 +84,7 @@ class project_manager(base.ResourceManager):
# Unauthorized # Unauthorized
if resp.status_code == 401: if resp.status_code == 401:
raise exceptions.Unauthorized('Unauthorized request') raise exceptions.Unauthorized("Unauthorized request")
if resp.status_code != 200: if resp.status_code != 200:
self._raise_api_exception(resp) self._raise_api_exception(resp)
@ -79,17 +93,18 @@ class project_manager(base.ResourceManager):
projects = [] projects = []
for json_object in json_objects: for json_object in json_objects:
json_object = json_object['project'] json_object = json_object["project"]
project = Project( project = Project(
self, self,
id=json_object['id'], id=json_object["id"],
domain_id=json_object['domain_id'], domain_id=json_object["domain_id"],
name=json_object['name'], name=json_object["name"],
extra=json_object['extra'], extra=json_object["extra"],
description=json_object['description'], description=json_object["description"],
enabled=json_object['enabled'], enabled=json_object["enabled"],
parent_id=json_object['parent_id'], parent_id=json_object["parent_id"],
is_domain=json_object['is_domain']) is_domain=json_object["is_domain"],
)
projects.append(project) projects.append(project)
@ -100,7 +115,7 @@ class project_manager(base.ResourceManager):
# Unauthorized # Unauthorized
if resp.status_code == 401: if resp.status_code == 401:
raise exceptions.Unauthorized('Unauthorized request') raise exceptions.Unauthorized("Unauthorized request")
if resp.status_code != 200: if resp.status_code != 200:
self._raise_api_exception(resp) self._raise_api_exception(resp)
@ -113,7 +128,7 @@ class project_manager(base.ResourceManager):
# Unauthorized # Unauthorized
if resp.status_code == 401: if resp.status_code == 401:
raise exceptions.Unauthorized('Unauthorized request') raise exceptions.Unauthorized("Unauthorized request")
if resp.status_code != 200: if resp.status_code != 200:
self._raise_api_exception(resp) self._raise_api_exception(resp)
@ -122,17 +137,17 @@ class project_manager(base.ResourceManager):
return json_object return json_object
def add_project(self, data): def add_project(self, data):
url = '/identity/projects/' url = "/identity/projects/"
return self.project_create(url, data) return self.project_create(url, data)
def list_projects(self): def list_projects(self):
url = '/identity/projects/' url = "/identity/projects/"
return self.projects_list(url) return self.projects_list(url)
def project_detail(self, project_ref): def project_detail(self, project_ref):
url = '/identity/projects/%s' % project_ref url = "/identity/projects/%s" % project_ref
return self._project_detail(url) return self._project_detail(url)
def update_project(self, project_ref, data): def update_project(self, project_ref, data):
url = '/identity/projects/%s' % project_ref url = "/identity/projects/%s" % project_ref
return self._project_update(url, data) return self._project_update(url, data)

View File

@ -13,7 +13,7 @@
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
# #
# Copyright (c) 2019 Wind River Systems, Inc. # Copyright (c) 2019, 2024 Wind River Systems, Inc.
# #
# SPDX-License-Identifier: Apache-2.0 # SPDX-License-Identifier: Apache-2.0
# #
@ -24,7 +24,7 @@ from dcdbsync.dbsyncclient import exceptions
class Role(base.Resource): class Role(base.Resource):
resource_name = 'role' resource_name = "role"
def __init__(self, manager, id, domain_id, name, description, extra={}): def __init__(self, manager, id, domain_id, name, description, extra={}):
self.manager = manager self.manager = manager
@ -36,10 +36,15 @@ class Role(base.Resource):
def info(self): def info(self):
resource_info = dict() resource_info = dict()
resource_info.update({self.resource_name: resource_info.update(
{'name': self.name, {
'id': self.id, self.resource_name: {
'domain_id': self.domain_id}}) "name": self.name,
"id": self.id,
"domain_id": self.domain_id,
}
}
)
return resource_info return resource_info
@ -51,7 +56,7 @@ class role_manager(base.ResourceManager):
# Unauthorized # Unauthorized
if resp.status_code == 401: if resp.status_code == 401:
raise exceptions.Unauthorized('Unauthorized request') raise exceptions.Unauthorized("Unauthorized request")
if resp.status_code != 201: if resp.status_code != 201:
self._raise_api_exception(resp) self._raise_api_exception(resp)
@ -64,7 +69,7 @@ class role_manager(base.ResourceManager):
# Unauthorized # Unauthorized
if resp.status_code == 401: if resp.status_code == 401:
raise exceptions.Unauthorized('Unauthorized request') raise exceptions.Unauthorized("Unauthorized request")
if resp.status_code != 200: if resp.status_code != 200:
self._raise_api_exception(resp) self._raise_api_exception(resp)
@ -73,14 +78,15 @@ class role_manager(base.ResourceManager):
roles = [] roles = []
for json_object in json_objects: for json_object in json_objects:
json_object = json_object.get('role') json_object = json_object.get("role")
role = Role( role = Role(
self, self,
id=json_object['id'], id=json_object["id"],
domain_id=json_object['domain_id'], domain_id=json_object["domain_id"],
name=json_object['name'], name=json_object["name"],
description=json_object['description'], description=json_object["description"],
extra=json_object['extra']) extra=json_object["extra"],
)
roles.append(role) roles.append(role)
@ -91,7 +97,7 @@ class role_manager(base.ResourceManager):
# Unauthorized # Unauthorized
if resp.status_code == 401: if resp.status_code == 401:
raise exceptions.Unauthorized('Unauthorized request') raise exceptions.Unauthorized("Unauthorized request")
if resp.status_code != 200: if resp.status_code != 200:
self._raise_api_exception(resp) self._raise_api_exception(resp)
@ -104,7 +110,7 @@ class role_manager(base.ResourceManager):
# Unauthorized # Unauthorized
if resp.status_code == 401: if resp.status_code == 401:
raise exceptions.Unauthorized('Unauthorized request') raise exceptions.Unauthorized("Unauthorized request")
if resp.status_code != 200: if resp.status_code != 200:
self._raise_api_exception(resp) self._raise_api_exception(resp)
@ -113,17 +119,17 @@ class role_manager(base.ResourceManager):
return json_object return json_object
def add_role(self, data): def add_role(self, data):
url = '/identity/roles/' url = "/identity/roles/"
return self.role_create(url, data) return self.role_create(url, data)
def list_roles(self): def list_roles(self):
url = '/identity/roles/' url = "/identity/roles/"
return self.roles_list(url) return self.roles_list(url)
def role_detail(self, role_ref): def role_detail(self, role_ref):
url = '/identity/roles/%s' % role_ref url = "/identity/roles/%s" % role_ref
return self._role_detail(url) return self._role_detail(url)
def update_role(self, role_ref, data): def update_role(self, role_ref, data):
url = '/identity/roles/%s' % role_ref url = "/identity/roles/%s" % role_ref
return self._role_update(url, data) return self._role_update(url, data)

View File

@ -13,7 +13,7 @@
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
# #
# Copyright (c) 2019 Wind River Systems, Inc. # Copyright (c) 2019, 2024 Wind River Systems, Inc.
# #
# SPDX-License-Identifier: Apache-2.0 # SPDX-License-Identifier: Apache-2.0
# #
@ -25,11 +25,25 @@ from dcdbsync.dbsyncclient import exceptions
class RevokeEvent(base.Resource): class RevokeEvent(base.Resource):
resource_name = 'token_revoke_event' resource_name = "token_revoke_event"
def __init__(self, manager, id, domain_id, project_id, user_id, role_id, def __init__(
trust_id, consumer_id, access_token_id, issued_before, self,
expires_at, revoked_at, audit_id, audit_chain_id): manager,
id,
domain_id,
project_id,
user_id,
role_id,
trust_id,
consumer_id,
access_token_id,
issued_before,
expires_at,
revoked_at,
audit_id,
audit_chain_id,
):
self.manager = manager self.manager = manager
self.id = id self.id = id
self.domain_id = domain_id self.domain_id = domain_id
@ -47,13 +61,18 @@ class RevokeEvent(base.Resource):
def info(self): def info(self):
resource_info = dict() resource_info = dict()
resource_info.update({self.resource_name: resource_info.update(
{'id': self.id, {
'project_id': self.project_id, self.resource_name: {
'user_id': self.user_id, "id": self.id,
'role_id': self.role_id, "project_id": self.project_id,
'audit_id': self.audit_id, "user_id": self.user_id,
'issued_before': self.issued_before}}) "role_id": self.role_id,
"audit_id": self.audit_id,
"issued_before": self.issued_before,
}
}
)
return resource_info return resource_info
@ -65,7 +84,7 @@ class revoke_event_manager(base.ResourceManager):
# Unauthorized # Unauthorized
if resp.status_code == 401: if resp.status_code == 401:
raise exceptions.Unauthorized('Unauthorized request') raise exceptions.Unauthorized("Unauthorized request")
if resp.status_code != 201: if resp.status_code != 201:
self._raise_api_exception(resp) self._raise_api_exception(resp)
@ -78,7 +97,7 @@ class revoke_event_manager(base.ResourceManager):
# Unauthorized # Unauthorized
if resp.status_code == 401: if resp.status_code == 401:
raise exceptions.Unauthorized('Unauthorized request') raise exceptions.Unauthorized("Unauthorized request")
if resp.status_code != 200: if resp.status_code != 200:
self._raise_api_exception(resp) self._raise_api_exception(resp)
@ -87,22 +106,23 @@ class revoke_event_manager(base.ResourceManager):
revoke_events = [] revoke_events = []
for json_object in json_objects: for json_object in json_objects:
json_object = json_object.get('revocation_event') json_object = json_object.get("revocation_event")
revoke_event = RevokeEvent( revoke_event = RevokeEvent(
self, self,
id=json_object['id'], id=json_object["id"],
domain_id=json_object['domain_id'], domain_id=json_object["domain_id"],
project_id=json_object['project_id'], project_id=json_object["project_id"],
user_id=json_object['user_id'], user_id=json_object["user_id"],
role_id=json_object['role_id'], role_id=json_object["role_id"],
trust_id=json_object['trust_id'], trust_id=json_object["trust_id"],
consumer_id=json_object['consumer_id'], consumer_id=json_object["consumer_id"],
access_token_id=json_object['access_token_id'], access_token_id=json_object["access_token_id"],
issued_before=json_object['issued_before'], issued_before=json_object["issued_before"],
expires_at=json_object['expires_at'], expires_at=json_object["expires_at"],
revoked_at=json_object['revoked_at'], revoked_at=json_object["revoked_at"],
audit_id=json_object['audit_id'], audit_id=json_object["audit_id"],
audit_chain_id=json_object['audit_chain_id']) audit_chain_id=json_object["audit_chain_id"],
)
revoke_events.append(revoke_event) revoke_events.append(revoke_event)
@ -113,7 +133,7 @@ class revoke_event_manager(base.ResourceManager):
# Unauthorized # Unauthorized
if resp.status_code == 401: if resp.status_code == 401:
raise exceptions.Unauthorized('Unauthorized request') raise exceptions.Unauthorized("Unauthorized request")
if resp.status_code != 200: if resp.status_code != 200:
self._raise_api_exception(resp) self._raise_api_exception(resp)
@ -126,41 +146,41 @@ class revoke_event_manager(base.ResourceManager):
# Unauthorized # Unauthorized
if resp.status_code == 401: if resp.status_code == 401:
raise exceptions.Unauthorized('Unauthorized request') raise exceptions.Unauthorized("Unauthorized request")
# NotFound # NotFound
if resp.status_code == 404: if resp.status_code == 404:
raise exceptions.NotFound('Requested item not found') raise exceptions.NotFound("Requested item not found")
if resp.status_code != 204: if resp.status_code != 204:
self._raise_api_exception(resp) self._raise_api_exception(resp)
def add_revoke_event(self, data): def add_revoke_event(self, data):
url = '/identity/token-revocation-events/' url = "/identity/token-revocation-events/"
return self.revoke_event_create(url, data) return self.revoke_event_create(url, data)
def list_revoke_events(self): def list_revoke_events(self):
url = '/identity/token-revocation-events/' url = "/identity/token-revocation-events/"
return self.revoke_events_list(url) return self.revoke_events_list(url)
def revoke_event_detail(self, user_id=None, audit_id=None): def revoke_event_detail(self, user_id=None, audit_id=None):
if user_id: if user_id:
url = '/identity/token-revocation-events/users/%s' % user_id url = "/identity/token-revocation-events/users/%s" % user_id
elif audit_id: elif audit_id:
url = '/identity/token-revocation-events/audits/%s' % audit_id url = "/identity/token-revocation-events/audits/%s" % audit_id
else: else:
raise exceptions.\ raise exceptions.IllegalArgumentException(
IllegalArgumentException('Token revocation event user ID' "Token revocation event user ID or audit ID required."
' or audit ID required.') )
return self._revoke_event_detail(url) return self._revoke_event_detail(url)
def delete_revoke_event(self, user_id=None, audit_id=None): def delete_revoke_event(self, user_id=None, audit_id=None):
if user_id: if user_id:
url = '/identity/token-revocation-events/users/%s' % user_id url = "/identity/token-revocation-events/users/%s" % user_id
elif audit_id: elif audit_id:
url = '/identity/token-revocation-events/audits/%s' % audit_id url = "/identity/token-revocation-events/audits/%s" % audit_id
else: else:
raise exceptions.\ raise exceptions.IllegalArgumentException(
IllegalArgumentException('Token revocation event ID' "Token revocation event ID or audit ID required."
' or audit ID required.') )
return self._revoke_event_delete(url) return self._revoke_event_delete(url)

View File

@ -10,11 +10,11 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
# #
# Copyright (c) 2019 Wind River Systems, Inc. # Copyright (c) 2019, 2024 Wind River Systems, Inc.
# #
# SPDX-License-Identifier: Apache-2.0 # SPDX-License-Identifier: Apache-2.0
# #
import pbr.version import pbr.version
version_info = pbr.version.VersionInfo('distributedcloud') version_info = pbr.version.VersionInfo("distributedcloud")

View File

@ -6,7 +6,6 @@ import sys
# List of module directories to check # List of module directories to check
modules = [ modules = [
"dccommon", "dccommon",
"dcdbsync/api",
"dcdbsync", "dcdbsync",
"dcorch/api", "dcorch/api",
"dcorch/common", "dcorch/common",
@ -23,7 +22,7 @@ modules = [
] ]
# List of modules that are already formatted with black # List of modules that are already formatted with black
formatted_modules = ["dccommon", "dcdbsync/api"] formatted_modules = ["dccommon", "dcdbsync"]
# Function to run black check # Function to run black check