"""Support for AVM Fritz!Box functions.""" import logging from fritzconnection.core.exceptions import FritzConnectionException, FritzSecurityError from fritzconnection.core.logger import fritzlogger from homeassistant.config_entries import ConfigEntry from homeassistant.const import ( CONF_HOST, CONF_PASSWORD, CONF_PORT, CONF_USERNAME, EVENT_HOMEASSISTANT_STOP, ) from homeassistant.core import Event, HomeAssistant, callback from homeassistant.exceptions import ConfigEntryAuthFailed, ConfigEntryNotReady from .common import FritzBoxTools, FritzData from .const import DATA_FRITZ, DOMAIN, PLATFORMS from .services import async_setup_services, async_unload_services _LOGGER = logging.getLogger(__name__) level = _LOGGER.getEffectiveLevel() _LOGGER.info( "Setting logging level of fritzconnection: %s", logging.getLevelName(level) ) fritzlogger.set_level(level) fritzlogger.enable() async def async_setup_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool: """Set up fritzboxtools from config entry.""" _LOGGER.debug("Setting up FRITZ!Box Tools component") fritz_tools = FritzBoxTools( hass=hass, host=entry.data[CONF_HOST], port=entry.data[CONF_PORT], username=entry.data[CONF_USERNAME], password=entry.data[CONF_PASSWORD], ) try: await fritz_tools.async_setup() await fritz_tools.async_start(entry.options) except FritzSecurityError as ex: raise ConfigEntryAuthFailed from ex except FritzConnectionException as ex: raise ConfigEntryNotReady from ex hass.data.setdefault(DOMAIN, {}) hass.data[DOMAIN][entry.entry_id] = fritz_tools if DATA_FRITZ not in hass.data: hass.data[DATA_FRITZ] = FritzData() @callback def _async_unload(event: Event) -> None: fritz_tools.async_unload() entry.async_on_unload( hass.bus.async_listen_once(EVENT_HOMEASSISTANT_STOP, _async_unload) ) entry.async_on_unload(entry.add_update_listener(update_listener)) # Load the other platforms like switch hass.config_entries.async_setup_platforms(entry, PLATFORMS) await async_setup_services(hass) return True async def async_unload_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool: """Unload FRITZ!Box Tools config entry.""" fritzbox: FritzBoxTools = hass.data[DOMAIN][entry.entry_id] fritzbox.async_unload() fritz_data = hass.data[DATA_FRITZ] fritz_data.tracked.pop(fritzbox.unique_id) if not bool(fritz_data.tracked): hass.data.pop(DATA_FRITZ) unload_ok = await hass.config_entries.async_unload_platforms(entry, PLATFORMS) if unload_ok: hass.data[DOMAIN].pop(entry.entry_id) await async_unload_services(hass) return unload_ok async def update_listener(hass: HomeAssistant, entry: ConfigEntry) -> None: """Update when config_entry options update.""" if entry.options: await hass.config_entries.async_reload(entry.entry_id)