Mqtt2Mongo/MonitorPublisher.py

64 lines
2.9 KiB
Python
Raw Permalink Normal View History

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)))