home_emulation/home_emulation.py

55 lines
1.4 KiB
Python
Raw Normal View History

2023-08-03 20:43:41 +02:00
import config
import devdi
2023-10-31 18:25:19 +01:00
import home
2023-08-03 20:43:41 +02:00
import logging
import mqtt
import os
2023-08-03 20:43:41 +02:00
import report
2023-10-31 18:25:19 +01:00
import user_interface
2023-08-03 20:43:41 +02:00
2023-10-31 18:25:19 +01:00
# TODO: Add some more ui commands for devices
# TODO: Add some test for smart_brain
2023-10-29 15:10:52 +01:00
# TODO: Implementation of missing devices in devices/__init__.py
logger = logging.getLogger(config.APP_NAME)
2023-08-03 20:43:41 +02:00
if __name__ == "__main__":
#
# Logging
#
if config.DEBUG:
report.appLoggingConfigure(None, 'stdout', ((config.APP_NAME, logging.DEBUG), ),
target_level=logging.WARNING, fmt=report.SHORT_FMT, host='localhost', port=19996)
else:
report.stdoutLoggingConfigure(((config.APP_NAME, logging.WARNING), ), report.SHORT_FMT)
#
# MQTT Client
#
2023-08-03 20:43:41 +02:00
mc = mqtt.mqtt_client(host=config.MQTT_SERVER, port=config.MQTT_PORT, username=config.MQTT_USER,
password=config.MQTT_PASSWORD, name=config.APP_NAME)
#
2023-10-29 15:10:52 +01:00
# Smarthome physical Devices
#
2023-10-29 15:10:52 +01:00
pd = devdi.physical_devices(mc)
#
# Smart Home Functionality
#
2023-10-31 18:25:19 +01:00
home.functions(pd)
2023-10-29 15:10:52 +01:00
2023-10-31 18:25:19 +01:00
#
# User Interface
#
ui = user_interface.user_interface()
# Add the device commands
for d in pd.values():
try:
for cmd in d.user_cmds:
ui.add_command(cmd, d.user_cmds[cmd])
except AttributeError:
pass # device seems to have no user commands
ui.run()