Home Assistant Unofficial Reference 2024.12.1
device_trigger.py
Go to the documentation of this file.
1 """Provides device automations for Lock."""
2 
3 from __future__ import annotations
4 
5 import voluptuous as vol
6 
7 from homeassistant.components.device_automation import DEVICE_TRIGGER_BASE_SCHEMA
8 from homeassistant.components.homeassistant.triggers import state as state_trigger
9 from homeassistant.const import (
10  CONF_DEVICE_ID,
11  CONF_DOMAIN,
12  CONF_ENTITY_ID,
13  CONF_FOR,
14  CONF_PLATFORM,
15  CONF_TYPE,
16 )
17 from homeassistant.core import CALLBACK_TYPE, HomeAssistant
18 from homeassistant.helpers import config_validation as cv, entity_registry as er
19 from homeassistant.helpers.trigger import TriggerActionType, TriggerInfo
20 from homeassistant.helpers.typing import ConfigType
21 
22 from . import DOMAIN, LockState
23 
24 TRIGGER_TYPES = {
25  "jammed",
26  "locked",
27  "locking",
28  "open",
29  "opening",
30  "unlocked",
31  "unlocking",
32 }
33 
34 TRIGGER_SCHEMA = DEVICE_TRIGGER_BASE_SCHEMA.extend(
35  {
36  vol.Required(CONF_ENTITY_ID): cv.entity_id_or_uuid,
37  vol.Required(CONF_TYPE): vol.In(TRIGGER_TYPES),
38  vol.Optional(CONF_FOR): cv.positive_time_period_dict,
39  }
40 )
41 
42 
44  hass: HomeAssistant, device_id: str
45 ) -> list[dict[str, str]]:
46  """List device triggers for Lock devices."""
47  registry = er.async_get(hass)
48  triggers = []
49 
50  # Get all the integrations entities for this device
51  for entry in er.async_entries_for_device(registry, device_id):
52  if entry.domain != DOMAIN:
53  continue
54 
55  # Add triggers for each entity that belongs to this integration
56  triggers += [
57  {
58  CONF_PLATFORM: "device",
59  CONF_DEVICE_ID: device_id,
60  CONF_DOMAIN: DOMAIN,
61  CONF_ENTITY_ID: entry.id,
62  CONF_TYPE: trigger,
63  }
64  for trigger in TRIGGER_TYPES
65  ]
66 
67  return triggers
68 
69 
71  hass: HomeAssistant, config: ConfigType
72 ) -> dict[str, vol.Schema]:
73  """List trigger capabilities."""
74  return {
75  "extra_fields": vol.Schema(
76  {vol.Optional(CONF_FOR): cv.positive_time_period_dict}
77  )
78  }
79 
80 
82  hass: HomeAssistant,
83  config: ConfigType,
84  action: TriggerActionType,
85  trigger_info: TriggerInfo,
86 ) -> CALLBACK_TYPE:
87  """Attach a trigger."""
88  if config[CONF_TYPE] == "jammed":
89  to_state = LockState.JAMMED
90  elif config[CONF_TYPE] == "opening":
91  to_state = LockState.OPENING
92  elif config[CONF_TYPE] == "locking":
93  to_state = LockState.LOCKING
94  elif config[CONF_TYPE] == "open":
95  to_state = LockState.OPEN
96  elif config[CONF_TYPE] == "unlocking":
97  to_state = LockState.UNLOCKING
98  elif config[CONF_TYPE] == "locked":
99  to_state = LockState.LOCKED
100  else:
101  to_state = LockState.UNLOCKED
102 
103  state_config = {
104  CONF_PLATFORM: "state",
105  CONF_ENTITY_ID: config[CONF_ENTITY_ID],
106  state_trigger.CONF_TO: to_state,
107  }
108  if CONF_FOR in config:
109  state_config[CONF_FOR] = config[CONF_FOR]
110  state_config = await state_trigger.async_validate_trigger_config(hass, state_config)
111  return await state_trigger.async_attach_trigger(
112  hass, state_config, action, trigger_info, platform_type="device"
113  )
dict[str, vol.Schema] async_get_trigger_capabilities(HomeAssistant hass, ConfigType config)
list[dict[str, str]] async_get_triggers(HomeAssistant hass, str device_id)
CALLBACK_TYPE async_attach_trigger(HomeAssistant hass, ConfigType config, TriggerActionType action, TriggerInfo trigger_info)