Tax Filing Service

<back to all web services

SubmitUmsatzsteuererklaerung2020Async

AsyncUmsatzsteuerJahressteuererklärung2020

An asynchronous service to create xml content that represents the annual VAT return for 2020.

Requires Authentication
The following routes are available for this service:
POST/SubmitUmsatzsteuererklaerung2020AsyncAn asynchronous service to create xml content that represents the annual VAT return for 2020
<?php namespace dtos;

use DateTime;
use Exception;
use DateInterval;
use JsonSerializable;
use ServiceStack\{IReturn,IReturnVoid,IGet,IPost,IPut,IDelete,IPatch,IMeta,IHasSessionId,IHasBearerToken,IHasVersion};
use ServiceStack\{ICrud,ICreateDb,IUpdateDb,IPatchDb,IDeleteDb,ISaveDb,AuditBase,QueryDb,QueryDb2,QueryData,QueryData2,QueryResponse};
use ServiceStack\{ResponseStatus,ResponseError,EmptyResponse,IdResponse,ArrayList,KeyValuePair2,StringResponse,StringsResponse,Tuple2,Tuple3,ByteArray};
use ServiceStack\{JsonConverters,Returns,TypeContext};


/** @description Stellt die Art der Ordnungsnummer dar. */
enum OrdNrArt : string
{
    case S = 'S';
    case O = 'O';
}

/** @description Stellt den Vorgang bei einer Veranlagung dar. */
enum VeranlagungVorgang : int
{
    case NurVeranlagung = 1;
    case VeranlagungMitVorauszahlung = 4;
}

/** @description Stellt die Informationen zur Bescheidrückübermittlung dar. */
// @Api(Description="Stellt die Informationen zur Bescheidrückübermittlung dar.")
class Rueckuebermittlung implements JsonSerializable
{
    public function __construct(
        /** @description Wird die elektronische Bereitstellung der Bescheiddaten gewünscht? */
        // @ApiMember(Description="Wird die elektronische Bereitstellung der Bescheiddaten gewünscht?")
        /** @var bool|null */
        public ?bool $bescheid=null,

        /** @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.")
        /** @var string|null */
        public ?string $artRueckuebermittlung=null,

        /** @description Öffentlicher Schlüssel mit variabler Länge. */
        // @ApiMember(Description="Öffentlicher Schlüssel mit variabler Länge.")
        /** @var string|null */
        public ?string $schluesselRueckuebermittlung=null,

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

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['bescheid'])) $this->bescheid = $o['bescheid'];
        if (isset($o['artRueckuebermittlung'])) $this->artRueckuebermittlung = $o['artRueckuebermittlung'];
        if (isset($o['schluesselRueckuebermittlung'])) $this->schluesselRueckuebermittlung = $o['schluesselRueckuebermittlung'];
        if (isset($o['adresseRueckuebermittlung'])) $this->adresseRueckuebermittlung = $o['adresseRueckuebermittlung'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->bescheid)) $o['bescheid'] = $this->bescheid;
        if (isset($this->artRueckuebermittlung)) $o['artRueckuebermittlung'] = $this->artRueckuebermittlung;
        if (isset($this->schluesselRueckuebermittlung)) $o['schluesselRueckuebermittlung'] = $this->schluesselRueckuebermittlung;
        if (isset($this->adresseRueckuebermittlung)) $o['adresseRueckuebermittlung'] = $this->adresseRueckuebermittlung;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Basisklasse für einen benutzerdefinierten Feldtyp */
// @Api(Description="Basisklasse für einen benutzerdefinierten Feldtyp")
class CustomFeldBase implements ICustomFeld, JsonSerializable
{
    public function __construct(
        /** @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.")
        /** @var int */
        public int $nr=0,

        /** @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")
        /** @var int */
        public int $index=0,

        /** @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")
        /** @var int */
        public int $lfdNr=0,

        /** @description Identifizierung der Zeile / Feld im Fremdprogramm. */
        // @ApiMember(Description="Identifizierung der Zeile / Feld im Fremdprogramm.")
        /** @var string|null */
        public ?string $alias=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nr'])) $this->nr = $o['nr'];
        if (isset($o['index'])) $this->index = $o['index'];
        if (isset($o['lfdNr'])) $this->lfdNr = $o['lfdNr'];
        if (isset($o['alias'])) $this->alias = $o['alias'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nr)) $o['nr'] = $this->nr;
        if (isset($this->index)) $o['index'] = $this->index;
        if (isset($this->lfdNr)) $o['lfdNr'] = $this->lfdNr;
        if (isset($this->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @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.")
class BoolXFeld extends CustomFeldBase implements JsonSerializable
{
    /**
     * @param int $nr
     * @param int $index
     * @param int $lfdNr
     * @param string|null $alias
     */
    public function __construct(
        int $nr=0,
        int $index=0,
        int $lfdNr=0,
        ?string $alias=null,
        /** @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")
        /** @var bool|null */
        public ?bool $wert=null
    ) {
        parent::__construct($nr,$index,$lfdNr,$alias);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['wert'])) $this->wert = $o['wert'];
        if (isset($o['nr'])) $this->nr = $o['nr'];
        if (isset($o['index'])) $this->index = $o['index'];
        if (isset($o['lfdNr'])) $this->lfdNr = $o['lfdNr'];
        if (isset($o['alias'])) $this->alias = $o['alias'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->wert)) $o['wert'] = $this->wert;
        if (isset($this->nr)) $o['nr'] = $this->nr;
        if (isset($this->index)) $o['index'] = $this->index;
        if (isset($this->lfdNr)) $o['lfdNr'] = $this->lfdNr;
        if (isset($this->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @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.")
class Bool1Feld extends CustomFeldBase implements JsonSerializable
{
    /**
     * @param int $nr
     * @param int $index
     * @param int $lfdNr
     * @param string|null $alias
     */
    public function __construct(
        int $nr=0,
        int $index=0,
        int $lfdNr=0,
        ?string $alias=null,
        /** @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")
        /** @var bool|null */
        public ?bool $wert=null
    ) {
        parent::__construct($nr,$index,$lfdNr,$alias);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['wert'])) $this->wert = $o['wert'];
        if (isset($o['nr'])) $this->nr = $o['nr'];
        if (isset($o['index'])) $this->index = $o['index'];
        if (isset($o['lfdNr'])) $this->lfdNr = $o['lfdNr'];
        if (isset($o['alias'])) $this->alias = $o['alias'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->wert)) $o['wert'] = $this->wert;
        if (isset($this->nr)) $o['nr'] = $this->nr;
        if (isset($this->index)) $o['index'] = $this->index;
        if (isset($this->lfdNr)) $o['lfdNr'] = $this->lfdNr;
        if (isset($this->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Zeichenkettenfeld. */
// @Api(Description="Zeichenkettenfeld.")
class StringFeld extends CustomFeldBase implements JsonSerializable
{
    /**
     * @param int $nr
     * @param int $index
     * @param int $lfdNr
     * @param string|null $alias
     */
    public function __construct(
        int $nr=0,
        int $index=0,
        int $lfdNr=0,
        ?string $alias=null,
        /** @description Wert des Feldes.  1 bis 999 Zeichen, alphanumerisch */
        // @ApiMember(Description="Wert des Feldes. \n 1 bis 999 Zeichen, alphanumerisch", IsRequired=true, Name="Wert")
        /** @var string */
        public string $wert=''
    ) {
        parent::__construct($nr,$index,$lfdNr,$alias);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['wert'])) $this->wert = $o['wert'];
        if (isset($o['nr'])) $this->nr = $o['nr'];
        if (isset($o['index'])) $this->index = $o['index'];
        if (isset($o['lfdNr'])) $this->lfdNr = $o['lfdNr'];
        if (isset($o['alias'])) $this->alias = $o['alias'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->wert)) $o['wert'] = $this->wert;
        if (isset($this->nr)) $o['nr'] = $this->nr;
        if (isset($this->index)) $o['index'] = $this->index;
        if (isset($this->lfdNr)) $o['lfdNr'] = $this->lfdNr;
        if (isset($this->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Stellt ein Datumbereich dar (TT.MM-TT.MM) dar */
// @Api(Description="Stellt ein Datumbereich dar (TT.MM-TT.MM) dar")
class ErklaerungZeitraum implements JsonSerializable
{
    public function __construct(
        /** @description Der Anfang des Datumbreiches. */
        // @ApiMember(Description="Der Anfang des Datumbreiches.", Name="Start")
        /** @var DateTime */
        public DateTime $start=new DateTime(),

        /** @description Das Ende des Datumbereiches. */
        // @ApiMember(Description="Das Ende des Datumbereiches.", Name="Ende")
        /** @var DateTime */
        public DateTime $ende=new DateTime()
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['start'])) $this->start = JsonConverters::from('DateTime', $o['start']);
        if (isset($o['ende'])) $this->ende = JsonConverters::from('DateTime', $o['ende']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->start)) $o['start'] = JsonConverters::to('DateTime', $this->start);
        if (isset($this->ende)) $o['ende'] = JsonConverters::to('DateTime', $this->ende);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Datums-Uhrzeitfeld. Format: TT.MM - TT. MM */
// @Api(Description="Datums-Uhrzeitfeld. Format: TT.MM - TT. MM")
class ZeitraumFeld extends CustomFeldBase implements JsonSerializable
{
    /**
     * @param int $nr
     * @param int $index
     * @param int $lfdNr
     * @param string|null $alias
     */
    public function __construct(
        int $nr=0,
        int $index=0,
        int $lfdNr=0,
        ?string $alias=null,
        /** @description Wert des Feldes. */
        // @ApiMember(Description="Wert des Feldes.", IsRequired=true)
        /** @var ErklaerungZeitraum|null */
        public ?ErklaerungZeitraum $wert=null
    ) {
        parent::__construct($nr,$index,$lfdNr,$alias);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['wert'])) $this->wert = JsonConverters::from('ErklaerungZeitraum', $o['wert']);
        if (isset($o['nr'])) $this->nr = $o['nr'];
        if (isset($o['index'])) $this->index = $o['index'];
        if (isset($o['lfdNr'])) $this->lfdNr = $o['lfdNr'];
        if (isset($o['alias'])) $this->alias = $o['alias'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->wert)) $o['wert'] = JsonConverters::to('ErklaerungZeitraum', $this->wert);
        if (isset($this->nr)) $o['nr'] = $this->nr;
        if (isset($this->index)) $o['index'] = $this->index;
        if (isset($this->lfdNr)) $o['lfdNr'] = $this->lfdNr;
        if (isset($this->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Art der Entgelte */
// @Flags()
enum Entgeltart : int
{
    case VereinbarteEntgelte = 1;
    case VereinnahmteEntgelte = 16;
}

/** @description Feld, welches die Art der Entgeltart darstellt. */
// @Api(Description="Feld, welches die Art der Entgeltart darstellt.")
class EntgeltartFeld extends CustomFeldBase implements JsonSerializable
{
    /**
     * @param int $nr
     * @param int $index
     * @param int $lfdNr
     * @param string|null $alias
     */
    public function __construct(
        int $nr=0,
        int $index=0,
        int $lfdNr=0,
        ?string $alias=null,
        /** @description Wert des Feldes. */
        // @ApiMember(Description="Wert des Feldes.", IsRequired=true)
        /** @var Entgeltart|null */
        public ?Entgeltart $wert=null
    ) {
        parent::__construct($nr,$index,$lfdNr,$alias);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['wert'])) $this->wert = JsonConverters::from('Entgeltart', $o['wert']);
        if (isset($o['nr'])) $this->nr = $o['nr'];
        if (isset($o['index'])) $this->index = $o['index'];
        if (isset($o['lfdNr'])) $this->lfdNr = $o['lfdNr'];
        if (isset($o['alias'])) $this->alias = $o['alias'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->wert)) $o['wert'] = JsonConverters::to('Entgeltart', $this->wert);
        if (isset($this->nr)) $o['nr'] = $this->nr;
        if (isset($this->index)) $o['index'] = $this->index;
        if (isset($this->lfdNr)) $o['lfdNr'] = $this->lfdNr;
        if (isset($this->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @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")
class AllgemeineAngaben2020 implements JsonSerializable
{
    public function __construct(
        /** @description Diese Steuererklärung wurde digital signiert? */
        // @ApiMember(Description="Diese Steuererklärung wurde digital signiert?", Name="Nr3000013")
        /** @var BoolXFeld|null */
        public ?BoolXFeld $nr3000013=null,

        /** @description Berichtigte Steuererklärung? */
        // @ApiMember(Description="Berichtigte Steuererklärung?", Name="Nr3000601")
        /** @var Bool1Feld|null */
        public ?Bool1Feld $nr3000601=null,

        /** @description Name des Unternehmers */
        // @ApiMember(Description="Name des Unternehmers", IsRequired=true, Name="Nr3000901")
        /** @var StringFeld|null */
        public ?StringFeld $nr3000901=null,

        /** @description gegebenenfalls abweichender Firmenname */
        // @ApiMember(Description="gegebenenfalls abweichender Firmenname", Name="Nr3000902")
        /** @var StringFeld|null */
        public ?StringFeld $nr3000902=null,

        /** @description Art des Unternehmens */
        // @ApiMember(Description="Art des Unternehmens", Name="Nr3001001")
        /** @var StringFeld|null */
        public ?StringFeld $nr3001001=null,

        /** @description Straße */
        // @ApiMember(Description="Straße", IsRequired=true, Name="Nr3001101")
        /** @var StringFeld|null */
        public ?StringFeld $nr3001101=null,

        /** @description Hausnummer */
        // @ApiMember(Description="Hausnummer", IsRequired=true, Name="Nr3001203")
        /** @var StringFeld|null */
        public ?StringFeld $nr3001203=null,

        /** @description Hausnummerzusatz */
        // @ApiMember(Description="Hausnummerzusatz", Name="Nr3001204")
        /** @var StringFeld|null */
        public ?StringFeld $nr3001204=null,

        /** @description Adressergänzung */
        // @ApiMember(Description="Adressergänzung", Name="Nr3001205")
        /** @var StringFeld|null */
        public ?StringFeld $nr3001205=null,

        /** @description Postleitzahl, Ort */
        // @ApiMember(Description="Postleitzahl, Ort", Name="Nr3001201")
        /** @var StringFeld|null */
        public ?StringFeld $nr3001201=null,

        /** @description Postleitzahl zu Postfach */
        // @ApiMember(Description="Postleitzahl zu Postfach", Name="Nr3001403")
        /** @var StringFeld|null */
        public ?StringFeld $nr3001403=null,

        /** @description Postfach */
        // @ApiMember(Description="Postfach", Name="Nr3001404")
        /** @var StringFeld|null */
        public ?StringFeld $nr3001404=null,

        /** @description Telefon */
        // @ApiMember(Description="Telefon", Name="Nr3001202")
        /** @var StringFeld|null */
        public ?StringFeld $nr3001202=null,

        /** @description E-Mail Adresse */
        // @ApiMember(Description="E-Mail Adresse", Name="Nr3001301")
        /** @var StringFeld|null */
        public ?StringFeld $nr3001301=null,

        /** @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")
        /** @var Bool1Feld|null */
        public ?Bool1Feld $nr3001402=null,

        /** @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")
        /** @var Bool1Feld|null */
        public ?Bool1Feld $nr3001801=null,

        /** @description 1. Zeitraum */
        // @ApiMember(Description="1. Zeitraum", Name="Nr3001401")
        /** @var ZeitraumFeld|null */
        public ?ZeitraumFeld $nr3001401=null,

        /** @description 2. Zeitraum */
        // @ApiMember(Description="2. Zeitraum", Name="Nr3001501")
        /** @var ZeitraumFeld|null */
        public ?ZeitraumFeld $nr3001501=null,

        /** @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")
        /** @var EntgeltartFeld|null */
        public ?EntgeltartFeld $nr3002203=null,

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

        /** @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")
        /** @var Bool1Feld|null */
        public ?Bool1Feld $nr3002201=null,

        /** @description Ergänzende Angaben zur Steuererklärung */
        // @ApiMember(Description="Ergänzende Angaben zur Steuererklärung", Name="Nr3002202")
        /** @var StringFeld|null */
        public ?StringFeld $nr3002202=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nr3000013'])) $this->nr3000013 = JsonConverters::from('BoolXFeld', $o['nr3000013']);
        if (isset($o['nr3000601'])) $this->nr3000601 = JsonConverters::from('Bool1Feld', $o['nr3000601']);
        if (isset($o['nr3000901'])) $this->nr3000901 = JsonConverters::from('StringFeld', $o['nr3000901']);
        if (isset($o['nr3000902'])) $this->nr3000902 = JsonConverters::from('StringFeld', $o['nr3000902']);
        if (isset($o['nr3001001'])) $this->nr3001001 = JsonConverters::from('StringFeld', $o['nr3001001']);
        if (isset($o['nr3001101'])) $this->nr3001101 = JsonConverters::from('StringFeld', $o['nr3001101']);
        if (isset($o['nr3001203'])) $this->nr3001203 = JsonConverters::from('StringFeld', $o['nr3001203']);
        if (isset($o['nr3001204'])) $this->nr3001204 = JsonConverters::from('StringFeld', $o['nr3001204']);
        if (isset($o['nr3001205'])) $this->nr3001205 = JsonConverters::from('StringFeld', $o['nr3001205']);
        if (isset($o['nr3001201'])) $this->nr3001201 = JsonConverters::from('StringFeld', $o['nr3001201']);
        if (isset($o['nr3001403'])) $this->nr3001403 = JsonConverters::from('StringFeld', $o['nr3001403']);
        if (isset($o['nr3001404'])) $this->nr3001404 = JsonConverters::from('StringFeld', $o['nr3001404']);
        if (isset($o['nr3001202'])) $this->nr3001202 = JsonConverters::from('StringFeld', $o['nr3001202']);
        if (isset($o['nr3001301'])) $this->nr3001301 = JsonConverters::from('StringFeld', $o['nr3001301']);
        if (isset($o['nr3001402'])) $this->nr3001402 = JsonConverters::from('Bool1Feld', $o['nr3001402']);
        if (isset($o['nr3001801'])) $this->nr3001801 = JsonConverters::from('Bool1Feld', $o['nr3001801']);
        if (isset($o['nr3001401'])) $this->nr3001401 = JsonConverters::from('ZeitraumFeld', $o['nr3001401']);
        if (isset($o['nr3001501'])) $this->nr3001501 = JsonConverters::from('ZeitraumFeld', $o['nr3001501']);
        if (isset($o['nr3002203'])) $this->nr3002203 = JsonConverters::from('EntgeltartFeld', $o['nr3002203']);
        if (isset($o['nr3001701'])) $this->nr3001701 = JsonConverters::from('Bool1Feld', $o['nr3001701']);
        if (isset($o['nr3002201'])) $this->nr3002201 = JsonConverters::from('Bool1Feld', $o['nr3002201']);
        if (isset($o['nr3002202'])) $this->nr3002202 = JsonConverters::from('StringFeld', $o['nr3002202']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nr3000013)) $o['nr3000013'] = JsonConverters::to('BoolXFeld', $this->nr3000013);
        if (isset($this->nr3000601)) $o['nr3000601'] = JsonConverters::to('Bool1Feld', $this->nr3000601);
        if (isset($this->nr3000901)) $o['nr3000901'] = JsonConverters::to('StringFeld', $this->nr3000901);
        if (isset($this->nr3000902)) $o['nr3000902'] = JsonConverters::to('StringFeld', $this->nr3000902);
        if (isset($this->nr3001001)) $o['nr3001001'] = JsonConverters::to('StringFeld', $this->nr3001001);
        if (isset($this->nr3001101)) $o['nr3001101'] = JsonConverters::to('StringFeld', $this->nr3001101);
        if (isset($this->nr3001203)) $o['nr3001203'] = JsonConverters::to('StringFeld', $this->nr3001203);
        if (isset($this->nr3001204)) $o['nr3001204'] = JsonConverters::to('StringFeld', $this->nr3001204);
        if (isset($this->nr3001205)) $o['nr3001205'] = JsonConverters::to('StringFeld', $this->nr3001205);
        if (isset($this->nr3001201)) $o['nr3001201'] = JsonConverters::to('StringFeld', $this->nr3001201);
        if (isset($this->nr3001403)) $o['nr3001403'] = JsonConverters::to('StringFeld', $this->nr3001403);
        if (isset($this->nr3001404)) $o['nr3001404'] = JsonConverters::to('StringFeld', $this->nr3001404);
        if (isset($this->nr3001202)) $o['nr3001202'] = JsonConverters::to('StringFeld', $this->nr3001202);
        if (isset($this->nr3001301)) $o['nr3001301'] = JsonConverters::to('StringFeld', $this->nr3001301);
        if (isset($this->nr3001402)) $o['nr3001402'] = JsonConverters::to('Bool1Feld', $this->nr3001402);
        if (isset($this->nr3001801)) $o['nr3001801'] = JsonConverters::to('Bool1Feld', $this->nr3001801);
        if (isset($this->nr3001401)) $o['nr3001401'] = JsonConverters::to('ZeitraumFeld', $this->nr3001401);
        if (isset($this->nr3001501)) $o['nr3001501'] = JsonConverters::to('ZeitraumFeld', $this->nr3001501);
        if (isset($this->nr3002203)) $o['nr3002203'] = JsonConverters::to('EntgeltartFeld', $this->nr3002203);
        if (isset($this->nr3001701)) $o['nr3001701'] = JsonConverters::to('Bool1Feld', $this->nr3001701);
        if (isset($this->nr3002201)) $o['nr3002201'] = JsonConverters::to('Bool1Feld', $this->nr3002201);
        if (isset($this->nr3002202)) $o['nr3002202'] = JsonConverters::to('StringFeld', $this->nr3002202);
        return empty($o) ? new class(){} : $o;
    }
}

/** @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")
class GeldBetragOhneCent implements JsonSerializable
{
    public function __construct(
        /** @description The intrinsic currency value. */
        // @ApiMember(Description="The intrinsic currency value.")
        /** @var int */
        public int $wert=0
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['wert'])) $this->wert = $o['wert'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->wert)) $o['wert'] = $this->wert;
        return empty($o) ? new class(){} : $o;
    }
}

/** @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")
class GeldBetragOhneCent5DE extends GeldBetragOhneCent implements JsonSerializable
{
    /**
     * @param int $wert
     */
    public function __construct(
        int $wert=0
    ) {
        parent::__construct($wert);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['wert'])) $this->wert = $o['wert'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->wert)) $o['wert'] = $this->wert;
        return empty($o) ? new class(){} : $o;
    }
}

