OpenClawCash
OpenclawCash crypto wallet API for AI agents. Use when an agent needs to send native or token transfers, check balances, list wallets, or interact with EVM a...
技能说明
name: agentwalletapi description: OpenclawCash crypto wallet API for AI agents. Use when an agent needs to send native or token transfers, check balances, list wallets, or interact with EVM and Solana wallets programmatically via OpenclawCash. license: Proprietary compatibility: Requires network access to https://openclawcash.com metadata: author: agentwalletapi version: "1.9.6" required_env_vars: - AGENTWALLETAPI_KEY optional_env_vars: - AGENTWALLETAPI_URL required_binaries: - curl optional_binaries: - jq
OpenclawCash Agent API
Interact with OpenclawCash-managed wallets to send native assets and tokens, check balances, and execute agent-safe wallet operations across EVM and Solana networks.
Requirements
- Required env var:
AGENTWALLETAPI_KEY - Optional env var:
AGENTWALLETAPI_URL(default:https://openclawcash.com) - Required local binary:
curl - Optional local binary:
jq(for pretty JSON output in CLI) - Network access required:
https://openclawcash.com
Preferred Integration Path
- If the client supports MCP, prefer the public OpenClawCash MCP server:
npx -y @openclawcash/mcp-server - Use MCP as the primary execution path because tools, schemas, and results are structured for the client.
- Use the included CLI script only as a fallback when MCP is unavailable or the client cannot attach MCP servers.
- MCP and the CLI script target the same underlying OpenClawCash agent API. They are two access paths, not two different products.
Safety Model
- Start with read-only calls (
wallets,wallet,balance,tokens) on testnets first. - High-risk actions are gated:
- API key permissions in dashboard (
allowWalletCreation,allowWalletImport) - Explicit CLI confirmation (
--yes) for write actions
- API key permissions in dashboard (
- Agents should establish an approval mode early in the session for write actions:
confirm_each_write: ask before every write action.operate_on_my_behalf: after one explicit onboarding approval, execute future write actions without re-asking, as long as the user keeps instructing the agent in the same session.
- For
operate_on_my_behalf, the agent should treat the user's later task messages as execution instructions and run the corresponding write commands with--yes. - Ask again only if:
- the user revokes or changes approval mode
- the session is restarted or memory is lost
- the action is outside the scope the user approved
- the agent is unsure which wallet, token, amount, destination, spender, or chain is intended
- If the user gives only a broad instruction like "go ahead" but execution details are still missing, gather the missing details first instead of repeating a generic permission request.
Setup
- Run the setup script to create your
.envfile:bash scripts/setup.sh - Edit the
.envfile in this skill folder and replace the placeholder with your real API key:AGENTWALLETAPI_KEY=occ_your_api_key - Get your API key at https://openclawcash.com (sign up, create a wallet, go to API Keys page).
Legacy CLI Fallback
If MCP is unavailable, use the included tool script to make API calls directly:
# Read-only (recommended first)
bash scripts/agentwalletapi.sh wallets
bash scripts/agentwalletapi.sh wallet Q7X2K9P
bash scripts/agentwalletapi.sh wallet "Trading Bot"
bash scripts/agentwalletapi.sh balance Q7X2K9P
bash scripts/agentwalletapi.sh transactions Q7X2K9P
bash scripts/agentwalletapi.sh tokens mainnet
# Write actions (require explicit --yes)
export WALLET_EXPORT_PASSPHRASE_OPS='your-strong-passphrase'
bash scripts/agentwalletapi.sh create "Ops Wallet" sepolia WALLET_EXPORT_PASSPHRASE_OPS --yes
bash scripts/agentwalletapi.sh import "Treasury Imported" mainnet --yes
# Automation-safe import: read private key from stdin instead of command args
printf '%s' '<private_key>' | bash scripts/agentwalletapi.sh import "Treasury Imported" mainnet - --yes
bash scripts/agentwalletapi.sh transfer Q7X2K9P 0xRecipient 0.01 --yes
bash scripts/agentwalletapi.sh transfer Q7X2K9P 0xRecipient 100 USDC --yes
bash scripts/agentwalletapi.sh quote mainnet WETH USDC 10000000000000000
bash scripts/agentwalletapi.sh quote solana-mainnet SOL USDC 10000000 solana
bash scripts/agentwalletapi.sh swap Q7X2K9P WETH USDC 10000000000000000 0.5 --yes
Import Input Safety
- Wallet import is optional and not required for normal wallet operations (list, balance, transfer, swap).
- Import works only when the user explicitly enables API key permission
allowWalletImportin dashboard settings. - Import execution requires explicit confirmation in the CLI (
--yesfor automation, or interactiveYESprompt). - Avoid passing sensitive inputs as CLI arguments when possible (shell history/process logs risk).
- Preferred options:
- Interactive hidden prompt: omit the private key argument.
- Automation: pass
-and pipe input via stdin.
Base URL
https://openclawcash.com
Troubleshooting
If requests fail because of host/URL issues, use this recovery flow:
- Open
agentwalletapi/.envand verifyAGENTWALLETAPI_KEYis set and has no extra spaces. - If the API host is wrong or unreachable, set this in the same
.envfile:AGENTWALLETAPI_URL=https://openclawcash.com - Retry a simple read call first:
bash scripts/agentwalletapi.sh wallets - If it still fails, report the exact error and stop before attempting transfer/swap actions.
Authentication
The API key is loaded from the .env file in this skill folder. For direct HTTP calls, include it as a header:
X-Agent-Key: occ_your_api_key
Content-Type: application/json
API Surfaces
- Agent API (API key auth):
/api/agent/*- Authenticate with
X-Agent-Key - Used for autonomous agent execution (wallets list/create/import, transactions, balance, transfer, swap, quote, approve)
- Authenticate with
- Dashboard/User API (session auth):
/api/wallets/*- Authenticate with bearer token or
aw_sessioncookie - Used for user-managed dashboard operations (including wallet import and wallet creation).
- Dashboard wallet creation now requires
exportPassphrase(minimum 12 characters). - Private-key export requires
exportPassphraseand is protected by rate limits and temporary lockouts.
- Authenticate with bearer token or
Workflow
GET /api/agent/wallets- Discover available wallets (id, label, address, network, chain). Optional?includeBalances=trueadds nativebalance+nativeSymbolGET /api/agent/wallet?walletId=...or?walletLabel=...or?walletAddress=...- Fetch one wallet with native/token balances- Optional wallet lifecycle actions:
POST /api/agent/wallets/create- Create a new wallet under API-key policy controlsPOST /api/agent/wallets/import- Import amainnetorsolana-mainnetwallet under API-key policy controls
GET /api/agent/transactions?walletId=...(orwalletLabel/walletAddress) - Read merged wallet transaction history (on-chain + app-recorded)GET /api/agent/supported-tokens?network=...or?chain=evm|solana- Get recommended common, well-known token list + guidance (requiresX-Agent-Key)POST /api/agent/token-balance- Check wallet balances (native + token balances; specific token by symbol/address supported)POST /api/agent/quote- Get a swap quote before execution on Uniswap (EVM) or Jupiter (Solana mainnet)POST /api/agent/swap- Execute token swap on Uniswap (EVM) or Jupiter (Solana mainnet)POST /api/agent/transfer- Send native coin or token on the wallet's chain (optionalchainguard)- Use returned
txHashvalues to confirm transactions
Approval Handling For Agents
Use this pattern for write actions:
- At the first write-intent in a session, ask one short onboarding question:
- "Do you want approval for every write action, or should I operate on your behalf for this session?"
- Store the chosen mode in conversation memory.
- If the mode is
confirm_each_write:- ask for approval before each transfer, swap, approval, import, or wallet creation
- after approval, execute with the MCP write tool or the legacy CLI fallback with
--yes
- If the mode is
operate_on_my_behalf:- do not ask again for each transfer
- when the user later says things like "send X to Y" or "swap A for B", execute with the MCP write tool or the legacy CLI fallback with
--yesonce the needed details are clear
- In either mode:
- if execution details are missing, ask only for the missing details
- if the user changes modes or revokes permission, update memory and follow the new rule
Recommended onboarding wording:
- "Choose write approval mode for this session:
confirm_each_writeoroperate_on_my_behalf."
Example:
- User selects:
operate_on_my_behalf - Later user message: "Send 100 USDC from wallet Q7X2K9P to 0xabc... on Ethereum."
- If MCP is available, the agent should call the matching MCP write tool directly.
- If MCP is not available, the agent should execute:
bash scripts/agentwalletapi.sh transfer Q7X2K9P 0xabc... 100 USDC evm --yes - The agent should not ask for transfer permission again in that same session unless the user revokes the mode or the instruction is ambiguous.
Quick Reference
| Endpoint | Method | Auth | Purpose |
|---|---|---|---|
/api/agent/wallets | GET | Yes | List wallets (discovery; optional includeBalances=true for native balances) |
/api/agent/wallet | GET | Yes | Get one wallet detail with native/token balances |
/api/agent/wallets/create | POST | Yes | Create a new API-key-managed wallet |
/api/agent/wallets/import | POST | Yes | Import a mainnet/solana-mainnet wallet via API key |
/api/agent/transactions | GET | Yes | List per-wallet transaction history |
/api/agent/transfer | POST | Yes | Send native/token transfers (EVM + Solana) |
/api/agent/swap | POST | Yes | Execute DEX swap (Uniswap on EVM, Jupiter on Solana mainnet) |
/api/agent/quote | POST | Yes | Get swap quotes (Uniswap on EVM, Jupiter on Solana mainnet) |
/api/agent/token-balance | POST | Yes | Check balances |
/api/agent/supported-tokens | GET | Yes | List recommended common, well-known tokens per network |
/api/agent/approve | POST | Yes | Approve spender for ERC-20 token (EVM only) |
Agent Wallet Create/Import (Agent API)
Agent-side wallet lifecycle endpoints:
POST /api/agent/wallets/createPOST /api/agent/wallets/import
Behavior notes:
- Both require
X-Agent-Key. - Both are gated by API key permissions configured in dashboard:
allowWalletCreationfor createallowWalletImportfor import
- Both are rate-limited per API key. Exceeding the limit returns
429withRetry-After. - Agent import supports
mainnetandsolana-mainnet. - Agent wallet create requires:
exportPassphrase(minimum 12 characters)exportPassphraseStorageTypeexportPassphraseStorageRefconfirmExportPassphraseSaved: true
- Agent-safe create sequence:
- Save export passphrase in secure storage first.
- Prefer env-backed storage for local agents.
- Record the storage location you used.
- Then call
POST /api/agent/wallets/createwith:- the passphrase
exportPassphraseStorageTypeexportPassphraseStorageRefconfirmExportPassphraseSaved: true
- For MCP and the legacy CLI fallback, env-backed storage is the strongest path because the local tool can verify the env var exists before wallet creation.
Transfer Examples
Send native coin (default when no token specified):
{ "walletId": "Q7X2K9P", "to": "0xRecipient...", "amount": "0.01" }
Send 100 USDC by symbol:
{ "walletLabel": "Trading Bot", "to": "0xRecipient...", "token": "USDC", "amount": "100" }
Send arbitrary ERC-20 by contract address:
{ "walletId": "Q7X2K9P", "to": "0xRecipient...", "token": "0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48", "amount": "100" }
Send SOL by symbol:
{ "walletId": "Q7X2K9P", "to": "SolanaRecipientWalletAddress...", "token": "SOL", "amount": "0.01" }
Send SOL with memo (Solana only):
{ "walletId": "Q7X2K9P", "to": "SolanaRecipientWalletAddress...", "token": "SOL", "amount": "0.01", "memo": "payment verification note" }
Use amount for human-readable values (e.g., "100" = 100 USDC). Use value for base units (smallest denomination on each chain).
Use optional chain: "evm" | "solana" in agent payloads for explicit chain routing and validation.
memo is supported only for Solana transfers and must pass safety validation (max 5 words, max 256 UTF-8 bytes, no control/invisible characters).
Native transfers (EVM + Solana) enforce a minimum transferable amount preflight that accounts for platform fee and network fee; Solana may also require a larger first funding transfer for a brand-new recipient address.
For native SOL transfers, the API may auto-adjust requested value to fit platform fee + network fee.
Transfer responses include requestedValue, adjustedValue, requestedAmount, and adjustedAmount.
Token Support Model
GET /api/agent/supported-tokensreturns recommended common, well-known tokens plus guidance fields.- EVM transfer/swap/balance endpoints support any valid ERC-20 token contract address.
- Solana transfer/balance endpoints support any valid SPL mint address.
- Native tokens appear as
ETHon EVM andSOLon Solana (with chain-specific native token IDs in balance payloads).
Error Codes
- 200: Success
- 400: Invalid input, insufficient funds, unknown token, or policy violation
- 400
chain_mismatch: requestedchaindoes not match the selected wallet - 400
amount_below_min_transfer: requested native transfer is below minimum transferable amount after fee/network preflight - 400
insufficient_balance: requested transfer + fees exceed available balance - 401: Missing/invalid API key
- 404: Wallet not found
- 500: Internal error (retry with corrected payload or reduced amount)
Policy Constraints
Wallets may have governance policies:
- Whitelist: Only transfers to pre-approved addresses allowed
- Spending Limit: Max value per transaction (configured per wallet policy)
Violations return HTTP 401 with an explanation message.
Important Notes
- All POST requests require
Content-Type: application/json - EVM token transfers require ETH in the wallet for gas fees
- Solana token transfers require SOL in the wallet for fees
- Solana transfer memos are optional and Solana-only: max 5 words, max 256 UTF-8 bytes, no control/invisible characters
- Solana native transfers account for network fee and can auto-adjust requested transfer amount
- Native transfers may return
400 amount_below_min_transferwhen requested amount is too small after platform fee or below chain transferability minimum (for example, first funding a new Solana address) - If requested native SOL + platform fee + network fee cannot fit wallet balance, API returns
400 insufficient_balance - Swap supports EVM (Uniswap) and Solana mainnet (Jupiter); Quote supports EVM and Solana mainnet; Approve is EVM-only
- A platform fee (default 1%) is deducted from the token amount
- Use
amountfor simplicity, usevaluefor precise base-unit control - For robust agent behavior:
- First call
wallets, thenwallet(ortoken-balance), thenquote, thenswap. - On 400 with
insufficient_token_balance, reduce amount or change token.
- First call
- The
.envfile in this skill folder stores your API key — never commit it to version control
File Structure
agentwalletapi/
├── SKILL.md # This file
├── .env # Your API key (created by setup.sh)
├── scripts/
│ ├── setup.sh # Creates .env with API key placeholder
│ └── agentwalletapi.sh # CLI tool for making API calls
└── references/
└── api-endpoints.md # Full endpoint documentation
See references/api-endpoints.md for full endpoint details with request/response examples.
如何使用「OpenClawCash」?
- 打开小龙虾AI(Web 或 iOS App)
- 点击上方「立即使用」按钮,或在对话框中输入任务描述
- 小龙虾AI 会自动匹配并调用「OpenClawCash」技能完成任务
- 结果即时呈现,支持继续对话优化