Skip to main content

One-liner x402 pay-per-request for FastAPI endpoints

Project description

FastAPI x402

One-liner cryptocurrency payments for FastAPI endpoints using the x402 protocol.

Transform any FastAPI endpoint into a paid API with just a single decorator. Accept stablecoin payments (USDC) on Base network with automatic settlement.

from fastapi import FastAPI
from fastapi_x402 import init_x402, pay

app = FastAPI()
init_x402(app, merchant_wallet="0x...", facilitator_url="https://x402.org/facilitator")

@app.get("/premium-data")
@pay("$0.01")  # Require 1 cent payment
async def get_premium_data():
    return {"data": "This costs $0.01 to access!"}

🚀 Features

  • 🔒 Pay-per-request: Monetize individual API calls
  • 🌐 Multi-network support: Accept payments on Base, Avalanche, and IoTeX
  • 💰 Stablecoin payments: Accept USDC across all supported networks
  • ⚡ Real-time settlement: Automatic blockchain settlement
  • 🛡️ Replay protection: Cryptographic payment verification
  • 📝 Standard protocol: Built on the x402 payment standard
  • 🔧 One-line integration: Just add @pay("$0.01") to any endpoint
  • 🔄 Auto-sync: Stays synchronized with Coinbase Facilitator supported networks
  • 🎯 Network control: Server dictates which networks clients can use for payment

📦 Installation

pip install fastapi-x402

🎯 Quick Start

1. Basic Setup

from fastapi import FastAPI
from fastapi_x402 import init_x402, pay

app = FastAPI()

# Initialize x402 with your merchant wallet and facilitator
init_x402(
    app,
    merchant_wallet="0x9ecae3f1abfce10971353FD21bD8B4785473fD18",
    facilitator_url="https://x402.org/facilitator"  # or your own facilitator
)

@app.get("/free-endpoint")
async def free_endpoint():
    return {"message": "This endpoint is free!"}

@app.get("/paid-endpoint")
@pay("$0.01")  # Require 1 cent payment
async def paid_endpoint():
    return {"secret": "This cost 1 cent to access!"}

@app.get("/expensive-data")
@pay("$1.00")  # Require $1 payment
async def expensive_data():
    return {"premium_data": "This is worth $1!"}

2. Run Your Server

uvicorn main:app --host 0.0.0.0 --port 8000

3. Test the Payment Flow

Without payment (gets 402 response):

curl http://localhost:8000/paid-endpoint

With payment (success):

curl -H "X-PAYMENT: eyJ4NDAyVmVyc2lvbiI6..." http://localhost:8000/paid-endpoint

💳 Client Integration

JavaScript/TypeScript

import { X402Client } from '@x402/client';

const client = new X402Client({
  network: 'base-sepolia',
  privateKey: 'your-wallet-private-key'
});

const response = await client.get('http://localhost:8000/paid-endpoint');
console.log(response.data); // Automatically handles payment

Python

import httpx
from x402_client import X402Client  # Coming soon

client = X402Client(network='base-sepolia', private_key='...')
response = await client.get('http://localhost:8000/paid-endpoint')

🔧 Configuration

Environment Variables

# Optional: Override default settings
X402_FACILITATOR_URL=https://your-facilitator.com
X402_NETWORK=base-sepolia
X402_ASSET_ADDRESS=0x036CbD53842c5426634e7929541eC2318f3dCF7e

Multi-Network Configuration

from fastapi_x402 import init_x402

# Support all available networks
init_x402(
    pay_to="0x...",
    network="all"  # Accepts payments on Base, Avalanche, and IoTeX
)

# Support specific networks
init_x402(
    pay_to="0x...",
    network=["base", "avalanche"]  # Only Base and Avalanche
)

# Support only testnets
init_x402(
    pay_to="0x...",
    network="testnets"  # base-sepolia and avalanche-fuji
)

# Support only mainnets
init_x402(
    pay_to="0x...",
    network="mainnets"  # base, avalanche, and iotex
)

Network Information

from fastapi_x402 import get_supported_networks_list, get_config_for_network

# List all supported networks
networks = get_supported_networks_list()
print(networks)  # ['base-sepolia', 'base', 'avalanche-fuji', 'avalanche', 'iotex']

# Get configuration for a specific network
config = get_config_for_network("base")
print(config["default_asset"]["address"])  # 0x833589fCD6eDb6E08f4c7C32D4f71b54bdA02913

🎯 Network Control Patterns

Your API can control which networks clients can use to pay:

1. Single Network (Server Dictates)

# Only accept Base network payments
init_x402(pay_to="0x...", network="base")

@pay("$0.01")
@app.get("/base-only")
def base_only():
    return {"data": "Must pay with Base USDC"}

402 Response: Client MUST pay on Base network

{"accepts": [{"network": "base", "asset": "0x833589fCD6eDb6E08f4c7C32D4f71b54bdA02913"}]}

2. Multiple Options (Client Chooses)

# Accept payments from multiple networks
init_x402(pay_to="0x...", network=["base", "avalanche", "iotex"])

@pay("$0.01")  
@app.get("/multi-choice")
def multi_choice():
    return {"data": "Pay with any supported network"}

