Skip to main content

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 (using pytest).
  • 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, and mypy for type checking.
  • Git Hooks: pre-commit is 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


Download files

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

Source Distribution

pytbk_api-0.0.1.0b1.tar.gz (18.9 kB view details)

Uploaded Source

Built Distribution

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

pytbk_api-0.0.1.0b1-py3-none-any.whl (10.4 kB view details)

Uploaded Python 3

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

Hashes for pytbk_api-0.0.1.0b1.tar.gz
Algorithm Hash digest
SHA256 3ed8a2eb7466c901f6dd180f010278a8df8c9a11c6f1e5d4fa7918402d47a9d5
MD5 1b2e27dfcfe9c392c4fa280ef7e00d42
BLAKE2b-256 669de0e75d11ae11f3a8a1b9f7e0033d2f49b8619419ee422b07b840fadd5e1d

See more details on using hashes here.

Provenance

The following attestation bundles were made for pytbk_api-0.0.1.0b1.tar.gz:

Publisher: publish.yml on albertogeniola/pytbk-api

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

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

Hashes for pytbk_api-0.0.1.0b1-py3-none-any.whl
Algorithm Hash digest
SHA256 8b20f6e9a2050ef1687197fadce5a053493ec44553a2f0f0ddc67da7025b5812
MD5 bf7eab98b3aa7a022b078b736f1dc7be
BLAKE2b-256 2d6678754dcc47770d55aa024d8f4095c2fe7ce5140f176acb2ca4ca4457f69d

See more details on using hashes here.

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

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