eInvoicing/README.md

93 lines
2.8 KiB
Markdown
Raw Normal View History

# eInvoicing
Tools for working with eInvoicing according to EU standard EU 16931.
As ZUGFeRD 2 and Factur-X unified their specification, these two names are used synonymously and interchangeably
throughout the documentation and code.
## Reading
### Extract eInvoice from a PDF or XML file:
```kotlin
val reader = EInvoiceReader()
// extract invoice data from a ZUGFeRD or Factor-X PDF that contains eInvoice XML as attachment
val invoiceFromPDF = reader.extractFromPdf(File("ZUGFeRD.pdf"))
// extract eInvoice data from a XML file like XRechnung:
val invoiceFromXml = reader.extractFromXml(File("XRechnung.xml"))
```
### Find all invoices of an IMAP email account
```kotlin
val emailsFetcher = EmailsFetcher()
2024-11-15 17:15:41 +00:00
val fetchResult = emailsFetcher.fetchAllEmails(EmailAccount(
username = "", // your email account username
password = "", // your email account username
2024-11-15 17:15:41 +00:00
serverAddress = "", // IMAP server address
2024-11-26 00:34:51 +00:00
port = null // IMAP server port, can be left null for default port 993
2024-11-15 17:15:41 +00:00
))
fetchResult.emails.forEach { email ->
println("${email.sender}: ${email.attachments.firstNotNullOfOrNull { it.invoice }?.totalAmounts?.duePayableAmount}")
}
2024-11-15 17:15:41 +00:00
```
### Validate eInvoice
```kotlin
val validator = EInvoiceValidator()
val invoiceFile = File("ZUGFeRD.pdf") // or XRechnung,xml, ...
val result = validator.validate(invoiceFile)
println("Is valid? ${result.isValid}")
println(result.report)
```
2024-11-15 17:15:41 +00:00
## Create eInvoice
```kotlin
fun create() {
val invoice = createInvoice()
val pdfResultFile = File.createTempFile("Zugferd", ".pdf")
val creator = EInvoiceCreator()
// create a PDF that also contains the eInvoice as XML attachment
creator.createPdfWithAttachedXml(invoice, pdfResultFile)
2024-11-15 17:15:41 +00:00
// create only the XML file
val xml = creator.createFacturXXml(invoice)
2024-11-15 17:15:41 +00:00
// create a XRechnung
val xRechnung = creator.createXRechnungXml(invoice)
}
private fun createInvoice() = Invoice(
2024-12-02 03:08:29 +00:00
details = InvoiceDetails("RE-00001", LocalDate.now()),
supplier = Party("codinux GmbH & Co. KG", "Fun Street 1", null, "12345", "Glückstadt"),
customer = Party("Abzock GmbH", "Ausbeutstr.", null, "12345", "Abzockhausen"),
items = listOf(InvoiceItem("Erbrachte Dienstleistungen", BigDecimal(170), "HUR", BigDecimal(105), BigDecimal(19))) // HUR = EN code for hour
2024-11-15 17:15:41 +00:00
)
```
### Attach invoice XML to existing PDF
```kotlin
val invoice: Invoice = createInvoice()
val existingPdf = File("Invoice.pdf")
val output = File("Zugferd.pdf")
val creator = EInvoiceCreator()
creator.attachInvoiceXmlToPdf(invoice, existingPdf, output)
// or if you already have the invoice XML:
val invoiceXml = creator.createXRechnungXml(invoice) // or creator.createZugferdXml(invoice), ...
creator.attachInvoiceXmlToPdf(invoiceXml, EInvoiceXmlFormat.XRechnung, existingPdf, output)
```