From c761e197c1e423e5472ab60bc756bf4635002069 Mon Sep 17 00:00:00 2001 From: Chaoscontrol Date: Mon, 2 Dec 2024 19:27:54 +0000 Subject: [PATCH 1/2] Making the binary_sensor initialise and recover state after HA restart --- custom_components/leafspy/binary_sensor.py | 25 ++++++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/custom_components/leafspy/binary_sensor.py b/custom_components/leafspy/binary_sensor.py index 52b6af8..ec2c2e8 100644 --- a/custom_components/leafspy/binary_sensor.py +++ b/custom_components/leafspy/binary_sensor.py @@ -12,6 +12,7 @@ from homeassistant.helpers.dispatcher import async_dispatcher_connect from homeassistant.helpers.entity_platform import AddEntitiesCallback from homeassistant.helpers.restore_state import RestoreEntity +from homeassistant.helpers import device_registry from homeassistant.helpers.typing import ConfigType, DiscoveryInfoType from homeassistant.util import slugify @@ -77,6 +78,27 @@ async def _process_message(context, message): _LOGGER.error("Error processing Leaf Spy message: %s", err) async_dispatcher_connect(hass, DOMAIN, _process_message) + + # Restore previously loaded devices + dev_reg = device_registry.async_get(hass) + dev_ids = { + identifier[1] + for device in dev_reg.devices.values() + for identifier in device.identifiers + if identifier[0] == DOMAIN + } + + if not dev_ids: + return True + + entities = [] + for dev_id in dev_ids: + entity = hass.data[DOMAIN]['binary_sensors'].get(dev_id) + if entity is None: + entity = LeafSpyBinarySensor(dev_id, BINARY_SENSOR_TYPES[0], False) + entities.append(entity) + async_add_entities(entities) + return True @@ -127,3 +149,6 @@ async def async_added_to_hass(self): self._value = transform_fn(last_state.state) except (ValueError, TypeError): _LOGGER.warning(f"Could not restore state for {self.name}") + + # Add this log line to confirm the method is being called + _LOGGER.debug(f"async_added_to_hass called for {self.name}") From 4fdaa147d8e57a1604d1f41bc203f2ec78b61a12 Mon Sep 17 00:00:00 2001 From: Chaoscontrol Date: Mon, 2 Dec 2024 19:28:29 +0000 Subject: [PATCH 2/2] Sensors to automatically initialise and restore state after HA restart --- custom_components/leafspy/sensor.py | 46 +++++++++++++++++++++++++++-- 1 file changed, 44 insertions(+), 2 deletions(-) diff --git a/custom_components/leafspy/sensor.py b/custom_components/leafspy/sensor.py index ed1b9f5..d0f46dc 100644 --- a/custom_components/leafspy/sensor.py +++ b/custom_components/leafspy/sensor.py @@ -22,6 +22,7 @@ from homeassistant.helpers.dispatcher import async_dispatcher_connect from homeassistant.helpers.entity_platform import AddEntitiesCallback from homeassistant.helpers.restore_state import RestoreEntity +from homeassistant.helpers import device_registry from homeassistant.components.sensor import SensorEntityDescription from homeassistant.helpers.typing import ConfigType, DiscoveryInfoType from homeassistant.util import slugify @@ -300,22 +301,50 @@ async def _process_message(context, message): native_unit_of_measurement=unit) if sensor is not None: - # Update with potentially new unit + # Update existing sensor sensor.entity_description = sensor_description sensor.update_state(value) else: + # Add a new sensor sensor = LeafSpySensor(dev_id, sensor_description, value) hass.data[DOMAIN]['sensors'][sensor_id] = sensor async_add_entities([sensor]) + # Add a log to confirm the sensor is being registered + _LOGGER.debug(f"Registered sensor: {sensor.name} with initial value: {value}") + except Exception as err: _LOGGER.error("Error processing Leaf Spy message: %s", err) _LOGGER.exception("Full traceback") async_dispatcher_connect(hass, DOMAIN, _process_message) + + # Restore previously loaded sensors + dev_reg = device_registry.async_get(hass) + dev_ids = { + identifier[1] + for device in dev_reg.devices.values() + for identifier in device.identifiers + if identifier[0] == DOMAIN + } + + if not dev_ids: + return True + + entities = [] + for dev_id in dev_ids: + # For each device ID, recreate the sensor entities + for description in SENSOR_TYPES: + sensor_id = f"{dev_id}_{description.key}" + sensor = LeafSpySensor(dev_id, description, None) # Initializing with None + hass.data[DOMAIN]['sensors'][sensor_id] = sensor + entities.append(sensor) + + async_add_entities(entities) return True + class LeafSpySensor(SensorEntity, RestoreEntity): """Representation of a Leaf Spy sensor.""" @@ -346,6 +375,11 @@ def device_info(self): return { "identifiers": {(DOMAIN, self._device_id)}, } + + @property + def should_poll(self) -> bool: + """Disable polling for this sensor.""" + return False def update_state(self, new_value): """Update the sensor state.""" @@ -355,11 +389,19 @@ def update_state(self, new_value): async def async_added_to_hass(self): """Restore last known state.""" await super().async_added_to_hass() - + + # Add this log line to confirm the method is being called + _LOGGER.debug(f"async_added_to_hass called for {self.name}") + + # Retrieve the last known state last_state = await self.async_get_last_state() if last_state: + # Log the restored state before transforming + _LOGGER.debug(f"Restored state for {self.name}: {last_state.state}") + try: transform_fn = self.entity_description.transform_fn self._value = transform_fn(last_state.state) + self.async_write_ha_state() # Make sure the restored state is written except (ValueError, TypeError): _LOGGER.warning(f"Could not restore state for {self.name}")