Tax Filing Service

<back to all web services

SubmitUmsatzsteuererklaerung2020

SyncUmsatzsteuerJahressteuererklärung2020

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

Requires Authentication
The following routes are available for this service:
POST/SubmitUmsatzsteuererklaerung2020A synchronous service to create xml content that represents the annual VAT return for 2020

/** @description Stellt die Art der Ordnungsnummer dar. */
export enum OrdNrArt
{
    S = 'S',
    O = 'O',
}

/** @description Stellt den Vorgang bei einer Veranlagung dar. */
export enum VeranlagungVorgang
{
    NurVeranlagung = 1,
    VeranlagungMitVorauszahlung = 4,
}

/** @description Stellt die Informationen zur Bescheidrückübermittlung dar. */
// @Api(Description="Stellt die Informationen zur Bescheidrückübermittlung dar.")
export class Rueckuebermittlung
{
    /** @description Wird die elektronische Bereitstellung der Bescheiddaten gewünscht? */
    // @ApiMember(Description="Wird die elektronische Bereitstellung der Bescheiddaten gewünscht?")
    public bescheid: boolean;

    /** @description Art der Adresse der Bescheidbereitstellung: INTERNET bei Rückübermittlung über Internet. */
    // @ApiMember(Description="Art der Adresse der Bescheidbereitstellung: INTERNET bei Rückübermittlung über Internet.")
    public artRueckuebermittlung?: string;

    /** @description Öffentlicher Schlüssel mit variabler Länge. */
    // @ApiMember(Description="Öffentlicher Schlüssel mit variabler Länge.")
    public schluesselRueckuebermittlung?: string;

    /** @description Erforderliche Adresselemente bei Benachrichtigung für Bescheidbereitstellung: E-Mail-Adresse. */
    // @ApiMember(Description="Erforderliche Adresselemente bei Benachrichtigung für Bescheidbereitstellung: E-Mail-Adresse.")
    public adresseRueckuebermittlung?: string;

    public constructor(init?: Partial<Rueckuebermittlung>) { (Object as any).assign(this, init); }
}

/** @description Basisklasse für einen benutzerdefinierten Feldtyp */
// @Api(Description="Basisklasse für einen benutzerdefinierten Feldtyp")
export class CustomFeldBase implements ICustomFeld
{
    /** @description Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung. */
    // @ApiMember(Description="Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung.")
    public nr: number;

    /** @description Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1 */
    // @ApiMember(Description="Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1")
    public index: number;

    /** @description Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1 */
    // @ApiMember(Description="Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1")
    public lfdNr: number;

    /** @description Identifizierung der Zeile / Feld im Fremdprogramm. */
    // @ApiMember(Description="Identifizierung der Zeile / Feld im Fremdprogramm.")
    public alias?: string;

    public constructor(init?: Partial<CustomFeldBase>) { (Object as any).assign(this, init); }
}

/** @description Boolescher Feldtyp, welcher als 'X' (Ja) oder '' (Nein) im Jahressteuererklärung angeschrieben wird. */
// @Api(Description="Boolescher Feldtyp, welcher als 'X' (Ja) oder '' (Nein) im Jahressteuererklärung angeschrieben wird.")
export class BoolXFeld extends CustomFeldBase
{
    /** @description Wenn der Wert true ist, 'X' wird im Jahressteuererklärung angeschrieben; ansonsten ein Leerstring. */
    // @ApiMember(Description="Wenn der Wert true ist, 'X' wird im Jahressteuererklärung angeschrieben; ansonsten ein Leerstring.", IsRequired=true, Name="Wert")
    public wert: boolean;

    /** @description Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung. */
    // @ApiMember(Description="Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung.")
    public nr: number;

    /** @description Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1 */
    // @ApiMember(Description="Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1")
    public index: number;

    /** @description Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1 */
    // @ApiMember(Description="Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1")
    public lfdNr: number;

    /** @description Identifizierung der Zeile / Feld im Fremdprogramm. */
    // @ApiMember(Description="Identifizierung der Zeile / Feld im Fremdprogramm.")
    public alias?: string;

    public constructor(init?: Partial<BoolXFeld>) { super(init); (Object as any).assign(this, init); }
}

/** @description Boolescher Feldtyp, welcher als '1' (Ja) oder '' (Nein) im Jahressteuererklärung angeschrieben wird. */
// @Api(Description="Boolescher Feldtyp, welcher als '1' (Ja) oder '' (Nein) im Jahressteuererklärung angeschrieben wird.")
export class Bool1Feld extends CustomFeldBase
{
    /** @description Wenn der Wert true ist, '1' wird im Jahressteuererklärung angeschrieben; ansonsten ein Leerstring. */
    // @ApiMember(Description="Wenn der Wert true ist, '1' wird im Jahressteuererklärung angeschrieben; ansonsten ein Leerstring.", IsRequired=true, Name="Wert")
    public wert: boolean;

    /** @description Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung. */
    // @ApiMember(Description="Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung.")
    public nr: number;

    /** @description Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1 */
    // @ApiMember(Description="Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1")
    public index: number;

    /** @description Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1 */
    // @ApiMember(Description="Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1")
    public lfdNr: number;

    /** @description Identifizierung der Zeile / Feld im Fremdprogramm. */
    // @ApiMember(Description="Identifizierung der Zeile / Feld im Fremdprogramm.")
    public alias?: string;

    public constructor(init?: Partial<Bool1Feld>) { super(init); (Object as any).assign(this, init); }
}

/** @description Zeichenkettenfeld. */
// @Api(Description="Zeichenkettenfeld.")
export class StringFeld extends CustomFeldBase
{
    /** @description Wert des Feldes.  1 bis 999 Zeichen, alphanumerisch */
    // @ApiMember(Description="Wert des Feldes. \n 1 bis 999 Zeichen, alphanumerisch", IsRequired=true, Name="Wert")
    public wert: string;

    /** @description Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung. */
    // @ApiMember(Description="Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung.")
    public nr: number;

    /** @description Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1 */
    // @ApiMember(Description="Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1")
    public index: number;

    /** @description Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1 */
    // @ApiMember(Description="Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1")
    public lfdNr: number;

    /** @description Identifizierung der Zeile / Feld im Fremdprogramm. */
    // @ApiMember(Description="Identifizierung der Zeile / Feld im Fremdprogramm.")
    public alias?: string;

    public constructor(init?: Partial<StringFeld>) { super(init); (Object as any).assign(this, init); }
}

/** @description Stellt ein Datumbereich dar (TT.MM-TT.MM) dar */
// @Api(Description="Stellt ein Datumbereich dar (TT.MM-TT.MM) dar")
export class ErklaerungZeitraum
{
    /** @description Der Anfang des Datumbreiches. */
    // @ApiMember(Description="Der Anfang des Datumbreiches.", Name="Start")
    public start: string;

    /** @description Das Ende des Datumbereiches. */
    // @ApiMember(Description="Das Ende des Datumbereiches.", Name="Ende")
    public ende: string;

    public constructor(init?: Partial<ErklaerungZeitraum>) { (Object as any).assign(this, init); }
}

/** @description Datums-Uhrzeitfeld. Format: TT.MM - TT. MM */
// @Api(Description="Datums-Uhrzeitfeld. Format: TT.MM - TT. MM")
export class ZeitraumFeld extends CustomFeldBase
{
    /** @description Wert des Feldes. */
    // @ApiMember(Description="Wert des Feldes.", IsRequired=true)
    public wert: ErklaerungZeitraum;

    /** @description Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung. */
    // @ApiMember(Description="Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung.")
    public nr: number;

    /** @description Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1 */
    // @ApiMember(Description="Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1")
    public index: number;

    /** @description Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1 */
    // @ApiMember(Description="Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1")
    public lfdNr: number;

    /** @description Identifizierung der Zeile / Feld im Fremdprogramm. */
    // @ApiMember(Description="Identifizierung der Zeile / Feld im Fremdprogramm.")
    public alias?: string;

    public constructor(init?: Partial<ZeitraumFeld>) { super(init); (Object as any).assign(this, init); }
}

/** @description Art der Entgelte */
// @Flags()
export enum Entgeltart
{
    VereinbarteEntgelte = 1,
    VereinnahmteEntgelte = 16,
}

/** @description Feld, welches die Art der Entgeltart darstellt. */
// @Api(Description="Feld, welches die Art der Entgeltart darstellt.")
export class EntgeltartFeld extends CustomFeldBase
{
    /** @description Wert des Feldes. */
    // @ApiMember(Description="Wert des Feldes.", IsRequired=true)
    public wert: Entgeltart;

    /** @description Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung. */
    // @ApiMember(Description="Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung.")
    public nr: number;

    /** @description Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1 */
    // @ApiMember(Description="Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1")
    public index: number;

    /** @description Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1 */
    // @ApiMember(Description="Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1")
    public lfdNr: number;

    /** @description Identifizierung der Zeile / Feld im Fremdprogramm. */
    // @ApiMember(Description="Identifizierung der Zeile / Feld im Fremdprogramm.")
    public alias?: string;

    public constructor(init?: Partial<EntgeltartFeld>) { super(init); (Object as any).assign(this, init); }
}

/** @description Allgemeine Angaben der Umsatzteuererklärung für 2020 -  General information for the VAT return of 2020 */
// @Api(Description="Allgemeine Angaben der Umsatzteuererklärung für 2020 -  General information for the VAT return of 2020")
export class AllgemeineAngaben2020
{
    /** @description Diese Steuererklärung wurde digital signiert? */
    // @ApiMember(Description="Diese Steuererklärung wurde digital signiert?", Name="Nr3000013")
    public nr3000013?: BoolXFeld;

    /** @description Berichtigte Steuererklärung? */
    // @ApiMember(Description="Berichtigte Steuererklärung?", Name="Nr3000601")
    public nr3000601?: Bool1Feld;

    /** @description Name des Unternehmers */
    // @ApiMember(Description="Name des Unternehmers", IsRequired=true, Name="Nr3000901")
    public nr3000901: StringFeld;

    /** @description gegebenenfalls abweichender Firmenname */
    // @ApiMember(Description="gegebenenfalls abweichender Firmenname", Name="Nr3000902")
    public nr3000902?: StringFeld;

    /** @description Art des Unternehmens */
    // @ApiMember(Description="Art des Unternehmens", Name="Nr3001001")
    public nr3001001?: StringFeld;

    /** @description Straße */
    // @ApiMember(Description="Straße", IsRequired=true, Name="Nr3001101")
    public nr3001101: StringFeld;

    /** @description Hausnummer */
    // @ApiMember(Description="Hausnummer", IsRequired=true, Name="Nr3001203")
    public nr3001203: StringFeld;

    /** @description Hausnummerzusatz */
    // @ApiMember(Description="Hausnummerzusatz", Name="Nr3001204")
    public nr3001204?: StringFeld;

    /** @description Adressergänzung */
    // @ApiMember(Description="Adressergänzung", Name="Nr3001205")
    public nr3001205?: StringFeld;

    /** @description Postleitzahl, Ort */
    // @ApiMember(Description="Postleitzahl, Ort", Name="Nr3001201")
    public nr3001201?: StringFeld;

    /** @description Postleitzahl zu Postfach */
    // @ApiMember(Description="Postleitzahl zu Postfach", Name="Nr3001403")
    public nr3001403?: StringFeld;

    /** @description Postfach */
    // @ApiMember(Description="Postfach", Name="Nr3001404")
    public nr3001404?: StringFeld;

    /** @description Telefon */
    // @ApiMember(Description="Telefon", Name="Nr3001202")
    public nr3001202?: StringFeld;

    /** @description E-Mail Adresse */
    // @ApiMember(Description="E-Mail Adresse", Name="Nr3001301")
    public nr3001301?: StringFeld;

    /** @description Im Ausland ansässiger Unternehmer? Bitte tätigen Sie in diesem Fall auch Angaben auf der Anlage UN */
    // @ApiMember(Description="Im Ausland ansässiger Unternehmer? Bitte tätigen Sie in diesem Fall auch Angaben auf der Anlage UN", Name="Nr3001402")
    public nr3001402?: Bool1Feld;

    /** @description Fiskalvertreter?  Bitte tätigen Sie in diesem Fall auch Angaben auf der Anlage FV. */
    // @ApiMember(Description="Fiskalvertreter?  Bitte tätigen Sie in diesem Fall auch Angaben auf der Anlage FV.", Name="Nr3001801")
    public nr3001801?: Bool1Feld;

    /** @description 1. Zeitraum */
    // @ApiMember(Description="1. Zeitraum", Name="Nr3001401")
    public nr3001401?: ZeitraumFeld;

    /** @description 2. Zeitraum */
    // @ApiMember(Description="2. Zeitraum", Name="Nr3001501")
    public nr3001501?: ZeitraumFeld;

    /** @description Die Steuer wurde nach vereinbarten Entgelten (falls ja, bitte eine 'Entgeltart.VereinbarteEntgelte' eintragen), nach vereinnahmten Entgelten (falls ja, bitte eine 'Entgeltart.VereinnahmteEntgelte' eintragen) oder nach vereinbarten und vereinnahmten Entgelten (falls ja, bitte eine 'Entgeltart.VereinbarteEntgelte | Entgeltart.VereinnahmteEntgelte ' eintragen) berechnet. */
    // @ApiMember(Description="Die Steuer wurde nach vereinbarten Entgelten (falls ja, bitte eine 'Entgeltart.VereinbarteEntgelte' eintragen), nach vereinnahmten Entgelten (falls ja, bitte eine 'Entgeltart.VereinnahmteEntgelte' eintragen) oder nach vereinbarten und vereinnahmten Entgelten (falls ja, bitte eine 'Entgeltart.VereinbarteEntgelte | Entgeltart.VereinnahmteEntgelte ' eintragen) berechnet.", IsRequired=true, Name="Nr3002203")
    public nr3002203: EntgeltartFeld;

    /** @description Verrechnung des Erstattungsbetrages erwünscht / Erstattungsbetrag ist abgetreten? */
    // @ApiMember(Description="Verrechnung des Erstattungsbetrages erwünscht / Erstattungsbetrag ist abgetreten?", Name="Nr3001701")
    public nr3001701?: Bool1Feld;

    /** @description Über die Angaben in der Steuererklärung hinaus sind weitere oder abweichende Angaben oder Sachverhalte zu berücksichtigen? */
    // @ApiMember(Description="Über die Angaben in der Steuererklärung hinaus sind weitere oder abweichende Angaben oder Sachverhalte zu berücksichtigen?", Name="Nr3002201")
    public nr3002201?: Bool1Feld;

    /** @description Ergänzende Angaben zur Steuererklärung */
    // @ApiMember(Description="Ergänzende Angaben zur Steuererklärung", Name="Nr3002202")
    public nr3002202?: StringFeld;

    public constructor(init?: Partial<AllgemeineAngaben2020>) { (Object as any).assign(this, init); }
}

/** @description Specifies an amount of money without cents with limits and a specialized string representation */
// @Api(Description="Specifies an amount of money without cents with limits and a specialized string representation")
export class GeldBetragOhneCent
{
    /** @description The intrinsic currency value. */
    // @ApiMember(Description="The intrinsic currency value.")
    public wert: number;

    public constructor(init?: Partial<GeldBetragOhneCent>) { (Object as any).assign(this, init); }
}

/** @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 */
// @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")
export class GeldBetragOhneCent5DE extends GeldBetragOhneCent
{
    /** @description The intrinsic currency value. */
    // @ApiMember(Description="The intrinsic currency value.")
    public wert: number;

    public constructor(init?: Partial<GeldBetragOhneCent5DE>) { super(init); (Object as any).assign(this, init); }
}

/** @description Geldbetrag ohne Cent mit 5 Stellen. Mindestens eine Ziffer und maximal 5 Ziffern. Minusvorzeichen erlaubt. */
// @Api(Description="Geldbetrag ohne Cent mit 5 Stellen. Mindestens eine Ziffer und maximal 5 Ziffern. Minusvorzeichen erlaubt.")
export class GeldBetragOhneCent5DEFeld extends CustomFeldBase
{
    /** @description Wert des Feldes. Mindestens eine Ziffer und maximal 5 Ziffern. Minusvorzeichen erlaubt. */
    // @ApiMember(Description="Wert des Feldes. Mindestens eine Ziffer und maximal 5 Ziffern. Minusvorzeichen erlaubt.", IsRequired=true)
    public betrag: GeldBetragOhneCent5DE;

    /** @description Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung. */
    // @ApiMember(Description="Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung.")
    public nr: number;

    /** @description Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1 */
    // @ApiMember(Description="Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1")
    public index: number;

    /** @description Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1 */
    // @ApiMember(Description="Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1")
    public lfdNr: number;

    /** @description Identifizierung der Zeile / Feld im Fremdprogramm. */
    // @ApiMember(Description="Identifizierung der Zeile / Feld im Fremdprogramm.")
    public alias?: string;

    public constructor(init?: Partial<GeldBetragOhneCent5DEFeld>) { super(init); (Object as any).assign(this, init); }
}

/** @description Specifies an amount of money without cents with limits and a specialized string representation */
// @Api(Description="Specifies an amount of money without cents with limits and a specialized string representation")
export class GrossGeldBetragOhneCent
{
    /** @description The intrinsic currency value. */
    // @ApiMember(Description="The intrinsic currency value.")
    public wert: number;

    public constructor(init?: Partial<GrossGeldBetragOhneCent>) { (Object as any).assign(this, init); }
}

/** @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. */
// @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.")
export class GeldBetragOhneCent12DE extends GrossGeldBetragOhneCent
{
    /** @description The intrinsic currency value. */
    // @ApiMember(Description="The intrinsic currency value.")
    public wert: number;

    public constructor(init?: Partial<GeldBetragOhneCent12DE>) { super(init); (Object as any).assign(this, init); }
}

/** @description Geldbetrag ohne Cent mit 12 Stellen. Mindestens eine Ziffer und maximal 12 Ziffern. Minusvorzeichen erlaubt. */
// @Api(Description="Geldbetrag ohne Cent mit 12 Stellen. Mindestens eine Ziffer und maximal 12 Ziffern. Minusvorzeichen erlaubt.")
export class GeldBetragOhneCent12DEFeld extends CustomFeldBase
{
    /** @description Wert des Feldes. Mindestens eine Ziffer und maximal 12 Ziffern. Minusvorzeichen erlaubt. */
    // @ApiMember(Description="Wert des Feldes. Mindestens eine Ziffer und maximal 12 Ziffern. Minusvorzeichen erlaubt.", IsRequired=true)
    public betrag: GeldBetragOhneCent12DE;

    /** @description Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung. */
    // @ApiMember(Description="Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung.")
    public nr: number;

    /** @description Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1 */
    // @ApiMember(Description="Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1")
    public index: number;

    /** @description Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1 */
    // @ApiMember(Description="Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1")
    public lfdNr: number;

    /** @description Identifizierung der Zeile / Feld im Fremdprogramm. */
    // @ApiMember(Description="Identifizierung der Zeile / Feld im Fremdprogramm.")
    public alias?: string;

