56 lines
1.6 KiB
Python
56 lines
1.6 KiB
Python
"""The openhome component."""
|
|
|
|
import asyncio
|
|
import logging
|
|
|
|
import aiohttp
|
|
from async_upnp_client.client import UpnpError
|
|
from openhomedevice.device import Device
|
|
|
|
from homeassistant.config_entries import ConfigEntry
|
|
from homeassistant.const import CONF_HOST, Platform
|
|
from homeassistant.core import HomeAssistant
|
|
from homeassistant.exceptions import ConfigEntryNotReady
|
|
from homeassistant.helpers import config_validation as cv
|
|
|
|
from .const import DOMAIN
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
PLATFORMS = [Platform.MEDIA_PLAYER, Platform.UPDATE]
|
|
|
|
CONFIG_SCHEMA = cv.empty_config_schema(DOMAIN)
|
|
|
|
|
|
async def async_unload_entry(hass: HomeAssistant, config_entry: ConfigEntry) -> bool:
|
|
"""Cleanup before removing config entry."""
|
|
unload_ok = await hass.config_entries.async_unload_platforms(
|
|
config_entry, PLATFORMS
|
|
)
|
|
hass.data[DOMAIN].pop(config_entry.entry_id)
|
|
|
|
return unload_ok
|
|
|
|
|
|
async def async_setup_entry(
|
|
hass: HomeAssistant,
|
|
config_entry: ConfigEntry,
|
|
) -> bool:
|
|
"""Set up the configuration config entry."""
|
|
_LOGGER.debug("Setting up config entry: %s", config_entry.unique_id)
|
|
|
|
device = await hass.async_add_executor_job(Device, config_entry.data[CONF_HOST])
|
|
|
|
try:
|
|
await device.init()
|
|
except (asyncio.TimeoutError, aiohttp.ClientError, UpnpError) as exc:
|
|
raise ConfigEntryNotReady from exc
|
|
|
|
_LOGGER.debug("Initialised device: %s", device.uuid())
|
|
|
|
hass.data.setdefault(DOMAIN, {})[config_entry.entry_id] = device
|
|
|
|
await hass.config_entries.async_forward_entry_setups(config_entry, PLATFORMS)
|
|
|
|
return True
|