forked from freakent/dbus-mqtt-devices
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdevice.py
49 lines (37 loc) · 1.8 KB
/
device.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
"""
Device Manager ---> DEVICE ---> Device Service
The Device represents the actual client device sending data to the dbus over
MQTT. Each device can support multiple device services, either of the same of
different types.
"""
import logging
import os
import sys
#AppDir = os.path.dirname(os.path.realpath(__file__))
#sys.path.insert(1, os.path.join(AppDir, 'ext', 'velib-python'))
from device_service import MQTTDeviceService
class MQTTDevice(object):
def __init__(self, device_mgr=None, device_status=None):
self.device_mgr = device_mgr
self.clientId = device_status.get("clientId")
self.version = device_status.get("version")
self._status = device_status
logging.info("**** Registering device: %s, services: %s ****", self.clientId, self._status['services'])
self._services = {}
if self._status.get("services") is not None and type(self._status.get("services")) is dict:
for id, service in self._status["services"].items():
logging.info("Registering Service %s for client %s", service, self.clientId)
device_service = MQTTDeviceService(self, id, service)
self._services[id] = device_service
else:
logging.warning("Device registration for client %s did not contain a valid services object", self.clientId)
def __del__(self):
if hasattr(self, '_services'):
for serviceId in self._services:
self._services[serviceId].__del__()
logging.info("Removed Service %s from client %s", serviceId, self.clientId)
del self._services
def device_instances(self):
return dict( map( lambda s : (s[0], s[1].device_instance), self._services.items() ))
def dbus_conn(self):
return self.device_mgr.dbus_conn