Skip to main content

Python Library that implements the BO4E Standard.

Project description

PyPi license code style PyPI pyversions

🇩🇪 Dies ist eine BO4E Referenz-Implementierung in Python. Gleichzeitig ist dieses Repository der Ort, um Fragen und Erweiterungen des BO4E-Standards zu diskutieren.

🇬🇧 This is a Python library that implements Business Objects for Energy BO4E.

Grundsätzliche Überlegungen

Pflichtfelder (nicht nullable Attributes)

Der BO4E Standard soll (in Zukunft, Stand 2023-10-05) keine fachlichen Pflichtfelder mehr enthalten. Die Entscheidung, was in welchen Fällen ein Pflichtfeld ist, obliegt den Anwendungen, die den Standard nutzen. Entsprechend ist auch die Validierung der Pflichtfelder nicht Teil des BO4E Standards sondern anwendungsspezifisch. Davon sind auch technische Pflichtfelder, namentlich _typ und _version nicht ausgenommen. Ob sie anzugeben sind, entscheidet die Anwendung. BO4E gibt sinnvolle Datenstrukturen vor, wie diese in der Praxis genutzt werden können und wollen wir aber nicht vorschreiben.

Verweise zwischen Objekten

Viele Objekte verweisen aufeinander und sind miteinander verknüpft. Dabei sind unsere Designentscheidungen:

  • Alle Verweise sind optional.

  • Verweise sind, wo sie naheliegend sind, im BO4E Standard vordefiniert (z.B. 1 Messlokation hat n Zähler).

  • Aber wir haben nicht jede theoretisch denkbare Verweise implementiert (z.B. allein dass User Zähler unter Angabe einer Email-Adresse suchen können, heißt nicht, dass der Zähler eine optionale Eigenschaft emailAdresse haben muss.)

  • Generell sollen Verweise zwischen zwei BOs bi-direktional sein, zwischen BOs und COMs aber nur unidirektional (z.B. soll jeder Zähler wissen zu welcher Messlokation er gehört aber eine Adresse muss nicht wissen, welchem Geschäftspartner, welcher Messlokation oder welcher Rechnung sie zugeordnet ist).

  • COMs können zwar weitere COMs beinhalten, jedoch sollte dies nicht dafür genutzt werden von einem COM eines BOs auf das COM eines anderen BOs zu verweisen. Bsp.: Die Adresse in Ansprechpartner ist identisch zur Lokationsadresse in der Marktlokation. Dann sollen beide Adressen als vollständiges COM dargestellt werden, statt nur als Verweis von einer Adresse auf die andere.

  • Oder anders formuliert: wir können aus einem BO oder einem COM auf ein anderes BO verweisen.

Dokumentation / Fragen und Anregungen zum BO4E Datenmodell

Die Dokumentation ist verfügbar unter https://bo4e.github.io/BO4E-python/. Die Doku wird erst seit Version v202401.0.3 mittels GitHub Pages gehosted. Die früheren Versionen sind auf read the docs einsehbar.

Unter /latest findet sich die Dokumentation des aktuellen Stands des main-Branches. /stable zeigt immer auf die letzte veröffentlichte Version (Release candidates ausgeschlossen). Zusätzlich ist jede Version (inklusive Release candidates) unter /v<version> auffindbar.

Die Doku bietet eine Übersicht über alle Klassen und Attribute, die im BO4E Standard definiert sind. Außerdem werden alle Beziehungen zwischen den Klassen durch Diagramme visualisiert. Die JSON-Schemas sind ebenfalls verlinkt. Alternativ können die JSON-Schemas auch direkt von GitHub heruntergeladen werden: https://github.com/bo4e/BO4E-Schemas. Seit Version v202401.1.1 gibt es zusätzlich eine Kompatibilitätsmatrix, die für jedes Objekt zeigt, zwischen welchen Versionen es einen “breaking change” gab.

Bei Fragen oder Anregungen, bitte einfach ein Issue in diesem Repo aufmachen.

Code Beiträge

Änderungsvorschläge (sowohl an das Datenmodell als auch an die Implementierung in Python) können direkt als Code in Form von Pull Requests eingereicht werden. Details dazu finden sich im Contribution Guide.

Entwicklungs-Setup

Die Entwicklungs-Abhängigkeiten sind in pyproject.toml unter [dependency-groups] (PEP 735) zentral gepflegt und über uv.lock gepinnt. uv (https://docs.astral.sh/uv/) wird als Paket-Manager verwendet, tox-uv integriert ihn in die bestehenden tox-Umgebungen.

# uv installieren (einmalig), siehe https://docs.astral.sh/uv/getting-started/installation/
curl -LsSf https://astral.sh/uv/install.sh | sh

# Repo klonen und volles Entwickler-Setup installieren
git clone https://github.com/bo4e/BO4E-python.git
cd BO4E-python
uv sync --group dev

# Einzelne tox-Umgebung ausführen (tox + tox-uv werden via uv installiert)
uv run tox -e tests
uv run tox -e linting
uv run tox -e docs

Die verfügbaren Gruppen sind: tests, coverage, type_check, linting, formatting, packaging, json_schemas, docs und dev (Sammel-Gruppe, enthält alle anderen plus pre-commit).

Nutzung als Python Library

In Python kann diese Library als Paket installiert werden:

pip install bo4e

Andere nennenswerte BO4E Implementierungen

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

bo4e-202607.0.0.tar.gz (792.3 kB view details)

Uploaded Source

Built Distribution

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

bo4e-202607.0.0-py3-none-any.whl (173.0 kB view details)

Uploaded Python 3

File details

Details for the file bo4e-202607.0.0.tar.gz.

File metadata

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

File hashes

Hashes for bo4e-202607.0.0.tar.gz
Algorithm Hash digest
SHA256 749be78c25a33a349c7b861919a4641fe815387207cdde6d2b251d972ca587a5
MD5 a4cc6a05fa0eeea06579f1b3b49dd677
BLAKE2b-256 a1fe472266934d2e3e723b60bd2e2476e61180c827b588fc82aee44a6456c1a0

See more details on using hashes here.

Provenance

The following attestation bundles were made for bo4e-202607.0.0.tar.gz:

Publisher: python-publish.yml on bo4e/BO4E-python

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

File details

Details for the file bo4e-202607.0.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for bo4e-202607.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9b7a4edf91df78fb9a70461ac9f4b5960161ffd7326b4459e2ae0eaee476f41f
MD5 dce45d78313fbe4eb98b03d399c93529
BLAKE2b-256 12c656976460a7cb32d766157f1392ff1a6131e931eb4485348107a3cdad28a9

See more details on using hashes here.

Provenance

The following attestation bundles were made for bo4e-202607.0.0-py3-none-any.whl:

Publisher: python-publish.yml on bo4e/BO4E-python

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