# Nimbus # Copyright (c) 2021-2024 Status Research & Development GmbH # Licensed and distributed under either of # * MIT license (license terms in the root directory or at # https://opensource.org/licenses/MIT). # * Apache v2 license (license terms in the root directory or at # https://www.apache.org/licenses/LICENSE-2.0). # at your option. This file may not be copied, modified, or distributed # except according to those terms. {.push raises:[].} import pkg/chronos, pkg/eth/common, pkg/stew/[interval_set, sorted_set], ../../core/chain, ../sync_desc, ./worker/helpers, ./worker_config export helpers, sync_desc, worker_config when enableTicker: import ./worker/start_stop/ticker type BnRangeSet* = IntervalSetRef[BlockNumber,uint64] ## Disjunct sets of block number intervals BnRange* = Interval[BlockNumber,uint64] ## Single block number interval LinkedHChainQueue* = SortedSet[BlockNumber,LinkedHChain] ## Block intervals sorted by largest block number. LinkedHChain* = object ## Public block items for the `LinkedHChainQueue` list, indexed by the ## largest block number. The list `revHdrs[]` is reversed, i.e. the largest ## block number has the least index `0`. This makes it easier to grow the ## sequence with parent headers, i.e. decreasing block numbers. ## hash*: Hash32 ## Hash of `headers[0]` revHdrs*: seq[seq[byte]] ## Encoded linked header chain parentHash*: Hash32 ## Parent hash of `headers[^1]` StagedBlocksQueue* = SortedSet[BlockNumber,BlocksForImport] ## Blocks sorted by least block number. BlocksForImport* = object ## Block request item sorted by least block number (i.e. from `blocks[0]`.) blocks*: seq[EthBlock] ## List of blocks for import # ------------------- LinkedHChainsLayout* = object ## Layout of a linked header chains defined by the triple `(C,D,E)` as ## described in the `README.md` text. ## :: ## 0 C D E ## o----------------o---------------------o----------------o---> ## | <-- linked --> | <-- unprocessed --> | <-- linked --> | ## coupler*: BlockNumber ## Right end `C` of linked chain `[0,C]` couplerHash*: Hash32 ## Hash of `C` dangling*: BlockNumber ## Left end `D` of linked chain `[D,E]` danglingParent*: Hash32 ## Parent hash of `D` endBn*: BlockNumber ## `E`, block num of some finalised block endHash*: Hash32 ## Hash of `E` BeaconHeader* = object ## Beacon state to be implicitely updated by RPC method changed*: bool ## Set a marker if something has changed header*: Header ## Beacon chain, finalised header hash*: Hash32 ## From RPC, hash of finalised header LinkedHChainsSync* = object ## Sync state for linked header chains final*: BeaconHeader ## Finalised block, see `F` in `README.md` unprocessed*: BnRangeSet ## Block or header ranges to fetch borrowed*: uint64 ## Total of temp. fetched ranges staged*: LinkedHChainQueue ## Blocks fetched but not stored yet layout*: LinkedHChainsLayout ## Current header chains layout lastLayout*: LinkedHChainsLayout ## Previous layout (for delta update) BlocksImportSync* = object ## Sync state for blocks to import/execute unprocessed*: BnRangeSet ## Blocks download requested borrowed*: uint64 ## Total of temp. fetched ranges topRequest*: BlockNumber ## Max requested block number staged*: StagedBlocksQueue ## Blocks ready for import # ------------------- BeaconBuddyData* = object ## Local descriptor data extension nHdrRespErrors*: int ## Number of errors/slow responses in a row nBdyRespErrors*: int ## Ditto for bodies # Debugging and logging. nMultiLoop*: int ## Number of runs stoppedMultiRun*: chronos.Moment ## Time when run-multi stopped multiRunIdle*: chronos.Duration ## Idle time between runs BeaconCtxData* = object ## Globally shared data extension nBuddies*: int ## Number of active workers lhcSyncState*: LinkedHChainsSync ## Syncing by linked header chains blkSyncState*: BlocksImportSync ## For importing/executing blocks nextUpdate*: Moment ## For updating metrics # Blocks import/execution settings for running `persistBlocks()` with # `nBodiesBatch` blocks in each round (minimum value is # `nFetchBodiesRequest`.) chain*: ChainRef importRunningOk*: bool ## Advisory lock, fetch vs. import nBodiesBatch*: int ## Default `nFetchBodiesBatchDefault` blocksStagedQuLenMax*: int ## Default `blocksStagedQueueLenMaxDefault` # Info stuff, no functional contribution nReorg*: int ## Number of reorg invocations (info only) # Debugging stuff when enableTicker: ticker*: TickerRef ## Logger ticker BeaconBuddyRef* = BuddyRef[BeaconCtxData,BeaconBuddyData] ## Extended worker peer descriptor BeaconCtxRef* = CtxRef[BeaconCtxData] ## Extended global descriptor # ------------------------------------------------------------------------------ # Public helpers # ------------------------------------------------------------------------------ func lhc*(ctx: BeaconCtxRef): var LinkedHChainsSync = ## Shortcut ctx.pool.lhcSyncState func blk*(ctx: BeaconCtxRef): var BlocksImportSync = ## Shortcut ctx.pool.blkSyncState func layout*(ctx: BeaconCtxRef): var LinkedHChainsLayout = ## Shortcut ctx.pool.lhcSyncState.layout func db*(ctx: BeaconCtxRef): CoreDbRef = ## Getter ctx.pool.chain.db # ------------------------------------------------------------------------------ # Public logging/debugging helpers # ------------------------------------------------------------------------------ proc `$`*(w: BnRange): string = if w.len == 1: $w.minPt else: $w.minPt & ".." & $w.maxPt # ------------------------------------------------------------------------------ # End # ------------------------------------------------------------------------------