Skip to main content

Automatically import bank transactions via Enable Banking (PSD2/Open Banking) into pretix

Project description

pretix-enablebanking

Connects pretix to your bank via Enable Banking (PSD2/Open Banking). Once configured, it periodically fetches bank transactions and feeds them into pretix's bank transfer pipeline — automatically matching incoming payments to orders.

Key capabilities:

  • OAuth-based bank connection via 400+ European banks (PSD2)
  • Automatic and on-demand transaction import
  • Multi-account support with per-account activation toggle
  • Configurable auto-fetch interval (every 1h, 4h, 12h, or 24h)
  • Works at organizer level (one connection per organizer)

Screenshots

Import — manual fetch & job history

Import

Settings — bank connection & API credentials

Settings

How it works

  1. You register an app at Enable Banking and get an App ID + RSA private key.
  2. You enter those credentials in the plugin settings and initiate an OAuth flow to connect your bank account.
  3. After authorization, Enable Banking provides access to your bank accounts. You activate the ones you want to import from.
  4. The plugin fetches transactions (automatically or on demand) and creates BankImportJob records, which pretix then processes to match payments against open orders.

The transaction import runs as a Celery task and uses Enable Banking's paginated transactions API. The last-fetched date per account is tracked to avoid re-importing.

Installation

pip install pretix-enablebanking

Then run migrations and restart the server:

python -m pretix migrate

The plugin registers itself automatically via the pretix.plugin entry point — no manual INSTALLED_APPS edit needed.

Development installation

git clone https://github.com/nicoknoll/pretix-enablebanking.git
cd pretix-enablebanking
pip install -e .

Setup in pretix

1. Get Enable Banking credentials

  1. Sign up at developers.enablebanking.com and create an application.
  2. Generate an RSA key pair. Register the public key with Enable Banking and keep the private key (PEM format).
  3. Note your Application ID.

2. Configure the plugin

In the pretix backend, go to your organizer → Bank transferEnable Banking settings:

  • Application ID — the App ID from Enable Banking
  • Private key (PEM) — your RSA private key (-----BEGIN PRIVATE KEY----- format)
  • Country — used to filter the list of available banks (ASPSPs)
  • Auto-fetch interval — how often transactions should be fetched automatically (set to "disabled" to import manually only)

Save, then select your bank from the dropdown and click Connect with bank. You'll be redirected to Enable Banking's hosted authorization page where you log into your bank and grant consent.

After authorization, you're redirected back and your accounts appear in the settings. Activate the accounts you want to import from and save.

3. Import transactions

Go to Bank transferAutomatic import to:

  • Trigger a manual import (optionally specify a start date)
  • View recent import jobs and their status
  • See when your bank connection expires (Enable Banking consent is typically valid for 90 days — renew before it expires)

Testing with the sandbox

Enable Banking provides a sandbox environment with a mock bank. Use these credentials when connecting Aachener Bank (country: DE):

Field Value
VR NetKey VRK1234567890ALL
PIN password
OTP 123456

The import view shows a Sandbox mode warning when a mock bank is connected.

Dependencies

Package Purpose
pretix >= 2.7.0 Host platform
requests HTTP calls to Enable Banking API
PyJWT RS256-signed JWT for API authentication (transitive via pretix)

Python 3.10+ required.

Permissions

The plugin operates at organizer level. Users need can_change_organizer_settings to access settings and trigger imports.

License

MIT — see LICENSE.

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

pretix_enablebanking-1.0.1.tar.gz (747.5 kB view details)

Uploaded Source

Built Distribution

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

pretix_enablebanking-1.0.1-py3-none-any.whl (27.3 kB view details)

Uploaded Python 3

File details

Details for the file pretix_enablebanking-1.0.1.tar.gz.

File metadata

  • Download URL: pretix_enablebanking-1.0.1.tar.gz
  • Upload date:
  • Size: 747.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.14

File hashes

Hashes for pretix_enablebanking-1.0.1.tar.gz
Algorithm Hash digest
SHA256 688f7122512854d0e2d1934473c453eed9d27e8f2644a3431f679089e6c1e621
MD5 eb74dd40b0417d393828c9a6ac5145c1
BLAKE2b-256 4bef26681b52fa6a0cff2b21d5d732e819b1b283d9d09115c6d5e87f5a4846ac

See more details on using hashes here.

File details

Details for the file pretix_enablebanking-1.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for pretix_enablebanking-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 4e742ff3ec7e788da6378bce8cefb0c05fcdcec87257a10bb77a0d1c8cbc1cbe
MD5 8e2584fe23f76600e51cd7bbdb695d68
BLAKE2b-256 ab796b5dfbba6a610fc2c80d03f168bbca99295f6b5c45fa3afc08bbf026cb46

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