summaryrefslogtreecommitdiffstats
path: root/api/escalator/opts.py
blob: f317b9026188737a61fee78acb18fb0c9a8ad6f7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
# Copyright (c) 2014 OpenStack Foundation.
#
# 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 copy
import itertools

import escalator.api.middleware.context
import escalator.api.versions
import escalator.common.config
import escalator.common.rpc
import escalator.common.wsgi
import escalator.notifier

__all__ = [
    'list_api_opts',
]


_api_opts = [
    (None, list(itertools.chain(
        escalator.api.middleware.context.context_opts,
        escalator.api.versions.versions_opts,
        escalator.common.config.common_opts,
        escalator.common.rpc.rpc_opts,
        escalator.common.wsgi.bind_opts,
        escalator.common.wsgi.eventlet_opts,
        escalator.common.wsgi.socket_opts,
        escalator.notifier.notifier_opts))),
    ('task', escalator.common.config.task_opts),
    ('paste_deploy', escalator.common.config.paste_deploy_opts)
]


def list_api_opts():
    """Return a list of oslo.config options available in Escalator API service.

    Each element of the list is a tuple. The first element is the name of the
    group under which the list of elements in the second element will be
    registered. A group name of None corresponds to the [DEFAULT] group in
    config files.

    This function is also discoverable via the 'escalator.api' entry point
    under the 'oslo.config.opts' namespace.

    The purpose of this is to allow tools like the Oslo sample config file
    generator to discover the options exposed to users by escalator.

    :returns: a list of (group_name, opts) tuples
    """

    return [(g, copy.deepcopy(o)) for g, o in _api_opts]