Add Surepetcare entity class (#56430)
parent
4c40d1767a
commit
a94514b00d
|
@ -1006,6 +1006,7 @@ omit =
|
||||||
homeassistant/components/suez_water/*
|
homeassistant/components/suez_water/*
|
||||||
homeassistant/components/supervisord/sensor.py
|
homeassistant/components/supervisord/sensor.py
|
||||||
homeassistant/components/surepetcare/__init__.py
|
homeassistant/components/surepetcare/__init__.py
|
||||||
|
homeassistant/components/surepetcare/entity.py
|
||||||
homeassistant/components/surepetcare/binary_sensor.py
|
homeassistant/components/surepetcare/binary_sensor.py
|
||||||
homeassistant/components/surepetcare/sensor.py
|
homeassistant/components/surepetcare/sensor.py
|
||||||
homeassistant/components/swiss_hydrological_data/sensor.py
|
homeassistant/components/swiss_hydrological_data/sensor.py
|
||||||
|
|
|
@ -0,0 +1,46 @@
|
||||||
|
"""Entity for Surepetcare."""
|
||||||
|
from __future__ import annotations
|
||||||
|
|
||||||
|
from abc import abstractmethod
|
||||||
|
|
||||||
|
from surepy.entities import SurepyEntity
|
||||||
|
|
||||||
|
from homeassistant.core import callback
|
||||||
|
from homeassistant.helpers.update_coordinator import CoordinatorEntity
|
||||||
|
|
||||||
|
from . import SurePetcareDataCoordinator
|
||||||
|
|
||||||
|
|
||||||
|
class SurePetcareEntity(CoordinatorEntity):
|
||||||
|
"""An implementation for Sure Petcare Entities."""
|
||||||
|
|
||||||
|
def __init__(
|
||||||
|
self,
|
||||||
|
surepetcare_id: int,
|
||||||
|
coordinator: SurePetcareDataCoordinator,
|
||||||
|
) -> None:
|
||||||
|
"""Initialize a Sure Petcare entity."""
|
||||||
|
super().__init__(coordinator)
|
||||||
|
|
||||||
|
self._id = surepetcare_id
|
||||||
|
|
||||||
|
surepy_entity: SurepyEntity = coordinator.data[surepetcare_id]
|
||||||
|
|
||||||
|
if surepy_entity.name:
|
||||||
|
self._device_name = surepy_entity.name.capitalize()
|
||||||
|
else:
|
||||||
|
self._device_name = surepy_entity.type.name.capitalize().replace("_", " ")
|
||||||
|
|
||||||
|
self._device_id = f"{surepy_entity.household_id}-{surepetcare_id}"
|
||||||
|
self._update_attr(coordinator.data[surepetcare_id])
|
||||||
|
|
||||||
|
@abstractmethod
|
||||||
|
@callback
|
||||||
|
def _update_attr(self, surepy_entity: SurepyEntity) -> None:
|
||||||
|
"""Update the state and attributes."""
|
||||||
|
|
||||||
|
@callback
|
||||||
|
def _handle_coordinator_update(self) -> None:
|
||||||
|
"""Get the latest data and update the state."""
|
||||||
|
self._update_attr(self.coordinator.data[self._id])
|
||||||
|
self.async_write_ha_state()
|
|
@ -11,12 +11,10 @@ from homeassistant.config_entries import ConfigEntry
|
||||||
from homeassistant.const import ATTR_VOLTAGE, DEVICE_CLASS_BATTERY, PERCENTAGE
|
from homeassistant.const import ATTR_VOLTAGE, DEVICE_CLASS_BATTERY, PERCENTAGE
|
||||||
from homeassistant.core import HomeAssistant, callback
|
from homeassistant.core import HomeAssistant, callback
|
||||||
from homeassistant.helpers.entity_platform import AddEntitiesCallback
|
from homeassistant.helpers.entity_platform import AddEntitiesCallback
|
||||||
from homeassistant.helpers.update_coordinator import (
|
|
||||||
CoordinatorEntity,
|
|
||||||
DataUpdateCoordinator,
|
|
||||||
)
|
|
||||||
|
|
||||||
|
from . import SurePetcareDataCoordinator
|
||||||
from .const import DOMAIN, SURE_BATT_VOLTAGE_DIFF, SURE_BATT_VOLTAGE_LOW
|
from .const import DOMAIN, SURE_BATT_VOLTAGE_DIFF, SURE_BATT_VOLTAGE_LOW
|
||||||
|
from .entity import SurePetcareEntity
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
@ -28,7 +26,7 @@ async def async_setup_entry(
|
||||||
|
|
||||||
entities: list[SureBattery] = []
|
entities: list[SureBattery] = []
|
||||||
|
|
||||||
coordinator: DataUpdateCoordinator = hass.data[DOMAIN][entry.entry_id]
|
coordinator: SurePetcareDataCoordinator = hass.data[DOMAIN][entry.entry_id]
|
||||||
|
|
||||||
for surepy_entity in coordinator.data.values():
|
for surepy_entity in coordinator.data.values():
|
||||||
|
|
||||||
|
@ -43,38 +41,24 @@ async def async_setup_entry(
|
||||||
async_add_entities(entities)
|
async_add_entities(entities)
|
||||||
|
|
||||||
|
|
||||||
class SureBattery(CoordinatorEntity, SensorEntity):
|
class SureBattery(SurePetcareEntity, SensorEntity):
|
||||||
"""A sensor implementation for Sure Petcare Entities."""
|
"""A sensor implementation for Sure Petcare Entities."""
|
||||||
|
|
||||||
def __init__(self, _id: int, coordinator: DataUpdateCoordinator) -> None:
|
_attr_device_class = DEVICE_CLASS_BATTERY
|
||||||
"""Initialize a Sure Petcare sensor."""
|
_attr_native_unit_of_measurement = PERCENTAGE
|
||||||
super().__init__(coordinator)
|
|
||||||
|
|
||||||
self._id = _id
|
def __init__(
|
||||||
|
self, surepetcare_id: int, coordinator: SurePetcareDataCoordinator
|
||||||
|
) -> None:
|
||||||
|
"""Initialize a Sure Petcare battery sensor."""
|
||||||
|
super().__init__(surepetcare_id, coordinator)
|
||||||
|
|
||||||
surepy_entity: SurepyEntity = coordinator.data[_id]
|
self._attr_name = f"{self._device_name} Battery Level"
|
||||||
|
self._attr_unique_id = f"{self._device_id}-battery"
|
||||||
self._attr_device_class = DEVICE_CLASS_BATTERY
|
|
||||||
if surepy_entity.name:
|
|
||||||
self._attr_name = f"{surepy_entity.type.name.capitalize()} {surepy_entity.name.capitalize()} Battery Level"
|
|
||||||
else:
|
|
||||||
self._attr_name = f"{surepy_entity.type.name.capitalize()} Battery Level"
|
|
||||||
self._attr_native_unit_of_measurement = PERCENTAGE
|
|
||||||
self._attr_unique_id = (
|
|
||||||
f"{surepy_entity.household_id}-{surepy_entity.id}-battery"
|
|
||||||
)
|
|
||||||
self._update_attr()
|
|
||||||
|
|
||||||
@callback
|
@callback
|
||||||
def _handle_coordinator_update(self) -> None:
|
def _update_attr(self, surepy_entity: SurepyEntity) -> None:
|
||||||
"""Get the latest data and update the state."""
|
|
||||||
self._update_attr()
|
|
||||||
self.async_write_ha_state()
|
|
||||||
|
|
||||||
@callback
|
|
||||||
def _update_attr(self) -> None:
|
|
||||||
"""Update the state and attributes."""
|
"""Update the state and attributes."""
|
||||||
surepy_entity = self.coordinator.data[self._id]
|
|
||||||
state = surepy_entity.raw_data()["status"]
|
state = surepy_entity.raw_data()["status"]
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
@ -94,4 +78,3 @@ class SureBattery(CoordinatorEntity, SensorEntity):
|
||||||
}
|
}
|
||||||
else:
|
else:
|
||||||
self._attr_extra_state_attributes = {}
|
self._attr_extra_state_attributes = {}
|
||||||
_LOGGER.debug("%s -> state: %s", self.name, state)
|
|
||||||
|
|
|
@ -6,9 +6,9 @@ from homeassistant.setup import async_setup_component
|
||||||
from . import HOUSEHOLD_ID, MOCK_CONFIG
|
from . import HOUSEHOLD_ID, MOCK_CONFIG
|
||||||
|
|
||||||
EXPECTED_ENTITY_IDS = {
|
EXPECTED_ENTITY_IDS = {
|
||||||
"sensor.pet_flap_pet_flap_battery_level": f"{HOUSEHOLD_ID}-13576-battery",
|
"sensor.pet_flap_battery_level": f"{HOUSEHOLD_ID}-13576-battery",
|
||||||
"sensor.cat_flap_cat_flap_battery_level": f"{HOUSEHOLD_ID}-13579-battery",
|
"sensor.cat_flap_battery_level": f"{HOUSEHOLD_ID}-13579-battery",
|
||||||
"sensor.feeder_feeder_battery_level": f"{HOUSEHOLD_ID}-12345-battery",
|
"sensor.feeder_battery_level": f"{HOUSEHOLD_ID}-12345-battery",
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue