Add waterleak alert timestamp (#1162)

The T300 reports the timestamp of the last alarm, this exposes it to
consumers.
This commit is contained in:
Teemu R. 2024-10-18 13:18:12 +02:00 committed by GitHub
parent acd0202cab
commit 8a17752ae2
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 568 additions and 534 deletions

View File

@ -2,10 +2,11 @@
from __future__ import annotations from __future__ import annotations
from datetime import datetime
from enum import Enum from enum import Enum
from ...feature import Feature from ...feature import Feature
from ..smartmodule import SmartModule from ..smartmodule import Module, SmartModule
class WaterleakStatus(Enum): class WaterleakStatus(Enum):
@ -47,6 +48,18 @@ class WaterleakSensor(SmartModule):
type=Feature.Type.BinarySensor, type=Feature.Type.BinarySensor,
) )
) )
self._add_feature(
Feature(
self._device,
id="water_alert_timestamp",
name="Last alert timestamp",
container=self,
attribute_getter="alert_timestamp",
icon="mdi:alert",
category=Feature.Category.Info,
type=Feature.Type.Sensor,
)
)
def query(self) -> dict: def query(self) -> dict:
"""Query to execute during the update cycle.""" """Query to execute during the update cycle."""
@ -62,3 +75,14 @@ class WaterleakSensor(SmartModule):
def alert(self) -> bool: def alert(self) -> bool:
"""Return true if alarm is active.""" """Return true if alarm is active."""
return self._device.sys_info["in_alarm"] return self._device.sys_info["in_alarm"]
@property
def alert_timestamp(self) -> datetime | None:
"""Return timestamp of the last leak trigger."""
# The key is not always be there, maybe if it hasn't ever been triggered?
if "trigger_timestamp" not in self._device.sys_info:
return None
ts = self._device.sys_info["trigger_timestamp"]
tz = self._device.modules[Module.Time].timezone
return datetime.fromtimestamp(ts, tz=tz)

View File

@ -64,28 +64,29 @@
"battery_percentage": 100, "battery_percentage": 100,
"bind_count": 1, "bind_count": 1,
"category": "subg.trigger.water-leak-sensor", "category": "subg.trigger.water-leak-sensor",
"device_id": "SCRUBBED_CHILD_DEVICE_ID_1", "device_id": "SCRUBBED_CHILD_DEVICE_ID_6",
"fw_ver": "1.7.0 Build 230628 Rel.194748", "fw_ver": "1.7.0 Build 230628 Rel.194748",
"hw_id": "00000000000000000000000000000000", "hw_id": "00000000000000000000000000000000",
"hw_ver": "1.0", "hw_ver": "1.0",
"in_alarm": false, "in_alarm": false,
"jamming_rssi": -120, "jamming_rssi": -119,
"jamming_signal_level": 1, "jamming_signal_level": 1,
"lastOnboardingTimestamp": 1714661760, "lastOnboardingTimestamp": 1728470353,
"mac": "98254A000000", "mac": "A86E84000000",
"model": "T300", "model": "T300",
"nickname": "I01BU0tFRF9OQU1FIw==", "nickname": "I01BU0tFRF9OQU1FIw==",
"oem_id": "00000000000000000000000000000000", "oem_id": "00000000000000000000000000000000",
"parent_device_id": "0000000000000000000000000000000000000000", "parent_device_id": "0000000000000000000000000000000000000000",
"region": "Europe/Berlin", "region": "CEST",
"report_interval": 16, "report_interval": 16,
"rssi": -49, "rssi": -44,
"signal_level": 3, "signal_level": 3,
"specs": "EU", "specs": "EU",
"status": "online", "status": "online",
"status_follow_edge": false, "status_follow_edge": false,
"trigger_timestamp": 1728480717,
"type": "SMART.TAPOSENSOR", "type": "SMART.TAPOSENSOR",
"water_leak_status": "normal" "water_leak_status": "water_dry"
}, },
"get_fw_download_state": { "get_fw_download_state": {
"cloud_cache_seconds": 1, "cloud_cache_seconds": 1,
@ -105,7 +106,7 @@
"type": 0 "type": 0
}, },
"get_temp_humidity_records": { "get_temp_humidity_records": {
"local_time": 1714681045, "local_time": 1729248928,
"past24h_humidity": [ "past24h_humidity": [
-1000, -1000,
-1000, -1000,
@ -504,30 +505,36 @@
"logs": [ "logs": [
{ {
"event": "waterDry", "event": "waterDry",
"eventId": "18a67996-611a-a7f9-5689-6699ee55806a", "eventId": "d595356d-4953-5654-d59d-b92b6aca9ab2",
"id": 8, "id": 114,
"timestamp": 1714680176 "timestamp": 1728480717
}, },
{ {
"event": "waterLeak", "event": "waterLeak",
"eventId": "4b43c78d-a832-7755-cc80-a6357cd88aa3", "eventId": "c43fc234-4ff2-ac03-d4bf-0254ff2ac03d",
"id": 7, "id": 113,
"timestamp": 1714680174 "timestamp": 1728480714
}, },
{ {
"event": "waterDry", "event": "waterDry",
"eventId": "2a3731ba-7f1d-2c34-38be-f5580e2d3cbc", "eventId": "3e68c39e-b027-e405-7d41-d714fd81bfa8",
"id": 6, "id": 112,
"timestamp": 1714680172 "timestamp": 1728471129
}, },
{ {
"event": "waterLeak", "event": "waterLeak",
"eventId": "eebb19c0-2cda-215c-62f5-be13cda215c6", "eventId": "0e8743a9-d46a-bdde-67bb-d562b9542219",
"id": 5, "id": 111,
"timestamp": 1714676832 "timestamp": 1728471123
},
{
"event": "waterDry",
"eventId": "97708bf6-4817-b06b-0ebc-ed45917b06b0",
"id": 110,
"timestamp": 1728471106
} }
], ],
"start_id": 8, "start_id": 114,
"sum": 4 "sum": 14
} }
} }

View File

@ -1,3 +1,4 @@
from datetime import datetime
from enum import Enum from enum import Enum
import pytest import pytest
@ -15,6 +16,8 @@ waterleak = parametrize(
("feature", "prop_name", "type"), ("feature", "prop_name", "type"),
[ [
("water_alert", "alert", int), ("water_alert", "alert", int),
# Can be converted to 'datetime | None' after py3.9 support is dropped
("water_alert_timestamp", "alert_timestamp", (datetime, type(None))),
("water_leak", "status", Enum), ("water_leak", "status", Enum),
], ],
) )