    public constructor(init?: Partial<GeldBetragOhneCent12DEFeld>) { super(init); (Object as any).assign(this, init); }
}

/** @description Angaben der Besteuerung von Kleinunternehmer der Umsatzsteuererklärung für 2020. */
// @Api(Description="Angaben der Besteuerung von Kleinunternehmer der Umsatzsteuererklärung für 2020.")
export class AngabenBesteuerungKleinunternehmer2020
{
    /** @description Umsatz im Kalenderjahr 2019 (Berechnung nach § 19 Absatz 1 und 3 UStG) */
    // @ApiMember(Description="Umsatz im Kalenderjahr 2019 (Berechnung nach § 19 Absatz 1 und 3 UStG)", Name="Nr3002301")
    public nr3002301?: GeldBetragOhneCent5DEFeld;

    /** @description Umsatz im Kalenderjahr 2020 (Berechnung nach § 19 Absatz 1 und 3 UStG) */
    // @ApiMember(Description="Umsatz im Kalenderjahr 2020 (Berechnung nach § 19 Absatz 1 und 3 UStG)", Name="Nr3002401")
    public nr3002401?: GeldBetragOhneCent12DEFeld;

    public constructor(init?: Partial<AngabenBesteuerungKleinunternehmer2020>) { (Object as any).assign(this, init); }
}

/** @description Steuerfreie Lieferungen, usw. für die Umsatzteuererklärung 2020. */
// @Api(Description="Steuerfreie Lieferungen, usw. für die Umsatzteuererklärung 2020.")
export class SteuerfreieLieferungenEtc2020
{
    /** @description an Abnehmer mit USt-Identifikationsnummer (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="an Abnehmer mit USt-Identifikationsnummer (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3103301")
    public nr3103301?: GeldBetragOhneCent12DEFeld;

    /** @description neuer Fahrzeuge an Abnehmer ohne USt-Identifikationsnummer (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="neuer Fahrzeuge an Abnehmer ohne USt-Identifikationsnummer (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3103401")
    public nr3103401?: GeldBetragOhneCent12DEFeld;

    /** @description neuer Fahrzeuge außerhalb eines Unternehmens (§ 2a UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="neuer Fahrzeuge außerhalb eines Unternehmens (§ 2a UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3103501")
    public nr3103501?: GeldBetragOhneCent12DEFeld;

    /** @description Ausfuhrlieferungen und Lohnveredelungen an Gegenständen der Ausfuhr (§ 4 Nummer 1 Buchstabe a UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="Ausfuhrlieferungen und Lohnveredelungen an Gegenständen der Ausfuhr (§ 4 Nummer 1 Buchstabe a UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3103801")
    public nr3103801?: GeldBetragOhneCent12DEFeld;

    /** @description Umsätze nach § ... UStG: */
    // @ApiMember(Description="Umsätze nach § ... UStG:", Name="Nr3103901")
    public nr3103901?: StringFeld;

    /** @description Umsätze nach § ... UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="Umsätze nach § ... UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3103902")
    public nr3103902?: GeldBetragOhneCent12DEFeld;

    /** @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) */
    // @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="Nr3104001")
    public nr3104001?: GeldBetragOhneCent12DEFeld;

    /** @description Reiseleistungen nach § 25 Absatz 2 UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="Reiseleistungen nach § 25 Absatz 2 UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3104101")
    public nr3104101?: GeldBetragOhneCent12DEFeld;

    /** @description Summe der Zeilen 67 bis 70 (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="Summe der Zeilen 67 bis 70 (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3104201")
    public nr3104201?: GeldBetragOhneCent12DEFeld;

    /** @description nach § 4 Nummer 12 UStG (Vermietung und Verpachtung von Grundstücken und so weiter) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="nach § 4 Nummer 12 UStG (Vermietung und Verpachtung von Grundstücken und so weiter) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3104401")
    public nr3104401?: GeldBetragOhneCent12DEFeld;

    /** @description nach § 4 Nummer ... UStG */
    // @ApiMember(Description="nach § 4 Nummer ... UStG", Name="Nr3104501")
    public nr3104501?: StringFeld;

    /** @description nach § 4 Nummer ... UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="nach § 4 Nummer ... UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3104502")
    public nr3104502?: GeldBetragOhneCent12DEFeld;

    /** @description Summe der Zeilen 73 und 74 (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="Summe der Zeilen 73 und 74 (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3104601")
    public nr3104601?: GeldBetragOhneCent12DEFeld;

    /** @description nach § ... UStG */
    // @ApiMember(Description="nach § ... UStG", Name="Nr3104901")
    public nr3104901?: StringFeld;

    /** @description nach § ... UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="nach § ... UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3104902")
    public nr3104902?: GeldBetragOhneCent12DEFeld;

    public constructor(init?: Partial<SteuerfreieLieferungenEtc2020>) { (Object as any).assign(this, init); }
}

/** @description Specifies an amount of money with cents with limits and a specialized string representation */
// @Api(Description="Specifies an amount of money with cents with limits and a specialized string representation")
export class GeldBetragMitCent
{
    /** @description The intrinsic currency value. */
    // @ApiMember(Description="The intrinsic currency value.")
    public wert: number;

    public constructor(init?: Partial<GeldBetragMitCent>) { (Object as any).assign(this, init); }
}

/** @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. */
// @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.")
export class GeldBetragMitCent12DE extends GeldBetragMitCent
{
    /** @description The intrinsic currency value. */
    // @ApiMember(Description="The intrinsic currency value.")
    public wert: number;

    public constructor(init?: Partial<GeldBetragMitCent12DE>) { super(init); (Object as any).assign(this, init); }
}

/** @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. */
// @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.")
export class GeldBetragMitCent12DEFeld extends CustomFeldBase
{
    /** @description Wert des Feldes. Mindestens eine Ziffer und maximal 12 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen erlaubt. */
    // @ApiMember(Description="Wert des Feldes. Mindestens eine Ziffer und maximal 12 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen erlaubt.", IsRequired=true)
    public betrag: GeldBetragMitCent12DE;

    /** @description Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung. */
    // @ApiMember(Description="Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung.")
    public nr: number;

    /** @description Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1 */
    // @ApiMember(Description="Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1")
    public index: number;

    /** @description Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1 */
    // @ApiMember(Description="Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1")
    public lfdNr: number;

    /** @description Identifizierung der Zeile / Feld im Fremdprogramm. */
    // @ApiMember(Description="Identifizierung der Zeile / Feld im Fremdprogramm.")
    public alias?: string;

    public constructor(init?: Partial<GeldBetragMitCent12DEFeld>) { super(init); (Object as any).assign(this, init); }
}

/** @description Steuerpflichtige Lieferungen, usw. für die Umsatzteuererklärung 2020. */
// @Api(Description="Steuerpflichtige Lieferungen, usw. für die Umsatzteuererklärung 2020.")
export class SteuerpflichtigeLieferungenEtc2020
{
    /** @description Lieferungen und sonstige Leistungen zu 19 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="Lieferungen und sonstige Leistungen zu 19 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3003303")
    public nr3003303?: GeldBetragOhneCent12DEFeld;

    /** @description Lieferungen und sonstige Leistungen zu 19 Prozent (Steuer) */
    // @ApiMember(Description="Lieferungen und sonstige Leistungen zu 19 Prozent (Steuer)", Name="Nr3003304")
    public nr3003304?: GeldBetragMitCent12DEFeld;

    /** @description 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 (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3003405")
    public nr3003405?: GeldBetragOhneCent12DEFeld;

    /** @description Unentgeltliche Wertabgaben - Lieferungen nach § 3 Absatz 1b UStG zu 19 Prozent (Steuer) */
    // @ApiMember(Description="Unentgeltliche Wertabgaben - Lieferungen nach § 3 Absatz 1b UStG zu 19 Prozent (Steuer)", Name="Nr3003406")
    public nr3003406?: GeldBetragMitCent12DEFeld;

    /** @description 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 (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3003505")
    public nr3003505?: GeldBetragOhneCent12DEFeld;

    /** @description Unentgeltliche Wertabgaben - Sonstige Leistungen nach § 3 Absatz 9a UStG zu 19 Prozent (Steuer) */
    // @ApiMember(Description="Unentgeltliche Wertabgaben - Sonstige Leistungen nach § 3 Absatz 9a UStG zu 19 Prozent (Steuer)", Name="Nr3003506")
    public nr3003506?: GeldBetragMitCent12DEFeld;

    /** @description Lieferungen und sonstige Leistungen zu 7 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="Lieferungen und sonstige Leistungen zu 7 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3004401")
    public nr3004401?: GeldBetragOhneCent12DEFeld;

    /** @description Lieferungen und sonstige Leistungen zu 7 Prozent (Steuer) */
    // @ApiMember(Description="Lieferungen und sonstige Leistungen zu 7 Prozent (Steuer)", Name="Nr3004402")
    public nr3004402?: GeldBetragMitCent12DEFeld;

    /** @description 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 (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3003703")
    public nr3003703?: GeldBetragOhneCent12DEFeld;

    /** @description Unentgeltliche Wertabgaben - Lieferungen nach § 3 Absatz 1b UStG zu 7 Prozent (Steuer) */
    // @ApiMember(Description="Unentgeltliche Wertabgaben - Lieferungen nach § 3 Absatz 1b UStG zu 7 Prozent (Steuer)", Name="Nr3003704")
    public nr3003704?: GeldBetragMitCent12DEFeld;

    /** @description 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 (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3003803")
    public nr3003803?: GeldBetragOhneCent12DEFeld;

    /** @description Unentgeltliche Wertabgaben - Sonstige Leistungen nach § 3 Absatz 9a UStG zu 7 Prozent (Steuer) */
    // @ApiMember(Description="Unentgeltliche Wertabgaben - Sonstige Leistungen nach § 3 Absatz 9a UStG zu 7 Prozent (Steuer)", Name="Nr3003804")
    public nr3003804?: GeldBetragMitCent12DEFeld;

    /** @description Umsätze zu anderen Steuersätzen (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="Umsätze zu anderen Steuersätzen (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3005001")
    public nr3005001?: GeldBetragOhneCent12DEFeld;

    /** @description Umsätze zu anderen Steuersätzen (Steuer) */
    // @ApiMember(Description="Umsätze zu anderen Steuersätzen (Steuer)", Name="Nr3005002")
    public nr3005002?: GeldBetragMitCent12DEFeld;

    /** @description Lieferungen in das übrige Gemeinschaftsgebiet an Abnehmer mit USt-Identifikationsnummer (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="Lieferungen in das übrige Gemeinschaftsgebiet an Abnehmer mit USt-Identifikationsnummer (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3005201")
    public nr3005201?: GeldBetragOhneCent12DEFeld;

    /** @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) */
    // @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="Nr3005301")
    public nr3005301?: GeldBetragOhneCent12DEFeld;

    /** @description Steuerpflichtige Lieferungen (einschließlich unentgeltlicher Wertabgaben) von Sägewerkserzeugnissen, die in der Anlage 2 zum UStG nicht aufgeführt sind (Steuer) */
    // @ApiMember(Description="Steuerpflichtige Lieferungen (einschließlich unentgeltlicher Wertabgaben) von Sägewerkserzeugnissen, die in der Anlage 2 zum UStG nicht aufgeführt sind (Steuer)", Name="Nr3005302")
    public nr3005302?: GeldBetragMitCent12DEFeld;

    /** @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 8,3 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 8,3 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3005003")
    public nr3005003?: GeldBetragOhneCent12DEFeld;

    /** @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 8,3 Prozent (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) zu 8,3 Prozent (Steuer)", Name="Nr3005004")
    public nr3005004?: GeldBetragMitCent12DEFeld;

    /** @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) */
    // @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="Nr3005701")
    public nr3005701?: GeldBetragOhneCent12DEFeld;

    /** @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) */
    // @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="Nr3005702")
    public nr3005702?: GeldBetragMitCent12DEFeld;

    /** @description Übrige steuerpflichtige Umsätze land- und forstwirtschaftlicher Betriebe, für die keine Steuer zu entrichten ist (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="Übrige steuerpflichtige Umsätze land- und forstwirtschaftlicher Betriebe, für die keine Steuer zu entrichten ist (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3005801")
    public nr3005801?: GeldBetragOhneCent12DEFeld;

    /** @description Nachsteuer/Anrechnung der Steuer, die auf bereits versteuerte Anzahlungen entfällt (im Falle der Anrechnung bitte auch Zeile 57 ausfüllen) (Steuer) */
    // @ApiMember(Description="Nachsteuer/Anrechnung der Steuer, die auf bereits versteuerte Anzahlungen entfällt (im Falle der Anrechnung bitte auch Zeile 57 ausfüllen) (Steuer)", Name="Nr3102901")
    public nr3102901?: GeldBetragMitCent12DEFeld;

    /** @description Betrag der Anzahlungen, für die die anzurechnende Steuer in Zeile 56 angegeben worden ist (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="Betrag der Anzahlungen, für die die anzurechnende Steuer in Zeile 56 angegeben worden ist (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3102801")
    public nr3102801?: GeldBetragOhneCent12DEFeld;

    /** @description Nachsteuer auf versteuerte Anzahlungen und ähnlich wegen Steuersatzänderung (Steuer) */
    // @ApiMember(Description="Nachsteuer auf versteuerte Anzahlungen und ähnlich wegen Steuersatzänderung (Steuer)", Name="Nr3005901")
    public nr3005901?: GeldBetragMitCent12DEFeld;

    /** @description Summe der Steuer (zu übertragen in Zeile 152) */
    // @ApiMember(Description="Summe der Steuer (zu übertragen in Zeile 152)", Name="Nr3006001")
    public nr3006001?: GeldBetragMitCent12DEFeld;

    public constructor(init?: Partial<SteuerpflichtigeLieferungenEtc2020>) { (Object as any).assign(this, init); }
}

/** @description Innergemeinschaftliche Erwerbe der Umsatzsteuererklärung für 2020. */
// @Api(Description="Innergemeinschaftliche Erwerbe der Umsatzsteuererklärung für 2020.")
export class InnergemeinschaftlicheErwerbe2020
{
    /** @description nach §§ 4b und 25c UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="nach §§ 4b und 25c UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3100901")
    public nr3100901?: GeldBetragOhneCent12DEFeld;

    /** @description zum Steuersatz von 19 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="zum Steuersatz von 19 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3100902")
    public nr3100902?: GeldBetragOhneCent12DEFeld;

    /** @description zum Steuersatz von 19 Prozent (Steuer) */
    // @ApiMember(Description="zum Steuersatz von 19 Prozent (Steuer)", Name="Nr3100903")
    public nr3100903?: GeldBetragMitCent12DEFeld;

    /** @description zum Steuersatz von 7 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="zum Steuersatz von 7 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3101301")
    public nr3101301?: GeldBetragOhneCent12DEFeld;

    /** @description zum Steuersatz von 7 Prozent (Steuer) */
    // @ApiMember(Description="zum Steuersatz von 7 Prozent (Steuer)", Name="Nr3101302")
    public nr3101302?: GeldBetragMitCent12DEFeld;

    /** @description zu anderen Steuersätzen (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="zu anderen Steuersätzen (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3101303")
    public nr3101303?: GeldBetragOhneCent12DEFeld;

    /** @description zu anderen Steuersätzen (Steuer) */
    // @ApiMember(Description="zu anderen Steuersätzen (Steuer)", Name="Nr3101304")
    public nr3101304?: GeldBetragMitCent12DEFeld;

    /** @description 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 (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3101401")
    public nr3101401?: GeldBetragOhneCent12DEFeld;

    /** @description neuer Fahrzeuge (§ 1b Absatz 2 und 3 UStG) von Lieferern ohne USt-Identifikationsnummer zum allgemeinen Steuersatz (Steuer) */
    // @ApiMember(Description="neuer Fahrzeuge (§ 1b Absatz 2 und 3 UStG) von Lieferern ohne USt-Identifikationsnummer zum allgemeinen Steuersatz (Steuer)", Name="Nr3101402")
    public nr3101402?: GeldBetragMitCent12DEFeld;

    /** @description Summe der Steuer (zu übertragen in Zeile 153) */
    // @ApiMember(Description="Summe der Steuer (zu übertragen in Zeile 153)", Name="Nr3101501")
    public nr3101501?: GeldBetragMitCent12DEFeld;

    public constructor(init?: Partial<InnergemeinschaftlicheErwerbe2020>) { (Object as any).assign(this, init); }
}

/** @description Steuerschuldner bei Auslagerung der Umsatzsteuererklärung für 2020. */
// @Api(Description="Steuerschuldner bei Auslagerung der Umsatzsteuererklärung für 2020.")
export class SteuerschuldnerBeiAuslagerung2020
{
    /** @description 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) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3102804")
    public nr3102804?: GeldBetragOhneCent12DEFeld;

    /** @description Lieferungen, die der Auslagerung vorangegangen sind (§ 4 Nummer 4a Satz 1 Buchstabe a Satz 2 UStG) (Steuer) */
    // @ApiMember(Description="Lieferungen, die der Auslagerung vorangegangen sind (§ 4 Nummer 4a Satz 1 Buchstabe a Satz 2 UStG) (Steuer)", Name="Nr3102805")
    public nr3102805?: GeldBetragMitCent12DEFeld;

    /** @description Summe der Steuer (zu übertragen in Zeile 154) */
    // @ApiMember(Description="Summe der Steuer (zu übertragen in Zeile 154)", Name="Nr3102904")
    public nr3102904?: GeldBetragMitCent12DEFeld;

    public constructor(init?: Partial<SteuerschuldnerBeiAuslagerung2020>) { (Object as any).assign(this, init); }
}

/** @description Innergemeinschaftliche Dreiecksgeschäfte der Umsatzsteuererklärung für 2020. */
// @Api(Description="Innergemeinschaftliche Dreiecksgeschäfte der Umsatzsteuererklärung für 2020.")
export class InnergemeinschaftlicheDreiecksgeschaefte2020
{
    /** @description Bemessungsgrundlage ohne Umsatzsteuer (volle EUR) */
    // @ApiMember(Description="Bemessungsgrundlage ohne Umsatzsteuer (volle EUR)", Name="Nr3101801")
    public nr3101801?: GeldBetragOhneCent12DEFeld;

    /** @description zum Steuersatz von 19 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="zum Steuersatz von 19 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3101701")
    public nr3101701?: GeldBetragOhneCent12DEFeld;

    /** @description zum Steuersatz von 19 Prozent (Steuer) */
    // @ApiMember(Description="zum Steuersatz von 19 Prozent (Steuer)", Name="Nr3101702")
    public nr3101702?: GeldBetragMitCent12DEFeld;

    /** @description zum Steuersatz von 7 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="zum Steuersatz von 7 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3102301")
    public nr3102301?: GeldBetragOhneCent12DEFeld;

    /** @description zum Steuersatz von 7 Prozent (Steuer) */
    // @ApiMember(Description="zum Steuersatz von 7 Prozent (Steuer)", Name="Nr3102302")
    public nr3102302?: GeldBetragMitCent12DEFeld;

