core/homeassistant/components/demo.py

175 lines
5.8 KiB
Python
Raw Normal View History

2014-11-02 17:41:41 +00:00
"""
2015-05-13 17:18:30 +00:00
Sets up a demo environment that mimics interaction with devices.
For more details about this component, please refer to the documentation
https://home-assistant.io/components/demo/
2014-11-02 17:41:41 +00:00
"""
import time
2014-11-02 17:41:41 +00:00
import homeassistant.bootstrap as bootstrap
2016-02-19 05:27:50 +00:00
import homeassistant.core as ha
import homeassistant.loader as loader
2016-02-19 05:27:50 +00:00
from homeassistant.const import ATTR_ENTITY_ID, CONF_PLATFORM
2014-11-02 17:41:41 +00:00
DOMAIN = "demo"
2015-11-03 08:19:28 +00:00
DEPENDENCIES = ['conversation', 'introduction', 'zone']
2014-11-02 17:41:41 +00:00
COMPONENTS_WITH_DEMO_PLATFORM = [
2015-12-05 09:12:38 +00:00
'alarm_control_panel',
'binary_sensor',
'camera',
'device_tracker',
2016-02-11 13:23:04 +00:00
'garage_door',
2015-12-05 09:12:38 +00:00
'light',
'lock',
'media_player',
'notify',
'rollershutter',
'sensor',
'switch',
'thermostat',
]
2014-11-02 17:41:41 +00:00
def setup(hass, config):
"""Setup a demo environment."""
group = loader.get_component('group')
configurator = loader.get_component('configurator')
2014-11-02 17:41:41 +00:00
2014-11-29 06:49:29 +00:00
config.setdefault(ha.DOMAIN, {})
config.setdefault(DOMAIN, {})
if config[DOMAIN].get('hide_demo_state') != 1:
2014-11-02 17:41:41 +00:00
hass.states.set('a.Demo_Mode', 'Enabled')
# Setup sun
2015-04-26 00:44:05 +00:00
if not hass.config.latitude:
hass.config.latitude = 32.87336
2015-04-26 00:44:05 +00:00
if not hass.config.longitude:
hass.config.longitude = 117.22743
2015-04-26 00:44:05 +00:00
bootstrap.setup_component(hass, 'sun')
2014-11-02 17:41:41 +00:00
# Setup demo platforms
demo_config = config.copy()
for component in COMPONENTS_WITH_DEMO_PLATFORM:
demo_config[component] = {CONF_PLATFORM: 'demo'}
bootstrap.setup_component(hass, component, demo_config)
2014-11-02 17:41:41 +00:00
# Setup room groups
2015-08-30 20:48:40 +00:00
lights = sorted(hass.states.entity_ids('light'))
switches = sorted(hass.states.entity_ids('switch'))
2015-08-24 02:46:18 +00:00
media_players = sorted(hass.states.entity_ids('media_player'))
2016-02-27 02:12:03 +00:00
group.Group(hass, 'living room', [
lights[1], switches[0], 'input_select.living_room_preset',
'rollershutter.living_room_window', media_players[1],
'scene.romantic_lights'])
group.Group(hass, 'bedroom', [lights[0], switches[1], media_players[0]])
2016-02-27 02:12:03 +00:00
group.Group(hass, 'kitchen', [
lights[2], 'rollershutter.kitchen_window', 'lock.kitchen_door'])
group.Group(hass, 'doors', [
'lock.front_door', 'lock.kitchen_door',
'garage_door.right_garage_door', 'garage_door.left_garage_door'])
group.Group(hass, 'automations', [
'input_select.who_cooks', 'input_boolean.notify', ])
group.Group(hass, 'people', [
'device_tracker.demo_anne_therese', 'device_tracker.demo_home_boy',
'device_tracker.demo_paulus'])
group.Group(hass, 'thermostats', [
'thermostat.nest', 'thermostat.thermostat'])
group.Group(hass, 'downstairs', [
'group.living_room', 'group.kitchen',
'scene.romantic_lights', 'rollershutter.kitchen_window',
'rollershutter.living_room_window', 'group.doors', 'thermostat.nest',
], view=True)
2016-02-27 02:12:03 +00:00
group.Group(hass, 'Upstairs', [
'thermostat.thermostat', 'group.bedroom',
2016-01-26 05:27:36 +00:00
], view=True)
# Setup scripts
bootstrap.setup_component(
hass, 'script',
2015-03-17 05:45:42 +00:00
{'script': {
'demo': {
2015-08-30 20:48:40 +00:00
'alias': 'Toggle {}'.format(lights[0].split('.')[1]),
'sequence': [{
'service': 'light.turn_off',
'data': {ATTR_ENTITY_ID: lights[0]}
2015-03-17 05:45:42 +00:00
}, {
'delay': {'seconds': 5}
}, {
'service': 'light.turn_on',
'data': {ATTR_ENTITY_ID: lights[0]}
2015-03-17 05:45:42 +00:00
}, {
'delay': {'seconds': 5}
}, {
'service': 'light.turn_off',
'data': {ATTR_ENTITY_ID: lights[0]}
2015-03-17 05:45:42 +00:00
}]
}}})
2015-03-17 05:35:57 +00:00
# Setup scenes
bootstrap.setup_component(
hass, 'scene',
{'scene': [
{'name': 'Romantic lights',
'entities': {
2015-03-17 05:45:42 +00:00
lights[0]: True,
lights[1]: {'state': 'on', 'xy_color': [0.33, 0.66],
'brightness': 200},
2015-03-17 05:35:57 +00:00
}},
{'name': 'Switch on and off',
'entities': {
2015-03-17 05:45:42 +00:00
switches[0]: True,
switches[1]: False,
2015-03-17 05:35:57 +00:00
}},
2015-03-17 05:45:42 +00:00
]})
2015-03-17 05:35:57 +00:00
2016-02-27 02:43:50 +00:00
# Set up input select
bootstrap.setup_component(
hass, 'input_select',
2016-02-27 02:12:03 +00:00
{'input_select':
{'living_room_preset': {'options': ['Visitors',
'Visitors with kids',
'Home Alone']},
'who_cooks': {'icon': 'mdi:panda',
2016-02-27 02:25:39 +00:00
'initial': 'Anne Therese',
'name': 'Who cooks today',
'options': ['Paulus', 'Anne Therese']}}})
2016-02-27 02:43:50 +00:00
# Set up input boolean
bootstrap.setup_component(
hass, 'input_boolean',
{'input_boolean': {'notify': {'icon': 'mdi:car',
2016-02-27 02:12:03 +00:00
'initial': False,
'name': 'Notify Anne Therese is home'}}})
# Setup configurator
configurator_ids = []
def hue_configuration_callback(data):
"""Fake callback, mark config as done."""
time.sleep(2)
# First time it is called, pretend it failed.
if len(configurator_ids) == 1:
configurator.notify_errors(
2015-01-20 05:39:24 +00:00
configurator_ids[0],
"Failed to register, please try again.")
configurator_ids.append(0)
else:
2015-01-20 05:39:24 +00:00
configurator.request_done(configurator_ids[0])
request_id = configurator.request_config(
hass, "Philips Hue", hue_configuration_callback,
description=("Press the button on the bridge to register Philips Hue "
"with Home Assistant."),
description_image="/static/images/config_philips_hue.jpg",
submit_caption="I have pressed the button"
)
configurator_ids.append(request_id)
2014-11-02 17:41:41 +00:00
return True