From 1fd111b09140c6e36b7e8d4558a746d596c2ab48 Mon Sep 17 00:00:00 2001 From: Jianrong Date: Sun, 7 Jan 2024 23:18:02 +1100 Subject: [PATCH 1/2] fix: Fix the wrong logic in GetPreviousCheckpointFromEpoch where we were looking for pre-current epoch --- internal/ethapi/api.go | 18 ++++++++---------- 1 file changed, 8 insertions(+), 10 deletions(-) diff --git a/internal/ethapi/api.go b/internal/ethapi/api.go index 259bc39a8..dc1b79ce8 100644 --- a/internal/ethapi/api.go +++ b/internal/ethapi/api.go @@ -882,6 +882,7 @@ func (s *PublicBlockChainAPI) GetCandidates(ctx context.Context, epoch rpc.Epoch block, err = s.b.BlockByNumber(ctx, checkpointNumber) if err != nil || block == nil { // || checkpointNumber == 0 { result[fieldSuccess] = false + log.Error("[GetCandidates] Error or block not found", "checkpointNumber", checkpointNumber) return result, err } @@ -898,6 +899,7 @@ func (s *PublicBlockChainAPI) GetCandidates(ctx context.Context, epoch rpc.Epoch statedb, _, err := s.b.StateAndHeaderByNumber(ctx, checkpointNumber) if err != nil { result[fieldSuccess] = false + log.Error("[GetCandidates] Error when load statedb", "checkpointNumber", checkpointNumber, "err", err) return result, err } candidatesAddresses := state.GetCandidates(statedb) @@ -910,7 +912,7 @@ func (s *PublicBlockChainAPI) GetCandidates(ctx context.Context, epoch rpc.Epoch } if err != nil || len(candidates) == 0 { - log.Debug("Candidates list cannot be found", "len(candidates)", len(candidates), "err", err) + log.Error("Candidates list cannot be found", "len(candidates)", len(candidates), "err", err) result[fieldSuccess] = false return result, err } @@ -976,21 +978,17 @@ func (s *PublicBlockChainAPI) GetPreviousCheckpointFromEpoch(ctx context.Context var checkpointNumber uint64 if engine, ok := s.b.GetEngine().(*XDPoS.XDPoS); ok { - currentCheckpointNumber, epochNumber, err := engine.GetCurrentEpochSwitchBlock(s.chainReader, s.b.CurrentBlock().Number()) - if err != nil { - log.Error("[GetPreviousCheckpointFromEpoch] Error while trying to get current epoch switch block information", "Block", s.b.CurrentBlock(), "Error", err) - } if epochNum == rpc.LatestEpochNumber { + currentCheckpointNumber, epochNumber, err := engine.GetCurrentEpochSwitchBlock(s.chainReader, s.b.CurrentBlock().Number()) + if err != nil { + log.Error("[GetPreviousCheckpointFromEpoch] Error while trying to get current epoch switch block information", "Block", s.b.CurrentBlock(), "Error", err) + } checkpointNumber = currentCheckpointNumber epochNum = rpc.EpochNumber(epochNumber) } else if epochNum < 2 { checkpointNumber = 0 } else { - blockNumberBeforeCurrentEpochSwitch := currentCheckpointNumber - 1 - checkpointNumber, _, err = engine.GetCurrentEpochSwitchBlock(s.chainReader, big.NewInt(int64(blockNumberBeforeCurrentEpochSwitch))) - if err != nil { - log.Error("[GetPreviousCheckpointFromEpoch] Error while trying to get last epoch switch block information", "Number", blockNumberBeforeCurrentEpochSwitch, "Error", err) - } + checkpointNumber = s.b.ChainConfig().XDPoS.Epoch * (uint64(epochNum) - 1) } return rpc.BlockNumber(checkpointNumber), epochNum } else { From 5791c5371581799710dadf073551cb53e943185e Mon Sep 17 00:00:00 2001 From: Jianrong Date: Mon, 8 Jan 2024 12:26:35 +1100 Subject: [PATCH 2/2] chore: Improve error log --- eth/api_backend.go | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/eth/api_backend.go b/eth/api_backend.go index 186c91e14..b706580e7 100644 --- a/eth/api_backend.go +++ b/eth/api_backend.go @@ -117,9 +117,13 @@ func (b *EthApiBackend) StateAndHeaderByNumber(ctx context.Context, blockNr rpc. } // Otherwise resolve the block number and return its state header, err := b.HeaderByNumber(ctx, blockNr) - if header == nil || err != nil { + if err != nil { + log.Error("[StateAndHeaderByNumber] Error while when loading header by blockNum", "blockNr", blockNr, "err", err) return nil, nil, err } + if header == nil { + return nil, nil, errors.New("header not found") + } stateDb, err := b.eth.BlockChain().StateAt(header.Root) return stateDb, header, err }