/** @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.")
class GeldBetragOhneCent5DEFeld extends CustomFeldBase implements JsonSerializable
{
    /**
     * @param int $nr
     * @param int $index
     * @param int $lfdNr
     * @param string|null $alias
     */
    public function __construct(
        int $nr=0,
        int $index=0,
        int $lfdNr=0,
        ?string $alias=null,
        /** @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)
        /** @var GeldBetragOhneCent5DE|null */
        public ?GeldBetragOhneCent5DE $betrag=null
    ) {
        parent::__construct($nr,$index,$lfdNr,$alias);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['betrag'])) $this->betrag = JsonConverters::from('GeldBetragOhneCent5DE', $o['betrag']);
        if (isset($o['nr'])) $this->nr = $o['nr'];
        if (isset($o['index'])) $this->index = $o['index'];
        if (isset($o['lfdNr'])) $this->lfdNr = $o['lfdNr'];
        if (isset($o['alias'])) $this->alias = $o['alias'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->betrag)) $o['betrag'] = JsonConverters::to('GeldBetragOhneCent5DE', $this->betrag);
        if (isset($this->nr)) $o['nr'] = $this->nr;
        if (isset($this->index)) $o['index'] = $this->index;
        if (isset($this->lfdNr)) $o['lfdNr'] = $this->lfdNr;
        if (isset($this->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @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")
class GrossGeldBetragOhneCent implements JsonSerializable
{
    public function __construct(
        /** @description The intrinsic currency value. */
        // @ApiMember(Description="The intrinsic currency value.")
        /** @var int */
        public int $wert=0
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['wert'])) $this->wert = $o['wert'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->wert)) $o['wert'] = $this->wert;
        return empty($o) ? new class(){} : $o;
    }
}

/** @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.")
class GeldBetragOhneCent12DE extends GrossGeldBetragOhneCent implements JsonSerializable
{
    /**
     * @param int $wert
     */
    public function __construct(
        int $wert=0
    ) {
        parent::__construct($wert);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['wert'])) $this->wert = $o['wert'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->wert)) $o['wert'] = $this->wert;
        return empty($o) ? new class(){} : $o;
    }
}

/** @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.")
class GeldBetragOhneCent12DEFeld extends CustomFeldBase implements JsonSerializable
{
    /**
     * @param int $nr
     * @param int $index
     * @param int $lfdNr
     * @param string|null $alias
     */
    public function __construct(
        int $nr=0,
        int $index=0,
        int $lfdNr=0,
        ?string $alias=null,
        /** @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)
        /** @var GeldBetragOhneCent12DE|null */
        public ?GeldBetragOhneCent12DE $betrag=null
    ) {
        parent::__construct($nr,$index,$lfdNr,$alias);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['betrag'])) $this->betrag = JsonConverters::from('GeldBetragOhneCent12DE', $o['betrag']);
        if (isset($o['nr'])) $this->nr = $o['nr'];
        if (isset($o['index'])) $this->index = $o['index'];
        if (isset($o['lfdNr'])) $this->lfdNr = $o['lfdNr'];
        if (isset($o['alias'])) $this->alias = $o['alias'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->betrag)) $o['betrag'] = JsonConverters::to('GeldBetragOhneCent12DE', $this->betrag);
        if (isset($this->nr)) $o['nr'] = $this->nr;
        if (isset($this->index)) $o['index'] = $this->index;
        if (isset($this->lfdNr)) $o['lfdNr'] = $this->lfdNr;
        if (isset($this->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @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.")
class AngabenBesteuerungKleinunternehmer2020 implements JsonSerializable
{
    public function __construct(
        /** @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")
        /** @var GeldBetragOhneCent5DEFeld|null */
        public ?GeldBetragOhneCent5DEFeld $nr3002301=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3002401=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nr3002301'])) $this->nr3002301 = JsonConverters::from('GeldBetragOhneCent5DEFeld', $o['nr3002301']);
        if (isset($o['nr3002401'])) $this->nr3002401 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3002401']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nr3002301)) $o['nr3002301'] = JsonConverters::to('GeldBetragOhneCent5DEFeld', $this->nr3002301);
        if (isset($this->nr3002401)) $o['nr3002401'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3002401);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Steuerfreie Lieferungen, usw. für die Umsatzteuererklärung 2020. */
// @Api(Description="Steuerfreie Lieferungen, usw. für die Umsatzteuererklärung 2020.")
class SteuerfreieLieferungenEtc2020 implements JsonSerializable
{
    public function __construct(
        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3103301=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3103401=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3103501=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3103801=null,

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

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

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3104001=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3104101=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3104201=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3104401=null,

        /** @description nach § 4 Nummer ... UStG */
        // @ApiMember(Description="nach § 4 Nummer ... UStG", Name="Nr3104501")
        /** @var StringFeld|null */
        public ?StringFeld $nr3104501=null,

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

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3104601=null,

        /** @description nach § ... UStG */
        // @ApiMember(Description="nach § ... UStG", Name="Nr3104901")
        /** @var StringFeld|null */
        public ?StringFeld $nr3104901=null,

        /** @description nach § ... UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
        // @ApiMember(Description="nach § ... UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3104902")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3104902=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nr3103301'])) $this->nr3103301 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3103301']);
        if (isset($o['nr3103401'])) $this->nr3103401 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3103401']);
        if (isset($o['nr3103501'])) $this->nr3103501 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3103501']);
        if (isset($o['nr3103801'])) $this->nr3103801 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3103801']);
        if (isset($o['nr3103901'])) $this->nr3103901 = JsonConverters::from('StringFeld', $o['nr3103901']);
        if (isset($o['nr3103902'])) $this->nr3103902 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3103902']);
        if (isset($o['nr3104001'])) $this->nr3104001 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3104001']);
        if (isset($o['nr3104101'])) $this->nr3104101 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3104101']);
        if (isset($o['nr3104201'])) $this->nr3104201 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3104201']);
        if (isset($o['nr3104401'])) $this->nr3104401 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3104401']);
        if (isset($o['nr3104501'])) $this->nr3104501 = JsonConverters::from('StringFeld', $o['nr3104501']);
        if (isset($o['nr3104502'])) $this->nr3104502 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3104502']);
        if (isset($o['nr3104601'])) $this->nr3104601 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3104601']);
        if (isset($o['nr3104901'])) $this->nr3104901 = JsonConverters::from('StringFeld', $o['nr3104901']);
        if (isset($o['nr3104902'])) $this->nr3104902 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3104902']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nr3103301)) $o['nr3103301'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3103301);
        if (isset($this->nr3103401)) $o['nr3103401'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3103401);
        if (isset($this->nr3103501)) $o['nr3103501'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3103501);
        if (isset($this->nr3103801)) $o['nr3103801'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3103801);
        if (isset($this->nr3103901)) $o['nr3103901'] = JsonConverters::to('StringFeld', $this->nr3103901);
        if (isset($this->nr3103902)) $o['nr3103902'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3103902);
        if (isset($this->nr3104001)) $o['nr3104001'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3104001);
        if (isset($this->nr3104101)) $o['nr3104101'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3104101);
        if (isset($this->nr3104201)) $o['nr3104201'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3104201);
        if (isset($this->nr3104401)) $o['nr3104401'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3104401);
        if (isset($this->nr3104501)) $o['nr3104501'] = JsonConverters::to('StringFeld', $this->nr3104501);
        if (isset($this->nr3104502)) $o['nr3104502'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3104502);
        if (isset($this->nr3104601)) $o['nr3104601'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3104601);
        if (isset($this->nr3104901)) $o['nr3104901'] = JsonConverters::to('StringFeld', $this->nr3104901);
        if (isset($this->nr3104902)) $o['nr3104902'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3104902);
        return empty($o) ? new class(){} : $o;
    }
}

/** @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")
class GeldBetragMitCent implements JsonSerializable
{
    public function __construct(
        /** @description The intrinsic currency value. */
        // @ApiMember(Description="The intrinsic currency value.")
        /** @var float */
        public float $wert=0.0
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['wert'])) $this->wert = $o['wert'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->wert)) $o['wert'] = $this->wert;
        return empty($o) ? new class(){} : $o;
    }
}

/** @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.")
class GeldBetragMitCent12DE extends GeldBetragMitCent implements JsonSerializable
{
    /**
     * @param float $wert
     */
    public function __construct(
        float $wert=0.0
    ) {
        parent::__construct($wert);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['wert'])) $this->wert = $o['wert'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->wert)) $o['wert'] = $this->wert;
        return empty($o) ? new class(){} : $o;
    }
}

