core/homeassistant/components/skybell/__init__.py

118 lines
3.6 KiB
Python

"""Support for the Skybell HD Doorbell."""
from __future__ import annotations
import asyncio
import os
from aioskybell import Skybell
from aioskybell.exceptions import SkybellAuthenticationException, SkybellException
import voluptuous as vol
from homeassistant.config_entries import SOURCE_IMPORT, ConfigEntry
from homeassistant.const import CONF_EMAIL, CONF_PASSWORD, CONF_USERNAME, Platform
from homeassistant.core import HomeAssistant
from homeassistant.exceptions import ConfigEntryNotReady
from homeassistant.helpers import config_validation as cv
from homeassistant.helpers.aiohttp_client import async_get_clientsession
from homeassistant.helpers.typing import ConfigType
from .const import DEFAULT_CACHEDB, DOMAIN
from .coordinator import SkybellDataUpdateCoordinator
CONFIG_SCHEMA = vol.Schema(
vol.All(
# Deprecated in Home Assistant 2022.6
cv.deprecated(DOMAIN),
{
DOMAIN: vol.Schema(
{
vol.Required(CONF_USERNAME): cv.string,
vol.Required(CONF_PASSWORD): cv.string,
}
)
},
),
extra=vol.ALLOW_EXTRA,
)
PLATFORMS = [
Platform.BINARY_SENSOR,
Platform.CAMERA,
Platform.LIGHT,
Platform.SENSOR,
Platform.SWITCH,
]
async def async_setup(hass: HomeAssistant, config: ConfigType) -> bool:
"""Set up the SkyBell component."""
hass.data.setdefault(DOMAIN, {})
entry_config = {}
if DOMAIN not in config:
return True
for parameter, value in config[DOMAIN].items():
if parameter == CONF_USERNAME:
entry_config[CONF_EMAIL] = value
else:
entry_config[parameter] = value
hass.async_create_task(
hass.config_entries.flow.async_init(
DOMAIN,
context={"source": SOURCE_IMPORT},
data=entry_config,
)
)
# Clean up unused cache file since we are using an account specific name
# Remove with import
def clean_cache():
"""Clean old cache filename."""
if os.path.exists(hass.config.path(DEFAULT_CACHEDB)):
os.remove(hass.config.path(DEFAULT_CACHEDB))
await hass.async_add_executor_job(clean_cache)
return True
async def async_setup_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
"""Set up Skybell from a config entry."""
email = entry.data[CONF_EMAIL]
password = entry.data[CONF_PASSWORD]
api = Skybell(
username=email,
password=password,
get_devices=True,
cache_path=hass.config.path(f"./skybell_{entry.unique_id}.pickle"),
session=async_get_clientsession(hass),
)
try:
devices = await api.async_initialize()
except SkybellAuthenticationException:
return False
except SkybellException as ex:
raise ConfigEntryNotReady(f"Unable to connect to Skybell service: {ex}") from ex
device_coordinators: list[SkybellDataUpdateCoordinator] = [
SkybellDataUpdateCoordinator(hass, device) for device in devices
]
await asyncio.gather(
*[
coordinator.async_config_entry_first_refresh()
for coordinator in device_coordinators
]
)
hass.data[DOMAIN][entry.entry_id] = device_coordinators
hass.config_entries.async_setup_platforms(entry, PLATFORMS)
return True
async def async_unload_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
"""Unload a config entry."""
if unload_ok := await hass.config_entries.async_unload_platforms(entry, PLATFORMS):
hass.data[DOMAIN].pop(entry.entry_id)
return unload_ok