skills/kraken-error-recovery/SKILL.md
Handle order failures, network errors, and duplicate submissions safely.
npx skillsauth add krakenfx/kraken-cli kraken-error-recoveryInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Use this skill for:
Parse the .error field from the JSON response:
| Category | Meaning | Recovery |
|----------|---------|----------|
| auth | Credentials invalid or expired | Re-authenticate, do not retry |
| rate_limit | Too many requests | Read suggestion and docs_url fields, adapt strategy |
| network | Connection failed | Retry with exponential backoff |
| validation | Invalid request parameters | Fix inputs, do not retry unchanged |
| api | Exchange-side rejection | Inspect error message, adjust request |
After a network error during order submission, the order may or may not have reached the exchange. Check before resubmitting:
kraken open-orders -o json 2>/dev/null
If the order appears in open-orders, do not resubmit. If absent:
kraken trades-history -o json 2>/dev/null
If the order filled immediately, it appears in trades. Only resubmit if the order is absent from both.
Use --cl-ord-id to tag orders with a unique identifier:
kraken order buy BTCUSD 0.001 --type limit --price 50000 --cl-ord-id "dca-2024-01-15-001" -o json 2>/dev/null
If the submission fails, query by client order ID to check if it reached the exchange:
kraken open-orders --cl-ord-id "dca-2024-01-15-001" -o json 2>/dev/null
Cancel by client order ID if needed:
kraken order cancel --cl-ord-id "dca-2024-01-15-001" -o json 2>/dev/null
1. Submit order (capture exit code and response)
2. If exit code != 0 and error == "network":
a. Wait 2 seconds
b. Check open-orders for the order (by cl-ord-id or recent orders)
c. If found → order succeeded, proceed
d. If not found → check trades-history
e. If in trades → order filled, proceed
f. If absent from both → safe to retry
3. Retry with same cl-ord-id
The CLI returns rate limit errors immediately with no internal retry. The error includes actionable fields for the agent to decide next steps.
On rate_limit error:
suggestion field for specific guidance on what limit was hit and how to adapt.docs_url field for the relevant Kraken documentation.# { "error": "rate_limit", "suggestion": "...", "docs_url": "...", "retryable": true }
kraken status -o json 2>/dev/null
If status succeeds, the rate limit has cleared.
Limit orders may partially fill. Check order status:
kraken query-orders <TXID> -o json 2>/dev/null
Fields: vol (requested volume), vol_exec (filled volume), status (open, closed, canceled).
If partially filled and the remaining volume is needed, amend or place a new order for the remaining amount.
An order stuck in open state that should have filled or been canceled:
kraken query-orders <TXID> -o json 2>/dev/null
kraken order cancel <TXID> -o json 2>/dev/null
kraken open-orders -o json 2>/dev/null
--cl-ord-id for all orders in automated loops.tools
Connect MCP clients to kraken-cli for native tool calling without subprocess wrappers.
testing
Safely withdraw funds to a pre-approved cold storage address.
testing
Run a weekly portfolio rebalance to maintain target asset allocations.
testing
Ride a trend with a trailing stop that locks in profits on reversal.