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
|
#!/usr/bin/env python
"""The XML-RPC Bcfg2 Server."""
__revision__ = '$Revision$'
import logging
import os.path
import sys
import Bcfg2.Logger
import Bcfg2.Options
import Bcfg2.Component
import Bcfg2.Server.Plugins.Metadata
from Bcfg2.Server.Core import CoreInitError
logger = logging.getLogger('bcfg2-server')
if __name__ == '__main__':
OPTINFO = {
'configfile': Bcfg2.Options.CFILE,
'daemon' : Bcfg2.Options.DAEMON,
'debug' : Bcfg2.Options.DEBUG,
'help' : Bcfg2.Options.HELP,
'verbose' : Bcfg2.Options.VERBOSE,
'to_file' : Bcfg2.Options.LOGGING_FILE_PATH,
}
OPTINFO.update({'repo': Bcfg2.Options.SERVER_REPOSITORY,
'plugins': Bcfg2.Options.SERVER_PLUGINS,
'password': Bcfg2.Options.SERVER_PASSWORD,
'fm': Bcfg2.Options.SERVER_FILEMONITOR,
})
OPTINFO.update({'key' : Bcfg2.Options.SERVER_KEY,
'cert' : Bcfg2.Options.SERVER_CERT,
'ca' : Bcfg2.Options.SERVER_CA,
'location' : Bcfg2.Options.SERVER_LOCATION,
'passwd' : Bcfg2.Options.SERVER_PASSWORD,
'static' : Bcfg2.Options.SERVER_STATIC,
'encoding' : Bcfg2.Options.ENCODING,
'filelog' : Bcfg2.Options.LOGGING_FILE_PATH,
'protocol' : Bcfg2.Options.SERVER_PROTOCOL,
})
setup = Bcfg2.Options.OptionParser(OPTINFO)
setup.parse(sys.argv[1:])
try:
# check whether the specified bcfg2.conf exists
if not os.path.exists(setup['configfile']):
print("Could not read %s" % setup['configfile'])
sys.exit(1)
Bcfg2.Component.run_component(Bcfg2.Server.Core.Core,
location=setup['location'],
daemon = setup['daemon'],
pidfile_name = setup['daemon'],
protocol = setup['protocol'],
to_file=setup['to_file'],
cfile=setup['configfile'],
register=False,
cls_kwargs={'repo':setup['repo'],
'plugins':setup['plugins'],
'password':setup['password'],
'encoding':setup['encoding'],
'ca':setup['ca'],
'filemonitor':setup['fm'],
'start_fam_thread':True},
keyfile=setup['key'],
certfile=setup['cert'],
ca=setup['ca'],
)
except CoreInitError, msg:
logger.error(msg)
logger.error("exiting")
sys.exit(1)
except KeyboardInterrupt:
sys.exit(1)
sys.exit(0)
|