-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathmqtt_logamatic.py
60 lines (44 loc) · 1.61 KB
/
mqtt_logamatic.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
import paho.mqtt.client
import logging
from dotenv import load_dotenv
import os
load_dotenv()
log = logging.getLogger(__name__)
log.setLevel(logging.INFO)
topic_prefix = os.getenv('TOPIC_PREFIX', "/heizung/logamatic/")
def on_connect(client, userdata, flags, rc, properties=None):
log.info("on_connect rc %d", rc);
client.subscribe(topic_prefix + "set_cnf/#")
def on_message(client, userdata, msg):
try:
log.debug("on_message %s", msg.topic)
callback(msg)
except Exception as E:
log.exception("Exception on_message %s : %s", msg.topic, msg.payload)
def on_disconnect(client, userdata, rc):
log.info("on_disconnect rc %d", rc);
def publish_value(key, value):
client.publish(topic_prefix + key, value, retain=True)
callback = None
client = paho.mqtt.client.Client(client_id="logamatic_mqtt_monitor_and_control")
client.on_connect = on_connect
client.on_message = on_message
client.on_disconnect = on_disconnect
def start(deliver_callback):
log.info("Start")
global callback
callback = deliver_callback
if os.getenv('MQTT_WRITE_USERNAME') and os.getenv('MQTT_WRITE_PASSWORD'):
client.username_pw_set(username=os.getenv('MQTT_WRITE_USERNAME'), password=os.getenv('MQTT_WRITE_PASSWORD'))
rc = client.connect(os.getenv('MQTT_WRITE_HOST', 'localhost'))
log.info("client.connect %d", rc)
client.loop_start()
def stop():
log.info("Stop")
client.loop_stop()
def test_callback(msg):
log.info("test_callback")
log.info("id %d data %s", msg.pkid, msg.data.hex())
if __name__ == "__main__":
logging.basicConfig()
start(test_callback)