Tax Filing Service

<back to all web services

CreateUmsatzsteuervoranmeldung2023XmlAsync

AsyncUmsatzsteuerVoranmeldung2023

An asynchronous service to create xml content that represents the preliminary VAT return (Umsatzsteuervoranmeldung) for 2023.

Requires Authentication
The following routes are available for this service:
POST/CreateUmsatzsteuervoranmeldung2023XmlAsyncAn asynchronous service to create xml content that represents the preliminary VAT return (Umsatzsteuervoranmeldung) for 2023
import 'package:servicestack/servicestack.dart';
import 'dart:typed_data';

/**
* Beim DatenLieferanten handelt es sich um diejenige natürliche Person, welche die Software bedient, bzw. in deren Namen die Software bedient wird,um die Daten zu übersenden (auf den Sendeknopf drückt - NICHT jedoch ein etwaiger Erfüllungsgehilfe).
*/
// @Api(Description="Beim DatenLieferanten handelt es sich um diejenige natürliche Person, welche die Software bedient, bzw. in deren Namen die Software bedient wird,um die Daten zu übersenden (auf den Sendeknopf drückt - NICHT jedoch ein etwaiger Erfüllungsgehilfe).")
class DatenLieferant implements IConvertible
{
    /**
    * Der Name des Datenlieferants.
    */
    // @ApiMember(Description="Der Name des Datenlieferants.", IsRequired=true, Name="Name")
    String? name;

    /**
    * Der Straßenname des Datenlieferants.
    */
    // @ApiMember(Description="Der Straßenname des Datenlieferants.", IsRequired=true, Name="Strasse")
    String? strasse;

    /**
    * Die Postleitzahl des Datenlieferants.
    */
    // @ApiMember(Description="Die Postleitzahl des Datenlieferants.", IsRequired=true, Name="PLZ")
    String? plz;

    /**
    * Der Ort des Datenlieferants.
    */
    // @ApiMember(Description="Der Ort des Datenlieferants.", IsRequired=true, Name="Ort")
    String? ort;

    /**
    * Die Telefonnummer (optional) des Datenlieferants.
    */
    // @ApiMember(Description="Die Telefonnummer (optional) des Datenlieferants.", Name="Telefon")
    String? telefon;

    /**
    * Die Email-Adresse (optional) des Datenlieferant.
    */
    // @ApiMember(Description="Die Email-Adresse (optional) des Datenlieferant.", Name="Email")
    String? email;

    DatenLieferant({this.name,this.strasse,this.plz,this.ort,this.telefon,this.email});
    DatenLieferant.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        name = json['name'];
        strasse = json['strasse'];
        plz = json['plz'];
        ort = json['ort'];
        telefon = json['telefon'];
        email = json['email'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'name': name,
        'strasse': strasse,
        'plz': plz,
        'ort': ort,
        'telefon': telefon,
        'email': email
    };

    getTypeName() => "DatenLieferant";
    TypeContext? context = _ctx;
}

/**
* Stellt einen Steuerberater dar.
*/
// @Api(Description="Stellt einen Steuerberater dar.")
class Berater implements IConvertible
{
    /**
    * Der Bezeichnung (optional) des Beraters (normalerweise der Name des Beraters Unternehmen).
    */
    // @ApiMember(Description="Der Bezeichnung (optional) des Beraters (normalerweise der Name des Beraters Unternehmen).", Name="Bezeichnung")
    String? bezeichnung;

    /**
    * Der Name (optional) des Beraters.
    */
    // @ApiMember(Description="Der Name (optional) des Beraters.", Name="Name")
    String? name;

    /**
    * Der Vorname (optional) des Beraters.
    */
    // @ApiMember(Description="Der Vorname (optional) des Beraters.", Name="Vorname")
    String? vorname;

    /**
    * Der Namenvorsatz (optional) des Beraters.
    */
    // @ApiMember(Description="Der Namenvorsatz (optional) des Beraters.", Name="Namensvorsatz")
    String? namensvorsatz;

    /**
    * Der Namenzusatz (optional) des Beraters.
    */
    // @ApiMember(Description="Der Namenzusatz (optional) des Beraters.", Name="Namenszusatz")
    String? namenszusatz;

    /**
    * Der Straßenname (optional) des Beraters.
    */
    // @ApiMember(Description="Der Straßenname (optional) des Beraters.", Name="Str")
    String? str;

    /**
    * Die Hausnummer (optional) des Beraters.
    */
    // @ApiMember(Description="Die Hausnummer (optional) des Beraters.", Name="Hausnummer")
    String? hausnummer;

    /**
    * Der Hausnummernzusatz (optional) des Beraters.
    */
    // @ApiMember(Description="Der Hausnummernzusatz (optional) des Beraters.", Name="HNrZusatz")
    String? hNrZusatz;

    /**
    * Der Anschriftenzusatz (optional) des Beraters.
    */
    // @ApiMember(Description="Der Anschriftenzusatz (optional) des Beraters.", Name="AnschriftenZusatz")
    String? anschriftenZusatz;

    /**
    * Der Ort (optional) des Beraters.
    */
    // @ApiMember(Description="Der Ort (optional) des Beraters.", Name="Ort")
    String? ort;

    /**
    * Die Postleitzahl (optional) des Beraters.
    */
    // @ApiMember(Description="Die Postleitzahl (optional) des Beraters.", Name="PLZ")
    String? plz;

    /**
    * Die Auslandspostleitzahl (optional) des Beraters.
    */
    // @ApiMember(Description="Die Auslandspostleitzahl (optional) des Beraters.", Name="AuslandsPLZ")
    String? auslandsPLZ;

    /**
    * Der Ländername (falls Anschrift im Ausland) des Beraters - optional. Der Ländername des Beraters kann mit 1-20 alphanumerischen Zeichen geliefert werden.
    */
    // @ApiMember(Description="Der Ländername (falls Anschrift im Ausland) des Beraters - optional. \nDer Ländername des Beraters kann mit 1-20 alphanumerischen Zeichen geliefert werden.", Name="Land")
    String? land;

    /**
    * Der Ort des Postfaches (optional) des Beraters.
    */
    // @ApiMember(Description="Der Ort des Postfaches (optional) des Beraters.", Name="PostfachOrt")
    String? postfachOrt;

    /**
    * Das Postfach (optional) des Beraters.
    */
    // @ApiMember(Description="Das Postfach (optional) des Beraters.", Name="Postfach")
    String? postfach;

    /**
    * Die Postleitzahl (optional) des Beraters.
    */
    // @ApiMember(Description="Die Postleitzahl (optional) des Beraters.", Name="PostfachPLZ")
    String? postfachPLZ;

    /**
    * Die Großkundenpostleitzahl (optional) des Beraters.
    */
    // @ApiMember(Description="Die Großkundenpostleitzahl (optional) des Beraters.", Name="GKPLZ")
    String? gkplz;

    /**
    * Die Telefonnummer (optional) des Beraters.
    */
    // @ApiMember(Description="Die Telefonnummer (optional) des Beraters.", Name="Telefon")
    String? telefon;

    /**
    * Die Emailadresse (optional) des Beraters.
    */
    // @ApiMember(Description="Die Emailadresse (optional) des Beraters.", Name="Email")
    String? email;

    Berater({this.bezeichnung,this.name,this.vorname,this.namensvorsatz,this.namenszusatz,this.str,this.hausnummer,this.hNrZusatz,this.anschriftenZusatz,this.ort,this.plz,this.auslandsPLZ,this.land,this.postfachOrt,this.postfach,this.postfachPLZ,this.gkplz,this.telefon,this.email});
    Berater.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        bezeichnung = json['bezeichnung'];
        name = json['name'];
        vorname = json['vorname'];
        namensvorsatz = json['namensvorsatz'];
        namenszusatz = json['namenszusatz'];
        str = json['str'];
        hausnummer = json['hausnummer'];
        hNrZusatz = json['hNrZusatz'];
        anschriftenZusatz = json['anschriftenZusatz'];
        ort = json['ort'];
        plz = json['plz'];
        auslandsPLZ = json['auslandsPLZ'];
        land = json['land'];
        postfachOrt = json['postfachOrt'];
        postfach = json['postfach'];
        postfachPLZ = json['postfachPLZ'];
        gkplz = json['gkplz'];
        telefon = json['telefon'];
        email = json['email'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'bezeichnung': bezeichnung,
        'name': name,
        'vorname': vorname,
        'namensvorsatz': namensvorsatz,
        'namenszusatz': namenszusatz,
        'str': str,
        'hausnummer': hausnummer,
        'hNrZusatz': hNrZusatz,
        'anschriftenZusatz': anschriftenZusatz,
        'ort': ort,
        'plz': plz,
        'auslandsPLZ': auslandsPLZ,
        'land': land,
        'postfachOrt': postfachOrt,
        'postfach': postfach,
        'postfachPLZ': postfachPLZ,
        'gkplz': gkplz,
        'telefon': telefon,
        'email': email
    };

    getTypeName() => "Berater";
    TypeContext? context = _ctx;
}

/**
* Stellt einen Mandant dar.
*/
// @Api(Description="Stellt einen Mandant dar.")
class Mandant implements IConvertible
{
    /**
    * Der Name (optional) des Mandanten.
    */
    // @ApiMember(Description="Der Name (optional) des Mandanten.", Name="Name")
    String? name;

    /**
    * Der Vorname (optional) des Mandanten.
    */
    // @ApiMember(Description="Der Vorname (optional) des Mandanten.", Name="Vorname")
    String? vorname;

    /**
    * Die Mandantennummer (optional) des Mandanten.
    */
    // @ApiMember(Description="Die Mandantennummer (optional) des Mandanten.", Name="MandantenNr")
    String? mandantenNr;

    /**
    * Das Bearbeiterkennzeichen (optional) des Mandanten.
    */
    // @ApiMember(Description="Das Bearbeiterkennzeichen (optional) des Mandanten.", Name="Bearbeiterkennzeichen")
    String? bearbeiterkennzeichen;

    Mandant({this.name,this.vorname,this.mandantenNr,this.bearbeiterkennzeichen});
    Mandant.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        name = json['name'];
        vorname = json['vorname'];
        mandantenNr = json['mandantenNr'];
        bearbeiterkennzeichen = json['bearbeiterkennzeichen'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'name': name,
        'vorname': vorname,
        'mandantenNr': mandantenNr,
        'bearbeiterkennzeichen': bearbeiterkennzeichen
    };

