ESPHome implementation of the CN105 protocal. It can operate as standalone or with slave (melcloud/procon) attached. It includes server control mode, realtime power output estimation and realtime daily energy counters.
The remote thermostat protocol CNRF is supported by https://github.com/gekkekoe/esphome-ecodan-remote-thermostat. It implements a virtual thermostat that can be linked with any temperature sensor.
English (default), Dutch, Italian, French, Spanish. Select the language in ecodan-esphome.yaml
file.
If you want to contribute with a translation: copy the file ecodan-labels-en.yaml
to ecodan-labels-xx.yaml
, fill in all the labels and submit a pull request.
It's possible to run a melcloud wifi adapter or procon as slave. The slave unit will function as usual. see proxy.md for more information
In sever control mode, the prohibit flags can be set. You can disable it by commenting the sever-control.yaml
entry in the ecodan-esphome.yaml
.
If you don't want to solder, use one of the tested boards. More boards that should be working. It also should work for airco units with cn105 connectors.
Tested boards
Board | Link | Notes |
---|---|---|
Heishamon V5 large | https://www.tindie.com/products/thehognl/heishamon-communication-pcb/ | see proxy.md |
M5Stack Atom Lite (ESP32 variants) | https://docs.m5stack.com/en/core/ATOM%20Lite | Grove ports used |
M5Stack Atom Lite (ESP32 variants) | https://docs.m5stack.com/en/core/ATOM%20Lite | Pins used example |
M5Stack Atom Lite S3 (ESP32-S3 variants) | https://docs.m5stack.com/en/core/AtomS3%20Lite | Grove ports used |
Cable
- Get one of the grove female cable and a ST PAP-05V-S connector. Remove one end of the grove connector and replace it with a ST PAP-05V-S connector. Here's an example:
Pin mapping (from left to right)
grove | cn105 |
---|---|
pin 1 - black (gnd) | pin 4 - black (gnd) |
pin 2 - red (5v) | pin 3 - red (5v) |
pin 3 - white (GPIO 2) | pin 2 - white (Tx) |
pin 4 - yellow (GPIO 1) | pin 1 - yellow (Rx) |
Note: pin 5 (12v) on the cn105 is not used.
atom s3 lite https://www.digikey.nl/en/products/detail/m5stack-technology-co-ltd/C124/18070571
grove cable (multiple options/lengths available) https://www.digikey.nl/en/products/detail/seeed-technology-co-ltd/110990036/5482563
JST PAP-05V-S connector https://www.digikey.nl/en/products/detail/jst-sales-america-inc/PAP-05V-S/759977
- Install ESPHome https://esphome.io/guides/getting_started_command_line.html. (Use Python <= 3.12 to avoid build errors on Windows)
python3 -m venv venv source venv/bin/activate pip3 install wheel pip3 install esphome
- Fill in
secrets.yaml
and copy theecodan-esphome.yaml
to your esphome folder and edit the values (check GPO pins (uart: section), you might need to swap the pins in the config) The secrets.yaml should at least contain the following entries:
wifi_ssid: "wifi network id"
wifi_password: "wifi password"
- Edit the following section in
ecodan-esphome.yaml
to match your configuration (esp board, zone1/zone2, language, server control, enable debug). Default is an esp32-s3 board, 1 zone and english language.
packages:
remote_package:
url: https://github.com/gekkekoe/esphome-ecodan-hp/
ref: main
refresh: always
files: [
confs/esp32s3.yaml, # confs/esp32.yaml, for regular board
confs/zone1.yaml,
## enable if you want to use zone 2
#confs/zone2.yaml,
## enable label language file
confs/ecodan-labels-en.yaml,
#confs/ecodan-labels-nl.yaml,
#confs/ecodan-labels-it.yaml,
#confs/ecodan-labels-fr.yaml,
#confs/ecodan-labels-es.yaml,
confs/server-control.yaml,
#confs/debug.yaml,
]
- Build
esphome compile ecodan-esphome.yaml
-
To find the tty* where the esp32 is connected at, use
sudo dmesg | grep tty
. On my machine it wasttyACM0
for usb-c, andttyUSB0
for usb-a.tty.usbmodemxxx
for Mac andCOMXX
for Windows -
Connect your esp32 via usb and flash
esphome upload --device=/dev/ttyACM0 ecodan-esphome.yaml
- You can update the firmware via the web interface of the esp after the initial flash, or use the following command to flash over the network
esphome upload --device ip_address ecodan-esphome.yaml
Here's how it's connected inside the heatpump:
The esphome component will be auto detected in Home Assistant: