~camptocamp/openobject-server/trunk-fix_1314680-afe

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
"""
Run an OpenERP cron process.
"""

import os

import common

def run(args):
    import openerp
    import openerp.cli.server
    import openerp.tools.config
    import openerp.service.cron
    config = openerp.tools.config

    os.environ["TZ"] = "UTC"
    common.set_addons(args)
    args.database = args.database or []

    config['log_handler'] = [':WARNING', 'openerp.addons.base.ir.ir_cron:DEBUG']

    openerp.multi_process = True
    common.setproctitle('openerp-cron [%s]' % ', '.join(args.database))

    openerp.cli.server.check_root_user()
    openerp.netsvc.init_logger()
    #openerp.cli.server.report_configuration()
    openerp.cli.server.setup_signal_handlers(openerp.cli.server.signal_handler)
    import openerp.addons.base
    if args.database:
        for db in args.database:
            openerp.cli.server.preload_registry(db)
        openerp.service.cron.start_service()
        openerp.cli.server.quit_on_signals()
    else:
        print "No database given."


def add_parser(subparsers):
    parser = subparsers.add_parser('cron',
        description='Run an OpenERP cron process.')
    common.add_addons_argument(parser)
    parser.add_argument('--database', action='append',
        help='Database for which cron jobs are processed (can be repeated)')

    parser.set_defaults(run=run)