api: process mqtt messages to keep a current local lock state
This commit is contained in:
parent
44d484cfc1
commit
4103c0ca5f
2 changed files with 53 additions and 15 deletions
|
|
@ -62,16 +62,22 @@ class AsyncMqttClient:
|
|||
looper: AsyncLooper
|
||||
client: mqtt.Client
|
||||
active_subscriptions: Set[str]
|
||||
messages: asyncio.Queue
|
||||
|
||||
def __init__(self, connection_string: str, username: str, password: str):
|
||||
self.connection_string = connection_string
|
||||
self.active_subscriptions = set()
|
||||
self.messages = asyncio.Queue()
|
||||
self.client = mqtt.Client(mqtt.CallbackAPIVersion.VERSION2, client_id="dooris")
|
||||
self.client.username = username
|
||||
self.client.password = password
|
||||
self.client.on_connect = self.on_connect
|
||||
self.client.on_connect_fail = self.on_connect_fail
|
||||
self.client.on_message = self.on_message
|
||||
self.client.on_disconnect = self.on_disconnect
|
||||
self.client.on_subscribe = self.on_subscribe
|
||||
self.client.on_unsubscribe = self.on_unsubscribe
|
||||
self.client.on_disconnect = self.on_disconnect
|
||||
|
||||
def on_connect(
|
||||
self,
|
||||
|
|
@ -84,6 +90,12 @@ class AsyncMqttClient:
|
|||
logger.debug(f"mqtt client connected with message '{reason_code}'")
|
||||
self.fut_connected.set_result(None)
|
||||
|
||||
def on_connect_fail(self, client, userdata):
|
||||
logger.error("mqtt client could not connect to broker")
|
||||
self.fut_connected.set_exception(
|
||||
Exception("mqtt client could not connect to broker")
|
||||
)
|
||||
|
||||
def on_disconnect(
|
||||
self,
|
||||
client: mqtt.Client,
|
||||
|
|
@ -97,26 +109,26 @@ class AsyncMqttClient:
|
|||
self.fut_disconnect.set_result(None)
|
||||
|
||||
def on_message(self, client: mqtt.Client, userdata: Any, msg: mqtt.MQTTMessage):
|
||||
logger.debug("mqtt client got message")
|
||||
print("msg", type(msg), msg)
|
||||
self.messages.put_nowait(msg)
|
||||
|
||||
def on_subscribe(self, client, userdata, mid, reason_code, properties):
|
||||
logger.debug(f"mqtt client subscribed to topics with message '{reason_code}'")
|
||||
self.fut_subscribe.set_result(None)
|
||||
|
||||
def on_unsubscribe(self, client, userdata, mid, reason_code, properties):
|
||||
logger.debug(f"mqtt client unsubscribed from topics with message '{reason_code}'")
|
||||
logger.debug(
|
||||
f"mqtt client unsubscribed from topics with message '{reason_code}'"
|
||||
)
|
||||
self.fut_unsubscribe.set_result(None)
|
||||
|
||||
async def update_subscriptions(self, topics: Iterable[str]):
|
||||
async def update_subscriptions(self, topics: Iterable[str], qos: int = 1):
|
||||
"""
|
||||
Update MQTT subscriptions so that the client is subscribed to exactly the given list of topics
|
||||
Update MQTT subscriptions so that the client is subscribed to exactly the given list of topics
|
||||
"""
|
||||
|
||||
to_add = topics.difference(self.active_subscriptions)
|
||||
if to_add:
|
||||
logger.info(f"mqtt client subscribing to topics {', '.join(to_add)}")
|
||||
qos = 2
|
||||
self.fut_subscribe = asyncio.get_running_loop().create_future()
|
||||
self.client.subscribe([(i, qos) for i in to_add])
|
||||
await self.fut_subscribe
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue