Skip to main content

Python SDK for MoltsPay - Agent-to-Agent Payments. LangChain compatible.

Project description

MoltsPay Python SDK

PyPI version Python versions License: MIT

Python SDK for MoltsPay - Agent-to-Agent Payments.

MoltsPay enables AI agents to pay each other for services using the x402 protocol - HTTP-native payments with USDC stablecoins. No gas fees, no complex wallet management.

What is MoltsPay?

MoltsPay is blockchain payment infrastructure designed for AI agents. It solves a fundamental problem: how do autonomous AI agents pay for services?

  • ๐Ÿค– Agent-to-Agent Commerce - AI agents can autonomously discover, pay for, and use services
  • ๐Ÿ’จ Gasless Payments - Uses EIP-2612 permits, no ETH needed
  • ๐Ÿ”— x402 Protocol - HTTP 402 Payment Required - payments as native HTTP flow
  • ๐Ÿ”’ Spending Limits - Set per-transaction and daily limits for safety
  • ๐ŸŒ Multi-Chain - Base and Polygon supported
  • ๐Ÿฆœ LangChain Ready - Drop-in tools for LangChain agents

Installation

pip install moltspay

For LangChain integration:

pip install moltspay[langchain]

Quick Start

from moltspay import MoltsPay

# Initialize (auto-creates wallet if not exists)
client = MoltsPay()
print(f"Wallet address: {client.address}")

# Discover services from a provider
services = client.discover("https://juai8.com/zen7")
for svc in services:
    print(f"{svc.id}: {svc.price} {svc.currency}")

# Pay for a service
result = client.pay(
    "https://juai8.com/zen7",
    "text-to-video",
    prompt="a cat dancing on the beach"
)
print(result.result)

Features

Auto Wallet Management

Wallet is automatically created on first run and stored at ~/.moltspay/wallet.json. Compatible with Node.js CLI.

from moltspay import MoltsPay

client = MoltsPay()
print(f"Address: {client.address}")
print(f"Balance: {client.balance()} USDC")

Spending Limits

Control your agent's spending with built-in limits:

from moltspay import MoltsPay

client = MoltsPay()

# Check current limits
limits = client.limits()
print(f"Max per tx: {limits.max_per_tx}")
print(f"Max per day: {limits.max_per_day}")
print(f"Spent today: {limits.spent_today}")

# Update limits
client.set_limits(max_per_tx=20, max_per_day=200)

Multi-Chain Support

MoltsPay supports multiple chains. Default is Base, but you can use Polygon:

from moltspay import MoltsPay

# Default: Base
client = MoltsPay()

# Use Polygon
client = MoltsPay(chain='polygon')

# Pay on Polygon
result = client.pay(
    "https://juai8.com/zen7",
    "text-to-video",
    prompt="a cat dancing"
)

Supported Chains:

Chain Network ID Token
Base eip155:8453 USDC
Polygon eip155:137 USDC

Both chains are gasless - the CDP facilitator handles all on-chain settlement.

Async Support

Full async/await support for high-performance applications:

import asyncio
from moltspay import AsyncMoltsPay

async def main():
    async with AsyncMoltsPay() as client:
        result = await client.pay(
            "https://juai8.com/zen7",
            "text-to-video",
            prompt="a cat dancing"
        )
        print(result.result)

asyncio.run(main())

Error Handling

Comprehensive exception types for robust error handling:

from moltspay import MoltsPay, InsufficientFunds, LimitExceeded, PaymentError

client = MoltsPay()

try:
    result = client.pay(...)
except InsufficientFunds as e:
    print(f"Need {e.required} USDC, have {e.balance}")
except LimitExceeded as e:
    print(f"Exceeds {e.limit_type} limit: {e.amount} > {e.limit}")
except PaymentError as e:
    print(f"Payment failed: {e}")

LangChain Integration

Use MoltsPay as tools in your LangChain agents - let your AI autonomously pay for services!

