Skip to main content

Reusable Django payment infrastructure with idempotency and webhook support

Project description

payment_infra

payment_infra is a reusable Django payment package that provides provider integrations, webhook handling, and idempotent payment processing logic you can plug into different Django projects.

Why use this package?

  • Reuse payment infrastructure across multiple Django services/projects.
  • Start quickly with Paystack charge + verification endpoints.
  • Handle webhook events through a structured service layer.
  • Reduce duplicate transaction processing with idempotency support.

Installation

Install from PyPI

python -m venv venv # create a virtual environment
pip install payment_infra

Install for local development

git clone "[repo url](https://github.com/0FFSIDE1/payment_infra.git)"
pip install -r requirements.txt

Using payment_infra in any Django project

1) Add the app to INSTALLED_APPS

INSTALLED_APPS = [
    # ...
    "rest_framework",
    "payment_infra",
]

2) Configure environment variables

Typical settings used by providers/runtime:

  • PAYSTACK_SECRET_KEY
  • PAYSTACK_PUBLIC_KEY
  • PAYSTACK_CALLBACK_URL
  • REDIS_URL
  • DJANGO_SECRET_KEY
  • CACHE_BACKEND

Exact variable wiring depends on your host project's Django settings.

3) Include the package URLs in your project urls

# project/urls.py
from django.urls import include, path

urlpatterns = [
    # ...
    path("payments", include("payment_infra.api.urls")),
]

With the example above, available endpoints become:

  • POST /payments/paystack/charge/
  • GET /payments/paystack/verify/<reference>/
  • POST /payments/webhooks/

4) Run migrations

python manage.py migrate

API example

Initiate payment

curl -X POST http://localhost:8000/payments/paystack/charge/ \
  -H "Content-Type: application/json" \
  -d '{
    "email": "customer@example.com",
    "amount": "1000.00",
    "idempotency_key": "trx-343487629495403" # optional (auto-generated if not provided)
    "currency": "NGN",
    "callback_url": "https://example.com/callback"
  }'

Verify Payment

curl -X GET 'http://localhost:8000/payments/paystack/verify/<reference>/' 
  • Replace: reference → with the actual reference returned from the charge endpoint.

Asynchronous payment processing example

from payment_infra.infrastructure.tasks.payment_task import process_payment_task

result = process_payment_task.delay(email, amount, currency, idempotency_key, metadata)

NB: You have to configure celery to use asynchronous payment processing

Package architecture

payment_infra/
├── api/                # DRF serializers, views, routes
├── application/        # Service/use-case layer and interfaces
├── domain/             # Core entities
├── infrastructure/     # Providers, repositories, idempotency, tasks
└── migrations/         # Django migrations

This layered design keeps payment orchestration logic decoupled from API and provider implementations, making it easier to extend for additional providers or custom project requirements.

Running tests (repository/local dev)

pytest

Run only integration tests:

pytest -m integration

Run only tests without real integration:

pytest -m "not integration"

Contributing

  • Fork the repo
  • Create a feature branch
git checkout -b feature/awesome
  • Run test after implementing your feature
pytest
  • Commit changes
git commit -m 'Add awesome feature'
  • Push branch and open a PR

Support

For enterprise inquiries, please contact offsideint@gmail.com

For bugs, open an issue on GitHub.

Built with ❤️ by OFFSIDE INTEGRATED TECHNOLOGY — because developers do not need hassle wiring payments.

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

payment_infra-1.0.3.tar.gz (19.6 kB view details)

Uploaded Source

Built Distribution

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

payment_infra-1.0.3-py3-none-any.whl (26.5 kB view details)

Uploaded Python 3

File details

Details for the file payment_infra-1.0.3.tar.gz.

File metadata

  • Download URL: payment_infra-1.0.3.tar.gz
  • Upload date:
  • Size: 19.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for payment_infra-1.0.3.tar.gz
Algorithm Hash digest
SHA256 5db0662547485c33aa67cb006fe816b31adc07849fc5446ad729ac0be13b236d
MD5 1652731ec617184382838010aeaea554
BLAKE2b-256 35d536e6fc2fba392e6fed0570fe74b8412eee54070ae641d161b6afc14c7fc1

See more details on using hashes here.

Provenance

The following attestation bundles were made for payment_infra-1.0.3.tar.gz:

Publisher: cd.yml on 0FFSIDE1/payment_infra

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file payment_infra-1.0.3-py3-none-any.whl.

File metadata

  • Download URL: payment_infra-1.0.3-py3-none-any.whl
  • Upload date:
  • Size: 26.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for payment_infra-1.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 53e5b9c6852f2a2b60671bf96ab6b31b6e86d69e80bcf4af8e13e317a62b834c
MD5 14b0f7ef34d63807fde4906f2a2301d0
BLAKE2b-256 19620b82aa0ac5e1c79743d23684b63a282a14e807e7bba90e71c2f08eae6add

See more details on using hashes here.

Provenance

The following attestation bundles were made for payment_infra-1.0.3-py3-none-any.whl:

Publisher: cd.yml on 0FFSIDE1/payment_infra

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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