supervisor to detect and correct thermostat deviations
- Honeywell thermostat through TCC web site (user must configure TCC web site credentials as environment variables).
- 3M50 thermostat on local net (user must provide local IP address of each 3m50 thermostat zone).
- SHT31 temperature sensor either locally or remote (user must provide local/remote IP address in environment variables and setup firewall port routing if remote).
- Mitsubishi ductless thermostat through Kumocloud on remote network (monitoring) or local network (monitoring and control).
- Blink camera temperature sensors.
- Nest thermostats.
- Honeywell thermostat support through TCC web site requires 3 minute poll time (or longer). Default for this thermostat is set to 10 minutes.
- a few other low frequency intermittent issues exist, refer to issues in github repo for details.
- KumoCloud remote connection currently only supports monitoring, cannot set or revert settings.
- supervisor_flask_server not currently working on Linux server.
pyhtcc for Honeywell thermostats (pip3 install pyhtcc)
radiotherm for 3m50 thermostats (mhrivnak/radiotherm or pip3 install radiotherm)
flask, flask-resful, and fask-wtf for sht31 flask server
flask and flask-wtf for supervisor flask server
pykumo for kumocloud
blinkpy for blink camera temp sensor support
python-google-nest for nest temp sensor support
coverage for code coverage analysis
psutil for all thermostat types
refer to requirements.txt for full list of package dependencies.
docker run --rm -it --privileged --env-file 'envfile' 'username'/thermostatsupervisor:'tag' thermostatsupervisor.'module' 'runtime parameters'
- '--rm' removes the docker container when done
- '-it' runs in interactive mode so that output is displayed in the console
- '--env-file' specifies your env variables from file 'envfile', see below for required env variables
- '--privileged' runs in privileged mode, this may be required to avoid PermissionErrors with device objects
- 'username' is your DockerHub username
- 'tag' is the Docker image tag (e.g. 'develop', 'main', etc.)
- 'module' is the module to run, (e.g. 'supervise', 'honeywell', 'kumocloud', etc.).
- 'runtime parameters' are supervise runtime parameters as specified below.
- 'DOCKER_USERNAME' is your DockerHub username
- 'DOCKER_PASSWORD' is your DockerHub password
- Honeywell pyhtcc.txt file in /home/pi/log/pyhtcc/ shows logging specific to pyhtcc class
- ./data/ folder contains supervisor logs
Environment variables required depend on the thermostat being used.
- All configurations require the GMAIL env vars:
- 'GMAIL_USERNAME': email account to send notifications from (source) and to (destination)
- 'GMAIL_PASSWORD': password for GMAIL_USERNAME
- Honeywell thermostat requires the 'TCC' env vars:
- 'TCC_USERNAME': username to Honeywell TCC website
- 'TCC_PASSWORD': password for TCC_USERNAME
- SHT31 temp sensor requires the 'SHT31' env vars:
- 'SHT31_REMOTE_IP_ADDRESS_'zone'': remote IP address / URL for SHT31 thermal sensor, 'zone' is the zone number.
- Mitsubishi ductless requires the 'KUMOCLOUD' env vars:
- 'KUMO_USERNAME': username for Kumocloud account
- 'KUMO_PASSWORD': password for Kumocloud account
- Blink camera temp sensor requires the 'BLINK' env vars:
- 'BLINK_USERNAME': username for Blink account
- 'BLINK_PASSWORD': password for Blink account
- 'BLINK_2FA': 2 factor auth string for Blink account
- Nest thermostat requires the 'NEST' env vars or env vars supplied via a json file:
- 'GCLOUD_CLIENT_ID': client ID from Google Clout OAuth credentials
- 'GCLOUD_CLIENT_SECRET': client secret from Google Clout OAuth credentials
- 'DAC_PROJECT_ID': project ID from the Nest Device access console
- Linux: update file ~/.profile and then "source ~/.profile" to load the file
- Windows: define env variables in control panel and then re-start IDE
- docker image: export the env files to a text file and specify during the docker run command
This is the main entry point script.
runtime parameters can be specified to override defaults either via single dash named parameters or values in order:
- '-h'= help screen
- argv[1] or '-t'= Thermostat type, currently support "honeywell", "mmm50", "sht31", "kumocloud", "kumolocal" and "blink". Default is "honeywell".
- argv[2] or '-z'= zone, currently support:
- honeywell = zone 0 only
- 3m50 = zones [0,1] on local net
- sht31: 0 = local net, 1 = remote URL
- kumocloud, kumolocal: [0,1]
- blink = [0,1,2,3,4,5,6,7,8]
- emulator = zone 0 only
- argv[3] or '-p'= poll time in seconds (default is thermostat-specific)
- argv[4] or '-c'= re-connect time in seconds (default is thermostat-specific)
- argv[5] or '-d'= tolerance from setpoint allowed in °F (default is 2°F)
- argv[6] or '-m'= target thermostat mode (e.g. OFF_MODE, COOL_MODE, HEAT_MODE, DRY_MODE, etc.), not yet fully functional.
- argv[7] or '-n'= number of measurements (default is infinitity).
command line usage (unnamed): "python -m thermostatsupervisor.supervise <thermostat type> <zone> <poll time> <connection time> <tolerance> <target mode> <measurements>".
command line usage (named): "python -m thermostatsupervisor.supervise -t <thermostat type> -z <zone> -p <poll time> -c <connection time> -d <tolerance> -m <target mode> -n <measurements>"
This module will render supervise.py output on an HTML page using Flask.
Same runtime parameters as supervise.py can be specified to override defaults:
Port is currently hard-coded to 5001, access at server's local IP address
command line usage: "python -m thermostatsupervisor.supervisor_flask_server <runtime parameters>"
Script will run an emulator with fabribated thermostat meta data.
command line usage: "python -m thermostatsupervisor.emulator <thermostat type> <zone>"
Script will logon to TCC web site and query thermostat meta data.
Default poll time is currently set to 3 minutes, longer poll times experience connection errors, shorter poll times are impractical based on emperical data.
command line usage: "python -m thermostatsupervisor.honeywell <thermostat type> <zone>"
Script will connect to 3m50 thermostat on local network, IP address stored in mmm_config.mmm_metadata.
Default poll time is currently set to 10 minutes.
command line usage: "python -m thermostatsupervisor.mmm <thermostat type> <zone>"
Script will connect to sht31 thermometer at URL specified (can be local IP or remote URL).
Default poll time is currently set to 1 minute.
command line usage: "python -m thermostatsupervisor.sht31 <thermostat type> <zone>"
This module will render sht31 sensor output on an HTML page using Flask.
Port is currently hard-coded to 5000.
Production data is at root, subfolders provide additional commands:
- /unit: unit test (fabricated) data
- /diag: fault register data
- /clear_diag: clear the fault register
- /enable_heater: enable the internal heater
- /disable_heater: disable the internal heater
- /soft_reset: perform soft reset
- /reset: perform hard reset
- /i2c_recovery: perform clock reset to unlock a stuck i2c bus
- /i2c_detect: detect i2c device on either bus
- /i2c_detect_0: detect i2c device on bus 0
- /i2c_detect_1: detect i2c device on bus 1
"python -m thermostatsupervisor.sht31_flask_server <debug>"
argv[1] = debug (bool): True to enable Flask debug mode, False is default.
production: "<ip>:<port>?measurements=<measurements>"
unit test: "<ip>:<port>/unit?measurements=<measurements>&seed=<seed>"
diag: "<ip>:<port>/diag"
measurements=number of measurements to average (default=10)
seed=seed value for fabricated data in unit test mode (default=0x7F)
Script will connect to Mitsubishi ductless thermostat through kumocloud account only.
Default poll time is currently set to 10 minutes.
Zone number refers to the thermostat order in kumocloud, 0=first thermostat data returned, 1=second thermostat, etc.
command line usage: "python -m thermostatsupervisor.kumocloud <thermostat type> <zone>"
Script will connect to Mitsubishi ductless thermostat through kumocloud account and local network.
Default poll time is currently set to 10 minutes.
Zone number refers to the thermostat order in kumocloud, 0=first thermostat data returned, 1=second thermostat, etc.
command line usage: "python -m thermostatsupervisor.kumolocal <thermostat type> <zone>"
Script will connect to Blink camera through Blink account.
Default poll time is currently set to 10 minutes.
Zone number refers to the thermostat order in Blink server, 0=first thermostat data returned, 1=second thermostat, etc.
command line usage: "python -m thermostatsupervisor.blink <thermostat type> <zone>"
Script will connect to nest thermostats through Google Device Access console account.
Follow instructions in this repo to setup Google Device Access registration and Google Cloud OAuth account: https://github.com/axlan/python-nest/.
Default poll time is currently set to 10 minutes.
Zone number refers to the thermostat order in nest server, 0=first thermostat data returned, 1=second thermostat, etc.
command line usage: "python -m thermostatsupervisor.nest <thermostat type> <zone>"
Thermostat class:
- print_all_thermostat_metadata(): Print all thermostat meta data.
- get_target_zone_id(): Return the target zone ID.
Zone class:
- get_current_mode(): Determine whether thermostat is following schedule or if it has been deviated from schedule.
- report_heating_parameters(): Display critical thermostat settings and reading to the screen.
- get_schedule_heat_sp(): Retrieve the scheduled heat setpoint.
- set_heat_setpoint(): Sets a new heat setpoint.
- get_schedule_cool_sp(): Retrieve the scheduled cool setpoint.
- set_cool_setpoint(): Set a new cool setpoint.
- refresh_zone_info(): Refresh the zone_info attribute.