rpc: add debug_tranceBlockByHash
, fix debug_traceBlock*
crash on non-existing block (#743)
* Problem: Missing debug_tranceBlockByHash RPC method Solution: (Fix #742) Add the missing method * Problem: debug_traceBlockByNumber crashed when block height not found Solution: (Fix #744) Fix memory reference error * Run go fmt * Revert comment on init.sh * Apply suggestions from code review Co-authored-by: Federico Kunze Küllmer <31522760+fedekunze@users.noreply.github.com> * Update rpc/ethereum/backend/backend.go * Update rpc/ethereum/backend/backend.go Co-authored-by: Federico Kunze Küllmer <31522760+fedekunze@users.noreply.github.com>
This commit is contained in:
parent
72c1098972
commit
481e3b82ce
@ -49,8 +49,9 @@ Ref: https://keepachangelog.com/en/1.0.0/
|
|||||||
* (rpc) [tharsis#624](https://github.com/tharsis/ethermint/pull/624) Implement new JSON-RPC endpoints from latest geth version
|
* (rpc) [tharsis#624](https://github.com/tharsis/ethermint/pull/624) Implement new JSON-RPC endpoints from latest geth version
|
||||||
* (evm) [tharsis#662](https://github.com/tharsis/ethermint/pull/662) Disable basefee for non london blocks
|
* (evm) [tharsis#662](https://github.com/tharsis/ethermint/pull/662) Disable basefee for non london blocks
|
||||||
* (cmd) [tharsis#712](https://github.com/tharsis/ethermint/pull/712) add tx cli to build evm transaction
|
* (cmd) [tharsis#712](https://github.com/tharsis/ethermint/pull/712) add tx cli to build evm transaction
|
||||||
* (rpc) [tharsis#733](https://github.com/tharsis/ethermint/pull/733) add JSON_RPC endpoint personal_unpair
|
* (rpc) [tharsis#733](https://github.com/tharsis/ethermint/pull/733) add JSON_RPC endpoint `personal_unpair`
|
||||||
* (rpc) [tharsis#740](https://github.com/tharsis/ethermint/pull/740) add JSON_RPC endpoint personal_initializeWallet
|
* (rpc) [tharsis#740](https://github.com/tharsis/ethermint/pull/740) add JSON_RPC endpoint `personal_initializeWallet`
|
||||||
|
* (rpc) [tharsis#743](https://github.com/tharsis/ethermint/pull/743) add JSON_RPC endpoint `debug_traceBlockByHash`
|
||||||
|
|
||||||
### Bug Fixes
|
### Bug Fixes
|
||||||
|
|
||||||
@ -61,6 +62,7 @@ Ref: https://keepachangelog.com/en/1.0.0/
|
|||||||
* (evm, test) [tharsis#649](https://github.com/tharsis/ethermint/pull/649) Test DynamicFeeTx.
|
* (evm, test) [tharsis#649](https://github.com/tharsis/ethermint/pull/649) Test DynamicFeeTx.
|
||||||
* (evm) [tharsis#702](https://github.com/tharsis/ethermint/pull/702) Fix panic in web3 RPC handlers
|
* (evm) [tharsis#702](https://github.com/tharsis/ethermint/pull/702) Fix panic in web3 RPC handlers
|
||||||
* (rpc) [tharsis#720](https://github.com/tharsis/ethermint/pull/720) Fix `debug_traceTransaction` failure
|
* (rpc) [tharsis#720](https://github.com/tharsis/ethermint/pull/720) Fix `debug_traceTransaction` failure
|
||||||
|
* (rpc) [tharsis#743](https://github.com/tharsis/ethermint/pull/743) Fix debug JSON RPC handler crash on non-existing block
|
||||||
|
|
||||||
### Improvements
|
### Improvements
|
||||||
|
|
||||||
|
@ -53,6 +53,7 @@ type Backend interface {
|
|||||||
// Blockchain API
|
// Blockchain API
|
||||||
BlockNumber() (hexutil.Uint64, error)
|
BlockNumber() (hexutil.Uint64, error)
|
||||||
GetTendermintBlockByNumber(blockNum types.BlockNumber) (*tmrpctypes.ResultBlock, error)
|
GetTendermintBlockByNumber(blockNum types.BlockNumber) (*tmrpctypes.ResultBlock, error)
|
||||||
|
GetTendermintBlockByHash(blockHash common.Hash) (*tmrpctypes.ResultBlock, error)
|
||||||
GetBlockByNumber(blockNum types.BlockNumber, fullTx bool) (map[string]interface{}, error)
|
GetBlockByNumber(blockNum types.BlockNumber, fullTx bool) (map[string]interface{}, error)
|
||||||
GetBlockByHash(hash common.Hash, fullTx bool) (map[string]interface{}, error)
|
GetBlockByHash(hash common.Hash, fullTx bool) (map[string]interface{}, error)
|
||||||
BlockByNumber(blockNum types.BlockNumber) (*ethtypes.Block, error)
|
BlockByNumber(blockNum types.BlockNumber) (*ethtypes.Block, error)
|
||||||
@ -306,6 +307,21 @@ func (e *EVMBackend) GetTendermintBlockByNumber(blockNum types.BlockNumber) (*tm
|
|||||||
return resBlock, nil
|
return resBlock, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetTendermintBlockByHash returns a Tendermint format block by block number
|
||||||
|
func (e *EVMBackend) GetTendermintBlockByHash(blockHash common.Hash) (*tmrpctypes.ResultBlock, error) {
|
||||||
|
resBlock, err := e.clientCtx.Client.BlockByHash(e.ctx, blockHash.Bytes())
|
||||||
|
if err != nil {
|
||||||
|
e.logger.Debug("tendermint client failed to get block", "blockHash", blockHash.Hex(), "error", err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
if resBlock == nil || resBlock.Block == nil {
|
||||||
|
e.logger.Debug("GetBlockByNumber block not found", "blockHash", blockHash.Hex())
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
return resBlock, nil
|
||||||
|
}
|
||||||
|
|
||||||
// BlockBloom query block bloom filter from block results
|
// BlockBloom query block bloom filter from block results
|
||||||
func (e *EVMBackend) BlockBloom(height *int64) (ethtypes.Bloom, error) {
|
func (e *EVMBackend) BlockBloom(height *int64) (ethtypes.Bloom, error) {
|
||||||
result, err := e.clientCtx.Client.BlockResults(e.ctx, height)
|
result, err := e.clientCtx.Client.BlockResults(e.ctx, height)
|
||||||
|
@ -167,12 +167,32 @@ func (a *API) TraceBlockByNumber(height rpctypes.BlockNumber, config *evmtypes.T
|
|||||||
// Get Tendermint Block
|
// Get Tendermint Block
|
||||||
resBlock, err := a.backend.GetTendermintBlockByNumber(height)
|
resBlock, err := a.backend.GetTendermintBlockByNumber(height)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
a.logger.Debug("get block failed", "height", height, "error", err.Error())
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
return a.traceBlock(height, config, resBlock)
|
return a.traceBlock(height, config, resBlock)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TraceBlockByHash returns the structured logs created during the execution of
|
||||||
|
// EVM and returns them as a JSON object.
|
||||||
|
func (a *API) TraceBlockByHash(hash common.Hash, config *evmtypes.TraceConfig) ([]*evmtypes.TxTraceResult, error) {
|
||||||
|
a.logger.Debug("debug_traceBlockByHash", "hash", hash)
|
||||||
|
// Get Tendermint Block
|
||||||
|
resBlock, err := a.backend.GetTendermintBlockByHash(hash)
|
||||||
|
if err != nil {
|
||||||
|
a.logger.Debug("get block failed", "hash", hash.Hex(), "error", err.Error())
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
if resBlock == nil || resBlock.Block == nil {
|
||||||
|
a.logger.Debug("block not found", "hash", hash.Hex())
|
||||||
|
return nil, errors.New("block not found")
|
||||||
|
}
|
||||||
|
|
||||||
|
return a.traceBlock(rpctypes.BlockNumber(resBlock.Block.Height), config, resBlock)
|
||||||
|
}
|
||||||
|
|
||||||
// traceBlock configures a new tracer according to the provided configuration, and
|
// traceBlock configures a new tracer according to the provided configuration, and
|
||||||
// executes all the transactions contained within. The return value will be one item
|
// executes all the transactions contained within. The return value will be one item
|
||||||
// per transaction, dependent on the requested tracer.
|
// per transaction, dependent on the requested tracer.
|
||||||
|
Loading…
Reference in New Issue
Block a user