Skip to main content

aiocomfoconnect is an asyncio Python 3 library for communicating with a Zehnder ComfoAir Q350/450/600 ventilation system

Project description

aiocomfoconnect

aiocomfoconnect is an asyncio Python 3 library for communicating with a Zehnder ComfoAir Q350/450/600 ventilation system. It's the successor of comfoconnect.

It's compatible with Python 3.10 and higher.

Installation

pip3 install aiocomfoconnect

CLI Usage

$ python -m aiocomfoconnect --help

$ python -m aiocomfoconnect discover

$ python -m aiocomfoconnect register --host 192.168.1.213

$ python -m aiocomfoconnect set-speed away --host 192.168.1.213
$ python -m aiocomfoconnect set-speed low --host 192.168.1.213
$ python -m aiocomfoconnect set-mode auto --host 192.168.1.213
$ python -m aiocomfoconnect set-speed medium --host 192.168.1.213
$ python -m aiocomfoconnect set-speed high --host 192.168.1.213
$ python -m aiocomfoconnect set-boost on --host 192.168.1.213 --timeout 1200

$ python -m aiocomfoconnect set-comfocool auto --host 192.168.1.213
$ python -m aiocomfoconnect set-comfocool off --host 192.168.1.213

$ python -m aiocomfoconnect show-sensors --host 192.168.1.213
$ python -m aiocomfoconnect show-sensor 276 --host 192.168.1.213
$ python -m aiocomfoconnect show-sensor 276 --host 192.168.1.213 -f

$ python -m aiocomfoconnect get-property --host 192.168.1.213 1 1 8 9  # Unit 0x01, SubUnit 0x01, Property 0x08, Type STRING. See PROTOCOL-RMI.md

Available methods

  • async connect(): Connect to the bridge.
  • async disconnect(): Disconnect from the bridge.
  • async register_sensor(sensor): Register a sensor.
  • async deregister_sensor(sensor): Deregister a sensor.
  • async get_mode(): Get the ventilation mode.
  • async set_mode(mode): Set the ventilation mode. (auto / manual)
  • async get_comfocool_mode(): Get Comfocool mode
  • async set_comfocool_mode(): Set Comfocool mode. (auto / off)
  • async get_speed(): Get the ventilation speed.
  • async set_speed(speed): Set the ventilation speed. (away / low / medium / high)
  • async get_bypass(): Get the bypass mode.
  • async set_bypass(mode, timeout=-1): Set the bypass mode. (auto / on / off)
  • async get_balance_mode(): Get the balance mode.
  • async set_balance_mode(mode, timeout=-1): Set the balance mode. (balance / supply only / exhaust only)
  • async get_boost(): Get the boost mode.
  • async set_boost(mode, timeout=-1): Set the boost mode. (boolean)
  • async get_away(): Get the away mode.
  • async set_away(mode, timeout=-1): Set the away mode. (boolean)
  • async get_temperature_profile(): Get the temperature profile.
  • async set_temperature_profile(profile): Set the temperature profile. (warm / normal / cool)
  • async get_sensor_ventmode_temperature_passive(): Get the sensor based ventilation passive temperature control setting.
  • async set_sensor_ventmode_temperature_passive(mode): Set the sensor based ventilation passive temperature control setting. (auto / on / off)
  • async get_sensor_ventmode_humidity_comfort(): Get the sensor based ventilation humidity comfort setting.
  • async set_sensor_ventmode_humidity_comfort(mode): Set the sensor based ventilation humidity comfort setting. (auto / on / off)
  • async get_sensor_ventmode_humidity_protection(): Get the sensor based ventilation humidity protection setting.
  • async set_sensor_ventmode_humidity_protection(mode): Set the sensor based ventilation humidity protection setting. (auto / on / off)

Low-level API

  • async cmd_start_session(): Start a session.
  • async cmd_close_session(): Close a session.
  • async cmd_list_registered_apps(): List registered apps.
  • async cmd_register_app(uuid, device_name, pin): Register an app.
  • async cmd_deregister_app(uuid): Deregister an app.
  • async cmd_version_request(): Request the bridge's version.
  • async cmd_time_request(): Request the bridge's time.
  • async cmd_rmi_request(message, node_id): Send a RMI request.
  • async cmd_rpdo_request(pdid, type, zone, timeout): Send a RPDO request.
  • async cmd_keepalive(): Send a keepalive message.

