2020-02-28 03:44:23 +00:00
|
|
|
"""Base class for August entity."""
|
|
|
|
|
|
|
|
|
2021-04-24 12:13:25 +00:00
|
|
|
from homeassistant.const import EVENT_HOMEASSISTANT_STOP
|
2020-02-28 03:44:23 +00:00
|
|
|
from homeassistant.core import callback
|
|
|
|
from homeassistant.helpers.event import async_track_time_interval
|
|
|
|
|
|
|
|
|
|
|
|
class AugustSubscriberMixin:
|
|
|
|
"""Base implementation for a subscriber."""
|
|
|
|
|
|
|
|
def __init__(self, hass, update_interval):
|
|
|
|
"""Initialize an subscriber."""
|
|
|
|
super().__init__()
|
|
|
|
self._hass = hass
|
|
|
|
self._update_interval = update_interval
|
|
|
|
self._subscriptions = {}
|
|
|
|
self._unsub_interval = None
|
2021-04-24 12:13:25 +00:00
|
|
|
self._stop_interval = None
|
2020-02-28 03:44:23 +00:00
|
|
|
|
|
|
|
@callback
|
|
|
|
def async_subscribe_device_id(self, device_id, update_callback):
|
2020-10-25 12:27:51 +00:00
|
|
|
"""Add an callback subscriber.
|
|
|
|
|
|
|
|
Returns a callable that can be used to unsubscribe.
|
|
|
|
"""
|
2020-02-28 03:44:23 +00:00
|
|
|
if not self._subscriptions:
|
2021-04-24 12:13:25 +00:00
|
|
|
self._async_setup_listeners()
|
|
|
|
|
2020-02-28 03:44:23 +00:00
|
|
|
self._subscriptions.setdefault(device_id, []).append(update_callback)
|
|
|
|
|
2020-10-25 12:27:51 +00:00
|
|
|
def _unsubscribe():
|
|
|
|
self.async_unsubscribe_device_id(device_id, update_callback)
|
|
|
|
|
|
|
|
return _unsubscribe
|
|
|
|
|
2021-04-24 12:13:25 +00:00
|
|
|
@callback
|
|
|
|
def _async_setup_listeners(self):
|
|
|
|
"""Create interval and stop listeners."""
|
|
|
|
self._unsub_interval = async_track_time_interval(
|
|
|
|
self._hass, self._async_refresh, self._update_interval
|
|
|
|
)
|
|
|
|
|
|
|
|
@callback
|
|
|
|
def _async_cancel_update_interval(_):
|
|
|
|
self._stop_interval = None
|
|
|
|
self._unsub_interval()
|
|
|
|
|
|
|
|
self._stop_interval = self._hass.bus.async_listen(
|
|
|
|
EVENT_HOMEASSISTANT_STOP, _async_cancel_update_interval
|
|
|
|
)
|
|
|
|
|
2020-02-28 03:44:23 +00:00
|
|
|
@callback
|
|
|
|
def async_unsubscribe_device_id(self, device_id, update_callback):
|
|
|
|
"""Remove a callback subscriber."""
|
|
|
|
self._subscriptions[device_id].remove(update_callback)
|
|
|
|
if not self._subscriptions[device_id]:
|
|
|
|
del self._subscriptions[device_id]
|
2021-04-24 12:13:25 +00:00
|
|
|
|
|
|
|
if self._subscriptions:
|
|
|
|
return
|
|
|
|
|
|
|
|
self._unsub_interval()
|
|
|
|
self._unsub_interval = None
|
|
|
|
if self._stop_interval:
|
|
|
|
self._stop_interval()
|
|
|
|
self._stop_interval = None
|
2020-02-28 03:44:23 +00:00
|
|
|
|
|
|
|
@callback
|
|
|
|
def async_signal_device_id_update(self, device_id):
|
|
|
|
"""Call the callbacks for a device_id."""
|
|
|
|
if not self._subscriptions.get(device_id):
|
|
|
|
return
|
|
|
|
|
|
|
|
for update_callback in self._subscriptions[device_id]:
|
|
|
|
update_callback()
|