hass-core/homeassistant/bootstrap.py

125 lines
3.7 KiB
Python
Raw Normal View History

"""
Provides methods to bootstrap a home assistant instance.
"""
import ConfigParser
import logging
import homeassistant as ha
import homeassistant.observers as observers
import homeassistant.actors as actors
import homeassistant.httpinterface as httpinterface
2013-11-10 16:46:48 -08:00
# pylint: disable=too-many-branches
def from_config_file(config_path):
""" Starts home assistant with all possible functionality
based on a config file. """
statusses = []
# Read config
config = ConfigParser.SafeConfigParser()
config.read(config_path)
# Init core
eventbus = ha.EventBus()
statemachine = ha.StateMachine(eventbus)
# Init observers
# Device scanner
if config.has_option('tomato', 'host') and \
2013-11-10 16:46:48 -08:00
config.has_option('tomato', 'username') and \
config.has_option('tomato', 'password') and \
config.has_option('tomato', 'http_id'):
device_scanner = observers.TomatoDeviceScanner(
2013-11-10 16:46:48 -08:00
config.get('tomato', 'host'),
config.get('tomato', 'username'),
config.get('tomato', 'password'),
config.get('tomato', 'http_id'))
if device_scanner.success_init:
statusses.append(("Device Scanner - Tomato", True))
else:
statusses.append(("Device Scanner - Tomato", False))
device_scanner = None
else:
device_scanner = None
# Device Tracker
if device_scanner:
2013-11-10 16:46:48 -08:00
device_tracker = observers.DeviceTracker(
eventbus, statemachine, device_scanner)
statusses.append(("Device Tracker", True))
else:
device_tracker = None
# Sun tracker
if config.has_option("common", "latitude") and \
2013-11-10 16:46:48 -08:00
config.has_option("common", "longitude"):
statusses.append(("Weather - Ephem",
2013-11-10 16:46:48 -08:00
observers.track_sun(
eventbus, statemachine,
config.get("common", "latitude"),
config.get("common", "longitude"))))
2013-11-10 16:46:48 -08:00
# --------------------------
# Init actors
# Light control
if config.has_section("hue"):
if config.has_option("hue", "host"):
light_control = actors.HueLightControl(config.get("hue", "host"))
else:
light_control = actors.HueLightControl()
statusses.append(("Light Control - Hue", light_control.success_init))
else:
light_control = None
# Light trigger
if light_control:
actors.LightTrigger(eventbus, statemachine,
device_tracker, light_control)
statusses.append(("Light Trigger", True))
if config.has_option("chromecast", "host"):
2013-11-10 16:46:48 -08:00
statusses.append(("Chromecast",
actors.setup_chromecast(
eventbus, config.get("chromecast", "host"))))
if config.has_option("downloader", "download_dir"):
2013-11-10 16:46:48 -08:00
result = actors.setup_file_downloader(
eventbus, config.get("downloader", "download_dir"))
statusses.append(("Downloader", result))
statusses.append(("Webbrowser", actors.setup_webbrowser(eventbus)))
statusses.append(("Media Buttons", actors.setup_media_buttons(eventbus)))
# Init HTTP interface
if config.has_option("httpinterface", "api_password"):
2013-11-10 16:46:48 -08:00
httpinterface.HTTPInterface(
eventbus, statemachine,
config.get("httpinterface", "api_password"))
statusses.append(("HTTPInterface", True))
logger = logging.getLogger(__name__)
for component, success_init in statusses:
status = "initialized" if success_init else "Failed to initialize"
logger.info("{}: {}".format(component, status))
ha.start_home_assistant(eventbus)