mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-15 06:28:20 +00:00
68d0c09daf
* Add, use and test `VerifyWeakSubjectivityRoot` * Comments * Make bazel test happy * Merge branch 'master' into verify-ws * Add flag to help * Merge branch 'verify-ws' of github.com:prysmaticlabs/prysm into verify-ws * Merge refs/heads/master into verify-ws * Merge refs/heads/master into verify-ws * Merge refs/heads/master into verify-ws * Merge branch 'master' of github.com:prysmaticlabs/prysm into verify-ws * Update beacon-chain/blockchain/service.go Co-authored-by: Raul Jordan <raul@prysmaticlabs.com> * Update beacon-chain/blockchain/weak_subjectivity_checks.go Co-authored-by: Raul Jordan <raul@prysmaticlabs.com> * Merge branch 'verify-ws' of github.com:prysmaticlabs/prysm into verify-ws * s/&&/|| for VerifyWeakSubjectivityRoot circuit breaker * Merge refs/heads/master into verify-ws * Merge refs/heads/master into verify-ws
61 lines
1.9 KiB
Go
61 lines
1.9 KiB
Go
package blockchain
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/core/helpers"
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/db/filters"
|
|
"github.com/prysmaticlabs/prysm/shared/bytesutil"
|
|
"github.com/prysmaticlabs/prysm/shared/params"
|
|
)
|
|
|
|
// VerifyWeakSubjectivityRoot verifies the weak subjectivity root in the service struct.
|
|
// Reference design: https://github.com/ethereum/eth2.0-specs/blob/master/specs/phase0/weak-subjectivity.md#weak-subjectivity-sync-procedure
|
|
func (s *Service) VerifyWeakSubjectivityRoot(ctx context.Context) error {
|
|
// TODO(7342): Remove the following to fully use weak subjectivity in production.
|
|
if len(s.wsRoot) == 0 || s.wsEpoch == 0 {
|
|
return nil
|
|
}
|
|
|
|
// Do nothing if the weak subjectivity has previously been verified,
|
|
// or weak subjectivity epoch is higher than last finalized epoch.
|
|
if s.wsVerified {
|
|
return nil
|
|
}
|
|
if s.wsEpoch > s.finalizedCheckpt.Epoch {
|
|
return nil
|
|
}
|
|
|
|
r := bytesutil.ToBytes32(s.wsRoot)
|
|
log.Infof("Performing weak subjectivity check for root %#x in epoch %d", r, s.wsEpoch)
|
|
// Save initial sync cached blocks to DB.
|
|
if err := s.beaconDB.SaveBlocks(ctx, s.getInitSyncBlocks()); err != nil {
|
|
return err
|
|
}
|
|
// A node should have the weak subjectivity block in the DB.
|
|
if !s.beaconDB.HasBlock(ctx, r) {
|
|
return fmt.Errorf("node does not have root in DB: %#x", r)
|
|
}
|
|
|
|
startSlot, err := helpers.StartSlot(s.wsEpoch)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
// A node should have the weak subjectivity block corresponds to the correct epoch in the DB.
|
|
filter := filters.NewFilter().SetStartSlot(startSlot).SetEndSlot(startSlot + params.BeaconConfig().SlotsPerEpoch)
|
|
roots, err := s.beaconDB.BlockRoots(ctx, filter)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
for _, root := range roots {
|
|
if r == root {
|
|
log.Info("Weak subjectivity check has passed")
|
|
s.wsVerified = true
|
|
return nil
|
|
}
|
|
}
|
|
|
|
return fmt.Errorf("node does not have root in db corresponding to epoch: %#x %d", r, s.wsEpoch)
|
|
}
|