/** @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.")
class GeldBetragMitCent12DEFeld extends CustomFeldBase implements JsonSerializable
{
    /**
     * @param int $nr
     * @param int $index
     * @param int $lfdNr
     * @param string|null $alias
     */
    public function __construct(
        int $nr=0,
        int $index=0,
        int $lfdNr=0,
        ?string $alias=null,
        /** @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)
        /** @var GeldBetragMitCent12DE|null */
        public ?GeldBetragMitCent12DE $betrag=null
    ) {
        parent::__construct($nr,$index,$lfdNr,$alias);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['betrag'])) $this->betrag = JsonConverters::from('GeldBetragMitCent12DE', $o['betrag']);
        if (isset($o['nr'])) $this->nr = $o['nr'];
        if (isset($o['index'])) $this->index = $o['index'];
        if (isset($o['lfdNr'])) $this->lfdNr = $o['lfdNr'];
        if (isset($o['alias'])) $this->alias = $o['alias'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->betrag)) $o['betrag'] = JsonConverters::to('GeldBetragMitCent12DE', $this->betrag);
        if (isset($this->nr)) $o['nr'] = $this->nr;
        if (isset($this->index)) $o['index'] = $this->index;
        if (isset($this->lfdNr)) $o['lfdNr'] = $this->lfdNr;
        if (isset($this->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Steuerpflichtige Lieferungen, usw. für die Umsatzteuererklärung 2020. */
// @Api(Description="Steuerpflichtige Lieferungen, usw. für die Umsatzteuererklärung 2020.")
class SteuerpflichtigeLieferungenEtc2020 implements JsonSerializable
{
    public function __construct(
        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3003303=null,

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

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3003405=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3003406=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3003505=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3003506=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3004401=null,

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

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3003703=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3003704=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3003803=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3003804=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3005001=null,

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

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3005201=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3005301=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3005302=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3005003=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3005004=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3005701=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3005702=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3005801=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3102901=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3102801=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3005901=null,

        /** @description Summe der Steuer (zu übertragen in Zeile 152) */
        // @ApiMember(Description="Summe der Steuer (zu übertragen in Zeile 152)", Name="Nr3006001")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3006001=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nr3003303'])) $this->nr3003303 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3003303']);
        if (isset($o['nr3003304'])) $this->nr3003304 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3003304']);
        if (isset($o['nr3003405'])) $this->nr3003405 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3003405']);
        if (isset($o['nr3003406'])) $this->nr3003406 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3003406']);
        if (isset($o['nr3003505'])) $this->nr3003505 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3003505']);
        if (isset($o['nr3003506'])) $this->nr3003506 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3003506']);
        if (isset($o['nr3004401'])) $this->nr3004401 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3004401']);
        if (isset($o['nr3004402'])) $this->nr3004402 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3004402']);
        if (isset($o['nr3003703'])) $this->nr3003703 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3003703']);
        if (isset($o['nr3003704'])) $this->nr3003704 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3003704']);
        if (isset($o['nr3003803'])) $this->nr3003803 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3003803']);
        if (isset($o['nr3003804'])) $this->nr3003804 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3003804']);
        if (isset($o['nr3005001'])) $this->nr3005001 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3005001']);
        if (isset($o['nr3005002'])) $this->nr3005002 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3005002']);
        if (isset($o['nr3005201'])) $this->nr3005201 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3005201']);
        if (isset($o['nr3005301'])) $this->nr3005301 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3005301']);
        if (isset($o['nr3005302'])) $this->nr3005302 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3005302']);
        if (isset($o['nr3005003'])) $this->nr3005003 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3005003']);
        if (isset($o['nr3005004'])) $this->nr3005004 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3005004']);
        if (isset($o['nr3005701'])) $this->nr3005701 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3005701']);
        if (isset($o['nr3005702'])) $this->nr3005702 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3005702']);
        if (isset($o['nr3005801'])) $this->nr3005801 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3005801']);
        if (isset($o['nr3102901'])) $this->nr3102901 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3102901']);
        if (isset($o['nr3102801'])) $this->nr3102801 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3102801']);
        if (isset($o['nr3005901'])) $this->nr3005901 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3005901']);
        if (isset($o['nr3006001'])) $this->nr3006001 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3006001']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nr3003303)) $o['nr3003303'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3003303);
        if (isset($this->nr3003304)) $o['nr3003304'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3003304);
        if (isset($this->nr3003405)) $o['nr3003405'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3003405);
        if (isset($this->nr3003406)) $o['nr3003406'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3003406);
        if (isset($this->nr3003505)) $o['nr3003505'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3003505);
        if (isset($this->nr3003506)) $o['nr3003506'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3003506);
        if (isset($this->nr3004401)) $o['nr3004401'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3004401);
        if (isset($this->nr3004402)) $o['nr3004402'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3004402);
        if (isset($this->nr3003703)) $o['nr3003703'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3003703);
        if (isset($this->nr3003704)) $o['nr3003704'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3003704);
        if (isset($this->nr3003803)) $o['nr3003803'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3003803);
        if (isset($this->nr3003804)) $o['nr3003804'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3003804);
        if (isset($this->nr3005001)) $o['nr3005001'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3005001);
        if (isset($this->nr3005002)) $o['nr3005002'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3005002);
        if (isset($this->nr3005201)) $o['nr3005201'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3005201);
        if (isset($this->nr3005301)) $o['nr3005301'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3005301);
        if (isset($this->nr3005302)) $o['nr3005302'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3005302);
        if (isset($this->nr3005003)) $o['nr3005003'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3005003);
        if (isset($this->nr3005004)) $o['nr3005004'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3005004);
        if (isset($this->nr3005701)) $o['nr3005701'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3005701);
        if (isset($this->nr3005702)) $o['nr3005702'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3005702);
        if (isset($this->nr3005801)) $o['nr3005801'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3005801);
        if (isset($this->nr3102901)) $o['nr3102901'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3102901);
        if (isset($this->nr3102801)) $o['nr3102801'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3102801);
        if (isset($this->nr3005901)) $o['nr3005901'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3005901);
        if (isset($this->nr3006001)) $o['nr3006001'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3006001);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Innergemeinschaftliche Erwerbe der Umsatzsteuererklärung für 2020. */
// @Api(Description="Innergemeinschaftliche Erwerbe der Umsatzsteuererklärung für 2020.")
class InnergemeinschaftlicheErwerbe2020 implements JsonSerializable
{
    public function __construct(
        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3100901=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3100902=null,

        /** @description zum Steuersatz von 19 Prozent (Steuer) */
        // @ApiMember(Description="zum Steuersatz von 19 Prozent (Steuer)", Name="Nr3100903")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3100903=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3101301=null,

        /** @description zum Steuersatz von 7 Prozent (Steuer) */
        // @ApiMember(Description="zum Steuersatz von 7 Prozent (Steuer)", Name="Nr3101302")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3101302=null,

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

        /** @description zu anderen Steuersätzen (Steuer) */
        // @ApiMember(Description="zu anderen Steuersätzen (Steuer)", Name="Nr3101304")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3101304=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3101401=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3101402=null,

        /** @description Summe der Steuer (zu übertragen in Zeile 153) */
        // @ApiMember(Description="Summe der Steuer (zu übertragen in Zeile 153)", Name="Nr3101501")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3101501=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nr3100901'])) $this->nr3100901 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3100901']);
        if (isset($o['nr3100902'])) $this->nr3100902 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3100902']);
        if (isset($o['nr3100903'])) $this->nr3100903 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3100903']);
        if (isset($o['nr3101301'])) $this->nr3101301 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3101301']);
        if (isset($o['nr3101302'])) $this->nr3101302 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3101302']);
        if (isset($o['nr3101303'])) $this->nr3101303 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3101303']);
        if (isset($o['nr3101304'])) $this->nr3101304 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3101304']);
        if (isset($o['nr3101401'])) $this->nr3101401 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3101401']);
        if (isset($o['nr3101402'])) $this->nr3101402 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3101402']);
        if (isset($o['nr3101501'])) $this->nr3101501 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3101501']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nr3100901)) $o['nr3100901'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3100901);
        if (isset($this->nr3100902)) $o['nr3100902'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3100902);
        if (isset($this->nr3100903)) $o['nr3100903'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3100903);
        if (isset($this->nr3101301)) $o['nr3101301'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3101301);
        if (isset($this->nr3101302)) $o['nr3101302'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3101302);
        if (isset($this->nr3101303)) $o['nr3101303'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3101303);
        if (isset($this->nr3101304)) $o['nr3101304'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3101304);
        if (isset($this->nr3101401)) $o['nr3101401'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3101401);
        if (isset($this->nr3101402)) $o['nr3101402'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3101402);
        if (isset($this->nr3101501)) $o['nr3101501'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3101501);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Steuerschuldner bei Auslagerung der Umsatzsteuererklärung für 2020. */
// @Api(Description="Steuerschuldner bei Auslagerung der Umsatzsteuererklärung für 2020.")
class SteuerschuldnerBeiAuslagerung2020 implements JsonSerializable
{
    public function __construct(
        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3102804=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3102805=null,

        /** @description Summe der Steuer (zu übertragen in Zeile 154) */
        // @ApiMember(Description="Summe der Steuer (zu übertragen in Zeile 154)", Name="Nr3102904")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3102904=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nr3102804'])) $this->nr3102804 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3102804']);
        if (isset($o['nr3102805'])) $this->nr3102805 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3102805']);
        if (isset($o['nr3102904'])) $this->nr3102904 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3102904']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nr3102804)) $o['nr3102804'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3102804);
        if (isset($this->nr3102805)) $o['nr3102805'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3102805);
        if (isset($this->nr3102904)) $o['nr3102904'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3102904);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Innergemeinschaftliche Dreiecksgeschäfte der Umsatzsteuererklärung für 2020. */
// @Api(Description="Innergemeinschaftliche Dreiecksgeschäfte der Umsatzsteuererklärung für 2020.")
class InnergemeinschaftlicheDreiecksgeschaefte2020 implements JsonSerializable
{
    public function __construct(
        /** @description Bemessungsgrundlage ohne Umsatzsteuer (volle EUR) */
        // @ApiMember(Description="Bemessungsgrundlage ohne Umsatzsteuer (volle EUR)", Name="Nr3101801")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3101801=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3101701=null,

        /** @description zum Steuersatz von 19 Prozent (Steuer) */
        // @ApiMember(Description="zum Steuersatz von 19 Prozent (Steuer)", Name="Nr3101702")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3101702=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3102301=null,

        /** @description zum Steuersatz von 7 Prozent (Steuer) */
        // @ApiMember(Description="zum Steuersatz von 7 Prozent (Steuer)", Name="Nr3102302")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3102302=null,

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

        /** @description zu anderen Steuersätzen (Steuer) */
        // @ApiMember(Description="zu anderen Steuersätzen (Steuer)", Name="Nr3102304")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3102304=null,

        /** @description Summe der Steuer (zu übertragen in Zeile 155) */
        // @ApiMember(Description="Summe der Steuer (zu übertragen in Zeile 155)", Name="Nr3102401")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3102401=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nr3101801'])) $this->nr3101801 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3101801']);
        if (isset($o['nr3101701'])) $this->nr3101701 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3101701']);
        if (isset($o['nr3101702'])) $this->nr3101702 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3101702']);
        if (isset($o['nr3102301'])) $this->nr3102301 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3102301']);
        if (isset($o['nr3102302'])) $this->nr3102302 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3102302']);
        if (isset($o['nr3102303'])) $this->nr3102303 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3102303']);
        if (isset($o['nr3102304'])) $this->nr3102304 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3102304']);
        if (isset($o['nr3102401'])) $this->nr3102401 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3102401']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nr3101801)) $o['nr3101801'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3101801);
        if (isset($this->nr3101701)) $o['nr3101701'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3101701);
        if (isset($this->nr3101702)) $o['nr3101702'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3101702);
        if (isset($this->nr3102301)) $o['nr3102301'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3102301);
        if (isset($this->nr3102302)) $o['nr3102302'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3102302);
        if (isset($this->nr3102303)) $o['nr3102303'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3102303);
        if (isset($this->nr3102304)) $o['nr3102304'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3102304);
        if (isset($this->nr3102401)) $o['nr3102401'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3102401);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Leistungsempfänger als Steuerschuldner der Umsatzsteuererklärung für 2020. */
// @Api(Description="Leistungsempfänger als Steuerschuldner der Umsatzsteuererklärung für 2020.")
class LeistungsempfaengerAlsSteuerschuldner2020 implements JsonSerializable
{
    public function __construct(
        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3102205=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3102206=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3102307=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3102308=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3102503=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3102504=null,

        /** @description Summe der Steuer (zu übertragen in Zeile 156) */
        // @ApiMember(Description="Summe der Steuer (zu übertragen in Zeile 156)", Name="Nr3102601")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3102601=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nr3102205'])) $this->nr3102205 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3102205']);
        if (isset($o['nr3102206'])) $this->nr3102206 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3102206']);
        if (isset($o['nr3102307'])) $this->nr3102307 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3102307']);
        if (isset($o['nr3102308'])) $this->nr3102308 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3102308']);
        if (isset($o['nr3102503'])) $this->nr3102503 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3102503']);
        if (isset($o['nr3102504'])) $this->nr3102504 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3102504']);
        if (isset($o['nr3102601'])) $this->nr3102601 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3102601']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nr3102205)) $o['nr3102205'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3102205);
        if (isset($this->nr3102206)) $o['nr3102206'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3102206);
        if (isset($this->nr3102307)) $o['nr3102307'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3102307);
        if (isset($this->nr3102308)) $o['nr3102308'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3102308);
        if (isset($this->nr3102503)) $o['nr3102503'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3102503);
        if (isset($this->nr3102504)) $o['nr3102504'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3102504);
        if (isset($this->nr3102601)) $o['nr3102601'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3102601);
        return empty($o) ? new class(){} : $o;
    }
}

/** @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.")
class PositiverGeldBetragOhneCent12DE extends GrossGeldBetragOhneCent implements JsonSerializable
{
    /**
     * @param int $wert
     */
    public function __construct(
        int $wert=0
    ) {
        parent::__construct($wert);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['wert'])) $this->wert = $o['wert'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->wert)) $o['wert'] = $this->wert;
        return empty($o) ? new class(){} : $o;
    }
}

/** @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.")
class PositiverGeldBetragOhneCent12DEFeld extends CustomFeldBase implements JsonSerializable
{
    /**
     * @param int $nr
     * @param int $index
     * @param int $lfdNr
     * @param string|null $alias
     */
    public function __construct(
        int $nr=0,
        int $index=0,
        int $lfdNr=0,
        ?string $alias=null,
        /** @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)
        /** @var PositiverGeldBetragOhneCent12DE|null */
        public ?PositiverGeldBetragOhneCent12DE $betrag=null
    ) {
        parent::__construct($nr,$index,$lfdNr,$alias);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['betrag'])) $this->betrag = JsonConverters::from('PositiverGeldBetragOhneCent12DE', $o['betrag']);
        if (isset($o['nr'])) $this->nr = $o['nr'];
        if (isset($o['index'])) $this->index = $o['index'];
        if (isset($o['lfdNr'])) $this->lfdNr = $o['lfdNr'];
        if (isset($o['alias'])) $this->alias = $o['alias'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->betrag)) $o['betrag'] = JsonConverters::to('PositiverGeldBetragOhneCent12DE', $this->betrag);
        if (isset($this->nr)) $o['nr'] = $this->nr;
        if (isset($this->index)) $o['index'] = $this->index;
        if (isset($this->lfdNr)) $o['lfdNr'] = $this->lfdNr;
        if (isset($this->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Ergänzende Angaben der Umsatzsteuererklärung für 2020. */
// @Api(Description="Ergänzende Angaben der Umsatzsteuererklärung für 2020.")
class ErgaenzendeAngaben2020 implements JsonSerializable
{
    public function __construct(
        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3105201=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3105301=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3105501=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3105601=null,

        /** @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")
        /** @var PositiverGeldBetragOhneCent12DEFeld|null */
        public ?PositiverGeldBetragOhneCent12DEFeld $nr3105101=null,

        /** @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")
        /** @var PositiverGeldBetragOhneCent12DEFeld|null */
        public ?PositiverGeldBetragOhneCent12DEFeld $nr3105102=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3105602=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3105702=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3105801=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3105901=null,

        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3106001=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nr3105201'])) $this->nr3105201 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3105201']);
        if (isset($o['nr3105301'])) $this->nr3105301 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3105301']);
        if (isset($o['nr3105501'])) $this->nr3105501 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3105501']);
        if (isset($o['nr3105601'])) $this->nr3105601 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3105601']);
        if (isset($o['nr3105101'])) $this->nr3105101 = JsonConverters::from('PositiverGeldBetragOhneCent12DEFeld', $o['nr3105101']);
        if (isset($o['nr3105102'])) $this->nr3105102 = JsonConverters::from('PositiverGeldBetragOhneCent12DEFeld', $o['nr3105102']);
        if (isset($o['nr3105602'])) $this->nr3105602 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3105602']);
        if (isset($o['nr3105702'])) $this->nr3105702 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3105702']);
        if (isset($o['nr3105801'])) $this->nr3105801 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3105801']);
        if (isset($o['nr3105901'])) $this->nr3105901 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3105901']);
        if (isset($o['nr3106001'])) $this->nr3106001 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3106001']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nr3105201)) $o['nr3105201'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3105201);
        if (isset($this->nr3105301)) $o['nr3105301'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3105301);
        if (isset($this->nr3105501)) $o['nr3105501'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3105501);
        if (isset($this->nr3105601)) $o['nr3105601'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3105601);
        if (isset($this->nr3105101)) $o['nr3105101'] = JsonConverters::to('PositiverGeldBetragOhneCent12DEFeld', $this->nr3105101);
        if (isset($this->nr3105102)) $o['nr3105102'] = JsonConverters::to('PositiverGeldBetragOhneCent12DEFeld', $this->nr3105102);
        if (isset($this->nr3105602)) $o['nr3105602'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3105602);
        if (isset($this->nr3105702)) $o['nr3105702'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3105702);
        if (isset($this->nr3105801)) $o['nr3105801'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3105801);
        if (isset($this->nr3105901)) $o['nr3105901'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3105901);
        if (isset($this->nr3106001)) $o['nr3106001'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3106001);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Abziehbare Vorsteuerbeträge der Umsatzsteuererklärung für 2020. */
// @Api(Description="Abziehbare Vorsteuerbeträge der Umsatzsteuererklärung für 2020.")
class AbziehbareVorsteuerbetraege2020 implements JsonSerializable
{
    public function __construct(
        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3006201=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3006301=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3006401=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3006503=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3006502=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3006501=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3006601=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3006701=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3006801=null,

        /** @description Summe der Vorsteuerbeträge (zu übertragen in Zeile 158) */
        // @ApiMember(Description="Summe der Vorsteuerbeträge (zu übertragen in Zeile 158)", Name="Nr3006901")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3006901=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nr3006201'])) $this->nr3006201 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3006201']);
        if (isset($o['nr3006301'])) $this->nr3006301 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3006301']);
        if (isset($o['nr3006401'])) $this->nr3006401 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3006401']);
        if (isset($o['nr3006503'])) $this->nr3006503 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3006503']);
        if (isset($o['nr3006502'])) $this->nr3006502 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3006502']);
        if (isset($o['nr3006501'])) $this->nr3006501 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3006501']);
        if (isset($o['nr3006601'])) $this->nr3006601 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3006601']);
        if (isset($o['nr3006701'])) $this->nr3006701 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3006701']);
        if (isset($o['nr3006801'])) $this->nr3006801 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3006801']);
        if (isset($o['nr3006901'])) $this->nr3006901 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3006901']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nr3006201)) $o['nr3006201'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3006201);
        if (isset($this->nr3006301)) $o['nr3006301'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3006301);
        if (isset($this->nr3006401)) $o['nr3006401'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3006401);
        if (isset($this->nr3006503)) $o['nr3006503'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3006503);
        if (isset($this->nr3006502)) $o['nr3006502'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3006502);
        if (isset($this->nr3006501)) $o['nr3006501'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3006501);
        if (isset($this->nr3006601)) $o['nr3006601'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3006601);
        if (isset($this->nr3006701)) $o['nr3006701'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3006701);
        if (isset($this->nr3006801)) $o['nr3006801'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3006801);
        if (isset($this->nr3006901)) $o['nr3006901'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3006901);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Datums-Uhrzeitfeld. Format: TT.MM.JJJJ. */
// @Api(Description="Datums-Uhrzeitfeld. Format: TT.MM.JJJJ.")
class DatumUhrzeitFeld extends CustomFeldBase implements JsonSerializable
{
    /**
     * @param int $nr
     * @param int $index
     * @param int $lfdNr
     * @param string|null $alias
     */
    public function __construct(
        int $nr=0,
        int $index=0,
        int $lfdNr=0,
        ?string $alias=null,
        /** @description Wert des Feldes. */
        // @ApiMember(Description="Wert des Feldes.", IsRequired=true, Name="Wert")
        /** @var DateTime */
        public DateTime $wert=new DateTime()
    ) {
        parent::__construct($nr,$index,$lfdNr,$alias);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['wert'])) $this->wert = JsonConverters::from('DateTime', $o['wert']);
        if (isset($o['nr'])) $this->nr = $o['nr'];
        if (isset($o['index'])) $this->index = $o['index'];
        if (isset($o['lfdNr'])) $this->lfdNr = $o['lfdNr'];
        if (isset($o['alias'])) $this->alias = $o['alias'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->wert)) $o['wert'] = JsonConverters::to('DateTime', $this->wert);
        if (isset($this->nr)) $o['nr'] = $this->nr;
        if (isset($this->index)) $o['index'] = $this->index;
        if (isset($this->lfdNr)) $o['lfdNr'] = $this->lfdNr;
        if (isset($this->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @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.")
class PositiverGeldBetragMitCent13DE extends GeldBetragMitCent implements JsonSerializable
{
    /**
     * @param float $wert
     */
    public function __construct(
        float $wert=0.0
    ) {
        parent::__construct($wert);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['wert'])) $this->wert = $o['wert'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->wert)) $o['wert'] = $this->wert;
        return empty($o) ? new class(){} : $o;
    }
}

/** @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.")
class PositiverGeldBetragMitCent13DEFeld extends CustomFeldBase implements JsonSerializable
{
    /**
     * @param int $nr
     * @param int $index
     * @param int $lfdNr
     * @param string|null $alias
     */
    public function __construct(
        int $nr=0,
        int $index=0,
        int $lfdNr=0,
        ?string $alias=null,
        /** @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)
        /** @var PositiverGeldBetragMitCent13DE|null */
        public ?PositiverGeldBetragMitCent13DE $betrag=null
    ) {
        parent::__construct($nr,$index,$lfdNr,$alias);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['betrag'])) $this->betrag = JsonConverters::from('PositiverGeldBetragMitCent13DE', $o['betrag']);
        if (isset($o['nr'])) $this->nr = $o['nr'];
        if (isset($o['index'])) $this->index = $o['index'];
        if (isset($o['lfdNr'])) $this->lfdNr = $o['lfdNr'];
        if (isset($o['alias'])) $this->alias = $o['alias'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->betrag)) $o['betrag'] = JsonConverters::to('PositiverGeldBetragMitCent13DE', $this->betrag);
        if (isset($this->nr)) $o['nr'] = $this->nr;
        if (isset($this->index)) $o['index'] = $this->index;
        if (isset($this->lfdNr)) $o['lfdNr'] = $this->lfdNr;
        if (isset($this->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @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.")
class PositiverGeldBetragMitCent12DE extends GeldBetragMitCent implements JsonSerializable
{
    /**
     * @param float $wert
     */
    public function __construct(
        float $wert=0.0
    ) {
        parent::__construct($wert);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['wert'])) $this->wert = $o['wert'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->wert)) $o['wert'] = $this->wert;
        return empty($o) ? new class(){} : $o;
    }
}

/** @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.")
class PositiverGeldBetragMitCent12DEFeld extends CustomFeldBase implements JsonSerializable
{
    /**
     * @param int $nr
     * @param int $index
     * @param int $lfdNr
     * @param string|null $alias
     */
    public function __construct(
        int $nr=0,
        int $index=0,
        int $lfdNr=0,
        ?string $alias=null,
        /** @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)
        /** @var PositiverGeldBetragMitCent12DE|null */
        public ?PositiverGeldBetragMitCent12DE $betrag=null
    ) {
        parent::__construct($nr,$index,$lfdNr,$alias);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['betrag'])) $this->betrag = JsonConverters::from('PositiverGeldBetragMitCent12DE', $o['betrag']);
        if (isset($o['nr'])) $this->nr = $o['nr'];
        if (isset($o['index'])) $this->index = $o['index'];
        if (isset($o['lfdNr'])) $this->lfdNr = $o['lfdNr'];
        if (isset($o['alias'])) $this->alias = $o['alias'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->betrag)) $o['betrag'] = JsonConverters::to('PositiverGeldBetragMitCent12DE', $this->betrag);
        if (isset($this->nr)) $o['nr'] = $this->nr;
        if (isset($this->index)) $o['index'] = $this->index;
        if (isset($this->lfdNr)) $o['lfdNr'] = $this->lfdNr;
        if (isset($this->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Berichtigung des Vorsteuerabzugs der Umsatzsteuererklärung für 2020. */
// @Api(Description="Berichtigung des Vorsteuerabzugs der Umsatzsteuererklärung für 2020.")
class BerichtigungVorsteuerabzug2020 implements JsonSerializable
{
    public function __construct(
        /** @description Berichtigung des Vorsteuerabzugs? Falls ja, bitte eine 'true' eintragen */
        // @ApiMember(Description="Berichtigung des Vorsteuerabzugs? Falls ja, bitte eine 'true' eintragen", Name="Nr3007301")
        /** @var Bool1Feld|null */
        public ?Bool1Feld $nr3007301=null,

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

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

        /** @description Art der Verwendung im Erstjahr */
        // @ApiMember(Description="Art der Verwendung im Erstjahr", Name="Nr3007403")
        /** @var StringFeld|null */
        public ?StringFeld $nr3007403=null,

        /** @description Umfang der Verwendung im Erstjahr */
        // @ApiMember(Description="Umfang der Verwendung im Erstjahr", Name="Nr3007404")
        /** @var PositiverGeldBetragMitCent13DEFeld|null */
        public ?PositiverGeldBetragMitCent13DEFeld $nr3007404=null,

        /** @description insgesamt angefallene Vorsteuer */
        // @ApiMember(Description="insgesamt angefallene Vorsteuer", Name="Nr3007405")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3007405=null,

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

        /** @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")
        /** @var Bool1Feld|null */
        public ?Bool1Feld $nr3007601=null,

        /** @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")
        /** @var Bool1Feld|null */
        public ?Bool1Feld $nr3008501=null,

        /** @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")
        /** @var Bool1Feld|null */
        public ?Bool1Feld $nr3008601=null,

        /** @description Veräußerung */
        // @ApiMember(Description="Veräußerung", Name="Nr3007801")
        /** @var BoolXFeld|null */
        public ?BoolXFeld $nr3007801=null,

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

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

        /** @description Nutzungsänderung, und zwar */
        // @ApiMember(Description="Nutzungsänderung, und zwar", Name="Nr3007901")
        /** @var BoolXFeld|null */
        public ?BoolXFeld $nr3007901=null,

        /** @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")
        /** @var BoolXFeld|null */
        public ?BoolXFeld $nr3008001=null,

        /** @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")
        /** @var BoolXFeld|null */
        public ?BoolXFeld $nr3008202=null,

        /** @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")
        /** @var BoolXFeld|null */
        public ?BoolXFeld $nr3008401=null,

        /** @description Begründung */
        // @ApiMember(Description="Begründung", Name="Nr3008402")
        /** @var StringFeld|null */
        public ?StringFeld $nr3008402=null,

        /** @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")
        /** @var PositiverGeldBetragMitCent12DEFeld|null */
        public ?PositiverGeldBetragMitCent12DEFeld $nr3008701=null,

        /** @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")
        /** @var PositiverGeldBetragMitCent12DEFeld|null */
        public ?PositiverGeldBetragMitCent12DEFeld $nr3008702=null,

        /** @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")
        /** @var PositiverGeldBetragMitCent12DEFeld|null */
        public ?PositiverGeldBetragMitCent12DEFeld $nr3008801=null,

        /** @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")
        /** @var PositiverGeldBetragMitCent12DEFeld|null */
        public ?PositiverGeldBetragMitCent12DEFeld $nr3008802=null,

        /** @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")
        /** @var PositiverGeldBetragMitCent12DEFeld|null */
        public ?PositiverGeldBetragMitCent12DEFeld $nr3008803=null,

        /** @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")
        /** @var PositiverGeldBetragMitCent12DEFeld|null */
        public ?PositiverGeldBetragMitCent12DEFeld $nr3008804=null,

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

        /** @description Summe zurückzuzahlen (zu übertragen in Zeile 161) */
        // @ApiMember(Description="Summe zurückzuzahlen (zu übertragen in Zeile 161)", Name="Nr3008902")
        /** @var PositiverGeldBetragMitCent12DEFeld|null */
        public ?PositiverGeldBetragMitCent12DEFeld $nr3008902=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nr3007301'])) $this->nr3007301 = JsonConverters::from('Bool1Feld', $o['nr3007301']);
        if (isset($o['nr3007401'])) $this->nr3007401 = JsonConverters::from('StringFeld', $o['nr3007401']);
        if (isset($o['nr3007402'])) $this->nr3007402 = JsonConverters::from('DatumUhrzeitFeld', $o['nr3007402']);
        if (isset($o['nr3007403'])) $this->nr3007403 = JsonConverters::from('StringFeld', $o['nr3007403']);
        if (isset($o['nr3007404'])) $this->nr3007404 = JsonConverters::from('PositiverGeldBetragMitCent13DEFeld', $o['nr3007404']);
        if (isset($o['nr3007405'])) $this->nr3007405 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3007405']);
        if (isset($o['nr3007406'])) $this->nr3007406 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3007406']);
        if (isset($o['nr3007601'])) $this->nr3007601 = JsonConverters::from('Bool1Feld', $o['nr3007601']);
        if (isset($o['nr3008501'])) $this->nr3008501 = JsonConverters::from('Bool1Feld', $o['nr3008501']);
        if (isset($o['nr3008601'])) $this->nr3008601 = JsonConverters::from('Bool1Feld', $o['nr3008601']);
        if (isset($o['nr3007801'])) $this->nr3007801 = JsonConverters::from('BoolXFeld', $o['nr3007801']);
        if (isset($o['nr3007802'])) $this->nr3007802 = JsonConverters::from('BoolXFeld', $o['nr3007802']);
        if (isset($o['nr3007803'])) $this->nr3007803 = JsonConverters::from('BoolXFeld', $o['nr3007803']);
        if (isset($o['nr3007901'])) $this->nr3007901 = JsonConverters::from('BoolXFeld', $o['nr3007901']);
        if (isset($o['nr3008001'])) $this->nr3008001 = JsonConverters::from('BoolXFeld', $o['nr3008001']);
        if (isset($o['nr3008202'])) $this->nr3008202 = JsonConverters::from('BoolXFeld', $o['nr3008202']);
        if (isset($o['nr3008401'])) $this->nr3008401 = JsonConverters::from('BoolXFeld', $o['nr3008401']);
        if (isset($o['nr3008402'])) $this->nr3008402 = JsonConverters::from('StringFeld', $o['nr3008402']);
        if (isset($o['nr3008701'])) $this->nr3008701 = JsonConverters::from('PositiverGeldBetragMitCent12DEFeld', $o['nr3008701']);
        if (isset($o['nr3008702'])) $this->nr3008702 = JsonConverters::from('PositiverGeldBetragMitCent12DEFeld', $o['nr3008702']);
        if (isset($o['nr3008801'])) $this->nr3008801 = JsonConverters::from('PositiverGeldBetragMitCent12DEFeld', $o['nr3008801']);
        if (isset($o['nr3008802'])) $this->nr3008802 = JsonConverters::from('PositiverGeldBetragMitCent12DEFeld', $o['nr3008802']);
        if (isset($o['nr3008803'])) $this->nr3008803 = JsonConverters::from('PositiverGeldBetragMitCent12DEFeld', $o['nr3008803']);
        if (isset($o['nr3008804'])) $this->nr3008804 = JsonConverters::from('PositiverGeldBetragMitCent12DEFeld', $o['nr3008804']);
        if (isset($o['nr3008901'])) $this->nr3008901 = JsonConverters::from('PositiverGeldBetragMitCent12DEFeld', $o['nr3008901']);
        if (isset($o['nr3008902'])) $this->nr3008902 = JsonConverters::from('PositiverGeldBetragMitCent12DEFeld', $o['nr3008902']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nr3007301)) $o['nr3007301'] = JsonConverters::to('Bool1Feld', $this->nr3007301);
        if (isset($this->nr3007401)) $o['nr3007401'] = JsonConverters::to('StringFeld', $this->nr3007401);
        if (isset($this->nr3007402)) $o['nr3007402'] = JsonConverters::to('DatumUhrzeitFeld', $this->nr3007402);
        if (isset($this->nr3007403)) $o['nr3007403'] = JsonConverters::to('StringFeld', $this->nr3007403);
        if (isset($this->nr3007404)) $o['nr3007404'] = JsonConverters::to('PositiverGeldBetragMitCent13DEFeld', $this->nr3007404);
        if (isset($this->nr3007405)) $o['nr3007405'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3007405);
        if (isset($this->nr3007406)) $o['nr3007406'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3007406);
        if (isset($this->nr3007601)) $o['nr3007601'] = JsonConverters::to('Bool1Feld', $this->nr3007601);
        if (isset($this->nr3008501)) $o['nr3008501'] = JsonConverters::to('Bool1Feld', $this->nr3008501);
        if (isset($this->nr3008601)) $o['nr3008601'] = JsonConverters::to('Bool1Feld', $this->nr3008601);
        if (isset($this->nr3007801)) $o['nr3007801'] = JsonConverters::to('BoolXFeld', $this->nr3007801);
        if (isset($this->nr3007802)) $o['nr3007802'] = JsonConverters::to('BoolXFeld', $this->nr3007802);
        if (isset($this->nr3007803)) $o['nr3007803'] = JsonConverters::to('BoolXFeld', $this->nr3007803);
        if (isset($this->nr3007901)) $o['nr3007901'] = JsonConverters::to('BoolXFeld', $this->nr3007901);
        if (isset($this->nr3008001)) $o['nr3008001'] = JsonConverters::to('BoolXFeld', $this->nr3008001);
        if (isset($this->nr3008202)) $o['nr3008202'] = JsonConverters::to('BoolXFeld', $this->nr3008202);
        if (isset($this->nr3008401)) $o['nr3008401'] = JsonConverters::to('BoolXFeld', $this->nr3008401);
        if (isset($this->nr3008402)) $o['nr3008402'] = JsonConverters::to('StringFeld', $this->nr3008402);
        if (isset($this->nr3008701)) $o['nr3008701'] = JsonConverters::to('PositiverGeldBetragMitCent12DEFeld', $this->nr3008701);
        if (isset($this->nr3008702)) $o['nr3008702'] = JsonConverters::to('PositiverGeldBetragMitCent12DEFeld', $this->nr3008702);
        if (isset($this->nr3008801)) $o['nr3008801'] = JsonConverters::to('PositiverGeldBetragMitCent12DEFeld', $this->nr3008801);
        if (isset($this->nr3008802)) $o['nr3008802'] = JsonConverters::to('PositiverGeldBetragMitCent12DEFeld', $this->nr3008802);
        if (isset($this->nr3008803)) $o['nr3008803'] = JsonConverters::to('PositiverGeldBetragMitCent12DEFeld', $this->nr3008803);
        if (isset($this->nr3008804)) $o['nr3008804'] = JsonConverters::to('PositiverGeldBetragMitCent12DEFeld', $this->nr3008804);
        if (isset($this->nr3008901)) $o['nr3008901'] = JsonConverters::to('PositiverGeldBetragMitCent12DEFeld', $this->nr3008901);
        if (isset($this->nr3008902)) $o['nr3008902'] = JsonConverters::to('PositiverGeldBetragMitCent12DEFeld', $this->nr3008902);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Berechnung der Umsatzsteuer der Umsatzsteuererklärung für 2020. */
// @Api(Description="Berechnung der Umsatzsteuer der Umsatzsteuererklärung für 2020.")
class BerechnungUmsatzsteuer2020 implements JsonSerializable
{
    public function __construct(
        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3009201=null,

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

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3009602=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3009501=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3009502=null,

        /** @description Zwischensumme */
        // @ApiMember(Description="Zwischensumme", Name="Nr3009801")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3009801=null,

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

        /** @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")
        /** @var PositiverGeldBetragMitCent12DEFeld|null */
        public ?PositiverGeldBetragMitCent12DEFeld $nr3010001=null,

        /** @description Verbleibender Betrag */
        // @ApiMember(Description="Verbleibender Betrag", Name="Nr3010201")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3010201=null,

        /** @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")
        /** @var PositiverGeldBetragMitCent12DEFeld|null */
        public ?PositiverGeldBetragMitCent12DEFeld $nr3009701=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3010301=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3010401=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3010501=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3010601=null,

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

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3011101=null,

        /** @description Vorauszahlungssoll 2020 (einschließlich Sondervorauszahlung) */
        // @ApiMember(Description="Vorauszahlungssoll 2020 (einschließlich Sondervorauszahlung)", IsRequired=true, Name="Nr3011301")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3011301=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3011401=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nr3009201'])) $this->nr3009201 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3009201']);
        if (isset($o['nr3009401'])) $this->nr3009401 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3009401']);
        if (isset($o['nr3009602'])) $this->nr3009602 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3009602']);
        if (isset($o['nr3009501'])) $this->nr3009501 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3009501']);
        if (isset($o['nr3009502'])) $this->nr3009502 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3009502']);
        if (isset($o['nr3009801'])) $this->nr3009801 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3009801']);
        if (isset($o['nr3009901'])) $this->nr3009901 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3009901']);
        if (isset($o['nr3010001'])) $this->nr3010001 = JsonConverters::from('PositiverGeldBetragMitCent12DEFeld', $o['nr3010001']);
        if (isset($o['nr3010201'])) $this->nr3010201 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3010201']);
        if (isset($o['nr3009701'])) $this->nr3009701 = JsonConverters::from('PositiverGeldBetragMitCent12DEFeld', $o['nr3009701']);
        if (isset($o['nr3010301'])) $this->nr3010301 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3010301']);
        if (isset($o['nr3010401'])) $this->nr3010401 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3010401']);
        if (isset($o['nr3010501'])) $this->nr3010501 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3010501']);
        if (isset($o['nr3010601'])) $this->nr3010601 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3010601']);
        if (isset($o['nr3010602'])) $this->nr3010602 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3010602']);
        if (isset($o['nr3011101'])) $this->nr3011101 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3011101']);
        if (isset($o['nr3011301'])) $this->nr3011301 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3011301']);
        if (isset($o['nr3011401'])) $this->nr3011401 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3011401']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nr3009201)) $o['nr3009201'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3009201);
        if (isset($this->nr3009401)) $o['nr3009401'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3009401);
        if (isset($this->nr3009602)) $o['nr3009602'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3009602);
        if (isset($this->nr3009501)) $o['nr3009501'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3009501);
        if (isset($this->nr3009502)) $o['nr3009502'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3009502);
        if (isset($this->nr3009801)) $o['nr3009801'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3009801);
        if (isset($this->nr3009901)) $o['nr3009901'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3009901);
        if (isset($this->nr3010001)) $o['nr3010001'] = JsonConverters::to('PositiverGeldBetragMitCent12DEFeld', $this->nr3010001);
        if (isset($this->nr3010201)) $o['nr3010201'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3010201);
        if (isset($this->nr3009701)) $o['nr3009701'] = JsonConverters::to('PositiverGeldBetragMitCent12DEFeld', $this->nr3009701);
        if (isset($this->nr3010301)) $o['nr3010301'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3010301);
        if (isset($this->nr3010401)) $o['nr3010401'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3010401);
        if (isset($this->nr3010501)) $o['nr3010501'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3010501);
        if (isset($this->nr3010601)) $o['nr3010601'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3010601);
        if (isset($this->nr3010602)) $o['nr3010602'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3010602);
        if (isset($this->nr3011101)) $o['nr3011101'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3011101);
        if (isset($this->nr3011301)) $o['nr3011301'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3011301);
        if (isset($this->nr3011401)) $o['nr3011401'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3011401);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Unterschrift der Umsatzsteuererklärung für 2020. */
// @Api(Description="Unterschrift der Umsatzsteuererklärung für 2020.")
class Unterschrift2020 implements JsonSerializable
{
    public function __construct(
        /** @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")
        /** @var Bool1Feld|null */
        public ?Bool1Feld $nr3002602=null,

        /** @description Name */
        // @ApiMember(Description="Name", Name="Nr3002501")
        /** @var StringFeld|null */
        public ?StringFeld $nr3002501=null,

        /** @description Vorname */
        // @ApiMember(Description="Vorname", Name="Nr3002502")
        /** @var StringFeld|null */
        public ?StringFeld $nr3002502=null,

        /** @description Straße, Hausnummer */
        // @ApiMember(Description="Straße, Hausnummer", Name="Nr3002503")
        /** @var StringFeld|null */
        public ?StringFeld $nr3002503=null,

        /** @description Postleitzahl, Wohnort */
        // @ApiMember(Description="Postleitzahl, Wohnort", Name="Nr3002504")
        /** @var StringFeld|null */
        public ?StringFeld $nr3002504=null,

        /** @description Telefon */
        // @ApiMember(Description="Telefon", Name="Nr3002505")
        /** @var StringFeld|null */
        public ?StringFeld $nr3002505=null,

        /** @description Mandantennummer */
        // @ApiMember(Description="Mandantennummer", Name="Nr3002506")
        /** @var StringFeld|null */
        public ?StringFeld $nr3002506=null,

        /** @description Mandantennummer für elektronische Bescheiddatenabholung */
        // @ApiMember(Description="Mandantennummer für elektronische Bescheiddatenabholung", Name="Nr3002507")
        /** @var StringFeld|null */
        public ?StringFeld $nr3002507=null,

        /** @description zusätzliche Angaben */
        // @ApiMember(Description="zusätzliche Angaben", Name="Nr3002508")
        /** @var StringFeld|null */
        public ?StringFeld $nr3002508=null,

        /** @description Bearbeiterkennzeichen */
        // @ApiMember(Description="Bearbeiterkennzeichen", Name="Nr3002509")
        /** @var StringFeld|null */
        public ?StringFeld $nr3002509=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nr3002602'])) $this->nr3002602 = JsonConverters::from('Bool1Feld', $o['nr3002602']);
        if (isset($o['nr3002501'])) $this->nr3002501 = JsonConverters::from('StringFeld', $o['nr3002501']);
        if (isset($o['nr3002502'])) $this->nr3002502 = JsonConverters::from('StringFeld', $o['nr3002502']);
        if (isset($o['nr3002503'])) $this->nr3002503 = JsonConverters::from('StringFeld', $o['nr3002503']);
        if (isset($o['nr3002504'])) $this->nr3002504 = JsonConverters::from('StringFeld', $o['nr3002504']);
        if (isset($o['nr3002505'])) $this->nr3002505 = JsonConverters::from('StringFeld', $o['nr3002505']);
        if (isset($o['nr3002506'])) $this->nr3002506 = JsonConverters::from('StringFeld', $o['nr3002506']);
        if (isset($o['nr3002507'])) $this->nr3002507 = JsonConverters::from('StringFeld', $o['nr3002507']);
        if (isset($o['nr3002508'])) $this->nr3002508 = JsonConverters::from('StringFeld', $o['nr3002508']);
        if (isset($o['nr3002509'])) $this->nr3002509 = JsonConverters::from('StringFeld', $o['nr3002509']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nr3002602)) $o['nr3002602'] = JsonConverters::to('Bool1Feld', $this->nr3002602);
        if (isset($this->nr3002501)) $o['nr3002501'] = JsonConverters::to('StringFeld', $this->nr3002501);
        if (isset($this->nr3002502)) $o['nr3002502'] = JsonConverters::to('StringFeld', $this->nr3002502);
        if (isset($this->nr3002503)) $o['nr3002503'] = JsonConverters::to('StringFeld', $this->nr3002503);
        if (isset($this->nr3002504)) $o['nr3002504'] = JsonConverters::to('StringFeld', $this->nr3002504);
        if (isset($this->nr3002505)) $o['nr3002505'] = JsonConverters::to('StringFeld', $this->nr3002505);
        if (isset($this->nr3002506)) $o['nr3002506'] = JsonConverters::to('StringFeld', $this->nr3002506);
        if (isset($this->nr3002507)) $o['nr3002507'] = JsonConverters::to('StringFeld', $this->nr3002507);
        if (isset($this->nr3002508)) $o['nr3002508'] = JsonConverters::to('StringFeld', $this->nr3002508);
        if (isset($this->nr3002509)) $o['nr3002509'] = JsonConverters::to('StringFeld', $this->nr3002509);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Allgemeine Angaben der Anlage UN für 2020. */
// @Api(Description="Allgemeine Angaben der Anlage UN für 2020.")
class AnlageUnAllgemeineAngaben2020 implements JsonSerializable
{
    public function __construct(
        /** @description IBAN */
        // @ApiMember(Description="IBAN", Name="Nr3201001")
        /** @var StringFeld|null */
        public ?StringFeld $nr3201001=null,

        /** @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")
        /** @var StringFeld|null */
        public ?StringFeld $nr3201002=null,

        /** @description Name des Geldinstituts (Zweigstelle) und Ort */
        // @ApiMember(Description="Name des Geldinstituts (Zweigstelle) und Ort", Name="Nr3200901")
        /** @var StringFeld|null */
        public ?StringFeld $nr3200901=null,

        /** @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")
        /** @var StringFeld|null */
        public ?StringFeld $nr3200902=null,

        /** @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")
        /** @var BoolXFeld|null */
        public ?BoolXFeld $nr3200904=null,

        /** @description Name des Kontoinhabers */
        // @ApiMember(Description="Name des Kontoinhabers", Name="Nr3200905")
        /** @var StringFeld|null */
        public ?StringFeld $nr3200905=null,

        /** @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")
        /** @var BoolXFeld|null */
        public ?BoolXFeld $nr3201301=null,

        /** @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")
        /** @var BoolXFeld|null */
        public ?BoolXFeld $nr3201401=null,

        /** @description Name */
        // @ApiMember(Description="Name", Name="Nr3201501")
        /** @var StringFeld|null */
        public ?StringFeld $nr3201501=null,

        /** @description Straße */
        // @ApiMember(Description="Straße", Name="Nr3201601")
        /** @var StringFeld|null */
        public ?StringFeld $nr3201601=null,

        /** @description Hausnummer */
        // @ApiMember(Description="Hausnummer", Name="Nr3201302")
        /** @var StringFeld|null */
        public ?StringFeld $nr3201302=null,

        /** @description Hausnummerzusatz */
        // @ApiMember(Description="Hausnummerzusatz", Name="Nr3201303")
        /** @var StringFeld|null */
        public ?StringFeld $nr3201303=null,

        /** @description Adressergänzung */
        // @ApiMember(Description="Adressergänzung", Name="Nr3201304")
        /** @var StringFeld|null */
        public ?StringFeld $nr3201304=null,

        /** @description Postleitzahl, Ort */
        // @ApiMember(Description="Postleitzahl, Ort", Name="Nr3201402")
        /** @var StringFeld|null */
        public ?StringFeld $nr3201402=null,

        /** @description Postleitzahl zu Postfach */
        // @ApiMember(Description="Postleitzahl zu Postfach", Name="Nr3201503")
        /** @var StringFeld|null */
        public ?StringFeld $nr3201503=null,

        /** @description Postfach */
        // @ApiMember(Description="Postfach", Name="Nr3201504")
        /** @var StringFeld|null */
        public ?StringFeld $nr3201504=null,

        /** @description E-Mail-Adresse */
        // @ApiMember(Description="E-Mail-Adresse", Name="Nr3201502")
        /** @var StringFeld|null */
        public ?StringFeld $nr3201502=null,

        /** @description Telefon */
        // @ApiMember(Description="Telefon", Name="Nr3201602")
        /** @var StringFeld|null */
        public ?StringFeld $nr3201602=null,

        /** @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")
        /** @var BoolXFeld|null */
        public ?BoolXFeld $nr3201701=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nr3201001'])) $this->nr3201001 = JsonConverters::from('StringFeld', $o['nr3201001']);
        if (isset($o['nr3201002'])) $this->nr3201002 = JsonConverters::from('StringFeld', $o['nr3201002']);
        if (isset($o['nr3200901'])) $this->nr3200901 = JsonConverters::from('StringFeld', $o['nr3200901']);
        if (isset($o['nr3200902'])) $this->nr3200902 = JsonConverters::from('StringFeld', $o['nr3200902']);
        if (isset($o['nr3200904'])) $this->nr3200904 = JsonConverters::from('BoolXFeld', $o['nr3200904']);
        if (isset($o['nr3200905'])) $this->nr3200905 = JsonConverters::from('StringFeld', $o['nr3200905']);
        if (isset($o['nr3201301'])) $this->nr3201301 = JsonConverters::from('BoolXFeld', $o['nr3201301']);
        if (isset($o['nr3201401'])) $this->nr3201401 = JsonConverters::from('BoolXFeld', $o['nr3201401']);
        if (isset($o['nr3201501'])) $this->nr3201501 = JsonConverters::from('StringFeld', $o['nr3201501']);
        if (isset($o['nr3201601'])) $this->nr3201601 = JsonConverters::from('StringFeld', $o['nr3201601']);
        if (isset($o['nr3201302'])) $this->nr3201302 = JsonConverters::from('StringFeld', $o['nr3201302']);
        if (isset($o['nr3201303'])) $this->nr3201303 = JsonConverters::from('StringFeld', $o['nr3201303']);
        if (isset($o['nr3201304'])) $this->nr3201304 = JsonConverters::from('StringFeld', $o['nr3201304']);
        if (isset($o['nr3201402'])) $this->nr3201402 = JsonConverters::from('StringFeld', $o['nr3201402']);
        if (isset($o['nr3201503'])) $this->nr3201503 = JsonConverters::from('StringFeld', $o['nr3201503']);
        if (isset($o['nr3201504'])) $this->nr3201504 = JsonConverters::from('StringFeld', $o['nr3201504']);
        if (isset($o['nr3201502'])) $this->nr3201502 = JsonConverters::from('StringFeld', $o['nr3201502']);
        if (isset($o['nr3201602'])) $this->nr3201602 = JsonConverters::from('StringFeld', $o['nr3201602']);
        if (isset($o['nr3201701'])) $this->nr3201701 = JsonConverters::from('BoolXFeld', $o['nr3201701']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nr3201001)) $o['nr3201001'] = JsonConverters::to('StringFeld', $this->nr3201001);
        if (isset($this->nr3201002)) $o['nr3201002'] = JsonConverters::to('StringFeld', $this->nr3201002);
        if (isset($this->nr3200901)) $o['nr3200901'] = JsonConverters::to('StringFeld', $this->nr3200901);
        if (isset($this->nr3200902)) $o['nr3200902'] = JsonConverters::to('StringFeld', $this->nr3200902);
        if (isset($this->nr3200904)) $o['nr3200904'] = JsonConverters::to('BoolXFeld', $this->nr3200904);
        if (isset($this->nr3200905)) $o['nr3200905'] = JsonConverters::to('StringFeld', $this->nr3200905);
        if (isset($this->nr3201301)) $o['nr3201301'] = JsonConverters::to('BoolXFeld', $this->nr3201301);
        if (isset($this->nr3201401)) $o['nr3201401'] = JsonConverters::to('BoolXFeld', $this->nr3201401);
        if (isset($this->nr3201501)) $o['nr3201501'] = JsonConverters::to('StringFeld', $this->nr3201501);
        if (isset($this->nr3201601)) $o['nr3201601'] = JsonConverters::to('StringFeld', $this->nr3201601);
        if (isset($this->nr3201302)) $o['nr3201302'] = JsonConverters::to('StringFeld', $this->nr3201302);
        if (isset($this->nr3201303)) $o['nr3201303'] = JsonConverters::to('StringFeld', $this->nr3201303);
        if (isset($this->nr3201304)) $o['nr3201304'] = JsonConverters::to('StringFeld', $this->nr3201304);
        if (isset($this->nr3201402)) $o['nr3201402'] = JsonConverters::to('StringFeld', $this->nr3201402);
        if (isset($this->nr3201503)) $o['nr3201503'] = JsonConverters::to('StringFeld', $this->nr3201503);
        if (isset($this->nr3201504)) $o['nr3201504'] = JsonConverters::to('StringFeld', $this->nr3201504);
        if (isset($this->nr3201502)) $o['nr3201502'] = JsonConverters::to('StringFeld', $this->nr3201502);
        if (isset($this->nr3201602)) $o['nr3201602'] = JsonConverters::to('StringFeld', $this->nr3201602);
        if (isset($this->nr3201701)) $o['nr3201701'] = JsonConverters::to('BoolXFeld', $this->nr3201701);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Anrechenbare Beträge der Anlage UN für 2019. */
// @Api(Description="Anrechenbare Beträge der Anlage UN für 2019.")
class AnlageUnAnrechenbareBetraege2020 implements JsonSerializable
{
    public function __construct(
        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3201902=null,

        /** @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")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3202002=null,

        /** @description Summe (zu übertragen in Zeile 166 der Steuererklärung) */
        // @ApiMember(Description="Summe (zu übertragen in Zeile 166 der Steuererklärung)", Name="Nr3202102")
        /** @var GeldBetragMitCent12DEFeld|null */
        public ?GeldBetragMitCent12DEFeld $nr3202102=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nr3201902'])) $this->nr3201902 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3201902']);
        if (isset($o['nr3202002'])) $this->nr3202002 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3202002']);
        if (isset($o['nr3202102'])) $this->nr3202102 = JsonConverters::from('GeldBetragMitCent12DEFeld', $o['nr3202102']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nr3201902)) $o['nr3201902'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3201902);
        if (isset($this->nr3202002)) $o['nr3202002'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3202002);
        if (isset($this->nr3202102)) $o['nr3202102'] = JsonConverters::to('GeldBetragMitCent12DEFeld', $this->nr3202102);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Datums-Uhrzeitfeld. Format: TT.MM. */
// @Api(Description="Datums-Uhrzeitfeld. Format: TT.MM.")
class YearlessDateTimeFeld extends CustomFeldBase implements JsonSerializable
{
    /**
     * @param int $nr
     * @param int $index
     * @param int $lfdNr
     * @param string|null $alias
     */
    public function __construct(
        int $nr=0,
        int $index=0,
        int $lfdNr=0,
        ?string $alias=null,
        /** @description Wert des Feldes. */
        // @ApiMember(Description="Wert des Feldes.", IsRequired=true)
        /** @var DateTime */
        public DateTime $wert=new DateTime()
    ) {
        parent::__construct($nr,$index,$lfdNr,$alias);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['wert'])) $this->wert = JsonConverters::from('DateTime', $o['wert']);
        if (isset($o['nr'])) $this->nr = $o['nr'];
        if (isset($o['index'])) $this->index = $o['index'];
        if (isset($o['lfdNr'])) $this->lfdNr = $o['lfdNr'];
        if (isset($o['alias'])) $this->alias = $o['alias'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->wert)) $o['wert'] = JsonConverters::to('DateTime', $this->wert);
        if (isset($this->nr)) $o['nr'] = $this->nr;
        if (isset($this->index)) $o['index'] = $this->index;
        if (isset($this->lfdNr)) $o['lfdNr'] = $this->lfdNr;
        if (isset($this->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @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.")
class AnlageUnErgaenzendeAngabenZuUmsaetzen2020 implements JsonSerializable
{
    public function __construct(
        /** @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")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3201901=null,

        /** @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")
        /** @var StringFeld|null */
        public ?StringFeld $nr3202901=null,

        /** @description für Besteuerungszeitraum 2020 (vom) */
        // @ApiMember(Description="für Besteuerungszeitraum 2020 (vom)", Name="Nr3202902")
        /** @var YearlessDateTimeFeld|null */
        public ?YearlessDateTimeFeld $nr3202902=null,

        /** @description bis zum Besteuerungszeitraum 2020 (bis) */
        // @ApiMember(Description="bis zum Besteuerungszeitraum 2020 (bis)", Name="Nr3202903")
        /** @var YearlessDateTimeFeld|null */
        public ?YearlessDateTimeFeld $nr3202903=null,

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

        /** @description Betrag (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
        // @ApiMember(Description="Betrag (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="Nr3202905")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3202905=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nr3201901'])) $this->nr3201901 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3201901']);
        if (isset($o['nr3202901'])) $this->nr3202901 = JsonConverters::from('StringFeld', $o['nr3202901']);
        if (isset($o['nr3202902'])) $this->nr3202902 = JsonConverters::from('YearlessDateTimeFeld', $o['nr3202902']);
        if (isset($o['nr3202903'])) $this->nr3202903 = JsonConverters::from('YearlessDateTimeFeld', $o['nr3202903']);
        if (isset($o['nr3202904'])) $this->nr3202904 = JsonConverters::from('StringFeld', $o['nr3202904']);
        if (isset($o['nr3202905'])) $this->nr3202905 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3202905']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nr3201901)) $o['nr3201901'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3201901);
        if (isset($this->nr3202901)) $o['nr3202901'] = JsonConverters::to('StringFeld', $this->nr3202901);
        if (isset($this->nr3202902)) $o['nr3202902'] = JsonConverters::to('YearlessDateTimeFeld', $this->nr3202902);
        if (isset($this->nr3202903)) $o['nr3202903'] = JsonConverters::to('YearlessDateTimeFeld', $this->nr3202903);
        if (isset($this->nr3202904)) $o['nr3202904'] = JsonConverters::to('StringFeld', $this->nr3202904);
        if (isset($this->nr3202905)) $o['nr3202905'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3202905);
        return empty($o) ? new class(){} : $o;
    }
}

/** @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.")
class Bool12Feld extends CustomFeldBase implements JsonSerializable
{
    /**
     * @param int $nr
     * @param int $index
     * @param int $lfdNr
     * @param string|null $alias
     */
    public function __construct(
        int $nr=0,
        int $index=0,
        int $lfdNr=0,
        ?string $alias=null,
        /** @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")
        /** @var bool|null */
        public ?bool $wert=null
    ) {
        parent::__construct($nr,$index,$lfdNr,$alias);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['wert'])) $this->wert = $o['wert'];
        if (isset($o['nr'])) $this->nr = $o['nr'];
        if (isset($o['index'])) $this->index = $o['index'];
        if (isset($o['lfdNr'])) $this->lfdNr = $o['lfdNr'];
        if (isset($o['alias'])) $this->alias = $o['alias'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->wert)) $o['wert'] = $this->wert;
        if (isset($this->nr)) $o['nr'] = $this->nr;
        if (isset($this->index)) $o['index'] = $this->index;
        if (isset($this->lfdNr)) $o['lfdNr'] = $this->lfdNr;
        if (isset($this->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @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.")
class AnlageUnVorsteuerVerguetungsverfahrenBeimBZSt2020 implements JsonSerializable
{
    public function __construct(
        /** @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")
        /** @var Bool12Feld|null */
        public ?Bool12Feld $nr3201101=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nr3201101'])) $this->nr3201101 = JsonConverters::from('Bool12Feld', $o['nr3201101']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nr3201101)) $o['nr3201101'] = JsonConverters::to('Bool12Feld', $this->nr3201101);
        return empty($o) ? new class(){} : $o;
    }
}

/** @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).")
class AnlageUn2020 implements JsonSerializable
{
    public function __construct(
        /** @description Allgemeine Angaben (General Information) */
        // @ApiMember(Description="Allgemeine Angaben (General Information)", Name="AllgemeineAngaben")
        /** @var AnlageUnAllgemeineAngaben2020|null */
        public ?AnlageUnAllgemeineAngaben2020 $allgemeineAngaben=null,

        /** @description Anrechenbare Beträge (Eligible amounts) */
        // @ApiMember(Description="Anrechenbare Beträge (Eligible amounts)", Name="AnrechenbareBetraege")
        /** @var AnlageUnAnrechenbareBetraege2020|null */
        public ?AnlageUnAnrechenbareBetraege2020 $anrechenbareBetraege=null,

        /** @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")
        /** @var AnlageUnErgaenzendeAngabenZuUmsaetzen2020|null */
        public ?AnlageUnErgaenzendeAngabenZuUmsaetzen2020 $ergaenzendeAngabenZuUmsaetzen=null,

        /** @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")
        /** @var AnlageUnVorsteuerVerguetungsverfahrenBeimBZSt2020|null */
        public ?AnlageUnVorsteuerVerguetungsverfahrenBeimBZSt2020 $vorsteuerVerguetungsverfahrenBeimBZSt=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['allgemeineAngaben'])) $this->allgemeineAngaben = JsonConverters::from('AnlageUnAllgemeineAngaben2020', $o['allgemeineAngaben']);
        if (isset($o['anrechenbareBetraege'])) $this->anrechenbareBetraege = JsonConverters::from('AnlageUnAnrechenbareBetraege2020', $o['anrechenbareBetraege']);
        if (isset($o['ergaenzendeAngabenZuUmsaetzen'])) $this->ergaenzendeAngabenZuUmsaetzen = JsonConverters::from('AnlageUnErgaenzendeAngabenZuUmsaetzen2020', $o['ergaenzendeAngabenZuUmsaetzen']);
        if (isset($o['vorsteuerVerguetungsverfahrenBeimBZSt'])) $this->vorsteuerVerguetungsverfahrenBeimBZSt = JsonConverters::from('AnlageUnVorsteuerVerguetungsverfahrenBeimBZSt2020', $o['vorsteuerVerguetungsverfahrenBeimBZSt']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->allgemeineAngaben)) $o['allgemeineAngaben'] = JsonConverters::to('AnlageUnAllgemeineAngaben2020', $this->allgemeineAngaben);
        if (isset($this->anrechenbareBetraege)) $o['anrechenbareBetraege'] = JsonConverters::to('AnlageUnAnrechenbareBetraege2020', $this->anrechenbareBetraege);
        if (isset($this->ergaenzendeAngabenZuUmsaetzen)) $o['ergaenzendeAngabenZuUmsaetzen'] = JsonConverters::to('AnlageUnErgaenzendeAngabenZuUmsaetzen2020', $this->ergaenzendeAngabenZuUmsaetzen);
        if (isset($this->vorsteuerVerguetungsverfahrenBeimBZSt)) $o['vorsteuerVerguetungsverfahrenBeimBZSt'] = JsonConverters::to('AnlageUnVorsteuerVerguetungsverfahrenBeimBZSt2020', $this->vorsteuerVerguetungsverfahrenBeimBZSt);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Aufstellung aller vertretenen Unternehmer */
// @Api(Description="Aufstellung aller vertretenen Unternehmer")
class AnlageFvAufstAllerVertrUnt2020 implements JsonSerializable
{
    public function __construct(
        /** @description Name des vertretenen Unternehmers */
        // @ApiMember(Description="Name des vertretenen Unternehmers", Name="Nr3300201")
        /** @var StringFeld|null */
        public ?StringFeld $nr3300201=null,

        /** @description Anschrift des vertretenen Unternehmers */
        // @ApiMember(Description="Anschrift des vertretenen Unternehmers", Name="Nr3300202")
        /** @var StringFeld|null */
        public ?StringFeld $nr3300202=null,

        /** @description Umsatzsteuer-Identifikationsnummer des vertretenen Unternehmers */
        // @ApiMember(Description="Umsatzsteuer-Identifikationsnummer des vertretenen Unternehmers", Name="Nr3300203")
        /** @var StringFeld|null */
        public ?StringFeld $nr3300203=null,

        /** @description Summe der jeweiligen Bemessungsgrundlagen in EUR */
        // @ApiMember(Description="Summe der jeweiligen Bemessungsgrundlagen in EUR", Name="Nr3300204")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3300204=null,

        /** @description  Summe aller Bemessungsgrundlagen in EUR */
        // @ApiMember(Description=" Summe aller Bemessungsgrundlagen in EUR", Name="Nr3300301")
        /** @var GeldBetragOhneCent12DEFeld|null */
        public ?GeldBetragOhneCent12DEFeld $nr3300301=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nr3300201'])) $this->nr3300201 = JsonConverters::from('StringFeld', $o['nr3300201']);
        if (isset($o['nr3300202'])) $this->nr3300202 = JsonConverters::from('StringFeld', $o['nr3300202']);
        if (isset($o['nr3300203'])) $this->nr3300203 = JsonConverters::from('StringFeld', $o['nr3300203']);
        if (isset($o['nr3300204'])) $this->nr3300204 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3300204']);
        if (isset($o['nr3300301'])) $this->nr3300301 = JsonConverters::from('GeldBetragOhneCent12DEFeld', $o['nr3300301']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nr3300201)) $o['nr3300201'] = JsonConverters::to('StringFeld', $this->nr3300201);
        if (isset($this->nr3300202)) $o['nr3300202'] = JsonConverters::to('StringFeld', $this->nr3300202);
        if (isset($this->nr3300203)) $o['nr3300203'] = JsonConverters::to('StringFeld', $this->nr3300203);
        if (isset($this->nr3300204)) $o['nr3300204'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3300204);
        if (isset($this->nr3300301)) $o['nr3300301'] = JsonConverters::to('GeldBetragOhneCent12DEFeld', $this->nr3300301);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Anlage FV zur Umsatzsteuererklärung 2020 */
// @Api(Description="Anlage FV zur Umsatzsteuererklärung 2020")
class AnlageFv2020 implements JsonSerializable
{
    public function __construct(
        /** @description Aufstellung aller vertretenen Unternehmer $index$.Unternehmer */
        // @ApiMember(Description="Aufstellung aller vertretenen Unternehmer $index$.Unternehmer", Name="AufstAllerVertrUnt")
        /** @var AnlageFvAufstAllerVertrUnt2020|null */
        public ?AnlageFvAufstAllerVertrUnt2020 $aufstAllerVertrUnt=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['aufstAllerVertrUnt'])) $this->aufstAllerVertrUnt = JsonConverters::from('AnlageFvAufstAllerVertrUnt2020', $o['aufstAllerVertrUnt']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->aufstAllerVertrUnt)) $o['aufstAllerVertrUnt'] = JsonConverters::to('AnlageFvAufstAllerVertrUnt2020', $this->aufstAllerVertrUnt);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Represents a base class for a file with raw data. */
// @Api(Description="Represents a base class for a file with raw data.")
class FileBase implements JsonSerializable
{
    public function __construct(
        /** @description The raw data content of the file. */
        // @ApiMember(Description="The raw data content of the file.", Name="Content")
        /** @var ByteArray|null */
        public ?ByteArray $content=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['content'])) $this->content = JsonConverters::from('ByteArray', $o['content']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->content)) $o['content'] = JsonConverters::to('ByteArray', $this->content);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Represents a portal certificate that is protected by a password. */
// @Api(Description="Represents a portal certificate that is protected by a password.")
class PortalCertificate extends FileBase implements ISecuredCertificate, IHasIndex, JsonSerializable
{
    /**
     * @param ByteArray|null $content
     */
    public function __construct(
        ?ByteArray $content=null,
        /** @description The unique identifier of the certificate. */
        // @ApiMember(Description="The unique identifier of the certificate.")
        /** @var string */
        public string $id='',

        /** @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.")
        /** @var int */
        public int $index=0,

        /** @description The password to protect the certificate from unauthorized access. */
        // @StringLength(255)
        // @ApiMember(Description="The password to protect the certificate from unauthorized access.")
        /** @var string|null */
        public ?string $pin=null,

        /** @description The description of the certificate. */
        // @StringLength(2147483647)
        // @ApiMember(Description="The description of the certificate.")
        /** @var string|null */
        public ?string $description=null,

        /** @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.")
        /** @var array<string>|null */
        public ?array $tags=null,

        /** @description Gets or sets the file name of the certificate. */
        // @ApiMember(Description="Gets or sets the file name of the certificate.")
        /** @var string|null */
        public ?string $name=null
    ) {
        parent::__construct($content);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['id'])) $this->id = $o['id'];
        if (isset($o['index'])) $this->index = $o['index'];
        if (isset($o['pin'])) $this->pin = $o['pin'];
        if (isset($o['description'])) $this->description = $o['description'];
        if (isset($o['tags'])) $this->tags = JsonConverters::fromArray('string', $o['tags']);
        if (isset($o['name'])) $this->name = $o['name'];
        if (isset($o['content'])) $this->content = JsonConverters::from('ByteArray', $o['content']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->id)) $o['id'] = $this->id;
        if (isset($this->index)) $o['index'] = $this->index;
        if (isset($this->pin)) $o['pin'] = $this->pin;
        if (isset($this->description)) $o['description'] = $this->description;
        if (isset($this->tags)) $o['tags'] = JsonConverters::toArray('string', $this->tags);
        if (isset($this->name)) $o['name'] = $this->name;
        if (isset($this->content)) $o['content'] = JsonConverters::to('ByteArray', $this->content);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Submits an annual VAT return (Umsatzsteuerjahresserklärung) for 2020. */
// @Api(Description="Submits an annual VAT return (Umsatzsteuerjahresserklärung) for 2020.")
class SubmitUmsatzsteuererklaerung2020Base implements IPost, IDruckRequest, IVeschlueselungsRequest, JsonSerializable
{
    public function __construct(
        /** @description Die Art des ermittelten Ordnungsbegriffs zu füllen. */
        // @ApiMember(Description="Die Art des ermittelten Ordnungsbegriffs zu füllen.")
        /** @var OrdNrArt|null */
        public ?OrdNrArt $ordNrArt=null,

        /** @description Der Vorgang bei einer Veranlagung. */
        // @ApiMember(Description="Der Vorgang bei einer Veranlagung.")
        /** @var VeranlagungVorgang|null */
        public ?VeranlagungVorgang $vorgang=null,

        /** @var string|null */
        public ?string $stNr=null,
        /** @var string|null */
        public ?string $id=null,
        /** @var string|null */
        public ?string $idEhefrau=null,
        /** @description Das Erstellungsdatum des Steuerfalls, im Format JJJJMMDD. */
        // @ApiMember(Description="Das Erstellungsdatum des Steuerfalls, im Format JJJJMMDD.")
        /** @var DateTime|null */
        public ?DateTime $erstelldatum=null,

        /** @description Die Erstellungszeit des Steuerfalls, im Format hhmmss. */
        // @ApiMember(Description="Die Erstellungszeit des Steuerfalls, im Format hhmmss.")
        /** @var DateTime|null */
        public ?DateTime $erstellzeit=null,

        /** @description Name, alphanumerisch, max. 45-stellig. */
        // @ApiMember(Description="Name, alphanumerisch, max. 45-stellig.")
        /** @var string|null */
        public ?string $absName=null,

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

        /** @description Postleitzahl des Absenders der Erklärung */
        // @ApiMember(Description="Postleitzahl des Absenders der Erklärung")
        /** @var string|null */
        public ?string $absPlz=null,

        /** @description Ort, alphanumerisch, max. 29-stellig. */
        // @ApiMember(Description="Ort, alphanumerisch, max. 29-stellig.")
        /** @var string|null */
        public ?string $absOrt=null,

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

        /** @description Wird die elektronische Bereitstellung der Bescheiddaten gewünscht? */
        // @ApiMember(Description="Wird die elektronische Bereitstellung der Bescheiddaten gewünscht?")
        /** @var Rueckuebermittlung|null */
        public ?Rueckuebermittlung $rueckuebermittlung=null,

        /** @description Allgemeine Angaben (General Information) */
        // @ApiMember(Description="Allgemeine Angaben (General Information)")
        /** @var AllgemeineAngaben2020|null */
        public ?AllgemeineAngaben2020 $allgemeineAngaben=null,

        /** @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)")
        /** @var AngabenBesteuerungKleinunternehmer2020|null */
        public ?AngabenBesteuerungKleinunternehmer2020 $angabenBesteuerungKleinunternehmer=null,

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

        /** @description Steuerpflichtige Lieferungen usw. (Taxable goods etc.) */
        // @ApiMember(Description="Steuerpflichtige Lieferungen usw. (Taxable goods etc.)")
        /** @var SteuerpflichtigeLieferungenEtc2020|null */
        public ?SteuerpflichtigeLieferungenEtc2020 $steuerpflichtigeLieferungenEtc=null,

        /** @description Innergemeinschaftliche Erwerbe (Intra-Community acquisitions) */
        // @ApiMember(Description="Innergemeinschaftliche Erwerbe (Intra-Community acquisitions)")
        /** @var InnergemeinschaftlicheErwerbe2020|null */
        public ?InnergemeinschaftlicheErwerbe2020 $innergemeinschaftlicheErwerbe=null,

        /** @description Steuerschuldner bei Auslagerung (Tax payer for outsourcing) */
        // @ApiMember(Description="Steuerschuldner bei Auslagerung (Tax payer for outsourcing)")
        /** @var SteuerschuldnerBeiAuslagerung2020|null */
        public ?SteuerschuldnerBeiAuslagerung2020 $steuerschuldnerBeiAuslagerung=null,

        /** @description Innergemeinschaftliche Dreiecksgeschäfte (Intra-Community triangular transactions) */
        // @ApiMember(Description="Innergemeinschaftliche Dreiecksgeschäfte (Intra-Community triangular transactions)")
        /** @var InnergemeinschaftlicheDreiecksgeschaefte2020|null */
        public ?InnergemeinschaftlicheDreiecksgeschaefte2020 $innergemeinschaftlicheDreiecksgeschaefte=null,

        /** @description Leistungsempfänger als Steuerschuldner (Beneficiary as tax payer) */
        // @ApiMember(Description="Leistungsempfänger als Steuerschuldner (Beneficiary as tax payer)")
        /** @var LeistungsempfaengerAlsSteuerschuldner2020|null */
        public ?LeistungsempfaengerAlsSteuerschuldner2020 $leistungsempfaengerAlsSteuerschuldner=null,

        /** @description Ergänzende Angaben (Supplementary information) */
        // @ApiMember(Description="Ergänzende Angaben (Supplementary information)")
        /** @var ErgaenzendeAngaben2020|null */
        public ?ErgaenzendeAngaben2020 $ergaenzendeAngaben=null,

        /** @description Abziehbare Vorsteuerbeträge (Deductible input tax amounts) */
        // @ApiMember(Description="Abziehbare Vorsteuerbeträge (Deductible input tax amounts)")
        /** @var AbziehbareVorsteuerbetraege2020|null */
        public ?AbziehbareVorsteuerbetraege2020 $abziehbareVorsteuerbetraege=null,

        /** @description Berichtigung vom Vorsteuerabzug (Adjustment of input tax deduction) */
        // @ApiMember(Description="Berichtigung vom Vorsteuerabzug (Adjustment of input tax deduction)")
        /** @var BerichtigungVorsteuerabzug2020|null */
        public ?BerichtigungVorsteuerabzug2020 $berichtigungVorsteuerabzug=null,

        /** @description Berechnung vom Umsatzsteuer (Calculation of VAT) */
        // @ApiMember(Description="Berechnung vom Umsatzsteuer (Calculation of VAT)")
        /** @var BerechnungUmsatzsteuer2020|null */
        public ?BerechnungUmsatzsteuer2020 $berechnungUmsatzsteuer=null,

        /** @description Unterschrift (Signature) */
        // @ApiMember(Description="Unterschrift (Signature)")
        /** @var Unterschrift2020|null */
        public ?Unterschrift2020 $unterschrift=null,

        /** @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).")
        /** @var AnlageUn2020|null */
        public ?AnlageUn2020 $anlageUn=null,

        /** @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$).")
        /** @var AnlageFv2020|null */
        public ?AnlageFv2020 $anlageFv=null,

        /** @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")
        /** @var string */
        public string $bundesfinanzamtsnummer='',

        /** @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")
        /** @var string */
        public string $datenLieferant='',

        /** @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")
        /** @var bool|null */
        public ?bool $duplexDruck=null,

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

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

        /** @description The authentification certificate. */
        // @ApiMember(Description="The authentification certificate.", IsRequired=true, Name="Zertifikat")
        /** @var PortalCertificate|null */
        public ?PortalCertificate $zertifikat=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['ordNrArt'])) $this->ordNrArt = JsonConverters::from('OrdNrArt', $o['ordNrArt']);
        if (isset($o['vorgang'])) $this->vorgang = JsonConverters::from('VeranlagungVorgang', $o['vorgang']);
        if (isset($o['stNr'])) $this->stNr = $o['stNr'];
        if (isset($o['id'])) $this->id = $o['id'];
        if (isset($o['idEhefrau'])) $this->idEhefrau = $o['idEhefrau'];
        if (isset($o['erstelldatum'])) $this->erstelldatum = JsonConverters::from('DateTime', $o['erstelldatum']);
        if (isset($o['erstellzeit'])) $this->erstellzeit = JsonConverters::from('DateTime', $o['erstellzeit']);
        if (isset($o['absName'])) $this->absName = $o['absName'];
        if (isset($o['absStr'])) $this->absStr = $o['absStr'];
        if (isset($o['absPlz'])) $this->absPlz = $o['absPlz'];
        if (isset($o['absOrt'])) $this->absOrt = $o['absOrt'];
        if (isset($o['copyright'])) $this->copyright = $o['copyright'];
        if (isset($o['rueckuebermittlung'])) $this->rueckuebermittlung = JsonConverters::from('Rueckuebermittlung', $o['rueckuebermittlung']);
        if (isset($o['allgemeineAngaben'])) $this->allgemeineAngaben = JsonConverters::from('AllgemeineAngaben2020', $o['allgemeineAngaben']);
        if (isset($o['angabenBesteuerungKleinunternehmer'])) $this->angabenBesteuerungKleinunternehmer = JsonConverters::from('AngabenBesteuerungKleinunternehmer2020', $o['angabenBesteuerungKleinunternehmer']);
        if (isset($o['steuerfreieLieferungenEtc'])) $this->steuerfreieLieferungenEtc = JsonConverters::from('SteuerfreieLieferungenEtc2020', $o['steuerfreieLieferungenEtc']);
        if (isset($o['steuerpflichtigeLieferungenEtc'])) $this->steuerpflichtigeLieferungenEtc = JsonConverters::from('SteuerpflichtigeLieferungenEtc2020', $o['steuerpflichtigeLieferungenEtc']);
        if (isset($o['innergemeinschaftlicheErwerbe'])) $this->innergemeinschaftlicheErwerbe = JsonConverters::from('InnergemeinschaftlicheErwerbe2020', $o['innergemeinschaftlicheErwerbe']);
        if (isset($o['steuerschuldnerBeiAuslagerung'])) $this->steuerschuldnerBeiAuslagerung = JsonConverters::from('SteuerschuldnerBeiAuslagerung2020', $o['steuerschuldnerBeiAuslagerung']);
        if (isset($o['innergemeinschaftlicheDreiecksgeschaefte'])) $this->innergemeinschaftlicheDreiecksgeschaefte = JsonConverters::from('InnergemeinschaftlicheDreiecksgeschaefte2020', $o['innergemeinschaftlicheDreiecksgeschaefte']);
        if (isset($o['leistungsempfaengerAlsSteuerschuldner'])) $this->leistungsempfaengerAlsSteuerschuldner = JsonConverters::from('LeistungsempfaengerAlsSteuerschuldner2020', $o['leistungsempfaengerAlsSteuerschuldner']);
        if (isset($o['ergaenzendeAngaben'])) $this->ergaenzendeAngaben = JsonConverters::from('ErgaenzendeAngaben2020', $o['ergaenzendeAngaben']);
        if (isset($o['abziehbareVorsteuerbetraege'])) $this->abziehbareVorsteuerbetraege = JsonConverters::from('AbziehbareVorsteuerbetraege2020', $o['abziehbareVorsteuerbetraege']);
        if (isset($o['berichtigungVorsteuerabzug'])) $this->berichtigungVorsteuerabzug = JsonConverters::from('BerichtigungVorsteuerabzug2020', $o['berichtigungVorsteuerabzug']);
        if (isset($o['berechnungUmsatzsteuer'])) $this->berechnungUmsatzsteuer = JsonConverters::from('BerechnungUmsatzsteuer2020', $o['berechnungUmsatzsteuer']);
        if (isset($o['unterschrift'])) $this->unterschrift = JsonConverters::from('Unterschrift2020', $o['unterschrift']);
        if (isset($o['anlageUn'])) $this->anlageUn = JsonConverters::from('AnlageUn2020', $o['anlageUn']);
        if (isset($o['anlageFv'])) $this->anlageFv = JsonConverters::from('AnlageFv2020', $o['anlageFv']);
        if (isset($o['bundesfinanzamtsnummer'])) $this->bundesfinanzamtsnummer = $o['bundesfinanzamtsnummer'];
        if (isset($o['datenLieferant'])) $this->datenLieferant = $o['datenLieferant'];
        if (isset($o['duplexDruck'])) $this->duplexDruck = $o['duplexDruck'];
        if (isset($o['protocolPrefix'])) $this->protocolPrefix = $o['protocolPrefix'];
        if (isset($o['fussText'])) $this->fussText = $o['fussText'];
        if (isset($o['zertifikat'])) $this->zertifikat = JsonConverters::from('PortalCertificate', $o['zertifikat']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->ordNrArt)) $o['ordNrArt'] = JsonConverters::to('OrdNrArt', $this->ordNrArt);
        if (isset($this->vorgang)) $o['vorgang'] = JsonConverters::to('VeranlagungVorgang', $this->vorgang);
        if (isset($this->stNr)) $o['stNr'] = $this->stNr;
        if (isset($this->id)) $o['id'] = $this->id;
        if (isset($this->idEhefrau)) $o['idEhefrau'] = $this->idEhefrau;
        if (isset($this->erstelldatum)) $o['erstelldatum'] = JsonConverters::to('DateTime', $this->erstelldatum);
        if (isset($this->erstellzeit)) $o['erstellzeit'] = JsonConverters::to('DateTime', $this->erstellzeit);
        if (isset($this->absName)) $o['absName'] = $this->absName;
        if (isset($this->absStr)) $o['absStr'] = $this->absStr;
        if (isset($this->absPlz)) $o['absPlz'] = $this->absPlz;
        if (isset($this->absOrt)) $o['absOrt'] = $this->absOrt;
        if (isset($this->copyright)) $o['copyright'] = $this->copyright;
        if (isset($this->rueckuebermittlung)) $o['rueckuebermittlung'] = JsonConverters::to('Rueckuebermittlung', $this->rueckuebermittlung);
        if (isset($this->allgemeineAngaben)) $o['allgemeineAngaben'] = JsonConverters::to('AllgemeineAngaben2020', $this->allgemeineAngaben);
        if (isset($this->angabenBesteuerungKleinunternehmer)) $o['angabenBesteuerungKleinunternehmer'] = JsonConverters::to('AngabenBesteuerungKleinunternehmer2020', $this->angabenBesteuerungKleinunternehmer);
        if (isset($this->steuerfreieLieferungenEtc)) $o['steuerfreieLieferungenEtc'] = JsonConverters::to('SteuerfreieLieferungenEtc2020', $this->steuerfreieLieferungenEtc);
        if (isset($this->steuerpflichtigeLieferungenEtc)) $o['steuerpflichtigeLieferungenEtc'] = JsonConverters::to('SteuerpflichtigeLieferungenEtc2020', $this->steuerpflichtigeLieferungenEtc);
        if (isset($this->innergemeinschaftlicheErwerbe)) $o['innergemeinschaftlicheErwerbe'] = JsonConverters::to('InnergemeinschaftlicheErwerbe2020', $this->innergemeinschaftlicheErwerbe);
        if (isset($this->steuerschuldnerBeiAuslagerung)) $o['steuerschuldnerBeiAuslagerung'] = JsonConverters::to('SteuerschuldnerBeiAuslagerung2020', $this->steuerschuldnerBeiAuslagerung);
        if (isset($this->innergemeinschaftlicheDreiecksgeschaefte)) $o['innergemeinschaftlicheDreiecksgeschaefte'] = JsonConverters::to('InnergemeinschaftlicheDreiecksgeschaefte2020', $this->innergemeinschaftlicheDreiecksgeschaefte);
        if (isset($this->leistungsempfaengerAlsSteuerschuldner)) $o['leistungsempfaengerAlsSteuerschuldner'] = JsonConverters::to('LeistungsempfaengerAlsSteuerschuldner2020', $this->leistungsempfaengerAlsSteuerschuldner);
        if (isset($this->ergaenzendeAngaben)) $o['ergaenzendeAngaben'] = JsonConverters::to('ErgaenzendeAngaben2020', $this->ergaenzendeAngaben);
        if (isset($this->abziehbareVorsteuerbetraege)) $o['abziehbareVorsteuerbetraege'] = JsonConverters::to('AbziehbareVorsteuerbetraege2020', $this->abziehbareVorsteuerbetraege);
        if (isset($this->berichtigungVorsteuerabzug)) $o['berichtigungVorsteuerabzug'] = JsonConverters::to('BerichtigungVorsteuerabzug2020', $this->berichtigungVorsteuerabzug);
        if (isset($this->berechnungUmsatzsteuer)) $o['berechnungUmsatzsteuer'] = JsonConverters::to('BerechnungUmsatzsteuer2020', $this->berechnungUmsatzsteuer);
        if (isset($this->unterschrift)) $o['unterschrift'] = JsonConverters::to('Unterschrift2020', $this->unterschrift);
        if (isset($this->anlageUn)) $o['anlageUn'] = JsonConverters::to('AnlageUn2020', $this->anlageUn);
        if (isset($this->anlageFv)) $o['anlageFv'] = JsonConverters::to('AnlageFv2020', $this->anlageFv);
        if (isset($this->bundesfinanzamtsnummer)) $o['bundesfinanzamtsnummer'] = $this->bundesfinanzamtsnummer;
        if (isset($this->datenLieferant)) $o['datenLieferant'] = $this->datenLieferant;
        if (isset($this->duplexDruck)) $o['duplexDruck'] = $this->duplexDruck;
        if (isset($this->protocolPrefix)) $o['protocolPrefix'] = $this->protocolPrefix;
        if (isset($this->fussText)) $o['fussText'] = $this->fussText;
        if (isset($this->zertifikat)) $o['zertifikat'] = JsonConverters::to('PortalCertificate', $this->zertifikat);
        return empty($o) ? new class(){} : $o;
    }
}

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

        /** @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")
        /** @var int */
        public int $index=0,

        /** @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")
        /** @var ResponseStatus|null */
        public ?ResponseStatus $responseStatus=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['id'])) $this->id = $o['id'];
        if (isset($o['index'])) $this->index = $o['index'];
        if (isset($o['responseStatus'])) $this->responseStatus = JsonConverters::from('ResponseStatus', $o['responseStatus']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->id)) $o['id'] = $this->id;
        if (isset($this->index)) $o['index'] = $this->index;
        if (isset($this->responseStatus)) $o['responseStatus'] = JsonConverters::to('ResponseStatus', $this->responseStatus);
        return empty($o) ? new class(){} : $o;
    }
}

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

        /** @description The status message that the ERiC API function returns. */
        // @ApiMember(Description="The status message that the ERiC API function returns.", Name="StatusText")
        /** @var string|null */
        public ?string $statusText=null
    ) {
        parent::__construct($id,$index,$responseStatus);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['statusCode'])) $this->statusCode = JsonConverters::from('EricFehlerCode', $o['statusCode']);
        if (isset($o['statusText'])) $this->statusText = $o['statusText'];
        if (isset($o['id'])) $this->id = $o['id'];
        if (isset($o['index'])) $this->index = $o['index'];
        if (isset($o['responseStatus'])) $this->responseStatus = JsonConverters::from('ResponseStatus', $o['responseStatus']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->statusCode)) $o['statusCode'] = JsonConverters::to('EricFehlerCode', $this->statusCode);
        if (isset($this->statusText)) $o['statusText'] = $this->statusText;
        if (isset($this->id)) $o['id'] = $this->id;
        if (isset($this->index)) $o['index'] = $this->index;
        if (isset($this->responseStatus)) $o['responseStatus'] = JsonConverters::to('ResponseStatus', $this->responseStatus);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Represents information returned from a successful tax declaration process. */
