@lodestar/beacon-node 1.35.0-dev.fcf8d024ea → 1.35.0-dev.feed916580
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/api/impl/config/constants.d.ts +0 -5
- package/lib/api/impl/config/constants.js +1 -6
- package/lib/api/impl/config/constants.js.map +1 -1
- package/lib/api/impl/validator/index.js +3 -5
- package/lib/api/impl/validator/index.js.map +1 -1
- package/lib/chain/archiveStore/historicalState/historicalStateRegen.js +0 -1
- package/lib/chain/archiveStore/historicalState/historicalStateRegen.js.map +1 -1
- package/lib/chain/archiveStore/historicalState/worker.js +1 -1
- package/lib/chain/archiveStore/historicalState/worker.js.map +1 -1
- package/lib/chain/blocks/blockInput/blockInput.js +1 -1
- package/lib/chain/blocks/blockInput/blockInput.js.map +1 -1
- package/lib/chain/blocks/importBlock.js +3 -4
- package/lib/chain/blocks/importBlock.js.map +1 -1
- package/lib/chain/blocks/verifyBlocksDataAvailability.js +1 -8
- package/lib/chain/blocks/verifyBlocksDataAvailability.js.map +1 -1
- package/lib/chain/blocks/writeBlockInputToDb.js +7 -1
- package/lib/chain/blocks/writeBlockInputToDb.js.map +1 -1
- package/lib/chain/bls/multithread/index.js +0 -1
- package/lib/chain/bls/multithread/index.js.map +1 -1
- package/lib/chain/chain.js +3 -2
- package/lib/chain/chain.js.map +1 -1
- package/lib/chain/emitter.d.ts +2 -2
- package/lib/chain/opPools/attestationPool.d.ts +3 -2
- package/lib/chain/opPools/attestationPool.js +5 -3
- package/lib/chain/opPools/attestationPool.js.map +1 -1
- package/lib/chain/opPools/syncCommitteeMessagePool.d.ts +2 -3
- package/lib/chain/opPools/syncCommitteeMessagePool.js +5 -6
- package/lib/chain/opPools/syncCommitteeMessagePool.js.map +1 -1
- package/lib/chain/opPools/types.d.ts +1 -1
- package/lib/chain/opPools/types.js +1 -1
- package/lib/chain/opPools/types.js.map +1 -1
- package/lib/chain/prepareNextSlot.d.ts +3 -3
- package/lib/chain/prepareNextSlot.js +8 -8
- package/lib/chain/prepareNextSlot.js.map +1 -1
- package/lib/chain/stateCache/persistentCheckpointsCache.js +8 -9
- package/lib/chain/stateCache/persistentCheckpointsCache.js.map +1 -1
- package/lib/chain/validation/lightClientFinalityUpdate.js +3 -4
- package/lib/chain/validation/lightClientFinalityUpdate.js.map +1 -1
- package/lib/chain/validation/lightClientOptimisticUpdate.d.ts +4 -6
- package/lib/chain/validation/lightClientOptimisticUpdate.js +11 -11
- package/lib/chain/validation/lightClientOptimisticUpdate.js.map +1 -1
- package/lib/chain/validatorMonitor.js +14 -20
- package/lib/chain/validatorMonitor.js.map +1 -1
- package/lib/db/buckets.d.ts +4 -4
- package/lib/db/buckets.js +4 -4
- package/lib/db/buckets.js.map +1 -1
- package/lib/db/repositories/blobSidecars.js +1 -1
- package/lib/db/repositories/blobSidecars.js.map +1 -1
- package/lib/db/repositories/blobSidecarsArchive.js +1 -1
- package/lib/db/repositories/blobSidecarsArchive.js.map +1 -1
- package/lib/db/repositories/blockArchiveIndex.d.ts +2 -2
- package/lib/db/repositories/dataColumnSidecar.js +1 -1
- package/lib/db/repositories/dataColumnSidecar.js.map +1 -1
- package/lib/db/repositories/dataColumnSidecarArchive.js +1 -1
- package/lib/db/repositories/dataColumnSidecarArchive.js.map +1 -1
- package/lib/metrics/metrics/lodestar.d.ts +1 -1
- package/lib/metrics/metrics/lodestar.js +3 -3
- package/lib/metrics/metrics/lodestar.js.map +1 -1
- package/lib/network/core/networkCoreWorkerHandler.js +3 -9
- package/lib/network/core/networkCoreWorkerHandler.js.map +1 -1
- package/lib/network/discv5/index.js +1 -4
- package/lib/network/discv5/index.js.map +1 -1
- package/lib/network/gossip/gossipsub.d.ts +0 -1
- package/lib/network/gossip/gossipsub.js +16 -35
- package/lib/network/gossip/gossipsub.js.map +1 -1
- package/lib/network/gossip/metrics.d.ts +7 -15
- package/lib/network/gossip/metrics.js +6 -16
- package/lib/network/gossip/metrics.js.map +1 -1
- package/lib/network/libp2p/index.js +1 -9
- package/lib/network/libp2p/index.js.map +1 -1
- package/lib/network/metadata.js +1 -2
- package/lib/network/metadata.js.map +1 -1
- package/lib/network/network.d.ts +1 -1
- package/lib/network/network.js +13 -11
- package/lib/network/network.js.map +1 -1
- package/lib/network/peers/datastore.d.ts +2 -2
- package/lib/network/peers/datastore.js +2 -2
- package/lib/network/peers/datastore.js.map +1 -1
- package/lib/network/processor/index.d.ts +1 -1
- package/lib/network/processor/index.js +3 -2
- package/lib/network/processor/index.js.map +1 -1
- package/lib/sync/types.d.ts +1 -0
- package/lib/sync/types.js.map +1 -1
- package/lib/sync/unknownBlock.d.ts +1 -0
- package/lib/sync/unknownBlock.js +19 -17
- package/lib/sync/unknownBlock.js.map +1 -1
- package/lib/sync/utils/downloadByRoot.d.ts +1 -3
- package/lib/sync/utils/downloadByRoot.js +9 -36
- package/lib/sync/utils/downloadByRoot.js.map +1 -1
- package/lib/util/blobs.js +3 -5
- package/lib/util/blobs.js.map +1 -1
- package/lib/util/clock.d.ts +0 -5
- package/lib/util/clock.js +0 -3
- package/lib/util/clock.js.map +1 -1
- package/lib/util/dataColumns.js +1 -1
- package/lib/util/dataColumns.js.map +1 -1
- package/lib/util/execution.js +2 -19
- package/lib/util/execution.js.map +1 -1
- package/package.json +22 -32
- package/lib/api/impl/api.d.ts.map +0 -1
- package/lib/api/impl/beacon/blocks/index.d.ts.map +0 -1
- package/lib/api/impl/beacon/blocks/utils.d.ts.map +0 -1
- package/lib/api/impl/beacon/index.d.ts.map +0 -1
- package/lib/api/impl/beacon/pool/index.d.ts.map +0 -1
- package/lib/api/impl/beacon/rewards/index.d.ts.map +0 -1
- package/lib/api/impl/beacon/state/index.d.ts.map +0 -1
- package/lib/api/impl/beacon/state/utils.d.ts.map +0 -1
- package/lib/api/impl/config/constants.d.ts.map +0 -1
- package/lib/api/impl/config/index.d.ts.map +0 -1
- package/lib/api/impl/debug/index.d.ts.map +0 -1
- package/lib/api/impl/errors.d.ts.map +0 -1
- package/lib/api/impl/events/index.d.ts.map +0 -1
- package/lib/api/impl/index.d.ts.map +0 -1
- package/lib/api/impl/lightclient/index.d.ts.map +0 -1
- package/lib/api/impl/lodestar/index.d.ts.map +0 -1
- package/lib/api/impl/node/index.d.ts.map +0 -1
- package/lib/api/impl/node/utils.d.ts.map +0 -1
- package/lib/api/impl/proof/index.d.ts.map +0 -1
- package/lib/api/impl/types.d.ts.map +0 -1
- package/lib/api/impl/utils.d.ts.map +0 -1
- package/lib/api/impl/validator/index.d.ts.map +0 -1
- package/lib/api/impl/validator/utils.d.ts.map +0 -1
- package/lib/api/index.d.ts.map +0 -1
- package/lib/api/options.d.ts.map +0 -1
- package/lib/api/rest/activeSockets.d.ts.map +0 -1
- package/lib/api/rest/base.d.ts.map +0 -1
- package/lib/api/rest/index.d.ts.map +0 -1
- package/lib/api/rest/swaggerUI.d.ts.map +0 -1
- package/lib/bun-wrappers/prometheus-gc-stats.d.ts.map +0 -1
- package/lib/chain/ColumnReconstructionTracker.d.ts.map +0 -1
- package/lib/chain/GetBlobsTracker.d.ts.map +0 -1
- package/lib/chain/archiveStore/archiveStore.d.ts.map +0 -1
- package/lib/chain/archiveStore/constants.d.ts.map +0 -1
- package/lib/chain/archiveStore/historicalState/getHistoricalState.d.ts.map +0 -1
- package/lib/chain/archiveStore/historicalState/historicalStateRegen.d.ts.map +0 -1
- package/lib/chain/archiveStore/historicalState/metrics.d.ts.map +0 -1
- package/lib/chain/archiveStore/historicalState/types.d.ts.map +0 -1
- package/lib/chain/archiveStore/historicalState/worker.d.ts.map +0 -1
- package/lib/chain/archiveStore/index.d.ts.map +0 -1
- package/lib/chain/archiveStore/interface.d.ts.map +0 -1
- package/lib/chain/archiveStore/strategies/frequencyStateArchiveStrategy.d.ts.map +0 -1
- package/lib/chain/archiveStore/utils/archiveBlocks.d.ts.map +0 -1
- package/lib/chain/archiveStore/utils/pruneHistory.d.ts.map +0 -1
- package/lib/chain/archiveStore/utils/updateBackfillRange.d.ts.map +0 -1
- package/lib/chain/balancesCache.d.ts.map +0 -1
- package/lib/chain/beaconProposerCache.d.ts.map +0 -1
- package/lib/chain/blocks/blockInput/blockInput.d.ts.map +0 -1
- package/lib/chain/blocks/blockInput/errors.d.ts.map +0 -1
- package/lib/chain/blocks/blockInput/index.d.ts.map +0 -1
- package/lib/chain/blocks/blockInput/types.d.ts.map +0 -1
- package/lib/chain/blocks/blockInput/utils.d.ts.map +0 -1
- package/lib/chain/blocks/importBlock.d.ts.map +0 -1
- package/lib/chain/blocks/index.d.ts.map +0 -1
- package/lib/chain/blocks/types.d.ts.map +0 -1
- package/lib/chain/blocks/utils/blowfishBanner.d.ts.map +0 -1
- package/lib/chain/blocks/utils/chainSegment.d.ts.map +0 -1
- package/lib/chain/blocks/utils/checkpoint.d.ts.map +0 -1
- package/lib/chain/blocks/utils/giraffeBanner.d.ts.map +0 -1
- package/lib/chain/blocks/utils/ownBanner.d.ts.map +0 -1
- package/lib/chain/blocks/utils/pandaMergeTransitionBanner.d.ts.map +0 -1
- package/lib/chain/blocks/utils/zebraBanner.d.ts.map +0 -1
- package/lib/chain/blocks/verifyBlock.d.ts.map +0 -1
- package/lib/chain/blocks/verifyBlocksDataAvailability.d.ts.map +0 -1
- package/lib/chain/blocks/verifyBlocksExecutionPayloads.d.ts.map +0 -1
- package/lib/chain/blocks/verifyBlocksSanityChecks.d.ts.map +0 -1
- package/lib/chain/blocks/verifyBlocksSignatures.d.ts.map +0 -1
- package/lib/chain/blocks/verifyBlocksStateTransitionOnly.d.ts.map +0 -1
- package/lib/chain/blocks/writeBlockInputToDb.d.ts.map +0 -1
- package/lib/chain/bls/index.d.ts.map +0 -1
- package/lib/chain/bls/interface.d.ts.map +0 -1
- package/lib/chain/bls/maybeBatch.d.ts.map +0 -1
- package/lib/chain/bls/multithread/index.d.ts.map +0 -1
- package/lib/chain/bls/multithread/jobItem.d.ts.map +0 -1
- package/lib/chain/bls/multithread/poolSize.d.ts.map +0 -1
- package/lib/chain/bls/multithread/types.d.ts.map +0 -1
- package/lib/chain/bls/multithread/utils.d.ts.map +0 -1
- package/lib/chain/bls/multithread/worker.d.ts.map +0 -1
- package/lib/chain/bls/singleThread.d.ts.map +0 -1
- package/lib/chain/bls/utils.d.ts.map +0 -1
- package/lib/chain/chain.d.ts.map +0 -1
- package/lib/chain/emitter.d.ts.map +0 -1
- package/lib/chain/errors/attestationError.d.ts.map +0 -1
- package/lib/chain/errors/attesterSlashingError.d.ts.map +0 -1
- package/lib/chain/errors/blobSidecarError.d.ts.map +0 -1
- package/lib/chain/errors/blockError.d.ts.map +0 -1
- package/lib/chain/errors/blsToExecutionChangeError.d.ts.map +0 -1
- package/lib/chain/errors/dataColumnSidecarError.d.ts.map +0 -1
- package/lib/chain/errors/gossipValidation.d.ts.map +0 -1
- package/lib/chain/errors/index.d.ts.map +0 -1
- package/lib/chain/errors/lightClientError.d.ts.map +0 -1
- package/lib/chain/errors/proposerSlashingError.d.ts.map +0 -1
- package/lib/chain/errors/syncCommitteeError.d.ts.map +0 -1
- package/lib/chain/errors/voluntaryExitError.d.ts.map +0 -1
- package/lib/chain/forkChoice/index.d.ts.map +0 -1
- package/lib/chain/genesis/genesis.d.ts.map +0 -1
- package/lib/chain/genesis/interface.d.ts.map +0 -1
- package/lib/chain/index.d.ts.map +0 -1
- package/lib/chain/initState.d.ts.map +0 -1
- package/lib/chain/interface.d.ts.map +0 -1
- package/lib/chain/lightClient/index.d.ts.map +0 -1
- package/lib/chain/lightClient/proofs.d.ts.map +0 -1
- package/lib/chain/lightClient/types.d.ts.map +0 -1
- package/lib/chain/opPools/aggregatedAttestationPool.d.ts.map +0 -1
- package/lib/chain/opPools/attestationPool.d.ts.map +0 -1
- package/lib/chain/opPools/index.d.ts.map +0 -1
- package/lib/chain/opPools/opPool.d.ts.map +0 -1
- package/lib/chain/opPools/syncCommitteeMessagePool.d.ts.map +0 -1
- package/lib/chain/opPools/syncContributionAndProofPool.d.ts.map +0 -1
- package/lib/chain/opPools/types.d.ts.map +0 -1
- package/lib/chain/opPools/utils.d.ts.map +0 -1
- package/lib/chain/options.d.ts.map +0 -1
- package/lib/chain/prepareNextSlot.d.ts.map +0 -1
- package/lib/chain/produceBlock/computeNewStateRoot.d.ts.map +0 -1
- package/lib/chain/produceBlock/index.d.ts.map +0 -1
- package/lib/chain/produceBlock/produceBlockBody.d.ts.map +0 -1
- package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.d.ts.map +0 -1
- package/lib/chain/regen/errors.d.ts.map +0 -1
- package/lib/chain/regen/index.d.ts.map +0 -1
- package/lib/chain/regen/interface.d.ts.map +0 -1
- package/lib/chain/regen/queued.d.ts.map +0 -1
- package/lib/chain/regen/regen.d.ts.map +0 -1
- package/lib/chain/reprocess.d.ts.map +0 -1
- package/lib/chain/rewards/attestationsRewards.d.ts.map +0 -1
- package/lib/chain/rewards/blockRewards.d.ts.map +0 -1
- package/lib/chain/rewards/syncCommitteeRewards.d.ts.map +0 -1
- package/lib/chain/seenCache/index.d.ts.map +0 -1
- package/lib/chain/seenCache/seenAggregateAndProof.d.ts.map +0 -1
- package/lib/chain/seenCache/seenAttestationData.d.ts.map +0 -1
- package/lib/chain/seenCache/seenAttesters.d.ts.map +0 -1
- package/lib/chain/seenCache/seenBlockAttesters.d.ts.map +0 -1
- package/lib/chain/seenCache/seenBlockProposers.d.ts.map +0 -1
- package/lib/chain/seenCache/seenCommittee.d.ts.map +0 -1
- package/lib/chain/seenCache/seenCommitteeContribution.d.ts.map +0 -1
- package/lib/chain/seenCache/seenGossipBlockInput.d.ts.map +0 -1
- package/lib/chain/serializeState.d.ts.map +0 -1
- package/lib/chain/shufflingCache.d.ts.map +0 -1
- package/lib/chain/stateCache/blockStateCacheImpl.d.ts.map +0 -1
- package/lib/chain/stateCache/datastore/db.d.ts.map +0 -1
- package/lib/chain/stateCache/datastore/file.d.ts.map +0 -1
- package/lib/chain/stateCache/datastore/index.d.ts.map +0 -1
- package/lib/chain/stateCache/datastore/types.d.ts.map +0 -1
- package/lib/chain/stateCache/fifoBlockStateCache.d.ts.map +0 -1
- package/lib/chain/stateCache/inMemoryCheckpointsCache.d.ts.map +0 -1
- package/lib/chain/stateCache/index.d.ts.map +0 -1
- package/lib/chain/stateCache/mapMetrics.d.ts.map +0 -1
- package/lib/chain/stateCache/persistentCheckpointsCache.d.ts.map +0 -1
- package/lib/chain/stateCache/types.d.ts.map +0 -1
- package/lib/chain/validation/aggregateAndProof.d.ts.map +0 -1
- package/lib/chain/validation/attestation.d.ts.map +0 -1
- package/lib/chain/validation/attesterSlashing.d.ts.map +0 -1
- package/lib/chain/validation/blobSidecar.d.ts.map +0 -1
- package/lib/chain/validation/block.d.ts.map +0 -1
- package/lib/chain/validation/blsToExecutionChange.d.ts.map +0 -1
- package/lib/chain/validation/dataColumnSidecar.d.ts.map +0 -1
- package/lib/chain/validation/index.d.ts.map +0 -1
- package/lib/chain/validation/lightClientFinalityUpdate.d.ts.map +0 -1
- package/lib/chain/validation/lightClientOptimisticUpdate.d.ts.map +0 -1
- package/lib/chain/validation/proposerSlashing.d.ts.map +0 -1
- package/lib/chain/validation/signatureSets/aggregateAndProof.d.ts.map +0 -1
- package/lib/chain/validation/signatureSets/contributionAndProof.d.ts.map +0 -1
- package/lib/chain/validation/signatureSets/index.d.ts.map +0 -1
- package/lib/chain/validation/signatureSets/selectionProof.d.ts.map +0 -1
- package/lib/chain/validation/signatureSets/syncCommittee.d.ts.map +0 -1
- package/lib/chain/validation/signatureSets/syncCommitteeContribution.d.ts.map +0 -1
- package/lib/chain/validation/signatureSets/syncCommitteeSelectionProof.d.ts.map +0 -1
- package/lib/chain/validation/syncCommittee.d.ts.map +0 -1
- package/lib/chain/validation/syncCommitteeContributionAndProof.d.ts.map +0 -1
- package/lib/chain/validation/voluntaryExit.d.ts.map +0 -1
- package/lib/chain/validatorMonitor.d.ts.map +0 -1
- package/lib/constants/constants.d.ts.map +0 -1
- package/lib/constants/index.d.ts.map +0 -1
- package/lib/constants/network.d.ts.map +0 -1
- package/lib/db/beacon.d.ts.map +0 -1
- package/lib/db/buckets.d.ts.map +0 -1
- package/lib/db/index.d.ts.map +0 -1
- package/lib/db/interface.d.ts.map +0 -1
- package/lib/db/options.d.ts.map +0 -1
- package/lib/db/repositories/attesterSlashing.d.ts.map +0 -1
- package/lib/db/repositories/backfilledRanges.d.ts.map +0 -1
- package/lib/db/repositories/blobSidecars.d.ts.map +0 -1
- package/lib/db/repositories/blobSidecarsArchive.d.ts.map +0 -1
- package/lib/db/repositories/block.d.ts.map +0 -1
- package/lib/db/repositories/blockArchive.d.ts.map +0 -1
- package/lib/db/repositories/blockArchiveIndex.d.ts.map +0 -1
- package/lib/db/repositories/blsToExecutionChange.d.ts.map +0 -1
- package/lib/db/repositories/checkpointState.d.ts.map +0 -1
- package/lib/db/repositories/dataColumnSidecar.d.ts.map +0 -1
- package/lib/db/repositories/dataColumnSidecarArchive.d.ts.map +0 -1
- package/lib/db/repositories/depositDataRoot.d.ts.map +0 -1
- package/lib/db/repositories/depositEvent.d.ts.map +0 -1
- package/lib/db/repositories/eth1Data.d.ts.map +0 -1
- package/lib/db/repositories/index.d.ts.map +0 -1
- package/lib/db/repositories/lightclientBestUpdate.d.ts.map +0 -1
- package/lib/db/repositories/lightclientCheckpointHeader.d.ts.map +0 -1
- package/lib/db/repositories/lightclientSyncCommittee.d.ts.map +0 -1
- package/lib/db/repositories/lightclientSyncCommitteeWitness.d.ts.map +0 -1
- package/lib/db/repositories/proposerSlashing.d.ts.map +0 -1
- package/lib/db/repositories/stateArchive.d.ts.map +0 -1
- package/lib/db/repositories/stateArchiveIndex.d.ts.map +0 -1
- package/lib/db/repositories/voluntaryExit.d.ts.map +0 -1
- package/lib/db/single/index.d.ts.map +0 -1
- package/lib/db/single/preGenesisState.d.ts.map +0 -1
- package/lib/db/single/preGenesisStateLastProcessedBlock.d.ts.map +0 -1
- package/lib/eth1/errors.d.ts.map +0 -1
- package/lib/eth1/eth1DataCache.d.ts.map +0 -1
- package/lib/eth1/eth1DepositDataTracker.d.ts.map +0 -1
- package/lib/eth1/eth1DepositsCache.d.ts.map +0 -1
- package/lib/eth1/eth1MergeBlockTracker.d.ts.map +0 -1
- package/lib/eth1/index.d.ts.map +0 -1
- package/lib/eth1/interface.d.ts.map +0 -1
- package/lib/eth1/options.d.ts.map +0 -1
- package/lib/eth1/provider/eth1Provider.d.ts.map +0 -1
- package/lib/eth1/provider/jsonRpcHttpClient.d.ts.map +0 -1
- package/lib/eth1/provider/jwt.d.ts.map +0 -1
- package/lib/eth1/provider/utils.d.ts.map +0 -1
- package/lib/eth1/stream.d.ts.map +0 -1
- package/lib/eth1/utils/depositContract.d.ts.map +0 -1
- package/lib/eth1/utils/deposits.d.ts.map +0 -1
- package/lib/eth1/utils/eth1Data.d.ts.map +0 -1
- package/lib/eth1/utils/eth1DepositEvent.d.ts.map +0 -1
- package/lib/eth1/utils/eth1Vote.d.ts.map +0 -1
- package/lib/eth1/utils/groupDepositEventsByBlock.d.ts.map +0 -1
- package/lib/eth1/utils/optimizeNextBlockDiffForGenesis.d.ts.map +0 -1
- package/lib/execution/builder/cache.d.ts.map +0 -1
- package/lib/execution/builder/http.d.ts.map +0 -1
- package/lib/execution/builder/index.d.ts.map +0 -1
- package/lib/execution/builder/interface.d.ts.map +0 -1
- package/lib/execution/builder/utils.d.ts.map +0 -1
- package/lib/execution/engine/disabled.d.ts.map +0 -1
- package/lib/execution/engine/http.d.ts.map +0 -1
- package/lib/execution/engine/index.d.ts.map +0 -1
- package/lib/execution/engine/interface.d.ts.map +0 -1
- package/lib/execution/engine/mock.d.ts.map +0 -1
- package/lib/execution/engine/payloadIdCache.d.ts.map +0 -1
- package/lib/execution/engine/types.d.ts.map +0 -1
- package/lib/execution/engine/utils.d.ts.map +0 -1
- package/lib/execution/index.d.ts.map +0 -1
- package/lib/index.d.ts.map +0 -1
- package/lib/metrics/index.d.ts.map +0 -1
- package/lib/metrics/metrics/beacon.d.ts.map +0 -1
- package/lib/metrics/metrics/lodestar.d.ts.map +0 -1
- package/lib/metrics/metrics.d.ts.map +0 -1
- package/lib/metrics/nodeJsMetrics.d.ts.map +0 -1
- package/lib/metrics/options.d.ts.map +0 -1
- package/lib/metrics/server/http.d.ts.map +0 -1
- package/lib/metrics/server/index.d.ts.map +0 -1
- package/lib/metrics/utils/avgMinMax.d.ts.map +0 -1
- package/lib/metrics/utils/gauge.d.ts.map +0 -1
- package/lib/metrics/utils/registryMetricCreator.d.ts.map +0 -1
- package/lib/monitoring/clientStats.d.ts.map +0 -1
- package/lib/monitoring/index.d.ts.map +0 -1
- package/lib/monitoring/options.d.ts.map +0 -1
- package/lib/monitoring/properties.d.ts.map +0 -1
- package/lib/monitoring/service.d.ts.map +0 -1
- package/lib/monitoring/system.d.ts.map +0 -1
- package/lib/monitoring/types.d.ts.map +0 -1
- package/lib/network/core/events.d.ts.map +0 -1
- package/lib/network/core/index.d.ts.map +0 -1
- package/lib/network/core/metrics.d.ts.map +0 -1
- package/lib/network/core/networkCore.d.ts.map +0 -1
- package/lib/network/core/networkCoreWorker.d.ts.map +0 -1
- package/lib/network/core/networkCoreWorkerHandler.d.ts.map +0 -1
- package/lib/network/core/types.d.ts.map +0 -1
- package/lib/network/discv5/index.d.ts.map +0 -1
- package/lib/network/discv5/types.d.ts.map +0 -1
- package/lib/network/discv5/utils.d.ts.map +0 -1
- package/lib/network/discv5/worker.d.ts.map +0 -1
- package/lib/network/events.d.ts.map +0 -1
- package/lib/network/forks.d.ts.map +0 -1
- package/lib/network/gossip/constants.d.ts.map +0 -1
- package/lib/network/gossip/encoding.d.ts.map +0 -1
- package/lib/network/gossip/errors.d.ts.map +0 -1
- package/lib/network/gossip/gossipsub.d.ts.map +0 -1
- package/lib/network/gossip/index.d.ts.map +0 -1
- package/lib/network/gossip/interface.d.ts.map +0 -1
- package/lib/network/gossip/metrics.d.ts.map +0 -1
- package/lib/network/gossip/scoringParameters.d.ts.map +0 -1
- package/lib/network/gossip/topic.d.ts.map +0 -1
- package/lib/network/index.d.ts.map +0 -1
- package/lib/network/interface.d.ts.map +0 -1
- package/lib/network/libp2p/error.d.ts.map +0 -1
- package/lib/network/libp2p/index.d.ts.map +0 -1
- package/lib/network/metadata.d.ts.map +0 -1
- package/lib/network/network.d.ts.map +0 -1
- package/lib/network/networkConfig.d.ts.map +0 -1
- package/lib/network/options.d.ts.map +0 -1
- package/lib/network/peers/client.d.ts.map +0 -1
- package/lib/network/peers/datastore.d.ts.map +0 -1
- package/lib/network/peers/discover.d.ts.map +0 -1
- package/lib/network/peers/index.d.ts.map +0 -1
- package/lib/network/peers/peerManager.d.ts.map +0 -1
- package/lib/network/peers/peersData.d.ts.map +0 -1
- package/lib/network/peers/score/constants.d.ts.map +0 -1
- package/lib/network/peers/score/index.d.ts.map +0 -1
- package/lib/network/peers/score/interface.d.ts.map +0 -1
- package/lib/network/peers/score/score.d.ts.map +0 -1
- package/lib/network/peers/score/store.d.ts.map +0 -1
- package/lib/network/peers/score/utils.d.ts.map +0 -1
- package/lib/network/peers/utils/assertPeerRelevance.d.ts.map +0 -1
- package/lib/network/peers/utils/enrSubnetsDeserialize.d.ts.map +0 -1
- package/lib/network/peers/utils/getConnectedPeerIds.d.ts.map +0 -1
- package/lib/network/peers/utils/index.d.ts.map +0 -1
- package/lib/network/peers/utils/prioritizePeers.d.ts.map +0 -1
- package/lib/network/peers/utils/subnetMap.d.ts.map +0 -1
- package/lib/network/processor/aggregatorTracker.d.ts.map +0 -1
- package/lib/network/processor/extractSlotRootFns.d.ts.map +0 -1
- package/lib/network/processor/gossipHandlers.d.ts.map +0 -1
- package/lib/network/processor/gossipQueues/index.d.ts.map +0 -1
- package/lib/network/processor/gossipQueues/indexed.d.ts.map +0 -1
- package/lib/network/processor/gossipQueues/linear.d.ts.map +0 -1
- package/lib/network/processor/gossipQueues/types.d.ts.map +0 -1
- package/lib/network/processor/gossipValidatorFn.d.ts.map +0 -1
- package/lib/network/processor/index.d.ts.map +0 -1
- package/lib/network/processor/types.d.ts.map +0 -1
- package/lib/network/reqresp/ReqRespBeaconNode.d.ts.map +0 -1
- package/lib/network/reqresp/handlers/beaconBlocksByRange.d.ts.map +0 -1
- package/lib/network/reqresp/handlers/beaconBlocksByRoot.d.ts.map +0 -1
- package/lib/network/reqresp/handlers/blobSidecarsByRange.d.ts.map +0 -1
- package/lib/network/reqresp/handlers/blobSidecarsByRoot.d.ts.map +0 -1
- package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts.map +0 -1
- package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.d.ts.map +0 -1
- package/lib/network/reqresp/handlers/index.d.ts.map +0 -1
- package/lib/network/reqresp/handlers/lightClientBootstrap.d.ts.map +0 -1
- package/lib/network/reqresp/handlers/lightClientFinalityUpdate.d.ts.map +0 -1
- package/lib/network/reqresp/handlers/lightClientOptimisticUpdate.d.ts.map +0 -1
- package/lib/network/reqresp/handlers/lightClientUpdatesByRange.d.ts.map +0 -1
- package/lib/network/reqresp/index.d.ts.map +0 -1
- package/lib/network/reqresp/interface.d.ts.map +0 -1
- package/lib/network/reqresp/protocols.d.ts.map +0 -1
- package/lib/network/reqresp/rateLimit.d.ts.map +0 -1
- package/lib/network/reqresp/score.d.ts.map +0 -1
- package/lib/network/reqresp/types.d.ts.map +0 -1
- package/lib/network/reqresp/utils/collect.d.ts.map +0 -1
- package/lib/network/reqresp/utils/collectSequentialBlocksInRange.d.ts.map +0 -1
- package/lib/network/reqresp/utils/dataColumnResponseValidation.d.ts.map +0 -1
- package/lib/network/statusCache.d.ts.map +0 -1
- package/lib/network/subnets/attnetsService.d.ts.map +0 -1
- package/lib/network/subnets/index.d.ts.map +0 -1
- package/lib/network/subnets/interface.d.ts.map +0 -1
- package/lib/network/subnets/syncnetsService.d.ts.map +0 -1
- package/lib/network/subnets/util.d.ts.map +0 -1
- package/lib/network/util.d.ts.map +0 -1
- package/lib/node/index.d.ts.map +0 -1
- package/lib/node/nodejs.d.ts.map +0 -1
- package/lib/node/notifier.d.ts.map +0 -1
- package/lib/node/options.d.ts.map +0 -1
- package/lib/node/utils/interop/deposits.d.ts.map +0 -1
- package/lib/node/utils/interop/state.d.ts.map +0 -1
- package/lib/node/utils/lightclient.d.ts.map +0 -1
- package/lib/node/utils/state.d.ts.map +0 -1
- package/lib/sync/backfill/backfill.d.ts.map +0 -1
- package/lib/sync/backfill/errors.d.ts.map +0 -1
- package/lib/sync/backfill/index.d.ts.map +0 -1
- package/lib/sync/backfill/verify.d.ts.map +0 -1
- package/lib/sync/constants.d.ts.map +0 -1
- package/lib/sync/index.d.ts.map +0 -1
- package/lib/sync/interface.d.ts.map +0 -1
- package/lib/sync/options.d.ts.map +0 -1
- package/lib/sync/range/batch.d.ts.map +0 -1
- package/lib/sync/range/chain.d.ts.map +0 -1
- package/lib/sync/range/range.d.ts.map +0 -1
- package/lib/sync/range/utils/batches.d.ts.map +0 -1
- package/lib/sync/range/utils/chainTarget.d.ts.map +0 -1
- package/lib/sync/range/utils/hashBlocks.d.ts.map +0 -1
- package/lib/sync/range/utils/index.d.ts.map +0 -1
- package/lib/sync/range/utils/peerBalancer.d.ts.map +0 -1
- package/lib/sync/range/utils/updateChains.d.ts.map +0 -1
- package/lib/sync/sync.d.ts.map +0 -1
- package/lib/sync/types.d.ts.map +0 -1
- package/lib/sync/unknownBlock.d.ts.map +0 -1
- package/lib/sync/utils/downloadByRange.d.ts.map +0 -1
- package/lib/sync/utils/downloadByRoot.d.ts.map +0 -1
- package/lib/sync/utils/pendingBlocksTree.d.ts.map +0 -1
- package/lib/sync/utils/remoteSyncType.d.ts.map +0 -1
- package/lib/util/address.d.ts.map +0 -1
- package/lib/util/array.d.ts.map +0 -1
- package/lib/util/asyncIterableToEvents.d.ts.map +0 -1
- package/lib/util/binarySearch.d.ts.map +0 -1
- package/lib/util/bitArray.d.ts.map +0 -1
- package/lib/util/blobs.d.ts.map +0 -1
- package/lib/util/bufferPool.d.ts.map +0 -1
- package/lib/util/bytes.d.ts.map +0 -1
- package/lib/util/chunkify.d.ts.map +0 -1
- package/lib/util/clock.d.ts.map +0 -1
- package/lib/util/dataColumns.d.ts.map +0 -1
- package/lib/util/dependentRoot.d.ts.map +0 -1
- package/lib/util/enum.d.ts.map +0 -1
- package/lib/util/error.d.ts.map +0 -1
- package/lib/util/eventLoop.d.ts.map +0 -1
- package/lib/util/execution.d.ts.map +0 -1
- package/lib/util/file.d.ts.map +0 -1
- package/lib/util/forkChoice.d.ts.map +0 -1
- package/lib/util/forkName.d.ts.map +0 -1
- package/lib/util/graffiti.d.ts.map +0 -1
- package/lib/util/hex.d.ts.map +0 -1
- package/lib/util/index.d.ts.map +0 -1
- package/lib/util/ip.d.ts.map +0 -1
- package/lib/util/itTrigger.d.ts.map +0 -1
- package/lib/util/kzg.d.ts.map +0 -1
- package/lib/util/map.d.ts.map +0 -1
- package/lib/util/metadata.d.ts.map +0 -1
- package/lib/util/multifork.d.ts.map +0 -1
- package/lib/util/numpy.d.ts.map +0 -1
- package/lib/util/peerId.d.ts.map +0 -1
- package/lib/util/profile.d.ts.map +0 -1
- package/lib/util/promises.d.ts.map +0 -1
- package/lib/util/queue/errors.d.ts.map +0 -1
- package/lib/util/queue/fnQueue.d.ts.map +0 -1
- package/lib/util/queue/index.d.ts.map +0 -1
- package/lib/util/queue/itemQueue.d.ts.map +0 -1
- package/lib/util/queue/options.d.ts.map +0 -1
- package/lib/util/serializedCache.d.ts.map +0 -1
- package/lib/util/set.d.ts.map +0 -1
- package/lib/util/shuffle.d.ts.map +0 -1
- package/lib/util/sortBy.d.ts.map +0 -1
- package/lib/util/sszBytes.d.ts.map +0 -1
- package/lib/util/strictEvents.d.ts.map +0 -1
- package/lib/util/time.d.ts.map +0 -1
- package/lib/util/timeSeries.d.ts.map +0 -1
- package/lib/util/types.d.ts.map +0 -1
- package/lib/util/workerEvents.d.ts.map +0 -1
- package/lib/util/wrapError.d.ts.map +0 -1
- package/src/api/impl/api.ts +0 -26
- package/src/api/impl/beacon/blocks/index.ts +0 -744
- package/src/api/impl/beacon/blocks/utils.ts +0 -75
- package/src/api/impl/beacon/index.ts +0 -35
- package/src/api/impl/beacon/pool/index.ts +0 -314
- package/src/api/impl/beacon/rewards/index.ts +0 -30
- package/src/api/impl/beacon/state/index.ts +0 -406
- package/src/api/impl/beacon/state/utils.ts +0 -189
- package/src/api/impl/config/constants.ts +0 -127
- package/src/api/impl/config/index.ts +0 -59
- package/src/api/impl/debug/index.ts +0 -131
- package/src/api/impl/errors.ts +0 -50
- package/src/api/impl/events/index.ts +0 -33
- package/src/api/impl/index.ts +0 -6
- package/src/api/impl/lightclient/index.ts +0 -64
- package/src/api/impl/lodestar/index.ts +0 -257
- package/src/api/impl/node/index.ts +0 -88
- package/src/api/impl/node/utils.ts +0 -51
- package/src/api/impl/proof/index.ts +0 -60
- package/src/api/impl/types.ts +0 -17
- package/src/api/impl/utils.ts +0 -25
- package/src/api/impl/validator/index.ts +0 -1540
- package/src/api/impl/validator/utils.ts +0 -85
- package/src/api/index.ts +0 -2
- package/src/api/options.ts +0 -16
- package/src/api/rest/activeSockets.ts +0 -109
- package/src/api/rest/base.ts +0 -216
- package/src/api/rest/index.ts +0 -63
- package/src/api/rest/swaggerUI.ts +0 -80
- package/src/bun-wrappers/prometheus-gc-stats.ts +0 -7
- package/src/chain/ColumnReconstructionTracker.ts +0 -90
- package/src/chain/GetBlobsTracker.ts +0 -115
- package/src/chain/archiveStore/archiveStore.ts +0 -222
- package/src/chain/archiveStore/constants.ts +0 -5
- package/src/chain/archiveStore/historicalState/getHistoricalState.ts +0 -116
- package/src/chain/archiveStore/historicalState/historicalStateRegen.ts +0 -68
- package/src/chain/archiveStore/historicalState/metrics.ts +0 -214
- package/src/chain/archiveStore/historicalState/types.ts +0 -41
- package/src/chain/archiveStore/historicalState/worker.ts +0 -77
- package/src/chain/archiveStore/index.ts +0 -3
- package/src/chain/archiveStore/interface.ts +0 -75
- package/src/chain/archiveStore/strategies/frequencyStateArchiveStrategy.ts +0 -138
- package/src/chain/archiveStore/utils/archiveBlocks.ts +0 -437
- package/src/chain/archiveStore/utils/pruneHistory.ts +0 -56
- package/src/chain/archiveStore/utils/updateBackfillRange.ts +0 -50
- package/src/chain/balancesCache.ts +0 -52
- package/src/chain/beaconProposerCache.ts +0 -43
- package/src/chain/blocks/blockInput/blockInput.ts +0 -852
- package/src/chain/blocks/blockInput/errors.ts +0 -48
- package/src/chain/blocks/blockInput/index.ts +0 -4
- package/src/chain/blocks/blockInput/types.ts +0 -145
- package/src/chain/blocks/blockInput/utils.ts +0 -21
- package/src/chain/blocks/importBlock.ts +0 -597
- package/src/chain/blocks/index.ts +0 -179
- package/src/chain/blocks/types.ts +0 -101
- package/src/chain/blocks/utils/blowfishBanner.ts +0 -28
- package/src/chain/blocks/utils/chainSegment.ts +0 -29
- package/src/chain/blocks/utils/checkpoint.ts +0 -25
- package/src/chain/blocks/utils/giraffeBanner.ts +0 -30
- package/src/chain/blocks/utils/ownBanner.ts +0 -20
- package/src/chain/blocks/utils/pandaMergeTransitionBanner.ts +0 -43
- package/src/chain/blocks/utils/zebraBanner.ts +0 -45
- package/src/chain/blocks/verifyBlock.ts +0 -242
- package/src/chain/blocks/verifyBlocksDataAvailability.ts +0 -42
- package/src/chain/blocks/verifyBlocksExecutionPayloads.ts +0 -438
- package/src/chain/blocks/verifyBlocksSanityChecks.ts +0 -129
- package/src/chain/blocks/verifyBlocksSignatures.ts +0 -105
- package/src/chain/blocks/verifyBlocksStateTransitionOnly.ts +0 -114
- package/src/chain/blocks/writeBlockInputToDb.ts +0 -120
- package/src/chain/bls/index.ts +0 -4
- package/src/chain/bls/interface.ts +0 -68
- package/src/chain/bls/maybeBatch.ts +0 -45
- package/src/chain/bls/multithread/index.ts +0 -582
- package/src/chain/bls/multithread/jobItem.ts +0 -119
- package/src/chain/bls/multithread/poolSize.ts +0 -16
- package/src/chain/bls/multithread/types.ts +0 -38
- package/src/chain/bls/multithread/utils.ts +0 -19
- package/src/chain/bls/multithread/worker.ts +0 -114
- package/src/chain/bls/singleThread.ts +0 -87
- package/src/chain/bls/utils.ts +0 -30
- package/src/chain/chain.ts +0 -1354
- package/src/chain/emitter.ts +0 -113
- package/src/chain/errors/attestationError.ts +0 -194
- package/src/chain/errors/attesterSlashingError.ts +0 -11
- package/src/chain/errors/blobSidecarError.ts +0 -60
- package/src/chain/errors/blockError.ts +0 -166
- package/src/chain/errors/blsToExecutionChangeError.ts +0 -13
- package/src/chain/errors/dataColumnSidecarError.ts +0 -80
- package/src/chain/errors/gossipValidation.ts +0 -20
- package/src/chain/errors/index.ts +0 -10
- package/src/chain/errors/lightClientError.ts +0 -30
- package/src/chain/errors/proposerSlashingError.ts +0 -11
- package/src/chain/errors/syncCommitteeError.ts +0 -36
- package/src/chain/errors/voluntaryExitError.ts +0 -13
- package/src/chain/forkChoice/index.ts +0 -112
- package/src/chain/genesis/genesis.ts +0 -190
- package/src/chain/genesis/interface.ts +0 -14
- package/src/chain/index.ts +0 -6
- package/src/chain/initState.ts +0 -221
- package/src/chain/interface.ts +0 -280
- package/src/chain/lightClient/index.ts +0 -764
- package/src/chain/lightClient/proofs.ts +0 -85
- package/src/chain/lightClient/types.ts +0 -33
- package/src/chain/opPools/aggregatedAttestationPool.ts +0 -1063
- package/src/chain/opPools/attestationPool.ts +0 -282
- package/src/chain/opPools/index.ts +0 -5
- package/src/chain/opPools/opPool.ts +0 -462
- package/src/chain/opPools/syncCommitteeMessagePool.ts +0 -169
- package/src/chain/opPools/syncContributionAndProofPool.ts +0 -240
- package/src/chain/opPools/types.ts +0 -35
- package/src/chain/opPools/utils.ts +0 -65
- package/src/chain/options.ts +0 -138
- package/src/chain/prepareNextSlot.ts +0 -277
- package/src/chain/produceBlock/computeNewStateRoot.ts +0 -55
- package/src/chain/produceBlock/index.ts +0 -2
- package/src/chain/produceBlock/produceBlockBody.ts +0 -797
- package/src/chain/produceBlock/validateBlobsAndKzgCommitments.ts +0 -54
- package/src/chain/regen/errors.ts +0 -30
- package/src/chain/regen/index.ts +0 -4
- package/src/chain/regen/interface.ts +0 -93
- package/src/chain/regen/queued.ts +0 -317
- package/src/chain/regen/regen.ts +0 -424
- package/src/chain/reprocess.ts +0 -161
- package/src/chain/rewards/attestationsRewards.ts +0 -196
- package/src/chain/rewards/blockRewards.ts +0 -150
- package/src/chain/rewards/syncCommitteeRewards.ts +0 -58
- package/src/chain/seenCache/index.ts +0 -5
- package/src/chain/seenCache/seenAggregateAndProof.ts +0 -120
- package/src/chain/seenCache/seenAttestationData.ts +0 -145
- package/src/chain/seenCache/seenAttesters.ts +0 -58
- package/src/chain/seenCache/seenBlockAttesters.ts +0 -18
- package/src/chain/seenCache/seenBlockProposers.ts +0 -48
- package/src/chain/seenCache/seenCommittee.ts +0 -43
- package/src/chain/seenCache/seenCommitteeContribution.ts +0 -104
- package/src/chain/seenCache/seenGossipBlockInput.ts +0 -373
- package/src/chain/serializeState.ts +0 -32
- package/src/chain/shufflingCache.ts +0 -238
- package/src/chain/stateCache/blockStateCacheImpl.ts +0 -150
- package/src/chain/stateCache/datastore/db.ts +0 -36
- package/src/chain/stateCache/datastore/file.ts +0 -53
- package/src/chain/stateCache/datastore/index.ts +0 -2
- package/src/chain/stateCache/datastore/types.ts +0 -13
- package/src/chain/stateCache/fifoBlockStateCache.ts +0 -208
- package/src/chain/stateCache/inMemoryCheckpointsCache.ts +0 -198
- package/src/chain/stateCache/index.ts +0 -3
- package/src/chain/stateCache/mapMetrics.ts +0 -52
- package/src/chain/stateCache/persistentCheckpointsCache.ts +0 -837
- package/src/chain/stateCache/types.ts +0 -86
- package/src/chain/validation/aggregateAndProof.ts +0 -258
- package/src/chain/validation/attestation.ts +0 -885
- package/src/chain/validation/attesterSlashing.ts +0 -61
- package/src/chain/validation/blobSidecar.ts +0 -301
- package/src/chain/validation/block.ts +0 -188
- package/src/chain/validation/blsToExecutionChange.ts +0 -61
- package/src/chain/validation/dataColumnSidecar.ts +0 -381
- package/src/chain/validation/index.ts +0 -9
- package/src/chain/validation/lightClientFinalityUpdate.ts +0 -46
- package/src/chain/validation/lightClientOptimisticUpdate.ts +0 -68
- package/src/chain/validation/proposerSlashing.ts +0 -54
- package/src/chain/validation/signatureSets/aggregateAndProof.ts +0 -38
- package/src/chain/validation/signatureSets/contributionAndProof.ts +0 -27
- package/src/chain/validation/signatureSets/index.ts +0 -6
- package/src/chain/validation/signatureSets/selectionProof.ts +0 -27
- package/src/chain/validation/signatureSets/syncCommittee.ts +0 -22
- package/src/chain/validation/signatureSets/syncCommitteeContribution.ts +0 -18
- package/src/chain/validation/signatureSets/syncCommitteeSelectionProof.ts +0 -27
- package/src/chain/validation/syncCommittee.ts +0 -165
- package/src/chain/validation/syncCommitteeContributionAndProof.ts +0 -122
- package/src/chain/validation/voluntaryExit.ts +0 -58
- package/src/chain/validatorMonitor.ts +0 -1309
- package/src/constants/constants.ts +0 -15
- package/src/constants/index.ts +0 -2
- package/src/constants/network.ts +0 -52
- package/src/db/beacon.ts +0 -113
- package/src/db/buckets.ts +0 -80
- package/src/db/index.ts +0 -2
- package/src/db/interface.ts +0 -76
- package/src/db/options.ts +0 -7
- package/src/db/repositories/attesterSlashing.ts +0 -38
- package/src/db/repositories/backfilledRanges.ts +0 -29
- package/src/db/repositories/blobSidecars.ts +0 -37
- package/src/db/repositories/blobSidecarsArchive.ts +0 -28
- package/src/db/repositories/block.ts +0 -33
- package/src/db/repositories/blockArchive.ts +0 -170
- package/src/db/repositories/blockArchiveIndex.ts +0 -45
- package/src/db/repositories/blsToExecutionChange.ts +0 -16
- package/src/db/repositories/checkpointState.ts +0 -31
- package/src/db/repositories/dataColumnSidecar.ts +0 -49
- package/src/db/repositories/dataColumnSidecarArchive.ts +0 -56
- package/src/db/repositories/depositDataRoot.ts +0 -80
- package/src/db/repositories/depositEvent.ts +0 -32
- package/src/db/repositories/eth1Data.ts +0 -33
- package/src/db/repositories/index.ts +0 -20
- package/src/db/repositories/lightclientBestUpdate.ts +0 -41
- package/src/db/repositories/lightclientCheckpointHeader.ts +0 -32
- package/src/db/repositories/lightclientSyncCommittee.ts +0 -16
- package/src/db/repositories/lightclientSyncCommitteeWitness.ts +0 -77
- package/src/db/repositories/proposerSlashing.ts +0 -15
- package/src/db/repositories/stateArchive.ts +0 -69
- package/src/db/repositories/stateArchiveIndex.ts +0 -18
- package/src/db/repositories/voluntaryExit.ts +0 -15
- package/src/db/single/index.ts +0 -2
- package/src/db/single/preGenesisState.ts +0 -37
- package/src/db/single/preGenesisStateLastProcessedBlock.ts +0 -34
- package/src/eth1/errors.ts +0 -40
- package/src/eth1/eth1DataCache.ts +0 -26
- package/src/eth1/eth1DepositDataTracker.ts +0 -410
- package/src/eth1/eth1DepositsCache.ts +0 -141
- package/src/eth1/eth1MergeBlockTracker.ts +0 -328
- package/src/eth1/index.ts +0 -157
- package/src/eth1/interface.ts +0 -131
- package/src/eth1/options.ts +0 -28
- package/src/eth1/provider/eth1Provider.ts +0 -229
- package/src/eth1/provider/jsonRpcHttpClient.ts +0 -390
- package/src/eth1/provider/jwt.ts +0 -36
- package/src/eth1/provider/utils.ts +0 -136
- package/src/eth1/stream.ts +0 -75
- package/src/eth1/utils/depositContract.ts +0 -37
- package/src/eth1/utils/deposits.ts +0 -70
- package/src/eth1/utils/eth1Data.ts +0 -100
- package/src/eth1/utils/eth1DepositEvent.ts +0 -12
- package/src/eth1/utils/eth1Vote.ts +0 -142
- package/src/eth1/utils/groupDepositEventsByBlock.ts +0 -19
- package/src/eth1/utils/optimizeNextBlockDiffForGenesis.ts +0 -18
- package/src/execution/builder/cache.ts +0 -39
- package/src/execution/builder/http.ts +0 -229
- package/src/execution/builder/index.ts +0 -27
- package/src/execution/builder/interface.ts +0 -49
- package/src/execution/builder/utils.ts +0 -19
- package/src/execution/engine/disabled.ts +0 -35
- package/src/execution/engine/http.ts +0 -644
- package/src/execution/engine/index.ts +0 -63
- package/src/execution/engine/interface.ts +0 -199
- package/src/execution/engine/mock.ts +0 -493
- package/src/execution/engine/payloadIdCache.ts +0 -54
- package/src/execution/engine/types.ts +0 -640
- package/src/execution/engine/utils.ts +0 -136
- package/src/execution/index.ts +0 -4
- package/src/index.ts +0 -20
- package/src/metrics/index.ts +0 -4
- package/src/metrics/metrics/beacon.ts +0 -390
- package/src/metrics/metrics/lodestar.ts +0 -1870
- package/src/metrics/metrics.ts +0 -43
- package/src/metrics/nodeJsMetrics.ts +0 -19
- package/src/metrics/options.ts +0 -22
- package/src/metrics/server/http.ts +0 -114
- package/src/metrics/server/index.ts +0 -1
- package/src/metrics/utils/avgMinMax.ts +0 -87
- package/src/metrics/utils/gauge.ts +0 -22
- package/src/metrics/utils/registryMetricCreator.ts +0 -41
- package/src/monitoring/clientStats.ts +0 -297
- package/src/monitoring/index.ts +0 -2
- package/src/monitoring/options.ts +0 -19
- package/src/monitoring/properties.ts +0 -152
- package/src/monitoring/service.ts +0 -235
- package/src/monitoring/system.ts +0 -146
- package/src/monitoring/types.ts +0 -21
- package/src/network/core/events.ts +0 -59
- package/src/network/core/index.ts +0 -3
- package/src/network/core/metrics.ts +0 -304
- package/src/network/core/networkCore.ts +0 -599
- package/src/network/core/networkCoreWorker.ts +0 -176
- package/src/network/core/networkCoreWorkerHandler.ts +0 -284
- package/src/network/core/types.ts +0 -119
- package/src/network/discv5/index.ts +0 -132
- package/src/network/discv5/types.ts +0 -74
- package/src/network/discv5/utils.ts +0 -50
- package/src/network/discv5/worker.ts +0 -137
- package/src/network/events.ts +0 -51
- package/src/network/forks.ts +0 -94
- package/src/network/gossip/constants.ts +0 -15
- package/src/network/gossip/encoding.ts +0 -111
- package/src/network/gossip/errors.ts +0 -7
- package/src/network/gossip/gossipsub.ts +0 -384
- package/src/network/gossip/index.ts +0 -4
- package/src/network/gossip/interface.ts +0 -215
- package/src/network/gossip/metrics.ts +0 -71
- package/src/network/gossip/scoringParameters.ts +0 -333
- package/src/network/gossip/topic.ts +0 -332
- package/src/network/index.ts +0 -8
- package/src/network/interface.ts +0 -134
- package/src/network/libp2p/error.ts +0 -55
- package/src/network/libp2p/index.ts +0 -153
- package/src/network/metadata.ts +0 -162
- package/src/network/network.ts +0 -767
- package/src/network/networkConfig.ts +0 -12
- package/src/network/options.ts +0 -70
- package/src/network/peers/client.ts +0 -29
- package/src/network/peers/datastore.ts +0 -188
- package/src/network/peers/discover.ts +0 -647
- package/src/network/peers/index.ts +0 -2
- package/src/network/peers/peerManager.ts +0 -899
- package/src/network/peers/peersData.ts +0 -65
- package/src/network/peers/score/constants.ts +0 -34
- package/src/network/peers/score/index.ts +0 -4
- package/src/network/peers/score/interface.ts +0 -74
- package/src/network/peers/score/score.ts +0 -200
- package/src/network/peers/score/store.ts +0 -95
- package/src/network/peers/score/utils.ts +0 -37
- package/src/network/peers/utils/assertPeerRelevance.ts +0 -99
- package/src/network/peers/utils/enrSubnetsDeserialize.ts +0 -27
- package/src/network/peers/utils/getConnectedPeerIds.ts +0 -33
- package/src/network/peers/utils/index.ts +0 -4
- package/src/network/peers/utils/prioritizePeers.ts +0 -627
- package/src/network/peers/utils/subnetMap.ts +0 -88
- package/src/network/processor/aggregatorTracker.ts +0 -38
- package/src/network/processor/extractSlotRootFns.ts +0 -64
- package/src/network/processor/gossipHandlers.ts +0 -951
- package/src/network/processor/gossipQueues/index.ts +0 -114
- package/src/network/processor/gossipQueues/indexed.ts +0 -219
- package/src/network/processor/gossipQueues/linear.ts +0 -162
- package/src/network/processor/gossipQueues/types.ts +0 -57
- package/src/network/processor/gossipValidatorFn.ts +0 -142
- package/src/network/processor/index.ts +0 -496
- package/src/network/processor/types.ts +0 -27
- package/src/network/reqresp/ReqRespBeaconNode.ts +0 -373
- package/src/network/reqresp/handlers/beaconBlocksByRange.ts +0 -101
- package/src/network/reqresp/handlers/beaconBlocksByRoot.ts +0 -49
- package/src/network/reqresp/handlers/blobSidecarsByRange.ts +0 -114
- package/src/network/reqresp/handlers/blobSidecarsByRoot.ts +0 -62
- package/src/network/reqresp/handlers/dataColumnSidecarsByRange.ts +0 -144
- package/src/network/reqresp/handlers/dataColumnSidecarsByRoot.ts +0 -88
- package/src/network/reqresp/handlers/index.ts +0 -78
- package/src/network/reqresp/handlers/lightClientBootstrap.ts +0 -31
- package/src/network/reqresp/handlers/lightClientFinalityUpdate.ts +0 -21
- package/src/network/reqresp/handlers/lightClientOptimisticUpdate.ts +0 -21
- package/src/network/reqresp/handlers/lightClientUpdatesByRange.ts +0 -39
- package/src/network/reqresp/index.ts +0 -2
- package/src/network/reqresp/interface.ts +0 -45
- package/src/network/reqresp/protocols.ts +0 -146
- package/src/network/reqresp/rateLimit.ts +0 -112
- package/src/network/reqresp/score.ts +0 -70
- package/src/network/reqresp/types.ts +0 -174
- package/src/network/reqresp/utils/collect.ts +0 -84
- package/src/network/reqresp/utils/collectSequentialBlocksInRange.ts +0 -57
- package/src/network/reqresp/utils/dataColumnResponseValidation.ts +0 -99
- package/src/network/statusCache.ts +0 -17
- package/src/network/subnets/attnetsService.ts +0 -385
- package/src/network/subnets/index.ts +0 -2
- package/src/network/subnets/interface.ts +0 -66
- package/src/network/subnets/syncnetsService.ts +0 -147
- package/src/network/subnets/util.ts +0 -63
- package/src/network/util.ts +0 -29
- package/src/node/index.ts +0 -2
- package/src/node/nodejs.ts +0 -349
- package/src/node/notifier.ts +0 -206
- package/src/node/options.ts +0 -51
- package/src/node/utils/interop/deposits.ts +0 -53
- package/src/node/utils/interop/state.ts +0 -59
- package/src/node/utils/lightclient.ts +0 -7
- package/src/node/utils/state.ts +0 -37
- package/src/sync/backfill/backfill.ts +0 -893
- package/src/sync/backfill/errors.ts +0 -23
- package/src/sync/backfill/index.ts +0 -1
- package/src/sync/backfill/verify.ts +0 -58
- package/src/sync/constants.ts +0 -71
- package/src/sync/index.ts +0 -2
- package/src/sync/interface.ts +0 -55
- package/src/sync/options.ts +0 -45
- package/src/sync/range/batch.ts +0 -455
- package/src/sync/range/chain.ts +0 -715
- package/src/sync/range/range.ts +0 -354
- package/src/sync/range/utils/batches.ts +0 -119
- package/src/sync/range/utils/chainTarget.ts +0 -62
- package/src/sync/range/utils/hashBlocks.ts +0 -27
- package/src/sync/range/utils/index.ts +0 -5
- package/src/sync/range/utils/peerBalancer.ts +0 -184
- package/src/sync/range/utils/updateChains.ts +0 -66
- package/src/sync/sync.ts +0 -290
- package/src/sync/types.ts +0 -57
- package/src/sync/unknownBlock.ts +0 -859
- package/src/sync/utils/downloadByRange.ts +0 -808
- package/src/sync/utils/downloadByRoot.ts +0 -560
- package/src/sync/utils/pendingBlocksTree.ts +0 -97
- package/src/sync/utils/remoteSyncType.ts +0 -144
- package/src/util/address.ts +0 -3
- package/src/util/array.ts +0 -311
- package/src/util/asyncIterableToEvents.ts +0 -164
- package/src/util/binarySearch.ts +0 -48
- package/src/util/bitArray.ts +0 -84
- package/src/util/blobs.ts +0 -210
- package/src/util/bufferPool.ts +0 -95
- package/src/util/bytes.ts +0 -11
- package/src/util/chunkify.ts +0 -27
- package/src/util/clock.ts +0 -212
- package/src/util/dataColumns.ts +0 -415
- package/src/util/dependentRoot.ts +0 -47
- package/src/util/enum.ts +0 -17
- package/src/util/error.ts +0 -56
- package/src/util/eventLoop.ts +0 -22
- package/src/util/execution.ts +0 -223
- package/src/util/file.ts +0 -52
- package/src/util/forkChoice.ts +0 -5
- package/src/util/forkName.ts +0 -20
- package/src/util/graffiti.ts +0 -39
- package/src/util/hex.ts +0 -9
- package/src/util/index.ts +0 -2
- package/src/util/ip.ts +0 -6
- package/src/util/itTrigger.ts +0 -49
- package/src/util/kzg.ts +0 -3
- package/src/util/map.ts +0 -77
- package/src/util/metadata.ts +0 -22
- package/src/util/multifork.ts +0 -69
- package/src/util/numpy.ts +0 -8
- package/src/util/peerId.ts +0 -16
- package/src/util/profile.ts +0 -54
- package/src/util/promises.ts +0 -14
- package/src/util/queue/errors.ts +0 -14
- package/src/util/queue/fnQueue.ts +0 -16
- package/src/util/queue/index.ts +0 -4
- package/src/util/queue/itemQueue.ts +0 -128
- package/src/util/queue/options.ts +0 -37
- package/src/util/serializedCache.ts +0 -20
- package/src/util/set.ts +0 -62
- package/src/util/shuffle.ts +0 -21
- package/src/util/sortBy.ts +0 -19
- package/src/util/sszBytes.ts +0 -481
- package/src/util/strictEvents.ts +0 -8
- package/src/util/time.ts +0 -13
- package/src/util/timeSeries.ts +0 -118
- package/src/util/types.ts +0 -31
- package/src/util/workerEvents.ts +0 -142
- package/src/util/wrapError.ts +0 -27
|
@@ -1,438 +0,0 @@
|
|
|
1
|
-
import {ChainForkConfig} from "@lodestar/config";
|
|
2
|
-
import {
|
|
3
|
-
ExecutionStatus,
|
|
4
|
-
IForkChoice,
|
|
5
|
-
LVHInvalidResponse,
|
|
6
|
-
LVHValidResponse,
|
|
7
|
-
MaybeValidExecutionStatus,
|
|
8
|
-
ProtoBlock,
|
|
9
|
-
assertValidTerminalPowBlock,
|
|
10
|
-
} from "@lodestar/fork-choice";
|
|
11
|
-
import {ForkSeq, SAFE_SLOTS_TO_IMPORT_OPTIMISTICALLY} from "@lodestar/params";
|
|
12
|
-
import {
|
|
13
|
-
CachedBeaconStateAllForks,
|
|
14
|
-
isExecutionBlockBodyType,
|
|
15
|
-
isExecutionEnabled,
|
|
16
|
-
isExecutionStateType,
|
|
17
|
-
isMergeTransitionBlock as isMergeTransitionBlockFn,
|
|
18
|
-
} from "@lodestar/state-transition";
|
|
19
|
-
import {Slot, bellatrix, electra} from "@lodestar/types";
|
|
20
|
-
import {ErrorAborted, Logger, toRootHex} from "@lodestar/utils";
|
|
21
|
-
import {IEth1ForBlockProduction} from "../../eth1/index.js";
|
|
22
|
-
import {ExecutionPayloadStatus, IExecutionEngine} from "../../execution/engine/interface.js";
|
|
23
|
-
import {Metrics} from "../../metrics/metrics.js";
|
|
24
|
-
import {IClock} from "../../util/clock.js";
|
|
25
|
-
import {BlockError, BlockErrorCode} from "../errors/index.js";
|
|
26
|
-
import {BlockProcessOpts} from "../options.js";
|
|
27
|
-
import {isBlockInputBlobs, isBlockInputColumns} from "./blockInput/blockInput.js";
|
|
28
|
-
import {IBlockInput} from "./blockInput/types.js";
|
|
29
|
-
import {ImportBlockOpts} from "./types.js";
|
|
30
|
-
|
|
31
|
-
export type VerifyBlockExecutionPayloadModules = {
|
|
32
|
-
eth1: IEth1ForBlockProduction;
|
|
33
|
-
executionEngine: IExecutionEngine;
|
|
34
|
-
clock: IClock;
|
|
35
|
-
logger: Logger;
|
|
36
|
-
metrics: Metrics | null;
|
|
37
|
-
forkChoice: IForkChoice;
|
|
38
|
-
config: ChainForkConfig;
|
|
39
|
-
};
|
|
40
|
-
|
|
41
|
-
type ExecAbortType = {blockIndex: number; execError: BlockError};
|
|
42
|
-
export type SegmentExecStatus =
|
|
43
|
-
| {
|
|
44
|
-
execAborted: null;
|
|
45
|
-
executionStatuses: MaybeValidExecutionStatus[];
|
|
46
|
-
executionTime: number;
|
|
47
|
-
mergeBlockFound: bellatrix.BeaconBlock | null;
|
|
48
|
-
}
|
|
49
|
-
| {execAborted: ExecAbortType; invalidSegmentLVH?: LVHInvalidResponse; mergeBlockFound: null};
|
|
50
|
-
|
|
51
|
-
type VerifyExecutionErrorResponse =
|
|
52
|
-
| {executionStatus: ExecutionStatus.Invalid; lvhResponse: LVHInvalidResponse; execError: BlockError}
|
|
53
|
-
| {executionStatus: null; lvhResponse: undefined; execError: BlockError};
|
|
54
|
-
|
|
55
|
-
type VerifyBlockExecutionResponse =
|
|
56
|
-
| VerifyExecutionErrorResponse
|
|
57
|
-
| {executionStatus: ExecutionStatus.Valid; lvhResponse: LVHValidResponse; execError: null}
|
|
58
|
-
| {executionStatus: ExecutionStatus.Syncing; lvhResponse?: LVHValidResponse; execError: null}
|
|
59
|
-
| {executionStatus: ExecutionStatus.PreMerge; lvhResponse: undefined; execError: null};
|
|
60
|
-
|
|
61
|
-
/**
|
|
62
|
-
* Verifies 1 or more execution payloads from a linear sequence of blocks.
|
|
63
|
-
*
|
|
64
|
-
* Since the EL client must be aware of each parent, all payloads must be submitted in sequence.
|
|
65
|
-
*/
|
|
66
|
-
export async function verifyBlocksExecutionPayload(
|
|
67
|
-
chain: VerifyBlockExecutionPayloadModules,
|
|
68
|
-
parentBlock: ProtoBlock,
|
|
69
|
-
blockInputs: IBlockInput[],
|
|
70
|
-
preState0: CachedBeaconStateAllForks,
|
|
71
|
-
signal: AbortSignal,
|
|
72
|
-
opts: BlockProcessOpts & ImportBlockOpts
|
|
73
|
-
): Promise<SegmentExecStatus> {
|
|
74
|
-
const executionStatuses: MaybeValidExecutionStatus[] = [];
|
|
75
|
-
let mergeBlockFound: bellatrix.BeaconBlock | null = null;
|
|
76
|
-
const recvToValLatency = Date.now() / 1000 - (opts.seenTimestampSec ?? Date.now() / 1000);
|
|
77
|
-
const lastBlock = blockInputs.at(-1);
|
|
78
|
-
|
|
79
|
-
// Error in the same way as verifyBlocksSanityChecks if empty blocks
|
|
80
|
-
if (!lastBlock) {
|
|
81
|
-
throw Error("Empty partiallyVerifiedBlocks");
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
// For a block with SYNCING status (called optimistic block), it's okay to import with
|
|
85
|
-
// SYNCING status as EL could switch into syncing
|
|
86
|
-
//
|
|
87
|
-
// 1. On initial startup/restart
|
|
88
|
-
// 2. When some reorg might have occurred and EL doesn't has a parent root
|
|
89
|
-
// (observed on devnets)
|
|
90
|
-
// 3. Because of some unavailable (and potentially invalid) root but there is no way
|
|
91
|
-
// of knowing if this is invalid/unavailable. For unavailable block, some proposer
|
|
92
|
-
// will (sooner or later) build on the available parent head which will
|
|
93
|
-
// eventually win in fork-choice as other validators vote on VALID blocks.
|
|
94
|
-
//
|
|
95
|
-
// Once EL catches up again and respond VALID, the fork choice will be updated which
|
|
96
|
-
// will either validate or prune invalid blocks
|
|
97
|
-
//
|
|
98
|
-
// We need to track and keep updating if its safe to optimistically import these blocks.
|
|
99
|
-
// The following is how we determine for a block if its safe:
|
|
100
|
-
//
|
|
101
|
-
// (but we need to modify this check for this segment of blocks because it checks if the
|
|
102
|
-
// parent of any block imported in forkchoice is post-merge and currently we could only
|
|
103
|
-
// have blocks[0]'s parent imported in the chain as this is no longer one by one verify +
|
|
104
|
-
// import.)
|
|
105
|
-
//
|
|
106
|
-
//
|
|
107
|
-
// When to import such blocks:
|
|
108
|
-
// From: https://github.com/ethereum/consensus-specs/pull/2844
|
|
109
|
-
// A block MUST NOT be optimistically imported, unless either of the following
|
|
110
|
-
// conditions are met:
|
|
111
|
-
//
|
|
112
|
-
// 1. Parent of the block has execution
|
|
113
|
-
//
|
|
114
|
-
// Since with the sync optimizations, the previous block might not have been in the
|
|
115
|
-
// forkChoice yet, so the below check could fail for safeSlotsToImportOptimistically
|
|
116
|
-
//
|
|
117
|
-
// Luckily, we can depend on the preState0 to see if we are already post merge w.r.t
|
|
118
|
-
// the blocks we are importing.
|
|
119
|
-
//
|
|
120
|
-
// Or in other words if
|
|
121
|
-
// - block status is syncing
|
|
122
|
-
// - and we are not in a post merge world and is parent is not optimistically safe
|
|
123
|
-
// - and we are syncing close to the chain head i.e. clock slot
|
|
124
|
-
// - and parent is optimistically safe
|
|
125
|
-
//
|
|
126
|
-
// then throw error
|
|
127
|
-
//
|
|
128
|
-
//
|
|
129
|
-
// - if we haven't yet imported a post merge ancestor in forkchoice i.e.
|
|
130
|
-
// - and we are syncing close to the clockSlot, i.e. merge Transition could be underway
|
|
131
|
-
//
|
|
132
|
-
//
|
|
133
|
-
// 2. The current slot (as per the system clock) is at least
|
|
134
|
-
// SAFE_SLOTS_TO_IMPORT_OPTIMISTICALLY ahead of the slot of the block being
|
|
135
|
-
// imported.
|
|
136
|
-
// This means that the merge transition could be underway and we can't afford to import
|
|
137
|
-
// a block which is not fully validated as it could affect liveliness of the network.
|
|
138
|
-
//
|
|
139
|
-
//
|
|
140
|
-
// For this segment of blocks:
|
|
141
|
-
// We are optimistically safe with respect to this entire block segment if:
|
|
142
|
-
// - all the blocks are way behind the current slot
|
|
143
|
-
// - or we have already imported a post-merge parent of first block of this chain in forkchoice
|
|
144
|
-
const currentSlot = chain.clock.currentSlot;
|
|
145
|
-
const safeSlotsToImportOptimistically = opts.safeSlotsToImportOptimistically ?? SAFE_SLOTS_TO_IMPORT_OPTIMISTICALLY;
|
|
146
|
-
let isOptimisticallySafe =
|
|
147
|
-
parentBlock.executionStatus !== ExecutionStatus.PreMerge ||
|
|
148
|
-
lastBlock.slot + safeSlotsToImportOptimistically < currentSlot;
|
|
149
|
-
|
|
150
|
-
for (let blockIndex = 0; blockIndex < blockInputs.length; blockIndex++) {
|
|
151
|
-
const blockInput = blockInputs[blockIndex];
|
|
152
|
-
// If blocks are invalid in consensus the main promise could resolve before this loop ends.
|
|
153
|
-
// In that case stop sending blocks to execution engine
|
|
154
|
-
if (signal.aborted) {
|
|
155
|
-
throw new ErrorAborted("verifyBlockExecutionPayloads");
|
|
156
|
-
}
|
|
157
|
-
const verifyResponse = await verifyBlockExecutionPayload(
|
|
158
|
-
chain,
|
|
159
|
-
blockInput,
|
|
160
|
-
preState0,
|
|
161
|
-
opts,
|
|
162
|
-
isOptimisticallySafe,
|
|
163
|
-
currentSlot
|
|
164
|
-
);
|
|
165
|
-
|
|
166
|
-
// If execError has happened, then we need to extract the segmentExecStatus and return
|
|
167
|
-
if (verifyResponse.execError !== null) {
|
|
168
|
-
return getSegmentErrorResponse({verifyResponse, blockIndex}, parentBlock, blockInputs);
|
|
169
|
-
}
|
|
170
|
-
|
|
171
|
-
// If we are here then its because executionStatus is one of MaybeValidExecutionStatus
|
|
172
|
-
const {executionStatus} = verifyResponse;
|
|
173
|
-
// It becomes optimistically safe for following blocks if a post-merge block is deemed fit
|
|
174
|
-
// for import. If it would not have been safe verifyBlockExecutionPayload would have
|
|
175
|
-
// returned execError and loop would have been aborted
|
|
176
|
-
if (executionStatus !== ExecutionStatus.PreMerge) {
|
|
177
|
-
isOptimisticallySafe = true;
|
|
178
|
-
}
|
|
179
|
-
executionStatuses.push(executionStatus);
|
|
180
|
-
|
|
181
|
-
const blockBody = blockInput.getBlock().message.body;
|
|
182
|
-
const isMergeTransitionBlock =
|
|
183
|
-
// If the merge block is found, stop the search as the isMergeTransitionBlockFn condition
|
|
184
|
-
// will still evaluate to true for the following blocks leading to errors (while syncing)
|
|
185
|
-
// as the preState0 still belongs to the pre state of the first block on segment
|
|
186
|
-
mergeBlockFound === null &&
|
|
187
|
-
isExecutionStateType(preState0) &&
|
|
188
|
-
isExecutionBlockBodyType(blockBody) &&
|
|
189
|
-
isMergeTransitionBlockFn(preState0, blockBody);
|
|
190
|
-
|
|
191
|
-
// If this is a merge transition block, check to ensure if it references
|
|
192
|
-
// a valid terminal PoW block.
|
|
193
|
-
//
|
|
194
|
-
// However specs define this check to be run inside forkChoice's onBlock
|
|
195
|
-
// (https://github.com/ethereum/consensus-specs/blob/dev/specs/bellatrix/fork-choice.md#on_block)
|
|
196
|
-
// but we perform the check here (as inspired from the lighthouse impl)
|
|
197
|
-
//
|
|
198
|
-
// Reasons:
|
|
199
|
-
// 1. If the block is not valid, we should fail early and not wait till
|
|
200
|
-
// forkChoice import.
|
|
201
|
-
// 2. It makes logical sense to pair it with the block validations and
|
|
202
|
-
// deal it with the external services like eth1 tracker here than
|
|
203
|
-
// in import block
|
|
204
|
-
if (isMergeTransitionBlock) {
|
|
205
|
-
const mergeBlock = blockInput.getBlock().message as bellatrix.BeaconBlock;
|
|
206
|
-
const mergeBlockHash = toRootHex(chain.config.getForkTypes(mergeBlock.slot).BeaconBlock.hashTreeRoot(mergeBlock));
|
|
207
|
-
const powBlockRootHex = toRootHex(mergeBlock.body.executionPayload.parentHash);
|
|
208
|
-
const powBlock = await chain.eth1.getPowBlock(powBlockRootHex).catch((error) => {
|
|
209
|
-
// Lets just warn the user here, errors if any will be reported on
|
|
210
|
-
// `assertValidTerminalPowBlock` checks
|
|
211
|
-
chain.logger.warn(
|
|
212
|
-
"Error fetching terminal PoW block referred in the merge transition block",
|
|
213
|
-
{powBlockHash: powBlockRootHex, mergeBlockHash},
|
|
214
|
-
error
|
|
215
|
-
);
|
|
216
|
-
return null;
|
|
217
|
-
});
|
|
218
|
-
|
|
219
|
-
const powBlockParent =
|
|
220
|
-
powBlock &&
|
|
221
|
-
(await chain.eth1.getPowBlock(powBlock.parentHash).catch((error) => {
|
|
222
|
-
// Lets just warn the user here, errors if any will be reported on
|
|
223
|
-
// `assertValidTerminalPowBlock` checks
|
|
224
|
-
chain.logger.warn(
|
|
225
|
-
"Error fetching parent of the terminal PoW block referred in the merge transition block",
|
|
226
|
-
{powBlockParentHash: powBlock.parentHash, powBlock: powBlockRootHex, mergeBlockHash},
|
|
227
|
-
error
|
|
228
|
-
);
|
|
229
|
-
return null;
|
|
230
|
-
}));
|
|
231
|
-
|
|
232
|
-
// executionStatus will never == ExecutionStatus.PreMerge if it's the mergeBlock. But gotta make TS happy =D
|
|
233
|
-
if (executionStatus === ExecutionStatus.PreMerge) {
|
|
234
|
-
throw Error("Merge block must not have executionStatus == PreMerge");
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
assertValidTerminalPowBlock(chain.config, mergeBlock, {executionStatus, powBlock, powBlockParent});
|
|
238
|
-
// Valid execution payload, but may not be in a valid beacon chain block. Delay printing the POS ACTIVATED banner
|
|
239
|
-
// to the end of the verify block routine, which confirms that this block is fully valid.
|
|
240
|
-
mergeBlockFound = mergeBlock;
|
|
241
|
-
}
|
|
242
|
-
}
|
|
243
|
-
|
|
244
|
-
const executionTime = Date.now();
|
|
245
|
-
if (
|
|
246
|
-
blockInputs.length === 1 &&
|
|
247
|
-
opts.seenTimestampSec !== undefined &&
|
|
248
|
-
executionStatuses[0] === ExecutionStatus.Valid
|
|
249
|
-
) {
|
|
250
|
-
const recvToValidation = executionTime / 1000 - opts.seenTimestampSec;
|
|
251
|
-
const validationTime = recvToValidation - recvToValLatency;
|
|
252
|
-
|
|
253
|
-
chain.metrics?.gossipBlock.executionPayload.recvToValidation.observe(recvToValidation);
|
|
254
|
-
chain.metrics?.gossipBlock.executionPayload.validationTime.observe(validationTime);
|
|
255
|
-
|
|
256
|
-
chain.logger.debug("Verified execution payload", {
|
|
257
|
-
slot: blockInputs[0].slot,
|
|
258
|
-
recvToValLatency,
|
|
259
|
-
recvToValidation,
|
|
260
|
-
validationTime,
|
|
261
|
-
});
|
|
262
|
-
}
|
|
263
|
-
|
|
264
|
-
return {
|
|
265
|
-
execAborted: null,
|
|
266
|
-
executionStatuses,
|
|
267
|
-
executionTime,
|
|
268
|
-
mergeBlockFound,
|
|
269
|
-
};
|
|
270
|
-
}
|
|
271
|
-
|
|
272
|
-
/**
|
|
273
|
-
* Verifies a single block execution payload by sending it to the EL client (via HTTP).
|
|
274
|
-
*/
|
|
275
|
-
export async function verifyBlockExecutionPayload(
|
|
276
|
-
chain: VerifyBlockExecutionPayloadModules,
|
|
277
|
-
blockInput: IBlockInput,
|
|
278
|
-
preState0: CachedBeaconStateAllForks,
|
|
279
|
-
opts: BlockProcessOpts,
|
|
280
|
-
isOptimisticallySafe: boolean,
|
|
281
|
-
currentSlot: Slot
|
|
282
|
-
): Promise<VerifyBlockExecutionResponse> {
|
|
283
|
-
const block = blockInput.getBlock();
|
|
284
|
-
/** Not null if execution is enabled */
|
|
285
|
-
const executionPayloadEnabled =
|
|
286
|
-
isExecutionStateType(preState0) &&
|
|
287
|
-
isExecutionBlockBodyType(block.message.body) &&
|
|
288
|
-
// Safe to use with a state previous to block's preState. isMergeComplete can only transition from false to true.
|
|
289
|
-
// - If preState0 is after merge block: condition is true, and will always be true
|
|
290
|
-
// - If preState0 is before merge block: the block could lie but then state transition function will throw above
|
|
291
|
-
// It is kinda safe to send non-trusted payloads to the execution client because at most it can trigger sync.
|
|
292
|
-
// TODO: If this becomes a problem, do some basic verification beforehand, like checking the proposer signature.
|
|
293
|
-
isExecutionEnabled(preState0, block.message)
|
|
294
|
-
? block.message.body.executionPayload
|
|
295
|
-
: null;
|
|
296
|
-
|
|
297
|
-
if (!executionPayloadEnabled) {
|
|
298
|
-
// isExecutionEnabled() -> false
|
|
299
|
-
return {executionStatus: ExecutionStatus.PreMerge, execError: null} as VerifyBlockExecutionResponse;
|
|
300
|
-
}
|
|
301
|
-
|
|
302
|
-
// TODO: Handle better notifyNewPayload() returning error is syncing
|
|
303
|
-
const fork = blockInput.forkName;
|
|
304
|
-
const versionedHashes =
|
|
305
|
-
isBlockInputBlobs(blockInput) || isBlockInputColumns(blockInput) ? blockInput.getVersionedHashes() : undefined;
|
|
306
|
-
const parentBlockRoot = ForkSeq[fork] >= ForkSeq.deneb ? block.message.parentRoot : undefined;
|
|
307
|
-
const executionRequests =
|
|
308
|
-
ForkSeq[fork] >= ForkSeq.electra ? (block.message.body as electra.BeaconBlockBody).executionRequests : undefined;
|
|
309
|
-
|
|
310
|
-
const logCtx = {slot: blockInput.slot, executionBlock: executionPayloadEnabled.blockNumber};
|
|
311
|
-
chain.logger.debug("Call engine api newPayload", logCtx);
|
|
312
|
-
const execResult = await chain.executionEngine.notifyNewPayload(
|
|
313
|
-
fork,
|
|
314
|
-
executionPayloadEnabled,
|
|
315
|
-
versionedHashes,
|
|
316
|
-
parentBlockRoot,
|
|
317
|
-
executionRequests
|
|
318
|
-
);
|
|
319
|
-
chain.logger.debug("Receive engine api newPayload result", {...logCtx, status: execResult.status});
|
|
320
|
-
|
|
321
|
-
chain.metrics?.engineNotifyNewPayloadResult.inc({result: execResult.status});
|
|
322
|
-
|
|
323
|
-
switch (execResult.status) {
|
|
324
|
-
case ExecutionPayloadStatus.VALID: {
|
|
325
|
-
const executionStatus: ExecutionStatus.Valid = ExecutionStatus.Valid;
|
|
326
|
-
const lvhResponse = {executionStatus, latestValidExecHash: execResult.latestValidHash};
|
|
327
|
-
return {executionStatus, lvhResponse, execError: null};
|
|
328
|
-
}
|
|
329
|
-
|
|
330
|
-
case ExecutionPayloadStatus.INVALID: {
|
|
331
|
-
const executionStatus: ExecutionStatus.Invalid = ExecutionStatus.Invalid;
|
|
332
|
-
const lvhResponse = {
|
|
333
|
-
executionStatus,
|
|
334
|
-
latestValidExecHash: execResult.latestValidHash,
|
|
335
|
-
invalidateFromParentBlockRoot: blockInput.parentRootHex,
|
|
336
|
-
};
|
|
337
|
-
const execError = new BlockError(block, {
|
|
338
|
-
code: BlockErrorCode.EXECUTION_ENGINE_ERROR,
|
|
339
|
-
execStatus: execResult.status,
|
|
340
|
-
errorMessage: execResult.validationError ?? "",
|
|
341
|
-
});
|
|
342
|
-
return {executionStatus, lvhResponse, execError};
|
|
343
|
-
}
|
|
344
|
-
|
|
345
|
-
// Accepted and Syncing have the same treatment, as final validation of block is pending
|
|
346
|
-
case ExecutionPayloadStatus.ACCEPTED:
|
|
347
|
-
case ExecutionPayloadStatus.SYNCING: {
|
|
348
|
-
// Check if the entire segment was deemed safe or, this block specifically itself if not in
|
|
349
|
-
// the safeSlotsToImportOptimistically window of current slot, then we can import else
|
|
350
|
-
// we need to throw and not import his block
|
|
351
|
-
const safeSlotsToImportOptimistically =
|
|
352
|
-
opts.safeSlotsToImportOptimistically ?? SAFE_SLOTS_TO_IMPORT_OPTIMISTICALLY;
|
|
353
|
-
if (!isOptimisticallySafe && blockInput.slot + safeSlotsToImportOptimistically >= currentSlot) {
|
|
354
|
-
const execError = new BlockError(block, {
|
|
355
|
-
code: BlockErrorCode.EXECUTION_ENGINE_ERROR,
|
|
356
|
-
execStatus: ExecutionPayloadStatus.UNSAFE_OPTIMISTIC_STATUS,
|
|
357
|
-
errorMessage: `not safe to import ${execResult.status} payload within ${opts.safeSlotsToImportOptimistically} of currentSlot`,
|
|
358
|
-
});
|
|
359
|
-
return {executionStatus: null, execError} as VerifyBlockExecutionResponse;
|
|
360
|
-
}
|
|
361
|
-
|
|
362
|
-
return {executionStatus: ExecutionStatus.Syncing, execError: null};
|
|
363
|
-
}
|
|
364
|
-
|
|
365
|
-
// If the block has is not valid, or it referenced an invalid terminal block then the
|
|
366
|
-
// block is invalid, however it has no bearing on any forkChoice cleanup
|
|
367
|
-
//
|
|
368
|
-
// There can be other reasons for which EL failed some of the observed ones are
|
|
369
|
-
// 1. Connection refused / can't connect to EL port
|
|
370
|
-
// 2. EL Internal Error
|
|
371
|
-
// 3. Geth sometimes gives invalid merkle root error which means invalid
|
|
372
|
-
// but expects it to be handled in CL as of now. But we should log as warning
|
|
373
|
-
// and give it as optimistic treatment and expect any other non-geth CL<>EL
|
|
374
|
-
// combination to reject the invalid block and propose a block.
|
|
375
|
-
// On kintsugi devnet, this has been observed to cause contiguous proposal failures
|
|
376
|
-
// as the network is geth dominated, till a non geth node proposes and moves network
|
|
377
|
-
// forward
|
|
378
|
-
// For network/unreachable errors, an optimization can be added to replay these blocks
|
|
379
|
-
// back. But for now, lets assume other mechanisms like unknown parent block of a future
|
|
380
|
-
// child block will cause it to replay
|
|
381
|
-
|
|
382
|
-
case ExecutionPayloadStatus.INVALID_BLOCK_HASH:
|
|
383
|
-
case ExecutionPayloadStatus.ELERROR:
|
|
384
|
-
case ExecutionPayloadStatus.UNAVAILABLE: {
|
|
385
|
-
const execError = new BlockError(block, {
|
|
386
|
-
code: BlockErrorCode.EXECUTION_ENGINE_ERROR,
|
|
387
|
-
execStatus: execResult.status,
|
|
388
|
-
errorMessage: execResult.validationError,
|
|
389
|
-
});
|
|
390
|
-
return {executionStatus: null, execError} as VerifyBlockExecutionResponse;
|
|
391
|
-
}
|
|
392
|
-
}
|
|
393
|
-
}
|
|
394
|
-
|
|
395
|
-
function getSegmentErrorResponse(
|
|
396
|
-
{verifyResponse, blockIndex}: {verifyResponse: VerifyExecutionErrorResponse; blockIndex: number},
|
|
397
|
-
parentBlock: ProtoBlock,
|
|
398
|
-
blocks: IBlockInput[]
|
|
399
|
-
): SegmentExecStatus {
|
|
400
|
-
const {executionStatus, lvhResponse, execError} = verifyResponse;
|
|
401
|
-
let invalidSegmentLVH: LVHInvalidResponse | undefined = undefined;
|
|
402
|
-
|
|
403
|
-
if (
|
|
404
|
-
executionStatus === ExecutionStatus.Invalid &&
|
|
405
|
-
lvhResponse !== undefined &&
|
|
406
|
-
lvhResponse.latestValidExecHash !== null
|
|
407
|
-
) {
|
|
408
|
-
let lvhFound = false;
|
|
409
|
-
for (let mayBeLVHIndex = blockIndex - 1; mayBeLVHIndex >= 0; mayBeLVHIndex--) {
|
|
410
|
-
const block = blocks[mayBeLVHIndex].getBlock();
|
|
411
|
-
if (
|
|
412
|
-
toRootHex((block.message.body as bellatrix.BeaconBlockBody).executionPayload.blockHash) ===
|
|
413
|
-
lvhResponse.latestValidExecHash
|
|
414
|
-
) {
|
|
415
|
-
lvhFound = true;
|
|
416
|
-
break;
|
|
417
|
-
}
|
|
418
|
-
}
|
|
419
|
-
|
|
420
|
-
// If there is no valid in the segment then we have to propagate invalid response
|
|
421
|
-
// in forkchoice as well if
|
|
422
|
-
// - if the parentBlock is also not the lvh
|
|
423
|
-
// - and parentBlock is not pre merge
|
|
424
|
-
if (
|
|
425
|
-
!lvhFound &&
|
|
426
|
-
parentBlock.executionStatus !== ExecutionStatus.PreMerge &&
|
|
427
|
-
parentBlock.executionPayloadBlockHash !== lvhResponse.latestValidExecHash
|
|
428
|
-
) {
|
|
429
|
-
invalidSegmentLVH = {
|
|
430
|
-
executionStatus: ExecutionStatus.Invalid,
|
|
431
|
-
latestValidExecHash: lvhResponse.latestValidExecHash,
|
|
432
|
-
invalidateFromParentBlockRoot: parentBlock.blockRoot,
|
|
433
|
-
};
|
|
434
|
-
}
|
|
435
|
-
}
|
|
436
|
-
const execAborted = {blockIndex, execError};
|
|
437
|
-
return {execAborted, invalidSegmentLVH} as SegmentExecStatus;
|
|
438
|
-
}
|
|
@@ -1,129 +0,0 @@
|
|
|
1
|
-
import {ChainForkConfig} from "@lodestar/config";
|
|
2
|
-
import {IForkChoice, ProtoBlock} from "@lodestar/fork-choice";
|
|
3
|
-
import {computeStartSlotAtEpoch} from "@lodestar/state-transition";
|
|
4
|
-
import {RootHex, Slot} from "@lodestar/types";
|
|
5
|
-
import {toRootHex} from "@lodestar/utils";
|
|
6
|
-
import {IClock} from "../../util/clock.js";
|
|
7
|
-
import {BlockError, BlockErrorCode} from "../errors/index.js";
|
|
8
|
-
import {IChainOptions} from "../options.js";
|
|
9
|
-
import {IBlockInput} from "./blockInput/types.js";
|
|
10
|
-
import {ImportBlockOpts} from "./types.js";
|
|
11
|
-
|
|
12
|
-
/**
|
|
13
|
-
* Verifies some early cheap sanity checks on the block before running the full state transition.
|
|
14
|
-
*
|
|
15
|
-
* - Parent is known to the fork-choice
|
|
16
|
-
* - Check skipped slots limit
|
|
17
|
-
* - check_block_relevancy()
|
|
18
|
-
* - Block not in the future
|
|
19
|
-
* - Not genesis block
|
|
20
|
-
* - Block's slot is < Infinity
|
|
21
|
-
* - Not finalized slot
|
|
22
|
-
* - Not already known
|
|
23
|
-
*/
|
|
24
|
-
export function verifyBlocksSanityChecks(
|
|
25
|
-
chain: {
|
|
26
|
-
forkChoice: IForkChoice;
|
|
27
|
-
clock: IClock;
|
|
28
|
-
config: ChainForkConfig;
|
|
29
|
-
opts: IChainOptions;
|
|
30
|
-
blacklistedBlocks: Map<RootHex, Slot | null>;
|
|
31
|
-
},
|
|
32
|
-
blocks: IBlockInput[],
|
|
33
|
-
opts: ImportBlockOpts
|
|
34
|
-
): {
|
|
35
|
-
relevantBlocks: IBlockInput[];
|
|
36
|
-
parentSlots: Slot[];
|
|
37
|
-
parentBlock: ProtoBlock | null;
|
|
38
|
-
} {
|
|
39
|
-
if (blocks.length === 0) {
|
|
40
|
-
throw Error("Empty partiallyVerifiedBlocks");
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
const relevantBlocks: IBlockInput[] = [];
|
|
44
|
-
const parentSlots: Slot[] = [];
|
|
45
|
-
let parentBlock: ProtoBlock | null = null;
|
|
46
|
-
|
|
47
|
-
for (const blockInput of blocks) {
|
|
48
|
-
const block = blockInput.getBlock();
|
|
49
|
-
const blockSlot = block.message.slot;
|
|
50
|
-
const blockHash = toRootHex(chain.config.getForkTypes(block.message.slot).BeaconBlock.hashTreeRoot(block.message));
|
|
51
|
-
|
|
52
|
-
if (chain.blacklistedBlocks.has(blockHash)) {
|
|
53
|
-
// Blacklisting blocks via CLI flag only requires to set the block hash
|
|
54
|
-
if (chain.blacklistedBlocks.get(blockHash) === null) {
|
|
55
|
-
// Set actual slot observed when processing the block
|
|
56
|
-
chain.blacklistedBlocks.set(blockHash, blockSlot);
|
|
57
|
-
}
|
|
58
|
-
throw new BlockError(block, {code: BlockErrorCode.BLACKLISTED_BLOCK});
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
if (chain.blacklistedBlocks.has(toRootHex(block.message.parentRoot))) {
|
|
62
|
-
chain.blacklistedBlocks.set(blockHash, blockSlot);
|
|
63
|
-
throw new BlockError(block, {code: BlockErrorCode.BLACKLISTED_BLOCK});
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
// Not genesis block
|
|
67
|
-
// IGNORE if `partiallyVerifiedBlock.ignoreIfKnown`
|
|
68
|
-
if (blockSlot === 0) {
|
|
69
|
-
if (opts.ignoreIfKnown) {
|
|
70
|
-
continue;
|
|
71
|
-
}
|
|
72
|
-
throw new BlockError(block, {code: BlockErrorCode.GENESIS_BLOCK});
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
// Not finalized slot
|
|
76
|
-
// IGNORE if `partiallyVerifiedBlock.ignoreIfFinalized`
|
|
77
|
-
const finalizedSlot = computeStartSlotAtEpoch(chain.forkChoice.getFinalizedCheckpoint().epoch);
|
|
78
|
-
if (blockSlot <= finalizedSlot) {
|
|
79
|
-
if (opts.ignoreIfFinalized) {
|
|
80
|
-
continue;
|
|
81
|
-
}
|
|
82
|
-
throw new BlockError(block, {code: BlockErrorCode.WOULD_REVERT_FINALIZED_SLOT, blockSlot, finalizedSlot});
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
const relevantLastBlock = relevantBlocks.at(-1);
|
|
86
|
-
let parentBlockSlot: Slot;
|
|
87
|
-
|
|
88
|
-
if (relevantLastBlock) {
|
|
89
|
-
parentBlockSlot = relevantLastBlock.getBlock().message.slot;
|
|
90
|
-
} else {
|
|
91
|
-
// When importing a block segment, only the first NON-IGNORED block must be known to the fork-choice.
|
|
92
|
-
const parentRoot = toRootHex(block.message.parentRoot);
|
|
93
|
-
parentBlock = chain.forkChoice.getBlockHex(parentRoot);
|
|
94
|
-
if (!parentBlock) {
|
|
95
|
-
throw new BlockError(block, {code: BlockErrorCode.PARENT_UNKNOWN, parentRoot});
|
|
96
|
-
}
|
|
97
|
-
// Parent is known to the fork-choice
|
|
98
|
-
parentBlockSlot = parentBlock.slot;
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
// Block not in the future, also checks for infinity
|
|
102
|
-
const currentSlot = chain.clock.currentSlot;
|
|
103
|
-
if (blockSlot > currentSlot) {
|
|
104
|
-
throw new BlockError(block, {code: BlockErrorCode.FUTURE_SLOT, blockSlot, currentSlot});
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
// Not already known
|
|
108
|
-
// IGNORE if `partiallyVerifiedBlock.ignoreIfKnown`
|
|
109
|
-
if (chain.forkChoice.hasBlockHex(blockHash)) {
|
|
110
|
-
if (opts.ignoreIfKnown) {
|
|
111
|
-
continue;
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
throw new BlockError(block, {code: BlockErrorCode.ALREADY_KNOWN, root: blockHash});
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
// Block is relevant
|
|
118
|
-
relevantBlocks.push(blockInput);
|
|
119
|
-
parentSlots.push(parentBlockSlot);
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
// Just assert to be over cautious and for purposes to be more explicit for someone
|
|
123
|
-
// going through the code segment
|
|
124
|
-
if (parentBlock === null && relevantBlocks.length > 0) {
|
|
125
|
-
throw Error(`Internal error, parentBlock should not be null for relevantBlocks=${relevantBlocks.length}`);
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
return {relevantBlocks, parentSlots, parentBlock};
|
|
129
|
-
}
|
|
@@ -1,105 +0,0 @@
|
|
|
1
|
-
import {CachedBeaconStateAllForks, getBlockSignatureSets} from "@lodestar/state-transition";
|
|
2
|
-
import {SignedBeaconBlock} from "@lodestar/types";
|
|
3
|
-
import {Logger} from "@lodestar/utils";
|
|
4
|
-
import {Metrics} from "../../metrics/metrics.js";
|
|
5
|
-
import {nextEventLoop} from "../../util/eventLoop.js";
|
|
6
|
-
import {IBlsVerifier} from "../bls/index.js";
|
|
7
|
-
import {BlockError, BlockErrorCode} from "../errors/blockError.js";
|
|
8
|
-
import {ImportBlockOpts} from "./types.js";
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* Verifies 1 or more block's signatures from a group of blocks in the same epoch.
|
|
12
|
-
* getBlockSignatureSets() guarantees to return the correct signingRoots as long as all blocks belong in the same
|
|
13
|
-
* epoch as `preState0`. Otherwise the shufflings won't be correct.
|
|
14
|
-
*
|
|
15
|
-
* Since all data is known in advance all signatures are verified at once in parallel.
|
|
16
|
-
*/
|
|
17
|
-
export async function verifyBlocksSignatures(
|
|
18
|
-
bls: IBlsVerifier,
|
|
19
|
-
logger: Logger,
|
|
20
|
-
metrics: Metrics | null,
|
|
21
|
-
preState0: CachedBeaconStateAllForks,
|
|
22
|
-
blocks: SignedBeaconBlock[],
|
|
23
|
-
opts: ImportBlockOpts
|
|
24
|
-
): Promise<{verifySignaturesTime: number}> {
|
|
25
|
-
const isValidPromises: Promise<boolean>[] = [];
|
|
26
|
-
const recvToValLatency = Date.now() / 1000 - (opts.seenTimestampSec ?? Date.now() / 1000);
|
|
27
|
-
|
|
28
|
-
// Verifies signatures after running state transition, so all SyncCommittee signed roots are known at this point.
|
|
29
|
-
// We must ensure block.slot <= state.slot before running getAllBlockSignatureSets().
|
|
30
|
-
// NOTE: If in the future multiple blocks signatures are verified at once, all blocks must be in the same epoch
|
|
31
|
-
// so the attester and proposer shufflings are correct.
|
|
32
|
-
for (const [i, block] of blocks.entries()) {
|
|
33
|
-
// Use [i] to make clear that the index has to be correct to blame the right block below on BlockError()
|
|
34
|
-
isValidPromises[i] = opts.validSignatures
|
|
35
|
-
? // Skip all signature verification
|
|
36
|
-
Promise.resolve(true)
|
|
37
|
-
: //
|
|
38
|
-
// Verify signatures per block to track which block is invalid
|
|
39
|
-
bls.verifySignatureSets(
|
|
40
|
-
getBlockSignatureSets(preState0, block, {
|
|
41
|
-
skipProposerSignature: opts.validProposerSignature,
|
|
42
|
-
})
|
|
43
|
-
);
|
|
44
|
-
|
|
45
|
-
// getBlockSignatureSets() takes 45ms in benchmarks for 2022Q2 mainnet blocks (100 sigs). When syncing a 32 blocks
|
|
46
|
-
// segments it will block the event loop for 1400 ms, which is too much. This call will allow the event loop to
|
|
47
|
-
// yield, which will cause one block's state transition to run. However, the tradeoff is okay and doesn't slow sync
|
|
48
|
-
if ((i + 1) % 8 === 0) {
|
|
49
|
-
await nextEventLoop();
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
// `rejectFirstInvalidResolveAllValid()` returns on isValid result with its index
|
|
54
|
-
const res = await rejectFirstInvalidResolveAllValid(isValidPromises);
|
|
55
|
-
if (!res.allValid) {
|
|
56
|
-
throw new BlockError(blocks[res.index], {code: BlockErrorCode.INVALID_SIGNATURE, state: preState0});
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
const verifySignaturesTime = Date.now();
|
|
60
|
-
if (blocks.length === 1 && opts.seenTimestampSec !== undefined) {
|
|
61
|
-
const recvToValidation = verifySignaturesTime / 1000 - opts.seenTimestampSec;
|
|
62
|
-
const validationTime = recvToValidation - recvToValLatency;
|
|
63
|
-
|
|
64
|
-
metrics?.gossipBlock.signatureVerification.recvToValidation.observe(recvToValidation);
|
|
65
|
-
metrics?.gossipBlock.signatureVerification.validationTime.observe(validationTime);
|
|
66
|
-
|
|
67
|
-
logger.debug("Verified block signatures", {
|
|
68
|
-
slot: blocks[0].message.slot,
|
|
69
|
-
recvToValLatency,
|
|
70
|
-
recvToValidation,
|
|
71
|
-
validationTime,
|
|
72
|
-
});
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
return {verifySignaturesTime};
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
type AllValidRes = {allValid: true} | {allValid: false; index: number};
|
|
79
|
-
|
|
80
|
-
/**
|
|
81
|
-
* From an array of promises that resolve a boolean isValid
|
|
82
|
-
* - if all valid, await all and return
|
|
83
|
-
* - if one invalid, abort immediately and return index of invalid
|
|
84
|
-
*/
|
|
85
|
-
export function rejectFirstInvalidResolveAllValid(isValidPromises: Promise<boolean>[]): Promise<AllValidRes> {
|
|
86
|
-
return new Promise<AllValidRes>((resolve, reject) => {
|
|
87
|
-
let validCount = 0;
|
|
88
|
-
|
|
89
|
-
for (let i = 0; i < isValidPromises.length; i++) {
|
|
90
|
-
isValidPromises[i]
|
|
91
|
-
.then((isValid) => {
|
|
92
|
-
if (isValid) {
|
|
93
|
-
if (++validCount >= isValidPromises.length) {
|
|
94
|
-
resolve({allValid: true});
|
|
95
|
-
}
|
|
96
|
-
} else {
|
|
97
|
-
resolve({allValid: false, index: i});
|
|
98
|
-
}
|
|
99
|
-
})
|
|
100
|
-
.catch((e) => {
|
|
101
|
-
reject(e);
|
|
102
|
-
});
|
|
103
|
-
}
|
|
104
|
-
});
|
|
105
|
-
}
|