Skip to main content

HTTP/Modbus-to-MQTT bridge for Kermi heat pumps with Home Assistant auto-discovery

Project description

kermi2mqtt

Tests Docker License Python 3.12+

Modbus-to-MQTT bridge for Kermi heat pumps with Home Assistant auto-discovery.

Features

  • Full monitoring - All heat pump sensors published via MQTT
  • Bidirectional control - Change settings (mode, preset, DHW temp) via MQTT
  • Home Assistant integration - Zero-config auto-discovery with climate & water_heater entities
  • Unified device - All entities grouped under single "Kermi X-Center" device in HA
  • Safety-first - Only exposes user-safe controls with validation
  • Kubernetes ready - Helm chart included for easy deployment
  • Async/efficient - Low resource usage (<50MB RAM)

Quick Start

Prerequisites

  • Kermi heat pump with Modbus TCP/RTU interface
  • MQTT broker (Mosquitto, Home Assistant, etc.)
  • Python 3.12+ or Docker

Installation

Option 1: Docker (Recommended)

# Create config file
cp config.example.yaml config.yaml
# Edit config.yaml with your Modbus and MQTT settings

# Build and run
docker build -t kermi2mqtt .
docker run -d --name kermi2mqtt \
  -v $(pwd)/config.yaml:/config/config.yaml:ro \
  kermi2mqtt

Or with Docker Compose:

docker-compose up -d

Option 2: Kubernetes (Helm)

# Add your values
cat > my-values.yaml << EOF
config:
  modbus:
    host: "xcenter.local"
    port: 502
  mqtt:
    host: "mqtt.local"
    port: 8883
    tlsEnabled: true
mqttAuth:
  username: "kermi"
  password: "your-password"
EOF

# Install
helm install kermi2mqtt ./charts/kermi2mqtt -f my-values.yaml

See charts/kermi2mqtt/values.yaml for all options.

Option 3: Python Package

# Install from PyPI
pip install kermi2mqtt

# Or install from source
git clone https://github.com/jr42/kermi2mqtt
cd kermi2mqtt
pip install -e .

Configuration

  1. Copy config.example.yaml to config.yaml
  2. Configure your Modbus connection:
    modbus:
      host: 192.168.1.100  # Your heat pump IP
      port: 502
      mode: tcp
    
  3. Configure your MQTT broker:
    mqtt:
      host: localhost
      port: 1883
    
  4. Set device ID (or leave blank for auto-detection):
    integration:
      device_id: my_heat_pump
      poll_interval: 30.0
    

Running

Docker

docker-compose up -d
docker-compose logs -f kermi2mqtt

Python

python -m kermi2mqtt --config config.yaml

Systemd Service

# Copy service file
sudo cp kermi2mqtt.service /etc/systemd/system/
sudo systemctl daemon-reload

# Enable and start
sudo systemctl enable kermi2mqtt
sudo systemctl start kermi2mqtt

# Check status
sudo systemctl status kermi2mqtt

MQTT Topics

State Topics (Published by kermi2mqtt)

kermi/{device_id}/sensors/outdoor_temp          → Outdoor temperature
kermi/{device_id}/sensors/supply_temp           → Supply temperature
kermi/{device_id}/sensors/cop                   → Coefficient of Performance
kermi/{device_id}/sensors/power_total           → Thermal power output
kermi/{device_id}/sensors/power_electrical      → Electrical power consumption

kermi/{device_id}/heating/actual                → Current heating temperature
kermi/{device_id}/heating/setpoint              → Heating setpoint
kermi/{device_id}/heating/circuit_status        → Heating circuit status

kermi/{device_id}/water_heater/actual           → DHW actual temperature
kermi/{device_id}/water_heater/setpoint         → DHW setpoint
kermi/{device_id}/water_heater/single_charge    → One-time heating active

kermi/{device_id}/availability                  → online/offline

Command Topics (Subscribe with MQTT client)

# Monitor all topics
mosquitto_sub -h localhost -t 'kermi/#' -v

# Monitor specific sensor
mosquitto_sub -h localhost -t 'kermi/my_heat_pump/sensors/outdoor_temp'

Home Assistant Integration

Entities automatically appear in Home Assistant with appropriate types:

  • Climate entities for heating/cooling control
  • Water Heater entities for domestic hot water
  • Sensor entities for temperature, power, COP readings
  • Switch entities for on/off controls
  • Binary Sensor entities for status indicators

All entities are grouped under a single Device in Home Assistant.

Architecture

┌─────────────────┐         ┌──────────────┐         ┌─────────────────┐
│  Kermi Heat     │ Modbus  │  kermi2mqtt  │  MQTT   │  Home Assistant │
│  Pump (x-center)│◄───────►│   Bridge     │◄───────►│  / MQTT Clients │
└─────────────────┘         └──────────────┘         └─────────────────┘
                                    │
                            ┌───────▼────────┐
                            │ py-kermi-xcenter│
                            │  (Modbus lib)   │
                            └─────────────────┘

