8000 GitHub - dlenski/mysotherm: Inspect and manipulate Mysa smart thermostats
[go: up one dir, main page]
More Web Proxy on the site http://driver.im/
Skip to content

dlenski/mysotherm

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

46 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

mysotherm

License: GPL v3

Inspect and manipulate Mysa smart thermostats.

Motivation

Mysa is a Canadian company that makes nice-looking smart thermostats. They're subsidized and promoted by utility companies including BC Hydro.

They have free Android and iOS apps, and they apparently integrate with other home automation stuff that I know nothing about and have never used.

My concerns:

  • The app claims to have "No fees (for real). All the features." but if you have their more inexpensive Mysa Lite device then you don't get in-app charting of temperature and energy usage or multi-thermostat zone control, despite the fact that those appear to be entirely software-based features.
  • The devices appear to be entirely "cloud-dependent": communication with the thermostats goes through AWS cloud services and there is no known local network API
  • The first one I bought was a Mysa Lite which had a stuck-open relay (yes, really) and I was tearing my hair out trying to figure out what was wrong with it.
  • And most importantly, I want to know how they work 🕵🏻‍♂️

Prior work

Back in 2020, https://github.com/fdurand/mysa-thermostats showed how to authenticate to the Mysa cloud service (it's AWS Cognito) and how to query the thermostat readings (https://app-prod.mysa.cloud/users/readingsForUser). fdurand/mysa-thermostats#1 (comment) also demonstrated that setting the thermostat is done via a separate API (MQTT over websocket to an AWS IoT server).

Current status

The API discovered in 2020 seems to have corresponded to Mysa's Android app 2.82, and no longer works (HTTP 500) with 2024-2025 versions of the app.

The Cognito authentication is still the same, but the HTTP API for reading the devices has been replaced with a bunch of new JSONful endpoints: GET /devices/state, GET /users

In January 2025, I figured out how to authenticate to the MQTT-over-WebSockets endpoint used by the app; the short summary is that Mysa is doing the AWS SigV4 "URL presigning" in an unusual and potentially insecure way.

I've figured out what most of the MQTT messages sent between the app and the thermostats mean. See mysa_messages.md for some semi-structured notes.

Inspecting Mysa thermostat devices

Check out this repository, and then use poetry install to install the required Python dependencies. Then you can inspect much of the interesting data stored for your thermostats with the login credentials that you use for the Mysa app:

poetry run mysotherm -u me@whatever.com -p PASSWORD

It should be pretty easy to add setpoint-adjusting and schedule-creating features to the CLI as well; I just haven't gotten around to it.

(I only own Mysa Baseboard V1 and V2 Lite devices. Would be very interested to learn if other devices have other kinds of data.)

"Magically upgrade" your Mysa V2 Lite thermostats

The Mysa V2 Lite is the most inexpensive and compact thermostat device that Mysa sells. Unlike the Mysa V1 which uses a triac to control baseboard heater current, the V2 devices use a simple relay; the Mysa V2 Lite also lacks a current sensor.

However, many of the restrictions of the device appear to be purely software-based. With Mysa V2 Lite, you don't get:

  • In-app charting of temperature or energy usage (even without a current sensor, it should still be possible to get a pretty good estimate of energy usage simply by asking the user to input the heater's peak power or current).
  • Multi-thermostat zone control, which appears entirely software-based.
  • Humidity sensor output: to my surprise, the Mysa V2 Lite appears to contain a perfectly functional humidity sensor even though it's not advertised as such.

Using the liten-up tool, you can "magically upgrade" your Mysa V2 Lite thermostat: this script tricks the app into thinking your device is a Mysa V1 thermostat, and then translates the slightly-incompatible setpoint messages into the correct format for this device.

Run with:

poetry run liten-up -u me@whatever.com -p PASSWORD

While running, the official Mysa smartphone apps will show humidity sensor, zone control, and usage statistics for your Mysa V2 Lite devices.

When you interrupt the program, it will attempt to "restore" the Mysa V2 Lite thermostats to their original state. (And you can poetry run liten-up --reset to do this by itself.)

Future?

In order to get energy usage statistics out of the Mysa V2 Lite devices, it'll probably be necessary to learn more about how the thermostats communicate with the cloud servers. They appear to connect to Amazon IoT gateway servers using MQTT-over-TLS with TLS client certificate authentication on port 8883.

In order to de-cloud-itate these devices, and prevent them from the inevitable future bitrot/bricking, it'll likely be necessary to overcome their certificate pinning.

Credits

License

GPLv3 or later

About

Inspect and manipulate Mysa smart thermostats

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published
0