Added a numeric_state automation platform
This commit is contained in:
parent
97eb84919b
commit
4eba1250e9
1 changed files with 61 additions and 0 deletions
61
homeassistant/components/automation/numeric_state.py
Normal file
61
homeassistant/components/automation/numeric_state.py
Normal file
|
@ -0,0 +1,61 @@
|
|||
"""
|
||||
homeassistant.components.automation.state
|
||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
|
||||
Offers state listening automation rules.
|
||||
"""
|
||||
import logging
|
||||
|
||||
from homeassistant.helpers.event import track_state_change
|
||||
from homeassistant.const import MATCH_ALL
|
||||
|
||||
|
||||
CONF_ENTITY_ID = "state_entity_id"
|
||||
CONF_BELOW = "state_below"
|
||||
CONF_ABOVE = "state_above"
|
||||
|
||||
|
||||
def register(hass, config, action):
|
||||
""" Listen for state changes based on `config`. """
|
||||
entity_id = config.get(CONF_ENTITY_ID)
|
||||
|
||||
if entity_id is None:
|
||||
logging.getLogger(__name__).error(
|
||||
"Missing configuration key %s", CONF_ENTITY_ID)
|
||||
return False
|
||||
|
||||
below = config.get(CONF_BELOW)
|
||||
above = config.get(CONF_ABOVE)
|
||||
|
||||
if below is None and above is None:
|
||||
logging.getLogger(__name__).error(
|
||||
"Missing configuration key %s or %s", CONF_BELOW, CONF_ABOVE)
|
||||
|
||||
def numeric_in_range(value, range_start, range_end):
|
||||
""" Checks if value is inside the range
|
||||
:param value:
|
||||
:param range_start:
|
||||
:param range_end:
|
||||
:return:
|
||||
"""
|
||||
value = float(value)
|
||||
|
||||
if range_start is not None and range_end is not None:
|
||||
return float(range_start) < value < float(range_end)
|
||||
elif range_end is not None:
|
||||
return value < float(range_end)
|
||||
else:
|
||||
return value > float(range_start)
|
||||
|
||||
def state_automation_listener(entity, from_s, to_s):
|
||||
""" Listens for state changes and calls action. """
|
||||
|
||||
# Fire action if we go from outside range into range
|
||||
if numeric_in_range(to_s.state, above, below) and \
|
||||
from_s is None or not numeric_in_range(from_s.state, above, below):
|
||||
action()
|
||||
|
||||
track_state_change(
|
||||
hass, entity_id, state_automation_listener)
|
||||
|
||||
return True
|
Loading…
Add table
Add a link
Reference in a new issue