2016-07-03 23:15:21 +02:00
|
|
|
import threading
|
|
|
|
import paho.mqtt.client as mqtt
|
|
|
|
from logger import Logger
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class MonitorPublisher(threading.Thread):
|
|
|
|
def __init__(self, queue, broker):
|
|
|
|
threading.Thread.__init__(self)
|
|
|
|
self.queue = queue
|
|
|
|
self.broker = broker
|
|
|
|
self.setDaemon(True)
|
|
|
|
|
2016-07-11 21:20:22 +02:00
|
|
|
self.nameMap = {
|
|
|
|
'light': { 'oldbody':'', 'body':'', 'slot': 1, 'header': 'Licht', 'cnt': 0 },
|
|
|
|
'computer': { 'oldbody':'', 'body':'', 'slot': 2, 'header': 'Computer', 'cnt': 0 },
|
|
|
|
'laundry': { 'oldbody':'', 'body':'', 'slot': 3, 'header': 'Waschm.', 'cnt': 0 },
|
|
|
|
'dryer': { 'oldbody':'', 'body':'', 'slot': 4, 'header': 'Trockner', 'cnt': 0 },
|
|
|
|
'dishwasher': { 'oldbody':'', 'body':'', 'slot': 5, 'header': 'Spuelm.', 'cnt': 0 },
|
|
|
|
'freezer': { 'oldbody':'', 'body':'', 'slot': 6, 'header': 'Gefrier.', 'cnt': 0 },
|
|
|
|
'electricity': { 'oldbody':'', 'body':'', 'slot': 7, 'header': 'Strom', 'cnt': 0 },
|
|
|
|
'thermom.': { 'oldbody':'', 'body':'', 'slot': 8, 'header': 'Temp.', 'cnt': 0 },
|
2016-10-23 13:43:30 +02:00
|
|
|
'fridge': { 'oldbody':'', 'body':'', 'slot': 9, 'header': 'Gefr.T.', 'cnt': 0 },
|
2016-07-11 21:20:22 +02:00
|
|
|
'os_x': { 'oldbody':'', 'body':'', 'slot': 10, 'header': 'Server', 'cnt': 0 },
|
|
|
|
}
|
|
|
|
|
2016-07-03 23:15:21 +02:00
|
|
|
def run(self):
|
|
|
|
client = mqtt.Client()
|
|
|
|
client.connect(self.broker, 1883, 60)
|
|
|
|
client.loop_start()
|
|
|
|
|
|
|
|
while True:
|
|
|
|
try:
|
|
|
|
msg = self.queue.get()
|
2016-07-11 21:20:22 +02:00
|
|
|
dataBlock = msg['data']
|
|
|
|
metadataBlock = msg['metadata']
|
|
|
|
if 'Slave' in metadataBlock:
|
|
|
|
if metadataBlock['Slave'] == 'Thermometer' and metadataBlock['device'] == 'ModbusHub':
|
|
|
|
metadataBlock['name'] = 'fridge'
|
|
|
|
name = metadataBlock['name']
|
|
|
|
Logger.log("Name: " + name)
|
|
|
|
if name in self.nameMap:
|
|
|
|
if name in ['light', 'computer', 'laundry', 'dryer', 'dishwasher', 'freezer', 'electricity']:
|
|
|
|
self.nameMap[name]['body'] = str(dataBlock['power'])
|
|
|
|
elif name == 'thermom.':
|
|
|
|
self.nameMap[name]['body'] = "{0:.2f}".format(dataBlock['temperature2'])
|
2016-10-23 13:43:30 +02:00
|
|
|
elif name == 'fridge':
|
|
|
|
self.nameMap[name]['body'] = "{0:.2f}".format(dataBlock['t2'])
|
2016-07-11 21:20:22 +02:00
|
|
|
|
|
|
|
if (self.nameMap[name]['oldbody'] != self.nameMap[name]['body']) or (self.nameMap[name]['cnt'] == 10):
|
|
|
|
self.nameMap[name]['cnt'] = 0;
|
|
|
|
self.nameMap[name]['oldbody'] = self.nameMap[name]['body']
|
|
|
|
message = str(self.nameMap[name]['slot']) + " " + self.nameMap[name]['header'] + " " + self.nameMap[name]['body']
|
2016-12-21 12:47:14 +01:00
|
|
|
client.publish("IoT/Monitor/Message/" + name, message, retain=True)
|
2016-07-11 21:20:22 +02:00
|
|
|
Logger.log("MonitorPublisher has sent: " + message)
|
|
|
|
else:
|
|
|
|
self.nameMap[name]['cnt'] += 1
|
|
|
|
else:
|
|
|
|
Logger.log("unknown name: " + name)
|
2016-07-03 23:15:21 +02:00
|
|
|
except Exception, e:
|
|
|
|
Logger.log("Unexcepted exception %s in MonitorPublisher: %s" % (e.__class__.__name__, str(e)))
|