ha-core/homeassistant/__main__.py

188 lines
5.0 KiB
Python
Raw Normal View History

""" Starts home assistant. """
from __future__ import print_function
import sys
import os
2014-11-05 16:58:20 +01:00
import argparse
from homeassistant import bootstrap
import homeassistant.config as config_util
2015-08-30 09:59:27 +02:00
from homeassistant.const import __version__, EVENT_HOMEASSISTANT_START
2015-05-01 07:44:24 +02:00
2015-08-31 17:53:59 +02:00
def validate_python():
""" Validate we're running the right Python version. """
major, minor = sys.version_info[:2]
if major < 3 or (major == 3 and minor < 4):
print("Home Assistant requires atleast Python 3.4")
sys.exit(1)
def ensure_config_path(config_dir):
2015-08-30 08:35:19 +02:00
""" Validates configuration directory. """
lib_dir = os.path.join(config_dir, 'lib')
# Test if configuration directory exists
2014-11-23 21:57:29 +01:00
if not os.path.isdir(config_dir):
if config_dir != config_util.get_default_config_dir():
print(('Fatal Error: Specified configuration directory does '
'not exist {} ').format(config_dir))
sys.exit(1)
try:
os.mkdir(config_dir)
except OSError:
print(('Fatal Error: Unable to create default configuration '
'directory {} ').format(config_dir))
sys.exit(1)
# Test if library directory exists
if not os.path.isdir(lib_dir):
try:
os.mkdir(lib_dir)
except OSError:
print(('Fatal Error: Unable to create library '
'directory {} ').format(lib_dir))
sys.exit(1)
2015-08-30 08:02:07 +02:00
def ensure_config_file(config_dir):
2015-08-30 08:35:19 +02:00
""" Ensure configuration file exists. """
config_path = config_util.ensure_config_exists(config_dir)
if config_path is None:
print('Error getting configuration path')
sys.exit(1)
2014-11-08 20:01:47 +01:00
return config_path
def get_arguments():
""" Get parsed passed in arguments. """
2015-08-30 08:02:07 +02:00
parser = argparse.ArgumentParser(
description="Home Assistant: Observe, Control, Automate.")
2015-08-30 09:59:27 +02:00
parser.add_argument('--version', action='version', version=__version__)
parser.add_argument(
'-c', '--config',
metavar='path_to_config_dir',
default=config_util.get_default_config_dir(),
help="Directory that contains the Home Assistant configuration")
parser.add_argument(
'--demo-mode',
action='store_true',
help='Start Home Assistant in demo mode')
parser.add_argument(
'--open-ui',
action='store_true',
help='Open the webinterface in a browser')
parser.add_argument(
'-v', '--verbose',
action='store_true',
help="Enable verbose logging to file.")
parser.add_argument(
'--pid-file',
metavar='path_to_pid_file',
default=None,
help='Path to PID file useful for running as daemon')
if os.name != "nt":
parser.add_argument(
'--daemon',
action='store_true',
help='Run Home Assistant as daemon')
arguments = parser.parse_args()
if os.name == "nt":
arguments.daemon = False
return arguments
def daemonize():
""" Move current process to daemon process """
# create first fork
pid = os.fork()
if pid > 0:
sys.exit(0)
# decouple fork
os.setsid()
os.umask(0)
# create second fork
pid = os.fork()
if pid > 0:
sys.exit(0)
def check_pid(pid_file):
""" Check that HA is not already running """
# check pid file
if pid_file:
try:
pid = int(open(pid_file, 'r').readline())
except IOError:
pass
else:
try:
os.kill(pid, 0)
except OSError:
pass
else:
print('Fatal Error: HomeAssistant is already running.')
sys.exit(1)
def write_pid(pid_file):
""" Create PID File """
# store pid
if pid_file:
# write pid file
pid = os.getpid()
try:
open(pid_file, 'w').write(str(pid))
except IOError:
pass
def main():
""" Starts Home Assistant. """
2015-08-31 17:53:59 +02:00
validate_python()
args = get_arguments()
config_dir = os.path.join(os.getcwd(), args.config)
2015-08-30 08:02:07 +02:00
ensure_config_path(config_dir)
# daemon functions
check_pid(args.pid_file)
if args.daemon:
daemonize()
write_pid(args.pid_file)
if args.demo_mode:
hass = bootstrap.from_config_dict({
'frontend': {},
'demo': {}
}, config_dir=config_dir, daemon=args.daemon, verbose=args.verbose)
else:
2015-08-30 08:02:07 +02:00
config_file = ensure_config_file(config_dir)
2015-08-31 06:22:05 +02:00
print('Config directory:', config_dir)
hass = bootstrap.from_config_file(
config_file, daemon=args.daemon, verbose=args.verbose)
if args.open_ui:
def open_browser(event):
""" Open the webinterface in a browser. """
if hass.config.api is not None:
import webbrowser
webbrowser.open(hass.config.api.base_url)
hass.bus.listen_once(EVENT_HOMEASSISTANT_START, open_browser)
2014-11-23 21:57:29 +01:00
hass.start()
hass.block_till_stopped()
if __name__ == "__main__":
main()