forked from bendikwa/igrill
-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathmonitor.py
executable file
·58 lines (43 loc) · 1.88 KB
/
monitor.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
#!/usr/bin/env python
import argparse
import logging
import threading
import time
from config import Config
from utils import log_setup, mqtt_init, get_device_threads, config_requirements, config_defaults
def main():
# Setup argument parsing
parser = argparse.ArgumentParser(description='Monitor bluetooth igrill devices, and export to MQTT')
parser.add_argument('-c', '--config', action='store', dest='config_directory', default='.',
help='Set config directory, default: \'.\'')
parser.add_argument('-l', '--log-level', action='store', dest='log_level', default='INFO',
help='Set log level, default: \'info\'')
parser.add_argument('-d', '--log-destination', action='store', dest='log_destination', default='',
help='Set log destination (file), default: \'\' (stdout)')
parser.add_argument('--configtest', help='Parse config only',
action="store_true")
options = parser.parse_args()
# Setup logging
log_setup(options.log_level, options.log_destination)
config = Config(options.config_directory, config_requirements, config_defaults)
if options.configtest:
exit(config.isvalid())
if not config.isvalid():
raise ValueError("Config found in directory {0} is not valid".format(options.config_directory))
run_event = threading.Event()
run_event.set()
# Get device threads
devices = get_device_threads(config.get_config('devices'), config.get_config('mqtt'), run_event)
for device in devices:
device.start()
try:
while True:
time.sleep(.1)
except KeyboardInterrupt:
logging.info('Signaling all device threads to finish')
run_event.clear()
for device in devices:
device.join()
logging.info('All threads finished, exiting')
if __name__ == '__main__':
main()