Skip to main content

debug_traceBlockByHash RPC Method

Returns the possible tracing result number by executing all transactions in the block specified by the block hash with a tracer (Trace Mode required).

Updated on
Dec 27, 2024

debug_traceBlockByHash RPC Method

Please note that this RPC method is available to all users on the Build plan and higher. If you are using the Free plan, you will need to upgrade to utilize this method. See our pricing for more information.

Parameters

blockHash
string
REQUIRED
The hash of the block to be traced
object
object
REQUIRED
The tracer object with the following fields:
tracer
string
The type of tracer. It could be callTracer or prestateTracer
callTracer
string
The calltracer keeps track of all call frames, including depth 0 calls, that are made during a transaction
prestateTracer
string
The prestateTracer replays the transaction and tracks every part of state that occured during the transaction
tracerConfig
object
The object to specify the configurations of the tracer
onlyTopCall
boolean
When set to true, this will only trace the primary (top-level) call and not any sub-calls. It eliminates the additional processing for each call frame

Returns

result
The result object which contains the following fields:
txHash
The hash of the transaction being traced
result
An object containing detailed information about the traced transaction
beforeEVMTransfers
An array representing EVM transfers that occurred before the execution of the transaction
purpose
(Optional) The purpose of the EVM transfer
from
(Optional) The Ethereum address initiating the transfer
to
(Optional) The Ethereum address receiving the transfer
value
(Optional) The value of the transfer, specified in hexadecimal format (Wei)
afterEVMTransfers
An array representing EVM transfers that occurred after the execution of the transaction
purpose
(Optional) The purpose of the EVM transfer
from
(Optional) The Ethereum address initiating the transfer
to
(Optional) The Ethereum address receiving the transfer
value
(Optional) The value of the transfer, specified in hexadecimal format (Wei)
from
The address the transaction is sent from
gas
The integer of the gas provided for the transaction execution
gasUsed
The integer of the gas used
to
The address the transaction is directed to
input
The data given at the time of input
output
(Optional) The data which is returned as an output
calls
(Optional) An array containing information about internal calls made during the transaction
from
The address making the call
gas
The gas limit specified for the call
gasUsed
The amount of gas used during the call
to
The address being called
input
The input data for the call
output
The output data of the call
error
The type of error, if any
revertReason
The type Solidity revert reason, if any
value
The value (in Wei) sent with the call
type
The type of call (e.g., CALL or STATICCALL)
calls
The sub-calls associated with the call
value
The integer of the value sent with this transaction
type
The type of the call
Request
1
curl https://docs-demo.xai-mainnet.quiknode.pro/ \
2
-X POST \
3
-H "Content-Type: application/json" \
4
--data '{"method":"debug_traceBlockByHash","params":["0xa8adef58b9f2cef14ab7386caf133b6c7397d675fc926306318387d32f66af10", {"tracer": "callTracer"}],"id":1,"jsonrpc":"2.0"}'
Don't have an account yet?
Create your QuickNode endpoint in seconds and start building
Get started for free