Tax Filing Service

<back to all web services

SubmitUmsatzsteuererklaerung2022

SyncUmsatzsteuerJahressteuererklärung2022

A synchronous service to submit an annual VAT return for 2022.

Requires Authentication
The following routes are available for this service:
POST/SubmitUmsatzsteuererklaerung2022A synchronous service to submit an annual VAT return for 2022
import datetime
import decimal
from marshmallow.fields import *
from servicestack import *
from typing import *
from dataclasses import dataclass, field
from dataclasses_json import dataclass_json, LetterCase, Undefined, config
from enum import Enum, IntEnum
Object = TypeVar('Object')


# @Api(Description="Basisklasse für einen benutzerdefinierten Datentyp")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class CustomTypBase(ICustomTyp):
    """
    Basisklasse für einen benutzerdefinierten Datentyp
    """

    # @ApiMember(Description="Identifizierung der Zeile / Typ im Fremdprogramm.", Name="Alias")
    alias: Optional[str] = None
    """
    Identifizierung der Zeile / Typ im Fremdprogramm.
    """


# @Api(Description="Boolescher Datentyp, welcher als '1' (Ja) oder '' (Nein) im Jahressteuererklärung angeschrieben wird.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Bool1Typ(CustomTypBase):
    """
    Boolescher Datentyp, welcher als '1' (Ja) oder '' (Nein) im Jahressteuererklärung angeschrieben wird.
    """

    # @ApiMember(Description="Wenn der Wert true ist, '1' wird im Jahressteuererklärung angeschrieben; ansonsten ein Leerstring.", IsRequired=true, Name="Wert")
    wert: bool = False
    """
    Wenn der Wert true ist, '1' wird im Jahressteuererklärung angeschrieben; ansonsten ein Leerstring.
    """


# @Api(Description="Berichtigte Erklärung")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class BerErkl2022:
    """
    Berichtigte Erklärung
    """

    # @ApiMember(Description="Berichtigte Steuererklärung? Falls ja, bitte eine 'true' eintragen", Name="E3000601")
    e3000601: Optional[Bool1Typ] = None
    """
    Berichtigte Steuererklärung? Falls ja, bitte eine 'true' eintragen
    """


# @Api(Description="Zeichenkettenfeld.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class StringTyp(CustomTypBase):
    """
    Zeichenkettenfeld.
    """

    # @ApiMember(Description="Der Wert des Datentyps. \n 1 bis 999 Zeichen, alphanumerisch", IsRequired=true, Name="Wert")
    wert: Optional[str] = None
    """
    Der Wert des Datentyps.  1 bis 999 Zeichen, alphanumerisch
    """


# @Api(Description="Adresse oder Postfach eines Unternehmens")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class UnternehmenAdr2022:
    """
    Adresse oder Postfach eines Unternehmens
    """

    # @ApiMember(Description="Straße", IsRequired=true, Name="E3001101")
    # @Validate(Validator="NotNull")
    e3001101: Optional[StringTyp] = None
    """
    Straße
    """


    # @ApiMember(Description="Hausnummer", IsRequired=true, Name="E3001203")
    # @Validate(Validator="NotNull")
    e3001203: Optional[StringTyp] = None
    """
    Hausnummer
    """


    # @ApiMember(Description="Hausnummerzusatz", Name="E3001204")
    e3001204: Optional[StringTyp] = None
    """
    Hausnummerzusatz
    """


    # @ApiMember(Description="Adressergänzung", Name="E3001205")
    e3001205: Optional[StringTyp] = None
    """
    Adressergänzung
    """


    # @ApiMember(Description="Postleitzahl, Ort", Name="E3001201")
    e3001201: Optional[StringTyp] = None
    """
    Postleitzahl, Ort
    """


    # @ApiMember(Description="Postleitzahl zu Postfach", Name="E3001403")
    e3001403: Optional[StringTyp] = None
    """
    Postleitzahl zu Postfach
    """


    # @ApiMember(Description="Postfach", Name="E3001404")
    e3001404: Optional[StringTyp] = None
    """
    Postfach
    """


# @Api(Description="Kontakt eines Unternehmens")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class UnternehmenKontakt2022:
    """
    Kontakt eines Unternehmens
    """

    # @ApiMember(Description="Telefon", Name="E3001202")
    e3001202: Optional[StringTyp] = None
    """
    Telefon
    """


    # @ApiMember(Description="E-Mail Adresse", Name="E3001301")
    e3001301: Optional[StringTyp] = None
    """
    E-Mail Adresse
    """


# @Api(Description="Angaben zum Unternehmen")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Unternehmen2022:
    """
    Angaben zum Unternehmen
    """

    # @ApiMember(Description="Name des Unternehmers", IsRequired=true, Name="E3000901")
    e3000901: Optional[StringTyp] = None
    """
    Name des Unternehmers
    """


    # @ApiMember(Description="gegebenenfalls abweichender Firmenname", Name="E3000902")
    e3000902: Optional[StringTyp] = None
    """
    gegebenenfalls abweichender Firmenname
    """


    # @ApiMember(Description="Art des Unternehmens", Name="E3001001")
    e3001001: Optional[StringTyp] = None
    """
    Art des Unternehmens
    """


    # @ApiMember(Description="Adresse oder Postfach", Name="Adr")
    adr: Optional[UnternehmenAdr2022] = None
    """
    Adresse oder Postfach
    """


    # @ApiMember(Description="Kontakt", Name="Kontakt")
    kontakt: Optional[UnternehmenKontakt2022] = None
    """
    Kontakt
    """


# @Api(Description="Im Ausland ansässiger Unternehmer")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class ImAuslAnsUnt2022:
    """
    Im Ausland ansässiger Unternehmer
    """

    # @ApiMember(Description="Im Ausland ansässiger Unternehmer (falls ja, bitte eine 1 eintragen? Bitte tätigen Sie in diesem Fall auch Angaben auf der Anlage UN.", Name="E3001402")
    e3001402: Optional[Bool1Typ] = None
    """
    Im Ausland ansässiger Unternehmer (falls ja, bitte eine 1 eintragen? Bitte tätigen Sie in diesem Fall auch Angaben auf der Anlage UN.
    """


# @Api(Description="Fiskalvertreter")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Fiskalvertr2022:
    """
    Fiskalvertreter
    """

    # @ApiMember(Description="Fiskalvertreter (falls ja, bitte eine 1 eintragen). Bitte tätigen Sie in diesem Fall auch Angaben auf der Anlage FV.", Name="E3001801")
    e3001801: Optional[Bool1Typ] = None
    """
    Fiskalvertreter (falls ja, bitte eine 1 eintragen). Bitte tätigen Sie in diesem Fall auch Angaben auf der Anlage FV.
    """


# @Api(Description="Stellt ein Datumbereich dar (TT.MM-TT.MM) dar")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class ErklaerungZeitraum:
    """
    Stellt ein Datumbereich dar (TT.MM-TT.MM) dar
    """

    # @ApiMember(Description="Der Anfang des Datumbreiches.")
    start: datetime.datetime = datetime.datetime(1, 1, 1)
    """
    Der Anfang des Datumbreiches.
    """


    # @ApiMember(Description="Das Ende des Datumbereiches.")
    ende: datetime.datetime = datetime.datetime(1, 1, 1)
    """
    Das Ende des Datumbereiches.
    """


# @Api(Description="Datum-Uhrzeit-Typ. Format: TT.MM - TT. MM")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class ZeitraumTyp(CustomTypBase):
    """
    Datum-Uhrzeit-Typ. Format: TT.MM - TT. MM
    """

    # @ApiMember(Description="Wert des Datentyps.", IsRequired=true, Name="Wert")
    wert: Optional[ErklaerungZeitraum] = None
    """
    Wert des Datentyps.
    """


# @Api(Description="Dauer der Unternehmereigenschaft")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class DauerUntEig2022:
    """
    Dauer der Unternehmereigenschaft
    """

    # @ApiMember(Description="1. Zeitraum", Name="E3001401")
    e3001401: Optional[ZeitraumTyp] = None
    """
    1. Zeitraum
    """


    # @ApiMember(Description="2. Zeitraum", Name="E3001501")
    e3001501: Optional[ZeitraumTyp] = None
    """
    2. Zeitraum
    """


# @Flags()
class Entgeltart(IntEnum):
    """
    Art der Entgelte
    """

    VEREINBARTE_ENTGELTE = 1
    VEREINNAHMTE_ENTGELTE = 16


# @Api(Description="Datentyp, welches die Art der Entgeltart darstellt.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class EntgeltartTyp(CustomTypBase):
    """
    Datentyp, welches die Art der Entgeltart darstellt.
    """

    # @ApiMember(Description="Wert des Datentyps.", IsRequired=true, Name="Wert")
    wert: Optional[Entgeltart] = None
    """
    Wert des Datentyps.
    """


# @Api(Description="Besteuerung der Entgelte")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class BestArt2022:
    """
    Besteuerung der Entgelte
    """

    # @ApiMember(Description="Die Steuer wurde berechnet nach", IsRequired=true, Name="E3002203")
    e3002203: Optional[EntgeltartTyp] = None
    """
    Die Steuer wurde berechnet nach
    """


# @Api(Description="Verrechnung / Abtretung")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Verrech2022:
    """
    Verrechnung / Abtretung
    """

    # @ApiMember(Description="Verrechnung des Erstattungsbetrages erwünscht / Erstattungsbetrag ist abgetreten?", Name="E3001701")
    e3001701: Optional[Bool1Typ] = None
    """
    Verrechnung des Erstattungsbetrages erwünscht / Erstattungsbetrag ist abgetreten?
    """


# @Api(Description="Ergänzende Angaben zur Steuererklärung")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class ErgAngErkl2022:
    """
    Ergänzende Angaben zur Steuererklärung
    """

    # @ApiMember(Description="Über die Angaben in der Steuererklärung hinaus sind weitere oder abweichende Angaben oder Sachverhalte zu berücksichtigen?", Name="E3002201")
    e3002201: Optional[Bool1Typ] = None
    """
    Über die Angaben in der Steuererklärung hinaus sind weitere oder abweichende Angaben oder Sachverhalte zu berücksichtigen?
    """


    # @ApiMember(Description="Ergänzende Angaben zur Steuererklärung", Name="E3002202")
    e3002202: Optional[StringTyp] = None
    """
    Ergänzende Angaben zur Steuererklärung
    """


# @Api(Description="Allgemeine Angaben")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Allg2022:
    """
    Allgemeine Angaben
    """

    # @ApiMember(Description="Angaben zum Unternehmen", IsRequired=true, Name="Unternehmen")
    # @Validate(Validator="NotNull")
    unternehmen: Optional[Unternehmen2022] = None
    """
    Angaben zum Unternehmen
    """


    # @ApiMember(Description="Im Ausland ansässiger Unternehmer?", Name="ImAuslAnsUnt")
    im_ausl_ans_unt: Optional[ImAuslAnsUnt2022] = None
    """
    Im Ausland ansässiger Unternehmer?
    """


    # @ApiMember(Description="Fiskalvertreter?", Name="Fiskalvetr")
    fiskalvetr: Optional[Fiskalvertr2022] = None
    """
    Fiskalvertreter?
    """


    # @ApiMember(Description="Dauer der Unternehmereigenschaft (falls nicht vom 1. Januar bis zum 31. Dezember 2022)", Name="DauerUntEig")
    dauer_unt_eig: Optional[DauerUntEig2022] = None
    """
    Dauer der Unternehmereigenschaft (falls nicht vom 1. Januar bis zum 31. Dezember 2022)
    """


    # @ApiMember(Description="Besteuerungen der Entgelte", Name="BestArt")
    best_art: Optional[BestArt2022] = None
    """
    Besteuerungen der Entgelte
    """


    # @ApiMember(Description="Verrechnungen / Abtretungen", Name="Verrech")
    verrech: Optional[Verrech2022] = None
    """
    Verrechnungen / Abtretungen
    """


    # @ApiMember(Description="Ergänzende Angaben zur Steuererklärung", Name="ErgAngErkl")
    erg_ang_erkl: Optional[ErgAngErkl2022] = None
    """
    Ergänzende Angaben zur Steuererklärung
    """


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Kanzlei2022:
    # @ApiMember(Description="Bearbeiterkennzeichen", Name="E3002509")
    e3002509: Optional[StringTyp] = None
    """
    Bearbeiterkennzeichen
    """


    # @ApiMember(Description="Mandantennummer", Name="E3002506")
    e3002506: Optional[StringTyp] = None
    """
    Mandantennummer
    """


    # @ApiMember(Description="(Feld? wird nicht gedruckt)Mandantennummer für Bescheiddatenabholung", Name="E3002507")
    e3002507: Optional[StringTyp] = None
    """
    (Feld? wird nicht gedruckt)Mandantennummer für Bescheiddatenabholung
    """


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Bearb2022:
    # @ApiMember(Description="Name", Name="E3002501")
    e3002501: Optional[StringTyp] = None
    """
    Name
    """


    # @ApiMember(Description="Vorname", Name="E3002502")
    e3002502: Optional[StringTyp] = None
    """
    Vorname
    """


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class MitwirkAdr2022:
    # @ApiMember(Description="Straße, Hausnummer", Name="E3002503")
    e3002503: Optional[StringTyp] = None
    """
    Straße, Hausnummer
    """


    # @ApiMember(Description="Postleitzahl, Wohnort", Name="E3002504")
    e3002504: Optional[StringTyp] = None
    """
    Postleitzahl, Wohnort
    """


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class MitwirkKontakt2022:
    # @ApiMember(Description="Telefon", Name="E3002505")
    e3002505: Optional[StringTyp] = None
    """
    Telefon
    """


    # @ApiMember(Description="zusätzliche Angaben", Name="E3002508")
    e3002508: Optional[StringTyp] = None
    """
    zusätzliche Angaben
    """


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class MitwirkErkl2022:
    # @ApiMember(Description="Die Steuererklärung wurde unter Mitwirkung eines Angehörigen der steuerberatenden Berufe im Sinne der §§ 3 und 4 des Steuerberatungsgesetzes erstellt", Name="E3002602")
    e3002602: Optional[Bool1Typ] = None
    """
    Die Steuererklärung wurde unter Mitwirkung eines Angehörigen der steuerberatenden Berufe im Sinne der §§ 3 und 4 des Steuerberatungsgesetzes erstellt
    """


# @Api(Description="Angaben zum Mitwirkender, der bei der Anfertigung dieser Steuererklärung einschließlich der Anlagen mitgewirkt hat.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Mitwirk2022:
    """
    Angaben zum Mitwirkender, der bei der Anfertigung dieser Steuererklärung einschließlich der Anlagen mitgewirkt hat.
    """

    # @ApiMember(Description="Angaben zu den Kanzleien", Name="Kanzlei")
    kanzlei: Optional[Kanzlei2022] = None
    """
    Angaben zu den Kanzleien
    """


    # @ApiMember(Description="Angaben zu den Bearbeiter", Name="Bearb")
    bearb: Optional[Bearb2022] = None
    """
    Angaben zu den Bearbeiter
    """


    # @ApiMember(Description="Adressen der Mitwirkende", Name="Adr")
    adr: Optional[MitwirkAdr2022] = None
    """
    Adressen der Mitwirkende
    """


    # @ApiMember(Description="Kontakte der Mitwirkende", Name="Kontakt")
    kontakt: Optional[MitwirkKontakt2022] = None
    """
    Kontakte der Mitwirkende
    """


    # @ApiMember(Description="Mitwirkungen bei der Steuererklärung", Name="MitwirkErkl")
    mitwirk_erkl: Optional[MitwirkErkl2022] = None
    """
    Mitwirkungen bei der Steuererklärung
    """


# @Api(Description="Specifies an amount of money without cents with limits and a specialized string representation")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class GeldBetragOhneCent:
    """
    Specifies an amount of money without cents with limits and a specialized string representation
    """

    # @ApiMember(Description="The intrinsic currency value.")
    wert: int = 0
    """
    The intrinsic currency value.
    """


# @Api(Description="Represents an amount of money without cents whose value has a maximum length of 5 digits.That is, 1 to 5 digits. Minus sign allowed")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class GeldBetragOhneCent5DE(GeldBetragOhneCent):
    """
    Represents an amount of money without cents whose value has a maximum length of 5 digits.That is, 1 to 5 digits. Minus sign allowed
    """

    pass


# @Api(Description="Geldbetrag ohne Cent mit 6 Stellen. Mindestens eine Ziffer und maximal 5 Ziffern. Minusvorzeichen erlaubt.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class GeldBetragOhneCent5DETyp(CustomTypBase):
    """
    Geldbetrag ohne Cent mit 6 Stellen. Mindestens eine Ziffer und maximal 5 Ziffern. Minusvorzeichen erlaubt.
    """

    # @ApiMember(Description="Wert des Datentyps. Mindestens eine Ziffer und maximal 5 Ziffern. Minusvorzeichen erlaubt.", IsRequired=true)
    betrag: Optional[GeldBetragOhneCent5DE] = None
    """
    Wert des Datentyps. Mindestens eine Ziffer und maximal 5 Ziffern. Minusvorzeichen erlaubt.
    """


# @Api(Description="Specifies an amount of money without cents with limits and a specialized string representation")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class GrossGeldBetragOhneCent:
    """
    Specifies an amount of money without cents with limits and a specialized string representation
    """

    # @ApiMember(Description="The intrinsic currency value.")
    wert: int = 0
    """
    The intrinsic currency value.
    """


# @Api(Description="Represents an amount of money without cents whose value has a maximum length of 12 digits.That is, 1 to 12 digits. Minus sign allowed")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class GeldBetragOhneCent12DE(GrossGeldBetragOhneCent):
    """
    Represents an amount of money without cents whose value has a maximum length of 12 digits.That is, 1 to 12 digits. Minus sign allowed
    """

    pass


# @Api(Description="Geldbetrag ohne Cent mit 13 Stellen. Mindestens eine Ziffer und maximal 12 Ziffern. Minusvorzeichen erlaubt.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class GeldBetragOhneCent12DETyp(CustomTypBase):
    """
    Geldbetrag ohne Cent mit 13 Stellen. Mindestens eine Ziffer und maximal 12 Ziffern. Minusvorzeichen erlaubt.
    """

    # @ApiMember(Description="Wert des Datentyps. Mindestens eine Ziffer und maximal 12 Ziffern. Minusvorzeichen erlaubt.", IsRequired=true)
    betrag: Optional[GeldBetragOhneCent12DE] = None
    """
    Wert des Datentyps. Mindestens eine Ziffer und maximal 12 Ziffern. Minusvorzeichen erlaubt.
    """


