Skip to main content

A modern Python API wrapper for Paddle's API with type hints and async support

Project description

Paddle SDK

A modern Python API wrapper for Paddle's API with type hints and async support.

License: MIT Python Version Code style: black

Features

  • 🚀 Synchronous and asynchronous client implementations
  • 📦 Support for Paddle's API (in development)
  • 🧩 Type hints throughout the codebase
  • 🔄 Automatic retry mechanism for failed requests
  • 🔧 Environment configuration (Sandbox/Production)
  • 🛡️ Comprehensive error handling
  • 📊 Extensive test coverage

Installation

pip install paddle.py

Quick Start

Synchronous Client

from paddle import Client, Environment

# Initialize the client
client = Client(
    api_key="API_KEY",
    environment=Environment.SANDBOX  # or Environment.PRODUCTION
)

# List products
products = client.products.list()
print(products)

# Get a specific product
product = client.products.get(product_id="pro_123456789")
print(product)

Asynchronous Client

import asyncio

from paddle.aio import AsyncClient
from paddle import Environment


async def main():
    async with AsyncClient(
        api_key="API_KEY",
        environment=Environment.SANDBOX,  # or Environment.PRODUCTION
    ) as client:
        # List products
        all_products = await client.products.list()
        print(all_products)

        # Get a product
        product = await client.products.get("pro_123456789")
        print(product)


if __name__ == "__main__":
    asyncio.run(main())

Development

Setup

  1. Clone the repository:
git clone https://github.com/CCXLV/paddle.py.git
cd paddle.py
  1. Create a virtual environment:
python -m venv .venv
source .venv/bin/activate  # On Windows: .venv\Scripts\activate
  1. Install development dependencies:
pip install -e .[dev]

Running Tests

# Run all tests
pytest

# Run with coverage
pytest --cov=paddle

Contributing

For detailed information on how to contribute to this project, please see our Contributing Guidelines.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Roadmap

See the CHANGELOG.md for planned API endpoints and features.

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

paddle_py-0.1.2.tar.gz (31.5 kB view details)

Uploaded Source

Built Distribution

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

paddle_py-0.1.2-py3-none-any.whl (44.1 kB view details)

Uploaded Python 3

File details

Details for the file paddle_py-0.1.2.tar.gz.

File metadata

  • Download URL: paddle_py-0.1.2.tar.gz
  • Upload date:
  • Size: 31.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.13

File hashes

Hashes for paddle_py-0.1.2.tar.gz
Algorithm Hash digest
SHA256 7ecf337057ea313a518634db46d24a4c9622f9e3628126d8f32c05b4b7e77a2e
MD5 8473f3421e4dcea9e9cbe24dc1b876dc
BLAKE2b-256 c49225c15eff1d97558d99708f978cfd8627edd6e6db10d0e9152d167ea14977

See more details on using hashes here.

File details

Details for the file paddle_py-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: paddle_py-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 44.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.13

File hashes

Hashes for paddle_py-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 5b05d43fa8716d43bffbd3fa5a01c0a919efcf9bebc7e1daa67d0248f620b2cd
MD5 77ea22a5262a6b121031be663b1adc63
BLAKE2b-256 7f61c39582378da1bc5ee972c740d0311331e19daf3099e7c43ba053ded622e2

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