e-Invoicing API
System Preparation
Configuration
For issuing e-invoicing messages the configuration of base data (company, location and e-invoicing) is required. Details on maintaining the configuration can be found in the chapter API - Base data/company header data and Cfg - Configuration
It is important to fill in the "ContactElectronicMail" field in the configuration so that in case of an error the creator of the e-invoice receives an email notification.
Application Programming Interface (API)
This chapter shows the extensions to the existing ESR specification.
First of all you have to trigger the electronic delivery of a transaction document.
To do so please specify Document Delivery ESR.DD, e.g.: DD="IT"
. Secondly, you must also specify the recipient of the Document Delivery (DDto).
In the Document Delivery (DDto) field, the delimiter ;
can be used to add additional information.
Attribute | Description | Example |
---|---|---|
ESR.DD | System with which the e-invoice is transmitted. Only the country code needs to be specified. A special system can also be specified. | "DE" "IT" "IT-FatturaPA" |
ESR.DDto | Unique Recipient of the e-invoice. see table below. |
Country (DD) | Name | Description | Example for DDto |
---|---|---|---|
DE | Leitweg ID (B2G) | The Leitweg ID is an identifier of an electronic invoice for the unique addressing of public contracting authorities in Germany | "0204:991-33333TEST-33" |
DE | E-Mail (B2B) | E-Mail adress of the receiver | "j.doe@efsta.eu" |
IT | Codice Destinatario (B2B) | The Codice Destinatario is used for sending tax documents in XML format to the Exchange System. | "VSRLPXY" |
IT | Codice Fiscale (B2B) | Codice Fiscale is a code used for tax and administrative purposes to uniquely identify Italian citizens. | "TMBLRT66T19A944Z" |
IT | PEC Destinario (B2B) | For PEC Destinario, an email address can be specified in addition to the Codice Destinatario or Codice Fiscale | "TMBLRT66T19A944Z;j.doe@efsta.eu" |
Customer data
Different from issuing simplified invoices, electronic documents always require full identification of the customer, including additional address information for the transport system. It is recommended to provide a well-maintained customer database on POS software side, and eventually a function to enter data of walk-in customers. Details about customer data can be found at Ctm Elements.
Customer data is mandatory for e-Invoice. For B2B invoices, a TaxId must always be specified.
Additional invoice information
This information can optionally be sent with the invoice. It is in addition to the normal invoice. Details on the UBL attributes can be found at https://docs.peppol.eu/poacc/billing/3.0/syntax/ubl-invoice/tree/
Attribute | Description | Example |
---|---|---|
ESR.UBL_DueDate | Due date of payment. Only to be specified, if it differs from Terms of payment. | "2024-08-15" |
UBL_Contact | ||
UBL_Person | ||
ESR.UBL_PaymentTerms | Terms of the payment. Only to be specified, if it differs from the Terms of payment in the configuration. | "30 days net" |
ESR.UBL_Delivery.D | The date on which the supply of goods or services was delivered | "2024-07-08" |
ESR.UBL_Delivery.Adr | The address where the delivery was made | |
ESR.UBL_Delivery.Adr2 | The address extension where the delivery was made | |
ESR.UBL_Delivery.City | The city where the delivery was made | |
ESR.UBL_Delivery.Zip | The postcode where the delivery was made | |
ESR.UBL_Delivery.Country | The country code where the delivery was made | |
ESR.UBL_ProfileID | https://docs.peppol.eu/poacc/billing/3.0/syntax/ubl-invoice/cbc-ProfileID | |
ESR.UBL_BuyerReference | An identifier assigned by the Buyer used for internal routing purposes. An invoice must have buyer reference or purchase order reference (BT-13). | |
ESR.UBL_OrderReference | ||
ESR.UBL_ContractDocumentReference | The identification of a contract. | |
ESR.UBL_ProjectReference | The identification of the project the invoice refers to. | |
ESR.UBL_Supplier.Name | The Name of the supplier. Only to be specified, if it differs from the ContactName in the configuration. | "John Doe" |
ESR.UBL_Supplier.Telephone | The contact phone number of the supplier. Only to be specified, if it differs from the ContactTelephone in the configuration. | "123456789" |
ESR.UBL_Supplier.ContactElectronicMail | The E-Mail address of the supplier. Only to be specified, if it differs from the ContactElectronicMail in the configuration. | "j.doe@efsta.eu" |
ESR.UBL_Payee.Nam | The name of the payee. Only to be specified, if it differs from the Nam field of the Customer object. | |
ESR.UBL_Payee.TaxId | The VAT number of the payee. Only to be specified, if it differs from the TaxId field of the Customer object. | |
ESR.UBL_Payee.GLN | The GLN number of the payee. | |
ESR.UBL_Payee.Adr | The address of the payee. Only to be specified, if it differs from the Adr field of the Customer object. | |
ESR.UBL_Payee.Adr2 | The address extension of the payee. Only to be specified, if it differs from the Adr2 field of the Customer object. | |
ESR.UBL_Payee.City | The city Name of the payee. Only to be specified, if it differs from the City field of the Customer object. | |
ESR.UBL_Payee.Zip | The postcode of the payee. Only to be specified, if it differs from the Zip field of the Customer object. | |
ESR.UBL_Payee.Ctry | The country code of the payee. Only to be specified, if it differs from the Ctry field of the Customer object. | |
Pos.UBL_OrderLineReference | ||
Pos.UBL_TaxExemptionReasonCode | A coded statement of the reason for why the amount is exempted from VAT. | |
Pos.UBL_TaxExemptionReason |
Example Request
- JSON
- XML
{"Tra":
{"ESR":
{"DD":"IT", "DDto": "CRCCLL95S67H501V",
"Ctm":
{"Nam":"The Buyercompany Inc", "Zip":"15000", "City":"Metropolis",
"TaxId":"IT123456789"},
"PosA":[
{"PN":"1", "IN":"4712", "Dsc":"Bike", "TaxG":"A", "Amt":"499.00"},
{"_":"Mod", "PN":"1", "Dsc":"Discount", "Amt":"-10.00"},
{"PN":"2", "Dsc":"helmet", "TaxG":"A", "Amt":"39.90"}],
"PayA":[
{"Dsc":"creditcard", "PayG":"creditcard", "Amt":"528.90"}
]
}
}
}
<Tra>
<ESR DD="IT" DDto="CRCCLL95S67H501V">
<Ctm Nam="The Buyercompany Inc" Zip="15000" City="Metropolis"
TaxId="IT123456789"/>
<PosA>
<Pos PN="1" IN="4712" Dsc="Bike" TaxG="A" Amt="499.00"/>
<Mod PN="1" Dsc="Discount" Amt="-10.00"/>
<Pos PN="2" Dsc="helmet" TaxG="A" Amt="39.90"/>
</PosA>
<PayA>
<Pay Dsc="creditcard" PayG="creditcard" Amt="528.90"/>
</PayA>
</ESR>
</Tra>
Workflow
The workflow for the /register REST request follows the usual POS rules, except that additional formal checks on the data supplied are performed. In case of an invalid XML result, the request is rejected with <Result RC="BAD" ErrorCode="xxx"/> (http status code 406) giving the code of the validation rule that failed. Fix eventual errors during development to avoid problems in production environment. Since the validation of the data (recipient) takes place online, the request can take up to 5 seconds longer than a normal transaction.
If the EFR is offline when you create an e-invoice, validation will be skipped and the e-invoice will be temporarily stored on the EFR. As soon as the EFR service is back online, the e-invoice will be sent. In this case, a validation error may occur after the e-invoice has been created and the e-invoice cannot be delivered.
Error Handling
The formal rules of an e-Invoice exceed the data required for a normal receipt and have to stand automatic check routines, that are performed before fiscalization and delivery (e.g. .xsd validation). In case of severe error HTTP StatusCode 406, RC="BAD" is delivered by EFR.
To find out more details about a failed transaction see directory
/EFR/rn/def/log/{yyyymmddhhmmss}
.log, where request and XML data is stored. Explanation
for errors can be found in the internet, use "UBL" and the error code for searching.
In case of a temporary delivery failure (internet outage), the delivery will be retried 24 hours, after that the document is forwarded to EFSTA cloud for further treatment in the Portal.
If the document cannot be delivered because of an error of the receiver, the forwarding is done immediately.