2015-03-16 06:36:42 +00:00
|
|
|
"""
|
2016-03-06 03:32:28 +00:00
|
|
|
Allow users to set and activate scenes.
|
2015-03-16 06:36:42 +00:00
|
|
|
|
2015-10-25 14:13:38 +00:00
|
|
|
For more details about this component, please refer to the documentation at
|
2015-11-09 12:12:18 +00:00
|
|
|
https://home-assistant.io/components/scene/
|
2015-03-16 06:36:42 +00:00
|
|
|
"""
|
2016-12-02 05:38:12 +00:00
|
|
|
import asyncio
|
2015-03-16 06:36:42 +00:00
|
|
|
from collections import namedtuple
|
|
|
|
|
2017-03-29 06:39:53 +00:00
|
|
|
import voluptuous as vol
|
|
|
|
|
|
|
|
import homeassistant.helpers.config_validation as cv
|
|
|
|
from homeassistant.components.scene import Scene, STATES
|
2016-02-19 05:27:50 +00:00
|
|
|
from homeassistant.const import (
|
2017-03-29 06:39:53 +00:00
|
|
|
ATTR_ENTITY_ID, ATTR_STATE, CONF_ENTITIES, CONF_NAME, CONF_PLATFORM,
|
|
|
|
STATE_OFF, STATE_ON)
|
2015-08-17 03:44:46 +00:00
|
|
|
from homeassistant.core import State
|
2017-03-29 06:39:53 +00:00
|
|
|
from homeassistant.helpers.state import async_reproduce_state, HASS_DOMAIN
|
|
|
|
|
|
|
|
PLATFORM_SCHEMA = vol.Schema({
|
|
|
|
vol.Required(CONF_PLATFORM): HASS_DOMAIN,
|
|
|
|
vol.Required(STATES): vol.All(
|
|
|
|
cv.ensure_list,
|
|
|
|
[
|
|
|
|
{
|
|
|
|
vol.Required(CONF_NAME): cv.string,
|
|
|
|
vol.Required(CONF_ENTITIES): {
|
|
|
|
cv.entity_id: vol.Any(str, bool, dict)
|
|
|
|
},
|
|
|
|
}
|
|
|
|
]
|
|
|
|
),
|
|
|
|
}, extra=vol.ALLOW_EXTRA)
|
|
|
|
|
|
|
|
SCENECONFIG = namedtuple('SceneConfig', [CONF_NAME, STATES])
|
2015-03-16 06:36:42 +00:00
|
|
|
|
|
|
|
|
2016-12-02 05:38:12 +00:00
|
|
|
@asyncio.coroutine
|
|
|
|
def async_setup_platform(hass, config, async_add_devices, discovery_info=None):
|
2017-05-02 16:18:47 +00:00
|
|
|
"""Set up home assistant scene entries."""
|
2017-03-29 06:39:53 +00:00
|
|
|
scene_config = config.get(STATES)
|
2016-02-28 20:00:51 +00:00
|
|
|
|
2017-03-01 04:33:19 +00:00
|
|
|
async_add_devices(HomeAssistantScene(
|
2016-12-02 05:38:12 +00:00
|
|
|
hass, _process_config(scene)) for scene in scene_config)
|
2015-03-16 06:36:42 +00:00
|
|
|
return True
|
|
|
|
|
|
|
|
|
|
|
|
def _process_config(scene_config):
|
2016-12-02 05:38:12 +00:00
|
|
|
"""Process passed in config into a format to work with.
|
|
|
|
|
|
|
|
Async friendly.
|
|
|
|
"""
|
2017-03-29 06:39:53 +00:00
|
|
|
name = scene_config.get(CONF_NAME)
|
2015-09-25 12:26:43 +00:00
|
|
|
|
2015-03-16 06:36:42 +00:00
|
|
|
states = {}
|
|
|
|
c_entities = dict(scene_config.get(CONF_ENTITIES, {}))
|
|
|
|
|
|
|
|
for entity_id in c_entities:
|
|
|
|
if isinstance(c_entities[entity_id], dict):
|
2015-12-27 19:24:34 +00:00
|
|
|
entity_attrs = c_entities[entity_id].copy()
|
2017-03-29 06:39:53 +00:00
|
|
|
state = entity_attrs.pop(ATTR_STATE, None)
|
2015-12-27 19:24:34 +00:00
|
|
|
attributes = entity_attrs
|
2015-03-16 06:36:42 +00:00
|
|
|
else:
|
|
|
|
state = c_entities[entity_id]
|
|
|
|
attributes = {}
|
|
|
|
|
|
|
|
# YAML translates 'on' to a boolean
|
|
|
|
# http://yaml.org/type/bool.html
|
|
|
|
if isinstance(state, bool):
|
|
|
|
state = STATE_ON if state else STATE_OFF
|
|
|
|
else:
|
|
|
|
state = str(state)
|
|
|
|
|
|
|
|
states[entity_id.lower()] = State(entity_id, state, attributes)
|
|
|
|
|
2017-03-29 06:39:53 +00:00
|
|
|
return SCENECONFIG(name, states)
|
2015-03-16 06:36:42 +00:00
|
|
|
|
|
|
|
|
2016-02-22 18:53:55 +00:00
|
|
|
class HomeAssistantScene(Scene):
|
2016-03-07 21:50:56 +00:00
|
|
|
"""A scene is a group of entities and the states we want them to be."""
|
2015-03-16 06:36:42 +00:00
|
|
|
|
|
|
|
def __init__(self, hass, scene_config):
|
2016-03-07 21:50:56 +00:00
|
|
|
"""Initialize the scene."""
|
2015-03-16 06:36:42 +00:00
|
|
|
self.hass = hass
|
|
|
|
self.scene_config = scene_config
|
|
|
|
|
|
|
|
@property
|
|
|
|
def name(self):
|
2016-03-07 21:50:56 +00:00
|
|
|
"""Return the name of the scene."""
|
2015-03-16 06:36:42 +00:00
|
|
|
return self.scene_config.name
|
|
|
|
|
|
|
|
@property
|
2016-02-22 18:53:55 +00:00
|
|
|
def device_state_attributes(self):
|
2016-03-07 21:50:56 +00:00
|
|
|
"""Return the scene state attributes."""
|
2015-03-16 06:36:42 +00:00
|
|
|
return {
|
2016-02-22 18:53:55 +00:00
|
|
|
ATTR_ENTITY_ID: list(self.scene_config.states.keys()),
|
2015-03-16 06:36:42 +00:00
|
|
|
}
|
|
|
|
|
2016-12-02 05:38:12 +00:00
|
|
|
@asyncio.coroutine
|
|
|
|
def async_activate(self):
|
2016-03-06 03:32:28 +00:00
|
|
|
"""Activate scene. Try to get entities into requested state."""
|
2016-12-02 05:38:12 +00:00
|
|
|
yield from async_reproduce_state(
|
|
|
|
self.hass, self.scene_config.states.values(), True)
|