Skip to main content

Python API library client for the FlowIt VMC machine

Project description

FLOW-IT-API

A Python API library client for FlowIt VMC (Ventilazione Meccanica Controllata) machines.

This library provides a simple, asynchronous interface to interact with FlowIt VMC devices over a local network, supporting both REST API for commands/status and WebSockets for real-time updates.

Context

FlowIt 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 FlowIt 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 flow_it_api.client import FlowItVMCMachine
from flow_it_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 FlowItVMCMachine(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 FlowItVMCMachine(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

  • FlowItVMCMachine: The primary entry point. Manages authentication, connection state, and coordination between REST and WebSocket clients.
  • Authenticator: Handles JWT token acquisition and automatic renewal.
  • FlowItWebSocket: 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/flow_it_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

flow_it_api-0.0.1.0b4.tar.gz (31.2 kB view details)

Uploaded Source

Built Distribution

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

flow_it_api-0.0.1.0b4-py3-none-any.whl (22.9 kB view details)

Uploaded Python 3

File details

Details for the file flow_it_api-0.0.1.0b4.tar.gz.

File metadata

  • Download URL: flow_it_api-0.0.1.0b4.tar.gz
  • Upload date:
  • Size: 31.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for flow_it_api-0.0.1.0b4.tar.gz
Algorithm Hash digest
SHA256 8526c5b540437a20c4a1460794e6e8fda4bf3e403d12ef713f1c578e4d02ebcf
MD5 a7674c9e9a3ac93c2085e5d3de3f5289
BLAKE2b-256 acc0eb9d88da0ea220899f87a8e985c58cc10f121da6280a29027140bfd5e994

See more details on using hashes here.

Provenance

The following attestation bundles were made for flow_it_api-0.0.1.0b4.tar.gz:

Publisher: publish.yml on albertogeniola/flow-it-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 flow_it_api-0.0.1.0b4-py3-none-any.whl.

File metadata

  • Download URL: flow_it_api-0.0.1.0b4-py3-none-any.whl
  • Upload date:
  • Size: 22.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for flow_it_api-0.0.1.0b4-py3-none-any.whl
Algorithm Hash digest
SHA256 5a29e7fb97f843110d237e55542c421ac95237da4d28aebbd13c02e66a1ea6db
MD5 471fb2b812ad7c1212673e8c875d925a
BLAKE2b-256 a0d9642069d2fe7457c1da6e25f0183a7fd0acd4a71bfbc46fe0c02ccb2243f5

See more details on using hashes here.

Provenance

The following attestation bundles were made for flow_it_api-0.0.1.0b4-py3-none-any.whl:

Publisher: publish.yml on albertogeniola/flow-it-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