core/homeassistant/components/automation/event.py

60 lines
1.9 KiB
Python
Raw Normal View History

"""
2016-03-07 19:20:07 +00:00
Offer event listening automation rules.
2015-10-13 19:07:24 +00:00
For more details about this automation rule, please refer to the documentation
at https://home-assistant.io/docs/automation/trigger/#event-trigger
"""
import asyncio
import logging
import voluptuous as vol
from homeassistant.core import callback, CoreState
from homeassistant.const import CONF_PLATFORM, EVENT_HOMEASSISTANT_START
from homeassistant.helpers import config_validation as cv
CONF_EVENT_TYPE = 'event_type'
CONF_EVENT_DATA = 'event_data'
_LOGGER = logging.getLogger(__name__)
TRIGGER_SCHEMA = vol.Schema({
vol.Required(CONF_PLATFORM): 'event',
vol.Required(CONF_EVENT_TYPE): cv.string,
vol.Optional(CONF_EVENT_DATA): dict,
})
@asyncio.coroutine
2016-10-01 08:22:13 +00:00
def async_trigger(hass, config, action):
2016-03-07 16:14:55 +00:00
"""Listen for events based on configuration."""
event_type = config.get(CONF_EVENT_TYPE)
2015-09-19 15:27:34 +00:00
event_data = config.get(CONF_EVENT_DATA)
if (event_type == EVENT_HOMEASSISTANT_START and
hass.state == CoreState.starting):
_LOGGER.warning('Deprecation: Automations should not listen to event '
"'homeassistant_start'. Use platform 'homeassistant' "
'instead. Feature will be removed in 0.45')
hass.async_run_job(action, {
'trigger': {
'platform': 'event',
'event': None,
},
})
return lambda: None
@callback
def handle_event(event):
2016-03-07 19:20:07 +00:00
"""Listen for events and calls the action when data matches."""
2015-09-19 15:27:34 +00:00
if not event_data or all(val == event.data.get(key) for key, val
in event_data.items()):
hass.async_run_job(action, {
'trigger': {
'platform': 'event',
'event': event,
},
})
2016-10-01 08:22:13 +00:00
return hass.bus.async_listen(event_type, handle_event)