    /** @description zu anderen Steuersätzen (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="zu anderen Steuersätzen (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3102303")
    public nr3102303?: GeldBetragOhneCent12DEFeld;

    /** @description zu anderen Steuersätzen (Steuer) */
    // @ApiMember(Description="zu anderen Steuersätzen (Steuer)", Name="Nr3102304")
    public nr3102304?: GeldBetragMitCent12DEFeld;

    /** @description Summe der Steuer (zu übertragen in Zeile 155) */
    // @ApiMember(Description="Summe der Steuer (zu übertragen in Zeile 155)", Name="Nr3102401")
    public nr3102401?: GeldBetragMitCent12DEFeld;

    public constructor(init?: Partial<InnergemeinschaftlicheDreiecksgeschaefte2020>) { (Object as any).assign(this, init); }
}

/** @description Leistungsempfänger als Steuerschuldner der Umsatzsteuererklärung für 2020. */
// @Api(Description="Leistungsempfänger als Steuerschuldner der Umsatzsteuererklärung für 2020.")
export class LeistungsempfaengerAlsSteuerschuldner2020
{
    /** @description 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) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3102205")
    public nr3102205?: GeldBetragOhneCent12DEFeld;

    /** @description Steuerpflichtige sonstige Leistungen eines im übrigen Gemeinschaftsgebiet ansässigen Unternehmers (§ 13b Absatz 1 UStG) (Steuer) */
    // @ApiMember(Description="Steuerpflichtige sonstige Leistungen eines im übrigen Gemeinschaftsgebiet ansässigen Unternehmers (§ 13b Absatz 1 UStG) (Steuer)", Name="Nr3102206")
    public nr3102206?: GeldBetragMitCent12DEFeld;

    /** @description 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) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3102307")
    public nr3102307?: GeldBetragOhneCent12DEFeld;

    /** @description Umsätze, die unter das GrEStG fallen (§ 13b Absatz 2 Nummer 3 UStG) (Steuer) */
    // @ApiMember(Description="Umsätze, die unter das GrEStG fallen (§ 13b Absatz 2 Nummer 3 UStG) (Steuer)", Name="Nr3102308")
    public nr3102308?: GeldBetragMitCent12DEFeld;

    /** @description Andere Leistungen (§ 13b Absatz 2 Nummer 1, 2, 4 bis 11 UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="Andere Leistungen (§ 13b Absatz 2 Nummer 1, 2, 4 bis 11 UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3102503")
    public nr3102503?: GeldBetragOhneCent12DEFeld;

    /** @description Andere Leistungen (§ 13b Absatz 2 Nummer 1, 2, 4 bis 11 UStG) (Steuer) */
    // @ApiMember(Description="Andere Leistungen (§ 13b Absatz 2 Nummer 1, 2, 4 bis 11 UStG) (Steuer)", Name="Nr3102504")
    public nr3102504?: GeldBetragMitCent12DEFeld;

    /** @description Summe der Steuer (zu übertragen in Zeile 156) */
    // @ApiMember(Description="Summe der Steuer (zu übertragen in Zeile 156)", Name="Nr3102601")
    public nr3102601?: GeldBetragMitCent12DEFeld;

    public constructor(init?: Partial<LeistungsempfaengerAlsSteuerschuldner2020>) { (Object as any).assign(this, init); }
}

/** @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. */
// @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.")
export class PositiverGeldBetragOhneCent12DE extends GrossGeldBetragOhneCent
{
    /** @description The intrinsic currency value. */
    // @ApiMember(Description="The intrinsic currency value.")
    public wert: number;

    public constructor(init?: Partial<PositiverGeldBetragOhneCent12DE>) { super(init); (Object as any).assign(this, init); }
}

/** @description Positiver Geldbetrag ohne Cent mit 13 Stellen. Mindestens eine Ziffer und maximal 12 Ziffern. Minusvorzeichen NICHT erlaubt. */
// @Api(Description="Positiver Geldbetrag ohne Cent mit 13 Stellen. Mindestens eine Ziffer und maximal 12 Ziffern. Minusvorzeichen NICHT erlaubt.")
export class PositiverGeldBetragOhneCent12DEFeld extends CustomFeldBase
{
    /** @description Wert des Feldes. Mindestens eine Ziffer und maximal 12 Ziffern. Minusvorzeichen NICHT erlaubt. */
    // @ApiMember(Description="Wert des Feldes. Mindestens eine Ziffer und maximal 12 Ziffern. Minusvorzeichen NICHT erlaubt.", IsRequired=true)
    public betrag: PositiverGeldBetragOhneCent12DE;

    /** @description Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung. */
    // @ApiMember(Description="Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung.")
    public nr: number;

    /** @description Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1 */
    // @ApiMember(Description="Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1")
    public index: number;

    /** @description Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1 */
    // @ApiMember(Description="Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1")
    public lfdNr: number;

    /** @description Identifizierung der Zeile / Feld im Fremdprogramm. */
    // @ApiMember(Description="Identifizierung der Zeile / Feld im Fremdprogramm.")
    public alias?: string;

    public constructor(init?: Partial<PositiverGeldBetragOhneCent12DEFeld>) { super(init); (Object as any).assign(this, init); }
}

/** @description Ergänzende Angaben der Umsatzsteuererklärung für 2020. */
// @Api(Description="Ergänzende Angaben der Umsatzsteuererklärung für 2020.")
export class ErgaenzendeAngaben2020
{
    /** @description Umsätze, die auf Grund eines Verzichts auf Steuerbefreiung (§ 9 UStG) als steuerpflichtig behandelt worden sind (Betrag volle EUR) */
    // @ApiMember(Description="Umsätze, die auf Grund eines Verzichts auf Steuerbefreiung (§ 9 UStG) als steuerpflichtig behandelt worden sind (Betrag volle EUR)", Name="Nr3105201")
    public nr3105201?: GeldBetragOhneCent12DEFeld;

    /** @description Steuerpflichtige Umsätze, für die der Leistungsempfänger die Steuer nach § 13b Absatz 5 UStG schuldet (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="Nr3105301")
    public nr3105301?: GeldBetragOhneCent12DEFeld;

    /** @description Beförderungs- und Versendungslieferungen in das übrige Gemeinschaftsgebiet (§ 3c UStG) in Abschnitt C enthalten (Betrag volle EUR) */
    // @ApiMember(Description="Beförderungs- und Versendungslieferungen in das übrige Gemeinschaftsgebiet (§ 3c UStG) in Abschnitt C enthalten (Betrag volle EUR)", Name="Nr3105501")
    public nr3105501?: GeldBetragOhneCent12DEFeld;

    /** @description Beförderungs- und Versendungslieferungen in das übrige Gemeinschaftsgebiet (§ 3c UStG) in anderen EU-Mitgliedstaaten zu versteuern (Betrag volle EUR) */
    // @ApiMember(Description="Beförderungs- und Versendungslieferungen in das übrige Gemeinschaftsgebiet (§ 3c UStG) in anderen EU-Mitgliedstaaten zu versteuern (Betrag volle EUR)", Name="Nr3105601")
    public nr3105601?: GeldBetragOhneCent12DEFeld;

    /** @description Telekommunikations-, Rundfunk- und Fernsehdienstleistungen sowie auf elektronischem Weg erbrachte sonstige Leistungen an im übrigen Gemeinschaftsgebiet ansässige Nichtunternehmer unter der Voraussetzung des § 3a Absatz 5 Sätze 3 und 4 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 unter der Voraussetzung des § 3a Absatz 5 Sätze 3 und 4 UStG in Abschnitt B oder C enthalten (Betrag volle EUR)", Name="Nr3105101")
    public nr3105101?: PositiverGeldBetragOhneCent12DEFeld;

    /** @description Telekommunikations-, Rundfunk- und Fernsehdienstleistungen sowie auf elektronischem Weg erbrachte sonstige Leistungen an im übrigen Gemeinschaftsgebiet ansässige Nichtunternehmer unter der Voraussetzung des § 3a Absatz 5 Sätze 3 und 4 UStG in anderen EU-Mitgliedstaaten zu versteuern (Betrag volle EUR) */
    // @ApiMember(Description="Telekommunikations-, Rundfunk- und Fernsehdienstleistungen sowie auf elektronischem Weg erbrachte sonstige Leistungen an im übrigen Gemeinschaftsgebiet ansässige Nichtunternehmer unter der Voraussetzung des § 3a Absatz 5 Sätze 3 und 4 UStG in anderen EU-Mitgliedstaaten zu versteuern (Betrag volle EUR)", Name="Nr3105102")
    public nr3105102?: PositiverGeldBetragOhneCent12DEFeld;

    /** @description Nicht steuerbare Geschäftsveräußerung im Ganzen gemäß § 1 Absatz 1a UStG (Betrag volle EUR) */
    // @ApiMember(Description="Nicht steuerbare Geschäftsveräußerung im Ganzen gemäß § 1 Absatz 1a UStG (Betrag volle EUR)", Name="Nr3105602")
    public nr3105602?: GeldBetragOhneCent12DEFeld;

    /** @description Nicht steuerbare sonstige Leistungen gemäß § 18b Satz 1 Nummer 2 UStG (Betrag volle EUR) */
    // @ApiMember(Description="Nicht steuerbare sonstige Leistungen gemäß § 18b Satz 1 Nummer 2 UStG (Betrag volle EUR)", Name="Nr3105702")
    public nr3105702?: GeldBetragOhneCent12DEFeld;

    /** @description Übrige nicht steuerbare Umsätze (Leistungsort nicht im Inland) (Betrag volle EUR) */
    // @ApiMember(Description="Übrige nicht steuerbare Umsätze (Leistungsort nicht im Inland) (Betrag volle EUR)", Name="Nr3105801")
    public nr3105801?: GeldBetragOhneCent12DEFeld;

    /** @description In den Zeilen 110, 113, 115 und 116 enthaltene Umsätze, die nach § 15 Absatz 2 und 3 UStG den Vorsteuerabzug ausschließen (Betrag volle EUR) */
    // @ApiMember(Description="In den Zeilen 110, 113, 115 und 116 enthaltene Umsätze, die nach § 15 Absatz 2 und 3 UStG den Vorsteuerabzug ausschließen (Betrag volle EUR)", Name="Nr3105901")
    public nr3105901?: GeldBetragOhneCent12DEFeld;

    /** @description Auf den inländischen Streckenanteil entfallende Umsätze grenzüberschreitender Personenbeförderungen im Luftverkehr (§ 26 Absatz 3 UStG) (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="Nr3106001")
    public nr3106001?: GeldBetragOhneCent12DEFeld;

    public constructor(init?: Partial<ErgaenzendeAngaben2020>) { (Object as any).assign(this, init); }
}

/** @description Abziehbare Vorsteuerbeträge der Umsatzsteuererklärung für 2020. */
// @Api(Description="Abziehbare Vorsteuerbeträge der Umsatzsteuererklärung für 2020.")
export class AbziehbareVorsteuerbetraege2020
{
    /** @description Vorsteuerbeträge aus Rechnungen von anderen Unternehmern (§ 15 Absatz 1 Satz 1 Nummer 1 UStG) */
    // @ApiMember(Description="Vorsteuerbeträge aus Rechnungen von anderen Unternehmern (§ 15 Absatz 1 Satz 1 Nummer 1 UStG)", Name="Nr3006201")
    public nr3006201?: GeldBetragMitCent12DEFeld;

    /** @description Vorsteuerbeträge aus innergemeinschaftlichen Erwerben von Gegenständen (§ 15 Absatz 1 Satz 1 Nummer 3 UStG)  */
    // @ApiMember(Description="Vorsteuerbeträge aus innergemeinschaftlichen Erwerben von Gegenständen (§ 15 Absatz 1 Satz 1 Nummer 3 UStG) ", Name="Nr3006301")
    public nr3006301?: GeldBetragMitCent12DEFeld;

    /** @description Entstandene Einfuhrumsatzsteuer (§ 15 Absatz 1 Satz 1 Nummer 2 UStG) */
    // @ApiMember(Description="Entstandene Einfuhrumsatzsteuer (§ 15 Absatz 1 Satz 1 Nummer 2 UStG)", Name="Nr3006401")
    public nr3006401?: GeldBetragMitCent12DEFeld;

    /** @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) */
    // @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="Nr3006503")
    public nr3006503?: GeldBetragMitCent12DEFeld;

    /** @description Vorsteuerbeträge aus Leistungen im Sinne des § 13b UStG (§ 15 Absatz 1 Satz 1 Nummer 4 UStG) */
    // @ApiMember(Description="Vorsteuerbeträge aus Leistungen im Sinne des § 13b UStG (§ 15 Absatz 1 Satz 1 Nummer 4 UStG)", Name="Nr3006502")
    public nr3006502?: GeldBetragMitCent12DEFeld;

    /** @description Vorsteuerbeträge, die nach den allgemeinen Durchschnittssätzen berechnet sind (§ 23 UStG) */
    // @ApiMember(Description="Vorsteuerbeträge, die nach den allgemeinen Durchschnittssätzen berechnet sind (§ 23 UStG)", Name="Nr3006501")
    public nr3006501?: GeldBetragMitCent12DEFeld;

    /** @description Vorsteuerbeträge nach dem Durchschnittssatz für bestimmte Körperschaften, Personenvereinigungen und Vermögensmassen (§ 23a UStG) */
    // @ApiMember(Description="Vorsteuerbeträge nach dem Durchschnittssatz für bestimmte Körperschaften, Personenvereinigungen und Vermögensmassen (§ 23a UStG)", Name="Nr3006601")
    public nr3006601?: GeldBetragMitCent12DEFeld;

    /** @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) */
    // @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="Nr3006701")
    public nr3006701?: GeldBetragMitCent12DEFeld;

    /** @description Vorsteuerbeträge aus innergemeinschaftlichen Dreiecksgeschäften (§ 25b Absatz 5 UStG) */
    // @ApiMember(Description="Vorsteuerbeträge aus innergemeinschaftlichen Dreiecksgeschäften (§ 25b Absatz 5 UStG)", Name="Nr3006801")
    public nr3006801?: GeldBetragMitCent12DEFeld;

    /** @description Summe der Vorsteuerbeträge (zu übertragen in Zeile 158) */
    // @ApiMember(Description="Summe der Vorsteuerbeträge (zu übertragen in Zeile 158)", Name="Nr3006901")
    public nr3006901?: GeldBetragMitCent12DEFeld;

    public constructor(init?: Partial<AbziehbareVorsteuerbetraege2020>) { (Object as any).assign(this, init); }
}

/** @description Datums-Uhrzeitfeld. Format: TT.MM.JJJJ. */
// @Api(Description="Datums-Uhrzeitfeld. Format: TT.MM.JJJJ.")
export class DatumUhrzeitFeld extends CustomFeldBase
{
    /** @description Wert des Feldes. */
    // @ApiMember(Description="Wert des Feldes.", IsRequired=true, Name="Wert")
    public wert: string;

    /** @description Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung. */
    // @ApiMember(Description="Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung.")
    public nr: number;

    /** @description Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1 */
    // @ApiMember(Description="Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1")
    public index: number;

    /** @description Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1 */
    // @ApiMember(Description="Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1")
    public lfdNr: number;

    /** @description Identifizierung der Zeile / Feld im Fremdprogramm. */
    // @ApiMember(Description="Identifizierung der Zeile / Feld im Fremdprogramm.")
    public alias?: string;

    public constructor(init?: Partial<DatumUhrzeitFeld>) { super(init); (Object as any).assign(this, init); }
}

/** @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. */
// @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.")
export class PositiverGeldBetragMitCent13DE extends GeldBetragMitCent
{
    /** @description The intrinsic currency value. */
    // @ApiMember(Description="The intrinsic currency value.")
    public wert: number;

    public constructor(init?: Partial<PositiverGeldBetragMitCent13DE>) { super(init); (Object as any).assign(this, init); }
}

/** @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. */
// @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.")
export class PositiverGeldBetragMitCent13DEFeld extends CustomFeldBase
{
    /** @description Wert des Feldes.  Mindestens eine Ziffer und maximal 13 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen NICHT erlaubt. */
    // @ApiMember(Description="Wert des Feldes.  Mindestens eine Ziffer und maximal 13 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen NICHT erlaubt.", IsRequired=true)
    public betrag: PositiverGeldBetragMitCent13DE;

    /** @description Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung. */
    // @ApiMember(Description="Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung.")
    public nr: number;

    /** @description Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1 */
    // @ApiMember(Description="Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1")
    public index: number;

    /** @description Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1 */
    // @ApiMember(Description="Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1")
    public lfdNr: number;

    /** @description Identifizierung der Zeile / Feld im Fremdprogramm. */
    // @ApiMember(Description="Identifizierung der Zeile / Feld im Fremdprogramm.")
    public alias?: string;

    public constructor(init?: Partial<PositiverGeldBetragMitCent13DEFeld>) { super(init); (Object as any).assign(this, init); }
}

/** @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. */
// @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.")
export class PositiverGeldBetragMitCent12DE extends GeldBetragMitCent
{
    /** @description The intrinsic currency value. */
    // @ApiMember(Description="The intrinsic currency value.")
    public wert: number;

    public constructor(init?: Partial<PositiverGeldBetragMitCent12DE>) { super(init); (Object as any).assign(this, init); }
}

/** @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. */
// @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.")
export class PositiverGeldBetragMitCent12DEFeld extends CustomFeldBase
{
    /** @description Wert des Feldes.  Mindestens eine Ziffer und maximal 12 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen NICHT erlaubt. */
    // @ApiMember(Description="Wert des Feldes.  Mindestens eine Ziffer und maximal 12 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen NICHT erlaubt.", IsRequired=true)
    public betrag: PositiverGeldBetragMitCent12DE;

    /** @description Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung. */
    // @ApiMember(Description="Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung.")
    public nr: number;

    /** @description Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1 */
    // @ApiMember(Description="Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1")
    public index: number;

    /** @description Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1 */
    // @ApiMember(Description="Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1")
    public lfdNr: number;

    /** @description Identifizierung der Zeile / Feld im Fremdprogramm. */
    // @ApiMember(Description="Identifizierung der Zeile / Feld im Fremdprogramm.")
    public alias?: string;

    public constructor(init?: Partial<PositiverGeldBetragMitCent12DEFeld>) { super(init); (Object as any).assign(this, init); }
}

/** @description Berichtigung des Vorsteuerabzugs der Umsatzsteuererklärung für 2020. */
// @Api(Description="Berichtigung des Vorsteuerabzugs der Umsatzsteuererklärung für 2020.")
export class BerichtigungVorsteuerabzug2020
{
    /** @description Berichtigung des Vorsteuerabzugs? Falls ja, bitte eine 'true' eintragen */
    // @ApiMember(Description="Berichtigung des Vorsteuerabzugs? Falls ja, bitte eine 'true' eintragen", Name="Nr3007301")
    public nr3007301?: Bool1Feld;

    /** @description Lage des Grundstücks oder Gebäudes */
    // @ApiMember(Description="Lage des Grundstücks oder Gebäudes", Name="Nr3007401")
    public nr3007401?: StringFeld;

    /** @description Zeitpunkt der erstmaligen tatsächlichen Verwendung */
    // @ApiMember(Description="Zeitpunkt der erstmaligen tatsächlichen Verwendung", Name="Nr3007402")
    public nr3007402?: DatumUhrzeitFeld;

    /** @description Art der Verwendung im Erstjahr */
    // @ApiMember(Description="Art der Verwendung im Erstjahr", Name="Nr3007403")
    public nr3007403?: StringFeld;

    /** @description Umfang der Verwendung im Erstjahr */
    // @ApiMember(Description="Umfang der Verwendung im Erstjahr", Name="Nr3007404")
    public nr3007404?: PositiverGeldBetragMitCent13DEFeld;

    /** @description insgesamt angefallene Vorsteuer */
    // @ApiMember(Description="insgesamt angefallene Vorsteuer", Name="Nr3007405")
    public nr3007405?: GeldBetragOhneCent12DEFeld;

    /** @description in den Vorjahren - Investitionsphase - bereits abgezogene Vorsteuer */
    // @ApiMember(Description="in den Vorjahren - Investitionsphase - bereits abgezogene Vorsteuer", Name="Nr3007406")
    public nr3007406?: GeldBetragOhneCent12DEFeld;

    /** @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 */
    // @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="Nr3007601")
    public nr3007601?: Bool1Feld;

    /** @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) */
    // @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="Nr3008501")
    public nr3008501?: Bool1Feld;

    /** @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 */
    // @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="Nr3008601")
    public nr3008601?: Bool1Feld;

    /** @description Veräußerung */
    // @ApiMember(Description="Veräußerung", Name="Nr3007801")
    public nr3007801?: BoolXFeld;

    /** @description Lieferung im Sinne des § 3 Absatz 1b UStG */
    // @ApiMember(Description="Lieferung im Sinne des § 3 Absatz 1b UStG", Name="Nr3007802")
    public nr3007802?: BoolXFeld;

    /** @description Wechsel der Besteuerungsform, § 15a Absatz 7 UStG */
    // @ApiMember(Description="Wechsel der Besteuerungsform, § 15a Absatz 7 UStG", Name="Nr3007803")
    public nr3007803?: BoolXFeld;

    /** @description Nutzungsänderung, und zwar */
    // @ApiMember(Description="Nutzungsänderung, und zwar", Name="Nr3007901")
    public nr3007901?: BoolXFeld;

    /** @description Übergang von steuerpflichtiger zu steuerfreier Vermietung oder umgekehrt beziehungsweise Änderung des Verwendungsschlüssels bei gemischt genutzten Grundstücken (insbesondere bei Mieterwechsel) */
    // @ApiMember(Description="Übergang von steuerpflichtiger zu steuerfreier Vermietung oder umgekehrt beziehungsweise Änderung des Verwendungsschlüssels bei gemischt genutzten Grundstücken (insbesondere bei Mieterwechsel)", Name="Nr3008001")
    public nr3008001?: BoolXFeld;

    /** @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 */
    // @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="Nr3008202")
    public nr3008202?: BoolXFeld;

    /** @description Andere Gründe für die geänderte Beurteilung des Vorsteuerabzugs: */
    // @ApiMember(Description="Andere Gründe für die geänderte Beurteilung des Vorsteuerabzugs:", Name="Nr3008401")
    public nr3008401?: BoolXFeld;

    /** @description Begründung */
    // @ApiMember(Description="Begründung", Name="Nr3008402")
    public nr3008402?: StringFeld;

    /** @description 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 (nachträglich abziehbar)", Name="Nr3008701")
    public nr3008701?: PositiverGeldBetragMitCent12DEFeld;

    /** @description zu 1. Grundstücke und so weiter, § 15a Absatz 1 Satz 2 UStG (zurückzuzahlen) */
    // @ApiMember(Description="zu 1. Grundstücke und so weiter, § 15a Absatz 1 Satz 2 UStG (zurückzuzahlen)", Name="Nr3008702")
    public nr3008702?: PositiverGeldBetragMitCent12DEFeld;

    /** @description 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 (nachträglich abziehbar)", Name="Nr3008801")
    public nr3008801?: PositiverGeldBetragMitCent12DEFeld;

    /** @description zu 2. andere Wirtschaftsgüter und so weiter, § 15a Absatz 1 Satz 1 UStG (zurückzuzahlen) */
    // @ApiMember(Description="zu 2. andere Wirtschaftsgüter und so weiter, § 15a Absatz 1 Satz 1 UStG (zurückzuzahlen)", Name="Nr3008802")
    public nr3008802?: PositiverGeldBetragMitCent12DEFeld;

    /** @description 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 (nachträglich abziehbar)", Name="Nr3008803")
    public nr3008803?: PositiverGeldBetragMitCent12DEFeld;

    /** @description zu 3. Wirtschaftsgüter und so weiter, § 15a Absatz 2 UStG (zurückzuzahlen) */
    // @ApiMember(Description="zu 3. Wirtschaftsgüter und so weiter, § 15a Absatz 2 UStG (zurückzuzahlen)", Name="Nr3008804")
    public nr3008804?: PositiverGeldBetragMitCent12DEFeld;

    /** @description Summe nachträglich abziehbar (zu übertragen in Zeile 159) */
    // @ApiMember(Description="Summe nachträglich abziehbar (zu übertragen in Zeile 159)", Name="Nr3008901")
    public nr3008901?: PositiverGeldBetragMitCent12DEFeld;

    /** @description Summe zurückzuzahlen (zu übertragen in Zeile 161) */
    // @ApiMember(Description="Summe zurückzuzahlen (zu übertragen in Zeile 161)", Name="Nr3008902")
    public nr3008902?: PositiverGeldBetragMitCent12DEFeld;

    public constructor(init?: Partial<BerichtigungVorsteuerabzug2020>) { (Object as any).assign(this, init); }
}

/** @description Berechnung der Umsatzsteuer der Umsatzsteuererklärung für 2020. */
// @Api(Description="Berechnung der Umsatzsteuer der Umsatzsteuererklärung für 2020.")
export class BerechnungUmsatzsteuer2020
{
    /** @description Umsatzsteuer auf steuerpflichtige Lieferungen, sonstige Leistungen und unentgeltliche Wertabgaben (aus Zeile 60) */
    // @ApiMember(Description="Umsatzsteuer auf steuerpflichtige Lieferungen, sonstige Leistungen und unentgeltliche Wertabgaben (aus Zeile 60)", Name="Nr3009201")
    public nr3009201?: GeldBetragMitCent12DEFeld;

    /** @description Umsatzsteuer auf innergemeinschaftliche Erwerbe (aus Zeile 86) */
    // @ApiMember(Description="Umsatzsteuer auf innergemeinschaftliche Erwerbe (aus Zeile 86)", Name="Nr3009401")
    public nr3009401?: GeldBetragMitCent12DEFeld;

    /** @description Umsatzsteuer, die vom Auslagerer oder Lagerhalter geschuldet wird (§ 13a Absatz 1 Nummer 6 UStG) (aus Zeile 90) */
    // @ApiMember(Description="Umsatzsteuer, die vom Auslagerer oder Lagerhalter geschuldet wird (§ 13a Absatz 1 Nummer 6 UStG) (aus Zeile 90)", Name="Nr3009602")
    public nr3009602?: GeldBetragMitCent12DEFeld;

    /** @description Umsatzsteuer, die vom letzten Abnehmer im innergemeinschaftlichen Dreiecksgeschäft geschuldet wird (§ 25b Absatz 2 UStG) (aus Zeile 97) */
    // @ApiMember(Description="Umsatzsteuer, die vom letzten Abnehmer im innergemeinschaftlichen Dreiecksgeschäft geschuldet wird (§ 25b Absatz 2 UStG) (aus Zeile 97)", Name="Nr3009501")
    public nr3009501?: GeldBetragMitCent12DEFeld;

    /** @description Umsatzsteuer, die vom Leistungsempfänger nach § 13b UStG geschuldet wird (aus Zeile 103) */
    // @ApiMember(Description="Umsatzsteuer, die vom Leistungsempfänger nach § 13b UStG geschuldet wird (aus Zeile 103)", Name="Nr3009502")
    public nr3009502?: GeldBetragMitCent12DEFeld;

    /** @description Zwischensumme */
    // @ApiMember(Description="Zwischensumme", Name="Nr3009801")
    public nr3009801?: GeldBetragMitCent12DEFeld;

    /** @description Abziehbare Vorsteuerbeträge (aus Zeile 131) */
    // @ApiMember(Description="Abziehbare Vorsteuerbeträge (aus Zeile 131)", Name="Nr3009901")
    public nr3009901?: GeldBetragMitCent12DEFeld;

    /** @description Vorsteuerbeträge, die auf Grund des § 15a UStG nachträglich abziehbar sind (aus Zeile 150) */
    // @ApiMember(Description="Vorsteuerbeträge, die auf Grund des § 15a UStG nachträglich abziehbar sind (aus Zeile 150)", Name="Nr3010001")
    public nr3010001?: PositiverGeldBetragMitCent12DEFeld;

    /** @description Verbleibender Betrag */
    // @ApiMember(Description="Verbleibender Betrag", Name="Nr3010201")
    public nr3010201?: GeldBetragMitCent12DEFeld;

    /** @description Vorsteuerbeträge, die auf Grund des § 15a UStG zurückzuzahlen sind (aus Zeile 150) */
    // @ApiMember(Description="Vorsteuerbeträge, die auf Grund des § 15a UStG zurückzuzahlen sind (aus Zeile 150)", Name="Nr3009701")
    public nr3009701?: PositiverGeldBetragMitCent12DEFeld;

    /** @description 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="In Rechnungen unrichtig oder unberechtigt ausgewiesene Steuerbeträge (§ 14c UStG) sowie Steuerbeträge, die nach § 6a Absatz 4 Satz 2 UStG geschuldet werden", Name="Nr3010301")
    public nr3010301?: GeldBetragMitCent12DEFeld;

    /** @description Steuerbeträge, die nach § 17 Absatz 1 Satz 6 UStG geschuldet werden */
    // @ApiMember(Description="Steuerbeträge, die nach § 17 Absatz 1 Satz 6 UStG geschuldet werden", Name="Nr3010401")
    public nr3010401?: GeldBetragMitCent12DEFeld;

    /** @description Steuer-, Vorsteuer- und Kürzungsbeträge, die auf frühere Besteuerungszeiträume entfallen (nur für Kleinunternehmer, die § 19 Absatz 1 UStG anwenden). */
    // @ApiMember(Description="Steuer-, Vorsteuer- und Kürzungsbeträge, die auf frühere Besteuerungszeiträume entfallen (nur für Kleinunternehmer, die § 19 Absatz 1 UStG anwenden).", Name="Nr3010501")
    public nr3010501?: GeldBetragMitCent12DEFeld;

    /** @description Umsatzsteuer / Überschuss (bei Überschuss - bitte dem Betrag ein Minuszeichen voranstellen) */
    // @ApiMember(Description="Umsatzsteuer / Überschuss (bei Überschuss - bitte dem Betrag ein Minuszeichen voranstellen)", Name="Nr3010601")
    public nr3010601?: GeldBetragMitCent12DEFeld;

    /** @description Anrechenbare Beträge (aus Zeile 23 der Anlage UN) */
    // @ApiMember(Description="Anrechenbare Beträge (aus Zeile 23 der Anlage UN)", Name="Nr3010602")
    public nr3010602?: GeldBetragMitCent12DEFeld;

    /** @description Verbleibende Umsatzsteuer / Verbleibender Überschuss (bei verbleibendem Überschuss - bitte dem Betrag ein Minuszeichen voranstellen) */
    // @ApiMember(Description="Verbleibende Umsatzsteuer / Verbleibender Überschuss (bei verbleibendem Überschuss - bitte dem Betrag ein Minuszeichen voranstellen)", IsRequired=true, Name="Nr3011101")
    public nr3011101: GeldBetragMitCent12DEFeld;

    /** @description Vorauszahlungssoll 2020 (einschließlich Sondervorauszahlung) */
    // @ApiMember(Description="Vorauszahlungssoll 2020 (einschließlich Sondervorauszahlung)", IsRequired=true, Name="Nr3011301")
    public nr3011301: GeldBetragMitCent12DEFeld;

    /** @description Noch an die Finanzkasse zu entrichten - Abschlusszahlung / Erstattungsanspruch (bei Erstattungsanspruch - bitte dem Betrag ein Minuszeichen voranstellen) */
    // @ApiMember(Description="Noch an die Finanzkasse zu entrichten - Abschlusszahlung / Erstattungsanspruch (bei Erstattungsanspruch - bitte dem Betrag ein Minuszeichen voranstellen)", IsRequired=true, Name="Nr3011401")
    public nr3011401: GeldBetragMitCent12DEFeld;

    public constructor(init?: Partial<BerechnungUmsatzsteuer2020>) { (Object as any).assign(this, init); }
}

/** @description Unterschrift der Umsatzsteuererklärung für 2020. */
// @Api(Description="Unterschrift der Umsatzsteuererklärung für 2020.")
export class Unterschrift2020
{
    /** @description Die Steuererklärung wurde unter Mitwirkung eines Angehörigen der steuerberatenden Berufe im Sinne der §§ 3 und 4 des Steuerberatungsgesetzes erstellt */
    // @ApiMember(Description="Die Steuererklärung wurde unter Mitwirkung eines Angehörigen der steuerberatenden Berufe im Sinne der §§ 3 und 4 des Steuerberatungsgesetzes erstellt", Name="Nr3002602")
    public nr3002602?: Bool1Feld;

    /** @description Name */
    // @ApiMember(Description="Name", Name="Nr3002501")
    public nr3002501?: StringFeld;

    /** @description Vorname */
    // @ApiMember(Description="Vorname", Name="Nr3002502")
    public nr3002502?: StringFeld;

    /** @description Straße, Hausnummer */
    // @ApiMember(Description="Straße, Hausnummer", Name="Nr3002503")
    public nr3002503?: StringFeld;

    /** @description Postleitzahl, Wohnort */
    // @ApiMember(Description="Postleitzahl, Wohnort", Name="Nr3002504")
    public nr3002504?: StringFeld;

    /** @description Telefon */
    // @ApiMember(Description="Telefon", Name="Nr3002505")
    public nr3002505?: StringFeld;

    /** @description Mandantennummer */
    // @ApiMember(Description="Mandantennummer", Name="Nr3002506")
    public nr3002506?: StringFeld;

    /** @description Mandantennummer für elektronische Bescheiddatenabholung */
    // @ApiMember(Description="Mandantennummer für elektronische Bescheiddatenabholung", Name="Nr3002507")
    public nr3002507?: StringFeld;

    /** @description zusätzliche Angaben */
    // @ApiMember(Description="zusätzliche Angaben", Name="Nr3002508")
    public nr3002508?: StringFeld;

    /** @description Bearbeiterkennzeichen */
    // @ApiMember(Description="Bearbeiterkennzeichen", Name="Nr3002509")
    public nr3002509?: StringFeld;

    public constructor(init?: Partial<Unterschrift2020>) { (Object as any).assign(this, init); }
}

/** @description Allgemeine Angaben der Anlage UN für 2020. */
// @Api(Description="Allgemeine Angaben der Anlage UN für 2020.")
export class AnlageUnAllgemeineAngaben2020
{
    /** @description IBAN */
    // @ApiMember(Description="IBAN", Name="Nr3201001")
    public nr3201001?: StringFeld;

    /** @description BIC (nur bei Bankverbindungen außerhalb des Europäischen Wirtschaftsraums) */
    // @ApiMember(Description="BIC (nur bei Bankverbindungen außerhalb des Europäischen Wirtschaftsraums)", Name="Nr3201002")
    public nr3201002?: StringFeld;

    /** @description Name des Geldinstituts (Zweigstelle) und Ort */
    // @ApiMember(Description="Name des Geldinstituts (Zweigstelle) und Ort", Name="Nr3200901")
    public nr3200901?: StringFeld;

    /** @description Kontonummer (nur bei Bankverbindungen außerhalb des Europäischen Zahlungsverkehrsraums - SEPA) */
    // @ApiMember(Description="Kontonummer (nur bei Bankverbindungen außerhalb des Europäischen Zahlungsverkehrsraums - SEPA)", Name="Nr3200902")
    public nr3200902?: StringFeld;

    /** @description Kontoinhaber ist der Unternehmer laut den allgemeinen Angaben auf Vordruck USt2A */
    // @ApiMember(Description="Kontoinhaber ist der Unternehmer laut den allgemeinen Angaben auf Vordruck USt2A", Name="Nr3200904")
    public nr3200904?: BoolXFeld;

    /** @description Name des Kontoinhabers */
    // @ApiMember(Description="Name des Kontoinhabers", Name="Nr3200905")
    public nr3200905?: StringFeld;

    /** @description Zur Wahrnehmung der steuerlichen Pflichten und Rechte als Bevollmächtigter (§ 80 AO) ist bestellt: */
    // @ApiMember(Description="Zur Wahrnehmung der steuerlichen Pflichten und Rechte als Bevollmächtigter (§ 80 AO) ist bestellt:", Name="Nr3201301")
    public nr3201301?: BoolXFeld;

    /** @description Zum Empfang von Schriftstücken als Empfangsbevollmächtigter (§ 123 AO) ist bestellt: */
    // @ApiMember(Description="Zum Empfang von Schriftstücken als Empfangsbevollmächtigter (§ 123 AO) ist bestellt:", Name="Nr3201401")
    public nr3201401?: BoolXFeld;

    /** @description Name */
    // @ApiMember(Description="Name", Name="Nr3201501")
    public nr3201501?: StringFeld;

    /** @description Straße */
    // @ApiMember(Description="Straße", Name="Nr3201601")
    public nr3201601?: StringFeld;

    /** @description Hausnummer */
    // @ApiMember(Description="Hausnummer", Name="Nr3201302")
    public nr3201302?: StringFeld;

    /** @description Hausnummerzusatz */
    // @ApiMember(Description="Hausnummerzusatz", Name="Nr3201303")
    public nr3201303?: StringFeld;

    /** @description Adressergänzung */
    // @ApiMember(Description="Adressergänzung", Name="Nr3201304")
    public nr3201304?: StringFeld;

    /** @description Postleitzahl, Ort */
    // @ApiMember(Description="Postleitzahl, Ort", Name="Nr3201402")
    public nr3201402?: StringFeld;

    /** @description Postleitzahl zu Postfach */
    // @ApiMember(Description="Postleitzahl zu Postfach", Name="Nr3201503")
    public nr3201503?: StringFeld;

    /** @description Postfach */
    // @ApiMember(Description="Postfach", Name="Nr3201504")
    public nr3201504?: StringFeld;

    /** @description E-Mail-Adresse */
    // @ApiMember(Description="E-Mail-Adresse", Name="Nr3201502")
    public nr3201502?: StringFeld;

    /** @description Telefon */
    // @ApiMember(Description="Telefon", Name="Nr3201602")
    public nr3201602?: StringFeld;

    /** @description Die Umsatzsteuererklärung wurde vom Bevollmächtigten elektronisch authentifiziert übermittelt. Die Voraussetzungen des § 150 Absatz 3 AO liegen vor. */
    // @ApiMember(Description="Die Umsatzsteuererklärung wurde vom Bevollmächtigten elektronisch authentifiziert übermittelt. Die Voraussetzungen des § 150 Absatz 3 AO liegen vor.", Name="Nr3201701")
    public nr3201701?: BoolXFeld;

    public constructor(init?: Partial<AnlageUnAllgemeineAngaben2020>) { (Object as any).assign(this, init); }
}

/** @description Anrechenbare Beträge der Anlage UN für 2019. */
// @Api(Description="Anrechenbare Beträge der Anlage UN für 2019.")
export class AnlageUnAnrechenbareBetraege2020
{
    /** @description Bei der Beförderungseinzelbesteuerung entrichtete Umsatzsteuer (§ 18 Absatz 5b Satz 2 UStG) - Belege bitte gesondert übermitteln - */
    // @ApiMember(Description="Bei der Beförderungseinzelbesteuerung entrichtete Umsatzsteuer (§ 18 Absatz 5b Satz 2 UStG) - Belege bitte gesondert übermitteln -", Name="Nr3201902")
    public nr3201902?: GeldBetragMitCent12DEFeld;

    /** @description Entrichtete Sicherheitsleistungen (§ 18 Absatz 12 Satz 5 UStG) - Belege bitte gesondert übermitteln - */
    // @ApiMember(Description="Entrichtete Sicherheitsleistungen (§ 18 Absatz 12 Satz 5 UStG) - Belege bitte gesondert übermitteln -", Name="Nr3202002")
    public nr3202002?: GeldBetragMitCent12DEFeld;

    /** @description Summe (zu übertragen in Zeile 166 der Steuererklärung) */
    // @ApiMember(Description="Summe (zu übertragen in Zeile 166 der Steuererklärung)", Name="Nr3202102")
    public nr3202102?: GeldBetragMitCent12DEFeld;

    public constructor(init?: Partial<AnlageUnAnrechenbareBetraege2020>) { (Object as any).assign(this, init); }
}

/** @description Datums-Uhrzeitfeld. Format: TT.MM. */
// @Api(Description="Datums-Uhrzeitfeld. Format: TT.MM.")
export class YearlessDateTimeFeld extends CustomFeldBase
{
    /** @description Wert des Feldes. */
    // @ApiMember(Description="Wert des Feldes.", IsRequired=true)
    public wert: string;

    /** @description Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung. */
    // @ApiMember(Description="Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung.")
    public nr: number;

    /** @description Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1 */
    // @ApiMember(Description="Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1")
    public index: number;

    /** @description Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1 */
    // @ApiMember(Description="Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1")
    public lfdNr: number;

    /** @description Identifizierung der Zeile / Feld im Fremdprogramm. */
    // @ApiMember(Description="Identifizierung der Zeile / Feld im Fremdprogramm.")
    public alias?: string;

    public constructor(init?: Partial<YearlessDateTimeFeld>) { super(init); (Object as any).assign(this, init); }
}

/** @description Ergänzende Angaben zu Umsätzen der Anlage UN für 2020. */
// @Api(Description="Ergänzende Angaben zu Umsätzen der Anlage UN für 2020.")
export class AnlageUnErgaenzendeAngabenZuUmsaetzen2020
{
    /** @description Beförderungs- und Versendungslieferungen aus dem übrigen Gemeinschaftsgebiet (§ 3c UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="Beförderungs- und Versendungslieferungen aus dem übrigen Gemeinschaftsgebiet (§ 3c UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3201901")
    public nr3201901?: GeldBetragOhneCent12DEFeld;

    /** @description Sonstige Leistungen auf dem Gebiet der Telekommunikation, Rundfunk- und Fernsehdienstleistungen aud auf die elektronischem Weg erbrachten sonstigen Leistungen (§ 3a Abs. 5 UStG), die bei */
    // @ApiMember(Description="Sonstige Leistungen auf dem Gebiet der Telekommunikation, Rundfunk- und Fernsehdienstleistungen aud auf die elektronischem Weg erbrachten sonstigen Leistungen (§ 3a Abs. 5 UStG), die bei", Name="Nr3202901")
    public nr3202901?: StringFeld;

    /** @description für Besteuerungszeitraum 2020 (vom) */
    // @ApiMember(Description="für Besteuerungszeitraum 2020 (vom)", Name="Nr3202902")
    public nr3202902?: YearlessDateTimeFeld;

    /** @description bis zum Besteuerungszeitraum 2020 (bis) */
    // @ApiMember(Description="bis zum Besteuerungszeitraum 2020 (bis)", Name="Nr3202903")
    public nr3202903?: YearlessDateTimeFeld;

    /** @description unter der Registriernummer: */
    // @ApiMember(Description="unter der Registriernummer:", Name="Nr3202904")
    public nr3202904?: StringFeld;

    /** @description Betrag (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
    // @ApiMember(Description="Betrag (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3202905")
    public nr3202905?: GeldBetragOhneCent12DEFeld;

    public constructor(init?: Partial<AnlageUnErgaenzendeAngabenZuUmsaetzen2020>) { (Object as any).assign(this, init); }
}

/** @description Boolescher Feldtyp, welcher als '1' (Ja) oder '2' (Nein) im Jahressteuererklärung angeschrieben wird. */
// @Api(Description="Boolescher Feldtyp, welcher als '1' (Ja) oder '2' (Nein) im Jahressteuererklärung angeschrieben wird.")
export class Bool12Feld extends CustomFeldBase
{
    /** @description Wenn der Wert true ist, '1' wird im Jahressteuererklärung angeschrieben; ansonsten '2'. */
    // @ApiMember(Description="Wenn der Wert true ist, '1' wird im Jahressteuererklärung angeschrieben; ansonsten '2'.", IsRequired=true, Name="Wert")
    public wert: boolean;

    /** @description Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung. */
    // @ApiMember(Description="Feldkennung: 7-stellig numerisch. Fest vergebene, eindeutige Nummer eines Feldes der Steuererklärung.")
    public nr: number;

    /** @description Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1 */
    // @ApiMember(Description="Feldindex: maximal 2-stellig numerisch (1-99). Indizierung bei mehrfachem Ausfüllen des gleichen Feldes (z. B. Unterstützung mehrerer bedürftiger Personen). Default: 1")
    public index: number;

    /** @description Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1 */
    // @ApiMember(Description="Indizierung bei mehrfach gleichen Anlagen (z. B. mehrere Anlagen V), die Durchnummerierung hat lückenlos aufsteigend zu erfolgen, von 1 bis 99999. Default: 1")
    public lfdNr: number;

    /** @description Identifizierung der Zeile / Feld im Fremdprogramm. */
    // @ApiMember(Description="Identifizierung der Zeile / Feld im Fremdprogramm.")
    public alias?: string;

    public constructor(init?: Partial<Bool12Feld>) { super(init); (Object as any).assign(this, init); }
}

/** @description Vorsteuer Vergütungsverfahren beim BZSt der Anlage UN für 2020. */
// @Api(Description="Vorsteuer Vergütungsverfahren beim BZSt der Anlage UN für 2020.")
export class AnlageUnVorsteuerVerguetungsverfahrenBeimBZSt2020
{
    /** @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? */
    // @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?", Name="Nr3201101")
    public nr3201101?: Bool12Feld;

    public constructor(init?: Partial<AnlageUnVorsteuerVerguetungsverfahrenBeimBZSt2020>) { (Object as any).assign(this, init); }
}

/** @description Anlage UN zur Umsatzsteuererklärung 2020 für im Ausland ansässige Unternehmer darstellt (Appendix to the VAT Declaration 2020 for entrepreneurs resident abroad). */
// @Api(Description="Anlage UN zur Umsatzsteuererklärung 2020 für im Ausland ansässige Unternehmer darstellt (Appendix to the VAT Declaration 2020 for entrepreneurs resident abroad).")
export class AnlageUn2020
{
    /** @description Allgemeine Angaben (General Information) */
    // @ApiMember(Description="Allgemeine Angaben (General Information)", Name="AllgemeineAngaben")
    public allgemeineAngaben?: AnlageUnAllgemeineAngaben2020;

    /** @description Anrechenbare Beträge (Eligible amounts) */
    // @ApiMember(Description="Anrechenbare Beträge (Eligible amounts)", Name="AnrechenbareBetraege")
    public anrechenbareBetraege?: AnlageUnAnrechenbareBetraege2020;

    /** @description Ergänzende Angaben zu Umsätzen (Supplementary information on turnover) */
    // @ApiMember(Description="Ergänzende Angaben zu Umsätzen (Supplementary information on turnover)", Name="ErgaenzendeAngabenZuUmsaetzen")
    public ergaenzendeAngabenZuUmsaetzen?: AnlageUnErgaenzendeAngabenZuUmsaetzen2020;

    /** @description Vorsteuervergütungsverfahren beim BZSt (Input tax refund procedure at BZSt) */
    // @ApiMember(Description="Vorsteuervergütungsverfahren beim BZSt (Input tax refund procedure at BZSt)", Name="VorsteuerVerguetungsverfahrenBeimBZSt")
    public vorsteuerVerguetungsverfahrenBeimBZSt?: AnlageUnVorsteuerVerguetungsverfahrenBeimBZSt2020;

    public constructor(init?: Partial<AnlageUn2020>) { (Object as any).assign(this, init); }
}

/** @description Aufstellung aller vertretenen Unternehmer */
// @Api(Description="Aufstellung aller vertretenen Unternehmer")
export class AnlageFvAufstAllerVertrUnt2020
{
    /** @description Name des vertretenen Unternehmers */
    // @ApiMember(Description="Name des vertretenen Unternehmers", Name="Nr3300201")
    public nr3300201?: StringFeld;

    /** @description Anschrift des vertretenen Unternehmers */
    // @ApiMember(Description="Anschrift des vertretenen Unternehmers", Name="Nr3300202")
    public nr3300202?: StringFeld;

    /** @description Umsatzsteuer-Identifikationsnummer des vertretenen Unternehmers */
    // @ApiMember(Description="Umsatzsteuer-Identifikationsnummer des vertretenen Unternehmers", Name="Nr3300203")
    public nr3300203?: StringFeld;

    /** @description Summe der jeweiligen Bemessungsgrundlagen in EUR */
    // @ApiMember(Description="Summe der jeweiligen Bemessungsgrundlagen in EUR", Name="Nr3300204")
    public nr3300204?: GeldBetragOhneCent12DEFeld;

    /** @description  Summe aller Bemessungsgrundlagen in EUR */
    // @ApiMember(Description=" Summe aller Bemessungsgrundlagen in EUR", Name="Nr3300301")
    public nr3300301?: GeldBetragOhneCent12DEFeld;

    public constructor(init?: Partial<AnlageFvAufstAllerVertrUnt2020>) { (Object as any).assign(this, init); }
}

/** @description Anlage FV zur Umsatzsteuererklärung 2020 */
// @Api(Description="Anlage FV zur Umsatzsteuererklärung 2020")
export class AnlageFv2020
{
    /** @description Aufstellung aller vertretenen Unternehmer $index$.Unternehmer */
    // @ApiMember(Description="Aufstellung aller vertretenen Unternehmer $index$.Unternehmer", Name="AufstAllerVertrUnt")
    public aufstAllerVertrUnt?: AnlageFvAufstAllerVertrUnt2020;

    public constructor(init?: Partial<AnlageFv2020>) { (Object as any).assign(this, init); }
}

/** @description Represents a base class for a file with raw data. */
// @Api(Description="Represents a base class for a file with raw data.")
export class FileBase
{
    /** @description The raw data content of the file. */
    // @ApiMember(Description="The raw data content of the file.", Name="Content")
    public content: string;

    public constructor(init?: Partial<FileBase>) { (Object as any).assign(this, init); }
}

/** @description Represents a portal certificate that is protected by a password. */
// @Api(Description="Represents a portal certificate that is protected by a password.")
export class PortalCertificate extends FileBase implements ISecuredCertificate, IHasIndex
{
    /** @description The unique identifier of the certificate. */
    // @ApiMember(Description="The unique identifier of the certificate.")
    public id: string;

    /** @description The position of the certificate element in an indexed collection of certificates. */
    // @ApiMember(Description="The position of the certificate element in an indexed collection of certificates.")
    public index: number;

    /** @description The password to protect the certificate from unauthorized access. */
    // @StringLength(255)
    // @ApiMember(Description="The password to protect the certificate from unauthorized access.")
    public pin?: string;

    /** @description The description of the certificate. */
    // @StringLength(2147483647)
    // @ApiMember(Description="The description of the certificate.")
    public description?: string;

    /** @description Tags that can be used to label or identify the certificate. */
    // @ApiMember(Description="Tags that can be used to label or identify the certificate.")
    public tags: string[];

    /** @description Gets or sets the file name of the certificate. */
    // @ApiMember(Description="Gets or sets the file name of the certificate.")
    public name?: string;

    /** @description The raw data content of the file. */
    // @ApiMember(Description="The raw data content of the file.", Name="Content")
    public content: string;

    public constructor(init?: Partial<PortalCertificate>) { super(init); (Object as any).assign(this, init); }
}

/** @description Submits an annual VAT return (Umsatzsteuerjahresserklärung) for 2020. */
// @Api(Description="Submits an annual VAT return (Umsatzsteuerjahresserklärung) for 2020.")
export class SubmitUmsatzsteuererklaerung2020Base implements IPost, IDruckRequest, IVeschlueselungsRequest
{
    /** @description Die Art des ermittelten Ordnungsbegriffs zu füllen. */
    // @ApiMember(Description="Die Art des ermittelten Ordnungsbegriffs zu füllen.")
    public ordNrArt: OrdNrArt;

    /** @description Der Vorgang bei einer Veranlagung. */
    // @ApiMember(Description="Der Vorgang bei einer Veranlagung.")
    public vorgang: VeranlagungVorgang;

    public stNr?: string;
    public id?: string;
    public idEhefrau?: string;
    /** @description Das Erstellungsdatum des Steuerfalls, im Format JJJJMMDD. */
    // @ApiMember(Description="Das Erstellungsdatum des Steuerfalls, im Format JJJJMMDD.")
    public erstelldatum?: string;

    /** @description Die Erstellungszeit des Steuerfalls, im Format hhmmss. */
    // @ApiMember(Description="Die Erstellungszeit des Steuerfalls, im Format hhmmss.")
    public erstellzeit?: string;

    /** @description Name, alphanumerisch, max. 45-stellig. */
    // @ApiMember(Description="Name, alphanumerisch, max. 45-stellig.")
    public absName?: string;

    /** @description Straße und Hausnummer, alphanumerisch, max. 30-stellig. */
    // @ApiMember(Description="Straße und Hausnummer, alphanumerisch, max. 30-stellig.")
    public absStr?: string;

    /** @description Postleitzahl des Absenders der Erklärung */
    // @ApiMember(Description="Postleitzahl des Absenders der Erklärung")
    public absPlz?: string;

    /** @description Ort, alphanumerisch, max. 29-stellig. */
    // @ApiMember(Description="Ort, alphanumerisch, max. 29-stellig.")
    public absOrt?: string;

    /** @description Copyrightmeldung des SW-Herstellers, alphanumerisch, max.50-stellig */
    // @ApiMember(Description="Copyrightmeldung des SW-Herstellers, alphanumerisch, max.50-stellig")
    public copyright?: string;

    /** @description Wird die elektronische Bereitstellung der Bescheiddaten gewünscht? */
    // @ApiMember(Description="Wird die elektronische Bereitstellung der Bescheiddaten gewünscht?")
    public rueckuebermittlung?: Rueckuebermittlung;

    /** @description Allgemeine Angaben (General Information) */
    // @ApiMember(Description="Allgemeine Angaben (General Information)")
    public allgemeineAngaben?: AllgemeineAngaben2020;

    /** @description Angaben der Besteuerung für Kleinunternehmer (Taxation details for small entrepreneurs) */
    // @ApiMember(Description="Angaben der Besteuerung für Kleinunternehmer (Taxation details for small entrepreneurs)")
    public angabenBesteuerungKleinunternehmer?: AngabenBesteuerungKleinunternehmer2020;

    /** @description Tax-free goods, etc. (Steuerfreie Lieferungen usw.) */
    // @ApiMember(Description="Tax-free goods, etc. (Steuerfreie Lieferungen usw.)")
    public steuerfreieLieferungenEtc?: SteuerfreieLieferungenEtc2020;

    /** @description Steuerpflichtige Lieferungen usw. (Taxable goods etc.) */
    // @ApiMember(Description="Steuerpflichtige Lieferungen usw. (Taxable goods etc.)")
    public steuerpflichtigeLieferungenEtc?: SteuerpflichtigeLieferungenEtc2020;

    /** @description Innergemeinschaftliche Erwerbe (Intra-Community acquisitions) */
    // @ApiMember(Description="Innergemeinschaftliche Erwerbe (Intra-Community acquisitions)")
    public innergemeinschaftlicheErwerbe?: InnergemeinschaftlicheErwerbe2020;

    /** @description Steuerschuldner bei Auslagerung (Tax payer for outsourcing) */
    // @ApiMember(Description="Steuerschuldner bei Auslagerung (Tax payer for outsourcing)")
    public steuerschuldnerBeiAuslagerung?: SteuerschuldnerBeiAuslagerung2020;

    /** @description Innergemeinschaftliche Dreiecksgeschäfte (Intra-Community triangular transactions) */
    // @ApiMember(Description="Innergemeinschaftliche Dreiecksgeschäfte (Intra-Community triangular transactions)")
    public innergemeinschaftlicheDreiecksgeschaefte?: InnergemeinschaftlicheDreiecksgeschaefte2020;

    /** @description Leistungsempfänger als Steuerschuldner (Beneficiary as tax payer) */
    // @ApiMember(Description="Leistungsempfänger als Steuerschuldner (Beneficiary as tax payer)")
    public leistungsempfaengerAlsSteuerschuldner?: LeistungsempfaengerAlsSteuerschuldner2020;

    /** @description Ergänzende Angaben (Supplementary information) */
    // @ApiMember(Description="Ergänzende Angaben (Supplementary information)")
    public ergaenzendeAngaben?: ErgaenzendeAngaben2020;

    /** @description Abziehbare Vorsteuerbeträge (Deductible input tax amounts) */
    // @ApiMember(Description="Abziehbare Vorsteuerbeträge (Deductible input tax amounts)")
    public abziehbareVorsteuerbetraege?: AbziehbareVorsteuerbetraege2020;

    /** @description Berichtigung vom Vorsteuerabzug (Adjustment of input tax deduction) */
    // @ApiMember(Description="Berichtigung vom Vorsteuerabzug (Adjustment of input tax deduction)")
    public berichtigungVorsteuerabzug?: BerichtigungVorsteuerabzug2020;

    /** @description Berechnung vom Umsatzsteuer (Calculation of VAT) */
    // @ApiMember(Description="Berechnung vom Umsatzsteuer (Calculation of VAT)")
    public berechnungUmsatzsteuer?: BerechnungUmsatzsteuer2020;

    /** @description Unterschrift (Signature) */
    // @ApiMember(Description="Unterschrift (Signature)")
    public unterschrift?: Unterschrift2020;

    /** @description Anlage UN zur Umsatzsteuererklärung für im Ausland ansässige Unternehmer (Appendix to the VAT Declaration 2020 for entrepreneurs resident abroad). */
    // @ApiMember(Description="Anlage UN zur Umsatzsteuererklärung für im Ausland ansässige Unternehmer (Appendix to the VAT Declaration 2020 for entrepreneurs resident abroad).")
    public anlageUn?: AnlageUn2020;

    /** @description Anlage FV zur Umsatzsteuererklärung $VZ$ (Appendix FV to the sales tax return $VZ$). */
    // @ApiMember(Description="Anlage FV zur Umsatzsteuererklärung $VZ$ (Appendix FV to the sales tax return $VZ$).")
    public anlageFv?: AnlageFv2020;

    /** @description The four-digit federal tax office number of the receiving tax office. */
    // @ApiMember(Description="The four-digit federal tax office number of the receiving tax office.", IsRequired=true, Name="Bundesfinanzamtsnummer")
    public bundesfinanzamtsnummer: string;

    /** @description The details of the provider that submits the tax data. */
    // @ApiMember(Description="The details of the provider that submits the tax data.", IsRequired=true, Name="DatenLieferant")
    public datenLieferant: string;

    /** @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. */
    // @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")
    public duplexDruck?: boolean;

    /** @description Name prefix of the generated transfer protocol file. */
    // @ApiMember(Description="Name prefix of the generated transfer protocol file.", IsRequired=true, Name="ProtocolPrefix")
    public protocolPrefix: string;

    /** @description Footer text to be used on the printout (optional). */
    // @ApiMember(Description="Footer text to be used on the printout (optional).", Name="FussText")
    public fussText?: string;

    /** @description The authentification certificate. */
    // @ApiMember(Description="The authentification certificate.", IsRequired=true, Name="Zertifikat")
    public zertifikat: PortalCertificate;

    public constructor(init?: Partial<SubmitUmsatzsteuererklaerung2020Base>) { (Object as any).assign(this, init); }
}

/** @description Specifies a service response from an ERiC service operation. */
// @Api(Description="Specifies a service response from an ERiC service operation.")
export class ServiceReponseBase implements IHasIndex
{
    /** @description The unique identifier of the response. */
    // @ApiMember(Description="The unique identifier of the response.", Name="Id")
    public id: string;

    /** @description The position of the response element in an indexed collection. */
    // @ApiMember(Description="The position of the response element in an indexed collection.", Name="Index")
    public index: number;

    /** @description Metadata that contains structured error information on the service response. */
    // @ApiMember(Description="Metadata that contains structured error information on the service response.", Name="ResponseStatus")
    public responseStatus?: ResponseStatus;

    public constructor(init?: Partial<ServiceReponseBase>) { (Object as any).assign(this, init); }
}

/** @description Enumeration of ERiC API error codes. */
export enum EricFehlerCode
{
    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_ABRUFCODE_NICHT_ERLAUBT = 610001029,
    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_ERSTE_SEITE_DRUCK_NICHT_UNTERSTUETZT = 610001220,
    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_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_E_INVALID_PARAM_ABC = 610201212,
    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_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_ZU_VIELE_ANHAENGE = 610301190,
    ERIC_IO_READER_ANHANG_ZU_GROSS = 610301191,
    ERIC_IO_READER_ANHAENGE_ZU_GROSS = 610301192,
    ERIC_IO_READER_SCHEMA_VALIDIERUNGSFEHLER = 610301200,
    ERIC_IO_READER_UNBEKANNTE_XML_ENTITY = 610301201,
    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,
}

/** @description Represent a base response that encapsulate any ERiC API function return value. */
// @Api(Description="Represent a base response that encapsulate any ERiC API function return value.")
export class EricFehlerCodeResponse extends ServiceReponseBase
{
    /** @description The status code that the ERiC API function returns. */
    // @ApiMember(Description="The status code that the ERiC API function returns.", Name="StatusCode")
    public statusCode: EricFehlerCode;

    /** @description The status message that the ERiC API function returns. */
    // @ApiMember(Description="The status message that the ERiC API function returns.", Name="StatusText")
    public statusText?: string;

    /** @description The unique identifier of the response. */
    // @ApiMember(Description="The unique identifier of the response.", Name="Id")
    public id: string;

    /** @description The position of the response element in an indexed collection. */
    // @ApiMember(Description="The position of the response element in an indexed collection.", Name="Index")
    public index: number;

    /** @description Metadata that contains structured error information on the service response. */
    // @ApiMember(Description="Metadata that contains structured error information on the service response.", Name="ResponseStatus")
    public responseStatus?: ResponseStatus;

    public constructor(init?: Partial<EricFehlerCodeResponse>) { super(init); (Object as any).assign(this, init); }
}

/** @description Represents information returned from a successful tax declaration process. */
// @Api(Description="Represents information returned from a successful tax declaration process.")
export class Erfolg
{
    /** @description The generated tele-number for the successful tax declaration process. */
    // @ApiMember(Description="The generated tele-number for the successful tax declaration process.")
    public telenummer: string[];

    /** @description The classification key for the successful tax declaration process. */
    // @ApiMember(Description="The classification key for the successful tax declaration process.")
    public ordnungsbegriffe: string[];

    public constructor(init?: Partial<Erfolg>) { (Object as any).assign(this, init); }
}

/** @description Represents information on the delivery. */
// @Api(Description="Represents information on the delivery.")
export class Transfer
{
    /** @description The ticket of the transfer. */
    // @ApiMember(Description="The ticket of the transfer.")
    public transferTicket?: string;

    public constructor(init?: Partial<Transfer>) { (Object as any).assign(this, init); }
}

/** @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. */
// @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.")
export class Transfers
{
    /** @description Contains information on all data deliveries, including deliveries that have not been confirmed by the server. */
    // @ApiMember(Description="Contains information on all data deliveries, including deliveries that have not been confirmed by the server.")
    public transferList: Transfer[];

    public constructor(init?: Partial<Transfers>) { (Object as any).assign(this, init); }
}

/** @description Represents value of an index field, which identfies the context about an error message. */
// @Api(Description="Represents value of an index field, which identfies the context about an error message.")
export class SemantischerIndex
{
    /** @description The name of the index field. */
    // @ApiMember(Description="The name of the index field.")
    public name?: string;

    /** @description The value of the index field. */
    // @ApiMember(Description="The value of the index field.")
    public value?: string;

    public constructor(init?: Partial<SemantischerIndex>) { (Object as any).assign(this, init); }
}

/** @description Represents information on an ERiC reference. */
// @Api(Description="Represents information on an ERiC reference.")
export class FehlerRegelpruefung
{
    /** @description The user data ticket of the reference. */
    // @ApiMember(Description="The user data ticket of the reference.")
    public nutzdatenticket?: string;

    /** @description The field identifier of the reference. */
    // @ApiMember(Description="The field identifier of the reference.")
    public feldidentifikator?: string;

    /** @description The multi-line index of the reference. */
    // @ApiMember(Description="The multi-line index of the reference.")
    public mehrfachzeilenindex?: string;

    /** @description The delivery number form of the reference. */
    // @ApiMember(Description="The delivery number form of the reference.")
    public lfdNrVordruck?: string;

    /** @description Indicates the line number of the error field mentioned in the form. */
    // @ApiMember(Description="Indicates the line number of the error field mentioned in the form.")
    public vordruckZeilennummer?: string;

    /** @description Specifies the value of one or more index fields that identify the context of error messages. */
    // @ApiMember(Description="Specifies the value of one or more index fields that identify the context of error messages.")
    public semantischeIndexes: SemantischerIndex[];

    /** @description The sub-subject-area of the reference. */
    // @ApiMember(Description="The sub-subject-area of the reference.")
    public untersachbereich?: string;

    /** @description The private identification number of the reference. */
    // @ApiMember(Description="The private identification number of the reference.")
    public privateKennnummer?: string;

    /** @description The name of the rule that applies to the reference. */
    // @ApiMember(Description="The name of the rule that applies to the reference.")
    public regelName?: string;

    /** @description The technical error identifier of the reference. */
    // @ApiMember(Description="The technical error identifier of the reference.")
    public fachlicheFehlerId?: string;

    /** @description The textual details of the reference. */
    // @ApiMember(Description="The textual details of the reference.")
    public text?: string;

    public constructor(init?: Partial<FehlerRegelpruefung>) { (Object as any).assign(this, init); }
}

export class Hinweis
{
    /** @description The user data ticket of the reference. */
    // @ApiMember(Description="The user data ticket of the reference.")
    public nutzdatenticket?: string;

    /** @description The field identifier of the reference. */
    // @ApiMember(Description="The field identifier of the reference.")
    public feldidentifikator?: string;

    /** @description The multi-line index of the reference. */
    // @ApiMember(Description="The multi-line index of the reference.")
    public mehrfachzeilenindex?: string;

    /** @description The delivery number form of the reference. */
    // @ApiMember(Description="The delivery number form of the reference.")
    public lfdNrVordruck?: string;

    /** @description Indicates the line number of the error field mentioned in the form. */
    // @ApiMember(Description="Indicates the line number of the error field mentioned in the form.")
    public vordruckZeilennummer?: string;

    /** @description Specifies the value of one or more index fields that identify the context of error messages. */
    // @ApiMember(Description="Specifies the value of one or more index fields that identify the context of error messages.")
    public semantischeIndexes: SemantischerIndex[];

    /** @description The sub-subject-area of the reference. */
    // @ApiMember(Description="The sub-subject-area of the reference.")
    public untersachbereich?: string;

    /** @description The private identification number of the reference. */
    // @ApiMember(Description="The private identification number of the reference.")
    public privateKennnummer?: string;

    /** @description The name of the rule that applies to the reference. */
    // @ApiMember(Description="The name of the rule that applies to the reference.")
    public regelName?: string;

    /** @description The technical note identifier of the reference. */
    // @ApiMember(Description="The technical note identifier of the reference.")
    public fachlicheHinweisId?: string;

    /** @description The textual details of the reference. */
    // @ApiMember(Description="The textual details of the reference.")
    public text?: string;

    public constructor(init?: Partial<Hinweis>) { (Object as any).assign(this, init); }
}

/** @description Represents a structure that contains the first output of the ERiC tax data submission process. */
// @Api(Description="Represents a structure that contains the first output of the ERiC tax data submission process.")
export class EricBearbeiteVorgang
{
    /** @description Information from the successful processing a tax declaration. */
    // @ApiMember(Description="Information from the successful processing a tax declaration.")
    public erfolg?: Erfolg;

    /** @description Gets or sets information on all data deliveries, including deliveries that have not been confirmed by the server. */
    // @ApiMember(Description="Gets or sets information on all data deliveries, including deliveries that have not been confirmed by the server.")
    public transfers?: Transfers;

    /** @description Error rules that result from the processing of a tax declaration. */
    // @ApiMember(Description="Error rules that result from the processing of a tax declaration.")
    public fehlerRegelpruefungen: FehlerRegelpruefung[];

    /** @description Hints that result the processing of a tax declaration. */
    // @ApiMember(Description="Hints that result the processing of a tax declaration.")
    public hinweise: Hinweis[];

    public constructor(init?: Partial<EricBearbeiteVorgang>) { (Object as any).assign(this, init); }
}

/** @description Auflistung der gültigen Verfahren */
export enum Verfahren
{
    ElsterAnmeldung = 'ElsterAnmeldung',
    ElsterBereitstellung = 'ElsterBereitstellung',
    ElsterBilanz = 'ElsterBilanz',
    ElsterBRM = 'ElsterBRM',
    ElsterBRMOrg = 'ElsterBRMOrg',
    ElsterDatenabholung = 'ElsterDatenabholung',
    ElsterErklaerung = 'ElsterErklaerung',
    ElsterExtern = 'ElsterExtern',
    ElsterFSE = 'ElsterFSE',
    ElsterKapESt = 'ElsterKapESt',
    ElsterKMV = 'ElsterKMV',
    ElsterKontoabfrage = 'ElsterKontoabfrage',
    ElsterLavendel = 'ElsterLavendel',
    ElsterLohn = 'ElsterLohn',
    ElsterLohn2 = 'ElsterLohn2',
    ElsterNachricht = 'ElsterNachricht',
    ElsterSignatur = 'ElsterSignatur',
    ElsterVollmachtDB = 'ElsterVollmachtDB',
}

/** @description Auflistung aller gültigen Datenarten. */
export enum Datenart
{
    Anlage34a = 'Anlage34a',
    AnpassungVorauszahlung = 'AnpassungVorauszahlung',
    AntragUStVerguetung4a = 'AntragUStVerguetung4a',
    AbrufcodeAntrag = 'AbrufcodeAntrag',
    AenderungAdresse = 'AenderungAdresse',
    AbrufcodeStorno = 'AbrufcodeStorno',
    AbrufvollmachtAnlage = 'AbrufvollmachtAnlage',
    AbrufvollmachtUpdate = 'AbrufvollmachtUpdate',
    AenderungBankverbindung = 'AenderungBankverbindung',
    AntraegeRechteLoeschen = 'AntraegeRechteLoeschen',
    AntraegeUndRechte = 'AntraegeUndRechte',
    Aufzeichnung146a = 'Aufzeichnung146a',
    BetPG = 'BetPG',
    Bilanz = 'Bilanz',
    Belegnachreichung = 'Belegnachreichung',
    BSBMitteilung = 'BSBMitteilung',
    BZSt2 = 'BZSt2',
    C19Mitteilung = 'C19Mitteilung',
    DUeAbmelden = 'DUeAbmelden',
    DUeAnmelden = 'DUeAnmelden',
    DUeUmmelden = 'DUeUmmelden',
    Einspruch = 'Einspruch',
    EinspruchNachtrag = 'EinspruchNachtrag',
    EinspruchRuecknahme = 'EinspruchRuecknahme',
    ELeVAntragELStAM = 'ELeVAntragELStAM',
    ELeVErmaessigung = 'ELeVErmaessigung',
    ELeVGetrenntlebend = 'ELeVGetrenntlebend',
    ELeVSteuerklassenwechsel = 'ELeVSteuerklassenwechsel',
    ELeVWiederaufnahmeEhe = 'ELeVWiederaufnahmeEhe',
    EPAntwort = 'EPAntwort',
    EPBescheid = 'EPBescheid',
    EPMitteilung = 'EPMitteilung',
    EPKurzmitteilung = 'EPKurzmitteilung',
    ElsterErklaerungDaten = 'ElsterErklaerungDaten',
    ElsterKMVDaten = 'ElsterKMVDaten',
    ElsterLohn2Daten = 'ElsterLohn2Daten',
    ElsterLohnDaten = 'ElsterLohnDaten',
    ElsterVaStDaten = 'ElsterVaStDaten',
    ElsterDIVADaten = 'ElsterDIVADaten',
    ElsterDIVDaten = 'ElsterDIVDaten',
    ElsterEPBescheidDaten = 'ElsterEPBescheidDaten',
    ElsterEPMitteilungDaten = 'ElsterEPMitteilungDaten',
    EPStBescheidAbholung = 'EPStBescheidAbholung',
    EPStMitteilungAbholung = 'EPStMitteilungAbholung',
    Erbschaftsteuer = 'Erbschaftsteuer',
    ESt = 'ESt',
    EStbeschraenkt = 'EStbeschraenkt',
    EUER = 'EUER',
    EUn = 'EUn',
    FEIN = 'FEIN',
    ForschungZulAntrag = 'ForschungZulAntrag',
    KStAntragOptionPersG = 'KStAntragOptionPersG',
    FLHMitteilung = 'FLHMitteilung',
    FreistellungKapitalertraegeBV = 'FreistellungKapitalertraegeBV',
    Fristverlaengerung = 'Fristverlaengerung',
    FsEVerein = 'FsEVerein',
    Gewerbemeldung = 'Gewerbemeldung',
    GDBMitteilung = 'GDBMitteilung',
    Gewinnermittlung13aEStG = 'Gewinnermittlung13aEStG',
    GewSt = 'GewSt',
    GewStZ = 'GewStZ',
    GrundsteuerBW = 'GrundsteuerBW',
    GrundsteuerBY = 'GrundsteuerBY',
    GrundsteuerHE = 'GrundsteuerHE',
    GrundsteuerHH = 'GrundsteuerHH',
    GrundsteuerNI = 'GrundsteuerNI',
    Grundsteuerwert = 'Grundsteuerwert',
    InvStG56Abs5 = 'InvStG56Abs5',
    InvStG51Feststellung = 'InvStG51Feststellung',
    KapEStA = 'KapEStA',
    KapEStInvStG = 'KapEStInvStG',
    KapG = 'KapG',
    KapGAus = 'KapGAus',
    KKVMitteilung = 'KKVMitteilung',
    Kontoabfrage = 'Kontoabfrage',
    Kontoinformation = 'Kontoinformation',
    KSt = 'KSt',
    KStZ = 'KStZ',
    KTTAnmeldungHH = 'KTTAnmeldungHH',
    KTTAnzeigeHH = 'KTTAnzeigeHH',
    Lohnersatzleistung = 'Lohnersatzleistung',
    LohnersatzMitteilung = 'LohnersatzMitteilung',
    LStA = 'LStA',
    LStB = 'LStB',
    LStHVVMAnlage = 'LStHVVMAnlage',
    LStHVVMUpdate = 'LStHVVMUpdate',
    OGHMitteilung = 'OGHMitteilung',
    VermoegenswirksameLeistung = 'VermoegenswirksameLeistung',
    VMWiderruf = 'VMWiderruf',
    VollmachtDetails = 'VollmachtDetails',
    VNoVMVRegistrierung = 'VNoVMVRegistrierung',
    VNoVMVUpdate = 'VNoVMVUpdate',
    VNoVMVLoeschung = 'VNoVMVLoeschung',
    VollfAAnlage = 'VollfAAnlage',
    VollfAUpdate = 'VollfAUpdate',
    VMoVMVStBAnlage = 'VMoVMVStBAnlage',
    VMoVMVStBUpdate = 'VMoVMVStBUpdate',
    VMoVMVFreischaltung = 'VMoVMVFreischaltung',
    VAGMitteilung = 'VAGMitteilung',
    DIVADatenBZSt = 'DIVADatenBZSt',
    DivaEinwilligungAnlageBRM = 'DivaEinwilligungAnlageBRM',
    DivaEinwilligungFreisch = 'DivaEinwilligungFreisch',
    DivaEinwilligungUpdateBRM = 'DivaEinwilligungUpdateBRM',
    DivaWiderrufBRM = 'DivaWiderrufBRM',
    DivaErgebnisliste = 'DivaErgebnisliste',
    LStHVDivaAdresseBRM = 'LStHVDivaAdresseBRM',
    VMErgebnisListeVNSicht = 'VMErgebnisListeVNSicht',
    PersG = 'PersG',
    PostfachAnfrage = 'PostfachAnfrage',
    PostfachStatus = 'PostfachStatus',
    ProtokollAnforderung = 'ProtokollAnforderung',
    Registrierung = 'Registrierung',
    Schenkungsteuer = 'Schenkungsteuer',
    SonstigeNachrichten = 'SonstigeNachrichten',
    SpezRechtAntrag = 'SpezRechtAntrag',
    SpezRechtFreischaltung = 'SpezRechtFreischaltung',
    SpezRechtListe = 'SpezRechtListe',
    SpezRechtStorno = 'SpezRechtStorno',
    SpezRechtTeilnahme = 'SpezRechtTeilnahme',
    StAb50a = 'StAb50a',
    Statusabfrage = 'Statusabfrage',
    UnentgeltlicheDepotuebertragung = 'UnentgeltlicheDepotuebertragung',
    UENSTAnmeldungBE = 'UENSTAnmeldungBE',
    UENSTAnzeigeBE = 'UENSTAnzeigeBE',
    USt = 'USt',
    UStVA = 'UStVA',
    UStDV = 'UStDV',
    UStSV = 'UStSV',
    VGNAnmeldungHB = 'VGNAnmeldungHB',
    VGNAnmeldungBE = 'VGNAnmeldungBE',
    VGNAnmeldungHH = 'VGNAnmeldungHH',
    VGNAnzeigeHH = 'VGNAnzeigeHH',
    WTBAnmeldungHB = 'WTBAnmeldungHB',
    ZMDO = 'ZMDO',
    ElsterVollmachtDaten = 'ElsterVollmachtDaten',
    MitteilungAbholung = 'MitteilungAbholung',
}

/** @description Hauptinformation ob die Daten authentifiziert wurden (send-Auth) oder nicht (send-NoSig) */
export enum Vorgang
{
    Send_Auth = 'Send_Auth',
    Send_Auth_Part = 'Send_Auth_Part',
    Send_NoSig = 'Send_NoSig',
    Send_NoSig_Part = 'Send_NoSig_Part',
}

/** @description Kennzeichnung der Datenlieferung ob es sich um einen Testfall handelt, gilt fuer die gesamte Datenlieferung. Ein Echtfall enthält dieses Element nicht. Ein Testfall muss mit einem Testmerker versehen werden, damit er nicht wie ein Echtfall verarbeitet wird. Handelt es sich um Daten, die nur zum Testen des Frontends versendet wurden, müssen sie nicht mehr weiter verarbeitet werden. */
export enum Testmerker
{
    TM010000001 = 10000001,
    TM080000001 = 80000001,
    TM160000001 = 160000001,
    TM160000002 = 160000002,
    TM220000000 = 220000000,
    TM220002000 = 220002000,
    TM230000001 = 230000001,
    TM240000000 = 240000000,
    TM370000001 = 370000001,
    TM520000000 = 520000000,
    TM700000001 = 700000001,
    TM700000004 = 700000004,
}

/** @description Represents the signature and associated information of the compressed, encrypted, base64-encoded content of the data part of the tax declaration/statement. */
// @Api(Description="Represents the signature and associated information of the compressed, encrypted, base64-encoded content of the data part of the tax declaration/statement.")
export class SigUser
{
    /** @description The content of the data. Currently supported: Raw XML (text), XElement or IXmlSerializable */
    // @ApiMember(Description="The content of the data. Currently supported: Raw XML (text), XElement or IXmlSerializable")
    public inhalt?: Object;

