
Change migrates the monasca-api to use oslo-config-generator in order to always build newest configuration file. That removes the need of maintaning the file along with changes to oslo configuration. The example of the file is also included in the documentation. Also: * ported case for launching api under WSGI and allowing the argument parsing of oslo to take place Story: 2000970 Task: 4865 Story: 2000964 Task: 4106 Change-Id: I57547b0e2122e40f58db5f949773900b76214526
83 lines
2.3 KiB
Python
83 lines
2.3 KiB
Python
# Copyright 2017 FUJITSU LIMITED
|
|
#
|
|
# 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 pkgutil
|
|
|
|
from oslo_config import cfg
|
|
from oslo_db import options as oslo_db_opts
|
|
from oslo_log import log
|
|
from oslo_utils import importutils
|
|
|
|
CONF = cfg.CONF
|
|
LOG = log.getLogger(__name__)
|
|
|
|
|
|
def load_conf_modules():
|
|
"""Loads all modules that contain configuration.
|
|
|
|
Method iterates over modules of :py:module:`monasca_api.conf`
|
|
and imports only those that contain following methods:
|
|
|
|
- list_opts (required by oslo_config.genconfig)
|
|
- register_opts (required by :py:currentmodule:)
|
|
|
|
"""
|
|
for modname in _list_module_names():
|
|
mod = importutils.import_module('monasca_api.conf.' + modname)
|
|
required_funcs = ['register_opts', 'list_opts']
|
|
for func in required_funcs:
|
|
if hasattr(mod, func):
|
|
yield mod
|
|
|
|
|
|
def _list_module_names():
|
|
package_path = os.path.dirname(os.path.abspath(__file__))
|
|
for _, modname, ispkg in pkgutil.iter_modules(path=[package_path]):
|
|
if not (modname == "opts" and ispkg):
|
|
yield modname
|
|
|
|
|
|
def register_opts():
|
|
"""Registers all conf modules opts.
|
|
|
|
This method allows different modules to register
|
|
opts according to their needs.
|
|
|
|
"""
|
|
_register_api_opts()
|
|
_register_db_opts()
|
|
|
|
|
|
def _register_api_opts():
|
|
for mod in load_conf_modules():
|
|
mod.register_opts(CONF)
|
|
|
|
|
|
def _register_db_opts():
|
|
oslo_db_opts.set_defaults(CONF, connection='sqlite://',
|
|
max_pool_size=10, max_overflow=20,
|
|
pool_timeout=10)
|
|
|
|
|
|
def list_opts():
|
|
"""Lists all conf modules opts.
|
|
|
|
Goes through all conf modules and yields their opts
|
|
|
|
"""
|
|
for mod in load_conf_modules():
|
|
mod_opts = mod.list_opts()
|
|
yield mod_opts[0], mod_opts[1]
|