Documentation
¶
Index ¶
- Constants
- type Logger
- type Option
- func WithAdjustmentWindow(adjustmentWindow int64) Option
- func WithCacheSize(cacheSize int) Option
- func WithMaxConcurrency(concurrency int64) Option
- func WithMetaData(metaData string) Option
- func WithPastBlockLimit(blocks int) Option
- func WithPruneSleepTime(sleepTime int) Option
- func WithSeenConcurrency(concurrency int64) Option
- type PruneHelper
- type StatefulSyncer
- func (s *StatefulSyncer) Block(ctx context.Context, network *types.NetworkIdentifier, ...) (*types.Block, error)
- func (s *StatefulSyncer) BlockAdded(ctx context.Context, block *types.Block) error
- func (s *StatefulSyncer) BlockRemoved(ctx context.Context, blockIdentifier *types.BlockIdentifier) error
- func (s *StatefulSyncer) BlockSeen(ctx context.Context, block *types.Block) error
- func (s *StatefulSyncer) NetworkStatus(ctx context.Context, network *types.NetworkIdentifier) (*types.NetworkStatusResponse, error)
- func (s *StatefulSyncer) Prune(ctx context.Context, helper PruneHelper) error
- func (s *StatefulSyncer) Sync(ctx context.Context, startIndex int64, endIndex int64) error
Constants ¶
const ( // DefaultPruneSleepTime is how long we sleep between // pruning attempts. DefaultPruneSleepTime = 10 * time.Minute )
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Logger ¶
type Logger interface { AddBlockStream(context.Context, *types.Block) error RemoveBlockStream(context.Context, *types.BlockIdentifier) error }
Logger is used by the statefulsyncer to log the addition and removal of blocks.
type Option ¶ added in v0.6.2
type Option func(s *StatefulSyncer)
Option is used to overwrite default values in StatefulSyncer construction. Any Option not provided falls back to the default value.
func WithAdjustmentWindow ¶ added in v0.6.2
WithAdjustmentWindow overrides the default adjustment window.
func WithCacheSize ¶ added in v0.6.2
WithCacheSize overrides the default cache size.
func WithMaxConcurrency ¶ added in v0.6.2
WithMaxConcurrency overrides the default max concurrency.
func WithMetaData ¶ added in v0.8.3
add a metaData map to fetcher
func WithPastBlockLimit ¶ added in v0.6.2
WithPastBlockLimit overrides the default past block limit
func WithPruneSleepTime ¶ added in v0.6.2
WithPruneSleepTime overrides the default prune sleep time.
func WithSeenConcurrency ¶ added in v0.6.5
WithSeenConcurrency overrides the number of concurrent invocations of BlockSeen we will handle. We default to the value of runtime.NumCPU().
type PruneHelper ¶ added in v0.5.4
type PruneHelper interface { // PruneableIndex is the largest block // index that is considered safe to prune. PruneableIndex(ctx context.Context, headIndex int64) (int64, error) }
PruneHelper is used by the stateful syncer to determine the safe pruneable index. This is a helper instead of a static argument because the pruneable index is often a function of the state of some number of structs.
type StatefulSyncer ¶
type StatefulSyncer struct {
// contains filtered or unexported fields
}
StatefulSyncer is an abstraction layer over the stateless syncer package. This layer handles sync restarts and provides fully populated blocks during reorgs (not provided by stateless syncer).
func New ¶
func New( ctx context.Context, network *types.NetworkIdentifier, fetcher *fetcher.Fetcher, blockStorage *modules.BlockStorage, counterStorage *modules.CounterStorage, logger Logger, cancel context.CancelFunc, workers []modules.BlockWorker, options ...Option, ) *StatefulSyncer
New returns a new *StatefulSyncer.
func (*StatefulSyncer) Block ¶
func (s *StatefulSyncer) Block( ctx context.Context, network *types.NetworkIdentifier, block *types.PartialBlockIdentifier, ) (*types.Block, error)
Block is called by the syncer to fetch a block.
func (*StatefulSyncer) BlockAdded ¶
BlockAdded is called by the syncer when a block is added.
func (*StatefulSyncer) BlockRemoved ¶
func (s *StatefulSyncer) BlockRemoved( ctx context.Context, blockIdentifier *types.BlockIdentifier, ) error
BlockRemoved is called by the syncer when a block is removed.
func (*StatefulSyncer) BlockSeen ¶ added in v0.6.5
BlockSeen is called by the syncer when a block is seen.
func (*StatefulSyncer) NetworkStatus ¶
func (s *StatefulSyncer) NetworkStatus( ctx context.Context, network *types.NetworkIdentifier, ) (*types.NetworkStatusResponse, error)
NetworkStatus is called by the syncer to get the current network status.
func (*StatefulSyncer) Prune ¶ added in v0.4.5
func (s *StatefulSyncer) Prune(ctx context.Context, helper PruneHelper) error
Prune will repeatedly attempt to prune BlockStorage until the context is canceled or an error is encountered.
PruneHelper is provided as an argument here instead of in the initializer because the caller may wish to change pruning strategies during syncing.