# Copyright (c) 2015 Huawei, Tech. Co,. Ltd. # Copyright (c) 2017, 2019, 2021, 2024, 2026 Wind River Systems, Inc. # All Rights Reserved. # # Licensed under the Apache License, Version 2.0 (the "License"); you may # not use this file except in compliance with the License. You may obtain # a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the # License for the specific language governing permissions and limitations # under the License. # import os import pecan from keystonemiddleware import auth_token from oslo_config import cfg from oslo_middleware import request_id from oslo_service import service from dcmanager.common import context as ctx from dcmanager.common.i18n import _ def setup_app(*args, **kwargs): opts = cfg.CONF.pecan config = { "server": {"port": cfg.CONF.bind_port, "host": cfg.CONF.bind_host}, "app": { "root": "dcmanager.api.controllers.root.RootController", "modules": ["dcmanager.api"], "debug": opts.debug, "auth_enable": opts.auth_enable, "errors": {400: "/error", "__force_dict__": True}, }, } pecan_config = pecan.configuration.conf_from_dict(config) # app_hooks = [], hook collection will be put here later app = pecan.make_app( pecan_config.app.root, debug=False, wrap_app=_wrap_app, force_canonical=False, hooks=lambda: [ctx.AuthHook(), ctx.AuditLoggingHook()], guess_content_type_from_ext=True, ) return app def _wrap_app(app): app = request_id.RequestId(app) if cfg.CONF.pecan.auth_enable: auth_type = _get_auth_type() # For Keystone or OIDC, we still need Keystone middleware # OIDC validation is handled in AuthHook if auth_type in ["keystone", "oidc"]: conf = dict(cfg.CONF.keystone_authtoken) conf.update({"delay_auth_decision": True}) # Policy enforcement works for both Keystone and OIDC return auth_token.AuthProtocol(app, conf) return app _launcher = None def _get_auth_type(): """Get authentication type from environment or config""" env_auth_type = os.environ.get("STX_AUTH_TYPE") if env_auth_type and env_auth_type.lower() in ["keystone", "oidc"]: return env_auth_type.lower() return cfg.CONF.auth_strategy def serve(api_service, conf, workers=1): global _launcher if _launcher: raise RuntimeError(_("serve() can only be called once")) _launcher = service.launch(conf, api_service, workers=workers) def wait(): _launcher.wait()