2015-02-24 01:23:25 +00:00
|
|
|
"""
|
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
|
2017-04-06 06:23:02 +00:00
|
|
|
at https://home-assistant.io/docs/automation/trigger/#event-trigger
|
2015-02-24 01:23:25 +00:00
|
|
|
"""
|
2017-02-18 22:17:18 +00:00
|
|
|
import asyncio
|
2015-02-24 01:23:25 +00:00
|
|
|
import logging
|
|
|
|
|
2016-04-28 10:03:57 +00:00
|
|
|
import voluptuous as vol
|
|
|
|
|
2017-05-07 06:52:39 +00:00
|
|
|
from homeassistant.core import callback
|
|
|
|
from homeassistant.const import CONF_PLATFORM
|
2016-04-28 10:03:57 +00:00
|
|
|
from homeassistant.helpers import config_validation as cv
|
|
|
|
|
2017-04-30 05:04:49 +00:00
|
|
|
CONF_EVENT_TYPE = 'event_type'
|
|
|
|
CONF_EVENT_DATA = 'event_data'
|
2015-02-24 01:23:25 +00:00
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
2016-04-28 10:03:57 +00:00
|
|
|
TRIGGER_SCHEMA = vol.Schema({
|
|
|
|
vol.Required(CONF_PLATFORM): 'event',
|
|
|
|
vol.Required(CONF_EVENT_TYPE): cv.string,
|
2017-10-07 20:13:32 +00:00
|
|
|
vol.Optional(CONF_EVENT_DATA, default={}): dict,
|
2016-04-28 10:03:57 +00:00
|
|
|
})
|
|
|
|
|
2015-02-24 01:23:25 +00:00
|
|
|
|
2017-02-18 22:17:18 +00:00
|
|
|
@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."""
|
2015-02-24 01:23:25 +00:00
|
|
|
event_type = config.get(CONF_EVENT_TYPE)
|
2017-10-07 20:13:32 +00:00
|
|
|
event_data_schema = vol.Schema(
|
|
|
|
config.get(CONF_EVENT_DATA),
|
|
|
|
extra=vol.ALLOW_EXTRA)
|
2015-02-24 01:23:25 +00:00
|
|
|
|
2016-10-05 03:44:32 +00:00
|
|
|
@callback
|
2015-02-24 01:23:25 +00:00
|
|
|
def handle_event(event):
|
2016-03-07 19:20:07 +00:00
|
|
|
"""Listen for events and calls the action when data matches."""
|
2017-10-07 20:13:32 +00:00
|
|
|
try:
|
|
|
|
event_data_schema(event.data)
|
|
|
|
except vol.Invalid:
|
|
|
|
# If event data doesn't match requested schema, skip event
|
|
|
|
return
|
|
|
|
|
|
|
|
hass.async_run_job(action, {
|
|
|
|
'trigger': {
|
|
|
|
'platform': 'event',
|
|
|
|
'event': event,
|
|
|
|
},
|
|
|
|
})
|
2015-02-24 01:23:25 +00:00
|
|
|
|
2016-10-01 08:22:13 +00:00
|
|
|
return hass.bus.async_listen(event_type, handle_event)
|