Skip to main content

Python library for processing agentic payments (ACP, AP2, x402) via Stripe with automated Square-managed payouts

Project description

AgenticlyPay

A Python library for processing agentic payments (ACP, AP2, x402) via Stripe. Built for agentic developers who need automated payment processing, monthly Square-managed payouts, and tax compliance.

Features

  • Multi-Protocol Support: Process payments using ACP (Agentic Commerce Protocol), AP2 (Agent Payments Protocol), or x402 protocols
  • Stripe Connect Integration: Seamless onboarding and account management for developers
  • Automated Square Payouts: Monthly automated payouts via Square to your connected bank details
  • Tax Compliance: Automatic 1099 form generation and filing
  • Transparent Pricing: 6.5% + $0.30 per transaction
  • Email-Only Configuration: No API keys needed - just use your email address

Important: Email Requirements

Your email address links your usage history and Square payouts. Ensure the email belongs to the owner of the Square account that will receive transfers.

Installation

pip install agenticlypay

Quick Start

Basic Usage

from agenticlypay import AgenticlyPayClient

# Initialize the client (no API keys needed!)
client = AgenticlyPayClient(base_url="https://api.agenticlypay.com")  # Optional, defaults to production

# Create a developer account
account = client.create_account(
    email="developer@example.com",
    country="US"
)

# Process a payment (AUTO protocol)
# IMPORTANT: Include your email for usage tracking
payment = client.process_payment(
    email="developer@example.com",
    protocol="AUTO",
    amount=10000,  # $100.00 in cents
    developer_account_id=account["account"]["account_id"],
    currency="usd",
    description="Payment for service"
    # Include `mandate` for AP2 or `resource_url` for x402
)

Using Convenience Wrappers

from agenticlypay import PaymentProcessor, ConnectManager

# Initialize components (no API keys needed!)
payment_processor = PaymentProcessor()
connect_manager = ConnectManager()

# Create a developer account
account = connect_manager.create_developer_account(
    email="developer@example.com",
    country="US"
)

# Process a payment
result = payment_processor.process_payment(
    email="developer@example.com",  # Required
    protocol="AUTO",
    amount=10000,  # $100.00 in cents
    developer_account_id=account["account_id"],
    currency="usd"
)

ACP Payment Example

from agenticlypay import AgenticlyPayClient

client = AgenticlyPayClient()

result = client.process_payment(
    email="developer@example.com",  # Required
    protocol="ACP",
    amount=10000,  # $100.00 in cents
    currency="usd",
    developer_account_id="acct_xxxxx",
    description="Payment for service"
)

Note: Monthly payouts are automatically initiated via Square to the bank account connected to your developer profile. Use an email that corresponds to your Square account.

AP2 Payment Example

result = client.process_payment(
    email="developer@example.com",  # Required
    protocol="AP2",
    amount=10000,
    currency="usd",
    developer_account_id="acct_xxxxx",
    mandate={
        "agent_id": "agent_123",
        "user_id": "user_456",
        "permissions": ["create_payment", "complete_purchase"],
        "expires_at": 1735689600,
        "mandate_id": "mandate_789"
    }
)

x402 Payment Example

result = client.process_payment(
    email="developer@example.com",  # Required
    protocol="x402",
    amount=10000,
    currency="usd",
    developer_account_id="acct_xxxxx",
    resource_url="/api/data/endpoint"
)

Complete Account Setup Example

from agenticlypay import AgenticlyPayClient

client = AgenticlyPayClient()

# 1. Create account
account = client.create_account(
    email="developer@example.com",
    country="US"
)

# 2. Create onboarding link
onboarding = client.create_onboarding_link(
    account_id=account["account"]["account_id"],
    refresh_url="https://yourapp.com/reauth",
    return_url="https://yourapp.com/success",
    email="developer@example.com"  # Required
)

# 3. Redirect user to onboarding.url
print(f"Onboarding URL: {onboarding['onboarding_link']['url']}")

# 4. Process payments
payment = client.process_payment(
    email="developer@example.com",  # Required
    protocol="AUTO",
    amount=10000,
    developer_account_id=account["account"]["account_id"],
    currency="usd"
)

Monthly Square Payouts

Monthly payouts are automatically sent via Square to the bank account associated with your developer account. Square handles the transfer once your balance reaches the payout threshold—no extra work on your end.

API Reference

AgenticlyPayClient

The main client class for interacting with the AgenticlyPay API.

Methods

  • create_account(email, country="US", metadata=None) - Create a developer account
  • get_account(account_id, email) - Get account status
  • create_onboarding_link(account_id, refresh_url, return_url, email) - Create onboarding link
  • configure_payout_schedule(account_id, interval, email, monthly_anchor=None, weekly_anchor=None) - Configure payout schedule
  • process_payment(email, protocol, amount, developer_account_id, currency="usd", ...) - Process a payment
  • confirm_payment(email, protocol, payment_id, payment_method=None) - Confirm a payment
  • get_payment_status(email, protocol, payment_id) - Get payment status
  • get_fee(email, amount) - Calculate fee
  • get_monthly_earnings(email, account_id, year, month) - Get monthly earnings
  • create_transfer(email, developer_account_id, amount, currency="usd", reference=None) - Create manual transfer
  • get_annual_earnings(email, account_id, year) - Get annual earnings for tax reporting

All methods require your email address for usage tracking and payout processing.

Error Handling

from agenticlypay import AgenticlyPayClient, AgenticlyPayError

client = AgenticlyPayClient()

try:
    account = client.create_account(email="developer@example.com", country="US")
except AgenticlyPayError as e:
    print(f"Error: {e}")
    print(f"Status Code: {e.status_code}")

License

MIT License

Support

For issues and questions, please visit our GitHub repository or contact support@agenticlypay.com

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

agenticlypay-0.5.0.tar.gz (34.4 kB view details)

Uploaded Source

Built Distribution

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

agenticlypay-0.5.0-py3-none-any.whl (42.2 kB view details)

Uploaded Python 3

File details

Details for the file agenticlypay-0.5.0.tar.gz.

File metadata

  • Download URL: agenticlypay-0.5.0.tar.gz
  • Upload date:
  • Size: 34.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for agenticlypay-0.5.0.tar.gz
Algorithm Hash digest
SHA256 630f51d0e4d417ac9f5495af1920109ceb770728c8db345693911157086f7567
MD5 c65b7fe737e710bd47fd011286512bfb
BLAKE2b-256 70245cbde0569d1a231574baf8e4fb4073989fb3d8078d5e17f8060934ce5735

See more details on using hashes here.

File details

Details for the file agenticlypay-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: agenticlypay-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 42.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for agenticlypay-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 4a3001d0e9ce3f47b4aa097ab23260e20a388873052f28ebfef92ecd1ee3a34b
MD5 0adc17cc3468e68c3157090419c59749
BLAKE2b-256 965a920192fddcde83d62f421603f48a1bbe7828c816b7566cb738f9b2a0b3eb

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