2019-02-14 04:35:12 +00:00
|
|
|
"""Support for Hydrawise cloud."""
|
2018-05-26 16:42:52 +00:00
|
|
|
|
2019-12-04 13:09:35 +00:00
|
|
|
from hydrawiser.core import Hydrawiser
|
2018-05-26 16:42:52 +00:00
|
|
|
from requests.exceptions import ConnectTimeout, HTTPError
|
|
|
|
import voluptuous as vol
|
|
|
|
|
2022-01-11 17:51:16 +00:00
|
|
|
from homeassistant.components import persistent_notification
|
2022-10-18 09:18:22 +00:00
|
|
|
from homeassistant.const import CONF_ACCESS_TOKEN, CONF_SCAN_INTERVAL
|
2023-05-22 13:47:32 +00:00
|
|
|
from homeassistant.core import HomeAssistant
|
2019-12-04 13:09:35 +00:00
|
|
|
import homeassistant.helpers.config_validation as cv
|
2023-05-22 13:47:32 +00:00
|
|
|
from homeassistant.helpers.dispatcher import dispatcher_send
|
2018-05-26 16:42:52 +00:00
|
|
|
from homeassistant.helpers.event import track_time_interval
|
2022-01-02 15:31:48 +00:00
|
|
|
from homeassistant.helpers.typing import ConfigType
|
2018-05-26 16:42:52 +00:00
|
|
|
|
2023-05-22 13:11:32 +00:00
|
|
|
from .const import (
|
|
|
|
DATA_HYDRAWISE,
|
|
|
|
DOMAIN,
|
|
|
|
LOGGER,
|
|
|
|
NOTIFICATION_ID,
|
|
|
|
NOTIFICATION_TITLE,
|
|
|
|
SCAN_INTERVAL,
|
|
|
|
SIGNAL_UPDATE_HYDRAWISE,
|
|
|
|
)
|
2018-05-26 16:42:52 +00:00
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
CONFIG_SCHEMA = vol.Schema(
|
|
|
|
{
|
|
|
|
DOMAIN: vol.Schema(
|
|
|
|
{
|
|
|
|
vol.Required(CONF_ACCESS_TOKEN): cv.string,
|
|
|
|
vol.Optional(CONF_SCAN_INTERVAL, default=SCAN_INTERVAL): cv.time_period,
|
|
|
|
}
|
|
|
|
)
|
|
|
|
},
|
|
|
|
extra=vol.ALLOW_EXTRA,
|
|
|
|
)
|
2018-05-26 16:42:52 +00:00
|
|
|
|
|
|
|
|
2022-01-02 15:31:48 +00:00
|
|
|
def setup(hass: HomeAssistant, config: ConfigType) -> bool:
|
2018-05-26 16:42:52 +00:00
|
|
|
"""Set up the Hunter Hydrawise component."""
|
|
|
|
conf = config[DOMAIN]
|
|
|
|
access_token = conf[CONF_ACCESS_TOKEN]
|
|
|
|
scan_interval = conf.get(CONF_SCAN_INTERVAL)
|
|
|
|
|
|
|
|
try:
|
|
|
|
hydrawise = Hydrawiser(user_token=access_token)
|
|
|
|
hass.data[DATA_HYDRAWISE] = HydrawiseHub(hydrawise)
|
|
|
|
except (ConnectTimeout, HTTPError) as ex:
|
2023-05-22 13:11:32 +00:00
|
|
|
LOGGER.error("Unable to connect to Hydrawise cloud service: %s", str(ex))
|
2022-01-11 17:51:16 +00:00
|
|
|
persistent_notification.create(
|
|
|
|
hass,
|
2020-02-28 11:39:29 +00:00
|
|
|
f"Error: {ex}<br />You will need to restart hass after fixing.",
|
2018-05-26 16:42:52 +00:00
|
|
|
title=NOTIFICATION_TITLE,
|
2019-07-31 19:25:30 +00:00
|
|
|
notification_id=NOTIFICATION_ID,
|
|
|
|
)
|
2018-05-26 16:42:52 +00:00
|
|
|
return False
|
|
|
|
|
|
|
|
def hub_refresh(event_time):
|
|
|
|
"""Call Hydrawise hub to refresh information."""
|
2023-05-22 13:11:32 +00:00
|
|
|
LOGGER.debug("Updating Hydrawise Hub component")
|
2018-05-26 16:42:52 +00:00
|
|
|
hass.data[DATA_HYDRAWISE].data.update_controller_info()
|
|
|
|
dispatcher_send(hass, SIGNAL_UPDATE_HYDRAWISE)
|
|
|
|
|
|
|
|
# Call the Hydrawise API to refresh updates
|
|
|
|
track_time_interval(hass, hub_refresh, scan_interval)
|
|
|
|
|
|
|
|
return True
|
|
|
|
|
|
|
|
|
2018-07-20 08:45:20 +00:00
|
|
|
class HydrawiseHub:
|
2018-05-26 16:42:52 +00:00
|
|
|
"""Representation of a base Hydrawise device."""
|
|
|
|
|
|
|
|
def __init__(self, data):
|
|
|
|
"""Initialize the entity."""
|
|
|
|
self.data = data
|