# @Api(Description="Angaben der Besteuerung von Kleinunternehmer der Umsatzsteuererklärung.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Kleinuntern2022:
    """
    Angaben der Besteuerung von Kleinunternehmer der Umsatzsteuererklärung.
    """

    # @ApiMember(Description="Umsatz im Kalenderjahr 2021 (Berechnung nach § 19 Absatz 1 und 3 UStG)", Name="E3002301")
    e3002301: Optional[GeldBetragOhneCent5DETyp] = None
    """
    Umsatz im Kalenderjahr 2021 (Berechnung nach § 19 Absatz 1 und 3 UStG)
    """


    # @ApiMember(Description="Umsatz im Kalenderjahr 2022 (Berechnung nach § 19 Absatz 1 und 3 UStG)", Name="E3002401")
    e3002401: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Umsatz im Kalenderjahr 2022 (Berechnung nach § 19 Absatz 1 und 3 UStG)
    """


# @Api(Description="Specifies an amount of money with cents with limits and a specialized string representation")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class GeldBetragMitCent:
    """
    Specifies an amount of money with cents with limits and a specialized string representation
    """

    # @ApiMember(Description="The intrinsic currency value.")
    wert: float = 0.0
    """
    The intrinsic currency value.
    """


# @Api(Description="Represents an amount of money with cents whose value has a maximum length of 14 digits. That is, 1 to 12 digits before the decimal separator and 2 digits after the decimal separator. Minus sign allowed.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class GeldBetragMitCent12DE(GeldBetragMitCent):
    """
    Represents an amount of money with cents whose value has a maximum length of 14 digits. That is, 1 to 12 digits before the decimal separator and 2 digits after the decimal separator. Minus sign allowed.
    """

    pass


# @Api(Description="Geldbetrag mit Cent mit 12 Vorkommastellen. Mindestens eine Ziffer und maximal 12 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen erlaubt. ',' als Dezimaltrennzeichen.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class GeldBetragMitCent12DETyp(CustomTypBase):
    """
    Geldbetrag mit Cent mit 12 Vorkommastellen. Mindestens eine Ziffer und maximal 12 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen erlaubt. ',' als Dezimaltrennzeichen.
    """

    # @ApiMember(Description="Wert des Datentyps. Mindestens eine Ziffer und maximal 12 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen erlaubt.", IsRequired=true, Name="Betrag")
    betrag: Optional[GeldBetragMitCent12DE] = None
    """
    Wert des Datentyps. Mindestens eine Ziffer und maximal 12 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen erlaubt.
    """


# @Api(Description="Umsätze zum allgemeinen Steuersatz")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class UmsAllg2022:
    """
    Umsätze zum allgemeinen Steuersatz
    """

    # @ApiMember(Description="Lieferungen und sonstige Leistungen zu 19 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3003303")
    e3003303: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Lieferungen und sonstige Leistungen zu 19 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="Lieferungen und sonstige Leistungen zu 19 Prozent (Steuer)", Name="E3003304")
    e3003304: Optional[GeldBetragMitCent12DETyp] = None
    """
    Lieferungen und sonstige Leistungen zu 19 Prozent (Steuer)
    """


    # @ApiMember(Description="Unentgeltliche Wertabgaben - Lieferungen nach § 3 Absatz 1b UStG zu 19 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3003405")
    e3003405: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Unentgeltliche Wertabgaben - Lieferungen nach § 3 Absatz 1b UStG zu 19 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="Unentgeltliche Wertabgaben - Lieferungen nach § 3 Absatz 1b UStG zu 19 Prozent (Steuer)", Name="E3003406")
    e3003406: Optional[GeldBetragMitCent12DETyp] = None
    """
    Unentgeltliche Wertabgaben - Lieferungen nach § 3 Absatz 1b UStG zu 19 Prozent (Steuer)
    """


    # @ApiMember(Description="Unentgeltliche Wertabgaben - Sonstige Leistungen nach § 3 Absatz 9a UStG zu 19 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3003505")
    e3003505: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Unentgeltliche Wertabgaben - Sonstige Leistungen nach § 3 Absatz 9a UStG zu 19 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="Unentgeltliche Wertabgaben - Sonstige Leistungen nach § 3 Absatz 9a UStG zu 19 Prozent (Steuer)", Name="E3003506")
    e3003506: Optional[GeldBetragMitCent12DETyp] = None
    """
    Unentgeltliche Wertabgaben - Sonstige Leistungen nach § 3 Absatz 9a UStG zu 19 Prozent (Steuer)
    """


# @Api(Description="Umsätze zum ermäßigten Steuersatz")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class UmsErm2022:
    """
    Umsätze zum ermäßigten Steuersatz
    """

    # @ApiMember(Description="Lieferungen und sonstige Leistungen zu 7 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3004401")
    e3004401: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Lieferungen und sonstige Leistungen zu 7 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="Lieferungen und sonstige Leistungen zu 7 Prozent (Steuer)", Name="E3004402")
    e3004402: Optional[GeldBetragMitCent12DETyp] = None
    """
    Lieferungen und sonstige Leistungen zu 7 Prozent (Steuer)
    """


    # @ApiMember(Description="Unentgeltliche Wertabgaben - Lieferungen nach § 3 Absatz 1b UStG zu 7 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3003703")
    e3003703: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Unentgeltliche Wertabgaben - Lieferungen nach § 3 Absatz 1b UStG zu 7 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="Unentgeltliche Wertabgaben - Lieferungen nach § 3 Absatz 1b UStG zu 7 Prozent (Steuer)", Name="E3003704")
    e3003704: Optional[GeldBetragMitCent12DETyp] = None
    """
    Unentgeltliche Wertabgaben - Lieferungen nach § 3 Absatz 1b UStG zu 7 Prozent (Steuer)
    """


    # @ApiMember(Description="Unentgeltliche Wertabgaben - Sonstige Leistungen nach § 3 Absatz 9a UStG zu 7 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3003803")
    e3003803: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Unentgeltliche Wertabgaben - Sonstige Leistungen nach § 3 Absatz 9a UStG zu 7 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="Unentgeltliche Wertabgaben - Sonstige Leistungen nach § 3 Absatz 9a UStG zu 7 Prozent (Steuer)", Name="E3003804")
    e3003804: Optional[GeldBetragMitCent12DETyp] = None
    """
    Unentgeltliche Wertabgaben - Sonstige Leistungen nach § 3 Absatz 9a UStG zu 7 Prozent (Steuer)
    """


# @Api(Description="Umsätze zu anderen Steuersätzen")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class UmsAnd2022:
    """
    Umsätze zu anderen Steuersätzen
    """

    # @ApiMember(Description="Umsätze zu anderen Steuersätzen (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3005001")
    e3005001: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Umsätze zu anderen Steuersätzen (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="Umsätze zu anderen Steuersätzen (Steuer)", Name="E3005002")
    e3005002: Optional[GeldBetragMitCent12DETyp] = None
    """
    Umsätze zu anderen Steuersätzen (Steuer)
    """


# @Api(Description="Umsätze land- und forstwirtschaftlicher Betriebe nach § 24 UStG")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class UmsLuf2022:
    """
    Umsätze land- und forstwirtschaftlicher Betriebe nach § 24 UStG
    """

    # @ApiMember(Description="Lieferungen in das übrige Gemeinschaftsgebiet an Abnehmer mit USt-Identifikationsnummer (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3005201")
    e3005201: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Lieferungen in das übrige Gemeinschaftsgebiet an Abnehmer mit USt-Identifikationsnummer (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="Steuerpflichtige Lieferungen (einschließlich unentgeltlicher Wertabgaben) von Sägewerkserzeugnissen, die in der Anlage 2 zum UStG nicht aufgeführt sind (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3005301")
    e3005301: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Steuerpflichtige Lieferungen (einschließlich unentgeltlicher Wertabgaben) von Sägewerkserzeugnissen, die in der Anlage 2 zum UStG nicht aufgeführt sind (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="Steuerpflichtige Lieferungen (einschließlich unentgeltlicher Wertabgaben) von Sägewerkserzeugnissen, die in der Anlage 2 zum UStG nicht aufgeführt sind (Steuer)", Name="E3005302")
    e3005302: Optional[GeldBetragMitCent12DETyp] = None
    """
    Steuerpflichtige Lieferungen (einschließlich unentgeltlicher Wertabgaben) von Sägewerkserzeugnissen, die in der Anlage 2 zum UStG nicht aufgeführt sind (Steuer)
    """


    # @ApiMember(Description="Steuerpflichtige Umsätze (einschließlich unentgeltlicher Wertabgaben) von Getränken, die in der Anlage 2 zum UStG nicht aufgeführt sind, sowie von alkoholischen Flüssigkeiten (zum Beispiel Wein) - Umsätze zu anderen Steuersätzen (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3005701")
    e3005701: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Steuerpflichtige Umsätze (einschließlich unentgeltlicher Wertabgaben) von Getränken, die in der Anlage 2 zum UStG nicht aufgeführt sind, sowie von alkoholischen Flüssigkeiten (zum Beispiel Wein) - Umsätze zu anderen Steuersätzen (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="Steuerpflichtige Umsätze (einschließlich unentgeltlicher Wertabgaben) von Getränken, die in der Anlage 2 zum UStG nicht aufgeführt sind, sowie von alkoholischen Flüssigkeiten (zum Beispiel Wein) - Umsätze zu anderen Steuersätzen (Steuer)", Name="E3005702")
    e3005702: Optional[GeldBetragMitCent12DETyp] = None
    """
    Steuerpflichtige Umsätze (einschließlich unentgeltlicher Wertabgaben) von Getränken, die in der Anlage 2 zum UStG nicht aufgeführt sind, sowie von alkoholischen Flüssigkeiten (zum Beispiel Wein) - Umsätze zu anderen Steuersätzen (Steuer)
    """


    # @ApiMember(Description="Übrige steuerpflichtige Umsätze land- und forstwirtschaftlicher Betriebe, für die keine Steuer zu entrichten ist (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3005801")
    e3005801: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Übrige steuerpflichtige Umsätze land- und forstwirtschaftlicher Betriebe, für die keine Steuer zu entrichten ist (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="Steuerpflichtige Umsätze (einschließlich unentgeltlicher Wertabgaben) von Getränken, die in der Anlage 2 zum UStG nicht aufgeführt sind, sowie von alkoholischen Flüssigkeiten (zum Beispiel Wein) zu 9,5 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3005101")
    e3005101: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Steuerpflichtige Umsätze (einschließlich unentgeltlicher Wertabgaben) von Getränken, die in der Anlage 2 zum UStG nicht aufgeführt sind, sowie von alkoholischen Flüssigkeiten (zum Beispiel Wein) zu 9,5 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="Steuerpflichtige Umsätze (einschließlich unentgeltlicher Wertabgaben) von Getränken, die in der Anlage 2 zum UStG nicht aufgeführt sind, sowie von alkoholischen Flüssigkeiten (zum Beispiel Wein) zu 9,5 Prozent (Steuer)", Name="E3005102")
    e3005102: Optional[GeldBetragMitCent12DETyp] = None
    """
    Steuerpflichtige Umsätze (einschließlich unentgeltlicher Wertabgaben) von Getränken, die in der Anlage 2 zum UStG nicht aufgeführt sind, sowie von alkoholischen Flüssigkeiten (zum Beispiel Wein) zu 9,5 Prozent (Steuer)
    """


# @Api(Description="Represents an unsigned amount of money with cents whose value has a maximum length of 14 digits. That is, 1 to 12 digits before the decimal separator and 2 digits after the decimal separator. Minus sign NOT allowed.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class PositiverGeldBetragMitCent12DE(GeldBetragMitCent):
    """
    Represents an unsigned amount of money with cents whose value has a maximum length of 14 digits. That is, 1 to 12 digits before the decimal separator and 2 digits after the decimal separator. Minus sign NOT allowed.
    """

    pass


# @Api(Description="Absoluter Geldbetrag mit Cent mit 12 Vorkommastellen. Mindestens eine Ziffer und maximal 12 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen NICHT erlaubt. ',' als Dezimaltrennzeichen.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class PositiverGeldBetragMitCent12DETyp(CustomTypBase):
    """
    Absoluter Geldbetrag mit Cent mit 12 Vorkommastellen. Mindestens eine Ziffer und maximal 12 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen NICHT erlaubt. ',' als Dezimaltrennzeichen.
    """

    # @ApiMember(Description="Wert des Datentyps.  Mindestens eine Ziffer und maximal 12 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen NICHT erlaubt.", IsRequired=true, Name="Betrag")
    betrag: Optional[PositiverGeldBetragMitCent12DE] = None
    """
    Wert des Datentyps.  Mindestens eine Ziffer und maximal 12 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen NICHT erlaubt.
    """


# @Api(Description="Steuer infolge Wechsels der Besteuerungsform")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class WechsBestForm2022:
    """
    Steuer infolge Wechsels der Besteuerungsform
    """

    # @ApiMember(Description="Steuer (Nachsteuer) auf vereinnahmte Anzahlungen infolge des Wechsels der Besteuerungsform", Name="E3102901")
    e3102901: Optional[PositiverGeldBetragMitCent12DETyp] = None
    """
    Steuer (Nachsteuer) auf vereinnahmte Anzahlungen infolge des Wechsels der Besteuerungsform
    """


# @Api(Description="Nachsteuer auf versteuerte Anzahlungen und ähnlich wegen Steuersatzänderung")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class NachstStSatzAend2022:
    """
    Nachsteuer auf versteuerte Anzahlungen und ähnlich wegen Steuersatzänderung
    """

    # @ApiMember(Description="Nachsteuer auf versteuerte Anzahlungen und ähnlich wegen Steuersatzänderung (Steuer)", Name="E3005901")
    e3005901: Optional[GeldBetragMitCent12DETyp] = None
    """
    Nachsteuer auf versteuerte Anzahlungen und ähnlich wegen Steuersatzänderung (Steuer)
    """


# @Api(Description="Summe")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class UmsSum2022:
    """
    Summe
    """

    # @ApiMember(Description="Summe der Steuer (zu übertragen in Zeile 152)", Name="E3006001")
    e3006001: Optional[GeldBetragMitCent12DETyp] = None
    """
    Summe der Steuer (zu übertragen in Zeile 152)
    """


# @Api(Description="Steuerpflichtige Lieferungen, sonstige Leistungen und unentgeltliche Wertabgaben")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Umsaetze2022:
    """
    Steuerpflichtige Lieferungen, sonstige Leistungen und unentgeltliche Wertabgaben
    """

    # @ApiMember(Description="Umsätze zum allgemeinen Steuersatz", Name="UmsAllg")
    ums_allg: Optional[UmsAllg2022] = None
    """
    Umsätze zum allgemeinen Steuersatz
    """


    # @ApiMember(Description="Umsätze zum ermäßigten Steuersatz", Name="UmsErm")
    ums_erm: Optional[UmsErm2022] = None
    """
    Umsätze zum ermäßigten Steuersatz
    """


    # @ApiMember(Description="Umsätze zu anderen Steuersätzen", Name="UmsAnd")
    ums_and: Optional[UmsAnd2022] = None
    """
    Umsätze zu anderen Steuersätzen
    """


    # @ApiMember(Description="Umsätze land- und forstwirtschaftlicher Betriebe nach § 24 UStG", Name="UmsLuf")
    ums_luf: Optional[UmsLuf2022] = None
    """
    Umsätze land- und forstwirtschaftlicher Betriebe nach § 24 UStG
    """


    # @ApiMember(Description="Steuer infolge Wechsels der Besteuerungsform", Name="WechsBestForm")
    wechs_best_form: Optional[WechsBestForm2022] = None
    """
    Steuer infolge Wechsels der Besteuerungsform
    """


    # @ApiMember(Description="Nachsteuer auf versteuerte Anzahlungen und ähnlich wegen Steuersatzänderung", Name="NachstStSatzAend")
    nachst_st_satz_aend: Optional[NachstStSatzAend2022] = None
    """
    Nachsteuer auf versteuerte Anzahlungen und ähnlich wegen Steuersatzänderung
    """


    # @ApiMember(Description="Summe", Name="UmsSum")
    ums_sum: Optional[UmsSum2022] = None
    """
    Summe
    """


# @Api(Description="Innergemeinschaftliche Lieferungen (§ 4 Nummer 1 Buchstabe b UStG)")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class IgLfg2022:
    """
    Innergemeinschaftliche Lieferungen (§ 4 Nummer 1 Buchstabe b UStG)
    """

    # @ApiMember(Description="an Abnehmer mit USt-Identifikationsnummer (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3103301")
    e3103301: Optional[GeldBetragOhneCent12DETyp] = None
    """
    an Abnehmer mit USt-Identifikationsnummer (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="neuer Fahrzeuge an Abnehmer ohne USt-Identifikationsnummer (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3103401")
    e3103401: Optional[GeldBetragOhneCent12DETyp] = None
    """
    neuer Fahrzeuge an Abnehmer ohne USt-Identifikationsnummer (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="neuer Fahrzeuge außerhalb eines Unternehmens (§ 2a UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3103501")
    e3103501: Optional[GeldBetragOhneCent12DETyp] = None
    """
    neuer Fahrzeuge außerhalb eines Unternehmens (§ 2a UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


# @Api(Description="Weitere steuerfreie Umsätze mit Vorsteuerabzug (zum Beispiel nach § 4 Nummer 1 Buchstabe a, 2 bis 7 UStG)")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class UmsStFreiWeit2022:
    """
    Weitere steuerfreie Umsätze mit Vorsteuerabzug (zum Beispiel nach § 4 Nummer 1 Buchstabe a, 2 bis 7 UStG)
    """

    # @ApiMember(Description="Ausfuhrlieferungen und Lohnveredelungen an Gegenständen der Ausfuhr (§ 4 Nummer 1 Buchstabe a UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3103801")
    e3103801: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Ausfuhrlieferungen und Lohnveredelungen an Gegenständen der Ausfuhr (§ 4 Nummer 1 Buchstabe a UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="Umsätze nach § ... UStG:", Name="E3103901")
    e3103901: Optional[StringTyp] = None
    """
    Umsätze nach § ... UStG:
    """


    # @ApiMember(Description="Umsätze nach § ... UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3103902")
    e3103902: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Umsätze nach § ... UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="Umsätze im Sinne des Offshore-Steuerabkommens, des Zusatzabkommens zum NATO-Truppenstatut und des Ergänzungsabkommens zum Protokoll über die NATO-Hauptquartiere (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3104001")
    e3104001: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Umsätze im Sinne des Offshore-Steuerabkommens, des Zusatzabkommens zum NATO-Truppenstatut und des Ergänzungsabkommens zum Protokoll über die NATO-Hauptquartiere (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="Reiseleistungen nach § 25 Absatz 2 UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3104101")
    e3104101: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Reiseleistungen nach § 25 Absatz 2 UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="Summe der Zeilen 67 bis 70 (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3104201")
    e3104201: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Summe der Zeilen 67 bis 70 (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


# @Api(Description="Steuerfreie Umsätze mit Vorsteuerabzug")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class MitVoStAbz2022:
    """
    Steuerfreie Umsätze mit Vorsteuerabzug
    """

    # @ApiMember(Description="a) Liste innergemeinschaftlicher Lieferungen (§ 4 Nummer 1 Buchstabe b UStG)", Name="IgLfg")
    ig_lfg: Optional[IgLfg2022] = None
    """
    a) Liste innergemeinschaftlicher Lieferungen (§ 4 Nummer 1 Buchstabe b UStG)
    """


    # @ApiMember(Description="b) Liste weiterer steuerfreien Umsätze mit Vorsteuerabzug (zum Beispiel nach § 4 Nummer 1 Buchstabe a, 2 bis 7 UStG)", Name="IgLfg")
    ums_st_frei_weit: Optional[UmsStFreiWeit2022] = None
    """
    b) Liste weiterer steuerfreien Umsätze mit Vorsteuerabzug (zum Beispiel nach § 4 Nummer 1 Buchstabe a, 2 bis 7 UStG)
    """


# @Api(Description="Steuerfreie Umsätze ohne Vorsteuerabzug nicht zum Gesamtumsatz (§ 19 Absatz 3 UStG) gehörend")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class NichtGesUms2022:
    """
    Steuerfreie Umsätze ohne Vorsteuerabzug nicht zum Gesamtumsatz (§ 19 Absatz 3 UStG) gehörend
    """

    # @ApiMember(Description="nach § 4 Nummer 12 UStG (Vermietung und Verpachtung von Grundstücken und so weiter) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3104401")
    e3104401: Optional[GeldBetragOhneCent12DETyp] = None
    """
    nach § 4 Nummer 12 UStG (Vermietung und Verpachtung von Grundstücken und so weiter) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="nach § 4 Nummer ... UStG", Name="E3104501")
    e3104501: Optional[StringTyp] = None
    """
    nach § 4 Nummer ... UStG
    """


    # @ApiMember(Description="nach § 4 Nummer ... UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3104502")
    e3104502: Optional[GeldBetragOhneCent12DETyp] = None
    """
    nach § 4 Nummer ... UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="Summe der Zeilen 73 und 74 (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3104601")
    e3104601: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Summe der Zeilen 73 und 74 (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class GesUms2022:
    # @ApiMember(Description="nach § ... UStG", Name="E3104901")
    e3104901: Optional[StringTyp] = None
    """
    nach § ... UStG
    """


    # @ApiMember(Description="nach § ... UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3104902")
    e3104902: Optional[GeldBetragOhneCent12DETyp] = None
    """
    nach § ... UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


# @Api(Description="Steuerfreie Umsätze ohne Vorsteuerabzug")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class OhneVoStAbz2022:
    """
    Steuerfreie Umsätze ohne Vorsteuerabzug
    """

    # @ApiMember(Description="a) Steuerfreie Umsätze ohne Vorsteuerabzug nicht zum Gesamtumsatz (§ 19 Absatz 3 UStG) gehörend", Name="NichtGesUms")
    nicht_ges_ums: Optional[NichtGesUms2022] = None
    """
    a) Steuerfreie Umsätze ohne Vorsteuerabzug nicht zum Gesamtumsatz (§ 19 Absatz 3 UStG) gehörend
    """


    # @ApiMember(Description="b) Steuerfreie Umsätze ohne Vorsteuerabzug zum Gesamtumsatz(§ 19 Absatz 3 UStG) gehörend", Name="GesUms")
    ges_ums: Optional[GesUms2022] = None
    """
    b) Steuerfreie Umsätze ohne Vorsteuerabzug zum Gesamtumsatz(§ 19 Absatz 3 UStG) gehörend
    """


# @Api(Description="Steuerfreie Lieferungen, sonstige Leistungen und unentgeltliche Wertabgaben.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class UmsStfrei2022:
    """
    Steuerfreie Lieferungen, sonstige Leistungen und unentgeltliche Wertabgaben.
    """

    # @ApiMember(Description="Steuerfreie Umsätze mit Vorsteuerabzug", Name="MitVoStAbz")
    mit_vo_st_abz: Optional[MitVoStAbz2022] = None
    """
    Steuerfreie Umsätze mit Vorsteuerabzug
    """


    # @ApiMember(Description="Steuerfreie Umsätze ohne Vorsteuerabzug", Name="OhneVoStAbz")
    ohne_vo_st_abz: Optional[OhneVoStAbz2022] = None
    """
    Steuerfreie Umsätze ohne Vorsteuerabzug
    """


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Stfrei2022:
    # @ApiMember(Description="von bestimmten Gegenständen und Anlagegold nach §§ 4b und 25c UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3100901")
    e3100901: Optional[GeldBetragOhneCent12DETyp] = None
    """
    von bestimmten Gegenständen und Anlagegold nach §§ 4b und 25c UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


# @Api(Description="Steuerpflichtige innergemeinschaftliche Erwerbe (§ 1a UStG)")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Stpfl2022:
    """
    Steuerpflichtige innergemeinschaftliche Erwerbe (§ 1a UStG)
    """

    # @ApiMember(Description="zum Steuersatz von 19 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3100902")
    e3100902: Optional[GeldBetragOhneCent12DETyp] = None
    """
    zum Steuersatz von 19 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="zum Steuersatz von 19 Prozent (Steuer)", Name="E3100903")
    e3100903: Optional[GeldBetragMitCent12DETyp] = None
    """
    zum Steuersatz von 19 Prozent (Steuer)
    """


    # @ApiMember(Description="zum Steuersatz von 7 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3101301")
    e3101301: Optional[GeldBetragOhneCent12DETyp] = None
    """
    zum Steuersatz von 7 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="zum Steuersatz von 7 Prozent (Steuer)", Name="E3101302")
    e3101302: Optional[GeldBetragMitCent12DETyp] = None
    """
    zum Steuersatz von 7 Prozent (Steuer)
    """


    # @ApiMember(Description="zu anderen Steuersätzen (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3101303")
    e3101303: Optional[GeldBetragOhneCent12DETyp] = None
    """
    zu anderen Steuersätzen (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="zu anderen Steuersätzen (Steuer)", Name="E3101304")
    e3101304: Optional[GeldBetragMitCent12DETyp] = None
    """
    zu anderen Steuersätzen (Steuer)
    """


    # @ApiMember(Description="neuer Fahrzeuge (§ 1b Absatz 2 und 3 UStG) von Lieferern ohne USt-Identifikationsnummer zum allgemeinen Steuersatz (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3101401")
    e3101401: Optional[GeldBetragOhneCent12DETyp] = None
    """
    neuer Fahrzeuge (§ 1b Absatz 2 und 3 UStG) von Lieferern ohne USt-Identifikationsnummer zum allgemeinen Steuersatz (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="neuer Fahrzeuge (§ 1b Absatz 2 und 3 UStG) von Lieferern ohne USt-Identifikationsnummer zum allgemeinen Steuersatz (Steuer)", Name="E3101402")
    e3101402: Optional[GeldBetragMitCent12DETyp] = None
    """
    neuer Fahrzeuge (§ 1b Absatz 2 und 3 UStG) von Lieferern ohne USt-Identifikationsnummer zum allgemeinen Steuersatz (Steuer)
    """


# @Api(Description="Summe")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class IgErwSum2022:
    """
    Summe
    """

    # @ApiMember(Description="Summe der Steuer (zu übertragen in Zeile 153)", Name="E3101501")
    e3101501: Optional[GeldBetragMitCent12DETyp] = None
    """
    Summe der Steuer (zu übertragen in Zeile 153)
    """


# @Api(Description="Innergemeinschaftliche Erwerbe")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class IgErw2022:
    """
    Innergemeinschaftliche Erwerbe
    """

    # @ApiMember(Description="Steuerfreie innergemeinschaftliche Erwerbe", Name="Stfrei")
    stfrei: Optional[Stfrei2022] = None
    """
    Steuerfreie innergemeinschaftliche Erwerbe
    """


    # @ApiMember(Description="Steuerpflichtige innergemeinschaftliche Erwerbe (§ 1a UStG)", Name="Stpfl")
    stpfl: Optional[Stpfl2022] = None
    """
    Steuerpflichtige innergemeinschaftliche Erwerbe (§ 1a UStG)
    """


    # @ApiMember(Description="Summe", Name="IgErwSum")
    ig_erw_sum: Optional[IgErwSum2022] = None
    """
    Summe
    """


# @Api(Description="Summe der Steuer (zu übertragen in Zeile 154)")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Auslag13aSum2022:
    """
    Summe der Steuer (zu übertragen in Zeile 154)
    """

    # @ApiMember(Description="Summe der Steuer (zu übertragen in Zeile 154)", Name="E3102904")
    e3102904: Optional[GeldBetragMitCent12DETyp] = None
    """
    Summe der Steuer (zu übertragen in Zeile 154)
    """


# @Api(Description="Steuerschuldner bei Auslagerung (§ 13a Absatz 1 Nummer 6 UStG)")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Auslag13a2022:
    """
    Steuerschuldner bei Auslagerung (§ 13a Absatz 1 Nummer 6 UStG)
    """

    # @ApiMember(Description="Lieferungen, die der Auslagerung vorangegangen sind (§ 4 Nummer 4a Satz 1 Buchstabe a Satz 2 UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3102804")
    e3102804: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Lieferungen, die der Auslagerung vorangegangen sind (§ 4 Nummer 4a Satz 1 Buchstabe a Satz 2 UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="Lieferungen, die der Auslagerung vorangegangen sind (§ 4 Nummer 4a Satz 1 Buchstabe a Satz 2 UStG) (Steuer)", Name="E3102805")
    e3102805: Optional[GeldBetragMitCent12DETyp] = None
    """
    Lieferungen, die der Auslagerung vorangegangen sind (§ 4 Nummer 4a Satz 1 Buchstabe a Satz 2 UStG) (Steuer)
    """


    # @ApiMember(Description="Summe der Steuer (zu übertragen in Zeile 154)", Name="Auslag13aSum")
    auslag13a_sum: Optional[Auslag13aSum2022] = None
    """
    Summe der Steuer (zu übertragen in Zeile 154)
    """


# @Api(Description="Lieferungen des ersten Abnehmers")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class LfgErstAbn2022:
    """
    Lieferungen des ersten Abnehmers
    """

    # @ApiMember(Description="Bemessungsgrundlage ohne Umsatzsteuer (volle EUR)", Name="E3101801")
    e3101801: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Bemessungsgrundlage ohne Umsatzsteuer (volle EUR)
    """


# @Api(Description="Lieferungen, für die der letzte Abnehmer die Umsatzsteuer schuldet")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class LfgLetztAbn2022:
    """
    Lieferungen, für die der letzte Abnehmer die Umsatzsteuer schuldet
    """

    # @ApiMember(Description="zum Steuersatz von 19 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3101701")
    e3101701: Optional[GeldBetragOhneCent12DETyp] = None
    """
    zum Steuersatz von 19 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="zum Steuersatz von 19 Prozent (Steuer)", Name="E3101702")
    e3101702: Optional[GeldBetragMitCent12DETyp] = None
    """
    zum Steuersatz von 19 Prozent (Steuer)
    """


    # @ApiMember(Description="zum Steuersatz von 7 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3102301")
    e3102301: Optional[GeldBetragOhneCent12DETyp] = None
    """
    zum Steuersatz von 7 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="zum Steuersatz von 7 Prozent (Steuer)", Name="E3102302")
    e3102302: Optional[GeldBetragMitCent12DETyp] = None
    """
    zum Steuersatz von 7 Prozent (Steuer)
    """


    # @ApiMember(Description="zu anderen Steuersätzen (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3102303")
    e3102303: Optional[GeldBetragOhneCent12DETyp] = None
    """
    zu anderen Steuersätzen (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="zu anderen Steuersätzen (Steuer)", Name="E3102304")
    e3102304: Optional[GeldBetragMitCent12DETyp] = None
    """
    zu anderen Steuersätzen (Steuer)
    """


