From c318d6beb0f25791869122e2725ce9998a6ffc14 Mon Sep 17 00:00:00 2001 From: Piers Powlesland Date: Wed, 2 Oct 2024 22:00:05 +0100 Subject: [PATCH 1/2] Revert historical rpc changes --- eth/tracers/api.go | 28 ++++++++++------------------ eth/tracers/api_test.go | 18 ------------------ ethclient/ethclient_test.go | 8 -------- internal/ethapi/api.go | 16 ++++++++-------- params/config.go | 4 ---- rpc/errors.go | 2 +- 6 files changed, 19 insertions(+), 57 deletions(-) diff --git a/eth/tracers/api.go b/eth/tracers/api.go index 26d82dac86..8cfd666545 100644 --- a/eth/tracers/api.go +++ b/eth/tracers/api.go @@ -22,6 +22,7 @@ import ( "encoding/json" "errors" "fmt" + "math/big" "os" "runtime" "sync" @@ -442,7 +443,7 @@ func (api *API) TraceBlockByNumber(ctx context.Context, number rpc.BlockNumber, return nil, err } - if api.backend.ChainConfig().IsPreCel2(block.Time()) { + if api.backend.ChainConfig().IsOptimismPreBedrock(block.Number()) { if api.backend.HistoricalRPCService() != nil { var histResult []*txTraceResult err = api.backend.HistoricalRPCService().CallContext(ctx, &histResult, "debug_traceBlockByNumber", number, config) @@ -466,7 +467,7 @@ func (api *API) TraceBlockByHash(ctx context.Context, hash common.Hash, config * return nil, err } - if api.backend.ChainConfig().IsPreCel2(block.Time()) { + if api.backend.ChainConfig().IsOptimismPreBedrock(block.Number()) { if api.backend.HistoricalRPCService() != nil { var histResult []*txTraceResult err = api.backend.HistoricalRPCService().CallContext(ctx, &histResult, "debug_traceBlockByHash", hash, config) @@ -882,12 +883,7 @@ func (api *API) TraceTransaction(ctx context.Context, hash common.Hash, config * return nil, ethapi.NewTxIndexingError() } - block, err := api.blockByHash(ctx, blockHash) - if err != nil { - return nil, err - } - - if api.backend.ChainConfig().IsPreCel2(block.Time()) { + if api.backend.ChainConfig().IsOptimismPreBedrock(new(big.Int).SetUint64(blockNumber)) { if api.backend.HistoricalRPCService() != nil { var histResult json.RawMessage err := api.backend.HistoricalRPCService().CallContext(ctx, &histResult, "debug_traceTransaction", hash, config) @@ -907,6 +903,10 @@ func (api *API) TraceTransaction(ctx context.Context, hash common.Hash, config * if config != nil && config.Reexec != nil { reexec = *config.Reexec } + block, err := api.blockByNumberAndHash(ctx, rpc.BlockNumber(blockNumber), blockHash) + if err != nil { + return nil, err + } tx, vmctx, statedb, release, err := api.backend.StateAtTransaction(ctx, block, int(index), reexec) if err != nil { return nil, err @@ -961,16 +961,8 @@ func (api *API) TraceCall(ctx context.Context, args ethapi.TransactionArgs, bloc return nil, err } - if api.backend.ChainConfig().IsPreCel2(block.Time()) { - if api.backend.HistoricalRPCService() != nil { - var histResult json.RawMessage - err := api.backend.HistoricalRPCService().CallContext(ctx, &histResult, "debug_traceCall", args, blockNrOrHash, config) - if err != nil { - return nil, fmt.Errorf("historical backend error: %w", err) - } - return histResult, nil - } - return nil, rpc.ErrNoHistoricalFallback + if api.backend.ChainConfig().IsOptimismPreBedrock(block.Number()) { + return nil, errors.New("l2geth does not have a debug_traceCall method") } // try to recompute the state diff --git a/eth/tracers/api_test.go b/eth/tracers/api_test.go index 51f6dec003..9dc98efc6f 100644 --- a/eth/tracers/api_test.go +++ b/eth/tracers/api_test.go @@ -546,15 +546,6 @@ func TestTraceTransactionHistorical(t *testing.T) { accounts[1].addr: {Balance: big.NewInt(params.Ether)}, }, } - - // Set Cel2Time so that we are in the pre-migration case - var cel2Time uint64 = 10000 - genesis.Config.Cel2Time = &cel2Time - // These two changes are a workaround to compensate for the Cel2Time - // check in Genesis.ToBlock(). Ideally we remove this and fix it there. - genesis.GasLimit = params.GenesisGasLimit - genesis.Difficulty = params.GenesisDifficulty - target := common.Hash{} signer := types.HomesteadSigner{} backend := newTestBackend(t, 1, genesis, func(i int, b *core.BlockGen) { @@ -700,15 +691,6 @@ func TestTraceBlockHistorical(t *testing.T) { accounts[2].addr: {Balance: big.NewInt(params.Ether)}, }, } - - // Set Cel2Time so that we are in the pre-migration case - var cel2Time uint64 = 10000 - genesis.Config.Cel2Time = &cel2Time - // These two changes are a workaround to compensate for the Cel2Time - // check in Genesis.ToBlock(). Ideally we remove this and fix it there. - genesis.GasLimit = params.GenesisGasLimit - genesis.Difficulty = params.GenesisDifficulty - genBlocks := 10 signer := types.HomesteadSigner{} backend := newTestBackend(t, genBlocks, genesis, func(i int, b *core.BlockGen) { diff --git a/ethclient/ethclient_test.go b/ethclient/ethclient_test.go index 0fd52a7cd7..795f3797d7 100644 --- a/ethclient/ethclient_test.go +++ b/ethclient/ethclient_test.go @@ -295,14 +295,6 @@ func newTestBackend(t *testing.T, enableHistoricalState bool) (*node.Node, []*ty actualGenesis = genesisForHistorical consensusEngine = beacon.New(ethash.NewFaker()) chainLength = 10 - - // Set Cel2Time so that we are in the pre-migration case - var cel2Time uint64 = 10000 - actualGenesis.Config.Cel2Time = &cel2Time - // These two changes are a workaround to compensate for the Cel2Time - // check in Genesis.ToBlock(). Ideally we remove this and fix it there. - actualGenesis.GasLimit = params.GenesisGasLimit - actualGenesis.Difficulty = params.GenesisDifficulty } else { actualGenesis = genesis consensusEngine = ethash.NewFaker() diff --git a/internal/ethapi/api.go b/internal/ethapi/api.go index 6ec4599fdc..9c7ca9a24f 100644 --- a/internal/ethapi/api.go +++ b/internal/ethapi/api.go @@ -671,7 +671,7 @@ func (api *BlockChainAPI) GetBalance(ctx context.Context, address common.Address return nil, err } - if api.b.ChainConfig().IsPreCel2(header.Time) { + if api.b.ChainConfig().IsOptimismPreBedrock(header.Number) { if api.b.HistoricalRPCService() != nil { var res hexutil.Big err := api.b.HistoricalRPCService().CallContext(ctx, &res, "eth_getBalance", address, blockNrOrHash) @@ -728,7 +728,7 @@ func (api *BlockChainAPI) GetProof(ctx context.Context, address common.Address, if err != nil { return nil, err } - if api.b.ChainConfig().IsPreCel2(header.Time) { + if api.b.ChainConfig().IsOptimismPreBedrock(header.Number) { if api.b.HistoricalRPCService() != nil { var res AccountResult err := api.b.HistoricalRPCService().CallContext(ctx, &res, "eth_getProof", address, storageKeys, blockNrOrHash) @@ -950,7 +950,7 @@ func (api *BlockChainAPI) GetCode(ctx context.Context, address common.Address, b return nil, err } - if api.b.ChainConfig().IsPreCel2(header.Time) { + if api.b.ChainConfig().IsOptimismPreBedrock(header.Number) { if api.b.HistoricalRPCService() != nil { var res hexutil.Bytes err := api.b.HistoricalRPCService().CallContext(ctx, &res, "eth_getCode", address, blockNrOrHash) @@ -981,7 +981,7 @@ func (api *BlockChainAPI) GetStorageAt(ctx context.Context, address common.Addre return nil, err } - if api.b.ChainConfig().IsPreCel2(header.Time) { + if api.b.ChainConfig().IsOptimismPreBedrock(header.Number) { if api.b.HistoricalRPCService() != nil { var res hexutil.Bytes err := api.b.HistoricalRPCService().CallContext(ctx, &res, "eth_getStorageAt", address, hexKey, blockNrOrHash) @@ -1262,7 +1262,7 @@ func (api *BlockChainAPI) Call(ctx context.Context, args TransactionArgs, blockN return nil, err } - if api.b.ChainConfig().IsPreCel2(header.Time) { + if api.b.ChainConfig().IsOptimismPreBedrock(header.Number) { if api.b.HistoricalRPCService() != nil { var res hexutil.Bytes err := api.b.HistoricalRPCService().CallContext(ctx, &res, "eth_call", args, blockNrOrHash, overrides) @@ -1363,7 +1363,7 @@ func (api *BlockChainAPI) EstimateGas(ctx context.Context, args TransactionArgs, return 0, err } - if api.b.ChainConfig().IsPreCel2(header.Time) { + if api.b.ChainConfig().IsOptimismPreBedrock(header.Number) { if api.b.HistoricalRPCService() != nil { var res hexutil.Uint64 err := api.b.HistoricalRPCService().CallContext(ctx, &res, "eth_estimateGas", args, blockNrOrHash) @@ -1725,7 +1725,7 @@ func (api *BlockChainAPI) CreateAccessList(ctx context.Context, args Transaction } header, err := headerByNumberOrHash(ctx, api.b, bNrOrHash) - if err == nil && header != nil && api.b.ChainConfig().IsPreCel2(header.Time) { + if err == nil && header != nil && api.b.ChainConfig().IsOptimismPreBedrock(header.Number) { if api.b.HistoricalRPCService() != nil { var res accessListResult err := api.b.HistoricalRPCService().CallContext(ctx, &res, "eth_createAccessList", args, blockNrOrHash) @@ -1898,7 +1898,7 @@ func (api *TransactionAPI) GetTransactionCount(ctx context.Context, address comm return nil, err } - if api.b.ChainConfig().IsPreCel2(header.Time) { + if api.b.ChainConfig().IsOptimismPreBedrock(header.Number) { if api.b.HistoricalRPCService() != nil { var res hexutil.Uint64 err := api.b.HistoricalRPCService().CallContext(ctx, &res, "eth_getTransactionCount", address, blockNrOrHash) diff --git a/params/config.go b/params/config.go index f0b1845700..3cb9eeec72 100644 --- a/params/config.go +++ b/params/config.go @@ -769,10 +769,6 @@ func (c *ChainConfig) IsCel2(time uint64) bool { return isTimestampForked(c.Cel2Time, time) } -func (c *ChainConfig) IsPreCel2(time uint64) bool { - return c.Cel2Time != nil && !c.IsCel2(time) -} - // IsGingerbread returns whether num represents a block number after the Gingerbread fork func (c *ChainConfig) IsGingerbread(num *big.Int) bool { return isBlockForked(c.GingerbreadBlock, num) diff --git a/rpc/errors.go b/rpc/errors.go index a9323717eb..67c523d11a 100644 --- a/rpc/errors.go +++ b/rpc/errors.go @@ -80,7 +80,7 @@ type NoHistoricalFallbackError struct{} func (e NoHistoricalFallbackError) ErrorCode() int { return -32801 } func (e NoHistoricalFallbackError) Error() string { - return "no historical RPC is available for this historical (pre-cel2) execution request" + return "no historical RPC is available for this historical (pre-bedrock) execution request" } type methodNotFoundError struct{ method string } From d4f2cf367ce39dfc907698637e6e94b6fa18f3c1 Mon Sep 17 00:00:00 2001 From: Piers Powlesland Date: Thu, 3 Oct 2024 15:41:29 +0100 Subject: [PATCH 2/2] Add support for historical trace call requests --- eth/tracers/api.go | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/eth/tracers/api.go b/eth/tracers/api.go index 8cfd666545..c4b03deae5 100644 --- a/eth/tracers/api.go +++ b/eth/tracers/api.go @@ -962,7 +962,15 @@ func (api *API) TraceCall(ctx context.Context, args ethapi.TransactionArgs, bloc } if api.backend.ChainConfig().IsOptimismPreBedrock(block.Number()) { - return nil, errors.New("l2geth does not have a debug_traceCall method") + if api.backend.HistoricalRPCService() != nil { + var histResult json.RawMessage + err := api.backend.HistoricalRPCService().CallContext(ctx, &histResult, "debug_traceCall", args, blockNrOrHash, config) + if err != nil { + return nil, fmt.Errorf("historical backend error: %w", err) + } + return histResult, nil + } + return nil, rpc.ErrNoHistoricalFallback } // try to recompute the state