core/homeassistant/components/input_boolean.py

180 lines
5.0 KiB
Python
Raw Normal View History

2016-01-15 06:51:28 +00:00
"""
Component to keep track of user controlled booleans for within automation.
For more details about this component, please refer to the documentation
at https://home-assistant.io/components/input_boolean/
"""
import asyncio
2016-01-15 06:51:28 +00:00
import logging
import os
2016-01-15 06:51:28 +00:00
import voluptuous as vol
2016-01-15 06:51:28 +00:00
from homeassistant.const import (
ATTR_ENTITY_ID, CONF_ICON, CONF_NAME, SERVICE_TURN_OFF, SERVICE_TURN_ON,
SERVICE_TOGGLE, STATE_ON)
from homeassistant.loader import bind_hass
import homeassistant.helpers.config_validation as cv
from homeassistant.config import load_yaml_config_file
2016-10-03 20:05:06 +00:00
from homeassistant.helpers.entity import ToggleEntity
2016-02-19 05:27:50 +00:00
from homeassistant.helpers.entity_component import EntityComponent
from homeassistant.helpers.restore_state import async_get_last_state
2016-01-15 06:51:28 +00:00
DOMAIN = 'input_boolean'
ENTITY_ID_FORMAT = DOMAIN + '.{}'
_LOGGER = logging.getLogger(__name__)
CONF_INITIAL = 'initial'
DEFAULT_INITIAL = False
2016-01-15 06:51:28 +00:00
SERVICE_SCHEMA = vol.Schema({
vol.Optional(ATTR_ENTITY_ID): cv.entity_ids,
})
CONFIG_SCHEMA = vol.Schema({
DOMAIN: vol.Schema({
cv.slug: vol.Any({
vol.Optional(CONF_NAME): cv.string,
vol.Optional(CONF_INITIAL): cv.boolean,
vol.Optional(CONF_ICON): cv.icon,
}, None)
})
}, extra=vol.ALLOW_EXTRA)
2016-01-15 06:51:28 +00:00
@bind_hass
2016-01-15 06:51:28 +00:00
def is_on(hass, entity_id):
"""Test if input_boolean is True."""
return hass.states.is_state(entity_id, STATE_ON)
@bind_hass
2016-01-15 06:51:28 +00:00
def turn_on(hass, entity_id):
"""Set input_boolean to True."""
hass.services.call(DOMAIN, SERVICE_TURN_ON, {ATTR_ENTITY_ID: entity_id})
@bind_hass
2016-01-15 06:51:28 +00:00
def turn_off(hass, entity_id):
"""Set input_boolean to False."""
hass.services.call(DOMAIN, SERVICE_TURN_OFF, {ATTR_ENTITY_ID: entity_id})
@bind_hass
def toggle(hass, entity_id):
"""Set input_boolean to False."""
hass.services.call(DOMAIN, SERVICE_TOGGLE, {ATTR_ENTITY_ID: entity_id})
@asyncio.coroutine
def async_setup(hass, config):
"""Set up an input boolean."""
2016-01-15 06:51:28 +00:00
component = EntityComponent(_LOGGER, DOMAIN, hass)
entities = []
for object_id, cfg in config[DOMAIN].items():
if not cfg:
cfg = {}
2016-01-15 06:51:28 +00:00
name = cfg.get(CONF_NAME)
initial = cfg.get(CONF_INITIAL)
2016-01-15 06:51:28 +00:00
icon = cfg.get(CONF_ICON)
entities.append(InputBoolean(object_id, name, initial, icon))
2016-01-15 06:51:28 +00:00
if not entities:
return False
@asyncio.coroutine
def async_handler_service(service):
2016-03-07 17:49:31 +00:00
"""Handle a calls to the input boolean services."""
target_inputs = component.async_extract_from_service(service)
2016-01-15 06:51:28 +00:00
if service.service == SERVICE_TURN_ON:
attr = 'async_turn_on'
elif service.service == SERVICE_TURN_OFF:
attr = 'async_turn_off'
else:
attr = 'async_toggle'
tasks = [getattr(input_b, attr)() for input_b in target_inputs]
2016-12-16 16:36:50 +00:00
if tasks:
yield from asyncio.wait(tasks, loop=hass.loop)
descriptions = yield from hass.async_add_job(
load_yaml_config_file, os.path.join(
os.path.dirname(__file__), 'services.yaml')
)
hass.services.async_register(
DOMAIN, SERVICE_TURN_OFF, async_handler_service,
descriptions[DOMAIN][SERVICE_TURN_OFF],
schema=SERVICE_SCHEMA)
hass.services.async_register(
DOMAIN, SERVICE_TURN_ON, async_handler_service,
descriptions[DOMAIN][SERVICE_TURN_ON],
schema=SERVICE_SCHEMA)
hass.services.async_register(
DOMAIN, SERVICE_TOGGLE, async_handler_service,
descriptions[DOMAIN][SERVICE_TOGGLE],
schema=SERVICE_SCHEMA)
2016-01-15 07:25:25 +00:00
yield from component.async_add_entities(entities)
2016-01-15 06:51:28 +00:00
return True
class InputBoolean(ToggleEntity):
2016-03-08 16:55:57 +00:00
"""Representation of a boolean input."""
def __init__(self, object_id, name, initial, icon):
2016-03-08 16:55:57 +00:00
"""Initialize a boolean input."""
2016-10-03 20:05:06 +00:00
self.entity_id = ENTITY_ID_FORMAT.format(object_id)
2016-01-15 06:51:28 +00:00
self._name = name
self._state = initial
2016-01-15 06:51:28 +00:00
self._icon = icon
@property
def should_poll(self):
2016-03-07 17:49:31 +00:00
"""If entity should be polled."""
2016-01-15 06:51:28 +00:00
return False
@property
def name(self):
2016-03-07 17:49:31 +00:00
"""Return name of the boolean input."""
2016-01-15 06:51:28 +00:00
return self._name
@property
def icon(self):
2016-03-07 17:49:31 +00:00
"""Returh the icon to be used for this entity."""
2016-01-15 06:51:28 +00:00
return self._icon
@property
def is_on(self):
2016-03-07 17:49:31 +00:00
"""Return true if entity is on."""
2016-01-15 06:51:28 +00:00
return self._state
@asyncio.coroutine
def async_added_to_hass(self):
"""Call when entity about to be added to hass."""
# If not None, we got an initial value.
if self._state is not None:
return
state = yield from async_get_last_state(self.hass, self.entity_id)
self._state = state and state.state == STATE_ON
@asyncio.coroutine
def async_turn_on(self, **kwargs):
2016-01-15 06:51:28 +00:00
"""Turn the entity on."""
self._state = True
yield from self.async_update_ha_state()
2016-01-15 06:51:28 +00:00
@asyncio.coroutine
def async_turn_off(self, **kwargs):
2016-01-15 06:51:28 +00:00
"""Turn the entity off."""
self._state = False
yield from self.async_update_ha_state()