Skip to main content

A python implementation for sending peppol eDelivery AS4 documents.

Project description

Peppol-py

A python implementation for sending peppol eDelivery AS4 documents. Most implementations are written in java such as oxalis and phase4 and are very complex. This code base is an order of magnitude smaller.

The implementation makes use of xmlsec for signing and encryption. Version 1.3 is needed for the rsa oaep aes128 gcm encryption used in peppol. Debian is still using 1.2 in both stable and unstable as of 5/6 2025 so we use xmlsec 1.3 as an external binary.

The protocol should be relatively simple:

  • Generate a transfer document with:
    • UserMessage describing the sender and receiver
    • Empty body
    • The gzipped actual document as an attachment
  • Hash the 3 elements and sign that.
  • Encrypt the gzipped attachment for the intended receiver
  • POST the transfer document with signature and encryption info, with the encrypted attachment as a multipart mime to the AS4 endpoint

The implementation includes support for using the SML and SMP protocol for finding the AS4 endpoint of the receiver.

CLI Usage

> python3 -m peppol_py --help

usage: python -m peppol_py [-h] [--verbose | --no-verbose] {send,validate} ...

Peppol utility

positional arguments:
  {send,validate}       command
    send                Send a Peppol document
    validate            Validate a Peppol document

options:
  -h, --help            show this help message and exit
  --verbose, --no-verbose
                        Enable debug logging

> python -m peppol_py send --help
usage: python -m peppol_py send [-h] --document DOCUMENT --service-provider SERVICE_PROVIDER
                                     [--xmlsec-path XMLSEC_PATH]
                                     [--schematron-path SCHEMATRON_PATH [SCHEMATRON_PATH ...]]
                                     [--keyfile KEYFILE] [--password PASSWORD] [--certfile CERTFILE]
                                     [--unwrap-sbh | --no-unwrap-sbh]
                                     [--test | --no-test]

options:
  -h, --help            show this help message and exit
  --document DOCUMENT   The path of the document to send
  --xmlsec-path XMLSEC_PATH
                        The path to latest xmlsec binary
  --schematron-path SCHEMATRON_PATH [SCHEMATRON_PATH ...]
                        Schematron XSL files to validate with, defaults to bundled PEPPOL-EN16931-UBL.xsl
  --keyfile KEYFILE     The path to the private key, defaults to key.pem
  --password PASSWORD   The password for the private key, defaults to empty
  --certfile CERTFILE   The path to the public key, defaults to cert.pem
  --unwrap-sbh, --no-unwrap-sbh
                        Unwrap standard business header already present in document. Useful for testbed.
  --service-provider SERVICE_PROVIDER
                        Service provider ID
  --test, --no-test     Use test SMP server, defaults to production

> python -m peppol_py validate --help
usage: python -m peppol_py validate [-h] --document DOCUMENT 
                                         [--schematron-path SCHEMATRON_PATH [SCHEMATRON_PATH ...]]

options:
  -h, --help            show this help message and exit
  --document DOCUMENT   The path of the document to validate
  --schematron-path SCHEMATRON_PATH [SCHEMATRON_PATH ...]
                        Schematron XSL files to validate with, defaults to bundled PEPPOL-EN16931-UBL.xsl

Examples

Send a document:

python3 -m peppol_py --verbose send --document test_invoice.xml \
        --schematron-path CEN-EN16931-UBL.xsl --test \
        --certfile cert.pem --keyfile key.pem \
        --service-provider PXX000000 

Validate a document:

python3 -m peppol_py validate --document test_invoice.xml \
        --schematron-path CEN-EN16931-UBL.xsl

Python API

Send document

To send a prepared xml document, call send_peppol_document:

from peppol_py import send_peppol_document
stats = send_peppol_document(
    document_content, xmlsec_path, keyfile, keyfile_password, certfile,
    sender_id=None, receiver_id=None, sender_country=None,
    document_type_version=None, test_environment=True, timeout=20, dryrun=False
)

See docstring or help(peppol_py.send_peppol_document) on a Python console for a full parameter description.

Validate document

To validate a prepared document, call validate_peppol_document:

from peppol_py import validate_peppol_document
stats = validate_peppol_document(
    document_content, schematron_xsls, remove_namespaces_from_errors=True, warnings=False
)

See docstring or help(peppol_py.validate_peppol_document) on a Python console for a full parameter description.

Send statistics

To validate a prepared document, call send_peppol_statistics:

from peppol_py import send_peppol_statistics

stats = send_peppol_statistics(
    aggr_stats, our_endpoint, xmlsec_path, keyfile, password, certfile,
    test_environment
)

See docstring or help(peppol_py.send_peppol_statistics) on a Python console for a full parameter description.

Background

This implementation was sponsored by iteras, one of the largest SSAS solutions in the nordics for managing print and digital media subscriptions.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

peppol_py-1.2.0.tar.gz (149.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

peppol_py-1.2.0-py3-none-any.whl (163.8 kB view details)

Uploaded Python 3

File details

Details for the file peppol_py-1.2.0.tar.gz.

File metadata

  • Download URL: peppol_py-1.2.0.tar.gz
  • Upload date:
  • Size: 149.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for peppol_py-1.2.0.tar.gz
Algorithm Hash digest
SHA256 d6fcc76e3d0e18a1c369d6cb8f3145f7ca35e0eb1459d13e75ec3a130a3ee7ac
MD5 97766ba6bae6818ae8e6635876076acf
BLAKE2b-256 a793afbe36b02529c36d00848c4762cd30797bc111ba53a16809e4ef59e2d05c

See more details on using hashes here.

File details

Details for the file peppol_py-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: peppol_py-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 163.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for peppol_py-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f27cbd7b51ae33d5d62fdf3900b03a47d6cb709f043cf4ce1c39b2539ca6bbe5
MD5 3745066316987c90b6305644c22121d3
BLAKE2b-256 02e4c01b7dea19cd0537eb8b0003a5c4d0786752a8411f8411d93d094097ab9c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page