-
Notifications
You must be signed in to change notification settings - Fork 1
/
manage.py
66 lines (52 loc) 路 1.41 KB
/
manage.py
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
"""Management commands for twentyquestions."""
import logging
import sys
import click
import scripts
logger = logging.getLogger(__name__)
LOG_FORMAT = '%(asctime)s:%(levelname)s:%(name)s:%(message)s'
@click.group(
context_settings={
'help_option_names': ['-h', '--help']
})
@click.option(
'--verbose', '-v',
is_flag=True,
help='Turn on verbose logging for debugging purposes.')
@click.option(
'--log-file', '-l',
type=str,
help='Log to the provided file path instead of stdout.')
def manage(verbose, log_file):
"""A high-level interface to admin scripts for twentyquestions."""
log_level = logging.DEBUG if verbose else logging.INFO
if log_file:
logging.basicConfig(
filename=log_file,
filemode='a',
format=LOG_FORMAT,
level=log_level)
else:
logging.basicConfig(
stream=sys.stdout,
format=LOG_FORMAT,
level=log_level)
subcommands = [
scripts.build,
scripts.create_splits,
scripts.deploy,
scripts.dockerize,
scripts.extractgames,
scripts.extractlabels,
scripts.extractmirrorsubjects,
scripts.extractquality,
scripts.extractquestions,
scripts.extracttypes,
scripts.groupbysubject,
scripts.promote,
scripts.serve
]
for subcommand in subcommands:
manage.add_command(subcommand)
if __name__ == '__main__':
manage()