Source code for bo4e.bo.zaehler

"""
Contains Zaehler class
and corresponding marshmallow schema for de-/serialization
"""

from decimal import Decimal

# pylint: disable=unused-argument
# pylint: disable=no-name-in-module
from typing import TYPE_CHECKING, Annotated, Literal, Optional

import pydantic
from pydantic import Field

from ..enum.typ import Typ
from ..utils import postprocess_docstring
from .geschaeftsobjekt import Geschaeftsobjekt

if TYPE_CHECKING:
    from ..bo.geraet import Geraet
    from ..com.zaehlwerk import Zaehlwerk
    from ..enum.befestigungsart import Befestigungsart
    from ..enum.messwerterfassung import Messwerterfassung
    from ..enum.registeranzahl import Registeranzahl
    from ..enum.sparte import Sparte
    from ..enum.zaehlerauspraegung import Zaehlerauspraegung
    from ..enum.zaehlergroesse import Zaehlergroesse
    from ..enum.zaehlertyp import Zaehlertyp
    from ..enum.zaehlertypspezifikation import ZaehlertypSpezifikation
    from .geschaeftspartner import Geschaeftspartner

# pylint: disable=too-many-instance-attributes, too-few-public-methods


[docs] @postprocess_docstring class Zaehler(Geschaeftsobjekt): """ Object containing information about a meter/"Zaehler". .. raw:: html <object data="../_static/images/bo4e/bo/Zaehler.svg" type="image/svg+xml"></object> .. HINT:: `Zaehler JSON Schema <https://json-schema.app/view/%23?url=https://raw.githubusercontent.com/BO4E/BO4E-Schemas/{__gh_version__}/src/bo4e_schemas/bo/Zaehler.json>`_ """ typ: Annotated[Literal[Typ.ZAEHLER], Field(alias="_typ")] = Typ.ZAEHLER zaehlernummer: Optional[str] = None #: Nummerierung des Zählers,vergeben durch den Messstellenbetreiber sparte: Optional["Sparte"] = None #: Strom oder Gas zaehlerauspraegung: Optional["Zaehlerauspraegung"] = None #: Spezifikation die Richtung des Zählers betreffend zaehlertyp: Optional["Zaehlertyp"] = None #: Typisierung des Zählers zaehlwerke: Optional[list["Zaehlwerk"]] = None registeranzahl: Optional["Registeranzahl"] = None #: Spezifikation bezüglich unterstützter Tarif zaehlerkonstante: Optional[Decimal] = None #: Zählerkonstante auf dem Zähler eichung_bis: Optional[pydantic.AwareDatetime] = None #: Bis zu diesem Datum (exklusiv) ist der Zähler geeicht. letzte_eichung: Optional[pydantic.AwareDatetime] = ( None #: Zu diesem Datum fand die letzte Eichprüfung des Zählers statt. ) zaehlerhersteller: Optional["Geschaeftspartner"] = None #: Der Hersteller des Zählers ist_fernschaltbar: Optional[bool] = None #: Fernschaltung messwerterfassung: Optional["Messwerterfassung"] = None #: Messwerterfassung des Zählers zaehlertypSpezifikation: Optional["ZaehlertypSpezifikation"] = None #: Besondere Spezifikation des Zählers befestigungsart: Optional["Befestigungsart"] = None #: Befestigungsart zaehlergroesse: Optional["Zaehlergroesse"] = None #: Größe des Zählers geraete: Optional[list["Geraet"]] = ( None #: Liste der Geräte, die zu diesem Zähler gehören, bspw. Smartmeter-Gateway )