// @Api(Description="Represents information returned from a successful tax declaration process.")
class Erfolg implements JsonSerializable
{
    public function __construct(
        /** @description The generated tele-number for the successful tax declaration process. */
        // @ApiMember(Description="The generated tele-number for the successful tax declaration process.")
        /** @var array<string>|null */
        public ?array $telenummer=null,

        /** @description The classification key for the successful tax declaration process. */
        // @ApiMember(Description="The classification key for the successful tax declaration process.")
        /** @var array<string>|null */
        public ?array $ordnungsbegriffe=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['telenummer'])) $this->telenummer = JsonConverters::fromArray('string', $o['telenummer']);
        if (isset($o['ordnungsbegriffe'])) $this->ordnungsbegriffe = JsonConverters::fromArray('string', $o['ordnungsbegriffe']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->telenummer)) $o['telenummer'] = JsonConverters::toArray('string', $this->telenummer);
        if (isset($this->ordnungsbegriffe)) $o['ordnungsbegriffe'] = JsonConverters::toArray('string', $this->ordnungsbegriffe);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Represents information on the delivery. */
// @Api(Description="Represents information on the delivery.")
class Transfer implements JsonSerializable
{
    public function __construct(
        /** @description The ticket of the transfer. */
        // @ApiMember(Description="The ticket of the transfer.")
        /** @var string|null */
        public ?string $transferTicket=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['transferTicket'])) $this->transferTicket = $o['transferTicket'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->transferTicket)) $o['transferTicket'] = $this->transferTicket;
        return empty($o) ? new class(){} : $o;
    }
}

