Allow reloading iZone config entry (#89572)
* Allow reloading of iZone config entries --------- Co-authored-by: epenet <6771947+epenet@users.noreply.github.com>
This commit is contained in:
parent
8807878529
commit
db6f0827aa
3 changed files with 29 additions and 20 deletions
|
@ -3,7 +3,7 @@ import voluptuous as vol
|
||||||
|
|
||||||
from homeassistant import config_entries
|
from homeassistant import config_entries
|
||||||
from homeassistant.config_entries import ConfigEntry
|
from homeassistant.config_entries import ConfigEntry
|
||||||
from homeassistant.const import CONF_EXCLUDE, Platform
|
from homeassistant.const import CONF_EXCLUDE, EVENT_HOMEASSISTANT_STOP, Platform
|
||||||
from homeassistant.core import HomeAssistant
|
from homeassistant.core import HomeAssistant
|
||||||
import homeassistant.helpers.config_validation as cv
|
import homeassistant.helpers.config_validation as cv
|
||||||
from homeassistant.helpers.typing import ConfigType
|
from homeassistant.helpers.typing import ConfigType
|
||||||
|
@ -29,29 +29,35 @@ CONFIG_SCHEMA = vol.Schema(
|
||||||
|
|
||||||
async def async_setup(hass: HomeAssistant, config: ConfigType) -> bool:
|
async def async_setup(hass: HomeAssistant, config: ConfigType) -> bool:
|
||||||
"""Register the iZone component config."""
|
"""Register the iZone component config."""
|
||||||
if not (conf := config.get(IZONE)):
|
|
||||||
return True
|
|
||||||
|
|
||||||
hass.data[DATA_CONFIG] = conf
|
# Check for manually added config, this may exclude some devices
|
||||||
|
if conf := config.get(IZONE):
|
||||||
|
hass.data[DATA_CONFIG] = conf
|
||||||
|
|
||||||
# Explicitly added in the config file, create a config entry.
|
# Explicitly added in the config file, create a config entry.
|
||||||
hass.async_create_task(
|
hass.async_create_task(
|
||||||
hass.config_entries.flow.async_init(
|
hass.config_entries.flow.async_init(
|
||||||
IZONE, context={"source": config_entries.SOURCE_IMPORT}
|
IZONE, context={"source": config_entries.SOURCE_IMPORT}
|
||||||
|
)
|
||||||
)
|
)
|
||||||
)
|
|
||||||
|
# Start the discovery service
|
||||||
|
await async_start_discovery_service(hass)
|
||||||
|
|
||||||
|
async def shutdown_event(event):
|
||||||
|
await async_stop_discovery_service(hass)
|
||||||
|
|
||||||
|
hass.bus.async_listen_once(EVENT_HOMEASSISTANT_STOP, shutdown_event)
|
||||||
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
|
||||||
async def async_setup_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
|
async def async_setup_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
|
||||||
"""Set up from a config entry."""
|
"""Set up from a config entry."""
|
||||||
await async_start_discovery_service(hass)
|
|
||||||
await hass.config_entries.async_forward_entry_setups(entry, PLATFORMS)
|
await hass.config_entries.async_forward_entry_setups(entry, PLATFORMS)
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
|
||||||
async def async_unload_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
|
async def async_unload_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
|
||||||
"""Unload the config entry and stop discovery process."""
|
"""Unload the config entry and stop discovery process."""
|
||||||
await async_stop_discovery_service(hass)
|
|
||||||
return await hass.config_entries.async_unload_platforms(entry, PLATFORMS)
|
return await hass.config_entries.async_unload_platforms(entry, PLATFORMS)
|
||||||
|
|
|
@ -95,7 +95,9 @@ async def async_setup_entry(
|
||||||
init_controller(controller)
|
init_controller(controller)
|
||||||
|
|
||||||
# connect to register any further components
|
# connect to register any further components
|
||||||
async_dispatcher_connect(hass, DISPATCH_CONTROLLER_DISCOVERED, init_controller)
|
config.async_on_unload(
|
||||||
|
async_dispatcher_connect(hass, DISPATCH_CONTROLLER_DISCOVERED, init_controller)
|
||||||
|
)
|
||||||
|
|
||||||
platform = entity_platform.async_get_current_platform()
|
platform = entity_platform.async_get_current_platform()
|
||||||
platform.async_register_entity_service(
|
platform.async_register_entity_service(
|
||||||
|
|
|
@ -1,7 +1,8 @@
|
||||||
"""Internal discovery service for iZone AC."""
|
"""Internal discovery service for iZone AC."""
|
||||||
|
import logging
|
||||||
|
|
||||||
import pizone
|
import pizone
|
||||||
|
|
||||||
from homeassistant.const import EVENT_HOMEASSISTANT_STOP
|
|
||||||
from homeassistant.core import HomeAssistant
|
from homeassistant.core import HomeAssistant
|
||||||
from homeassistant.helpers import aiohttp_client
|
from homeassistant.helpers import aiohttp_client
|
||||||
from homeassistant.helpers.dispatcher import async_dispatcher_send
|
from homeassistant.helpers.dispatcher import async_dispatcher_send
|
||||||
|
@ -15,15 +16,17 @@ from .const import (
|
||||||
DISPATCH_ZONE_UPDATE,
|
DISPATCH_ZONE_UPDATE,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
class DiscoveryService(pizone.Listener):
|
class DiscoveryService(pizone.Listener):
|
||||||
"""Discovery data and interfacing with pizone library."""
|
"""Discovery data and interfacing with pizone library."""
|
||||||
|
|
||||||
def __init__(self, hass):
|
def __init__(self, hass: HomeAssistant) -> None:
|
||||||
"""Initialise discovery service."""
|
"""Initialise discovery service."""
|
||||||
super().__init__()
|
super().__init__()
|
||||||
self.hass = hass
|
self.hass = hass
|
||||||
self.pi_disco = None
|
self.pi_disco: pizone.DiscoveryService | None = None
|
||||||
|
|
||||||
# Listener interface
|
# Listener interface
|
||||||
def controller_discovered(self, ctrl: pizone.Controller) -> None:
|
def controller_discovered(self, ctrl: pizone.Controller) -> None:
|
||||||
|
@ -52,6 +55,7 @@ async def async_start_discovery_service(hass: HomeAssistant):
|
||||||
if disco := hass.data.get(DATA_DISCOVERY_SERVICE):
|
if disco := hass.data.get(DATA_DISCOVERY_SERVICE):
|
||||||
# Already started
|
# Already started
|
||||||
return disco
|
return disco
|
||||||
|
_LOGGER.debug("Starting iZone Discovery Service")
|
||||||
|
|
||||||
# discovery local services
|
# discovery local services
|
||||||
disco = DiscoveryService(hass)
|
disco = DiscoveryService(hass)
|
||||||
|
@ -62,11 +66,6 @@ async def async_start_discovery_service(hass: HomeAssistant):
|
||||||
disco.pi_disco = pizone.discovery(disco, session=session)
|
disco.pi_disco = pizone.discovery(disco, session=session)
|
||||||
await disco.pi_disco.start_discovery()
|
await disco.pi_disco.start_discovery()
|
||||||
|
|
||||||
async def shutdown_event(event):
|
|
||||||
await async_stop_discovery_service(hass)
|
|
||||||
|
|
||||||
hass.bus.async_listen_once(EVENT_HOMEASSISTANT_STOP, shutdown_event)
|
|
||||||
|
|
||||||
return disco
|
return disco
|
||||||
|
|
||||||
|
|
||||||
|
@ -77,3 +76,5 @@ async def async_stop_discovery_service(hass: HomeAssistant):
|
||||||
|
|
||||||
await disco.pi_disco.close()
|
await disco.pi_disco.close()
|
||||||
del hass.data[DATA_DISCOVERY_SERVICE]
|
del hass.data[DATA_DISCOVERY_SERVICE]
|
||||||
|
|
||||||
|
_LOGGER.debug("Stopped iZone Discovery Service")
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue