POST | /async/datenabholungen/protokolle/17/verarbeitungsprotokoll/batch |
---|
using System;
using System.Collections;
using System.Collections.Generic;
using System.Runtime.Serialization;
using ServiceStack;
using ServiceStack.DataAnnotations;
using PwC.xEric.Core.Services.Contracts.Datenabholungen.Requests.Protokolle;
using PwC.xEric.Core.Domain.Concretes.Models;
using PwC.DigitalHub.Utilities.IO.Core.Contracts.Models;
using PwC.xEric.Core.Domain.Concretes.Datenabholungen.Models;
namespace PwC.DigitalHub.Utilities.IO.Core.Contracts.Models
{
///<summary>
///Represents a base class for a file with raw data.
///</summary>
[Api(Description="Represents a base class for a file with raw data.")]
public partial class FileBase
{
public FileBase()
{
Content = new byte[]{};
}
///<summary>
///The raw data content of the file.
///</summary>
[ApiMember(Description="The raw data content of the file.", Name="Content")]
public virtual byte[] Content { get; set; }
}
}
namespace PwC.xEric.Core.Domain.Concretes.Datenabholungen.Models
{
///<summary>
///Represents the request to retrieve tax assessments by means of a specfied ID.
///</summary>
[Api(Description="Represents the request to retrieve tax assessments by means of a specfied ID.")]
public partial class Abholung
{
///<summary>
///The identifier of the data record.
///</summary>
[ApiMember(Description="The identifier of the data record.")]
public virtual string Id { get; set; }
///<summary>
///The ID number of the receipt owner. This attribute is only required for the tax type 'ElsterVaStDaten'.
///</summary>
[ApiMember(Description="The ID number of the receipt owner. This attribute is only required for the tax type 'ElsterVaStDaten'.")]
public virtual string Idnr { get; set; }
///<summary>
///The assessment year (YYYY) of the receipt. This attribute is only required for the tax type 'ElsterVaStDaten'.
///</summary>
[ApiMember(Description="The assessment year (YYYY) of the receipt. This attribute is only required for the tax type 'ElsterVaStDaten'.")]
public virtual int? Veranlagungsjahr { get; set; }
///<summary>
///The transmission path used.
///</summary>
[ApiMember(Description="The transmission path used.")]
public virtual Uebertragungsweg? Uebertragungsweg { get; set; }
///<summary>
///The character encoding of the data record (e.g. ISO-8859-15). The exception is the data type ElsterVaStDaten, here we submit KEIN ENCODING.
///</summary>
[ApiMember(Description="The character encoding of the data record (e.g. ISO-8859-15). The exception is the data type ElsterVaStDaten, here we submit KEIN ENCODING.")]
public virtual string Encoding { get; set; }
///<summary>
///The client number; only applicable to the tax type 'ElsterDIVADaten'.
///</summary>
[ApiMember(Description="The client number; only applicable to the tax type 'ElsterDIVADaten'.")]
public virtual string Mandantennummer { get; set; }
///<summary>
///The tax number; only applicable to the tax type 'ElsterDIVADaten'.
///</summary>
[ApiMember(Description="The tax number; only applicable to the tax type 'ElsterDIVADaten'.")]
public virtual string Steuernummer { get; set; }
///<summary>
///The asessment date; only applicable to the tax type 'ElsterDIVADaten'.
///</summary>
[ApiMember(Description="The asessment date; only applicable to the tax type 'ElsterDIVADaten'.")]
public virtual DateTime? Bescheiddatum { get; set; }
///<summary>
///Das Datenpaket angeforderter Datensaetze. Nur bei der Direktsendung ueber das ERiClet.
///</summary>
[ApiMember(Description="Das Datenpaket angeforderter Datensaetze. Nur bei der Direktsendung ueber das ERiClet.")]
public virtual Datenpaket Datenpaket { get; set; }
///<summary>
///Download requested data records. Ensure the second payload data block is empty for bulk retrieval operations.
///</summary>
[ApiMember(Description="Download requested data records. Ensure the second payload data block is empty for bulk retrieval operations.")]
public virtual Download Download { get; set; }
}
///<summary>
///Represents a request to retrieve data records by means of one or more IDs.
///</summary>
[Api(Description="Represents a request to retrieve data records by means of one or more IDs.")]
public partial class Abholung17
: Abholung
{
///<summary>
///The tax type (e.g. ESB) of the data record.
///</summary>
[ApiMember(Description="The tax type (e.g. ESB) of the data record.")]
public virtual Steuerart? Steuerart { get; set; }
///<summary>
///The meta information of the identifier.
///</summary>
[ApiMember(Description="The meta information of the identifier.")]
public virtual MetaInformationen17 MetaInformationen { get; set; }
///<summary>
///Die Transfertickets der Datensaetze. Es duerfen max. 100 Bereitstellungstickets in einem Request angegeben werden.
///</summary>
[ApiMember(Description="Die Transfertickets der Datensaetze. Es duerfen max. 100 Bereitstellungstickets in einem Request angegeben werden.")]
public virtual string Bereitstellungsticket { get; set; }
///<summary>
///The attachments of the data records.
///</summary>
[ApiMember(Description="The attachments of the data records.")]
public virtual Anhaenge17 Anhaenge { get; set; }
///<summary>
///The identifier of the data record.
///</summary>
[ApiMember(Description="The identifier of the data record.")]
public virtual string Id { get; set; }
///<summary>
///The ID number of the receipt owner. This attribute is only required for the tax type 'ElsterVaStDaten'.
///</summary>
[ApiMember(Description="The ID number of the receipt owner. This attribute is only required for the tax type 'ElsterVaStDaten'.")]
public virtual string Idnr { get; set; }
///<summary>
///The assessment year (YYYY) of the receipt. This attribute is only required for the tax type 'ElsterVaStDaten'.
///</summary>
[ApiMember(Description="The assessment year (YYYY) of the receipt. This attribute is only required for the tax type 'ElsterVaStDaten'.")]
public virtual int? Veranlagungsjahr { get; set; }
///<summary>
///The transmission path used.
///</summary>
[ApiMember(Description="The transmission path used.")]
public virtual Uebertragungsweg? Uebertragungsweg { get; set; }
///<summary>
///The character encoding of the data record (e.g. ISO-8859-15). The exception is the data type ElsterVaStDaten, here we submit KEIN ENCODING.
///</summary>
[ApiMember(Description="The character encoding of the data record (e.g. ISO-8859-15). The exception is the data type ElsterVaStDaten, here we submit KEIN ENCODING.")]
public virtual string Encoding { get; set; }
///<summary>
///The client number; only applicable to the tax type 'ElsterDIVADaten'.
///</summary>
[ApiMember(Description="The client number; only applicable to the tax type 'ElsterDIVADaten'.")]
public virtual string Mandantennummer { get; set; }
///<summary>
///The tax number; only applicable to the tax type 'ElsterDIVADaten'.
///</summary>
[ApiMember(Description="The tax number; only applicable to the tax type 'ElsterDIVADaten'.")]
public virtual string Steuernummer { get; set; }
///<summary>
///The asessment date; only applicable to the tax type 'ElsterDIVADaten'.
///</summary>
[ApiMember(Description="The asessment date; only applicable to the tax type 'ElsterDIVADaten'.")]
public virtual DateTime? Bescheiddatum { get; set; }
///<summary>
///Das Datenpaket angeforderter Datensaetze. Nur bei der Direktsendung ueber das ERiClet.
///</summary>
[ApiMember(Description="Das Datenpaket angeforderter Datensaetze. Nur bei der Direktsendung ueber das ERiClet.")]
public virtual Datenpaket Datenpaket { get; set; }
///<summary>
///Download requested data records. Ensure the second payload data block is empty for bulk retrieval operations.
///</summary>
[ApiMember(Description="Download requested data records. Ensure the second payload data block is empty for bulk retrieval operations.")]
public virtual Download Download { get; set; }
}
///<summary>
///Represents a list of attachments.
///</summary>
public partial class Anhaenge17
{
}
///<summary>
///Specifies the encoding of the metadata.
///</summary>
public enum Coding
{
text,
base64,
}
///<summary>
///The data packet from the retrieval operation.
///</summary>
[Api(Description="The data packet from the retrieval operation.")]
public partial class Datenpaket
{
///<summary>
///Encoded (compressed and encrypted) requested data record
///</summary>
[ApiMember(Description="Encoded (compressed and encrypted) requested data record")]
public virtual string Value { get; set; }
}
///<summary>
///Represents the download of requested records. The downloaded content from the web server takes place: a) with https b) on port 443 c) on datenabholung1.elster.de or datenabholung2.elster.de. The HTTP Basic Authentication mechanism according to RFC 2617 is used for authentication.
///</summary>
[Api(Description="Represents the download of requested records. The downloaded content from the web server takes place: a) with https b) on port 443 c) on datenabholung1.elster.de or datenabholung2.elster.de. The HTTP Basic Authentication mechanism according to RFC 2617 is used for authentication.")]
public partial class Download
{
///<summary>
///The link to the data on the web server.
///</summary>
[ApiMember(Description="The link to the data on the web server.")]
public virtual string Url { get; set; }
///<summary>
///The user name for the web server.
///</summary>
[ApiMember(Description="The user name for the web server.")]
public virtual string Benutzer { get; set; }
///<summary>
///Password for the web server.
///</summary>
[ApiMember(Description="Password for the web server.")]
public virtual string Passwort { get; set; }
}
///<summary>
///Represents the metadata of a data record.
///</summary>
[Api(Description="Represents the metadata of a data record.")]
public partial class Meta17
{
///<summary>
///The type of metadata, e.g. datei [file]
///</summary>
[ApiMember(Description="The type of metadata, e.g. datei [file]")]
public virtual string Name { get; set; }
///<summary>
///The encoding of the metadata (text or base64)
///</summary>
[ApiMember(Description="The encoding of the metadata (text or base64)")]
public virtual Coding? Coding { get; set; }
///<summary>
///The content of the metadata
///</summary>
[ApiMember(Description="The content of the metadata")]
public virtual string Value { get; set; }
}
///<summary>
///Represents a list of meta information maps.
///</summary>
public partial class MetaInfoMaps17
{
}
///<summary>
///Represents meta information.
///</summary>
[Api(Description="Represents meta information.")]
public partial class MetaInformationen17
{
public MetaInformationen17()
{
Meta = new List<Meta17>{};
}
///<summary>
///List of metadata.
///</summary>
[ApiMember(Description="List of metadata.")]
public virtual List<Meta17> Meta { get; set; }
///<summary>
///List of meta infomation maps.
///</summary>
[ApiMember(Description="List of meta infomation maps.")]
public virtual MetaInfoMaps17 MetaInfoMaps { get; set; }
}
///<summary>
///Represents the various tax types for the retrieval of data.
///</summary>
public enum Steuerart
{
ESB,
GSB,
USB,
EPBescheid,
EPMitteilung,
Gewerbesteuerbescheid,
Gewerbesteuermitteilung,
GEWMB,
DIVAAnzeigeEinerLotterie,
DIVABescheid,
DivaBescheidESt,
DIVABuchmachersteuer,
DIVALotteriesteuerEinmal,
DIVALotteriesteuerMehr,
DIVASportwettensteuer,
DIVATotalisator,
OZGBescheid,
VerbindlicheAuskunft,
VerbindlicheZusage,
DivaSonstigerVA,
DivaBescheidErbSt,
DivaBescheidFEIN,
DivaBescheidGewSt,
DivaBescheidKSt,
DivaBescheidUSt,
DivaBescheidSchenkSt,
DIVATroncabgabe,
DIVAVirtuelleAutomatenStB,
DIVAOnlinePokerStB,
LStHVVMRM,
EinlagenrueckgewaehrVA,
FTTMeldungVA,
StatusInvStGVA,
UStVEUVA,
VERSVA,
AltZertVA,
KapEStEntlastungVA,
PostUDLVA,
StAb50aVA,
StAbEntlastungVA,
KassenangelegenheitenVA,
KStOptVA,
SteueroasenabwehrVA,
KDBVollmachtRM,
STBKE,
VDBKDBRueckmeldungLief,
AnhangRueckmeldung,
DivaEinwilligungRM,
GlueckspielF,
OZGMitteilung,
VerbindlicheAuskunftInfoF,
ELOProtokoll,
}
///<summary>
///Represents the transmission path.
///</summary>
public enum Uebertragungsweg
{
direkt,
link,
sammellink,
}
}
namespace PwC.xEric.Core.Domain.Concretes.Models
{
///<summary>
///Represents a portal certificate that is protected by a password.
///</summary>
[Api(Description="Represents a portal certificate that is protected by a password.")]
public partial class PortalCertificate
: FileBase, ISecuredCertificate, IHasIndex
{
public PortalCertificate()
{
Tags = new List<string>{};
Content = new byte[]{};
}
///<summary>
///The unique identifier of the certificate.
///</summary>
[ApiMember(Description="The unique identifier of the certificate.")]
public virtual Guid Id { get; set; }
///<summary>
///The position of the certificate element in an indexed collection of certificates.
///</summary>
[ApiMember(Description="The position of the certificate element in an indexed collection of certificates.")]
public virtual int Index { get; set; }
///<summary>
///The password to protect the certificate from unauthorized access.
///</summary>
[StringLength(255)]
[ApiMember(Description="The password to protect the certificate from unauthorized access.")]
public virtual string Pin { get; set; }
///<summary>
///The description of the certificate.
///</summary>
[StringLength(int.MaxValue)]
[ApiMember(Description="The description of the certificate.")]
public virtual string Description { get; set; }
///<summary>
///Tags that can be used to label or identify the certificate.
///</summary>
[ApiMember(Description="Tags that can be used to label or identify the certificate.")]
public virtual List<string> Tags { get; set; }
///<summary>
///Gets or sets the file name of the certificate.
///</summary>
[ApiMember(Description="Gets or sets the file name of the certificate.")]
public virtual string Name { get; set; }
///<summary>
///The raw data content of the file.
///</summary>
[ApiMember(Description="The raw data content of the file.", Name="Content")]
public virtual byte[] Content { get; set; }
}
}
namespace PwC.xEric.Core.Services.Contracts.Datenabholungen.Requests.Protokolle
{
///<summary>
///Represents the service request to retrieve logs about tax statements.
///</summary>
[Api(Description="Represents the service request to retrieve logs about tax statements.")]
public partial class BatchProtokollRequest17Async
: BatchProtokollRequestBase17
{
public BatchProtokollRequest17Async()
{
Bescheide = new List<Abholung17>{};
}
///<summary>
///The tax assessements, whose processing records shall be obtained.
///</summary>
[ApiMember(Description="The tax assessements, whose processing records shall be obtained.", Name="Bescheide")]
public virtual List<Abholung17> Bescheide { get; set; }
///<summary>
///The authentification certificate.
///</summary>
[ApiMember(Description="The authentification certificate.", IsRequired=true, Name="Zertifikat")]
public virtual PortalCertificate Zertifikat { get; set; }
}
///<summary>
///Represents a base service request to retrieve processing records from specified tax statements.
///</summary>
[Api(Description="Represents a base service request to retrieve processing records from specified tax statements.")]
public partial class BatchProtokollRequestBase
: IPost
{
///<summary>
///The authentification certificate.
///</summary>
[ApiMember(Description="The authentification certificate.", IsRequired=true, Name="Zertifikat")]
public virtual PortalCertificate Zertifikat { get; set; }
}
///<summary>
///Represents a base service request to retrieve processing records from specified tax statements. Applicable to version 17..
///</summary>
[Api(Description="Represents a base service request to retrieve processing records from specified tax statements. Applicable to version 17..")]
public partial class BatchProtokollRequestBase17
: BatchProtokollRequestBase
{
public BatchProtokollRequestBase17()
{
Bescheide = new List<Abholung17>{};
}
///<summary>
///The tax assessements, whose processing records shall be obtained.
///</summary>
[ApiMember(Description="The tax assessements, whose processing records shall be obtained.", Name="Bescheide")]
public virtual List<Abholung17> Bescheide { get; set; }
///<summary>
///The authentification certificate.
///</summary>
[ApiMember(Description="The authentification certificate.", IsRequired=true, Name="Zertifikat")]
public virtual PortalCertificate Zertifikat { get; set; }
}
}
C# BatchProtokollRequest17Async DTOs
To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=jsv
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /async/datenabholungen/protokolle/17/verarbeitungsprotokoll/batch HTTP/1.1
Host: taxfiling.pwc.de
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
bescheide:
[
{
steuerart: ESB,
metaInformationen:
{
meta:
[
{
name: String,
coding: text,
value: String
}
],
metaInfoMaps:
[
{
typ: String,
meta:
[
{
name: String,
coding: text,
value: String
}
]
}
]
},
bereitstellungsticket: String,
anhaenge:
[
{
metadatenAnhang:
[
{
schluesselAnhang:
{
dateibezeichnungID: String,
dateibezeichnungKurz: String,
value: String
},
wertAnhang:
{
dateibezeichnungID: String,
dateibezeichnungKurz: String,
value: String
}
}
],
dateibezeichnung: String,
dateityp: String,
dateiinhalt: String
}
],
id: String,
idnr: String,
veranlagungsjahr: 0,
uebertragungsweg: direkt,
encoding: String,
mandantennummer: String,
steuernummer: String,
bescheiddatum: 0001-01-01,
datenpaket:
{
value: String
},
download:
{
url: String,
benutzer: String,
passwort: String
}
}
],
zertifikat:
{
id: 00000000000000000000000000000000,
index: 0,
pin: String,
description: String,
tags:
[
String
],
name: String,
content: AA==
}
}
HTTP/1.1 200 OK Content-Type: text/jsv Content-Length: length [ { protokoll: { version: 0, zeitStempel: 0001-01-01, datenTeil: { transferTicket: String, code: 0, text: String, nutzdatenbloecke: [ { nutzdatenTicket: String, code: 0, text: String, verarbeiteteNds: 0, nichtverarbeiteteNds: 0, ndSFehler: [ { lfdNr: String, kmId: String, ordnungsMerkmal: String, fehlerNummer: 0, fehlerText: String } ] } ] } }, id: String, index: 0, responseStatus: { errorCode: String, message: String, stackTrace: String, errors: [ { errorCode: String, fieldName: String, message: String, meta: { String: String } } ], meta: { String: String } } } ]