    public constructor(init?: Partial<SigUser>) { (Object as any).assign(this, init); }
}

/** @description Einheitliche Abkürzungen fuer die Bundesländer bzw. alternative Empfänger */
export enum Bundesland
{
    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',
}

/** @description Represents a receiver of tax data. */
// @Api(Description="Represents a receiver of tax data.")
export class Empfaenger
{
    /** @description The identifier of the receiver. */
    // @ApiMember(Description="The identifier of the receiver.")
    public id?: string;

    /** @description The destination of the receiver. */
    // @ApiMember(Description="The destination of the receiver.")
    public ziel?: Bundesland;

    public constructor(init?: Partial<Empfaenger>) { (Object as any).assign(this, init); }
}

/** @description Protokoll der Verschluesselung. Es kann vorkommen, dass verschieden Verschluesselungsarten eingesetzt werden, eine Unterscheidung ist hier nötig, um das richtige Entschluesselungstool anzusteuern. Mit welcher Verschluesselungsart wurden die Inhalte von den Elementen 'DatenLieferant' und ggf. 'SigUser' im TransferHeader und dem Element 'DatenTeil' verschluesselt */
export enum Verschluesselungsart
{
    PKCS_7v1_5 = 'PKCS_7v1_5',
    PKCS_7v1_5enveloped = 'PKCS_7v1_5enveloped',
    NO_BASE64 = 'NO_BASE64',
    CMSEncryptedData = 'CMSEncryptedData',
    CMSEnvelopedData = 'CMSEnvelopedData',
    EnvelopedData__RSA_OAEP__AES_128__GZip__B64 = 'EnvelopedData__RSA_OAEP__AES_128__GZip__B64',
}

/** @description Mit welcher Kompression wurden die Inhalte von den Elementen DatenLieferant und ggf. SigUser im TransferHeader und dem Element DatenTeil komprimiert. */
export enum Kompression
{
    GZIP = 'GZIP',
    NO_BASE64 = 'NO_BASE64',
}

/** @description [Documentation unavailable] */
// @Api(Description="[Documentation unavailable]")
export class EricTyp
{
    /** @description The content of the data. Currently supported: Raw XML (text), XmlElement, XElement or IXmlSerializable */
    // @ApiMember(Description="The content of the data. Currently supported: Raw XML (text), XmlElement, XElement or IXmlSerializable")
    public inhalt?: Object;

    public constructor(init?: Partial<EricTyp>) { (Object as any).assign(this, init); }
}

/** @description [Documentation unavailable] */
// @Api(Description="[Documentation unavailable]")
export class Erstellung
{
    /** @description [Documentation unavailable] */
    // @ApiMember(Description="[Documentation unavailable]")
    public eric?: EricTyp;

    public constructor(init?: Partial<Erstellung>) { (Object as any).assign(this, init); }
}

/** @description Represents information on the encryption of tax data. */
// @Api(Description="Represents information on the encryption of tax data.")
export class Datei
{
    /** @description The type of data encryption used. */
    // @ApiMember(Description="The type of data encryption used.")
    public verschluesselung: Verschluesselungsart;

    /** @description The type of data compression used. */
    // @ApiMember(Description="The type of data compression used.")
    public kompression: Kompression;

    /** @description The transport key used in the encryption. */
    // @ApiMember(Description="The transport key used in the encryption.")
    public transportSchluessel?: string;

    /** @description [Documentation unavailable] */
    // @ApiMember(Description="[Documentation unavailable]")
    public erstellung?: Erstellung;

    public constructor(init?: Partial<Datei>) { (Object as any).assign(this, init); }
}

/** @description Represents an external error stack. */
// @Api(Description="Represents an external error stack.")
export class Rueckgabe
{
    /** @description The external error code. Either a zero (0) if no external errors occurred; otherwise an error number. */
    // @ApiMember(Description="The external error code. Either a zero (0) if no external errors occurred; otherwise an error number.")
    public code?: string;

    /** @description The external error message. */
    // @ApiMember(Description="The external error message.")
    public text?: string;

    public constructor(init?: Partial<Rueckgabe>) { (Object as any).assign(this, init); }
}

/** @description Represents an internal error stack. */
// @Api(Description="Represents an internal error stack.")
export class Stack
{
    /** @description The internal error code. Either a zero (0) if no internal errors occurred; otherwise an error number. */
    // @ApiMember(Description="The internal error code. Either a zero (0) if no internal errors occurred; otherwise an error number.")
    public code?: string;

    /** @description The external error message. */
    // @ApiMember(Description="The external error message.")
    public text?: string;

    public constructor(init?: Partial<Stack>) { (Object as any).assign(this, init); }
}

/** @description Represents an ERiC return code. */
// @Api(Description="Represents an ERiC return code.")
export class RC
{
    /** @description The return value of the return code. */
    // @ApiMember(Description="The return value of the return code.")
    public rueckgabe?: Rueckgabe;

    /** @description The internal value of the return code. */
    // @ApiMember(Description="The internal value of the return code.")
    public stack?: Stack;

    public constructor(init?: Partial<RC>) { (Object as any).assign(this, init); }
}

/** @description Represents an ERiC extension. */
// @Api(Description="Represents an ERiC extension.")
export class Zusatz
{
    /** @description The user-customizable items for the extension. Data providers can use these items for their own extensions/information. */
    // @ApiMember(Description="The user-customizable items for the extension. Data providers can use these items for their own extensions/information.")
    public infos: string[];

    /** @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). */
    // @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).")
    public elsterInfos: string[];

    public constructor(init?: Partial<Zusatz>) { (Object as any).assign(this, init); }
}

/** @description Represents the transfer header part of an ELSTER document. */
// @Api(Description="Represents the transfer header part of an ELSTER document.")
export class TransferHeader
{
    /** @description The version of the transfer header. */
    // @ApiMember(Description="The version of the transfer header.", IsRequired=true)
    public version: string;

    /** @description The tax operation used in the ELSTER process. */
    // @ApiMember(Description="The tax operation used in the ELSTER process.", IsRequired=true)
    public verfahren: Verfahren;

    /** @description The tax data type of the ELSTER process. */
    // @ApiMember(Description="The tax data type of the ELSTER process.", IsRequired=true)
    public datenArt: Datenart;

    /** @description The authentification procedure of the ELSTER process. */
    // @ApiMember(Description="The authentification procedure of the ELSTER process.", IsRequired=true)
    public vorgang: Vorgang;

    /** @description The ticket identifier after a successful ELSTER process. */
    // @ApiMember(Description="The ticket identifier after a successful ELSTER process.")
    public transferTicket?: string;

    /** @description 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 flag that indicates whether the tax declaration or filing is a test case. For production purposes, this value should not be set.")
    public testmerker?: Testmerker;

    /** @description 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 signature and associated information on the compressed, encrypted, base64-encoded content of the the data part of a tax declaration / statement.")
    public sigUser?: SigUser;

    /** @description The receiving ELSTER server. */
    // @ApiMember(Description="The receiving ELSTER server.")
    public empfaenger?: Empfaenger;

    /** @description The identifier of the software manufacturer, through whose software the tax declaration is filed. */
    // @ApiMember(Description="The identifier of the software manufacturer, through whose software the tax declaration is filed.", IsRequired=true)
    public herstellerID: string;

    /** @description The details of the provider that submits tax data. */
    // @ApiMember(Description="The details of the provider that submits tax data.", IsRequired=true)
    public datenLieferant: string;

    /** @description The date of receipt of the tax data. */
    // @ApiMember(Description="The date of receipt of the tax data.")
    public eingangsDatum?: string;

    /** @description The encryption data required for authenticated transmission of tax data. */
    // @ApiMember(Description="The encryption data required for authenticated transmission of tax data.")
    public datei?: Datei;

    /** @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. */
    // @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.")
    public rc?: RC;

    /** @description The details of the software that submits the tax data. */
    // @ApiMember(Description="The details of the software that submits the tax data.")
    public versionClient?: string;

    /** @description Data extensions to the transfer header. */
    // @ApiMember(Description="Data extensions to the transfer header.")
    public zusatz?: Zusatz;

    public constructor(init?: Partial<TransferHeader>) { (Object as any).assign(this, init); }
}

/** @description Represents a receriver ID */
export enum EmpfaengerID
{
    L = 'L',
    F = 'F',
}

/** @description Represents a receiver of tax data. */
// @Api(Description="Represents a receiver of tax data.")
export class NDHEmpfaenger
{
    /** @description The identifier of the receiver. */
    // @ApiMember(Description="The identifier of the receiver.")
    public id: EmpfaengerID;

    /** @description The value of the receiver. */
    // @ApiMember(Description="The value of the receiver.")
    public value?: string;

    public constructor(init?: Partial<NDHEmpfaenger>) { (Object as any).assign(this, init); }
}

/** @description Represents a manufacturer/vendor of tax software. */
// @Api(Description="Represents a manufacturer/vendor of tax software.")
export class Hersteller
{
    /** @description The product name of the tax software produced by the manufacturer. */
    // @ApiMember(Description="The product name of the tax software produced by the manufacturer.")
    public produktName?: string;

    /** @description The product version of the tax software produced by the manufacturer. */
    // @ApiMember(Description="The product version of the tax software produced by the manufacturer.")
    public produktVersion?: string;

    public constructor(init?: Partial<Hersteller>) { (Object as any).assign(this, init); }
}

/** @description Represents the header of a tax data. */
// @Api(Description="Represents the header of a tax data.")
export class NutzdatenHeader
{
    /** @description The version of the header. */
    // @ApiMember(Description="The version of the header.", IsRequired=true)
    public version: string;

    /** @description The ticket identifier of the header. */
    // @ApiMember(Description="The ticket identifier of the header.", IsRequired=true)
    public nutzdatenTicket: string;

    /** @description The receiver of the header. */
    // @ApiMember(Description="The receiver of the header.", IsRequired=true)
    public empfaenger: NDHEmpfaenger;

    /** @description The software manufacturer, through whose software the tax declaration or filing is submitted. */
    // @ApiMember(Description="The software manufacturer, through whose software the tax declaration or filing is submitted.", IsRequired=true)
    public hersteller: Hersteller;

    /** @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. */
    // @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.")
    public datenLieferant?: string;

    /** @description The return code of the header. */
    // @ApiMember(Description="The return code of the header.")
    public rc?: RC;

    /** @description The data extensions of the header. */
    // @ApiMember(Description="The data extensions of the header.")
    public zusatz?: Zusatz;

    public constructor(init?: Partial<NutzdatenHeader>) { (Object as any).assign(this, init); }
}

/** @description Represents an encapsulation of tax data content. */
// @Api(Description="Represents an encapsulation of tax data content.")
export class Nutzdaten
{
    /** @description The content of the tax data. This varies by tax declaration. Currently supported formats: Raw XML (text), XElement, and IXmlSerializable */
    // @ApiMember(Description="The content of the tax data. This varies by tax declaration. Currently supported formats: Raw XML (text), XElement, and IXmlSerializable", IsRequired=true)
    public inhalt: Object;

    public constructor(init?: Partial<Nutzdaten>) { (Object as any).assign(this, init); }
}

/** @description Represents a block of tax data. */
// @Api(Description="Represents a block of tax data.")
export class Nutzdatenblock
{
    /** @description The header part of the block. */
    // @ApiMember(Description="The header part of the block.", IsRequired=true)
    public nutzdatenHeader: NutzdatenHeader;

    /** @description The data part of the block. */
    // @ApiMember(Description="The data part of the block.", IsRequired=true)
    public nutzdaten: Nutzdaten;

    public constructor(init?: Partial<Nutzdatenblock>) { (Object as any).assign(this, init); }
}

/** @description Represents the data part of an ELSTER document. */
// @Api(Description="Represents the data part of an ELSTER document.")
export class DatenTeil
{
    /** @description The blocks of tax data of the ELSTER document. */
    // @ApiMember(Description="The blocks of tax data of the ELSTER document.", IsRequired=true)
    public nutzdatenbloecke: Nutzdatenblock[];

    public constructor(init?: Partial<DatenTeil>) { (Object as any).assign(this, init); }
}

/** @description Represents an ELSTER document. */
// @Api(Description="Represents an ELSTER document.")
export class Elster
{
    /** @description The transfer header part of the ELSTER document. */
    // @ApiMember(Description="The transfer header part of the ELSTER document.", IsRequired=true)
    public transferHeader: TransferHeader;

    /** @description The data (facts) part of the ELSTER document. */
    // @ApiMember(Description="The data (facts) part of the ELSTER document.")
    public datenTeil?: DatenTeil;

    public constructor(init?: Partial<Elster>) { (Object as any).assign(this, init); }
}

/** @description Represents information about a file or directory. */
// @Api(Description="Represents information about a file or directory.")
export class FileMetadata implements IFileMetadata
{
    /** @description 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 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="Name")
    public name: string;

    /** @description The full path of the directory or file. */
    // @ApiMember(Description="The full path of the directory or file.", Name="FullName")
    public fullName: string;

    /** @description The time the current file or directory was last accessed. */
    // @ApiMember(Description="The time the current file or directory was last accessed.", Name="LastAccessTime")
    public lastAccessTime: string;

    /** @description The name of the file. */
    // @ApiMember(Description="The name of the file.", Name="LastAccessTimeUtc")
    public lastAccessTimeUtc: string;

    /** @description The time when the current file or directory was last written to. */
    // @ApiMember(Description="The time when the current file or directory was last written to.", Name="LastAccessTime")
    public lastWriteTime: string;

    /** @description The time, in coordinated universal time (UTC), 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.", Name="LastWriteTimeUtc")
    public lastWriteTimeUtc: string;

    /** @description The size, in bytes, of the current file. */
    // @ApiMember(Description="The size, in bytes, of the current file.", Name="Length")
    public length: number;

    /** @description The size, in bytes, of the current file. */
    // @ApiMember(Description="The size, in bytes, of the current file.", Name="UserId")
    public userId: number;

    /** @description The file group id. */
    // @ApiMember(Description="The file group id.", Name="GroupId")
    public groupId: number;

    /** @description A value that indicates whether the others can read from this file. */
    // @ApiMember(Description="A value that indicates whether the others can read from this file.", Name="OthersCanRead")
    public othersCanRead: boolean;

    /** @description A value that indicates whether the group members can execute this file. */
    // @ApiMember(Description="A value that indicates whether the group members can execute this file.", Name="GroupCanExecute")
    public groupCanExecute: boolean;

    /** @description A value that indicates whether the group members can write into this file. */
    // @ApiMember(Description="A value that indicates whether the group members can write into this file.", Name="GroupCanWrite")
    public groupCanWrite: boolean;

