Introduction

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.

Setup

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

  1. Within the Console, navigate to ConfigurationApps
  2. Find the Peppol app in the list
  3. 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.

3

Configure a workflow to receive invoices

4

Configure the Peppol app

Within the Console, navigate to ConfigurationApps, 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.

Congratulations! Your workspace is now configured to send and receive Peppol documents and programmatically onboard Peppol participants with Invopop.

Running

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.

Registering parties

Business entities are represented in Invopop as GOBL org.party objects, which we call Parties. To register a party:

  1. Upload it to the Silo
  2. Send it to the party registration workflow

Upload a party document

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:

  1. Find the Contacts section in the sidebar and click Suppliers
  2. Click + New Supplier to open the editor
  3. Enter the required information (or use the example below)

The mandatory fields for Peppol registration are:

  • Fiscal name
  • Peppol participant ID

Tax ID is optional, but recommended.

Click Build to validate the document, then Save.

Send to the registration workflow

Once the document is saved:

  1. Click the Select Workflow button
  2. Select the Register Supplier workflow created during setup
  3. Click Run Workflow

The execution should succeed, and the silo entry’s state will change to “Processing.” Click the Meta tab to see the registration link:

When successful, you’ll see the Peppol Participant ID in the Meta tab of the entry. The party can now send and/or receive invoices in Peppol via Invopop.

Sending invoices

To send an invoice, you need to:

  1. Store it as a Silo Entry
  2. 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:

  1. Set the appropriate $regime field based on the issuer’s country (e.g., NO for Norway, FI for Finland)
  2. Add the peppol addon to enable Peppol-specific validations and extensions

Receiving invoices

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.

FAQ

Please contact the Invopop support team if you have any questions that are not listed here.