Source code for bo4e.bo.geschaeftspartner

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

# pylint: disable=too-many-instance-attributes, too-few-public-methods, disable=duplicate-code
from typing import TYPE_CHECKING, Annotated, Literal, Optional

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 ..enum.anrede import Anrede
    from ..enum.geschaeftspartnerrolle import Geschaeftspartnerrolle
    from ..enum.organisationstyp import Organisationstyp
    from ..enum.titel import Titel
    from .person import Person


[docs] @postprocess_docstring class Geschaeftspartner(Geschaeftsobjekt): """ Mit diesem Objekt können Geschäftspartner übertragen werden. Sowohl Unternehmen, als auch Privatpersonen können Geschäftspartner sein. Hinweis: "Marktteilnehmer" haben ein eigenes BO, welches sich von diesem BO ableitet. Hier sollte daher keine Zuordnung zu Marktrollen erfolgen. .. raw:: html <object data="../_static/images/bo4e/bo/Geschaeftspartner.svg" type="image/svg+xml"></object> .. HINT:: `Geschaeftspartner JSON Schema <https://json-schema.app/view/%23?url=https://raw.githubusercontent.com/BO4E/BO4E-Schemas/{__gh_version__}/src/bo4e_schemas/bo/Geschaeftspartner.json>`_ """ typ: Annotated[Literal[Typ.GESCHAEFTSPARTNER], Field(alias="_typ")] = Typ.GESCHAEFTSPARTNER anrede: Optional["Anrede"] = None """Mögliche Anrede der Person""" 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". """ titel: Optional["Titel"] = None """Möglicher Titel der Person""" vorname: Optional[str] = None """Vorname der Person""" nachname: Optional[str] = None """Nachname (Familienname) der Person""" ansprechpartner: Optional[list["Person"]] = None organisationstyp: Optional["Organisationstyp"] = None """ Kennzeichnung ob es sich um ein Gewerbe/Unternehmen, eine Privatperson oder eine andere Art von Organisation handelt. """ organisationsname: Optional[str] = None """ Name der Firma, wenn Gewerbe oder andere Organisation. """ kontaktwege: Optional[list["Kontaktweg"]] = None """Kontaktwege des Geschäftspartners""" geschaeftspartnerrollen: Optional[list["Geschaeftspartnerrolle"]] = None """Rollen, die die Geschäftspartner inne haben (z.B. Interessent, Kunde)""" handelsregisternummer: Optional[str] = None """Handelsregisternummer des Geschäftspartners""" amtsgericht: Optional[str] = None """Amtsgericht bzw Handelsregistergericht, das die Handelsregisternummer herausgegeben hat""" umsatzsteuer_id: Optional[str] = None """ Die Steuer-ID des Geschäftspartners; Beispiel: "DE 813281825" """ glaeubiger_id: Optional[str] = None """ Die Gläubiger-ID welche im Zahlungsverkehr verwendet wird; Z.B. "DE 47116789" """ website: Optional[str] = None """Internetseite des Marktpartners""" adresse: Optional["Adresse"] = None """Adresse des Geschäftspartners"""
# Todo: Add optional connection to marktteilnehmer as discussed in workshop # not clear what is the best solution here - circular import marktteilnehmer? # discussed in workshop on Feb 6 2024: yes we need the bidirectional option, let's figure out a solution somehow.