    getTypeName() => "Mandant";
    TypeContext? context = _ctx;
}

/**
* Stellt einen Unternehmer dar.
*/
// @Api(Description="Stellt einen Unternehmer dar.")
class Unternehmer implements IConvertible
{
    /**
    * Der Bezeichnung (optional) des Unternehmers (normalerweise der Name des Unternehmers Unternehmen).
    */
    // @ApiMember(Description="Der Bezeichnung (optional) des Unternehmers (normalerweise der Name des Unternehmers Unternehmen).", Name="Bezeichnung")
    String? bezeichnung;

    /**
    * Der Name (optional) des Unternehmers.
    */
    // @ApiMember(Description="Der Name (optional) des Unternehmers.", Name="Name")
    String? name;

    /**
    * Der Vorname (optional) des Unternehmers.
    */
    // @ApiMember(Description="Der Vorname (optional) des Unternehmers.", Name="Vorname")
    String? vorname;

    /**
    * Der Namenvorsatz (optional) des Unternehmers.
    */
    // @ApiMember(Description="Der Namenvorsatz (optional) des Unternehmers.", Name="Namensvorsatz")
    String? namensvorsatz;

    /**
    * Der Namenzusatz (optional) des Unternehmers.
    */
    // @ApiMember(Description="Der Namenzusatz (optional) des Unternehmers.", Name="Namenszusatz")
    String? namenszusatz;

    /**
    * Der Straßenname (optional) des Unternehmers.
    */
    // @ApiMember(Description="Der Straßenname (optional) des Unternehmers.", Name="Str")
    String? str;

    /**
    * Die Hausnummer (optional) des Unternehmers.
    */
    // @ApiMember(Description="Die Hausnummer (optional) des Unternehmers.", Name="Hausnummer")
    String? hausnummer;

    /**
    * Der Hausnummernzusatz (optional) des Unternehmers.
    */
    // @ApiMember(Description="Der Hausnummernzusatz (optional) des Unternehmers.", Name="HNrZusatz")
    String? hNrZusatz;

    /**
    * Der Anschriftenzusatz (optional) des Unternehmers.
    */
    // @ApiMember(Description="Der Anschriftenzusatz (optional) des Unternehmers.", Name="AnschriftenZusatz")
    String? anschriftenZusatz;

    /**
    * Der Ort (optional) des Unternehmers.
    */
    // @ApiMember(Description="Der Ort (optional) des Unternehmers.", Name="Ort")
    String? ort;

    /**
    * Die Postleitzahl (optional) des Unternehmers.
    */
    // @ApiMember(Description="Die Postleitzahl (optional) des Unternehmers.", Name="PLZ")
    String? plz;

    /**
    * Die Auslandspostleitzahl (optional) des Unternehmers.
    */
    // @ApiMember(Description="Die Auslandspostleitzahl (optional) des Unternehmers.", Name="AuslandsPLZ")
    String? auslandsPLZ;

    /**
    * Der Ländername (falls Anschrift im Ausland) des Unternehmers - optional. Der Ländername des Unternehmers kann mit 1-20 alphanumerischen Zeichen geliefert werden.
    */
    // @ApiMember(Description="Der Ländername (falls Anschrift im Ausland) des Unternehmers - optional. \nDer Ländername des Unternehmers kann mit 1-20 alphanumerischen Zeichen geliefert werden.", Name="Land")
    String? land;

    /**
    * Der Ort des Postfaches (optional) des Unternehmers.
    */
    // @ApiMember(Description="Der Ort des Postfaches (optional) des Unternehmers.", Name="PostfachOrt")
    String? postfachOrt;

    /**
    * Das Postfach (optional) des Unternehmers.
    */
    // @ApiMember(Description="Das Postfach (optional) des Unternehmers.", Name="Postfach")
    String? postfach;

    /**
    * Die Postleitzahl (optional) des Unternehmers.
    */
    // @ApiMember(Description="Die Postleitzahl (optional) des Unternehmers.", Name="PostfachPLZ")
    String? postfachPLZ;

    /**
    * Die Großkundenpostleitzahl (optional) des Unternehmers.
    */
    // @ApiMember(Description="Die Großkundenpostleitzahl (optional) des Unternehmers.", Name="GKPLZ")
    String? gkplz;

    /**
    * Die Telefonnummer (optional) des Unternehmers.
    */
    // @ApiMember(Description="Die Telefonnummer (optional) des Unternehmers.", Name="Telefon")
    String? telefon;

    /**
    * Die Emailadresse (optional) des Unternehmers.
    */
    // @ApiMember(Description="Die Emailadresse (optional) des Unternehmers.", Name="Email")
    String? email;

    Unternehmer({this.bezeichnung,this.name,this.vorname,this.namensvorsatz,this.namenszusatz,this.str,this.hausnummer,this.hNrZusatz,this.anschriftenZusatz,this.ort,this.plz,this.auslandsPLZ,this.land,this.postfachOrt,this.postfach,this.postfachPLZ,this.gkplz,this.telefon,this.email});
    Unternehmer.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        bezeichnung = json['bezeichnung'];
        name = json['name'];
        vorname = json['vorname'];
        namensvorsatz = json['namensvorsatz'];
        namenszusatz = json['namenszusatz'];
        str = json['str'];
        hausnummer = json['hausnummer'];
        hNrZusatz = json['hNrZusatz'];
        anschriftenZusatz = json['anschriftenZusatz'];
        ort = json['ort'];
        plz = json['plz'];
        auslandsPLZ = json['auslandsPLZ'];
        land = json['land'];
        postfachOrt = json['postfachOrt'];
        postfach = json['postfach'];
        postfachPLZ = json['postfachPLZ'];
        gkplz = json['gkplz'];
        telefon = json['telefon'];
        email = json['email'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'bezeichnung': bezeichnung,
        'name': name,
        'vorname': vorname,
        'namensvorsatz': namensvorsatz,
        'namenszusatz': namenszusatz,
        'str': str,
        'hausnummer': hausnummer,
        'hNrZusatz': hNrZusatz,
        'anschriftenZusatz': anschriftenZusatz,
        'ort': ort,
        'plz': plz,
        'auslandsPLZ': auslandsPLZ,
        'land': land,
        'postfachOrt': postfachOrt,
        'postfach': postfach,
        'postfachPLZ': postfachPLZ,
        'gkplz': gkplz,
        'telefon': telefon,
        'email': email
    };

    getTypeName() => "Unternehmer";
    TypeContext? context = _ctx;
}

/**
* Stellt eine Anbindung zum ELSTER Online Portal (EOP) dar.
*/
// @Api(Description="Stellt eine Anbindung zum ELSTER Online Portal (EOP) dar.")
class EOP implements IConvertible
{
    String? transferausgabe;

    EOP({this.transferausgabe});
    EOP.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        transferausgabe = json['transferausgabe'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'transferausgabe': transferausgabe
    };

    getTypeName() => "EOP";
    TypeContext? context = _ctx;
}

/**
* reate XML content that represents a VAT registration (Umsatzsteueranmeldung) for 2023.
*/
// @Api(Description="reate XML content that represents a VAT registration (Umsatzsteueranmeldung) for 2023.")
abstract class CreateUmsatzsteueranmeldung2023XmlBase implements IPost
{
    /**
    * Natürliche Person, welche die Software bedient, bzw. in deren Namen die Software bedient wird, um die Daten zu übersenden (Natural person who operates the software or under whose name the software is operated in order to transmit the data).
    */
    // @ApiMember(Description="Natürliche Person, welche die Software bedient, bzw. in deren Namen die Software bedient wird, um die Daten zu übersenden (Natural person who operates the software or under whose name the software is operated in order to transmit the data).", IsRequired=true, Name="DatenLieferant")
    DatenLieferant? datenLieferant;

    /**
    * Das Datum der Erstellung (Date of creation).
    */
    // @ApiMember(Description="Das Datum der Erstellung (Date of creation).", IsRequired=true, Name="Erstellungsdatum")
    DateTime? erstellungsdatum;

    /**
    * Der Steuerberater, der den Steuerfall bearbeitet und abgibt (The tax adviser who processes and submits the tax case).
    */
    // @ApiMember(Description="Der Steuerberater, der den Steuerfall bearbeitet und abgibt (The tax adviser who processes and submits the tax case).", Name="Berater")
    Berater? berater;

    /**
    * Der Mandant, für den der Steuerfall bearbeitet wird (The client for which the tax case is being processed).
    */
    // @ApiMember(Description="Der Mandant, für den der Steuerfall bearbeitet wird (The client for which the tax case is being processed).", Name="Mandant")
    Mandant? mandant;

    /**
    * Der natürliche oder jüritische Person, der den Steuerfall bearbeitet und abgibt (The natural or legal person who processes and submits the tax case).
    */
    // @ApiMember(Description="Der natürliche oder jüritische Person, der den Steuerfall bearbeitet und abgibt (The natural or legal person who processes and submits the tax case).", Name="Unternehmer")
    Unternehmer? unternehmer;

    /**
    * Die vierstellige Bundesfinanzamtsnummer des empfangenden Finanzamtes (The four-digit federal tax office number of the receiving tax office).
    */
    // @ApiMember(Description="Die vierstellige Bundesfinanzamtsnummer des empfangenden Finanzamtes (The four-digit federal tax office number of the receiving tax office).", IsRequired=true, Name="Bundesfinanzamtsnummer")
    String? bundesfinanzamtsnummer;

    /**
    * Die Anbindung zum ELSTER Online Portal (EOP).
    */
    // @ApiMember(Description="Die Anbindung zum ELSTER Online Portal (EOP).", Name="EOP")
    EOP? eop;

    CreateUmsatzsteueranmeldung2023XmlBase({this.datenLieferant,this.erstellungsdatum,this.berater,this.mandant,this.unternehmer,this.bundesfinanzamtsnummer,this.eop});
    CreateUmsatzsteueranmeldung2023XmlBase.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        datenLieferant = JsonConverters.fromJson(json['datenLieferant'],'DatenLieferant',context!);
        erstellungsdatum = JsonConverters.fromJson(json['erstellungsdatum'],'DateTime',context!);
        berater = JsonConverters.fromJson(json['berater'],'Berater',context!);
        mandant = JsonConverters.fromJson(json['mandant'],'Mandant',context!);
        unternehmer = JsonConverters.fromJson(json['unternehmer'],'Unternehmer',context!);
        bundesfinanzamtsnummer = json['bundesfinanzamtsnummer'];
        eop = JsonConverters.fromJson(json['eop'],'EOP',context!);
        return this;
    }

    Map<String, dynamic> toJson() => {
        'datenLieferant': JsonConverters.toJson(datenLieferant,'DatenLieferant',context!),
        'erstellungsdatum': JsonConverters.toJson(erstellungsdatum,'DateTime',context!),
        'berater': JsonConverters.toJson(berater,'Berater',context!),
        'mandant': JsonConverters.toJson(mandant,'Mandant',context!),
        'unternehmer': JsonConverters.toJson(unternehmer,'Unternehmer',context!),
        'bundesfinanzamtsnummer': bundesfinanzamtsnummer,
        'eop': JsonConverters.toJson(eop,'EOP',context!)
    };

    getTypeName() => "CreateUmsatzsteueranmeldung2023XmlBase";
    TypeContext? context = _ctx;
}

/**
* Stellt den Zeitraum für eine Anmeldung dar
*/
enum AnmeldungZeitraum
{
    ZR01,
    ZR02,
    ZR03,
    ZR04,
    ZR05,
    ZR06,
    ZR07,
    ZR08,
    ZR09,
    ZR10,
    ZR11,
    ZR12,
    ZR41,
    ZR42,
    ZR43,
    ZR44,
}

/**
* Stellt den Pflichtkennzahl Kz09 dar, welche die Angabe diverser Informationen ermöglicht. Beispiele: 74931 74931*Name Berater*Berufsbezeichnung*** 74931*****Name Mandant 74931***Tel.Nr:Berater/Vorwahl*Tel.Nr:Berater/Anschluss*Name Mandant
*/
// @Api(Description="Stellt den Pflichtkennzahl Kz09 dar, welche die Angabe diverser Informationen ermöglicht. Beispiele: 74931 74931*Name Berater*Berufsbezeichnung*** 74931*****Name Mandant 74931***Tel.Nr:Berater/Vorwahl*Tel.Nr:Berater/Anschluss*Name Mandant")
class Kz09 implements IConvertible
{
    /**
    * Die Bezeichnung des Softwareherstellers (Pflicht), über dessen Software die Steuererklärung oder (Vor)anmeldung abgegeben wird. Die Bezeichnung muss 5-stellig sein.
    */
    // @ApiMember(Description="Die Bezeichnung des Softwareherstellers (Pflicht), über dessen Software die Steuererklärung oder (Vor)anmeldung abgegeben wird. Die Bezeichnung muss 5-stellig sein.", IsRequired=true, Name="HerstellerId")
    int? herstellerId;

    /**
    * Der Name des Beraters, welcher die Steuererklärung oder (Vor)anmeldung abgegeben wird. Das Name des Beraters kann von 0- bis 85-stellig sein.
    */
    // @ApiMember(Description="Der Name des Beraters, welcher die Steuererklärung oder (Vor)anmeldung abgegeben wird. Das Name des Beraters kann von 0- bis 85-stellig sein.", Name="BeraterName")
    String? beraterName;

    /**
    * Die Berufbezeichnung des Beraters. Die Berufbezeichnung des Beraterskann von 0- bis 85-stellig sein.
    */
    // @ApiMember(Description="Die Berufbezeichnung des Beraters. Die Berufbezeichnung des Beraterskann von 0- bis 85-stellig sein.", Name="Berufsbezeichnung")
    String? berufsbezeichnung;

    /**
    * Die Telefonnummervorwahl des Beraters. Die Telefonnummervorwahl des Beraters kann von 0- bis 85-stellig sein.
    */
    // @ApiMember(Description="Die Telefonnummervorwahl des Beraters. Die Telefonnummervorwahl des Beraters kann von 0- bis 85-stellig sein.", Name="Berufsbezeichnung")
    String? beraterTelNrVorwahl;

    /**
    * Der Telefonnummeranschluss des Beraters. Der Telefonnummeranschluss des Beraters kann von 0- bis 85-stellig sein.
    */
    // @ApiMember(Description="Der Telefonnummeranschluss des Beraters. Der Telefonnummeranschluss des Beraters kann von 0- bis 85-stellig sein.", Name="BeraterTelNrAnschluss")
    String? beraterTelNrAnschluss;

    /**
    * Der Name des Mandanten. Der Name des Mandanten kann von 0- bis 85-stellig sein.
    */
    // @ApiMember(Description="Der Name des Mandanten. Der Name des Mandanten kann von 0- bis 85-stellig sein.", Name="MandantName")
    String? mandantName;

    Kz09({this.herstellerId,this.beraterName,this.berufsbezeichnung,this.beraterTelNrVorwahl,this.beraterTelNrAnschluss,this.mandantName});
    Kz09.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        herstellerId = json['herstellerId'];
        beraterName = json['beraterName'];
        berufsbezeichnung = json['berufsbezeichnung'];
        beraterTelNrVorwahl = json['beraterTelNrVorwahl'];
        beraterTelNrAnschluss = json['beraterTelNrAnschluss'];
        mandantName = json['mandantName'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'herstellerId': herstellerId,
        'beraterName': beraterName,
        'berufsbezeichnung': berufsbezeichnung,
        'beraterTelNrVorwahl': beraterTelNrVorwahl,
        'beraterTelNrAnschluss': beraterTelNrAnschluss,
        'mandantName': mandantName
    };

    getTypeName() => "Kz09";
    TypeContext? context = _ctx;
}

/**
* Specifies an integer data type with limits and a specialized string representation
*/
// @Api(Description="Specifies an integer data type with limits and a specialized string representation")
abstract class Ganzzahl
{
    /**
    * The intrinsic integer value.
    */
    // @ApiMember(Description="The intrinsic integer value.")
    int? wert;

    Ganzzahl({this.wert});
    Ganzzahl.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        wert = json['wert'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'wert': wert
    };

    getTypeName() => "Ganzzahl";
    TypeContext? context = _ctx;
}

/**
* Represents an integer data type whose value has a maximum length of 1 digit. Minus sign allowed.
*/
// @Api(Description="Represents an integer data type whose value has a maximum length of 1 digit. Minus sign allowed.")
class Ganzzahl1EN extends Ganzzahl implements IConvertible
{
    /**
    * The intrinsic integer value.
    */
    // @ApiMember(Description="The intrinsic integer value.")
    int? wert;

    Ganzzahl1EN({this.wert});
    Ganzzahl1EN.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        super.fromMap(json);
        wert = json['wert'];
        return this;
    }

    Map<String, dynamic> toJson() => super.toJson()..addAll({
        'wert': wert
    });

    getTypeName() => "Ganzzahl1EN";
    TypeContext? context = _ctx;
}

/**
* 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")
abstract class GrossGeldBetragOhneCent
{
    /**
    * The intrinsic currency value.
    */
    // @ApiMember(Description="The intrinsic currency value.")
    int? wert;

    GrossGeldBetragOhneCent({this.wert});
    GrossGeldBetragOhneCent.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        wert = json['wert'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'wert': wert
    };

    getTypeName() => "GrossGeldBetragOhneCent";
    TypeContext? context = _ctx;
}

/**
* Represents an amount of money without cents whose value has a maximum length of 13 digits. That is, 1 to 13 digits. Minus sign allowed.
*/
// @Api(Description="Represents an amount of money without cents whose value has a maximum length of 13 digits. That is, 1 to 13 digits. Minus sign allowed.")
class GeldBetragOhneCent13EN extends GrossGeldBetragOhneCent implements IConvertible
{
    /**
    * The intrinsic currency value.
    */
    // @ApiMember(Description="The intrinsic currency value.")
    int? wert;

    GeldBetragOhneCent13EN({this.wert});
    GeldBetragOhneCent13EN.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        super.fromMap(json);
        wert = json['wert'];
        return this;
    }

    Map<String, dynamic> toJson() => super.toJson()..addAll({
        'wert': wert
    });

    getTypeName() => "GeldBetragOhneCent13EN";
    TypeContext? context = _ctx;
}

/**
* 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")
abstract class GeldBetragMitCent
{
    /**
    * The intrinsic currency value.
    */
    // @ApiMember(Description="The intrinsic currency value.")
    double? wert;

    GeldBetragMitCent({this.wert});
    GeldBetragMitCent.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        wert = JsonConverters.toDouble(json['wert']);
        return this;
    }

    Map<String, dynamic> toJson() => {
        'wert': wert
    };

    getTypeName() => "GeldBetragMitCent";
    TypeContext? context = _ctx;
}

/**
* Represents an amount of money with cents whose value has a maximum length of 13 digits. That is, 1 to 11 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 13 digits. That is, 1 to 11 digits before the decimal separator and 2 digits after the decimal separator. Minus sign allowed.")
class GeldBetragMitCent11EN extends GeldBetragMitCent implements IConvertible
{
    /**
    * The intrinsic currency value.
    */
    // @ApiMember(Description="The intrinsic currency value.")
    double? wert;

    GeldBetragMitCent11EN({this.wert});
    GeldBetragMitCent11EN.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        super.fromMap(json);
        wert = JsonConverters.toDouble(json['wert']);
        return this;
    }

    Map<String, dynamic> toJson() => super.toJson()..addAll({
        'wert': wert
    });

    getTypeName() => "GeldBetragMitCent11EN";
    TypeContext? context = _ctx;
}

/**
* Represents an unsigned amount of money with cents whose value has a maximum length of 13 digits. That is, 1 to 11 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 13 digits. That is, 1 to 11 digits before the decimal separator and 2 digits after the decimal separator. Minus sign NOT allowed.")
class PositiverGeldBetragMitCent11EN extends GeldBetragMitCent implements IConvertible
{
    /**
    * The intrinsic currency value.
    */
    // @ApiMember(Description="The intrinsic currency value.")
    double? wert;

    PositiverGeldBetragMitCent11EN({this.wert});
    PositiverGeldBetragMitCent11EN.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        super.fromMap(json);
        wert = JsonConverters.toDouble(json['wert']);
        return this;
    }

    Map<String, dynamic> toJson() => super.toJson()..addAll({
        'wert': wert
    });

    getTypeName() => "PositiverGeldBetragMitCent11EN";
    TypeContext? context = _ctx;
}

