Requirements
- Target platform
- OpenClaw
- Install method
- Manual import
- Extraction
- Extract archive
- Prerequisites
- OpenClaw
- Primary doc
- SKILL.md
Swap any Solana token from chat. Say 'swap 1 SOL for USDC' and it handles everything — quoting, signing, sending, confirming. No API keys, no wallet extensions, no setup beyond a keypair. Powered by Jupiter. Use when a user wants to swap, trade, exchange, buy, or sell Solana SPL tokens, SOL, USDC, memecoins, or any token pair on Solana.
Swap any Solana token from chat. Say 'swap 1 SOL for USDC' and it handles everything — quoting, signing, sending, confirming. No API keys, no wallet extensions, no setup beyond a keypair. Powered by Jupiter. Use when a user wants to swap, trade, exchange, buy, or sell Solana SPL tokens, SOL, USDC, memecoins, or any token pair on Solana.
Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.
I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Tell me what you changed and call out any manual steps you could not complete.
I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Summarize what changed and any follow-up checks I should run.
Swap any Solana token from chat. Say "swap 1 SOL for USDC" and it handles everything — quoting, signing, sending, confirming. No API keys, no wallet extensions, no setup beyond a keypair. Powered by Jupiter.
First run: Install dependencies (automatic if install spec is supported, otherwise manual): cd {baseDir} && npm install --production Required env var: SOLANA_KEYPAIR_PATH — path to a Solana keypair JSON file (standard solana-keygen format). This skill reads your keypair to sign transactions. Only use with a keypair you trust this skill to access. Optional env vars: SOLANA_RPC_URL — custom RPC endpoint (default: https://api.mainnet-beta.solana.com) OSS_DEFAULT_SLIPPAGE_BPS — default slippage in basis points (default: 100 = 1%) OSS_PRIORITY_FEE_FLOOR — minimum priority fee in lamports (default: 50000) No API keys required. Jupiter is used unauthenticated.
TokenMintSOL (wrapped)So11111111111111111111111111111111111111112USDCEPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1vUSDTEs9vMFrzaCERmJfrF4H2FYD4KCoNkY11McCe8BenwNYB For other tokens, ask the user for the mint address.
node {baseDir}/scripts/swap.mjs prepare \ --from So11111111111111111111111111111111111111112 \ --to EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v \ --amount 1000000000 \ --slippage 100 Returns JSON: { "prepareId": "abc123", "expectedOut": "150230000", "minOut": "148727700", "priceImpact": "0.01", "expiresAt": "2025-02-13T20:00:00Z", "summary": { "from": "1 SOL", "to": "~150.23 USDC", "minReceived": "148.73 USDC", "slippage": "1%", "priceImpact": "0.01%", "destination": "owner" } } Always show the summary to the user and wait for confirmation before executing. If priceImpact > 1%, warn the user explicitly.
After user confirms: node {baseDir}/scripts/swap.mjs execute --prepareId abc123 Returns JSON: { "signature": "5UzV...", "submittedAt": "2025-02-13T19:58:12Z" }
node {baseDir}/scripts/swap.mjs status --signature 5UzV... Returns JSON: { "state": "confirmed", "slot": 123456789, "confirmationStatus": "finalized" } States: submitted → confirmed | failed | expired | unknown
node {baseDir}/scripts/swap.mjs receipt --signature 5UzV... Returns JSON with actual amounts swapped, fees, and a Solscan link.
All commands return JSON with error field on failure: { "error": { "code": "INSUFFICIENT_SOL", "message": "Not enough SOL for fees. Have 0.001, need ~0.006", "retryable": false } } Error codes and retry guidance: CodeRetry?ActionINVALID_INPUTNoFix the inputINSUFFICIENT_SOLNoTell user they need more SOLKEYPAIR_NOT_FOUNDNoCheck SOLANA_KEYPAIR_PATH is setKEYPAIR_INVALIDNoCheck keypair file formatPREPARE_EXPIREDYesRun prepare again, re-confirm with userPREPARE_ALREADY_EXECUTEDNoThis swap was already sentBACKEND_UNAVAILABLEYesWait 3s, retry prepare up to 2xBACKEND_QUOTE_FAILEDNoNo route — tell user (bad pair or no liquidity)TX_EXPIREDYesRun prepare again, re-confirm with userTX_BROADCAST_FAILEDYesRetry execute once (if not expired)TX_FAILED_ONCHAINNoSwap failed (e.g., slippage). Do NOT retry.RPC_UNAVAILABLEYesWait 3s, retry up to 2x
Always confirm before executing. Show the user the summary from prepare and wait for explicit "yes" / "go" / "confirm". Never auto-retry failed onchain transactions. If TX_FAILED_ONCHAIN, the tx landed and failed — retrying sends a new tx. Re-confirm on re-prepare. If you need to prepare again (expired quote), show the new summary — prices may have changed. Handle amounts in base units. SOL = 9 decimals (1 SOL = 1000000000), USDC = 6 decimals (1 USDC = 1000000). Ask for mint addresses if the user mentions a token you don't recognize. Don't guess. Report the Solscan link after confirmation: https://solscan.io/tx/{signature}
This skill signs transactions using the configured keypair. It does NOT create, import, or manage keys. Keypair material is never logged, echoed, or included in any output. Third-party destinations require explicit --allowThirdParty flag. All swaps enforce slippage protection via minOut. Prepared swaps expire after 120 seconds by default.
Jupiter unauthenticated API — Token2022 and pump.fun tokens may not work. No best-price routing — takes whatever Jupiter returns. Receipt amounts are best-effort (derived from pre/post balance diffs). Solana mainnet only.
Code helpers, APIs, CLIs, browser automation, testing, and developer operations.
Largest current source with strong distribution and engagement signals.