    /** @description A value that indicates whether the group members can read from this file. */
    // @ApiMember(Description="A value that indicates whether the group members can read from this file.", Name="GroupCanRead")
    public groupCanRead: boolean;

    /** @description A value that indicates whether the owner can execute this file. */
    // @ApiMember(Description="A value that indicates whether the owner can execute this file.", Name="OwnerCanExecute")
    public ownerCanExecute: boolean;

    /** @description A value that indicates whether the owner can write into this file. */
    // @ApiMember(Description="A value that indicates whether the owner can write into this file.", Name="OwnerCanWrite")
    public ownerCanWrite: boolean;

    /** @description A value that indicates whether the owner can read from this file. */
    // @ApiMember(Description="A value that indicates whether the owner can read from this file.", Name="OthersCanRead")
    public ownerCanRead: boolean;

    /** @description A value that indicates whether others can read from this file. */
    // @ApiMember(Description="A value that indicates whether others can read from this file.", Name="OthersCanExecute")
    public othersCanExecute: boolean;

    /** @description A value that indicates whether others can write into this file. */
    // @ApiMember(Description="A value that indicates whether others can write into this file.", Name="OthersCanWrite")
    public othersCanWrite: boolean;

    /** @description Extensions to the file attributes. */
    // @ApiMember(Description="Extensions to the file attributes.", Name="Extensions")
    public extensions: { [index: string]: string; };

    public constructor(init?: Partial<FileMetadata>) { (Object as any).assign(this, init); }
}

/** @description Represents a file that contains raw data content in bytes */
// @Api(Description="Represents a file that contains raw data content in bytes")
export class BinaryFile extends FileBase
{
    /** @description The attributes of the file. */
    // @ApiMember(Description="The attributes of the file.", Name="Metadata")
    public metadata: FileMetadata;

    /** @description The name of the file without information on its directory path. */
    // @ApiMember(Description="The name of the file without information on its directory path.", Name="Name")
    public name: string;

    /** @description The raw data content of the file. */
    // @ApiMember(Description="The raw data content of the file.", Name="Content")
    public content: string;

    public constructor(init?: Partial<BinaryFile>) { super(init); (Object as any).assign(this, init); }
}

/** @description A type that encapsulates the return values from the ERiC API function that processes tax data. */
// @Api(Description="A type that encapsulates the return values from the ERiC API function that processes tax data.")
export class BearbeiteVorgangResponse extends EricFehlerCodeResponse
{
    /** @description The return value of the process. */
    // @ApiMember(Description="The return value of the process.")
    public rueckgabe?: EricBearbeiteVorgang;

    /** @description The server response of the process. */
    // @ApiMember(Description="The server response of the process.")
    public serverantwort?: Elster;

    /** @description If available, the PDF-based files to represent generated transfer prototocols. */
    // @ApiMember(Description="If available, the PDF-based files to represent generated transfer prototocols.")
    public transferProtocols: BinaryFile[];

    /** @description The status code that the ERiC API function returns. */
    // @ApiMember(Description="The status code that the ERiC API function returns.", Name="StatusCode")
    public statusCode: EricFehlerCode;

    /** @description The status message that the ERiC API function returns. */
    // @ApiMember(Description="The status message that the ERiC API function returns.", Name="StatusText")
    public statusText?: string;

    /** @description The unique identifier of the response. */
    // @ApiMember(Description="The unique identifier of the response.", Name="Id")
    public id: string;

    /** @description The position of the response element in an indexed collection. */
    // @ApiMember(Description="The position of the response element in an indexed collection.", Name="Index")
    public index: number;

    /** @description Metadata that contains structured error information on the service response. */
    // @ApiMember(Description="Metadata that contains structured error information on the service response.", Name="ResponseStatus")
    public responseStatus?: ResponseStatus;

    public constructor(init?: Partial<BearbeiteVorgangResponse>) { super(init); (Object as any).assign(this, init); }
}

/** @description A synchronous service to submit an annual VAT return for 2020. */
// @Api(Description="A synchronous service to submit an annual VAT return for 2020.")
export class SubmitUmsatzsteuererklaerung2020 extends SubmitUmsatzsteuererklaerung2020Base
{
    /** @description Die Art des ermittelten Ordnungsbegriffs zu füllen. */
    // @ApiMember(Description="Die Art des ermittelten Ordnungsbegriffs zu füllen.")
    public ordNrArt: OrdNrArt;

    /** @description Der Vorgang bei einer Veranlagung. */
    // @ApiMember(Description="Der Vorgang bei einer Veranlagung.")
    public vorgang: VeranlagungVorgang;

    public stNr?: string;
    public id?: string;
    public idEhefrau?: string;
    /** @description Das Erstellungsdatum des Steuerfalls, im Format JJJJMMDD. */
    // @ApiMember(Description="Das Erstellungsdatum des Steuerfalls, im Format JJJJMMDD.")
    public erstelldatum?: string;

    /** @description Die Erstellungszeit des Steuerfalls, im Format hhmmss. */
    // @ApiMember(Description="Die Erstellungszeit des Steuerfalls, im Format hhmmss.")
    public erstellzeit?: string;

    /** @description Name, alphanumerisch, max. 45-stellig. */
    // @ApiMember(Description="Name, alphanumerisch, max. 45-stellig.")
    public absName?: string;

    /** @description Straße und Hausnummer, alphanumerisch, max. 30-stellig. */
    // @ApiMember(Description="Straße und Hausnummer, alphanumerisch, max. 30-stellig.")
    public absStr?: string;

    /** @description Postleitzahl des Absenders der Erklärung */
    // @ApiMember(Description="Postleitzahl des Absenders der Erklärung")
    public absPlz?: string;

    /** @description Ort, alphanumerisch, max. 29-stellig. */
    // @ApiMember(Description="Ort, alphanumerisch, max. 29-stellig.")
    public absOrt?: string;

    /** @description Copyrightmeldung des SW-Herstellers, alphanumerisch, max.50-stellig */
    // @ApiMember(Description="Copyrightmeldung des SW-Herstellers, alphanumerisch, max.50-stellig")
    public copyright?: string;

    /** @description Wird die elektronische Bereitstellung der Bescheiddaten gewünscht? */
    // @ApiMember(Description="Wird die elektronische Bereitstellung der Bescheiddaten gewünscht?")
    public rueckuebermittlung?: Rueckuebermittlung;

    /** @description Allgemeine Angaben (General Information) */
    // @ApiMember(Description="Allgemeine Angaben (General Information)")
    public allgemeineAngaben?: AllgemeineAngaben2020;

    /** @description Angaben der Besteuerung für Kleinunternehmer (Taxation details for small entrepreneurs) */
    // @ApiMember(Description="Angaben der Besteuerung für Kleinunternehmer (Taxation details for small entrepreneurs)")
    public angabenBesteuerungKleinunternehmer?: AngabenBesteuerungKleinunternehmer2020;

    /** @description Tax-free goods, etc. (Steuerfreie Lieferungen usw.) */
    // @ApiMember(Description="Tax-free goods, etc. (Steuerfreie Lieferungen usw.)")
    public steuerfreieLieferungenEtc?: SteuerfreieLieferungenEtc2020;

    /** @description Steuerpflichtige Lieferungen usw. (Taxable goods etc.) */
    // @ApiMember(Description="Steuerpflichtige Lieferungen usw. (Taxable goods etc.)")
    public steuerpflichtigeLieferungenEtc?: SteuerpflichtigeLieferungenEtc2020;

    /** @description Innergemeinschaftliche Erwerbe (Intra-Community acquisitions) */
    // @ApiMember(Description="Innergemeinschaftliche Erwerbe (Intra-Community acquisitions)")
    public innergemeinschaftlicheErwerbe?: InnergemeinschaftlicheErwerbe2020;

    /** @description Steuerschuldner bei Auslagerung (Tax payer for outsourcing) */
    // @ApiMember(Description="Steuerschuldner bei Auslagerung (Tax payer for outsourcing)")
    public steuerschuldnerBeiAuslagerung?: SteuerschuldnerBeiAuslagerung2020;

    /** @description Innergemeinschaftliche Dreiecksgeschäfte (Intra-Community triangular transactions) */
    // @ApiMember(Description="Innergemeinschaftliche Dreiecksgeschäfte (Intra-Community triangular transactions)")
    public innergemeinschaftlicheDreiecksgeschaefte?: InnergemeinschaftlicheDreiecksgeschaefte2020;

    /** @description Leistungsempfänger als Steuerschuldner (Beneficiary as tax payer) */
    // @ApiMember(Description="Leistungsempfänger als Steuerschuldner (Beneficiary as tax payer)")
    public leistungsempfaengerAlsSteuerschuldner?: LeistungsempfaengerAlsSteuerschuldner2020;

    /** @description Ergänzende Angaben (Supplementary information) */
    // @ApiMember(Description="Ergänzende Angaben (Supplementary information)")
    public ergaenzendeAngaben?: ErgaenzendeAngaben2020;

    /** @description Abziehbare Vorsteuerbeträge (Deductible input tax amounts) */
    // @ApiMember(Description="Abziehbare Vorsteuerbeträge (Deductible input tax amounts)")
    public abziehbareVorsteuerbetraege?: AbziehbareVorsteuerbetraege2020;

    /** @description Berichtigung vom Vorsteuerabzug (Adjustment of input tax deduction) */
    // @ApiMember(Description="Berichtigung vom Vorsteuerabzug (Adjustment of input tax deduction)")
    public berichtigungVorsteuerabzug?: BerichtigungVorsteuerabzug2020;

    /** @description Berechnung vom Umsatzsteuer (Calculation of VAT) */
    // @ApiMember(Description="Berechnung vom Umsatzsteuer (Calculation of VAT)")
    public berechnungUmsatzsteuer?: BerechnungUmsatzsteuer2020;

    /** @description Unterschrift (Signature) */
    // @ApiMember(Description="Unterschrift (Signature)")
    public unterschrift?: Unterschrift2020;

    /** @description Anlage UN zur Umsatzsteuererklärung für im Ausland ansässige Unternehmer (Appendix to the VAT Declaration 2020 for entrepreneurs resident abroad). */
    // @ApiMember(Description="Anlage UN zur Umsatzsteuererklärung für im Ausland ansässige Unternehmer (Appendix to the VAT Declaration 2020 for entrepreneurs resident abroad).")
    public anlageUn?: AnlageUn2020;

    /** @description Anlage FV zur Umsatzsteuererklärung $VZ$ (Appendix FV to the sales tax return $VZ$). */
    // @ApiMember(Description="Anlage FV zur Umsatzsteuererklärung $VZ$ (Appendix FV to the sales tax return $VZ$).")
    public anlageFv?: AnlageFv2020;

    /** @description The four-digit federal tax office number of the receiving tax office. */
    // @ApiMember(Description="The four-digit federal tax office number of the receiving tax office.", IsRequired=true, Name="Bundesfinanzamtsnummer")
    public bundesfinanzamtsnummer: string;

    /** @description The details of the provider that submits the tax data. */
    // @ApiMember(Description="The details of the provider that submits the tax data.", IsRequired=true, Name="DatenLieferant")
    public datenLieferant: string;

    /** @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. */
    // @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")
    public duplexDruck?: boolean;

    /** @description Name prefix of the generated transfer protocol file. */
    // @ApiMember(Description="Name prefix of the generated transfer protocol file.", IsRequired=true, Name="ProtocolPrefix")
    public protocolPrefix: string;

    /** @description Footer text to be used on the printout (optional). */
    // @ApiMember(Description="Footer text to be used on the printout (optional).", Name="FussText")
    public fussText?: string;

    /** @description The authentification certificate. */
    // @ApiMember(Description="The authentification certificate.", IsRequired=true, Name="Zertifikat")
    public zertifikat: PortalCertificate;

    public constructor(init?: Partial<SubmitUmsatzsteuererklaerung2020>) { super(init); (Object as any).assign(this, init); }
}

TypeScript SubmitUmsatzsteuererklaerung2020 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 /SubmitUmsatzsteuererklaerung2020 HTTP/1.1 
Host: taxfiling.pwc.de 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	ordNrArt: S,
	vorgang: NurVeranlagung,
	stNr: String,
	id: String,
	idEhefrau: String,
	erstelldatum: 0001-01-01,
	erstellzeit: 0001-01-01,
	absName: String,
	absStr: String,
	absPlz: String,
	absOrt: String,
	copyright: String,
	rueckuebermittlung: 
	{
		bescheid: False,
		artRueckuebermittlung: String,
		schluesselRueckuebermittlung: String,
		adresseRueckuebermittlung: String
	},
	allgemeineAngaben: 
	{
		nr3000013: 
		{
			wert: False,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3000601: 
		{
			wert: False,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3000901: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3000902: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3001001: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3001101: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3001203: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3001204: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3001205: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3001201: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3001403: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3001404: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3001202: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3001301: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3001402: 
		{
			wert: False,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3001801: 
		{
			wert: False,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3001401: 
		{
			wert: 
			{
				start: 0001-01-01,
				ende: 0001-01-01
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3001501: 
		{
			wert: 
			{
				start: 0001-01-01,
				ende: 0001-01-01
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3002203: 
		{
			wert: 1,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3001701: 
		{
			wert: False,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3002201: 
		{
			wert: False,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3002202: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		}
	},
	angabenBesteuerungKleinunternehmer: 
	{
		nr3002301: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3002401: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		}
	},
	steuerfreieLieferungenEtc: 
	{
		nr3103301: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3103401: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3103501: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3103801: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3103901: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3103902: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3104001: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3104101: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3104201: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3104401: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3104501: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3104502: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3104601: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3104901: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3104902: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		}
	},
	steuerpflichtigeLieferungenEtc: 
	{
		nr3003303: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3003304: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3003405: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3003406: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3003505: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3003506: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3004401: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3004402: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3003703: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3003704: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3003803: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3003804: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3005001: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3005002: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3005201: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3005301: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3005302: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3005003: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3005004: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3005701: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3005702: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3005801: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3102901: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3102801: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3005901: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3006001: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		}
	},
	innergemeinschaftlicheErwerbe: 
	{
		nr3100901: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3100902: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3100903: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3101301: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3101302: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3101303: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3101304: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3101401: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3101402: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3101501: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		}
	},
	steuerschuldnerBeiAuslagerung: 
	{
		nr3102804: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3102805: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3102904: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		}
	},
	innergemeinschaftlicheDreiecksgeschaefte: 
	{
		nr3101801: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3101701: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3101702: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3102301: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3102302: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3102303: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3102304: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3102401: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		}
	},
	leistungsempfaengerAlsSteuerschuldner: 
	{
		nr3102205: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3102206: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3102307: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3102308: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3102503: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3102504: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3102601: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		}
	},
	ergaenzendeAngaben: 
	{
		nr3105201: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3105301: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3105501: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3105601: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3105101: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3105102: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3105602: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3105702: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3105801: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3105901: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3106001: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		}
	},
	abziehbareVorsteuerbetraege: 
	{
		nr3006201: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3006301: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3006401: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3006503: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3006502: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3006501: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3006601: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3006701: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3006801: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3006901: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		}
	},
	berichtigungVorsteuerabzug: 
	{
		nr3007301: 
		{
			wert: False,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3007401: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3007402: 
		{
			wert: 0001-01-01,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3007403: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3007404: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3007405: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3007406: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3007601: 
		{
			wert: False,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3008501: 
		{
			wert: False,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3008601: 
		{
			wert: False,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3007801: 
		{
			wert: False,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3007802: 
		{
			wert: False,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3007803: 
		{
			wert: False,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3007901: 
		{
			wert: False,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3008001: 
		{
			wert: False,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3008202: 
		{
			wert: False,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3008401: 
		{
			wert: False,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3008402: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3008701: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3008702: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3008801: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3008802: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3008803: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3008804: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3008901: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3008902: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		}
	},
	berechnungUmsatzsteuer: 
	{
		nr3009201: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3009401: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3009602: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3009501: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3009502: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3009801: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3009901: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3010001: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3010201: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3009701: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3010301: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3010401: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3010501: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3010601: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3010602: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3011101: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3011301: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3011401: 
		{
			betrag: 
			{
				wert: 0
			},
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		}
	},
	unterschrift: 
	{
		nr3002602: 
		{
			wert: False,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3002501: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3002502: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3002503: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3002504: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3002505: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3002506: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3002507: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3002508: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		},
		nr3002509: 
		{
			wert: String,
			nr: 0,
			index: 0,
			lfdNr: 0,
			alias: String
		}
	},
	anlageUn: 
	{
		allgemeineAngaben: 
		{
			nr3201001: 
			{
				wert: String,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3201002: 
			{
				wert: String,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3200901: 
			{
				wert: String,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3200902: 
			{
				wert: String,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3200904: 
			{
				wert: False,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3200905: 
			{
				wert: String,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3201301: 
			{
				wert: False,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3201401: 
			{
				wert: False,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3201501: 
			{
				wert: String,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3201601: 
			{
				wert: String,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3201302: 
			{
				wert: String,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3201303: 
			{
				wert: String,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3201304: 
			{
				wert: String,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3201402: 
			{
				wert: String,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3201503: 
			{
				wert: String,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3201504: 
			{
				wert: String,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3201502: 
			{
				wert: String,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3201602: 
			{
				wert: String,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3201701: 
			{
				wert: False,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			}
		},
		anrechenbareBetraege: 
		{
			nr3201902: 
			{
				betrag: 
				{
					wert: 0
				},
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3202002: 
			{
				betrag: 
				{
					wert: 0
				},
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3202102: 
			{
				betrag: 
				{
					wert: 0
				},
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			}
		},
		ergaenzendeAngabenZuUmsaetzen: 
		{
			nr3201901: 
			{
				betrag: 
				{
					wert: 0
				},
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3202901: 
			{
				wert: String,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3202902: 
			{
				wert: 0001-01-01,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3202903: 
			{
				wert: 0001-01-01,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3202904: 
			{
				wert: String,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3202905: 
			{
				betrag: 
				{
					wert: 0
				},
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			}
		},
		vorsteuerVerguetungsverfahrenBeimBZSt: 
		{
			nr3201101: 
			{
				wert: False,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			}
		}
	},
	anlageFv: 
	{
		aufstAllerVertrUnt: 
		{
			nr3300201: 
			{
				wert: String,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3300202: 
			{
				wert: String,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3300203: 
			{
				wert: String,
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3300204: 
			{
				betrag: 
				{
					wert: 0
				},
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			},
			nr3300301: 
			{
				betrag: 
				{
					wert: 0
				},
				nr: 0,
				index: 0,
				lfdNr: 0,
				alias: String
			}
		}
	},
	bundesfinanzamtsnummer: String,
	datenLieferant: String,
	duplexDruck: False,
	protocolPrefix: String,
	fussText: String,
	zertifikat: 
	{
		id: 00000000000000000000000000000000,
		index: 0,
		pin: String,
		description: String,
		tags: 
		[
			String
		],
		name: 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: 34a,
			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
		}
	}
}