/**
* 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.")
class PositiverGeldBetragMitCent13EN extends GeldBetragMitCent implements IConvertible
{
    /**
    * The intrinsic currency value.
    */
    // @ApiMember(Description="The intrinsic currency value.")
    double? wert;

    PositiverGeldBetragMitCent13EN({this.wert});
    PositiverGeldBetragMitCent13EN.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        super.fromMap(json);
        wert = JsonConverters.toDouble(json['wert']);
        return this;
    }

    Map<String, dynamic> toJson() => super.toJson()..addAll({
        'wert': wert
    });

    getTypeName() => "PositiverGeldBetragMitCent13EN";
    TypeContext? context = _ctx;
}

/**
* Represents an unsigned amount of money without cents whose value has a maximum length of 13 digits. That is, 1 to 13 digits. Minus sign NOT allowed.
*/
// @Api(Description="Represents an unsigned amount of money without cents whose value has a maximum length of 13 digits. That is, 1 to 13 digits. Minus sign NOT allowed.")
class PositiverGeldBetragOhneCent13EN extends GrossGeldBetragOhneCent implements IConvertible
{
    /**
    * The intrinsic currency value.
    */
    // @ApiMember(Description="The intrinsic currency value.")
    int? wert;

    PositiverGeldBetragOhneCent13EN({this.wert});
    PositiverGeldBetragOhneCent13EN.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        super.fromMap(json);
        wert = json['wert'];
        return this;
    }

    Map<String, dynamic> toJson() => super.toJson()..addAll({
        'wert': wert
    });

    getTypeName() => "PositiverGeldBetragOhneCent13EN";
    TypeContext? context = _ctx;
}

/**
* Umsatzsteuervoranmeldung für 2023 (Preliminary VAT declaration for 2023).
*/
// @Api(Description="Umsatzsteuervoranmeldung für 2023 (Preliminary VAT declaration for 2023).")
class Umsatzsteuervoranmeldung2023 implements IConvertible
{
    /**
    * Das Jahr der Veranlagung.
    */
    // @ApiMember(Description="Das Jahr der Veranlagung.", IsRequired=true, Name="Jahr")
    int? jahr;

    /**
    * Anmeldungszeitraum.
    */
    // @ApiMember(Description="Anmeldungszeitraum.", IsRequired=true, Name="Zeitraum")
    AnmeldungZeitraum? zeitraum;

    /**
    * Steuernummer
    */
    // @ApiMember(Description="Steuernummer", IsRequired=true, Name="Steuernummer")
    String? steuernummer;

    /**
    * Fünfstellige HerstellerID (Pflichtangabe wenn der zugehörige Kontext angegeben wird).
    */
    // @ApiMember(Description="Fünfstellige HerstellerID (Pflichtangabe wenn der zugehörige Kontext angegeben wird).", IsRequired=true, Name="Kz09")
    Kz09? kz09;

    /**
    * Berichtigte Anmeldung
    */
    // @ApiMember(Description="Berichtigte Anmeldung", Name="Kz10")
    Ganzzahl1EN? kz10;

    /**
    * Nicht steuerbare sonstige Leistungen gemäß § 18b Satz 1 Nummer 2 UStG
    */
    // @ApiMember(Description="Nicht steuerbare sonstige Leistungen gemäß § 18b Satz 1 Nummer 2 UStG", Name="Kz21")
    GeldBetragOhneCent13EN? kz21;

    /**
    * Belege
    */
    // @ApiMember(Description="Belege", Name="Kz22")
    Ganzzahl1EN? kz22;

    /**
    * Über die Angaben in der Steueranmeldung hinaus sind weitere oder abweichende Angaben oder Sachverhalte zu berücksichtigen
    */
    // @ApiMember(Description="Über die Angaben in der Steueranmeldung hinaus sind weitere oder abweichende Angaben oder Sachverhalte zu berücksichtigen", Name="Kz23")
    Ganzzahl1EN? kz23;

    /**
    * Ergänzende Angaben zur Steueranmeldung
    */
    // @ApiMember(Description="Ergänzende Angaben zur Steueranmeldung", Name="Kz23_Begruendung")
    String? kz23_Begruendung;

    /**
    * Das SEPA-Lastschriftmandat wird ausnahmsweise (zum Beispiel wegen Verrechnungswünschen) für diesen Voranmeldungszeitraum widerrufen (falls ja, bitte eine 1 eintragen). Ein gegebenenfalls verbleibender Restbetrag ist gesondert zu entrichten.
    */
    // @ApiMember(Description="Das SEPA-Lastschriftmandat wird ausnahmsweise (zum Beispiel wegen Verrechnungswünschen) für diesen Voranmeldungszeitraum widerrufen (falls ja, bitte eine 1 eintragen). Ein gegebenenfalls verbleibender Restbetrag ist gesondert zu entrichten.", Name="Kz26")
    Ganzzahl1EN? kz26;

    /**
    * Verrechnung des Erstattungsbetrags erwünscht / Erstattungsbetrag ist abgetreten (Teilen Sie bitte die Verrechnungswünsche dem Finanzamt gesondert mit).
    */
    // @ApiMember(Description="Verrechnung des Erstattungsbetrags erwünscht / Erstattungsbetrag ist abgetreten (Teilen Sie bitte die Verrechnungswünsche dem Finanzamt gesondert mit).", Name="Kz29")
    Ganzzahl1EN? kz29;

    /**
    * zu anderen Steuersätzen (Bemessungsgrundlage)
    */
    // @ApiMember(Description="zu anderen Steuersätzen (Bemessungsgrundlage)", Name="Kz35")
    GeldBetragOhneCent13EN? kz35;

    /**
    * zu anderen Steuersätzen (Steuer)
    */
    // @ApiMember(Description="zu anderen Steuersätzen (Steuer)", Name="Kz36")
    GeldBetragMitCent11EN? kz36;

    /**
    * Minderung der abziehbaren Vorsteuerbeträge (in der Zeile 37 aus Rechnungen von anderen Unternehmen (§ 15 Absatz 1 Satz 1 Nummer 1 UStG) sowie in den Zeilen 41 und 42 enthalten)
    */
    // @ApiMember(Description="Minderung der abziehbaren Vorsteuerbeträge (in der Zeile 37 aus Rechnungen von anderen Unternehmen (§ 15 Absatz 1 Satz 1 Nummer 1 UStG) sowie in den Zeilen 41 und 42 enthalten)", Name="Kz37")
    PositiverGeldBetragMitCent11EN? kz37;

    /**
    * Abzug der festgesetzten Sondervorauszahlung für Dauerfristverlängerung (in der Regel nur in der letzten Voranmeldung des Besteuerungszeitraums auszufüllen)
    */
    // @ApiMember(Description="Abzug der festgesetzten Sondervorauszahlung für Dauerfristverlängerung (in der Regel nur in der letzten Voranmeldung des Besteuerungszeitraums auszufüllen)", Name="Kz39")
    PositiverGeldBetragMitCent13EN? kz39;

    /**
    * Innergemeinschaftliche Lieferungen (§ 4 Nummer 1 Buchstabe b UStG) an Abnehmer mit Umsatzsteuer-Identifikationsnummer
    */
    // @ApiMember(Description="Innergemeinschaftliche Lieferungen (§ 4 Nummer 1 Buchstabe b UStG) an Abnehmer mit Umsatzsteuer-Identifikationsnummer", Name="Kz41")
    GeldBetragOhneCent13EN? kz41;

    /**
    * Lieferungen des ersten Abnehmers bei innergemeinschaftlichen Dreiecksgeschäften (§ 25b UStG)
    */
    // @ApiMember(Description="Lieferungen des ersten Abnehmers bei innergemeinschaftlichen Dreiecksgeschäften (§ 25b UStG)", Name="Kz42")
    GeldBetragOhneCent13EN? kz42;

    /**
    * Weitere steuerfreie Umsätze mit Vorsteuerabzug (zum Beispiel Ausfuhrlieferungen, Umsätze nach § 4 Nummer 2 bis 7 UStG)
    */
    // @ApiMember(Description="Weitere steuerfreie Umsätze mit Vorsteuerabzug (zum Beispiel Ausfuhrlieferungen, Umsätze nach § 4 Nummer 2 bis 7 UStG)", Name="Kz43")
    GeldBetragOhneCent13EN? kz43;

    /**
    * Innergemeinschaftliche Lieferungen (§ 4 Nummer 1 Buchstabe b UStG) neuer Fahrzeuge an Abnehmer ohne Umsatzsteuer-Identifikationsnummer
    */
    // @ApiMember(Description="Innergemeinschaftliche Lieferungen (§ 4 Nummer 1 Buchstabe b UStG) neuer Fahrzeuge an Abnehmer ohne Umsatzsteuer-Identifikationsnummer", Name="Kz44")
    GeldBetragOhneCent13EN? kz44;

    /**
    * Übrige nicht steuerbare Umsätze (Leistungsort nicht im Inland)
    */
    // @ApiMember(Description="Übrige nicht steuerbare Umsätze (Leistungsort nicht im Inland)", Name="Kz45")
    GeldBetragOhneCent13EN? kz45;

    /**
    * Sonstige Leistungen nach § 3a Absatz 2 UStG eines im übrigen Gemeinschaftsgebiet ansässigen Unternehmers (§ 13b Absatz 1 UStG) (Bemessungsgrundlage)
    */
    // @ApiMember(Description="Sonstige Leistungen nach § 3a Absatz 2 UStG eines im übrigen Gemeinschaftsgebiet ansässigen Unternehmers (§ 13b Absatz 1 UStG) (Bemessungsgrundlage)", Name="Kz46")
    GeldBetragOhneCent13EN? kz46;

    /**
    * Sonstige Leistungen nach § 3a Absatz 2 UStG eines im übrigen Gemeinschaftsgebiet ansässigen Unternehmers (§ 13b Absatz 1 UStG) (Steuer)
    */
    // @ApiMember(Description="Sonstige Leistungen nach § 3a Absatz 2 UStG eines im übrigen Gemeinschaftsgebiet ansässigen Unternehmers (§ 13b Absatz 1 UStG) (Steuer)", Name="Kz47")
    GeldBetragMitCent11EN? kz47;

    /**
    * Steuerfreie Umsätze ohne Vorsteuerabzug (zum Beispiel Umsätze nach § 4 Nummer 8 bis 29 UStG)
    */
    // @ApiMember(Description="Steuerfreie Umsätze ohne Vorsteuerabzug (zum Beispiel Umsätze nach § 4 Nummer 8 bis 29 UStG)", Name="Kz48")
    GeldBetragOhneCent13EN? kz48;

    /**
    * Innergemeinschaftliche Lieferungen (§ 4 Nummer 1 Buchstabe b UStG) neuer Fahrzeuge außerhalb eines Unternehmens (§ 2a UStG)
    */
    // @ApiMember(Description="Innergemeinschaftliche Lieferungen (§ 4 Nummer 1 Buchstabe b UStG) neuer Fahrzeuge außerhalb eines Unternehmens (§ 2a UStG)", Name="Kz49")
    GeldBetragOhneCent13EN? kz49;

    /**
    * Minderung der Bemessungsgrundlage (in den Zeilen 12 bis 17 enthalten)
    */
    // @ApiMember(Description="Minderung der Bemessungsgrundlage (in den Zeilen 12 bis 17 enthalten)", Name="Kz50")
    PositiverGeldBetragOhneCent13EN? kz50;

    /**
    * 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="Kz59")
    GeldBetragMitCent11EN? kz59;

    /**
    * Steuerpflichtige Umsätze des leistenden Unternehmers, für die der Leistungsempfänger die Steuer nach § 13b Absatz 5 UStG schuldet
    */
    // @ApiMember(Description="Steuerpflichtige Umsätze des leistenden Unternehmers, für die der Leistungsempfänger die Steuer nach § 13b Absatz 5 UStG schuldet", Name="Kz60")
    GeldBetragOhneCent13EN? kz60;

    /**
    * Vorsteuerbeträge aus dem innergemeinschaftlichen Erwerb von Gegenständen (§ 15 Absatz 1 Satz 1 Nummer 3 UStG)
    */
    // @ApiMember(Description="Vorsteuerbeträge aus dem innergemeinschaftlichen Erwerb von Gegenständen (§ 15 Absatz 1 Satz 1 Nummer 3 UStG)", Name="Kz61")
    GeldBetragMitCent11EN? kz61;

    /**
    * Entstandene Einfuhrumsatzsteuer (§ 15 Absatz 1 Satz 1 Nummer 2 UStG))
    */
    // @ApiMember(Description="Entstandene Einfuhrumsatzsteuer (§ 15 Absatz 1 Satz 1 Nummer 2 UStG))", Name="Kz62")
    GeldBetragMitCent11EN? kz62;

    /**
    * Vorsteuerbeträge, die nach allgemeinen Durchschnittssätzen berechnet sind (§ 23a UStG)
    */
    // @ApiMember(Description="Vorsteuerbeträge, die nach allgemeinen Durchschnittssätzen berechnet sind (§ 23a UStG)", Name="Kz63")
    GeldBetragMitCent11EN? kz63;

    /**
    * Berichtigung des Vorsteuerabzugs (§ 15a UStG)
    */
    // @ApiMember(Description="Berichtigung des Vorsteuerabzugs (§ 15a UStG)", Name="Kz64")
    GeldBetragMitCent11EN? kz64;

    /**
    * Steuer infolge des Wechsels der Besteuerungsform sowie Nachsteuer auf versteuerte Anzahlungen und ähnlichem wegen Steuersatzänderung
    */
    // @ApiMember(Description="Steuer infolge des Wechsels der Besteuerungsform sowie Nachsteuer auf versteuerte Anzahlungen und ähnlichem wegen Steuersatzänderung", Name="Kz65")
    GeldBetragMitCent11EN? kz65;

    /**
    * Vorsteuerbeträge aus Rechnungen von anderen Unternehmern (§ 15 Absatz 1 Satz 1 Nummer 1 UStG),  aus Leistungen im Sinne des § 13a Absatz 1 Nummer 6 UStG (§ 15 Absatz 1 Satz 1 Nummer 5 UStG) und aus innergemeinschaftlichen Dreiecksgeschäften (§ 25b Absatz 5 UStG)
    */
    // @ApiMember(Description="Vorsteuerbeträge aus Rechnungen von anderen Unternehmern (§ 15 Absatz 1 Satz 1 Nummer 1 UStG),  aus Leistungen im Sinne des § 13a Absatz 1 Nummer 6 UStG (§ 15 Absatz 1 Satz 1 Nummer 5 UStG) und aus innergemeinschaftlichen Dreiecksgeschäften (§ 25b Absatz 5 UStG)", Name="Kz66")
    GeldBetragMitCent11EN? kz66;

    /**
    * 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="Kz67")
    GeldBetragMitCent11EN? kz67;

    /**
    * In Rechnungen unrichtig oder unberechtigt ausgewiesene Steuerbeträge (§ 14c UStG) sowie Steuerbeträge, die nach § 6a Absatz 4 Satz 2, § 17 Absatz 1 Satz 7, § 25b Absatz 2 UStG oder von einem Auslagerer oder Lagerhalter nach § 13a Absatz 1 Nummer 6 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, § 17 Absatz 1 Satz 7, § 25b Absatz 2 UStG oder von einem Auslagerer oder Lagerhalter nach § 13a Absatz 1 Nummer 6 UStG geschuldet werden", Name="Kz69")
    GeldBetragMitCent11EN? kz69;

    /**
    * Umsätze, die unter das GrEStG fallen (§ 13b Absatz 2 Nummer 3 UStG) (Bemessungsgrundlage)
    */
    // @ApiMember(Description="Umsätze, die unter das GrEStG fallen (§ 13b Absatz 2 Nummer 3 UStG) (Bemessungsgrundlage)", Name="Kz73")
    GeldBetragOhneCent13EN? kz73;

    /**
    * 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="Kz74")
    GeldBetragMitCent11EN? kz74;

    /**
    * Umsätze, für die eine Steuer nach § 24 UStG zu entrichten ist (Sägewerkserzeugnisse, Getränke und alkoholische Flüssigkeiten, zum Beispiel Wein) (Bemessungsgrundlage)
    */
    // @ApiMember(Description="Umsätze, für die eine Steuer nach § 24 UStG zu entrichten ist (Sägewerkserzeugnisse, Getränke und alkoholische Flüssigkeiten, zum Beispiel Wein) (Bemessungsgrundlage)", Name="Kz76")
    GeldBetragOhneCent13EN? kz76;

    /**
    * Lieferungen land- und forstwirtschaftlicher Betriebe nach § 24 UStG an Abnehmer mit Umsatzsteuer-Identifikationsnummer
    */
    // @ApiMember(Description="Lieferungen land- und forstwirtschaftlicher Betriebe nach § 24 UStG an Abnehmer mit Umsatzsteuer-Identifikationsnummer", Name="Kz77")
    GeldBetragOhneCent13EN? kz77;

    /**
    * Umsätze, für die eine Steuer nach § 24 UStG zu entrichten ist (Sägewerkserzeugnisse, Getränke und alkoholische Flüssigkeiten, zum Beispiel Wein) (Steuer)
    */
    // @ApiMember(Description="Umsätze, für die eine Steuer nach § 24 UStG zu entrichten ist (Sägewerkserzeugnisse, Getränke und alkoholische Flüssigkeiten, zum Beispiel Wein) (Steuer)", Name="Kz80")
    GeldBetragMitCent11EN? kz80;

    /**
    * zum Steuersatz von 19 Prozent
    */
    // @ApiMember(Description="zum Steuersatz von 19 Prozent", Name="Kz81")
    GeldBetragOhneCent13EN? kz81;

    /**
    * Verbleibende Umsatzsteuer-Vorauszahlung beziehungsweise verbleibender Überschuss
    */
    // @ApiMember(Description="Verbleibende Umsatzsteuer-Vorauszahlung beziehungsweise verbleibender Überschuss", IsRequired=true, Name="Kz83")
    GeldBetragMitCent11EN? kz83;

    /**
    * Andere Leistungen (§ 13b Absatz 2 Nummer 1, 2, 4 bis 12 UStG) (Bemessungsgrundlage)
    */
    // @ApiMember(Description="Andere Leistungen (§ 13b Absatz 2 Nummer 1, 2, 4 bis 12 UStG) (Bemessungsgrundlage)", Name="Kz84")
    GeldBetragOhneCent13EN? kz84;

    /**
    * Andere Leistungen (§ 13b Absatz 2 Nummer 1, 2, 4 bis 12 UStG) (Steuer)
    */
    // @ApiMember(Description="Andere Leistungen (§ 13b Absatz 2 Nummer 1, 2, 4 bis 12 UStG) (Steuer)", Name="Kz85")
    GeldBetragMitCent11EN? kz85;

    /**
    * zum Steuersatz von 7 Prozent
    */
    // @ApiMember(Description="zum Steuersatz von 7 Prozent", Name="Kz86")
    GeldBetragOhneCent13EN? kz86;

    /**
    * zum Steuersatz von 0 Prozent
    */
    // @ApiMember(Description="zum Steuersatz von 0 Prozent", Name="Kz87")
    GeldBetragOhneCent13EN? kz87;

    /**
    * zum Steuersatz von 19 Prozent
    */
    // @ApiMember(Description="zum Steuersatz von 19 Prozent", Name="Kz89")
    GeldBetragOhneCent13EN? kz89;

    /**
    * zum Steuersatz von 0 Prozent
    */
    // @ApiMember(Description="zum Steuersatz von 0 Prozent", Name="Kz90")
    GeldBetragOhneCent13EN? kz90;

    /**
    * Steuerfreie innergemeinschaftliche Erwerbe von bestimmten Gegenständen und Anlagegold (§§ 4b und 25c UStG)
    */
    // @ApiMember(Description="Steuerfreie innergemeinschaftliche Erwerbe von bestimmten Gegenständen und Anlagegold (§§ 4b und 25c UStG)", Name="Kz91")
    GeldBetragOhneCent13EN? kz91;

    /**
    * zum Steuersatz von 7 Prozent
    */
    // @ApiMember(Description="zum Steuersatz von 7 Prozent", Name="Kz93")
    GeldBetragOhneCent13EN? kz93;

    /**
    * Erwerbe nach §§ 4b und 25c UStG
    */
    // @ApiMember(Description="Erwerbe nach §§ 4b und 25c UStG", Name="Kz94")
    GeldBetragOhneCent13EN? kz94;

    /**
    * zu anderen Steuersätzen (Bemessungsgrundlage)
    */
    // @ApiMember(Description="zu anderen Steuersätzen (Bemessungsgrundlage)", Name="Kz95")
    GeldBetragOhneCent13EN? kz95;

    /**
    * neuer Fahrzeuge (§ 1b Absatz 2 und 3 UStG) von Lieferern ohne Umsatzsteuer-Identifikationsnummer zum allgemeinen Steuersatz (Steuer)
    */
    // @ApiMember(Description="neuer Fahrzeuge (§ 1b Absatz 2 und 3 UStG) von Lieferern ohne Umsatzsteuer-Identifikationsnummer zum allgemeinen Steuersatz (Steuer)", Name="Kz96")
    GeldBetragMitCent11EN? kz96;

    /**
    * zu anderen Steuersätzen (Steuer)
    */
    // @ApiMember(Description="zu anderen Steuersätzen (Steuer)", Name="Kz98")
    GeldBetragMitCent11EN? kz98;

    Umsatzsteuervoranmeldung2023({this.jahr,this.zeitraum,this.steuernummer,this.kz09,this.kz10,this.kz21,this.kz22,this.kz23,this.kz23_Begruendung,this.kz26,this.kz29,this.kz35,this.kz36,this.kz37,this.kz39,this.kz41,this.kz42,this.kz43,this.kz44,this.kz45,this.kz46,this.kz47,this.kz48,this.kz49,this.kz50,this.kz59,this.kz60,this.kz61,this.kz62,this.kz63,this.kz64,this.kz65,this.kz66,this.kz67,this.kz69,this.kz73,this.kz74,this.kz76,this.kz77,this.kz80,this.kz81,this.kz83,this.kz84,this.kz85,this.kz86,this.kz87,this.kz89,this.kz90,this.kz91,this.kz93,this.kz94,this.kz95,this.kz96,this.kz98});
    Umsatzsteuervoranmeldung2023.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        jahr = json['jahr'];
        zeitraum = JsonConverters.fromJson(json['zeitraum'],'AnmeldungZeitraum',context!);
        steuernummer = json['steuernummer'];
        kz09 = JsonConverters.fromJson(json['kz09'],'Kz09',context!);
        kz10 = JsonConverters.fromJson(json['kz10'],'Ganzzahl1EN',context!);
        kz21 = JsonConverters.fromJson(json['kz21'],'GeldBetragOhneCent13EN',context!);
        kz22 = JsonConverters.fromJson(json['kz22'],'Ganzzahl1EN',context!);
        kz23 = JsonConverters.fromJson(json['kz23'],'Ganzzahl1EN',context!);
        kz23_Begruendung = json['kz23_Begruendung'];
        kz26 = JsonConverters.fromJson(json['kz26'],'Ganzzahl1EN',context!);
        kz29 = JsonConverters.fromJson(json['kz29'],'Ganzzahl1EN',context!);
        kz35 = JsonConverters.fromJson(json['kz35'],'GeldBetragOhneCent13EN',context!);
        kz36 = JsonConverters.fromJson(json['kz36'],'GeldBetragMitCent11EN',context!);
        kz37 = JsonConverters.fromJson(json['kz37'],'PositiverGeldBetragMitCent11EN',context!);
        kz39 = JsonConverters.fromJson(json['kz39'],'PositiverGeldBetragMitCent13EN',context!);
        kz41 = JsonConverters.fromJson(json['kz41'],'GeldBetragOhneCent13EN',context!);
        kz42 = JsonConverters.fromJson(json['kz42'],'GeldBetragOhneCent13EN',context!);
        kz43 = JsonConverters.fromJson(json['kz43'],'GeldBetragOhneCent13EN',context!);
        kz44 = JsonConverters.fromJson(json['kz44'],'GeldBetragOhneCent13EN',context!);
        kz45 = JsonConverters.fromJson(json['kz45'],'GeldBetragOhneCent13EN',context!);
        kz46 = JsonConverters.fromJson(json['kz46'],'GeldBetragOhneCent13EN',context!);
        kz47 = JsonConverters.fromJson(json['kz47'],'GeldBetragMitCent11EN',context!);
        kz48 = JsonConverters.fromJson(json['kz48'],'GeldBetragOhneCent13EN',context!);
        kz49 = JsonConverters.fromJson(json['kz49'],'GeldBetragOhneCent13EN',context!);
        kz50 = JsonConverters.fromJson(json['kz50'],'PositiverGeldBetragOhneCent13EN',context!);
        kz59 = JsonConverters.fromJson(json['kz59'],'GeldBetragMitCent11EN',context!);
        kz60 = JsonConverters.fromJson(json['kz60'],'GeldBetragOhneCent13EN',context!);
        kz61 = JsonConverters.fromJson(json['kz61'],'GeldBetragMitCent11EN',context!);
        kz62 = JsonConverters.fromJson(json['kz62'],'GeldBetragMitCent11EN',context!);
        kz63 = JsonConverters.fromJson(json['kz63'],'GeldBetragMitCent11EN',context!);
        kz64 = JsonConverters.fromJson(json['kz64'],'GeldBetragMitCent11EN',context!);
        kz65 = JsonConverters.fromJson(json['kz65'],'GeldBetragMitCent11EN',context!);
        kz66 = JsonConverters.fromJson(json['kz66'],'GeldBetragMitCent11EN',context!);
        kz67 = JsonConverters.fromJson(json['kz67'],'GeldBetragMitCent11EN',context!);
        kz69 = JsonConverters.fromJson(json['kz69'],'GeldBetragMitCent11EN',context!);
        kz73 = JsonConverters.fromJson(json['kz73'],'GeldBetragOhneCent13EN',context!);
        kz74 = JsonConverters.fromJson(json['kz74'],'GeldBetragMitCent11EN',context!);
        kz76 = JsonConverters.fromJson(json['kz76'],'GeldBetragOhneCent13EN',context!);
        kz77 = JsonConverters.fromJson(json['kz77'],'GeldBetragOhneCent13EN',context!);
        kz80 = JsonConverters.fromJson(json['kz80'],'GeldBetragMitCent11EN',context!);
        kz81 = JsonConverters.fromJson(json['kz81'],'GeldBetragOhneCent13EN',context!);
        kz83 = JsonConverters.fromJson(json['kz83'],'GeldBetragMitCent11EN',context!);
        kz84 = JsonConverters.fromJson(json['kz84'],'GeldBetragOhneCent13EN',context!);
        kz85 = JsonConverters.fromJson(json['kz85'],'GeldBetragMitCent11EN',context!);
        kz86 = JsonConverters.fromJson(json['kz86'],'GeldBetragOhneCent13EN',context!);
        kz87 = JsonConverters.fromJson(json['kz87'],'GeldBetragOhneCent13EN',context!);
        kz89 = JsonConverters.fromJson(json['kz89'],'GeldBetragOhneCent13EN',context!);
        kz90 = JsonConverters.fromJson(json['kz90'],'GeldBetragOhneCent13EN',context!);
        kz91 = JsonConverters.fromJson(json['kz91'],'GeldBetragOhneCent13EN',context!);
        kz93 = JsonConverters.fromJson(json['kz93'],'GeldBetragOhneCent13EN',context!);
        kz94 = JsonConverters.fromJson(json['kz94'],'GeldBetragOhneCent13EN',context!);
        kz95 = JsonConverters.fromJson(json['kz95'],'GeldBetragOhneCent13EN',context!);
        kz96 = JsonConverters.fromJson(json['kz96'],'GeldBetragMitCent11EN',context!);
        kz98 = JsonConverters.fromJson(json['kz98'],'GeldBetragMitCent11EN',context!);
        return this;
    }

    Map<String, dynamic> toJson() => {
        'jahr': jahr,
        'zeitraum': JsonConverters.toJson(zeitraum,'AnmeldungZeitraum',context!),
        'steuernummer': steuernummer,
        'kz09': JsonConverters.toJson(kz09,'Kz09',context!),
        'kz10': JsonConverters.toJson(kz10,'Ganzzahl1EN',context!),
        'kz21': JsonConverters.toJson(kz21,'GeldBetragOhneCent13EN',context!),
        'kz22': JsonConverters.toJson(kz22,'Ganzzahl1EN',context!),
        'kz23': JsonConverters.toJson(kz23,'Ganzzahl1EN',context!),
        'kz23_Begruendung': kz23_Begruendung,
        'kz26': JsonConverters.toJson(kz26,'Ganzzahl1EN',context!),
        'kz29': JsonConverters.toJson(kz29,'Ganzzahl1EN',context!),
        'kz35': JsonConverters.toJson(kz35,'GeldBetragOhneCent13EN',context!),
        'kz36': JsonConverters.toJson(kz36,'GeldBetragMitCent11EN',context!),
        'kz37': JsonConverters.toJson(kz37,'PositiverGeldBetragMitCent11EN',context!),
        'kz39': JsonConverters.toJson(kz39,'PositiverGeldBetragMitCent13EN',context!),
        'kz41': JsonConverters.toJson(kz41,'GeldBetragOhneCent13EN',context!),
        'kz42': JsonConverters.toJson(kz42,'GeldBetragOhneCent13EN',context!),
        'kz43': JsonConverters.toJson(kz43,'GeldBetragOhneCent13EN',context!),
        'kz44': JsonConverters.toJson(kz44,'GeldBetragOhneCent13EN',context!),
        'kz45': JsonConverters.toJson(kz45,'GeldBetragOhneCent13EN',context!),
        'kz46': JsonConverters.toJson(kz46,'GeldBetragOhneCent13EN',context!),
        'kz47': JsonConverters.toJson(kz47,'GeldBetragMitCent11EN',context!),
        'kz48': JsonConverters.toJson(kz48,'GeldBetragOhneCent13EN',context!),
        'kz49': JsonConverters.toJson(kz49,'GeldBetragOhneCent13EN',context!),
        'kz50': JsonConverters.toJson(kz50,'PositiverGeldBetragOhneCent13EN',context!),
        'kz59': JsonConverters.toJson(kz59,'GeldBetragMitCent11EN',context!),
        'kz60': JsonConverters.toJson(kz60,'GeldBetragOhneCent13EN',context!),
        'kz61': JsonConverters.toJson(kz61,'GeldBetragMitCent11EN',context!),
        'kz62': JsonConverters.toJson(kz62,'GeldBetragMitCent11EN',context!),
        'kz63': JsonConverters.toJson(kz63,'GeldBetragMitCent11EN',context!),
        'kz64': JsonConverters.toJson(kz64,'GeldBetragMitCent11EN',context!),
        'kz65': JsonConverters.toJson(kz65,'GeldBetragMitCent11EN',context!),
        'kz66': JsonConverters.toJson(kz66,'GeldBetragMitCent11EN',context!),
        'kz67': JsonConverters.toJson(kz67,'GeldBetragMitCent11EN',context!),
        'kz69': JsonConverters.toJson(kz69,'GeldBetragMitCent11EN',context!),
        'kz73': JsonConverters.toJson(kz73,'GeldBetragOhneCent13EN',context!),
        'kz74': JsonConverters.toJson(kz74,'GeldBetragMitCent11EN',context!),
        'kz76': JsonConverters.toJson(kz76,'GeldBetragOhneCent13EN',context!),
        'kz77': JsonConverters.toJson(kz77,'GeldBetragOhneCent13EN',context!),
        'kz80': JsonConverters.toJson(kz80,'GeldBetragMitCent11EN',context!),
        'kz81': JsonConverters.toJson(kz81,'GeldBetragOhneCent13EN',context!),
        'kz83': JsonConverters.toJson(kz83,'GeldBetragMitCent11EN',context!),
        'kz84': JsonConverters.toJson(kz84,'GeldBetragOhneCent13EN',context!),
        'kz85': JsonConverters.toJson(kz85,'GeldBetragMitCent11EN',context!),
        'kz86': JsonConverters.toJson(kz86,'GeldBetragOhneCent13EN',context!),
        'kz87': JsonConverters.toJson(kz87,'GeldBetragOhneCent13EN',context!),
        'kz89': JsonConverters.toJson(kz89,'GeldBetragOhneCent13EN',context!),
        'kz90': JsonConverters.toJson(kz90,'GeldBetragOhneCent13EN',context!),
        'kz91': JsonConverters.toJson(kz91,'GeldBetragOhneCent13EN',context!),
        'kz93': JsonConverters.toJson(kz93,'GeldBetragOhneCent13EN',context!),
        'kz94': JsonConverters.toJson(kz94,'GeldBetragOhneCent13EN',context!),
        'kz95': JsonConverters.toJson(kz95,'GeldBetragOhneCent13EN',context!),
        'kz96': JsonConverters.toJson(kz96,'GeldBetragMitCent11EN',context!),
        'kz98': JsonConverters.toJson(kz98,'GeldBetragMitCent11EN',context!)
    };

    getTypeName() => "Umsatzsteuervoranmeldung2023";
    TypeContext? context = _ctx;
}

