Home Assistant Unofficial Reference 2024.12.1
device_action.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 async_validate_entity_schema
8 from homeassistant.const import (
9  ATTR_ENTITY_ID,
10  CONF_DEVICE_ID,
11  CONF_DOMAIN,
12  CONF_ENTITY_ID,
13  CONF_TYPE,
14 )
15 from homeassistant.core import Context, HomeAssistant
16 from homeassistant.helpers import entity_registry as er
18 from homeassistant.helpers.typing import ConfigType, TemplateVarsType
19 
20 from . import DOMAIN, SERVICE_RETURN_TO_BASE, SERVICE_START
21 
22 ACTION_TYPES = {"clean", "dock"}
23 
24 _ACTION_SCHEMA = cv.DEVICE_ACTION_BASE_SCHEMA.extend(
25  {
26  vol.Required(CONF_TYPE): vol.In(ACTION_TYPES),
27  vol.Required(CONF_ENTITY_ID): cv.entity_id_or_uuid,
28  }
29 )
30 
31 
33  hass: HomeAssistant, config: ConfigType
34 ) -> ConfigType:
35  """Validate config."""
36  return async_validate_entity_schema(hass, config, _ACTION_SCHEMA)
37 
38 
40  hass: HomeAssistant, device_id: str
41 ) -> list[dict[str, str]]:
42  """List device actions for Vacuum devices."""
43  registry = er.async_get(hass)
44  actions = []
45 
46  # Get all the integrations entities for this device
47  for entry in er.async_entries_for_device(registry, device_id):
48  if entry.domain != DOMAIN:
49  continue
50 
51  base_action = {
52  CONF_DEVICE_ID: device_id,
53  CONF_DOMAIN: DOMAIN,
54  CONF_ENTITY_ID: entry.id,
55  }
56 
57  actions.append({**base_action, CONF_TYPE: "clean"})
58  actions.append({**base_action, CONF_TYPE: "dock"})
59 
60  return actions
61 
62 
64  hass: HomeAssistant,
65  config: ConfigType,
66  variables: TemplateVarsType,
67  context: Context | None,
68 ) -> None:
69  """Execute a device action."""
70  service_data = {ATTR_ENTITY_ID: config[CONF_ENTITY_ID]}
71 
72  if config[CONF_TYPE] == "clean":
73  service = SERVICE_START
74  elif config[CONF_TYPE] == "dock":
75  service = SERVICE_RETURN_TO_BASE
76 
77  await hass.services.async_call(
78  DOMAIN, service, service_data, blocking=True, context=context
79  )
ConfigType async_validate_entity_schema(HomeAssistant hass, ConfigType config, VolSchemaType schema)
Definition: __init__.py:344
ConfigType async_validate_action_config(HomeAssistant hass, ConfigType config)
list[dict[str, str]] async_get_actions(HomeAssistant hass, str device_id)
None async_call_action_from_config(HomeAssistant hass, ConfigType config, TemplateVarsType variables, Context|None context)