POST | /async/datenabholungen/protokolle/17/verarbeitungsprotokoll/batch |
---|
"use strict";
export class FileBase {
/** @param {{content?:string}} [init] */
constructor(init) { Object.assign(this, init) }
/**
* @type {string}
* @description The raw data content of the file. */
content;
}
export class PortalCertificate extends FileBase {
/** @param {{id?:string,index?:number,pin?:string,description?:string,tags?:string[],name?:string,content?:string,content?:string}} [init] */
constructor(init) { super(init); Object.assign(this, init) }
/**
* @type {string}
* @description The unique identifier of the certificate. */
id;
/**
* @type {number}
* @description The position of the certificate element in an indexed collection of certificates. */
index;
/**
* @type {?string}
* @description The password to protect the certificate from unauthorized access. */
pin;
/**
* @type {?string}
* @description The description of the certificate. */
description;
/**
* @type {string[]}
* @description Tags that can be used to label or identify the certificate. */
tags;
/**
* @type {?string}
* @description Gets or sets the file name of the certificate. */
name;
/**
* @type {string}
* @description The raw data content of the file. */
content;
}
export class BatchProtokollRequestBase {
/** @param {{zertifikat?:PortalCertificate}} [init] */
constructor(init) { Object.assign(this, init) }
/**
* @type {PortalCertificate}
* @description The authentification certificate. */
zertifikat;
}
/** @typedef {'direkt'|'link'|'sammellink'} */
export var Uebertragungsweg;
(function (Uebertragungsweg) {
Uebertragungsweg["direkt"] = "direkt"
Uebertragungsweg["link"] = "link"
Uebertragungsweg["sammellink"] = "sammellink"
})(Uebertragungsweg || (Uebertragungsweg = {}));
export class Datenpaket {
/** @param {{value?:string}} [init] */
constructor(init) { Object.assign(this, init) }
/**
* @type {?string}
* @description Encoded (compressed and encrypted) requested data record */
value;
}
export class Download {
/** @param {{url?:string,benutzer?:string,passwort?:string}} [init] */
constructor(init) { Object.assign(this, init) }
/**
* @type {?string}
* @description The link to the data on the web server. */
url;
/**
* @type {?string}
* @description The user name for the web server. */
benutzer;
/**
* @type {?string}
* @description Password for the web server. */
passwort;
}
export class Abholung {
/** @param {{id?:string,idnr?:string,veranlagungsjahr?:number,uebertragungsweg?:Uebertragungsweg,encoding?:string,mandantennummer?:string,steuernummer?:string,bescheiddatum?:string,datenpaket?:Datenpaket,download?:Download}} [init] */
constructor(init) { Object.assign(this, init) }
/**
* @type {?string}
* @description The identifier of the data record. */
id;
/**
* @type {?string}
* @description The ID number of the receipt owner. This attribute is only required for the tax type 'ElsterVaStDaten'. */
idnr;
/**
* @type {?number}
* @description The assessment year (YYYY) of the receipt. This attribute is only required for the tax type 'ElsterVaStDaten'. */
veranlagungsjahr;
/**
* @type {?Uebertragungsweg}
* @description The transmission path used. */
uebertragungsweg;
/**
* @type {?string}
* @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. */
encoding;
/**
* @type {?string}
* @description The client number; only applicable to the tax type 'ElsterDIVADaten'. */
mandantennummer;
/**
* @type {?string}
* @description The tax number; only applicable to the tax type 'ElsterDIVADaten'. */
steuernummer;
/**
* @type {?string}
* @description The asessment date; only applicable to the tax type 'ElsterDIVADaten'. */
bescheiddatum;
/**
* @type {?Datenpaket}
* @description Das Datenpaket angeforderter Datensaetze. Nur bei der Direktsendung ueber das ERiClet. */
datenpaket;
/**
* @type {?Download}
* @description Download requested data records. Ensure the second payload data block is empty for bulk retrieval operations. */
download;
}
/** @typedef {'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'} */
export var Steuerart;
(function (Steuerart) {
Steuerart["ESB"] = "ESB"
Steuerart["GSB"] = "GSB"
Steuerart["USB"] = "USB"
Steuerart["EPBescheid"] = "EPBescheid"
Steuerart["EPMitteilung"] = "EPMitteilung"
Steuerart["Gewerbesteuerbescheid"] = "Gewerbesteuerbescheid"
Steuerart["Gewerbesteuermitteilung"] = "Gewerbesteuermitteilung"
Steuerart["GEWMB"] = "GEWMB"
Steuerart["DIVAAnzeigeEinerLotterie"] = "DIVAAnzeigeEinerLotterie"
Steuerart["DIVABescheid"] = "DIVABescheid"
Steuerart["DivaBescheidESt"] = "DivaBescheidESt"
Steuerart["DIVABuchmachersteuer"] = "DIVABuchmachersteuer"
Steuerart["DIVALotteriesteuerEinmal"] = "DIVALotteriesteuerEinmal"
Steuerart["DIVALotteriesteuerMehr"] = "DIVALotteriesteuerMehr"
Steuerart["DIVASportwettensteuer"] = "DIVASportwettensteuer"
Steuerart["DIVATotalisator"] = "DIVATotalisator"
Steuerart["OZGBescheid"] = "OZGBescheid"
Steuerart["VerbindlicheAuskunft"] = "VerbindlicheAuskunft"
Steuerart["VerbindlicheZusage"] = "VerbindlicheZusage"
Steuerart["DivaSonstigerVA"] = "DivaSonstigerVA"
Steuerart["DivaBescheidErbSt"] = "DivaBescheidErbSt"
Steuerart["DivaBescheidFEIN"] = "DivaBescheidFEIN"
Steuerart["DivaBescheidGewSt"] = "DivaBescheidGewSt"
Steuerart["DivaBescheidKSt"] = "DivaBescheidKSt"
Steuerart["DivaBescheidUSt"] = "DivaBescheidUSt"
Steuerart["DivaBescheidSchenkSt"] = "DivaBescheidSchenkSt"
Steuerart["DIVATroncabgabe"] = "DIVATroncabgabe"
Steuerart["DIVAVirtuelleAutomatenStB"] = "DIVAVirtuelleAutomatenStB"
Steuerart["DIVAOnlinePokerStB"] = "DIVAOnlinePokerStB"
Steuerart["LStHVVMRM"] = "LStHVVMRM"
Steuerart["EinlagenrueckgewaehrVA"] = "EinlagenrueckgewaehrVA"
Steuerart["FTTMeldungVA"] = "FTTMeldungVA"
Steuerart["StatusInvStGVA"] = "StatusInvStGVA"
Steuerart["UStVEUVA"] = "UStVEUVA"
Steuerart["VERSVA"] = "VERSVA"
Steuerart["AltZertVA"] = "AltZertVA"
Steuerart["KapEStEntlastungVA"] = "KapEStEntlastungVA"
Steuerart["PostUDLVA"] = "PostUDLVA"
Steuerart["StAb50aVA"] = "StAb50aVA"
Steuerart["StAbEntlastungVA"] = "StAbEntlastungVA"
Steuerart["KassenangelegenheitenVA"] = "KassenangelegenheitenVA"
Steuerart["KStOptVA"] = "KStOptVA"
Steuerart["SteueroasenabwehrVA"] = "SteueroasenabwehrVA"
Steuerart["KDBVollmachtRM"] = "KDBVollmachtRM"
Steuerart["STBKE"] = "STBKE"
Steuerart["VDBKDBRueckmeldungLief"] = "VDBKDBRueckmeldungLief"
Steuerart["AnhangRueckmeldung"] = "AnhangRueckmeldung"
Steuerart["DivaEinwilligungRM"] = "DivaEinwilligungRM"
Steuerart["GlueckspielF"] = "GlueckspielF"
Steuerart["OZGMitteilung"] = "OZGMitteilung"
Steuerart["VerbindlicheAuskunftInfoF"] = "VerbindlicheAuskunftInfoF"
Steuerart["ELOProtokoll"] = "ELOProtokoll"
})(Steuerart || (Steuerart = {}));
/** @typedef {'text'|'base64'} */
export var Coding;
(function (Coding) {
Coding["text"] = "text"
Coding["base64"] = "base64"
})(Coding || (Coding = {}));
export class Meta17 {
/** @param {{name?:string,coding?:Coding,value?:string}} [init] */
constructor(init) { Object.assign(this, init) }
/**
* @type {?string}
* @description The type of metadata, e.g. datei [file] */
name;
/**
* @type {?Coding}
* @description The encoding of the metadata (text or base64) */
coding;
/**
* @type {?string}
* @description The content of the metadata */
value;
}
export class MetaInfoMaps17 {
constructor(init) { Object.assign(this, init) }
}
export class MetaInformationen17 {
/** @param {{meta?:Meta17[],metaInfoMaps?:MetaInfoMaps17}} [init] */
constructor(init) { Object.assign(this, init) }
/**
* @type {Meta17[]}
* @description List of metadata. */
meta;
/**
* @type {?MetaInfoMaps17}
* @description List of meta infomation maps. */
metaInfoMaps;
}
export class Anhaenge17 {
constructor(init) { Object.assign(this, init) }
}
export class Abholung17 extends Abholung {
/** @param {{steuerart?:Steuerart,metaInformationen?:MetaInformationen17,bereitstellungsticket?:string,anhaenge?:Anhaenge17,id?:string,idnr?:string,veranlagungsjahr?:number,uebertragungsweg?:Uebertragungsweg,encoding?:string,mandantennummer?:string,steuernummer?:string,bescheiddatum?:string,datenpaket?:Datenpaket,download?:Download,id?:string,idnr?:string,veranlagungsjahr?:number,uebertragungsweg?:Uebertragungsweg,encoding?:string,mandantennummer?:string,steuernummer?:string,bescheiddatum?:string,datenpaket?:Datenpaket,download?:Download}} [init] */
constructor(init) { super(init); Object.assign(this, init) }
/**
* @type {?Steuerart}
* @description The tax type (e.g. ESB) of the data record. */
steuerart;
/**
* @type {?MetaInformationen17}
* @description The meta information of the identifier. */
metaInformationen;
/**
* @type {?string}
* @description Die Transfertickets der Datensaetze. Es duerfen max. 100 Bereitstellungstickets in einem Request angegeben werden. */
bereitstellungsticket;
/**
* @type {?Anhaenge17}
* @description The attachments of the data records. */
anhaenge;
/**
* @type {?string}
* @description The identifier of the data record. */
id;
/**
* @type {?string}
* @description The ID number of the receipt owner. This attribute is only required for the tax type 'ElsterVaStDaten'. */
idnr;
/**
* @type {?number}
* @description The assessment year (YYYY) of the receipt. This attribute is only required for the tax type 'ElsterVaStDaten'. */
veranlagungsjahr;
/**
* @type {?Uebertragungsweg}
* @description The transmission path used. */
uebertragungsweg;
/**
* @type {?string}
* @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. */
encoding;
/**
* @type {?string}
* @description The client number; only applicable to the tax type 'ElsterDIVADaten'. */
mandantennummer;
/**
* @type {?string}
* @description The tax number; only applicable to the tax type 'ElsterDIVADaten'. */
steuernummer;
/**
* @type {?string}
* @description The asessment date; only applicable to the tax type 'ElsterDIVADaten'. */
bescheiddatum;
/**
* @type {?Datenpaket}
* @description Das Datenpaket angeforderter Datensaetze. Nur bei der Direktsendung ueber das ERiClet. */
datenpaket;
/**
* @type {?Download}
* @description Download requested data records. Ensure the second payload data block is empty for bulk retrieval operations. */
download;
}
export class BatchProtokollRequestBase17 extends BatchProtokollRequestBase {
/** @param {{bescheide?:Abholung17[],zertifikat?:PortalCertificate,zertifikat?:PortalCertificate}} [init] */
constructor(init) { super(init); Object.assign(this, init) }
/**
* @type {Abholung17[]}
* @description The tax assessements, whose processing records shall be obtained. */
bescheide;
/**
* @type {PortalCertificate}
* @description The authentification certificate. */
zertifikat;
}
export class BatchProtokollRequest17Async extends BatchProtokollRequestBase17 {
/** @param {{bescheide?:Abholung17[],zertifikat?:PortalCertificate,bescheide?:Abholung17[],zertifikat?:PortalCertificate,zertifikat?:PortalCertificate}} [init] */
constructor(init) { super(init); Object.assign(this, init) }
/**
* @type {Abholung17[]}
* @description The tax assessements, whose processing records shall be obtained. */
bescheide;
/**
* @type {PortalCertificate}
* @description The authentification certificate. */
zertifikat;
}
JavaScript 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 } } } ]