/**
* Create XML content that represents the preliminary VAT return (Umsatzsteuervoranmeldung) for 2023.
*/
// @Api(Description="Create XML content that represents the preliminary VAT return (Umsatzsteuervoranmeldung) for 2023.")
abstract class CreateUmsatzsteuervoranmeldung2023XmlBase extends CreateUmsatzsteueranmeldung2023XmlBase
{
    /**
    * Die Umsatzsteuervoranmeldung (The preliminary VAT return).
    */
    // @ApiMember(Description="Die Umsatzsteuervoranmeldung (The preliminary VAT return).", IsRequired=true, Name="Umsatzsteuervoranmeldung")
    Umsatzsteuervoranmeldung2023? umsatzsteuervoranmeldung;

    /**
    * Natürliche Person, welche die Software bedient, bzw. in deren Namen die Software bedient wird, um die Daten zu übersenden (Natural person who operates the software or under whose name the software is operated in order to transmit the data).
    */
    // @ApiMember(Description="Natürliche Person, welche die Software bedient, bzw. in deren Namen die Software bedient wird, um die Daten zu übersenden (Natural person who operates the software or under whose name the software is operated in order to transmit the data).", IsRequired=true, Name="DatenLieferant")
    DatenLieferant? datenLieferant;

    /**
    * Das Datum der Erstellung (Date of creation).
    */
    // @ApiMember(Description="Das Datum der Erstellung (Date of creation).", IsRequired=true, Name="Erstellungsdatum")
    DateTime? erstellungsdatum;

    /**
    * Der Steuerberater, der den Steuerfall bearbeitet und abgibt (The tax adviser who processes and submits the tax case).
    */
    // @ApiMember(Description="Der Steuerberater, der den Steuerfall bearbeitet und abgibt (The tax adviser who processes and submits the tax case).", Name="Berater")
    Berater? berater;

    /**
    * Der Mandant, für den der Steuerfall bearbeitet wird (The client for which the tax case is being processed).
    */
    // @ApiMember(Description="Der Mandant, für den der Steuerfall bearbeitet wird (The client for which the tax case is being processed).", Name="Mandant")
    Mandant? mandant;

    /**
    * Der natürliche oder jüritische Person, der den Steuerfall bearbeitet und abgibt (The natural or legal person who processes and submits the tax case).
    */
    // @ApiMember(Description="Der natürliche oder jüritische Person, der den Steuerfall bearbeitet und abgibt (The natural or legal person who processes and submits the tax case).", Name="Unternehmer")
    Unternehmer? unternehmer;

    /**
    * Die vierstellige Bundesfinanzamtsnummer des empfangenden Finanzamtes (The four-digit federal tax office number of the receiving tax office).
    */
    // @ApiMember(Description="Die vierstellige Bundesfinanzamtsnummer des empfangenden Finanzamtes (The four-digit federal tax office number of the receiving tax office).", IsRequired=true, Name="Bundesfinanzamtsnummer")
    String? bundesfinanzamtsnummer;

    /**
    * Die Anbindung zum ELSTER Online Portal (EOP).
    */
    // @ApiMember(Description="Die Anbindung zum ELSTER Online Portal (EOP).", Name="EOP")
    EOP? eop;

    CreateUmsatzsteuervoranmeldung2023XmlBase({this.umsatzsteuervoranmeldung,this.datenLieferant,this.erstellungsdatum,this.berater,this.mandant,this.unternehmer,this.bundesfinanzamtsnummer,this.eop});
    CreateUmsatzsteuervoranmeldung2023XmlBase.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        super.fromMap(json);
        umsatzsteuervoranmeldung = JsonConverters.fromJson(json['umsatzsteuervoranmeldung'],'Umsatzsteuervoranmeldung2023',context!);
        datenLieferant = JsonConverters.fromJson(json['datenLieferant'],'DatenLieferant',context!);
        erstellungsdatum = JsonConverters.fromJson(json['erstellungsdatum'],'DateTime',context!);
        berater = JsonConverters.fromJson(json['berater'],'Berater',context!);
        mandant = JsonConverters.fromJson(json['mandant'],'Mandant',context!);
        unternehmer = JsonConverters.fromJson(json['unternehmer'],'Unternehmer',context!);
        bundesfinanzamtsnummer = json['bundesfinanzamtsnummer'];
        eop = JsonConverters.fromJson(json['eop'],'EOP',context!);
        return this;
    }

    Map<String, dynamic> toJson() => super.toJson()..addAll({
        'umsatzsteuervoranmeldung': JsonConverters.toJson(umsatzsteuervoranmeldung,'Umsatzsteuervoranmeldung2023',context!),
        'datenLieferant': JsonConverters.toJson(datenLieferant,'DatenLieferant',context!),
        'erstellungsdatum': JsonConverters.toJson(erstellungsdatum,'DateTime',context!),
        'berater': JsonConverters.toJson(berater,'Berater',context!),
        'mandant': JsonConverters.toJson(mandant,'Mandant',context!),
        'unternehmer': JsonConverters.toJson(unternehmer,'Unternehmer',context!),
        'bundesfinanzamtsnummer': bundesfinanzamtsnummer,
        'eop': JsonConverters.toJson(eop,'EOP',context!)
    });

    getTypeName() => "CreateUmsatzsteuervoranmeldung2023XmlBase";
    TypeContext? context = _ctx;
}

/**
* Represents the response from a service that generates XML content.
*/
// @Api(Description="Represents the response from a service that generates XML content.")
class XmlResponse implements IConvertible
{
    /**
    * The XML-based content of the response.
    */
    // @ApiMember(Description="The XML-based content of the response.")
    String? content;

    /**
    * Metadata that contains structured error information on the XML response.
    */
    // @ApiMember(Description="Metadata that contains structured error information on the XML response.")
    ResponseStatus? responseStatus;

    XmlResponse({this.content,this.responseStatus});
    XmlResponse.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        content = json['content'];
        responseStatus = JsonConverters.fromJson(json['responseStatus'],'ResponseStatus',context!);
        return this;
    }

    Map<String, dynamic> toJson() => {
        'content': content,
        'responseStatus': JsonConverters.toJson(responseStatus,'ResponseStatus',context!)
    };

    getTypeName() => "XmlResponse";
    TypeContext? context = _ctx;
}

/**
* An asynchronous service to create xml content that represents the preliminary VAT return (Umsatzsteuervoranmeldung) for 2023.
*/
// @Api(Description="An asynchronous service to create xml content that represents the preliminary VAT return (Umsatzsteuervoranmeldung) for 2023.")
class CreateUmsatzsteuervoranmeldung2023XmlAsync extends CreateUmsatzsteuervoranmeldung2023XmlBase implements IConvertible
{
    /**
    * Die Umsatzsteuervoranmeldung (The preliminary VAT return).
    */
    // @ApiMember(Description="Die Umsatzsteuervoranmeldung (The preliminary VAT return).", IsRequired=true, Name="Umsatzsteuervoranmeldung")
    Umsatzsteuervoranmeldung2023? umsatzsteuervoranmeldung;

    /**
    * Natürliche Person, welche die Software bedient, bzw. in deren Namen die Software bedient wird, um die Daten zu übersenden (Natural person who operates the software or under whose name the software is operated in order to transmit the data).
    */
    // @ApiMember(Description="Natürliche Person, welche die Software bedient, bzw. in deren Namen die Software bedient wird, um die Daten zu übersenden (Natural person who operates the software or under whose name the software is operated in order to transmit the data).", IsRequired=true, Name="DatenLieferant")
    DatenLieferant? datenLieferant;

