Skip to main content

Extract and distribute Homematic CCU/OpenCCU configuration metadata (translations, easymodes, link profiles).

Project description

openccu-data

Extract and distribute Homematic CCU configuration metadata (translations, easymodes, link profiles) from OCCU / OpenCCU / RaspberryMatic.

This repository is the single source of truth for the data artifacts that are consumed by aiohomematic and aiohomematic-config. Both projects vendor the produced JSON archives at runtime.

What this provides

Extractor Source Output
openccu-extract-easymodes TCL config under config/easymodes/ openccu_data/data/easymode_extract.json.gz
openccu-extract-translations JS translation files + stringtable openccu_data/data/translation_extract.json.gz + translation_custom/
openccu-extract-profiles TCL link-profile files per receiver openccu_data/data/profiles/<RECEIVER_TYPE>.json.gz (+ _receiver_type_aliases.json)

All three read from either:

  • a local OCCU/OpenCCU/RaspberryMatic checkout (OCCU_PATH=/path/to/occu), or
  • a running CCU instance over HTTP/HTTPS (CCU_URL=https://my-ccu.local).

If both are set, the easymode/translation extractors merge results; the profile extractor prefers the running CCU and falls back to local.

Repository layout

openccu-data/
├── LICENSE                MIT (covers the code)
├── NOTICE.md              Data-artifact licensing (EQ-3/OCCU)
├── README.md              this file
├── CLAUDE.md              guide for AI assistants
├── changelog.md
├── pyproject.toml
├── openccu_data/
│   ├── const.py
│   ├── easymodes/extractor.py        easymode metadata parser
│   ├── translations/extractor.py     CCU WebUI translation parser
│   ├── profiles/extractor.py         easymode link-profile parser
│   └── data/                         committed, vendored output
│       ├── easymode_extract.json.gz
│       ├── translation_extract.json.gz
│       ├── translation_custom/*.json
│       └── profiles/*.json.gz (+ _receiver_type_aliases.json)
├── script/                           CLI wrappers
└── tests/

Installation

python -m pip install -e .[test]

No third-party runtime dependencies; only the standard library.

Usage

Console scripts

After installation, three console scripts are available on the PATH:

OCCU_PATH=/path/to/occu openccu-extract-easymodes
OCCU_PATH=/path/to/occu openccu-extract-translations
CCU_URL=https://my-ccu.local openccu-extract-profiles

Output lands in openccu_data/data/ by default. Override via OUTPUT_DIR.

Without installation

OCCU_PATH=/path/to/occu python script/extract_easymodes.py
OCCU_PATH=/path/to/occu python script/extract_translations.py
CCU_URL=https://my-ccu.local python script/extract_profiles.py

Environment variables

Variable Purpose
OCCU_PATH Path to a local OCCU/RaspberryMatic checkout
CCU_URL URL of a running CCU/OpenCCU instance (http:// or https://)
OUTPUT_DIR Override the default output directory
RECEIVERS (extract_profiles only) comma-separated list of receiver channel types

.env files at the repository root are auto-loaded (existing env vars win).

Vendoring into consumer projects

The committed artifacts in openccu_data/data/ are the source of truth. Consumers maintain their own runtime copies:

Consumer Vendored copy
aiohomematic aiohomematic/ccu_data/easymode_extract.json.gz
aiohomematic aiohomematic/ccu_data/translation_extract.json.gz
aiohomematic aiohomematic/ccu_data/translation_custom/*.json
aiohomematic-config aiohomematic_config/profiles/*.json.gz (+ _receiver_type_aliases.json)

After regenerating any artifact, copy the relevant files into the consumer repository and open a PR there as well.

Development

python -m pip install -e .[test]
pytest tests/
ruff check openccu_data/ tests/
mypy

License

  • Code: MIT.
  • Data artifacts under openccu_data/data/: derivative of OCCU/RaspberryMatic and subject to the EQ-3 license (see NOTICE.md). The curated translation_custom/ overrides are MIT.

"Homematic" and "HomematicIP" are trademarks of eQ-3 AG. This project is not affiliated with or endorsed by eQ-3 AG.

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_data-2026.5.0.tar.gz (668.3 kB view details)

Uploaded Source

Built Distribution

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

openccu_data-2026.5.0-py3-none-any.whl (682.2 kB view details)

Uploaded Python 3

File details

Details for the file openccu_data-2026.5.0.tar.gz.

File metadata

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

File hashes

Hashes for openccu_data-2026.5.0.tar.gz
Algorithm Hash digest
SHA256 8da1ab13d3b6ed65e35f68d1738ab1bec5136f93531e4d473528a0a25422a014
MD5 a191bc24e586cfd4c91d8407f5186b8c
BLAKE2b-256 e5b60fab851c99d9c1895af4dde56313e731ae1b8664dad777b0b864d28fb2ed

See more details on using hashes here.

Provenance

The following attestation bundles were made for openccu_data-2026.5.0.tar.gz:

Publisher: python-publish.yml on SukramJ/openccu-data

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_data-2026.5.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for openccu_data-2026.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d9a2ec97a9901f516ebf8ee90f49ebef49480a28704661d73eba1c6d6720b111
MD5 b49a6da396b54c9547aab1ce723baed0
BLAKE2b-256 1577d0907209bce8ff0d3e89a109b2d63c86fc254afaa58098db3215e2d37cc8

See more details on using hashes here.

Provenance

The following attestation bundles were made for openccu_data-2026.5.0-py3-none-any.whl:

Publisher: python-publish.yml on SukramJ/openccu-data

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