From bed239c90a3b5fef5c6bf4559a774b9d09987c30 Mon Sep 17 00:00:00 2001 From: Pedro Lamas Date: Sun, 7 Nov 2021 22:29:11 +0000 Subject: [PATCH] mqtt: implements last will and testament Signed-off-by: Pedro Lamas --- moonraker/components/mqtt.py | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/moonraker/components/mqtt.py b/moonraker/components/mqtt.py index 0b5feee..e91358f 100644 --- a/moonraker/components/mqtt.py +++ b/moonraker/components/mqtt.py @@ -1,4 +1,4 @@ -# MQTT client implemenation for Moonraker +# MQTT client implementation for Moonraker # # Copyright (C) 2021 Eric Callahan # @@ -191,6 +191,7 @@ class MQTTClient(APITransport, Subscribable): self.api_request_topic = f"{self.instance_name}/moonraker/api/request" self.api_resp_topic = f"{self.instance_name}/moonraker/api/response" self.klipper_status_topic = f"{self.instance_name}/klipper/status" + self.moonraker_status_topic = f"{self.instance_name}/moonraker/status" status_cfg = config.get("status_objects", None) self.status_objs: Dict[str, Any] = {} if status_cfg is not None: @@ -235,6 +236,9 @@ class MQTTClient(APITransport, Subscribable): self.helper = AIOHelper(self.client) if self.user_name is not None: self.client.username_pw_set(self.user_name, self.password) + self.client.will_set(self.moonraker_status_topic, + payload=json.dumps({'server': 'offline'}), + qos=self.qos, retain=True) retries = 5 for _ in range(retries): try: @@ -288,6 +292,8 @@ class MQTTClient(APITransport, Subscribable): ) -> None: logging.info("MQTT Client Connected") if reason_code == 0: + self.publish_topic(self.moonraker_status_topic, + {'server': 'online'}, retain=True) subs = [(k, v[0]) for k, v in self.subscribed_topics.items()] if subs: res, msg_id = client.subscribe(subs) @@ -619,6 +625,9 @@ class MQTTClient(APITransport, Subscribable): self.reconnect_task = None if not self.is_connected(): return + await self.publish_topic(self.moonraker_status_topic, + {'server': 'offline'}, + retain=True) self.disconnect_evt = asyncio.Event() self.client.disconnect() try: