Skip to main content

The Pay payment provider for Pretix

Project description

The Pay payment provider plugin for Pretix. It creates payments via The Pay API, redirects customers to The Pay, and confirms payment status using the return and notification callbacks.

Features

  • The Pay REST API integration (payment creation, status lookup)

  • Redirect-based checkout flow

  • Server-to-server notifications

  • Refunds (full and partial)

  • ISO 4217 currency support with correct minor units

  • Demo mode via Test Mode setting

  • Multi-language gateway support (Czech, Slovak, English)

Requirements

  • Pretix >= 2.7.0

  • Python >= 3.8

  • requests >= 2.25.0

Installation

Install from PyPI:

pip install pretix-thepay

Or install from source:

pip install -e /path/to/pretix-thepay

Enable the plugin in pretix.cfg:

[pretix]
plugins = pretix_thepay

Restart Pretix after enabling the plugin.

Configuration

In the Pretix control panel, enable The Pay and configure:

  • Merchant ID: Your The Pay merchant ID

  • Project ID: Your The Pay project ID

  • API Password: Your The Pay API password

  • Language: Default language for the payment gateway

  • Test Mode: Enable to use the demo environment

Behavior

  1. The customer selects The Pay.

  2. Pretix creates a payment at The Pay and redirects the customer.

  3. The customer completes payment on The Pay.

  4. Pretix confirms the payment by querying The Pay from the return URL and from notifications.

Notes

  • Test Mode switches the API base URL to the demo environment.

  • The Pay requires a customer name plus email or phone; Pretix order data is used.

Refunds

Refunds are initiated from Pretix and sent to The Pay. The plugin supports full and partial refunds for payments that support automatic refunds in The Pay.

Troubleshooting

Payment not created

  • Verify Merchant ID, Project ID, and API Password

  • Check Pretix logs for The Pay API response details

  • Ensure the customer has a name and email or phone

Notifications not arriving

  • Make sure Pretix is reachable from The Pay (public URL)

  • Confirm your server IP is allowed in The Pay administration

Docker

For Pretix in Docker:

FROM pretix/standalone:stable
USER root
RUN pip3 install pretix-thepay
USER pretixuser
RUN cd /pretix/src && make production

License

Apache Software License 2.0

References

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_thepay-9.0.15.tar.gz (15.4 kB view details)

Uploaded Source

Built Distribution

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

pretix_thepay-9.0.15-py3-none-any.whl (15.3 kB view details)

Uploaded Python 3

File details

Details for the file pretix_thepay-9.0.15.tar.gz.

File metadata

  • Download URL: pretix_thepay-9.0.15.tar.gz
  • Upload date:
  • Size: 15.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for pretix_thepay-9.0.15.tar.gz
Algorithm Hash digest
SHA256 9eb918c0cbf3d9ac52c8561262d3e126d84b00d26ac4fcc45a289c08e88cb84f
MD5 d017e8f94052f76a8c5387bb90d56c2c
BLAKE2b-256 2373fa0813ebc171d9ca41032e68f08d1f95a3f5f843c60fcdb2195d88fcbbc4

See more details on using hashes here.

File details

Details for the file pretix_thepay-9.0.15-py3-none-any.whl.

File metadata

  • Download URL: pretix_thepay-9.0.15-py3-none-any.whl
  • Upload date:
  • Size: 15.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for pretix_thepay-9.0.15-py3-none-any.whl
Algorithm Hash digest
SHA256 35e82c75d4311c0610cc727d2d6c884278ffe5ad7a24fb8cf62bb50ec722483d
MD5 61bd739c9ab08ee97279d51b76b20717
BLAKE2b-256 0a789c4918c8f7a54a580ef6d8cb18ad58d49106dbdb93dc1dc46f0d5d24bca1

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