2019-08-06 12:39:07 +00:00
|
|
|
"""This component provides HA switch support for Ring Door Bell/Chimes."""
|
2019-09-19 06:39:09 +00:00
|
|
|
from datetime import timedelta
|
2019-12-05 05:13:28 +00:00
|
|
|
import logging
|
|
|
|
|
2020-01-19 21:39:16 +00:00
|
|
|
import requests
|
|
|
|
|
2020-04-26 16:50:37 +00:00
|
|
|
from homeassistant.components.switch import SwitchEntity
|
2019-08-06 12:39:07 +00:00
|
|
|
from homeassistant.core import callback
|
2019-09-19 06:39:09 +00:00
|
|
|
import homeassistant.util.dt as dt_util
|
2019-08-06 12:39:07 +00:00
|
|
|
|
2020-01-15 16:10:42 +00:00
|
|
|
from . import DOMAIN
|
|
|
|
from .entity import RingEntityMixin
|
2019-08-06 12:39:07 +00:00
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
SIREN_ICON = "mdi:alarm-bell"
|
|
|
|
|
|
|
|
|
|
|
|
# It takes a few seconds for the API to correctly return an update indicating
|
|
|
|
# that the changes have been made. Once we request a change (i.e. a light
|
|
|
|
# being turned on) we simply wait for this time delta before we allow
|
|
|
|
# updates to take place.
|
|
|
|
|
|
|
|
SKIP_UPDATES_DELAY = timedelta(seconds=5)
|
|
|
|
|
|
|
|
|
2020-01-10 20:35:31 +00:00
|
|
|
async def async_setup_entry(hass, config_entry, async_add_entities):
|
2019-08-06 12:39:07 +00:00
|
|
|
"""Create the switches for the Ring devices."""
|
2020-01-15 16:10:42 +00:00
|
|
|
devices = hass.data[DOMAIN][config_entry.entry_id]["devices"]
|
2019-08-06 12:39:07 +00:00
|
|
|
switches = []
|
2020-01-14 20:54:45 +00:00
|
|
|
|
|
|
|
for device in devices["stickup_cams"]:
|
2019-08-06 12:39:07 +00:00
|
|
|
if device.has_capability("siren"):
|
2020-01-15 16:10:42 +00:00
|
|
|
switches.append(SirenSwitch(config_entry.entry_id, device))
|
2019-08-06 12:39:07 +00:00
|
|
|
|
2020-01-15 16:10:42 +00:00
|
|
|
async_add_entities(switches)
|
2019-08-06 12:39:07 +00:00
|
|
|
|
|
|
|
|
2020-04-26 16:50:37 +00:00
|
|
|
class BaseRingSwitch(RingEntityMixin, SwitchEntity):
|
2019-08-06 12:39:07 +00:00
|
|
|
"""Represents a switch for controlling an aspect of a ring device."""
|
|
|
|
|
2020-01-15 16:10:42 +00:00
|
|
|
def __init__(self, config_entry_id, device, device_type):
|
2019-08-06 12:39:07 +00:00
|
|
|
"""Initialize the switch."""
|
2020-01-15 16:10:42 +00:00
|
|
|
super().__init__(config_entry_id, device)
|
2019-08-06 12:39:07 +00:00
|
|
|
self._device_type = device_type
|
2019-09-03 19:14:39 +00:00
|
|
|
self._unique_id = f"{self._device.id}-{self._device_type}"
|
2020-01-14 20:54:45 +00:00
|
|
|
|
2019-08-06 12:39:07 +00:00
|
|
|
@property
|
|
|
|
def name(self):
|
|
|
|
"""Name of the device."""
|
2019-09-03 19:14:39 +00:00
|
|
|
return f"{self._device.name} {self._device_type}"
|
2019-08-06 12:39:07 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def unique_id(self):
|
|
|
|
"""Return a unique ID."""
|
|
|
|
return self._unique_id
|
|
|
|
|
|
|
|
|
|
|
|
class SirenSwitch(BaseRingSwitch):
|
|
|
|
"""Creates a switch to turn the ring cameras siren on and off."""
|
|
|
|
|
2020-01-15 16:10:42 +00:00
|
|
|
def __init__(self, config_entry_id, device):
|
2019-08-06 12:39:07 +00:00
|
|
|
"""Initialize the switch for a device with a siren."""
|
2020-01-15 16:10:42 +00:00
|
|
|
super().__init__(config_entry_id, device, "siren")
|
2019-09-19 06:39:09 +00:00
|
|
|
self._no_updates_until = dt_util.utcnow()
|
2020-01-15 16:10:42 +00:00
|
|
|
self._siren_on = device.siren > 0
|
|
|
|
|
|
|
|
@callback
|
|
|
|
def _update_callback(self):
|
|
|
|
"""Call update method."""
|
|
|
|
if self._no_updates_until > dt_util.utcnow():
|
|
|
|
return
|
|
|
|
|
|
|
|
self._siren_on = self._device.siren > 0
|
|
|
|
self.async_write_ha_state()
|
2019-08-06 12:39:07 +00:00
|
|
|
|
|
|
|
def _set_switch(self, new_state):
|
2020-01-05 12:09:17 +00:00
|
|
|
"""Update switch state, and causes Home Assistant to correctly update."""
|
2020-01-19 21:39:16 +00:00
|
|
|
try:
|
|
|
|
self._device.siren = new_state
|
|
|
|
except requests.Timeout:
|
|
|
|
_LOGGER.error("Time out setting %s siren to %s", self.entity_id, new_state)
|
|
|
|
return
|
|
|
|
|
2019-08-06 12:39:07 +00:00
|
|
|
self._siren_on = new_state > 0
|
2019-09-19 06:39:09 +00:00
|
|
|
self._no_updates_until = dt_util.utcnow() + SKIP_UPDATES_DELAY
|
2019-08-06 12:39:07 +00:00
|
|
|
self.schedule_update_ha_state()
|
|
|
|
|
|
|
|
@property
|
|
|
|
def is_on(self):
|
|
|
|
"""If the switch is currently on or off."""
|
|
|
|
return self._siren_on
|
|
|
|
|
|
|
|
def turn_on(self, **kwargs):
|
|
|
|
"""Turn the siren on for 30 seconds."""
|
|
|
|
self._set_switch(1)
|
|
|
|
|
|
|
|
def turn_off(self, **kwargs):
|
|
|
|
"""Turn the siren off."""
|
|
|
|
self._set_switch(0)
|
|
|
|
|
|
|
|
@property
|
|
|
|
def icon(self):
|
|
|
|
"""Return the icon."""
|
|
|
|
return SIREN_ICON
|