swap-tokens
SKILL.md
Swapping Tokens
Use the fdx call swapTokens command to swap between tokens via decentralized exchanges on any supported chain. Unlike centralized exchange swaps, these execute directly on-chain through DEX protocols.
Confirm wallet is authenticated
fdx status
If the wallet is not authenticated, refer to the authenticate skill.
Check Balance Before Swapping
Verify the wallet holds enough of the source token:
fdx call getWalletOverview --chainKey <chain>
Executing a Swap
fdx call swapTokens \
--chainKey <chain> \
--tokenIn <token> \
--tokenOut <token> \
--amount <amount>
Parameters
| Parameter | Required | Description |
|---|---|---|
--chainKey |
Yes | Blockchain to swap on (e.g. ethereum, polygon, base, solana) |
--tokenIn |
Yes | Source token — symbol (e.g. USDC, ETH) or contract address |
--tokenOut |
Yes | Destination token — symbol or contract address |
--amount |
Yes | Amount of tokenIn to swap (human-readable) |
--mode |
No | Swap mode (e.g. exact input, exact output) |
--objective |
No | Optimization objective (e.g. best price, lowest gas) |
--maxSlippageBps |
No | Maximum slippage tolerance in basis points (100 = 1%) |
--deadlineSeconds |
No | Transaction deadline in seconds |
Examples
Basic swaps
# Swap 100 USDC for ETH on Ethereum
fdx call swapTokens \
--chainKey ethereum \
--tokenIn USDC \
--tokenOut ETH \
--amount 100
# Swap 0.05 ETH for USDC on Base
fdx call swapTokens \
--chainKey base \
--tokenIn ETH \
--tokenOut USDC \
--amount 0.05
# Swap SOL for USDC on Solana
fdx call swapTokens \
--chainKey solana \
--tokenIn SOL \
--tokenOut USDC \
--amount 2
Swap with slippage control
# Swap with 0.5% max slippage
fdx call swapTokens \
--chainKey ethereum \
--tokenIn USDC \
--tokenOut ETH \
--amount 500 \
--maxSlippageBps 50
Swap using contract addresses
# Swap using explicit token contract addresses
fdx call swapTokens \
--chainKey ethereum \
--tokenIn 0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48 \
--tokenOut 0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2 \
--amount 100
Flow
- Check authentication with
fdx status - Check balance with
fdx call getWalletOverview --chainKey <chain> - Confirm the swap details with the human (amount, tokens, chain, slippage)
- Execute with
fdx call swapTokens - Optionally check updated balance with
fdx call getWalletOverview
Important: DEX swaps are subject to slippage — the final output amount may differ slightly from the quoted amount. For large swaps, consider setting --maxSlippageBps explicitly.
Prerequisites
- Must be authenticated (
fdx statusto check, seeauthenticateskill) - Wallet must hold sufficient balance of the source token on the target chain
- If the wallet has insufficient funds, suggest using the
fund-walletskill
Error Handling
- "Not authenticated" — Run
fdx setupfirst, or seeauthenticateskill - "Insufficient balance" — Check balance with
getWalletOverview; seefund-walletskill - "Cannot swap a token to itself" —
tokenInandtokenOutmust be different - "No liquidity" — Try a smaller amount or a different token pair
- "Swap failed" — May be a slippage issue; try with a higher
--maxSlippageBps
Weekly Installs
4
Repository
financedistrict…t-skillsGitHub Stars
1
First Seen
Feb 19, 2026
Security Audits
Installed on
opencode4
gemini-cli4
github-copilot4
codex4
kimi-cli4
amp4