2019-09-19 21:31:54 +00:00
|
|
|
"""Config flow for izone."""
|
|
|
|
|
|
|
|
import asyncio
|
2021-03-23 13:36:43 +00:00
|
|
|
from contextlib import suppress
|
2019-12-06 05:08:08 +00:00
|
|
|
import logging
|
2019-09-19 21:31:54 +00:00
|
|
|
|
|
|
|
from async_timeout import timeout
|
|
|
|
|
2022-02-14 17:10:50 +00:00
|
|
|
from homeassistant.core import HomeAssistant, callback
|
2019-09-19 21:31:54 +00:00
|
|
|
from homeassistant.helpers import config_entry_flow
|
|
|
|
from homeassistant.helpers.dispatcher import async_dispatcher_connect
|
|
|
|
|
2019-12-06 05:08:08 +00:00
|
|
|
from .const import DISPATCH_CONTROLLER_DISCOVERED, IZONE, TIMEOUT_DISCOVERY
|
|
|
|
from .discovery import async_start_discovery_service, async_stop_discovery_service
|
2019-09-19 21:31:54 +00:00
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
2022-02-14 17:10:50 +00:00
|
|
|
async def _async_has_devices(hass: HomeAssistant) -> bool:
|
2019-09-19 21:31:54 +00:00
|
|
|
|
|
|
|
controller_ready = asyncio.Event()
|
2021-01-16 13:24:00 +00:00
|
|
|
|
|
|
|
@callback
|
|
|
|
def dispatch_discovered(_):
|
|
|
|
controller_ready.set()
|
|
|
|
|
|
|
|
async_dispatcher_connect(hass, DISPATCH_CONTROLLER_DISCOVERED, dispatch_discovered)
|
2019-09-19 21:31:54 +00:00
|
|
|
|
|
|
|
disco = await async_start_discovery_service(hass)
|
|
|
|
|
2021-03-23 13:36:43 +00:00
|
|
|
with suppress(asyncio.TimeoutError):
|
2019-09-19 21:31:54 +00:00
|
|
|
async with timeout(TIMEOUT_DISCOVERY):
|
|
|
|
await controller_ready.wait()
|
|
|
|
|
|
|
|
if not disco.pi_disco.controllers:
|
|
|
|
await async_stop_discovery_service(hass)
|
|
|
|
_LOGGER.debug("No controllers found")
|
|
|
|
return False
|
|
|
|
|
|
|
|
_LOGGER.debug("Controllers %s", disco.pi_disco.controllers)
|
|
|
|
return True
|
|
|
|
|
|
|
|
|
2021-04-29 21:12:58 +00:00
|
|
|
config_entry_flow.register_discovery_flow(IZONE, "iZone Aircon", _async_has_devices)
|