A tool for controlling Hcalory diesel heaters over Bluetooth.
Project description
hcalory-control
A little tool to control BLE-capable Hcalory heaters. This has only been tested on the Hcalory W1 model.
CLI Usage
❯ hcalory-control --help
usage: hcalory-control [-h] --address ADDRESS {start_heat,stop_heat,up,down,gear,thermostat,pump_data}
positional arguments:
{start_heat,stop_heat,up,down,gear,thermostat,pump_data}
options:
-h, --help show this help message and exit
--address ADDRESS Bluetooth MAC address of heater
To get the current state of the heater, use pump_data
:
❯ hcalory-control --address ec:b1:c3:00:4d:61 pump_data
{
"ambient_temperature": 87,
"body_temperature": 226,
"heater_mode": "thermostat",
"heater_setting": 74,
"heater_state": "running",
"voltage": 13
}
Temperature/"gear" mode changes are done by incrementing/decrementing, not by setting the absolute value you want:
❯ hcalory-control --address ec:b1:c3:00:4d:61 up
Before command:
{
"ambient_temperature": 86,
"body_temperature": 219,
"heater_mode": "thermostat",
"heater_setting": 74,
"heater_state": "running",
"voltage": 13
}
After command:
{
"ambient_temperature": 86,
"body_temperature": 219,
"heater_mode": "thermostat",
"heater_setting": 75,
"heater_state": "running",
"voltage": 13
}
Usage as a library
The main
and run_command
functions should serve as a decent example. Getting the current running state out of these heaters is weird. In order to get your notification on the read characteristic to give you anything, you have to ask the heater to send something by writing to the write characteristic. The official app does this once a second, which seems wildly inefficient to me. I've no idea why they didn't just make the heater push data out on its own when things changed.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file hcalory_control-0.1.2.tar.gz
.
File metadata
- Download URL: hcalory_control-0.1.2.tar.gz
- Upload date:
- Size: 26.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.5.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f861914cbdeb951402db4cb7ef9b6caa6cd023d31407835ce00bd9e3cf96fe6a |
|
MD5 | 974bebb098c0837cfd284eef3f44eb93 |
|
BLAKE2b-256 | df1291a7cfd67a172e98c98b9db08c752440423ac94052497adf9285488a283c |
File details
Details for the file hcalory_control-0.1.2-py3-none-any.whl
.
File metadata
- Download URL: hcalory_control-0.1.2-py3-none-any.whl
- Upload date:
- Size: 8.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.5.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8ca87816103b959d3e589a20e08696381eaf6ecac4915914e854a20f10c4982a |
|
MD5 | 1acd848498700925377ed4e7729c3cae |
|
BLAKE2b-256 | a292fd833503580e31b536be3392259a56e891fec7fdd04cecd6f08cbaa7a1d5 |