core/homeassistant/components/automation/template.py

54 lines
1.6 KiB
Python
Raw Normal View History

2015-12-16 17:52:33 +00:00
"""
2016-03-07 19:20:07 +00:00
Offer template automation rules.
2015-12-16 17:52:33 +00:00
For more details about this automation rule, please refer to the documentation
at https://home-assistant.io/components/automation/#template-trigger
"""
import logging
import voluptuous as vol
from homeassistant.const import (
CONF_VALUE_TEMPLATE, CONF_PLATFORM, MATCH_ALL)
from homeassistant.helpers import condition
from homeassistant.helpers.event import track_state_change
import homeassistant.helpers.config_validation as cv
2015-12-16 17:52:33 +00:00
_LOGGER = logging.getLogger(__name__)
TRIGGER_SCHEMA = IF_ACTION_SCHEMA = vol.Schema({
vol.Required(CONF_PLATFORM): 'template',
vol.Required(CONF_VALUE_TEMPLATE): cv.template,
})
2015-12-16 17:52:33 +00:00
def trigger(hass, config, action):
2016-03-07 16:14:55 +00:00
"""Listen for state changes based on configuration."""
2015-12-16 17:52:33 +00:00
value_template = config.get(CONF_VALUE_TEMPLATE)
2015-12-16 22:07:14 +00:00
# Local variable to keep track of if the action has already been triggered
already_triggered = False
def state_changed_listener(entity_id, from_s, to_s):
2016-03-07 19:20:07 +00:00
"""Listen for state changes and calls action."""
2015-12-16 22:07:14 +00:00
nonlocal already_triggered
template_result = condition.template(hass, value_template)
2015-12-16 17:52:33 +00:00
# Check to see if template returns true
2015-12-16 22:07:14 +00:00
if template_result and not already_triggered:
already_triggered = True
action({
'trigger': {
'platform': 'template',
'entity_id': entity_id,
'from_state': from_s,
'to_state': to_s,
},
})
2015-12-16 22:07:14 +00:00
elif not template_result:
already_triggered = False
2015-12-16 17:52:33 +00:00
track_state_change(hass, MATCH_ALL, state_changed_listener)
2015-12-16 17:52:33 +00:00
return True