# @Api(Description="Summe")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class IgDreiSum2022:
    """
    Summe
    """

    # @ApiMember(Description="Summe der Steuer (zu übertragen in Zeile 155)", Name="E3102401")
    e3102401: Optional[GeldBetragMitCent12DETyp] = None
    """
    Summe der Steuer (zu übertragen in Zeile 155)
    """


# @Api(Description="Innergemeinschaftliche Dreiecksgeschäfte (§ 25b UStG)")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class IgDrei2022:
    """
    Innergemeinschaftliche Dreiecksgeschäfte (§ 25b UStG)
    """

    # @ApiMember(Description="Lieferungen des ersten Abnehmers", Name="LfgErstAbn")
    lfg_erst_abn: Optional[LfgErstAbn2022] = None
    """
    Lieferungen des ersten Abnehmers
    """


    # @ApiMember(Description="Lieferungen, für die der letzte Abnehmer die Umsatzsteuer schuldet", Name="LfgLetztAbn")
    lfg_letzt_abn: Optional[LfgLetztAbn2022] = None
    """
    Lieferungen, für die der letzte Abnehmer die Umsatzsteuer schuldet
    """


    # @ApiMember(Description="Summe", Name="IgDreiSum")
    ig_drei_sum: Optional[IgDreiSum2022] = None
    """
    Summe
    """


