Python API library client for the TBK VMC machine
Project description
PYTBK-API
A Python API library client for TBK VMC (Ventilazione Meccanica Controllata) machines.
This library provides a simple, asynchronous interface to interact with TBK VMC devices over a local network, supporting both REST API for commands/status and WebSockets for real-time updates.
Context
TBK VMC devices use two fans to control airflow (Inflow and Outflow) and are equipped with multiple sensors (Temperature, Humidity, Pressure, IAQ). While these devices connect to TBK cloud services, they also expose a local LAN API for direct control.
Installation
Prerequisites
- Python 3.11 or higher
Setup Virtual Environment
python -m venv .venv
source .venv/bin/activate # On Windows: .venv\Scripts\activate
pip install -e .
For development:
pip install -e .[dev]
# Install pre-commit hooks
pre-commit install
Usage
The library uses httpx for asynchronous HTTP requests and websockets for real-time updates.
Basic Example
import asyncio
import logging
from pytbk_api.client import TbkVMCMachine
from pytbk_api.const import Speed
# Setup logging to see the library version and actions
logging.basicConfig(level=logging.INFO)
async def main():
host = "http://192.168.1.50"
# You can retrieve your API password from the device's menu using the on-board display
password = "your_api_password"
async with TbkVMCMachine(host, password) as vmc:
# Get device info (Model, FW version, etc.)
info = await vmc.get_info()
print(f"Device: {info.model}, FW: {info.fw_ver}")
# Fetch initial state
state = await vmc.refresh_state()
print(f"Current Speed: {state.mode.speed}")
print(f"Temperature: {state.mode.temperatureIn_celsius}°C")
# Send a command
await vmc.send_command(Speed.LEVEL_3, flow_in=True, flow_out=True)
if __name__ == "__main__":
asyncio.run(main())
Real-time Updates (WebSocket)
The library can listen for real-time updates pushed by the device:
async def on_data(data):
print(f"Update received! New IAQ: {data.mode.iaq}")
# Initialize machine and websocket
async with TbkVMCMachine(host, password) as vmc:
vmc.websocket._on_data = on_data
vmc.websocket.start()
# Keep the loop running to receive events
await asyncio.sleep(60)
Library Architecture
Key Components
TbkVMCMachine: The primary entry point. Manages authentication, connection state, and coordination between REST and WebSocket clients.Authenticator: Handles JWT token acquisition and automatic renewal.TbkWebSocket: Manages the persistent WebSocket connection and reconnection logic.Models: Pydantic models providing type-safe access to machine data, including automatic Kelvin-to-Celsius conversions.
Features
- Asynchronous: Built on
asyncio. - Automatic Auth: Handles login and token refreshing transparently via decorators.
- Type Safety: Full Pydantic v2 model support.
- Temperature Conversion: Access temperatures in both Kelvin (raw) and Celsius (processed).
- Comprehensive Logging: Detailed internal logging for debugging, including version tracking at load time.
- Dynamic Versioning: Versioning is automatically managed via Git tags (VCS).
Development
The project structure:
src/pytbk_api/: Library source code (src layout).tests/: Unit tests (usingpytest).specs/: OpenAPI/YAML specifications for the device API.example.py: A comprehensive CLI test client.
Quality Control
This project uses several tools to ensure code quality:
- Linting & Formatting:
black,isort, andmypyfor type checking. - Git Hooks:
pre-commitis used to run all checks locally before every commit. - CI/CD: GitHub Actions runs the full test suite across multiple Python versions and handles automated releases to PyPI.
To run tests locally:
pytest --cov=src --cov-report=term-missing
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 pytbk_api-0.0.1.0b1.tar.gz.
File metadata
- Download URL: pytbk_api-0.0.1.0b1.tar.gz
- Upload date:
- Size: 18.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3ed8a2eb7466c901f6dd180f010278a8df8c9a11c6f1e5d4fa7918402d47a9d5
|
|
| MD5 |
1b2e27dfcfe9c392c4fa280ef7e00d42
|
|
| BLAKE2b-256 |
669de0e75d11ae11f3a8a1b9f7e0033d2f49b8619419ee422b07b840fadd5e1d
|
Provenance
The following attestation bundles were made for pytbk_api-0.0.1.0b1.tar.gz:
Publisher:
publish.yml on albertogeniola/pytbk-api
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pytbk_api-0.0.1.0b1.tar.gz -
Subject digest:
3ed8a2eb7466c901f6dd180f010278a8df8c9a11c6f1e5d4fa7918402d47a9d5 - Sigstore transparency entry: 1428999861
- Sigstore integration time:
-
Permalink:
albertogeniola/pytbk-api@58c1896f1b0de3a13427d97741eee776006bc0cc -
Branch / Tag:
refs/tags/v0.0.1.0b1 - Owner: https://github.com/albertogeniola
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@58c1896f1b0de3a13427d97741eee776006bc0cc -
Trigger Event:
push
-
Statement type:
File details
Details for the file pytbk_api-0.0.1.0b1-py3-none-any.whl.
File metadata
- Download URL: pytbk_api-0.0.1.0b1-py3-none-any.whl
- Upload date:
- Size: 10.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8b20f6e9a2050ef1687197fadce5a053493ec44553a2f0f0ddc67da7025b5812
|
|
| MD5 |
bf7eab98b3aa7a022b078b736f1dc7be
|
|
| BLAKE2b-256 |
2d6678754dcc47770d55aa024d8f4095c2fe7ce5140f176acb2ca4ca4457f69d
|
Provenance
The following attestation bundles were made for pytbk_api-0.0.1.0b1-py3-none-any.whl:
Publisher:
publish.yml on albertogeniola/pytbk-api
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pytbk_api-0.0.1.0b1-py3-none-any.whl -
Subject digest:
8b20f6e9a2050ef1687197fadce5a053493ec44553a2f0f0ddc67da7025b5812 - Sigstore transparency entry: 1428999864
- Sigstore integration time:
-
Permalink:
albertogeniola/pytbk-api@58c1896f1b0de3a13427d97741eee776006bc0cc -
Branch / Tag:
refs/tags/v0.0.1.0b1 - Owner: https://github.com/albertogeniola
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@58c1896f1b0de3a13427d97741eee776006bc0cc -
Trigger Event:
push
-
Statement type: