From quicknode-pack
Diagnoses and fixes QuickNode RPC errors like nonce too low, gas failures, rate limits for ethers.js and viem in blockchain apps.
npx claudepluginhub jeremylongshore/claude-code-plugins-plus-skills --plugin quicknode-packThis skill is limited to using the following tools:
Quick reference for the top blockchain RPC errors when using QuickNode endpoints with ethers.js or viem.
Handles QuickNode rate limits for blockchain RPC endpoints with ethers.js examples, error tables, backoff advice, and SDK integration. For Web3/Ethereum development.
Diagnoses and fixes Alchemy SDK errors including rate limits, RPC failures, invalid parameters, authentication issues, and blockchain queries.
Fetches blockchain data like balances, transactions, blocks, gas prices, and contract reads across 100+ chains via DRPC RPC. Sets up API keys and MCP tools for queries.
Share bugs, ideas, or general feedback.
Quick reference for the top blockchain RPC errors when using QuickNode endpoints with ethers.js or viem.
Error: nonce has already been used (error={"code":-32000,"message":"nonce too low"})
Fix:
// Get the correct nonce before sending
const nonce = await provider.getTransactionCount(wallet.address, 'pending');
const tx = await wallet.sendTransaction({ ...txData, nonce });
Error: insufficient funds for intrinsic transaction cost
Fix:
const balance = await provider.getBalance(wallet.address);
const gasEstimate = await provider.estimateGas(txData);
const feeData = await provider.getFeeData();
const totalCost = gasEstimate * feeData.gasPrice! + txData.value;
if (balance < totalCost) {
console.error(`Need ${ethers.formatEther(totalCost)} ETH, have ${ethers.formatEther(balance)}`);
}
Error: execution reverted (reason="ERC20: transfer amount exceeds balance")
Fix: The contract function would revert. Check contract requirements:
try {
const gas = await contract.transfer.estimateGas(to, amount);
} catch (err) {
console.error('Revert reason:', err.reason);
// Check: sufficient token balance, approvals, contract state
}
Error: 429 Too Many Requests
Fix: Implement exponential backoff or upgrade plan:
async function retryRpc<T>(fn: () => Promise<T>, retries = 3): Promise<T> {
for (let i = 0; i < retries; i++) {
try { return await fn(); }
catch (err: any) {
if (err.code === 'SERVER_ERROR' && i < retries - 1) {
await new Promise(r => setTimeout(r, 1000 * Math.pow(2, i)));
continue;
}
throw err;
}
}
throw new Error('Max retries');
}
Error: Method not found — qn_getTokenMetadataByContractAddress
Fix: This method requires an add-on. Enable it in QuickNode Dashboard > Endpoints > Add-ons.
Error: WebSocket connection closed unexpectedly
Fix:
const wsProvider = new ethers.WebSocketProvider(process.env.QUICKNODE_WSS);
wsProvider.websocket.on('close', () => {
console.log('WebSocket closed, reconnecting...');
// Reconnect logic
});
| RPC Code | Meaning | Retryable |
|---|---|---|
| -32000 | Nonce/gas issue | Fix and retry |
| -32602 | Invalid params | No — fix request |
| -32603 | Internal error | Yes — retry |
| 429 | Rate limited | Yes — backoff |
For debugging, see quicknode-debug-bundle.