mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-11 04:00:05 +00:00
4b3a723166
* Do not stop on error loading synced tips * Terence's review * Update beacon-chain/blockchain/optimistic_sync.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> Co-authored-by: Radosław Kapka <rkapka@wp.pl> Co-authored-by: prylabs-bulldozer[bot] <58059840+prylabs-bulldozer[bot]@users.noreply.github.com>
54 lines
2.0 KiB
Go
54 lines
2.0 KiB
Go
package blockchain
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/pkg/errors"
|
|
types "github.com/prysmaticlabs/eth2-types"
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/core/blocks"
|
|
"github.com/prysmaticlabs/prysm/config/params"
|
|
"github.com/prysmaticlabs/prysm/encoding/bytesutil"
|
|
"github.com/prysmaticlabs/prysm/proto/prysm/v1alpha1/block"
|
|
)
|
|
|
|
// optimisticCandidateBlock returns true if this block can be optimistically synced.
|
|
//
|
|
// Spec pseudocode definition:
|
|
// def is_optimistic_candidate_block(opt_store: OptimisticStore, current_slot: Slot, block: BeaconBlock) -> bool:
|
|
// justified_root = opt_store.block_states[opt_store.head_block_root].current_justified_checkpoint.root
|
|
// justified_is_execution_block = is_execution_block(opt_store.blocks[justified_root])
|
|
// block_is_deep = block.slot + SAFE_SLOTS_TO_IMPORT_OPTIMISTICALLY <= current_slot
|
|
// return justified_is_execution_block or block_is_deep
|
|
func (s *Service) optimisticCandidateBlock(ctx context.Context, blk block.BeaconBlock) (bool, error) {
|
|
if blk.Slot()+params.BeaconConfig().SafeSlotsToImportOptimistically <= s.CurrentSlot() {
|
|
return true, nil
|
|
}
|
|
j := s.store.JustifiedCheckpt()
|
|
if j == nil {
|
|
return false, errNilJustifiedInStore
|
|
}
|
|
jBlock, err := s.cfg.BeaconDB.Block(ctx, bytesutil.ToBytes32(j.Root))
|
|
if err != nil {
|
|
return false, err
|
|
}
|
|
return blocks.ExecutionBlock(jBlock.Block().Body())
|
|
}
|
|
|
|
// loadSyncedTips loads a previously saved synced Tips from DB
|
|
// if no synced tips are saved, then it creates one from the given
|
|
// root and slot number.
|
|
func (s *Service) loadSyncedTips(root [32]byte, slot types.Slot) error {
|
|
// Initialize synced tips
|
|
tips, err := s.cfg.BeaconDB.ValidatedTips(s.ctx)
|
|
if err != nil || len(tips) == 0 {
|
|
tips[root] = slot
|
|
if err != nil {
|
|
log.WithError(err).Warn("Could not read synced tips from DB, using finalized checkpoint as synced tip")
|
|
}
|
|
}
|
|
if err := s.cfg.ForkChoiceStore.SetSyncedTips(tips); err != nil {
|
|
return errors.Wrap(err, "could not set synced tips")
|
|
}
|
|
return nil
|
|
}
|