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
|