2020-07-20 09:52:52 +00:00
|
|
|
"""The Wolf SmartSet Service integration."""
|
2020-07-21 17:37:54 +00:00
|
|
|
from datetime import timedelta
|
2020-07-20 09:52:52 +00:00
|
|
|
import logging
|
|
|
|
|
2020-11-21 10:10:11 +00:00
|
|
|
from httpx import ConnectError, ConnectTimeout
|
2020-07-20 09:52:52 +00:00
|
|
|
from wolf_smartset.token_auth import InvalidAuth
|
2020-11-19 14:24:28 +00:00
|
|
|
from wolf_smartset.wolf_client import FetchFailed, WolfClient
|
2020-07-20 09:52:52 +00:00
|
|
|
|
|
|
|
from homeassistant.config_entries import ConfigEntry
|
|
|
|
from homeassistant.const import CONF_PASSWORD, CONF_USERNAME
|
|
|
|
from homeassistant.core import HomeAssistant
|
2020-11-21 10:10:11 +00:00
|
|
|
from homeassistant.exceptions import ConfigEntryNotReady
|
2020-07-20 09:52:52 +00:00
|
|
|
from homeassistant.helpers.update_coordinator import DataUpdateCoordinator, UpdateFailed
|
|
|
|
|
|
|
|
from .const import (
|
|
|
|
COORDINATOR,
|
|
|
|
DEVICE_GATEWAY,
|
|
|
|
DEVICE_ID,
|
|
|
|
DEVICE_NAME,
|
|
|
|
DOMAIN,
|
|
|
|
PARAMETERS,
|
|
|
|
)
|
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
2021-04-27 20:51:11 +00:00
|
|
|
PLATFORMS = ["sensor"]
|
2020-07-20 09:52:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def async_setup_entry(hass: HomeAssistant, entry: ConfigEntry):
|
|
|
|
"""Set up Wolf SmartSet Service from a config entry."""
|
|
|
|
username = entry.data[CONF_USERNAME]
|
|
|
|
password = entry.data[CONF_PASSWORD]
|
|
|
|
device_name = entry.data[DEVICE_NAME]
|
|
|
|
device_id = entry.data[DEVICE_ID]
|
|
|
|
gateway_id = entry.data[DEVICE_GATEWAY]
|
|
|
|
_LOGGER.debug(
|
2020-12-28 17:34:08 +00:00
|
|
|
"Setting up wolflink integration for device: %s (ID: %s, gateway: %s)",
|
2020-07-20 09:52:52 +00:00
|
|
|
device_name,
|
|
|
|
device_id,
|
|
|
|
gateway_id,
|
|
|
|
)
|
|
|
|
|
|
|
|
wolf_client = WolfClient(username, password)
|
|
|
|
|
2020-11-21 10:10:11 +00:00
|
|
|
try:
|
|
|
|
parameters = await fetch_parameters(wolf_client, gateway_id, device_id)
|
|
|
|
except InvalidAuth:
|
|
|
|
_LOGGER.debug("Authentication failed")
|
|
|
|
return False
|
2020-07-20 09:52:52 +00:00
|
|
|
|
|
|
|
async def async_update_data():
|
|
|
|
"""Update all stored entities for Wolf SmartSet."""
|
|
|
|
try:
|
|
|
|
values = await wolf_client.fetch_value(gateway_id, device_id, parameters)
|
|
|
|
return {v.value_id: v.value for v in values}
|
|
|
|
except ConnectError as exception:
|
2020-08-28 11:50:32 +00:00
|
|
|
raise UpdateFailed(
|
|
|
|
f"Error communicating with API: {exception}"
|
|
|
|
) from exception
|
2020-11-19 14:24:28 +00:00
|
|
|
except FetchFailed as exception:
|
|
|
|
raise UpdateFailed(
|
|
|
|
f"Could not fetch values from server due to: {exception}"
|
|
|
|
) from exception
|
2020-08-28 11:50:32 +00:00
|
|
|
except InvalidAuth as exception:
|
|
|
|
raise UpdateFailed("Invalid authentication during update.") from exception
|
2020-07-20 09:52:52 +00:00
|
|
|
|
|
|
|
coordinator = DataUpdateCoordinator(
|
|
|
|
hass,
|
|
|
|
_LOGGER,
|
|
|
|
name="wolflink",
|
|
|
|
update_method=async_update_data,
|
|
|
|
update_interval=timedelta(minutes=1),
|
|
|
|
)
|
|
|
|
|
|
|
|
await coordinator.async_refresh()
|
|
|
|
|
2021-04-27 20:51:11 +00:00
|
|
|
hass.data.setdefault(DOMAIN, {})
|
2020-07-20 09:52:52 +00:00
|
|
|
hass.data[DOMAIN][entry.entry_id] = {}
|
|
|
|
hass.data[DOMAIN][entry.entry_id][PARAMETERS] = parameters
|
|
|
|
hass.data[DOMAIN][entry.entry_id][COORDINATOR] = coordinator
|
|
|
|
hass.data[DOMAIN][entry.entry_id][DEVICE_ID] = device_id
|
|
|
|
|
2021-04-27 20:51:11 +00:00
|
|
|
hass.config_entries.async_setup_platforms(entry, PLATFORMS)
|
2020-07-20 09:52:52 +00:00
|
|
|
|
|
|
|
return True
|
|
|
|
|
|
|
|
|
|
|
|
async def async_unload_entry(hass: HomeAssistant, entry: ConfigEntry):
|
|
|
|
"""Unload a config entry."""
|
2021-04-27 20:51:11 +00:00
|
|
|
unload_ok = await hass.config_entries.async_unload_platforms(entry, PLATFORMS)
|
2020-07-20 09:52:52 +00:00
|
|
|
if unload_ok:
|
|
|
|
hass.data[DOMAIN].pop(entry.entry_id)
|
|
|
|
|
|
|
|
return unload_ok
|
|
|
|
|
|
|
|
|
|
|
|
async def fetch_parameters(client: WolfClient, gateway_id: int, device_id: int):
|
|
|
|
"""
|
|
|
|
Fetch all available parameters with usage of WolfClient.
|
|
|
|
|
|
|
|
By default Reglertyp entity is removed because API will not provide value for this parameter.
|
|
|
|
"""
|
|
|
|
try:
|
|
|
|
fetched_parameters = await client.fetch_parameters(gateway_id, device_id)
|
|
|
|
return [param for param in fetched_parameters if param.name != "Reglertyp"]
|
2020-11-21 10:10:11 +00:00
|
|
|
except (ConnectError, ConnectTimeout, FetchFailed) as exception:
|
|
|
|
raise ConfigEntryNotReady(
|
|
|
|
f"Error communicating with API: {exception}"
|
|
|
|
) from exception
|