    /**
    * Das Datum der Erstellung (Date of creation).
    */
    // @ApiMember(Description="Das Datum der Erstellung (Date of creation).", IsRequired=true, Name="Erstellungsdatum")
    DateTime? erstellungsdatum;

    /**
    * Der Steuerberater, der den Steuerfall bearbeitet und abgibt (The tax adviser who processes and submits the tax case).
    */
    // @ApiMember(Description="Der Steuerberater, der den Steuerfall bearbeitet und abgibt (The tax adviser who processes and submits the tax case).", Name="Berater")
    Berater? berater;

    /**
    * Der Mandant, für den der Steuerfall bearbeitet wird (The client for which the tax case is being processed).
    */
    // @ApiMember(Description="Der Mandant, für den der Steuerfall bearbeitet wird (The client for which the tax case is being processed).", Name="Mandant")
    Mandant? mandant;

    /**
    * Der natürliche oder jüritische Person, der den Steuerfall bearbeitet und abgibt (The natural or legal person who processes and submits the tax case).
    */
    // @ApiMember(Description="Der natürliche oder jüritische Person, der den Steuerfall bearbeitet und abgibt (The natural or legal person who processes and submits the tax case).", Name="Unternehmer")
    Unternehmer? unternehmer;

    /**
    * Die vierstellige Bundesfinanzamtsnummer des empfangenden Finanzamtes (The four-digit federal tax office number of the receiving tax office).
    */
    // @ApiMember(Description="Die vierstellige Bundesfinanzamtsnummer des empfangenden Finanzamtes (The four-digit federal tax office number of the receiving tax office).", IsRequired=true, Name="Bundesfinanzamtsnummer")
    String? bundesfinanzamtsnummer;

    /**
    * Die Anbindung zum ELSTER Online Portal (EOP).
    */
    // @ApiMember(Description="Die Anbindung zum ELSTER Online Portal (EOP).", Name="EOP")
    EOP? eop;

    CreateUmsatzsteuervoranmeldung2023XmlAsync({this.umsatzsteuervoranmeldung,this.datenLieferant,this.erstellungsdatum,this.berater,this.mandant,this.unternehmer,this.bundesfinanzamtsnummer,this.eop});
    CreateUmsatzsteuervoranmeldung2023XmlAsync.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        super.fromMap(json);
        umsatzsteuervoranmeldung = JsonConverters.fromJson(json['umsatzsteuervoranmeldung'],'Umsatzsteuervoranmeldung2023',context!);
        datenLieferant = JsonConverters.fromJson(json['datenLieferant'],'DatenLieferant',context!);
        erstellungsdatum = JsonConverters.fromJson(json['erstellungsdatum'],'DateTime',context!);
        berater = JsonConverters.fromJson(json['berater'],'Berater',context!);
        mandant = JsonConverters.fromJson(json['mandant'],'Mandant',context!);
        unternehmer = JsonConverters.fromJson(json['unternehmer'],'Unternehmer',context!);
        bundesfinanzamtsnummer = json['bundesfinanzamtsnummer'];
        eop = JsonConverters.fromJson(json['eop'],'EOP',context!);
        return this;
    }

    Map<String, dynamic> toJson() => super.toJson()..addAll({
        'umsatzsteuervoranmeldung': JsonConverters.toJson(umsatzsteuervoranmeldung,'Umsatzsteuervoranmeldung2023',context!),
        'datenLieferant': JsonConverters.toJson(datenLieferant,'DatenLieferant',context!),
        'erstellungsdatum': JsonConverters.toJson(erstellungsdatum,'DateTime',context!),
        'berater': JsonConverters.toJson(berater,'Berater',context!),
        'mandant': JsonConverters.toJson(mandant,'Mandant',context!),
        'unternehmer': JsonConverters.toJson(unternehmer,'Unternehmer',context!),
        'bundesfinanzamtsnummer': bundesfinanzamtsnummer,
        'eop': JsonConverters.toJson(eop,'EOP',context!)
    });

    getTypeName() => "CreateUmsatzsteuervoranmeldung2023XmlAsync";
    TypeContext? context = _ctx;
}

TypeContext _ctx = TypeContext(library: 'taxfiling.pwc.de', types: <String, TypeInfo> {
    'DatenLieferant': TypeInfo(TypeOf.Class, create:() => DatenLieferant()),
    'Berater': TypeInfo(TypeOf.Class, create:() => Berater()),
    'Mandant': TypeInfo(TypeOf.Class, create:() => Mandant()),
    'Unternehmer': TypeInfo(TypeOf.Class, create:() => Unternehmer()),
    'EOP': TypeInfo(TypeOf.Class, create:() => EOP()),
    'CreateUmsatzsteueranmeldung2023XmlBase': TypeInfo(TypeOf.AbstractClass),
    'AnmeldungZeitraum': TypeInfo(TypeOf.Enum, enumValues:AnmeldungZeitraum.values),
    'Kz09': TypeInfo(TypeOf.Class, create:() => Kz09()),
    'Ganzzahl': TypeInfo(TypeOf.AbstractClass),
    'Ganzzahl1EN': TypeInfo(TypeOf.Class, create:() => Ganzzahl1EN()),
    'GrossGeldBetragOhneCent': TypeInfo(TypeOf.AbstractClass),
    'GeldBetragOhneCent13EN': TypeInfo(TypeOf.Class, create:() => GeldBetragOhneCent13EN()),
    'GeldBetragMitCent': TypeInfo(TypeOf.AbstractClass),
    'GeldBetragMitCent11EN': TypeInfo(TypeOf.Class, create:() => GeldBetragMitCent11EN()),
    'PositiverGeldBetragMitCent11EN': TypeInfo(TypeOf.Class, create:() => PositiverGeldBetragMitCent11EN()),
    'PositiverGeldBetragMitCent13EN': TypeInfo(TypeOf.Class, create:() => PositiverGeldBetragMitCent13EN()),
    'PositiverGeldBetragOhneCent13EN': TypeInfo(TypeOf.Class, create:() => PositiverGeldBetragOhneCent13EN()),
    'Umsatzsteuervoranmeldung2023': TypeInfo(TypeOf.Class, create:() => Umsatzsteuervoranmeldung2023()),
    'CreateUmsatzsteuervoranmeldung2023XmlBase': TypeInfo(TypeOf.AbstractClass),
    'XmlResponse': TypeInfo(TypeOf.Class, create:() => XmlResponse()),
    'CreateUmsatzsteuervoranmeldung2023XmlAsync': TypeInfo(TypeOf.Class, create:() => CreateUmsatzsteuervoranmeldung2023XmlAsync()),
});

Dart CreateUmsatzsteuervoranmeldung2023XmlAsync DTOs

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

HTTP + X-MSGPACK

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

POST /CreateUmsatzsteuervoranmeldung2023XmlAsync HTTP/1.1 
Host: taxfiling.pwc.de 
Accept: application/x-msgpack
Content-Type: application/x-msgpack
Content-Length: length

{"umsatzsteuervoranmeldung":{"jahr":0,"zeitraum":"0","steuernummer":"String","kz09":{"herstellerId":0,"beraterName":"String","berufsbezeichnung":"String","beraterTelNrVorwahl":"String","beraterTelNrAnschluss":"String","mandantName":"String"},"kz10":{"wert":0},"kz21":{"wert":0},"kz22":{"wert":0},"kz23":{"wert":0},"kz23_Begruendung":"String","kz26":{"wert":0},"kz29":{"wert":0},"kz35":{"wert":0},"kz36":{"wert":0},"kz37":{"wert":0},"kz39":{"wert":0},"kz41":{"wert":0},"kz42":{"wert":0},"kz43":{"wert":0},"kz44":{"wert":0},"kz45":{"wert":0},"kz46":{"wert":0},"kz47":{"wert":0},"kz48":{"wert":0},"kz49":{"wert":0},"kz50":{"wert":0},"kz59":{"wert":0},"kz60":{"wert":0},"kz61":{"wert":0},"kz62":{"wert":0},"kz63":{"wert":0},"kz64":{"wert":0},"kz65":{"wert":0},"kz66":{"wert":0},"kz67":{"wert":0},"kz69":{"wert":0},"kz73":{"wert":0},"kz74":{"wert":0},"kz76":{"wert":0},"kz77":{"wert":0},"kz80":{"wert":0},"kz81":{"wert":0},"kz83":{"wert":0},"kz84":{"wert":0},"kz85":{"wert":0},"kz86":{"wert":0},"kz87":{"wert":0},"kz89":{"wert":0},"kz90":{"wert":0},"kz91":{"wert":0},"kz93":{"wert":0},"kz94":{"wert":0},"kz95":{"wert":0},"kz96":{"wert":0},"kz98":{"wert":0}},"datenLieferant":{"name":"String","strasse":"String","plz":"String","ort":"String","telefon":"String","email":"String"},"erstellungsdatum":"\/Date(-62135596800000-0000)\/","berater":{"bezeichnung":"String","name":"String","vorname":"String","namensvorsatz":"String","namenszusatz":"String","str":"String","hausnummer":"String","hNrZusatz":"String","anschriftenZusatz":"String","ort":"String","plz":"String","auslandsPLZ":"String","land":"String","postfachOrt":"String","postfach":"String","postfachPLZ":"String","gkplz":"String","telefon":"String","email":"String"},"mandant":{"name":"String","vorname":"String","mandantenNr":"String","bearbeiterkennzeichen":"String"},"unternehmer":{"bezeichnung":"String","name":"String","vorname":"String","namensvorsatz":"String","namenszusatz":"String","str":"String","hausnummer":"String","hNrZusatz":"String","anschriftenZusatz":"String","ort":"String","plz":"String","auslandsPLZ":"String","land":"String","postfachOrt":"String","postfach":"String","postfachPLZ":"String","gkplz":"String","telefon":"String","email":"String"},"bundesfinanzamtsnummer":"String","eop":{"transferausgabe":"String"}}
HTTP/1.1 200 OK
Content-Type: application/x-msgpack
Content-Length: length

{"content":"String","responseStatus":{"errorCode":"String","message":"String","stackTrace":"String","errors":[{"errorCode":"String","fieldName":"String","message":"String","meta":{"String":"String"}}],"meta":{"String":"String"}}}