Tax Filing Service

<back to all web services

CreateUmsatzsteuererklaerung2023Xml

SyncUmsatzsteuerJahressteuererklärung2023

A synchronous service to create XML content that represents the annual VAT return for 2023.

Requires Authentication
The following routes are available for this service:
POST/CreateUmsatzsteuererklaerung2023XmlA synchronous service to create xml content that represents the annual VAT return for 2023
<?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 Basisklasse für einen benutzerdefinierten Datentyp */
// @Api(Description="Basisklasse für einen benutzerdefinierten Datentyp")
class CustomTypBase implements ICustomTyp, JsonSerializable
{
    public function __construct(
        /** @description Identifizierung der Zeile / Typ im Fremdprogramm. */
        // @ApiMember(Description="Identifizierung der Zeile / Typ im Fremdprogramm.", Name="Alias")
        /** @var string|null */
        public ?string $alias=null
    ) {
    }

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

/** @description Boolescher Datentyp, welcher als '1' (Ja) oder '' (Nein) im Jahressteuererklärung angeschrieben wird. */
// @Api(Description="Boolescher Datentyp, welcher als '1' (Ja) oder '' (Nein) im Jahressteuererklärung angeschrieben wird.")
class Bool1Typ extends CustomTypBase implements JsonSerializable
{
    /**
     * @param string|null $alias
     */
    public function __construct(
        ?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($alias);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['wert'])) $this->wert = $o['wert'];
        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->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Berichtigte Erklärung */
// @Api(Description="Berichtigte Erklärung")
class BerErkl2023 implements JsonSerializable
{
    public function __construct(
        /** @description Berichtigte Steuererklärung */
        // @ApiMember(Description="Berichtigte Steuererklärung", Name="E3000601")
        /** @var Bool1Typ|null */
        public ?Bool1Typ $e3000601=null
    ) {
    }

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

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

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['wert'])) $this->wert = $o['wert'];
        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->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Adresse oder Postfach eines Unternehmens */
// @Api(Description="Adresse oder Postfach eines Unternehmens")
class UnternehmenAdr2023 implements JsonSerializable
{
    public function __construct(
        /** @description Straße */
        // @ApiMember(Description="Straße", IsRequired=true, Name="E3001101")
        // @Validate(Validator="NotNull")
        /** @var StringTyp|null */
        public ?StringTyp $e3001101=null,

        /** @description Hausnummer */
        // @ApiMember(Description="Hausnummer", IsRequired=true, Name="E3001203")
        // @Validate(Validator="NotNull")
        /** @var StringTyp|null */
        public ?StringTyp $e3001203=null,

        /** @description Hausnummerzusatz */
        // @ApiMember(Description="Hausnummerzusatz", Name="E3001204")
        /** @var StringTyp|null */
        public ?StringTyp $e3001204=null,

        /** @description Adressergänzung */
        // @ApiMember(Description="Adressergänzung", Name="E3001205")
        /** @var StringTyp|null */
        public ?StringTyp $e3001205=null,

        /** @description Postleitzahl */
        // @ApiMember(Description="Postleitzahl", Name="E3001206")
        /** @var StringTyp|null */
        public ?StringTyp $e3001206=null,

        /** @description Ort */
        // @ApiMember(Description="Ort", Name="E3001207")
        /** @var StringTyp|null */
        public ?StringTyp $e3001207=null,

        /** @description Postleitzahl zu Postfach */
        // @ApiMember(Description="Postleitzahl zu Postfach", Name="E3001403")
        /** @var StringTyp|null */
        public ?StringTyp $e3001403=null,

        /** @description Postfach */
        // @ApiMember(Description="Postfach", Name="E3001404")
        /** @var StringTyp|null */
        public ?StringTyp $e3001404=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['e3001101'])) $this->e3001101 = JsonConverters::from('StringTyp', $o['e3001101']);
        if (isset($o['e3001203'])) $this->e3001203 = JsonConverters::from('StringTyp', $o['e3001203']);
        if (isset($o['e3001204'])) $this->e3001204 = JsonConverters::from('StringTyp', $o['e3001204']);
        if (isset($o['e3001205'])) $this->e3001205 = JsonConverters::from('StringTyp', $o['e3001205']);
        if (isset($o['e3001206'])) $this->e3001206 = JsonConverters::from('StringTyp', $o['e3001206']);
        if (isset($o['e3001207'])) $this->e3001207 = JsonConverters::from('StringTyp', $o['e3001207']);
        if (isset($o['e3001403'])) $this->e3001403 = JsonConverters::from('StringTyp', $o['e3001403']);
        if (isset($o['e3001404'])) $this->e3001404 = JsonConverters::from('StringTyp', $o['e3001404']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->e3001101)) $o['e3001101'] = JsonConverters::to('StringTyp', $this->e3001101);
        if (isset($this->e3001203)) $o['e3001203'] = JsonConverters::to('StringTyp', $this->e3001203);
        if (isset($this->e3001204)) $o['e3001204'] = JsonConverters::to('StringTyp', $this->e3001204);
        if (isset($this->e3001205)) $o['e3001205'] = JsonConverters::to('StringTyp', $this->e3001205);
        if (isset($this->e3001206)) $o['e3001206'] = JsonConverters::to('StringTyp', $this->e3001206);
        if (isset($this->e3001207)) $o['e3001207'] = JsonConverters::to('StringTyp', $this->e3001207);
        if (isset($this->e3001403)) $o['e3001403'] = JsonConverters::to('StringTyp', $this->e3001403);
        if (isset($this->e3001404)) $o['e3001404'] = JsonConverters::to('StringTyp', $this->e3001404);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Kontakt eines Unternehmens */
// @Api(Description="Kontakt eines Unternehmens")
class UnternehmenKontakt2023 implements JsonSerializable
{
    public function __construct(
        /** @description Telefon */
        // @ApiMember(Description="Telefon", Name="E3001202")
        /** @var StringTyp|null */
        public ?StringTyp $e3001202=null,

        /** @description E-Mail Adresse */
        // @ApiMember(Description="E-Mail Adresse", Name="E3001301")
        /** @var StringTyp|null */
        public ?StringTyp $e3001301=null
    ) {
    }

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

/** @description Angaben zum Unternehmen */
// @Api(Description="Angaben zum Unternehmen")
class Unternehmen2023 implements JsonSerializable
{
    public function __construct(
        /** @description Name des Unternehmers */
        // @ApiMember(Description="Name des Unternehmers", IsRequired=true, Name="E3000901")
        /** @var StringTyp|null */
        public ?StringTyp $e3000901=null,

        /** @description ggf. abweichender Firmenname */
        // @ApiMember(Description="ggf. abweichender Firmenname", Name="E3000902")
        /** @var StringTyp|null */
        public ?StringTyp $e3000902=null,

        /** @description Art des Unternehmens */
        // @ApiMember(Description="Art des Unternehmens", Name="E3001001")
        /** @var StringTyp|null */
        public ?StringTyp $e3001001=null,

        /** @description Adresse oder Postfach */
        // @ApiMember(Description="Adresse oder Postfach", Name="Adr")
        /** @var UnternehmenAdr2023|null */
        public ?UnternehmenAdr2023 $adr=null,

        /** @description Kontakt */
        // @ApiMember(Description="Kontakt", Name="Kontakt")
        /** @var UnternehmenKontakt2023|null */
        public ?UnternehmenKontakt2023 $kontakt=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['e3000901'])) $this->e3000901 = JsonConverters::from('StringTyp', $o['e3000901']);
        if (isset($o['e3000902'])) $this->e3000902 = JsonConverters::from('StringTyp', $o['e3000902']);
        if (isset($o['e3001001'])) $this->e3001001 = JsonConverters::from('StringTyp', $o['e3001001']);
        if (isset($o['adr'])) $this->adr = JsonConverters::from('UnternehmenAdr2023', $o['adr']);
        if (isset($o['kontakt'])) $this->kontakt = JsonConverters::from('UnternehmenKontakt2023', $o['kontakt']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->e3000901)) $o['e3000901'] = JsonConverters::to('StringTyp', $this->e3000901);
        if (isset($this->e3000902)) $o['e3000902'] = JsonConverters::to('StringTyp', $this->e3000902);
        if (isset($this->e3001001)) $o['e3001001'] = JsonConverters::to('StringTyp', $this->e3001001);
        if (isset($this->adr)) $o['adr'] = JsonConverters::to('UnternehmenAdr2023', $this->adr);
        if (isset($this->kontakt)) $o['kontakt'] = JsonConverters::to('UnternehmenKontakt2023', $this->kontakt);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Im Ausland ansässiger Unternehmer */
// @Api(Description="Im Ausland ansässiger Unternehmer")
class ImAuslAnsUnt2023 implements JsonSerializable
{
    public function __construct(
        /** @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="E3001402")
        /** @var Bool1Typ|null */
        public ?Bool1Typ $e3001402=null
    ) {
    }

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

/** @description Fiskalvertreter */
// @Api(Description="Fiskalvertreter")
class Fiskalvertr2023 implements JsonSerializable
{
    public function __construct(
        /** @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="E3001801")
        /** @var Bool1Typ|null */
        public ?Bool1Typ $e3001801=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['e3001801'])) $this->e3001801 = JsonConverters::from('Bool1Typ', $o['e3001801']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->e3001801)) $o['e3001801'] = JsonConverters::to('Bool1Typ', $this->e3001801);
        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 Datum-Uhrzeit-Typ. Format: TT.MM - TT. MM */
