Skip to main content

Async Python REST + WebSocket client for the openccu-loom daemon

Project description

openccu-loom-client

Status: WIP / Alpha — transport, event bus, domain store, the full daemon REST surface (HA-relevant + admin/ops), and the aiohomematic compat namespace are in place (see "Status of the wire contract" below).

Async Python REST + WebSocket client for the openccu-loom daemon.

Designed as the drop-in replacement for aiohomematic in the homematicip_local Home-Assistant custom component, once the daemon has fully replaced direct XML-RPC/JSON-RPC contact with the CCU.

Architecture

Wire types come from the sister package openccu-loom-types (Pydantic models + enum catalogue, generated from the daemon's assets/openapi.yaml and assets/schemas/enums.json). This package adds:

  • transport/http.py — async REST client (aiohttp), RFC 9457 problem+json parsing, retry/backoff.
  • transport/ws.py — WebSocket loop with subscribe/unsubscribe, heartbeat, resume-after-reconnect via seq/since cursor per ADR-0022.
  • client.pyLoomClient facade: snapshot bootstrap, event bus, in-memory store, and the operation modules (devices, datapoints, custom_data_points, hub, system, schedules, links).
  • compat/aiohomematic/ — namespace shim so existing homematicip_local imports keep working during the cutover. This includes a LoomCentralAdapter that presents aiohomematic's CentralUnit + coordinator surface, and a categorised data-point model (generic Dp*, hub SysvarDp*/ProgramDp*, custom CustomDp* for light/cover/climate/lock/siren/valve/switch) with unique_id/category/registered bookkeeping. A refresh bridge fans the daemon's value/sysvar/custom events into the single DataPointStateChangedEvent (keyed by unique_id) HA entities subscribe to.

Status of the wire contract

The daemon's external-client contract is tracked in docs/external-clients/asks.md in the daemon repo. As of openccu-loom-types==0.1.2, all push-event payloads needed by Home Assistant (DataPointValueChanged, CustomDataPointStateChanged, CentralStateChanged, SystemStatusChanged, SysvarChanged, ProgramExecuted, InstallModeChanged, DeviceCreated, DeviceRemoved) ship typed and are bound in the event registry.

The full daemon REST surface is wrapped — typed end-to-end against openccu-loom-types:

  • HA-relevant: devices/channels/data-points, paramsets, batch reads, custom data points, programs and sysvars (incl. create / metadata-patch / lifecycle), alarm/service messages (incl. ack), install-mode, interfaces, rooms/functions, firmware updates, calculated data points, climate schedules / week-profiles, and direct/central links.
  • Admin / ops: auth + API-token provisioning (client.auth), users (client.users), centrals (client.centrals), config management (client.config_admin), diagnostics / log-levels / capture / RPC-recording / metrics / values-cache / MQTT-reload / audit (client.diagnostics), backups (client.backup), edit-lock sessions (client.sessions), the Matter bridge (client.matter), and parameter visibility (client.visibility).

The schedule, link and calculated-data-point schemas were added to the daemon's openapi.yaml (components.schemas) and regenerated into openccu-loom-types 0.1.3, so they are typed rather than free-form dicts.

Two gaps remain and are daemon-side, not closeable from the client alone:

  • OptimisticRollback — not yet broadcast by the daemon; synthesized client-side from REST set_value failures in the meantime.
  • Device trigger / keypress events — central-links forwarding can be enabled via REST, but the daemon does not yet emit the corresponding click broadcast (reserved topic namespace). The DeviceTriggerEvent compat class is ready to bind once it ships.

Development

python3.11 -m venv venv
source venv/bin/activate
pip install -e '.[dev]'
pytest

License

MIT. See LICENSE.

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

openccu_loom_client-2026.6.4.tar.gz (117.6 kB view details)

Uploaded Source

Built Distribution

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

openccu_loom_client-2026.6.4-py3-none-any.whl (146.8 kB view details)

Uploaded Python 3

File details

Details for the file openccu_loom_client-2026.6.4.tar.gz.

File metadata

  • Download URL: openccu_loom_client-2026.6.4.tar.gz
  • Upload date:
  • Size: 117.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for openccu_loom_client-2026.6.4.tar.gz
Algorithm Hash digest
SHA256 05be68c0134c359d1cf667746c1941e5715e4a6785a8c6e89fd44870cf9207dd
MD5 284fc24641ddd9db19ecf78de37cf2c9
BLAKE2b-256 9e2ee35acdbc78b78133b48405251d6b103c8f3744c53233e196e424c72f2887

See more details on using hashes here.

Provenance

The following attestation bundles were made for openccu_loom_client-2026.6.4.tar.gz:

Publisher: python-publish.yml on SukramJ/openccu-loom-client

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

File details

Details for the file openccu_loom_client-2026.6.4-py3-none-any.whl.

File metadata

File hashes

Hashes for openccu_loom_client-2026.6.4-py3-none-any.whl
Algorithm Hash digest
SHA256 ca4f331bd1b541caf9625161b4cb175a62a4ef94bf365c25999c42dafbd0afca
MD5 d12b10749b370ee5dd1c74f52e7f7a40
BLAKE2b-256 27511300d81f6068a524b3ed078c7cd7af2521fb29b5396cedd9b1e8260d7207

See more details on using hashes here.

Provenance

The following attestation bundles were made for openccu_loom_client-2026.6.4-py3-none-any.whl:

Publisher: python-publish.yml on SukramJ/openccu-loom-client

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