Skip to main content

eth_estimateGas

Estimates the gas necessary to execute a transaction on Moonriver.

Why Moonriver? Build on the Moonbeam canary network on Kusama for real-world testing of EVM dApps with Moonbeam code ships here first, full EVM compatibility on Kusama, 80% fee burn mechanism, and XCM cross-chain messaging.

Use Cases#

The eth_estimateGas method is essential for:

  • Transaction preparation - Set appropriate gas limits
  • Cost estimation - Calculate transaction costs before sending
  • Error detection - Identify reverts before spending gas
  • DeFi operations - Estimate costs for production-grade dApp testing, early feature deployment, and Kusama-based EVM applications

Parameters#

ParameterTypeRequiredDescription
fromDATANoSender address
toDATANoRecipient address
gasQUANTITYNoGas limit
gasPriceQUANTITYNoGas price
valueQUANTITYNoValue in wei
dataDATANoTransaction data

Request#

{
"jsonrpc": "2.0",
"method": "eth_estimateGas",
"params": [{
"from": "5GrwvaEF5zXb26Fz9rcQpDWS57CtERHpNehXCPcNoHGKutQY",
"to": "5GrwvaEF5zXb26Fz9rcQpDWS57CtERHpNehXCPcNoHGKutQY",
"value": "0x1"
}],
"id": 1
}

Returns#

TypeDescription
QUANTITYEstimated gas amount in hexadecimal

Response#

{
"jsonrpc": "2.0",
"id": 1,
"result": "0x5208"
}

Note: 0x5208 = 21000 gas (standard ETH transfer)

Code Examples#

curl -X POST  \
-H "Content-Type: application/json" \
-d '{
"jsonrpc": "2.0",
"method": "eth_estimateGas",
"params": [{
"from": "5GrwvaEF5zXb26Fz9rcQpDWS57CtERHpNehXCPcNoHGKutQY",
"to": "5GrwvaEF5zXb26Fz9rcQpDWS57CtERHpNehXCPcNoHGKutQY",
"value": "0x1"
}],
"id": 1
}'

Error Handling#

Error CodeMessageDescription
-32000Execution revertedTransaction would fail
-32602Invalid paramsInvalid transaction parameters

Tip: If estimation fails, the transaction would likely revert if sent.