mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-05 02:24:29 +00:00
60 lines
1.5 KiB
Go
60 lines
1.5 KiB
Go
|
package integrity
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
"fmt"
|
||
|
"time"
|
||
|
|
||
|
"github.com/ledgerwatch/erigon-lib/common"
|
||
|
"github.com/ledgerwatch/erigon-lib/kv"
|
||
|
"github.com/ledgerwatch/erigon/core/rawdb"
|
||
|
"github.com/ledgerwatch/erigon/eth/stagedsync/stages"
|
||
|
"github.com/ledgerwatch/erigon/turbo/services"
|
||
|
"github.com/ledgerwatch/erigon/turbo/snapshotsync/freezeblocks"
|
||
|
"github.com/ledgerwatch/log/v3"
|
||
|
)
|
||
|
|
||
|
func NoGapsInCanonicalHeaders(tx kv.Tx, ctx context.Context, br services.BlockReader) {
|
||
|
logEvery := time.NewTicker(10 * time.Second)
|
||
|
defer logEvery.Stop()
|
||
|
|
||
|
if err := br.(*freezeblocks.BlockReader).Integrity(ctx); err != nil {
|
||
|
panic(err)
|
||
|
}
|
||
|
|
||
|
firstBlockInDB := br.(*freezeblocks.BlockReader).FrozenBlocks() + 1
|
||
|
lastBlockNum, err := stages.GetStageProgress(tx, stages.Headers)
|
||
|
if err != nil {
|
||
|
panic(err)
|
||
|
}
|
||
|
|
||
|
for i := firstBlockInDB; i < lastBlockNum; i++ {
|
||
|
hash, err := rawdb.ReadCanonicalHash(tx, i)
|
||
|
if err != nil {
|
||
|
panic(err)
|
||
|
}
|
||
|
if hash == (common.Hash{}) {
|
||
|
err = fmt.Errorf("canonical marker not found: %d\n", i)
|
||
|
panic(err)
|
||
|
}
|
||
|
header := rawdb.ReadHeader(tx, hash, i)
|
||
|
if header == nil {
|
||
|
err = fmt.Errorf("header not found: %d\n", i)
|
||
|
panic(err)
|
||
|
}
|
||
|
body, _, _ := rawdb.ReadBody(tx, hash, i)
|
||
|
if body == nil {
|
||
|
err = fmt.Errorf("header not found: %d\n", i)
|
||
|
panic(err)
|
||
|
}
|
||
|
|
||
|
select {
|
||
|
case <-ctx.Done():
|
||
|
return
|
||
|
case <-logEvery.C:
|
||
|
log.Info("[integrity] NoGapsInCanonicalHeaders", "progress", fmt.Sprintf("%dK/%dK", i/1000, lastBlockNum/1000))
|
||
|
default:
|
||
|
}
|
||
|
}
|
||
|
}
|