Home Assistant Unofficial Reference 2024.12.1
device_action.py
Go to the documentation of this file.
1 """Provides device actions for Humidifier."""
2 
3 from __future__ import annotations
4 
5 import voluptuous as vol
6 
8  async_get_entity_registry_entry_or_raise,
9  async_validate_entity_schema,
10  toggle_entity,
11 )
12 from homeassistant.const import (
13  ATTR_ENTITY_ID,
14  ATTR_MODE,
15  CONF_DEVICE_ID,
16  CONF_DOMAIN,
17  CONF_ENTITY_ID,
18  CONF_TYPE,
19 )
20 from homeassistant.core import Context, HomeAssistant
21 from homeassistant.exceptions import HomeAssistantError
22 from homeassistant.helpers import entity_registry as er
24 from homeassistant.helpers.entity import get_capability, get_supported_features
25 from homeassistant.helpers.typing import ConfigType, TemplateVarsType, VolDictType
26 
27 from . import DOMAIN, const
28 
29 # mypy: disallow-any-generics
30 
31 SET_HUMIDITY_SCHEMA = cv.DEVICE_ACTION_BASE_SCHEMA.extend(
32  {
33  vol.Required(CONF_TYPE): "set_humidity",
34  vol.Required(CONF_ENTITY_ID): cv.entity_id_or_uuid,
35  vol.Required(const.ATTR_HUMIDITY): vol.Coerce(int),
36  }
37 )
38 
39 SET_MODE_SCHEMA = cv.DEVICE_ACTION_BASE_SCHEMA.extend(
40  {
41  vol.Required(CONF_TYPE): "set_mode",
42  vol.Required(CONF_ENTITY_ID): cv.entity_id_or_uuid,
43  vol.Required(ATTR_MODE): cv.string,
44  }
45 )
46 
47 ONOFF_SCHEMA = toggle_entity.ACTION_SCHEMA.extend({vol.Required(CONF_DOMAIN): DOMAIN})
48 
49 _ACTION_SCHEMA = vol.Any(SET_HUMIDITY_SCHEMA, SET_MODE_SCHEMA, ONOFF_SCHEMA)
50 
51 
53  hass: HomeAssistant, config: ConfigType
54 ) -> ConfigType:
55  """Validate config."""
56  return async_validate_entity_schema(hass, config, _ACTION_SCHEMA)
57 
58 
60  hass: HomeAssistant, device_id: str
61 ) -> list[dict[str, str]]:
62  """List device actions for Humidifier devices."""
63  registry = er.async_get(hass)
64  actions = await toggle_entity.async_get_actions(hass, device_id, DOMAIN)
65 
66  # Get all the integrations entities for this device
67  for entry in er.async_entries_for_device(registry, device_id):
68  if entry.domain != DOMAIN:
69  continue
70 
71  supported_features = get_supported_features(hass, entry.entity_id)
72 
73  base_action = {
74  CONF_DEVICE_ID: device_id,
75  CONF_DOMAIN: DOMAIN,
76  CONF_ENTITY_ID: entry.id,
77  }
78  actions.append({**base_action, CONF_TYPE: "set_humidity"})
79 
80  if supported_features & const.HumidifierEntityFeature.MODES:
81  actions.append({**base_action, CONF_TYPE: "set_mode"})
82 
83  return actions
84 
85 
87  hass: HomeAssistant,
88  config: ConfigType,
89  variables: TemplateVarsType,
90  context: Context | None,
91 ) -> None:
92  """Execute a device action."""
93  service_data = {ATTR_ENTITY_ID: config[CONF_ENTITY_ID]}
94 
95  if config[CONF_TYPE] == "set_humidity":
96  service = const.SERVICE_SET_HUMIDITY
97  service_data[const.ATTR_HUMIDITY] = config[const.ATTR_HUMIDITY]
98  elif config[CONF_TYPE] == "set_mode":
99  service = const.SERVICE_SET_MODE
100  service_data[ATTR_MODE] = config[ATTR_MODE]
101  else:
102  await toggle_entity.async_call_action_from_config(
103  hass, config, variables, context, DOMAIN
104  )
105  return
106 
107  await hass.services.async_call(
108  DOMAIN, service, service_data, blocking=True, context=context
109  )
110 
111 
113  hass: HomeAssistant, config: ConfigType
114 ) -> dict[str, vol.Schema]:
115  """List action capabilities."""
116  action_type = config[CONF_TYPE]
117 
118  fields: VolDictType = {}
119 
120  if action_type == "set_humidity":
121  fields[vol.Required(const.ATTR_HUMIDITY)] = vol.Coerce(int)
122  elif action_type == "set_mode":
123  try:
125  hass, config[CONF_ENTITY_ID]
126  )
127  available_modes = (
128  get_capability(hass, entry.entity_id, const.ATTR_AVAILABLE_MODES) or []
129  )
130  except HomeAssistantError:
131  available_modes = []
132  fields[vol.Required(ATTR_MODE)] = vol.In(available_modes)
133  else:
134  return {}
135 
136  return {"extra_fields": vol.Schema(fields)}
er.RegistryEntry async_get_entity_registry_entry_or_raise(HomeAssistant hass, str entity_registry_id)
Definition: __init__.py:332
ConfigType async_validate_entity_schema(HomeAssistant hass, ConfigType config, VolSchemaType schema)
Definition: __init__.py:344
None async_call_action_from_config(HomeAssistant hass, ConfigType config, TemplateVarsType variables, Context|None context)
ConfigType async_validate_action_config(HomeAssistant hass, ConfigType config)
list[dict[str, str]] async_get_actions(HomeAssistant hass, str device_id)
dict[str, vol.Schema] async_get_action_capabilities(HomeAssistant hass, ConfigType config)
int get_supported_features(HomeAssistant hass, str entity_id)
Definition: entity.py:169
Any|None get_capability(HomeAssistant hass, str entity_id, str capability)
Definition: entity.py:139