402 Response: Client can choose from multiple networks

{"accepts": [
  {"network": "base", "asset": "0x833589fCD6eDb6E08f4c7C32D4f71b54bdA02913"},
  {"network": "avalanche", "asset": "0xB97EF9Ef8734C71904D8002F8b6Bc66Dd9c48a6E"},
  {"network": "iotex", "asset": "0xcdf79194c6c285077a58da47641d4dbe51f63542"}
]}

3. Network-Specific Endpoints

@app.get("/pay-with-avalanche")
async def avalanche_only(request: Request):
    # Custom 402 response for Avalanche only
    return JSONResponse(status_code=402, content={
        "accepts": [{"network": "avalanche", "asset": "0xB97..."}]
    })

4. Dynamic Network Selection

@app.get("/premium/{network}")
def network_specific(network: str):
    if network not in ["base", "avalanche"]:
        raise HTTPException(400, "Network not supported")
    # Endpoint accepts payment only on specified network

📋 API Reference

init_x402(app, merchant_wallet, facilitator_url=None, config=None)

Initialize x402 middleware for your FastAPI app.

Parameters:

  • app (FastAPI): Your FastAPI application instance
  • merchant_wallet (str): Your wallet address to receive payments
  • facilitator_url (str, optional): Custom facilitator URL
  • config (X402Config, optional): Advanced configuration

@pay(amount)

Decorator to require payment for an endpoint.

Parameters:

  • amount (str): Payment amount (e.g., "$0.01", "$1.00")

Returns:

  • HTTP 402 if no valid payment provided
  • HTTP 200 with settlement info if payment valid

🌐 Networks & Assets

Supported Networks

  • Base Sepolia (testnet) - base-sepolia
  • Base Mainnet - base
  • Avalanche Fuji (testnet) - avalanche-fuji
  • Avalanche Mainnet - avalanche
  • IoTeX Mainnet - iotex

Supported Assets

All networks support USDC with automatic configuration:

  • Base Sepolia: 0x036CbD53842c5426634e7929541eC2318f3dCF7e
  • Base Mainnet: 0x833589fCD6eDb6E08f4c7C32D4f71b54bdA02913
  • Avalanche Fuji: 0x5425890298aed601595a70AB815c96711a31Bc65
  • Avalanche Mainnet: 0xB97EF9Ef8734C71904D8002F8b6Bc66Dd9c48a6E
  • IoTeX: 0xcdf79194c6c285077a58da47641d4dbe51f63542

🧪 Testing

Run Tests

# Install dev dependencies
pip install -e .[dev]

# Run tests
pytest

# Run with coverage
pytest --cov=fastapi_x402

Test on Base Sepolia

  1. Get testnet USDC from Base Sepolia faucet
  2. Set up test wallet with CDP SDK
  3. Use the test client examples in /examples

🔐 Security

  • Replay Protection: Each payment can only be used once
  • Cryptographic Verification: All payments are cryptographically signed
  • Timeout Protection: Payments expire after specified timeout
  • Facilitator Validation: Third-party validation of payment authenticity

🤝 Contributing

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add some amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

Development Setup

git clone https://github.com/fastapi-x402/fastapi-x402.git
cd fastapi-x402
pip install -e .[dev]
pre-commit install

📚 Examples

Check out the /examples directory for:

  • Basic server setup
  • Client integration examples
  • Advanced configuration
  • Testing utilities

🆘 Support

📄 License

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

🙏 Acknowledgments


Ready to monetize your APIs? Install fastapi-x402 and start earning in minutes! 🚀

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

fastapi_x402-0.1.1.tar.gz (25.7 kB view details)

Uploaded Source

Built Distribution

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

fastapi_x402-0.1.1-py3-none-any.whl (19.1 kB view details)

Uploaded Python 3

File details

Details for the file fastapi_x402-0.1.1.tar.gz.

File metadata

  • Download URL: fastapi_x402-0.1.1.tar.gz
  • Upload date:
  • Size: 25.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for fastapi_x402-0.1.1.tar.gz
Algorithm Hash digest
SHA256 082fa5903c972473a5b4f8f984ff7f2f88c5d0063dd2ee28e4ae839ab8abd5ca
MD5 cbb267df9b7e3fc96558ebd9a132dcca
BLAKE2b-256 27cda67db4b113423251be3f74c9a03d539bf32bd35dd2240080dffb483f712c

See more details on using hashes here.

Provenance

The following attestation bundles were made for fastapi_x402-0.1.1.tar.gz:

Publisher: publish.yml on jordo1138/fastapi-x402

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

File details

Details for the file fastapi_x402-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: fastapi_x402-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 19.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for fastapi_x402-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 845887bd12ecff8c3966dbaed66e6d4a12af385b6fefe478ae2a0a175f1087cd
MD5 d9b7b38c2b40c6933feda43076da6e2a
BLAKE2b-256 5033d129d51a4c68674d2e67c35c02f0fc4ad5f2a33c5fd5bfd3700a32a62101

See more details on using hashes here.

Provenance

The following attestation bundles were made for fastapi_x402-0.1.1-py3-none-any.whl:

Publisher: publish.yml on jordo1138/fastapi-x402

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