summaryrefslogtreecommitdiffstats
path: root/bitbake/bin/bitbake-prserv
diff options
context:
space:
mode:
Diffstat (limited to 'bitbake/bin/bitbake-prserv')
-rwxr-xr-xbitbake/bin/bitbake-prserv106
1 files changed, 77 insertions, 29 deletions
diff --git a/bitbake/bin/bitbake-prserv b/bitbake/bin/bitbake-prserv
index 5be42f3ce5..3992e84eab 100755
--- a/bitbake/bin/bitbake-prserv
+++ b/bitbake/bin/bitbake-prserv
@@ -7,49 +7,97 @@
7 7
8import os 8import os
9import sys,logging 9import sys,logging
10import optparse 10import argparse
11import warnings 11import warnings
12warnings.simplefilter("default") 12warnings.simplefilter("default")
13 13
14sys.path.insert(0, os.path.join(os.path.dirname(os.path.dirname(__file__)),'lib')) 14sys.path.insert(0, os.path.join(os.path.dirname(os.path.dirname(__file__)), "lib"))
15 15
16import prserv 16import prserv
17import prserv.serv 17import prserv.serv
18 18
19__version__="1.0.0" 19VERSION = "2.0.0"
20 20
21PRHOST_DEFAULT='0.0.0.0' 21PRHOST_DEFAULT="0.0.0.0"
22PRPORT_DEFAULT=8585 22PRPORT_DEFAULT=8585
23 23
24def init_logger(logfile, loglevel):
25 numeric_level = getattr(logging, loglevel.upper(), None)
26 if not isinstance(numeric_level, int):
27 raise ValueError("Invalid log level: %s" % loglevel)
28 FORMAT = "%(asctime)-15s %(message)s"
29 logging.basicConfig(level=numeric_level, filename=logfile, format=FORMAT)
30
24def main(): 31def main():
25 parser = optparse.OptionParser( 32 parser = argparse.ArgumentParser(
26 version="Bitbake PR Service Core version %s, %%prog version %s" % (prserv.__version__, __version__), 33 description="BitBake PR Server. Version=%s" % VERSION,
27 usage = "%prog < --start | --stop > [options]") 34 formatter_class=argparse.RawTextHelpFormatter)
28 35
29 parser.add_option("-f", "--file", help="database filename(default: prserv.sqlite3)", action="store", 36 parser.add_argument(
30 dest="dbfile", type="string", default="prserv.sqlite3") 37 "-f",
31 parser.add_option("-l", "--log", help="log filename(default: prserv.log)", action="store", 38 "--file",
32 dest="logfile", type="string", default="prserv.log") 39 default="prserv.sqlite3",
33 parser.add_option("--loglevel", help="logging level, i.e. CRITICAL, ERROR, WARNING, INFO, DEBUG", 40 help="database filename (default: prserv.sqlite3)",
34 action = "store", type="string", dest="loglevel", default = "INFO") 41 )
35 parser.add_option("--start", help="start daemon", 42 parser.add_argument(
36 action="store_true", dest="start") 43 "-l",
37 parser.add_option("--stop", help="stop daemon", 44 "--log",
38 action="store_true", dest="stop") 45 default="prserv.log",
39 parser.add_option("--host", help="ip address to bind", action="store", 46 help="log filename(default: prserv.log)",
40 dest="host", type="string", default=PRHOST_DEFAULT) 47 )
41 parser.add_option("--port", help="port number(default: 8585)", action="store", 48 parser.add_argument(
42 dest="port", type="int", default=PRPORT_DEFAULT) 49 "--loglevel",
43 parser.add_option("-r", "--read-only", help="open database in read-only mode", 50 default="INFO",
44 action="store_true") 51 help="logging level, i.e. CRITICAL, ERROR, WARNING, INFO, DEBUG",
52 )
53 parser.add_argument(
54 "--start",
55 action="store_true",
56 help="start daemon",
57 )
58 parser.add_argument(
59 "--stop",
60 action="store_true",
61 help="stop daemon",
62 )
63 parser.add_argument(
64 "--host",
65 help="ip address to bind",
66 default=PRHOST_DEFAULT,
67 )
68 parser.add_argument(
69 "--port",
70 type=int,
71 default=PRPORT_DEFAULT,
72 help="port number (default: 8585)",
73 )
74 parser.add_argument(
75 "-r",
76 "--read-only",
77 action="store_true",
78 help="open database in read-only mode",
79 )
80 parser.add_argument(
81 "-u",
82 "--upstream",
83 default=os.environ.get("PRSERV_UPSTREAM", None),
84 help="Upstream PR service (host:port)",
85 )
45 86
46 options, args = parser.parse_args(sys.argv) 87 args = parser.parse_args()
47 prserv.init_logger(os.path.abspath(options.logfile),options.loglevel) 88 init_logger(os.path.abspath(args.log), args.loglevel)
48 89
49 if options.start: 90 if args.start:
50 ret=prserv.serv.start_daemon(options.dbfile, options.host, options.port,os.path.abspath(options.logfile), options.read_only) 91 ret=prserv.serv.start_daemon(
51 elif options.stop: 92 args.file,
52 ret=prserv.serv.stop_daemon(options.host, options.port) 93 args.host,
94 args.port,
95 os.path.abspath(args.log),
96 args.read_only,
97 args.upstream
98 )
99 elif args.stop:
100 ret=prserv.serv.stop_daemon(args.host, args.port)
53 else: 101 else:
54 ret=parser.print_help() 102 ret=parser.print_help()
55 return ret 103 return ret