Examples

Discovery of ComfoConnect LAN C Bridges

import asyncio

from aiocomfoconnect import discover_bridges


async def main():
    """ ComfoConnect LAN C Bridge discovery example."""

    # Discover all ComfoConnect LAN C Bridges on the subnet.
    bridges = await discover_bridges()
    print(bridges)


if __name__ == "__main__":
    asyncio.run(main())

Basic Example

import asyncio

from aiocomfoconnect import ComfoConnect
from aiocomfoconnect.const import VentilationSpeed
from aiocomfoconnect.sensors import SENSORS


async def main(local_uuid, host, uuid):
    """ Basic example."""

    def sensor_callback(sensor, value):
        """ Print sensor updates. """
        print(f"{sensor.name} = {value}")

    # Connect to the Bridge
    comfoconnect = ComfoConnect(host, uuid, sensor_callback=sensor_callback)
    await comfoconnect.connect(local_uuid)

    # Register all sensors
    for key in SENSORS:
        await comfoconnect.register_sensor(SENSORS[key])

    # Set speed to LOW
    await comfoconnect.set_speed(VentilationSpeed.LOW)

    # Wait 2 minutes so we can see some sensor updates
    await asyncio.sleep(120)

    # Disconnect from the bridge
    await comfoconnect.disconnect()


if __name__ == "__main__":
    asyncio.run(main(local_uuid='00000000000000000000000000001337', host='192.168.1.20', uuid='00000000000000000000000000000055'))  # Replace with your bridge's IP and UUID

Development Notes

Protocol Documentation

Decode network traffic

You can use the scripts/decode_pcap.py file to decode network traffic between the Mobile App and the ComfoConnect LAN C. Make sure that the first TCP session in the capture is the connection between the bridge and the app. It's therefore recommended to start the capture before you open the app.

$ sudo tcpdump -i any -s 0 -w /tmp/capture.pcap tcp and port 56747
$ python3 script/decode_pcap.py /tmp/capture.pcap

Generate zehnder_pb2.py file

python3 -m pip install grpcio-tools==1.67.1
python3 -m grpc_tools.protoc -Iprotobuf --python_out=aiocomfoconnect/protobuf protobuf/*.proto

Docker

You can build a Docker image to make it easier to develop and experiment on your local machine. You can use the docker build -t aiocomfoconnect . or the shortcut make build command to create a docker image.

Next, you can run this image by running docker run aiocomfoconnect. Any args from aiocomfoconnect can be passed into this command, just like the python3 -m aiocomfoconnect command.

Interesting 3th party repositories

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

aiocomfoconnect-0.1.14.tar.gz (30.3 kB view details)

Uploaded Source

Built Distribution

aiocomfoconnect-0.1.14-py3-none-any.whl (32.0 kB view details)

Uploaded Python 3

File details

Details for the file aiocomfoconnect-0.1.14.tar.gz.

File metadata

  • Download URL: aiocomfoconnect-0.1.14.tar.gz
  • Upload date:
  • Size: 30.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.3 Linux/5.15.153.1-microsoft-standard-WSL2

File hashes

Hashes for aiocomfoconnect-0.1.14.tar.gz
Algorithm Hash digest
SHA256 8a4fa6f4ef384432edde60437aad7e2fe115933f39dddb749194961f7b14f1b8
MD5 1381b21302c103ce592bb3693ead4cfb
BLAKE2b-256 ede449c94d14433c5dcae32a821be2111d300e0c2d6cfb27302329a19af42a6f

See more details on using hashes here.

File details

Details for the file aiocomfoconnect-0.1.14-py3-none-any.whl.

File metadata

  • Download URL: aiocomfoconnect-0.1.14-py3-none-any.whl
  • Upload date:
  • Size: 32.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.3 Linux/5.15.153.1-microsoft-standard-WSL2

File hashes

Hashes for aiocomfoconnect-0.1.14-py3-none-any.whl
Algorithm Hash digest
SHA256 4d17b100bda8497be2f2a5fab37e8e0efa6d4b7ad37642d488b9be230a4d0f83
MD5 96358bb1b7e549e38a2f7a7ba38ee4fb
BLAKE2b-256 dec01b2c0599783979048ac8b13072558c1569ae62424843817386f8367bc8e3

See more details on using hashes here.

Supported by

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