/** @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.")
class Transfers implements JsonSerializable
{
    public function __construct(
        /** @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.")
        /** @var array<Transfer>|null */
        public ?array $transferList=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['transferList'])) $this->transferList = JsonConverters::fromArray('Transfer', $o['transferList']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->transferList)) $o['transferList'] = JsonConverters::toArray('Transfer', $this->transferList);
        return empty($o) ? new class(){} : $o;
    }
}

/** @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.")
class SemantischerIndex implements JsonSerializable
{
    public function __construct(
        /** @description The name of the index field. */
        // @ApiMember(Description="The name of the index field.")
        /** @var string|null */
        public ?string $name=null,

        /** @description The value of the index field. */
        // @ApiMember(Description="The value of the index field.")
        /** @var string|null */
        public ?string $value=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['name'])) $this->name = $o['name'];
        if (isset($o['value'])) $this->value = $o['value'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->name)) $o['name'] = $this->name;
        if (isset($this->value)) $o['value'] = $this->value;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Represents information on an ERiC reference. */
// @Api(Description="Represents information on an ERiC reference.")
class FehlerRegelpruefung implements JsonSerializable
{
    public function __construct(
        /** @description The user data ticket of the reference. */
        // @ApiMember(Description="The user data ticket of the reference.")
        /** @var string|null */
        public ?string $nutzdatenticket=null,

        /** @description The field identifier of the reference. */
        // @ApiMember(Description="The field identifier of the reference.")
        /** @var string|null */
        public ?string $feldidentifikator=null,

        /** @description The multi-line index of the reference. */
        // @ApiMember(Description="The multi-line index of the reference.")
        /** @var string|null */
        public ?string $mehrfachzeilenindex=null,

        /** @description The delivery number form of the reference. */
        // @ApiMember(Description="The delivery number form of the reference.")
        /** @var string|null */
        public ?string $lfdNrVordruck=null,

        /** @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.")
        /** @var string|null */
        public ?string $vordruckZeilennummer=null,

        /** @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.")
        /** @var array<SemantischerIndex>|null */
        public ?array $semantischeIndexes=null,

        /** @description The sub-subject-area of the reference. */
        // @ApiMember(Description="The sub-subject-area of the reference.")
        /** @var string|null */
        public ?string $untersachbereich=null,

        /** @description The private identification number of the reference. */
        // @ApiMember(Description="The private identification number of the reference.")
        /** @var string|null */
        public ?string $privateKennnummer=null,

        /** @description The name of the rule that applies to the reference. */
        // @ApiMember(Description="The name of the rule that applies to the reference.")
        /** @var string|null */
        public ?string $regelName=null,

        /** @description The technical error identifier of the reference. */
        // @ApiMember(Description="The technical error identifier of the reference.")
        /** @var string|null */
        public ?string $fachlicheFehlerId=null,

        /** @description The textual details of the reference. */
        // @ApiMember(Description="The textual details of the reference.")
        /** @var string|null */
        public ?string $text=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nutzdatenticket'])) $this->nutzdatenticket = $o['nutzdatenticket'];
        if (isset($o['feldidentifikator'])) $this->feldidentifikator = $o['feldidentifikator'];
        if (isset($o['mehrfachzeilenindex'])) $this->mehrfachzeilenindex = $o['mehrfachzeilenindex'];
        if (isset($o['lfdNrVordruck'])) $this->lfdNrVordruck = $o['lfdNrVordruck'];
        if (isset($o['vordruckZeilennummer'])) $this->vordruckZeilennummer = $o['vordruckZeilennummer'];
        if (isset($o['semantischeIndexes'])) $this->semantischeIndexes = JsonConverters::fromArray('SemantischerIndex', $o['semantischeIndexes']);
        if (isset($o['untersachbereich'])) $this->untersachbereich = $o['untersachbereich'];
        if (isset($o['privateKennnummer'])) $this->privateKennnummer = $o['privateKennnummer'];
        if (isset($o['regelName'])) $this->regelName = $o['regelName'];
        if (isset($o['fachlicheFehlerId'])) $this->fachlicheFehlerId = $o['fachlicheFehlerId'];
        if (isset($o['text'])) $this->text = $o['text'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nutzdatenticket)) $o['nutzdatenticket'] = $this->nutzdatenticket;
        if (isset($this->feldidentifikator)) $o['feldidentifikator'] = $this->feldidentifikator;
        if (isset($this->mehrfachzeilenindex)) $o['mehrfachzeilenindex'] = $this->mehrfachzeilenindex;
        if (isset($this->lfdNrVordruck)) $o['lfdNrVordruck'] = $this->lfdNrVordruck;
        if (isset($this->vordruckZeilennummer)) $o['vordruckZeilennummer'] = $this->vordruckZeilennummer;
        if (isset($this->semantischeIndexes)) $o['semantischeIndexes'] = JsonConverters::toArray('SemantischerIndex', $this->semantischeIndexes);
        if (isset($this->untersachbereich)) $o['untersachbereich'] = $this->untersachbereich;
        if (isset($this->privateKennnummer)) $o['privateKennnummer'] = $this->privateKennnummer;
        if (isset($this->regelName)) $o['regelName'] = $this->regelName;
        if (isset($this->fachlicheFehlerId)) $o['fachlicheFehlerId'] = $this->fachlicheFehlerId;
        if (isset($this->text)) $o['text'] = $this->text;
        return empty($o) ? new class(){} : $o;
    }
}

