core/homeassistant/components/deluge/coordinator.py

70 lines
2.4 KiB
Python
Raw Normal View History

2022-03-23 04:01:24 +00:00
"""Data update coordinator for the Deluge integration."""
2022-03-23 04:01:24 +00:00
from __future__ import annotations
from datetime import timedelta
from ssl import SSLError
from typing import TYPE_CHECKING, Any
2022-03-23 04:01:24 +00:00
from deluge_client.client import DelugeRPCClient, FailedToReconnectException
from homeassistant.const import Platform
from homeassistant.core import HomeAssistant
from homeassistant.exceptions import ConfigEntryAuthFailed
from homeassistant.helpers.update_coordinator import DataUpdateCoordinator, UpdateFailed
from .const import LOGGER, DelugeGetSessionStatusKeys
2022-03-23 04:01:24 +00:00
if TYPE_CHECKING:
from . import DelugeConfigEntry
2022-03-23 04:01:24 +00:00
class DelugeDataUpdateCoordinator(
DataUpdateCoordinator[dict[Platform, dict[str, Any]]]
):
2022-03-23 04:01:24 +00:00
"""Data update coordinator for the Deluge integration."""
config_entry: DelugeConfigEntry
2022-03-23 04:01:24 +00:00
def __init__(
self, hass: HomeAssistant, api: DelugeRPCClient, entry: DelugeConfigEntry
2022-03-23 04:01:24 +00:00
) -> None:
"""Initialize the coordinator."""
super().__init__(
hass=hass,
logger=LOGGER,
name=entry.title,
update_interval=timedelta(seconds=30),
)
self.api = api
self.config_entry = entry
async def _async_update_data(self) -> dict[Platform, dict[str, Any]]:
2022-03-23 04:01:24 +00:00
"""Get the latest data from Deluge and updates the state."""
data = {}
try:
_data = await self.hass.async_add_executor_job(
2022-03-23 04:01:24 +00:00
self.api.call,
"core.get_session_status",
[iter_member.value for iter_member in list(DelugeGetSessionStatusKeys)],
2022-03-23 04:01:24 +00:00
)
data[Platform.SENSOR] = {k.decode(): v for k, v in _data.items()}
2022-03-23 04:01:24 +00:00
data[Platform.SWITCH] = await self.hass.async_add_executor_job(
self.api.call, "core.get_torrents_status", {}, ["paused"]
)
except (
ConnectionRefusedError,
TimeoutError,
2022-03-23 04:01:24 +00:00
SSLError,
FailedToReconnectException,
) as ex:
raise UpdateFailed(f"Connection to Deluge Daemon Lost: {ex}") from ex
2022-03-25 23:34:12 +00:00
except Exception as ex:
2022-03-23 04:01:24 +00:00
if type(ex).__name__ == "BadLoginError":
raise ConfigEntryAuthFailed(
"Credentials for Deluge client are not valid"
) from ex
LOGGER.error("Unknown error connecting to Deluge: %s", ex)
raise
2022-03-23 04:01:24 +00:00
return data