Resend last known state on reconnect

This commit is contained in:
T 2025-01-27 23:50:22 +01:00
parent 1941698a52
commit 80573055d9
4 changed files with 10 additions and 2 deletions

View File

@ -1,3 +1,3 @@
#!/bin/bash
VERSION=3.3.1
VERSION=$(grep -oP '(?<=Version: ).*$' debian/DEBIAN/control)
dpkg-deb --root-owner-group -b debian "foodoord_${VERSION}_all.deb"

View File

@ -1,5 +1,5 @@
Package: foodoord
Version: 3.3.1
Version: 3.3.2
Maintainer: Tobi <tobi@chaospott.de>
Architecture: all
Description: Control the doors of the club, ja!

View File

@ -24,6 +24,7 @@ class FoodoorMQTT:
self.client.on_connect = self.on_connect
self.client.on_message = self.on_message
self._last_state = None
self._connect_lock = threading.Condition()
def connect(self):
@ -39,6 +40,8 @@ class FoodoorMQTT:
self.client.loop_stop()
def on_connect(self, client, userdata, flags, rc):
if self._last_state is not None:
self.send_state(self._last_state)
with self._connect_lock:
self._connect_lock.notify()
@ -46,6 +49,7 @@ class FoodoorMQTT:
print(f"MQTT-Server Message: {msg.topic} {msg.payload}")
def send_state(self, locked: bool):
self._last_state = locked
self.client.publish(f"foobar/{self.area}/foodoor/status", {
False: "open",
True: "closed",

View File

@ -22,6 +22,7 @@ class FoodoorMQTT:
self.client.on_connect = self.on_connect
self.client.on_message = self.on_message
self._last_state = None
self._connect_lock = threading.Condition()
def connect(self):
@ -37,6 +38,8 @@ class FoodoorMQTT:
self.client.loop_stop()
def on_connect(self, client, userdata, flags, rc):
if self._last_state is not None:
self.send_state(self._last_state)
with self._connect_lock:
self._connect_lock.notify()
@ -44,6 +47,7 @@ class FoodoorMQTT:
print(f"MQTT-Server Message: {msg.topic} {msg.payload}")
def send_state(self, locked: bool):
self._last_state = locked
self.client.publish(f"foobar/{self.area}/foodoor/status", {
False: "open",
True: "closed",