-
Notifications
You must be signed in to change notification settings - Fork 1
/
dbconf.py
88 lines (81 loc) · 2.93 KB
/
dbconf.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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
from pydantic import BaseModel, Extra
from pydantic import validator
from typing import List, Optional, Union, Any
from argparse import ArgumentParser, ArgumentDefaultsHelpFormatter
from os import environ
from setlogger import set_logger
import json
class PenDBConfigModel(BaseModel):
db_name: str = "patients"
table_name: str = "entry"
mongodb_url: str = "mongodb://127.0.0.1:27017/apitest?retryWrites=true&w=majority"
log_file: str
log_stdout: bool = False
enable_debug: bool = False
tz: str = "Asia/Tokyo"
server_address: str
server_port: Optional[int]
server_cert: Union[str, None]
enable_tls: bool = False
logger: Any
loop: Any
@validator("enable_tls", always=True)
def update_enable_tls(cls, v, values, config, **kwargs):
return True if values["server_cert"] else False
class Config():
extra = Extra.forbid
def __from_args(args):
ap = ArgumentParser(
description="PEN Backend server.",
formatter_class=ArgumentDefaultsHelpFormatter)
ap.add_argument("config_file", metavar="CONFIG_FILE",
help="specify the config file.")
ap.add_argument("-d", action="store_true", dest="enable_debug",
help="enable debug mode.")
ap.add_argument("-D", action="store_true", dest="log_stdout",
help="enable to show messages onto stdout.")
opt = ap.parse_args(args)
environ["PEN_CONFIG_FILE"] = opt.config_file
environ["PEN_ENABLE_DEBUG"] = str(opt.enable_debug)
environ["PEN_LOG_STDOUT"] = str(opt.log_stdout)
def set_config(prog_name, loop, args=None):
def get_env_bool(optval, envkey):
c = environ.get(envkey)
if c is None:
return optval
elif c.upper() in [ "TRUE", "1" ]:
return True
elif c.upper() in [ "FALSE", "0" ]:
return False
else:
raise ValueError(f"ERROR: {key} must be bool, but {c}")
"""
priority order
1. cli arguments.
2. environment variable.
3. config file.
"""
if args is not None:
__from_args(args)
# load the config file.
config_file = environ["PEN_CONFIG_FILE"]
try:
config = PenDBConfigModel.parse_obj(json.load(open(config_file)))
except Exception as e:
print("ERROR: {} read error. {}".format(config_file, e))
exit(1)
# set logger
config.logger = set_logger(prog_name,
log_file=config.log_file,
logging_stdout=config.log_stdout,
debug_mode=config.enable_debug)
# overwrite the config by the cli options/env variable.
get_env_bool(config.enable_debug, "PEN_ENABLE_DEBUG")
get_env_bool(config.log_stdout, "PEN_LOG_STDOUT")
config.loop = loop
return config
if __name__ == "__main__":
import sys
conf = json.load(open(sys.argv[1]))
m = PenDBConfigModel.parse_obj(conf)
print(m)