Skip to main content

Framework-agnostic payment processing core.

Project description

python-getpaid-core

PyPI version Python version License

Framework-agnostic payment processing core.

python-getpaid-core is the foundation of the Getpaid ecosystem. It provides the abstract interfaces, semantic payment update engine, and plugin registry needed to build a robust payment system without coupling your logic to a specific web framework or payment provider.

Installation

pip install python-getpaid-core

Quick Start: Creating a Custom Processor

To implement a new payment backend, subclass BaseProcessor and implement at least prepare_transaction.

from getpaid_core import BaseProcessor
from getpaid_core.types import TransactionResult

class MyPaymentProcessor(BaseProcessor):
    slug = "my-provider"
    display_name = "My Payment Provider"
    accepted_currencies = ["USD", "EUR"]

    async def prepare_transaction(self, **kwargs) -> TransactionResult:
        # Generate payment link or form data
        return TransactionResult(
            redirect_url=f"https://api.provider.com/pay/{self.payment.id}",
            method="GET"
        )

Registering your Processor

Register your processor using entry points in your pyproject.toml so it can be discovered by the registry:

[project.entry-points."getpaid.backends"]
my-provider = "my_package.processors:MyPaymentProcessor"

Architecture Overview

  • BaseProcessor: The abstract base class that all payment gateway plugins must implement. It provides the standard interface for transaction preparation, callback handling, charging, and refunds.
  • PaymentFlow: Manages the payment lifecycle using semantic payment update objects. It ensures that payments move between states (e.g., NEW -> PREPARED -> PAID) according to strict business rules.
  • PluginRegistry: A central service for discovering and managing payment processors registered via getpaid.backends entry points.
  • State Engine: Applies semantic payment and fraud events to payment objects, merges provider metadata, and tracks idempotent provider event IDs.

API Summary

Class / Module Role
BaseProcessor Abstract base for implementing payment gateways.
PaymentFlow Semantic orchestration for payment lifecycles.
PaymentStatus Enum for all possible payment states (NEW, PAID, FAILED, etc.).
registry Singleton registry for backend discovery.
TransactionResult Standard response for transaction initiation.
GetPaidException Base exception for all payment-related errors.

Ecosystem

getpaid-core is the heart of a larger ecosystem designed to make payment processing easy in any Python web application.

Framework Wrappers

Processor Plugins

License

This project is licensed under the MIT 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

python_getpaid_core-3.0.0a3.tar.gz (52.5 kB view details)

Uploaded Source

Built Distribution

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

python_getpaid_core-3.0.0a3-py3-none-any.whl (14.7 kB view details)

Uploaded Python 3

File details

Details for the file python_getpaid_core-3.0.0a3.tar.gz.

File metadata

  • Download URL: python_getpaid_core-3.0.0a3.tar.gz
  • Upload date:
  • Size: 52.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.3 {"installer":{"name":"uv","version":"0.10.3","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Manjaro Linux","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for python_getpaid_core-3.0.0a3.tar.gz
Algorithm Hash digest
SHA256 dc98dcfe1bd581500b6ab96db28653b384cc2b24eb30b30824e7ac5b6703f2cb
MD5 779d8cc125cd3c9ad8ecf084d676527f
BLAKE2b-256 d60ae0fd72ed27879c7d6fe7282a4a160479c5dabcd1c1a20b89b213d370e42f

See more details on using hashes here.

File details

Details for the file python_getpaid_core-3.0.0a3-py3-none-any.whl.

File metadata

  • Download URL: python_getpaid_core-3.0.0a3-py3-none-any.whl
  • Upload date:
  • Size: 14.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.3 {"installer":{"name":"uv","version":"0.10.3","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Manjaro Linux","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for python_getpaid_core-3.0.0a3-py3-none-any.whl
Algorithm Hash digest
SHA256 d45b5e0b2b5cb867f9f4357ce7b8abd047759a4cc1ff5624b68ce1bfdcb56e96
MD5 7f1716ad617ee7129e292503e28c21eb
BLAKE2b-256 bac6cb0ef9e36d6fa91723eff288733d47deb5c338476944d007aaa7db855547

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