2022-02-22 21:15:16 +00:00
|
|
|
"""Validate device conditions."""
|
|
|
|
from __future__ import annotations
|
|
|
|
|
2023-01-20 23:44:17 +00:00
|
|
|
from typing import TYPE_CHECKING, Any, Protocol
|
2022-02-22 21:15:16 +00:00
|
|
|
|
|
|
|
import voluptuous as vol
|
|
|
|
|
|
|
|
from homeassistant.const import CONF_DOMAIN
|
|
|
|
from homeassistant.core import HomeAssistant
|
|
|
|
from homeassistant.helpers import config_validation as cv
|
2023-02-24 03:30:51 +00:00
|
|
|
from homeassistant.helpers.condition import ConditionProtocol, trace_condition_function
|
2022-02-22 21:15:16 +00:00
|
|
|
from homeassistant.helpers.typing import ConfigType
|
|
|
|
|
2022-05-23 10:18:17 +00:00
|
|
|
from . import DeviceAutomationType, async_get_device_automation_platform
|
2023-01-20 23:44:17 +00:00
|
|
|
from .helpers import async_validate_device_automation_config
|
2022-02-22 21:15:16 +00:00
|
|
|
|
|
|
|
if TYPE_CHECKING:
|
|
|
|
from homeassistant.helpers import condition
|
|
|
|
|
|
|
|
|
2023-02-24 03:30:51 +00:00
|
|
|
class DeviceAutomationConditionProtocol(ConditionProtocol, Protocol):
|
2022-02-22 21:15:16 +00:00
|
|
|
"""Define the format of device_condition modules.
|
|
|
|
|
2023-02-24 03:30:51 +00:00
|
|
|
Each module must define either CONDITION_SCHEMA or async_validate_condition_config
|
|
|
|
from ConditionProtocol.
|
2022-02-22 21:15:16 +00:00
|
|
|
"""
|
|
|
|
|
2022-06-03 06:00:47 +00:00
|
|
|
async def async_get_condition_capabilities(
|
2022-05-19 16:24:01 +00:00
|
|
|
self, hass: HomeAssistant, config: ConfigType
|
2022-06-03 06:00:47 +00:00
|
|
|
) -> dict[str, vol.Schema]:
|
2022-05-19 16:24:01 +00:00
|
|
|
"""List condition capabilities."""
|
|
|
|
|
2022-06-03 06:00:47 +00:00
|
|
|
async def async_get_conditions(
|
2022-05-19 16:24:01 +00:00
|
|
|
self, hass: HomeAssistant, device_id: str
|
2022-06-03 06:00:47 +00:00
|
|
|
) -> list[dict[str, Any]]:
|
2022-05-19 16:24:01 +00:00
|
|
|
"""List conditions."""
|
2022-02-22 21:15:16 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def async_validate_condition_config(
|
|
|
|
hass: HomeAssistant, config: ConfigType
|
|
|
|
) -> ConfigType:
|
|
|
|
"""Validate device condition config."""
|
2023-01-20 23:44:17 +00:00
|
|
|
return await async_validate_device_automation_config(
|
|
|
|
hass, config, cv.DEVICE_CONDITION_SCHEMA, DeviceAutomationType.CONDITION
|
|
|
|
)
|
2022-02-22 21:15:16 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def async_condition_from_config(
|
|
|
|
hass: HomeAssistant, config: ConfigType
|
|
|
|
) -> condition.ConditionCheckerType:
|
|
|
|
"""Test a device condition."""
|
|
|
|
platform = await async_get_device_automation_platform(
|
|
|
|
hass, config[CONF_DOMAIN], DeviceAutomationType.CONDITION
|
|
|
|
)
|
2023-02-24 03:30:51 +00:00
|
|
|
return trace_condition_function(platform.async_condition_from_config(hass, config))
|