Skip to main content

Homematic interface for Home Assistant running on Python 3.

Project description

releasebadge License GitHub Sponsors

AIO Homematic

A lightweight Python 3 library that powers Home Assistant integrations for controlling and monitoring Homematic and HomematicIP devices. Some third‑party devices/gateways (e.g., Bosch, Intertechno) may be supported as well.

This project is the modern successor to pyhomematic, focusing on automatic entity creation, fewer manual device definitions, and faster startups.

How it works

Unlike pyhomematic, which required manual device mappings, aiohomematic automatically creates entities for each relevant parameter on every device channel (unless blacklisted). To achieve this it:

  • Fetches and caches device paramsets (VALUES) for fast successive startups.
  • Provides hooks for custom entity classes where complex behavior is needed (e.g., thermostats, lights, covers, climate, locks, sirens).
  • Includes helpers for robust operation, such as automatic reconnection after CCU restarts.

Key features

  • Automatic entity discovery from device/channel parameters.
  • Extensible via custom entity classes for complex devices.
  • Caching of paramsets to speed up restarts.
  • Designed to integrate with Home Assistant.

Quickstart for Home Assistant

Use the Home Assistant custom integration "Homematic(IP) Local", which is powered by aiohomematic.

New to Homematic? See the Glossary for definitions of terms like Backend, Interface, Device, Channel, and the difference between Integration and Add-on.

  1. Prerequisites
    • Use latest version of Home Assistant.
    • A CCU3, OpenCCU, or Homegear instance reachable from Home Assistant.
    • For HomematicIP devices, ensure CCU firmware meets the minimum versions listed below.
  2. Install the integration
  3. Configure via Home Assistant UI
    • In Home Assistant: Settings → Devices & Services → Add Integration → search for "Homematic(IP) Local".
    • Enter the CCU/Homegear host (IP or hostname). If you use HTTPS on the CCU, enable TLS and don't use verify if self‑signed.
    • Always enter credentials.
    • Choose which interfaces to enable (HM, HmIP, Virtual). Default ports are typically 2001 (HM), 2010 (HmIP), 9292 (Virtual).
  4. Network callbacks
    • The integration needs to receive XML‑RPC callbacks from the CCU. Make sure Home Assistant is reachable from the CCU (no NAT/firewall blocking). Callbacks are only required for special network setups.
  5. Verify
    • After setup, devices should appear under Devices & Services → Homematic(IP) Local. Discovery may take a few seconds after the first connection while paramsets are fetched and cached for faster restarts.

If you need to use aiohomematic directly in Python, see the Public API and example below.

Requirements

Due to a bug in earlier CCU2/CCU3 firmware, aiohomematic requires at least the following versions when used with HomematicIP devices:

  • CCU2: 2.53.27
  • CCU3: 3.53.26

See details here: https://github.com/OpenCCU/OpenCCU/issues/843. Other CCU‑like platforms using the buggy HmIPServer version are not supported.

Public API and imports

  • The public API of aiohomematic is explicitly defined via all in each module and subpackage.
  • Backwards‑compatible imports should target these modules:
    • aiohomematic.central: CentralUnit, CentralConfig and related schemas
    • aiohomematic.central.event: display received events from the backend
    • aiohomematic.client: Client, InterfaceConfig, create_client, get_client
    • aiohomematic.model: device/data point abstractions (see subpackages for details)
    • aiohomematic.exceptions: library exception types intended for consumers
    • aiohomematic.const: constants and enums (stable subset; see module all)
    • aiohomematic.performance: display some performance metrics (enabled when DEBUG is enabled)
  • The top‑level package only exposes version to avoid import cycles and keep startup lean. Prefer importing from the specific submodules listed above.

Example:

from aiohomematic.central import CentralConfig
from aiohomematic import client as hmcl

cfg = CentralConfig(
    central_id="ccu-main",
    host="ccu.local",
    username="admin",
    password="secret",
    default_callback_port=43439,
    interface_configs={hmcl.InterfaceConfig(interface=hmcl.Interface.HMIP, port=2010, enabled=True)},
)
central = cfg.create_central()

Useful links

  • Changelog: see for release history and latest changes.
  • Definition of calculated data points: see
  • Naming: see for how device, channel and data point names are created.
  • Homematic(IP) Local integration: https://github.com/sukramj/homematicip_local
  • Input select helper: see for an overview of how to use the input select helper.
  • Troubleshooting with Home Assistant: see for common issues and how to debug them.
  • Unignore mechanism: see for how to unignore devices that are ignored by default.

Useful developer links

  • Architecture overview: see for an overview of the architecture of the library.
  • Data flow: see for an overview of how data flows through the library.
  • Extending the model: see for adding custom device profiles and calculated data points.
  • Home Assistant lifecycle (discovery, updates, teardown): see for details on how the integration works and how to debug issues.
  • RSSI fix: see for how RSSI values are fixed for Home Assistant.
  • Sequence diagrams: see for a sequence diagram of how the library works.

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

aiohomematic-2025.12.36.tar.gz (373.5 kB view details)

Uploaded Source

Built Distribution

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

aiohomematic-2025.12.36-py3-none-any.whl (436.5 kB view details)

Uploaded Python 3

File details

Details for the file aiohomematic-2025.12.36.tar.gz.

File metadata

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

File hashes

Hashes for aiohomematic-2025.12.36.tar.gz
Algorithm Hash digest
SHA256 3d7620674d3c0785ab609d0adc7b5e40b792431db23e0f74f5680c560d94a489
MD5 a8e8216ca0aaa181da3aff04fb99aee4
BLAKE2b-256 985313f8798cf733f79380075811051945ebefb98b3ac30d515219b13a7ba677

See more details on using hashes here.

Provenance

The following attestation bundles were made for aiohomematic-2025.12.36.tar.gz:

Publisher: python-publish.yml on SukramJ/aiohomematic

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

File details

Details for the file aiohomematic-2025.12.36-py3-none-any.whl.

File metadata

File hashes

Hashes for aiohomematic-2025.12.36-py3-none-any.whl
Algorithm Hash digest
SHA256 7585d70e821794dd185374dd78b122fccdf690cab5b94ecc3fc79ecc644f38fc
MD5 caf599c72a872704dc628a3357163f99
BLAKE2b-256 2d781cef026a4a40361c1d62d6c512268ca48839b9b34a6d4737914dbab1e9f6

See more details on using hashes here.

Provenance

The following attestation bundles were made for aiohomematic-2025.12.36-py3-none-any.whl:

Publisher: python-publish.yml on SukramJ/aiohomematic

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