2019-12-13 14:38:41 +00:00
|
|
|
"""Helpers to help with integration platforms."""
|
2021-04-20 15:40:41 +00:00
|
|
|
from __future__ import annotations
|
|
|
|
|
2019-12-13 14:38:41 +00:00
|
|
|
import asyncio
|
2021-09-29 14:32:11 +00:00
|
|
|
from collections.abc import Awaitable, Callable
|
2019-12-13 14:38:41 +00:00
|
|
|
import logging
|
2021-09-29 14:32:11 +00:00
|
|
|
from typing import Any
|
2019-12-13 14:38:41 +00:00
|
|
|
|
|
|
|
from homeassistant.core import Event, HomeAssistant
|
2020-06-25 01:14:50 +00:00
|
|
|
from homeassistant.loader import async_get_integration, bind_hass
|
2019-12-13 14:38:41 +00:00
|
|
|
from homeassistant.setup import ATTR_COMPONENT, EVENT_COMPONENT_LOADED
|
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
@bind_hass
|
|
|
|
async def async_process_integration_platforms(
|
|
|
|
hass: HomeAssistant,
|
|
|
|
platform_name: str,
|
|
|
|
# Any = platform.
|
|
|
|
process_platform: Callable[[HomeAssistant, str, Any], Awaitable[None]],
|
|
|
|
) -> None:
|
|
|
|
"""Process a specific platform for all current and future loaded integrations."""
|
|
|
|
|
|
|
|
async def _process(component_name: str) -> None:
|
2021-08-25 18:37:03 +00:00
|
|
|
"""Process component being loaded."""
|
2020-06-25 01:14:50 +00:00
|
|
|
if "." in component_name:
|
|
|
|
return
|
|
|
|
|
|
|
|
integration = await async_get_integration(hass, component_name)
|
|
|
|
|
2019-12-13 14:38:41 +00:00
|
|
|
try:
|
|
|
|
platform = integration.get_platform(platform_name)
|
2020-06-25 01:14:50 +00:00
|
|
|
except ImportError as err:
|
|
|
|
if f"{component_name}.{platform_name}" not in str(err):
|
|
|
|
_LOGGER.exception(
|
|
|
|
"Unexpected error importing %s/%s.py",
|
|
|
|
component_name,
|
|
|
|
platform_name,
|
|
|
|
)
|
2019-12-13 14:38:41 +00:00
|
|
|
return
|
|
|
|
|
|
|
|
try:
|
|
|
|
await process_platform(hass, component_name, platform)
|
|
|
|
except Exception: # pylint: disable=broad-except
|
|
|
|
_LOGGER.exception(
|
|
|
|
"Error processing platform %s.%s", component_name, platform_name
|
|
|
|
)
|
|
|
|
|
|
|
|
async def async_component_loaded(event: Event) -> None:
|
|
|
|
"""Handle a new component loaded."""
|
|
|
|
await _process(event.data[ATTR_COMPONENT])
|
|
|
|
|
|
|
|
hass.bus.async_listen(EVENT_COMPONENT_LOADED, async_component_loaded)
|
|
|
|
|
|
|
|
tasks = [_process(comp) for comp in hass.config.components]
|
|
|
|
|
|
|
|
if tasks:
|
|
|
|
await asyncio.gather(*tasks)
|