mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-10 19:51:20 +00:00
93 lines
2.4 KiB
Go
93 lines
2.4 KiB
Go
// Package attestations defines an attestation pool
|
|
// service implementation which is used to manage the lifecycle
|
|
// of aggregated, unaggregated, and fork-choice attestations.
|
|
package attestations
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
"time"
|
|
|
|
lru "github.com/hashicorp/golang-lru"
|
|
lruwrpr "github.com/prysmaticlabs/prysm/v4/cache/lru"
|
|
"github.com/prysmaticlabs/prysm/v4/config/params"
|
|
)
|
|
|
|
var forkChoiceProcessedRootsSize = 1 << 16
|
|
|
|
// Service of attestation pool operations.
|
|
type Service struct {
|
|
cfg *Config
|
|
ctx context.Context
|
|
cancel context.CancelFunc
|
|
err error
|
|
forkChoiceProcessedRoots *lru.Cache
|
|
genesisTime uint64
|
|
}
|
|
|
|
// Config options for the service.
|
|
type Config struct {
|
|
Pool Pool
|
|
pruneInterval time.Duration
|
|
InitialSyncComplete chan struct{}
|
|
}
|
|
|
|
// NewService instantiates a new attestation pool service instance that will
|
|
// be registered into a running beacon node.
|
|
func NewService(ctx context.Context, cfg *Config) (*Service, error) {
|
|
cache := lruwrpr.New(forkChoiceProcessedRootsSize)
|
|
|
|
if cfg.pruneInterval == 0 {
|
|
// Prune expired attestations from the pool every slot interval.
|
|
cfg.pruneInterval = time.Duration(params.BeaconConfig().SecondsPerSlot) * time.Second
|
|
}
|
|
|
|
ctx, cancel := context.WithCancel(ctx)
|
|
return &Service{
|
|
cfg: cfg,
|
|
ctx: ctx,
|
|
cancel: cancel,
|
|
forkChoiceProcessedRoots: cache,
|
|
}, nil
|
|
}
|
|
|
|
// Start an attestation pool service's main event loop.
|
|
func (s *Service) Start() {
|
|
if err := s.waitForSync(s.cfg.InitialSyncComplete); err != nil {
|
|
log.WithError(err).Error("failed to wait for initial sync")
|
|
return
|
|
}
|
|
go s.prepareForkChoiceAtts()
|
|
go s.pruneAttsPool()
|
|
}
|
|
|
|
// waitForSync waits until the beacon node is synced to the latest head.
|
|
func (s *Service) waitForSync(syncChan chan struct{}) error {
|
|
select {
|
|
case <-syncChan:
|
|
return nil
|
|
case <-s.ctx.Done():
|
|
return errors.New("context closed, exiting goroutine")
|
|
}
|
|
}
|
|
|
|
// Stop the beacon block attestation pool service's main event loop
|
|
// and associated goroutines.
|
|
func (s *Service) Stop() error {
|
|
defer s.cancel()
|
|
return nil
|
|
}
|
|
|
|
// Status returns the current service err if there's any.
|
|
func (s *Service) Status() error {
|
|
if s.err != nil {
|
|
return s.err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// SetGenesisTime sets genesis time for operation service to use.
|
|
func (s *Service) SetGenesisTime(t uint64) {
|
|
s.genesisTime = t
|
|
}
|