mirror of
https://github.com/home-assistant/core.git
synced 2025-07-19 03:07:37 +00:00
Re-architect Guardian to use better entity descriptions and properties (#107028)
* Re-architect Guardian to use better entity descriptions and properties * Reduce blast area * Code review * Remove mixins
This commit is contained in:
parent
2331f89936
commit
4fa76801af
@ -365,27 +365,8 @@ class GuardianEntity(CoordinatorEntity[GuardianDataUpdateCoordinator]):
|
|||||||
"""Initialize."""
|
"""Initialize."""
|
||||||
super().__init__(coordinator)
|
super().__init__(coordinator)
|
||||||
|
|
||||||
self._attr_extra_state_attributes = {}
|
|
||||||
self.entity_description = description
|
self.entity_description = description
|
||||||
|
|
||||||
@callback
|
|
||||||
def _async_update_from_latest_data(self) -> None:
|
|
||||||
"""Update the entity's underlying data.
|
|
||||||
|
|
||||||
This should be extended by Guardian platforms.
|
|
||||||
"""
|
|
||||||
|
|
||||||
@callback
|
|
||||||
def _handle_coordinator_update(self) -> None:
|
|
||||||
"""Respond to a DataUpdateCoordinator update."""
|
|
||||||
self._async_update_from_latest_data()
|
|
||||||
self.async_write_ha_state()
|
|
||||||
|
|
||||||
async def async_added_to_hass(self) -> None:
|
|
||||||
"""Handle entity which will be added."""
|
|
||||||
await super().async_added_to_hass()
|
|
||||||
self._async_update_from_latest_data()
|
|
||||||
|
|
||||||
|
|
||||||
class PairedSensorEntity(GuardianEntity):
|
class PairedSensorEntity(GuardianEntity):
|
||||||
"""Define a Guardian paired sensor entity."""
|
"""Define a Guardian paired sensor entity."""
|
||||||
@ -410,14 +391,14 @@ class PairedSensorEntity(GuardianEntity):
|
|||||||
self._attr_unique_id = f"{paired_sensor_uid}_{description.key}"
|
self._attr_unique_id = f"{paired_sensor_uid}_{description.key}"
|
||||||
|
|
||||||
|
|
||||||
@dataclass(frozen=True)
|
@dataclass(frozen=True, kw_only=True)
|
||||||
class ValveControllerEntityDescriptionMixin:
|
class ValveControllerEntityDescriptionMixin:
|
||||||
"""Define an entity description mixin for valve controller entities."""
|
"""Define an entity description mixin for valve controller entities."""
|
||||||
|
|
||||||
api_category: str
|
api_category: str
|
||||||
|
|
||||||
|
|
||||||
@dataclass(frozen=True)
|
@dataclass(frozen=True, kw_only=True)
|
||||||
class ValveControllerEntityDescription(
|
class ValveControllerEntityDescription(
|
||||||
EntityDescription, ValveControllerEntityDescriptionMixin
|
EntityDescription, ValveControllerEntityDescriptionMixin
|
||||||
):
|
):
|
||||||
|
@ -1,7 +1,9 @@
|
|||||||
"""Binary sensors for the Elexa Guardian integration."""
|
"""Binary sensors for the Elexa Guardian integration."""
|
||||||
from __future__ import annotations
|
from __future__ import annotations
|
||||||
|
|
||||||
|
from collections.abc import Callable
|
||||||
from dataclasses import dataclass
|
from dataclasses import dataclass
|
||||||
|
from typing import Any
|
||||||
|
|
||||||
from homeassistant.components.binary_sensor import (
|
from homeassistant.components.binary_sensor import (
|
||||||
DOMAIN as BINARY_SENSOR_DOMAIN,
|
DOMAIN as BINARY_SENSOR_DOMAIN,
|
||||||
@ -39,24 +41,35 @@ SENSOR_KIND_LEAK_DETECTED = "leak_detected"
|
|||||||
SENSOR_KIND_MOVED = "moved"
|
SENSOR_KIND_MOVED = "moved"
|
||||||
|
|
||||||
|
|
||||||
@dataclass(frozen=True)
|
@dataclass(frozen=True, kw_only=True)
|
||||||
|
class PairedSensorBinarySensorDescription(BinarySensorEntityDescription):
|
||||||
|
"""Describe a Guardian paired sensor binary sensor."""
|
||||||
|
|
||||||
|
is_on_fn: Callable[[dict[str, Any]], bool]
|
||||||
|
|
||||||
|
|
||||||
|
@dataclass(frozen=True, kw_only=True)
|
||||||
class ValveControllerBinarySensorDescription(
|
class ValveControllerBinarySensorDescription(
|
||||||
BinarySensorEntityDescription, ValveControllerEntityDescription
|
BinarySensorEntityDescription, ValveControllerEntityDescription
|
||||||
):
|
):
|
||||||
"""Describe a Guardian valve controller binary sensor."""
|
"""Describe a Guardian valve controller binary sensor."""
|
||||||
|
|
||||||
|
is_on_fn: Callable[[dict[str, Any]], bool]
|
||||||
|
|
||||||
|
|
||||||
PAIRED_SENSOR_DESCRIPTIONS = (
|
PAIRED_SENSOR_DESCRIPTIONS = (
|
||||||
BinarySensorEntityDescription(
|
PairedSensorBinarySensorDescription(
|
||||||
key=SENSOR_KIND_LEAK_DETECTED,
|
key=SENSOR_KIND_LEAK_DETECTED,
|
||||||
translation_key="leak",
|
translation_key="leak",
|
||||||
device_class=BinarySensorDeviceClass.MOISTURE,
|
device_class=BinarySensorDeviceClass.MOISTURE,
|
||||||
|
is_on_fn=lambda data: data["wet"],
|
||||||
),
|
),
|
||||||
BinarySensorEntityDescription(
|
PairedSensorBinarySensorDescription(
|
||||||
key=SENSOR_KIND_MOVED,
|
key=SENSOR_KIND_MOVED,
|
||||||
translation_key="moved",
|
translation_key="moved",
|
||||||
device_class=BinarySensorDeviceClass.MOVING,
|
device_class=BinarySensorDeviceClass.MOVING,
|
||||||
entity_category=EntityCategory.DIAGNOSTIC,
|
entity_category=EntityCategory.DIAGNOSTIC,
|
||||||
|
is_on_fn=lambda data: data["moved"],
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -66,6 +79,7 @@ VALVE_CONTROLLER_DESCRIPTIONS = (
|
|||||||
translation_key="leak",
|
translation_key="leak",
|
||||||
device_class=BinarySensorDeviceClass.MOISTURE,
|
device_class=BinarySensorDeviceClass.MOISTURE,
|
||||||
api_category=API_SYSTEM_ONBOARD_SENSOR_STATUS,
|
api_category=API_SYSTEM_ONBOARD_SENSOR_STATUS,
|
||||||
|
is_on_fn=lambda data: data["wet"],
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -133,7 +147,7 @@ async def async_setup_entry(
|
|||||||
class PairedSensorBinarySensor(PairedSensorEntity, BinarySensorEntity):
|
class PairedSensorBinarySensor(PairedSensorEntity, BinarySensorEntity):
|
||||||
"""Define a binary sensor related to a Guardian valve controller."""
|
"""Define a binary sensor related to a Guardian valve controller."""
|
||||||
|
|
||||||
entity_description: BinarySensorEntityDescription
|
entity_description: PairedSensorBinarySensorDescription
|
||||||
|
|
||||||
def __init__(
|
def __init__(
|
||||||
self,
|
self,
|
||||||
@ -146,13 +160,10 @@ class PairedSensorBinarySensor(PairedSensorEntity, BinarySensorEntity):
|
|||||||
|
|
||||||
self._attr_is_on = True
|
self._attr_is_on = True
|
||||||
|
|
||||||
@callback
|
@property
|
||||||
def _async_update_from_latest_data(self) -> None:
|
def is_on(self) -> bool:
|
||||||
"""Update the entity's underlying data."""
|
"""Return true if the binary sensor is on."""
|
||||||
if self.entity_description.key == SENSOR_KIND_LEAK_DETECTED:
|
return self.entity_description.is_on_fn(self.coordinator.data)
|
||||||
self._attr_is_on = self.coordinator.data["wet"]
|
|
||||||
elif self.entity_description.key == SENSOR_KIND_MOVED:
|
|
||||||
self._attr_is_on = self.coordinator.data["moved"]
|
|
||||||
|
|
||||||
|
|
||||||
class ValveControllerBinarySensor(ValveControllerEntity, BinarySensorEntity):
|
class ValveControllerBinarySensor(ValveControllerEntity, BinarySensorEntity):
|
||||||
@ -171,8 +182,7 @@ class ValveControllerBinarySensor(ValveControllerEntity, BinarySensorEntity):
|
|||||||
|
|
||||||
self._attr_is_on = True
|
self._attr_is_on = True
|
||||||
|
|
||||||
@callback
|
@property
|
||||||
def _async_update_from_latest_data(self) -> None:
|
def is_on(self) -> bool:
|
||||||
"""Update the entity."""
|
"""Return true if the binary sensor is on."""
|
||||||
if self.entity_description.key == SENSOR_KIND_LEAK_DETECTED:
|
return self.entity_description.is_on_fn(self.coordinator.data)
|
||||||
self._attr_is_on = self.coordinator.data["wet"]
|
|
||||||
|
@ -23,21 +23,14 @@ from . import GuardianData, ValveControllerEntity, ValveControllerEntityDescript
|
|||||||
from .const import API_SYSTEM_DIAGNOSTICS, DOMAIN
|
from .const import API_SYSTEM_DIAGNOSTICS, DOMAIN
|
||||||
|
|
||||||
|
|
||||||
@dataclass(frozen=True)
|
@dataclass(frozen=True, kw_only=True)
|
||||||
class GuardianButtonEntityDescriptionMixin:
|
|
||||||
"""Define an mixin for button entities."""
|
|
||||||
|
|
||||||
push_action: Callable[[Client], Awaitable]
|
|
||||||
|
|
||||||
|
|
||||||
@dataclass(frozen=True)
|
|
||||||
class ValveControllerButtonDescription(
|
class ValveControllerButtonDescription(
|
||||||
ButtonEntityDescription,
|
ButtonEntityDescription, ValveControllerEntityDescription
|
||||||
ValveControllerEntityDescription,
|
|
||||||
GuardianButtonEntityDescriptionMixin,
|
|
||||||
):
|
):
|
||||||
"""Describe a Guardian valve controller button."""
|
"""Describe a Guardian valve controller button."""
|
||||||
|
|
||||||
|
push_action: Callable[[Client], Awaitable]
|
||||||
|
|
||||||
|
|
||||||
BUTTON_KIND_REBOOT = "reboot"
|
BUTTON_KIND_REBOOT = "reboot"
|
||||||
BUTTON_KIND_RESET_VALVE_DIAGNOSTICS = "reset_valve_diagnostics"
|
BUTTON_KIND_RESET_VALVE_DIAGNOSTICS = "reset_valve_diagnostics"
|
||||||
|
@ -1,7 +1,9 @@
|
|||||||
"""Sensors for the Elexa Guardian integration."""
|
"""Sensors for the Elexa Guardian integration."""
|
||||||
from __future__ import annotations
|
from __future__ import annotations
|
||||||
|
|
||||||
|
from collections.abc import Callable
|
||||||
from dataclasses import dataclass
|
from dataclasses import dataclass
|
||||||
|
from typing import Any
|
||||||
|
|
||||||
from homeassistant.components.sensor import (
|
from homeassistant.components.sensor import (
|
||||||
SensorDeviceClass,
|
SensorDeviceClass,
|
||||||
@ -19,6 +21,7 @@ from homeassistant.const import (
|
|||||||
from homeassistant.core import HomeAssistant, callback
|
from homeassistant.core import HomeAssistant, callback
|
||||||
from homeassistant.helpers.dispatcher import async_dispatcher_connect
|
from homeassistant.helpers.dispatcher import async_dispatcher_connect
|
||||||
from homeassistant.helpers.entity_platform import AddEntitiesCallback
|
from homeassistant.helpers.entity_platform import AddEntitiesCallback
|
||||||
|
from homeassistant.helpers.typing import StateType
|
||||||
|
|
||||||
from . import (
|
from . import (
|
||||||
GuardianData,
|
GuardianData,
|
||||||
@ -39,25 +42,36 @@ SENSOR_KIND_TEMPERATURE = "temperature"
|
|||||||
SENSOR_KIND_UPTIME = "uptime"
|
SENSOR_KIND_UPTIME = "uptime"
|
||||||
|
|
||||||
|
|
||||||
@dataclass(frozen=True)
|
@dataclass(frozen=True, kw_only=True)
|
||||||
|
class PairedSensorDescription(SensorEntityDescription):
|
||||||
|
"""Describe a Guardian paired sensor."""
|
||||||
|
|
||||||
|
value_fn: Callable[[dict[str, Any]], StateType]
|
||||||
|
|
||||||
|
|
||||||
|
@dataclass(frozen=True, kw_only=True)
|
||||||
class ValveControllerSensorDescription(
|
class ValveControllerSensorDescription(
|
||||||
SensorEntityDescription, ValveControllerEntityDescription
|
SensorEntityDescription, ValveControllerEntityDescription
|
||||||
):
|
):
|
||||||
"""Describe a Guardian valve controller sensor."""
|
"""Describe a Guardian valve controller sensor."""
|
||||||
|
|
||||||
|
value_fn: Callable[[dict[str, Any]], StateType]
|
||||||
|
|
||||||
|
|
||||||
PAIRED_SENSOR_DESCRIPTIONS = (
|
PAIRED_SENSOR_DESCRIPTIONS = (
|
||||||
SensorEntityDescription(
|
PairedSensorDescription(
|
||||||
key=SENSOR_KIND_BATTERY,
|
key=SENSOR_KIND_BATTERY,
|
||||||
device_class=SensorDeviceClass.VOLTAGE,
|
device_class=SensorDeviceClass.VOLTAGE,
|
||||||
entity_category=EntityCategory.DIAGNOSTIC,
|
entity_category=EntityCategory.DIAGNOSTIC,
|
||||||
native_unit_of_measurement=UnitOfElectricPotential.VOLT,
|
native_unit_of_measurement=UnitOfElectricPotential.VOLT,
|
||||||
|
value_fn=lambda data: data["battery"],
|
||||||
),
|
),
|
||||||
SensorEntityDescription(
|
PairedSensorDescription(
|
||||||
key=SENSOR_KIND_TEMPERATURE,
|
key=SENSOR_KIND_TEMPERATURE,
|
||||||
device_class=SensorDeviceClass.TEMPERATURE,
|
device_class=SensorDeviceClass.TEMPERATURE,
|
||||||
native_unit_of_measurement=UnitOfTemperature.FAHRENHEIT,
|
native_unit_of_measurement=UnitOfTemperature.FAHRENHEIT,
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
|
value_fn=lambda data: data["temperature"],
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
VALVE_CONTROLLER_DESCRIPTIONS = (
|
VALVE_CONTROLLER_DESCRIPTIONS = (
|
||||||
@ -67,6 +81,7 @@ VALVE_CONTROLLER_DESCRIPTIONS = (
|
|||||||
native_unit_of_measurement=UnitOfTemperature.FAHRENHEIT,
|
native_unit_of_measurement=UnitOfTemperature.FAHRENHEIT,
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
api_category=API_SYSTEM_ONBOARD_SENSOR_STATUS,
|
api_category=API_SYSTEM_ONBOARD_SENSOR_STATUS,
|
||||||
|
value_fn=lambda data: data["temperature"],
|
||||||
),
|
),
|
||||||
ValveControllerSensorDescription(
|
ValveControllerSensorDescription(
|
||||||
key=SENSOR_KIND_UPTIME,
|
key=SENSOR_KIND_UPTIME,
|
||||||
@ -75,6 +90,7 @@ VALVE_CONTROLLER_DESCRIPTIONS = (
|
|||||||
entity_category=EntityCategory.DIAGNOSTIC,
|
entity_category=EntityCategory.DIAGNOSTIC,
|
||||||
native_unit_of_measurement=UnitOfTime.MINUTES,
|
native_unit_of_measurement=UnitOfTime.MINUTES,
|
||||||
api_category=API_SYSTEM_DIAGNOSTICS,
|
api_category=API_SYSTEM_DIAGNOSTICS,
|
||||||
|
value_fn=lambda data: data["uptime"],
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -125,15 +141,12 @@ async def async_setup_entry(
|
|||||||
class PairedSensorSensor(PairedSensorEntity, SensorEntity):
|
class PairedSensorSensor(PairedSensorEntity, SensorEntity):
|
||||||
"""Define a binary sensor related to a Guardian valve controller."""
|
"""Define a binary sensor related to a Guardian valve controller."""
|
||||||
|
|
||||||
entity_description: SensorEntityDescription
|
entity_description: PairedSensorDescription
|
||||||
|
|
||||||
@callback
|
@property
|
||||||
def _async_update_from_latest_data(self) -> None:
|
def native_value(self) -> StateType:
|
||||||
"""Update the entity's underlying data."""
|
"""Return the value reported by the sensor."""
|
||||||
if self.entity_description.key == SENSOR_KIND_BATTERY:
|
return self.entity_description.value_fn(self.coordinator.data)
|
||||||
self._attr_native_value = self.coordinator.data["battery"]
|
|
||||||
elif self.entity_description.key == SENSOR_KIND_TEMPERATURE:
|
|
||||||
self._attr_native_value = self.coordinator.data["temperature"]
|
|
||||||
|
|
||||||
|
|
||||||
class ValveControllerSensor(ValveControllerEntity, SensorEntity):
|
class ValveControllerSensor(ValveControllerEntity, SensorEntity):
|
||||||
@ -141,10 +154,7 @@ class ValveControllerSensor(ValveControllerEntity, SensorEntity):
|
|||||||
|
|
||||||
entity_description: ValveControllerSensorDescription
|
entity_description: ValveControllerSensorDescription
|
||||||
|
|
||||||
@callback
|
@property
|
||||||
def _async_update_from_latest_data(self) -> None:
|
def native_value(self) -> StateType:
|
||||||
"""Update the entity's underlying data."""
|
"""Return the value reported by the sensor."""
|
||||||
if self.entity_description.key == SENSOR_KIND_TEMPERATURE:
|
return self.entity_description.value_fn(self.coordinator.data)
|
||||||
self._attr_native_value = self.coordinator.data["temperature"]
|
|
||||||
elif self.entity_description.key == SENSOR_KIND_UPTIME:
|
|
||||||
self._attr_native_value = self.coordinator.data["uptime"]
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
"""Switches for the Elexa Guardian integration."""
|
"""Switches for the Elexa Guardian integration."""
|
||||||
from __future__ import annotations
|
from __future__ import annotations
|
||||||
|
|
||||||
from collections.abc import Awaitable, Callable
|
from collections.abc import Awaitable, Callable, Mapping
|
||||||
from dataclasses import dataclass
|
from dataclasses import dataclass
|
||||||
from typing import Any
|
from typing import Any
|
||||||
|
|
||||||
@ -11,7 +11,7 @@ from aioguardian.errors import GuardianError
|
|||||||
from homeassistant.components.switch import SwitchEntity, SwitchEntityDescription
|
from homeassistant.components.switch import SwitchEntity, SwitchEntityDescription
|
||||||
from homeassistant.config_entries import ConfigEntry
|
from homeassistant.config_entries import ConfigEntry
|
||||||
from homeassistant.const import EntityCategory
|
from homeassistant.const import EntityCategory
|
||||||
from homeassistant.core import HomeAssistant, callback
|
from homeassistant.core import HomeAssistant
|
||||||
from homeassistant.exceptions import HomeAssistantError
|
from homeassistant.exceptions import HomeAssistantError
|
||||||
from homeassistant.helpers.entity_platform import AddEntitiesCallback
|
from homeassistant.helpers.entity_platform import AddEntitiesCallback
|
||||||
|
|
||||||
@ -28,21 +28,25 @@ ATTR_TRAVEL_COUNT = "travel_count"
|
|||||||
SWITCH_KIND_ONBOARD_AP = "onboard_ap"
|
SWITCH_KIND_ONBOARD_AP = "onboard_ap"
|
||||||
SWITCH_KIND_VALVE = "valve"
|
SWITCH_KIND_VALVE = "valve"
|
||||||
|
|
||||||
|
ON_STATES = {
|
||||||
@dataclass(frozen=True)
|
"start_opening",
|
||||||
class SwitchDescriptionMixin:
|
"opening",
|
||||||
"""Define an entity description mixin for Guardian switches."""
|
"finish_opening",
|
||||||
|
"opened",
|
||||||
off_action: Callable[[Client], Awaitable]
|
}
|
||||||
on_action: Callable[[Client], Awaitable]
|
|
||||||
|
|
||||||
|
|
||||||
@dataclass(frozen=True)
|
@dataclass(frozen=True, kw_only=True)
|
||||||
class ValveControllerSwitchDescription(
|
class ValveControllerSwitchDescription(
|
||||||
SwitchEntityDescription, ValveControllerEntityDescription, SwitchDescriptionMixin
|
SwitchEntityDescription, ValveControllerEntityDescription
|
||||||
):
|
):
|
||||||
"""Describe a Guardian valve controller switch."""
|
"""Describe a Guardian valve controller switch."""
|
||||||
|
|
||||||
|
extra_state_attributes_fn: Callable[[dict[str, Any]], Mapping[str, Any]]
|
||||||
|
is_on_fn: Callable[[dict[str, Any]], bool]
|
||||||
|
off_fn: Callable[[Client], Awaitable]
|
||||||
|
on_fn: Callable[[Client], Awaitable]
|
||||||
|
|
||||||
|
|
||||||
async def _async_disable_ap(client: Client) -> None:
|
async def _async_disable_ap(client: Client) -> None:
|
||||||
"""Disable the onboard AP."""
|
"""Disable the onboard AP."""
|
||||||
@ -70,17 +74,29 @@ VALVE_CONTROLLER_DESCRIPTIONS = (
|
|||||||
translation_key="onboard_access_point",
|
translation_key="onboard_access_point",
|
||||||
icon="mdi:wifi",
|
icon="mdi:wifi",
|
||||||
entity_category=EntityCategory.CONFIG,
|
entity_category=EntityCategory.CONFIG,
|
||||||
|
extra_state_attributes_fn=lambda data: {
|
||||||
|
ATTR_CONNECTED_CLIENTS: data.get("ap_clients"),
|
||||||
|
ATTR_STATION_CONNECTED: data["station_connected"],
|
||||||
|
},
|
||||||
api_category=API_WIFI_STATUS,
|
api_category=API_WIFI_STATUS,
|
||||||
off_action=_async_disable_ap,
|
is_on_fn=lambda data: data["ap_enabled"],
|
||||||
on_action=_async_enable_ap,
|
off_fn=_async_disable_ap,
|
||||||
|
on_fn=_async_enable_ap,
|
||||||
),
|
),
|
||||||
ValveControllerSwitchDescription(
|
ValveControllerSwitchDescription(
|
||||||
key=SWITCH_KIND_VALVE,
|
key=SWITCH_KIND_VALVE,
|
||||||
translation_key="valve_controller",
|
translation_key="valve_controller",
|
||||||
icon="mdi:water",
|
icon="mdi:water",
|
||||||
api_category=API_VALVE_STATUS,
|
api_category=API_VALVE_STATUS,
|
||||||
off_action=_async_close_valve,
|
extra_state_attributes_fn=lambda data: {
|
||||||
on_action=_async_open_valve,
|
ATTR_AVG_CURRENT: data["average_current"],
|
||||||
|
ATTR_INST_CURRENT: data["instantaneous_current"],
|
||||||
|
ATTR_INST_CURRENT_DDT: data["instantaneous_current_ddt"],
|
||||||
|
ATTR_TRAVEL_COUNT: data["travel_count"],
|
||||||
|
},
|
||||||
|
is_on_fn=lambda data: data["state"] in ON_STATES,
|
||||||
|
off_fn=_async_close_valve,
|
||||||
|
on_fn=_async_open_valve,
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -100,13 +116,6 @@ async def async_setup_entry(
|
|||||||
class ValveControllerSwitch(ValveControllerEntity, SwitchEntity):
|
class ValveControllerSwitch(ValveControllerEntity, SwitchEntity):
|
||||||
"""Define a switch related to a Guardian valve controller."""
|
"""Define a switch related to a Guardian valve controller."""
|
||||||
|
|
||||||
ON_STATES = {
|
|
||||||
"start_opening",
|
|
||||||
"opening",
|
|
||||||
"finish_opening",
|
|
||||||
"opened",
|
|
||||||
}
|
|
||||||
|
|
||||||
entity_description: ValveControllerSwitchDescription
|
entity_description: ValveControllerSwitchDescription
|
||||||
|
|
||||||
def __init__(
|
def __init__(
|
||||||
@ -120,29 +129,15 @@ class ValveControllerSwitch(ValveControllerEntity, SwitchEntity):
|
|||||||
|
|
||||||
self._client = data.client
|
self._client = data.client
|
||||||
|
|
||||||
@callback
|
@property
|
||||||
def _async_update_from_latest_data(self) -> None:
|
def extra_state_attributes(self) -> Mapping[str, Any]:
|
||||||
"""Update the entity."""
|
"""Return entity specific state attributes."""
|
||||||
if self.entity_description.key == SWITCH_KIND_ONBOARD_AP:
|
return self.entity_description.extra_state_attributes_fn(self.coordinator.data)
|
||||||
self._attr_extra_state_attributes.update(
|
|
||||||
{
|
@property
|
||||||
ATTR_CONNECTED_CLIENTS: self.coordinator.data.get("ap_clients"),
|
def is_on(self) -> bool:
|
||||||
ATTR_STATION_CONNECTED: self.coordinator.data["station_connected"],
|
"""Return True if entity is on."""
|
||||||
}
|
return self.entity_description.is_on_fn(self.coordinator.data)
|
||||||
)
|
|
||||||
self._attr_is_on = self.coordinator.data["ap_enabled"]
|
|
||||||
elif self.entity_description.key == SWITCH_KIND_VALVE:
|
|
||||||
self._attr_is_on = self.coordinator.data["state"] in self.ON_STATES
|
|
||||||
self._attr_extra_state_attributes.update(
|
|
||||||
{
|
|
||||||
ATTR_AVG_CURRENT: self.coordinator.data["average_current"],
|
|
||||||
ATTR_INST_CURRENT: self.coordinator.data["instantaneous_current"],
|
|
||||||
ATTR_INST_CURRENT_DDT: self.coordinator.data[
|
|
||||||
"instantaneous_current_ddt"
|
|
||||||
],
|
|
||||||
ATTR_TRAVEL_COUNT: self.coordinator.data["travel_count"],
|
|
||||||
}
|
|
||||||
)
|
|
||||||
|
|
||||||
async def async_turn_off(self, **kwargs: Any) -> None:
|
async def async_turn_off(self, **kwargs: Any) -> None:
|
||||||
"""Turn the switch off."""
|
"""Turn the switch off."""
|
||||||
@ -151,7 +146,7 @@ class ValveControllerSwitch(ValveControllerEntity, SwitchEntity):
|
|||||||
|
|
||||||
try:
|
try:
|
||||||
async with self._client:
|
async with self._client:
|
||||||
await self.entity_description.off_action(self._client)
|
await self.entity_description.off_fn(self._client)
|
||||||
except GuardianError as err:
|
except GuardianError as err:
|
||||||
raise HomeAssistantError(
|
raise HomeAssistantError(
|
||||||
f'Error while turning "{self.entity_id}" off: {err}'
|
f'Error while turning "{self.entity_id}" off: {err}'
|
||||||
@ -167,7 +162,7 @@ class ValveControllerSwitch(ValveControllerEntity, SwitchEntity):
|
|||||||
|
|
||||||
try:
|
try:
|
||||||
async with self._client:
|
async with self._client:
|
||||||
await self.entity_description.on_action(self._client)
|
await self.entity_description.on_fn(self._client)
|
||||||
except GuardianError as err:
|
except GuardianError as err:
|
||||||
raise HomeAssistantError(
|
raise HomeAssistantError(
|
||||||
f'Error while turning "{self.entity_id}" on: {err}'
|
f'Error while turning "{self.entity_id}" on: {err}'
|
||||||
|
Loading…
x
Reference in New Issue
Block a user