core/homeassistant/components/roku/__init__.py

64 lines
2.0 KiB
Python
Raw Normal View History

"""Support for Roku."""
2021-03-18 13:31:38 +00:00
from __future__ import annotations
2022-02-06 04:17:31 +00:00
from collections.abc import Callable
import logging
from rokuecp import RokuConnectionError, RokuError
2020-10-29 08:51:48 +00:00
from homeassistant.config_entries import ConfigEntry
2021-12-04 12:19:49 +00:00
from homeassistant.const import CONF_HOST, Platform
from homeassistant.core import HomeAssistant
from homeassistant.helpers import config_validation as cv
from .const import DOMAIN
from .coordinator import RokuDataUpdateCoordinator
CONFIG_SCHEMA = cv.removed(DOMAIN, raise_if_present=False)
2022-01-17 02:39:18 +00:00
PLATFORMS = [
Platform.BINARY_SENSOR,
Platform.MEDIA_PLAYER,
Platform.REMOTE,
Platform.SENSOR,
]
_LOGGER = logging.getLogger(__name__)
async def async_setup_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
"""Set up Roku from a config entry."""
hass.data.setdefault(DOMAIN, {})
2021-10-21 06:33:10 +00:00
if not (coordinator := hass.data[DOMAIN].get(entry.entry_id)):
coordinator = RokuDataUpdateCoordinator(hass, host=entry.data[CONF_HOST])
hass.data[DOMAIN][entry.entry_id] = coordinator
await coordinator.async_config_entry_first_refresh()
2019-07-31 19:25:30 +00:00
hass.config_entries.async_setup_platforms(entry, PLATFORMS)
return True
async def async_unload_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
"""Unload a config entry."""
unload_ok = await hass.config_entries.async_unload_platforms(entry, PLATFORMS)
if unload_ok:
hass.data[DOMAIN].pop(entry.entry_id)
return unload_ok
2022-02-06 04:17:31 +00:00
def roku_exception_handler(func: Callable) -> Callable:
"""Decorate Roku calls to handle Roku exceptions."""
2022-02-06 04:17:31 +00:00
async def handler(self, *args, **kwargs) -> None: # type: ignore
try:
await func(self, *args, **kwargs)
except RokuConnectionError as error:
if self.available:
_LOGGER.error("Error communicating with API: %s", error)
except RokuError as error:
if self.available:
_LOGGER.error("Invalid response from API: %s", error)
return handler