-
Notifications
You must be signed in to change notification settings - Fork 32
/
main.py
91 lines (79 loc) · 3.21 KB
/
main.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
89
90
91
import os
import yaml
import argparse
import logging
from api import API
from mqtt import MQTT
from config import Config
from doods import Doods
# Allows you to pass a flattened dict into an unflattened one for things like
# Hass.IO that only allows config a single level deep for some reason.
def unflatten_dict(d):
ret = {}
def sub_unflatten_dict(subd, keys, value):
if len(keys) > 0:
key = keys[0]
if not key in subd:
subd[key] = {}
subd[key] = sub_unflatten_dict(subd[key], keys[1:], value)
return subd
else:
return value
for path, val in d.items():
keys = path.split(".")
key = keys[0]
if not key in ret:
ret[key] = {}
ret[key] = sub_unflatten_dict(ret[key], keys[1:], val)
return ret
def hex_to_rgb(hex):
return tuple(int(hex.strip('#')[i:i+2], 16) for i in (0, 2, 4))
def main():
parser = argparse.ArgumentParser(description='DOODS2 - Dedicated Open Object Detection Service')
parser.add_argument('--config', '-c', help='Configuration File', default='config.yaml')
parser.add_argument('action', nargs='?', help='Action: api=Start REST api, mqtt=Start MQTT forwarder', default='api')
args = parser.parse_args()
# Use environment, followed by arguments, followed by default config.yaml
config_file = os.environ.get('CONFIG_FILE', args.config)
# Load config file
with open(config_file, 'r') as stream:
try:
config = Config(**unflatten_dict(yaml.safe_load(stream)))
except yaml.YAMLError as exc:
print(exc)
# It's ugly and I'm sure there's a better way to do it, but if we specified colors as hex strings
# convert them to color arrays.
if isinstance(config.doods.boxes.boxColor, str):
config.doods.boxes.boxColor = hex_to_rgb(config.doods.boxes.boxColor)
if isinstance(config.doods.boxes.fontColor, str):
config.doods.boxes.fontColor = hex_to_rgb(config.doods.boxes.fontColor)
if isinstance(config.doods.regions.boxColor, str):
config.doods.regions.boxColor = hex_to_rgb(config.doods.regions.boxColor)
if isinstance(config.doods.regions.fontColor, str):
config.doods.regions.fontColor = hex_to_rgb(config.doods.regions.fontColor)
if isinstance(config.doods.globals.fontColor, str):
config.doods.globals.fontColor = hex_to_rgb(config.doods.globals.fontColor)
# Setup logging
level = logging.getLevelName(config.logger.level.upper())
logger = logging.getLogger("doods")
logger.propagate = False
logger.setLevel(level)
formatter = logging.Formatter("%(asctime)s - %(name)s - %(levelname)s - %(message)s")
handler = logging.StreamHandler()
handler.setLevel(level)
handler.setFormatter(formatter)
logger.addHandler(handler)
# Initialize doods
doods = Doods(config.doods)
if args.action == 'api':
# Start the server
api = API(config.server, doods)
api.run()
elif args.action == 'mqtt':
# Start the server
mqtt = MQTT(config.mqtt, doods, metrics_server_config=config.server)
mqtt.run()
else:
print('Unknown action: '+args.action)
if __name__ == "__main__":
main()