From 5fbfea9a8142eec6092162d21e889d57f701c12a Mon Sep 17 00:00:00 2001 From: Wizmo2 Date: Sat, 11 Dec 2021 11:52:51 -0500 Subject: [PATCH] Add ssdp discovery --- custom_components/zidoo/config_flow.py | 44 +++++++++++++++++++++++--- custom_components/zidoo/manifest.json | 16 +++++++++- 2 files changed, 54 insertions(+), 6 deletions(-) diff --git a/custom_components/zidoo/config_flow.py b/custom_components/zidoo/config_flow.py index e2372fb..cc32aaf 100644 --- a/custom_components/zidoo/config_flow.py +++ b/custom_components/zidoo/config_flow.py @@ -7,6 +7,8 @@ from homeassistant import config_entries, exceptions from homeassistant.const import CONF_HOST, CONF_NAME, CONF_PASSWORD from homeassistant.core import callback +from homeassistant.components import ssdp +from urllib.parse import urlparse from .const import ( _LOGGER, @@ -16,8 +18,14 @@ CONF_SHORTCUT, ) +SUPPORTED_MANUFACTURERS = ["Zidoo", "ZIDOO", "Plutinosoft LLCL"] +IGNORED_MODELS = [] + DATA_SCHEMA = vol.Schema( - {vol.Required(CONF_HOST): str, vol.Optional(CONF_PASSWORD): str} + { + vol.Required(CONF_HOST): str, + vol.Optional(CONF_PASSWORD): str + } ) @@ -26,7 +34,6 @@ async def validate_input(hass, data): Data has the keys from DATA_SCHEMA with values provided by the user. """ - try: player = ZidooRC(data[CONF_HOST]) response = await hass.async_add_executor_job( @@ -69,7 +76,7 @@ def async_get_options_flow(config_entry): """Return flow options.""" return ZidooOptionsFlowHandler(config_entry) - async def async_step_user(self, user_input=None): + async def async_step_user(self, user_input=None, confirmOnly=False): """ Manage device specific parameters. """ @@ -95,6 +102,15 @@ async def async_step_user(self, user_input=None): title=validated["title"], data=user_input ) + if confirmOnly: + name = self.context.get(CONF_NAME) + return self.async_show_form( + step_id="user", + description_placeholders={"name": name}, + data_schema=vol.Schema({vol.Optional(CONF_PASSWORD): str}), + errors=errors, + ) + return self.async_show_form( step_id="user", data_schema=self.discovery_schema or DATA_SCHEMA, @@ -105,6 +121,26 @@ async def async_step_import(self, user_input): """Handle import.""" return await self.async_step_user(user_input) + async def async_step_ssdp(self, discovery_info): + """Handle a discovered Harmony device.""" + _LOGGER.debug("SSDP discovery_info: %s", discovery_info) + + parsed_url = urlparse(discovery_info[ssdp.ATTR_SSDP_LOCATION]) + friendly_name = discovery_info[ssdp.ATTR_UPNP_FRIENDLY_NAME] + + self._async_abort_entries_match({CONF_HOST: parsed_url.hostname}) + + self.context["title_placeholders"] = {"name": friendly_name} + + user_input = { + CONF_HOST: parsed_url.hostname, + CONF_NAME: friendly_name, + } + + _LOGGER.debug("SSDP discovery_info: %s", user_input) + + return self.async_user_setup(user_input, True) + class ZidooOptionsFlowHandler(config_entries.OptionsFlow): """Handle a option flow for wiser hub.""" @@ -132,10 +168,8 @@ async def async_step_init(self, user_input=None): class CannotConnect(exceptions.HomeAssistantError): """Error to indicate we cannot connect.""" - class InvalidAuth(exceptions.HomeAssistantError): """Error to indicate there is invalid auth.""" - class UnknownError(exceptions.HomeAssistantError): """Error to indicate there is an unknown error.""" diff --git a/custom_components/zidoo/manifest.json b/custom_components/zidoo/manifest.json index 8f498d9..7be0c6a 100644 --- a/custom_components/zidoo/manifest.json +++ b/custom_components/zidoo/manifest.json @@ -7,5 +7,19 @@ "requirements": [], "codeowners": ["@wizmo2"], "iot_class": "local_polling", - "version": "1.2.5" + "version": "1.2.6", + "ssdp": [ + { + "manufacturer": "Zidoo", + "deviceType": "urn:schemas-upnp-org:device:MediaRenderer:1" + }, + { + "manufacturer": "ZIDOO", + "deviceType": "urn:schemas-upnp-org:device:MediaRenderer:1" + }, + { + "manufacturer": "Plutinosoft LLC", + "deviceType": "urn:schemas-upnp-org:device:MediaRenderer:1" + } + ] }