2021-04-11 20:35:25 +00:00
|
|
|
"""A wrapper 'hub' for the Litter-Robot API."""
|
2022-02-23 07:44:35 +00:00
|
|
|
from __future__ import annotations
|
|
|
|
|
2022-08-25 16:32:27 +00:00
|
|
|
from collections.abc import Generator, Mapping
|
2021-04-11 20:35:25 +00:00
|
|
|
from datetime import timedelta
|
2021-02-22 18:53:57 +00:00
|
|
|
import logging
|
2022-07-25 20:52:13 +00:00
|
|
|
from typing import Any
|
2021-02-22 18:53:57 +00:00
|
|
|
|
2022-08-29 15:48:24 +00:00
|
|
|
from pylitterbot import Account, FeederRobot, LitterRobot
|
2021-02-22 18:53:57 +00:00
|
|
|
from pylitterbot.exceptions import LitterRobotException, LitterRobotLoginException
|
|
|
|
|
|
|
|
from homeassistant.const import CONF_PASSWORD, CONF_USERNAME
|
|
|
|
from homeassistant.core import HomeAssistant
|
2022-08-29 04:40:28 +00:00
|
|
|
from homeassistant.exceptions import ConfigEntryAuthFailed, ConfigEntryNotReady
|
2022-08-25 16:32:27 +00:00
|
|
|
from homeassistant.helpers.aiohttp_client import async_get_clientsession
|
2021-04-11 20:35:25 +00:00
|
|
|
from homeassistant.helpers.update_coordinator import DataUpdateCoordinator
|
2021-02-22 18:53:57 +00:00
|
|
|
|
|
|
|
from .const import DOMAIN
|
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
2021-11-19 05:29:38 +00:00
|
|
|
UPDATE_INTERVAL_SECONDS = 20
|
2021-02-22 18:53:57 +00:00
|
|
|
|
|
|
|
|
|
|
|
class LitterRobotHub:
|
|
|
|
"""A Litter-Robot hub wrapper class."""
|
|
|
|
|
2022-07-25 20:52:13 +00:00
|
|
|
def __init__(self, hass: HomeAssistant, data: Mapping[str, Any]) -> None:
|
2021-02-22 18:53:57 +00:00
|
|
|
"""Initialize the Litter-Robot hub."""
|
|
|
|
self._data = data
|
2022-08-25 16:32:27 +00:00
|
|
|
self.account = Account(websession=async_get_clientsession(hass))
|
2021-02-22 18:53:57 +00:00
|
|
|
|
2021-04-11 20:35:25 +00:00
|
|
|
async def _async_update_data() -> bool:
|
2021-02-22 18:53:57 +00:00
|
|
|
"""Update all device states from the Litter-Robot API."""
|
|
|
|
await self.account.refresh_robots()
|
|
|
|
return True
|
|
|
|
|
|
|
|
self.coordinator = DataUpdateCoordinator(
|
|
|
|
hass,
|
|
|
|
_LOGGER,
|
|
|
|
name=DOMAIN,
|
|
|
|
update_method=_async_update_data,
|
2021-04-11 20:35:25 +00:00
|
|
|
update_interval=timedelta(seconds=UPDATE_INTERVAL_SECONDS),
|
2021-02-22 18:53:57 +00:00
|
|
|
)
|
|
|
|
|
2021-04-11 20:35:25 +00:00
|
|
|
async def login(self, load_robots: bool = False) -> None:
|
2021-02-22 18:53:57 +00:00
|
|
|
"""Login to Litter-Robot."""
|
|
|
|
try:
|
|
|
|
await self.account.connect(
|
|
|
|
username=self._data[CONF_USERNAME],
|
|
|
|
password=self._data[CONF_PASSWORD],
|
|
|
|
load_robots=load_robots,
|
|
|
|
)
|
2022-02-23 07:44:35 +00:00
|
|
|
return
|
2021-02-22 18:53:57 +00:00
|
|
|
except LitterRobotLoginException as ex:
|
2022-08-29 04:40:28 +00:00
|
|
|
raise ConfigEntryAuthFailed("Invalid credentials") from ex
|
2021-02-22 18:53:57 +00:00
|
|
|
except LitterRobotException as ex:
|
2022-08-29 04:40:28 +00:00
|
|
|
raise ConfigEntryNotReady("Unable to connect to Litter-Robot API") from ex
|
2022-08-25 16:32:27 +00:00
|
|
|
|
|
|
|
def litter_robots(self) -> Generator[LitterRobot, Any, Any]:
|
|
|
|
"""Get Litter-Robots from the account."""
|
|
|
|
return (
|
|
|
|
robot for robot in self.account.robots if isinstance(robot, LitterRobot)
|
|
|
|
)
|
2022-08-29 15:48:24 +00:00
|
|
|
|
|
|
|
def feeder_robots(self) -> Generator[FeederRobot, Any, Any]:
|
|
|
|
"""Get Feeder-Robots from the account."""
|
|
|
|
return (
|
|
|
|
robot for robot in self.account.robots if isinstance(robot, FeederRobot)
|
|
|
|
)
|