summaryrefslogtreecommitdiff
path: root/src/relay_mqtt_util.py
blob: 45d24057a046a7563ec5e92a18d2f84ede2ff628 (plain)
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
#!/usr/bin/env python3
from typing import Optional
from argparse import ArgumentParser

from home.config import config
from home.mqtt import MQTTRelay, MQTTRelayDevice
from home.mqtt.payload import MQTTPayload
from home.mqtt.payload.relay import (
    InitialStatPayload, StatPayload, OTAResultPayload
)

mqtt_relay: Optional[MQTTRelay] = None


def on_mqtt_message(device_id, p: MQTTPayload):
    message = None

    if isinstance(p, InitialStatPayload) or isinstance(p, StatPayload):
        message = f'[stat] state={"on" if p.flags.state else "off"}'
        message += f' rssi={p.rssi}'
        message += f' free_heap={p.free_heap}'
        if isinstance(p, InitialStatPayload):
            message += f' fw={p.fw_version}'

    elif isinstance(p, OTAResultPayload):
        message = f'[otares] result={p.result} error_code={p.error_code}'

    if message:
        print(message)


if __name__ == '__main__':
    parser = ArgumentParser()
    parser.add_argument('--device-id', type=str, required=True)

    config.load('relay_mqtt_util', parser=parser)
    arg = parser.parse_args()

    mqtt_relay = MQTTRelay(devices=MQTTRelayDevice(id=arg.device_id))
    mqtt_relay.set_message_callback(on_mqtt_message)
    mqtt_relay.configure_tls()
    try:
        mqtt_relay.connect_and_loop()
    except KeyboardInterrupt:
        mqtt_relay.disconnect()