2024-10-24 16:22:45 +00:00
|
|
|
"""Implementation of device module."""
|
|
|
|
|
|
|
|
from __future__ import annotations
|
|
|
|
|
|
|
|
from ...feature import Feature
|
2024-11-23 08:07:47 +00:00
|
|
|
from ..smartcammodule import SmartCamModule
|
2024-10-24 16:22:45 +00:00
|
|
|
|
|
|
|
|
2024-11-23 08:07:47 +00:00
|
|
|
class DeviceModule(SmartCamModule):
|
2024-10-24 16:22:45 +00:00
|
|
|
"""Implementation of device module."""
|
|
|
|
|
|
|
|
NAME = "devicemodule"
|
|
|
|
QUERY_GETTER_NAME = "getDeviceInfo"
|
|
|
|
QUERY_MODULE_NAME = "device_info"
|
|
|
|
QUERY_SECTION_NAMES = ["basic_info", "info"]
|
|
|
|
|
2024-12-20 06:16:18 +00:00
|
|
|
def query(self) -> dict:
|
|
|
|
"""Query to execute during the update cycle."""
|
2025-01-13 17:19:40 +00:00
|
|
|
if self._device._is_hub_child:
|
|
|
|
# Child devices get their device info updated by the parent device.
|
|
|
|
# and generally don't support connection type as they're not
|
|
|
|
# connected to the network
|
|
|
|
return {}
|
2024-12-20 06:16:18 +00:00
|
|
|
q = super().query()
|
|
|
|
q["getConnectionType"] = {"network": {"get_connection_type": []}}
|
|
|
|
|
|
|
|
return q
|
|
|
|
|
2024-10-24 16:22:45 +00:00
|
|
|
def _initialize_features(self) -> None:
|
|
|
|
"""Initialize features after the initial update."""
|
|
|
|
self._add_feature(
|
|
|
|
Feature(
|
|
|
|
self._device,
|
|
|
|
id="device_id",
|
|
|
|
name="Device ID",
|
|
|
|
attribute_getter="device_id",
|
|
|
|
category=Feature.Category.Debug,
|
|
|
|
type=Feature.Type.Sensor,
|
|
|
|
)
|
|
|
|
)
|
2024-12-20 06:16:18 +00:00
|
|
|
if self.rssi is not None:
|
|
|
|
self._add_feature(
|
|
|
|
Feature(
|
|
|
|
self._device,
|
|
|
|
container=self,
|
|
|
|
id="rssi",
|
|
|
|
name="RSSI",
|
|
|
|
attribute_getter="rssi",
|
|
|
|
icon="mdi:signal",
|
|
|
|
unit_getter=lambda: "dBm",
|
|
|
|
category=Feature.Category.Debug,
|
|
|
|
type=Feature.Type.Sensor,
|
|
|
|
)
|
|
|
|
)
|
|
|
|
self._add_feature(
|
|
|
|
Feature(
|
|
|
|
self._device,
|
|
|
|
container=self,
|
|
|
|
id="signal_level",
|
|
|
|
name="Signal Level",
|
|
|
|
attribute_getter="signal_level",
|
|
|
|
icon="mdi:signal",
|
|
|
|
category=Feature.Category.Info,
|
|
|
|
type=Feature.Type.Sensor,
|
|
|
|
)
|
|
|
|
)
|
2024-10-24 16:22:45 +00:00
|
|
|
|
|
|
|
async def _post_update_hook(self) -> None:
|
|
|
|
"""Overriden to prevent module disabling.
|
|
|
|
|
|
|
|
Overrides the default behaviour to disable a module if the query returns
|
|
|
|
an error because this module is critical.
|
|
|
|
"""
|
|
|
|
|
|
|
|
@property
|
|
|
|
def device_id(self) -> str:
|
|
|
|
"""Return the device id."""
|
2025-01-13 17:19:40 +00:00
|
|
|
return self._device._info["device_id"]
|
2024-12-20 06:16:18 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def rssi(self) -> int | None:
|
|
|
|
"""Return the device id."""
|
2025-01-13 17:19:40 +00:00
|
|
|
return self.data.get("getConnectionType", {}).get("rssiValue")
|
2024-12-20 06:16:18 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def signal_level(self) -> int | None:
|
|
|
|
"""Return the device id."""
|
2025-01-13 17:19:40 +00:00
|
|
|
return self.data.get("getConnectionType", {}).get("rssi")
|