// @Api(Description="Datum-Uhrzeit-Typ. Format: TT.MM - TT. MM")
class ZeitraumTyp extends CustomTypBase implements JsonSerializable
{
    /**
     * @param string|null $alias
     */
    public function __construct(
        ?string $alias=null,
        /** @description Wert des Datentyps. */
        // @ApiMember(Description="Wert des Datentyps.", IsRequired=true, Name="Wert")
        /** @var ErklaerungZeitraum|null */
        public ?ErklaerungZeitraum $wert=null
    ) {
        parent::__construct($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['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->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Dauer der Unternehmereigenschaft */
// @Api(Description="Dauer der Unternehmereigenschaft")
class DauerUntEig2023 implements JsonSerializable
{
    public function __construct(
        /** @description 1. Zeitraum */
        // @ApiMember(Description="1. Zeitraum", Name="E3001401")
        /** @var ZeitraumTyp|null */
        public ?ZeitraumTyp $e3001401=null,

        /** @description 2. Zeitraum */
        // @ApiMember(Description="2. Zeitraum", Name="E3001501")
        /** @var ZeitraumTyp|null */
        public ?ZeitraumTyp $e3001501=null
    ) {
    }

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

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

/** @description Datentyp, welches die Art der Entgeltart darstellt. */
// @Api(Description="Datentyp, welches die Art der Entgeltart darstellt.")
class EntgeltartTyp extends CustomTypBase implements JsonSerializable
{
    /**
     * @param string|null $alias
     */
    public function __construct(
        ?string $alias=null,
        /** @description Wert des Datentyps. */
        // @ApiMember(Description="Wert des Datentyps.", IsRequired=true, Name="Wert")
        /** @var Entgeltart|null */
        public ?Entgeltart $wert=null
    ) {
        parent::__construct($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['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->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Besteuerung der Entgelte */
// @Api(Description="Besteuerung der Entgelte")
class BestArt2023 implements JsonSerializable
{
    public function __construct(
        /** @description Die Steuer wurde berechnet nach */
        // @ApiMember(Description="Die Steuer wurde berechnet nach", IsRequired=true, Name="E3002203")
        /** @var EntgeltartTyp|null */
        public ?EntgeltartTyp $e3002203=null
    ) {
    }

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

/** @description Verrechnung / Abtretung */
// @Api(Description="Verrechnung / Abtretung")
class Verrech2023 implements JsonSerializable
{
    public function __construct(
        /** @description Verrechnung des Erstattungsbetrages erwünscht / Erstattungsbetrag ist abgetreten (Teilen Sie bitte die Verrechnungswünsche dem Finanzamt gesondert mit). */
        // @ApiMember(Description="Verrechnung des Erstattungsbetrages erwünscht / Erstattungsbetrag ist abgetreten (Teilen Sie bitte die Verrechnungswünsche dem Finanzamt gesondert mit).", Name="E3001701")
        /** @var Bool1Typ|null */
        public ?Bool1Typ $e3001701=null
    ) {
    }

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

/** @description Ergänzende Angaben zur Steuererklärung */
// @Api(Description="Ergänzende Angaben zur Steuererklärung")
class ErgAngErkl2023 implements JsonSerializable
{
    public function __construct(
        /** @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="E3002201")
        /** @var Bool1Typ|null */
        public ?Bool1Typ $e3002201=null,

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

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

/** @description Allgemeine Angaben */
// @Api(Description="Allgemeine Angaben")
class Allg2023 implements JsonSerializable
{
    public function __construct(
        /** @description Angaben zum Unternehmen */
        // @ApiMember(Description="Angaben zum Unternehmen", IsRequired=true, Name="Unternehmen")
        // @Validate(Validator="NotNull")
        /** @var Unternehmen2023|null */
        public ?Unternehmen2023 $unternehmen=null,

        /** @description Im Ausland ansässiger Unternehmer? */
        // @ApiMember(Description="Im Ausland ansässiger Unternehmer?", Name="ImAuslAnsUnt")
        /** @var ImAuslAnsUnt2023|null */
        public ?ImAuslAnsUnt2023 $imAuslAnsUnt=null,

        /** @description Fiskalvertreter? */
        // @ApiMember(Description="Fiskalvertreter?", Name="Fiskalvetr")
        /** @var Fiskalvertr2023|null */
        public ?Fiskalvertr2023 $fiskalvetr=null,

        /** @description Dauer der Unternehmereigenschaft (falls nicht vom 1. Januar bis zum 31. Dezember 2023) */
        // @ApiMember(Description="Dauer der Unternehmereigenschaft (falls nicht vom 1. Januar bis zum 31. Dezember 2023)", Name="DauerUntEig")
        /** @var DauerUntEig2023|null */
        public ?DauerUntEig2023 $dauerUntEig=null,

        /** @description Besteuerungen der Entgelte */
        // @ApiMember(Description="Besteuerungen der Entgelte", Name="BestArt")
        /** @var BestArt2023|null */
        public ?BestArt2023 $bestArt=null,

        /** @description Verrechnungen / Abtretungen */
        // @ApiMember(Description="Verrechnungen / Abtretungen", Name="Verrech")
        /** @var Verrech2023|null */
        public ?Verrech2023 $verrech=null,

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

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['unternehmen'])) $this->unternehmen = JsonConverters::from('Unternehmen2023', $o['unternehmen']);
        if (isset($o['imAuslAnsUnt'])) $this->imAuslAnsUnt = JsonConverters::from('ImAuslAnsUnt2023', $o['imAuslAnsUnt']);
        if (isset($o['fiskalvetr'])) $this->fiskalvetr = JsonConverters::from('Fiskalvertr2023', $o['fiskalvetr']);
        if (isset($o['dauerUntEig'])) $this->dauerUntEig = JsonConverters::from('DauerUntEig2023', $o['dauerUntEig']);
        if (isset($o['bestArt'])) $this->bestArt = JsonConverters::from('BestArt2023', $o['bestArt']);
        if (isset($o['verrech'])) $this->verrech = JsonConverters::from('Verrech2023', $o['verrech']);
        if (isset($o['ergAngErkl'])) $this->ergAngErkl = JsonConverters::from('ErgAngErkl2023', $o['ergAngErkl']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->unternehmen)) $o['unternehmen'] = JsonConverters::to('Unternehmen2023', $this->unternehmen);
        if (isset($this->imAuslAnsUnt)) $o['imAuslAnsUnt'] = JsonConverters::to('ImAuslAnsUnt2023', $this->imAuslAnsUnt);
        if (isset($this->fiskalvetr)) $o['fiskalvetr'] = JsonConverters::to('Fiskalvertr2023', $this->fiskalvetr);
        if (isset($this->dauerUntEig)) $o['dauerUntEig'] = JsonConverters::to('DauerUntEig2023', $this->dauerUntEig);
        if (isset($this->bestArt)) $o['bestArt'] = JsonConverters::to('BestArt2023', $this->bestArt);
        if (isset($this->verrech)) $o['verrech'] = JsonConverters::to('Verrech2023', $this->verrech);
        if (isset($this->ergAngErkl)) $o['ergAngErkl'] = JsonConverters::to('ErgAngErkl2023', $this->ergAngErkl);
        return empty($o) ? new class(){} : $o;
    }
}

class Kanzlei2023 implements JsonSerializable
{
    public function __construct(
        /** @description Bearbeiterkennzeichen */
        // @ApiMember(Description="Bearbeiterkennzeichen", Name="E3002509")
        /** @var StringTyp|null */
        public ?StringTyp $e3002509=null,

        /** @description Mandantennummer */
        // @ApiMember(Description="Mandantennummer", Name="E3002506")
        /** @var StringTyp|null */
        public ?StringTyp $e3002506=null,

        /** @description (Feld? wird nicht gedruckt) Ihr Zeichen/gegebenenfalls Zuordnungskriterium für Bescheiddatenübermittlung */
        // @ApiMember(Description="(Feld? wird nicht gedruckt) Ihr Zeichen/gegebenenfalls Zuordnungskriterium für Bescheiddatenübermittlung", Name="E3002507")
        /** @var StringTyp|null */
        public ?StringTyp $e3002507=null
    ) {
    }

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

class Bearb2023 implements JsonSerializable
{
    public function __construct(
        /** @description Name */
        // @ApiMember(Description="Name", Name="E3002501")
        /** @var StringTyp|null */
        public ?StringTyp $e3002501=null,

        /** @description Vorname */
        // @ApiMember(Description="Vorname", Name="E3002502")
        /** @var StringTyp|null */
        public ?StringTyp $e3002502=null
    ) {
    }

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

class MitwirkAdr2023 implements JsonSerializable
{
    public function __construct(
        /** @description Straße, Hausnummer */
        // @ApiMember(Description="Straße, Hausnummer", Name="E3002503")
        /** @var StringTyp|null */
        public ?StringTyp $e3002503=null,

        /** @description Postleitzahl, Wohnort */
        // @ApiMember(Description="Postleitzahl, Wohnort", Name="E3002504")
        /** @var StringTyp|null */
        public ?StringTyp $e3002504=null
    ) {
    }

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

class MitwirkKontakt2023 implements JsonSerializable
{
    public function __construct(
        /** @description Telefon */
        // @ApiMember(Description="Telefon", Name="E3002505")
        /** @var StringTyp|null */
        public ?StringTyp $e3002505=null,

        /** @description zusätzliche Angaben */
        // @ApiMember(Description="zusätzliche Angaben", Name="E3002508")
        /** @var StringTyp|null */
        public ?StringTyp $e3002508=null
    ) {
    }

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

class MitwirkErkl2023 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="E3002602")
        /** @var Bool1Typ|null */
        public ?Bool1Typ $e3002602=null
    ) {
    }

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

/** @description Angaben zum Mitwirkender, der bei der Anfertigung dieser Steuererklärung einschließlich der Anlagen mitgewirkt hat. */
// @Api(Description="Angaben zum Mitwirkender, der bei der Anfertigung dieser Steuererklärung einschließlich der Anlagen mitgewirkt hat.")
class Mitwirk2023 implements JsonSerializable
{
    public function __construct(
        /** @description Angaben zu den Kanzleien */
        // @ApiMember(Description="Angaben zu den Kanzleien", Name="Kanzlei")
        /** @var Kanzlei2023|null */
        public ?Kanzlei2023 $kanzlei=null,

        /** @description Angaben zu den Bearbeiter */
        // @ApiMember(Description="Angaben zu den Bearbeiter", Name="Bearb")
        /** @var Bearb2023|null */
        public ?Bearb2023 $bearb=null,

        /** @description Adressen der Mitwirkende */
        // @ApiMember(Description="Adressen der Mitwirkende", Name="Adr")
        /** @var MitwirkAdr2023|null */
        public ?MitwirkAdr2023 $adr=null,

        /** @description Kontakte der Mitwirkende */
        // @ApiMember(Description="Kontakte der Mitwirkende", Name="Kontakt")
        /** @var MitwirkKontakt2023|null */
        public ?MitwirkKontakt2023 $kontakt=null,

        /** @description Mitwirkungen bei der Steuererklärung */
        // @ApiMember(Description="Mitwirkungen bei der Steuererklärung", Name="MitwirkErkl")
        /** @var MitwirkErkl2023|null */
        public ?MitwirkErkl2023 $mitwirkErkl=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['kanzlei'])) $this->kanzlei = JsonConverters::from('Kanzlei2023', $o['kanzlei']);
        if (isset($o['bearb'])) $this->bearb = JsonConverters::from('Bearb2023', $o['bearb']);
        if (isset($o['adr'])) $this->adr = JsonConverters::from('MitwirkAdr2023', $o['adr']);
        if (isset($o['kontakt'])) $this->kontakt = JsonConverters::from('MitwirkKontakt2023', $o['kontakt']);
        if (isset($o['mitwirkErkl'])) $this->mitwirkErkl = JsonConverters::from('MitwirkErkl2023', $o['mitwirkErkl']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->kanzlei)) $o['kanzlei'] = JsonConverters::to('Kanzlei2023', $this->kanzlei);
        if (isset($this->bearb)) $o['bearb'] = JsonConverters::to('Bearb2023', $this->bearb);
        if (isset($this->adr)) $o['adr'] = JsonConverters::to('MitwirkAdr2023', $this->adr);
        if (isset($this->kontakt)) $o['kontakt'] = JsonConverters::to('MitwirkKontakt2023', $this->kontakt);
        if (isset($this->mitwirkErkl)) $o['mitwirkErkl'] = JsonConverters::to('MitwirkErkl2023', $this->mitwirkErkl);
        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 6 Stellen. Mindestens eine Ziffer und maximal 5 Ziffern. Minusvorzeichen erlaubt. */
// @Api(Description="Geldbetrag ohne Cent mit 6 Stellen. Mindestens eine Ziffer und maximal 5 Ziffern. Minusvorzeichen erlaubt.")
class GeldBetragOhneCent5DETyp extends CustomTypBase implements JsonSerializable
{
    /**
     * @param string|null $alias
     */
    public function __construct(
        ?string $alias=null,
        /** @description Wert des Datentyps. Mindestens eine Ziffer und maximal 5 Ziffern. Minusvorzeichen erlaubt. */
        // @ApiMember(Description="Wert des Datentyps. Mindestens eine Ziffer und maximal 5 Ziffern. Minusvorzeichen erlaubt.", IsRequired=true)
        /** @var GeldBetragOhneCent5DE|null */
        public ?GeldBetragOhneCent5DE $betrag=null
    ) {
        parent::__construct($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['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->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 13 Stellen. Mindestens eine Ziffer und maximal 12 Ziffern. Minusvorzeichen erlaubt. */
// @Api(Description="Geldbetrag ohne Cent mit 13 Stellen. Mindestens eine Ziffer und maximal 12 Ziffern. Minusvorzeichen erlaubt.")
class GeldBetragOhneCent12DETyp extends CustomTypBase implements JsonSerializable
{
    /**
     * @param string|null $alias
     */
    public function __construct(
        ?string $alias=null,
        /** @description Wert des Datentyps. Mindestens eine Ziffer und maximal 12 Ziffern. Minusvorzeichen erlaubt. */
        // @ApiMember(Description="Wert des Datentyps. Mindestens eine Ziffer und maximal 12 Ziffern. Minusvorzeichen erlaubt.", IsRequired=true)
        /** @var GeldBetragOhneCent12DE|null */
        public ?GeldBetragOhneCent12DE $betrag=null
    ) {
        parent::__construct($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['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->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Kleinenuntern Betrag Tabelle 2023 */
// @Api(Description="Kleinenuntern Betrag Tabelle 2023")
class KleineunternTabelle2023 implements JsonSerializable
{
    public function __construct(
        /** @description Umsatz im Kalenderjahr 2022 (Berechnung nach § 19 Absatz 1 und 3 UStG) */
        // @ApiMember(Description="Umsatz im Kalenderjahr 2022 (Berechnung nach § 19 Absatz 1 und 3 UStG)", Name="E3002301")
        /** @var GeldBetragOhneCent5DETyp|null */
        public ?GeldBetragOhneCent5DETyp $e3002301=null,

        /** @description Umsatz im Kalenderjahr 2023 (Berechnung nach § 19 Absatz 1 und 3 UStG) */
        // @ApiMember(Description="Umsatz im Kalenderjahr 2023 (Berechnung nach § 19 Absatz 1 und 3 UStG)", Name="E3002401")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3002401=null
    ) {
    }

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

/** @description Angaben der Besteuerung von Kleinunternehmer der Umsatzsteuererklärung. */
// @Api(Description="Angaben der Besteuerung von Kleinunternehmer der Umsatzsteuererklärung.")
class Kleinuntern2023 implements JsonSerializable
{
    public function __construct(
        /** @description Betrag Tabelle */
        // @ApiMember(Description="Betrag Tabelle", Name="Tabelle")
        /** @var KleineunternTabelle2023|null */
        public ?KleineunternTabelle2023 $tabelle=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['tabelle'])) $this->tabelle = JsonConverters::from('KleineunternTabelle2023', $o['tabelle']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->tabelle)) $o['tabelle'] = JsonConverters::to('KleineunternTabelle2023', $this->tabelle);
        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 GeldBetragMitCent12DETyp extends CustomTypBase implements JsonSerializable
{
    /**
     * @param string|null $alias
     */
    public function __construct(
        ?string $alias=null,
        /** @description Wert des Datentyps. Mindestens eine Ziffer und maximal 12 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen erlaubt. */
        // @ApiMember(Description="Wert des Datentyps. Mindestens eine Ziffer und maximal 12 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen erlaubt.", IsRequired=true, Name="Betrag")
        /** @var GeldBetragMitCent12DE|null */
        public ?GeldBetragMitCent12DE $betrag=null
    ) {
        parent::__construct($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['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->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Umsätze zum Unentgeltliche Wertabgaben */
// @Api(Description="Umsätze zum Unentgeltliche Wertabgaben")
class UmsAllgUnentWertabgaben2023 implements JsonSerializable
{
    public function __construct(
        /** @description Lieferungen nach § 3 Absatz 1b UStG zu 19 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
        // @ApiMember(Description="Lieferungen nach § 3 Absatz 1b UStG zu 19 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3003405")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3003405=null,

        /** @description Lieferungen nach § 3 Absatz 1b UStG zu 19 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
        // @ApiMember(Description="Lieferungen nach § 3 Absatz 1b UStG zu 19 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3003406")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3003406=null,

        /** @description Sonstige Leistungen nach § 3 Absatz 9a UStG zu 19 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
        // @ApiMember(Description="Sonstige Leistungen nach § 3 Absatz 9a UStG zu 19 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3003505")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3003505=null,

        /** @description Sonstige Leistungen nach § 3 Absatz 9a UStG zu 19 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
        // @ApiMember(Description="Sonstige Leistungen nach § 3 Absatz 9a UStG zu 19 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3003506")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3003506=null
    ) {
    }

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

/** @description Umsätze zum allgemeinen Steuersatz */
// @Api(Description="Umsätze zum allgemeinen Steuersatz")
class UmsAllg2023 implements JsonSerializable
{
    public function __construct(
        /** @description Lieferungen und sonstige Leistungen zu 19 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
        // @ApiMember(Description="Lieferungen und sonstige Leistungen zu 19 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3003303")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3003303=null,

        /** @description Lieferungen und sonstige Leistungen zu 19 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
        // @ApiMember(Description="Lieferungen und sonstige Leistungen zu 19 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3003304")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3003304=null,

        /** @description Umsätze zum Unentgeltliche Wertabgaben */
        // @ApiMember(Description="Umsätze zum Unentgeltliche Wertabgaben", Name="Unent_Wertabgaben")
        /** @var UmsAllgUnentWertabgaben2023|null */
        public ?UmsAllgUnentWertabgaben2023 $unent_Wertabgaben=null
    ) {
    }

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

/** @description Umsätze zum ermäßigten Steuersatz Unentgeltliche Wertabgaben */
// @Api(Description="Umsätze zum ermäßigten Steuersatz Unentgeltliche Wertabgaben")
class UmsErmUnentWertabgaben2023 implements JsonSerializable
{
    public function __construct(
        /** @description Lieferungen nach § 3 Absatz 1b UStG zu 7 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
        // @ApiMember(Description="Lieferungen nach § 3 Absatz 1b UStG zu 7 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3003703")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3003703=null,

        /** @description Lieferungen nach § 3 Absatz 1b UStG zu 7 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
        // @ApiMember(Description="Lieferungen nach § 3 Absatz 1b UStG zu 7 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3003704")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3003704=null,

        /** @description Sonstige Leistungen nach § 3 Absatz 9a UStG zu 7 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
        // @ApiMember(Description="Sonstige Leistungen nach § 3 Absatz 9a UStG zu 7 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3003803")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3003803=null,

        /** @description Sonstige Leistungen nach § 3 Absatz 9a UStG zu 7 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
        // @ApiMember(Description="Sonstige Leistungen nach § 3 Absatz 9a UStG zu 7 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3003804")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3003804=null
    ) {
    }

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

/** @description Umsätze zum ermäßigten Steuersatz */
// @Api(Description="Umsätze zum ermäßigten Steuersatz")
class UmsErm2023 implements JsonSerializable
{
    public function __construct(
        /** @description Lieferungen und sonstige Leistungen zu 7 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
        // @ApiMember(Description="Lieferungen und sonstige Leistungen zu 7 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3004401")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3004401=null,

        /** @description Lieferungen und sonstige Leistungen zu 7 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
        // @ApiMember(Description="Lieferungen und sonstige Leistungen zu 7 % (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3004402")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3004402=null,

        /** @description Umsätze zum ermäßigten Steuersatz Unentgeltliche Wertabgaben */
        // @ApiMember(Description="Umsätze zum ermäßigten Steuersatz Unentgeltliche Wertabgaben", Name="Unent_Wertabgaben")
        /** @var UmsErmUnentWertabgaben2023|null */
        public ?UmsErmUnentWertabgaben2023 $unent_Wertabgaben=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['e3004401'])) $this->e3004401 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3004401']);
        if (isset($o['e3004402'])) $this->e3004402 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3004402']);
        if (isset($o['unent_Wertabgaben'])) $this->unent_Wertabgaben = JsonConverters::from('UmsErmUnentWertabgaben2023', $o['unent_Wertabgaben']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->e3004401)) $o['e3004401'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3004401);
        if (isset($this->e3004402)) $o['e3004402'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3004402);
        if (isset($this->unent_Wertabgaben)) $o['unent_Wertabgaben'] = JsonConverters::to('UmsErmUnentWertabgaben2023', $this->unent_Wertabgaben);
        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 PositiverGeldBetragOhneCent12DETyp extends CustomTypBase implements JsonSerializable
{
    /**
     * @param string|null $alias
     */
    public function __construct(
        ?string $alias=null,
        /** @description Wert des Datentyps. Mindestens eine Ziffer und maximal 12 Ziffern. Minusvorzeichen NICHT erlaubt. */
        // @ApiMember(Description="Wert des Datentyps. Mindestens eine Ziffer und maximal 12 Ziffern. Minusvorzeichen NICHT erlaubt.", IsRequired=true)
        /** @var PositiverGeldBetragOhneCent12DE|null */
        public ?PositiverGeldBetragOhneCent12DE $betrag=null
    ) {
        parent::__construct($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['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->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Umsätze zum ermäßigten Steuersatz von 0 % (Unentgeltliche Wertabgaben) */
// @Api(Description="Umsätze zum ermäßigten Steuersatz von 0 % (Unentgeltliche Wertabgaben)")
class UmsErm0UnentWertabgaben2023 implements JsonSerializable
{
    public function __construct(
        /** @description Lieferungen nach § 3 Absatz 1b UStG zu 0 % (Bemessungsgrundlage ohne Umsatzsteuer Steuer) */
        // @ApiMember(Description="Lieferungen nach § 3 Absatz 1b UStG zu 0 % (Bemessungsgrundlage ohne Umsatzsteuer Steuer)", Name="E3002901")
        /** @var PositiverGeldBetragOhneCent12DETyp|null */
        public ?PositiverGeldBetragOhneCent12DETyp $e3002901=null,

        /** @description Sonstige Leistungen nach § 3 Absatz 9a UStG zu 0 % (Bemessungsgrundlage ohne Umsatzsteuer Steuer) */
        // @ApiMember(Description="Sonstige Leistungen nach § 3 Absatz 9a UStG zu 0 % (Bemessungsgrundlage ohne Umsatzsteuer Steuer)", Name="E3003001")
        /** @var PositiverGeldBetragOhneCent12DETyp|null */
        public ?PositiverGeldBetragOhneCent12DETyp $e3003001=null
    ) {
    }

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

/** @description Umsätze zum ermäßigten Steuersatz von 0 % */
// @Api(Description="Umsätze zum ermäßigten Steuersatz von 0 %")
class UmsErm02023 implements JsonSerializable
{
    public function __construct(
        /** @description Lieferungen und sonstige Leistungen zu 0 % (Bemessungsgrundlage ohne Umsatzsteuer Steuer) */
        // @ApiMember(Description="Lieferungen und sonstige Leistungen zu 0 % (Bemessungsgrundlage ohne Umsatzsteuer Steuer)", Name="E3002801")
        /** @var PositiverGeldBetragOhneCent12DETyp|null */
        public ?PositiverGeldBetragOhneCent12DETyp $e3002801=null,

        /** @description Umsätze zum ermäßigten Steuersatz von 0 % (Unentgeltliche Wertabgaben) */
        // @ApiMember(Description="Umsätze zum ermäßigten Steuersatz von 0 % (Unentgeltliche Wertabgaben)", Name="Unent_Wertabgaben")
        /** @var UmsErm0UnentWertabgaben2023|null */
        public ?UmsErm0UnentWertabgaben2023 $unent_Wertabgaben=null
    ) {
    }

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

/** @description Umsätze zu anderen Steuersätzen (Bemessungsgrundlage ohne Umsatzsteuer Steuer) */
// @Api(Description="Umsätze zu anderen Steuersätzen (Bemessungsgrundlage ohne Umsatzsteuer Steuer)")
class UmsAnd2023 implements JsonSerializable
{
    public function __construct(
        /** @description Umsätze zu anderen Steuersätzen (Bemessungsgrundlage ohne Umsatzsteuer Steuer) */
        // @ApiMember(Description="Umsätze zu anderen Steuersätzen (Bemessungsgrundlage ohne Umsatzsteuer Steuer)", Name="E3005001")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3005001=null,

        /** @description Umsätze zu anderen Steuersätzen (Bemessungsgrundlage ohne Umsatzsteuer Steuer) */
        // @ApiMember(Description="Umsätze zu anderen Steuersätzen (Bemessungsgrundlage ohne Umsatzsteuer Steuer)", Name="E3005002")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3005002=null
    ) {
    }

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

/** @description Umsätze land- und forstwirtschaftlicher Betriebe nach § 24 UStG */
// @Api(Description="Umsätze land- und forstwirtschaftlicher Betriebe nach § 24 UStG")
class UmsLuf2023 implements JsonSerializable
{
    public function __construct(
        /** @description Lieferungen in das übrige Gemeinschaftsgebiet an Abnehmer mit Umsatzsteuer-Identifikationsnummer */
        // @ApiMember(Description="Lieferungen in das übrige Gemeinschaftsgebiet an Abnehmer mit Umsatzsteuer-Identifikationsnummer", Name="E3005201")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3005201=null,

        /** @description Steuerpflichtige Umsätze (einschließlich unentgeltlicher Wertabgaben), für die eine Steuer nach § 24 UStG zu entrichten ist (Sägewerkserzeugnisse, Getränke und alkoholische Flüssigkeiten, z. B. Wein) */
        // @ApiMember(Description="Steuerpflichtige Umsätze (einschließlich unentgeltlicher Wertabgaben), für die eine Steuer nach § 24 UStG zu entrichten ist (Sägewerkserzeugnisse, Getränke und alkoholische Flüssigkeiten, z. B. Wein)", Name="E3005005")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3005005=null,

        /** @description Steuerpflichtige Umsätze (einschließlich unentgeltlicher Wertabgaben), für die eine Steuer nach § 24 UStG zu entrichten ist (Sägewerkserzeugnisse, Getränke und alkoholische Flüssigkeiten, z. B. Wein) */
        // @ApiMember(Description="Steuerpflichtige Umsätze (einschließlich unentgeltlicher Wertabgaben), für die eine Steuer nach § 24 UStG zu entrichten ist (Sägewerkserzeugnisse, Getränke und alkoholische Flüssigkeiten, z. B. Wein)", Name="E3005006")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3005006=null,

        /** @description Übrige steuerpflichtige Umsätze land- und forstwirtschaftlicher Betriebe, für die keine Steuer zu entrichten ist */
        // @ApiMember(Description="Übrige steuerpflichtige Umsätze land- und forstwirtschaftlicher Betriebe, für die keine Steuer zu entrichten ist", Name="E3005801")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3005801=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['e3005201'])) $this->e3005201 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3005201']);
        if (isset($o['e3005005'])) $this->e3005005 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3005005']);
        if (isset($o['e3005006'])) $this->e3005006 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3005006']);
        if (isset($o['e3005801'])) $this->e3005801 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3005801']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->e3005201)) $o['e3005201'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3005201);
        if (isset($this->e3005005)) $o['e3005005'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3005005);
        if (isset($this->e3005006)) $o['e3005006'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3005006);
        if (isset($this->e3005801)) $o['e3005801'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3005801);
        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 PositiverGeldBetragMitCent12DETyp extends CustomTypBase implements JsonSerializable
{
    /**
     * @param string|null $alias
     */
    public function __construct(
        ?string $alias=null,
        /** @description Wert des Datentyps.  Mindestens eine Ziffer und maximal 12 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen NICHT erlaubt. */
        // @ApiMember(Description="Wert des Datentyps.  Mindestens eine Ziffer und maximal 12 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen NICHT erlaubt.", IsRequired=true, Name="Betrag")
        /** @var PositiverGeldBetragMitCent12DE|null */
        public ?PositiverGeldBetragMitCent12DE $betrag=null
    ) {
        parent::__construct($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['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->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Steuer infolge Wechsels der Besteuerungsform */
// @Api(Description="Steuer infolge Wechsels der Besteuerungsform")
class WechsBestForm2023 implements JsonSerializable
{
    public function __construct(
        /** @description Steuer (Nachsteuer) auf vereinnahmte Anzahlungen infolge des Wechsels der Besteuerungsform */
        // @ApiMember(Description="Steuer (Nachsteuer) auf vereinnahmte Anzahlungen infolge des Wechsels der Besteuerungsform", Name="E3102901")
        /** @var PositiverGeldBetragMitCent12DETyp|null */
        public ?PositiverGeldBetragMitCent12DETyp $e3102901=null
    ) {
    }

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

/** @description Nachsteuer auf versteuerte Anzahlungen und ähnlich wegen Steuersatzänderung */
// @Api(Description="Nachsteuer auf versteuerte Anzahlungen und ähnlich wegen Steuersatzänderung")
class NachstStSatzAend2023 implements JsonSerializable
{
    public function __construct(
        /** @description Nachsteuer auf versteuerte Anzahlungen und ähnlichem wegen Steuersatzänderung */
        // @ApiMember(Description="Nachsteuer auf versteuerte Anzahlungen und ähnlichem wegen Steuersatzänderung", Name="E3005901")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3005901=null
    ) {
    }

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

/** @description Summe */
// @Api(Description="Summe")
class UmsSum2023 implements JsonSerializable
{
    public function __construct(
        /** @description Summe der Steuer (zu übertragen in Zeile 102) */
        // @ApiMember(Description="Summe der Steuer (zu übertragen in Zeile 102)", Name="E3006001")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3006001=null
    ) {
    }

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

/** @description Umsaetze Tabelle 2023 (Bemessungsgrundlage ohne Umsatzsteuer Steuer) */
// @Api(Description="Umsaetze Tabelle 2023 (Bemessungsgrundlage ohne Umsatzsteuer Steuer)")
class UmsaetzeTabelle2023 implements JsonSerializable
{
    public function __construct(
        /** @description Umsätze zum allgemeinen Steuersatz */
        // @ApiMember(Description="Umsätze zum allgemeinen Steuersatz", Name="UmsAllg")
        /** @var UmsAllg2023|null */
        public ?UmsAllg2023 $umsAllg=null,

        /** @description Umsätze zum ermäßigten Steuersatz */
        // @ApiMember(Description="Umsätze zum ermäßigten Steuersatz", Name="UmsErm")
        /** @var UmsErm2023|null */
        public ?UmsErm2023 $umsErm=null,

        /** @description Umsätze zum ermäßigten Steuersatz */
        // @ApiMember(Description="Umsätze zum ermäßigten Steuersatz", Name="UmsErm0")
        /** @var UmsErm02023|null */
        public ?UmsErm02023 $umsErm0=null,

        /** @description Umsätze zu anderen Steuersätzen */
        // @ApiMember(Description="Umsätze zu anderen Steuersätzen", Name="UmsAnd")
        /** @var UmsAnd2023|null */
        public ?UmsAnd2023 $umsAnd=null,

        /** @description Umsätze land- und forstwirtschaftlicher Betriebe nach § 24 UStG */
        // @ApiMember(Description="Umsätze land- und forstwirtschaftlicher Betriebe nach § 24 UStG", Name="UmsLuf")
        /** @var UmsLuf2023|null */
        public ?UmsLuf2023 $umsLuf=null,

        /** @description Steuer infolge Wechsels der Besteuerungsform */
        // @ApiMember(Description="Steuer infolge Wechsels der Besteuerungsform", Name="WechsBestForm")
        /** @var WechsBestForm2023|null */
        public ?WechsBestForm2023 $wechsBestForm=null,

        /** @description Nachsteuer auf versteuerte Anzahlungen und ähnlich wegen Steuersatzänderung */
        // @ApiMember(Description="Nachsteuer auf versteuerte Anzahlungen und ähnlich wegen Steuersatzänderung", Name="NachstStSatzAend")
        /** @var NachstStSatzAend2023|null */
        public ?NachstStSatzAend2023 $nachstStSatzAend=null,

        /** @description Summe */
        // @ApiMember(Description="Summe", Name="UmsSum")
        /** @var UmsSum2023|null */
        public ?UmsSum2023 $umsSum=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['umsAllg'])) $this->umsAllg = JsonConverters::from('UmsAllg2023', $o['umsAllg']);
        if (isset($o['umsErm'])) $this->umsErm = JsonConverters::from('UmsErm2023', $o['umsErm']);
        if (isset($o['umsErm0'])) $this->umsErm0 = JsonConverters::from('UmsErm02023', $o['umsErm0']);
        if (isset($o['umsAnd'])) $this->umsAnd = JsonConverters::from('UmsAnd2023', $o['umsAnd']);
        if (isset($o['umsLuf'])) $this->umsLuf = JsonConverters::from('UmsLuf2023', $o['umsLuf']);
        if (isset($o['wechsBestForm'])) $this->wechsBestForm = JsonConverters::from('WechsBestForm2023', $o['wechsBestForm']);
        if (isset($o['nachstStSatzAend'])) $this->nachstStSatzAend = JsonConverters::from('NachstStSatzAend2023', $o['nachstStSatzAend']);
        if (isset($o['umsSum'])) $this->umsSum = JsonConverters::from('UmsSum2023', $o['umsSum']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->umsAllg)) $o['umsAllg'] = JsonConverters::to('UmsAllg2023', $this->umsAllg);
        if (isset($this->umsErm)) $o['umsErm'] = JsonConverters::to('UmsErm2023', $this->umsErm);
        if (isset($this->umsErm0)) $o['umsErm0'] = JsonConverters::to('UmsErm02023', $this->umsErm0);
        if (isset($this->umsAnd)) $o['umsAnd'] = JsonConverters::to('UmsAnd2023', $this->umsAnd);
        if (isset($this->umsLuf)) $o['umsLuf'] = JsonConverters::to('UmsLuf2023', $this->umsLuf);
        if (isset($this->wechsBestForm)) $o['wechsBestForm'] = JsonConverters::to('WechsBestForm2023', $this->wechsBestForm);
        if (isset($this->nachstStSatzAend)) $o['nachstStSatzAend'] = JsonConverters::to('NachstStSatzAend2023', $this->nachstStSatzAend);
        if (isset($this->umsSum)) $o['umsSum'] = JsonConverters::to('UmsSum2023', $this->umsSum);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Steuerpflichtige Lieferungen, sonstige Leistungen und unentgeltliche Wertabgaben */
// @Api(Description="Steuerpflichtige Lieferungen, sonstige Leistungen und unentgeltliche Wertabgaben")
class Umsaetze2023 implements JsonSerializable
{
    public function __construct(
        /** @description Umsätze Tabelle 2023 (Bemessungsgrundlage ohne Umsatzsteuer Steuer) */
        // @ApiMember(Description="Umsätze Tabelle 2023 (Bemessungsgrundlage ohne Umsatzsteuer Steuer)", Name="Tabelle")
        /** @var UmsaetzeTabelle2023|null */
        public ?UmsaetzeTabelle2023 $tabelle=null
    ) {
    }

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

/** @description Innergemeinschaftliche Lieferungen (§ 4 Nummer 1 Buchstabe b UStG) */
// @Api(Description="Innergemeinschaftliche Lieferungen (§ 4 Nummer 1 Buchstabe b UStG)")
class IgLfg2023 implements JsonSerializable
{
    public function __construct(
        /** @description an Abnehmer mit Umsatzsteuer-Identifikationsnummer */
        // @ApiMember(Description="an Abnehmer mit Umsatzsteuer-Identifikationsnummer", Name="E3103301")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3103301=null,

        /** @description neuer Fahrzeuge an Abnehmer ohne Umsatzsteuer-Identifikationsnummer */
        // @ApiMember(Description="neuer Fahrzeuge an Abnehmer ohne Umsatzsteuer-Identifikationsnummer", Name="E3103401")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3103401=null,

        /** @description neuer Fahrzeuge außerhalb eines Unternehmens (§ 2a UStG) */
        // @ApiMember(Description="neuer Fahrzeuge außerhalb eines Unternehmens (§ 2a UStG)", Name="E3103501")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3103501=null
    ) {
    }

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

/** @description Weitere steuerfreie Umsätze mit Vorsteuerabzug (zum Beispiel nach § 4 Nummer 1 Buchstabe a, 2 bis 7 UStG) */
// @Api(Description="Weitere steuerfreie Umsätze mit Vorsteuerabzug (zum Beispiel nach § 4 Nummer 1 Buchstabe a, 2 bis 7 UStG)")
class UmsStFreiWeit2023 implements JsonSerializable
{
    public function __construct(
        /** @description Ausfuhrlieferungen und Lohnveredelungen an Gegenständen der Ausfuhr (§ 4 Nummer 1 Buchstabe a UStG) */
        // @ApiMember(Description="Ausfuhrlieferungen und Lohnveredelungen an Gegenständen der Ausfuhr (§ 4 Nummer 1 Buchstabe a UStG)", Name="E3103801")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3103801=null,

        /** @description Weitere steuerfreie Umsätze mit Vorsteuerabzug (z. B. nach § 4 Nummer 1 Buchstabe a, 2 bis 7 UStG), Umsätze nach § ... UStG (Bemessungsgrundlage ohne Umsatzsteuer)  */
        // @ApiMember(Description="Weitere steuerfreie Umsätze mit Vorsteuerabzug (z. B. nach § 4 Nummer 1 Buchstabe a, 2 bis 7 UStG), Umsätze nach § ... UStG (Bemessungsgrundlage ohne Umsatzsteuer) ", Name="E3103901")
        /** @var StringTyp|null */
        public ?StringTyp $e3103901=null,

        /** @description Weitere steuerfreie Umsätze mit Vorsteuerabzug (z. B. nach § 4 Nummer 1 Buchstabe a, 2 bis 7 UStG), Umsätze nach § ... UStG (Bemessungsgrundlage ohne Umsatzsteuer) */
        // @ApiMember(Description="Weitere steuerfreie Umsätze mit Vorsteuerabzug (z. B. nach § 4 Nummer 1 Buchstabe a, 2 bis 7 UStG), Umsätze nach § ... UStG (Bemessungsgrundlage ohne Umsatzsteuer)", Name="E3103902")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3103902=null,

        /** @description Umsätze im Sinne des Offshore-Steuerabkommens, des Zusatzabkommens zum NATO-Truppenstatut und des Ergänzungsabkommens zum Protokoll über die NATO-Hauptquartiere */
        // @ApiMember(Description="Umsätze im Sinne des Offshore-Steuerabkommens, des Zusatzabkommens zum NATO-Truppenstatut und des Ergänzungsabkommens zum Protokoll über die NATO-Hauptquartiere", Name="E3104001")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3104001=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="E3104101")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3104101=null,

        /** @description Summe der Zeilen 41 bis 44 */
        // @ApiMember(Description="Summe der Zeilen 41 bis 44", Name="E3104201")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3104201=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['e3103801'])) $this->e3103801 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3103801']);
        if (isset($o['e3103901'])) $this->e3103901 = JsonConverters::from('StringTyp', $o['e3103901']);
        if (isset($o['e3103902'])) $this->e3103902 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3103902']);
        if (isset($o['e3104001'])) $this->e3104001 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3104001']);
        if (isset($o['e3104101'])) $this->e3104101 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3104101']);
        if (isset($o['e3104201'])) $this->e3104201 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3104201']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->e3103801)) $o['e3103801'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3103801);
        if (isset($this->e3103901)) $o['e3103901'] = JsonConverters::to('StringTyp', $this->e3103901);
        if (isset($this->e3103902)) $o['e3103902'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3103902);
        if (isset($this->e3104001)) $o['e3104001'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3104001);
        if (isset($this->e3104101)) $o['e3104101'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3104101);
        if (isset($this->e3104201)) $o['e3104201'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3104201);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Steuerfreie Umsätze mit Vorsteuerabzug */
// @Api(Description="Steuerfreie Umsätze mit Vorsteuerabzug")
class MitVoStAbz2023 implements JsonSerializable
{
    public function __construct(
        /** @description a) Liste innergemeinschaftlicher Lieferungen (§ 4 Nummer 1 Buchstabe b UStG) */
        // @ApiMember(Description="a) Liste innergemeinschaftlicher Lieferungen (§ 4 Nummer 1 Buchstabe b UStG)", Name="IgLfg")
        /** @var IgLfg2023|null */
        public ?IgLfg2023 $igLfg=null,

        /** @description b) Liste weiterer steuerfreien Umsätze mit Vorsteuerabzug (zum Beispiel nach § 4 Nummer 1 Buchstabe a, 2 bis 7 UStG) */
        // @ApiMember(Description="b) Liste weiterer steuerfreien Umsätze mit Vorsteuerabzug (zum Beispiel nach § 4 Nummer 1 Buchstabe a, 2 bis 7 UStG)", Name="IgLfg")
        /** @var UmsStFreiWeit2023|null */
        public ?UmsStFreiWeit2023 $umsStFreiWeit=null
    ) {
    }

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

/** @description Steuerfreie Umsätze ohne Vorsteuerabzug nicht zum Gesamtumsatz (§ 19 Absatz 3 UStG) gehörend */
// @Api(Description="Steuerfreie Umsätze ohne Vorsteuerabzug nicht zum Gesamtumsatz (§ 19 Absatz 3 UStG) gehörend")
class NichtGesUms2023 implements JsonSerializable
{
    public function __construct(
        /** @description z. B. nach § 4 Nummer 12 UStG (Vermietung und Verpachtung von Grundstücken) */
        // @ApiMember(Description="z. B. nach § 4 Nummer 12 UStG (Vermietung und Verpachtung von Grundstücken)", Name="E3104401")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3104401=null,

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

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

        /** @description Summe der Zeilen 46 und 47 */
        // @ApiMember(Description="Summe der Zeilen 46 und 47", Name="E3104601")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3104601=null
    ) {
    }

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

class GesUms2023 implements JsonSerializable
{
    public function __construct(
        /** @description Zum Gesamtumsatz (§ 19 Absatz 3 UStG) gehörend nach § ... UStG (Bemessungsgrundlage ohne Umsatzsteuer) */
        // @ApiMember(Description="Zum Gesamtumsatz (§ 19 Absatz 3 UStG) gehörend nach § ... UStG (Bemessungsgrundlage ohne Umsatzsteuer)", Name="E3104901")
        /** @var StringTyp|null */
        public ?StringTyp $e3104901=null,

        /** @description Zum Gesamtumsatz (§ 19 Absatz 3 UStG) gehörend nach § ... UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
        // @ApiMember(Description="Zum Gesamtumsatz (§ 19 Absatz 3 UStG) gehörend nach § ... UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3104902")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3104902=null
    ) {
    }

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

/** @description Steuerfreie Umsätze ohne Vorsteuerabzug */
// @Api(Description="Steuerfreie Umsätze ohne Vorsteuerabzug")
class OhneVoStAbz2023 implements JsonSerializable
{
    public function __construct(
        /** @description a) Steuerfreie Umsätze ohne Vorsteuerabzug nicht zum Gesamtumsatz (§ 19 Absatz 3 UStG) gehörend */
        // @ApiMember(Description="a) Steuerfreie Umsätze ohne Vorsteuerabzug nicht zum Gesamtumsatz (§ 19 Absatz 3 UStG) gehörend", Name="NichtGesUms")
        /** @var NichtGesUms2023|null */
        public ?NichtGesUms2023 $nichtGesUms=null,

        /** @description b) Steuerfreie Umsätze ohne Vorsteuerabzug zum Gesamtumsatz(§ 19 Absatz 3 UStG) gehörend */
        // @ApiMember(Description="b) Steuerfreie Umsätze ohne Vorsteuerabzug zum Gesamtumsatz(§ 19 Absatz 3 UStG) gehörend", Name="GesUms")
        /** @var GesUms2023|null */
        public ?GesUms2023 $gesUms=null
    ) {
    }

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

/** @description Bemessungsgrundlage ohne Umsatzsteuer */
// @Api(Description="Bemessungsgrundlage ohne Umsatzsteuer")
class UmsStfreiTabelle2023 implements JsonSerializable
{
    public function __construct(
        /** @description Steuerfreie Umsätze mit Vorsteuerabzug */
        // @ApiMember(Description="Steuerfreie Umsätze mit Vorsteuerabzug", Name="MitVoStAbz")
        /** @var MitVoStAbz2023|null */
        public ?MitVoStAbz2023 $mitVoStAbz=null,

        /** @description Steuerfreie Umsätze ohne Vorsteuerabzug */
        // @ApiMember(Description="Steuerfreie Umsätze ohne Vorsteuerabzug", Name="OhneVoStAbz")
        /** @var OhneVoStAbz2023|null */
        public ?OhneVoStAbz2023 $ohneVoStAbz=null
    ) {
    }

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

/** @description Steuerfreie Lieferungen, sonstige Leistungen und unentgeltliche Wertabgaben. */
// @Api(Description="Steuerfreie Lieferungen, sonstige Leistungen und unentgeltliche Wertabgaben.")
class UmsStfrei2023 implements JsonSerializable
{
    public function __construct(
        /** @description Bemessungsgrundlage ohne Umsatzsteuer */
        // @ApiMember(Description="Bemessungsgrundlage ohne Umsatzsteuer", Name="Tabelle")
        /** @var UmsStfreiTabelle2023|null */
        public ?UmsStfreiTabelle2023 $tabelle=null
    ) {
    }

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

class Stfrei2023 implements JsonSerializable
{
    public function __construct(
        /** @description von bestimmten Gegenständen und Anlagegold nach §§ 4b und 25c UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
        // @ApiMember(Description="von bestimmten Gegenständen und Anlagegold nach §§ 4b und 25c UStG (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3100901")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3100901=null
    ) {
    }

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

/** @description Steuerpflichtige innergemeinschaftliche Erwerbe (§ 1a UStG) */
// @Api(Description="Steuerpflichtige innergemeinschaftliche Erwerbe (§ 1a UStG)")
class Stpfl2023 implements JsonSerializable
{
    public function __construct(
        /** @description zum Steuersatz von 19 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
        // @ApiMember(Description="zum Steuersatz von 19 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3100902")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3100902=null,

        /** @description zum Steuersatz von 19 Prozent (Steuer) */
        // @ApiMember(Description="zum Steuersatz von 19 Prozent (Steuer)", Name="E3100903")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3100903=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="E3101301")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3101301=null,

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

        /** @description zum Steuersatz von 0 Prozent (Steuer) */
        // @ApiMember(Description="zum Steuersatz von 0 Prozent (Steuer)", Name="E3101305")
        /** @var PositiverGeldBetragOhneCent12DETyp|null */
        public ?PositiverGeldBetragOhneCent12DETyp $e3101305=null,

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

        /** @description zu anderen Steuersätzen (Steuer) */
        // @ApiMember(Description="zu anderen Steuersätzen (Steuer)", Name="E3101304")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3101304=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="E3101401")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3101401=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="E3101402")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3101402=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['e3100902'])) $this->e3100902 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3100902']);
        if (isset($o['e3100903'])) $this->e3100903 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3100903']);
        if (isset($o['e3101301'])) $this->e3101301 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3101301']);
        if (isset($o['e3101302'])) $this->e3101302 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3101302']);
        if (isset($o['e3101305'])) $this->e3101305 = JsonConverters::from('PositiverGeldBetragOhneCent12DETyp', $o['e3101305']);
        if (isset($o['e3101303'])) $this->e3101303 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3101303']);
        if (isset($o['e3101304'])) $this->e3101304 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3101304']);
        if (isset($o['e3101401'])) $this->e3101401 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3101401']);
        if (isset($o['e3101402'])) $this->e3101402 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3101402']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->e3100902)) $o['e3100902'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3100902);
        if (isset($this->e3100903)) $o['e3100903'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3100903);
        if (isset($this->e3101301)) $o['e3101301'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3101301);
        if (isset($this->e3101302)) $o['e3101302'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3101302);
        if (isset($this->e3101305)) $o['e3101305'] = JsonConverters::to('PositiverGeldBetragOhneCent12DETyp', $this->e3101305);
        if (isset($this->e3101303)) $o['e3101303'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3101303);
        if (isset($this->e3101304)) $o['e3101304'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3101304);
        if (isset($this->e3101401)) $o['e3101401'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3101401);
        if (isset($this->e3101402)) $o['e3101402'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3101402);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Summe */
// @Api(Description="Summe")
class IgErwSum2023 implements JsonSerializable
{
    public function __construct(
        /** @description Summe der Steuer (zu übertragen in Zeile 153) */
        // @ApiMember(Description="Summe der Steuer (zu übertragen in Zeile 153)", Name="E3101501")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3101501=null
    ) {
    }

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

/** @description Innergemeinschaftliche Erwerbe Bemessungsgrundlage ohne Umsatzsteuer Steuer Tabelle */
// @Api(Description="Innergemeinschaftliche Erwerbe Bemessungsgrundlage ohne Umsatzsteuer Steuer Tabelle")
class IgErwTabelle2023 implements JsonSerializable
{
    public function __construct(
        /** @description Steuerfreie innergemeinschaftliche Erwerbe */
        // @ApiMember(Description="Steuerfreie innergemeinschaftliche Erwerbe", Name="Stfrei")
        /** @var Stfrei2023|null */
        public ?Stfrei2023 $stfrei=null,

        /** @description Steuerpflichtige innergemeinschaftliche Erwerbe (§ 1a UStG) */
        // @ApiMember(Description="Steuerpflichtige innergemeinschaftliche Erwerbe (§ 1a UStG)", Name="Stpfl")
        /** @var Stpfl2023|null */
        public ?Stpfl2023 $stpfl=null,

        /** @description Summe */
        // @ApiMember(Description="Summe", Name="IgErwSum")
        /** @var IgErwSum2023|null */
        public ?IgErwSum2023 $igErwSum=null
    ) {
    }

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

/** @description Innergemeinschaftliche Erwerbe */
// @Api(Description="Innergemeinschaftliche Erwerbe")
class IgErw2023 implements JsonSerializable
{
    public function __construct(
        /** @description Innergemeinschaftliche Erwerbe Bemessungsgrundlage ohne Umsatzsteuer Steuer Tabelle */
        // @ApiMember(Description="Innergemeinschaftliche Erwerbe Bemessungsgrundlage ohne Umsatzsteuer Steuer Tabelle", Name="Tabelle")
        /** @var IgErwTabelle2023|null */
        public ?IgErwTabelle2023 $tabelle=null
    ) {
    }

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

/** @description Summe der Steuer (zu übertragen in Zeile 154) */
// @Api(Description="Summe der Steuer (zu übertragen in Zeile 154)")
class Auslag13aSum2023 implements JsonSerializable
{
    public function __construct(
        /** @description Summe der Steuer (zu übertragen in Zeile 154) */
        // @ApiMember(Description="Summe der Steuer (zu übertragen in Zeile 154)", Name="E3102904")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3102904=null
    ) {
    }

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

/** @description Steuerschuldner bei Auslagerung (§ 13a Absatz 1 Nummer 6 UStG) Tabelle (Bemessungsgrundlage ohne Umsatzsteuer Steuer) */
// @Api(Description="Steuerschuldner bei Auslagerung (§ 13a Absatz 1 Nummer 6 UStG) Tabelle (Bemessungsgrundlage ohne Umsatzsteuer Steuer)")
class Auslag13aTabelle2023 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="E3102804")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3102804=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="E3102805")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3102805=null,

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

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

/** @description Steuerschuldner bei Auslagerung (§ 13a Absatz 1 Nummer 6 UStG) */
// @Api(Description="Steuerschuldner bei Auslagerung (§ 13a Absatz 1 Nummer 6 UStG)")
class Auslag13a2023 implements JsonSerializable
{
    public function __construct(
        /** @description Steuerschuldner bei Auslagerung (§ 13a Absatz 1 Nummer 6 UStG) Tabelle (Bemessungsgrundlage ohne Umsatzsteuer Steuer) */
        // @ApiMember(Description="Steuerschuldner bei Auslagerung (§ 13a Absatz 1 Nummer 6 UStG) Tabelle (Bemessungsgrundlage ohne Umsatzsteuer Steuer)", Name="Tabelle")
        /** @var Auslag13aTabelle2023|null */
        public ?Auslag13aTabelle2023 $tabelle=null
    ) {
    }

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

/** @description Lieferungen des ersten Abnehmers */
// @Api(Description="Lieferungen des ersten Abnehmers")
class LfgErstAbn2023 implements JsonSerializable
{
    public function __construct(
        /** @description Bemessungsgrundlage ohne Umsatzsteuer (volle EUR) */
        // @ApiMember(Description="Bemessungsgrundlage ohne Umsatzsteuer (volle EUR)", Name="E3101801")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3101801=null
    ) {
    }

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

/** @description Lieferungen, für die der letzte Abnehmer die Umsatzsteuer schuldet */
// @Api(Description="Lieferungen, für die der letzte Abnehmer die Umsatzsteuer schuldet")
class LfgLetztAbn2023 implements JsonSerializable
{
    public function __construct(
        /** @description zum Steuersatz von 19 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
        // @ApiMember(Description="zum Steuersatz von 19 Prozent (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3101701")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3101701=null,

        /** @description zum Steuersatz von 19 Prozent (Steuer) */
        // @ApiMember(Description="zum Steuersatz von 19 Prozent (Steuer)", Name="E3101702")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3101702=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="E3102301")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3102301=null,

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

        /** @description zum Steuersatz von 0 Prozent (Steuer) */
        // @ApiMember(Description="zum Steuersatz von 0 Prozent (Steuer)", Name="E3102305")
        /** @var PositiverGeldBetragOhneCent12DETyp|null */
        public ?PositiverGeldBetragOhneCent12DETyp $e3102305=null,

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

        /** @description zu anderen Steuersätzen (Steuer) */
        // @ApiMember(Description="zu anderen Steuersätzen (Steuer)", Name="E3102304")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3102304=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['e3101701'])) $this->e3101701 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3101701']);
        if (isset($o['e3101702'])) $this->e3101702 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3101702']);
        if (isset($o['e3102301'])) $this->e3102301 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3102301']);
        if (isset($o['e3102302'])) $this->e3102302 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3102302']);
        if (isset($o['e3102305'])) $this->e3102305 = JsonConverters::from('PositiverGeldBetragOhneCent12DETyp', $o['e3102305']);
        if (isset($o['e3102303'])) $this->e3102303 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3102303']);
        if (isset($o['e3102304'])) $this->e3102304 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3102304']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->e3101701)) $o['e3101701'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3101701);
        if (isset($this->e3101702)) $o['e3101702'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3101702);
        if (isset($this->e3102301)) $o['e3102301'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3102301);
        if (isset($this->e3102302)) $o['e3102302'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3102302);
        if (isset($this->e3102305)) $o['e3102305'] = JsonConverters::to('PositiverGeldBetragOhneCent12DETyp', $this->e3102305);
        if (isset($this->e3102303)) $o['e3102303'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3102303);
        if (isset($this->e3102304)) $o['e3102304'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3102304);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Summe */
// @Api(Description="Summe")
class IgDreiSum2023 implements JsonSerializable
{
    public function __construct(
        /** @description Summe der Steuer (zu übertragen in Zeile 105) */
        // @ApiMember(Description="Summe der Steuer (zu übertragen in Zeile 105)", Name="E3102401")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3102401=null
    ) {
    }

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

/** @description Innergemeinschaftliche Dreiecksgeschäfte (§ 25b UStG) Tabelle (Bemessungsgrundlage ohne Umsatzsteuer Steuer) */
// @Api(Description="Innergemeinschaftliche Dreiecksgeschäfte (§ 25b UStG) Tabelle (Bemessungsgrundlage ohne Umsatzsteuer Steuer)")
class IgDreiTabelle2023 implements JsonSerializable
{
    public function __construct(
        /** @description Lieferungen des ersten Abnehmers */
        // @ApiMember(Description="Lieferungen des ersten Abnehmers", Name="LfgErstAbn")
        /** @var LfgErstAbn2023|null */
        public ?LfgErstAbn2023 $lfgErstAbn=null,

        /** @description Lieferungen, für die der letzte Abnehmer die Umsatzsteuer schuldet */
        // @ApiMember(Description="Lieferungen, für die der letzte Abnehmer die Umsatzsteuer schuldet", Name="LfgLetztAbn")
        /** @var LfgLetztAbn2023|null */
        public ?LfgLetztAbn2023 $lfgLetztAbn=null,

        /** @description Summe */
        // @ApiMember(Description="Summe", Name="IgDreiSum")
        /** @var IgDreiSum2023|null */
        public ?IgDreiSum2023 $igDreiSum=null
    ) {
    }

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

/** @description Innergemeinschaftliche Dreiecksgeschäfte (§ 25b UStG) */
// @Api(Description="Innergemeinschaftliche Dreiecksgeschäfte (§ 25b UStG)")
class IgDrei2023 implements JsonSerializable
{
    public function __construct(
        /** @description Innergemeinschaftliche Dreiecksgeschäfte (§ 25b UStG) Tabelle (Bemessungsgrundlage ohne Umsatzsteuer Steuer) */
        // @ApiMember(Description="Innergemeinschaftliche Dreiecksgeschäfte (§ 25b UStG) Tabelle (Bemessungsgrundlage ohne Umsatzsteuer Steuer)", Name="Tabelle")
        /** @var IgDreiTabelle2023|null */
        public ?IgDreiTabelle2023 $tabelle=null
    ) {
    }

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

/** @description Summe der Steuer (zu übertragen in Zeile 156) */
// @Api(Description="Summe der Steuer (zu übertragen in Zeile 156)")
class Ums13bSum2023 implements JsonSerializable
{
    public function __construct(
        /** @description Summe der Steuer (zu übertragen in Zeile 106) */
        // @ApiMember(Description="Summe der Steuer (zu übertragen in Zeile 106)", Name="E3102601")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3102601=null
    ) {
    }

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

class Ums13bTabelle2023 implements JsonSerializable
{
    public function __construct(
        /** @description Sonstige Leistungen nach § 3a Absatz 2 UStG eines im übrigen Gemeinschaftsgebiet ansässigen Unternehmers (§ 13b Absatz 1 UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
        // @ApiMember(Description="Sonstige Leistungen nach § 3a Absatz 2 UStG eines im übrigen Gemeinschaftsgebiet ansässigen Unternehmers (§ 13b Absatz 1 UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3102205")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3102205=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="E3102206")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3102206=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="E3102307")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3102307=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="E3102308")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3102308=null,

        /** @description Andere Leistungen (§ 13b Absatz 2 Nummer 1, 2, 4 bis 12 UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
        // @ApiMember(Description="Andere Leistungen (§ 13b Absatz 2 Nummer 1, 2, 4 bis 12 UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3102503")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3102503=null,

        /** @description Andere Leistungen (§ 13b Absatz 2 Nummer 1, 2, 4 bis 12 UStG) (Steuer) */
        // @ApiMember(Description="Andere Leistungen (§ 13b Absatz 2 Nummer 1, 2, 4 bis 12 UStG) (Steuer)", Name="E3102504")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3102504=null,

        /** @description Summe */
        // @ApiMember(Description="Summe", Name="Ums13bSum")
        /** @var Ums13bSum2023|null */
        public ?Ums13bSum2023 $ums13bSum=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['e3102205'])) $this->e3102205 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3102205']);
        if (isset($o['e3102206'])) $this->e3102206 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3102206']);
        if (isset($o['e3102307'])) $this->e3102307 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3102307']);
        if (isset($o['e3102308'])) $this->e3102308 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3102308']);
        if (isset($o['e3102503'])) $this->e3102503 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3102503']);
        if (isset($o['e3102504'])) $this->e3102504 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3102504']);
        if (isset($o['ums13bSum'])) $this->ums13bSum = JsonConverters::from('Ums13bSum2023', $o['ums13bSum']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->e3102205)) $o['e3102205'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3102205);
        if (isset($this->e3102206)) $o['e3102206'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3102206);
        if (isset($this->e3102307)) $o['e3102307'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3102307);
        if (isset($this->e3102308)) $o['e3102308'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3102308);
        if (isset($this->e3102503)) $o['e3102503'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3102503);
        if (isset($this->e3102504)) $o['e3102504'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3102504);
        if (isset($this->ums13bSum)) $o['ums13bSum'] = JsonConverters::to('Ums13bSum2023', $this->ums13bSum);
        return empty($o) ? new class(){} : $o;
    }
}

class Ums13b2023 implements JsonSerializable
{
    public function __construct(
        /** @description Leistungsempfänger als Steuerschuldner (§ 13b UStG) Tabelle (Bemessungsgrundlage ohne Umsatzsteuer Steuer) */
        // @ApiMember(Description="Leistungsempfänger als Steuerschuldner (§ 13b UStG) Tabelle (Bemessungsgrundlage ohne Umsatzsteuer Steuer)", Name="Tabelle")
        /** @var Ums13bTabelle2023|null */
        public ?Ums13bTabelle2023 $tabelle=null
    ) {
    }

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

/** @description Ergänzende Angaben zu Umsätzen Betrag Tabelle */
// @Api(Description="Ergänzende Angaben zu Umsätzen Betrag Tabelle")
class ErgAngUmsTabelle2023 implements JsonSerializable
{
    public function __construct(
        /** @description Umsätze, die auf Grund eines Verzichts auf Steuerbefreiung (§ 9 UStG) als steuerpflichtig behandelt worden sind (in Abschnitt C enthalten) (Betrag volle EUR) */
        // @ApiMember(Description="Umsätze, die auf Grund eines Verzichts auf Steuerbefreiung (§ 9 UStG) als steuerpflichtig behandelt worden sind (in Abschnitt C enthalten) (Betrag volle EUR)", Name="E3105201")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3105201=null,

        /** @description Steuerpflichtige Umsätze des leistenden Unternehmers, für die der Leistungsempfänger die Steuer nach § 13b Absatz 5 UStG schuldet (Betrag volle EUR) */
        // @ApiMember(Description="Steuerpflichtige Umsätze des leistenden Unternehmers, für die der Leistungsempfänger die Steuer nach § 13b Absatz 5 UStG schuldet (Betrag volle EUR)", Name="E3105301")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3105301=null,

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

        /** @description Telekommunikations-, Rundfunk- und Fernsehdienstleistungen sowie auf elektronischem Weg erbrachte sonstige Leistungen an im übrigen Gemeinschaftsgebiet ansässige Nichtunternehmer sowie innergemeinschaftliche Fernverkäufe in das übrige Gemeinschaftsgebiet unter der Voraussetzung des § 3a Absatz 5 Sätze 3 und 4 UStG und § 3c Absatz 4 Sätze 1 und 2 UStG (in anderen EU-Mitgliedstaaten zu versteuern) (Betrag volle EUR) */
        // @ApiMember(Description="Telekommunikations-, Rundfunk- und Fernsehdienstleistungen sowie auf elektronischem Weg erbrachte sonstige Leistungen an im übrigen Gemeinschaftsgebiet ansässige Nichtunternehmer sowie innergemeinschaftliche Fernverkäufe in das übrige Gemeinschaftsgebiet unter der Voraussetzung des § 3a Absatz 5 Sätze 3 und 4 UStG und § 3c Absatz 4 Sätze 1 und 2 UStG (in anderen EU-Mitgliedstaaten zu versteuern) (Betrag volle EUR)", Name="E3105102")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3105102=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="E3105602")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3105602=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="E3105702")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3105702=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="E3105801")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3105801=null,

        /** @description In den Zeilen 72, 74 und 75 enthaltene Umsätze, die nach § 15 Absatz 2 und 3 UStG den Vorsteuerabzug ausschließen (Betrag volle EUR) */
        // @ApiMember(Description="In den Zeilen 72, 74 und 75 enthaltene Umsätze, die nach § 15 Absatz 2 und 3 UStG den Vorsteuerabzug ausschließen (Betrag volle EUR)", Name="E3105901")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3105901=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="E3106001")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3106001=null,

        /** @description Minderung der Bemessungsgrundlage nach § 17 Absatz 1 Satz 1 in Verbindung mit Absatz 2 Nummer 1 Satz 1 UStG (in Abschnitt B oder C enthalten) (Betrag volle EUR) */
        // @ApiMember(Description="Minderung der Bemessungsgrundlage nach § 17 Absatz 1 Satz 1 in Verbindung mit Absatz 2 Nummer 1 Satz 1 UStG (in Abschnitt B oder C enthalten) (Betrag volle EUR)", Name="E3106101")
        /** @var PositiverGeldBetragOhneCent12DETyp|null */
        public ?PositiverGeldBetragOhneCent12DETyp $e3106101=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['e3105201'])) $this->e3105201 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3105201']);
        if (isset($o['e3105301'])) $this->e3105301 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3105301']);
        if (isset($o['e3105101'])) $this->e3105101 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3105101']);
        if (isset($o['e3105102'])) $this->e3105102 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3105102']);
        if (isset($o['e3105602'])) $this->e3105602 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3105602']);
        if (isset($o['e3105702'])) $this->e3105702 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3105702']);
        if (isset($o['e3105801'])) $this->e3105801 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3105801']);
        if (isset($o['e3105901'])) $this->e3105901 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3105901']);
        if (isset($o['e3106001'])) $this->e3106001 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3106001']);
        if (isset($o['e3106101'])) $this->e3106101 = JsonConverters::from('PositiverGeldBetragOhneCent12DETyp', $o['e3106101']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->e3105201)) $o['e3105201'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3105201);
        if (isset($this->e3105301)) $o['e3105301'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3105301);
        if (isset($this->e3105101)) $o['e3105101'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3105101);
        if (isset($this->e3105102)) $o['e3105102'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3105102);
        if (isset($this->e3105602)) $o['e3105602'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3105602);
        if (isset($this->e3105702)) $o['e3105702'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3105702);
        if (isset($this->e3105801)) $o['e3105801'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3105801);
        if (isset($this->e3105901)) $o['e3105901'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3105901);
        if (isset($this->e3106001)) $o['e3106001'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3106001);
        if (isset($this->e3106101)) $o['e3106101'] = JsonConverters::to('PositiverGeldBetragOhneCent12DETyp', $this->e3106101);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Ergänzende Angaben zu Umsätzen */
// @Api(Description="Ergänzende Angaben zu Umsätzen")
class ErgAngUms2023 implements JsonSerializable
{
    public function __construct(
        /** @description Ergänzende Angaben zu Umsätzen Betrag Tabelle */
        // @ApiMember(Description="Ergänzende Angaben zu Umsätzen Betrag Tabelle", Name="Tabelle")
        /** @var ErgAngUmsTabelle2023|null */
        public ?ErgAngUmsTabelle2023 $tabelle=null
    ) {
    }

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

/** @description Summe der Vorsteuerbeträge (zu übertragen in Zeile 158) */
// @Api(Description="Summe der Vorsteuerbeträge (zu übertragen in Zeile 158)")
class AbzVoStSum2023 implements JsonSerializable
{
    public function __construct(
        /** @description Summe der Vorsteuerbeträge (zu übertragen in Zeile 158) */
        // @ApiMember(Description="Summe der Vorsteuerbeträge (zu übertragen in Zeile 158)", Name="E3006901")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3006901=null
    ) {
    }

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

class ErgAng2023 implements JsonSerializable
{
    public function __construct(
        /** @description Minderung der abziehbaren Vorsteuerbeträge nach § 17 Absatz 1 Satz 2 in Verbindung mit Absatz 2 Nummer 1 Satz 1 UStG (in den Zeilen 79, 84 und 85 enthalten) */
        // @ApiMember(Description="Minderung der abziehbaren Vorsteuerbeträge nach § 17 Absatz 1 Satz 2 in Verbindung mit Absatz 2 Nummer 1 Satz 1 UStG (in den Zeilen 79, 84 und 85 enthalten)", Name="E3007001")
        /** @var PositiverGeldBetragMitCent12DETyp|null */
        public ?PositiverGeldBetragMitCent12DETyp $e3007001=null
    ) {
    }

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

/** @description Abziehbare Vorsteuerbeträge (ohne die Berichtigung nach § 15a UStG) Steuer Tabelle */
// @Api(Description="Abziehbare Vorsteuerbeträge (ohne die Berichtigung nach § 15a UStG) Steuer Tabelle")
class AbzVoStTabelle2023 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="E3006201")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3006201=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="E3006301")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3006301=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="E3006401")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3006401=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="E3006503")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3006503=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="E3006502")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3006502=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="E3006601")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3006601=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="E3006701")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3006701=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="E3006801")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3006801=null,

        /** @description Summe der Vorsteuerbeträge (zu übertragen in Zeile 108) */
        // @ApiMember(Description="Summe der Vorsteuerbeträge (zu übertragen in Zeile 108)", Name="AbzVoStSum")
        /** @var AbzVoStSum2023|null */
        public ?AbzVoStSum2023 $abzVoStSum=null,

        /** @description Ergänzende Angabe */
        // @ApiMember(Description="Ergänzende Angabe", Name="AbzVoStSum")
        /** @var ErgAng2023|null */
        public ?ErgAng2023 $ergAng=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['e3006201'])) $this->e3006201 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3006201']);
        if (isset($o['e3006301'])) $this->e3006301 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3006301']);
        if (isset($o['e3006401'])) $this->e3006401 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3006401']);
        if (isset($o['e3006503'])) $this->e3006503 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3006503']);
        if (isset($o['e3006502'])) $this->e3006502 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3006502']);
        if (isset($o['e3006601'])) $this->e3006601 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3006601']);
        if (isset($o['e3006701'])) $this->e3006701 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3006701']);
        if (isset($o['e3006801'])) $this->e3006801 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3006801']);
        if (isset($o['abzVoStSum'])) $this->abzVoStSum = JsonConverters::from('AbzVoStSum2023', $o['abzVoStSum']);
        if (isset($o['ergAng'])) $this->ergAng = JsonConverters::from('ErgAng2023', $o['ergAng']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->e3006201)) $o['e3006201'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3006201);
        if (isset($this->e3006301)) $o['e3006301'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3006301);
        if (isset($this->e3006401)) $o['e3006401'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3006401);
        if (isset($this->e3006503)) $o['e3006503'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3006503);
        if (isset($this->e3006502)) $o['e3006502'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3006502);
        if (isset($this->e3006601)) $o['e3006601'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3006601);
        if (isset($this->e3006701)) $o['e3006701'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3006701);
        if (isset($this->e3006801)) $o['e3006801'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3006801);
        if (isset($this->abzVoStSum)) $o['abzVoStSum'] = JsonConverters::to('AbzVoStSum2023', $this->abzVoStSum);
        if (isset($this->ergAng)) $o['ergAng'] = JsonConverters::to('ErgAng2023', $this->ergAng);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Abziehbare Vorsteuerbeträge (ohne die Berichtigung nach § 15a UStG) */
// @Api(Description="Abziehbare Vorsteuerbeträge (ohne die Berichtigung nach § 15a UStG)")
class AbzVoSt2023 implements JsonSerializable
{
    public function __construct(
        /** @description Abziehbare Vorsteuerbeträge (ohne die Berichtigung nach § 15a UStG) Steuer Tabelle */
        // @ApiMember(Description="Abziehbare Vorsteuerbeträge (ohne die Berichtigung nach § 15a UStG) Steuer Tabelle", Name="Tabelle")
        /** @var AbzVoStTabelle2023|null */
        public ?AbzVoStTabelle2023 $tabelle=null
    ) {
    }

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

/** @description Datum-Uhrzeit-Typ. Format: TT.MM.JJJJ. */
// @Api(Description="Datum-Uhrzeit-Typ. Format: TT.MM.JJJJ.")
class DatumUhrzeitTyp extends CustomTypBase implements JsonSerializable
{
    /**
     * @param string|null $alias
     */
    public function __construct(
        ?string $alias=null,
        /** @description Wert des Datentyps. */
        // @ApiMember(Description="Wert des Datentyps.", IsRequired=true, Name="Wert")
        /** @var DateTime */
        public DateTime $wert=new DateTime()
    ) {
        parent::__construct($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['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->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 PositiverGeldBetragMitCent13DETyp extends CustomTypBase implements JsonSerializable
{
    /**
     * @param string|null $alias
     */
    public function __construct(
        ?string $alias=null,
        /** @description Wert des Datentyps.  Mindestens eine Ziffer und maximal 13 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen NICHT erlaubt. */
        // @ApiMember(Description="Wert des Datentyps.  Mindestens eine Ziffer und maximal 13 Ziffern vor dem Dezimaltrennzeichen. 2 Ziffern nach dem Dezimaltrennzeichen. Minusvorzeichen NICHT erlaubt.", IsRequired=true)
        /** @var PositiverGeldBetragMitCent13DE|null */
        public ?PositiverGeldBetragMitCent13DE $betrag=null
    ) {
        parent::__construct($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['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->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Angaben zum Grundstück oder Gebäude. */
// @Api(Description="Angaben zum Grundstück oder Gebäude.")
class AngGrdst2023 implements JsonSerializable
{
    public function __construct(
        /** @description Lage des Grundstücks oder Gebäudes */
        // @ApiMember(Description="Lage des Grundstücks oder Gebäudes", Name="E3007401")
        /** @var StringTyp|null */
        public ?StringTyp $e3007401=null,

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

        /** @description Art der Verwendung im Erstjahr */
        // @ApiMember(Description="Art der Verwendung im Erstjahr", Name="E3007403")
        /** @var StringTyp|null */
        public ?StringTyp $e3007403=null,

        /** @description Umfang der Verwendung im Erstjahr */
        // @ApiMember(Description="Umfang der Verwendung im Erstjahr", Name="E3007404")
        /** @var PositiverGeldBetragMitCent13DETyp|null */
        public ?PositiverGeldBetragMitCent13DETyp $e3007404=null,

        /** @description insgesamt angefallene Vorsteuer */
        // @ApiMember(Description="insgesamt angefallene Vorsteuer", Name="E3007405")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3007405=null,

        /** @description in den Vorjahren - Investitionsphase - bereits abgezogene Vorsteuer */
        // @ApiMember(Description="in den Vorjahren - Investitionsphase - bereits abgezogene Vorsteuer", Name="E3007406")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3007406=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['e3007401'])) $this->e3007401 = JsonConverters::from('StringTyp', $o['e3007401']);
        if (isset($o['e3007402'])) $this->e3007402 = JsonConverters::from('DatumUhrzeitTyp', $o['e3007402']);
        if (isset($o['e3007403'])) $this->e3007403 = JsonConverters::from('StringTyp', $o['e3007403']);
        if (isset($o['e3007404'])) $this->e3007404 = JsonConverters::from('PositiverGeldBetragMitCent13DETyp', $o['e3007404']);
        if (isset($o['e3007405'])) $this->e3007405 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3007405']);
        if (isset($o['e3007406'])) $this->e3007406 = JsonConverters::from('GeldBetragOhneCent12DETyp', $o['e3007406']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->e3007401)) $o['e3007401'] = JsonConverters::to('StringTyp', $this->e3007401);
        if (isset($this->e3007402)) $o['e3007402'] = JsonConverters::to('DatumUhrzeitTyp', $this->e3007402);
        if (isset($this->e3007403)) $o['e3007403'] = JsonConverters::to('StringTyp', $this->e3007403);
        if (isset($this->e3007404)) $o['e3007404'] = JsonConverters::to('PositiverGeldBetragMitCent13DETyp', $this->e3007404);
        if (isset($this->e3007405)) $o['e3007405'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3007405);
        if (isset($this->e3007406)) $o['e3007406'] = JsonConverters::to('GeldBetragOhneCent12DETyp', $this->e3007406);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Angaben zur erstmaligen Verwendung von Grundstücken, Grundstücksteilen, Gebäuden oder Gebäudeteilen */
// @Api(Description="Angaben zur erstmaligen Verwendung von Grundstücken, Grundstücksteilen, Gebäuden oder Gebäudeteilen")
class GrdstErstmVerw2023 implements JsonSerializable
{
    public function __construct(
        /** @description Sind im Kalenderjahr 2023 Grundstücke, Grundstücksteile, Gebäude oder Gebäudeteile, für die Vorsteuer abgezogen worden ist, erstmals tatsächlich verwendet worden? Falls ja, bitte eine 1 eintragen */
        // @ApiMember(Description="Sind im Kalenderjahr 2023 Grundstücke, Grundstücksteile, Gebäude oder Gebäudeteile, für die Vorsteuer abgezogen worden ist, erstmals tatsächlich verwendet worden? Falls ja, bitte eine 1 eintragen", Name="E3007301")
        /** @var Bool1Typ|null */
        public ?Bool1Typ $e3007301=null,

        /** @description Angaben zum Grundstück oder Gebäude. */
        // @ApiMember(Description="Angaben zum Grundstück oder Gebäude.", Name="AngGrdst")
        /** @var AngGrdst2023|null */
        public ?AngGrdst2023 $angGrdst=null
    ) {
    }

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

/** @description Haben sich im Jahr 2023 die für den ursprünglichen Vorsteuerabzug maßgebenden Verhältnisse geändert bei. */
// @Api(Description="Haben sich im Jahr 2023 die für den ursprünglichen Vorsteuerabzug maßgebenden Verhältnisse geändert bei.")
class AendVerh2023 implements JsonSerializable
{
    public function __construct(
        /** @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="E3007601")
        /** @var Bool1Typ|null */
        public ?Bool1Typ $e3007601=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="E3008501")
        /** @var Bool1Typ|null */
        public ?Bool1Typ $e3008501=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="E3008601")
        /** @var Bool1Typ|null */
        public ?Bool1Typ $e3008601=null
    ) {
    }

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

/** @description Boolescher Datentyp, welcher als 'X' (Ja) oder Leerstring (Nein) im Jahressteuererklärung angeschrieben wird. */
// @Api(Description="Boolescher Datentyp, welcher als 'X' (Ja) oder Leerstring (Nein) im Jahressteuererklärung angeschrieben wird.")
class BoolXTyp extends CustomTypBase implements JsonSerializable
{
    /**
     * @param string|null $alias
     */
    public function __construct(
        ?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($alias);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['wert'])) $this->wert = $o['wert'];
        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->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Nutzungsänderung. */
// @Api(Description="Nutzungsänderung.")
class NutzAend2023 implements JsonSerializable
{
    public function __construct(
        /** @description Nutzungsänderung, und zwar */
        // @ApiMember(Description="Nutzungsänderung, und zwar", Name="E3007901")
        /** @var BoolXTyp|null */
        public ?BoolXTyp $e3007901=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="E3008001")
        /** @var BoolXTyp|null */
        public ?BoolXTyp $e3008001=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="E3008202")
        /** @var BoolXTyp|null */
        public ?BoolXTyp $e3008202=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="E3008401")
        /** @var BoolXTyp|null */
        public ?BoolXTyp $e3008401=null,

        /** @description Begründung */
        // @ApiMember(Description="Begründung", Name="E3008402")
        /** @var StringTyp|null */
        public ?StringTyp $e3008402=null
    ) {
    }

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

/** @description Die Verhältnisse, die ursprünglich für die Beurteilung des Vorsteuerabzugs maßgebend waren, haben sich seitdem geändert durch: */
// @Api(Description="Die Verhältnisse, die ursprünglich für die Beurteilung des Vorsteuerabzugs maßgebend waren, haben sich seitdem geändert durch:")
class GrundAendVerh2023 implements JsonSerializable
{
    public function __construct(
        /** @description Veräußerung */
        // @ApiMember(Description="Veräußerung", Name="E3007801")
        /** @var BoolXTyp|null */
        public ?BoolXTyp $e3007801=null,

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

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

        /** @description Nutzungsänderungen */
        // @ApiMember(Description="Nutzungsänderungen", Name="NutzAend")
        /** @var NutzAend2023|null */
        public ?NutzAend2023 $nutzAend=null
    ) {
    }

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

/** @description Summe */
// @Api(Description="Summe")
class VoStBerBetrSum2023 implements JsonSerializable
{
    public function __construct(
        /** @description Summe nachträglich abziehbar (zu übertragen in Zeile 109) */
        // @ApiMember(Description="Summe nachträglich abziehbar (zu übertragen in Zeile 109)", Name="E3008901")
        /** @var PositiverGeldBetragMitCent12DETyp|null */
        public ?PositiverGeldBetragMitCent12DETyp $e3008901=null,

        /** @description Summe zurückzuzahlen (zu übertragen in Zeile 111) */
        // @ApiMember(Description="Summe zurückzuzahlen (zu übertragen in Zeile 111)", Name="E3008902")
        /** @var PositiverGeldBetragMitCent12DETyp|null */
        public ?PositiverGeldBetragMitCent12DETyp $e3008902=null
    ) {
    }

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

/** @description Vorsteuerberichtigungsbeträge nachträglich abziehbar zurückzuzahlen Tabelle */
// @Api(Description="Vorsteuerberichtigungsbeträge nachträglich abziehbar zurückzuzahlen Tabelle")
class VoStBerBetrTabelle2023 implements JsonSerializable
{
    public function __construct(
        /** @description zu 1. (z. B. Grundstücke, § 15a Absatz 1 Satz 2 UStG) (nachträglich abziehbar) */
        // @ApiMember(Description="zu 1. (z. B. Grundstücke, § 15a Absatz 1 Satz 2 UStG) (nachträglich abziehbar)", Name="E3008701")
        /** @var PositiverGeldBetragMitCent12DETyp|null */
        public ?PositiverGeldBetragMitCent12DETyp $e3008701=null,

        /** @description zu 1. (z. B. Grundstücke, § 15a Absatz 1 Satz 2 UStG) (zurückzuzahlen) */
        // @ApiMember(Description="zu 1. (z. B. Grundstücke, § 15a Absatz 1 Satz 2 UStG) (zurückzuzahlen)", Name="E3008702")
        /** @var PositiverGeldBetragMitCent12DETyp|null */
        public ?PositiverGeldBetragMitCent12DETyp $e3008702=null,

        /** @description zu 2. (z. B. andere Wirtschaftsgüter, § 15a Absatz 1 Satz 1 UStG) */
        // @ApiMember(Description="zu 2. (z. B. andere Wirtschaftsgüter, § 15a Absatz 1 Satz 1 UStG)", Name="E3008801")
        /** @var PositiverGeldBetragMitCent12DETyp|null */
        public ?PositiverGeldBetragMitCent12DETyp $e3008801=null,

        /** @description zu 2. (z. B. andere Wirtschaftsgüter, § 15a Absatz 1 Satz 1 UStG) (zurückzuzahlen) */
        // @ApiMember(Description="zu 2. (z. B. andere Wirtschaftsgüter, § 15a Absatz 1 Satz 1 UStG) (zurückzuzahlen)", Name="E3008802")
        /** @var PositiverGeldBetragMitCent12DETyp|null */
        public ?PositiverGeldBetragMitCent12DETyp $e3008802=null,

        /** @description zu 3. (z. B. Wirtschaftsgüter,§ 15a Absatz 2 UStG) (nachträglich abziehbar) */
        // @ApiMember(Description="zu 3. (z. B. Wirtschaftsgüter,§ 15a Absatz 2 UStG) (nachträglich abziehbar)", Name="E3008803")
        /** @var PositiverGeldBetragMitCent12DETyp|null */
        public ?PositiverGeldBetragMitCent12DETyp $e3008803=null,

        /** @description zu 3. (z. B. Wirtschaftsgüter, § 15a Absatz 2 UStG) (zurückzuzahlen) */
        // @ApiMember(Description="zu 3. (z. B. Wirtschaftsgüter, § 15a Absatz 2 UStG) (zurückzuzahlen)", Name="E3008804")
        /** @var PositiverGeldBetragMitCent12DETyp|null */
        public ?PositiverGeldBetragMitCent12DETyp $e3008804=null,

        /** @description Summe */
        // @ApiMember(Description="Summe", Name="VoStBerBetrSum")
        /** @var VoStBerBetrSum2023|null */
        public ?VoStBerBetrSum2023 $voStBerBetrSum=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['e3008701'])) $this->e3008701 = JsonConverters::from('PositiverGeldBetragMitCent12DETyp', $o['e3008701']);
        if (isset($o['e3008702'])) $this->e3008702 = JsonConverters::from('PositiverGeldBetragMitCent12DETyp', $o['e3008702']);
        if (isset($o['e3008801'])) $this->e3008801 = JsonConverters::from('PositiverGeldBetragMitCent12DETyp', $o['e3008801']);
        if (isset($o['e3008802'])) $this->e3008802 = JsonConverters::from('PositiverGeldBetragMitCent12DETyp', $o['e3008802']);
        if (isset($o['e3008803'])) $this->e3008803 = JsonConverters::from('PositiverGeldBetragMitCent12DETyp', $o['e3008803']);
        if (isset($o['e3008804'])) $this->e3008804 = JsonConverters::from('PositiverGeldBetragMitCent12DETyp', $o['e3008804']);
        if (isset($o['voStBerBetrSum'])) $this->voStBerBetrSum = JsonConverters::from('VoStBerBetrSum2023', $o['voStBerBetrSum']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->e3008701)) $o['e3008701'] = JsonConverters::to('PositiverGeldBetragMitCent12DETyp', $this->e3008701);
        if (isset($this->e3008702)) $o['e3008702'] = JsonConverters::to('PositiverGeldBetragMitCent12DETyp', $this->e3008702);
        if (isset($this->e3008801)) $o['e3008801'] = JsonConverters::to('PositiverGeldBetragMitCent12DETyp', $this->e3008801);
        if (isset($this->e3008802)) $o['e3008802'] = JsonConverters::to('PositiverGeldBetragMitCent12DETyp', $this->e3008802);
        if (isset($this->e3008803)) $o['e3008803'] = JsonConverters::to('PositiverGeldBetragMitCent12DETyp', $this->e3008803);
        if (isset($this->e3008804)) $o['e3008804'] = JsonConverters::to('PositiverGeldBetragMitCent12DETyp', $this->e3008804);
        if (isset($this->voStBerBetrSum)) $o['voStBerBetrSum'] = JsonConverters::to('VoStBerBetrSum2023', $this->voStBerBetrSum);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Vorsteuerberichtigungsbeträge. */
// @Api(Description="Vorsteuerberichtigungsbeträge.")
class VoStBerBetr2023 implements JsonSerializable
{
    public function __construct(
        /** @description Vorsteuerberichtigungsbeträge nachträglich abziehbar zurückzuzahlen Tabelle */
        // @ApiMember(Description="Vorsteuerberichtigungsbeträge nachträglich abziehbar zurückzuzahlen Tabelle", Name="Tabelle")
        /** @var VoStBerBetrTabelle2023|null */
        public ?VoStBerBetrTabelle2023 $tabelle=null
    ) {
    }

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

/** @description Berichtigung des Vorsteuerabzugs (§ 15a UStG). */
// @Api(Description="Berichtigung des Vorsteuerabzugs (§ 15a UStG).")
class BerVoSt15a2023 implements JsonSerializable
{
    public function __construct(
        /** @description Sind im Kalenderjahr 2023 Grundstücke, Grundstücksteile, Gebäude oder Gebäudeteile, für die Vorsteuer abgezogen worden ist, erstmals tatsächlich verwendet worden? */
        // @ApiMember(Description="Sind im Kalenderjahr 2023 Grundstücke, Grundstücksteile, Gebäude oder Gebäudeteile, für die Vorsteuer abgezogen worden ist, erstmals tatsächlich verwendet worden?", Name="GrdstErstmVerw")
        /** @var GrdstErstmVerw2023|null */
        public ?GrdstErstmVerw2023 $grdstErstmVerw=null,

        /** @description Haben sich im Jahr 2023 die für den ursprünglichen Vorsteuerabzug maßgebenden Verhältnisse geändert bei */
        // @ApiMember(Description="Haben sich im Jahr 2023 die für den ursprünglichen Vorsteuerabzug maßgebenden Verhältnisse geändert bei", Name="AendVerh")
        /** @var AendVerh2023|null */
        public ?AendVerh2023 $aendVerh=null,

        /** @description Die Verhältnisse, die ursprünglich für die Beurteilung des Vorsteuerabzugs maßgebend waren, haben sich seitdem geändert durch: */
        // @ApiMember(Description="Die Verhältnisse, die ursprünglich für die Beurteilung des Vorsteuerabzugs maßgebend waren, haben sich seitdem geändert durch:", Name="GrundAendVerh")
        /** @var GrundAendVerh2023|null */
        public ?GrundAendVerh2023 $grundAendVerh=null,

        /** @description Nutzungsänderung */
        // @ApiMember(Description="Nutzungsänderung", Name="VoStBerBetr")
        /** @var VoStBerBetr2023|null */
        public ?VoStBerBetr2023 $voStBerBetr=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['grdstErstmVerw'])) $this->grdstErstmVerw = JsonConverters::from('GrdstErstmVerw2023', $o['grdstErstmVerw']);
        if (isset($o['aendVerh'])) $this->aendVerh = JsonConverters::from('AendVerh2023', $o['aendVerh']);
        if (isset($o['grundAendVerh'])) $this->grundAendVerh = JsonConverters::from('GrundAendVerh2023', $o['grundAendVerh']);
        if (isset($o['voStBerBetr'])) $this->voStBerBetr = JsonConverters::from('VoStBerBetr2023', $o['voStBerBetr']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->grdstErstmVerw)) $o['grdstErstmVerw'] = JsonConverters::to('GrdstErstmVerw2023', $this->grdstErstmVerw);
        if (isset($this->aendVerh)) $o['aendVerh'] = JsonConverters::to('AendVerh2023', $this->aendVerh);
        if (isset($this->grundAendVerh)) $o['grundAendVerh'] = JsonConverters::to('GrundAendVerh2023', $this->grundAendVerh);
        if (isset($this->voStBerBetr)) $o['voStBerBetr'] = JsonConverters::to('VoStBerBetr2023', $this->voStBerBetr);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Verbleibende Umsatzsteuer / Verbleibender Überschuss. */
// @Api(Description="Verbleibende Umsatzsteuer / Verbleibender Überschuss.")
class VerblUSt2023 implements JsonSerializable
{
    public function __construct(
        /** @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="E3011101")
        // @Validate(Validator="NotNull")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3011101=null,

        /** @description Vorauszahlungssoll 2023 (einschließlich Sondervorauszahlung) */
        // @ApiMember(Description="Vorauszahlungssoll 2023 (einschließlich Sondervorauszahlung)", IsRequired=true, Name="E3011301")
        // @Validate(Validator="NotNull")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3011301=null
    ) {
    }

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

/** @description Noch an die Finanzkasse zu entrichten - Abschlusszahlung / Erstattungsanspruch - */
// @Api(Description="Noch an die Finanzkasse zu entrichten - Abschlusszahlung / Erstattungsanspruch -")
class ZahlErstatt2023 implements JsonSerializable
{
    public function __construct(
        /** @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="E3011401")
        // @Validate(Validator="NotNull")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3011401=null
    ) {
    }

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

/** @description Berechnung der zu entrichtenden Umsatzsteuer, Steuer Tabelle */
// @Api(Description="Berechnung der zu entrichtenden Umsatzsteuer, Steuer Tabelle")
class BerechUStTabelle2023 implements JsonSerializable
{
    public function __construct(
        /** @description Umsatzsteuer auf steuerpflichtige Lieferungen, sonstige Leistungen und unentgeltliche Wertabgaben (aus Zeile 37) */
        // @ApiMember(Description="Umsatzsteuer auf steuerpflichtige Lieferungen, sonstige Leistungen und unentgeltliche Wertabgaben (aus Zeile 37)", Name="E3009201")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3009201=null,

        /** @description Umsatzsteuer auf innergemeinschaftliche Erwerbe (aus Zeile 56) */
        // @ApiMember(Description="Umsatzsteuer auf innergemeinschaftliche Erwerbe (aus Zeile 56)", Name="E3009401")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3009401=null,

        /** @description Umsatzsteuer, die vom Auslagerer oder Lagerhalter geschuldet wird (§ 13a Absatz 1 Nummer 6 UStG) (aus Zeile 58) */
        // @ApiMember(Description="Umsatzsteuer, die vom Auslagerer oder Lagerhalter geschuldet wird (§ 13a Absatz 1 Nummer 6 UStG) (aus Zeile 58)", Name="E3009602")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3009602=null,

        /** @description Umsatzsteuer, die vom letzten Abnehmer im innergemeinschaftlichen Dreiecksgeschäft geschuldet wird (§ 25b Absatz 2 UStG) (aus Zeile 64) */
        // @ApiMember(Description="Umsatzsteuer, die vom letzten Abnehmer im innergemeinschaftlichen Dreiecksgeschäft geschuldet wird (§ 25b Absatz 2 UStG) (aus Zeile 64)", Name="E3009501")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3009501=null,

        /** @description Umsatzsteuer, die vom Leistungsempfänger nach § 13b UStG geschuldet wird (aus Zeile 68) */
        // @ApiMember(Description="Umsatzsteuer, die vom Leistungsempfänger nach § 13b UStG geschuldet wird (aus Zeile 68)", Name="E3009502")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3009502=null,

        /** @description Zwischensumme */
        // @ApiMember(Description="Zwischensumme", Name="E3009801")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3009801=null,

        /** @description Abziehbare Vorsteuerbeträge (aus Zeile 87) */
        // @ApiMember(Description="Abziehbare Vorsteuerbeträge (aus Zeile 87)", Name="E3009901")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3009901=null,

        /** @description Vorsteuerbeträge, die auf Grund des § 15a UStG nachträglich abziehbar sind (aus Zeile 101) */
        // @ApiMember(Description="Vorsteuerbeträge, die auf Grund des § 15a UStG nachträglich abziehbar sind (aus Zeile 101)", Name="E3010001")
        /** @var PositiverGeldBetragMitCent12DETyp|null */
        public ?PositiverGeldBetragMitCent12DETyp $e3010001=null,

        /** @description Verbleibender Betrag */
        // @ApiMember(Description="Verbleibender Betrag", Name="E3010201")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3010201=null,

        /** @description Vorsteuerbeträge, die auf Grund des § 15a UStG zurückzuzahlen sind (aus Zeile 101) */
        // @ApiMember(Description="Vorsteuerbeträge, die auf Grund des § 15a UStG zurückzuzahlen sind (aus Zeile 101)", Name="E3009701")
        /** @var PositiverGeldBetragMitCent12DETyp|null */
        public ?PositiverGeldBetragMitCent12DETyp $e3009701=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="E3010301")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3010301=null,

        /** @description Steuerbeträge, die nach § 17 Absatz 1 Satz 7 UStG geschuldet werden */
        // @ApiMember(Description="Steuerbeträge, die nach § 17 Absatz 1 Satz 7 UStG geschuldet werden", Name="E3010401")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3010401=null,

        /** @description Steuer- und Vorsteuerbeträge, die auf frühere Besteuerungszeiträume entfallen (nur für Kleinunternehmer, die § 19 Absatz 1 UStG anwenden) */
        // @ApiMember(Description="Steuer- und Vorsteuerbeträge, die auf frühere Besteuerungszeiträume entfallen (nur für Kleinunternehmer, die § 19 Absatz 1 UStG anwenden)", Name="E3010501")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3010501=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="E3010601")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3010601=null,

        /** @description Anrechenbare Beträge (aus Zeile 19 der Anlage UN) */
        // @ApiMember(Description="Anrechenbare Beträge (aus Zeile 19 der Anlage UN)", Name="E3010602")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3010602=null,

        /** @description Verbleibende Umsatzsteuer / Verbleibender Überschuss */
        // @ApiMember(Description="Verbleibende Umsatzsteuer / Verbleibender Überschuss", Name="VerblUSt")
        /** @var VerblUSt2023|null */
        public ?VerblUSt2023 $verblUSt=null,

        /** @description Noch an die Finanzkasse zu entrichten - Abschlusszahlung / Erstattungsanspruch - */
        // @ApiMember(Description="Noch an die Finanzkasse zu entrichten - Abschlusszahlung / Erstattungsanspruch -", Name="ZahlErstatt")
        /** @var ZahlErstatt2023|null */
        public ?ZahlErstatt2023 $zahlErstatt=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['e3009201'])) $this->e3009201 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3009201']);
        if (isset($o['e3009401'])) $this->e3009401 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3009401']);
        if (isset($o['e3009602'])) $this->e3009602 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3009602']);
        if (isset($o['e3009501'])) $this->e3009501 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3009501']);
        if (isset($o['e3009502'])) $this->e3009502 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3009502']);
        if (isset($o['e3009801'])) $this->e3009801 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3009801']);
        if (isset($o['e3009901'])) $this->e3009901 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3009901']);
        if (isset($o['e3010001'])) $this->e3010001 = JsonConverters::from('PositiverGeldBetragMitCent12DETyp', $o['e3010001']);
        if (isset($o['e3010201'])) $this->e3010201 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3010201']);
        if (isset($o['e3009701'])) $this->e3009701 = JsonConverters::from('PositiverGeldBetragMitCent12DETyp', $o['e3009701']);
        if (isset($o['e3010301'])) $this->e3010301 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3010301']);
        if (isset($o['e3010401'])) $this->e3010401 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3010401']);
        if (isset($o['e3010501'])) $this->e3010501 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3010501']);
        if (isset($o['e3010601'])) $this->e3010601 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3010601']);
        if (isset($o['e3010602'])) $this->e3010602 = JsonConverters::from('GeldBetragMitCent12DETyp', $o['e3010602']);
        if (isset($o['verblUSt'])) $this->verblUSt = JsonConverters::from('VerblUSt2023', $o['verblUSt']);
        if (isset($o['zahlErstatt'])) $this->zahlErstatt = JsonConverters::from('ZahlErstatt2023', $o['zahlErstatt']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->e3009201)) $o['e3009201'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3009201);
        if (isset($this->e3009401)) $o['e3009401'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3009401);
        if (isset($this->e3009602)) $o['e3009602'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3009602);
        if (isset($this->e3009501)) $o['e3009501'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3009501);
        if (isset($this->e3009502)) $o['e3009502'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3009502);
        if (isset($this->e3009801)) $o['e3009801'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3009801);
        if (isset($this->e3009901)) $o['e3009901'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3009901);
        if (isset($this->e3010001)) $o['e3010001'] = JsonConverters::to('PositiverGeldBetragMitCent12DETyp', $this->e3010001);
        if (isset($this->e3010201)) $o['e3010201'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3010201);
        if (isset($this->e3009701)) $o['e3009701'] = JsonConverters::to('PositiverGeldBetragMitCent12DETyp', $this->e3009701);
        if (isset($this->e3010301)) $o['e3010301'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3010301);
        if (isset($this->e3010401)) $o['e3010401'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3010401);
        if (isset($this->e3010501)) $o['e3010501'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3010501);
        if (isset($this->e3010601)) $o['e3010601'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3010601);
        if (isset($this->e3010602)) $o['e3010602'] = JsonConverters::to('GeldBetragMitCent12DETyp', $this->e3010602);
        if (isset($this->verblUSt)) $o['verblUSt'] = JsonConverters::to('VerblUSt2023', $this->verblUSt);
        if (isset($this->zahlErstatt)) $o['zahlErstatt'] = JsonConverters::to('ZahlErstatt2023', $this->zahlErstatt);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Berechnung der zu entrichtenden Umsatzsteuer. */
// @Api(Description="Berechnung der zu entrichtenden Umsatzsteuer.")
class BerechUSt2023 implements JsonSerializable
{
    public function __construct(
        /** @description Berechnung der zu entrichtenden Umsatzsteuer, Steuer Tabelle */
        // @ApiMember(Description="Berechnung der zu entrichtenden Umsatzsteuer, Steuer Tabelle", Name="Tabelle")
        /** @var BerechUStTabelle2023|null */
        public ?BerechUStTabelle2023 $tabelle=null
    ) {
    }

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

/** @description Bankverbindung. */
// @Api(Description="Bankverbindung.")
class Bank2023 implements JsonSerializable
{
    public function __construct(
        /** @description IBAN */
        // @ApiMember(Description="IBAN", Name="E3201001")
        /** @var StringTyp|null */
        public ?StringTyp $e3201001=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="E3201002")
        /** @var StringTyp|null */
        public ?StringTyp $e3201002=null,

        /** @description Name des Geldinstituts (Zweigstelle) und Ort */
        // @ApiMember(Description="Name des Geldinstituts (Zweigstelle) und Ort", Name="E3200901")
        /** @var StringTyp|null */
        public ?StringTyp $e3200901=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="E3200902")
        /** @var StringTyp|null */
        public ?StringTyp $e3200902=null,

        /** @description Kontoinhaber laut Zeile 4 auf Vordruck USt2A */
        // @ApiMember(Description="Kontoinhaber laut Zeile 4 auf Vordruck USt2A", Name="E3200904")
        /** @var BoolXTyp|null */
        public ?BoolXTyp $e3200904=null,

        /** @description Name des Kontoinhabers */
        // @ApiMember(Description="Name des Kontoinhabers", Name="E3200905")
        /** @var StringTyp|null */
        public ?StringTyp $e3200905=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['e3201001'])) $this->e3201001 = JsonConverters::from('StringTyp', $o['e3201001']);
        if (isset($o['e3201002'])) $this->e3201002 = JsonConverters::from('StringTyp', $o['e3201002']);
        if (isset($o['e3200901'])) $this->e3200901 = JsonConverters::from('StringTyp', $o['e3200901']);
        if (isset($o['e3200902'])) $this->e3200902 = JsonConverters::from('StringTyp', $o['e3200902']);
        if (isset($o['e3200904'])) $this->e3200904 = JsonConverters::from('BoolXTyp', $o['e3200904']);
        if (isset($o['e3200905'])) $this->e3200905 = JsonConverters::from('StringTyp', $o['e3200905']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->e3201001)) $o['e3201001'] = JsonConverters::to('StringTyp', $this->e3201001);
        if (isset($this->e3201002)) $o['e3201002'] = JsonConverters::to('StringTyp', $this->e3201002);
        if (isset($this->e3200901)) $o['e3200901'] = JsonConverters::to('StringTyp', $this->e3200901);
        if (isset($this->e3200902)) $o['e3200902'] = JsonConverters::to('StringTyp', $this->e3200902);
        if (isset($this->e3200904)) $o['e3200904'] = JsonConverters::to('BoolXTyp', $this->e3200904);
        if (isset($this->e3200905)) $o['e3200905'] = JsonConverters::to('StringTyp', $this->e3200905);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Bevollmächtigter/Empfangsbevollmächtigter Kontakt. */
// @Api(Description="Bevollmächtigter/Empfangsbevollmächtigter Kontakt.")
class VollmKontakt2023 implements JsonSerializable
{
    public function __construct(
        /** @description Telefon */
        // @ApiMember(Description="Telefon", Name="E3201602")
        /** @var StringTyp|null */
        public ?StringTyp $e3201602=null,

        /** @description E-Mail-Adresse */
        // @ApiMember(Description="E-Mail-Adresse", Name="E3201502")
        /** @var StringTyp|null */
        public ?StringTyp $e3201502=null
    ) {
    }

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

/** @description Angaben zur Unterschrift. */
// @Api(Description="Angaben zur Unterschrift.")
class AngUnterschr2023 implements JsonSerializable
{
    public function __construct(
        /** @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="E3201701")
        /** @var BoolXTyp|null */
        public ?BoolXTyp $e3201701=null
    ) {
    }

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

/** @description Bevollmächtigter/Empfangsbevollmächtigter. */
// @Api(Description="Bevollmächtigter/Empfangsbevollmächtigter.")
class Vollm2023 implements JsonSerializable
{
    public function __construct(
        /** @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="E3201301")
        /** @var BoolXTyp|null */
        public ?BoolXTyp $e3201301=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="E3201401")
        /** @var BoolXTyp|null */
        public ?BoolXTyp $e3201401=null,

        /** @description Name */
        // @ApiMember(Description="Name", Name="E3201501")
        /** @var StringTyp|null */
        public ?StringTyp $e3201501=null,

        /** @description Straße */
        // @ApiMember(Description="Straße", Name="E3201601")
        /** @var StringTyp|null */
        public ?StringTyp $e3201601=null,

        /** @description Hausnummer */
        // @ApiMember(Description="Hausnummer", Name="E3201302")
        /** @var StringTyp|null */
        public ?StringTyp $e3201302=null,

        /** @description Hausnummerzusatz */
        // @ApiMember(Description="Hausnummerzusatz", Name="E3201303")
        /** @var StringTyp|null */
        public ?StringTyp $e3201303=null,

        /** @description Adressergänzung */
        // @ApiMember(Description="Adressergänzung", Name="E3201304")
        /** @var StringTyp|null */
        public ?StringTyp $e3201304=null,

        /** @description Postleitzahl */
        // @ApiMember(Description="Postleitzahl", Name="E3201403")
        /** @var StringTyp|null */
        public ?StringTyp $e3201403=null,

        /** @description Ort */
        // @ApiMember(Description="Ort", Name="E3201404")
        /** @var StringTyp|null */
        public ?StringTyp $e3201404=null,

        /** @description Postleitzahl zu Postfach */
        // @ApiMember(Description="Postleitzahl zu Postfach", Name="E3201503")
        /** @var StringTyp|null */
        public ?StringTyp $e3201503=null,

        /** @description Postfach */
        // @ApiMember(Description="Postfach", Name="E3201504")
        /** @var StringTyp|null */
        public ?StringTyp $e3201504=null,

        /** @description Bevollmächtigter/Empfangsbevollmächtigter Kontakt */
        // @ApiMember(Description="Bevollmächtigter/Empfangsbevollmächtigter Kontakt", Name="Kontakt")
        /** @var VollmKontakt2023|null */
        public ?VollmKontakt2023 $kontakt=null,

        /** @description Angaben zur Unterschrift */
        // @ApiMember(Description="Angaben zur Unterschrift", Name="AngUnterschr")
        /** @var AngUnterschr2023|null */
        public ?AngUnterschr2023 $angUnterschr=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['e3201301'])) $this->e3201301 = JsonConverters::from('BoolXTyp', $o['e3201301']);
        if (isset($o['e3201401'])) $this->e3201401 = JsonConverters::from('BoolXTyp', $o['e3201401']);
        if (isset($o['e3201501'])) $this->e3201501 = JsonConverters::from('StringTyp', $o['e3201501']);
        if (isset($o['e3201601'])) $this->e3201601 = JsonConverters::from('StringTyp', $o['e3201601']);
        if (isset($o['e3201302'])) $this->e3201302 = JsonConverters::from('StringTyp', $o['e3201302']);
        if (isset($o['e3201303'])) $this->e3201303 = JsonConverters::from('StringTyp', $o['e3201303']);
        if (isset($o['e3201304'])) $this->e3201304 = JsonConverters::from('StringTyp', $o['e3201304']);
        if (isset($o['e3201403'])) $this->e3201403 = JsonConverters::from('StringTyp', $o['e3201403']);
        if (isset($o['e3201404'])) $this->e3201404 = JsonConverters::from('StringTyp', $o['e3201404']);
        if (isset($o['e3201503'])) $this->e3201503 = JsonConverters::from('StringTyp', $o['e3201503']);
        if (isset($o['e3201504'])) $this->e3201504 = JsonConverters::from('StringTyp', $o['e3201504']);
        if (isset($o['kontakt'])) $this->kontakt = JsonConverters::from('VollmKontakt2023', $o['kontakt']);
        if (isset($o['angUnterschr'])) $this->angUnterschr = JsonConverters::from('AngUnterschr2023', $o['angUnterschr']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->e3201301)) $o['e3201301'] = JsonConverters::to('BoolXTyp', $this->e3201301);
        if (isset($this->e3201401)) $o['e3201401'] = JsonConverters::to('BoolXTyp', $this->e3201401);
        if (isset($this->e3201501)) $o['e3201501'] = JsonConverters::to('StringTyp', $this->e3201501);
        if (isset($this->e3201601)) $o['e3201601'] = JsonConverters::to('StringTyp', $this->e3201601);
        if (isset($this->e3201302)) $o['e3201302'] = JsonConverters::to('StringTyp', $this->e3201302);
        if (isset($this->e3201303)) $o['e3201303'] = JsonConverters::to('StringTyp', $this->e3201303);
        if (isset($this->e3201304)) $o['e3201304'] = JsonConverters::to('StringTyp', $this->e3201304);
        if (isset($this->e3201403)) $o['e3201403'] = JsonConverters::to('StringTyp', $this->e3201403);
        if (isset($this->e3201404)) $o['e3201404'] = JsonConverters::to('StringTyp', $this->e3201404);
        if (isset($this->e3201503)) $o['e3201503'] = JsonConverters::to('StringTyp', $this->e3201503);
        if (isset($this->e3201504)) $o['e3201504'] = JsonConverters::to('StringTyp', $this->e3201504);
        if (isset($this->kontakt)) $o['kontakt'] = JsonConverters::to('VollmKontakt2023', $this->kontakt);
        if (isset($this->angUnterschr)) $o['angUnterschr'] = JsonConverters::to('AngUnterschr2023', $this->angUnterschr);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Allgemeine Angaben. */
// @Api(Description="Allgemeine Angaben.")
class UnAllg2023 implements JsonSerializable
{
    public function __construct(
        /** @description Bankverbindung */
        // @ApiMember(Description="Bankverbindung", Name="Bank")
        /** @var Bank2023|null */
        public ?Bank2023 $bank=null,

        /** @description Bevollmächtigter/Empfangsbevollmächtigter */
        // @ApiMember(Description="Bevollmächtigter/Empfangsbevollmächtigter", Name="Vollm")
        /** @var Vollm2023|null */
        public ?Vollm2023 $vollm=null
    ) {
    }

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

/** @description Boolescher Datentyp, welcher als '1' (Ja) oder '2' (Nein) im Jahressteuererklärung angeschrieben wird. */
// @Api(Description="Boolescher Datentyp, welcher als '1' (Ja) oder '2' (Nein) im Jahressteuererklärung angeschrieben wird.")
class Bool12Typ extends CustomTypBase implements JsonSerializable
{
    /**
     * @param string|null $alias
     */
    public function __construct(
        ?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($alias);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['wert'])) $this->wert = $o['wert'];
        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->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Vorsteuer-Vergütungsverfahren beim Bundeszentralamt für Steuern. */
// @Api(Description="Vorsteuer-Vergütungsverfahren beim Bundeszentralamt für Steuern.")
class VoStVerguetBZSt2023 implements JsonSerializable
{
    public function __construct(
        /** @description Ist für das Kalenderjahr 2023 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 2023 die Vergütung von Vorsteuern in einem besonderen Verfahren (§ 18 Absatz 9 UStG, §§ 59 bis 61a UStDV) beantragt worden?", IsRequired=true, Name="E3201101")
        // @Validate(Validator="NotNull")
        /** @var Bool12Typ|null */
        public ?Bool12Typ $e3201101=null
    ) {
    }

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

/** @description C. Anrechenbare Beträge. */
// @Api(Description="C. Anrechenbare Beträge.")
class AnrechBetr2023 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="E3201902")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3201902=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="E3202002")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3202002=null,

        /** @description Summe (zu übertragen in Zeile 116 der Steuererklärung) */
        // @ApiMember(Description="Summe (zu übertragen in Zeile 116 der Steuererklärung)", Name="E3202102")
        /** @var GeldBetragMitCent12DETyp|null */
        public ?GeldBetragMitCent12DETyp $e3202102=null
    ) {
    }

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

/** @description In den steuerpflichtigen Umsätzen enthaltene Umsätze. */
// @Api(Description="In den steuerpflichtigen Umsätzen enthaltene Umsätze.")
class InstpflUmsEnt2023 implements JsonSerializable
{
    public function __construct(
        /** @description Innergemeinschaftliche Fernverkäufe aus dem übrigen Gemeinschaftsgebiet (§ 3c UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR) */
        // @ApiMember(Description="Innergemeinschaftliche Fernverkäufe aus dem übrigen Gemeinschaftsgebiet (§ 3c UStG) (Bemessungsgrundlage ohne Umsatzsteuer, volle EUR)", Name="E3201901")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3201901=null
    ) {
    }

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

/** @description Ergänzende Angaben zu Umsätzen Tabelle (Bemessungsgrundlage ohne Umsatzsteuer) */
// @Api(Description="Ergänzende Angaben zu Umsätzen Tabelle (Bemessungsgrundlage ohne Umsatzsteuer)")
class UnErgAngUmsTabelle2023 implements JsonSerializable
{
    public function __construct(
        /** @description In den steuerpflichtigen Umsätzen enthaltene Umsätze */
        // @ApiMember(Description="In den steuerpflichtigen Umsätzen enthaltene Umsätze", Name="InstpflUmsEnt")
        /** @var InstpflUmsEnt2023|null */
        public ?InstpflUmsEnt2023 $instpflUmsEnt=null
    ) {
    }

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

/** @description Ergänzende Angaben zu Umsätzen. */
// @Api(Description="Ergänzende Angaben zu Umsätzen.")
class UnErgAngUms2023 implements JsonSerializable
{
    public function __construct(
        /** @description Ergänzende Angaben zu Umsätzen Tabelle (Bemessungsgrundlage ohne Umsatzsteuer) */
        // @ApiMember(Description="Ergänzende Angaben zu Umsätzen Tabelle (Bemessungsgrundlage ohne Umsatzsteuer)", Name="Tabelle")
        /** @var UnErgAngUmsTabelle2023|null */
        public ?UnErgAngUmsTabelle2023 $tabelle=null
    ) {
    }

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

/** @description Anlage UN zur Umsatzsteuererklärung für im Ausland ansässige Unternehmer. */
// @Api(Description="Anlage UN zur Umsatzsteuererklärung für im Ausland ansässige Unternehmer.")
class UN2023 implements JsonSerializable
{
    public function __construct(
        /** @description A. Allgemeine Angaben */
        // @ApiMember(Description="A. Allgemeine Angaben", Name="Allg")
        /** @var UnAllg2023|null */
        public ?UnAllg2023 $allg=null,

        /** @description B. Vorsteuer-Vergütungsverfahren beim Bundeszentralamt für Steuern */
        // @ApiMember(Description="B. Vorsteuer-Vergütungsverfahren beim Bundeszentralamt für Steuern", Name="VoStVerguetBZSt")
        /** @var VoStVerguetBZSt2023|null */
        public ?VoStVerguetBZSt2023 $voStVerguetBZSt=null,

        /** @description C. Anrechenbare Beträge */
        // @ApiMember(Description="C. Anrechenbare Beträge", Name="AnrechBetr")
        /** @var AnrechBetr2023|null */
        public ?AnrechBetr2023 $anrechBetr=null,

        /** @description D. Ergänzende Angaben zu Umsätzen */
        // @ApiMember(Description="D. Ergänzende Angaben zu Umsätzen", Name="ErgAngUms")
        /** @var UnErgAngUms2023|null */
        public ?UnErgAngUms2023 $ergAngUms=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['allg'])) $this->allg = JsonConverters::from('UnAllg2023', $o['allg']);
        if (isset($o['voStVerguetBZSt'])) $this->voStVerguetBZSt = JsonConverters::from('VoStVerguetBZSt2023', $o['voStVerguetBZSt']);
        if (isset($o['anrechBetr'])) $this->anrechBetr = JsonConverters::from('AnrechBetr2023', $o['anrechBetr']);
        if (isset($o['ergAngUms'])) $this->ergAngUms = JsonConverters::from('UnErgAngUms2023', $o['ergAngUms']);
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->allg)) $o['allg'] = JsonConverters::to('UnAllg2023', $this->allg);
        if (isset($this->voStVerguetBZSt)) $o['voStVerguetBZSt'] = JsonConverters::to('VoStVerguetBZSt2023', $this->voStVerguetBZSt);
        if (isset($this->anrechBetr)) $o['anrechBetr'] = JsonConverters::to('AnrechBetr2023', $this->anrechBetr);
        if (isset($this->ergAngUms)) $o['ergAngUms'] = JsonConverters::to('UnErgAngUms2023', $this->ergAngUms);
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Einzelner vertretene Unternehmer */
// @Api(Description="Einzelner vertretene Unternehmer")
class Einz2023 implements JsonSerializable
{
    public function __construct(
        /** @description Name des vertretenen Unternehmers */
        // @ApiMember(Description="Name des vertretenen Unternehmers", Name="E3300201")
        /** @var StringTyp|null */
        public ?StringTyp $e3300201=null,

        /** @description Anschrift des vertretenen Unternehmers */
        // @ApiMember(Description="Anschrift des vertretenen Unternehmers", Name="E3300202")
        /** @var StringTyp|null */
        public ?StringTyp $e3300202=null,

        /** @description Falls vorhanden: Umsatzsteuer-Identifikationsnummer des vertretenen Unternehmers */
        // @ApiMember(Description="Falls vorhanden: Umsatzsteuer-Identifikationsnummer des vertretenen Unternehmers", Name="E3300203")
        /** @var StringTyp|null */
        public ?StringTyp $e3300203=null,

        /** @description Summe der jeweiligen Bemessungsgrundlagen in EUR */
        // @ApiMember(Description="Summe der jeweiligen Bemessungsgrundlagen in EUR", Name="E3300204")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3300204=null
    ) {
    }

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

/** @description Summe */
// @Api(Description="Summe")
class AufstAllerVertrUntSum2023 implements JsonSerializable
{
    public function __construct(
        /** @description  Summe in EUR */
        // @ApiMember(Description=" Summe in EUR", Name="E3300301")
        /** @var GeldBetragOhneCent12DETyp|null */
        public ?GeldBetragOhneCent12DETyp $e3300301=null
    ) {
    }

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

/** @description Aufstellung aller vertretenen Unternehmer */
// @Api(Description="Aufstellung aller vertretenen Unternehmer")
class AufstAllerVertrUnt2023 implements JsonSerializable
{
    public function __construct(
        /** @description Die vertretenen Unternehmer */
        // @ApiMember(Description="Die vertretenen Unternehmer", Name="Einzs")
        /** @var array<Einz2023>|null */
        public ?array $einzs=null,

        /** @description Die Summe */
        // @ApiMember(Description="Die Summe", Name="Sum")
        /** @var AufstAllerVertrUntSum2023|null */
        public ?AufstAllerVertrUntSum2023 $sum=null
    ) {
    }

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

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

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

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

/** @description Datentyp, welches den Vorgang bei einer Veranlagung darstellt. */
// @Api(Description="Datentyp, welches den Vorgang bei einer Veranlagung darstellt.")
class VeranlagungVorgangTyp extends CustomTypBase implements JsonSerializable
{
    /**
     * @param string|null $alias
     */
    public function __construct(
        ?string $alias=null,
        /** @description Wert des Datentyps. */
        // @ApiMember(Description="Wert des Datentyps.", IsRequired=true, Name="Wert")
        /** @var VeranlagungVorgang|null */
        public ?VeranlagungVorgang $wert=null
    ) {
        parent::__construct($alias);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['wert'])) $this->wert = JsonConverters::from('VeranlagungVorgang', $o['wert']);
        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('VeranlagungVorgang', $this->wert);
        if (isset($this->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

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

/** @description Datentyp, welches die ermittelten Ordnungsbegriff zu füllen darstellt. */
// @Api(Description="Datentyp, welches die ermittelten Ordnungsbegriff zu füllen darstellt.")
class OrdNrArtTyp extends CustomTypBase implements JsonSerializable
{
    /**
     * @param string|null $alias
     */
    public function __construct(
        ?string $alias=null,
        /** @description Wert des Datentyps. */
        // @ApiMember(Description="Wert des Datentyps.", IsRequired=true, Name="Wert")
        /** @var OrdNrArt|null */
        public ?OrdNrArt $wert=null
    ) {
        parent::__construct($alias);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['wert'])) $this->wert = JsonConverters::from('OrdNrArt', $o['wert']);
        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('OrdNrArt', $this->wert);
        if (isset($this->alias)) $o['alias'] = $this->alias;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Stellt die Informationen zur Bescheidrückübermittlung für die neue Struktur der Jahrresteuererklärung dar. */
// @Api(Description="Stellt die Informationen zur Bescheidrückübermittlung für die neue Struktur der Jahrresteuererklärung dar.")
class E50Rueckuebermittlung 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 Bool12Typ|null */
        public ?Bool12Typ $bescheid=null,

        /** @description Art der Benachrichtigung über vorliegende Bescheiddaten zur Abholung. */
        // @ApiMember(Description="Art der Benachrichtigung über vorliegende Bescheiddaten zur Abholung.")
        /** @var StringTyp|null */
        public ?StringTyp $artRueckuebermittlung=null,

        /** @description Schlüssel unter dem die Bescheiddaten verschlüsselt zur Abholung bereitgestellt werden sollen */
        // @ApiMember(Description="Schlüssel unter dem die Bescheiddaten verschlüsselt zur Abholung bereitgestellt werden sollen")
        /** @var StringTyp|null */
        public ?StringTyp $schluesselRueckuebermittlung=null,

        /** @description Benachrichtigungsadresse (in der Regel E-Mail-Adresse) für die Benachrichtigung über die elektronische Bereitstellung der Bescheiddaten. */
        // @ApiMember(Description="Benachrichtigungsadresse (in der Regel E-Mail-Adresse) für die Benachrichtigung über die elektronische Bereitstellung der Bescheiddaten.")
        /** @var StringTyp|null */
        public ?StringTyp $adresseRueckuebermittlung=null
    ) {
    }

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

/** @description Create XML content that represents an annual VAT return (Umsatzsteuerjahresserklärung) for 2023. */
// @Api(Description="Create XML content that represents an annual VAT return (Umsatzsteuerjahresserklärung) for 2023.")
class CreateUmsatzsteuererklaerung2023XmlBase implements IPost, JsonSerializable
{
    public function __construct(
        /** @description Berichtigte Erklärung */
        // @ApiMember(Description="Berichtigte Erklärung", Name="BerErkl")
        /** @var BerErkl2023|null */
        public ?BerErkl2023 $berErkl=null,

        /** @description A. Allgemeine Angaben. */
        // @ApiMember(Description="A. Allgemeine Angaben.", Name="Allg")
        /** @var Allg2023|null */
        public ?Allg2023 $allg=null,

        /** @description Angaben zu den Mitwirkenden, die bei der Anfertigung dieser Steuererklärung einschließlich der Anlagen mitgewirkt haben. */
        // @ApiMember(Description="Angaben zu den Mitwirkenden, die bei der Anfertigung dieser Steuererklärung einschließlich der Anlagen mitgewirkt haben.", Name="Mitwirk")
        /** @var Mitwirk2023|null */
        public ?Mitwirk2023 $mitwirk=null,

        /** @description B. Angaben zur Besteuerung der Kleinunternehmer (§ 19 Absatz 1 UStG). Die Zeilen 33 und 34 sind nur auszufüllen, wenn der Umsatz $VZ-1$ (zuzüglich Steuer) nicht mehr als 22.000 € betragen hat und auf die Anwendung des § 19 Absatz 1 UStG nicht verzichtet worden ist. */
        // @ApiMember(Description="B. Angaben zur Besteuerung der Kleinunternehmer (§ 19 Absatz 1 UStG). Die Zeilen 33 und 34 sind nur auszufüllen, wenn der Umsatz $VZ-1$ (zuzüglich Steuer) nicht mehr als 22.000 € betragen hat und auf die Anwendung des § 19 Absatz 1 UStG nicht verzichtet worden ist.", Name="Kleinuntern")
        /** @var Kleinuntern2023|null */
        public ?Kleinuntern2023 $kleinuntern=null,

        /** @description C. Steuerpflichtige Lieferungen, sonstige Leistungen und unentgeltliche Wertabgaben. */
        // @ApiMember(Description="C. Steuerpflichtige Lieferungen, sonstige Leistungen und unentgeltliche Wertabgaben.", Name="Umsaetze")
        /** @var Umsaetze2023|null */
        public ?Umsaetze2023 $umsaetze=null,

        /** @description D. Steuerfreie Lieferungen, sonstige Leistungen und unentgeltliche Wertabgaben. */
        // @ApiMember(Description="D. Steuerfreie Lieferungen, sonstige Leistungen und unentgeltliche Wertabgaben.", Name="UmsStfrei")
        /** @var UmsStfrei2023|null */
        public ?UmsStfrei2023 $umsStfrei=null,

        /** @description E. Innergemeinschaftliche Erwerbe. */
        // @ApiMember(Description="E. Innergemeinschaftliche Erwerbe.", Name="IgErw")
        /** @var IgErw2023|null */
        public ?IgErw2023 $igErw=null,

        /** @description F. Steuerschuldner bei Auslagerung (§ 13a Absatz 1 Nummer 6 UStG). */
        // @ApiMember(Description="F. Steuerschuldner bei Auslagerung (§ 13a Absatz 1 Nummer 6 UStG).", Name="Auslag13a")
        /** @var Auslag13a2023|null */
        public ?Auslag13a2023 $auslag13a=null,

        /** @description G. Innergemeinschaftliche Dreiecksgeschäfte (§ 25b UStG). */
        // @ApiMember(Description="G. Innergemeinschaftliche Dreiecksgeschäfte (§ 25b UStG).", Name="IgDrei")
        /** @var IgDrei2023|null */
        public ?IgDrei2023 $igDrei=null,

        /** @description H. Leistungsempfänger als Steuerschuldner (§ 13b UStG). */
        // @ApiMember(Description="H. Leistungsempfänger als Steuerschuldner (§ 13b UStG).", Name="Ums13b")
        /** @var Ums13b2023|null */
        public ?Ums13b2023 $ums13b=null,

        /** @description I. Ergänzende Angaben zu Umsätzen. */
        // @ApiMember(Description="I. Ergänzende Angaben zu Umsätzen.", Name="ErgAngUms")
        /** @var ErgAngUms2023|null */
        public ?ErgAngUms2023 $ergAngUms=null,

        /** @description J. Abziehbare Vorsteuerbeträge */
        // @ApiMember(Description="J. Abziehbare Vorsteuerbeträge", Name="AbzVoSt")
        /** @var AbzVoSt2023|null */
        public ?AbzVoSt2023 $abzVoSt=null,

        /** @description K. Berichtigung des Vorsteuerabzugs (§ 15a UStG) */
        // @ApiMember(Description="K. Berichtigung des Vorsteuerabzugs (§ 15a UStG)", Name="BerVoSt15a")
        /** @var BerVoSt15a2023|null */
        public ?BerVoSt15a2023 $berVoSt15a=null,

        /** @description L. Berechnung der zu entrichtenden Umsatzsteuer */
        // @ApiMember(Description="L. Berechnung der zu entrichtenden Umsatzsteuer", Name="BerechUSt")
        /** @var BerechUSt2023|null */
        public ?BerechUSt2023 $berechUSt=null,

        /** @description Anlage UN zur Umsatzsteuererklärung für im Ausland ansässige Unternehmer */
        // @ApiMember(Description="Anlage UN zur Umsatzsteuererklärung für im Ausland ansässige Unternehmer", Name="Un")
        /** @var UN2023|null */
        public ?UN2023 $un=null,

        /** @description Anlage FV zur Umsatzsteuererklärung $VZ$ */
        // @ApiMember(Description="Anlage FV zur Umsatzsteuererklärung $VZ$", Name="Fv")
        /** @var FV2023|null */
        public ?FV2023 $fv=null,

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

        /** @description Die Steuernummer. Bundeseinheitliche 13-stellige Steuernummer im ELSTER-Steuernummernformat */
        // @ApiMember(Description="Die Steuernummer. Bundeseinheitliche 13-stellige Steuernummer im ELSTER-Steuernummernformat")
        /** @var StringTyp|null */
        public ?StringTyp $stNr=null,

        /** @description Ordnungsbegriff */
        // @ApiMember(Description="Ordnungsbegriff")
        /** @var StringTyp|null */
        public ?StringTyp $ordnungsbegriff=null,

        /** @description Identifikationsnummer steuerpflichtige Person / Ehemann / Person A */
        // @ApiMember(Description="Identifikationsnummer steuerpflichtige Person / Ehemann / Person A")
        /** @var StringTyp|null */
        public ?StringTyp $id=null,

        /** @description Identifikationsnummer Ehefrau / Person B */
        // @ApiMember(Description="Identifikationsnummer Ehefrau / Person B")
        /** @var StringTyp|null */
        public ?StringTyp $idEhefrau=null,

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

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

        /** @description Postleitzahl des Absenders der Erklärung, numerisch, 5-stellig. */
        // @ApiMember(Description="Postleitzahl des Absenders der Erklärung, numerisch, 5-stellig.")
        /** @var StringTyp|null */
        public ?StringTyp $absPlz=null,

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

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

        /** @description TeleNummer (für finanzamtsinterne Zwecke; keine Eingabe durch Anwender) */
        // @ApiMember(Description="TeleNummer (für finanzamtsinterne Zwecke; keine Eingabe durch Anwender)")
        /** @var StringTyp|null */
        public ?StringTyp $teleNummer=null,

        /** @description Die Art des ermittelten Ordnungsbegriffs zu füllen. */
        // @ApiMember(Description="Die Art des ermittelten Ordnungsbegriffs zu füllen.")
        /** @var OrdNrArtTyp|null */
        public ?OrdNrArtTyp $ordNrArt=null,

        /** @description Die zur Abholung notwendigen Informationen werden hier angegeben. */
        // @ApiMember(Description="Die zur Abholung notwendigen Informationen werden hier angegeben.")
        /** @var E50Rueckuebermittlung|null */
        public ?E50Rueckuebermittlung $rueckuebermittlung=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=''
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['berErkl'])) $this->berErkl = JsonConverters::from('BerErkl2023', $o['berErkl']);
        if (isset($o['allg'])) $this->allg = JsonConverters::from('Allg2023', $o['allg']);
        if (isset($o['mitwirk'])) $this->mitwirk = JsonConverters::from('Mitwirk2023', $o['mitwirk']);
        if (isset($o['kleinuntern'])) $this->kleinuntern = JsonConverters::from('Kleinuntern2023', $o['kleinuntern']);
        if (isset($o['umsaetze'])) $this->umsaetze = JsonConverters::from('Umsaetze2023', $o['umsaetze']);
        if (isset($o['umsStfrei'])) $this->umsStfrei = JsonConverters::from('UmsStfrei2023', $o['umsStfrei']);
        if (isset($o['igErw'])) $this->igErw = JsonConverters::from('IgErw2023', $o['igErw']);
        if (isset($o['auslag13a'])) $this->auslag13a = JsonConverters::from('Auslag13a2023', $o['auslag13a']);
        if (isset($o['igDrei'])) $this->igDrei = JsonConverters::from('IgDrei2023', $o['igDrei']);
        if (isset($o['ums13b'])) $this->ums13b = JsonConverters::from('Ums13b2023', $o['ums13b']);
        if (isset($o['ergAngUms'])) $this->ergAngUms = JsonConverters::from('ErgAngUms2023', $o['ergAngUms']);
        if (isset($o['abzVoSt'])) $this->abzVoSt = JsonConverters::from('AbzVoSt2023', $o['abzVoSt']);
        if (isset($o['berVoSt15a'])) $this->berVoSt15a = JsonConverters::from('BerVoSt15a2023', $o['berVoSt15a']);
        if (isset($o['berechUSt'])) $this->berechUSt = JsonConverters::from('BerechUSt2023', $o['berechUSt']);
        if (isset($o['un'])) $this->un = JsonConverters::from('UN2023', $o['un']);
        if (isset($o['fv'])) $this->fv = JsonConverters::from('FV2023', $o['fv']);
        if (isset($o['vorgang'])) $this->vorgang = JsonConverters::from('VeranlagungVorgangTyp', $o['vorgang']);
        if (isset($o['stNr'])) $this->stNr = JsonConverters::from('StringTyp', $o['stNr']);
        if (isset($o['ordnungsbegriff'])) $this->ordnungsbegriff = JsonConverters::from('StringTyp', $o['ordnungsbegriff']);
        if (isset($o['id'])) $this->id = JsonConverters::from('StringTyp', $o['id']);
        if (isset($o['idEhefrau'])) $this->idEhefrau = JsonConverters::from('StringTyp', $o['idEhefrau']);
        if (isset($o['absName'])) $this->absName = JsonConverters::from('StringTyp', $o['absName']);
        if (isset($o['absStr'])) $this->absStr = JsonConverters::from('StringTyp', $o['absStr']);
        if (isset($o['absPlz'])) $this->absPlz = JsonConverters::from('StringTyp', $o['absPlz']);
        if (isset($o['absOrt'])) $this->absOrt = JsonConverters::from('StringTyp', $o['absOrt']);
        if (isset($o['copyright'])) $this->copyright = JsonConverters::from('StringTyp', $o['copyright']);
        if (isset($o['teleNummer'])) $this->teleNummer = JsonConverters::from('StringTyp', $o['teleNummer']);
        if (isset($o['ordNrArt'])) $this->ordNrArt = JsonConverters::from('OrdNrArtTyp', $o['ordNrArt']);
        if (isset($o['rueckuebermittlung'])) $this->rueckuebermittlung = JsonConverters::from('E50Rueckuebermittlung', $o['rueckuebermittlung']);
        if (isset($o['bundesfinanzamtsnummer'])) $this->bundesfinanzamtsnummer = $o['bundesfinanzamtsnummer'];
        if (isset($o['datenLieferant'])) $this->datenLieferant = $o['datenLieferant'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->berErkl)) $o['berErkl'] = JsonConverters::to('BerErkl2023', $this->berErkl);
        if (isset($this->allg)) $o['allg'] = JsonConverters::to('Allg2023', $this->allg);
        if (isset($this->mitwirk)) $o['mitwirk'] = JsonConverters::to('Mitwirk2023', $this->mitwirk);
        if (isset($this->kleinuntern)) $o['kleinuntern'] = JsonConverters::to('Kleinuntern2023', $this->kleinuntern);
        if (isset($this->umsaetze)) $o['umsaetze'] = JsonConverters::to('Umsaetze2023', $this->umsaetze);
        if (isset($this->umsStfrei)) $o['umsStfrei'] = JsonConverters::to('UmsStfrei2023', $this->umsStfrei);
        if (isset($this->igErw)) $o['igErw'] = JsonConverters::to('IgErw2023', $this->igErw);
        if (isset($this->auslag13a)) $o['auslag13a'] = JsonConverters::to('Auslag13a2023', $this->auslag13a);
        if (isset($this->igDrei)) $o['igDrei'] = JsonConverters::to('IgDrei2023', $this->igDrei);
        if (isset($this->ums13b)) $o['ums13b'] = JsonConverters::to('Ums13b2023', $this->ums13b);
        if (isset($this->ergAngUms)) $o['ergAngUms'] = JsonConverters::to('ErgAngUms2023', $this->ergAngUms);
        if (isset($this->abzVoSt)) $o['abzVoSt'] = JsonConverters::to('AbzVoSt2023', $this->abzVoSt);
        if (isset($this->berVoSt15a)) $o['berVoSt15a'] = JsonConverters::to('BerVoSt15a2023', $this->berVoSt15a);
        if (isset($this->berechUSt)) $o['berechUSt'] = JsonConverters::to('BerechUSt2023', $this->berechUSt);
        if (isset($this->un)) $o['un'] = JsonConverters::to('UN2023', $this->un);
        if (isset($this->fv)) $o['fv'] = JsonConverters::to('FV2023', $this->fv);
        if (isset($this->vorgang)) $o['vorgang'] = JsonConverters::to('VeranlagungVorgangTyp', $this->vorgang);
        if (isset($this->stNr)) $o['stNr'] = JsonConverters::to('StringTyp', $this->stNr);
        if (isset($this->ordnungsbegriff)) $o['ordnungsbegriff'] = JsonConverters::to('StringTyp', $this->ordnungsbegriff);
        if (isset($this->id)) $o['id'] = JsonConverters::to('StringTyp', $this->id);
        if (isset($this->idEhefrau)) $o['idEhefrau'] = JsonConverters::to('StringTyp', $this->idEhefrau);
        if (isset($this->absName)) $o['absName'] = JsonConverters::to('StringTyp', $this->absName);
        if (isset($this->absStr)) $o['absStr'] = JsonConverters::to('StringTyp', $this->absStr);
        if (isset($this->absPlz)) $o['absPlz'] = JsonConverters::to('StringTyp', $this->absPlz);
        if (isset($this->absOrt)) $o['absOrt'] = JsonConverters::to('StringTyp', $this->absOrt);
        if (isset($this->copyright)) $o['copyright'] = JsonConverters::to('StringTyp', $this->copyright);
        if (isset($this->teleNummer)) $o['teleNummer'] = JsonConverters::to('StringTyp', $this->teleNummer);
        if (isset($this->ordNrArt)) $o['ordNrArt'] = JsonConverters::to('OrdNrArtTyp', $this->ordNrArt);
        if (isset($this->rueckuebermittlung)) $o['rueckuebermittlung'] = JsonConverters::to('E50Rueckuebermittlung', $this->rueckuebermittlung);
        if (isset($this->bundesfinanzamtsnummer)) $o['bundesfinanzamtsnummer'] = $this->bundesfinanzamtsnummer;
        if (isset($this->datenLieferant)) $o['datenLieferant'] = $this->datenLieferant;
        return empty($o) ? new class(){} : $o;
    }
}

/** @description Represents the response from a service that generates XML content. */
// @Api(Description="Represents the response from a service that generates XML content.")
class XmlResponse implements JsonSerializable
{
    public function __construct(
        /** @description The XML-based content of the response. */
        // @ApiMember(Description="The XML-based content of the response.")
        /** @var string|null */
        public ?string $content=null,

        /** @description Metadata that contains structured error information on the XML response. */
        // @ApiMember(Description="Metadata that contains structured error information on the XML response.")
        /** @var ResponseStatus|null */
        public ?ResponseStatus $responseStatus=null
    ) {
    }

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

/** @description A synchronous service to create XML content that represents the annual VAT return for 2023. */
// @Api(Description="A synchronous service to create XML content that represents the annual VAT return for 2023.")
class CreateUmsatzsteuererklaerung2023Xml extends CreateUmsatzsteuererklaerung2023XmlBase implements JsonSerializable
{
    /**
     * @param BerErkl2023|null $berErkl
     * @param Allg2023|null $allg
     * @param Mitwirk2023|null $mitwirk
     * @param Kleinuntern2023|null $kleinuntern
     * @param Umsaetze2023|null $umsaetze
     * @param UmsStfrei2023|null $umsStfrei
     * @param IgErw2023|null $igErw
     * @param Auslag13a2023|null $auslag13a
     * @param IgDrei2023|null $igDrei
     * @param Ums13b2023|null $ums13b
     * @param ErgAngUms2023|null $ergAngUms
     * @param AbzVoSt2023|null $abzVoSt
     * @param BerVoSt15a2023|null $berVoSt15a
     * @param BerechUSt2023|null $berechUSt
     * @param UN2023|null $un
     * @param FV2023|null $fv
     * @param VeranlagungVorgangTyp|null $vorgang
     * @param StringTyp|null $stNr
     * @param StringTyp|null $ordnungsbegriff
     * @param StringTyp|null $id
     * @param StringTyp|null $idEhefrau
     * @param StringTyp|null $absName
     * @param StringTyp|null $absStr
     * @param StringTyp|null $absPlz
     * @param StringTyp|null $absOrt
     * @param StringTyp|null $copyright
     * @param StringTyp|null $teleNummer
     * @param OrdNrArtTyp|null $ordNrArt
     * @param E50Rueckuebermittlung|null $rueckuebermittlung
     * @param string $bundesfinanzamtsnummer
     * @param string $datenLieferant
     */
    public function __construct(
        ?BerErkl2023 $berErkl=null,
        ?Allg2023 $allg=null,
        ?Mitwirk2023 $mitwirk=null,
        ?Kleinuntern2023 $kleinuntern=null,
        ?Umsaetze2023 $umsaetze=null,
        ?UmsStfrei2023 $umsStfrei=null,
        ?IgErw2023 $igErw=null,
        ?Auslag13a2023 $auslag13a=null,
        ?IgDrei2023 $igDrei=null,
        ?Ums13b2023 $ums13b=null,
        ?ErgAngUms2023 $ergAngUms=null,
        ?AbzVoSt2023 $abzVoSt=null,
        ?BerVoSt15a2023 $berVoSt15a=null,
        ?BerechUSt2023 $berechUSt=null,
        ?UN2023 $un=null,
        ?FV2023 $fv=null,
        ?VeranlagungVorgangTyp $vorgang=null,
        ?StringTyp $stNr=null,
        ?StringTyp $ordnungsbegriff=null,
        ?StringTyp $id=null,
        ?StringTyp $idEhefrau=null,
        ?StringTyp $absName=null,
        ?StringTyp $absStr=null,
        ?StringTyp $absPlz=null,
        ?StringTyp $absOrt=null,
        ?StringTyp $copyright=null,
        ?StringTyp $teleNummer=null,
        ?OrdNrArtTyp $ordNrArt=null,
        ?E50Rueckuebermittlung $rueckuebermittlung=null,
        string $bundesfinanzamtsnummer='',
        string $datenLieferant=''
    ) {
        parent::__construct($berErkl,$allg,$mitwirk,$kleinuntern,$umsaetze,$umsStfrei,$igErw,$auslag13a,$igDrei,$ums13b,$ergAngUms,$abzVoSt,$berVoSt15a,$berechUSt,$un,$fv,$vorgang,$stNr,$ordnungsbegriff,$id,$idEhefrau,$absName,$absStr,$absPlz,$absOrt,$copyright,$teleNummer,$ordNrArt,$rueckuebermittlung,$bundesfinanzamtsnummer,$datenLieferant);
    }

    /** @throws Exception */
    public function fromMap($o): void {
        parent::fromMap($o);
        if (isset($o['berErkl'])) $this->berErkl = JsonConverters::from('BerErkl2023', $o['berErkl']);
        if (isset($o['allg'])) $this->allg = JsonConverters::from('Allg2023', $o['allg']);
        if (isset($o['mitwirk'])) $this->mitwirk = JsonConverters::from('Mitwirk2023', $o['mitwirk']);
        if (isset($o['kleinuntern'])) $this->kleinuntern = JsonConverters::from('Kleinuntern2023', $o['kleinuntern']);
        if (isset($o['umsaetze'])) $this->umsaetze = JsonConverters::from('Umsaetze2023', $o['umsaetze']);
        if (isset($o['umsStfrei'])) $this->umsStfrei = JsonConverters::from('UmsStfrei2023', $o['umsStfrei']);
        if (isset($o['igErw'])) $this->igErw = JsonConverters::from('IgErw2023', $o['igErw']);
        if (isset($o['auslag13a'])) $this->auslag13a = JsonConverters::from('Auslag13a2023', $o['auslag13a']);
        if (isset($o['igDrei'])) $this->igDrei = JsonConverters::from('IgDrei2023', $o['igDrei']);
        if (isset($o['ums13b'])) $this->ums13b = JsonConverters::from('Ums13b2023', $o['ums13b']);
        if (isset($o['ergAngUms'])) $this->ergAngUms = JsonConverters::from('ErgAngUms2023', $o['ergAngUms']);
        if (isset($o['abzVoSt'])) $this->abzVoSt = JsonConverters::from('AbzVoSt2023', $o['abzVoSt']);
        if (isset($o['berVoSt15a'])) $this->berVoSt15a = JsonConverters::from('BerVoSt15a2023', $o['berVoSt15a']);
        if (isset($o['berechUSt'])) $this->berechUSt = JsonConverters::from('BerechUSt2023', $o['berechUSt']);
        if (isset($o['un'])) $this->un = JsonConverters::from('UN2023', $o['un']);
        if (isset($o['fv'])) $this->fv = JsonConverters::from('FV2023', $o['fv']);
        if (isset($o['vorgang'])) $this->vorgang = JsonConverters::from('VeranlagungVorgangTyp', $o['vorgang']);
        if (isset($o['stNr'])) $this->stNr = JsonConverters::from('StringTyp', $o['stNr']);
        if (isset($o['ordnungsbegriff'])) $this->ordnungsbegriff = JsonConverters::from('StringTyp', $o['ordnungsbegriff']);
        if (isset($o['id'])) $this->id = JsonConverters::from('StringTyp', $o['id']);
        if (isset($o['idEhefrau'])) $this->idEhefrau = JsonConverters::from('StringTyp', $o['idEhefrau']);
        if (isset($o['absName'])) $this->absName = JsonConverters::from('StringTyp', $o['absName']);
        if (isset($o['absStr'])) $this->absStr = JsonConverters::from('StringTyp', $o['absStr']);
        if (isset($o['absPlz'])) $this->absPlz = JsonConverters::from('StringTyp', $o['absPlz']);
        if (isset($o['absOrt'])) $this->absOrt = JsonConverters::from('StringTyp', $o['absOrt']);
        if (isset($o['copyright'])) $this->copyright = JsonConverters::from('StringTyp', $o['copyright']);
        if (isset($o['teleNummer'])) $this->teleNummer = JsonConverters::from('StringTyp', $o['teleNummer']);
        if (isset($o['ordNrArt'])) $this->ordNrArt = JsonConverters::from('OrdNrArtTyp', $o['ordNrArt']);
        if (isset($o['rueckuebermittlung'])) $this->rueckuebermittlung = JsonConverters::from('E50Rueckuebermittlung', $o['rueckuebermittlung']);
        if (isset($o['bundesfinanzamtsnummer'])) $this->bundesfinanzamtsnummer = $o['bundesfinanzamtsnummer'];
        if (isset($o['datenLieferant'])) $this->datenLieferant = $o['datenLieferant'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = parent::jsonSerialize();
        if (isset($this->berErkl)) $o['berErkl'] = JsonConverters::to('BerErkl2023', $this->berErkl);
        if (isset($this->allg)) $o['allg'] = JsonConverters::to('Allg2023', $this->allg);
        if (isset($this->mitwirk)) $o['mitwirk'] = JsonConverters::to('Mitwirk2023', $this->mitwirk);
        if (isset($this->kleinuntern)) $o['kleinuntern'] = JsonConverters::to('Kleinuntern2023', $this->kleinuntern);
        if (isset($this->umsaetze)) $o['umsaetze'] = JsonConverters::to('Umsaetze2023', $this->umsaetze);
        if (isset($this->umsStfrei)) $o['umsStfrei'] = JsonConverters::to('UmsStfrei2023', $this->umsStfrei);
        if (isset($this->igErw)) $o['igErw'] = JsonConverters::to('IgErw2023', $this->igErw);
        if (isset($this->auslag13a)) $o['auslag13a'] = JsonConverters::to('Auslag13a2023', $this->auslag13a);
        if (isset($this->igDrei)) $o['igDrei'] = JsonConverters::to('IgDrei2023', $this->igDrei);
        if (isset($this->ums13b)) $o['ums13b'] = JsonConverters::to('Ums13b2023', $this->ums13b);
        if (isset($this->ergAngUms)) $o['ergAngUms'] = JsonConverters::to('ErgAngUms2023', $this->ergAngUms);
        if (isset($this->abzVoSt)) $o['abzVoSt'] = JsonConverters::to('AbzVoSt2023', $this->abzVoSt);
        if (isset($this->berVoSt15a)) $o['berVoSt15a'] = JsonConverters::to('BerVoSt15a2023', $this->berVoSt15a);
        if (isset($this->berechUSt)) $o['berechUSt'] = JsonConverters::to('BerechUSt2023', $this->berechUSt);
        if (isset($this->un)) $o['un'] = JsonConverters::to('UN2023', $this->un);
        if (isset($this->fv)) $o['fv'] = JsonConverters::to('FV2023', $this->fv);
        if (isset($this->vorgang)) $o['vorgang'] = JsonConverters::to('VeranlagungVorgangTyp', $this->vorgang);
        if (isset($this->stNr)) $o['stNr'] = JsonConverters::to('StringTyp', $this->stNr);
        if (isset($this->ordnungsbegriff)) $o['ordnungsbegriff'] = JsonConverters::to('StringTyp', $this->ordnungsbegriff);
        if (isset($this->id)) $o['id'] = JsonConverters::to('StringTyp', $this->id);
        if (isset($this->idEhefrau)) $o['idEhefrau'] = JsonConverters::to('StringTyp', $this->idEhefrau);
        if (isset($this->absName)) $o['absName'] = JsonConverters::to('StringTyp', $this->absName);
        if (isset($this->absStr)) $o['absStr'] = JsonConverters::to('StringTyp', $this->absStr);
        if (isset($this->absPlz)) $o['absPlz'] = JsonConverters::to('StringTyp', $this->absPlz);
        if (isset($this->absOrt)) $o['absOrt'] = JsonConverters::to('StringTyp', $this->absOrt);
        if (isset($this->copyright)) $o['copyright'] = JsonConverters::to('StringTyp', $this->copyright);
        if (isset($this->teleNummer)) $o['teleNummer'] = JsonConverters::to('StringTyp', $this->teleNummer);
        if (isset($this->ordNrArt)) $o['ordNrArt'] = JsonConverters::to('OrdNrArtTyp', $this->ordNrArt);
        if (isset($this->rueckuebermittlung)) $o['rueckuebermittlung'] = JsonConverters::to('E50Rueckuebermittlung', $this->rueckuebermittlung);
        if (isset($this->bundesfinanzamtsnummer)) $o['bundesfinanzamtsnummer'] = $this->bundesfinanzamtsnummer;
        if (isset($this->datenLieferant)) $o['datenLieferant'] = $this->datenLieferant;
        return empty($o) ? new class(){} : $o;
    }
}

PHP CreateUmsatzsteuererklaerung2023Xml DTOs

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

HTTP + XML

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

POST /CreateUmsatzsteuererklaerung2023Xml HTTP/1.1 
Host: taxfiling.pwc.de 
Accept: application/xml
Content-Type: application/xml
Content-Length: length

<CreateUmsatzsteuererklaerung2023Xml xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/PwC.xEric.Core.Services.Contracts.Umsatzsteuer.Requests">
  <AbsName alias="String">String</AbsName>
  <AbsOrt alias="String">String</AbsOrt>
  <AbsPlz alias="String">String</AbsPlz>
  <AbsStr alias="String">String</AbsStr>
  <AbzVoSt>
    <Tabelle>
      <E3006201 alias="String">0,00</E3006201>
      <E3006301 alias="String">0,00</E3006301>
      <E3006401 alias="String">0,00</E3006401>
      <E3006503 alias="String">0,00</E3006503>
      <E3006502 alias="String">0,00</E3006502>
      <E3006601 alias="String">0,00</E3006601>
      <E3006701 alias="String">0,00</E3006701>
      <E3006801 alias="String">0,00</E3006801>
      <Abz_VoSt_Sum>
        <E3006901 alias="String">0,00</E3006901>
      </Abz_VoSt_Sum>
      <Erg_Ang>
        <E3007001 alias="String">0,00</E3007001>
      </Erg_Ang>
    </Tabelle>
  </AbzVoSt>
  <Allg>
    <Unternehmen>
      <E3000901 alias="String">String</E3000901>
      <E3000902 alias="String">String</E3000902>
      <E3001001 alias="String">String</E3001001>
      <Adr>
        <E3001101 alias="String">String</E3001101>
        <E3001203 alias="String">String</E3001203>
        <E3001204 alias="String">String</E3001204>
        <E3001205 alias="String">String</E3001205>
        <E3001206 alias="String">String</E3001206>
        <E3001207 alias="String">String</E3001207>
        <E3001403 alias="String">String</E3001403>
        <E3001404 alias="String">String</E3001404>
      </Adr>
      <Kontakt>
        <E3001202 alias="String">String</E3001202>
        <E3001301 alias="String">String</E3001301>
      </Kontakt>
    </Unternehmen>
    <Dauer_Unt_Eig>
      <E3001401 alias="String">01.01-01.01</E3001401>
      <E3001501 alias="String">01.01-01.01</E3001501>
    </Dauer_Unt_Eig>
    <Best_Art>
      <E3002203 alias="String">1</E3002203>
    </Best_Art>
    <Erg_Ang_Erkl>
      <E3002202 alias="String">String</E3002202>
    </Erg_Ang_Erkl>
  </Allg>
  <Auslag13a>
    <Tabelle>
      <E3102804 alias="String">0</E3102804>
      <E3102805 alias="String">0,00</E3102805>
      <Auslag_13a_Sum>
        <E3102904 alias="String">0,00</E3102904>
      </Auslag_13a_Sum>
    </Tabelle>
  </Auslag13a>
  <BerErkl>
    <E3000601 alias="String" />
  </BerErkl>
  <BerVoSt15a>
    <Grdst_erstm_Verw>
      <Ang_Grdst>
        <E3007401 alias="String">String</E3007401>
        <E3007402 alias="String">01.01.0001</E3007402>
        <E3007403 alias="String">String</E3007403>
        <E3007404 alias="String">0,00</E3007404>
        <E3007405 alias="String">0</E3007405>
        <E3007406 alias="String">0</E3007406>
      </Ang_Grdst>
    </Grdst_erstm_Verw>
    <Grund_Aend_Verh>
      <Nutz_aend>
        <E3008402 alias="String">String</E3008402>
      </Nutz_aend>
    </Grund_Aend_Verh>
    <VoSt_Ber_Betr>
      <Tabelle>
        <E3008701 alias="String">0,00</E3008701>
        <E3008702 alias="String">0,00</E3008702>
        <E3008801 alias="String">0,00</E3008801>
        <E3008802 alias="String">0,00</E3008802>
        <E3008803 alias="String">0,00</E3008803>
        <E3008804 alias="String">0,00</E3008804>
        <VoSt_Ber_Betr_Sum>
          <E3008901 alias="String">0,00</E3008901>
          <E3008902 alias="String">0,00</E3008902>
        </VoSt_Ber_Betr_Sum>
      </Tabelle>
    </VoSt_Ber_Betr>
  </BerVoSt15a>
  <BerechUSt>
    <Tabelle>
      <E3009201 alias="String">0,00</E3009201>
      <E3009401 alias="String">0,00</E3009401>
      <E3009602 alias="String">0,00</E3009602>
      <E3009501 alias="String">0,00</E3009501>
      <E3009502 alias="String">0,00</E3009502>
      <E3009801 alias="String">0,00</E3009801>
      <E3009901 alias="String">0,00</E3009901>
      <E3010001 alias="String">0,00</E3010001>
      <E3010201 alias="String">0,00</E3010201>
      <E3009701 alias="String">0,00</E3009701>
      <E3010301 alias="String">0,00</E3010301>
      <E3010401 alias="String">0,00</E3010401>
      <E3010501 alias="String">0,00</E3010501>
      <E3010601 alias="String">0,00</E3010601>
      <E3010602 alias="String">0,00</E3010602>
      <Verbl_USt>
        <E3011101 alias="String">0,00</E3011101>
        <E3011301 alias="String">0,00</E3011301>
      </Verbl_USt>
      <Zahl_Erstatt>
        <E3011401 alias="String">0,00</E3011401>
      </Zahl_Erstatt>
    </Tabelle>
  </BerechUSt>
  <Bundesfinanzamtsnummer>String</Bundesfinanzamtsnummer>
  <Copyright alias="String">String</Copyright>
  <DatenLieferant>String</DatenLieferant>
  <ErgAngUms>
    <Tabelle>
      <E3105201 alias="String">0</E3105201>
      <E3105301 alias="String">0</E3105301>
      <E3105101 alias="String">0</E3105101>
      <E3105102 alias="String">0</E3105102>
      <E3105602 alias="String">0</E3105602>
      <E3105702 alias="String">0</E3105702>
      <E3105801 alias="String">0</E3105801>
      <E3105901 alias="String">0</E3105901>
      <E3106001 alias="String">0</E3106001>
      <E3106101 alias="String">0</E3106101>
    </Tabelle>
  </ErgAngUms>
  <Fv>
    <Aufst_aller_vertr_Unt>
      <Einz>
        <E3300201 alias="String">String</E3300201>
        <E3300202 alias="String">String</E3300202>
        <E3300203 alias="String">String</E3300203>
        <E3300204 alias="String">0</E3300204>
      </Einz>
      <Sum>
        <E3300301 alias="String">0</E3300301>
      </Sum>
    </Aufst_aller_vertr_Unt>
  </Fv>
  <ID alias="String">String</ID>
  <IDEhefrau alias="String">String</IDEhefrau>
  <IgDrei>
    <Tabelle>
      <Lfg_erst_Abn>
        <E3101801 alias="String">0</E3101801>
      </Lfg_erst_Abn>
      <Lfg_letzt_Abn>
        <E3101701 alias="String">0</E3101701>
        <E3101702 alias="String">0,00</E3101702>
        <E3102301 alias="String">0</E3102301>
        <E3102302 alias="String">0,00</E3102302>
        <E3102305 alias="String">0</E3102305>
        <E3102303 alias="String">0</E3102303>
        <E3102304 alias="String">0,00</E3102304>
      </Lfg_letzt_Abn>
      <Ig_Drei_Sum>
        <E3102401 alias="String">0,00</E3102401>
      </Ig_Drei_Sum>
    </Tabelle>
  </IgDrei>
  <IgErw>
    <Tabelle>
      <Stfrei>
        <E3100901 alias="String">0</E3100901>
      </Stfrei>
      <Stpfl>
        <E3100902 alias="String">0</E3100902>
        <E3100903 alias="String">0,00</E3100903>
        <E3101301 alias="String">0</E3101301>
        <E3101302 alias="String">0,00</E3101302>
        <E3101305 alias="String">0</E3101305>
        <E3101303 alias="String">0</E3101303>
        <E3101304 alias="String">0,00</E3101304>
        <E3101401 alias="String">0</E3101401>
        <E3101402 alias="String">0,00</E3101402>
      </Stpfl>
      <Ig_Erw_Sum>
        <E3101501 alias="String">0,00</E3101501>
      </Ig_Erw_Sum>
    </Tabelle>
  </IgErw>
  <Kleinuntern>
    <Tabelle>
      <E3002301 alias="String">0</E3002301>
      <E3002401 alias="String">0</E3002401>
    </Tabelle>
  </Kleinuntern>
  <Mitwirk>
    <Kanzlei>
      <E3002509 alias="String">String</E3002509>
      <E3002506 alias="String">String</E3002506>
      <E3002507 alias="String">String</E3002507>
    </Kanzlei>
    <Bearb>
      <E3002501 alias="String">String</E3002501>
      <E3002502 alias="String">String</E3002502>
    </Bearb>
    <Adr>
      <E3002503 alias="String">String</E3002503>
      <E3002504 alias="String">String</E3002504>
    </Adr>
    <Kontakt>
      <E3002505 alias="String">String</E3002505>
      <E3002508 alias="String">String</E3002508>
    </Kontakt>
  </Mitwirk>
  <OrdNrArt alias="String">S</OrdNrArt>
  <Ordnungsbegriff alias="String">String</Ordnungsbegriff>
  <Rueckuebermittlung>
    <Bescheid alias="String">2</Bescheid>
    <ArtRueckuebermittlung alias="String">String</ArtRueckuebermittlung>
    <SchluesselRueckuebermittlung alias="String">String</SchluesselRueckuebermittlung>
    <AdresseRueckuebermittlung alias="String">String</AdresseRueckuebermittlung>
  </Rueckuebermittlung>
  <StNr alias="String">String</StNr>
  <TeleNummer alias="String">String</TeleNummer>
  <Ums13b>
    <Tabelle>
      <E3102205 alias="String">0</E3102205>
      <E3102206 alias="String">0,00</E3102206>
      <E3102307 alias="String">0</E3102307>
      <E3102308 alias="String">0,00</E3102308>
      <E3102503 alias="String">0</E3102503>
      <E3102504 alias="String">0,00</E3102504>
      <Ums_13b_Sum>
        <E3102601 alias="String">0,00</E3102601>
      </Ums_13b_Sum>
    </Tabelle>
  </Ums13b>
  <UmsStfrei>
    <Tabelle>
      <Mit_VoSt_Abz>
        <Ig_Lfg>
          <E3103301 alias="String">0</E3103301>
          <E3103401 alias="String">0</E3103401>
          <E3103501 alias="String">0</E3103501>
        </Ig_Lfg>
        <Ums_stfrei_weit>
          <E3103801 alias="String">0</E3103801>
          <E3103901 alias="String">String</E3103901>
          <E3103902 alias="String">0</E3103902>
          <E3104001 alias="String">0</E3104001>
          <E3104101 alias="String">0</E3104101>
          <E3104201 alias="String">0</E3104201>
        </Ums_stfrei_weit>
      </Mit_VoSt_Abz>
      <Ohne_VoSt_Abz>
        <Nicht_Ges_Ums>
          <E3104401 alias="String">0</E3104401>
          <E3104501 alias="String">String</E3104501>
          <E3104502 alias="String">0</E3104502>
          <E3104601 alias="String">0</E3104601>
        </Nicht_Ges_Ums>
        <Ges_Ums>
          <E3104901 alias="String">String</E3104901>
          <E3104902 alias="String">0</E3104902>
        </Ges_Ums>
      </Ohne_VoSt_Abz>
    </Tabelle>
  </UmsStfrei>
  <Umsaetze>
    <Tabelle>
      <Ums_allg>
        <E3003303 alias="String">0</E3003303>
        <E3003304 alias="String">0,00</E3003304>
        <Unent_Wertabgaben>
          <E3003405 alias="String">0</E3003405>
          <E3003406 alias="String">0,00</E3003406>
          <E3003505 alias="String">0</E3003505>
          <E3003506 alias="String">0,00</E3003506>
        </Unent_Wertabgaben>
      </Ums_allg>
      <Ums_erm>
        <E3004401 alias="String">0</E3004401>
        <E3004402 alias="String">0,00</E3004402>
        <Unent_Wertabgaben>
          <E3003703 alias="String">0</E3003703>
          <E3003704 alias="String">0,00</E3003704>
          <E3003803 alias="String">0</E3003803>
          <E3003804 alias="String">0,00</E3003804>
        </Unent_Wertabgaben>
      </Ums_erm>
      <Ums_and>
        <E3005001 alias="String">0</E3005001>
        <E3005002 alias="String">0,00</E3005002>
      </Ums_and>
      <Ums_LuF>
        <E3005201 alias="String">0</E3005201>
        <E3005005 alias="String">0</E3005005>
        <E3005006 alias="String">0,00</E3005006>
        <E3005801 alias="String">0</E3005801>
      </Ums_LuF>
      <Wechs_Best_form>
        <E3102901 alias="String">0,00</E3102901>
      </Wechs_Best_form>
      <Wechs_St_satz_Aend>
        <E3005901 alias="String">0,00</E3005901>
      </Wechs_St_satz_Aend>
      <Ums_Sum>
        <E3006001 alias="String">0,00</E3006001>
      </Ums_Sum>
    </Tabelle>
  </Umsaetze>
  <Un>
    <Allg>
      <Bank>
        <E3201001 alias="String">String</E3201001>
        <E3201002 alias="String">String</E3201002>
        <E3200901 alias="String">String</E3200901>
        <E3200902 alias="String">String</E3200902>
        <E3200905 alias="String">String</E3200905>
      </Bank>
      <Vollm>
        <E3201501 alias="String">String</E3201501>
        <E3201601 alias="String">String</E3201601>
        <E3201302 alias="String">String</E3201302>
        <E3201303 alias="String">String</E3201303>
        <E3201304 alias="String">String</E3201304>
        <E3201403 alias="String">String</E3201403>
        <E3201404 alias="String">String</E3201404>
        <E3201503 alias="String">String</E3201503>
        <E3201504 alias="String">String</E3201504>
        <Kontakt>
          <E3201602 alias="String">String</E3201602>
          <E3201502 alias="String">String</E3201502>
        </Kontakt>
      </Vollm>
    </Allg>
    <VoSt_Verguet_BZSt>
      <E3201101 alias="String">2</E3201101>
    </VoSt_Verguet_BZSt>
    <Anrech_Betr>
      <E3201902 alias="String">0,00</E3201902>
      <E3202002 alias="String">0,00</E3202002>
      <E3202102 alias="String">0,00</E3202102>
    </Anrech_Betr>
    <Erg_Ang_Ums>
      <Tabelle>
        <In_stpfl_Ums_ent>
          <E3201901 alias="String">0</E3201901>
        </In_stpfl_Ums_ent>
      </Tabelle>
    </Erg_Ang_Ums>
  </Un>
  <Vorgang alias="String">01</Vorgang>
</CreateUmsatzsteuererklaerung2023Xml>
HTTP/1.1 200 OK
Content-Type: application/xml
Content-Length: length

<XmlResponse xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/PwC.xEric.Core.Services.Contracts.Responses">
  <Content>String</Content>
  <ResponseStatus xmlns:d2p1="http://schemas.servicestack.net/types">
    <d2p1:ErrorCode>String</d2p1:ErrorCode>
    <d2p1:Message>String</d2p1:Message>
    <d2p1:StackTrace>String</d2p1:StackTrace>
    <d2p1:Errors>
      <d2p1:ResponseError>
        <d2p1:ErrorCode>String</d2p1:ErrorCode>
        <d2p1:FieldName>String</d2p1:FieldName>
        <d2p1:Message>String</d2p1:Message>
        <d2p1:Meta xmlns:d5p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
          <d5p1:KeyValueOfstringstring>
            <d5p1:Key>String</d5p1:Key>
            <d5p1:Value>String</d5p1:Value>
          </d5p1:KeyValueOfstringstring>
        </d2p1:Meta>
      </d2p1:ResponseError>
    </d2p1:Errors>
    <d2p1:Meta xmlns:d3p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
      <d3p1:KeyValueOfstringstring>
        <d3p1:Key>String</d3p1:Key>
        <d3p1:Value>String</d3p1:Value>
      </d3p1:KeyValueOfstringstring>
    </d2p1:Meta>
  </ResponseStatus>
</XmlResponse>