Peppol (Pan-European Public Procurement On-Line) is a global network for electronic document exchange, widely adopted for e-invoicing across multiple countries. It provides a standardized protocol for companies to exchange business documents like invoices, credit notes, and purchase orders.The Peppol network is particularly popular in:
Nordic countries (Norway, Finland)
Asia-Pacific region (Japan, Singapore, Malaysia, Australia, New Zealand)
Several EU countries for business-to-government invoicing (Germany, Italy, Croatia)
Invopop allows you to send and receive documents through the Peppol network using a single integration while continuing to work with our GOBL format.This guide walks you through the steps to register a company in Invopop and then issue and receive invoices on its behalf.
Letโs prepare your workspace to work with Peppol. Weโll configure the Peppol app and create three workflows:
Invoice issuance workflow: Send invoices through the Peppol network
Invoice reception workflow: Receive invoices from the Peppol network
Party registration workflow: Programmatically onboard companies (Parties) with Invopop
If you only want to send invoices through Peppol, you can skip step 3 and 4 of the setup. Alternatively, if you only want to receive invoices through Peppol, you can skip step 2.The Peppol app is designed to only send and receive the document, generating and importing the appropriate file is delegated to format specific apps such as Oasis UBL or UN/CEFACT CII. This is done to keep the Peppol app simple and focused on the Peppol protocol, while allowing you to use the format that best suits your needs.
1
Connect the Peppol app
Within the Console, navigate to Configuration โ Apps
Find the Peppol app in the list
Click Connect to activate it. The Peppol app should now appear in the list of Enabled apps
2
Configure a workflow to issue invoices
Now weโll create the workflow that converts invoices to a valid Peppol format and sends them through the Peppol network. In this example, weโll generate a Peppol BIS Billing UBL 3.0 document.Skip this step if you only want to receive invoices via Peppol.
Template
Code
Build from scratch
Peppol issue invoice workflow
This workflow convert a GOBL document into the Peppol format and sends it to the network
In Console create a new workflow and select Empty Invoice workflow in the template selector, then add the following steps:
Import Peppol Document - Add two conditions with codes UBL and CII to handle both formats.
Import UBL Document - Add this to the condition with UBL.
Import CII Document - Add this to the condition with CII.
Set State - to Registered.
Send Webhook (optional) - let your services know a Peppol document was received.
Finally, in the Error Handling area, add the Set State action and select Error.
4
Configure the Peppol app
Within the Console, navigate to Configuration โ Apps, find the Peppol App and click Configure. Youโll need to set two fields:
Incoming Workflow: Select the Receive Invoice Workflow created in Step 3. This is where the app will send incoming invoices (expenses) received from the Peppol network.
5
Configure a Party registration workflow
This workflow onboards companies (Peppol participants) to Invopop before they can issue or receive invoices. If youโre managing your own invoices only, you may use this workflow just once. However, if youโre offering Peppol to your customers through Invopop (white-label use case), youโll run this workflow for each merchant you onboard.
Template
Code
Build from scratch
Peppol supplier registration workflow
Onboards Peppol participants by sending a registration link
Example Peppol register party invoice workflow with states
{ "name": "Register Peppol party", "description": "Onboards participants before they can issue or receive invoices", "steps": [ { "id": "0adf46e0-8fdb-11f0-a8fb-61ec9e5a76ba", "name": "Register Party for Approval", "provider": "peppol.register.approval" }, { "id": "0e44b900-8fdb-11f0-a8fb-61ec9e5a76ba", "name": "Set State", "provider": "silo.state", "summary": "Set state to `processing`{.state .processing}", "config": { "state": "processing" } }, { "id": "12aaf950-8fdb-11f0-a8fb-61ec9e5a76ba", "name": "Wait for Approval", "provider": "peppol.wait.approval" }, { "id": "7a5a4db0-0fae-11f0-b37b-0be1c251a274", "name": "Register Peppol Party", "provider": "peppol.register", "summary": "Enable with groups: ubl-invoice", "config": { "disable": false, "doc_groups": [ "ubl-invoice" ], "visibility": "smp+sml+peppol" } }, { "id": "7c2fa9f0-0fae-11f0-b37b-0be1c251a274", "name": "Set State", "provider": "silo.state", "summary": "Set state to `registered`{.state .registered}", "config": { "state": "registered" } } ], "rescue": [ { "id": "a34e83f0-25dc-11f0-b641-350e77c28eed", "name": "Set State", "provider": "silo.state", "summary": "Set state to `error`{.state .error}", "config": { "state": "error" } } ]}
Before starting, review the workflows guide to understand the general setup process.In Console, create a new workflow and choose Empty Party workflow as the base. Then name the workflow with a descriptive label such as โRegister Peppol participantโ.This workflow is composed by these steps:
Register for Approval - This generates a link to the registration wizard where proof of ownership will be collected.
Set State - select Processing.
Wait for Approval - Invopop will validate the company identity and ownership. This can take up to 72 hours.
Register Peppol Party - Complete the normal registration process after approval.
Set State - select Registered.
Finally, in the Error Handling area, add the Set State action and select Error.
Congratulations! Your workspace is now configured to send and receive Peppol documents and programmatically onboard Peppol participants with Invopop.
After setup, you can perform three key operations with Peppol in Invopop: onboarding entities (parties) so they can use Peppol, sending invoices through Peppol, and receiving Peppol invoices.
Business entities are represented in Invopop as GOBL org.party objects, which we call Parties.Peppol requires Invopop to collect proof of ownership for regulatory compliance. As outlined in Section 3.3 End user Identification of the Internal Regulations II document, key details such as VAT number, address, contact information, and company name must be provided and validated during registration.To register a party:
Upload it to the Silo with required company information
Send it to the party registration workflow
Note for Belgium: If youโre registering for the first time in Belgium, youโll need to use a migration workflow (a modified initial registration path required when first onboarding in Belgium) instead of the standard registration workflow. See the Belgium Peppol Guide for specific instructions on obtaining a migration key from BOSA and setting up the migration process.
You can upload parties via the Create an Entry API endpoint or manually through the Console. For this guide, weโll demonstrate the manual process:
Find the Contacts section in the sidebar and click Suppliers
Click + New Supplier to open the editor
Enter the required information (or use the example below)
The mandatory fields for Peppol registration are:
Company name (fiscal name)
VAT number (tax ID)
Complete company address
Contact information
Peppol participant ID
If no Peppol participant ID is provided, Invopop will assign one during registration based on the VAT number and the country.All fields are required for identity validation and proof of ownership verification.Click Build to validate the document, then Save.
Select the Register Supplier workflow created during setup
Click Run Workflow
The execution should succeed, and the silo entryโs state will change to โProcessing.โ The first step creates a registration link that you can extract from the Meta tab or via the API:
This link leads to a webform where you can upload proof of ownership documents and confirm your company details:
After submitting the webform, Invopop will be notified and will validate your information within up to 72 hours. The approval status will be shown in the Meta tab of the entry.
For programmatic integration, you can use our API instead of the webform. This is particularly useful for white-label implementations where you want to integrate the registration process into your own application.You can achieve this by uploading the proof of ownership document using the API. This launches the validation process automatically.
When Invopop approves your registration, we will automatically register your party with the Peppol network as before. Youโll see the Peppol Participant ID in the Meta tab of the entry and the supplierโs entry will contain an inboxes array. This information should be included in each invoice issued by this supplier.
The party can now send and/or receive invoices in Peppol via Invopop.
To send an invoice, you need to store it as a Silo Entry with the
Store it as a Silo Entry with the Peppol inboxes previously obtained.
Send it to the Sending Invoice Workflow created during setup
You can perform these steps manually via the Console or programmatically via the API using the Create an Entry and Create a Job endpoints. For API usage, refer to our quickstart guide.When creating your invoice, ensure you:
Set the appropriate $regime field based on the issuerโs country (e.g., NO for Norway, FI for Finland)
Add the eu-en16931-v2017 addon to enable validations and extensions needed for Peppol
Invopop automatically processes invoices received from the Peppol network using your configured Incoming Workflow.The workflow converts Peppol documents to GOBL format and creates Silo Entries for each invoice. Configure your workflow with webhooks or Google Drive integration to deliver these invoices to your systems.