summaryrefslogtreecommitdiffstats
path: root/src/sbin/bcfg2-server
blob: 1b8b0d158e31aa759662ec3b0471f3648b0ede0a (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
#!/usr/bin/env python

"""The XML-RPC Bcfg2 server."""

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,
        'repo'      : Bcfg2.Options.SERVER_REPOSITORY,
        'plugins'   : Bcfg2.Options.SERVER_PLUGINS,
        'password'  : Bcfg2.Options.SERVER_PASSWORD,
        'fm'        : Bcfg2.Options.SERVER_FILEMONITOR,
        'ignore'    : Bcfg2.Options.SERVER_FAM_IGNORE,
        'key'       : Bcfg2.Options.SERVER_KEY,
        'cert'      : Bcfg2.Options.SERVER_CERT,
        'ca'        : Bcfg2.Options.SERVER_CA,
        'listen_all': Bcfg2.Options.SERVER_LISTEN_ALL,
        '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,
                                      listen_all=setup['listen_all'],
                                      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,
                                                  'setup':setup},
                                      keyfile=setup['key'],
                                      certfile=setup['cert'],
                                      ca=setup['ca']
                                      )
    except CoreInitError:
        msg = sys.exc_info()[1]
        logger.error(msg)
        logger.error("exiting")
        sys.exit(1)
    except KeyboardInterrupt:
        sys.exit(1)
    sys.exit(0)