from langchain.agents import initialize_agent, AgentType
from langchain_openai import ChatOpenAI
from moltspay.integrations.langchain import MoltsPayTool

llm = ChatOpenAI(model="gpt-4")
tools = [MoltsPayTool()]

agent = initialize_agent(
    tools, 
    llm, 
    agent=AgentType.OPENAI_FUNCTIONS,
    verbose=True
)

# Agent can now pay for AI services!
result = agent.run("Generate a video of a cat dancing on the beach")

Available Tools

Two tools available for different use cases:

from moltspay.integrations.langchain import get_moltspay_tools

tools = get_moltspay_tools()  # Returns both tools
Tool Description
MoltsPayTool Pay for and execute services
MoltsPayDiscoverTool Discover available services and prices

CLI Compatibility

Wallet format is fully compatible with the Node.js CLI:

# Create wallet with Node CLI
npx moltspay init --chain base

# Use same wallet in Python
python -c "from moltspay import MoltsPay; print(MoltsPay().address)"

How x402 Works

Your Agent                     Service Provider              Blockchain
    โ”‚                               โ”‚                           โ”‚
    โ”‚ Request service               โ”‚                           โ”‚
    โ”‚ โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€>   โ”‚                           โ”‚
    โ”‚                               โ”‚                           โ”‚
    โ”‚ 402 + price + wallet          โ”‚                           โ”‚
    โ”‚ <โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€   โ”‚                           โ”‚
    โ”‚                               โ”‚                           โ”‚
    โ”‚ [Sign payment - NO GAS]       โ”‚                           โ”‚
    โ”‚                               โ”‚                           โ”‚
    โ”‚ Request + signed payment      โ”‚                           โ”‚
    โ”‚ โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€>   โ”‚ Verify & settle           โ”‚
    โ”‚                               โ”‚ โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€>โ”‚
    โ”‚                               โ”‚                           โ”‚
    โ”‚ 200 OK + result               โ”‚                           โ”‚
    โ”‚ <โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€   โ”‚                           โ”‚

Your agent never pays gas - the CDP facilitator handles all on-chain settlement.

Use Cases

  • AI Assistants - Let your assistant pay for premium APIs
  • Autonomous Agents - Agents that can spend within limits
  • Multi-Agent Systems - Agents paying other agents for services
  • AI Pipelines - Pay-per-use for expensive compute steps

Running a Server (Accepting Payments)

Want to accept payments for your AI services? See the Server Guide.

Quick start:

# Install
pip install moltspay

# Create skill structure
mkdir my_skill && cd my_skill
# Add moltspay.services.json and __init__.py (see docs)

# Start server
moltspay-server ./my_skill --port 8402

Related Projects

Links

License

MIT

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

moltspay-0.4.1.tar.gz (36.0 kB view details)

Uploaded Source

Built Distribution

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

moltspay-0.4.1-py3-none-any.whl (30.4 kB view details)

Uploaded Python 3

File details

Details for the file moltspay-0.4.1.tar.gz.

File metadata

  • Download URL: moltspay-0.4.1.tar.gz
  • Upload date:
  • Size: 36.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for moltspay-0.4.1.tar.gz
Algorithm Hash digest
SHA256 f4e66f8b5a5079dc923cd69f4272d49ef98e088f2d55122d3830a84c91834477
MD5 10ef108a8e6fe2e986001fb1beea4fde
BLAKE2b-256 96645d6ce42fed236531605c3c2f88dfcf56fd76c106bcfe8fa9a3d5787f33be

See more details on using hashes here.

File details

Details for the file moltspay-0.4.1-py3-none-any.whl.

File metadata

  • Download URL: moltspay-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 30.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for moltspay-0.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 1f29c7dd95d4f471fa2f70cae77a4a731e72f3f7464ce647238ff95634f769d9
MD5 32a718d20ef667d45d1f2e59ce55e13c
BLAKE2b-256 414faa687d6c762bccf5f1580a142772c5757d57f6592573cadc58d309189539

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