1 """Provides device automations for Alarm control panel."""
3 from __future__
import annotations
5 from typing
import Final
7 import voluptuous
as vol
18 SERVICE_ALARM_ARM_AWAY,
19 SERVICE_ALARM_ARM_HOME,
20 SERVICE_ALARM_ARM_NIGHT,
21 SERVICE_ALARM_ARM_VACATION,
23 SERVICE_ALARM_TRIGGER,
31 from .
import ATTR_CODE_ARM_REQUIRED, DOMAIN
32 from .const
import AlarmControlPanelEntityFeature
34 ACTION_TYPES: Final[set[str]] = {
43 _ACTION_SCHEMA: Final = cv.DEVICE_ACTION_BASE_SCHEMA.extend(
45 vol.Required(CONF_TYPE): vol.In(ACTION_TYPES),
46 vol.Required(CONF_ENTITY_ID): cv.entity_id_or_uuid,
47 vol.Optional(CONF_CODE): cv.string,
53 hass: HomeAssistant, config: ConfigType
55 """Validate config."""
60 hass: HomeAssistant, device_id: str
61 ) -> list[dict[str, str]]:
62 """List device actions for Alarm control panel devices."""
63 registry = er.async_get(hass)
67 for entry
in er.async_entries_for_device(registry, device_id):
68 if entry.domain != DOMAIN:
74 CONF_DEVICE_ID: device_id,
76 CONF_ENTITY_ID: entry.id,
80 if supported_features & AlarmControlPanelEntityFeature.ARM_AWAY:
81 actions.append({**base_action, CONF_TYPE:
"arm_away"})
82 if supported_features & AlarmControlPanelEntityFeature.ARM_HOME:
83 actions.append({**base_action, CONF_TYPE:
"arm_home"})
84 if supported_features & AlarmControlPanelEntityFeature.ARM_NIGHT:
85 actions.append({**base_action, CONF_TYPE:
"arm_night"})
86 if supported_features & AlarmControlPanelEntityFeature.ARM_VACATION:
87 actions.append({**base_action, CONF_TYPE:
"arm_vacation"})
88 actions.append({**base_action, CONF_TYPE:
"disarm"})
89 if supported_features & AlarmControlPanelEntityFeature.TRIGGER:
90 actions.append({**base_action, CONF_TYPE:
"trigger"})
98 variables: TemplateVarsType,
99 context: Context |
None,
101 """Execute a device action."""
102 service_data = {ATTR_ENTITY_ID: config[CONF_ENTITY_ID]}
103 if CONF_CODE
in config:
104 service_data[ATTR_CODE] = config[CONF_CODE]
106 if config[CONF_TYPE] ==
"arm_away":
107 service = SERVICE_ALARM_ARM_AWAY
108 elif config[CONF_TYPE] ==
"arm_home":
109 service = SERVICE_ALARM_ARM_HOME
110 elif config[CONF_TYPE] ==
"arm_night":
111 service = SERVICE_ALARM_ARM_NIGHT
112 elif config[CONF_TYPE] ==
"arm_vacation":
113 service = SERVICE_ALARM_ARM_VACATION
114 elif config[CONF_TYPE] ==
"disarm":
115 service = SERVICE_ALARM_DISARM
116 elif config[CONF_TYPE] ==
"trigger":
117 service = SERVICE_ALARM_TRIGGER
119 await hass.services.async_call(
120 DOMAIN, service, service_data, blocking=
True, context=context
125 hass: HomeAssistant, config: ConfigType
126 ) -> dict[str, vol.Schema]:
127 """List action capabilities."""
130 registry = er.async_get(hass)
131 entity_id = er.async_resolve_entity_id(registry, config[CONF_ENTITY_ID])
132 state = hass.states.get(entity_id)
if entity_id
else None
133 code_required = state.attributes.get(ATTR_CODE_ARM_REQUIRED)
if state
else False
135 if config[CONF_TYPE] ==
"trigger" or (
136 config[CONF_TYPE] !=
"disarm" and not code_required
140 return {
"extra_fields": vol.Schema({vol.Optional(CONF_CODE): str})}
dict[str, vol.Schema] async_get_action_capabilities(HomeAssistant hass, ConfigType config)
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)
ConfigType async_validate_entity_schema(HomeAssistant hass, ConfigType config, VolSchemaType schema)
int get_supported_features(HomeAssistant hass, str entity_id)