package verify import ( "context" "fmt" "time" "github.com/ledgerwatch/erigon-lib/kv/mdbx" "github.com/ledgerwatch/erigon/common" "github.com/ledgerwatch/erigon/common/changeset" "github.com/ledgerwatch/erigon/common/dbutils" "github.com/ledgerwatch/erigon/ethdb/bitmapdb" ) func CheckIndex(ctx context.Context, chaindata string, changeSetBucket string, indexBucket string) error { db := mdbx.MustOpen(chaindata) defer db.Close() tx, err := db.BeginRo(context.Background()) if err != nil { return err } defer tx.Rollback() startTime := time.Now() i := 0 if err := changeset.ForEach(tx, changeSetBucket, nil, func(blockN uint64, k, v []byte) error { i++ if i%100_000 == 0 { fmt.Printf("Processed %dK, %s\n", blockN/1000, time.Since(startTime)) } select { default: case <-ctx.Done(): return ctx.Err() } bm, innerErr := bitmapdb.Get64(tx, indexBucket, dbutils.CompositeKeyWithoutIncarnation(k), blockN-1, blockN+1) if innerErr != nil { return innerErr } if !bm.Contains(blockN) { return fmt.Errorf("%v,%v", blockN, common.Bytes2Hex(k)) } return nil }); err != nil { return err } fmt.Println("Check was successful") return nil }