/* Options: Date: 2025-02-21 11:19:08 SwiftVersion: 6.0 Version: 8.52 Tip: To override a DTO option, remove "//" prefix before updating BaseUrl: https://taxfiling.staging.pwc.de //BaseClass: //AddModelExtensions: True //AddServiceStackTypes: True //MakePropertiesOptional: True IncludeTypes: SubmitUStVa2021AsTaxConsultant.* //ExcludeTypes: //ExcludeGenericBaseTypes: False //AddResponseStatus: False //AddImplicitVersion: //AddDescriptionAsComments: True //InitializeCollections: False //TreatTypesAsStrings: //DefaultImports: Foundation,ServiceStack */ import Foundation import ServiceStack /** * A synchronous service to create XML content that represents the preliminary VAT return (Umsatzsteuervoranmeldung) as a tax consultant for 2021. */ // @Route("/SubmitUStVa2021AsTaxConsultant", "POST") // @Api(Description="A synchronous service to create XML content that represents the preliminary VAT return (Umsatzsteuervoranmeldung) as a tax consultant for 2021.") public class SubmitUStVa2021AsTaxConsultant : SubmitUStVa2021AsTaxConsultantBase, IReturn { public typealias Return = BearbeiteVorgangResponse required public init(){ super.init() } required public init(from decoder: Decoder) throws { try super.init(from: decoder) } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) } } /** * A type that encapsulates the return values from the ERiC API function that processes tax data. */ // @Api(Description="A type that encapsulates the return values from the ERiC API function that processes tax data.") public class BearbeiteVorgangResponse : EricFehlerCodeResponse { /** * The return value of the process. */ // @ApiMember(Description="The return value of the process.") public var rueckgabe:EricBearbeiteVorgang? /** * The server response of the process. */ // @ApiMember(Description="The server response of the process.") public var serverantwort:Elster? /** * If available, the PDF-based files to represent generated transfer prototocols. */ // @ApiMember(Description="If available, the PDF-based files to represent generated transfer prototocols.") public var transferProtocols:[BinaryFile] = [] required public init(){ super.init() } private enum CodingKeys : String, CodingKey { case rueckgabe case serverantwort case transferProtocols } required public init(from decoder: Decoder) throws { try super.init(from: decoder) let container = try decoder.container(keyedBy: CodingKeys.self) rueckgabe = try container.decodeIfPresent(EricBearbeiteVorgang.self, forKey: .rueckgabe) serverantwort = try container.decodeIfPresent(Elster.self, forKey: .serverantwort) transferProtocols = try container.decodeIfPresent([BinaryFile].self, forKey: .transferProtocols) ?? [] } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) var container = encoder.container(keyedBy: CodingKeys.self) if rueckgabe != nil { try container.encode(rueckgabe, forKey: .rueckgabe) } if serverantwort != nil { try container.encode(serverantwort, forKey: .serverantwort) } if transferProtocols.count > 0 { try container.encode(transferProtocols, forKey: .transferProtocols) } } } public protocol IDruckRequest { var duplexDruck:Bool? { get set } var protocolPrefix:String? { get set } var fussText:String? { get set } } /** * Represents a portal certificate that is protected by a password. */ // @Api(Description="Represents a portal certificate that is protected by a password.") public class PortalCertificate : FileBase, ISecuredCertificate { /** * The file name of the certificate. */ // @ApiMember(Description="The file name of the certificate.") // @StringLength(128) public var name:String? /** * The password to protect the certificate from unauthorized access. */ // @StringLength(255) // @ApiMember(Description="The password to protect the certificate from unauthorized access.") public var pin:String? /** * The description of the certificate. */ // @StringLength(Int32.max) // @ApiMember(Description="The description of the certificate.") public var Description:String? /** * Tags that can be used to label or identify the certificate. */ // @ApiMember(Description="Tags that can be used to label or identify the certificate.") public var tags:[String] = [] required public init(){ super.init() } private enum CodingKeys : String, CodingKey { case name case pin case Description case tags } required public init(from decoder: Decoder) throws { try super.init(from: decoder) let container = try decoder.container(keyedBy: CodingKeys.self) name = try container.decodeIfPresent(String.self, forKey: .name) pin = try container.decodeIfPresent(String.self, forKey: .pin) Description = try container.decodeIfPresent(String.self, forKey: .Description) tags = try container.decodeIfPresent([String].self, forKey: .tags) ?? [] } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) var container = encoder.container(keyedBy: CodingKeys.self) if name != nil { try container.encode(name, forKey: .name) } if pin != nil { try container.encode(pin, forKey: .pin) } if Description != nil { try container.encode(Description, forKey: .Description) } if tags.count > 0 { try container.encode(tags, forKey: .tags) } } } public protocol IVeschlueselungsRequest { var zertifikat:PortalCertificate? { get set } } /** * Beim DatenLieferanten handelt es sich um diejenige natürliche Person, welche die Software bedient, bzw. in deren Namen die Software bedient wird,um die Daten zu übersenden (auf den Sendeknopf drückt - NICHT jedoch ein etwaiger Erfüllungsgehilfe). */ // @Api(Description="Beim DatenLieferanten handelt es sich um diejenige natürliche Person, welche die Software bedient, bzw. in deren Namen die Software bedient wird,um die Daten zu übersenden (auf den Sendeknopf drückt - NICHT jedoch ein etwaiger Erfüllungsgehilfe).") public class DatenLieferant : Codable { /** * Der Name des Datenlieferants. */ // @ApiMember(Description="Der Name des Datenlieferants.") public var name:String? /** * Der Straßenname des Datenlieferants. */ // @ApiMember(Description="Der Straßenname des Datenlieferants.") public var strasse:String? /** * Die Postleitzahl des Datenlieferants. */ // @ApiMember(Description="Die Postleitzahl des Datenlieferants.") public var plz:String? /** * Der Ort des Datenlieferants. */ // @ApiMember(Description="Der Ort des Datenlieferants.") public var ort:String? /** * Die Telefonnummer (optional) des Datenlieferants. */ // @ApiMember(Description="Die Telefonnummer (optional) des Datenlieferants.") public var telefon:String? /** * Die Email-Adresse (optional) des Datenlieferant. */ // @ApiMember(Description="Die Email-Adresse (optional) des Datenlieferant.") public var email:String? required public init(){} } /** * Stellt einen Steuerberater dar. */ // @Api(Description="Stellt einen Steuerberater dar.") public class Berater : Codable { /** * Der Bezeichnung (optional) des Beraters (normalerweise der Name des Beraters Unternehmen). */ // @ApiMember(Description="Der Bezeichnung (optional) des Beraters (normalerweise der Name des Beraters Unternehmen).") public var bezeichnung:String? /** * Der Name (optional) des Beraters. */ // @ApiMember(Description="Der Name (optional) des Beraters.") public var name:String? /** * Der Vorname (optional) des Beraters. */ // @ApiMember(Description="Der Vorname (optional) des Beraters.") public var vorname:String? /** * Der Namenvorsatz (optional) des Beraters. */ // @ApiMember(Description="Der Namenvorsatz (optional) des Beraters.") public var namensvorsatz:String? /** * Der Namenzusatz (optional) des Beraters. */ // @ApiMember(Description="Der Namenzusatz (optional) des Beraters.") public var namenszusatz:String? /** * Der Straßenname (optional) des Beraters. */ // @ApiMember(Description="Der Straßenname (optional) des Beraters.") public var str:String? /** * Die Hausnummer (optional) des Beraters. */ // @ApiMember(Description="Die Hausnummer (optional) des Beraters.") public var hausnummer:String? /** * Der Hausnummernzusatz (optional) des Beraters. */ // @ApiMember(Description="Der Hausnummernzusatz (optional) des Beraters.") public var hNrZusatz:String? /** * Der Anschriftenzusatz (optional) des Beraters. */ // @ApiMember(Description="Der Anschriftenzusatz (optional) des Beraters.") public var anschriftenZusatz:String? /** * Der Ort (optional) des Beraters. */ // @ApiMember(Description="Der Ort (optional) des Beraters.") public var ort:String? /** * Die Postleitzahl (optional) des Beraters. */ // @ApiMember(Description="Die Postleitzahl (optional) des Beraters.") public var plz:String? /** * Die Auslandspostleitzahl (optional) des Beraters. */ // @ApiMember(Description="Die Auslandspostleitzahl (optional) des Beraters.") public var auslandsPLZ:String? /** * Der Ländername (falls Anschrift im Ausland) des Beraters - optional. Der Ländername des Beraters kann mit 1-20 alphanumerischen Zeichen geliefert werden. */ // @ApiMember(Description="Der Ländername (falls Anschrift im Ausland) des Beraters - optional. \nDer Ländername des Beraters kann mit 1-20 alphanumerischen Zeichen geliefert werden.") public var land:String? /** * Der Ort des Postfaches (optional) des Beraters. */ // @ApiMember(Description="Der Ort des Postfaches (optional) des Beraters.") public var postfachOrt:String? /** * Das Postfach (optional) des Beraters. */ // @ApiMember(Description="Das Postfach (optional) des Beraters.") public var postfach:String? /** * Die Postleitzahl (optional) des Beraters. */ // @ApiMember(Description="Die Postleitzahl (optional) des Beraters.") public var postfachPLZ:String? /** * Die Großkundenpostleitzahl (optional) des Beraters. */ // @ApiMember(Description="Die Großkundenpostleitzahl (optional) des Beraters.") public var gkplz:String? /** * Die Telefonnummer (optional) des Beraters. */ // @ApiMember(Description="Die Telefonnummer (optional) des Beraters.") public var telefon:String? /** * Die Emailadresse (optional) des Beraters. */ // @ApiMember(Description="Die Emailadresse (optional) des Beraters.") public var email:String? required public init(){} } /** * Stellt einen Mandant dar. */ // @Api(Description="Stellt einen Mandant dar.") public class Mandant : Codable { /** * Der Name (optional) des Mandanten. */ // @ApiMember(Description="Der Name (optional) des Mandanten.") public var name:String? /** * Der Vorname (optional) des Mandanten. */ // @ApiMember(Description="Der Vorname (optional) des Mandanten.") public var vorname:String? /** * Die Mandantennummer (optional) des Mandanten. */ // @ApiMember(Description="Die Mandantennummer (optional) des Mandanten.") public var mandantenNr:String? /** * Das Bearbeiterkennzeichen (optional) des Mandanten. */ // @ApiMember(Description="Das Bearbeiterkennzeichen (optional) des Mandanten.") public var bearbeiterkennzeichen:String? required public init(){} } /** * Umsatzsteuervoranmeldung für 2021 (Preliminary VAT declaration for 2021). */ // @Api(Description="Umsatzsteuervoranmeldung für 2021 (Preliminary VAT declaration for 2021).") public class Umsatzsteuervoranmeldung2021 : Codable { /** * Das Jahr der Veranlagung. */ // @ApiMember(Description="Das Jahr der Veranlagung.", IsRequired=true) public var jahr:Int? /** * Anmeldungszeitraum. */ // @ApiMember(Description="Anmeldungszeitraum.") public var zeitraum:AnmeldungZeitraum? /** * Steuernummer */ // @ApiMember(Description="Steuernummer") public var steuernummer:String? /** * Pflichtkennzahl, welche die Angabe diverser Informationen ermöglicht. */ // @ApiMember(Description="Pflichtkennzahl, welche die Angabe diverser Informationen ermöglicht.", IsRequired=true) public var kz09:Kz09? /** * Berichtigte Anmeldung */ // @ApiMember(Description="Berichtigte Anmeldung") public var kz10:Ganzzahl1EN? /** * Nicht steuerbare sonstige Leistungen gemäß § 18b Satz 1 Nummer 2 UStG */ // @ApiMember(Description="Nicht steuerbare sonstige Leistungen gemäß § 18b Satz 1 Nummer 2 UStG") public var kz21:GeldBetragOhneCent13EN? /** * Belege */ // @ApiMember(Description="Belege") public var kz22:Ganzzahl1EN? /** * Über die Angaben in der Steueranmeldung hinaus sind weitere oder abweichende Angaben oder Sachverhalte zu berücksichtigen */ // @ApiMember(Description="Über die Angaben in der Steueranmeldung hinaus sind weitere oder abweichende Angaben oder Sachverhalte zu berücksichtigen") public var kz23:Ganzzahl1EN? /** * Ergänzende Angaben zur Steueranmeldung */ // @ApiMember(Description="Ergänzende Angaben zur Steueranmeldung") public var kz23_Begruendung:String? /** * Das SEPA-Lastschriftmandat wird ausnahmsweise (zum Beispiel wegen Verrechnungswünschen) für diesen Voranmeldungszeitraum widerrufen (falls ja, bitte eine 1 eintragen). Ein gegebenenfalls verbleibender Restbetrag ist gesondert zu entrichten. */ // @ApiMember(Description="Das SEPA-Lastschriftmandat wird ausnahmsweise (zum Beispiel wegen Verrechnungswünschen) für diesen Voranmeldungszeitraum widerrufen (falls ja, bitte eine 1 eintragen). Ein gegebenenfalls verbleibender Restbetrag ist gesondert zu entrichten.") public var kz26:Ganzzahl1EN? /** * Verrechnung des Erstattungsbetrags erwünscht / Erstattungsbetrag ist abgetreten (falls ja, bitte eine 1 eintragen). */ // @ApiMember(Description="Verrechnung des Erstattungsbetrags erwünscht / Erstattungsbetrag ist abgetreten (falls ja, bitte eine 1 eintragen).") public var kz29:Ganzzahl1EN? /** * zu anderen Steuersätzen (Bemessungsgrundlage) */ // @ApiMember(Description="zu anderen Steuersätzen (Bemessungsgrundlage)") public var kz35:GeldBetragOhneCent13EN? /** * zu anderen Steuersätzen (Steuer) */ // @ApiMember(Description="zu anderen Steuersätzen (Steuer)") public var kz36:GeldBetragMitCent11EN? /** * Minderung der abziehbaren Vorsteuerbeträge (in der Zeile 55 aus Rechnungen von anderen Unternehmen (§ 15 Absatz 1 Satz 1 Nummer 1 UStG) sowie in den Zeilen 59 und 60 enthalten) */ // @ApiMember(Description="Minderung der abziehbaren Vorsteuerbeträge (in der Zeile 55 aus Rechnungen von anderen Unternehmen (§ 15 Absatz 1 Satz 1 Nummer 1 UStG) sowie in den Zeilen 59 und 60 enthalten)") public var kz37:PositiverGeldBetragMitCent11EN? /** * Abzug der festgesetzten Sondervorauszahlung für Dauerfristverlängerung (in der Regel nur in der letzten Voranmeldung des Besteuerungszeitraums auszufüllen) */ // @ApiMember(Description="Abzug der festgesetzten Sondervorauszahlung für Dauerfristverlängerung (in der Regel nur in der letzten Voranmeldung des Besteuerungszeitraums auszufüllen)") public var kz39:PositiverGeldBetragMitCent13EN? /** * Innergemeinschaftliche Lieferungen (§ 4 Nummer 1 Buchstabe b UStG) an Abnehmer mit Umsatzsteuer-Identifikationsnummer */ // @ApiMember(Description="Innergemeinschaftliche Lieferungen (§ 4 Nummer 1 Buchstabe b UStG) an Abnehmer mit Umsatzsteuer-Identifikationsnummer") public var kz41:GeldBetragOhneCent13EN? /** * Lieferungen des ersten Abnehmers bei innergemeinschaftlichen Dreiecksgeschäften (§ 25b UStG) */ // @ApiMember(Description="Lieferungen des ersten Abnehmers bei innergemeinschaftlichen Dreiecksgeschäften (§ 25b UStG)") public var kz42:GeldBetragOhneCent13EN? /** * Weitere steuerfreie Umsätze mit Vorsteuerabzug (zum Beispiel Ausfuhrlieferungen, Umsätze nach § 4 Nummer 2 bis 7 UStG) */ // @ApiMember(Description="Weitere steuerfreie Umsätze mit Vorsteuerabzug (zum Beispiel Ausfuhrlieferungen, Umsätze nach § 4 Nummer 2 bis 7 UStG)") public var kz43:GeldBetragOhneCent13EN? /** * Innergemeinschaftliche Lieferungen (§ 4 Nummer 1 Buchstabe b UStG) neuer Fahrzeuge an Abnehmer ohne Umsatzsteuer-Identifikationsnummer */ // @ApiMember(Description="Innergemeinschaftliche Lieferungen (§ 4 Nummer 1 Buchstabe b UStG) neuer Fahrzeuge an Abnehmer ohne Umsatzsteuer-Identifikationsnummer") public var kz44:GeldBetragOhneCent13EN? /** * Übrige nicht steuerbare Umsätze (Leistungsort nicht im Inland) */ // @ApiMember(Description="Übrige nicht steuerbare Umsätze (Leistungsort nicht im Inland)") public var kz45:GeldBetragOhneCent13EN? /** * Sonstige Leistungen nach § 3a Absatz 2 UStG eines im übrigen Gemeinschaftsgebiet ansässigen Unternehmers (§ 13b Absatz 1 UStG) (Bemessungsgrundlage) */ // @ApiMember(Description="Sonstige Leistungen nach § 3a Absatz 2 UStG eines im übrigen Gemeinschaftsgebiet ansässigen Unternehmers (§ 13b Absatz 1 UStG) (Bemessungsgrundlage)") public var kz46:GeldBetragOhneCent13EN? /** * Sonstige Leistungen nach § 3a Absatz 2 UStG eines im übrigen Gemeinschaftsgebiet ansässigen Unternehmers (§ 13b Absatz 1 UStG) (Steuer) */ // @ApiMember(Description="Sonstige Leistungen nach § 3a Absatz 2 UStG eines im übrigen Gemeinschaftsgebiet ansässigen Unternehmers (§ 13b Absatz 1 UStG) (Steuer)") public var kz47:GeldBetragMitCent11EN? /** * Steuerfreie Umsätze ohne Vorsteuerabzug (zum Beispiel Umsätze nach § 4 Nummer 8 bis 29 UStG) */ // @ApiMember(Description="Steuerfreie Umsätze ohne Vorsteuerabzug (zum Beispiel Umsätze nach § 4 Nummer 8 bis 29 UStG)") public var kz48:GeldBetragOhneCent13EN? /** * Innergemeinschaftliche Lieferungen (§ 4 Nummer 1 Buchstabe b UStG) neuer Fahrzeuge außerhalb eines Unternehmens (§ 2a UStG) */ // @ApiMember(Description="Innergemeinschaftliche Lieferungen (§ 4 Nummer 1 Buchstabe b UStG) neuer Fahrzeuge außerhalb eines Unternehmens (§ 2a UStG)") public var kz49:GeldBetragOhneCent13EN? /** * Minderung der Bemessungsgrundlage (in den Zeilen 20 bis 24 enthalten) */ // @ApiMember(Description="Minderung der Bemessungsgrundlage (in den Zeilen 20 bis 24 enthalten)") public var kz50:PositiverGeldBetragOhneCent13EN? /** * 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)") public var kz59:GeldBetragMitCent11EN? /** * Steuerpflichtige Umsätze des leistenden Unternehmers, für die der Leistungsempfänger die Steuer nach § 13b Absatz 5 UStG schuldet */ // @ApiMember(Description="Steuerpflichtige Umsätze des leistenden Unternehmers, für die der Leistungsempfänger die Steuer nach § 13b Absatz 5 UStG schuldet") public var kz60:GeldBetragOhneCent13EN? /** * Vorsteuerbeträge aus dem innergemeinschaftlichen Erwerb von Gegenständen (§ 15 Absatz 1 Satz 1 Nummer 3 UStG) */ // @ApiMember(Description="Vorsteuerbeträge aus dem innergemeinschaftlichen Erwerb von Gegenständen (§ 15 Absatz 1 Satz 1 Nummer 3 UStG)") public var kz61:GeldBetragMitCent11EN? /** * Entstandene Einfuhrumsatzsteuer (§ 15 Absatz 1 Satz 1 Nummer 2 UStG)) */ // @ApiMember(Description="Entstandene Einfuhrumsatzsteuer (§ 15 Absatz 1 Satz 1 Nummer 2 UStG))") public var kz62:GeldBetragMitCent11EN? /** * Vorsteuerbeträge, die nach allgemeinen Durchschnittssätzen berechnet sind (§§ 23 und 23a UStG) */ // @ApiMember(Description="Vorsteuerbeträge, die nach allgemeinen Durchschnittssätzen berechnet sind (§§ 23 und 23a UStG)") public var kz63:GeldBetragMitCent11EN? /** * Berichtigung des Vorsteuerabzugs (§ 15a UStG) */ // @ApiMember(Description="Berichtigung des Vorsteuerabzugs (§ 15a UStG)") public var kz64:GeldBetragMitCent11EN? /** * Steuer infolge des Wechsels der Besteuerungsform sowie Nachsteuer auf versteuerte Anzahlungen und ähnlichem wegen Steuersatzänderung */ // @ApiMember(Description="Steuer infolge des Wechsels der Besteuerungsform sowie Nachsteuer auf versteuerte Anzahlungen und ähnlichem wegen Steuersatzänderung") public var kz65:GeldBetragMitCent11EN? /** * Vorsteuerbeträge aus Rechnungen von anderen Unternehmern (§ 15 Absatz 1 Satz 1 Nummer 1 UStG), aus Leistungen im Sinne des § 13a Absatz 1 Nummer 6 UStG (§ 15 Absatz 1 Satz 1 Nummer 5 UStG) und aus innergemeinschaftlichen Dreiecksgeschäften (§ 25b Absatz 5 UStG) */ // @ApiMember(Description="Vorsteuerbeträge aus Rechnungen von anderen Unternehmern (§ 15 Absatz 1 Satz 1 Nummer 1 UStG), aus Leistungen im Sinne des § 13a Absatz 1 Nummer 6 UStG (§ 15 Absatz 1 Satz 1 Nummer 5 UStG) und aus innergemeinschaftlichen Dreiecksgeschäften (§ 25b Absatz 5 UStG)") public var kz66:GeldBetragMitCent11EN? /** * 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)") public var kz67:GeldBetragMitCent11EN? /** * In Rechnungen unrichtig oder unberechtigt ausgewiesene Steuerbeträge (§ 14c UStG) sowie Steuerbeträge, die nach § 6a Absatz 4 Satz 2, § 17 Absatz 1 Satz 7, § 25b Absatz 2 UStG oder von einem Auslagerer oder Lagerhalter nach § 13a Absatz 1 Nummer 6 UStG geschuldet werden */ // @ApiMember(Description="In Rechnungen unrichtig oder unberechtigt ausgewiesene Steuerbeträge (§ 14c UStG) sowie Steuerbeträge, die nach § 6a Absatz 4 Satz 2, § 17 Absatz 1 Satz 7, § 25b Absatz 2 UStG oder von einem Auslagerer oder Lagerhalter nach § 13a Absatz 1 Nummer 6 UStG geschuldet werden") public var kz69:GeldBetragMitCent11EN? /** * Umsätze, die unter das GrEStG fallen (§ 13b Absatz 2 Nummer 3 UStG) (Bemessungsgrundlage) */ // @ApiMember(Description="Umsätze, die unter das GrEStG fallen (§ 13b Absatz 2 Nummer 3 UStG) (Bemessungsgrundlage)") public var kz73:GeldBetragOhneCent13EN? /** * 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)") public var kz74:GeldBetragMitCent11EN? /** * Umsätze, für die eine Steuer nach § 24 UStG zu entrichten ist (Sägewerkserzeugnisse, Getränke und alkoholische Flüssigkeiten, zum Beispiel Wein) (Bemessungsgrundlage) */ // @ApiMember(Description="Umsätze, für die eine Steuer nach § 24 UStG zu entrichten ist (Sägewerkserzeugnisse, Getränke und alkoholische Flüssigkeiten, zum Beispiel Wein) (Bemessungsgrundlage)") public var kz76:GeldBetragOhneCent13EN? /** * Lieferungen land- und forstwirtschaftlicher Betriebe nach § 24 UStG an Abnehmer mit Umsatzsteuer-Identifikationsnummer */ // @ApiMember(Description="Lieferungen land- und forstwirtschaftlicher Betriebe nach § 24 UStG an Abnehmer mit Umsatzsteuer-Identifikationsnummer") public var kz77:GeldBetragOhneCent13EN? /** * Umsätze, für die eine Steuer nach § 24 UStG zu entrichten ist (Sägewerkserzeugnisse, Getränke und alkoholische Flüssigkeiten, zum Beispiel Wein) (Steuer) */ // @ApiMember(Description="Umsätze, für die eine Steuer nach § 24 UStG zu entrichten ist (Sägewerkserzeugnisse, Getränke und alkoholische Flüssigkeiten, zum Beispiel Wein) (Steuer)") public var kz80:GeldBetragMitCent11EN? /** * zum Steuersatz von 19 Prozent */ // @ApiMember(Description="zum Steuersatz von 19 Prozent") public var kz81:GeldBetragOhneCent13EN? /** * Verbleibende Umsatzsteuer-Vorauszahlung beziehungsweise verbleibender Überschuss */ // @ApiMember(Description="Verbleibende Umsatzsteuer-Vorauszahlung beziehungsweise verbleibender Überschuss") public var kz83:GeldBetragMitCent11EN? /** * Andere Leistungen (§ 13b Absatz 2 Nummer 1, 2, 4 bis 12 UStG) (Bemessungsgrundlage) */ // @ApiMember(Description="Andere Leistungen (§ 13b Absatz 2 Nummer 1, 2, 4 bis 12 UStG) (Bemessungsgrundlage)") public var kz84:GeldBetragOhneCent13EN? /** * 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)") public var kz85:GeldBetragMitCent11EN? /** * zum Steuersatz von 7 Prozent */ // @ApiMember(Description="zum Steuersatz von 7 Prozent") public var kz86:GeldBetragOhneCent13EN? /** * zum Steuersatz von 19 Prozent */ // @ApiMember(Description="zum Steuersatz von 19 Prozent") public var kz89:GeldBetragOhneCent13EN? /** * Steuerfreie innergemeinschaftliche Erwerbe von bestimmten Gegenständen und Anlagegold (§§ 4b und 25c UStG) */ // @ApiMember(Description="Steuerfreie innergemeinschaftliche Erwerbe von bestimmten Gegenständen und Anlagegold (§§ 4b und 25c UStG)") public var kz91:GeldBetragOhneCent13EN? /** * zum Steuersatz von 7 Prozent */ // @ApiMember(Description="zum Steuersatz von 7 Prozent") public var kz93:GeldBetragOhneCent13EN? /** * Erwerbe nach §§ 4b und 25c UStG */ // @ApiMember(Description="Erwerbe nach §§ 4b und 25c UStG") public var kz94:GeldBetragOhneCent13EN? /** * zu anderen Steuersätzen (Bemessungsgrundlage) */ // @ApiMember(Description="zu anderen Steuersätzen (Bemessungsgrundlage)") public var kz95:GeldBetragOhneCent13EN? /** * neuer Fahrzeuge (§ 1b Absatz 2 und 3 UStG) von Lieferern ohne Umsatzsteuer-Identifikationsnummer zum allgemeinen Steuersatz (Steuer) */ // @ApiMember(Description="neuer Fahrzeuge (§ 1b Absatz 2 und 3 UStG) von Lieferern ohne Umsatzsteuer-Identifikationsnummer zum allgemeinen Steuersatz (Steuer)") public var kz96:GeldBetragMitCent11EN? /** * zu anderen Steuersätzen (Steuer) */ // @ApiMember(Description="zu anderen Steuersätzen (Steuer)") public var kz98:GeldBetragMitCent11EN? required public init(){} } /** * Stellt eine Anbindung zum ELSTER Online Portal (EOP) dar. */ // @Api(Description="Stellt eine Anbindung zum ELSTER Online Portal (EOP) dar.") public class EOP : Codable { public var transferausgabe:String? required public init(){} } /** * Submits the preliminary VAT return (Umsatzsteuervoranmeldung) as a tax consultant for 2021. */ // @Api(Description="Submits the preliminary VAT return (Umsatzsteuervoranmeldung) as a tax consultant for 2021.") public class SubmitUStVa2021AsTaxConsultantBase : SubmitUmsatzsteueranmeldung2021AsTaxConsultantBase { /** * Die Umsatzsteuervoranmeldung (The preliminary VAT return). */ // @ApiMember(Description="Die Umsatzsteuervoranmeldung (The preliminary VAT return).", IsRequired=true) public var umsatzsteuervoranmeldung:Umsatzsteuervoranmeldung2021? required public init(){ super.init() } private enum CodingKeys : String, CodingKey { case umsatzsteuervoranmeldung } required public init(from decoder: Decoder) throws { try super.init(from: decoder) let container = try decoder.container(keyedBy: CodingKeys.self) umsatzsteuervoranmeldung = try container.decodeIfPresent(Umsatzsteuervoranmeldung2021.self, forKey: .umsatzsteuervoranmeldung) } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) var container = encoder.container(keyedBy: CodingKeys.self) if umsatzsteuervoranmeldung != nil { try container.encode(umsatzsteuervoranmeldung, forKey: .umsatzsteuervoranmeldung) } } } /** * Represents a structure that contains the first output of the ERiC tax data submission process. */ // @Api(Description="Represents a structure that contains the first output of the ERiC tax data submission process.") public class EricBearbeiteVorgang : Codable { /** * Information from the successful processing a tax declaration. */ // @ApiMember(Description="Information from the successful processing a tax declaration.") public var erfolg:Erfolg? /** * Gets or sets information on all data deliveries, including deliveries that have not been confirmed by the server. */ // @ApiMember(Description="Gets or sets information on all data deliveries, including deliveries that have not been confirmed by the server.") public var transfers:Transfers? /** * Error rules that result from the processing of a tax declaration. */ // @ApiMember(Description="Error rules that result from the processing of a tax declaration.") public var fehlerRegelpruefungen:[FehlerRegelpruefung] = [] /** * Hints that result the processing of a tax declaration. */ // @ApiMember(Description="Hints that result the processing of a tax declaration.") public var hinweise:[Hinweis] = [] required public init(){} } /** * Represents an ELSTER document. */ // @Api(Description="Represents an ELSTER document.") public class Elster : Codable { /** * The transfer header part of the ELSTER document. */ // @ApiMember(Description="The transfer header part of the ELSTER document.", IsRequired=true) public var transferHeader:TransferHeader? /** * The data (facts) part of the ELSTER document. */ // @ApiMember(Description="The data (facts) part of the ELSTER document.", IsRequired=true) public var datenTeil:DatenTeil? required public init(){} } /** * Represents a generic file that contains raw data content in bytes */ // @Api(Description="Represents a generic file that contains raw data content in bytes") public class BinaryFile : FileBase { /** * The attributes of the file. */ // @ApiMember(Description="The attributes of the file.") public var metadata:FileMetadata? /** * The name of the file without information on its directory path. */ // @ApiMember(Description="The name of the file without information on its directory path.") public var name:String? required public init(){ super.init() } private enum CodingKeys : String, CodingKey { case metadata case name } required public init(from decoder: Decoder) throws { try super.init(from: decoder) let container = try decoder.container(keyedBy: CodingKeys.self) metadata = try container.decodeIfPresent(FileMetadata.self, forKey: .metadata) name = try container.decodeIfPresent(String.self, forKey: .name) } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) var container = encoder.container(keyedBy: CodingKeys.self) if metadata != nil { try container.encode(metadata, forKey: .metadata) } if name != nil { try container.encode(name, forKey: .name) } } } /** * Represents a base class for a file with raw data. */ // @Api(Description="Represents a base class for a file with raw data.") public class FileBase : Codable { /** * The raw data content of the file in bytes. */ // @ApiMember(Description="The raw data content of the file in bytes.", Name="Content") public var content:[UInt8]? required public init(){} } public protocol ISecuredCertificate { var pin:String? { get set } } /** * Stellt den Zeitraum für eine Anmeldung dar */ public enum AnmeldungZeitraum : Int, Codable { case ZR01 = 1 case ZR02 = 2 case ZR03 = 3 case ZR04 = 4 case ZR05 = 5 case ZR06 = 6 case ZR07 = 7 case ZR08 = 8 case ZR09 = 9 case ZR10 = 10 case ZR11 = 11 case ZR12 = 12 case ZR41 = 41 case ZR42 = 42 case ZR43 = 43 case ZR44 = 44 } /** * Stellt den Pflichtkennzahl Kz09 dar, welche die Angabe diverser Informationen ermöglicht. Beispiele: 74931 74931*Name Berater*Berufsbezeichnung*** 74931*****Name Mandant 74931***Tel.Nr:Berater/Vorwahl*Tel.Nr:Berater/Anschluss*Name Mandant */ // @Api(Description="Stellt den Pflichtkennzahl Kz09 dar, welche die Angabe diverser Informationen ermöglicht. Beispiele: 74931 74931*Name Berater*Berufsbezeichnung*** 74931*****Name Mandant 74931***Tel.Nr:Berater/Vorwahl*Tel.Nr:Berater/Anschluss*Name Mandant") public class Kz09 : Codable { /** * Die Bezeichnung des Softwareherstellers (Pflicht), über dessen Software die Steuererklärung oder (Vor)anmeldung abgegeben wird. Die Bezeichnung muss 5-stellig sein. */ // @ApiMember(Description="Die Bezeichnung des Softwareherstellers (Pflicht), über dessen Software die Steuererklärung oder (Vor)anmeldung abgegeben wird. Die Bezeichnung muss 5-stellig sein.", IsRequired=true, Name="HerstellerId") public var herstellerId:Int? /** * Der Name des Beraters, welcher die Steuererklärung oder (Vor)anmeldung abgegeben wird. Das Name des Beraters kann von 0- bis 85-stellig sein. */ // @ApiMember(Description="Der Name des Beraters, welcher die Steuererklärung oder (Vor)anmeldung abgegeben wird. Das Name des Beraters kann von 0- bis 85-stellig sein.", Name="BeraterName") public var beraterName:String? /** * Die Berufbezeichnung des Beraters. Die Berufbezeichnung des Beraterskann von 0- bis 85-stellig sein. */ // @ApiMember(Description="Die Berufbezeichnung des Beraters. Die Berufbezeichnung des Beraterskann von 0- bis 85-stellig sein.", Name="Berufsbezeichnung") public var berufsbezeichnung:String? /** * Die Telefonnummervorwahl des Beraters. Die Telefonnummervorwahl des Beraters kann von 0- bis 85-stellig sein. */ // @ApiMember(Description="Die Telefonnummervorwahl des Beraters. Die Telefonnummervorwahl des Beraters kann von 0- bis 85-stellig sein.", Name="Berufsbezeichnung") public var beraterTelNrVorwahl:String? /** * Der Telefonnummeranschluss des Beraters. Der Telefonnummeranschluss des Beraters kann von 0- bis 85-stellig sein. */ // @ApiMember(Description="Der Telefonnummeranschluss des Beraters. Der Telefonnummeranschluss des Beraters kann von 0- bis 85-stellig sein.", Name="BeraterTelNrAnschluss") public var beraterTelNrAnschluss:String? /** * Der Name des Mandanten. Der Name des Mandanten kann von 0- bis 85-stellig sein. */ // @ApiMember(Description="Der Name des Mandanten. Der Name des Mandanten kann von 0- bis 85-stellig sein.", Name="MandantName") public var mandantName:String? required public init(){} } /** * Represents an integer data type whose value has a maximum length of 1 digit. Minus sign allowed. */ // @Api(Description="Represents an integer data type whose value has a maximum length of 1 digit. Minus sign allowed.") public class Ganzzahl1EN : Ganzzahl { required public init(){ super.init() } required public init(from decoder: Decoder) throws { try super.init(from: decoder) } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) } } /** * Represents an amount of money without cents whose value has a maximum length of 13 digits. That is, 1 to 13 digits. Minus sign allowed. */ // @Api(Description="Represents an amount of money without cents whose value has a maximum length of 13 digits. That is, 1 to 13 digits. Minus sign allowed.") public class GeldBetragOhneCent13EN : GrossGeldBetragOhneCent { required public init(){ super.init() } required public init(from decoder: Decoder) throws { try super.init(from: decoder) } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) } } /** * Represents an amount of money with cents whose value has a maximum length of 13 digits. That is, 1 to 11 digits before the decimal separator and 2 digits after the decimal separator. Minus sign allowed. */ // @Api(Description="Represents an amount of money with cents whose value has a maximum length of 13 digits. That is, 1 to 11 digits before the decimal separator and 2 digits after the decimal separator. Minus sign allowed.") public class GeldBetragMitCent11EN : GeldBetragMitCent { required public init(){ super.init() } required public init(from decoder: Decoder) throws { try super.init(from: decoder) } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) } } /** * 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.") public class PositiverGeldBetragMitCent13EN : GeldBetragMitCent { required public init(){ super.init() } required public init(from decoder: Decoder) throws { try super.init(from: decoder) } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) } } /** * Represents an unsigned amount of money without cents whose value has a maximum length of 13 digits. That is, 1 to 13 digits. Minus sign NOT allowed. */ // @Api(Description="Represents an unsigned amount of money without cents whose value has a maximum length of 13 digits. That is, 1 to 13 digits. Minus sign NOT allowed.") public class PositiverGeldBetragOhneCent13EN : GrossGeldBetragOhneCent { required public init(){ super.init() } required public init(from decoder: Decoder) throws { try super.init(from: decoder) } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) } } /** * Represents an unsigned amount of money with cents whose value has a maximum length of 13 digits. That is, 1 to 11 digits before the decimal separator and 2 digits after the decimal separator. Minus sign NOT allowed. */ // @Api(Description="Represents an unsigned amount of money with cents whose value has a maximum length of 13 digits. That is, 1 to 11 digits before the decimal separator and 2 digits after the decimal separator. Minus sign NOT allowed.") public class PositiverGeldBetragMitCent11EN : GeldBetragMitCent { required public init(){ super.init() } required public init(from decoder: Decoder) throws { try super.init(from: decoder) } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) } } /** * Submits a VAT registration (Umsatzsteueranmeldung) for 2021 and files in the XML content as a tax consultant. */ // @Api(Description="Submits a VAT registration (Umsatzsteueranmeldung) for 2021 and files in the XML content as a tax consultant.") public class SubmitUmsatzsteueranmeldung2021AsTaxConsultantBase : IPost, IDruckRequest, IVeschlueselungsRequest, Codable { /** * Natürliche Person, welche die Software bedient, bzw. in deren Namen die Software bedient wird, um die Daten zu übersenden (Natural person who operates the software or under whose name the software is operated in order to transmit the data). */ // @ApiMember(Description="Natürliche Person, welche die Software bedient, bzw. in deren Namen die Software bedient wird, um die Daten zu übersenden (Natural person who operates the software or under whose name the software is operated in order to transmit the data).", IsRequired=true) public var datenLieferant:DatenLieferant? /** * Das Datum der Erstellung (Date of creation). */ // @ApiMember(Description="Das Datum der Erstellung (Date of creation).", IsRequired=true) public var erstellungsdatum:Date? /** * Der Steuerberater, der den Steuerfall bearbeitet und abgibt (The tax adviser who processes and submits the tax case). */ // @ApiMember(Description="Der Steuerberater, der den Steuerfall bearbeitet und abgibt (The tax adviser who processes and submits the tax case).") public var berater:Berater? /** * Der Mandant, für den der Steuerfall bearbeitet wird (The client for which the tax case is being processed). */ // @ApiMember(Description="Der Mandant, für den der Steuerfall bearbeitet wird (The client for which the tax case is being processed).") public var mandant:Mandant? /** * Die vierstellige Bundesfinanzamtsnummer des empfangenden Finanzamtes (The four-digit federal tax office number of the receiving tax office). */ // @ApiMember(Description="Die vierstellige Bundesfinanzamtsnummer des empfangenden Finanzamtes (The four-digit federal tax office number of the receiving tax office).", IsRequired=true) public var bundesfinanzamtsnummer:String? /** * Die Anbindung zum ELSTER Online Portal (EOP). */ // @ApiMember(Description="Die Anbindung zum ELSTER Online Portal (EOP).") public var eop:EOP? /** * Should the PDF file be prepared for a double-sided printout with a margin for punching?. True: The straight sides are indented to the left for a stitching margin for punching. False: There is no indentation of the straight sides. The created PDF is only intended for printing pages page by page. */ // @ApiMember(Description="Should the PDF file be prepared for a double-sided printout with a margin for punching?. True: The straight sides are indented to the left for a stitching margin for punching. False: There is no indentation of the straight sides. The created PDF is only intended for printing pages page by page.") public var duplexDruck:Bool? /** * Name prefix of the generated transfer protocol file. */ // @ApiMember(Description="Name prefix of the generated transfer protocol file.") public var protocolPrefix:String? /** * Footer text to be used on the printout (optional). */ // @ApiMember(Description="Footer text to be used on the printout (optional).", Name="FussText") public var fussText:String? /** * The authentification certificate. */ // @ApiMember(Description="The authentification certificate.", IsRequired=true) public var zertifikat:PortalCertificate? required public init(){} } /** * Represents information returned from a successful tax declaration process. */ // @Api(Description="Represents information returned from a successful tax declaration process.") public class Erfolg : Codable { /** * The generated tele-number for the successful tax declaration process. */ // @ApiMember(Description="The generated tele-number for the successful tax declaration process.") public var telenummer:[String] = [] /** * The classification key for the successful tax declaration process. */ // @ApiMember(Description="The classification key for the successful tax declaration process.") public var ordnungsbegriffe:[String] = [] required public init(){} } /** * Represents information on all data deliveries, including deliveries that have not been confirmed by the server. For more information, see the ERiC developer manual in the 'TransferTicket' section. */ // @Api(Description="Represents information on all data deliveries, including deliveries that have not been confirmed by the server. For more information, see the ERiC developer manual in the 'TransferTicket' section.") public class Transfers : Codable { /** * Contains information on all data deliveries, including deliveries that have not been confirmed by the server. */ // @ApiMember(Description="Contains information on all data deliveries, including deliveries that have not been confirmed by the server.") public var transferList:[Transfer] = [] required public init(){} } /** * Represents information on an ERiC reference. */ // @Api(Description="Represents information on an ERiC reference.") public class FehlerRegelpruefung : Codable { /** * The user data ticket of the reference. */ // @ApiMember(Description="The user data ticket of the reference.") public var nutzdatenticket:String? /** * The field identifier of the reference. */ // @ApiMember(Description="The field identifier of the reference.") public var feldidentifikator:String? /** * The multi-line index of the reference. */ // @ApiMember(Description="The multi-line index of the reference.") public var mehrfachzeilenindex:String? /** * The delivery number form of the reference. */ // @ApiMember(Description="The delivery number form of the reference.") public var lfdNrVordruck:String? /** * Indicates the line number of the error field mentioned in the form. */ // @ApiMember(Description="Indicates the line number of the error field mentioned in the form.") public var vordruckZeilennummer:String? /** * Specifies the value of one or more index fields that identify the context of error messages. */ // @ApiMember(Description="Specifies the value of one or more index fields that identify the context of error messages.") public var semantischeIndexes:[SemantischerIndex] = [] /** * The sub-subject-area of the reference. */ // @ApiMember(Description="The sub-subject-area of the reference.") public var untersachbereich:String? /** * The private identification number of the reference. */ // @ApiMember(Description="The private identification number of the reference.") public var privateKennnummer:String? /** * The name of the rule that applies to the reference. */ // @ApiMember(Description="The name of the rule that applies to the reference.") public var regelName:String? /** * The technical error identifier of the reference. */ // @ApiMember(Description="The technical error identifier of the reference.") public var fachlicheFehlerId:String? /** * The textual details of the reference. */ // @ApiMember(Description="The textual details of the reference.") public var text:String? required public init(){} } public class Hinweis : Codable { /** * The user data ticket of the reference. */ // @ApiMember(Description="The user data ticket of the reference.") public var nutzdatenticket:String? /** * The field identifier of the reference. */ // @ApiMember(Description="The field identifier of the reference.") public var feldidentifikator:String? /** * The multi-line index of the reference. */ // @ApiMember(Description="The multi-line index of the reference.") public var mehrfachzeilenindex:String? /** * The delivery number form of the reference. */ // @ApiMember(Description="The delivery number form of the reference.") public var lfdNrVordruck:String? /** * Indicates the line number of the error field mentioned in the form. */ // @ApiMember(Description="Indicates the line number of the error field mentioned in the form.") public var vordruckZeilennummer:String? /** * Specifies the value of one or more index fields that identify the context of error messages. */ // @ApiMember(Description="Specifies the value of one or more index fields that identify the context of error messages.") public var semantischeIndexes:[SemantischerIndex] = [] /** * The sub-subject-area of the reference. */ // @ApiMember(Description="The sub-subject-area of the reference.") public var untersachbereich:String? /** * The private identification number of the reference. */ // @ApiMember(Description="The private identification number of the reference.") public var privateKennnummer:String? /** * The name of the rule that applies to the reference. */ // @ApiMember(Description="The name of the rule that applies to the reference.") public var regelName:String? /** * The technical note identifier of the reference. */ // @ApiMember(Description="The technical note identifier of the reference.") public var fachlicheHinweisId:String? /** * The textual details of the reference. */ // @ApiMember(Description="The textual details of the reference.") public var text:String? required public init(){} } /** * Represents the transfer header part of an ELSTER document. */ // @Api(Description="Represents the transfer header part of an ELSTER document.") public class TransferHeader : Codable { /** * The version of the transfer header. */ // @ApiMember(Description="The version of the transfer header.", IsRequired=true) public var version:String? /** * The tax operation used in the ELSTER process. */ // @ApiMember(Description="The tax operation used in the ELSTER process.", IsRequired=true) public var verfahren:Verfahren? /** * The tax data type of the ELSTER process. */ // @ApiMember(Description="The tax data type of the ELSTER process.", IsRequired=true) public var datenArt:Datenart? /** * The authentification procedure of the ELSTER process. */ // @ApiMember(Description="The authentification procedure of the ELSTER process.", IsRequired=true) public var vorgang:Vorgang? /** * The ticket identifier after a successful ELSTER process. */ // @ApiMember(Description="The ticket identifier after a successful ELSTER process.") public var transferTicket:String? /** * The flag that indicates whether the tax declaration or filing is a test case. For production purposes, this value should not be set. */ // @ApiMember(Description="The flag that indicates whether the tax declaration or filing is a test case. For production purposes, this value should not be set.") public var testmerker:Testmerker? /** * The signature and associated information on the compressed, encrypted, base64-encoded content of the the data part of a tax declaration / statement. */ // @ApiMember(Description="The signature and associated information on the compressed, encrypted, base64-encoded content of the the data part of a tax declaration / statement.") public var sigUser:SigUser? /** * The receiving ELSTER server. */ // @ApiMember(Description="The receiving ELSTER server.") public var empfaenger:Empfaenger? /** * The identifier of the software manufacturer, through whose software the tax declaration is filed. */ // @ApiMember(Description="The identifier of the software manufacturer, through whose software the tax declaration is filed.", IsRequired=true) public var herstellerID:String? /** * The details of the provider that submits tax data. */ // @ApiMember(Description="The details of the provider that submits tax data.", IsRequired=true) public var datenLieferant:String? /** * The date of receipt of the tax data. */ // @ApiMember(Description="The date of receipt of the tax data.") public var eingangsDatum:Date? /** * The encryption data required for authenticated transmission of tax data. */ // @ApiMember(Description="The encryption data required for authenticated transmission of tax data.", IsRequired=true) public var datei:Datei? /** * The return code of the transfer header and is included in the response XML of the ELSTER server. The value should never be set by the data provider. */ // @ApiMember(Description="The return code of the transfer header and is included in the response XML of the ELSTER server. The value should never be set by the data provider.") public var rc:RC? /** * The details of the software that submits the tax data. */ // @ApiMember(Description="The details of the software that submits the tax data.") public var versionClient:String? /** * Data extensions to the transfer header. */ // @ApiMember(Description="Data extensions to the transfer header.") public var zusatz:Zusatz? required public init(){} } /** * Represents the data part of an ELSTER document. */ // @Api(Description="Represents the data part of an ELSTER document.") public class DatenTeil : Codable { /** * The blocks of tax data of the ELSTER document. */ // @ApiMember(Description="The blocks of tax data of the ELSTER document.", IsRequired=true) public var nutzdatenbloecke:[Nutzdatenblock] = [] required public init(){} } /** * Represents information about a file or directory. */ // @Api(Description="Represents information about a file or directory.") public class FileMetadata : IFileMetadata, Codable { /** * The name of the file.For files, gets the name of the file.For directories, gets the name of the last directory in the hierarchy if a hierarchy exists; otherwise, the name of the directory. */ // @ApiMember(Description="The name of the file.\nFor files, gets the name of the file.\nFor directories, gets the name of the last directory in the hierarchy if a hierarchy exists; otherwise, the name of the directory.") public var name:String? /** * The full path of the directory or file. */ // @ApiMember(Description="The full path of the directory or file.") public var fullName:String? /** * The time the current file or directory was last accessed. */ // @ApiMember(Description="The time the current file or directory was last accessed.") public var lastAccessTime:Date? /** * The name of the file. */ // @ApiMember(Description="The name of the file.") public var lastAccessTimeUtc:Date? /** * The time when the current file or directory was last written to. */ // @ApiMember(Description="The time when the current file or directory was last written to.") public var lastWriteTime:Date? /** * The time, in coordinated universal time (UTC), when the current file or directory was last written to. */ // @ApiMember(Description="The time, in coordinated universal time (UTC), when the current file or directory was last written to.") public var lastWriteTimeUtc:Date? /** * The size, in bytes, of the current file. */ // @ApiMember(Description="The size, in bytes, of the current file.") public var length:Int? /** * The size, in bytes, of the current file. */ // @ApiMember(Description="The size, in bytes, of the current file.") public var userId:Int? /** * The file group id. */ // @ApiMember(Description="The file group id.") public var groupId:Int? /** * A value that indicates whether the others can read from this file. */ // @ApiMember(Description="A value that indicates whether the others can read from this file.") public var othersCanRead:Bool? /** * A value that indicates whether the group members can execute this file. */ // @ApiMember(Description="A value that indicates whether the group members can execute this file.") public var groupCanExecute:Bool? /** * A value that indicates whether the group members can write into this file. */ // @ApiMember(Description="A value that indicates whether the group members can write into this file.") public var groupCanWrite:Bool? /** * A value that indicates whether the group members can read from this file. */ // @ApiMember(Description="A value that indicates whether the group members can read from this file.") public var groupCanRead:Bool? /** * A value that indicates whether the owner can execute this file. */ // @ApiMember(Description="A value that indicates whether the owner can execute this file.") public var ownerCanExecute:Bool? /** * A value that indicates whether the owner can write into this file. */ // @ApiMember(Description="A value that indicates whether the owner can write into this file.") public var ownerCanWrite:Bool? /** * A value that indicates whether the owner can read from this file. */ // @ApiMember(Description="A value that indicates whether the owner can read from this file.") public var ownerCanRead:Bool? /** * A value that indicates whether others can read from this file. */ // @ApiMember(Description="A value that indicates whether others can read from this file.") public var othersCanExecute:Bool? /** * A value that indicates whether others can write into this file. */ // @ApiMember(Description="A value that indicates whether others can write into this file.") public var othersCanWrite:Bool? /** * Extensions to the file attributes. */ // @ApiMember(Description="Extensions to the file attributes.") public var extensions:[String:String] = [:] required public init(){} } /** * Specifies an integer data type with limits and a specialized string representation */ // @Api(Description="Specifies an integer data type with limits and a specialized string representation") public class Ganzzahl : Codable { /** * The intrinsic integer value. */ // @ApiMember(Description="The intrinsic integer value.") public var wert:Int? required public init(){} } /** * 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") public class GrossGeldBetragOhneCent : Codable { /** * The intrinsic currency value. */ // @ApiMember(Description="The intrinsic currency value.") public var wert:Int? required public init(){} } /** * 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") public class GeldBetragMitCent : Codable { /** * The intrinsic currency value. */ // @ApiMember(Description="The intrinsic currency value.") public var wert:Double? required public init(){} } /** * Represents information on the delivery. */ // @Api(Description="Represents information on the delivery.") public class Transfer : Codable { /** * The ticket of the transfer. */ // @ApiMember(Description="The ticket of the transfer.") public var transferTicket:String? required public init(){} } /** * Represents value of an index field, which identfies the context about an error message. */ // @Api(Description="Represents value of an index field, which identfies the context about an error message.") public class SemantischerIndex : Codable { /** * The name of the index field. */ // @ApiMember(Description="The name of the index field.") public var name:String? /** * The value of the index field. */ // @ApiMember(Description="The value of the index field.") public var value:String? required public init(){} } /** * Auflistung der gültigen Verfahren */ public enum Verfahren : String, Codable { case ElsterAnmeldung case ElsterBereitstellung case ElsterBilanz case ElsterBRM case ElsterBRMOrg case ElsterDatenabholung case ElsterErklaerung case ElsterExtern case ElsterFSE case ElsterKapESt case ElsterKMV case ElsterKontoabfrage case ElsterLavendel case ElsterLohn case ElsterLohn2 case ElsterNachricht case ElsterSignatur case ElsterVollmachtDB case ElsterRabe } /** * Auflistung aller gültigen Datenarten. */ public enum Datenart : String, Codable { case Anlage34a case AnpassungVorauszahlung case AntragUStVerguetung4a case AbrufcodeAntrag case AenderungAdresse case AbrufcodeStorno case AbrufvollmachtAnlage case AbrufvollmachtUpdate case AenderungBankverbindung case AntraegeRechteLoeschen case AntraegeUndRechte case Aufzeichnung146a case Bilanz case Belegnachreichung case BSBMitteilung case BZSt2 case C19Mitteilung case DUeAbmelden case DUeAnmelden case DUeUmmelden case Einspruch case EinspruchNachtrag case EinspruchRuecknahme case ELeVAntragELStAM case ELeVErmaessigung case ELeVGetrenntlebend case ELeVSteuerklassenwechsel case ELeVWiederaufnahmeEhe case EPAntwort case EPBescheid case EPMitteilung case EPKurzmitteilung case ElsterErklaerungDaten case ElsterKMVDaten case ElsterLohn2Daten case ElsterLohnDaten case ElsterVaStDaten case ElsterDIVADaten case ElsterDIVDaten case ElsterEPBescheidDaten case ElsterEPMitteilungDaten case EPStBescheidAbholung case EPStMitteilungAbholung case Erbschaftsteuer case ESt case EStbeschraenkt case EUER case EUn case FEIN case KStAntragOptionPersG case FLHMitteilung case FreistellungKapitalertraegeBV case Fristverlaengerung case FsEVerein case Gewerbemeldung case GDBMitteilung case Gewinnermittlung13aEStG case GewSt case GewStZ case GrundsteuerBW case GrundsteuerBY case GrundsteuerHE case GrundsteuerHH case GrundsteuerNI case GrundsteuerAendAZ case GrundsteuerAendAZBW case GrundsteuerAendAZBY case GrundsteuerAendAZHE case GrundsteuerAendAZHH case GrundsteuerAendAZNI case Grundsteuerwert case InvStG56Abs5 case InvStG51Feststellung case IBANMeldung case KapEStA case KapEStInvStG case KapG case KapGAus case KKVMitteilung case Kontoabfrage case Kontoinformation case KSt case KStAntragEinlagenrueck case KStZ case KStZerlegungVZ case KTTAnmeldungHH case KTTAnzeigeHH case Lohnersatzleistung case LohnersatzMitteilung case LStA case LStB case LStHVVMAnlage case LStHVVMUpdate case LSTMitteilung case OGHMitteilung case MindestStUnternehmenEU case MVOMitteilung case MVZMitteilung case FZLMitteilung case NEKMitteilung case VermoegenswirksameLeistung case VMWiderruf case VollmachtDetails case VNoVMVRegistrierung case VNoVMVUpdate case VNoVMVLoeschung case VollfAAnlage case VollfAUpdate case VMoVMVStBAnlage case VMoVMVStBUpdate case VMoVMVFreischaltung case DIVADatenBZSt case DivaEinwilligungAnlageBRM case DivaEinwilligungFreisch case DivaEinwilligungUpdateBRM case DivaWiderrufBRM case DivaErgebnisliste case LStHVDivaAdresseBRM case VMErgebnisListeVNSicht case PersG case PostfachAnfrage case PostfachStatus case ProtokollAnforderung case RabeExtDatenhaltungCheck case RabeExtDatenhaltungPflege case Registrierung case Schenkungsteuer case SonstigeNachrichten case SpezRechtAntrag case SpezRechtFreischaltung case SpezRechtListe case SpezRechtStorno case SpezRechtTeilnahme case StAb50a case StAbS50a case Statusabfrage case StundungAntrag case UnentgeltlicheDepotuebertragung case UENSTAnmeldungBE case UENSTAnzeigeBE case USt case UStAKfzEinzel case UStVA case UStDV case UStSV case VAGMitteilung case VGNAnmeldungHB case VGNAnmeldungBE case VGNAnmeldungHH case VGNAnzeigeHH case VGNAnzeigeBE case WTBAnmeldungHB case ZMDO case ElsterVollmachtDaten case MitteilungAbholung case PostfachBestaetigung } /** * Hauptinformation ob die Daten authentifiziert wurden (send-Auth) oder nicht (send-NoSig) */ public enum Vorgang : String, Codable { case Send_Auth case Send_Auth_Part case Send_NoSig case Send_NoSig_Part } /** * Kennzeichnung der Datenlieferung ob es sich um einen Testfall handelt, gilt fuer die gesamte Datenlieferung. Ein Echtfall enthält dieses Element nicht. Ein Testfall muss mit einem Testmerker versehen werden, damit er nicht wie ein Echtfall verarbeitet wird. Handelt es sich um Daten, die nur zum Testen des Frontends versendet wurden, müssen sie nicht mehr weiter verarbeitet werden. */ public enum Testmerker : Int, Codable { case TM010000001 = 10000001 case TM080000001 = 80000001 case TM160000001 = 160000001 case TM160000002 = 160000002 case TM220000000 = 220000000 case TM220002000 = 220002000 case TM230000001 = 230000001 case TM240000000 = 240000000 case TM300000002 = 300000002 case TM370000001 = 370000001 case TM520000000 = 520000000 case TM700000001 = 700000001 case TM700000004 = 700000004 } /** * Represents the signature and associated information of the compressed, encrypted, base64-encoded content of the data part of the tax declaration/statement. */ // @Api(Description="Represents the signature and associated information of the compressed, encrypted, base64-encoded content of the data part of the tax declaration/statement.") public class SigUser : Codable { /** * The content of the data. Currently supported: Raw XML (text), XElement or IXmlSerializable */ // @ApiMember(Description="The content of the data. Currently supported: Raw XML (text), XElement or IXmlSerializable") public var inhalt:String? required public init(){} } /** * Represents a receiver of tax data. */ // @Api(Description="Represents a receiver of tax data.") public class Empfaenger : Codable { /** * The identifier of the receiver. */ // @ApiMember(Description="The identifier of the receiver.", IsRequired=true) public var id:String? /** * The destination of the receiver. */ // @ApiMember(Description="The destination of the receiver.") public var ziel:String? required public init(){} } /** * Represents information on the encryption of tax data. */ // @Api(Description="Represents information on the encryption of tax data.") public class Datei : Codable { /** * The type of data encryption used. */ // @ApiMember(Description="The type of data encryption used.", IsRequired=true) public var verschluesselung:Verschluesselungsart? /** * The type of data compression used. */ // @ApiMember(Description="The type of data compression used.", IsRequired=true) public var kompression:Kompression? /** * The transport key used in the encryption. */ // @ApiMember(Description="The transport key used in the encryption.") public var transportSchluessel:String? /** * [Documentation unavailable] */ // @ApiMember(Description="[Documentation unavailable]") public var erstellung:Erstellung? required public init(){} } /** * Represents an ERiC return code. */ // @Api(Description="Represents an ERiC return code.") public class RC : Codable { /** * The return value of the return code. */ // @ApiMember(Description="The return value of the return code.", IsRequired=true) public var rueckgabe:Rueckgabe? /** * The internal value of the return code. */ // @ApiMember(Description="The internal value of the return code.") public var stack:Stack? required public init(){} } /** * Represents an ERiC extension. */ // @Api(Description="Represents an ERiC extension.") public class Zusatz : Codable { /** * The user-customizable items for the extension. Data providers can use these items for their own extensions/information. */ // @ApiMember(Description="The user-customizable items for the extension. Data providers can use these items for their own extensions/information.") public var infos:[String] = [] /** * The ELSTER items for the extension. They can be included in the response XML from the ELSTER server, if special information must be returned to the user after data submission. For example, for authenticated submission, information about impending certificate expiration etc. It must not be supplied by the data provider (even when empty). */ // @ApiMember(Description="The ELSTER items for the extension. They can be included in the response XML from the ELSTER server, if special information must be returned to the user after data submission. For example, for authenticated submission, information about impending certificate expiration etc. It must not be supplied by the data provider (even when empty).") public var elsterInfos:[String] = [] required public init(){} } /** * Represents a block of tax data. */ // @Api(Description="Represents a block of tax data.") public class Nutzdatenblock : Codable { /** * The header part of the block. */ // @ApiMember(Description="The header part of the block.", IsRequired=true) public var nutzdatenHeader:NutzdatenHeader? /** * The data part of the block. */ // @ApiMember(Description="The data part of the block.", IsRequired=true) public var nutzdaten:Nutzdaten? required public init(){} } public protocol IFileMetadata { var name:String? { get set } var fullName:String? { get set } var lastAccessTime:Date? { get set } var lastAccessTimeUtc:Date? { get set } var lastWriteTime:Date? { get set } var lastWriteTimeUtc:Date? { get set } var length:Int? { get set } var userId:Int? { get set } var groupId:Int? { get set } var groupCanExecute:Bool? { get set } var groupCanWrite:Bool? { get set } var groupCanRead:Bool? { get set } var ownerCanRead:Bool? { get set } var ownerCanExecute:Bool? { get set } var ownerCanWrite:Bool? { get set } var othersCanRead:Bool? { get set } var othersCanExecute:Bool? { get set } var othersCanWrite:Bool? { get set } var extensions:[String:String]? { get set } } /** * Protokoll der Verschluesselung. Es kann vorkommen, dass verschieden Verschluesselungsarten eingesetzt werden, eine Unterscheidung ist hier nötig, um das richtige Entschluesselungstool anzusteuern. Mit welcher Verschluesselungsart wurden die Inhalte von den Elementen 'DatenLieferant' und ggf. 'SigUser' im TransferHeader und dem Element 'DatenTeil' verschluesselt */ public enum Verschluesselungsart : String, Codable { case PKCS_7v1_5 case PKCS_7v1_5enveloped case NO_BASE64 case CMSEncryptedData case CMSEnvelopedData case EnvelopedData__RSA_OAEP__AES_128__GZip__B64 } /** * Mit welcher Kompression wurden die Inhalte von den Elementen DatenLieferant und ggf. SigUser im TransferHeader und dem Element DatenTeil komprimiert. */ public enum Kompression : String, Codable { case GZIP case NO_BASE64 } /** * [Documentation unavailable] */ // @Api(Description="[Documentation unavailable]") public class Erstellung : Codable { /** * [Documentation unavailable] */ // @ApiMember(Description="[Documentation unavailable]") public var eric:EricTyp? required public init(){} } /** * Represents an external error stack. */ // @Api(Description="Represents an external error stack.") public class Rueckgabe : Codable { /** * The external error code. Either a zero (0) if no external errors occurred; otherwise an error number. */ // @ApiMember(Description="The external error code. Either a zero (0) if no external errors occurred; otherwise an error number.", IsRequired=true) public var code:String? /** * The external error message. */ // @ApiMember(Description="The external error message.", IsRequired=true) public var text:String? required public init(){} } /** * Represents an internal error stack. */ // @Api(Description="Represents an internal error stack.") public class Stack : Codable { /** * The internal error code. Either a zero (0) if no internal errors occurred; otherwise an error number. */ // @ApiMember(Description="The internal error code. Either a zero (0) if no internal errors occurred; otherwise an error number.", IsRequired=true) public var code:String? /** * The external error message. */ // @ApiMember(Description="The external error message.", IsRequired=true) public var text:String? required public init(){} } /** * Represents the header of a tax data. */ // @Api(Description="Represents the header of a tax data.") public class NutzdatenHeader : Codable { /** * The version of the header. */ // @ApiMember(Description="The version of the header.", IsRequired=true) public var version:String? /** * The ticket identifier of the header. */ // @ApiMember(Description="The ticket identifier of the header.", IsRequired=true) public var nutzdatenTicket:String? /** * The receiver of the header. */ // @ApiMember(Description="The receiver of the header.", IsRequired=true) public var empfaenger:NDHEmpfaenger? /** * The software manufacturer, through whose software the tax declaration or filing is submitted. */ // @ApiMember(Description="The software manufacturer, through whose software the tax declaration or filing is submitted.", IsRequired=true) public var hersteller:Hersteller? /** * The details of the data provider (e.g. taxpayer, tax consulant or firm), who produced the tax data and it must not necessarily be the same person declared in the TransferHeader section. */ // @ApiMember(Description="The details of the data provider (e.g. taxpayer, tax consulant or firm), who produced the tax data and it must not necessarily be the same person declared in the TransferHeader section.") public var datenLieferant:String? /** * The return code of the header. */ // @ApiMember(Description="The return code of the header.") public var rc:RC? /** * The data extensions of the header. */ // @ApiMember(Description="The data extensions of the header.") public var zusatz:Zusatz? required public init(){} } /** * Represents an encapsulation of tax data content. */ // @Api(Description="Represents an encapsulation of tax data content.") public class Nutzdaten : Codable { /** * The content of the tax data. This varies by tax declaration. Currently supported formats: Raw XML (text), XElement, and IXmlSerializable */ // @ApiMember(Description="The content of the tax data. This varies by tax declaration. Currently supported formats: Raw XML (text), XElement, and IXmlSerializable", IsRequired=true) public var inhalt:String? required public init(){} } /** * [Documentation unavailable] */ // @Api(Description="[Documentation unavailable]") public class EricTyp : Codable { /** * The content of the data. Currently supported: Raw XML (text), XmlElement, XElement or IXmlSerializable */ // @ApiMember(Description="The content of the data. Currently supported: Raw XML (text), XmlElement, XElement or IXmlSerializable") public var inhalt:String? required public init(){} } /** * Represents a receiver of tax data. */ // @Api(Description="Represents a receiver of tax data.") public class NDHEmpfaenger : Codable { /** * The identifier of the receiver. */ // @ApiMember(Description="The identifier of the receiver.", IsRequired=true) public var id:EmpfaengerID? /** * The value of the receiver. */ // @ApiMember(Description="The value of the receiver.", IsRequired=true) public var value:String? required public init(){} } /** * Represents a manufacturer/vendor of tax software. */ // @Api(Description="Represents a manufacturer/vendor of tax software.") public class Hersteller : Codable { /** * The product name of the tax software produced by the manufacturer. */ // @ApiMember(Description="The product name of the tax software produced by the manufacturer.", IsRequired=true) public var produktName:String? /** * The product version of the tax software produced by the manufacturer. */ // @ApiMember(Description="The product version of the tax software produced by the manufacturer.", IsRequired=true) public var produktVersion:String? required public init(){} } /** * Represents a receriver ID */ public enum EmpfaengerID : String, Codable { case L case F } /** * Represent a base response that encapsulate any ERiC API function return value. */ // @Api(Description="Represent a base response that encapsulate any ERiC API function return value.") public class EricFehlerCodeResponse : ServiceReponseBase { /** * The status code that the ERiC API function returns. */ // @ApiMember(Description="The status code that the ERiC API function returns.") public var statusCode:EricFehlerCode? /** * The status message that the ERiC API function returns. */ // @ApiMember(Description="The status message that the ERiC API function returns.") public var statusText:String? required public init(){ super.init() } private enum CodingKeys : String, CodingKey { case statusCode case statusText } required public init(from decoder: Decoder) throws { try super.init(from: decoder) let container = try decoder.container(keyedBy: CodingKeys.self) statusCode = try container.decodeIfPresent(EricFehlerCode.self, forKey: .statusCode) statusText = try container.decodeIfPresent(String.self, forKey: .statusText) } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) var container = encoder.container(keyedBy: CodingKeys.self) if statusCode != nil { try container.encode(statusCode, forKey: .statusCode) } if statusText != nil { try container.encode(statusText, forKey: .statusText) } } }