# @Api(Description="Summe der Steuer (zu übertragen in Zeile 156)")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Ums13bSum2022:
    """
    Summe der Steuer (zu übertragen in Zeile 156)
    """

    # @ApiMember(Description="Summe der Steuer (zu übertragen in Zeile 156)", Name="E3102601")
    e3102601: Optional[GeldBetragMitCent12DETyp] = None
    """
    Summe der Steuer (zu übertragen in Zeile 156)
    """


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Ums13b2022:
    # @ApiMember(Description="Steuerpflichtige sonstige Leistungen eines im übrigen Gemeinschaftsgebiet ansässigen Unternehmers (§ 13b Absatz 1 UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3102205")
    e3102205: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Steuerpflichtige sonstige Leistungen eines im übrigen Gemeinschaftsgebiet ansässigen Unternehmers (§ 13b Absatz 1 UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="Steuerpflichtige sonstige Leistungen eines im übrigen Gemeinschaftsgebiet ansässigen Unternehmers (§ 13b Absatz 1 UStG) (Steuer)", Name="E3102206")
    e3102206: Optional[GeldBetragMitCent12DETyp] = None
    """
    Steuerpflichtige sonstige Leistungen eines im übrigen Gemeinschaftsgebiet ansässigen Unternehmers (§ 13b Absatz 1 UStG) (Steuer)
    """


    # @ApiMember(Description="Umsätze, die unter das GrEStG fallen (§ 13b Absatz 2 Nummer 3 UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3102307")
    e3102307: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Umsätze, die unter das GrEStG fallen (§ 13b Absatz 2 Nummer 3 UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="Umsätze, die unter das GrEStG fallen (§ 13b Absatz 2 Nummer 3 UStG) (Steuer)", Name="E3102308")
    e3102308: Optional[GeldBetragMitCent12DETyp] = None
    """
    Umsätze, die unter das GrEStG fallen (§ 13b Absatz 2 Nummer 3 UStG) (Steuer)
    """


    # @ApiMember(Description="Andere Leistungen (§ 13b Absatz 2 Nummer 1, 2, 4 bis 12 UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3102503")
    e3102503: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Andere Leistungen (§ 13b Absatz 2 Nummer 1, 2, 4 bis 12 UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


    # @ApiMember(Description="Andere Leistungen (§ 13b Absatz 2 Nummer 1, 2, 4 bis 12 UStG) (Steuer)", Name="E3102504")
    e3102504: Optional[GeldBetragMitCent12DETyp] = None
    """
    Andere Leistungen (§ 13b Absatz 2 Nummer 1, 2, 4 bis 12 UStG) (Steuer)
    """


    # @ApiMember(Description="Summe", Name="Ums13bSum")
    ums13b_sum: Optional[Ums13bSum2022] = None
    """
    Summe
    """


# @Api(Description="Represents an unsigned amount of money without cents whose value has a maximum length of 12 digits.That is, 1 to 12 digits. Minus sign NOT allowed")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class PositiverGeldBetragOhneCent12DE(GrossGeldBetragOhneCent):
    """
    Represents an unsigned amount of money without cents whose value has a maximum length of 12 digits.That is, 1 to 12 digits. Minus sign NOT allowed
    """

    pass


# @Api(Description="Positiver Geldbetrag ohne Cent mit 13 Stellen. Mindestens eine Ziffer und maximal 12 Ziffern. Minusvorzeichen NICHT erlaubt.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class PositiverGeldBetragOhneCent12DETyp(CustomTypBase):
    """
    Positiver Geldbetrag ohne Cent mit 13 Stellen. Mindestens eine Ziffer und maximal 12 Ziffern. Minusvorzeichen NICHT erlaubt.
    """

    # @ApiMember(Description="Wert des Datentyps. Mindestens eine Ziffer und maximal 12 Ziffern. Minusvorzeichen NICHT erlaubt.", IsRequired=true)
    betrag: Optional[PositiverGeldBetragOhneCent12DE] = None
    """
    Wert des Datentyps. Mindestens eine Ziffer und maximal 12 Ziffern. Minusvorzeichen NICHT erlaubt.
    """


# @Api(Description="Ergänzende Angaben zu Umsätzen")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class ErgAngUms2022:
    """
    Ergänzende Angaben zu Umsätzen
    """

    # @ApiMember(Description="Umsätze, die auf Grund eines Verzichts auf Steuerbefreiung (§ 9 UStG) als steuerpflichtig behandelt worden sind (Betrag volle EUR)", Name="E3105201")
    e3105201: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Umsätze, die auf Grund eines Verzichts auf Steuerbefreiung (§ 9 UStG) als steuerpflichtig behandelt worden sind (Betrag volle EUR)
    """


    # @ApiMember(Description="Steuerpflichtige Umsätze, für die der Leistungsempfänger die Steuer nach § 13b Absatz 5 UStG schuldet (Betrag volle EUR)", Name="E3105301")
    e3105301: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Steuerpflichtige Umsätze, für die der Leistungsempfänger die Steuer nach § 13b Absatz 5 UStG schuldet (Betrag volle EUR)
    """


    # @ApiMember(Description="Telekommunikations-, Rundfunk- und Fernsehdienstleistungen sowie auf elektronischem Weg erbrachte sonstige Leistungen an im übrigen Gemeinschaftsgebiet ansässige Nichtunternehmer sowie innergemeinschaftliche Fernverkäufe in das übrige Gemeinschaftsgebiet unter der Voraussetzung des § 3a Absatz 5 Sätze 3 und 4 UStG und § 3c Absatz 4 Sätze 1 und 2 UStG in Abschnitt B oder C enthalten (Betrag volle EUR)", Name="E3105101")
    e3105101: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Telekommunikations-, Rundfunk- und Fernsehdienstleistungen sowie auf elektronischem Weg erbrachte sonstige Leistungen an im übrigen Gemeinschaftsgebiet ansässige Nichtunternehmer sowie innergemeinschaftliche Fernverkäufe in das übrige Gemeinschaftsgebiet unter der Voraussetzung des § 3a Absatz 5 Sätze 3 und 4 UStG und § 3c Absatz 4 Sätze 1 und 2 UStG in Abschnitt B oder C enthalten (Betrag volle EUR)
    """


    # @ApiMember(Description="Telekommunikations-, Rundfunk- und Fernsehdienstleistungen sowie auf elektronischem Weg erbrachte sonstige Leistungen an im übrigen Gemeinschaftsgebiet ansässige Nichtunternehmer sowie innergemeinschaftliche Fernverkäufe in das übrige Gemeinschaftsgebiet unter der Voraussetzung des § 3a Absatz 5 Sätze 3 und 4 UStG und § 3c Absatz 4 Sätze 1 und 2 UStG in anderen EU-Mitgliedstaaten zu versteuern (Betrag volle EUR)", Name="E3105102")
    e3105102: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Telekommunikations-, Rundfunk- und Fernsehdienstleistungen sowie auf elektronischem Weg erbrachte sonstige Leistungen an im übrigen Gemeinschaftsgebiet ansässige Nichtunternehmer sowie innergemeinschaftliche Fernverkäufe in das übrige Gemeinschaftsgebiet unter der Voraussetzung des § 3a Absatz 5 Sätze 3 und 4 UStG und § 3c Absatz 4 Sätze 1 und 2 UStG in anderen EU-Mitgliedstaaten zu versteuern (Betrag volle EUR)
    """


    # @ApiMember(Description="Nicht steuerbare Geschäftsveräußerung im Ganzen gemäß § 1 Absatz 1a UStG (Betrag volle EUR)", Name="E3105602")
    e3105602: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Nicht steuerbare Geschäftsveräußerung im Ganzen gemäß § 1 Absatz 1a UStG (Betrag volle EUR)
    """


    # @ApiMember(Description="Nicht steuerbare sonstige Leistungen gemäß § 18b Satz 1 Nummer 2 UStG (Betrag volle EUR)", Name="E3105702")
    e3105702: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Nicht steuerbare sonstige Leistungen gemäß § 18b Satz 1 Nummer 2 UStG (Betrag volle EUR)
    """


    # @ApiMember(Description="Übrige nicht steuerbare Umsätze (Leistungsort nicht im Inland) (Betrag volle EUR)", Name="E3105801")
    e3105801: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Übrige nicht steuerbare Umsätze (Leistungsort nicht im Inland) (Betrag volle EUR)
    """


    # @ApiMember(Description="In den Zeilen 109, 111 und 112 enthaltene Umsätze, die nach § 15 Absatz 2 und 3 UStG den Vorsteuerabzug ausschließen (Betrag volle EUR)", Name="E3105901")
    e3105901: Optional[GeldBetragOhneCent12DETyp] = None
    """
    In den Zeilen 109, 111 und 112 enthaltene Umsätze, die nach § 15 Absatz 2 und 3 UStG den Vorsteuerabzug ausschließen (Betrag volle EUR)
    """


    # @ApiMember(Description="Auf den inländischen Streckenanteil entfallende Umsätze grenzüberschreitender Personenbeförderungen im Luftverkehr (§ 26 Absatz 3 UStG) (Betrag volle EUR)", Name="E3106001")
    e3106001: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Auf den inländischen Streckenanteil entfallende Umsätze grenzüberschreitender Personenbeförderungen im Luftverkehr (§ 26 Absatz 3 UStG) (Betrag volle EUR)
    """


    # @ApiMember(Description="Minderung der Bemessungsgrundlage nach § 17 Absatz 1 Satz 1 in Verbindung mit Absatz 2 Nummer 1 Satz 1 UStG (in Abschnitt B oder C enthalten) (Betrag volle EUR)", Name="E3106101")
    e3106101: Optional[PositiverGeldBetragOhneCent12DETyp] = None
    """
    Minderung der Bemessungsgrundlage nach § 17 Absatz 1 Satz 1 in Verbindung mit Absatz 2 Nummer 1 Satz 1 UStG (in Abschnitt B oder C enthalten) (Betrag volle EUR)
    """


# @Api(Description="Summe der Vorsteuerbeträge (zu übertragen in Zeile 158)")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class AbzVoStSum2022:
    """
    Summe der Vorsteuerbeträge (zu übertragen in Zeile 158)
    """

    # @ApiMember(Description="Summe der Vorsteuerbeträge (zu übertragen in Zeile 158)", Name="E3006901")
    e3006901: Optional[GeldBetragMitCent12DETyp] = None
    """
    Summe der Vorsteuerbeträge (zu übertragen in Zeile 158)
    """


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class ErgAng2022:
    # @ApiMember(Description="Minderung der abziehbaren Vorsteuerbeträge nach § 17 Absatz 1 Satz 2 in Verbindung mit Absatz 2 Nummer 1 Satz 1 UStG (in den Zeilen 122, 127 bis 129 enthalten)", Name="E3007001")
    e3007001: Optional[PositiverGeldBetragMitCent12DETyp] = None
    """
    Minderung der abziehbaren Vorsteuerbeträge nach § 17 Absatz 1 Satz 2 in Verbindung mit Absatz 2 Nummer 1 Satz 1 UStG (in den Zeilen 122, 127 bis 129 enthalten)
    """


# @Api(Description="Abziehbare Vorsteuerbeträge")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class AbzVoSt2022:
    """
    Abziehbare Vorsteuerbeträge
    """

    # @ApiMember(Description="Vorsteuerbeträge aus Rechnungen von anderen Unternehmern (§ 15 Absatz 1 Satz 1 Nummer 1 UStG)", Name="E3006201")
    e3006201: Optional[GeldBetragMitCent12DETyp] = None
    """
    Vorsteuerbeträge aus Rechnungen von anderen Unternehmern (§ 15 Absatz 1 Satz 1 Nummer 1 UStG)
    """


    # @ApiMember(Description="Vorsteuerbeträge aus innergemeinschaftlichen Erwerben von Gegenständen (§ 15 Absatz 1 Satz 1 Nummer 3 UStG) ", Name="E3006301")
    e3006301: Optional[GeldBetragMitCent12DETyp] = None
    """
    Vorsteuerbeträge aus innergemeinschaftlichen Erwerben von Gegenständen (§ 15 Absatz 1 Satz 1 Nummer 3 UStG) 
    """


    # @ApiMember(Description="Entstandene Einfuhrumsatzsteuer (§ 15 Absatz 1 Satz 1 Nummer 2 UStG)", Name="E3006401")
    e3006401: Optional[GeldBetragMitCent12DETyp] = None
    """
    Entstandene Einfuhrumsatzsteuer (§ 15 Absatz 1 Satz 1 Nummer 2 UStG)
    """


    # @ApiMember(Description="Vorsteuerabzug für die Steuer, die der Abnehmer als Auslagerer nach § 13a Absatz 1 Nummer 6 UStG schuldet (§ 15 Absatz 1 Satz 1 Nummer 5 UStG)", Name="E3006503")
    e3006503: Optional[GeldBetragMitCent12DETyp] = None
    """
    Vorsteuerabzug für die Steuer, die der Abnehmer als Auslagerer nach § 13a Absatz 1 Nummer 6 UStG schuldet (§ 15 Absatz 1 Satz 1 Nummer 5 UStG)
    """


    # @ApiMember(Description="Vorsteuerbeträge aus Leistungen im Sinne des § 13b UStG (§ 15 Absatz 1 Satz 1 Nummer 4 UStG)", Name="E3006502")
    e3006502: Optional[GeldBetragMitCent12DETyp] = None
    """
    Vorsteuerbeträge aus Leistungen im Sinne des § 13b UStG (§ 15 Absatz 1 Satz 1 Nummer 4 UStG)
    """


    # @ApiMember(Description="Vorsteuerbeträge, die nach den allgemeinen Durchschnittssätzen berechnet sind (§ 23 UStG)", Name="E3006501")
    e3006501: Optional[GeldBetragMitCent12DETyp] = None
    """
    Vorsteuerbeträge, die nach den allgemeinen Durchschnittssätzen berechnet sind (§ 23 UStG)
    """


    # @ApiMember(Description="Vorsteuerbeträge nach dem Durchschnittssatz für bestimmte Körperschaften, Personenvereinigungen und Vermögensmassen (§ 23a UStG)", Name="E3006601")
    e3006601: Optional[GeldBetragMitCent12DETyp] = None
    """
    Vorsteuerbeträge nach dem Durchschnittssatz für bestimmte Körperschaften, Personenvereinigungen und Vermögensmassen (§ 23a UStG)
    """


    # @ApiMember(Description="Vorsteuerabzug für innergemeinschaftliche Lieferungen neuer Fahrzeuge außerhalb eines Unternehmens (§ 2a UStG) sowie von Kleinunternehmern im Sinne des § 19 Absatz 1 UStG (§ 15 Absatz 4a UStG)", Name="E3006701")
    e3006701: Optional[GeldBetragMitCent12DETyp] = None
    """
    Vorsteuerabzug für innergemeinschaftliche Lieferungen neuer Fahrzeuge außerhalb eines Unternehmens (§ 2a UStG) sowie von Kleinunternehmern im Sinne des § 19 Absatz 1 UStG (§ 15 Absatz 4a UStG)
    """


    # @ApiMember(Description="Vorsteuerbeträge aus innergemeinschaftlichen Dreiecksgeschäften (§ 25b Absatz 5 UStG)", Name="E3006801")
    e3006801: Optional[GeldBetragMitCent12DETyp] = None
    """
    Vorsteuerbeträge aus innergemeinschaftlichen Dreiecksgeschäften (§ 25b Absatz 5 UStG)
    """


    # @ApiMember(Description="Summe der Vorsteuerbeträge (zu übertragen in Zeile 158)", Name="AbzVoStSum")
    abz_vo_st_sum: Optional[AbzVoStSum2022] = None
    """
    Summe der Vorsteuerbeträge (zu übertragen in Zeile 158)
    """


    # @ApiMember(Description="Ergänzende Angabe", Name="AbzVoStSum")
    erg_ang: Optional[ErgAng2022] = None
    """
    Ergänzende Angabe
    """


# @Api(Description="Datum-Uhrzeit-Typ. Format: TT.MM.JJJJ.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class DatumUhrzeitTyp(CustomTypBase):
    """
    Datum-Uhrzeit-Typ. Format: TT.MM.JJJJ.
    """

    # @ApiMember(Description="Wert des Datentyps.", IsRequired=true, Name="Wert")
    wert: datetime.datetime = datetime.datetime(1, 1, 1)
    """
    Wert des Datentyps.
    """


# @Api(Description="Represents an unsigned amount of money with cents whose value has a maximum length of 15 digits. That is, 1 to 13 digits before the decimal separator and 2 digits after the decimal separator. Minus sign NOT allowed.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class PositiverGeldBetragMitCent13DE(GeldBetragMitCent):
    """
    Represents an unsigned amount of money with cents whose value has a maximum length of 15 digits. That is, 1 to 13 digits before the decimal separator and 2 digits after the decimal separator. Minus sign NOT allowed.
    """

    pass


# @Api(Description="Absoluter Geldbetrag mit Cent mit 13 Vorkommastellen. Mindestens eine Ziffer und maximal 13 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen NICHT erlaubt. ',' als Dezimaltrennzeichen.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class PositiverGeldBetragMitCent13DETyp(CustomTypBase):
    """
    Absoluter Geldbetrag mit Cent mit 13 Vorkommastellen. Mindestens eine Ziffer und maximal 13 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen NICHT erlaubt. ',' als Dezimaltrennzeichen.
    """

    # @ApiMember(Description="Wert des Datentyps.  Mindestens eine Ziffer und maximal 13 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen NICHT erlaubt.", IsRequired=true)
    betrag: Optional[PositiverGeldBetragMitCent13DE] = None
    """
    Wert des Datentyps.  Mindestens eine Ziffer und maximal 13 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen NICHT erlaubt.
    """


# @Api(Description="Angaben zum Grundstück oder Gebäude.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class AngGrdst2022:
    """
    Angaben zum Grundstück oder Gebäude.
    """

    # @ApiMember(Description="Lage des Grundstücks oder Gebäudes", Name="E3007401")
    e3007401: Optional[StringTyp] = None
    """
    Lage des Grundstücks oder Gebäudes
    """


    # @ApiMember(Description="Zeitpunkt der erstmaligen tatsächlichen Verwendung", Name="E3007402")
    e3007402: Optional[DatumUhrzeitTyp] = None
    """
    Zeitpunkt der erstmaligen tatsächlichen Verwendung
    """


    # @ApiMember(Description="Art der Verwendung im Erstjahr", Name="E3007403")
    e3007403: Optional[StringTyp] = None
    """
    Art der Verwendung im Erstjahr
    """


    # @ApiMember(Description="Umfang der Verwendung im Erstjahr", Name="E3007404")
    e3007404: Optional[PositiverGeldBetragMitCent13DETyp] = None
    """
    Umfang der Verwendung im Erstjahr
    """


    # @ApiMember(Description="insgesamt angefallene Vorsteuer", Name="E3007405")
    e3007405: Optional[GeldBetragOhneCent12DETyp] = None
    """
    insgesamt angefallene Vorsteuer
    """


    # @ApiMember(Description="in den Vorjahren - Investitionsphase - bereits abgezogene Vorsteuer", Name="E3007406")
    e3007406: Optional[GeldBetragOhneCent12DETyp] = None
    """
    in den Vorjahren - Investitionsphase - bereits abgezogene Vorsteuer
    """


# @Api(Description="Sind im Kalenderjahr 2022 Grundstücke, Grundstücksteile, Gebäude oder Gebäudeteile, für die Vorsteuer abgezogen worden ist, erstmals tatsächlich verwendet worden?")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class GrdstErstmVerw2022:
    """
    Sind im Kalenderjahr 2022 Grundstücke, Grundstücksteile, Gebäude oder Gebäudeteile, für die Vorsteuer abgezogen worden ist, erstmals tatsächlich verwendet worden?
    """

    # @ApiMember(Description="Falls ja, bitte eine 1 eintragen", Name="E3007301")
    e3007301: Optional[Bool1Typ] = None
    """
    Falls ja, bitte eine 1 eintragen
    """


    # @ApiMember(Description="Angaben zum Grundstück oder Gebäude.", Name="AngGrdst")
    ang_grdst: Optional[AngGrdst2022] = None
    """
    Angaben zum Grundstück oder Gebäude.
    """


# @Api(Description="Haben sich im Jahr 2022 die für den ursprünglichen Vorsteuerabzug maßgebenden Verhältnisse geändert bei.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class AendVerh2022:
    """
    Haben sich im Jahr 2022 die für den ursprünglichen Vorsteuerabzug maßgebenden Verhältnisse geändert bei.
    """

    # @ApiMember(Description="1. Grundstücken, Grundstücksteilen, Gebäuden oder Gebäudeteilen, die innerhalb der letzten 10 Jahre erstmals tatsächlich und nicht nur einmalig zur Ausführung von Umsätzen verwendet worden sind? Falls ja, bitte eine 'true' eintragen", Name="E3007601")
    e3007601: Optional[Bool1Typ] = None
    """
    1. Grundstücken, Grundstücksteilen, Gebäuden oder Gebäudeteilen, die innerhalb der letzten 10 Jahre erstmals tatsächlich und nicht nur einmalig zur Ausführung von Umsätzen verwendet worden sind? Falls ja, bitte eine 'true' eintragen
    """


    # @ApiMember(Description="2. anderen Wirtschaftsgütern und sonstigen Leistungen, die innerhalb der letzten 5 Jahre erstmals tatsächlich und nicht nur einmalig zur Ausführung von Umsätzen verwendet worden sind? Falls ja, bitte eine 'true' eintragen)", Name="E3008501")
    e3008501: Optional[Bool1Typ] = None
    """
    2. anderen Wirtschaftsgütern und sonstigen Leistungen, die innerhalb der letzten 5 Jahre erstmals tatsächlich und nicht nur einmalig zur Ausführung von Umsätzen verwendet worden sind? Falls ja, bitte eine 'true' eintragen)
    """


    # @ApiMember(Description="3. Wirtschaftsgütern und sonstigen Leistungen, die nur einmalig zur Ausführung von Umsätzen verwendet worden sind? Falls ja, bitte eine 1 eintragen", Name="E3008601")
    e3008601: Optional[Bool1Typ] = None
    """
    3. Wirtschaftsgütern und sonstigen Leistungen, die nur einmalig zur Ausführung von Umsätzen verwendet worden sind? Falls ja, bitte eine 1 eintragen
    """


# @Api(Description="Boolescher Datentyp, welcher als 'X' (Ja) oder Leerstring (Nein) im Jahressteuererklärung angeschrieben wird.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class BoolXTyp(CustomTypBase):
    """
    Boolescher Datentyp, welcher als 'X' (Ja) oder Leerstring (Nein) im Jahressteuererklärung angeschrieben wird.
    """

    # @ApiMember(Description="Wenn der Wert true ist, 'X' wird im Jahressteuererklärung angeschrieben; ansonsten ein Leerstring.", IsRequired=true, Name="Wert")
    wert: bool = False
    """
    Wenn der Wert true ist, 'X' wird im Jahressteuererklärung angeschrieben; ansonsten ein Leerstring.
    """


# @Api(Description="Nutzungsänderung.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class NutzAend2022:
    """
    Nutzungsänderung.
    """

    # @ApiMember(Description="Nutzungsänderung, und zwar", Name="E3007901")
    e3007901: Optional[BoolXTyp] = None
    """
    Nutzungsänderung, und zwar
    """


    # @ApiMember(Description="Übergang von steuerpflichtiger zu steuerfreier Vermietung oder umgekehrt beziehungsweise Änderung des Verwendungsschlüssels bei gemischt genutzten Grundstücken (insbesondere bei Mieterwechsel)", Name="E3008001")
    e3008001: Optional[BoolXTyp] = None
    """
    Übergang von steuerpflichtiger zu steuerfreier Vermietung oder umgekehrt beziehungsweise Änderung des Verwendungsschlüssels bei gemischt genutzten Grundstücken (insbesondere bei Mieterwechsel)
    """


    # @ApiMember(Description="steuerfreie Vermietung bisher eigengewerblich genutzter Räume oder umgekehrt; Übergang von einer Vermietung für NATO- oder ähnliche Zwecke zu einer nach  § 4 Nummer 12 UStG steuerfreien Vermietung", Name="E3008202")
    e3008202: Optional[BoolXTyp] = None
    """
    steuerfreie Vermietung bisher eigengewerblich genutzter Räume oder umgekehrt; Übergang von einer Vermietung für NATO- oder ähnliche Zwecke zu einer nach  § 4 Nummer 12 UStG steuerfreien Vermietung
    """


    # @ApiMember(Description="Andere Gründe für die geänderte Beurteilung des Vorsteuerabzugs:", Name="E3008401")
    e3008401: Optional[BoolXTyp] = None
    """
    Andere Gründe für die geänderte Beurteilung des Vorsteuerabzugs:
    """


    # @ApiMember(Description="Begründung", Name="E3008402")
    e3008402: Optional[StringTyp] = None
    """
    Begründung
    """


# @Api(Description="Die Verhältnisse, die ursprünglich für die Beurteilung des Vorsteuerabzugs maßgebend waren, haben sich seitdem geändert durch:")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class GrundAendVerh2022:
    """
    Die Verhältnisse, die ursprünglich für die Beurteilung des Vorsteuerabzugs maßgebend waren, haben sich seitdem geändert durch:
    """

    # @ApiMember(Description="Veräußerung", Name="E3007801")
    e3007801: Optional[BoolXTyp] = None
    """
    Veräußerung
    """


    # @ApiMember(Description="Lieferung im Sinne des § 3 Absatz 1b UStG", Name="E3007802")
    e3007802: Optional[BoolXTyp] = None
    """
    Lieferung im Sinne des § 3 Absatz 1b UStG
    """


    # @ApiMember(Description="Wechsel der Besteuerungsform, § 15a Absatz 7 UStG", Name="E3007803")
    e3007803: Optional[BoolXTyp] = None
    """
    Wechsel der Besteuerungsform, § 15a Absatz 7 UStG
    """


    # @ApiMember(Description="Nutzungsänderungen", Name="NutzAend")
    nutz_aend: Optional[NutzAend2022] = None
    """
    Nutzungsänderungen
    """


# @Api(Description="Summe")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class VoStBerBetrSum2022:
    """
    Summe
    """

    # @ApiMember(Description="Summe nachträglich abziehbar (zu übertragen in Zeile 159)", Name="E3008901")
    e3008901: Optional[PositiverGeldBetragMitCent12DETyp] = None
    """
    Summe nachträglich abziehbar (zu übertragen in Zeile 159)
    """


    # @ApiMember(Description="Summe zurückzuzahlen (zu übertragen in Zeile 161)", Name="E3008902")
    e3008902: Optional[PositiverGeldBetragMitCent12DETyp] = None
    """
    Summe zurückzuzahlen (zu übertragen in Zeile 161)
    """


# @Api(Description="Vorsteuerberichtigungsbeträge.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class VoStBerBetr2022:
    """
    Vorsteuerberichtigungsbeträge.
    """

    # @ApiMember(Description="zu 1. Grundstücke und so weiter, § 15a Absatz 1 Satz 2 UStG (nachträglich abziehbar)", Name="E3008701")
    e3008701: Optional[PositiverGeldBetragMitCent12DETyp] = None
    """
    zu 1. Grundstücke und so weiter, § 15a Absatz 1 Satz 2 UStG (nachträglich abziehbar)
    """


    # @ApiMember(Description="zu 1. Grundstücke und so weiter, § 15a Absatz 1 Satz 2 UStG (zurückzuzahlen)", Name="E3008702")
    e3008702: Optional[PositiverGeldBetragMitCent12DETyp] = None
    """
    zu 1. Grundstücke und so weiter, § 15a Absatz 1 Satz 2 UStG (zurückzuzahlen)
    """


    # @ApiMember(Description="zu 2. andere Wirtschaftsgüter und so weiter, § 15a Absatz 1 Satz 1 UStG (nachträglich abziehbar)", Name="E3008801")
    e3008801: Optional[PositiverGeldBetragMitCent12DETyp] = None
    """
    zu 2. andere Wirtschaftsgüter und so weiter, § 15a Absatz 1 Satz 1 UStG (nachträglich abziehbar)
    """


    # @ApiMember(Description="zu 2. andere Wirtschaftsgüter und so weiter, § 15a Absatz 1 Satz 1 UStG (zurückzuzahlen)", Name="E3008802")
    e3008802: Optional[PositiverGeldBetragMitCent12DETyp] = None
    """
    zu 2. andere Wirtschaftsgüter und so weiter, § 15a Absatz 1 Satz 1 UStG (zurückzuzahlen)
    """


    # @ApiMember(Description="zu 3. Wirtschaftsgüter und so weiter, § 15a Absatz 2 UStG (nachträglich abziehbar)", Name="E3008803")
    e3008803: Optional[PositiverGeldBetragMitCent12DETyp] = None
    """
    zu 3. Wirtschaftsgüter und so weiter, § 15a Absatz 2 UStG (nachträglich abziehbar)
    """


    # @ApiMember(Description="zu 3. Wirtschaftsgüter und so weiter, § 15a Absatz 2 UStG (zurückzuzahlen)", Name="E3008804")
    e3008804: Optional[PositiverGeldBetragMitCent12DETyp] = None
    """
    zu 3. Wirtschaftsgüter und so weiter, § 15a Absatz 2 UStG (zurückzuzahlen)
    """


    # @ApiMember(Description="Summe", Name="VoStBerBetrSum")
    vo_st_ber_betr_sum: Optional[VoStBerBetrSum2022] = None
    """
    Summe
    """


# @Api(Description="Berichtigung des Vorsteuerabzugs (§ 15a UStG).")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class BerVoSt15a2022:
    """
    Berichtigung des Vorsteuerabzugs (§ 15a UStG).
    """

    # @ApiMember(Description="Sind im Kalenderjahr 2022 Grundstücke, Grundstücksteile, Gebäude oder Gebäudeteile, für die Vorsteuer abgezogen worden ist, erstmals tatsächlich verwendet worden?", Name="GrdstErstmVerw")
    grdst_erstm_verw: Optional[GrdstErstmVerw2022] = None
    """
    Sind im Kalenderjahr 2022 Grundstücke, Grundstücksteile, Gebäude oder Gebäudeteile, für die Vorsteuer abgezogen worden ist, erstmals tatsächlich verwendet worden?
    """


    # @ApiMember(Description="Haben sich im Jahr 2022 die für den ursprünglichen Vorsteuerabzug maßgebenden Verhältnisse geändert bei", Name="AendVerh")
    aend_verh: Optional[AendVerh2022] = None
    """
    Haben sich im Jahr 2022 die für den ursprünglichen Vorsteuerabzug maßgebenden Verhältnisse geändert bei
    """


    # @ApiMember(Description="Die Verhältnisse, die ursprünglich für die Beurteilung des Vorsteuerabzugs maßgebend waren, haben sich seitdem geändert durch:", Name="GrundAendVerh")
    grund_aend_verh: Optional[GrundAendVerh2022] = None
    """
    Die Verhältnisse, die ursprünglich für die Beurteilung des Vorsteuerabzugs maßgebend waren, haben sich seitdem geändert durch:
    """


    # @ApiMember(Description="Nutzungsänderung", Name="VoStBerBetr")
    vo_st_ber_betr: Optional[VoStBerBetr2022] = None
    """
    Nutzungsänderung
    """


# @Api(Description="Verbleibende Umsatzsteuer / Verbleibender Überschuss.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class VerblUSt2022:
    """
    Verbleibende Umsatzsteuer / Verbleibender Überschuss.
    """

    # @ApiMember(Description="Verbleibende Umsatzsteuer / Verbleibender Überschuss (bei verbleibendem Überschuss - bitte dem Betrag ein Minuszeichen voranstellen)", IsRequired=true, Name="E3011101")
    # @Validate(Validator="NotNull")
    e3011101: Optional[GeldBetragMitCent12DETyp] = None
    """
    Verbleibende Umsatzsteuer / Verbleibender Überschuss (bei verbleibendem Überschuss - bitte dem Betrag ein Minuszeichen voranstellen)
    """


    # @ApiMember(Description="Vorauszahlungssoll 2022 (einschließlich Sondervorauszahlung)", IsRequired=true, Name="E3011301")
    # @Validate(Validator="NotNull")
    e3011301: Optional[GeldBetragMitCent12DETyp] = None
    """
    Vorauszahlungssoll 2022 (einschließlich Sondervorauszahlung)
    """


# @Api(Description="Noch an die Finanzkasse zu entrichten - Abschlusszahlung / Erstattungsanspruch -")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class ZahlErstatt2022:
    """
    Noch an die Finanzkasse zu entrichten - Abschlusszahlung / Erstattungsanspruch -
    """

    # @ApiMember(Description="Noch an die Finanzkasse zu entrichten - Abschlusszahlung / Erstattungsanspruch (bei Erstattungsanspruch - bitte dem Betrag ein Minuszeichen voranstellen)", IsRequired=true, Name="E3011401")
    # @Validate(Validator="NotNull")
    e3011401: Optional[GeldBetragMitCent12DETyp] = None
    """
    Noch an die Finanzkasse zu entrichten - Abschlusszahlung / Erstattungsanspruch (bei Erstattungsanspruch - bitte dem Betrag ein Minuszeichen voranstellen)
    """


# @Api(Description="Berechnung der zu entrichtenden Umsatzsteuer.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class BerechUSt2022:
    """
    Berechnung der zu entrichtenden Umsatzsteuer.
    """

    # @ApiMember(Description="Umsatzsteuer auf steuerpflichtige Lieferungen, sonstige Leistungen und unentgeltliche Wertabgaben (aus Zeile 60)", Name="E3009201")
    e3009201: Optional[GeldBetragMitCent12DETyp] = None
    """
    Umsatzsteuer auf steuerpflichtige Lieferungen, sonstige Leistungen und unentgeltliche Wertabgaben (aus Zeile 60)
    """


    # @ApiMember(Description="Umsatzsteuer auf innergemeinschaftliche Erwerbe (aus Zeile 86)", Name="E3009401")
    e3009401: Optional[GeldBetragMitCent12DETyp] = None
    """
    Umsatzsteuer auf innergemeinschaftliche Erwerbe (aus Zeile 86)
    """


    # @ApiMember(Description="Umsatzsteuer, die vom Auslagerer oder Lagerhalter geschuldet wird (§ 13a Absatz 1 Nummer 6 UStG) (aus Zeile 90)", Name="E3009602")
    e3009602: Optional[GeldBetragMitCent12DETyp] = None
    """
    Umsatzsteuer, die vom Auslagerer oder Lagerhalter geschuldet wird (§ 13a Absatz 1 Nummer 6 UStG) (aus Zeile 90)
    """


    # @ApiMember(Description="Umsatzsteuer, die vom letzten Abnehmer im innergemeinschaftlichen Dreiecksgeschäft geschuldet wird (§ 25b Absatz 2 UStG) (aus Zeile 97)", Name="E3009501")
    e3009501: Optional[GeldBetragMitCent12DETyp] = None
    """
    Umsatzsteuer, die vom letzten Abnehmer im innergemeinschaftlichen Dreiecksgeschäft geschuldet wird (§ 25b Absatz 2 UStG) (aus Zeile 97)
    """


    # @ApiMember(Description="Umsatzsteuer, die vom Leistungsempfänger nach § 13b UStG geschuldet wird (aus Zeile 103)", Name="E3009502")
    e3009502: Optional[GeldBetragMitCent12DETyp] = None
    """
    Umsatzsteuer, die vom Leistungsempfänger nach § 13b UStG geschuldet wird (aus Zeile 103)
    """


    # @ApiMember(Description="Zwischensumme", Name="E3009801")
    e3009801: Optional[GeldBetragMitCent12DETyp] = None
    """
    Zwischensumme
    """


    # @ApiMember(Description="Abziehbare Vorsteuerbeträge (aus Zeile 131)", Name="E3009901")
    e3009901: Optional[GeldBetragMitCent12DETyp] = None
    """
    Abziehbare Vorsteuerbeträge (aus Zeile 131)
    """


    # @ApiMember(Description="Vorsteuerbeträge, die auf Grund des § 15a UStG nachträglich abziehbar sind (aus Zeile 150)", Name="E3010001")
    e3010001: Optional[PositiverGeldBetragMitCent12DETyp] = None
    """
    Vorsteuerbeträge, die auf Grund des § 15a UStG nachträglich abziehbar sind (aus Zeile 150)
    """


    # @ApiMember(Description="Verbleibender Betrag", Name="E3010201")
    e3010201: Optional[GeldBetragMitCent12DETyp] = None
    """
    Verbleibender Betrag
    """


    # @ApiMember(Description="Vorsteuerbeträge, die auf Grund des § 15a UStG zurückzuzahlen sind (aus Zeile 150)", Name="E3009701")
    e3009701: Optional[PositiverGeldBetragMitCent12DETyp] = None
    """
    Vorsteuerbeträge, die auf Grund des § 15a UStG zurückzuzahlen sind (aus Zeile 150)
    """


    # @ApiMember(Description="In Rechnungen unrichtig oder unberechtigt ausgewiesene Steuerbeträge (§ 14c UStG) sowie Steuerbeträge, die nach § 6a Absatz 4 Satz 2 UStG geschuldet werden", Name="E3010301")
    e3010301: Optional[GeldBetragMitCent12DETyp] = None
    """
    In Rechnungen unrichtig oder unberechtigt ausgewiesene Steuerbeträge (§ 14c UStG) sowie Steuerbeträge, die nach § 6a Absatz 4 Satz 2 UStG geschuldet werden
    """


    # @ApiMember(Description="Steuerbeträge, die nach § 17 Absatz 1 Satz 7 UStG geschuldet werden", Name="E3010401")
    e3010401: Optional[GeldBetragMitCent12DETyp] = None
    """
    Steuerbeträge, die nach § 17 Absatz 1 Satz 7 UStG geschuldet werden
    """


    # @ApiMember(Description="Steuer- und Vorsteuerbeträge, die auf frühere Besteuerungszeiträume entfallen (nur für Kleinunternehmer, die § 19 Absatz 1 UStG anwenden)", Name="E3010501")
    e3010501: Optional[GeldBetragMitCent12DETyp] = None
    """
    Steuer- und Vorsteuerbeträge, die auf frühere Besteuerungszeiträume entfallen (nur für Kleinunternehmer, die § 19 Absatz 1 UStG anwenden)
    """


    # @ApiMember(Description="Umsatzsteuer / Überschuss (bei Überschuss - bitte dem Betrag ein Minuszeichen voranstellen)", Name="E3010601")
    e3010601: Optional[GeldBetragMitCent12DETyp] = None
    """
    Umsatzsteuer / Überschuss (bei Überschuss - bitte dem Betrag ein Minuszeichen voranstellen)
    """


    # @ApiMember(Description="Anrechenbare Beträge (aus Zeile 23 der Anlage UN)", Name="E3010602")
    e3010602: Optional[GeldBetragMitCent12DETyp] = None
    """
    Anrechenbare Beträge (aus Zeile 23 der Anlage UN)
    """


    # @ApiMember(Description="Verbleibende Umsatzsteuer / Verbleibender Überschuss", Name="VerblUSt")
    verbl_u_st: Optional[VerblUSt2022] = None
    """
    Verbleibende Umsatzsteuer / Verbleibender Überschuss
    """


    # @ApiMember(Description="Noch an die Finanzkasse zu entrichten - Abschlusszahlung / Erstattungsanspruch -", Name="ZahlErstatt")
    zahl_erstatt: Optional[ZahlErstatt2022] = None
    """
    Noch an die Finanzkasse zu entrichten - Abschlusszahlung / Erstattungsanspruch -
    """


# @Api(Description="Bankverbindung.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Bank2022:
    """
    Bankverbindung.
    """

    # @ApiMember(Description="IBAN", Name="E3201001")
    e3201001: Optional[StringTyp] = None
    """
    IBAN
    """


    # @ApiMember(Description="BIC (nur bei Bankverbindungen außerhalb des Europäischen Wirtschaftsraums)", Name="E3201002")
    e3201002: Optional[StringTyp] = None
    """
    BIC (nur bei Bankverbindungen außerhalb des Europäischen Wirtschaftsraums)
    """


    # @ApiMember(Description="Name des Geldinstituts (Zweigstelle) und Ort", Name="E3200901")
    e3200901: Optional[StringTyp] = None
    """
    Name des Geldinstituts (Zweigstelle) und Ort
    """


    # @ApiMember(Description="Kontonummer (nur bei Bankverbindungen außerhalb des Europäischen Zahlungsverkehrsraums - SEPA)", Name="E3200902")
    e3200902: Optional[StringTyp] = None
    """
    Kontonummer (nur bei Bankverbindungen außerhalb des Europäischen Zahlungsverkehrsraums - SEPA)
    """


    # @ApiMember(Description="Kontoinhaber ist der Unternehmer laut den allgemeinen Angaben auf Vordruck USt2A", Name="E3200904")
    e3200904: Optional[BoolXTyp] = None
    """
    Kontoinhaber ist der Unternehmer laut den allgemeinen Angaben auf Vordruck USt2A
    """


    # @ApiMember(Description="Name des Kontoinhabers", Name="E3200905")
    e3200905: Optional[StringTyp] = None
    """
    Name des Kontoinhabers
    """


# @Api(Description="Angaben zur Unterschrift.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class AngUnterschr2022:
    """
    Angaben zur Unterschrift.
    """

    # @ApiMember(Description="Die Umsatzsteuererklärung wurde vom Bevollmächtigten elektronisch authentifiziert übermittelt. Die Voraussetzungen des § 150 Absatz 3 AO liegen vor.", Name="E3201701")
    e3201701: Optional[BoolXTyp] = None
    """
    Die Umsatzsteuererklärung wurde vom Bevollmächtigten elektronisch authentifiziert übermittelt. Die Voraussetzungen des § 150 Absatz 3 AO liegen vor.
    """


# @Api(Description="Bevollmächtigter/Empfangsbevollmächtigter.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Vollm2022:
    """
    Bevollmächtigter/Empfangsbevollmächtigter.
    """

    # @ApiMember(Description="Zur Wahrnehmung der steuerlichen Pflichten und Rechte als Bevollmächtigter (§ 80 AO) ist bestellt:", Name="E3201301")
    e3201301: Optional[BoolXTyp] = None
    """
    Zur Wahrnehmung der steuerlichen Pflichten und Rechte als Bevollmächtigter (§ 80 AO) ist bestellt:
    """


    # @ApiMember(Description="Zum Empfang von Schriftstücken als Empfangsbevollmächtigter (§ 123 AO) ist bestellt:", Name="E3201401")
    e3201401: Optional[BoolXTyp] = None
    """
    Zum Empfang von Schriftstücken als Empfangsbevollmächtigter (§ 123 AO) ist bestellt:
    """


    # @ApiMember(Description="Name", Name="E3201501")
    e3201501: Optional[StringTyp] = None
    """
    Name
    """


    # @ApiMember(Description="Straße", Name="E3201601")
    e3201601: Optional[StringTyp] = None
    """
    Straße
    """


    # @ApiMember(Description="Hausnummer", Name="E3201302")
    e3201302: Optional[StringTyp] = None
    """
    Hausnummer
    """


    # @ApiMember(Description="Hausnummerzusatz", Name="E3201303")
    e3201303: Optional[StringTyp] = None
    """
    Hausnummerzusatz
    """


    # @ApiMember(Description="Adressergänzung", Name="E3201304")
    e3201304: Optional[StringTyp] = None
    """
    Adressergänzung
    """


    # @ApiMember(Description="Postleitzahl, Ort", Name="E3201402")
    e3201402: Optional[StringTyp] = None
    """
    Postleitzahl, Ort
    """


    # @ApiMember(Description="Postleitzahl zu Postfach", Name="E3201503")
    e3201503: Optional[StringTyp] = None
    """
    Postleitzahl zu Postfach
    """


    # @ApiMember(Description="Postfach", Name="E3201504")
    e3201504: Optional[StringTyp] = None
    """
    Postfach
    """


    # @ApiMember(Description="Telefon", Name="E3201602")
    e3201602: Optional[StringTyp] = None
    """
    Telefon
    """


    # @ApiMember(Description="E-Mail-Adresse", Name="E3201502")
    e3201502: Optional[StringTyp] = None
    """
    E-Mail-Adresse
    """


    # @ApiMember(Description="Angaben zur Unterschrift", Name="AngUnterschr")
    ang_unterschr: Optional[AngUnterschr2022] = None
    """
    Angaben zur Unterschrift
    """


# @Api(Description="Allgemeine Angaben.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class UnAllg2022:
    """
    Allgemeine Angaben.
    """

    # @ApiMember(Description="Bankverbindung", Name="Bank")
    bank: Optional[Bank2022] = None
    """
    Bankverbindung
    """


    # @ApiMember(Description="Bevollmächtigter/Empfangsbevollmächtigter", Name="Vollm")
    vollm: Optional[Vollm2022] = None
    """
    Bevollmächtigter/Empfangsbevollmächtigter
    """


# @Api(Description="Boolescher Datentyp, welcher als '1' (Ja) oder '2' (Nein) im Jahressteuererklärung angeschrieben wird.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Bool12Typ(CustomTypBase):
    """
    Boolescher Datentyp, welcher als '1' (Ja) oder '2' (Nein) im Jahressteuererklärung angeschrieben wird.
    """

    # @ApiMember(Description="Wenn der Wert true ist, '1' wird im Jahressteuererklärung angeschrieben; ansonsten '2'.", IsRequired=true, Name="Wert")
    wert: bool = False
    """
    Wenn der Wert true ist, '1' wird im Jahressteuererklärung angeschrieben; ansonsten '2'.
    """


# @Api(Description="Vorsteuer-Vergütungsverfahren beim Bundeszentralamt für Steuern.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class VoStVerguetBZSt2022:
    """
    Vorsteuer-Vergütungsverfahren beim Bundeszentralamt für Steuern.
    """

    # @ApiMember(Description="Ist für das Kalenderjahr die Vergütung von Vorsteuern in einem besonderen Verfahren (§ 18 Absatz 9 UStG, §§ 59 bis 61a UStDV) beantragt worden?", IsRequired=true, Name="E3201101")
    # @Validate(Validator="NotNull")
    e3201101: Optional[Bool12Typ] = None
    """
    Ist für das Kalenderjahr die Vergütung von Vorsteuern in einem besonderen Verfahren (§ 18 Absatz 9 UStG, §§ 59 bis 61a UStDV) beantragt worden?
    """


# @Api(Description="C. Anrechenbare Beträge.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class AnrechBetr2022:
    """
    C. Anrechenbare Beträge.
    """

    # @ApiMember(Description="Bei der Beförderungseinzelbesteuerung entrichtete Umsatzsteuer (§ 18 Absatz 5b Satz 2 UStG) - Belege bitte gesondert übermitteln -", Name="E3201902")
    e3201902: Optional[GeldBetragMitCent12DETyp] = None
    """
    Bei der Beförderungseinzelbesteuerung entrichtete Umsatzsteuer (§ 18 Absatz 5b Satz 2 UStG) - Belege bitte gesondert übermitteln -
    """


    # @ApiMember(Description="Entrichtete Sicherheitsleistungen (§ 18 Absatz 12 Satz 5 UStG) - Belege bitte gesondert übermitteln -", Name="E3202002")
    e3202002: Optional[GeldBetragMitCent12DETyp] = None
    """
    Entrichtete Sicherheitsleistungen (§ 18 Absatz 12 Satz 5 UStG) - Belege bitte gesondert übermitteln -
    """


    # @ApiMember(Description="Summe (zu übertragen in Zeile 166 der Steuererklärung)", Name="E3202102")
    e3202102: Optional[GeldBetragMitCent12DETyp] = None
    """
    Summe (zu übertragen in Zeile 166 der Steuererklärung)
    """


# @Api(Description="In den steuerpflichtigen Umsätzen enthaltene Umsätze.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class InstpflUmsEnt2022:
    """
    In den steuerpflichtigen Umsätzen enthaltene Umsätze.
    """

    # @ApiMember(Description="Innergemeinschaftliche Fernverkäufe aus dem übrigen Gemeinschaftsgebiet (§ 3c UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3201901")
    e3201901: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Innergemeinschaftliche Fernverkäufe aus dem übrigen Gemeinschaftsgebiet (§ 3c UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)
    """


# @Api(Description="Ergänzende Angaben zu Umsätzen.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class UnErgAngUms2022:
    """
    Ergänzende Angaben zu Umsätzen.
    """

    # @ApiMember(Description="In den steuerpflichtigen Umsätzen enthaltene Umsätze", Name="InstpflUmsEnt")
    instpfl_ums_ent: Optional[InstpflUmsEnt2022] = None
    """
    In den steuerpflichtigen Umsätzen enthaltene Umsätze
    """


# @Api(Description="Anlage UN zur Umsatzsteuererklärung für im Ausland ansässige Unternehmer.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class UN2022:
    """
    Anlage UN zur Umsatzsteuererklärung für im Ausland ansässige Unternehmer.
    """

    # @ApiMember(Description="A. Allgemeine Angaben", Name="Allg")
    allg: Optional[UnAllg2022] = None
    """
    A. Allgemeine Angaben
    """


    # @ApiMember(Description="B. Vorsteuer-Vergütungsverfahren beim Bundeszentralamt für Steuern", Name="VoStVerguetBZSt")
    vo_st_verguet_b_z_st: Optional[VoStVerguetBZSt2022] = None
    """
    B. Vorsteuer-Vergütungsverfahren beim Bundeszentralamt für Steuern
    """


    # @ApiMember(Description="C. Anrechenbare Beträge", Name="AnrechBetr")
    anrech_betr: Optional[AnrechBetr2022] = None
    """
    C. Anrechenbare Beträge
    """


    # @ApiMember(Description="D. Ergänzende Angaben zu Umsätzen", Name="ErgAngUms")
    erg_ang_ums: Optional[UnErgAngUms2022] = None
    """
    D. Ergänzende Angaben zu Umsätzen
    """


# @Api(Description="Einzelner vertretene Unternehmer")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Einz2022:
    """
    Einzelner vertretene Unternehmer
    """

    # @ApiMember(Description="Name des vertretenen Unternehmers", Name="E3300201")
    e3300201: Optional[StringTyp] = None
    """
    Name des vertretenen Unternehmers
    """


    # @ApiMember(Description="Anschrift des vertretenen Unternehmers", Name="E3300202")
    e3300202: Optional[StringTyp] = None
    """
    Anschrift des vertretenen Unternehmers
    """


    # @ApiMember(Description="Umsatzsteuer-Identifikationsnummer des vertretenen Unternehmers", Name="E3300203")
    e3300203: Optional[StringTyp] = None
    """
    Umsatzsteuer-Identifikationsnummer des vertretenen Unternehmers
    """


    # @ApiMember(Description="Summe der jeweiligen Bemessungsgrundlagen in EUR", Name="E3300204")
    e3300204: Optional[GeldBetragOhneCent12DETyp] = None
    """
    Summe der jeweiligen Bemessungsgrundlagen in EUR
    """


# @Api(Description="Summe")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class AufstAllerVertrUntSum2022:
    """
    Summe
    """

    # @ApiMember(Description=" Summe aller Bemessungsgrundlagen in EUR", Name="E3300301")
    e3300301: Optional[GeldBetragOhneCent12DETyp] = None
    """
     Summe aller Bemessungsgrundlagen in EUR
    """


# @Api(Description="Aufstellung aller vertretenen Unternehmer")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class AufstAllerVertrUnt2022:
    """
    Aufstellung aller vertretenen Unternehmer
    """

    # @ApiMember(Description="Die vertretenen Unternehmer", Name="Einzs")
    einzs: List[Einz2022] = field(default_factory=list)
    """
    Die vertretenen Unternehmer
    """


    # @ApiMember(Description="Die Summe", Name="Sum")
    sum: Optional[AufstAllerVertrUntSum2022] = None
    """
    Die Summe
    """


# @Api(Description="Anlage FV zur Umsatzsteuererklärung 2022")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class FV2022:
    """
    Anlage FV zur Umsatzsteuererklärung 2022
    """

    # @ApiMember(Description="Aufstellung aller vertretenen Unternehmer", Name="AufstAllerVertrUnt")
    aufst_aller_vertr_unt: Optional[AufstAllerVertrUnt2022] = None
    """
    Aufstellung aller vertretenen Unternehmer
    """


class Unterfallart(IntEnum):
    """
    Represents a subclaim type of certain data types.
    """

    E_ST = 10
    E_STBESCHRAENKT = 12
    ANLAGE34A = 13
    GEW_ST = 20
    GEW_ST_Z = 21
    K_ST30 = 30
    K_ST31 = 31
    K_ST32 = 32
    K_ST33 = 33
    K_ST_Z = 39
    U_ST = 50
    U_ST_SV = 57
    U_ST_V_A = 58
    L_ST_A = 64
    GEWINNERMITTLUNG13A_E_ST_G = 76
    EUER = 77
    GRUNDSTEUERWERT = 88
    FEIN90 = 90
    FEIN95 = 95
    INV_ST_G56_ABS5 = 97
    KEINE = 98


# @Api(Description="Datentyp, welches die UnterfallArt bestimmter Datenarten darstellt.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class UnterfallartTyp(CustomTypBase):
    """
    Datentyp, welches die UnterfallArt bestimmter Datenarten darstellt.
    """

    # @ApiMember(Description="Wert des Datentyps.", IsRequired=true, Name="Wert")
    wert: Optional[Unterfallart] = None
    """
    Wert des Datentyps.
    """


class VeranlagungVorgang(IntEnum):
    """
    Stellt den Vorgang bei einer Veranlagung dar.
    """

    NUR_VERANLAGUNG = 1
    VERANLAGUNG_MIT_VORAUSZAHLUNG = 4


# @Api(Description="Datentyp, welches den Vorgang bei einer Veranlagung darstellt.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class VeranlagungVorgangTyp(CustomTypBase):
    """
    Datentyp, welches den Vorgang bei einer Veranlagung darstellt.
    """

    # @ApiMember(Description="Wert des Datentyps.", IsRequired=true, Name="Wert")
    wert: Optional[VeranlagungVorgang] = None
    """
    Wert des Datentyps.
    """


class OrdNrArt(str, Enum):
    """
    Stellt die Art der Ordnungsnummer dar.
    """

    S = 'S'
    O = 'O'


# @Api(Description="Datentyp, welches die ermittelten Ordnungsbegriff zu füllen darstellt.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class OrdNrArtTyp(CustomTypBase):
    """
    Datentyp, welches die ermittelten Ordnungsbegriff zu füllen darstellt.
    """

    # @ApiMember(Description="Wert des Datentyps.", IsRequired=true, Name="Wert")
    wert: Optional[OrdNrArt] = None
    """
    Wert des Datentyps.
    """


# @Api(Description="Stellt die Informationen zur Bescheidrückübermittlung für die neue Struktur der Jahrresteuererklärung dar.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class E50Rueckuebermittlung:
    """
    Stellt die Informationen zur Bescheidrückübermittlung für die neue Struktur der Jahrresteuererklärung dar.
    """

    # @ApiMember(Description="Wird die elektronische Bereitstellung der Bescheiddaten gewünscht?")
    bescheid: Optional[Bool12Typ] = None
    """
    Wird die elektronische Bereitstellung der Bescheiddaten gewünscht?
    """


    # @ApiMember(Description="Art der Benachrichtigung über vorliegende Bescheiddaten zur Abholung.")
    art_rueckuebermittlung: Optional[StringTyp] = None
    """
    Art der Benachrichtigung über vorliegende Bescheiddaten zur Abholung.
    """


    # @ApiMember(Description="Schlüssel unter dem die Bescheiddaten verschlüsselt zur Abholung bereitgestellt werden sollen")
    schluessel_rueckuebermittlung: Optional[StringTyp] = None
    """
    Schlüssel unter dem die Bescheiddaten verschlüsselt zur Abholung bereitgestellt werden sollen
    """


    # @ApiMember(Description="Benachrichtigungsadresse (in der Regel E-Mail-Adresse) für die Benachrichtigung über die elektronische Bereitstellung der Bescheiddaten.")
    adresse_rueckuebermittlung: Optional[StringTyp] = None
    """
    Benachrichtigungsadresse (in der Regel E-Mail-Adresse) für die Benachrichtigung über die elektronische Bereitstellung der Bescheiddaten.
    """


# @Api(Description="Represents a base class for a file with raw data.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class FileBase:
    """
    Represents a base class for a file with raw data.
    """

    # @ApiMember(Description="The raw data content of the file in bytes.", Name="Content")
    content: Optional[bytes] = None
    """
    The raw data content of the file in bytes.
    """


# @Api(Description="Represents a portal certificate that is protected by a password.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class PortalCertificate(FileBase, ISecuredCertificate):
    """
    Represents a portal certificate that is protected by a password.
    """

    # @ApiMember(Description="The file name of the certificate.")
    # @StringLength(128)
    name: Optional[str] = None
    """
    The file name of the certificate.
    """


    # @StringLength(255)
    # @ApiMember(Description="The password to protect the certificate from unauthorized access.")
    pin: Optional[str] = None
    """
    The password to protect the certificate from unauthorized access.
    """


    # @StringLength(2147483647)
    # @ApiMember(Description="The description of the certificate.")
    description: Optional[str] = None
    """
    The description of the certificate.
    """


    # @ApiMember(Description="Tags that can be used to label or identify the certificate.")
    tags: List[str] = field(default_factory=list)
    """
    Tags that can be used to label or identify the certificate.
    """


# @Api(Description="Submits an annual VAT return (Umsatzsteuerjahresserklärung) for 2022.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class SubmitUmsatzsteuererklaerung2022Base(IReturn[BearbeiteVorgangResponse], IPost, IDruckRequest, IVeschlueselungsRequest):
    """
    Submits an annual VAT return (Umsatzsteuerjahresserklärung) for 2022.
    """

    # @ApiMember(Description="Berichtigte Erklärung", Name="BerErkl")
    ber_erkl: Optional[BerErkl2022] = None
    """
    Berichtigte Erklärung
    """


    # @ApiMember(Description="A. Allgemeine Angaben.", Name="Allg")
    allg: Optional[Allg2022] = None
    """
    A. Allgemeine Angaben.
    """


    # @ApiMember(Description="Angaben zu den Mitwirkenden, die bei der Anfertigung dieser Steuererklärung einschließlich der Anlagen mitgewirkt haben.", Name="Mitwirk")
    mitwirk: Optional[Mitwirk2022] = None
    """
    Angaben zu den Mitwirkenden, die bei der Anfertigung dieser Steuererklärung einschließlich der Anlagen mitgewirkt haben.
    """


    # @ApiMember(Description="B. Angaben zur Besteuerung der Kleinunternehmer (§ 19 Absatz 1 UStG). Die Zeilen 33 und 34 sind nur auszufüllen, wenn der Umsatz $VZ-1$ (zuzüglich Steuer) nicht mehr als 22.000 € betragen hat und auf die Anwendung des § 19 Absatz 1 UStG nicht verzichtet worden ist.", Name="Kleinuntern")
    kleinuntern: Optional[Kleinuntern2022] = None
    """
    B. Angaben zur Besteuerung der Kleinunternehmer (§ 19 Absatz 1 UStG). Die Zeilen 33 und 34 sind nur auszufüllen, wenn der Umsatz $VZ-1$ (zuzüglich Steuer) nicht mehr als 22.000 € betragen hat und auf die Anwendung des § 19 Absatz 1 UStG nicht verzichtet worden ist.
    """


    # @ApiMember(Description="C. Steuerpflichtige Lieferungen, sonstige Leistungen und unentgeltliche Wertabgaben.", Name="Umsaetze")
    umsaetze: Optional[Umsaetze2022] = None
    """
    C. Steuerpflichtige Lieferungen, sonstige Leistungen und unentgeltliche Wertabgaben.
    """


    # @ApiMember(Description="D. Steuerfreie Lieferungen, sonstige Leistungen und unentgeltliche Wertabgaben.", Name="UmsStfrei")
    ums_stfrei: Optional[UmsStfrei2022] = None
    """
    D. Steuerfreie Lieferungen, sonstige Leistungen und unentgeltliche Wertabgaben.
    """


    # @ApiMember(Description="E. Innergemeinschaftliche Erwerbe.", Name="IgErw")
    ig_erw: Optional[IgErw2022] = None
    """
    E. Innergemeinschaftliche Erwerbe.
    """


    # @ApiMember(Description="F. Steuerschuldner bei Auslagerung (§ 13a Absatz 1 Nummer 6 UStG).", Name="Auslag13a")
    auslag13a: Optional[Auslag13a2022] = None
    """
    F. Steuerschuldner bei Auslagerung (§ 13a Absatz 1 Nummer 6 UStG).
    """


    # @ApiMember(Description="G. Innergemeinschaftliche Dreiecksgeschäfte (§ 25b UStG).", Name="IgDrei")
    ig_drei: Optional[IgDrei2022] = None
    """
    G. Innergemeinschaftliche Dreiecksgeschäfte (§ 25b UStG).
    """


    # @ApiMember(Description="H. Leistungsempfänger als Steuerschuldner (§ 13b UStG).", Name="Ums13b")
    ums13b: Optional[Ums13b2022] = None
    """
    H. Leistungsempfänger als Steuerschuldner (§ 13b UStG).
    """


    # @ApiMember(Description="I. Ergänzende Angaben zu Umsätzen.", Name="ErgAngUms")
    erg_ang_ums: Optional[ErgAngUms2022] = None
    """
    I. Ergänzende Angaben zu Umsätzen.
    """


    # @ApiMember(Description="J. Abziehbare Vorsteuerbeträge", Name="AbzVoSt")
    abz_vo_st: Optional[AbzVoSt2022] = None
    """
    J. Abziehbare Vorsteuerbeträge
    """


    # @ApiMember(Description="K. Berichtigung des Vorsteuerabzugs (§ 15a UStG)", Name="BerVoSt15a")
    ber_vo_st15a: Optional[BerVoSt15a2022] = None
    """
    K. Berichtigung des Vorsteuerabzugs (§ 15a UStG)
    """


    # @ApiMember(Description="L. Berechnung der zu entrichtenden Umsatzsteuer", Name="BerechUSt")
    berech_u_st: Optional[BerechUSt2022] = None
    """
    L. Berechnung der zu entrichtenden Umsatzsteuer
    """


    # @ApiMember(Description="Anlage UN zur Umsatzsteuererklärung für im Ausland ansässige Unternehmer")
    un: Optional[UN2022] = None
    """
    Anlage UN zur Umsatzsteuererklärung für im Ausland ansässige Unternehmer
    """


    # @ApiMember(Description="Anlage FV zur Umsatzsteuererklärung $VZ$")
    fv: Optional[FV2022] = None
    """
    Anlage FV zur Umsatzsteuererklärung $VZ$
    """


    # @ApiMember(Description="Unterfalllarten für die verschiedenen Verfahren.")
    unterfallart: Optional[UnterfallartTyp] = None
    """
    Unterfalllarten für die verschiedenen Verfahren.
    """


    # @ApiMember(Description="Der Vorgang bei einer Veranlagung.")
    vorgang: Optional[VeranlagungVorgangTyp] = None
    """
    Der Vorgang bei einer Veranlagung.
    """


    # @ApiMember(Description="Die Steuernummer. Bundeseinheitliche 13-stellige Steuernummer im ELSTER-Steuernummernformat")
    st_nr: Optional[StringTyp] = None
    """
    Die Steuernummer. Bundeseinheitliche 13-stellige Steuernummer im ELSTER-Steuernummernformat
    """


    # @ApiMember(Description="Ordnungsbegriff")
    ordnungsbegriff: Optional[StringTyp] = None
    """
    Ordnungsbegriff
    """


    # @ApiMember(Description="Identifikationsnummer steuerpflichtige Person / Ehemann / Person A")
    id: Optional[StringTyp] = None
    """
    Identifikationsnummer steuerpflichtige Person / Ehemann / Person A
    """


    # @ApiMember(Description="Identifikationsnummer Ehefrau / Person B")
    id_ehefrau: Optional[StringTyp] = None
    """
    Identifikationsnummer Ehefrau / Person B
    """


    # @ApiMember(Description="Name, alphanumerisch, max. 45-stellig.")
    abs_name: Optional[StringTyp] = None
    """
    Name, alphanumerisch, max. 45-stellig.
    """


    # @ApiMember(Description="Straße und Hausnummer, alphanumerisch, max. 30-stellig.")
    abs_str: Optional[StringTyp] = None
    """
    Straße und Hausnummer, alphanumerisch, max. 30-stellig.
    """


    # @ApiMember(Description="Postleitzahl des Absenders der Erklärung, numerisch, 5-stellig.")
    abs_plz: Optional[StringTyp] = None
    """
    Postleitzahl des Absenders der Erklärung, numerisch, 5-stellig.
    """


    # @ApiMember(Description="Ort, alphanumerisch, max. 29-stellig.")
    abs_ort: Optional[StringTyp] = None
    """
    Ort, alphanumerisch, max. 29-stellig.
    """


    # @ApiMember(Description="Copyrightmeldung des SW-Herstellers, alphanumerisch, max.50-stellig")
    copyright: Optional[StringTyp] = None
    """
    Copyrightmeldung des SW-Herstellers, alphanumerisch, max.50-stellig
    """


    # @ApiMember(Description="TeleNummer (für finanzamtsinterne Zwecke; keine Eingabe durch Anwender)")
    tele_nummer: Optional[StringTyp] = None
    """
    TeleNummer (für finanzamtsinterne Zwecke; keine Eingabe durch Anwender)
    """


    # @ApiMember(Description="Die Art des ermittelten Ordnungsbegriffs zu füllen.")
    ord_nr_art: Optional[OrdNrArtTyp] = None
    """
    Die Art des ermittelten Ordnungsbegriffs zu füllen.
    """


    # @ApiMember(Description="Die zur Abholung notwendigen Informationen werden hier angegeben.")
    rueckuebermittlung: Optional[E50Rueckuebermittlung] = None
    """
    Die zur Abholung notwendigen Informationen werden hier angegeben.
    """


    # @ApiMember(Description="The four-digit federal tax office number of the receiving tax office.", IsRequired=true, Name="Bundesfinanzamtsnummer")
    bundesfinanzamtsnummer: Optional[str] = None
    """
    The four-digit federal tax office number of the receiving tax office.
    """


    # @ApiMember(Description="The details of the provider that submits the tax data.", IsRequired=true, Name="DatenLieferant")
    daten_lieferant: Optional[str] = None
    """
    The details of the provider that submits the tax data.
    """


    # @ApiMember(Description="Should the PDF file be prepared for a double-sided printout with a margin for punching?.  True: The straight sides are indented to the left for a stitching margin for punching. False: There is no indentation of the straight sides. The created PDF is only intended for printing pages page by page.", Name="DuplexDruck")
    duplex_druck: Optional[bool] = None
    """
    Should the PDF file be prepared for a double-sided printout with a margin for punching?.  True: The straight sides are indented to the left for a stitching margin for punching. False: There is no indentation of the straight sides. The created PDF is only intended for printing pages page by page.
    """


    # @ApiMember(Description="Name prefix of the generated transfer protocol file.", IsRequired=true, Name="ProtocolPrefix")
    protocol_prefix: Optional[str] = None
    """
    Name prefix of the generated transfer protocol file.
    """


    # @ApiMember(Description="Footer text to be used on the printout (optional).", Name="FussText")
    fuss_text: Optional[str] = None
    """
    Footer text to be used on the printout (optional).
    """


    # @ApiMember(Description="The authentification certificate.", IsRequired=true, Name="Zertifikat")
    zertifikat: Optional[PortalCertificate] = None
    """
    The authentification certificate.
    """
    @staticmethod
    def response_type(): return BearbeiteVorgangResponse


# @Api(Description="Specifies a service response from an ERiC service operation.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class ServiceReponseBase(IHasIndex):
    """
    Specifies a service response from an ERiC service operation.
    """

    # @ApiMember(Description="The unique identifier of the response.")
    id: Optional[str] = None
    """
    The unique identifier of the response.
    """


    # @ApiMember(Description="The position of the response element in an indexed collection.")
    index: int = 0
    """
    The position of the response element in an indexed collection.
    """


    # @ApiMember(Description="Metadata that contains structured error information on the service response.")
    response_status: Optional[ResponseStatus] = None
    """
    Metadata that contains structured error information on the service response.
    """


class EricFehlerCode(IntEnum):
    """
    Enumeration of ERiC API error codes.
    """

    ERIC_OK = 0
    ERIC_GLOBAL_UNKNOWN = 610001001
    ERIC_GLOBAL_PRUEF_FEHLER = 610001002
    ERIC_GLOBAL_HINWEISE = 610001003
    ERIC_GLOBAL_FEHLERMELDUNG_NICHT_VORHANDEN = 610001007
    ERIC_GLOBAL_KEINE_DATEN_VORHANDEN = 610001008
    ERIC_GLOBAL_NICHT_GENUEGEND_ARBEITSSPEICHER = 610001013
    ERIC_GLOBAL_DATEI_NICHT_GEFUNDEN = 610001014
    ERIC_GLOBAL_HERSTELLER_ID_NICHT_ERLAUBT = 610001016
    ERIC_GLOBAL_ILLEGAL_STATE = 610001017
    ERIC_GLOBAL_FUNKTION_NICHT_ERLAUBT = 610001018
    ERIC_GLOBAL_ECHTFALL_NICHT_ERLAUBT = 610001019
    ERIC_GLOBAL_NO_VERSAND_IN_BETA_VERSION = 610001020
    ERIC_GLOBAL_TESTMERKER_UNGUELTIG = 610001025
    ERIC_GLOBAL_DATENSATZ_ZU_GROSS = 610001026
    ERIC_GLOBAL_VERSCHLUESSELUNGS_PARAMETER_NICHT_ERLAUBT = 610001027
    ERIC_GLOBAL_NUR_PORTALZERTIFIKAT_ERLAUBT = 610001028
    ERIC_GLOBAL_ERROR_XML_CREATE = 610001030
    ERIC_GLOBAL_TEXTPUFFERGROESSE_FIX = 610001031
    ERIC_GLOBAL_INTERNER_FEHLER = 610001032
    ERIC_GLOBAL_ARITHMETIKFEHLER = 610001033
    ERIC_GLOBAL_STEUERNUMMER_UNGUELTIG = 610001034
    ERIC_GLOBAL_STEUERNUMMER_FALSCHE_LAENGE = 610001035
    ERIC_GLOBAL_STEUERNUMMER_NICHT_NUMERISCH = 610001036
    ERIC_GLOBAL_LANDESNUMMER_UNBEKANNT = 610001037
    ERIC_GLOBAL_BUFANR_UNBEKANNT = 610001038
    ERIC_GLOBAL_LANDESNUMMER_BUFANR = 610001039
    ERIC_GLOBAL_PUFFER_ZUGRIFFSKONFLIKT = 610001040
    ERIC_GLOBAL_PUFFER_UEBERLAUF = 610001041
    ERIC_GLOBAL_DATENARTVERSION_UNBEKANNT = 610001042
    ERIC_GLOBAL_DATENARTVERSION_XML_INKONSISTENT = 610001044
    ERIC_GLOBAL_COMMONDATA_NICHT_VERFUEGBAR = 610001045
    ERIC_GLOBAL_LOG_EXCEPTION = 610001046
    ERIC_GLOBAL_TRANSPORTSCHLUESSEL_NICHT_ERLAUBT = 610001047
    ERIC_GLOBAL_OEFFENTLICHER_SCHLUESSEL_UNGUELTIG = 610001048
    ERIC_GLOBAL_TRANSPORTSCHLUESSEL_TYP_FALSCH = 610001049
    ERIC_GLOBAL_PUFFER_UNGLEICHER_INSTANZ = 610001050
    ERIC_GLOBAL_VORSATZ_UNGUELTIG = 610001051
    ERIC_GLOBAL_DATEIZUGRIFF_VERWEIGERT = 610001053
    ERIC_GLOBAL_UNGUELTIGE_INSTANZ = 610001080
    ERIC_GLOBAL_NICHT_INITIALISIERT = 610001081
    ERIC_GLOBAL_MEHRFACHE_INITIALISIERUNG = 610001082
    ERIC_GLOBAL_FEHLER_INITIALISIERUNG = 610001083
    ERIC_GLOBAL_UNKNOWN_PARAMETER_ERROR = 610001102
    ERIC_GLOBAL_CHECK_CORRUPTED_NDS = 610001108
    ERIC_GLOBAL_VERSCHLUESSELUNGS_PARAMETER_NICHT_ANGEGEBEN = 610001206
    ERIC_GLOBAL_SEND_FLAG_MEHR_ALS_EINES = 610001209
    ERIC_GLOBAL_UNGUELTIGE_FLAG_KOMBINATION = 610001218
    ERIC_GLOBAL_UNGUELTIGER_PARAMETER = 610001222
    ERIC_GLOBAL_DRUCK_FUER_VERFAHREN_NICHT_ERLAUBT = 610001224
    ERIC_GLOBAL_VERSAND_ART_NICHT_UNTERSTUETZT = 610001225
    ERIC_GLOBAL_UNGUELTIGE_PARAMETER_VERSION = 610001226
    ERIC_GLOBAL_TRANSFERHANDLE = 610001227
    ERIC_GLOBAL_PLUGININITIALISIERUNG = 610001228
    ERIC_GLOBAL_INKOMPATIBLE_VERSIONEN = 610001229
    ERIC_GLOBAL_VERSCHLUESSELUNGSVERFAHREN_NICHT_UNTERSTUETZT = 610001230
    ERIC_GLOBAL_MEHRFACHAUFRUFE_NICHT_UNTERSTUETZT = 610001231
    ERIC_GLOBAL_UTI_COUNTRY_NOT_SUPPORTED = 610001404
    ERIC_GLOBAL_IBAN_FORMALER_FEHLER = 610001501
    ERIC_GLOBAL_IBAN_LAENDERCODE_FEHLER = 610001502
    ERIC_GLOBAL_IBAN_LANDESFORMAT_FEHLER = 610001503
    ERIC_GLOBAL_IBAN_PRUEFZIFFER_FEHLER = 610001504
    ERIC_GLOBAL_BIC_FORMALER_FEHLER = 610001510
    ERIC_GLOBAL_BIC_LAENDERCODE_FEHLER = 610001511
    ERIC_GLOBAL_ZULASSUNGSNUMMER_ZU_LANG = 610001519
    ERIC_GLOBAL_IDNUMMER_UNGUELTIG = 610001525
    ERIC_GLOBAL_NULL_PARAMETER = 610001526
    ERIC_GLOBAL_EWAZ_UNGUELTIG = 610001527
    ERIC_GLOBAL_EWAZ_LANDESKUERZEL_UNBEKANNT = 610001528
    ERIC_GLOBAL_UPDATE_NECESSARY = 610001851
    ERIC_GLOBAL_EINSTELLUNG_NAME_UNGUELTIG = 610001860
    ERIC_GLOBAL_EINSTELLUNG_WERT_UNGUELTIG = 610001861
    ERIC_GLOBAL_ERR_DEKODIEREN = 610001862
    ERIC_GLOBAL_FUNKTION_NICHT_UNTERSTUETZT = 610001863
    ERIC_GLOBAL_NUTZDATENTICKETS_NICHT_EINDEUTIG = 610001865
    ERIC_GLOBAL_NUTZDATENHEADERVERSIONEN_UNEINHEITLICH = 610001866
    ERIC_GLOBAL_BUNDESLAENDER_UNEINHEITLICH = 610001867
    ERIC_GLOBAL_ZEITRAEUME_UNEINHEITLICH = 610001868
    ERIC_GLOBAL_NUTZDATENHEADER_EMPFAENGER_NICHT_KORREKT = 610001869
    ERIC_TRANSFER_COM_ERROR = 610101200
    ERIC_TRANSFER_VORGANG_NICHT_UNTERSTUETZT = 610101201
    ERIC_TRANSFER_ERR_XML_THEADER = 610101210
    ERIC_TRANSFER_ERR_PARAM = 610101251
    ERIC_TRANSFER_ERR_DATENTEILENDNOTFOUND = 610101253
    ERIC_TRANSFER_ERR_BEGINDATENLIEFERANT = 610101255
    ERIC_TRANSFER_ERR_ENDDATENLIEFERANT = 610101256
    ERIC_TRANSFER_ERR_BEGINTRANSPORTSCHLUESSEL = 610101257
    ERIC_TRANSFER_ERR_ENDTRANSPORTSCHLUESSEL = 610101258
    ERIC_TRANSFER_ERR_BEGINDATENGROESSE = 610101259
    ERIC_TRANSFER_ERR_ENDDATENGROESSE = 610101260
    ERIC_TRANSFER_ERR_SEND = 610101271
    ERIC_TRANSFER_ERR_NOTENCRYPTED = 610101274
    ERIC_TRANSFER_ERR_PROXYCONNECT = 610101276
    ERIC_TRANSFER_ERR_CONNECTSERVER = 610101278
    ERIC_TRANSFER_ERR_NORESPONSE = 610101279
    ERIC_TRANSFER_ERR_PROXYAUTH = 610101280
    ERIC_TRANSFER_ERR_SEND_INIT = 610101282
    ERIC_TRANSFER_ERR_TIMEOUT = 610101283
    ERIC_TRANSFER_ERR_PROXYPORT_INVALID = 610101284
    ERIC_TRANSFER_ERR_OTHER = 610101291
    ERIC_TRANSFER_ERR_XML_NHEADER = 610101292
    ERIC_TRANSFER_ERR_XML_ENCODING = 610101293
    ERIC_TRANSFER_ERR_ENDSIGUSER = 610101294
    ERIC_TRANSFER_ERR_XMLTAG_NICHT_GEFUNDEN = 610101295
    ERIC_TRANSFER_ERR_DATENTEILFEHLER = 610101297
    ERIC_TRANSFER_EID_ZERTIFIKATFEHLER = 610101500
    ERIC_TRANSFER_EID_KEINKONTO = 610101510
    ERIC_TRANSFER_EID_IDNRNICHTEINDEUTIG = 610101511
    ERIC_TRANSFER_EID_SERVERFEHLER = 610101512
    ERIC_TRANSFER_EID_KEINCLIENT = 610101520
    ERIC_TRANSFER_EID_CLIENTFEHLER = 610101521
    ERIC_TRANSFER_EID_FEHLENDEFELDER = 610101522
    ERIC_TRANSFER_EID_IDENTIFIKATIONABGEBROCHEN = 610101523
    ERIC_TRANSFER_EID_NPABLOCKIERT = 610101524
    ERIC_CRYPT_ERROR_CREATE_KEY = 610201016
    ERIC_CRYPT_E_INVALID_HANDLE = 610201101
    ERIC_CRYPT_E_MAX_SESSION = 610201102
    ERIC_CRYPT_E_BUSY = 610201103
    ERIC_CRYPT_E_OUT_OF_MEM = 610201104
    ERIC_CRYPT_E_PSE_PATH = 610201105
    ERIC_CRYPT_E_PIN_WRONG = 610201106
    ERIC_CRYPT_E_PIN_LOCKED = 610201107
    ERIC_CRYPT_E_P7_READ = 610201108
    ERIC_CRYPT_E_P7_DECODE = 610201109
    ERIC_CRYPT_E_P7_RECIPIENT = 610201110
    ERIC_CRYPT_E_P12_READ = 610201111
    ERIC_CRYPT_E_P12_DECODE = 610201112
    ERIC_CRYPT_E_P12_SIG_KEY = 610201113
    ERIC_CRYPT_E_P12_ENC_KEY = 610201114
    ERIC_CRYPT_E_P11_SIG_KEY = 610201115
    ERIC_CRYPT_E_P11_ENC_KEY = 610201116
    ERIC_CRYPT_E_XML_PARSE = 610201117
    ERIC_CRYPT_E_XML_SIG_ADD = 610201118
    ERIC_CRYPT_E_XML_SIG_TAG = 610201119
    ERIC_CRYPT_E_XML_SIG_SIGN = 610201120
    ERIC_CRYPT_E_ENCODE_UNKNOWN = 610201121
    ERIC_CRYPT_E_ENCODE_ERROR = 610201122
    ERIC_CRYPT_E_XML_INIT = 610201123
    ERIC_CRYPT_E_ENCRYPT = 610201124
    ERIC_CRYPT_E_DECRYPT = 610201125
    ERIC_CRYPT_E_P11_SLOT_EMPTY = 610201126
    ERIC_CRYPT_E_NO_SIG_ENC_KEY = 610201127
    ERIC_CRYPT_E_LOAD_DLL = 610201128
    ERIC_CRYPT_E_NO_SERVICE = 610201129
    ERIC_CRYPT_E_ESICL_EXCEPTION = 610201130
    ERIC_CRYPT_E_ESIGNER_NICHT_GELADEN = 610201140
    ERIC_CRYPT_E_INKOMPATIBLE_ESIGNER_VERSION = 610201141
    ERIC_CRYPT_E_VERALTETE_ESIGNER_VERSION = 610201142
    ERIC_CRYPT_E_TOKEN_TYPE_MISMATCH = 610201144
    ERIC_CRYPT_E_P12_CREATE = 610201146
    ERIC_CRYPT_E_VERIFY_CERT_CHAIN = 610201147
    ERIC_CRYPT_E_P11_ENGINE_LOADED = 610201148
    ERIC_CRYPT_E_USER_CANCEL = 610201149
    ERIC_CRYPT_ZERTIFIKAT = 610201200
    ERIC_CRYPT_SIGNATUR = 610201201
    ERIC_CRYPT_NICHT_UNTERSTUETZTES_PSE_FORMAT = 610201203
    ERIC_CRYPT_PIN_BENOETIGT = 610201205
    ERIC_CRYPT_PIN_STAERKE_NICHT_AUSREICHEND = 610201206
    ERIC_CRYPT_E_INTERN = 610201208
    ERIC_CRYPT_ZERTIFIKATSPFAD_KEIN_VERZEICHNIS = 610201209
    ERIC_CRYPT_ZERTIFIKATSDATEI_EXISTIERT_BEREITS = 610201210
    ERIC_CRYPT_PIN_ENTHAELT_UNGUELTIGE_ZEICHEN = 610201211
    ERIC_CRYPT_CORRUPTED = 610201213
    ERIC_CRYPT_EIDKARTE_NICHT_UNTERSTUETZT = 610201214
    ERIC_CRYPT_E_SC_SLOT_EMPTY = 610201215
    ERIC_CRYPT_E_SC_NO_APPLET = 610201216
    ERIC_CRYPT_E_SC_SESSION = 610201217
    ERIC_CRYPT_E_P11_NO_SIG_CERT = 610201218
    ERIC_CRYPT_E_P11_INIT_FAILED = 610201219
    ERIC_CRYPT_E_P11_NO_ENC_CERT = 610201220
    ERIC_CRYPT_E_P12_NO_SIG_CERT = 610201221
    ERIC_CRYPT_E_P12_NO_ENC_CERT = 610201222
    ERIC_CRYPT_E_SC_ENC_KEY = 610201223
    ERIC_CRYPT_E_SC_NO_SIG_CERT = 610201224
    ERIC_CRYPT_E_SC_NO_ENC_CERT = 610201225
    ERIC_CRYPT_E_SC_INIT_FAILED = 610201226
    ERIC_CRYPT_E_SC_SIG_KEY = 610201227
    ERIC_CRYPT_E_DATA_NOT_INITIALIZED = 610201228
    ERIC_CRYPT_E_ASN1_READ_BUFFER_TOO_SMALL = 610201229
    ERIC_CRYPT_E_ASN1_READ_DATA_INCOMPLETE = 610201230
    ERIC_CRYPT_E_ASN1_NO_ENVELOPED_DATA = 610201231
    ERIC_CRYPT_E_ASN1_NO_CONTENT_DATA = 610201232
    ERIC_IO_FEHLER = 610301001
    ERIC_IO_DATEI_INKORREKT = 610301005
    ERIC_IO_PARSE_FEHLER = 610301006
    ERIC_IO_NDS_GENERIERUNG_FEHLGESCHLAGEN = 610301007
    ERIC_IO_MASTERDATENSERVICE_NICHT_VERFUEGBAR = 610301010
    ERIC_IO_STEUERZEICHEN_IM_NDS = 610301014
    ERIC_IO_VERSIONSINFORMATIONEN_NICHT_GEFUNDEN = 610301031
    ERIC_IO_FALSCHES_VERFAHREN = 610301104
    ERIC_IO_READER_MEHRFACHE_STEUERFAELLE = 610301105
    ERIC_IO_READER_UNERWARTETE_ELEMENTE = 610301106
    ERIC_IO_READER_FORMALE_FEHLER = 610301107
    ERIC_IO_READER_FALSCHES_ENCODING = 610301108
    ERIC_IO_READER_MEHRFACHE_NUTZDATEN_ELEMENTE = 610301109
    ERIC_IO_READER_MEHRFACHE_NUTZDATENBLOCK_ELEMENTE = 610301110
    ERIC_IO_UNBEKANNTE_DATENART = 610301111
    ERIC_IO_READER_UNTERSACHBEREICH_UNGUELTIG = 610301114
    ERIC_IO_READER_ZU_VIELE_NUTZDATENBLOCK_ELEMENTE = 610301115
    ERIC_IO_READER_STEUERZEICHEN_IM_TRANSFERHEADER = 610301150
    ERIC_IO_READER_STEUERZEICHEN_IM_NUTZDATENHEADER = 610301151
    ERIC_IO_READER_STEUERZEICHEN_IN_DEN_NUTZDATEN = 610301152
    ERIC_IO_READER_RABE_FEHLER = 610301170
    ERIC_IO_READER_KEINE_RABEID = 610301171
    ERIC_IO_READER_RABEID_UNGUELTIG = 610301172
    ERIC_IO_READER_RABE_VERIFIKATIONSID_UNGUELTIG = 610301173
    ERIC_IO_READER_RABE_REFERENZID_UNGUELTIG = 610301174
    ERIC_IO_READER_RABE_REFERENZID_NICHT_ERLAUBT = 610301175
    ERIC_IO_READER_RABE_REFERENZIDS_NICHT_EINDEUTIG = 610301176
    ERIC_IO_READER_ZU_VIELE_ANHAENGE = 610301190
    ERIC_IO_READER_ANHANG_ZU_GROSS = 610301191
    ERIC_IO_READER_ANHAENGE_ZU_GROSS = 610301192
    ERIC_IO_READER_ANHANG_ZU_KLEIN = 610301193
    ERIC_IO_READER_SCHEMA_VALIDIERUNGSFEHLER = 610301200
    ERIC_IO_READER_UNBEKANNTE_XML_ENTITY = 610301201
    ERIC_IO_TESTHERSTELLERID_GESPERRT = 610301202
    ERIC_IO_DATENTEILNOTFOUND = 610301252
    ERIC_IO_DATENTEILENDNOTFOUND = 610301253
    ERIC_IO_UEBERGABEPARAMETER_FEHLERHAFT = 610301300
    ERIC_IO_UNGUELTIGE_UTF8_SEQUENZ = 610301400
    ERIC_IO_UNGUELTIGE_ZEICHEN_IN_PARAMETER = 610301401
    ERIC_PRINT_INTERNER_FEHLER = 610501001
    ERIC_PRINT_DRUCKVORLAGE_NICHT_GEFUNDEN = 610501002
    ERIC_PRINT_UNGUELTIGER_DATEI_PFAD = 610501004
    ERIC_PRINT_INITIALISIERUNG_FEHLERHAFT = 610501007
    ERIC_PRINT_AUSGABEZIEL_UNBEKANNT = 610501008
    ERIC_PRINT_ABBRUCH_DRUCKVORBEREITUNG = 610501009
    ERIC_PRINT_ABBRUCH_GENERIERUNG = 610501010
    ERIC_PRINT_STEUERFALL_NICHT_UNTERSTUETZT = 610501011
    ERIC_PRINT_FUSSTEXT_ZU_LANG = 610501012
    ERIC_PRINT_PDFCALLBACK = 610501015


# @Api(Description="Represent a base response that encapsulate any ERiC API function return value.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class EricFehlerCodeResponse(ServiceReponseBase):
    """
    Represent a base response that encapsulate any ERiC API function return value.
    """

    # @ApiMember(Description="The status code that the ERiC API function returns.")
    status_code: Optional[EricFehlerCode] = None
    """
    The status code that the ERiC API function returns.
    """


    # @ApiMember(Description="The status message that the ERiC API function returns.")
    status_text: Optional[str] = None
    """
    The status message that the ERiC API function returns.
    """


# @Api(Description="Represents information returned from a successful tax declaration process.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Erfolg:
    """
    Represents information returned from a successful tax declaration process.
    """

    # @ApiMember(Description="The generated tele-number for the successful tax declaration process.")
    telenummer: List[str] = field(default_factory=list)
    """
    The generated tele-number for the successful tax declaration process.
    """


    # @ApiMember(Description="The classification key for the successful tax declaration process.")
    ordnungsbegriffe: List[str] = field(default_factory=list)
    """
    The classification key for the successful tax declaration process.
    """


# @Api(Description="Represents information on the delivery.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Transfer:
    """
    Represents information on the delivery.
    """

    # @ApiMember(Description="The ticket of the transfer.")
    transfer_ticket: Optional[str] = None
    """
    The ticket of the transfer.
    """


# @Api(Description="Represents information on all data deliveries, including deliveries that have not been confirmed by the server. For more information, see the ERiC developer manual in the 'TransferTicket' section.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Transfers:
    """
    Represents information on all data deliveries, including deliveries that have not been confirmed by the server. For more information, see the ERiC developer manual in the 'TransferTicket' section.
    """

    # @ApiMember(Description="Contains information on all data deliveries, including deliveries that have not been confirmed by the server.")
    transfer_list: List[Transfer] = field(default_factory=list)
    """
    Contains information on all data deliveries, including deliveries that have not been confirmed by the server.
    """


# @Api(Description="Represents value of an index field, which identfies the context about an error message.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class SemantischerIndex:
    """
    Represents value of an index field, which identfies the context about an error message.
    """

    # @ApiMember(Description="The name of the index field.")
    name: Optional[str] = None
    """
    The name of the index field.
    """


    # @ApiMember(Description="The value of the index field.")
    value: Optional[str] = None
    """
    The value of the index field.
    """


# @Api(Description="Represents information on an ERiC reference.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class FehlerRegelpruefung:
    """
    Represents information on an ERiC reference.
    """

    # @ApiMember(Description="The user data ticket of the reference.")
    nutzdatenticket: Optional[str] = None
    """
    The user data ticket of the reference.
    """


    # @ApiMember(Description="The field identifier of the reference.")
    feldidentifikator: Optional[str] = None
    """
    The field identifier of the reference.
    """


    # @ApiMember(Description="The multi-line index of the reference.")
    mehrfachzeilenindex: Optional[str] = None
    """
    The multi-line index of the reference.
    """


    # @ApiMember(Description="The delivery number form of the reference.")
    lfd_nr_vordruck: Optional[str] = None
    """
    The delivery number form of the reference.
    """


    # @ApiMember(Description="Indicates the line number of the error field mentioned in the form.")
    vordruck_zeilennummer: Optional[str] = None
    """
    Indicates the line number of the error field mentioned in the form.
    """


    # @ApiMember(Description="Specifies the value of one or more index fields that identify the context of error messages.")
    semantische_indexes: List[SemantischerIndex] = field(default_factory=list)
    """
    Specifies the value of one or more index fields that identify the context of error messages.
    """


    # @ApiMember(Description="The sub-subject-area of the reference.")
    untersachbereich: Optional[str] = None
    """
    The sub-subject-area of the reference.
    """


    # @ApiMember(Description="The private identification number of the reference.")
    private_kennnummer: Optional[str] = None
    """
    The private identification number of the reference.
    """


    # @ApiMember(Description="The name of the rule that applies to the reference.")
    regel_name: Optional[str] = None
    """
    The name of the rule that applies to the reference.
    """


    # @ApiMember(Description="The technical error identifier of the reference.")
    fachliche_fehler_id: Optional[str] = None
    """
    The technical error identifier of the reference.
    """


    # @ApiMember(Description="The textual details of the reference.")
    text: Optional[str] = None
    """
    The textual details of the reference.
    """


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Hinweis:
    # @ApiMember(Description="The user data ticket of the reference.")
    nutzdatenticket: Optional[str] = None
    """
    The user data ticket of the reference.
    """


    # @ApiMember(Description="The field identifier of the reference.")
    feldidentifikator: Optional[str] = None
    """
    The field identifier of the reference.
    """


    # @ApiMember(Description="The multi-line index of the reference.")
    mehrfachzeilenindex: Optional[str] = None
    """
    The multi-line index of the reference.
    """


    # @ApiMember(Description="The delivery number form of the reference.")
    lfd_nr_vordruck: Optional[str] = None
    """
    The delivery number form of the reference.
    """


    # @ApiMember(Description="Indicates the line number of the error field mentioned in the form.")
    vordruck_zeilennummer: Optional[str] = None
    """
    Indicates the line number of the error field mentioned in the form.
    """


    # @ApiMember(Description="Specifies the value of one or more index fields that identify the context of error messages.")
    semantische_indexes: List[SemantischerIndex] = field(default_factory=list)
    """
    Specifies the value of one or more index fields that identify the context of error messages.
    """


    # @ApiMember(Description="The sub-subject-area of the reference.")
    untersachbereich: Optional[str] = None
    """
    The sub-subject-area of the reference.
    """


    # @ApiMember(Description="The private identification number of the reference.")
    private_kennnummer: Optional[str] = None
    """
    The private identification number of the reference.
    """


    # @ApiMember(Description="The name of the rule that applies to the reference.")
    regel_name: Optional[str] = None
    """
    The name of the rule that applies to the reference.
    """


    # @ApiMember(Description="The technical note identifier of the reference.")
    fachliche_hinweis_id: Optional[str] = None
    """
    The technical note identifier of the reference.
    """


    # @ApiMember(Description="The textual details of the reference.")
    text: Optional[str] = None
    """
    The textual details of the reference.
    """


# @Api(Description="Represents a structure that contains the first output of the ERiC tax data submission process.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class EricBearbeiteVorgang:
    """
    Represents a structure that contains the first output of the ERiC tax data submission process.
    """

    # @ApiMember(Description="Information from the successful processing a tax declaration.")
    erfolg: Optional[Erfolg] = None
    """
    Information from the successful processing a tax declaration.
    """


    # @ApiMember(Description="Gets or sets information on all data deliveries, including deliveries that have not been confirmed by the server.")
    transfers: Optional[Transfers] = None
    """
    Gets or sets information on all data deliveries, including deliveries that have not been confirmed by the server.
    """


    # @ApiMember(Description="Error rules that result from the processing of a tax declaration.")
    fehler_regelpruefungen: List[FehlerRegelpruefung] = field(default_factory=list)
    """
    Error rules that result from the processing of a tax declaration.
    """


    # @ApiMember(Description="Hints that result the processing of a tax declaration.")
    hinweise: List[Hinweis] = field(default_factory=list)
    """
    Hints that result the processing of a tax declaration.
    """


class Verfahren(str, Enum):
    """
    Enumeration of valid procedures
    """

    ELSTER_ANMELDUNG = 'ElsterAnmeldung'
    ELSTER_BEREITSTELLUNG = 'ElsterBereitstellung'
    ELSTER_BILANZ = 'ElsterBilanz'
    ELSTER_B_R_M = 'ElsterBRM'
    ELSTER_B_R_M_ORG = 'ElsterBRMOrg'
    ELSTER_DATENABHOLUNG = 'ElsterDatenabholung'
    ELSTER_ERKLAERUNG = 'ElsterErklaerung'
    ELSTER_EXTERN = 'ElsterExtern'
    ELSTER_F_S_E = 'ElsterFSE'
    ELSTER_KAP_E_ST = 'ElsterKapESt'
    ELSTER_K_M_V = 'ElsterKMV'
    ELSTER_KONTOABFRAGE = 'ElsterKontoabfrage'
    ELSTER_LAVENDEL = 'ElsterLavendel'
    ELSTER_LOHN = 'ElsterLohn'
    ELSTER_LOHN2 = 'ElsterLohn2'
    ELSTER_NACHRICHT = 'ElsterNachricht'
    ELSTER_SIGNATUR = 'ElsterSignatur'
    ELSTER_VOLLMACHT_D_B = 'ElsterVollmachtDB'


class Datenart(str, Enum):
    """
    Enumeration of all valid data types.
    """

    ABRUFCODE_ANTRAG = 'AbrufcodeAntrag'
    ABRUFCODE_STORNO = 'AbrufcodeStorno'
    ABRUFVOLLMACHT_ANLAGE = 'AbrufvollmachtAnlage'
    ABRUFVOLLMACHT_UPDATE = 'AbrufvollmachtUpdate'
    AENDERUNG_ADRESSE = 'AenderungAdresse'
    AENDERUNG_BANKVERBINDUNG = 'AenderungBankverbindung'
    ANLAGE34A = 'Anlage34a'
    ANPASSUNG_VORAUSZAHLUNG = 'AnpassungVorauszahlung'
    ANTRAEGE_RECHTE_LOESCHEN = 'AntraegeRechteLoeschen'
    ANTRAEGE_UND_RECHTE = 'AntraegeUndRechte'
    ANTR_ANSAESSIGKEIT_BESCH = 'AntrAnsaessigkeitBesch'
    ANTRAG_U_ST_VERGUETUNG4A = 'AntragUStVerguetung4a'
    A_ST_G_H_Z_B = 'AStGHZB'
    AUFZEICHNUNG146A = 'Aufzeichnung146a'
    BAULEISTUNG_ST_AB_ANMELDUNG = 'BauleistungStAbAnmeldung'
    BAULEISTUNG_ST_AB_ERSTATTUNG = 'BauleistungStAbErstattung'
    BELEGNACHREICHUNG = 'Belegnachreichung'
    BET_P_G = 'BetPG'
    BILANZ = 'Bilanz'
    BSB_MITTEILUNG = 'BSBMitteilung'
    BZ_ST2 = 'BZSt2'
    C19_MITTEILUNG = 'C19Mitteilung'
    DIVA_DATEN_B_Z_ST = 'DIVADatenBZSt'
    DIVA_ERGEBNISLISTE = 'DivaErgebnisliste'
    DIVA_EINWILLIGUNG_ANLAGE_B_R_M = 'DivaEinwilligungAnlageBRM'
    DIVA_EINWILLIGUNG_FREISCH = 'DivaEinwilligungFreisch'
    DIVA_EINWILLIGUNG_UPDATE_B_R_M = 'DivaEinwilligungUpdateBRM'
    DIVA_WIDERRUF_B_R_M = 'DivaWiderrufBRM'
    D_UE_ABMELDEN = 'DUeAbmelden'
    D_UE_ANMELDEN = 'DUeAnmelden'
    D_UE_UMMELDEN = 'DUeUmmelden'
    EINSPRUCH = 'Einspruch'
    EINSPRUCH_NACHTRAG = 'EinspruchNachtrag'
    EINSPRUCH_RUECKNAHME = 'EinspruchRuecknahme'
    E_LE_V_ANTRAG_E_L_ST_A_M = 'ELeVAntragELStAM'
    E_LE_V_ERMAESSIGUNG = 'ELeVErmaessigung'
    E_LE_V_GETRENNTLEBEND = 'ELeVGetrenntlebend'
    E_LE_V_STEUERKLASSENWECHSEL = 'ELeVSteuerklassenwechsel'
    E_LE_V_WIEDERAUFNAHME_EHE = 'ELeVWiederaufnahmeEhe'
    ELSTER_D_I_V_A_DATEN = 'ElsterDIVADaten'
    ELSTER_D_I_V_DATEN = 'ElsterDIVDaten'
    ELSTER_E_P_BESCHEID_DATEN = 'ElsterEPBescheidDaten'
    ELSTER_E_P_MITTEILUNG_DATEN = 'ElsterEPMitteilungDaten'
    ELSTER_ERKLAERUNG_DATEN = 'ElsterErklaerungDaten'
    ELSTER_K_M_V_DATEN = 'ElsterKMVDaten'
    ELSTER_LOHN_DATEN = 'ElsterLohnDaten'
    ELSTER_LOHN2_DATEN = 'ElsterLohn2Daten'
    ELSTER_VA_ST_DATEN = 'ElsterVaStDaten'
    ELSTER_VOLLMACHT_DATEN = 'ElsterVollmachtDaten'
    EP_ANTWORT = 'EPAntwort'
    EP_BESCHEID = 'EPBescheid'
    EP_KURZMITTEILUNG = 'EPKurzmitteilung'
    EP_MITTEILUNG = 'EPMitteilung'
    EP_ST_BESCHEID_ABHOLUNG = 'EPStBescheidAbholung'
    EP_ST_MITTEILUNG_ABHOLUNG = 'EPStMitteilungAbholung'
    ERBSCHAFTSTEUER = 'Erbschaftsteuer'
    E_ST = 'ESt'
    E_STBESCHRAENKT = 'EStbeschraenkt'
    EUER = 'EUER'
    E_UN = 'EUn'
    FEIN = 'FEIN'
    FLH_MITTEILUNG = 'FLHMitteilung'
    FZL_MITTEILUNG = 'FZLMitteilung'
    FORSCHUNG_ZUL_ANTRAG = 'ForschungZulAntrag'
    FREISTELLUNG_KAPITALERTRAEGE_B_V = 'FreistellungKapitalertraegeBV'
    FRISTVERLAENGERUNG = 'Fristverlaengerung'
    FS_E_VEREIN = 'FsEVerein'
    GDB_MITTEILUNG = 'GDBMitteilung'
    GEWERBEMELDUNG = 'Gewerbemeldung'
    GEWINNERMITTLUNG13A_E_ST_G = 'Gewinnermittlung13aEStG'
    GEW_ST = 'GewSt'
    GEW_ST_Z = 'GewStZ'
    GRUNDSTEUER_AEND_A_Z = 'GrundsteuerAendAZ'
    GRUNDSTEUER_AEND_A_Z_B_W = 'GrundsteuerAendAZBW'
    GRUNDSTEUER_AEND_A_Z_B_Y = 'GrundsteuerAendAZBY'
    GRUNDSTEUER_AEND_A_Z_H_E = 'GrundsteuerAendAZHE'
    GRUNDSTEUER_AEND_A_Z_H_H = 'GrundsteuerAendAZHH'
    GRUNDSTEUER_AEND_A_Z_N_I = 'GrundsteuerAendAZNI'
    GRUNDSTEUER_B_W = 'GrundsteuerBW'
    GRUNDSTEUER_B_Y = 'GrundsteuerBY'
    GRUNDSTEUER_H_E = 'GrundsteuerHE'
    GRUNDSTEUER_H_H = 'GrundsteuerHH'
    GRUNDSTEUER_N_I = 'GrundsteuerNI'
    GRUNDSTEUERWERT = 'Grundsteuerwert'
    IBAN_MELDUNG = 'IBANMeldung'
    INV_ST_G51_FESTSTELLUNG = 'InvStG51Feststellung'
    INV_ST_G56_ABS5 = 'InvStG56Abs5'
    KAP_G = 'KapG'
    KAP_G_AUS = 'KapGAus'
    KAP_E_ST_A = 'KapEStA'
    KAP_E_ST_INV_ST_G = 'KapEStInvStG'
    KKV_MITTEILUNG = 'KKVMitteilung'
    KONTOABFRAGE = 'Kontoabfrage'
    KONTOINFORMATION = 'Kontoinformation'
    K_ST = 'KSt'
    K_ST_ANTRAG_EINLAGENRUECK = 'KStAntragEinlagenrueck'
    K_ST_ANTRAG_OPTION_PERS_G = 'KStAntragOptionPersG'
    K_ST_Z = 'KStZ'
    K_ST_ZERLEGUNG_V_Z = 'KStZerlegungVZ'
    KTT_ANMELDUNG_H_H = 'KTTAnmeldungHH'
    KTT_ANZEIGE_H_H = 'KTTAnzeigeHH'
    LOHNERSATZLEISTUNG = 'Lohnersatzleistung'
    LOHNERSATZ_MITTEILUNG = 'LohnersatzMitteilung'
    L_ST_A = 'LStA'
    L_ST_B = 'LStB'
    L_ST_H_V_DIVA_ADRESSE_B_R_M = 'LStHVDivaAdresseBRM'
    L_ST_H_V_V_M_ANLAGE = 'LStHVVMAnlage'
    L_ST_H_V_V_M_UPDATE = 'LStHVVMUpdate'
    LST_MITTEILUNG = 'LSTMitteilung'
    MINDEST_ST_UNTERNEHMEN_E_U = 'MindestStUnternehmenEU'
    MITTEILUNG_ABHOLUNG = 'MitteilungAbholung'
    MVO_MITTEILUNG = 'MVOMitteilung'
    MVZ_MITTEILUNG = 'MVZMitteilung'
    NEK_MITTEILUNG = 'NEKMitteilung'
    OGH_MITTEILUNG = 'OGHMitteilung'
    PERS_G = 'PersG'
    POSTFACH_ANFRAGE = 'PostfachAnfrage'
    POSTFACH_BESTAETIGUNG = 'PostfachBestaetigung'
    POSTFACH_STATUS = 'PostfachStatus'
    PROTOKOLL_ANFORDERUNG = 'ProtokollAnforderung'
    RABE_EXT_DATENHALTUNG_CHECK = 'RabeExtDatenhaltungCheck'
    RABE_EXT_DATENHALTUNG_PFLEGE = 'RabeExtDatenhaltungPflege'
    REGISTRIERUNG = 'Registrierung'
    SCHENKUNGSTEUER = 'Schenkungsteuer'
    SONSTIGE_NACHRICHTEN = 'SonstigeNachrichten'
    SPEZ_RECHT_ANTRAG = 'SpezRechtAntrag'
    SPEZ_RECHT_FREISCHALTUNG = 'SpezRechtFreischaltung'
    SPEZ_RECHT_LISTE = 'SpezRechtListe'
    SPEZ_RECHT_STORNO = 'SpezRechtStorno'
    SPEZ_RECHT_TEILNAHME = 'SpezRechtTeilnahme'
    ST_AB_S50A = 'StAbS50a'
    STATUSABFRAGE = 'Statusabfrage'
    STUNDUNG_ANTRAG = 'StundungAntrag'
    UENST_ANMELDUNG_B_E = 'UENSTAnmeldungBE'
    UENST_ANZEIGE_B_E = 'UENSTAnzeigeBE'
    UNENTGELTLICHE_DEPOTUEBERTRAGUNG = 'UnentgeltlicheDepotuebertragung'
    U_ST = 'USt'
    U_ST_A_KFZ_EINZEL = 'UStAKfzEinzel'
    U_ST_D_V = 'UStDV'
    U_ST_S_V = 'UStSV'
    U_ST_V_A = 'UStVA'
    VAG_MITTEILUNG = 'VAGMitteilung'
    VERMOEGENSWIRKSAME_LEISTUNG = 'VermoegenswirksameLeistung'
    VGN_ANMELDUNG_B_E = 'VGNAnmeldungBE'
    VGN_ANMELDUNG_H_B = 'VGNAnmeldungHB'
    VGN_ANMELDUNG_H_H = 'VGNAnmeldungHH'
    VGN_ANZEIGE_B_E = 'VGNAnzeigeBE'
    VGN_ANZEIGE_H_H = 'VGNAnzeigeHH'
    VM_ERGEBNIS_LISTE_V_N_SICHT = 'VMErgebnisListeVNSicht'
    V_MO_V_M_V_FREISCHALTUNG = 'VMoVMVFreischaltung'
    V_MO_V_M_V_ST_B_ANLAGE = 'VMoVMVStBAnlage'
    V_MO_V_M_V_ST_B_UPDATE = 'VMoVMVStBUpdate'
    VM_WIDERRUF = 'VMWiderruf'
    V_NO_V_M_V_LOESCHUNG = 'VNoVMVLoeschung'
    V_NO_V_M_V_REGISTRIERUNG = 'VNoVMVRegistrierung'
    V_NO_V_M_V_UPDATE = 'VNoVMVUpdate'
    VOLLF_A_ANLAGE = 'VollfAAnlage'
    VOLLF_A_UPDATE = 'VollfAUpdate'
    VOLLMACHT_DETAILS = 'VollmachtDetails'
    WTB_ANMELDUNG_H_B = 'WTBAnmeldungHB'
    ZMDO = 'ZMDO'
    ZUWENDUNGSBESTAETIGUNG = 'Zuwendungsbestaetigung'


class Vorgang(str, Enum):
    """
    Main information whether the data was authenticated (send-Auth) or not (send-NoSig)
    """

    SEND_AUTH = 'Send_Auth'
    SEND_AUTH_PART = 'Send_Auth_Part'
    SEND_NOSIG = 'Send_NoSig'


class Testmerker(IntEnum):
    """
    Marking of the data delivery whether it is a test case, applies to the entire data delivery. A real case does not contain this element. A test case must be marked with a test marker so that it is not processed like a real case. If the data was only sent for testing the frontend, it does not need to be processed further.
    """

    TM010000001 = 10000001
    TM080000001 = 80000001
    TM160000001 = 160000001
    TM160000002 = 160000002
    TM220000000 = 220000000
    TM220002000 = 220002000
    TM230000001 = 230000001
    TM240000000 = 240000000
    TM370000001 = 370000001
    TM520000000 = 520000000
    TM700000001 = 700000001
    TM700000004 = 700000004


# @Api(Description="Represents the signature and associated information of the compressed, encrypted, base64-encoded content of the data part of the tax declaration/statement.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class SigUser:
    """
    Represents the signature and associated information of the compressed, encrypted, base64-encoded content of the data part of the tax declaration/statement.
    """

    # @ApiMember(Description="The content of the data. Currently supported: Raw XML (text), XElement or IXmlSerializable")
    inhalt: Optional[Object] = None
    """
    The content of the data. Currently supported: Raw XML (text), XElement or IXmlSerializable
    """


class Bundesland(str, Enum):
    """
    Uniform abbreviations for the federal states or alternative recipients
    """

    BW = 'BW'
    BY = 'BY'
    BE = 'BE'
    BB = 'BB'
    HB = 'HB'
    HH = 'HH'
    HE = 'HE'
    MV = 'MV'
    NI = 'NI'
    NW = 'NW'
    RP = 'RP'
    SL = 'SL'
    SN = 'SN'
    ST = 'ST'
    SH = 'SH'
    TH = 'TH'
    EC = 'EC'
    BF = 'BF'
    CS = 'CS'
    CD = 'CD'
    CM = 'CM'
    CN = 'CN'
    DS = 'DS'
    OP = 'OP'
    TK = 'TK'
    ZF = 'ZF'


# @Api(Description="Represents a receiver of tax data.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Empfaenger:
    """
    Represents a receiver of tax data.
    """

    # @ApiMember(Description="The identifier of the receiver.", IsRequired=true)
    id: Optional[str] = None
    """
    The identifier of the receiver.
    """


    # @ApiMember(Description="The destination of the receiver.", IsRequired=true)
    ziel: Optional[Bundesland] = None
    """
    The destination of the receiver.
    """


class Verschluesselungsart(str, Enum):
    """
    Encryption protocol. Different encryption types may be used, a distinction is necessary here to control the correct decryption tool. With which encryption type were the contents of the elements 'DatenLieferant' and possibly 'SigUser' in the TransferHeader and the element 'DatenTeil' encrypted
    """

    PKCS_7V1_5 = 'PKCS_7v1_5'
    PKCS_7V1_5ENVELOPED = 'PKCS_7v1_5enveloped'
    NO_BASE64 = 'NO_BASE64'
    CMS_ENCRYPTED_DATA = 'CMSEncryptedData'
    CMS_ENVELOPED_DATA = 'CMSEnvelopedData'
    ENVELOPEDDATA__RSA_OAEP__AES_128__GZIP__B64 = 'EnvelopedData__RSA_OAEP__AES_128__GZip__B64'


class Kompression(str, Enum):
    """
    With which compression the contents of the elements 'DatenLieferant' and possibly 'SigUser' in the TransferHeader and the element DatenTeil were compressed.
    """

    GZIP = 'GZIP'
    NO_BASE64 = 'NO_BASE64'


# @Api(Description="[Documentation unavailable]")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class EricTyp:
    """
    [Documentation unavailable]
    """

    # @ApiMember(Description="The content of the data. Currently supported: Raw XML (text), XmlElement, XElement or IXmlSerializable")
    inhalt: Optional[Object] = None
    """
    The content of the data. Currently supported: Raw XML (text), XmlElement, XElement or IXmlSerializable
    """


# @Api(Description="[Documentation unavailable]")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Erstellung:
    """
    [Documentation unavailable]
    """

    # @ApiMember(Description="[Documentation unavailable]")
    eric: Optional[EricTyp] = None
    """
    [Documentation unavailable]
    """


# @Api(Description="Represents information on the encryption of tax data.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Datei:
    """
    Represents information on the encryption of tax data.
    """

    # @ApiMember(Description="The type of data encryption used.")
    verschluesselung: Optional[Verschluesselungsart] = None
    """
    The type of data encryption used.
    """


    # @ApiMember(Description="The type of data compression used.")
    kompression: Optional[Kompression] = None
    """
    The type of data compression used.
    """


    # @ApiMember(Description="The transport key used in the encryption.")
    transport_schluessel: Optional[str] = None
    """
    The transport key used in the encryption.
    """


    # @ApiMember(Description="[Documentation unavailable]")
    erstellung: Optional[Erstellung] = None
    """
    [Documentation unavailable]
    """


# @Api(Description="Represents an external error stack.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Rueckgabe:
    """
    Represents an external error stack.
    """

    # @ApiMember(Description="The external error code. Either a zero (0) if no external errors occurred; otherwise an error number.")
    code: Optional[str] = None
    """
    The external error code. Either a zero (0) if no external errors occurred; otherwise an error number.
    """


    # @ApiMember(Description="The external error message.")
    text: Optional[str] = None
    """
    The external error message.
    """


# @Api(Description="Represents an internal error stack.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Stack:
    """
    Represents an internal error stack.
    """

    # @ApiMember(Description="The internal error code. Either a zero (0) if no internal errors occurred; otherwise an error number.")
    code: Optional[str] = None
    """
    The internal error code. Either a zero (0) if no internal errors occurred; otherwise an error number.
    """


    # @ApiMember(Description="The external error message.")
    text: Optional[str] = None
    """
    The external error message.
    """


# @Api(Description="Represents an ERiC return code.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class RC:
    """
    Represents an ERiC return code.
    """

    # @ApiMember(Description="The return value of the return code.")
    rueckgabe: Optional[Rueckgabe] = None
    """
    The return value of the return code.
    """


    # @ApiMember(Description="The internal value of the return code.")
    stack: Optional[Stack] = None
    """
    The internal value of the return code.
    """


# @Api(Description="Represents an ERiC extension.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Zusatz:
    """
    Represents an ERiC extension.
    """

    # @ApiMember(Description="The user-customizable items for the extension. Data providers can use these items for their own extensions/information.")
    infos: List[str] = field(default_factory=list)
    """
    The user-customizable items for the extension. Data providers can use these items for their own extensions/information.
    """


    # @ApiMember(Description="The ELSTER items for the extension. They can be included in the response XML from the ELSTER server, if special information must be returned to the user after data submission. For example, for authenticated submission, information about impending certificate expiration etc. It must not be supplied by the data provider (even when empty).")
    elster_infos: List[str] = field(default_factory=list)
    """
    The ELSTER items for the extension. They can be included in the response XML from the ELSTER server, if special information must be returned to the user after data submission. For example, for authenticated submission, information about impending certificate expiration etc. It must not be supplied by the data provider (even when empty).
    """


# @Api(Description="Represents the transfer header part of an ELSTER document.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class TransferHeader:
    """
    Represents the transfer header part of an ELSTER document.
    """

    # @ApiMember(Description="The version of the transfer header.", IsRequired=true)
    version: Optional[str] = None
    """
    The version of the transfer header.
    """


    # @ApiMember(Description="The tax operation used in the ELSTER process.", IsRequired=true)
    verfahren: Optional[Verfahren] = None
    """
    The tax operation used in the ELSTER process.
    """


    # @ApiMember(Description="The tax data type of the ELSTER process.", IsRequired=true)
    daten_art: Optional[Datenart] = None
    """
    The tax data type of the ELSTER process.
    """


    # @ApiMember(Description="The authentification procedure of the ELSTER process.", IsRequired=true)
    vorgang: Optional[Vorgang] = None
    """
    The authentification procedure of the ELSTER process.
    """


    # @ApiMember(Description="The ticket identifier after a successful ELSTER process.")
    transfer_ticket: Optional[str] = None
    """
    The ticket identifier after a successful ELSTER process.
    """


    # @ApiMember(Description="The flag that indicates whether the tax declaration or filing is a test case. For production purposes, this value should not be set.")
    testmerker: Optional[Testmerker] = None
    """
    The flag that indicates whether the tax declaration or filing is a test case. For production purposes, this value should not be set.
    """


    # @ApiMember(Description="The signature and associated information on the compressed, encrypted, base64-encoded content of the the data part of a tax declaration / statement.")
    sig_user: Optional[SigUser] = None
    """
    The signature and associated information on the compressed, encrypted, base64-encoded content of the the data part of a tax declaration / statement.
    """


    # @ApiMember(Description="The receiving ELSTER server.")
    empfaenger: Optional[Empfaenger] = None
    """
    The receiving ELSTER server.
    """


    # @ApiMember(Description="The identifier of the software manufacturer, through whose software the tax declaration is filed.", IsRequired=true)
    hersteller_i_d: Optional[str] = None
    """
    The identifier of the software manufacturer, through whose software the tax declaration is filed.
    """


    # @ApiMember(Description="The details of the provider that submits tax data.", IsRequired=true)
    daten_lieferant: Optional[str] = None
    """
    The details of the provider that submits tax data.
    """


    # @ApiMember(Description="The date of receipt of the tax data.")
    eingangs_datum: Optional[datetime.datetime] = None
    """
    The date of receipt of the tax data.
    """


    # @ApiMember(Description="The encryption data required for authenticated transmission of tax data.")
    datei: Optional[Datei] = None
    """
    The encryption data required for authenticated transmission of tax data.
    """


    # @ApiMember(Description="The return code of the transfer header and is included in the response XML of the ELSTER server. The value should never be set by the data provider.")
    rc: Optional[RC] = None
    """
    The return code of the transfer header and is included in the response XML of the ELSTER server. The value should never be set by the data provider.
    """


    # @ApiMember(Description="The details of the software that submits the tax data.")
    version_client: Optional[str] = None
    """
    The details of the software that submits the tax data.
    """


    # @ApiMember(Description="Data extensions to the transfer header.")
    zusatz: Optional[Zusatz] = None
    """
    Data extensions to the transfer header.
    """


class EmpfaengerID(str, Enum):
    """
    Represents a receriver ID
    """

    L = 'L'
    F = 'F'


# @Api(Description="Represents a receiver of tax data.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class NDHEmpfaenger:
    """
    Represents a receiver of tax data.
    """

    # @ApiMember(Description="The identifier of the receiver.")
    id: Optional[EmpfaengerID] = None
    """
    The identifier of the receiver.
    """


    # @ApiMember(Description="The value of the receiver.")
    value: Optional[str] = None
    """
    The value of the receiver.
    """


# @Api(Description="Represents a manufacturer/vendor of tax software.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Hersteller:
    """
    Represents a manufacturer/vendor of tax software.
    """

    # @ApiMember(Description="The product name of the tax software produced by the manufacturer.")
    produkt_name: Optional[str] = None
    """
    The product name of the tax software produced by the manufacturer.
    """


    # @ApiMember(Description="The product version of the tax software produced by the manufacturer.")
    produkt_version: Optional[str] = None
    """
    The product version of the tax software produced by the manufacturer.
    """


# @Api(Description="Represents the header of a tax data.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class NutzdatenHeader:
    """
    Represents the header of a tax data.
    """

    # @ApiMember(Description="The version of the header.", IsRequired=true)
    version: Optional[str] = None
    """
    The version of the header.
    """


    # @ApiMember(Description="The ticket identifier of the header.", IsRequired=true)
    nutzdaten_ticket: Optional[str] = None
    """
    The ticket identifier of the header.
    """


    # @ApiMember(Description="The receiver of the header.", IsRequired=true)
    empfaenger: Optional[NDHEmpfaenger] = None
    """
    The receiver of the header.
    """


    # @ApiMember(Description="The software manufacturer, through whose software the tax declaration or filing is submitted.", IsRequired=true)
    hersteller: Optional[Hersteller] = None
    """
    The software manufacturer, through whose software the tax declaration or filing is submitted.
    """


    # @ApiMember(Description="The details of the data provider (e.g. taxpayer, tax consulant or firm), who produced the tax data and it must not necessarily be the same person declared in the TransferHeader section.")
    daten_lieferant: Optional[str] = None
    """
    The details of the data provider (e.g. taxpayer, tax consulant or firm), who produced the tax data and it must not necessarily be the same person declared in the TransferHeader section.
    """


    # @ApiMember(Description="The return code of the header.")
    rc: Optional[RC] = None
    """
    The return code of the header.
    """


    # @ApiMember(Description="The data extensions of the header.")
    zusatz: Optional[Zusatz] = None
    """
    The data extensions of the header.
    """


# @Api(Description="Represents an encapsulation of tax data content.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Nutzdaten:
    """
    Represents an encapsulation of tax data content.
    """

    # @ApiMember(Description="The content of the tax data. This varies by tax declaration. Currently supported formats: Raw XML (text), XElement, and IXmlSerializable", IsRequired=true)
    inhalt: Optional[Object] = None
    """
    The content of the tax data. This varies by tax declaration. Currently supported formats: Raw XML (text), XElement, and IXmlSerializable
    """


# @Api(Description="Represents a block of tax data.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Nutzdatenblock:
    """
    Represents a block of tax data.
    """

    # @ApiMember(Description="The header part of the block.", IsRequired=true)
    nutzdaten_header: Optional[NutzdatenHeader] = None
    """
    The header part of the block.
    """


    # @ApiMember(Description="The data part of the block.", IsRequired=true)
    nutzdaten: Optional[Nutzdaten] = None
    """
    The data part of the block.
    """


# @Api(Description="Represents the data part of an ELSTER document.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class DatenTeil:
    """
    Represents the data part of an ELSTER document.
    """

    # @ApiMember(Description="The blocks of tax data of the ELSTER document.", IsRequired=true)
    nutzdatenbloecke: List[Nutzdatenblock] = field(default_factory=list)
    """
    The blocks of tax data of the ELSTER document.
    """


# @Api(Description="Represents an ELSTER document.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Elster:
    """
    Represents an ELSTER document.
    """

    # @ApiMember(Description="The transfer header part of the ELSTER document.", IsRequired=true)
    transfer_header: Optional[TransferHeader] = None
    """
    The transfer header part of the ELSTER document.
    """


    # @ApiMember(Description="The data (facts) part of the ELSTER document.")
    daten_teil: Optional[DatenTeil] = None
    """
    The data (facts) part of the ELSTER document.
    """


# @Api(Description="Represents information about a file or directory.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class FileMetadata(IFileMetadata):
    """
    Represents information about a file or directory.
    """

    # @ApiMember(Description="The name of the file.\nFor files, gets the name of the file.\nFor directories, gets the name of the last directory in the hierarchy if a hierarchy exists; otherwise, the name of the directory.")
    name: Optional[str] = None
    """
    The name of the file.For files, gets the name of the file.For directories, gets the name of the last directory in the hierarchy if a hierarchy exists; otherwise, the name of the directory.
    """


    # @ApiMember(Description="The full path of the directory or file.")
    full_name: Optional[str] = None
    """
    The full path of the directory or file.
    """


    # @ApiMember(Description="The time the current file or directory was last accessed.")
    last_access_time: datetime.datetime = datetime.datetime(1, 1, 1)
    """
    The time the current file or directory was last accessed.
    """


    # @ApiMember(Description="The name of the file.")
    last_access_time_utc: datetime.datetime = datetime.datetime(1, 1, 1)
    """
    The name of the file.
    """


    # @ApiMember(Description="The time when the current file or directory was last written to.")
    last_write_time: datetime.datetime = datetime.datetime(1, 1, 1)
    """
    The time when the current file or directory was last written to.
    """


    # @ApiMember(Description="The time, in coordinated universal time (UTC), when the current file or directory was last written to.")
    last_write_time_utc: datetime.datetime = datetime.datetime(1, 1, 1)
    """
    The time, in coordinated universal time (UTC), when the current file or directory was last written to.
    """


    # @ApiMember(Description="The size, in bytes, of the current file.")
    length: int = 0
    """
    The size, in bytes, of the current file.
    """


    # @ApiMember(Description="The size, in bytes, of the current file.")
    user_id: int = 0
    """
    The size, in bytes, of the current file.
    """


    # @ApiMember(Description="The file group id.")
    group_id: int = 0
    """
    The file group id.
    """


    # @ApiMember(Description="A value that indicates whether the others can read from this file.")
    others_can_read: bool = False
    """
    A value that indicates whether the others can read from this file.
    """


    # @ApiMember(Description="A value that indicates whether the group members can execute this file.")
    group_can_execute: bool = False
    """
    A value that indicates whether the group members can execute this file.
    """


    # @ApiMember(Description="A value that indicates whether the group members can write into this file.")
    group_can_write: bool = False
    """
    A value that indicates whether the group members can write into this file.
    """


    # @ApiMember(Description="A value that indicates whether the group members can read from this file.")
    group_can_read: bool = False
    """
    A value that indicates whether the group members can read from this file.
    """


    # @ApiMember(Description="A value that indicates whether the owner can execute this file.")
    owner_can_execute: bool = False
    """
    A value that indicates whether the owner can execute this file.
    """


    # @ApiMember(Description="A value that indicates whether the owner can write into this file.")
    owner_can_write: bool = False
    """
    A value that indicates whether the owner can write into this file.
    """


    # @ApiMember(Description="A value that indicates whether the owner can read from this file.")
    owner_can_read: bool = False
    """
    A value that indicates whether the owner can read from this file.
    """


    # @ApiMember(Description="A value that indicates whether others can read from this file.")
    others_can_execute: bool = False
    """
    A value that indicates whether others can read from this file.
    """


    # @ApiMember(Description="A value that indicates whether others can write into this file.")
    others_can_write: bool = False
    """
    A value that indicates whether others can write into this file.
    """


    # @ApiMember(Description="Extensions to the file attributes.")
    extensions: Dict[str, str] = field(default_factory=dict)
    """
    Extensions to the file attributes.
    """


# @Api(Description="Represents a generic file that contains raw data content in bytes")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class BinaryFile(FileBase):
    """
    Represents a generic file that contains raw data content in bytes
    """

    # @ApiMember(Description="The attributes of the file.")
    metadata: Optional[FileMetadata] = None
    """
    The attributes of the file.
    """


    # @ApiMember(Description="The name of the file without information on its directory path.")
    name: Optional[str] = None
    """
    The name of the file without information on its directory path.
    """


# @Api(Description="A type that encapsulates the return values from the ERiC API function that processes tax data.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class BearbeiteVorgangResponse(EricFehlerCodeResponse):
    """
    A type that encapsulates the return values from the ERiC API function that processes tax data.
    """

    # @ApiMember(Description="The return value of the process.")
    rueckgabe: Optional[EricBearbeiteVorgang] = None
    """
    The return value of the process.
    """


    # @ApiMember(Description="The server response of the process.")
    serverantwort: Optional[Elster] = None
    """
    The server response of the process.
    """


    # @ApiMember(Description="If available, the PDF-based files to represent generated transfer prototocols.")
    transfer_protocols: List[BinaryFile] = field(default_factory=list)
    """
    If available, the PDF-based files to represent generated transfer prototocols.
    """


# @Api(Description="A synchronous service to submit an annual VAT return for 2022.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class SubmitUmsatzsteuererklaerung2022(SubmitUmsatzsteuererklaerung2022Base):
    """
    A synchronous service to submit an annual VAT return for 2022.
    """

    pass

Python SubmitUmsatzsteuererklaerung2022 DTOs

To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=jsv

HTTP + JSV

The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.

POST /SubmitUmsatzsteuererklaerung2022 HTTP/1.1 
Host: taxfiling.pwc.de 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	berErkl: 
	{
		e3000601: 
		{
			wert: False,
			alias: String
		}
	},
	allg: 
	{
		unternehmen: 
		{
			e3000901: 
			{
				wert: String,
				alias: String
			},
			e3000902: 
			{
				wert: String,
				alias: String
			},
			e3001001: 
			{
				wert: String,
				alias: String
			},
			adr: 
			{
				e3001101: 
				{
					wert: String,
					alias: String
				},
				e3001203: 
				{
					wert: String,
					alias: String
				},
				e3001204: 
				{
					wert: String,
					alias: String
				},
				e3001205: 
				{
					wert: String,
					alias: String
				},
				e3001201: 
				{
					wert: String,
					alias: String
				},
				e3001403: 
				{
					wert: String,
					alias: String
				},
				e3001404: 
				{
					wert: String,
					alias: String
				}
			},
			kontakt: 
			{
				e3001202: 
				{
					wert: String,
					alias: String
				},
				e3001301: 
				{
					wert: String,
					alias: String
				}
			}
		},
		imAuslAnsUnt: 
		{
			e3001402: 
			{
				wert: False,
				alias: String
			}
		},
		fiskalvetr: 
		{
			e3001801: 
			{
				wert: False,
				alias: String
			}
		},
		dauerUntEig: 
		{
			e3001401: 
			{
				wert: 
				{
					start: 0001-01-01,
					ende: 0001-01-01
				},
				alias: String
			},
			e3001501: 
			{
				wert: 
				{
					start: 0001-01-01,
					ende: 0001-01-01
				},
				alias: String
			}
		},
		bestArt: 
		{
			e3002203: 
			{
				wert: 1,
				alias: String
			}
		},
		verrech: 
		{
			e3001701: 
			{
				wert: False,
				alias: String
			}
		},
		ergAngErkl: 
		{
			e3002201: 
			{
				wert: False,
				alias: String
			},
			e3002202: 
			{
				wert: String,
				alias: String
			}
		}
	},
	mitwirk: 
	{
		kanzlei: 
		{
			e3002509: 
			{
				wert: String,
				alias: String
			},
			e3002506: 
			{
				wert: String,
				alias: String
			},
			e3002507: 
			{
				wert: String,
				alias: String
			}
		},
		bearb: 
		{
			e3002501: 
			{
				wert: String,
				alias: String
			},
			e3002502: 
			{
				wert: String,
				alias: String
			}
		},
		adr: 
		{
			e3002503: 
			{
				wert: String,
				alias: String
			},
			e3002504: 
			{
				wert: String,
				alias: String
			}
		},
		kontakt: 
		{
			e3002505: 
			{
				wert: String,
				alias: String
			},
			e3002508: 
			{
				wert: String,
				alias: String
			}
		},
		mitwirkErkl: 
		{
			e3002602: 
			{
				wert: False,
				alias: String
			}
		}
	},
	kleinuntern: 
	{
		e3002301: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3002401: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		}
	},
	umsaetze: 
	{
		umsAllg: 
		{
			e3003303: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3003304: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3003405: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3003406: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3003505: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3003506: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			}
		},
		umsErm: 
		{
			e3004401: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3004402: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3003703: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3003704: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3003803: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3003804: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			}
		},
		umsAnd: 
		{
			e3005001: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3005002: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			}
		},
		umsLuf: 
		{
			e3005201: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3005301: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3005302: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3005701: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3005702: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3005801: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3005101: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3005102: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			}
		},
		wechsBestForm: 
		{
			e3102901: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			}
		},
		nachstStSatzAend: 
		{
			e3005901: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			}
		},
		umsSum: 
		{
			e3006001: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			}
		}
	},
	umsStfrei: 
	{
		mitVoStAbz: 
		{
			igLfg: 
			{
				e3103301: 
				{
					betrag: 
					{
						wert: 0
					},
					alias: String
				},
				e3103401: 
				{
					betrag: 
					{
						wert: 0
					},
					alias: String
				},
				e3103501: 
				{
					betrag: 
					{
						wert: 0
					},
					alias: String
				}
			},
			umsStFreiWeit: 
			{
				e3103801: 
				{
					betrag: 
					{
						wert: 0
					},
					alias: String
				},
				e3103901: 
				{
					wert: String,
					alias: String
				},
				e3103902: 
				{
					betrag: 
					{
						wert: 0
					},
					alias: String
				},
				e3104001: 
				{
					betrag: 
					{
						wert: 0
					},
					alias: String
				},
				e3104101: 
				{
					betrag: 
					{
						wert: 0
					},
					alias: String
				},
				e3104201: 
				{
					betrag: 
					{
						wert: 0
					},
					alias: String
				}
			}
		},
		ohneVoStAbz: 
		{
			nichtGesUms: 
			{
				e3104401: 
				{
					betrag: 
					{
						wert: 0
					},
					alias: String
				},
				e3104501: 
				{
					wert: String,
					alias: String
				},
				e3104502: 
				{
					betrag: 
					{
						wert: 0
					},
					alias: String
				},
				e3104601: 
				{
					betrag: 
					{
						wert: 0
					},
					alias: String
				}
			},
			gesUms: 
			{
				e3104901: 
				{
					wert: String,
					alias: String
				},
				e3104902: 
				{
					betrag: 
					{
						wert: 0
					},
					alias: String
				}
			}
		}
	},
	igErw: 
	{
		stfrei: 
		{
			e3100901: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			}
		},
		stpfl: 
		{
			e3100902: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3100903: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3101301: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3101302: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3101303: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3101304: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3101401: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3101402: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			}
		},
		igErwSum: 
		{
			e3101501: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			}
		}
	},
	auslag13a: 
	{
		e3102804: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3102805: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		auslag13aSum: 
		{
			e3102904: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			}
		}
	},
	igDrei: 
	{
		lfgErstAbn: 
		{
			e3101801: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			}
		},
		lfgLetztAbn: 
		{
			e3101701: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3101702: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3102301: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3102302: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3102303: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3102304: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			}
		},
		igDreiSum: 
		{
			e3102401: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			}
		}
	},
	ums13b: 
	{
		e3102205: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3102206: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3102307: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3102308: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3102503: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3102504: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		ums13bSum: 
		{
			e3102601: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			}
		}
	},
	ergAngUms: 
	{
		e3105201: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3105301: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3105101: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3105102: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3105602: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3105702: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3105801: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3105901: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3106001: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3106101: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		}
	},
	abzVoSt: 
	{
		e3006201: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3006301: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3006401: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3006503: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3006502: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3006501: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3006601: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3006701: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3006801: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		abzVoStSum: 
		{
			e3006901: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			}
		},
		ergAng: 
		{
			e3007001: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			}
		}
	},
	berVoSt15a: 
	{
		grdstErstmVerw: 
		{
			e3007301: 
			{
				wert: False,
				alias: String
			},
			angGrdst: 
			{
				e3007401: 
				{
					wert: String,
					alias: String
				},
				e3007402: 
				{
					wert: 0001-01-01,
					alias: String
				},
				e3007403: 
				{
					wert: String,
					alias: String
				},
				e3007404: 
				{
					betrag: 
					{
						wert: 0
					},
					alias: String
				},
				e3007405: 
				{
					betrag: 
					{
						wert: 0
					},
					alias: String
				},
				e3007406: 
				{
					betrag: 
					{
						wert: 0
					},
					alias: String
				}
			}
		},
		aendVerh: 
		{
			e3007601: 
			{
				wert: False,
				alias: String
			},
			e3008501: 
			{
				wert: False,
				alias: String
			},
			e3008601: 
			{
				wert: False,
				alias: String
			}
		},
		grundAendVerh: 
		{
			e3007801: 
			{
				wert: False,
				alias: String
			},
			e3007802: 
			{
				wert: False,
				alias: String
			},
			e3007803: 
			{
				wert: False,
				alias: String
			},
			nutzAend: 
			{
				e3007901: 
				{
					wert: False,
					alias: String
				},
				e3008001: 
				{
					wert: False,
					alias: String
				},
				e3008202: 
				{
					wert: False,
					alias: String
				},
				e3008401: 
				{
					wert: False,
					alias: String
				},
				e3008402: 
				{
					wert: String,
					alias: String
				}
			}
		},
		voStBerBetr: 
		{
			e3008701: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3008702: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3008801: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3008802: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3008803: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3008804: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			voStBerBetrSum: 
			{
				e3008901: 
				{
					betrag: 
					{
						wert: 0
					},
					alias: String
				},
				e3008902: 
				{
					betrag: 
					{
						wert: 0
					},
					alias: String
				}
			}
		}
	},
	berechUSt: 
	{
		e3009201: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3009401: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3009602: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3009501: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3009502: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3009801: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3009901: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3010001: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3010201: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3009701: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3010301: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3010401: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3010501: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3010601: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		e3010602: 
		{
			betrag: 
			{
				wert: 0
			},
			alias: String
		},
		verblUSt: 
		{
			e3011101: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3011301: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			}
		},
		zahlErstatt: 
		{
			e3011401: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			}
		}
	},
	un: 
	{
		allg: 
		{
			bank: 
			{
				e3201001: 
				{
					wert: String,
					alias: String
				},
				e3201002: 
				{
					wert: String,
					alias: String
				},
				e3200901: 
				{
					wert: String,
					alias: String
				},
				e3200902: 
				{
					wert: String,
					alias: String
				},
				e3200904: 
				{
					wert: False,
					alias: String
				},
				e3200905: 
				{
					wert: String,
					alias: String
				}
			},
			vollm: 
			{
				e3201301: 
				{
					wert: False,
					alias: String
				},
				e3201401: 
				{
					wert: False,
					alias: String
				},
				e3201501: 
				{
					wert: String,
					alias: String
				},
				e3201601: 
				{
					wert: String,
					alias: String
				},
				e3201302: 
				{
					wert: String,
					alias: String
				},
				e3201303: 
				{
					wert: String,
					alias: String
				},
				e3201304: 
				{
					wert: String,
					alias: String
				},
				e3201402: 
				{
					wert: String,
					alias: String
				},
				e3201503: 
				{
					wert: String,
					alias: String
				},
				e3201504: 
				{
					wert: String,
					alias: String
				},
				e3201602: 
				{
					wert: String,
					alias: String
				},
				e3201502: 
				{
					wert: String,
					alias: String
				},
				angUnterschr: 
				{
					e3201701: 
					{
						wert: False,
						alias: String
					}
				}
			}
		},
		voStVerguetBZSt: 
		{
			e3201101: 
			{
				wert: False,
				alias: String
			}
		},
		anrechBetr: 
		{
			e3201902: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3202002: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			},
			e3202102: 
			{
				betrag: 
				{
					wert: 0
				},
				alias: String
			}
		},
		ergAngUms: 
		{
			instpflUmsEnt: 
			{
				e3201901: 
				{
					betrag: 
					{
						wert: 0
					},
					alias: String
				}
			}
		}
	},
	fv: 
	{
		aufstAllerVertrUnt: 
		{
			einzs: 
			[
				{
					e3300201: 
					{
						wert: String,
						alias: String
					},
					e3300202: 
					{
						wert: String,
						alias: String
					},
					e3300203: 
					{
						wert: String,
						alias: String
					},
					e3300204: 
					{
						betrag: 
						{
							wert: 0
						},
						alias: String
					}
				}
			],
			sum: 
			{
				e3300301: 
				{
					betrag: 
					{
						wert: 0
					},
					alias: String
				}
			}
		}
	},
	unterfallart: 
	{
		wert: ESt,
		alias: String
	},
	vorgang: 
	{
		wert: NurVeranlagung,
		alias: String
	},
	stNr: 
	{
		wert: String,
		alias: String
	},
	ordnungsbegriff: 
	{
		wert: String,
		alias: String
	},
	id: 
	{
		wert: String,
		alias: String
	},
	idEhefrau: 
	{
		wert: String,
		alias: String
	},
	absName: 
	{
		wert: String,
		alias: String
	},
	absStr: 
	{
		wert: String,
		alias: String
	},
	absPlz: 
	{
		wert: String,
		alias: String
	},
	absOrt: 
	{
		wert: String,
		alias: String
	},
	copyright: 
	{
		wert: String,
		alias: String
	},
	teleNummer: 
	{
		wert: String,
		alias: String
	},
	ordNrArt: 
	{
		wert: S,
		alias: String
	},
	rueckuebermittlung: 
	{
		bescheid: 
		{
			wert: False,
			alias: String
		},
		artRueckuebermittlung: 
		{
			wert: String,
			alias: String
		},
		schluesselRueckuebermittlung: 
		{
			wert: String,
			alias: String
		},
		adresseRueckuebermittlung: 
		{
			wert: String,
			alias: String
		}
	},
	bundesfinanzamtsnummer: String,
	datenLieferant: String,
	duplexDruck: False,
	protocolPrefix: String,
	fussText: String,
	zertifikat: 
	{
		name: String,
		pin: String,
		description: String,
		tags: 
		[
			String
		],
		content: AA==
	}
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length

{
	rueckgabe: 
	{
		erfolg: 
		{
			telenummer: 
			[
				String
			],
			ordnungsbegriffe: 
			[
				String
			]
		},
		transfers: 
		{
			transferList: 
			[
				{
					transferTicket: String
				}
			]
		},
		fehlerRegelpruefungen: 
		[
			{
				nutzdatenticket: String,
				feldidentifikator: String,
				mehrfachzeilenindex: String,
				lfdNrVordruck: String,
				vordruckZeilennummer: String,
				semantischeIndexes: 
				[
					{
						name: String,
						value: String
					}
				],
				untersachbereich: String,
				privateKennnummer: String,
				regelName: String,
				fachlicheFehlerId: String,
				text: String
			}
		],
		hinweise: 
		[
			{
				nutzdatenticket: String,
				feldidentifikator: String,
				mehrfachzeilenindex: String,
				lfdNrVordruck: String,
				vordruckZeilennummer: String,
				semantischeIndexes: 
				[
					{
						name: String,
						value: String
					}
				],
				untersachbereich: String,
				privateKennnummer: String,
				regelName: String,
				fachlicheHinweisId: String,
				text: String
			}
		]
	},
	serverantwort: 
	{
		transferHeader: 
		{
			version: String,
			verfahren: ElsterAnmeldung,
			datenArt: AbrufcodeAntrag,
			vorgang: send-Auth,
			transferTicket: String,
			testmerker: 0,
			sigUser: 
			{
				inhalt: {}
			},
			empfaenger: 
			{
				id: String,
				ziel: BW
			},
			herstellerID: String,
			datenLieferant: String,
			eingangsDatum: 0001-01-01,
			datei: 
			{
				verschluesselung: PKCS#7v1.5,
				kompression: GZIP,
				transportSchluessel: String,
				erstellung: 
				{
					eric: 
					{
						inhalt: {}
					}
				}
			},
			rc: 
			{
				rueckgabe: 
				{
					code: String,
					text: String
				},
				stack: 
				{
					code: String,
					text: String
				}
			},
			versionClient: String,
			zusatz: 
			{
				infos: 
				[
					String
				],
				elsterInfos: 
				[
					String
				]
			}
		},
		datenTeil: 
		{
			nutzdatenbloecke: 
			[
				{
					nutzdatenHeader: 
					{
						version: String,
						nutzdatenTicket: String,
						empfaenger: 
						{
							id: L,
							value: String
						},
						hersteller: 
						{
							produktName: String,
							produktVersion: String
						},
						datenLieferant: String,
						rc: 
						{
							rueckgabe: 
							{
								code: String,
								text: String
							},
							stack: 
							{
								code: String,
								text: String
							}
						},
						zusatz: 
						{
							infos: 
							[
								String
							],
							elsterInfos: 
							[
								String
							]
						}
					},
					nutzdaten: 
					{
						inhalt: {}
					}
				}
			]
		}
	},
	transferProtocols: 
	[
		{
			metadata: 
			{
				name: String,
				fullName: String,
				lastAccessTime: 0001-01-01,
				lastAccessTimeUtc: 0001-01-01,
				lastWriteTime: 0001-01-01,
				lastWriteTimeUtc: 0001-01-01,
				length: 0,
				userId: 0,
				groupId: 0,
				othersCanRead: False,
				groupCanExecute: False,
				groupCanWrite: False,
				groupCanRead: False,
				ownerCanExecute: False,
				ownerCanWrite: False,
				ownerCanRead: False,
				othersCanExecute: False,
				othersCanWrite: False,
				extensions: 
				{
					String: String
				}
			},
			name: String,
			content: AA==
		}
	],
	statusCode: ERIC_OK,
	statusText: String,
	id: String,
	index: 0,
	responseStatus: 
	{
		errorCode: String,
		message: String,
		stackTrace: String,
		errors: 
		[
			{
				errorCode: String,
				fieldName: String,
				message: String,
				meta: 
				{
					String: String
				}
			}
		],
		meta: 
		{
			String: String
		}
	}
}