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.0b7.tar.gz (31.5 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.0b7-py3-none-any.whl (23.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: flow_it_api-0.0.1.0b7.tar.gz
  • Upload date:
  • Size: 31.5 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.0b7.tar.gz
Algorithm Hash digest
SHA256 dc4f3504b80f8ab38184fa017684a33a9d67141ff382c8a1b982e8df9eef26ac
MD5 3572bc39989cbf0c7216322b739aa920
BLAKE2b-256 78614e5517d71d50a116b9000727ebd30c7a6db36cae28df87c9122a8e8745be

See more details on using hashes here.

Provenance

The following attestation bundles were made for flow_it_api-0.0.1.0b7.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.0b7-py3-none-any.whl.

File metadata

  • Download URL: flow_it_api-0.0.1.0b7-py3-none-any.whl
  • Upload date:
  • Size: 23.3 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.0b7-py3-none-any.whl
Algorithm Hash digest
SHA256 243c30fa6f8a55c4968df79272a0dcc59692b8e889e41d0c7c9de170cf5caab0
MD5 4ab28d7b4baedc034fc3b56c74370120
BLAKE2b-256 ebc87b5a85a892ec46995548928923b75ebe018be4feb5583376a45463f5b95a

See more details on using hashes here.

Provenance

The following attestation bundles were made for flow_it_api-0.0.1.0b7-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