forked from ekeih/dynstatus
-
Notifications
You must be signed in to change notification settings - Fork 0
/
dynstatus.py
executable file
·86 lines (73 loc) · 2.95 KB
/
dynstatus.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
#!/usr/bin/env python3
import os
import sys
import glob
import location
import logging
import argparse
def setup_configuration():
logging.debug('setup configuration')
config_path = os.environ.get('XDG_CONFIG_HOME')
home_path = os.environ.get('HOME')
if config_path != None:
config_path = config_path + '/dynstatus'
elif home_path != None:
config_path = home_path + '/.config/dynstatus'
logging.info('config_path %s', config_path)
if not (os.access(config_path + '/config.py', os.F_OK)):
logging.error('Config file not found')
exit()
else:
sys.path.append(config_path)
global config
import config
def run_plugins():
logging.debug('run_plugins')
best_location = location.get_matching_config(config)
logging.info('Best location: ' + best_location['name'])
plugins_folder = os.path.expanduser(config.dynstatus['plugins_path'])
logging.debug('Plugins path: ' + plugins_folder)
sys.path.append(plugins_folder)
for plugin in config.dynstatus['plugins']:
try:
plugin = __import__(plugin)
plugin.run(best_location)
except:
pass
def run_daemon():
import time
logging.info('Running dynstatus in daemon mode.')
interval = config.dynstatus['daemon_interval']
logging.info('Interval: %s', interval)
if os.fork():
sys.exit()
while True:
logging.info('Run plugins')
run_plugins()
time.sleep(interval)
def print_help():
parser.print_help()
if __name__ == '__main__':
parser = argparse.ArgumentParser(description='Dynstatus tries to pinpoint your location based on your network configuration (WLAN, IP, ...) and enables you to run code to react to changes.')
parser.add_argument('-d','--daemon',action="store_true",dest="daemon",help='Dynstatus will fork to background and detect your location and run your plugins periodically. The interval is configured in the config.py of dynstatus.',required=False,default=False)
parser.add_argument('-g','--get', help='Dynstatus can give you status information without running the plugins. You can ask for every location setting of your config.py.',default='ssid',required=False)
args = parser.parse_args()
logging.basicConfig(format='%(asctime)s: (%(levelname)s) %(message)s', datefmt='%d.%m.%Y %H:%M:%S', level=logging.DEBUG)
logging.debug('=============================================')
logging.debug('dynstatus v0.1')
logging.debug('Developed by Max Rosin <dynstatus@hackrid.de>')
logging.debug('=============================================')
setup_configuration()
# argparse
if len(sys.argv) <= 1:
run_plugins()
elif args.daemon:
run_daemon()
elif args.get:
best_location = location.get_matching_config(config)
if args.get in best_location:
print(best_location[args.get])
else:
print('Unknown value.')
else:
print_help()