Home Assistant Unofficial Reference 2024.12.1
device_trigger.py
Go to the documentation of this file.
1 """Provides device automations for Media player."""
2 
3 from __future__ import annotations
4 
5 import voluptuous as vol
6 
8  DEVICE_TRIGGER_BASE_SCHEMA,
9  entity,
10 )
11 from homeassistant.components.homeassistant.triggers import state as state_trigger
12 from homeassistant.const import (
13  CONF_DEVICE_ID,
14  CONF_DOMAIN,
15  CONF_ENTITY_ID,
16  CONF_FOR,
17  CONF_PLATFORM,
18  CONF_TYPE,
19  STATE_BUFFERING,
20  STATE_IDLE,
21  STATE_OFF,
22  STATE_ON,
23  STATE_PAUSED,
24  STATE_PLAYING,
25 )
26 from homeassistant.core import CALLBACK_TYPE, HomeAssistant
27 from homeassistant.helpers import config_validation as cv, entity_registry as er
28 from homeassistant.helpers.trigger import TriggerActionType, TriggerInfo
29 from homeassistant.helpers.typing import ConfigType
30 
31 from .const import DOMAIN
32 
33 TRIGGER_TYPES = {"turned_on", "turned_off", "buffering", "idle", "paused", "playing"}
34 
35 MEDIA_PLAYER_TRIGGER_SCHEMA = DEVICE_TRIGGER_BASE_SCHEMA.extend(
36  {
37  vol.Required(CONF_ENTITY_ID): cv.entity_id_or_uuid,
38  vol.Required(CONF_TYPE): vol.In(TRIGGER_TYPES),
39  vol.Optional(CONF_FOR): cv.positive_time_period_dict,
40  }
41 )
42 
43 TRIGGER_SCHEMA = vol.All(
44  vol.Any(
45  MEDIA_PLAYER_TRIGGER_SCHEMA,
46  entity.TRIGGER_SCHEMA,
47  ),
48  vol.Schema({vol.Required(CONF_DOMAIN): DOMAIN}, extra=vol.ALLOW_EXTRA),
49 )
50 
51 
53  hass: HomeAssistant, device_id: str
54 ) -> list[dict[str, str]]:
55  """List device triggers for Media player entities."""
56  registry = er.async_get(hass)
57  triggers = await entity.async_get_triggers(hass, device_id, DOMAIN)
58 
59  # Get all the integration entities for this device
60  for entry in er.async_entries_for_device(registry, device_id):
61  if entry.domain != DOMAIN:
62  continue
63 
64  # Add triggers for each entity that belongs to this integration
65  triggers += [
66  {
67  CONF_PLATFORM: "device",
68  CONF_DEVICE_ID: device_id,
69  CONF_DOMAIN: DOMAIN,
70  CONF_ENTITY_ID: entry.id,
71  CONF_TYPE: trigger,
72  }
73  for trigger in TRIGGER_TYPES
74  ]
75 
76  return triggers
77 
78 
80  hass: HomeAssistant, config: ConfigType
81 ) -> dict[str, vol.Schema]:
82  """List trigger capabilities."""
83  if config[CONF_TYPE] not in TRIGGER_TYPES:
84  return await entity.async_get_trigger_capabilities(hass, config)
85  return {
86  "extra_fields": vol.Schema(
87  {vol.Optional(CONF_FOR): cv.positive_time_period_dict}
88  )
89  }
90 
91 
93  hass: HomeAssistant,
94  config: ConfigType,
95  action: TriggerActionType,
96  trigger_info: TriggerInfo,
97 ) -> CALLBACK_TYPE:
98  """Attach a trigger."""
99  if config[CONF_TYPE] not in TRIGGER_TYPES:
100  return await entity.async_attach_trigger(hass, config, action, trigger_info)
101  if config[CONF_TYPE] == "buffering":
102  to_state = STATE_BUFFERING
103  elif config[CONF_TYPE] == "idle":
104  to_state = STATE_IDLE
105  elif config[CONF_TYPE] == "turned_off":
106  to_state = STATE_OFF
107  elif config[CONF_TYPE] == "turned_on":
108  to_state = STATE_ON
109  elif config[CONF_TYPE] == "paused":
110  to_state = STATE_PAUSED
111  else: # "playing"
112  to_state = STATE_PLAYING
113 
114  state_config = {
115  CONF_PLATFORM: "state",
116  CONF_ENTITY_ID: config[CONF_ENTITY_ID],
117  state_trigger.CONF_TO: to_state,
118  }
119  if CONF_FOR in config:
120  state_config[CONF_FOR] = config[CONF_FOR]
121  state_config = await state_trigger.async_validate_trigger_config(hass, state_config)
122  return await state_trigger.async_attach_trigger(
123  hass, state_config, action, trigger_info, platform_type="device"
124  )
list[dict[str, str]] async_get_triggers(HomeAssistant hass, str device_id)
dict[str, vol.Schema] async_get_trigger_capabilities(HomeAssistant hass, ConfigType config)
CALLBACK_TYPE async_attach_trigger(HomeAssistant hass, ConfigType config, TriggerActionType action, TriggerInfo trigger_info)