mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-11 12:10:05 +00:00
d55757500f
* Initial spec rewrite * Finish adding merkle tree implementation * Last bits * Move reverse function * Add comments * Add deposit tree snapshot * Add deposit tree * Add comments + cleanup * Fixes * Add missing errors * Small fixes * Add unhandled error * Cleanup * Fix unsafe file.Close * Add missing comments * Small fixes * Address some of deepSource' compaints * Add depositCount check * Add finalizedDeposit check * Replace pointer magic with copy() * Add test for slice reversal * add back bytes method * Add package level description * Remove zerohash gen and add additional checks * Add additional comments * Small lint fixes * Forgot an error * Small fixes * Move Uint64ToBytesLittleEndian32 + test * Fix uint subtraction issue * Move mixInLength below error handling * Fix * Fix deposit root * integrate 4881 * edits * added in deposit tree fetcher * add file * Add remaining fetcher functions * Add new file for inserter functions * Fixes and additional funcs * Cleanup * Add * Graph * pushed up edits * fix up * Updates * Add EIP4881 toggle flag * Add interfaces * Fix tests * More changes * Fix * Remove generated graph * Fix spacing * Changes * Fixes * Changes * Test Fix * gaz * Fix a couple tests * Fix last tests * define protos * proto methods * pushed * regen * Add proto funcs * builds * pushin up * Fix and cleanup * Fix spectest * General cleanup * add 4881 to e2e * Remove debug statements + remove test skip * Implement first set of missing methods * Replace Zerohashes + cleanup * gazelle * fmt * Put back defensive check * Add error logs * InsertFinalizedDeposits: return an error * Remove logging * Radek' Review * Lint fixes * build * Remove cancel * Update beacon-chain/deterministic-genesis/service.go Co-authored-by: Raul Jordan <raul@prysmaticlabs.com> * Update beacon-chain/cache/depositsnapshot/deposit_inserter.go Co-authored-by: Raul Jordan <raul@prysmaticlabs.com> * Cleanup * Fix panic when DepositSnapshot is nil on init * Gofmt * Fix RootEquivalence test * Gofmt * Add missing comments * Nishant' review * Add Insert benchmarks * fix up copy method * Fix deep copy * Fix conflicts * Return error * Fix linter issues * add in migration logic * Cleanup + tests * fix * Fix incorrect index in test * Fix linter * Gofmt * fix it * fixes for off by 1 * gaz * fix cast * fix it * remove ErrZeroIndex * Fix merkle_tree_test * add fallback * add fix for insertion bug * add many fixes * fix empty snapshot * clean up * use feature * remove check * fix failing tests * skip it * fix test * fix test again * fix for the last time * Apply suggestions from code review Co-authored-by: Radosław Kapka <rkapka@wp.pl> * fix it * remove cancel * fix for voting * addressing more comments * fix err * potuz's review * one more test * fix bad test * make 4881 part of dev mode * add workaround for new trie * comment * preston's review * james's review * add comment * james review * preston's review * remove skipped test * gaz --------- Co-authored-by: rauljordan <raul@prysmaticlabs.com> Co-authored-by: nisdas <nishdas93@gmail.com> Co-authored-by: Radosław Kapka <rkapka@wp.pl> Co-authored-by: prylabs-bulldozer[bot] <58059840+prylabs-bulldozer[bot]@users.noreply.github.com>
181 lines
4.8 KiB
Go
181 lines
4.8 KiB
Go
package blockchain
|
|
|
|
import (
|
|
"github.com/prysmaticlabs/prysm/v4/async/event"
|
|
"github.com/prysmaticlabs/prysm/v4/beacon-chain/cache"
|
|
statefeed "github.com/prysmaticlabs/prysm/v4/beacon-chain/core/feed/state"
|
|
"github.com/prysmaticlabs/prysm/v4/beacon-chain/db"
|
|
"github.com/prysmaticlabs/prysm/v4/beacon-chain/execution"
|
|
"github.com/prysmaticlabs/prysm/v4/beacon-chain/forkchoice"
|
|
"github.com/prysmaticlabs/prysm/v4/beacon-chain/operations/attestations"
|
|
"github.com/prysmaticlabs/prysm/v4/beacon-chain/operations/blstoexec"
|
|
"github.com/prysmaticlabs/prysm/v4/beacon-chain/operations/slashings"
|
|
"github.com/prysmaticlabs/prysm/v4/beacon-chain/operations/voluntaryexits"
|
|
"github.com/prysmaticlabs/prysm/v4/beacon-chain/p2p"
|
|
"github.com/prysmaticlabs/prysm/v4/beacon-chain/startup"
|
|
"github.com/prysmaticlabs/prysm/v4/beacon-chain/state"
|
|
"github.com/prysmaticlabs/prysm/v4/beacon-chain/state/stategen"
|
|
ethpb "github.com/prysmaticlabs/prysm/v4/proto/prysm/v1alpha1"
|
|
)
|
|
|
|
type Option func(s *Service) error
|
|
|
|
// WithMaxGoroutines to control resource use of the blockchain service.
|
|
func WithMaxGoroutines(x int) Option {
|
|
return func(s *Service) error {
|
|
s.cfg.MaxRoutines = x
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// WithWeakSubjectivityCheckpoint for checkpoint sync.
|
|
func WithWeakSubjectivityCheckpoint(c *ethpb.Checkpoint) Option {
|
|
return func(s *Service) error {
|
|
s.cfg.WeakSubjectivityCheckpt = c
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// WithDatabase for head access.
|
|
func WithDatabase(beaconDB db.HeadAccessDatabase) Option {
|
|
return func(s *Service) error {
|
|
s.cfg.BeaconDB = beaconDB
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// WithChainStartFetcher to retrieve information about genesis.
|
|
func WithChainStartFetcher(f execution.ChainStartFetcher) Option {
|
|
return func(s *Service) error {
|
|
s.cfg.ChainStartFetcher = f
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// WithExecutionEngineCaller to call execution engine.
|
|
func WithExecutionEngineCaller(c execution.EngineCaller) Option {
|
|
return func(s *Service) error {
|
|
s.cfg.ExecutionEngineCaller = c
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// WithDepositCache for deposit lifecycle after chain inclusion.
|
|
func WithDepositCache(c cache.DepositCache) Option {
|
|
return func(s *Service) error {
|
|
s.cfg.DepositCache = c
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// WithProposerIdsCache for proposer id cache.
|
|
func WithProposerIdsCache(c *cache.ProposerPayloadIDsCache) Option {
|
|
return func(s *Service) error {
|
|
s.cfg.ProposerSlotIndexCache = c
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// WithAttestationPool for attestation lifecycle after chain inclusion.
|
|
func WithAttestationPool(p attestations.Pool) Option {
|
|
return func(s *Service) error {
|
|
s.cfg.AttPool = p
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// WithExitPool for exits lifecycle after chain inclusion.
|
|
func WithExitPool(p voluntaryexits.PoolManager) Option {
|
|
return func(s *Service) error {
|
|
s.cfg.ExitPool = p
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// WithSlashingPool for slashings lifecycle after chain inclusion.
|
|
func WithSlashingPool(p slashings.PoolManager) Option {
|
|
return func(s *Service) error {
|
|
s.cfg.SlashingPool = p
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// WithBLSToExecPool to keep track of BLS to Execution address changes.
|
|
func WithBLSToExecPool(p blstoexec.PoolManager) Option {
|
|
return func(s *Service) error {
|
|
s.cfg.BLSToExecPool = p
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// WithP2PBroadcaster to broadcast messages after appropriate processing.
|
|
func WithP2PBroadcaster(p p2p.Broadcaster) Option {
|
|
return func(s *Service) error {
|
|
s.cfg.P2p = p
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// WithStateNotifier to notify an event feed of state processing.
|
|
func WithStateNotifier(n statefeed.Notifier) Option {
|
|
return func(s *Service) error {
|
|
s.cfg.StateNotifier = n
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// WithForkChoiceStore to update an optimized fork-choice representation.
|
|
func WithForkChoiceStore(f forkchoice.ForkChoicer) Option {
|
|
return func(s *Service) error {
|
|
s.cfg.ForkChoiceStore = f
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// WithAttestationService for dealing with attestation lifecycles.
|
|
func WithAttestationService(srv *attestations.Service) Option {
|
|
return func(s *Service) error {
|
|
s.cfg.AttService = srv
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// WithStateGen for managing state regeneration and replay.
|
|
func WithStateGen(g *stategen.State) Option {
|
|
return func(s *Service) error {
|
|
s.cfg.StateGen = g
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// WithSlasherAttestationsFeed to forward attestations into slasher if enabled.
|
|
func WithSlasherAttestationsFeed(f *event.Feed) Option {
|
|
return func(s *Service) error {
|
|
s.cfg.SlasherAttestationsFeed = f
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// WithFinalizedStateAtStartUp to store finalized state at start up.
|
|
func WithFinalizedStateAtStartUp(st state.BeaconState) Option {
|
|
return func(s *Service) error {
|
|
s.cfg.FinalizedStateAtStartUp = st
|
|
return nil
|
|
}
|
|
}
|
|
|
|
func WithClockSynchronizer(gs *startup.ClockSynchronizer) Option {
|
|
return func(s *Service) error {
|
|
s.clockSetter = gs
|
|
s.clockWaiter = gs
|
|
return nil
|
|
}
|
|
}
|
|
|
|
func WithSyncComplete(c chan struct{}) Option {
|
|
return func(s *Service) error {
|
|
s.syncComplete = c
|
|
return nil
|
|
}
|
|
}
|