72 lines
2.0 KiB
Python
72 lines
2.0 KiB
Python
"""Device action validator."""
|
|
from __future__ import annotations
|
|
|
|
from typing import Any, Protocol
|
|
|
|
import voluptuous as vol
|
|
|
|
from homeassistant.const import CONF_DOMAIN
|
|
from homeassistant.core import Context, HomeAssistant
|
|
from homeassistant.helpers import config_validation as cv
|
|
from homeassistant.helpers.typing import ConfigType
|
|
|
|
from . import DeviceAutomationType, async_get_device_automation_platform
|
|
from .helpers import async_validate_device_automation_config
|
|
|
|
|
|
class DeviceAutomationActionProtocol(Protocol):
|
|
"""Define the format of device_action modules.
|
|
|
|
Each module must define either ACTION_SCHEMA or async_validate_action_config.
|
|
"""
|
|
|
|
ACTION_SCHEMA: vol.Schema
|
|
|
|
async def async_validate_action_config(
|
|
self, hass: HomeAssistant, config: ConfigType
|
|
) -> ConfigType:
|
|
"""Validate config."""
|
|
|
|
async def async_call_action_from_config(
|
|
self,
|
|
hass: HomeAssistant,
|
|
config: ConfigType,
|
|
variables: dict[str, Any],
|
|
context: Context | None,
|
|
) -> None:
|
|
"""Execute a device action."""
|
|
|
|
async def async_get_action_capabilities(
|
|
self, hass: HomeAssistant, config: ConfigType
|
|
) -> dict[str, vol.Schema]:
|
|
"""List action capabilities."""
|
|
|
|
async def async_get_actions(
|
|
self, hass: HomeAssistant, device_id: str
|
|
) -> list[dict[str, Any]]:
|
|
"""List actions."""
|
|
|
|
|
|
async def async_validate_action_config(
|
|
hass: HomeAssistant, config: ConfigType
|
|
) -> ConfigType:
|
|
"""Validate config."""
|
|
return await async_validate_device_automation_config(
|
|
hass, config, cv.DEVICE_ACTION_SCHEMA, DeviceAutomationType.ACTION
|
|
)
|
|
|
|
|
|
async def async_call_action_from_config(
|
|
hass: HomeAssistant,
|
|
config: ConfigType,
|
|
variables: dict[str, Any],
|
|
context: Context | None,
|
|
) -> None:
|
|
"""Execute a device action."""
|
|
platform = await async_get_device_automation_platform(
|
|
hass,
|
|
config[CONF_DOMAIN],
|
|
DeviceAutomationType.ACTION,
|
|
)
|
|
await platform.async_call_action_from_config(hass, config, variables, context)
|