Home Assistant Unofficial Reference 2024.12.1
device_trigger.py
Go to the documentation of this file.
1 """Provides device automations for Vacuum."""
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, STATE_CLEANING, STATE_DOCKED
23 
24 TRIGGER_TYPES = {"cleaning", "docked"}
25 
26 TRIGGER_SCHEMA = DEVICE_TRIGGER_BASE_SCHEMA.extend(
27  {
28  vol.Required(CONF_ENTITY_ID): cv.entity_id_or_uuid,
29  vol.Required(CONF_TYPE): vol.In(TRIGGER_TYPES),
30  vol.Optional(CONF_FOR): cv.positive_time_period_dict,
31  }
32 )
33 
34 
36  hass: HomeAssistant, device_id: str
37 ) -> list[dict[str, str]]:
38  """List device triggers for Vacuum devices."""
39  registry = er.async_get(hass)
40  triggers = []
41 
42  # Get all the integrations entities for this device
43  for entry in er.async_entries_for_device(registry, device_id):
44  if entry.domain != DOMAIN:
45  continue
46 
47  triggers += [
48  {
49  CONF_PLATFORM: "device",
50  CONF_DEVICE_ID: device_id,
51  CONF_DOMAIN: DOMAIN,
52  CONF_ENTITY_ID: entry.id,
53  CONF_TYPE: trigger,
54  }
55  for trigger in TRIGGER_TYPES
56  ]
57 
58  return triggers
59 
60 
62  hass: HomeAssistant, config: ConfigType
63 ) -> dict[str, vol.Schema]:
64  """List trigger capabilities."""
65  return {
66  "extra_fields": vol.Schema(
67  {vol.Optional(CONF_FOR): cv.positive_time_period_dict}
68  )
69  }
70 
71 
73  hass: HomeAssistant,
74  config: ConfigType,
75  action: TriggerActionType,
76  trigger_info: TriggerInfo,
77 ) -> CALLBACK_TYPE:
78  """Attach a trigger."""
79  if config[CONF_TYPE] == "cleaning":
80  to_state = STATE_CLEANING
81  else:
82  to_state = STATE_DOCKED
83 
84  state_config = {
85  CONF_PLATFORM: "state",
86  CONF_ENTITY_ID: config[CONF_ENTITY_ID],
87  state_trigger.CONF_TO: to_state,
88  }
89  if CONF_FOR in config:
90  state_config[CONF_FOR] = config[CONF_FOR]
91  state_config = await state_trigger.async_validate_trigger_config(hass, state_config)
92  return await state_trigger.async_attach_trigger(
93  hass, state_config, action, trigger_info, platform_type="device"
94  )
CALLBACK_TYPE async_attach_trigger(HomeAssistant hass, ConfigType config, TriggerActionType action, TriggerInfo trigger_info)
list[dict[str, str]] async_get_triggers(HomeAssistant hass, str device_id)
dict[str, vol.Schema] async_get_trigger_capabilities(HomeAssistant hass, ConfigType config)