From b34d57e2aa3a11bd6ded56d49671b72ac39fd652 Mon Sep 17 00:00:00 2001 From: Duco Sebel <74970928+DCSBL@users.noreply.github.com> Date: Sun, 12 Dec 2021 20:44:46 +0100 Subject: [PATCH] Fix using wrong method for accessing discovery data (#69) * Fix using wrong method for accessing discovery data * Add import for zeroconf --- .../homewizard_energy/config_flow.py | 24 ++++++++++--------- 1 file changed, 13 insertions(+), 11 deletions(-) diff --git a/custom_components/homewizard_energy/config_flow.py b/custom_components/homewizard_energy/config_flow.py index f895349..b17b6ba 100644 --- a/custom_components/homewizard_energy/config_flow.py +++ b/custom_components/homewizard_energy/config_flow.py @@ -11,6 +11,7 @@ from voluptuous.util import Lower from homeassistant import config_entries +from homeassistant.components import zeroconf from homeassistant.const import CONF_HOST, CONF_IP_ADDRESS, CONF_PORT from homeassistant.data_entry_flow import FlowResult @@ -53,32 +54,33 @@ async def async_step_user( return await self.async_step_check(entry_info) - async def async_step_zeroconf(self, discovery_info): + async def async_step_zeroconf( + self, discovery_info: zeroconf.ZeroconfServiceInfo + ) -> FlowResult: """Handle zeroconf discovery.""" _LOGGER.debug("config_flow async_step_zeroconf") # Validate doscovery entry if ( - "host" not in discovery_info - or "api_enabled" not in discovery_info["properties"] - or "path" not in discovery_info["properties"] - or "product_name" not in discovery_info["properties"] - or "product_type" not in discovery_info["properties"] - or "serial" not in discovery_info["properties"] + "api_enabled" not in discovery_info.properties + or "path" not in discovery_info.properties + or "product_name" not in discovery_info.properties + or "product_type" not in discovery_info.properties + or "serial" not in discovery_info.properties ): return self.async_abort(reason="invalid_discovery_parameters") - if (discovery_info["properties"]["path"]) != "/api/v1": + if (discovery_info.properties["path"]) != "/api/v1": return self.async_abort(reason="unsupported_api_version") - if (discovery_info["properties"]["api_enabled"]) != "1": + if (discovery_info.properties["api_enabled"]) != "1": return self.async_abort(reason="api_not_enabled") # Pass parameters entry_info = { - CONF_IP_ADDRESS: discovery_info["host"], - CONF_PORT: discovery_info["port"], + CONF_IP_ADDRESS: discovery_info.host, + CONF_PORT: discovery_info.port, } return await self.async_step_check(entry_info)