Skip to main content

Asynchronous library to interact with Iregul systems via undocumented API

Project description

aioiregul

Python Version License

Asynchronous Python library to interact with IRegul systems via their undocumented API over sockets.

Note: This library is under active development.

Features

  • 🔄 Fully asynchronous using asyncio and aiohttp
  • 🔌 Socket-based communication with IRegul systems
  • 🎯 Type-safe with comprehensive type hints
  • 📊 Parse and decode IRegul API responses
  • 🏠 Home automation integration ready

Requirements

  • Python 3.14 or higher
  • aiohttp
  • BeautifulSoup4
  • python-slugify

Installation

uv pip install aioiregul

Or install from source:

git clone https://github.com/PoppyPop/aioiregul.git
cd aioiregul
uv sync --all-extras

Quick Start

import asyncio
import aioiregul

async def main():
    # Configure connection options
    options = aioiregul.ConnectionOptions(
        username='your_username',
        password='your_password'
    )

    # Create device instance
    device = aioiregul.Device(options)

    # Collect data from the device
    data = await device.collect()

    # Display results
    print(data)

# Run the async function
asyncio.run(main())

Development Setup

Using VS Code Devcontainer (Recommended)

The easiest way to get started with development:

  1. Install Docker and VS Code
  2. Install the Remote - Containers extension
  3. Open the project in VS Code
  4. Click "Reopen in Container" when prompted

All dependencies and tools will be automatically installed!

Local Development

# Install uv if you haven't already
curl -LsSf https://astral.sh/uv/install.sh | sh  # Linux/Mac
# Or on Windows:
powershell -c "irm https://astral.sh/uv/install.ps1 | iex"

# Sync all dependencies
uv sync --all-extras

# Install pre-commit hooks
uv run pre-commit install

Running Tests

# Run all tests
uv run pytest

# Run with coverage
uv run pytest --cov=aioiregul --cov-report=html

# Run specific test
uv run pytest tests/test_iregul.py -v

Code Quality

# Format code
uv run ruff format .

# Lint code
uv run ruff check . --fix

# Type checking
uv run mypy src/

# Run all pre-commit hooks
uv run pre-commit run --all-files

Project Structure

aioiregul/
├── .devcontainer/          # VS Code devcontainer configuration
├── src/
│   └── aioiregul/         # Main library code
├── tests/                 # Unit tests
├── examples/              # Example scripts and sample data
├── pyproject.toml         # Project configuration
├── CONTRIBUTING.md        # Contribution guidelines
└── README.md              # This file

API Documentation

ConnectionOptions

Configuration for connecting to IRegul systems.

@dataclass
class ConnectionOptions:
    username: str                    # IRegul account username
    password: str                    # IRegul account password
    iregul_base_url: str            # Base URL (default: https://vpn.i-regul.com/modules/)
    refresh_rate: timedelta         # Data refresh interval (default: 5 minutes)

Device

Main class for interacting with IRegul devices.

device = Device(options: ConnectionOptions)
data = await device.collect()  # Fetch current device data

IRegulData

Data structure for IRegul measurements.

@dataclass
class IRegulData:
    id: str           # Data point identifier
    name: str         # Human-readable name
    value: Decimal    # Measured value
    unit: str         # Unit of measurement

Contributing

Contributions are welcome! Please see CONTRIBUTING.md for guidelines.

Development Checklist

  • Write tests for new features
  • Update documentation
  • Follow code style guidelines (Ruff, MyPy)
  • Add type hints to all functions
  • Write docstrings for public APIs

License

This project is licensed under the MIT License - see the LICENSE file for details.

Acknowledgments

This library reverse-engineers the undocumented IRegul API. It is not officially supported by IRegul.

Support

Changelog

See CHANGELOG.md for version history and changes.

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

aioiregul-0.2.4.tar.gz (133.5 kB view details)

Uploaded Source

Built Distribution

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

aioiregul-0.2.4-py3-none-any.whl (38.4 kB view details)

Uploaded Python 3

File details

Details for the file aioiregul-0.2.4.tar.gz.

File metadata

  • Download URL: aioiregul-0.2.4.tar.gz
  • Upload date:
  • Size: 133.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for aioiregul-0.2.4.tar.gz
Algorithm Hash digest
SHA256 a42167e6789d9e4f8b54441e5fea13448bb3f00ad3b9ed9c7b03c53bac14ede6
MD5 1cb7a7fff86e90ef0e070be98675c166
BLAKE2b-256 bc04566dd2cc5c96d10e0882f8f1628b66d088372e6ed4fbe020dd5285b5f13e

See more details on using hashes here.

Provenance

The following attestation bundles were made for aioiregul-0.2.4.tar.gz:

Publisher: publish-to-test-pypi.yml on PoppyPop/aioiregul

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

File details

Details for the file aioiregul-0.2.4-py3-none-any.whl.

File metadata

  • Download URL: aioiregul-0.2.4-py3-none-any.whl
  • Upload date:
  • Size: 38.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for aioiregul-0.2.4-py3-none-any.whl
Algorithm Hash digest
SHA256 c586fea2de346c1606ffc43bcff29123b60b012bba2cbc115f63628a3092581c
MD5 bddc0768822446cc1b8ea5c1bc56b7f3
BLAKE2b-256 645cbd682e9e35f68cc032872a0e67136e3bcc4372f37df348e243e8fe550d6a

See more details on using hashes here.

Provenance

The following attestation bundles were made for aioiregul-0.2.4-py3-none-any.whl:

Publisher: publish-to-test-pypi.yml on PoppyPop/aioiregul

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