Skip to main content

A simplified wrapper for PayPal's Python Server SDK

Project description

README.md

PayPal Easy

A simplified, developer-friendly wrapper around PayPal's Python Server SDK.

Why PayPal Easy?

PayPal's official Python SDK can be challenging to work with due to:

  • Missing or inconsistent class imports
  • Complex parameter structures
  • Inconsistent documentation
  • Verbose API calls

PayPal Easy solves these problems by providing:

  • ✅ Clean, consistent API
  • ✅ Proper error handling
  • ✅ Type hints and IDE support
  • ✅ Simplified method signatures
  • ✅ Django integration helpers

Installation

pip install paypal-easy

Quick Start

from paypal_easy import PayPalEasyClient, Environment, Currency
from decimal import Decimal

# Initialize client
client = PayPalEasyClient(
    client_id="your_client_id",
    client_secret="your_client_secret",
    environment=Environment.SANDBOX
)

# Create an order
result = client.create_order(
    amount=Decimal("29.99"),
    currency=Currency.USD,
    description="Premium subscription",
    return_url="https://yoursite.com/success",
    cancel_url="https://yoursite.com/cancel"
)

if hasattr(result, 'id'):  # Success
    print(f"Order created: {result.id}")
    print(f"Approval URL: {result.approval_url}")
else:  # Error
    print(f"Error: {result.message}")

Django Integration

# views.py
from paypal_easy.django_integration import PayPalEasyDjangoMixin
from django.views import View

class CreatePaymentView(PayPalEasyDjangoMixin, View):
    def post(self, request):
        client = self.get_paypal_client()
        
        result = client.create_order(
            amount=request.POST.get('amount'),
            description="Order payment"
        )
        
        if hasattr(result, 'id'):
            return self.paypal_success_response(result)
        else:
            return self.paypal_error_response(result)

Features

  • Simple Order Creation: Create orders with minimal code
  • Automatic URL Handling: Easy approval flow setup
  • Error Handling: Consistent error responses
  • Django Integration: Ready-to-use Django mixins
  • Type Safety: Full type hints for better IDE support
  • Logging: Built-in logging for debugging

Comparison

Before (Official SDK)

from paypalserversdk.paypal_serversdk_client import PaypalServersdkClient
from paypalserversdk.configuration import Environment
from paypalserversdk.http.auth.o_auth_2 import ClientCredentialsAuthCredentials
from paypalserversdk.models.order_request import OrderRequest

credentials = ClientCredentialsAuthCredentials(
    o_auth_client_id=client_id,
    o_auth_client_secret=client_secret
)

client = PaypalServersdkClient(
    environment=Environment.SANDBOX,
    client_credentials_auth_credentials=credentials
)

order_request = OrderRequest({
    "intent": "CAPTURE",
    "purchase_units": [{
        "amount": {
            "currency_code": "USD", 
            "value": "29.99"
        }
    }]
})

response = client.orders.create_order({'body': order_request})

After (PayPal Easy)

from paypal_easy import PayPalEasyClient, Environment, Currency

client = PayPalEasyClient(client_id, client_secret, Environment.SANDBOX)
result = client.create_order(amount="29.99", currency=Currency.USD)

Contributing

Contributions welcome! Please feel free to submit issues and enhancement requests.

Donations

Would you like to support the work we do?

Click Here to Donate - Donate Link

License

MIT License - see LICENSE file for details.

Maintainers

William Mabotja - Portfolio Site

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

paypal_easy-0.1.7.tar.gz (8.9 kB view details)

Uploaded Source

Built Distribution

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

paypal_easy-0.1.7-py3-none-any.whl (9.6 kB view details)

Uploaded Python 3

File details

Details for the file paypal_easy-0.1.7.tar.gz.

File metadata

  • Download URL: paypal_easy-0.1.7.tar.gz
  • Upload date:
  • Size: 8.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.5

File hashes

Hashes for paypal_easy-0.1.7.tar.gz
Algorithm Hash digest
SHA256 9a8ecc0285efd8c4032805528162baa3d6803e258b4ec441de0265ffc9bdfbe3
MD5 fcffd3da850d89252e046761a8b70932
BLAKE2b-256 f5b7dea3772068b8605a0ff1d4cbda0e04814010cb1567e63d2ba80bc559ea36

See more details on using hashes here.

File details

Details for the file paypal_easy-0.1.7-py3-none-any.whl.

File metadata

  • Download URL: paypal_easy-0.1.7-py3-none-any.whl
  • Upload date:
  • Size: 9.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.5

File hashes

Hashes for paypal_easy-0.1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 7442c10a81ab3f1fea9244bef706cff20e6fff242fddca8828008b3eae63d9b2
MD5 e0118f5f3bff04df0841635391ebfba0
BLAKE2b-256 a385df6c06ff17b5b7de0933d0d4763f26f178a30642bb65bf61c66e2bee6e84

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