mirror of
https://github.com/home-assistant/core.git
synced 2025-07-23 05:07:41 +00:00
Use forward_entry_setups in ZHA (#74834)
This commit is contained in:
parent
2986a2f01b
commit
5774f2e7b9
@ -31,7 +31,6 @@ from .core.const import (
|
|||||||
DATA_ZHA,
|
DATA_ZHA,
|
||||||
DATA_ZHA_CONFIG,
|
DATA_ZHA_CONFIG,
|
||||||
DATA_ZHA_GATEWAY,
|
DATA_ZHA_GATEWAY,
|
||||||
DATA_ZHA_PLATFORM_LOADED,
|
|
||||||
DATA_ZHA_SHUTDOWN_TASK,
|
DATA_ZHA_SHUTDOWN_TASK,
|
||||||
DOMAIN,
|
DOMAIN,
|
||||||
PLATFORMS,
|
PLATFORMS,
|
||||||
@ -111,11 +110,6 @@ async def async_setup_entry(hass: HomeAssistant, config_entry: ConfigEntry) -> b
|
|||||||
zha_gateway = ZHAGateway(hass, config, config_entry)
|
zha_gateway = ZHAGateway(hass, config, config_entry)
|
||||||
await zha_gateway.async_initialize()
|
await zha_gateway.async_initialize()
|
||||||
|
|
||||||
zha_data[DATA_ZHA_PLATFORM_LOADED] = []
|
|
||||||
for platform in PLATFORMS:
|
|
||||||
coro = hass.config_entries.async_forward_entry_setup(config_entry, platform)
|
|
||||||
zha_data[DATA_ZHA_PLATFORM_LOADED].append(hass.async_create_task(coro))
|
|
||||||
|
|
||||||
device_registry = dr.async_get(hass)
|
device_registry = dr.async_get(hass)
|
||||||
device_registry.async_get_or_create(
|
device_registry.async_get_or_create(
|
||||||
config_entry_id=config_entry.entry_id,
|
config_entry_id=config_entry.entry_id,
|
||||||
@ -136,7 +130,10 @@ async def async_setup_entry(hass: HomeAssistant, config_entry: ConfigEntry) -> b
|
|||||||
zha_data[DATA_ZHA_SHUTDOWN_TASK] = hass.bus.async_listen_once(
|
zha_data[DATA_ZHA_SHUTDOWN_TASK] = hass.bus.async_listen_once(
|
||||||
ha_const.EVENT_HOMEASSISTANT_STOP, async_zha_shutdown
|
ha_const.EVENT_HOMEASSISTANT_STOP, async_zha_shutdown
|
||||||
)
|
)
|
||||||
asyncio.create_task(async_load_entities(hass))
|
|
||||||
|
await zha_gateway.async_initialize_devices_and_entities()
|
||||||
|
await hass.config_entries.async_forward_entry_setups(config_entry, PLATFORMS)
|
||||||
|
async_dispatcher_send(hass, SIGNAL_ADD_ENTITIES)
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
|
||||||
@ -161,18 +158,6 @@ async def async_unload_entry(hass: HomeAssistant, config_entry: ConfigEntry) ->
|
|||||||
return True
|
return True
|
||||||
|
|
||||||
|
|
||||||
async def async_load_entities(hass: HomeAssistant) -> None:
|
|
||||||
"""Load entities after integration was setup."""
|
|
||||||
zha_gateway: ZHAGateway = hass.data[DATA_ZHA][DATA_ZHA_GATEWAY]
|
|
||||||
await zha_gateway.async_initialize_devices_and_entities()
|
|
||||||
to_setup = hass.data[DATA_ZHA][DATA_ZHA_PLATFORM_LOADED]
|
|
||||||
results = await asyncio.gather(*to_setup, return_exceptions=True)
|
|
||||||
for res in results:
|
|
||||||
if isinstance(res, Exception):
|
|
||||||
_LOGGER.warning("Couldn't setup zha platform: %s", res)
|
|
||||||
async_dispatcher_send(hass, SIGNAL_ADD_ENTITIES)
|
|
||||||
|
|
||||||
|
|
||||||
async def async_migrate_entry(hass: HomeAssistant, config_entry: ConfigEntry) -> bool:
|
async def async_migrate_entry(hass: HomeAssistant, config_entry: ConfigEntry) -> bool:
|
||||||
"""Migrate old entry."""
|
"""Migrate old entry."""
|
||||||
_LOGGER.debug("Migrating from version %s", config_entry.version)
|
_LOGGER.debug("Migrating from version %s", config_entry.version)
|
||||||
|
@ -171,7 +171,6 @@ DATA_ZHA_CONFIG = "config"
|
|||||||
DATA_ZHA_BRIDGE_ID = "zha_bridge_id"
|
DATA_ZHA_BRIDGE_ID = "zha_bridge_id"
|
||||||
DATA_ZHA_CORE_EVENTS = "zha_core_events"
|
DATA_ZHA_CORE_EVENTS = "zha_core_events"
|
||||||
DATA_ZHA_GATEWAY = "zha_gateway"
|
DATA_ZHA_GATEWAY = "zha_gateway"
|
||||||
DATA_ZHA_PLATFORM_LOADED = "platform_loaded"
|
|
||||||
DATA_ZHA_SHUTDOWN_TASK = "zha_shutdown_task"
|
DATA_ZHA_SHUTDOWN_TASK = "zha_shutdown_task"
|
||||||
|
|
||||||
DEBUG_COMP_BELLOWS = "bellows"
|
DEBUG_COMP_BELLOWS = "bellows"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user