/* Options: Date: 2025-10-26 22:26:11 Version: 8.60 Tip: To override a DTO option, remove "//" prefix before updating BaseUrl: https://reportfiling.staging.pwc.de //Package: //AddServiceStackTypes: True //AddResponseStatus: False //AddImplicitVersion: //AddDescriptionAsComments: True IncludeTypes: RetrieveProtocols.* //ExcludeTypes: //InitializeCollections: False //TreatTypesAsStrings: //DefaultImports: java.math.*,java.util.*,java.io.InputStream,net.servicestack.client.* */ import java.math.* import java.util.* import java.io.InputStream import net.servicestack.client.* /** * Represents a request to retrieve protocols. */ @Route(Path="/sync/elma/protocols/retrieve", Verbs="POST") @Api(Description="Represents a request to retrieve protocols.") open class RetrieveProtocols : RetrieveProtocolsBase(), IReturn { companion object { private val responseType = RetrievalResponse::class.java } override fun getResponseType(): Any? = RetrieveProtocols.responseType } /** * Encapsulates the results of a protocol retrieval operation. */ @Api(Description="Encapsulates the results of a protocol retrieval operation.") open class RetrievalResponse { /** * Processing logs that indicate the status of submitted reports. */ @ApiMember(Description="Processing logs that indicate the status of submitted reports.", Name="Protocols") open var protocols:ArrayList? = null /** * Other artefacts including the auxillary files from the BZSt. */ @ApiMember(Description="Other artefacts including the auxillary files from the BZSt.", Name="Files") open var files:ArrayList? = null /** * The status of the response. */ @ApiMember(Description="The status of the response.", Name="ResponseStatus") open var responseStatus:ResponseStatus? = null } /** * Represent parameters to search or filter on submissions. */ @Api(Description="Represent parameters to search or filter on submissions. ") open class SearchCriteria { /** * Full or partial name of the item (report or protocol) to search. */ @ApiMember(Description="Full or partial name of the item (report or protocol) to search.") open var name:String? = null /** * TThe ELMA product designation. */ @ApiMember(Description="TThe ELMA product designation.") open var designation:Verfahren? = null } /** * Represents the credentials of a user to authenticate the access of an ELMA server. */ @Api(Description="Represents the credentials of a user to authenticate the access of an ELMA server.") open class ElmaCredential : IElmaCredential { /** * The unique identifier of this instance. This identifer is only relevant in the context of data storage and retrieval. */ @ApiMember(Description="The unique identifier of this instance. This identifer is only relevant in the context of data storage and retrieval.", IsRequired=true, Name="Id") open var id:String? = null /** * The security certificate to authenticate the user and grant access to the ELMA server. This certificate is generated from the BZSt-issued *.pfx BOP certificate. More details on BOP (BZSt-Online Portal - https://www.elster.de/bportal/start) */ @ApiMember(Description="The security certificate to authenticate the user and grant access to the ELMA server. This certificate is generated from the BZSt-issued *.pfx BOP certificate. More details on BOP (BZSt-Online Portal - https://www.elster.de/bportal/start)", IsRequired=true, Name="Certificate") @Required() @StringLength(MaximumLength=2147483647) override var certificate:PemCertificate? = null /** * The BZSt (Bundeszentralamt für Steuern) - tax number of the user. 11-character text field that may only consist of two capital letters and 9 digits (0-9). The fiscal authority BZSt provides this number during registration at the BOP (BZSt-Online Portal - https://www.elster.de/bportal/start). The number is available in the private area of the BOP user account under "My BOP" under the "Registration Information" */ @ApiMember(Description="The BZSt (Bundeszentralamt für Steuern) - tax number of the user. 11-character text field that may only consist of two capital letters and 9 digits (0-9). The fiscal authority BZSt provides this number during registration at the BOP (BZSt-Online Portal - https://www.elster.de/bportal/start). The number is available in the private area of the BOP user account under \"My BOP\" under the \"Registration Information\"", IsRequired=true, Name="AuthSteuernummer") @Required() @StringLength(MaximumLength=11) override var authSteuernummer:String? = null /** * The account identifier of a BZSt-Online Portal (BOP) user. 10-character text field that may only contain numbers (0-9). */ @ApiMember(Description="The account identifier of a BZSt-Online Portal (BOP) user. 10-character text field that may only contain numbers (0-9).", IsRequired=true, Name="AccountId") @Required() @StringLength(MaximumLength=10) override var accountId:String? = null /** * The password to protect the certificate from unauthorized access. */ @ApiMember(Description="The password to protect the certificate from unauthorized access.", IsRequired=true, Name="Password") override var password:String? = null } /** * Specifies a request to retrieve protocols. */ @Api(Description="Specifies a request to retrieve protocols.") open class RetrieveProtocolsBase : IPost, IAuthenticateRequest, IStageableRequest, ISearchRequest { /** * The parameters to search for protocols. */ @ApiMember(Description="The parameters to search for protocols.", IsRequired=true) override var searchCriteria:SearchCriteria? = null /** * The credential to gain access on the ELMA server. */ @ApiMember(Description="The credential to gain access on the ELMA server.", IsRequired=true) override var credential:ElmaCredential? = null /** * Should operations be staged on the ELMA server? true: operations are executed on the Test ELMA server. false: operations are executed on the Live (Production) ELMA server. */ @ApiMember(Description="Should operations be staged on the ELMA server? true: operations are executed on the Test ELMA server. false: operations are executed on the Live (Production) ELMA server.") override var stagingEnabled:Boolean? = null } interface IAuthenticateRequest { var credential:ElmaCredential? } interface IStageableRequest { var stagingEnabled:Boolean? } interface ISearchRequest { var searchCriteria:SearchCriteria? } /** * Represents a PEM-encoded certificate. */ @Api(Description="Represents a PEM-encoded certificate.") open class PemCertificate { /** * The unique identifier (e.g. the file name) of the certificate. */ @ApiMember(Description="The unique identifier (e.g. the file name) of the certificate.", IsRequired=true, Name="Id") open var id:String? = null /** * The PEM-encoded content of the certificate. */ @ApiMember(Description="The PEM-encoded content of the certificate.", IsRequired=true, Name="Content") open var content:String? = null /** * The description of the certificate. */ @ApiMember(Description="The description of the certificate.", Name="Description") open var description:String? = null /** * Tags to label or identify the certificate. */ @ApiMember(Description="Tags to label or identify the certificate.", Name="Tags") open var tags:ArrayList? = null } /** * Represents an ELMA report document. */ @Api(Description="Represents an ELMA report document.") open class Elma { /** * The unique identifier of this instance. This identifer is only relevant in the context of data storage and retrieval. */ @ApiMember(Description="The unique identifier of this instance. This identifer is only relevant in the context of data storage and retrieval.", IsRequired=true, Name="Id") open var id:String? = null /** * The location of the XML Schema to use for the root namespace. */ @ApiMember(Description="The location of the XML Schema to use for the root namespace.", Name="SchemaLocation") open var schemaLocation:String? = null /** * The type of reporting process. */ @ApiMember(Description="The type of reporting process.", IsRequired=true, Name="Verfahren") open var verfahren:Verfahren? = null /** * The communication section of the ELMA report document. */ @ApiMember(Description="The communication section of the ELMA report document.", IsRequired=true, Name="ElmaKom") open var elmaKom:ElmaKom? = null /** * The communication section of the ELMA report document. */ @ApiMember(Description="The communication section of the ELMA report document.", Name="ElmaProtokoll") open var elmaProtokoll:ElmaProtokoll? = null /** * The communication section of the ELMA report document. */ @ApiMember(Description="The communication section of the ELMA report document.", Name="ElmaFehler") open var elmaFehler:ElmaFehler? = null } /** * Represents a generic file that contains raw data content in bytes */ @Api(Description="Represents a generic file that contains raw data content in bytes") open class BinaryFile : FileBase() { /** * The attributes of the file. */ @ApiMember(Description="The attributes of the file.") open var metadata:FileMetadata? = null /** * The name of the file without information on its directory path. */ @ApiMember(Description="The name of the file without information on its directory path.") open var name:String? = null } /** * Represents information about a file or directory. */ @Api(Description="Represents information about a file or directory.") open class FileMetadata : IFileMetadata { /** * 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.") override var name:String? = null /** * The full path of the directory or file. */ @ApiMember(Description="The full path of the directory or file.") override var fullName:String? = null /** * The time the current file or directory was last accessed. */ @ApiMember(Description="The time the current file or directory was last accessed.") override var lastAccessTime:Date? = null /** * The name of the file. */ @ApiMember(Description="The name of the file.") override var lastAccessTimeUtc:Date? = null /** * 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.") override var lastWriteTime:Date? = null /** * 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.") override var lastWriteTimeUtc:Date? = null /** * The size, in bytes, of the current file. */ @ApiMember(Description="The size, in bytes, of the current file.") override var length:Long? = null /** * The size, in bytes, of the current file. */ @ApiMember(Description="The size, in bytes, of the current file.") override var userId:Int? = null /** * The file group id. */ @ApiMember(Description="The file group id.") override var groupId:Int? = null /** * 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.") override var othersCanRead:Boolean? = null /** * 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.") override var groupCanExecute:Boolean? = null /** * 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.") override var groupCanWrite:Boolean? = null /** * 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.") override var groupCanRead:Boolean? = null /** * A value that indicates whether the owner can execute this file. */ @ApiMember(Description="A value that indicates whether the owner can execute this file.") override var ownerCanExecute:Boolean? = null /** * 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.") override var ownerCanWrite:Boolean? = null /** * 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.") override var ownerCanRead:Boolean? = null /** * A value that indicates whether others can read from this file. */ @ApiMember(Description="A value that indicates whether others can read from this file.") override var othersCanExecute:Boolean? = null /** * A value that indicates whether others can write into this file. */ @ApiMember(Description="A value that indicates whether others can write into this file.") override var othersCanWrite:Boolean? = null /** * Extensions to the file attributes. */ @ApiMember(Description="Extensions to the file attributes.") override var extensions:HashMap = HashMap() } enum class Verfahren { Cc, Cs, Dc, Fc, Fs, Fa, Km, } interface IElmaCredential { var certificate:PemCertificate? var authSteuernummer:String? var accountId:String? var password:String? } /** * Represents the communication section of an ELMA report document. */ @Api(Description="Represents the communication section of an ELMA report document.") open class ElmaKom { /** * The version number of the ELMAKOM definition. */ @ApiMember(Description="The version number of the ELMAKOM definition.", IsRequired=true, Name="ElmakomVersion") open var elmakomVersion:String? = null /** * The header part of the ELMAKOM definition. */ @ApiMember(Description="The header part of the ELMAKOM definition.", IsRequired=true, Name="ElmaHeader") open var elmaHeader:ElmaHeader? = null /** * The process part of the ELMAKOM definition. */ @ApiMember(Description="The process part of the ELMAKOM definition.", IsRequired=true, Name="ElmaVerfahren") open var elmaVerfahren:ElmaVerfahren? = null } /** * Represents an ELMA protocol report, which the ELMA servers return after a formal verification of a submitted ELMA report. */ @Api(Description="Represents an ELMA protocol report, which the ELMA servers return after a formal verification of a submitted ELMA report.") open class ElmaProtokoll { /** * File name of the processed input ELMA report. */ @ApiMember(Description="File name of the processed input ELMA report.", Name="Dateiname") open var dateiname:String? = null /** * The BZSt (Bundeszentralamt für Steuern) - tax number of the user. 11-character text field that may only consist of two capital letters and 9 digits (0-9). The fiscal authority BZSt provides this number during registration at the BOP (BZSt-Online Portal - https://www.elster.de/bportal/start). The number is available in the private area of the BOP user account under "My BOP" under the "Registration Information" */ @ApiMember(Description="The BZSt (Bundeszentralamt für Steuern) - tax number of the user. 11-character text field that may only consist of two capital letters and 9 digits (0-9). The fiscal authority BZSt provides this number during registration at the BOP (BZSt-Online Portal - https://www.elster.de/bportal/start). The number is available in the private area of the BOP user account under \"My BOP\" under the \"Registration Information\"", IsRequired=true, Name="AuthSteuernummer") open var authSteuernummer:String? = null /** * The account identifier of a BZSt-Online Portal (BOP) user. 10-character text field that may only contain numbers (0-9). */ @ApiMember(Description="The account identifier of a BZSt-Online Portal (BOP) user. 10-character text field that may only contain numbers (0-9).", IsRequired=true, Name="AccountId") open var accountId:String? = null /** * Date on which the request was processed by ELAN (ELMA receiving server at BZSt). */ @ApiMember(Description="Date on which the request was processed by ELAN (ELMA receiving server at BZSt).", Name="VerarbeitungsDatum") open var verarbeitungsDatum:Date? = null /** * Time of processing by ELAN (ELMA receiving server at BZSt). */ @ApiMember(Description="Time of processing by ELAN (ELMA receiving server at BZSt).", Name="VerarbeitungsZeit") open var verarbeitungsZeit:Date? = null /** * The status code of the ELMA process. */ @ApiMember(Description="The status code of the ELMA process.", Name="Status") open var status:Status? = null /** * A brief description of the status. */ @ApiMember(Description="A brief description of the status.", Name="StatusText") open var statusText:String? = null /** * A detailed information on the status. */ @ApiMember(Description="A detailed information on the status.", Name="StatusDetail") open var statusDetail:String? = null /** * User custom ID.This field can be filled with internal reference information of the user. */ @ApiMember(Description="User custom ID.This field can be filled with internal reference information of the user.", Name="KundeneigeneId") open var kundeneigeneId:String? = null /** * Data transfer identifier.Hexadecimal formatted number. Example: 550e8400-e29b-11d4-a716-446655440000 */ @ApiMember(Description="Data transfer identifier.Hexadecimal formatted number. Example: 550e8400-e29b-11d4-a716-446655440000", Name="UUID") open var uuid:UUID? = null } /** * Represents an ELMA protocol report, which the ELMA servers return after a formal verification of a submitted ELMA report. */ @Api(Description="Represents an ELMA protocol report, which the ELMA servers return after a formal verification of a submitted ELMA report.") open class ElmaFehler { /** * File name of the processed input ELMA report. */ @ApiMember(Description="File name of the processed input ELMA report.", Name="Dateiname") open var dateiname:String? = null /** * The BZSt (Bundeszentralamt für Steuern) - tax number of the user. 11-character text field that may only consist of two capital letters and 9 digits (0-9). The fiscal authority BZSt provides this number during registration at the BOP (BZSt-Online Portal - https://www.elster.de/bportal/start). The number is available in the private area of the BOP user account under "My BOP" under the "Registration Information" */ @ApiMember(Description="The BZSt (Bundeszentralamt für Steuern) - tax number of the user. 11-character text field that may only consist of two capital letters and 9 digits (0-9). The fiscal authority BZSt provides this number during registration at the BOP (BZSt-Online Portal - https://www.elster.de/bportal/start). The number is available in the private area of the BOP user account under \"My BOP\" under the \"Registration Information\"", IsRequired=true, Name="AuthSteuernummer") open var authSteuernummer:String? = null /** * The account identifier of a BZSt-Online Portal (BOP) user. 10-character text field that may only contain numbers (0-9). */ @ApiMember(Description="The account identifier of a BZSt-Online Portal (BOP) user. 10-character text field that may only contain numbers (0-9).", IsRequired=true, Name="AccountId") open var accountId:String? = null /** * Date on which the request was processed by ELAN (ELMA receiving server at BZSt). */ @ApiMember(Description="Date on which the request was processed by ELAN (ELMA receiving server at BZSt).", Name="VerarbeitungsDatum") open var verarbeitungsDatum:Date? = null /** * Time of processing by ELAN (ELMA receiving server at BZSt). */ @ApiMember(Description="Time of processing by ELAN (ELMA receiving server at BZSt).", Name="VerarbeitungsZeit") open var verarbeitungsZeit:Date? = null /** * The status code of the ELMA process. */ @ApiMember(Description="The status code of the ELMA process.", Name="FehlerID") open var fehlerID:Status? = null /** * A brief description of the error status. */ @ApiMember(Description="A brief description of the error status.", Name="FehlerText") open var fehlerText:String? = null /** * A detailed information on the status. */ @ApiMember(Description="A detailed information on the status.", Name="FehlerProzess") open var fehlerProzess:String? = null /** * User custom ID.This field can be filled with internal reference information of the user. */ @ApiMember(Description="User custom ID.This field can be filled with internal reference information of the user.", Name="KundeneigeneId") open var kundeneigeneId:String? = null /** * Data transfer identifier.Hexadecimal formatted number. Example: 550e8400-e29b-11d4-a716-446655440000 */ @ApiMember(Description="Data transfer identifier.Hexadecimal formatted number. Example: 550e8400-e29b-11d4-a716-446655440000", Name="UUID") open var uuid:UUID? = null } /** * Represents a base class for a file with raw data. */ @Api(Description="Represents a base class for a file with raw data.") open class FileBase { /** * The raw data content of the file in bytes. */ @ApiMember(Description="The raw data content of the file in bytes.", Name="Content") open var content:ByteArray? = null } interface IFileMetadata { var name:String? var fullName:String? var lastAccessTime:Date? var lastAccessTimeUtc:Date? var lastWriteTime:Date? var lastWriteTimeUtc:Date? var length:Long? var userId:Int? var groupId:Int? var groupCanExecute:Boolean? var groupCanWrite:Boolean? var groupCanRead:Boolean? var ownerCanRead:Boolean? var ownerCanExecute:Boolean? var ownerCanWrite:Boolean? var othersCanRead:Boolean? var othersCanExecute:Boolean? var othersCanWrite:Boolean? var extensions:HashMap? } /** * Represents the header of an ELMA communication section. */ @Api(Description="Represents the header of an ELMA communication section.") open class ElmaHeader { /** * The process-specific report type of an ELMA document.It distinguishes by the type of input. */ @ApiMember(Description="The process-specific report type of an ELMA document.It distinguishes by the type of input.", IsRequired=true, Name="DatenArt") open var datenArt:DatenArt? = null /** * The BZSt (Bundeszentralamt für Steuern) - tax number of the user. 11-character text field that may only consist of two capital letters and 9 digits (0-9). The fiscal authority BZSt provides this number during registration at the BOP (BZSt-Online Portal - https://www.elster.de/bportal/start). The number is available in the private area of the BOP user account under "My BOP" under the "Registration Information" */ @ApiMember(Description="The BZSt (Bundeszentralamt für Steuern) - tax number of the user. 11-character text field that may only consist of two capital letters and 9 digits (0-9). The fiscal authority BZSt provides this number during registration at the BOP (BZSt-Online Portal - https://www.elster.de/bportal/start). The number is available in the private area of the BOP user account under \"My BOP\" under the \"Registration Information\"", IsRequired=true, Name="AuthSteuernummer") open var authSteuernummer:String? = null /** * The account identifier of a BZSt-Online Portal (BOP) user. 10-character text field that may only contain numbers (0-9). */ @ApiMember(Description="The account identifier of a BZSt-Online Portal (BOP) user. 10-character text field that may only contain numbers (0-9).", IsRequired=true, Name="AccountId") open var accountId:String? = null /** * The time of creation.Corresponds to the time, at which the user created a file. */ @ApiMember(Description="The time of creation.Corresponds to the time, at which the user created a file.", Name="ErstellungsDatum") open var erstellungsDatum:Date? = null /** * User custom ID.This field can be filled with internal reference information of the user. */ @ApiMember(Description="User custom ID.This field can be filled with internal reference information of the user.", Name="KundeneigeneId") open var kundeneigeneId:String? = null /** * Data transfer identifier.Hexadecimal formatted number. Example: 550e8400-e29b-11d4-a716-446655440000 */ @ApiMember(Description="Data transfer identifier.Hexadecimal formatted number. Example: 550e8400-e29b-11d4-a716-446655440000", Name="UUID") open var uuid:UUID? = null /** * Distinguishes between test and live data transfer. */ @ApiMember(Description="Distinguishes between test and live data transfer.", Name="Verarbeitungslauf") open var verarbeitungslauf:Verarbeitungslauf? = null } open class ElmaVerfahren { /** * The content of process-specific definition. */ @ApiMember(Description="The content of process-specific definition.", Name="Inhalt") open var inhalt:Object? = null } enum class Status(val value:Int) { ElmaGlobalUnbekannt(0), ElmaOk(8000), ElmaParserFehler(8001), ElmaUngueltigeKodierung(8002), ElmaUngueltigeDateiname(8003), ElmaFalscheBzstnrOderAccountid(8004), ElmaSignaturDateiFehlt(8005), ElmaSignaturPruefungFehlerhaft(8006), ElmaNotwendigeFachlicheBerechtigungenFehlen(8007), ElmaFreischaltungFehlt(8008), ElmaSperreVorhanden(8009), ElmaDateinameBereitsVerwendet(8010), ElmaDateiinhaltIdentisch(8011), ElmaBzstnrOderAccountidStimmtNichtUberein(8012), ElmaTestdaten(8013), } enum class DatenArt { ElmaCc, ElmaCcrm, ElmaCrs, ElmaCrsrm, ElmaDc, ElmaDcrm, ElmaFc, ElmaFcrm, } enum class Verarbeitungslauf { Produktionslauf, Testlauf, }