class Hinweis implements JsonSerializable
{
    public function __construct(
        /** @description The user data ticket of the reference. */
        // @ApiMember(Description="The user data ticket of the reference.")
        /** @var string|null */
        public ?string $nutzdatenticket=null,

        /** @description The field identifier of the reference. */
        // @ApiMember(Description="The field identifier of the reference.")
        /** @var string|null */
        public ?string $feldidentifikator=null,

        /** @description The multi-line index of the reference. */
        // @ApiMember(Description="The multi-line index of the reference.")
        /** @var string|null */
        public ?string $mehrfachzeilenindex=null,

        /** @description The delivery number form of the reference. */
        // @ApiMember(Description="The delivery number form of the reference.")
        /** @var string|null */
        public ?string $lfdNrVordruck=null,

        /** @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.")
        /** @var string|null */
        public ?string $vordruckZeilennummer=null,

        /** @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.")
        /** @var array<SemantischerIndex>|null */
        public ?array $semantischeIndexes=null,

        /** @description The sub-subject-area of the reference. */
        // @ApiMember(Description="The sub-subject-area of the reference.")
        /** @var string|null */
        public ?string $untersachbereich=null,

        /** @description The private identification number of the reference. */
        // @ApiMember(Description="The private identification number of the reference.")
        /** @var string|null */
        public ?string $privateKennnummer=null,

        /** @description The name of the rule that applies to the reference. */
        // @ApiMember(Description="The name of the rule that applies to the reference.")
        /** @var string|null */
        public ?string $regelName=null,

        /** @description The technical note identifier of the reference. */
        // @ApiMember(Description="The technical note identifier of the reference.")
        /** @var string|null */
        public ?string $fachlicheHinweisId=null,

        /** @description The textual details of the reference. */
        // @ApiMember(Description="The textual details of the reference.")
        /** @var string|null */
        public ?string $text=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nutzdatenticket'])) $this->nutzdatenticket = $o['nutzdatenticket'];
        if (isset($o['feldidentifikator'])) $this->feldidentifikator = $o['feldidentifikator'];
        if (isset($o['mehrfachzeilenindex'])) $this->mehrfachzeilenindex = $o['mehrfachzeilenindex'];
        if (isset($o['lfdNrVordruck'])) $this->lfdNrVordruck = $o['lfdNrVordruck'];
        if (isset($o['vordruckZeilennummer'])) $this->vordruckZeilennummer = $o['vordruckZeilennummer'];
        if (isset($o['semantischeIndexes'])) $this->semantischeIndexes = JsonConverters::fromArray('SemantischerIndex', $o['semantischeIndexes']);
        if (isset($o['untersachbereich'])) $this->untersachbereich = $o['untersachbereich'];
        if (isset($o['privateKennnummer'])) $this->privateKennnummer = $o['privateKennnummer'];
        if (isset($o['regelName'])) $this->regelName = $o['regelName'];
        if (isset($o['fachlicheHinweisId'])) $this->fachlicheHinweisId = $o['fachlicheHinweisId'];
        if (isset($o['text'])) $this->text = $o['text'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nutzdatenticket)) $o['nutzdatenticket'] = $this->nutzdatenticket;
        if (isset($this->feldidentifikator)) $o['feldidentifikator'] = $this->feldidentifikator;
        if (isset($this->mehrfachzeilenindex)) $o['mehrfachzeilenindex'] = $this->mehrfachzeilenindex;
        if (isset($this->lfdNrVordruck)) $o['lfdNrVordruck'] = $this->lfdNrVordruck;
        if (isset($this->vordruckZeilennummer)) $o['vordruckZeilennummer'] = $this->vordruckZeilennummer;
        if (isset($this->semantischeIndexes)) $o['semantischeIndexes'] = JsonConverters::toArray('SemantischerIndex', $this->semantischeIndexes);
        if (isset($this->untersachbereich)) $o['untersachbereich'] = $this->untersachbereich;
        if (isset($this->privateKennnummer)) $o['privateKennnummer'] = $this->privateKennnummer;
        if (isset($this->regelName)) $o['regelName'] = $this->regelName;
        if (isset($this->fachlicheHinweisId)) $o['fachlicheHinweisId'] = $this->fachlicheHinweisId;
        if (isset($this->text)) $o['text'] = $this->text;
        return empty($o) ? new class(){} : $o;
    }
}

/** @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.")
class EricBearbeiteVorgang implements JsonSerializable
{
    public function __construct(
        /** @description Information from the successful processing a tax declaration. */
        // @ApiMember(Description="Information from the successful processing a tax declaration.")
        /** @var Erfolg|null */
        public ?Erfolg $erfolg=null,

        /** @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.")
        /** @var Transfers|null */
        public ?Transfers $transfers=null,

        /** @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.")
        /** @var array<FehlerRegelpruefung>|null */
        public ?array $fehlerRegelpruefungen=null,

        /** @description Hints that result the processing of a tax declaration. */
        // @ApiMember(Description="Hints that result the processing of a tax declaration.")
        /** @var array<Hinweis>|null */
        public ?array $hinweise=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['erfolg'])) $this->erfolg = JsonConverters::from('Erfolg', $o['erfolg']);
        if (isset($o['transfers'])) $this->transfers = JsonConverters::from('Transfers', $o['transfers']);
        if (isset($o['fehlerRegelpruefungen'])) $this->fehlerRegelpruefungen = JsonConverters::fromArray('FehlerRegelpruefung', $o['fehlerRegelpruefungen']);
        if (isset($o['hinweise'])) $this->hinweise = JsonConverters::fromArray('Hinweis', $o['hinweise']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->erfolg)) $o['erfolg'] = JsonConverters::to('Erfolg', $this->erfolg);
        if (isset($this->transfers)) $o['transfers'] = JsonConverters::to('Transfers', $this->transfers);
        if (isset($this->fehlerRegelpruefungen)) $o['fehlerRegelpruefungen'] = JsonConverters::toArray('FehlerRegelpruefung', $this->fehlerRegelpruefungen);
        if (isset($this->hinweise)) $o['hinweise'] = JsonConverters::toArray('Hinweis', $this->hinweise);
        return empty($o) ? new class(){} : $o;
    }
}

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

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

/** @description Hauptinformation ob die Daten authentifiziert wurden (send-Auth) oder nicht (send-NoSig) */
enum Vorgang : string
{
    case Send_Auth = 'Send_Auth';
    case Send_Auth_Part = 'Send_Auth_Part';
    case Send_NoSig = 'Send_NoSig';
    case 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. */
enum Testmerker : int
{
    case TM010000001 = 10000001;
    case TM080000001 = 80000001;
    case TM160000001 = 160000001;
    case TM160000002 = 160000002;
    case TM220000000 = 220000000;
    case TM220002000 = 220002000;
    case TM230000001 = 230000001;
    case TM240000000 = 240000000;
    case TM370000001 = 370000001;
    case TM520000000 = 520000000;
    case TM700000001 = 700000001;
    case 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.")
class SigUser implements JsonSerializable
{
    public function __construct(
        /** @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")
        /** @var Object|null */
        public ?Object $inhalt=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['inhalt'])) $this->inhalt = JsonConverters::from('Object', $o['inhalt']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->inhalt)) $o['inhalt'] = JsonConverters::to('Object', $this->inhalt);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Einheitliche Abkürzungen fuer die Bundesländer bzw. alternative Empfänger */
enum Bundesland : string
{
    case BW = 'BW';
    case BY = 'BY';
    case BE = 'BE';
    case BB = 'BB';
    case HB = 'HB';
    case HH = 'HH';
    case HE = 'HE';
    case MV = 'MV';
    case NI = 'NI';
    case NW = 'NW';
    case RP = 'RP';
    case SL = 'SL';
    case SN = 'SN';
    case ST = 'ST';
    case SH = 'SH';
    case TH = 'TH';
    case EC = 'EC';
    case BF = 'BF';
    case CS = 'CS';
    case CD = 'CD';
    case CM = 'CM';
    case CN = 'CN';
    case DS = 'DS';
    case OP = 'OP';
    case TK = 'TK';
    case ZF = 'ZF';
}

/** @description Represents a receiver of tax data. */
// @Api(Description="Represents a receiver of tax data.")
class Empfaenger implements JsonSerializable
{
    public function __construct(
        /** @description The identifier of the receiver. */
        // @ApiMember(Description="The identifier of the receiver.")
        /** @var string|null */
        public ?string $id=null,

        /** @description The destination of the receiver. */
        // @ApiMember(Description="The destination of the receiver.")
        /** @var Bundesland|null */
        public ?Bundesland $ziel=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['id'])) $this->id = $o['id'];
        if (isset($o['ziel'])) $this->ziel = JsonConverters::from('Bundesland', $o['ziel']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->id)) $o['id'] = $this->id;
        if (isset($this->ziel)) $o['ziel'] = JsonConverters::to('Bundesland', $this->ziel);
        return empty($o) ? new class(){} : $o;
    }
}

/** @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 */
enum Verschluesselungsart : string
{
    case PKCS_7v1_5 = 'PKCS_7v1_5';
    case PKCS_7v1_5enveloped = 'PKCS_7v1_5enveloped';
    case NO_BASE64 = 'NO_BASE64';
    case CMSEncryptedData = 'CMSEncryptedData';
    case CMSEnvelopedData = 'CMSEnvelopedData';
    case 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. */
enum Kompression : string
{
    case GZIP = 'GZIP';
    case NO_BASE64 = 'NO_BASE64';
}

/** @description [Documentation unavailable] */
// @Api(Description="[Documentation unavailable]")
class EricTyp implements JsonSerializable
{
    public function __construct(
        /** @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")
        /** @var Object|null */
        public ?Object $inhalt=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['inhalt'])) $this->inhalt = JsonConverters::from('Object', $o['inhalt']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->inhalt)) $o['inhalt'] = JsonConverters::to('Object', $this->inhalt);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description [Documentation unavailable] */
// @Api(Description="[Documentation unavailable]")
class Erstellung implements JsonSerializable
{
    public function __construct(
        /** @description [Documentation unavailable] */
        // @ApiMember(Description="[Documentation unavailable]")
        /** @var EricTyp|null */
        public ?EricTyp $eric=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['eric'])) $this->eric = JsonConverters::from('EricTyp', $o['eric']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->eric)) $o['eric'] = JsonConverters::to('EricTyp', $this->eric);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Represents information on the encryption of tax data. */
// @Api(Description="Represents information on the encryption of tax data.")
class Datei implements JsonSerializable
{
    public function __construct(
        /** @description The type of data encryption used. */
        // @ApiMember(Description="The type of data encryption used.")
        /** @var Verschluesselungsart|null */
        public ?Verschluesselungsart $verschluesselung=null,

        /** @description The type of data compression used. */
        // @ApiMember(Description="The type of data compression used.")
        /** @var Kompression|null */
        public ?Kompression $kompression=null,

        /** @description The transport key used in the encryption. */
        // @ApiMember(Description="The transport key used in the encryption.")
        /** @var string|null */
        public ?string $transportSchluessel=null,

        /** @description [Documentation unavailable] */
        // @ApiMember(Description="[Documentation unavailable]")
        /** @var Erstellung|null */
        public ?Erstellung $erstellung=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['verschluesselung'])) $this->verschluesselung = JsonConverters::from('Verschluesselungsart', $o['verschluesselung']);
        if (isset($o['kompression'])) $this->kompression = JsonConverters::from('Kompression', $o['kompression']);
        if (isset($o['transportSchluessel'])) $this->transportSchluessel = $o['transportSchluessel'];
        if (isset($o['erstellung'])) $this->erstellung = JsonConverters::from('Erstellung', $o['erstellung']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->verschluesselung)) $o['verschluesselung'] = JsonConverters::to('Verschluesselungsart', $this->verschluesselung);
        if (isset($this->kompression)) $o['kompression'] = JsonConverters::to('Kompression', $this->kompression);
        if (isset($this->transportSchluessel)) $o['transportSchluessel'] = $this->transportSchluessel;
        if (isset($this->erstellung)) $o['erstellung'] = JsonConverters::to('Erstellung', $this->erstellung);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Represents an external error stack. */
// @Api(Description="Represents an external error stack.")
class Rueckgabe implements JsonSerializable
{
    public function __construct(
        /** @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.")
        /** @var string|null */
        public ?string $code=null,

        /** @description The external error message. */
        // @ApiMember(Description="The external error message.")
        /** @var string|null */
        public ?string $text=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['code'])) $this->code = $o['code'];
        if (isset($o['text'])) $this->text = $o['text'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->code)) $o['code'] = $this->code;
        if (isset($this->text)) $o['text'] = $this->text;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Represents an internal error stack. */
// @Api(Description="Represents an internal error stack.")
class Stack implements JsonSerializable
{
    public function __construct(
        /** @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.")
        /** @var string|null */
        public ?string $code=null,

        /** @description The external error message. */
        // @ApiMember(Description="The external error message.")
        /** @var string|null */
        public ?string $text=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['code'])) $this->code = $o['code'];
        if (isset($o['text'])) $this->text = $o['text'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->code)) $o['code'] = $this->code;
        if (isset($this->text)) $o['text'] = $this->text;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Represents an ERiC return code. */
// @Api(Description="Represents an ERiC return code.")
class RC implements JsonSerializable
{
    public function __construct(
        /** @description The return value of the return code. */
        // @ApiMember(Description="The return value of the return code.")
        /** @var Rueckgabe|null */
        public ?Rueckgabe $rueckgabe=null,

        /** @description The internal value of the return code. */
        // @ApiMember(Description="The internal value of the return code.")
        /** @var Stack|null */
        public ?Stack $stack=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['rueckgabe'])) $this->rueckgabe = JsonConverters::from('Rueckgabe', $o['rueckgabe']);
        if (isset($o['stack'])) $this->stack = JsonConverters::from('Stack', $o['stack']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->rueckgabe)) $o['rueckgabe'] = JsonConverters::to('Rueckgabe', $this->rueckgabe);
        if (isset($this->stack)) $o['stack'] = JsonConverters::to('Stack', $this->stack);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Represents an ERiC extension. */
// @Api(Description="Represents an ERiC extension.")
class Zusatz implements JsonSerializable
{
    public function __construct(
        /** @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.")
        /** @var array<string>|null */
        public ?array $infos=null,

        /** @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).")
        /** @var array<string>|null */
        public ?array $elsterInfos=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['infos'])) $this->infos = JsonConverters::fromArray('string', $o['infos']);
        if (isset($o['elsterInfos'])) $this->elsterInfos = JsonConverters::fromArray('string', $o['elsterInfos']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->infos)) $o['infos'] = JsonConverters::toArray('string', $this->infos);
        if (isset($this->elsterInfos)) $o['elsterInfos'] = JsonConverters::toArray('string', $this->elsterInfos);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Represents the transfer header part of an ELSTER document. */
// @Api(Description="Represents the transfer header part of an ELSTER document.")
class TransferHeader implements JsonSerializable
{
    public function __construct(
        /** @description The version of the transfer header. */
        // @ApiMember(Description="The version of the transfer header.", IsRequired=true)
        /** @var string */
        public string $version='',

        /** @description The tax operation used in the ELSTER process. */
        // @ApiMember(Description="The tax operation used in the ELSTER process.", IsRequired=true)
        /** @var Verfahren|null */
        public ?Verfahren $verfahren=null,

        /** @description The tax data type of the ELSTER process. */
        // @ApiMember(Description="The tax data type of the ELSTER process.", IsRequired=true)
        /** @var Datenart|null */
        public ?Datenart $datenArt=null,

        /** @description The authentification procedure of the ELSTER process. */
        // @ApiMember(Description="The authentification procedure of the ELSTER process.", IsRequired=true)
        /** @var Vorgang|null */
        public ?Vorgang $vorgang=null,

        /** @description The ticket identifier after a successful ELSTER process. */
        // @ApiMember(Description="The ticket identifier after a successful ELSTER process.")
        /** @var string|null */
        public ?string $transferTicket=null,

        /** @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.")
        /** @var Testmerker|null */
        public ?Testmerker $testmerker=null,

        /** @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.")
        /** @var SigUser|null */
        public ?SigUser $sigUser=null,

        /** @description The receiving ELSTER server. */
        // @ApiMember(Description="The receiving ELSTER server.")
        /** @var Empfaenger|null */
        public ?Empfaenger $empfaenger=null,

        /** @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)
        /** @var string */
        public string $herstellerID='',

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

        /** @description The date of receipt of the tax data. */
        // @ApiMember(Description="The date of receipt of the tax data.")
        /** @var DateTime|null */
        public ?DateTime $eingangsDatum=null,

        /** @description The encryption data required for authenticated transmission of tax data. */
        // @ApiMember(Description="The encryption data required for authenticated transmission of tax data.")
        /** @var Datei|null */
        public ?Datei $datei=null,

        /** @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.")
        /** @var RC|null */
        public ?RC $rc=null,

        /** @description The details of the software that submits the tax data. */
        // @ApiMember(Description="The details of the software that submits the tax data.")
        /** @var string|null */
        public ?string $versionClient=null,

        /** @description Data extensions to the transfer header. */
        // @ApiMember(Description="Data extensions to the transfer header.")
        /** @var Zusatz|null */
        public ?Zusatz $zusatz=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['version'])) $this->version = $o['version'];
        if (isset($o['verfahren'])) $this->verfahren = JsonConverters::from('Verfahren', $o['verfahren']);
        if (isset($o['datenArt'])) $this->datenArt = JsonConverters::from('Datenart', $o['datenArt']);
        if (isset($o['vorgang'])) $this->vorgang = JsonConverters::from('Vorgang', $o['vorgang']);
        if (isset($o['transferTicket'])) $this->transferTicket = $o['transferTicket'];
        if (isset($o['testmerker'])) $this->testmerker = JsonConverters::from('Testmerker', $o['testmerker']);
        if (isset($o['sigUser'])) $this->sigUser = JsonConverters::from('SigUser', $o['sigUser']);
        if (isset($o['empfaenger'])) $this->empfaenger = JsonConverters::from('Empfaenger', $o['empfaenger']);
        if (isset($o['herstellerID'])) $this->herstellerID = $o['herstellerID'];
        if (isset($o['datenLieferant'])) $this->datenLieferant = $o['datenLieferant'];
        if (isset($o['eingangsDatum'])) $this->eingangsDatum = JsonConverters::from('DateTime', $o['eingangsDatum']);
        if (isset($o['datei'])) $this->datei = JsonConverters::from('Datei', $o['datei']);
        if (isset($o['rc'])) $this->rc = JsonConverters::from('RC', $o['rc']);
        if (isset($o['versionClient'])) $this->versionClient = $o['versionClient'];
        if (isset($o['zusatz'])) $this->zusatz = JsonConverters::from('Zusatz', $o['zusatz']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->version)) $o['version'] = $this->version;
        if (isset($this->verfahren)) $o['verfahren'] = JsonConverters::to('Verfahren', $this->verfahren);
        if (isset($this->datenArt)) $o['datenArt'] = JsonConverters::to('Datenart', $this->datenArt);
        if (isset($this->vorgang)) $o['vorgang'] = JsonConverters::to('Vorgang', $this->vorgang);
        if (isset($this->transferTicket)) $o['transferTicket'] = $this->transferTicket;
        if (isset($this->testmerker)) $o['testmerker'] = JsonConverters::to('Testmerker', $this->testmerker);
        if (isset($this->sigUser)) $o['sigUser'] = JsonConverters::to('SigUser', $this->sigUser);
        if (isset($this->empfaenger)) $o['empfaenger'] = JsonConverters::to('Empfaenger', $this->empfaenger);
        if (isset($this->herstellerID)) $o['herstellerID'] = $this->herstellerID;
        if (isset($this->datenLieferant)) $o['datenLieferant'] = $this->datenLieferant;
        if (isset($this->eingangsDatum)) $o['eingangsDatum'] = JsonConverters::to('DateTime', $this->eingangsDatum);
        if (isset($this->datei)) $o['datei'] = JsonConverters::to('Datei', $this->datei);
        if (isset($this->rc)) $o['rc'] = JsonConverters::to('RC', $this->rc);
        if (isset($this->versionClient)) $o['versionClient'] = $this->versionClient;
        if (isset($this->zusatz)) $o['zusatz'] = JsonConverters::to('Zusatz', $this->zusatz);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Represents a receriver ID */
enum EmpfaengerID : string
{
    case L = 'L';
    case F = 'F';
}

/** @description Represents a receiver of tax data. */
// @Api(Description="Represents a receiver of tax data.")
class NDHEmpfaenger implements JsonSerializable
{
    public function __construct(
        /** @description The identifier of the receiver. */
        // @ApiMember(Description="The identifier of the receiver.")
        /** @var EmpfaengerID|null */
        public ?EmpfaengerID $id=null,

        /** @description The value of the receiver. */
        // @ApiMember(Description="The value of the receiver.")
        /** @var string|null */
        public ?string $value=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['id'])) $this->id = JsonConverters::from('EmpfaengerID', $o['id']);
        if (isset($o['value'])) $this->value = $o['value'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->id)) $o['id'] = JsonConverters::to('EmpfaengerID', $this->id);
        if (isset($this->value)) $o['value'] = $this->value;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Represents a manufacturer/vendor of tax software. */
// @Api(Description="Represents a manufacturer/vendor of tax software.")
class Hersteller implements JsonSerializable
{
    public function __construct(
        /** @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.")
        /** @var string|null */
        public ?string $produktName=null,

        /** @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.")
        /** @var string|null */
        public ?string $produktVersion=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['produktName'])) $this->produktName = $o['produktName'];
        if (isset($o['produktVersion'])) $this->produktVersion = $o['produktVersion'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->produktName)) $o['produktName'] = $this->produktName;
        if (isset($this->produktVersion)) $o['produktVersion'] = $this->produktVersion;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Represents the header of a tax data. */
// @Api(Description="Represents the header of a tax data.")
class NutzdatenHeader implements JsonSerializable
{
    public function __construct(
        /** @description The version of the header. */
        // @ApiMember(Description="The version of the header.", IsRequired=true)
        /** @var string */
        public string $version='',

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

        /** @description The receiver of the header. */
        // @ApiMember(Description="The receiver of the header.", IsRequired=true)
        /** @var NDHEmpfaenger|null */
        public ?NDHEmpfaenger $empfaenger=null,

        /** @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)
        /** @var Hersteller|null */
        public ?Hersteller $hersteller=null,

        /** @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.")
        /** @var string|null */
        public ?string $datenLieferant=null,

        /** @description The return code of the header. */
        // @ApiMember(Description="The return code of the header.")
        /** @var RC|null */
        public ?RC $rc=null,

        /** @description The data extensions of the header. */
        // @ApiMember(Description="The data extensions of the header.")
        /** @var Zusatz|null */
        public ?Zusatz $zusatz=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['version'])) $this->version = $o['version'];
        if (isset($o['nutzdatenTicket'])) $this->nutzdatenTicket = $o['nutzdatenTicket'];
        if (isset($o['empfaenger'])) $this->empfaenger = JsonConverters::from('NDHEmpfaenger', $o['empfaenger']);
        if (isset($o['hersteller'])) $this->hersteller = JsonConverters::from('Hersteller', $o['hersteller']);
        if (isset($o['datenLieferant'])) $this->datenLieferant = $o['datenLieferant'];
        if (isset($o['rc'])) $this->rc = JsonConverters::from('RC', $o['rc']);
        if (isset($o['zusatz'])) $this->zusatz = JsonConverters::from('Zusatz', $o['zusatz']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->version)) $o['version'] = $this->version;
        if (isset($this->nutzdatenTicket)) $o['nutzdatenTicket'] = $this->nutzdatenTicket;
        if (isset($this->empfaenger)) $o['empfaenger'] = JsonConverters::to('NDHEmpfaenger', $this->empfaenger);
        if (isset($this->hersteller)) $o['hersteller'] = JsonConverters::to('Hersteller', $this->hersteller);
        if (isset($this->datenLieferant)) $o['datenLieferant'] = $this->datenLieferant;
        if (isset($this->rc)) $o['rc'] = JsonConverters::to('RC', $this->rc);
        if (isset($this->zusatz)) $o['zusatz'] = JsonConverters::to('Zusatz', $this->zusatz);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Represents an encapsulation of tax data content. */
// @Api(Description="Represents an encapsulation of tax data content.")
class Nutzdaten implements JsonSerializable
{
    public function __construct(
        /** @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)
        /** @var Object|null */
        public ?Object $inhalt=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['inhalt'])) $this->inhalt = JsonConverters::from('Object', $o['inhalt']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->inhalt)) $o['inhalt'] = JsonConverters::to('Object', $this->inhalt);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Represents a block of tax data. */
// @Api(Description="Represents a block of tax data.")
class Nutzdatenblock implements JsonSerializable
{
    public function __construct(
        /** @description The header part of the block. */
        // @ApiMember(Description="The header part of the block.", IsRequired=true)
        /** @var NutzdatenHeader|null */
        public ?NutzdatenHeader $nutzdatenHeader=null,

        /** @description The data part of the block. */
        // @ApiMember(Description="The data part of the block.", IsRequired=true)
        /** @var Nutzdaten|null */
        public ?Nutzdaten $nutzdaten=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nutzdatenHeader'])) $this->nutzdatenHeader = JsonConverters::from('NutzdatenHeader', $o['nutzdatenHeader']);
        if (isset($o['nutzdaten'])) $this->nutzdaten = JsonConverters::from('Nutzdaten', $o['nutzdaten']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nutzdatenHeader)) $o['nutzdatenHeader'] = JsonConverters::to('NutzdatenHeader', $this->nutzdatenHeader);
        if (isset($this->nutzdaten)) $o['nutzdaten'] = JsonConverters::to('Nutzdaten', $this->nutzdaten);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Represents the data part of an ELSTER document. */
// @Api(Description="Represents the data part of an ELSTER document.")
class DatenTeil implements JsonSerializable
{
    public function __construct(
        /** @description The blocks of tax data of the ELSTER document. */
        // @ApiMember(Description="The blocks of tax data of the ELSTER document.", IsRequired=true)
        /** @var array<Nutzdatenblock>|null */
        public ?array $nutzdatenbloecke=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['nutzdatenbloecke'])) $this->nutzdatenbloecke = JsonConverters::fromArray('Nutzdatenblock', $o['nutzdatenbloecke']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->nutzdatenbloecke)) $o['nutzdatenbloecke'] = JsonConverters::toArray('Nutzdatenblock', $this->nutzdatenbloecke);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Represents an ELSTER document. */
// @Api(Description="Represents an ELSTER document.")
class Elster implements JsonSerializable
{
    public function __construct(
        /** @description The transfer header part of the ELSTER document. */
        // @ApiMember(Description="The transfer header part of the ELSTER document.", IsRequired=true)
        /** @var TransferHeader|null */
        public ?TransferHeader $transferHeader=null,

        /** @description The data (facts) part of the ELSTER document. */
        // @ApiMember(Description="The data (facts) part of the ELSTER document.")
        /** @var DatenTeil|null */
        public ?DatenTeil $datenTeil=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['transferHeader'])) $this->transferHeader = JsonConverters::from('TransferHeader', $o['transferHeader']);
        if (isset($o['datenTeil'])) $this->datenTeil = JsonConverters::from('DatenTeil', $o['datenTeil']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->transferHeader)) $o['transferHeader'] = JsonConverters::to('TransferHeader', $this->transferHeader);
        if (isset($this->datenTeil)) $o['datenTeil'] = JsonConverters::to('DatenTeil', $this->datenTeil);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Represents information about a file or directory. */
// @Api(Description="Represents information about a file or directory.")
class FileMetadata implements IFileMetadata, JsonSerializable
{
    public function __construct(
        /** @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")
        /** @var string|null */
        public ?string $name=null,

        /** @description The full path of the directory or file. */
        // @ApiMember(Description="The full path of the directory or file.", Name="FullName")
        /** @var string|null */
        public ?string $fullName=null,

        /** @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")
        /** @var DateTime */
        public DateTime $lastAccessTime=new DateTime(),

        /** @description The name of the file. */
        // @ApiMember(Description="The name of the file.", Name="LastAccessTimeUtc")
        /** @var DateTime */
        public DateTime $lastAccessTimeUtc=new DateTime(),

        /** @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")
        /** @var DateTime */
        public DateTime $lastWriteTime=new DateTime(),

        /** @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")
        /** @var DateTime */
        public DateTime $lastWriteTimeUtc=new DateTime(),

        /** @description The size, in bytes, of the current file. */
        // @ApiMember(Description="The size, in bytes, of the current file.", Name="Length")
        /** @var int */
        public int $length=0,

        /** @description The size, in bytes, of the current file. */
        // @ApiMember(Description="The size, in bytes, of the current file.", Name="UserId")
        /** @var int */
        public int $userId=0,

        /** @description The file group id. */
        // @ApiMember(Description="The file group id.", Name="GroupId")
        /** @var int */
        public int $groupId=0,

        /** @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")
        /** @var bool|null */
        public ?bool $othersCanRead=null,

        /** @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")
        /** @var bool|null */
        public ?bool $groupCanExecute=null,

        /** @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")
        /** @var bool|null */
        public ?bool $groupCanWrite=null,

        /** @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")
        /** @var bool|null */
        public ?bool $groupCanRead=null,

        /** @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")
        /** @var bool|null */
        public ?bool $ownerCanExecute=null,

        /** @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")
        /** @var bool|null */
        public ?bool $ownerCanWrite=null,

        /** @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")
        /** @var bool|null */
        public ?bool $ownerCanRead=null,

        /** @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")
        /** @var bool|null */
        public ?bool $othersCanExecute=null,

        /** @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")
        /** @var bool|null */
        public ?bool $othersCanWrite=null,

        /** @description Extensions to the file attributes. */
        // @ApiMember(Description="Extensions to the file attributes.", Name="Extensions")
        /** @var array<string,string>|null */
        public ?array $extensions=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['name'])) $this->name = $o['name'];
        if (isset($o['fullName'])) $this->fullName = $o['fullName'];
        if (isset($o['lastAccessTime'])) $this->lastAccessTime = JsonConverters::from('DateTime', $o['lastAccessTime']);
        if (isset($o['lastAccessTimeUtc'])) $this->lastAccessTimeUtc = JsonConverters::from('DateTime', $o['lastAccessTimeUtc']);
        if (isset($o['lastWriteTime'])) $this->lastWriteTime = JsonConverters::from('DateTime', $o['lastWriteTime']);
        if (isset($o['lastWriteTimeUtc'])) $this->lastWriteTimeUtc = JsonConverters::from('DateTime', $o['lastWriteTimeUtc']);
        if (isset($o['length'])) $this->length = $o['length'];
        if (isset($o['userId'])) $this->userId = $o['userId'];
        if (isset($o['groupId'])) $this->groupId = $o['groupId'];
        if (isset($o['othersCanRead'])) $this->othersCanRead = $o['othersCanRead'];
        if (isset($o['groupCanExecute'])) $this->groupCanExecute = $o['groupCanExecute'];
        if (isset($o['groupCanWrite'])) $this->groupCanWrite = $o['groupCanWrite'];
        if (isset($o['groupCanRead'])) $this->groupCanRead = $o['groupCanRead'];
        if (isset($o['ownerCanExecute'])) $this->ownerCanExecute = $o['ownerCanExecute'];
        if (isset($o['ownerCanWrite'])) $this->ownerCanWrite = $o['ownerCanWrite'];
        if (isset($o['ownerCanRead'])) $this->ownerCanRead = $o['ownerCanRead'];
        if (isset($o['othersCanExecute'])) $this->othersCanExecute = $o['othersCanExecute'];
        if (isset($o['othersCanWrite'])) $this->othersCanWrite = $o['othersCanWrite'];
        if (isset($o['extensions'])) $this->extensions = JsonConverters::from(JsonConverters::context('Dictionary',genericArgs:['string','string']), $o['extensions']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->name)) $o['name'] = $this->name;
        if (isset($this->fullName)) $o['fullName'] = $this->fullName;
        if (isset($this->lastAccessTime)) $o['lastAccessTime'] = JsonConverters::to('DateTime', $this->lastAccessTime);
        if (isset($this->lastAccessTimeUtc)) $o['lastAccessTimeUtc'] = JsonConverters::to('DateTime', $this->lastAccessTimeUtc);
        if (isset($this->lastWriteTime)) $o['lastWriteTime'] = JsonConverters::to('DateTime', $this->lastWriteTime);
        if (isset($this->lastWriteTimeUtc)) $o['lastWriteTimeUtc'] = JsonConverters::to('DateTime', $this->lastWriteTimeUtc);
        if (isset($this->length)) $o['length'] = $this->length;
        if (isset($this->userId)) $o['userId'] = $this->userId;
        if (isset($this->groupId)) $o['groupId'] = $this->groupId;
        if (isset($this->othersCanRead)) $o['othersCanRead'] = $this->othersCanRead;
        if (isset($this->groupCanExecute)) $o['groupCanExecute'] = $this->groupCanExecute;
        if (isset($this->groupCanWrite)) $o['groupCanWrite'] = $this->groupCanWrite;
        if (isset($this->groupCanRead)) $o['groupCanRead'] = $this->groupCanRead;
        if (isset($this->ownerCanExecute)) $o['ownerCanExecute'] = $this->ownerCanExecute;
        if (isset($this->ownerCanWrite)) $o['ownerCanWrite'] = $this->ownerCanWrite;
        if (isset($this->ownerCanRead)) $o['ownerCanRead'] = $this->ownerCanRead;
        if (isset($this->othersCanExecute)) $o['othersCanExecute'] = $this->othersCanExecute;
        if (isset($this->othersCanWrite)) $o['othersCanWrite'] = $this->othersCanWrite;
        if (isset($this->extensions)) $o['extensions'] = JsonConverters::to(JsonConverters::context('Dictionary',genericArgs:['string','string']), $this->extensions);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Represents a file that contains raw data content in bytes */
// @Api(Description="Represents a file that contains raw data content in bytes")
class BinaryFile extends FileBase implements JsonSerializable
{
    /**
     * @param ByteArray|null $content
     */
    public function __construct(
        ?ByteArray $content=null,
        /** @description The attributes of the file. */
        // @ApiMember(Description="The attributes of the file.", Name="Metadata")
        /** @var FileMetadata|null */
        public ?FileMetadata $metadata=null,

        /** @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")
        /** @var string|null */
        public ?string $name=null
    ) {
        parent::__construct($content);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['metadata'])) $this->metadata = JsonConverters::from('FileMetadata', $o['metadata']);
        if (isset($o['name'])) $this->name = $o['name'];
        if (isset($o['content'])) $this->content = JsonConverters::from('ByteArray', $o['content']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->metadata)) $o['metadata'] = JsonConverters::to('FileMetadata', $this->metadata);
        if (isset($this->name)) $o['name'] = $this->name;
        if (isset($this->content)) $o['content'] = JsonConverters::to('ByteArray', $this->content);
        return empty($o) ? new class(){} : $o;
    }
}

/** @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.")
class BearbeiteVorgangResponse extends EricFehlerCodeResponse implements JsonSerializable
{
    /**
     * @param string $id
     * @param int $index
     * @param ResponseStatus|null $responseStatus
     * @param EricFehlerCode|null $statusCode
     * @param string|null $statusText
     * @param string $id
     * @param int $index
     * @param ResponseStatus|null $responseStatus
     */
    public function __construct(
        string $id='',
        int $index=0,
        ?ResponseStatus $responseStatus=null,
        ?EricFehlerCode $statusCode=null,
        ?string $statusText=null,
        string $id='',
        int $index=0,
        ?ResponseStatus $responseStatus=null,
        /** @description The return value of the process. */
        // @ApiMember(Description="The return value of the process.")
        /** @var EricBearbeiteVorgang|null */
        public ?EricBearbeiteVorgang $rueckgabe=null,

        /** @description The server response of the process. */
        // @ApiMember(Description="The server response of the process.")
        /** @var Elster|null */
        public ?Elster $serverantwort=null,

        /** @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.")
        /** @var array<BinaryFile>|null */
        public ?array $transferProtocols=null
    ) {
        parent::__construct($id,$index,$responseStatus,$statusCode,$statusText,$id,$index,$responseStatus);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['rueckgabe'])) $this->rueckgabe = JsonConverters::from('EricBearbeiteVorgang', $o['rueckgabe']);
        if (isset($o['serverantwort'])) $this->serverantwort = JsonConverters::from('Elster', $o['serverantwort']);
        if (isset($o['transferProtocols'])) $this->transferProtocols = JsonConverters::fromArray('BinaryFile', $o['transferProtocols']);
        if (isset($o['statusCode'])) $this->statusCode = JsonConverters::from('EricFehlerCode', $o['statusCode']);
        if (isset($o['statusText'])) $this->statusText = $o['statusText'];
        if (isset($o['id'])) $this->id = $o['id'];
        if (isset($o['index'])) $this->index = $o['index'];
        if (isset($o['responseStatus'])) $this->responseStatus = JsonConverters::from('ResponseStatus', $o['responseStatus']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->rueckgabe)) $o['rueckgabe'] = JsonConverters::to('EricBearbeiteVorgang', $this->rueckgabe);
        if (isset($this->serverantwort)) $o['serverantwort'] = JsonConverters::to('Elster', $this->serverantwort);
        if (isset($this->transferProtocols)) $o['transferProtocols'] = JsonConverters::toArray('BinaryFile', $this->transferProtocols);
        if (isset($this->statusCode)) $o['statusCode'] = JsonConverters::to('EricFehlerCode', $this->statusCode);
        if (isset($this->statusText)) $o['statusText'] = $this->statusText;
        if (isset($this->id)) $o['id'] = $this->id;
        if (isset($this->index)) $o['index'] = $this->index;
        if (isset($this->responseStatus)) $o['responseStatus'] = JsonConverters::to('ResponseStatus', $this->responseStatus);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description An asynchronous service to create xml content that represents the annual VAT return for 2020. */
// @Api(Description="An asynchronous service to create xml content that represents the annual VAT return for 2020.")
class SubmitUmsatzsteuererklaerung2020Async extends SubmitUmsatzsteuererklaerung2020Base implements JsonSerializable
{
    /**
     * @param OrdNrArt|null $ordNrArt
     * @param VeranlagungVorgang|null $vorgang
     * @param string|null $stNr
     * @param string|null $id
     * @param string|null $idEhefrau
     * @param DateTime|null $erstelldatum
     * @param DateTime|null $erstellzeit
     * @param string|null $absName
     * @param string|null $absStr
     * @param string|null $absPlz
     * @param string|null $absOrt
     * @param string|null $copyright
     * @param Rueckuebermittlung|null $rueckuebermittlung
     * @param AllgemeineAngaben2020|null $allgemeineAngaben
     * @param AngabenBesteuerungKleinunternehmer2020|null $angabenBesteuerungKleinunternehmer
     * @param SteuerfreieLieferungenEtc2020|null $steuerfreieLieferungenEtc
     * @param SteuerpflichtigeLieferungenEtc2020|null $steuerpflichtigeLieferungenEtc
     * @param InnergemeinschaftlicheErwerbe2020|null $innergemeinschaftlicheErwerbe
     * @param SteuerschuldnerBeiAuslagerung2020|null $steuerschuldnerBeiAuslagerung
     * @param InnergemeinschaftlicheDreiecksgeschaefte2020|null $innergemeinschaftlicheDreiecksgeschaefte
     * @param LeistungsempfaengerAlsSteuerschuldner2020|null $leistungsempfaengerAlsSteuerschuldner
     * @param ErgaenzendeAngaben2020|null $ergaenzendeAngaben
     * @param AbziehbareVorsteuerbetraege2020|null $abziehbareVorsteuerbetraege
     * @param BerichtigungVorsteuerabzug2020|null $berichtigungVorsteuerabzug
     * @param BerechnungUmsatzsteuer2020|null $berechnungUmsatzsteuer
     * @param Unterschrift2020|null $unterschrift
     * @param AnlageUn2020|null $anlageUn
     * @param AnlageFv2020|null $anlageFv
     * @param string $bundesfinanzamtsnummer
     * @param string $datenLieferant
     * @param bool|null $duplexDruck
     * @param string $protocolPrefix
     * @param string|null $fussText
     * @param PortalCertificate|null $zertifikat
     */
    public function __construct(
        ?OrdNrArt $ordNrArt=null,
        ?VeranlagungVorgang $vorgang=null,
        ?string $stNr=null,
        ?string $id=null,
        ?string $idEhefrau=null,
        ?DateTime $erstelldatum=null,
        ?DateTime $erstellzeit=null,
        ?string $absName=null,
        ?string $absStr=null,
        ?string $absPlz=null,
        ?string $absOrt=null,
        ?string $copyright=null,
        ?Rueckuebermittlung $rueckuebermittlung=null,
        ?AllgemeineAngaben2020 $allgemeineAngaben=null,
        ?AngabenBesteuerungKleinunternehmer2020 $angabenBesteuerungKleinunternehmer=null,
        ?SteuerfreieLieferungenEtc2020 $steuerfreieLieferungenEtc=null,
        ?SteuerpflichtigeLieferungenEtc2020 $steuerpflichtigeLieferungenEtc=null,
        ?InnergemeinschaftlicheErwerbe2020 $innergemeinschaftlicheErwerbe=null,
        ?SteuerschuldnerBeiAuslagerung2020 $steuerschuldnerBeiAuslagerung=null,
        ?InnergemeinschaftlicheDreiecksgeschaefte2020 $innergemeinschaftlicheDreiecksgeschaefte=null,
        ?LeistungsempfaengerAlsSteuerschuldner2020 $leistungsempfaengerAlsSteuerschuldner=null,
        ?ErgaenzendeAngaben2020 $ergaenzendeAngaben=null,
        ?AbziehbareVorsteuerbetraege2020 $abziehbareVorsteuerbetraege=null,
        ?BerichtigungVorsteuerabzug2020 $berichtigungVorsteuerabzug=null,
        ?BerechnungUmsatzsteuer2020 $berechnungUmsatzsteuer=null,
        ?Unterschrift2020 $unterschrift=null,
        ?AnlageUn2020 $anlageUn=null,
        ?AnlageFv2020 $anlageFv=null,
        string $bundesfinanzamtsnummer='',
        string $datenLieferant='',
        ?bool $duplexDruck=null,
        string $protocolPrefix='',
        ?string $fussText=null,
        ?PortalCertificate $zertifikat=null
    ) {
        parent::__construct($ordNrArt,$vorgang,$stNr,$id,$idEhefrau,$erstelldatum,$erstellzeit,$absName,$absStr,$absPlz,$absOrt,$copyright,$rueckuebermittlung,$allgemeineAngaben,$angabenBesteuerungKleinunternehmer,$steuerfreieLieferungenEtc,$steuerpflichtigeLieferungenEtc,$innergemeinschaftlicheErwerbe,$steuerschuldnerBeiAuslagerung,$innergemeinschaftlicheDreiecksgeschaefte,$leistungsempfaengerAlsSteuerschuldner,$ergaenzendeAngaben,$abziehbareVorsteuerbetraege,$berichtigungVorsteuerabzug,$berechnungUmsatzsteuer,$unterschrift,$anlageUn,$anlageFv,$bundesfinanzamtsnummer,$datenLieferant,$duplexDruck,$protocolPrefix,$fussText,$zertifikat);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['ordNrArt'])) $this->ordNrArt = JsonConverters::from('OrdNrArt', $o['ordNrArt']);
        if (isset($o['vorgang'])) $this->vorgang = JsonConverters::from('VeranlagungVorgang', $o['vorgang']);
        if (isset($o['stNr'])) $this->stNr = $o['stNr'];
        if (isset($o['id'])) $this->id = $o['id'];
        if (isset($o['idEhefrau'])) $this->idEhefrau = $o['idEhefrau'];
        if (isset($o['erstelldatum'])) $this->erstelldatum = JsonConverters::from('DateTime', $o['erstelldatum']);
        if (isset($o['erstellzeit'])) $this->erstellzeit = JsonConverters::from('DateTime', $o['erstellzeit']);
        if (isset($o['absName'])) $this->absName = $o['absName'];
        if (isset($o['absStr'])) $this->absStr = $o['absStr'];
        if (isset($o['absPlz'])) $this->absPlz = $o['absPlz'];
        if (isset($o['absOrt'])) $this->absOrt = $o['absOrt'];
        if (isset($o['copyright'])) $this->copyright = $o['copyright'];
        if (isset($o['rueckuebermittlung'])) $this->rueckuebermittlung = JsonConverters::from('Rueckuebermittlung', $o['rueckuebermittlung']);
        if (isset($o['allgemeineAngaben'])) $this->allgemeineAngaben = JsonConverters::from('AllgemeineAngaben2020', $o['allgemeineAngaben']);
        if (isset($o['angabenBesteuerungKleinunternehmer'])) $this->angabenBesteuerungKleinunternehmer = JsonConverters::from('AngabenBesteuerungKleinunternehmer2020', $o['angabenBesteuerungKleinunternehmer']);
        if (isset($o['steuerfreieLieferungenEtc'])) $this->steuerfreieLieferungenEtc = JsonConverters::from('SteuerfreieLieferungenEtc2020', $o['steuerfreieLieferungenEtc']);
        if (isset($o['steuerpflichtigeLieferungenEtc'])) $this->steuerpflichtigeLieferungenEtc = JsonConverters::from('SteuerpflichtigeLieferungenEtc2020', $o['steuerpflichtigeLieferungenEtc']);
        if (isset($o['innergemeinschaftlicheErwerbe'])) $this->innergemeinschaftlicheErwerbe = JsonConverters::from('InnergemeinschaftlicheErwerbe2020', $o['innergemeinschaftlicheErwerbe']);
        if (isset($o['steuerschuldnerBeiAuslagerung'])) $this->steuerschuldnerBeiAuslagerung = JsonConverters::from('SteuerschuldnerBeiAuslagerung2020', $o['steuerschuldnerBeiAuslagerung']);
        if (isset($o['innergemeinschaftlicheDreiecksgeschaefte'])) $this->innergemeinschaftlicheDreiecksgeschaefte = JsonConverters::from('InnergemeinschaftlicheDreiecksgeschaefte2020', $o['innergemeinschaftlicheDreiecksgeschaefte']);
        if (isset($o['leistungsempfaengerAlsSteuerschuldner'])) $this->leistungsempfaengerAlsSteuerschuldner = JsonConverters::from('LeistungsempfaengerAlsSteuerschuldner2020', $o['leistungsempfaengerAlsSteuerschuldner']);
        if (isset($o['ergaenzendeAngaben'])) $this->ergaenzendeAngaben = JsonConverters::from('ErgaenzendeAngaben2020', $o['ergaenzendeAngaben']);
        if (isset($o['abziehbareVorsteuerbetraege'])) $this->abziehbareVorsteuerbetraege = JsonConverters::from('AbziehbareVorsteuerbetraege2020', $o['abziehbareVorsteuerbetraege']);
        if (isset($o['berichtigungVorsteuerabzug'])) $this->berichtigungVorsteuerabzug = JsonConverters::from('BerichtigungVorsteuerabzug2020', $o['berichtigungVorsteuerabzug']);
        if (isset($o['berechnungUmsatzsteuer'])) $this->berechnungUmsatzsteuer = JsonConverters::from('BerechnungUmsatzsteuer2020', $o['berechnungUmsatzsteuer']);
        if (isset($o['unterschrift'])) $this->unterschrift = JsonConverters::from('Unterschrift2020', $o['unterschrift']);
        if (isset($o['anlageUn'])) $this->anlageUn = JsonConverters::from('AnlageUn2020', $o['anlageUn']);
        if (isset($o['anlageFv'])) $this->anlageFv = JsonConverters::from('AnlageFv2020', $o['anlageFv']);
        if (isset($o['bundesfinanzamtsnummer'])) $this->bundesfinanzamtsnummer = $o['bundesfinanzamtsnummer'];
        if (isset($o['datenLieferant'])) $this->datenLieferant = $o['datenLieferant'];
        if (isset($o['duplexDruck'])) $this->duplexDruck = $o['duplexDruck'];
        if (isset($o['protocolPrefix'])) $this->protocolPrefix = $o['protocolPrefix'];
        if (isset($o['fussText'])) $this->fussText = $o['fussText'];
        if (isset($o['zertifikat'])) $this->zertifikat = JsonConverters::from('PortalCertificate', $o['zertifikat']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->ordNrArt)) $o['ordNrArt'] = JsonConverters::to('OrdNrArt', $this->ordNrArt);
        if (isset($this->vorgang)) $o['vorgang'] = JsonConverters::to('VeranlagungVorgang', $this->vorgang);
        if (isset($this->stNr)) $o['stNr'] = $this->stNr;
        if (isset($this->id)) $o['id'] = $this->id;
        if (isset($this->idEhefrau)) $o['idEhefrau'] = $this->idEhefrau;
        if (isset($this->erstelldatum)) $o['erstelldatum'] = JsonConverters::to('DateTime', $this->erstelldatum);
        if (isset($this->erstellzeit)) $o['erstellzeit'] = JsonConverters::to('DateTime', $this->erstellzeit);
        if (isset($this->absName)) $o['absName'] = $this->absName;
        if (isset($this->absStr)) $o['absStr'] = $this->absStr;
        if (isset($this->absPlz)) $o['absPlz'] = $this->absPlz;
        if (isset($this->absOrt)) $o['absOrt'] = $this->absOrt;
        if (isset($this->copyright)) $o['copyright'] = $this->copyright;
        if (isset($this->rueckuebermittlung)) $o['rueckuebermittlung'] = JsonConverters::to('Rueckuebermittlung', $this->rueckuebermittlung);
        if (isset($this->allgemeineAngaben)) $o['allgemeineAngaben'] = JsonConverters::to('AllgemeineAngaben2020', $this->allgemeineAngaben);
        if (isset($this->angabenBesteuerungKleinunternehmer)) $o['angabenBesteuerungKleinunternehmer'] = JsonConverters::to('AngabenBesteuerungKleinunternehmer2020', $this->angabenBesteuerungKleinunternehmer);
        if (isset($this->steuerfreieLieferungenEtc)) $o['steuerfreieLieferungenEtc'] = JsonConverters::to('SteuerfreieLieferungenEtc2020', $this->steuerfreieLieferungenEtc);
        if (isset($this->steuerpflichtigeLieferungenEtc)) $o['steuerpflichtigeLieferungenEtc'] = JsonConverters::to('SteuerpflichtigeLieferungenEtc2020', $this->steuerpflichtigeLieferungenEtc);
        if (isset($this->innergemeinschaftlicheErwerbe)) $o['innergemeinschaftlicheErwerbe'] = JsonConverters::to('InnergemeinschaftlicheErwerbe2020', $this->innergemeinschaftlicheErwerbe);
        if (isset($this->steuerschuldnerBeiAuslagerung)) $o['steuerschuldnerBeiAuslagerung'] = JsonConverters::to('SteuerschuldnerBeiAuslagerung2020', $this->steuerschuldnerBeiAuslagerung);
        if (isset($this->innergemeinschaftlicheDreiecksgeschaefte)) $o['innergemeinschaftlicheDreiecksgeschaefte'] = JsonConverters::to('InnergemeinschaftlicheDreiecksgeschaefte2020', $this->innergemeinschaftlicheDreiecksgeschaefte);
        if (isset($this->leistungsempfaengerAlsSteuerschuldner)) $o['leistungsempfaengerAlsSteuerschuldner'] = JsonConverters::to('LeistungsempfaengerAlsSteuerschuldner2020', $this->leistungsempfaengerAlsSteuerschuldner);
        if (isset($this->ergaenzendeAngaben)) $o['ergaenzendeAngaben'] = JsonConverters::to('ErgaenzendeAngaben2020', $this->ergaenzendeAngaben);
        if (isset($this->abziehbareVorsteuerbetraege)) $o['abziehbareVorsteuerbetraege'] = JsonConverters::to('AbziehbareVorsteuerbetraege2020', $this->abziehbareVorsteuerbetraege);
        if (isset($this->berichtigungVorsteuerabzug)) $o['berichtigungVorsteuerabzug'] = JsonConverters::to('BerichtigungVorsteuerabzug2020', $this->berichtigungVorsteuerabzug);
        if (isset($this->berechnungUmsatzsteuer)) $o['berechnungUmsatzsteuer'] = JsonConverters::to('BerechnungUmsatzsteuer2020', $this->berechnungUmsatzsteuer);
        if (isset($this->unterschrift)) $o['unterschrift'] = JsonConverters::to('Unterschrift2020', $this->unterschrift);
        if (isset($this->anlageUn)) $o['anlageUn'] = JsonConverters::to('AnlageUn2020', $this->anlageUn);
        if (isset($this->anlageFv)) $o['anlageFv'] = JsonConverters::to('AnlageFv2020', $this->anlageFv);
        if (isset($this->bundesfinanzamtsnummer)) $o['bundesfinanzamtsnummer'] = $this->bundesfinanzamtsnummer;
        if (isset($this->datenLieferant)) $o['datenLieferant'] = $this->datenLieferant;
        if (isset($this->duplexDruck)) $o['duplexDruck'] = $this->duplexDruck;
        if (isset($this->protocolPrefix)) $o['protocolPrefix'] = $this->protocolPrefix;
        if (isset($this->fussText)) $o['fussText'] = $this->fussText;
        if (isset($this->zertifikat)) $o['zertifikat'] = JsonConverters::to('PortalCertificate', $this->zertifikat);
        return empty($o) ? new class(){} : $o;
    }
}

PHP SubmitUmsatzsteuererklaerung2020Async 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 /SubmitUmsatzsteuererklaerung2020Async 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
		}
	}
}