-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathpresence_controller.py
52 lines (42 loc) · 1.88 KB
/
presence_controller.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
import logging
import telnetlib
import time
from datetime import datetime
class PresenceController:
def __init__(self, router_host, router_username, router_password, monitored_mac_addresses):
self._router_host = router_host
self._router_username = router_username
self._router_password = router_password
# dict MAC address -> last seen timestamp
self._monitored_mac_addresses = dict(zip(monitored_mac_addresses,
[datetime.fromtimestamp(0)]*len(monitored_mac_addresses)))
def _check_connected_devices(self):
tn = telnetlib.Telnet(self._router_host)
tn.read_until("login: ")
tn.write(self._router_username + "\n")
tn.read_until("Password: ")
tn.write(self._router_password + "\n")
tn.write("wl -i eth2 assoclist\n")
tn.write("exit\n")
response = tn.read_all()
for device in self._monitored_mac_addresses.keys():
if device in response:
self._monitored_mac_addresses[device] = datetime.now()
def dispatch(self):
successful_result = False
while not successful_result:
try:
self._check_connected_devices()
successful_result = True
except Exception as e:
logging.exception("Presense controller error")
logging.info("Sleeping 60 seconds...")
time.sleep(60)
current_time = datetime.now()
for device in self._monitored_mac_addresses.keys():
time_diff = current_time - self._monitored_mac_addresses[device]
if time_diff.total_seconds() < 5*60:
return True
logging.info("PresenceController: No devices from the list are alive for the last 5 minutes, disabling:" + \
str(self._monitored_mac_addresses))
return False