Python library to interface with Airios RF bridges
Project description
pyAirios
A Python library to interface with Airios RF bridges.
Description
Airios develop and produce several components for residential ventilation systems that final manufacturers use to build their products upon, from controller boards to remote controls or sensors.
All of these components communicate over a proprietary RF protocol from Honeywell called Ramses II in the 868Mhz band. The RF bridge allows third party applications to access the nodes in the RF network over standard Modbus protocol.
There are two bridge models with different interfaces. The BRDG-02R13 has a RS485 serial interface (Modbus-RTU) and the BRDG-02EM23 is an Ethernet device (Modbus-TCP).
This library only supports the RS485 model.
Working principle
Each device in the RF network is called a node and nodes must be bound together to be able to communicate. There are two classes of nodes:
- Controllers (typically ventilation units). Binding mode is enabled for a fixed period after power cycle.
- Accessories (remote controls or sensors). They bind to a controller in a device-specific way, e.g., pressing a combination of buttons.
The bridge is an accessory with special features. It can bind to multiple controllers and at the same time it can "intercept" the accessories binding procedure so they are bound to the controller and the bridge at the same time. Each bound device to the bridge creates a new virtual Modbus slave with its own address and register set. The register set depends on the bounded product.
NOTE: Binding is only possible when products have the same OEM code. The RF bridge has a registry to change it if necessary.
Supported devices
This library has been tested with the following devices:
Installation
python -m pip install pyairios
How to use
The library offers a high level and easy to use API:
transport = AiriosModbusRTUTransport(device="/dev/ttyACM0")
api = Airios(transport)
vmd = api.node(<slave id>)
A command line interface is also included in the library for testing purposes. Use the help or ? command to get the list of available commands in each context.
Acknowledgements
- Siber for providing the documentation and an outstanding support.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pyairios-1.0.7.tar.gz.
File metadata
- Download URL: pyairios-1.0.7.tar.gz
- Upload date:
- Size: 32.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
13fe04f2840c60d19aaa71c8d3246adfdeed49e8271cfe606f8be016e261128f
|
|
| MD5 |
f9c0892bbe30a23cc828395711f9046e
|
|
| BLAKE2b-256 |
513ec85126fad465f4e5bc5abfd519fbdd4d89176ff5a8b401f8f2a493e49848
|
Provenance
The following attestation bundles were made for pyairios-1.0.7.tar.gz:
Publisher:
pypi-publish.yml on scabrero/pyairios
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pyairios-1.0.7.tar.gz -
Subject digest:
13fe04f2840c60d19aaa71c8d3246adfdeed49e8271cfe606f8be016e261128f - Sigstore transparency entry: 529117615
- Sigstore integration time:
-
Permalink:
scabrero/pyairios@3797defba5432404c4ded2ff8c945ee1da32ec9b -
Branch / Tag:
refs/tags/v1.0.7 - Owner: https://github.com/scabrero
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi-publish.yml@3797defba5432404c4ded2ff8c945ee1da32ec9b -
Trigger Event:
release
-
Statement type:
File details
Details for the file pyairios-1.0.7-py3-none-any.whl.
File metadata
- Download URL: pyairios-1.0.7-py3-none-any.whl
- Upload date:
- Size: 34.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b0f2fe188114214db732829870b1b4b4c5b4ebd73ad9e329fcbaea0eb4dc78fc
|
|
| MD5 |
693c2d4384f34a075d2d8f3801e4bd6e
|
|
| BLAKE2b-256 |
7bc2cd2196a5921fddd5a2c65622ede54417d95f69edef20ebc0badbc0f3153e
|
Provenance
The following attestation bundles were made for pyairios-1.0.7-py3-none-any.whl:
Publisher:
pypi-publish.yml on scabrero/pyairios
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pyairios-1.0.7-py3-none-any.whl -
Subject digest:
b0f2fe188114214db732829870b1b4b4c5b4ebd73ad9e329fcbaea0eb4dc78fc - Sigstore transparency entry: 529117621
- Sigstore integration time:
-
Permalink:
scabrero/pyairios@3797defba5432404c4ded2ff8c945ee1da32ec9b -
Branch / Tag:
refs/tags/v1.0.7 - Owner: https://github.com/scabrero
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi-publish.yml@3797defba5432404c4ded2ff8c945ee1da32ec9b -
Trigger Event:
release
-
Statement type: