core/homeassistant/components/automation/event.py

57 lines
1.6 KiB
Python
Raw Normal View History

"""Offer event listening automation rules."""
import logging
import voluptuous as vol
from homeassistant.const import CONF_PLATFORM
from homeassistant.core import callback
from homeassistant.helpers import config_validation as cv
# mypy: allow-untyped-defs
2019-07-31 19:25:30 +00:00
CONF_EVENT_TYPE = "event_type"
CONF_EVENT_DATA = "event_data"
_LOGGER = logging.getLogger(__name__)
2019-07-31 19:25:30 +00:00
TRIGGER_SCHEMA = vol.Schema(
{
vol.Required(CONF_PLATFORM): "event",
vol.Required(CONF_EVENT_TYPE): cv.string,
vol.Optional(CONF_EVENT_DATA): dict,
}
)
async def async_attach_trigger(
hass, config, action, automation_info, *, platform_type="event"
):
2016-03-07 16:14:55 +00:00
"""Listen for events based on configuration."""
event_type = config.get(CONF_EVENT_TYPE)
2019-07-31 19:25:30 +00:00
event_data_schema = (
vol.Schema(config.get(CONF_EVENT_DATA), extra=vol.ALLOW_EXTRA)
if config.get(CONF_EVENT_DATA)
else None
)
@callback
def handle_event(event):
2016-03-07 19:20:07 +00:00
"""Listen for events and calls the action when data matches."""
if event_data_schema:
# Check that the event data matches the configured
# schema if one was provided
try:
event_data_schema(event.data)
except vol.Invalid:
# If event data doesn't match requested schema, skip event
return
2019-07-31 19:25:30 +00:00
hass.async_run_job(
action(
{"trigger": {"platform": platform_type, "event": event}},
2019-07-31 19:25:30 +00:00
context=event.context,
)
)
2016-10-01 08:22:13 +00:00
return hass.bus.async_listen(event_type, handle_event)