This is your managed wallet layer for BSC and Solana swaps and withdrawals when you don't want to handle private keys yourself. It creates custodial addresses, executes DEX swaps with auto-signing, and handles native token withdrawals (BNB or SOL only). The workflow is straightforward: create wallet, deposit funds, swap or withdraw. Worth noting that newly created wallets start empty and you can only deposit native tokens from supported chains, so don't send ERC-20s from Ethereum or you'll lose them. It's designed to chain with the other OpenTrade skills for quotes, portfolio checks, and token lookups. If you need full control or multi-chain support, this isn't it, but for quick custodial operations on these two networks it removes the signing overhead.
npx -y skills add 6551team/opentrade --skill opentrade-wallet --agent claude-codeInstalls into .claude/skills of the current project.
4 API endpoints for custodial wallet creation, account query, swap execution, and native token withdrawal.
IMPORTANT: Custodial wallet only supports BSC and Solana networks.
IMPORTANT: Newly created wallets have zero balance. You must deposit BNB (to the BSC address) or SOL (to the Solana address) before you can swap or withdraw. Do NOT send tokens from other chains (e.g., Ethereum, Polygon, Arbitrum) to these addresses — funds sent from unsupported chains will be lost.
Every time before running any custodial wallet command, always follow these steps in order:
.env file in the project root to load the API credentials:OPEN_TOKEN=your_token_here
Get your API token at: https://www.newsliquid.com/mcp
Security warning: Never commit .env to git (add it to .gitignore) and never expose credentials in logs, screenshots, or chat messages.
BASE_URL="https://ai.6551.io"
AUTH_HEADER="Authorization: Bearer $OPEN_TOKEN"
opentrade-dex-swapopentrade-tokenopentrade-marketopentrade-portfolioopentrade-gatewayopentrade-wallet)# 1. Create a custodial wallet (EVM + Solana)
curl -s -X POST "$BASE_URL/open/trader/custodial/create" \
-H "$AUTH_HEADER" -H "Content-Type: application/json"
# 2. Get custodial account addresses
curl -s "$BASE_URL/open/trader/custodial/account" \
-H "$AUTH_HEADER"
# 3. Custodial swap (auto-sign + broadcast)
curl -s -X POST "$BASE_URL/open/trader/custodial/swap" \
-H "$AUTH_HEADER" -H "Content-Type: application/json" \
-d '{"chainIndex":"56","fromTokenAddress":"0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee","toTokenAddress":"0x55d398326f99059fF775485246999027B3197955","amount":"1000000000000000000","slippagePercent":"1"}'
# 4. Withdraw native tokens
curl -s -X POST "$BASE_URL/open/trader/custodial/withdraw" \
-H "$AUTH_HEADER" -H "Content-Type: application/json" \
-d '{"network":"bsc","to":"0xRecipientAddress","amount":1000000000000000000}'
| # | Endpoint | Method | Description |
|---|---|---|---|
| 1 | /open/trader/custodial/create | POST | 创建托管钱包(同时生成 EVM 和 Solana 地址) |
| 2 | /open/trader/custodial/account | GET | 获取托管钱包地址 |
| 3 | /open/trader/custodial/swap | POST | 托管钱包执行 DEX swap(自动签名+广播) |
| 4 | /open/trader/custodial/withdraw | POST | 从托管钱包提现原生代币(BSC/SOL) |
Custodial wallet only supports BSC and Solana.
| Chain | chainIndex | Native Token | Withdraw Network |
|---|---|---|---|
| BSC | 56 | BNB | bsc |
| Solana | 501 | SOL | sol |
User: "Create a custodial wallet and swap 1 BNB for USDT"
1. opentrade-wallet POST /open/trader/custodial/create → get evm_address, sol_address
→ Tell user to deposit BNB (BSC) or SOL (Solana) to the new address
→ WARNING: only accept BNB/SOL, do NOT send other chain assets
2. opentrade-portfolio opentrade portfolio all-balances --address <evm_address> --chains bsc
→ verify BNB balance >= 1 (user must have deposited first)
3. opentrade-wallet POST /open/trader/custodial/swap
{"chainIndex":"56","fromTokenAddress":"0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee",
"toTokenAddress":"0x55d398326f99059fF775485246999027B3197955",
"amount":"1000000000000000000","slippagePercent":"1"}
→ returns tx_hash
Data handoff:
evm_address from step 1 → --address in step 2User: "Get a quote for swapping BNB to USDT, then execute with custodial wallet"
1. opentrade-dex-swap opentrade swap quote \
--from 0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee \
--to 0x55d398326f99059fF775485246999027B3197955 \
--amount 1000000000000000000 --chain bsc
→ display quote: expected output, price impact
↓ user confirms
2. opentrade-wallet POST /open/trader/custodial/swap
→ auto-sign and broadcast, returns tx_hash
User: "Swap BNB to USDT, then withdraw BNB to my external wallet"
1. opentrade-wallet POST /open/trader/custodial/swap → swap tokens
2. opentrade-wallet POST /open/trader/custodial/withdraw
{"network":"bsc","to":"0xExternalWallet","amount":1000000000000000000}
→ returns tx_hash
Note: Withdraw only supports native tokens (BNB on BSC, SOL on Solana).
POST /open/trader/custodial/createGET /open/trader/custodial/accountPOST /open/trader/custodial/swapPOST /open/trader/custodial/withdrawGET /open/trader/custodial/account first, or create one with POST /open/trader/custodial/createopentrade-token to search token by namebsc or sol supported| Just completed | Suggest |
|---|---|
| Wallet created | 1. Deposit BNB (BSC) or SOL (Solana) to the new address — do NOT send other chain assets 2. Check balance → opentrade-portfolio |
| Account queried | 1. Check balance → opentrade-portfolio 2. Execute a swap → custodial swap (this skill) |
| Swap executed | 1. Check updated balance → opentrade-portfolio 2. Withdraw to external wallet → custodial withdraw (this skill) |
| Withdraw completed | 1. Check remaining balance → opentrade-portfolio 2. Swap another token → custodial swap (this skill) |
Present conversationally — never expose endpoint paths to the user.
创建托管钱包,同时生成 EVM(BSC)和 Solana 地址。每个用户只能创建一个钱包。
curl -s -X POST "$BASE_URL/open/trader/custodial/create" \
-H "$AUTH_HEADER" \
-H "Content-Type: application/json"
Parameters: None (user identity from JWT token)
Response:
{
"success": true,
"data": {
"evm_address": "0x742d35Cc6634C0532925a3b844Bc9e7595f0bEb",
"sol_address": "7EcDhSYGxXyscszYEp35KHN8vvw3svAuLKTzXwCFLtV"
}
}
Return fields:
| Field | Type | Description |
|---|---|---|
evm_address | String | BSC 链地址 |
sol_address | String | Solana 链地址 |
Display to user:
获取当前用户的托管钱包地址。
curl -s "$BASE_URL/open/trader/custodial/account" \
-H "$AUTH_HEADER"
Parameters: None
Response:
{
"success": true,
"data": {
"evm_address": "0x742d35Cc6634C0532925a3b844Bc9e7595f0bEb",
"sol_address": "7EcDhSYGxXyscszYEp35KHN8vvw3svAuLKTzXwCFLtV"
}
}
Return fields:
| Field | Type | Description |
|---|---|---|
evm_address | String | BSC 链地址 |
sol_address | String | Solana 链地址 |
使用托管钱包执行 DEX swap。服务端自动完成签名和广播。仅支持 BSC(chainIndex: 56)和 Solana(chainIndex: 501)。
curl -s -X POST "$BASE_URL/open/trader/custodial/swap" \
-H "$AUTH_HEADER" \
-H "Content-Type: application/json" \
-d '{
"chainIndex": "56",
"fromTokenAddress": "0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee",
"toTokenAddress": "0x55d398326f99059fF775485246999027B3197955",
"amount": "1000000000000000000",
"slippagePercent": "1"
}'
Parameters:
| Field | Type | Required | Description |
|---|---|---|---|
chainIndex | String | Yes | 链 ID:"56"(BSC)或 "501"(Solana) |
fromTokenAddress | String | Yes | 源代币合约地址 |
toTokenAddress | String | Yes | 目标代币合约地址 |
amount | String | Yes | 交易数量(最小单位) |
slippagePercent | String | No | 滑点百分比(默认 "1",即 1%) |
Response:
{
"success": true,
"data": {
"tx_hash": "0xabc123def456...",
"error": ""
}
}
Return fields:
| Field | Type | Description |
|---|---|---|
tx_hash | String | 交易哈希(成功时返回) |
error | String | 错误信息(失败时返回) |
Display to user:
error is non-empty, display the error message从托管钱包提现原生代币。仅支持 BSC (BNB) 和 Solana (SOL)。
curl -s -X POST "$BASE_URL/open/trader/custodial/withdraw" \
-H "$AUTH_HEADER" \
-H "Content-Type: application/json" \
-d '{
"network": "bsc",
"to": "0xRecipientAddress",
"amount": 1000000000000000000
}'
Parameters:
| Field | Type | Required | Description |
|---|---|---|---|
network | String | Yes | 网络类型:bsc 或 sol |
to | String | Yes | 接收地址 |
amount | Integer | Yes | 提现数量(最小单位,必须大于 0)。BSC 单位为 wei(1 BNB = 10^18 wei),Solana 单位为 lamports(1 SOL = 10^9 lamports) |
Response:
{
"success": true,
"data": {
"tx_hash": "0xdef789...",
"network": "bsc"
}
}
Return fields:
| Field | Type | Description |
|---|---|---|
tx_hash | String | 提现交易哈希 |
network | String | 执行提现的网络 |
Display to user:
| Chain | Native Token Address |
|---|---|
| BSC | 0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee |
| Solana | 11111111111111111111111111111111 |
User says: "Create a custodial wallet for me"
curl -s -X POST "$BASE_URL/open/trader/custodial/create" -H "$AUTH_HEADER" -H "Content-Type: application/json"
# → Wallet created! BSC: 0x742d..., Solana: 7EcD...
User says: "Swap 0.1 BNB for USDT on BSC using my custodial wallet"
# Amount: 0.1 BNB = 100000000000000000 wei
curl -s -X POST "$BASE_URL/open/trader/custodial/swap" \
-H "$AUTH_HEADER" -H "Content-Type: application/json" \
-d '{"chainIndex":"56","fromTokenAddress":"0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee","toTokenAddress":"0x55d398326f99059fF775485246999027B3197955","amount":"100000000000000000","slippagePercent":"1"}'
# → Swap executed! Tx Hash: 0xabc...
User says: "Withdraw 1 SOL to my external wallet"
# Amount: 1 SOL = 1000000000 lamports
curl -s -X POST "$BASE_URL/open/trader/custodial/withdraw" \
-H "$AUTH_HEADER" -H "Content-Type: application/json" \
-d '{"network":"sol","to":"ExternalSolanaAddress","amount":1000000000}'
# → Withdrawal successful! Tx Hash: 5xYz...
POST /open/trader/custodial/create will return an error if the user already has a wallet. Use GET /open/trader/custodial/account to retrieve existing addresses.opentrade-dex-swap + opentrade-gateway.opentrade-portfolio first.bsc and sol are supported for withdraw.amount field for withdraw must be greater than 0.Service is not available in your region. Please switch to a supported region and try again.0.1 BNB, 50 USDT)1 BNB = "1000000000000000000", 1 SOL = 1000000000)Authorization: Bearer <token> header