From fbce94246674f23a8faa5a772d6d0ad0901e90b1 Mon Sep 17 00:00:00 2001 From: jontofront Date: Tue, 17 Dec 2024 20:03:01 +0200 Subject: [PATCH] feat: enhance number entity addition by checking ecoMAX360i controller compatibility --- custom_components/econet300/number.py | 25 ++++++++++++++++++++++--- 1 file changed, 22 insertions(+), 3 deletions(-) diff --git a/custom_components/econet300/number.py b/custom_components/econet300/number.py index 208f1ab..5f710ab 100644 --- a/custom_components/econet300/number.py +++ b/custom_components/econet300/number.py @@ -126,15 +126,25 @@ async def async_set_native_value(self, value: float) -> None: self.async_write_ha_state() -def can_add(key: str, coordinator: EconetDataCoordinator): +def can_add_number_entity(key: str, coordinator: EconetDataCoordinator): """Check if a given entity can be added based on the availability of data in the coordinator.""" try: + # Check for unsupported controllers + controller_id = coordinator.data.get("sysParams", {}).get("controllerID", "") + if controller_id == "ecoMAX360i": + _LOGGER.info( + "Skipping key '%s' because controller '%s' does not support paramsEdits", + key, + controller_id, + ) + return False + # Check for paramsEdits availability for othr controllers return ( coordinator.has_param_edit_data(key) and coordinator.data["paramsEdits"][key] ) except KeyError as e: - _LOGGER.error("KeyError in can_add: %s", e) + _LOGGER.error("KeyError in can_add_number_entity: %s", e) return False @@ -171,6 +181,15 @@ async def async_setup_entry( coordinator = hass.data[DOMAIN][entry.entry_id][SERVICE_COORDINATOR] api = hass.data[DOMAIN][entry.entry_id][SERVICE_API] + # Check the controller type before proceeding + controller_id = coordinator.data.get("sysParams", {}).get("controllerID", "") + if controller_id == "ecoMAX360i": + _LOGGER.info( + "Controller '%s' detected - skipping setup of number entities.", + controller_id, + ) + return + entities: list[EconetNumber] = [] for key in NUMBER_MAP: @@ -182,7 +201,7 @@ async def async_setup_entry( ) continue - if can_add(key, coordinator): + if can_add_number_entity(key, coordinator): entity_description = create_number_entity_description(key) apply_limits(entity_description, number_limits) entities.append(EconetNumber(entity_description, coordinator, api))