Home Assistant Unofficial Reference 2024.12.1
lock.py
Go to the documentation of this file.
1 """Support for SimpliSafe locks."""
2 
3 from __future__ import annotations
4 
5 from typing import Any
6 
7 from simplipy.device.lock import Lock, LockStates
8 from simplipy.errors import SimplipyError
9 from simplipy.system.v3 import SystemV3
10 from simplipy.websocket import EVENT_LOCK_LOCKED, EVENT_LOCK_UNLOCKED, WebsocketEvent
11 
12 from homeassistant.components.lock import LockEntity
13 from homeassistant.config_entries import ConfigEntry
14 from homeassistant.core import HomeAssistant, callback
15 from homeassistant.exceptions import HomeAssistantError
16 from homeassistant.helpers.entity_platform import AddEntitiesCallback
17 
18 from . import SimpliSafe
19 from .const import DOMAIN, LOGGER
20 from .entity import SimpliSafeEntity
21 
22 ATTR_LOCK_LOW_BATTERY = "lock_low_battery"
23 ATTR_PIN_PAD_LOW_BATTERY = "pin_pad_low_battery"
24 
25 STATE_MAP_FROM_WEBSOCKET_EVENT = {
26  EVENT_LOCK_LOCKED: True,
27  EVENT_LOCK_UNLOCKED: False,
28 }
29 
30 WEBSOCKET_EVENTS_TO_LISTEN_FOR = (EVENT_LOCK_LOCKED, EVENT_LOCK_UNLOCKED)
31 
32 
34  hass: HomeAssistant, entry: ConfigEntry, async_add_entities: AddEntitiesCallback
35 ) -> None:
36  """Set up SimpliSafe locks based on a config entry."""
37  simplisafe = hass.data[DOMAIN][entry.entry_id]
38  locks: list[SimpliSafeLock] = []
39 
40  for system in simplisafe.systems.values():
41  if system.version == 2:
42  LOGGER.warning("Skipping lock setup for V2 system: %s", system.system_id)
43  continue
44 
45  locks.extend(
46  SimpliSafeLock(simplisafe, system, lock) for lock in system.locks.values()
47  )
48 
49  async_add_entities(locks)
50 
51 
53  """Define a SimpliSafe lock."""
54 
55  _attr_name = None
56  _device: Lock
57 
58  def __init__(self, simplisafe: SimpliSafe, system: SystemV3, lock: Lock) -> None:
59  """Initialize."""
60  super().__init__(
61  simplisafe,
62  system,
63  device=lock,
64  additional_websocket_events=WEBSOCKET_EVENTS_TO_LISTEN_FOR,
65  )
66 
67  async def async_lock(self, **kwargs: Any) -> None:
68  """Lock the lock."""
69  try:
70  await self._device_device.async_lock()
71  except SimplipyError as err:
72  raise HomeAssistantError(
73  f'Error while locking "{self._device.name}": {err}'
74  ) from err
75 
76  self._attr_is_locked_attr_is_locked = True
77  self.async_write_ha_stateasync_write_ha_state()
78 
79  async def async_unlock(self, **kwargs: Any) -> None:
80  """Unlock the lock."""
81  try:
82  await self._device_device.async_unlock()
83  except SimplipyError as err:
84  raise HomeAssistantError(
85  f'Error while unlocking "{self._device.name}": {err}'
86  ) from err
87 
88  self._attr_is_locked_attr_is_locked = False
89  self.async_write_ha_stateasync_write_ha_state()
90 
91  @callback
92  def async_update_from_rest_api(self) -> None:
93  """Update the entity with the provided REST API data."""
94  self._attr_is_jammed_attr_is_jammed = self._device_device.state == LockStates.JAMMED
95  self._attr_is_locked_attr_is_locked = self._device_device.state == LockStates.LOCKED
96 
97  self._attr_extra_state_attributes_attr_extra_state_attributes.update(
98  {
99  ATTR_LOCK_LOW_BATTERY: self._device_device.lock_low_battery,
100  ATTR_PIN_PAD_LOW_BATTERY: self._device_device.pin_pad_low_battery,
101  }
102  )
103 
104  @callback
105  def async_update_from_websocket_event(self, event: WebsocketEvent) -> None:
106  """Update the entity when new data comes from the websocket."""
107  assert event.event_type
108 
109  if state := STATE_MAP_FROM_WEBSOCKET_EVENT.get(event.event_type) is not None:
110  self._attr_is_locked_attr_is_locked = state
111  self.async_reset_error_countasync_reset_error_count()
112  else:
113  LOGGER.error("Unknown lock websocket event: %s", event.event_type)
114  self.async_increment_error_countasync_increment_error_count()
None __init__(self, SimpliSafe simplisafe, SystemV3 system, Lock lock)
Definition: lock.py:58
None async_update_from_websocket_event(self, WebsocketEvent event)
Definition: lock.py:105
IssData update(pyiss.ISS iss)
Definition: __init__.py:33
None async_setup_entry(HomeAssistant hass, ConfigEntry entry, AddEntitiesCallback async_add_entities)
Definition: lock.py:35