2021-04-25 10:10:33 +00:00
|
|
|
"""Support for AVM Fritz!Box functions."""
|
|
|
|
import logging
|
|
|
|
|
2021-12-30 11:53:54 +00:00
|
|
|
from fritzconnection.core.exceptions import (
|
|
|
|
FritzConnectionException,
|
|
|
|
FritzResourceError,
|
|
|
|
FritzSecurityError,
|
|
|
|
)
|
2021-04-25 10:10:33 +00:00
|
|
|
|
|
|
|
from homeassistant.config_entries import ConfigEntry
|
2021-12-16 12:24:32 +00:00
|
|
|
from homeassistant.const import CONF_HOST, CONF_PASSWORD, CONF_PORT, CONF_USERNAME
|
|
|
|
from homeassistant.core import HomeAssistant
|
2021-04-25 10:10:33 +00:00
|
|
|
from homeassistant.exceptions import ConfigEntryAuthFailed, ConfigEntryNotReady
|
|
|
|
|
2021-04-29 18:10:36 +00:00
|
|
|
from .common import FritzBoxTools, FritzData
|
|
|
|
from .const import DATA_FRITZ, DOMAIN, PLATFORMS
|
2021-05-11 20:56:52 +00:00
|
|
|
from .services import async_setup_services, async_unload_services
|
2021-04-25 10:10:33 +00:00
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
async def async_setup_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
|
|
|
|
"""Set up fritzboxtools from config entry."""
|
|
|
|
_LOGGER.debug("Setting up FRITZ!Box Tools component")
|
2022-01-06 11:15:40 +00:00
|
|
|
avm_device = FritzBoxTools(
|
2021-04-25 10:10:33 +00:00
|
|
|
hass=hass,
|
|
|
|
host=entry.data[CONF_HOST],
|
|
|
|
port=entry.data[CONF_PORT],
|
|
|
|
username=entry.data[CONF_USERNAME],
|
|
|
|
password=entry.data[CONF_PASSWORD],
|
|
|
|
)
|
|
|
|
|
|
|
|
try:
|
2022-01-06 11:15:40 +00:00
|
|
|
await avm_device.async_setup(entry.options)
|
2021-04-25 10:10:33 +00:00
|
|
|
except FritzSecurityError as ex:
|
|
|
|
raise ConfigEntryAuthFailed from ex
|
2021-12-30 11:53:54 +00:00
|
|
|
except (FritzConnectionException, FritzResourceError) as ex:
|
2021-04-25 10:10:33 +00:00
|
|
|
raise ConfigEntryNotReady from ex
|
|
|
|
|
|
|
|
hass.data.setdefault(DOMAIN, {})
|
2022-01-06 11:15:40 +00:00
|
|
|
hass.data[DOMAIN][entry.entry_id] = avm_device
|
2021-04-25 10:10:33 +00:00
|
|
|
|
2021-04-29 18:10:36 +00:00
|
|
|
if DATA_FRITZ not in hass.data:
|
|
|
|
hass.data[DATA_FRITZ] = FritzData()
|
|
|
|
|
2021-05-24 14:54:57 +00:00
|
|
|
entry.async_on_unload(entry.add_update_listener(update_listener))
|
|
|
|
|
2022-01-06 11:15:40 +00:00
|
|
|
await avm_device.async_config_entry_first_refresh()
|
2021-12-16 12:24:32 +00:00
|
|
|
|
2021-04-25 10:10:33 +00:00
|
|
|
# Load the other platforms like switch
|
2021-04-27 06:46:49 +00:00
|
|
|
hass.config_entries.async_setup_platforms(entry, PLATFORMS)
|
2021-04-25 10:10:33 +00:00
|
|
|
|
2021-05-11 20:56:52 +00:00
|
|
|
await async_setup_services(hass)
|
|
|
|
|
2021-04-25 10:10:33 +00:00
|
|
|
return True
|
|
|
|
|
|
|
|
|
2021-05-04 03:11:21 +00:00
|
|
|
async def async_unload_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
|
2021-04-25 10:10:33 +00:00
|
|
|
"""Unload FRITZ!Box Tools config entry."""
|
2022-01-06 11:15:40 +00:00
|
|
|
avm_device: FritzBoxTools = hass.data[DOMAIN][entry.entry_id]
|
2021-04-25 10:10:33 +00:00
|
|
|
|
2021-04-29 18:10:36 +00:00
|
|
|
fritz_data = hass.data[DATA_FRITZ]
|
2022-01-06 11:15:40 +00:00
|
|
|
fritz_data.tracked.pop(avm_device.unique_id)
|
2021-04-29 18:10:36 +00:00
|
|
|
|
|
|
|
if not bool(fritz_data.tracked):
|
|
|
|
hass.data.pop(DATA_FRITZ)
|
|
|
|
|
2021-04-27 06:46:49 +00:00
|
|
|
unload_ok = await hass.config_entries.async_unload_platforms(entry, PLATFORMS)
|
2021-04-25 10:10:33 +00:00
|
|
|
if unload_ok:
|
|
|
|
hass.data[DOMAIN].pop(entry.entry_id)
|
|
|
|
|
2021-05-11 20:56:52 +00:00
|
|
|
await async_unload_services(hass)
|
|
|
|
|
2021-04-25 10:10:33 +00:00
|
|
|
return unload_ok
|
2021-05-24 14:54:57 +00:00
|
|
|
|
|
|
|
|
2021-06-13 14:45:35 +00:00
|
|
|
async def update_listener(hass: HomeAssistant, entry: ConfigEntry) -> None:
|
2021-05-24 14:54:57 +00:00
|
|
|
"""Update when config_entry options update."""
|
|
|
|
if entry.options:
|
|
|
|
await hass.config_entries.async_reload(entry.entry_id)
|