Source code for bo4e.bo.person

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

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 ..com.adresse import Adresse
    from ..com.kontaktweg import Kontaktweg
    from ..com.zustaendigkeit import Zustaendigkeit
    from ..enum.anrede import Anrede
    from ..enum.titel import Titel


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


[docs] @postprocess_docstring class Person(Geschaeftsobjekt): """ Object containing information about a Person .. raw:: html <object data="../_static/images/bo4e/bo/Person.svg" type="image/svg+xml"></object> .. HINT:: `Person JSON Schema <https://json-schema.app/view/%23?url=https://raw.githubusercontent.com/BO4E/BO4E-Schemas/{__gh_version__}/src/bo4e_schemas/bo/Person.json>`_ """ typ: Annotated[Literal[Typ.PERSON], Field(alias="_typ")] = Typ.PERSON #: Mögliche Anrede der Person anrede: Optional["Anrede"] = None individuelle_anrede: Optional[str] = None """ Im Falle einer nicht standardisierten Anrede kann hier eine frei definierbare Anrede vorgegeben werden. Beispiel: "Vereinsgemeinschaft", "Pfarrer", "Hochwürdigster Herr Abt". """ #: Möglicher Titel der Person titel: Optional["Titel"] = None #: Vorname der Person vorname: Optional[str] = None #: Nachname (Familienname) der Person nachname: Optional[str] = None #: Kontaktwege der Person kontaktwege: Optional[list["Kontaktweg"]] = None #: Geburtsdatum der Person geburtsdatum: Optional[pydantic.AwareDatetime] = None #: Weitere Informationen zur Person kommentar: Optional[str] = None #: Liste der Abteilungen und Zuständigkeiten der Person zustaendigkeiten: Optional[list["Zustaendigkeit"]] = None #: Adresse der Person, falls diese von der Adresse des Geschäftspartners abweicht adresse: Optional["Adresse"] = None