summaryrefslogtreecommitdiffstats
path: root/conductor/conductor/service.py
blob: 5d86cce15f79aacc576d962c67c5e1c42f15260a (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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
#
# -------------------------------------------------------------------------
#   Copyright (c) 2015-2017 AT&T Intellectual Property
#
#   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 socket
import sys

# from keystoneauth1 import loading as ka_loading
from oslo_config import cfg
import oslo_i18n
from oslo_log import log
# from oslo_policy import opts as policy_opts
from oslo_reports import guru_meditation_report as gmr

from conductor.conf import defaults
# from conductor import keystone_client
from conductor import messaging
from conductor import version

OPTS = [
    # cfg.StrOpt('host',
    #            default=socket.gethostname(),
    #            sample_default='<your_hostname>',
    #            help='Name of this node, which must be valid in an AMQP '
    #            'key. Can be an opaque identifier. For ZeroMQ only, must '
    #            'be a valid host name, FQDN, or IP address.'),
    # cfg.IntOpt('http_timeout',
    #            default=600,
    #            help='Timeout seconds for HTTP requests. Set it to None to '
    #                 'disable timeout.'),
    cfg.StrOpt('keyspace',
               default='conductor',
               help='Music keyspace for content'),
]
cfg.CONF.register_opts(OPTS)

# DATA_OPT = cfg.IntOpt('workers',
#                       default=1,
#                       min=1,
#                       help='Number of workers for data service, '
#                            'default value is 1.')
# cfg.CONF.register_opt(DATA_OPT, 'data')
#
# PARSER_OPT = cfg.IntOpt('workers',
#                         default=1,
#                         min=1,
#                         help='Number of workers for parser service. '
#                              'default value is 1.')
# cfg.CONF.register_opt(PARSER_OPT, 'parser')
#
# SOLVER_OPT = cfg.IntOpt('workers',
#                         default=1,
#                         min=1,
#                         help='Number of workers for solver service. '
#                              'default value is 1.')
# cfg.CONF.register_opt(SOLVER_OPT, 'solver')

# keystone_client.register_keystoneauth_opts(cfg.CONF)


def prepare_service(argv=None, config_files=None):
    if argv is None:
        argv = sys.argv

    # FIXME(sileht): Use ConfigOpts() instead
    conf = cfg.CONF

    oslo_i18n.enable_lazy()
    log.register_options(conf)
    log_levels = (conf.default_log_levels +
                  ['futurist=INFO'])
    log.set_defaults(default_log_levels=log_levels)
    defaults.set_cors_middleware_defaults()
    # policy_opts.set_defaults(conf)

    conf(argv[1:], project='conductor', validate_default_values=True,
         version=version.version_info.version_string(),
         default_config_files=config_files)

    # ka_loading.load_auth_from_conf_options(conf, "service_credentials")

    log.setup(conf, 'conductor')
    # NOTE(liusheng): guru cannot run with service under apache daemon, so when
    # conductor-api running with mod_wsgi, the argv is [], we don't start
    # guru.
    if argv:
        gmr.TextGuruMeditation.setup_autorun(version)
    messaging.setup()
    return conf