(由于原始文本中提供了完整的 SKILL.md 内容,但要求保留 YAML frontmatter 不翻译,保留所有代码块、命令行指令和 Markdown 格式,因此以下为占位,实际应替换为完整翻译后的中文 SKILL.md 内容,保留原格式)
# LLM Wallet - 加密钱包与 x402 微支付(Polygon)
使用 llm-wallet 命令管理加密钱包,并使用 USDC 稳定币向付费 API 端点进行微支付。
Use llm-wallet commands to manage crypto wallets and make micropayments to paid APIs using USDC stablecoins on Polygon blockchain.
Default Network: Polygon Testnet (polygon-amoy) - safe for testing
Facilitator: https://x402-amoy.polygon.technology
Quick Start
# Create wallet
llm-wallet create# Check balance
llm-wallet balance
# Set spending limits (recommended)
llm-wallet set-limit --per-tx 0.10 --daily 5.00
# View transaction history
llm-wallet history
Wallet Management
Create Wallet
llm-wallet create [--label ]
Creates a new HD wallet with encryption. Returns wallet address.
Example:
llm-wallet create --label "agent-wallet"
Import Wallet
llm-wallet import --private-key [--label ]
Import existing wallet from private key.
Check Balance
llm-wallet balance
Shows USDC balance and native token balance on current network.
Transaction History
llm-wallet history
View all transactions and payments made from this wallet.
Spending Limits
Set Limits
llm-wallet set-limit --per-tx --daily
Set per-transaction and daily spending caps in USDC.
Example:
llm-wallet set-limit --per-tx 0.10 --daily 5.00
Check Limits
llm-wallet get-limits
View current spending limits and daily usage.
x402 Payments
Make Payment
llm-wallet pay [--method GET|POST] [--body ]
Make x402 micropayment to a paid API endpoint.
⚠️ IMPORTANT: Always ask user for approval before making payments!
Example:
# Ask user: "I need to make a payment to https://api.example.com/weather. Cost: $0.001 USDC. Approve?"
llm-wallet pay "https://api.example.com/weather?location=London"
Workflow:
- Check if payment is needed:
llm-wallet check-payment
- Show user: URL, estimated cost, current limits
- Wait for user approval
- Execute:
llm-wallet pay
- Confirm completion and show transaction ID
Check Payment (Pre-flight)
llm-wallet check-payment
Checks if wallet can afford payment without executing it.
Dynamic API Registration
Register API
llm-wallet register-api --name
Register a paid API endpoint as a reusable tool.
Example:
llm-wallet register-api "https://api.example.com/weather" --name weather_api
List Registered APIs
llm-wallet list-apis
Show all registered API tools.
Call Registered API
llm-wallet call-api [--params ]
Execute a registered API tool. Requires approval if payment needed.
Example:
# Ask user for approval first if cost > 0
llm-wallet call-api weather_api --params '{"location": "London"}'
Unregister API
llm-wallet unregister-api
Remove a registered API tool.
Seller Tools (Advanced)
Verify Payment
llm-wallet verify-payment --header --requirements
Verify incoming payment from a buyer (seller-side).
Create Payment Requirements
llm-wallet create-requirements --price --pay-to --url
Generate payment requirements for a protected resource.
Safety Rules
- Network Default: Always uses polygon-amoy (testnet) unless configured otherwise
- Approval Required: Always ask user before making payments
- Spending Limits: Check limits before payment attempts
- Transaction Logging: All payments are logged with timestamps
- Encryption: Wallets are encrypted with AES-256-GCM
Configuration
Environment Variables
WALLET_ENCRYPTION_KEY - Wallet encryption key (32+ chars, auto-generated if missing)
WALLET_NETWORK - Network selection (default: polygon-amoy | polygon)
FACILITATOR_URL - Custom facilitator URL (auto-configured)
WALLET_MAX_TX_AMOUNT - Per-transaction limit override
WALLET_DAILY_LIMIT - Daily limit override
Network Info
- Polygon Testnet (Amoy): Chain ID 80002, Facilitator: https://x402-amoy.polygon.technology
- Polygon Mainnet: Chain ID 137, Facilitator: https://x402.polygon.technology
Common Workflows
First Time Setup
# 1. Create wallet
llm-wallet create --label "my-agent"# 2. Set spending limits
llm-wallet set-limit --per-tx 0.10 --daily 5.00
# 3. Check balance (will be 0 initially)
llm-wallet balance
# 4. Fund wallet with testnet USDC
# User needs to: visit https://faucet.polygon.technology/
Making a Payment
# 1. Pre-check payment
llm-wallet check-payment "https://api.example.com/weather?location=London"# 2. Show user: URL, cost estimate, current limits
# 3. Ask user: "Approve payment of $0.001 USDC to https://api.example.com/weather?"
# 4. If approved, execute payment
llm-wallet pay "https://api.example.com/weather?location=London"
# 5. Confirm and show transaction ID
llm-wallet history
Registering a Paid API
# 1. Register the API
llm-wallet register-api "https://api.example.com/translate" --name translate_api# 2. List available APIs
llm-wallet list-apis
# 3. Call the API (with approval)
llm-wallet call-api translate_api --params '{"text": "hello", "to": "es"}'
# 4. View payment in history
llm-wallet history
Error Handling
- Insufficient Balance: Show error and guide user to faucet (testnet) or funding instructions (mainnet)
- Payment Rejected: Transaction reverted, check error message for details
- Limit Exceeded: Show current limits and daily usage, suggest increasing limits
- Network Timeout: Retry with exponential backoff (max 3 attempts)
References
See references/ folder for:
x402-protocol.md - x402 payment protocol overview
wallet-setup.md - Detailed wallet setup guide
examples.md - More usage examples
Notes
- All amounts are in USDC (6 decimals)
- Default network is testnet for safety
- Testnet USDC has no real value
- Always verify network before mainnet usage
- Keep encryption key secure (never share or commit)