From onchainos-skills
Bridges tokens across blockchains via OKX DEX. Quotes, compares, and executes cross-chain swaps through protocols like Stargate and Across, then tracks arrival.
How this skill is triggered — by the user, by Claude, or both
Slash command
/onchainos-skills:okx-dex-bridgeThe summary Claude sees in its skill listing — used to decide when to auto-load this skill
Bridge tokens across chains. This skill orchestrates two happy paths:
Bridge tokens across chains. This skill orchestrates two happy paths:
execute, one-shot): resolve → quote → confirm → execute → report.status): query until the funds land on the destination chain.There are 7 cross-chain subcommands; this file orchestrates the two flows above. For anything outside them, the References table at the end says which file to open.
onchainos command this session, read and follow ../okx-agentic-wallet/_shared/preflight.md (fallback _shared/preflight.md).../okx-agentic-wallet/_shared/chain-support.md (fallback _shared/chain-support.md).Only these 7 subcommands exist — do not invent new ones.
**When you are not certain of a subcommand's exact flags, run `onchainos cross-chain --help` first** and build the call from the live flag list it prints. `--help` is the source of truth for flags (name, required, default, mutual exclusivity). The signatures in this index and the example commands in the steps below are a routing map, not the full flag list; do not treat them as complete.| # | Command | Role |
|---|---|---|
| 1 | cross-chain bridges [--from-chain] [--to-chain] | List / filter bridge protocols (pair pre-check). |
| 2 | cross-chain tokens [--from-chain] [--to-chain] | List bridgeable from-tokens. |
| 3 | cross-chain quote --from --to --from-chain --to-chain --readable-amount [...] | Read-only quote → routerList[]. |
| 4 | cross-chain approve --chain --token --wallet --bridge-id (--amount | --readable-amount) | Manual ERC-20 approve (not used in Path A). |
| 5 | cross-chain swap --from --to --from-chain --to-chain --readable-amount --wallet [...] | Unsigned tx / calldata only (not used in Path A). |
| 6 | cross-chain execute --from --to --from-chain --to-chain --readable-amount --wallet [...] | One-shot: quote → approve → wait → swap → broadcast. |
| 7 | cross-chain status (--tx-hash | --order-id) --bridge-id --from-chain | Query status. |
Path A uses 3, 6. Path B uses 7. bridges is the optional Step 2.5 pre-check. approve / swap are for the manual calldata flow only.
CA sources, in order:
--from/--to.onchainos token search --query <symbol> --chains <chain> — for any symbol the CLI does not resolve. Search on the CORRECT chain.After token search, show results and wait for confirmation. Multiple → numbered list (name/symbol/CA/chain/marketCap), ask user to pick. Single → show details and confirm. Never skip confirmation — wrong token = permanent fund loss.
Native token addresses (do NOT use token search):
| Chain | Native Address |
|---|---|
| EVM (Ethereum, BSC, Polygon, Arbitrum, Base, …) | 0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee |
| Solana | 11111111111111111111111111111111 |
Follow Token Address Resolution. Resolve --from with --from-chain, --to with --to-chain.
--from-chain and --to-chain required — ask if missing.--readable-amount.--slippage only on user request.onchainos wallet status; not logged in → login; multiple accounts → ask which.--receive-address required; family must match --to-chain.--receive-address ≠ wallet → Fund-action gates (second confirmation).execute gates it before broadcasting (Step 5).--bridge-id for the server's optimal route.Fail fast on pairs no bridge connects:
onchainos cross-chain bridges --from-chain <fromChain> --to-chain <toChain>
onchainos cross-chain quote \
--from <address> --to <address> \
--from-chain <chain> --to-chain <chain> \
--readable-amount <amount> \
--wallet <walletAddress> --check-approve \
[--bridge-id <id>] [--sort <0|1|2>] [--allow-bridges <ids>] [--deny-bridges <ids>]
Pass --wallet --check-approve for an accurate needApprove.
--sort — route ranking preference (omit = server picks 0):
0 — optimal (server default)1 — fastest2 — max outputrouterList[] is a multi-bridge list. Render exactly these 7 columns, every time (translate headers to the user's language; the sample row names the source field — do not print it literally). If a value is empty/zero/null, show the default; never drop a column.
| # | Bridge | Est. Receive | Min. Receive | Fee | Est. Time | Approve |
|---|--------------|-----------------|-------------------|-----------------|----------------|---------------|
| n | `bridgeName` | `toTokenAmount` | `minimumReceived` | `crossChainFee` | `estimateTime` | `needApprove` |
otherNativeFee when non-zero; default 0.estimateTime seconds → human (~43s, ~6min).needApprove → Yes/No (default No). Gloss below the table: Yes = first-time approval to the {bridgeName} router; No = allowance sufficient.Render every entry as a row — do NOT collapse to one even when only one is returned. Recommend route #1 (server's top pick by current sort) with a one-line reason (lowest fee / fastest / max output). If routerList is empty → transit-fallback.md.
Get confirmation before execute, after these checks:
priceImpactPercentage > 10% → WARN prominently (empty in pre-prod → treat as 0%).receiveAddress != wallet → Fund-action gates (second confirmation).onchainos cross-chain execute \
--from <address> --to <address> \
--from-chain <chain> --to-chain <chain> \
--readable-amount <amount> \
--wallet <walletAddress> \
[--bridge-id <id> | --route-index <n>] [--sort <0|1|2>] \
[--receive-address <addr>] [--mev-protection]
Pin a route with --bridge-id or --route-index per the user's choice. Apply the quote-freshness rule before broadcasting. Decide --mev-protection per MEV protection.
Outcomes:
action=execute (success) → response carries nextSteps.checkBridgeStatus + fromTxHash, swapOrderId, bridgeId, bridgeName, fromChainIndex (+ approveTxHash if an approval ran). Go to Step 6.action=blocked (insufficient_balance/insufficient_gas) → relay message (deposit / top up gas) and stop; nothing broadcast.action=fallback → no direct route → transit-fallback.md.execution reverted, approve/revoke timeout, backend risk warning) → troubleshooting.md. A risk warning still requires the Fund-action gates before any --force.Cross-chain transfer broadcast.
Route: {bridgeName}
From: {fromAmount} {fromTokenSymbol} on {fromChain}
Expected arrival: ~{toTokenAmount} {toTokenSymbol} on {toChain}
Minimum guaranteed: {minimumReceived} {toTokenSymbol}
Bridge fee: {crossChainFee} {fromTokenSymbol}
Estimated time: ~{estimateTime} seconds
Source TX: {fromTxHash}
Order ID: {swapOrderId}
Bridge: {bridgeName} (id={bridgeId})
Source chain: {fromChain} ({fromChainIndex})
To check arrival status, choose either:
- Tell me in chat with the tx hash, e.g. "check if tx {fromTxHash} has arrived". I will run the command for you.
- Run directly in terminal — paste verbatim (--bridge-id and --from-chain are REQUIRED):
{nextSteps.checkBridgeStatus}
Keep BOTH options in the status block — never collapse to command-only. The natural-language phrasing MUST embed the actual `fromTxHash`. The terminal command MUST be the `nextSteps.checkBridgeStatus` string verbatim (CLI-assembled → exempt from the untrusted-output rule); do NOT hand-assemble it.
User queries status after the estimated arrival time. Either form works:
onchainos cross-chain status --tx-hash <fromTxHash> --bridge-id <bridgeId> --from-chain <fromChainIndex>
onchainos cross-chain status --order-id <swapOrderId> --bridge-id <bridgeId> --from-chain <fromChainIndex>
If the most recent execute response is available, reuse its nextSteps.checkBridgeStatus verbatim; otherwise ask the user for the missing values.
Interpret status (the to* fields are empty/zero until SUCCESS — rely on them only after SUCCESS):
| Status | User message |
|---|---|
SUCCESS | "Cross-chain transfer complete. {toAmount} {toTokenSymbol} arrived on {toChain}. Destination TX: {toTxHash}" |
PENDING | "Transfer in progress. Bridge: {bridgeName}. Check again shortly. Estimated arrival: ~{estimateTime}." |
NOT_FOUND | First seconds: "Bridge has not yet indexed your transaction. Wait 10–30s and re-check." Persisting >5min: "Source chain may not have confirmed it. Verify on the explorer." |
sleep-loop in chat. If not SUCCESS, report it and tell the user when to recheck (~estimateTime). Scripted polling → troubleshooting.md → Status Polling.SUCCESS.Every flag that broadcasts a tx or expands spending authority needs an explicit user yes/no. The Step 4 route confirmation covers the in-flight approval; these cover flags that change destination, route, or risk behavior.
| Flag | Effect | Required gate |
|---|---|---|
--force | Bypasses the backend risk warning (potential honeypot / poisoned contract) | On that warning, explicitly tell the user the risk is "potential fund loss"; re-run with --force only on explicit confirm |
--bridge-id / --route-index | Pins a specific bridge (overrides optimal route) | Only if the user picked from the table or named a bridge; never pin unprompted |
--allow-bridges / --deny-bridges | Restricts the bridge set | Only when the user said "use only X" / "don't use X" |
--receive-address ≠ wallet | Sends to a non-sender address | "Wrong destination = permanent fund loss" + second confirmation of the address |
--mev-protection | MEV-protected broadcast | Auto-forced for relay/mayan/butterswap; otherwise by size threshold (below) |
When in doubt, ask — a delayed confirm beats a wrong broadcast.
The CLI auto-forces MEV protection for relay / mayan / butterswap — you don't decide those. For other bridges, compute txValueUsd = fromTokenAmount × fromTokenPrice and pass --mev-protection when txValueUsd >= threshold:
| Chain | Threshold | Action |
|---|---|---|
| Ethereum | $2,000 | pass --mev-protection |
| BNB Chain | $200 | pass --mev-protection |
| Base | $200 | pass --mev-protection |
| Other EVM | $100 | no MEV option exists — above this, warn it broadcasts without protection, then proceed |
If fromTokenPrice is unavailable → enable by default. Re-evaluate every time the amount changes; do NOT carry it over from a previous command.
1.5 ETH, 3,200 USDC). Always show both source and destination chain + token.--from/--to/--receive-address) and in display. Solana is case-sensitive — keep as-is.quote and compare new toTokenAmount against the baseline's minimumReceived. A freshly confirmed quote becomes the new baseline.Only when the user explicitly authorized it. Three rules: (1) never assume silent mode; (2) BLOCK-level risks (esp. receiveAddress != wallet) still halt and notify; (3) log every silent tx (timestamp, pair, amount, route, fromTxHash, status) and present on request.
When you hit one of these situations, open the matching file:
| Situation | Read |
|---|---|
Any error code, failed/stuck tx, status NOT_FOUND or long PENDING, writing a polling script | references/troubleshooting.md |
routerList empty / action=fallback / "no direct route" / transit tokens | references/transit-fallback.md |
Need a return-field schema or worked example; running manual approve / swap; any flag a --help couldn't clarify | references/cli-reference.md |
npx claudepluginhub okx/onchainos-skills --plugin onchainos-skillsMonitors cross-chain bridge TVL, volume, fees, and transaction status across protocols like Stargate, Wormhole. Compares routes and tracks transfers.
Swaps tokens via OKX DEX aggregator across 20+ chains (EVM, Solana, Sui, Tron, Ton). Supports quotes, one-shot execute with approve+trade, and calldata-only unsigned swaps with slippage and MEV protection.
Swaps tokens on the same chain or bridges tokens across chains using swaps.xyz. Builds unsigned transactions, signs locally, broadcasts, and registers for tracking.