Development

Setup

# Clone repository
git clone https://github.com/jr42/kermi2mqtt
cd kermi2mqtt

# Create virtual environment
python -m venv .venv
source .venv/bin/activate  # or `.venv\Scripts\activate` on Windows

# Install with dev dependencies
pip install -e ".[dev]"

Testing

# Run tests
pytest

# Run tests with coverage
pytest --cov=src/kermi2mqtt --cov-report=html

# Run linters
ruff check src/ tests/
mypy src/kermi2mqtt/
black --check src/ tests/

Project Structure

kermi2mqtt/
├── src/kermi2mqtt/           # Main package
│   ├── __main__.py           # Entry point
│   ├── config.py             # Configuration loading
│   ├── modbus_client.py      # Modbus wrapper
│   ├── mqtt_client.py        # MQTT wrapper
│   ├── bridge.py             # Main bridge logic
│   ├── safety.py             # Safety validation
│   ├── ha_discovery.py       # HA discovery payloads
│   ├── mappings.py           # Attribute definitions
│   └── models/               # Data models
├── charts/kermi2mqtt/        # Helm chart for Kubernetes
├── tests/                    # Test suite
├── Dockerfile                # Container image
└── config.example.yaml       # Example configuration

Safety

This integration only exposes user-safe controls equivalent to the heat pump's physical interface:

Safe to modify:

  • Temperature setpoints (40-60°C for DHW)
  • Operating modes (heating/cooling)
  • One-time water heating
  • Heating schedules

Not exposed (hardware safety):

  • Compressor controls
  • Refrigerant valve positions
  • System pressure
  • Low-level firmware parameters

See specs/001-modbus-mqtt/safety.md for detailed safety documentation.

Troubleshooting

Connection Issues

# Test Modbus connection
python -c "from kermi_xcenter import KermiModbusClient, HeatPump; import asyncio; asyncio.run(test())"

# Check MQTT broker
mosquitto_sub -h localhost -t '#' -v

Logs

# Docker logs
docker-compose logs -f kermi2mqtt

# Systemd logs
journalctl -u kermi2mqtt -f

# Increase log verbosity in config.yaml
logging:
  level: DEBUG

Common Issues

  1. "No response from heat pump"

    • Check network connectivity: ping <heat_pump_ip>
    • Verify Modbus port 502 is accessible
    • Check firewall rules
  2. "MQTT connection failed"

    • Verify broker is running: systemctl status mosquitto
    • Test broker: mosquitto_sub -h localhost -t test
    • Check credentials in config.yaml
  3. "Entities not appearing in Home Assistant"

    • Check MQTT discovery prefix matches HA config (default: homeassistant)
    • Verify kermi2mqtt is publishing: mosquitto_sub -t 'homeassistant/#'
    • Restart Home Assistant after first discovery

Contributing

Contributions welcome! Please:

  1. Fork the repository
  2. Create a feature branch
  3. Make your changes with tests
  4. Run linters and tests
  5. Submit a pull request

License

Apache License 2.0 - see LICENSE for details.

Credits

Disclaimer

This software is not affiliated with or endorsed by Kermi. Use at your own risk. Always ensure changes are safe for your equipment.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

kermi2mqtt-0.1.0.tar.gz (52.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

kermi2mqtt-0.1.0-py3-none-any.whl (50.8 kB view details)

Uploaded Python 3

File details

Details for the file kermi2mqtt-0.1.0.tar.gz.

File metadata

  • Download URL: kermi2mqtt-0.1.0.tar.gz
  • Upload date:
  • Size: 52.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for kermi2mqtt-0.1.0.tar.gz
Algorithm Hash digest
SHA256 25bbce9489f6ca243199a3b901860df6a4aeee1ce031b69e8a48b00478983e8b
MD5 66ebac6f0f288dc2d4e0eacbe545d851
BLAKE2b-256 68c48a168eb5c321ac5f83be01835a86dcccccc6a6060cb0e61f62dd23f20f8a

See more details on using hashes here.

Provenance

The following attestation bundles were made for kermi2mqtt-0.1.0.tar.gz:

Publisher: release.yml on jr42/kermi2mqtt

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file kermi2mqtt-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: kermi2mqtt-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 50.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for kermi2mqtt-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 534485d38cc9cc1e30540a7a84a82dc6be15c4d68ba8d2bf14c7e929461c9ddb
MD5 8e27257368de3ad7418e5abdc97298df
BLAKE2b-256 e4998b9f37d2a993002043a2e6622380c60ec9ae0e41edb10139220a91e7ff28

See more details on using hashes here.

Provenance

The following attestation bundles were made for kermi2mqtt-0.1.0-py3-none-any.whl:

Publisher: release.yml on jr42/kermi2mqtt

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page