Home Assistant Unofficial Reference 2024.12.1
button.py
Go to the documentation of this file.
1 """Support for relays and actions in a DoorBird video doorbell."""
2 
3 from collections.abc import Callable, Coroutine
4 from dataclasses import dataclass, replace
5 from typing import Any
6 
7 from homeassistant.components.button import ButtonEntity, ButtonEntityDescription
8 from homeassistant.const import EntityCategory
9 from homeassistant.core import HomeAssistant
10 from homeassistant.helpers.entity_platform import AddEntitiesCallback
11 
12 from .device import ConfiguredDoorBird, async_reset_device_favorites
13 from .entity import DoorBirdEntity
14 from .models import DoorBirdConfigEntry, DoorBirdData
15 
16 IR_RELAY = "__ir_light__"
17 
18 
19 @dataclass(frozen=True, kw_only=True)
21  """Class to describe a Doorbird Button entity."""
22 
23  press_action: Callable[[ConfiguredDoorBird, str], Coroutine[Any, Any, bool | None]]
24 
25 
26 RELAY_ENTITY_DESCRIPTION = DoorbirdButtonEntityDescription(
27  key="relay",
28  press_action=lambda door_station, relay: door_station.device.energize_relay(relay),
29 )
30 BUTTON_DESCRIPTIONS: tuple[DoorbirdButtonEntityDescription, ...] = (
32  key="__ir_light__",
33  translation_key="ir",
34  press_action=lambda door_station, _: door_station.device.turn_light_on(),
35  ),
37  key="reset_favorites",
38  translation_key="reset_favorites",
39  press_action=lambda door_station, _: async_reset_device_favorites(door_station),
40  entity_category=EntityCategory.CONFIG,
41  ),
42 )
43 
44 
46  hass: HomeAssistant,
47  config_entry: DoorBirdConfigEntry,
48  async_add_entities: AddEntitiesCallback,
49 ) -> None:
50  """Set up the DoorBird button platform."""
51  door_bird_data = config_entry.runtime_data
52  relays: list[str] = door_bird_data.door_station_info["RELAYS"]
53  entities = [
55  door_bird_data,
56  replace(RELAY_ENTITY_DESCRIPTION, name=f"Relay {relay}"),
57  relay,
58  )
59  for relay in relays
60  ]
61  entities.extend(
62  DoorBirdButton(door_bird_data, button_description)
63  for button_description in BUTTON_DESCRIPTIONS
64  )
65  async_add_entities(entities)
66 
67 
69  """A button for a DoorBird device."""
70 
71  entity_description: DoorbirdButtonEntityDescription
72 
73  def __init__(
74  self,
75  door_bird_data: DoorBirdData,
76  entity_description: DoorbirdButtonEntityDescription,
77  relay: str | None = None,
78  ) -> None:
79  """Initialize a button for a DoorBird device."""
80  super().__init__(door_bird_data)
81  self._relay_relay = relay or ""
82  self.entity_descriptionentity_description = entity_description
83  self._attr_unique_id_attr_unique_id = f"{self._mac_addr}_{relay or entity_description.key}"
84 
85  async def async_press(self) -> None:
86  """Call the press action."""
87  await self.entity_descriptionentity_description.press_action(self._door_station_door_station, self._relay_relay)
None __init__(self, DoorBirdData door_bird_data, DoorbirdButtonEntityDescription entity_description, str|None relay=None)
Definition: button.py:78
None async_setup_entry(HomeAssistant hass, DoorBirdConfigEntry config_entry, AddEntitiesCallback async_add_entities)
Definition: button.py:49
None async_reset_device_favorites(ConfiguredDoorBird door_station)
Definition: device.py:258