@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.
Files changed (945) hide show
  1. package/lib/api/impl/config/constants.d.ts +0 -5
  2. package/lib/api/impl/config/constants.js +1 -6
  3. package/lib/api/impl/config/constants.js.map +1 -1
  4. package/lib/api/impl/validator/index.js +3 -5
  5. package/lib/api/impl/validator/index.js.map +1 -1
  6. package/lib/chain/archiveStore/historicalState/historicalStateRegen.js +0 -1
  7. package/lib/chain/archiveStore/historicalState/historicalStateRegen.js.map +1 -1
  8. package/lib/chain/archiveStore/historicalState/worker.js +1 -1
  9. package/lib/chain/archiveStore/historicalState/worker.js.map +1 -1
  10. package/lib/chain/blocks/blockInput/blockInput.js +1 -1
  11. package/lib/chain/blocks/blockInput/blockInput.js.map +1 -1
  12. package/lib/chain/blocks/importBlock.js +3 -4
  13. package/lib/chain/blocks/importBlock.js.map +1 -1
  14. package/lib/chain/blocks/verifyBlocksDataAvailability.js +1 -8
  15. package/lib/chain/blocks/verifyBlocksDataAvailability.js.map +1 -1
  16. package/lib/chain/blocks/writeBlockInputToDb.js +7 -1
  17. package/lib/chain/blocks/writeBlockInputToDb.js.map +1 -1
  18. package/lib/chain/bls/multithread/index.js +0 -1
  19. package/lib/chain/bls/multithread/index.js.map +1 -1
  20. package/lib/chain/chain.js +3 -2
  21. package/lib/chain/chain.js.map +1 -1
  22. package/lib/chain/emitter.d.ts +2 -2
  23. package/lib/chain/opPools/attestationPool.d.ts +3 -2
  24. package/lib/chain/opPools/attestationPool.js +5 -3
  25. package/lib/chain/opPools/attestationPool.js.map +1 -1
  26. package/lib/chain/opPools/syncCommitteeMessagePool.d.ts +2 -3
  27. package/lib/chain/opPools/syncCommitteeMessagePool.js +5 -6
  28. package/lib/chain/opPools/syncCommitteeMessagePool.js.map +1 -1
  29. package/lib/chain/opPools/types.d.ts +1 -1
  30. package/lib/chain/opPools/types.js +1 -1
  31. package/lib/chain/opPools/types.js.map +1 -1
  32. package/lib/chain/prepareNextSlot.d.ts +3 -3
  33. package/lib/chain/prepareNextSlot.js +8 -8
  34. package/lib/chain/prepareNextSlot.js.map +1 -1
  35. package/lib/chain/stateCache/persistentCheckpointsCache.js +8 -9
  36. package/lib/chain/stateCache/persistentCheckpointsCache.js.map +1 -1
  37. package/lib/chain/validation/lightClientFinalityUpdate.js +3 -4
  38. package/lib/chain/validation/lightClientFinalityUpdate.js.map +1 -1
  39. package/lib/chain/validation/lightClientOptimisticUpdate.d.ts +4 -6
  40. package/lib/chain/validation/lightClientOptimisticUpdate.js +11 -11
  41. package/lib/chain/validation/lightClientOptimisticUpdate.js.map +1 -1
  42. package/lib/chain/validatorMonitor.js +14 -20
  43. package/lib/chain/validatorMonitor.js.map +1 -1
  44. package/lib/db/buckets.d.ts +4 -4
  45. package/lib/db/buckets.js +4 -4
  46. package/lib/db/buckets.js.map +1 -1
  47. package/lib/db/repositories/blobSidecars.js +1 -1
  48. package/lib/db/repositories/blobSidecars.js.map +1 -1
  49. package/lib/db/repositories/blobSidecarsArchive.js +1 -1
  50. package/lib/db/repositories/blobSidecarsArchive.js.map +1 -1
  51. package/lib/db/repositories/blockArchiveIndex.d.ts +2 -2
  52. package/lib/db/repositories/dataColumnSidecar.js +1 -1
  53. package/lib/db/repositories/dataColumnSidecar.js.map +1 -1
  54. package/lib/db/repositories/dataColumnSidecarArchive.js +1 -1
  55. package/lib/db/repositories/dataColumnSidecarArchive.js.map +1 -1
  56. package/lib/metrics/metrics/lodestar.d.ts +1 -1
  57. package/lib/metrics/metrics/lodestar.js +3 -3
  58. package/lib/metrics/metrics/lodestar.js.map +1 -1
  59. package/lib/network/core/networkCoreWorkerHandler.js +3 -9
  60. package/lib/network/core/networkCoreWorkerHandler.js.map +1 -1
  61. package/lib/network/discv5/index.js +1 -4
  62. package/lib/network/discv5/index.js.map +1 -1
  63. package/lib/network/gossip/gossipsub.d.ts +0 -1
  64. package/lib/network/gossip/gossipsub.js +16 -35
  65. package/lib/network/gossip/gossipsub.js.map +1 -1
  66. package/lib/network/gossip/metrics.d.ts +7 -15
  67. package/lib/network/gossip/metrics.js +6 -16
  68. package/lib/network/gossip/metrics.js.map +1 -1
  69. package/lib/network/libp2p/index.js +1 -9
  70. package/lib/network/libp2p/index.js.map +1 -1
  71. package/lib/network/metadata.js +1 -2
  72. package/lib/network/metadata.js.map +1 -1
  73. package/lib/network/network.d.ts +1 -1
  74. package/lib/network/network.js +13 -11
  75. package/lib/network/network.js.map +1 -1
  76. package/lib/network/peers/datastore.d.ts +2 -2
  77. package/lib/network/peers/datastore.js +2 -2
  78. package/lib/network/peers/datastore.js.map +1 -1
  79. package/lib/network/processor/index.d.ts +1 -1
  80. package/lib/network/processor/index.js +3 -2
  81. package/lib/network/processor/index.js.map +1 -1
  82. package/lib/sync/types.d.ts +1 -0
  83. package/lib/sync/types.js.map +1 -1
  84. package/lib/sync/unknownBlock.d.ts +1 -0
  85. package/lib/sync/unknownBlock.js +19 -17
  86. package/lib/sync/unknownBlock.js.map +1 -1
  87. package/lib/sync/utils/downloadByRoot.d.ts +1 -3
  88. package/lib/sync/utils/downloadByRoot.js +9 -36
  89. package/lib/sync/utils/downloadByRoot.js.map +1 -1
  90. package/lib/util/blobs.js +3 -5
  91. package/lib/util/blobs.js.map +1 -1
  92. package/lib/util/clock.d.ts +0 -5
  93. package/lib/util/clock.js +0 -3
  94. package/lib/util/clock.js.map +1 -1
  95. package/lib/util/dataColumns.js +1 -1
  96. package/lib/util/dataColumns.js.map +1 -1
  97. package/lib/util/execution.js +2 -19
  98. package/lib/util/execution.js.map +1 -1
  99. package/package.json +22 -32
  100. package/lib/api/impl/api.d.ts.map +0 -1
  101. package/lib/api/impl/beacon/blocks/index.d.ts.map +0 -1
  102. package/lib/api/impl/beacon/blocks/utils.d.ts.map +0 -1
  103. package/lib/api/impl/beacon/index.d.ts.map +0 -1
  104. package/lib/api/impl/beacon/pool/index.d.ts.map +0 -1
  105. package/lib/api/impl/beacon/rewards/index.d.ts.map +0 -1
  106. package/lib/api/impl/beacon/state/index.d.ts.map +0 -1
  107. package/lib/api/impl/beacon/state/utils.d.ts.map +0 -1
  108. package/lib/api/impl/config/constants.d.ts.map +0 -1
  109. package/lib/api/impl/config/index.d.ts.map +0 -1
  110. package/lib/api/impl/debug/index.d.ts.map +0 -1
  111. package/lib/api/impl/errors.d.ts.map +0 -1
  112. package/lib/api/impl/events/index.d.ts.map +0 -1
  113. package/lib/api/impl/index.d.ts.map +0 -1
  114. package/lib/api/impl/lightclient/index.d.ts.map +0 -1
  115. package/lib/api/impl/lodestar/index.d.ts.map +0 -1
  116. package/lib/api/impl/node/index.d.ts.map +0 -1
  117. package/lib/api/impl/node/utils.d.ts.map +0 -1
  118. package/lib/api/impl/proof/index.d.ts.map +0 -1
  119. package/lib/api/impl/types.d.ts.map +0 -1
  120. package/lib/api/impl/utils.d.ts.map +0 -1
  121. package/lib/api/impl/validator/index.d.ts.map +0 -1
  122. package/lib/api/impl/validator/utils.d.ts.map +0 -1
  123. package/lib/api/index.d.ts.map +0 -1
  124. package/lib/api/options.d.ts.map +0 -1
  125. package/lib/api/rest/activeSockets.d.ts.map +0 -1
  126. package/lib/api/rest/base.d.ts.map +0 -1
  127. package/lib/api/rest/index.d.ts.map +0 -1
  128. package/lib/api/rest/swaggerUI.d.ts.map +0 -1
  129. package/lib/bun-wrappers/prometheus-gc-stats.d.ts.map +0 -1
  130. package/lib/chain/ColumnReconstructionTracker.d.ts.map +0 -1
  131. package/lib/chain/GetBlobsTracker.d.ts.map +0 -1
  132. package/lib/chain/archiveStore/archiveStore.d.ts.map +0 -1
  133. package/lib/chain/archiveStore/constants.d.ts.map +0 -1
  134. package/lib/chain/archiveStore/historicalState/getHistoricalState.d.ts.map +0 -1
  135. package/lib/chain/archiveStore/historicalState/historicalStateRegen.d.ts.map +0 -1
  136. package/lib/chain/archiveStore/historicalState/metrics.d.ts.map +0 -1
  137. package/lib/chain/archiveStore/historicalState/types.d.ts.map +0 -1
  138. package/lib/chain/archiveStore/historicalState/worker.d.ts.map +0 -1
  139. package/lib/chain/archiveStore/index.d.ts.map +0 -1
  140. package/lib/chain/archiveStore/interface.d.ts.map +0 -1
  141. package/lib/chain/archiveStore/strategies/frequencyStateArchiveStrategy.d.ts.map +0 -1
  142. package/lib/chain/archiveStore/utils/archiveBlocks.d.ts.map +0 -1
  143. package/lib/chain/archiveStore/utils/pruneHistory.d.ts.map +0 -1
  144. package/lib/chain/archiveStore/utils/updateBackfillRange.d.ts.map +0 -1
  145. package/lib/chain/balancesCache.d.ts.map +0 -1
  146. package/lib/chain/beaconProposerCache.d.ts.map +0 -1
  147. package/lib/chain/blocks/blockInput/blockInput.d.ts.map +0 -1
  148. package/lib/chain/blocks/blockInput/errors.d.ts.map +0 -1
  149. package/lib/chain/blocks/blockInput/index.d.ts.map +0 -1
  150. package/lib/chain/blocks/blockInput/types.d.ts.map +0 -1
  151. package/lib/chain/blocks/blockInput/utils.d.ts.map +0 -1
  152. package/lib/chain/blocks/importBlock.d.ts.map +0 -1
  153. package/lib/chain/blocks/index.d.ts.map +0 -1
  154. package/lib/chain/blocks/types.d.ts.map +0 -1
  155. package/lib/chain/blocks/utils/blowfishBanner.d.ts.map +0 -1
  156. package/lib/chain/blocks/utils/chainSegment.d.ts.map +0 -1
  157. package/lib/chain/blocks/utils/checkpoint.d.ts.map +0 -1
  158. package/lib/chain/blocks/utils/giraffeBanner.d.ts.map +0 -1
  159. package/lib/chain/blocks/utils/ownBanner.d.ts.map +0 -1
  160. package/lib/chain/blocks/utils/pandaMergeTransitionBanner.d.ts.map +0 -1
  161. package/lib/chain/blocks/utils/zebraBanner.d.ts.map +0 -1
  162. package/lib/chain/blocks/verifyBlock.d.ts.map +0 -1
  163. package/lib/chain/blocks/verifyBlocksDataAvailability.d.ts.map +0 -1
  164. package/lib/chain/blocks/verifyBlocksExecutionPayloads.d.ts.map +0 -1
  165. package/lib/chain/blocks/verifyBlocksSanityChecks.d.ts.map +0 -1
  166. package/lib/chain/blocks/verifyBlocksSignatures.d.ts.map +0 -1
  167. package/lib/chain/blocks/verifyBlocksStateTransitionOnly.d.ts.map +0 -1
  168. package/lib/chain/blocks/writeBlockInputToDb.d.ts.map +0 -1
  169. package/lib/chain/bls/index.d.ts.map +0 -1
  170. package/lib/chain/bls/interface.d.ts.map +0 -1
  171. package/lib/chain/bls/maybeBatch.d.ts.map +0 -1
  172. package/lib/chain/bls/multithread/index.d.ts.map +0 -1
  173. package/lib/chain/bls/multithread/jobItem.d.ts.map +0 -1
  174. package/lib/chain/bls/multithread/poolSize.d.ts.map +0 -1
  175. package/lib/chain/bls/multithread/types.d.ts.map +0 -1
  176. package/lib/chain/bls/multithread/utils.d.ts.map +0 -1
  177. package/lib/chain/bls/multithread/worker.d.ts.map +0 -1
  178. package/lib/chain/bls/singleThread.d.ts.map +0 -1
  179. package/lib/chain/bls/utils.d.ts.map +0 -1
  180. package/lib/chain/chain.d.ts.map +0 -1
  181. package/lib/chain/emitter.d.ts.map +0 -1
  182. package/lib/chain/errors/attestationError.d.ts.map +0 -1
  183. package/lib/chain/errors/attesterSlashingError.d.ts.map +0 -1
  184. package/lib/chain/errors/blobSidecarError.d.ts.map +0 -1
  185. package/lib/chain/errors/blockError.d.ts.map +0 -1
  186. package/lib/chain/errors/blsToExecutionChangeError.d.ts.map +0 -1
  187. package/lib/chain/errors/dataColumnSidecarError.d.ts.map +0 -1
  188. package/lib/chain/errors/gossipValidation.d.ts.map +0 -1
  189. package/lib/chain/errors/index.d.ts.map +0 -1
  190. package/lib/chain/errors/lightClientError.d.ts.map +0 -1
  191. package/lib/chain/errors/proposerSlashingError.d.ts.map +0 -1
  192. package/lib/chain/errors/syncCommitteeError.d.ts.map +0 -1
  193. package/lib/chain/errors/voluntaryExitError.d.ts.map +0 -1
  194. package/lib/chain/forkChoice/index.d.ts.map +0 -1
  195. package/lib/chain/genesis/genesis.d.ts.map +0 -1
  196. package/lib/chain/genesis/interface.d.ts.map +0 -1
  197. package/lib/chain/index.d.ts.map +0 -1
  198. package/lib/chain/initState.d.ts.map +0 -1
  199. package/lib/chain/interface.d.ts.map +0 -1
  200. package/lib/chain/lightClient/index.d.ts.map +0 -1
  201. package/lib/chain/lightClient/proofs.d.ts.map +0 -1
  202. package/lib/chain/lightClient/types.d.ts.map +0 -1
  203. package/lib/chain/opPools/aggregatedAttestationPool.d.ts.map +0 -1
  204. package/lib/chain/opPools/attestationPool.d.ts.map +0 -1
  205. package/lib/chain/opPools/index.d.ts.map +0 -1
  206. package/lib/chain/opPools/opPool.d.ts.map +0 -1
  207. package/lib/chain/opPools/syncCommitteeMessagePool.d.ts.map +0 -1
  208. package/lib/chain/opPools/syncContributionAndProofPool.d.ts.map +0 -1
  209. package/lib/chain/opPools/types.d.ts.map +0 -1
  210. package/lib/chain/opPools/utils.d.ts.map +0 -1
  211. package/lib/chain/options.d.ts.map +0 -1
  212. package/lib/chain/prepareNextSlot.d.ts.map +0 -1
  213. package/lib/chain/produceBlock/computeNewStateRoot.d.ts.map +0 -1
  214. package/lib/chain/produceBlock/index.d.ts.map +0 -1
  215. package/lib/chain/produceBlock/produceBlockBody.d.ts.map +0 -1
  216. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.d.ts.map +0 -1
  217. package/lib/chain/regen/errors.d.ts.map +0 -1
  218. package/lib/chain/regen/index.d.ts.map +0 -1
  219. package/lib/chain/regen/interface.d.ts.map +0 -1
  220. package/lib/chain/regen/queued.d.ts.map +0 -1
  221. package/lib/chain/regen/regen.d.ts.map +0 -1
  222. package/lib/chain/reprocess.d.ts.map +0 -1
  223. package/lib/chain/rewards/attestationsRewards.d.ts.map +0 -1
  224. package/lib/chain/rewards/blockRewards.d.ts.map +0 -1
  225. package/lib/chain/rewards/syncCommitteeRewards.d.ts.map +0 -1
  226. package/lib/chain/seenCache/index.d.ts.map +0 -1
  227. package/lib/chain/seenCache/seenAggregateAndProof.d.ts.map +0 -1
  228. package/lib/chain/seenCache/seenAttestationData.d.ts.map +0 -1
  229. package/lib/chain/seenCache/seenAttesters.d.ts.map +0 -1
  230. package/lib/chain/seenCache/seenBlockAttesters.d.ts.map +0 -1
  231. package/lib/chain/seenCache/seenBlockProposers.d.ts.map +0 -1
  232. package/lib/chain/seenCache/seenCommittee.d.ts.map +0 -1
  233. package/lib/chain/seenCache/seenCommitteeContribution.d.ts.map +0 -1
  234. package/lib/chain/seenCache/seenGossipBlockInput.d.ts.map +0 -1
  235. package/lib/chain/serializeState.d.ts.map +0 -1
  236. package/lib/chain/shufflingCache.d.ts.map +0 -1
  237. package/lib/chain/stateCache/blockStateCacheImpl.d.ts.map +0 -1
  238. package/lib/chain/stateCache/datastore/db.d.ts.map +0 -1
  239. package/lib/chain/stateCache/datastore/file.d.ts.map +0 -1
  240. package/lib/chain/stateCache/datastore/index.d.ts.map +0 -1
  241. package/lib/chain/stateCache/datastore/types.d.ts.map +0 -1
  242. package/lib/chain/stateCache/fifoBlockStateCache.d.ts.map +0 -1
  243. package/lib/chain/stateCache/inMemoryCheckpointsCache.d.ts.map +0 -1
  244. package/lib/chain/stateCache/index.d.ts.map +0 -1
  245. package/lib/chain/stateCache/mapMetrics.d.ts.map +0 -1
  246. package/lib/chain/stateCache/persistentCheckpointsCache.d.ts.map +0 -1
  247. package/lib/chain/stateCache/types.d.ts.map +0 -1
  248. package/lib/chain/validation/aggregateAndProof.d.ts.map +0 -1
  249. package/lib/chain/validation/attestation.d.ts.map +0 -1
  250. package/lib/chain/validation/attesterSlashing.d.ts.map +0 -1
  251. package/lib/chain/validation/blobSidecar.d.ts.map +0 -1
  252. package/lib/chain/validation/block.d.ts.map +0 -1
  253. package/lib/chain/validation/blsToExecutionChange.d.ts.map +0 -1
  254. package/lib/chain/validation/dataColumnSidecar.d.ts.map +0 -1
  255. package/lib/chain/validation/index.d.ts.map +0 -1
  256. package/lib/chain/validation/lightClientFinalityUpdate.d.ts.map +0 -1
  257. package/lib/chain/validation/lightClientOptimisticUpdate.d.ts.map +0 -1
  258. package/lib/chain/validation/proposerSlashing.d.ts.map +0 -1
  259. package/lib/chain/validation/signatureSets/aggregateAndProof.d.ts.map +0 -1
  260. package/lib/chain/validation/signatureSets/contributionAndProof.d.ts.map +0 -1
  261. package/lib/chain/validation/signatureSets/index.d.ts.map +0 -1
  262. package/lib/chain/validation/signatureSets/selectionProof.d.ts.map +0 -1
  263. package/lib/chain/validation/signatureSets/syncCommittee.d.ts.map +0 -1
  264. package/lib/chain/validation/signatureSets/syncCommitteeContribution.d.ts.map +0 -1
  265. package/lib/chain/validation/signatureSets/syncCommitteeSelectionProof.d.ts.map +0 -1
  266. package/lib/chain/validation/syncCommittee.d.ts.map +0 -1
  267. package/lib/chain/validation/syncCommitteeContributionAndProof.d.ts.map +0 -1
  268. package/lib/chain/validation/voluntaryExit.d.ts.map +0 -1
  269. package/lib/chain/validatorMonitor.d.ts.map +0 -1
  270. package/lib/constants/constants.d.ts.map +0 -1
  271. package/lib/constants/index.d.ts.map +0 -1
  272. package/lib/constants/network.d.ts.map +0 -1
  273. package/lib/db/beacon.d.ts.map +0 -1
  274. package/lib/db/buckets.d.ts.map +0 -1
  275. package/lib/db/index.d.ts.map +0 -1
  276. package/lib/db/interface.d.ts.map +0 -1
  277. package/lib/db/options.d.ts.map +0 -1
  278. package/lib/db/repositories/attesterSlashing.d.ts.map +0 -1
  279. package/lib/db/repositories/backfilledRanges.d.ts.map +0 -1
  280. package/lib/db/repositories/blobSidecars.d.ts.map +0 -1
  281. package/lib/db/repositories/blobSidecarsArchive.d.ts.map +0 -1
  282. package/lib/db/repositories/block.d.ts.map +0 -1
  283. package/lib/db/repositories/blockArchive.d.ts.map +0 -1
  284. package/lib/db/repositories/blockArchiveIndex.d.ts.map +0 -1
  285. package/lib/db/repositories/blsToExecutionChange.d.ts.map +0 -1
  286. package/lib/db/repositories/checkpointState.d.ts.map +0 -1
  287. package/lib/db/repositories/dataColumnSidecar.d.ts.map +0 -1
  288. package/lib/db/repositories/dataColumnSidecarArchive.d.ts.map +0 -1
  289. package/lib/db/repositories/depositDataRoot.d.ts.map +0 -1
  290. package/lib/db/repositories/depositEvent.d.ts.map +0 -1
  291. package/lib/db/repositories/eth1Data.d.ts.map +0 -1
  292. package/lib/db/repositories/index.d.ts.map +0 -1
  293. package/lib/db/repositories/lightclientBestUpdate.d.ts.map +0 -1
  294. package/lib/db/repositories/lightclientCheckpointHeader.d.ts.map +0 -1
  295. package/lib/db/repositories/lightclientSyncCommittee.d.ts.map +0 -1
  296. package/lib/db/repositories/lightclientSyncCommitteeWitness.d.ts.map +0 -1
  297. package/lib/db/repositories/proposerSlashing.d.ts.map +0 -1
  298. package/lib/db/repositories/stateArchive.d.ts.map +0 -1
  299. package/lib/db/repositories/stateArchiveIndex.d.ts.map +0 -1
  300. package/lib/db/repositories/voluntaryExit.d.ts.map +0 -1
  301. package/lib/db/single/index.d.ts.map +0 -1
  302. package/lib/db/single/preGenesisState.d.ts.map +0 -1
  303. package/lib/db/single/preGenesisStateLastProcessedBlock.d.ts.map +0 -1
  304. package/lib/eth1/errors.d.ts.map +0 -1
  305. package/lib/eth1/eth1DataCache.d.ts.map +0 -1
  306. package/lib/eth1/eth1DepositDataTracker.d.ts.map +0 -1
  307. package/lib/eth1/eth1DepositsCache.d.ts.map +0 -1
  308. package/lib/eth1/eth1MergeBlockTracker.d.ts.map +0 -1
  309. package/lib/eth1/index.d.ts.map +0 -1
  310. package/lib/eth1/interface.d.ts.map +0 -1
  311. package/lib/eth1/options.d.ts.map +0 -1
  312. package/lib/eth1/provider/eth1Provider.d.ts.map +0 -1
  313. package/lib/eth1/provider/jsonRpcHttpClient.d.ts.map +0 -1
  314. package/lib/eth1/provider/jwt.d.ts.map +0 -1
  315. package/lib/eth1/provider/utils.d.ts.map +0 -1
  316. package/lib/eth1/stream.d.ts.map +0 -1
  317. package/lib/eth1/utils/depositContract.d.ts.map +0 -1
  318. package/lib/eth1/utils/deposits.d.ts.map +0 -1
  319. package/lib/eth1/utils/eth1Data.d.ts.map +0 -1
  320. package/lib/eth1/utils/eth1DepositEvent.d.ts.map +0 -1
  321. package/lib/eth1/utils/eth1Vote.d.ts.map +0 -1
  322. package/lib/eth1/utils/groupDepositEventsByBlock.d.ts.map +0 -1
  323. package/lib/eth1/utils/optimizeNextBlockDiffForGenesis.d.ts.map +0 -1
  324. package/lib/execution/builder/cache.d.ts.map +0 -1
  325. package/lib/execution/builder/http.d.ts.map +0 -1
  326. package/lib/execution/builder/index.d.ts.map +0 -1
  327. package/lib/execution/builder/interface.d.ts.map +0 -1
  328. package/lib/execution/builder/utils.d.ts.map +0 -1
  329. package/lib/execution/engine/disabled.d.ts.map +0 -1
  330. package/lib/execution/engine/http.d.ts.map +0 -1
  331. package/lib/execution/engine/index.d.ts.map +0 -1
  332. package/lib/execution/engine/interface.d.ts.map +0 -1
  333. package/lib/execution/engine/mock.d.ts.map +0 -1
  334. package/lib/execution/engine/payloadIdCache.d.ts.map +0 -1
  335. package/lib/execution/engine/types.d.ts.map +0 -1
  336. package/lib/execution/engine/utils.d.ts.map +0 -1
  337. package/lib/execution/index.d.ts.map +0 -1
  338. package/lib/index.d.ts.map +0 -1
  339. package/lib/metrics/index.d.ts.map +0 -1
  340. package/lib/metrics/metrics/beacon.d.ts.map +0 -1
  341. package/lib/metrics/metrics/lodestar.d.ts.map +0 -1
  342. package/lib/metrics/metrics.d.ts.map +0 -1
  343. package/lib/metrics/nodeJsMetrics.d.ts.map +0 -1
  344. package/lib/metrics/options.d.ts.map +0 -1
  345. package/lib/metrics/server/http.d.ts.map +0 -1
  346. package/lib/metrics/server/index.d.ts.map +0 -1
  347. package/lib/metrics/utils/avgMinMax.d.ts.map +0 -1
  348. package/lib/metrics/utils/gauge.d.ts.map +0 -1
  349. package/lib/metrics/utils/registryMetricCreator.d.ts.map +0 -1
  350. package/lib/monitoring/clientStats.d.ts.map +0 -1
  351. package/lib/monitoring/index.d.ts.map +0 -1
  352. package/lib/monitoring/options.d.ts.map +0 -1
  353. package/lib/monitoring/properties.d.ts.map +0 -1
  354. package/lib/monitoring/service.d.ts.map +0 -1
  355. package/lib/monitoring/system.d.ts.map +0 -1
  356. package/lib/monitoring/types.d.ts.map +0 -1
  357. package/lib/network/core/events.d.ts.map +0 -1
  358. package/lib/network/core/index.d.ts.map +0 -1
  359. package/lib/network/core/metrics.d.ts.map +0 -1
  360. package/lib/network/core/networkCore.d.ts.map +0 -1
  361. package/lib/network/core/networkCoreWorker.d.ts.map +0 -1
  362. package/lib/network/core/networkCoreWorkerHandler.d.ts.map +0 -1
  363. package/lib/network/core/types.d.ts.map +0 -1
  364. package/lib/network/discv5/index.d.ts.map +0 -1
  365. package/lib/network/discv5/types.d.ts.map +0 -1
  366. package/lib/network/discv5/utils.d.ts.map +0 -1
  367. package/lib/network/discv5/worker.d.ts.map +0 -1
  368. package/lib/network/events.d.ts.map +0 -1
  369. package/lib/network/forks.d.ts.map +0 -1
  370. package/lib/network/gossip/constants.d.ts.map +0 -1
  371. package/lib/network/gossip/encoding.d.ts.map +0 -1
  372. package/lib/network/gossip/errors.d.ts.map +0 -1
  373. package/lib/network/gossip/gossipsub.d.ts.map +0 -1
  374. package/lib/network/gossip/index.d.ts.map +0 -1
  375. package/lib/network/gossip/interface.d.ts.map +0 -1
  376. package/lib/network/gossip/metrics.d.ts.map +0 -1
  377. package/lib/network/gossip/scoringParameters.d.ts.map +0 -1
  378. package/lib/network/gossip/topic.d.ts.map +0 -1
  379. package/lib/network/index.d.ts.map +0 -1
  380. package/lib/network/interface.d.ts.map +0 -1
  381. package/lib/network/libp2p/error.d.ts.map +0 -1
  382. package/lib/network/libp2p/index.d.ts.map +0 -1
  383. package/lib/network/metadata.d.ts.map +0 -1
  384. package/lib/network/network.d.ts.map +0 -1
  385. package/lib/network/networkConfig.d.ts.map +0 -1
  386. package/lib/network/options.d.ts.map +0 -1
  387. package/lib/network/peers/client.d.ts.map +0 -1
  388. package/lib/network/peers/datastore.d.ts.map +0 -1
  389. package/lib/network/peers/discover.d.ts.map +0 -1
  390. package/lib/network/peers/index.d.ts.map +0 -1
  391. package/lib/network/peers/peerManager.d.ts.map +0 -1
  392. package/lib/network/peers/peersData.d.ts.map +0 -1
  393. package/lib/network/peers/score/constants.d.ts.map +0 -1
  394. package/lib/network/peers/score/index.d.ts.map +0 -1
  395. package/lib/network/peers/score/interface.d.ts.map +0 -1
  396. package/lib/network/peers/score/score.d.ts.map +0 -1
  397. package/lib/network/peers/score/store.d.ts.map +0 -1
  398. package/lib/network/peers/score/utils.d.ts.map +0 -1
  399. package/lib/network/peers/utils/assertPeerRelevance.d.ts.map +0 -1
  400. package/lib/network/peers/utils/enrSubnetsDeserialize.d.ts.map +0 -1
  401. package/lib/network/peers/utils/getConnectedPeerIds.d.ts.map +0 -1
  402. package/lib/network/peers/utils/index.d.ts.map +0 -1
  403. package/lib/network/peers/utils/prioritizePeers.d.ts.map +0 -1
  404. package/lib/network/peers/utils/subnetMap.d.ts.map +0 -1
  405. package/lib/network/processor/aggregatorTracker.d.ts.map +0 -1
  406. package/lib/network/processor/extractSlotRootFns.d.ts.map +0 -1
  407. package/lib/network/processor/gossipHandlers.d.ts.map +0 -1
  408. package/lib/network/processor/gossipQueues/index.d.ts.map +0 -1
  409. package/lib/network/processor/gossipQueues/indexed.d.ts.map +0 -1
  410. package/lib/network/processor/gossipQueues/linear.d.ts.map +0 -1
  411. package/lib/network/processor/gossipQueues/types.d.ts.map +0 -1
  412. package/lib/network/processor/gossipValidatorFn.d.ts.map +0 -1
  413. package/lib/network/processor/index.d.ts.map +0 -1
  414. package/lib/network/processor/types.d.ts.map +0 -1
  415. package/lib/network/reqresp/ReqRespBeaconNode.d.ts.map +0 -1
  416. package/lib/network/reqresp/handlers/beaconBlocksByRange.d.ts.map +0 -1
  417. package/lib/network/reqresp/handlers/beaconBlocksByRoot.d.ts.map +0 -1
  418. package/lib/network/reqresp/handlers/blobSidecarsByRange.d.ts.map +0 -1
  419. package/lib/network/reqresp/handlers/blobSidecarsByRoot.d.ts.map +0 -1
  420. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts.map +0 -1
  421. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.d.ts.map +0 -1
  422. package/lib/network/reqresp/handlers/index.d.ts.map +0 -1
  423. package/lib/network/reqresp/handlers/lightClientBootstrap.d.ts.map +0 -1
  424. package/lib/network/reqresp/handlers/lightClientFinalityUpdate.d.ts.map +0 -1
  425. package/lib/network/reqresp/handlers/lightClientOptimisticUpdate.d.ts.map +0 -1
  426. package/lib/network/reqresp/handlers/lightClientUpdatesByRange.d.ts.map +0 -1
  427. package/lib/network/reqresp/index.d.ts.map +0 -1
  428. package/lib/network/reqresp/interface.d.ts.map +0 -1
  429. package/lib/network/reqresp/protocols.d.ts.map +0 -1
  430. package/lib/network/reqresp/rateLimit.d.ts.map +0 -1
  431. package/lib/network/reqresp/score.d.ts.map +0 -1
  432. package/lib/network/reqresp/types.d.ts.map +0 -1
  433. package/lib/network/reqresp/utils/collect.d.ts.map +0 -1
  434. package/lib/network/reqresp/utils/collectSequentialBlocksInRange.d.ts.map +0 -1
  435. package/lib/network/reqresp/utils/dataColumnResponseValidation.d.ts.map +0 -1
  436. package/lib/network/statusCache.d.ts.map +0 -1
  437. package/lib/network/subnets/attnetsService.d.ts.map +0 -1
  438. package/lib/network/subnets/index.d.ts.map +0 -1
  439. package/lib/network/subnets/interface.d.ts.map +0 -1
  440. package/lib/network/subnets/syncnetsService.d.ts.map +0 -1
  441. package/lib/network/subnets/util.d.ts.map +0 -1
  442. package/lib/network/util.d.ts.map +0 -1
  443. package/lib/node/index.d.ts.map +0 -1
  444. package/lib/node/nodejs.d.ts.map +0 -1
  445. package/lib/node/notifier.d.ts.map +0 -1
  446. package/lib/node/options.d.ts.map +0 -1
  447. package/lib/node/utils/interop/deposits.d.ts.map +0 -1
  448. package/lib/node/utils/interop/state.d.ts.map +0 -1
  449. package/lib/node/utils/lightclient.d.ts.map +0 -1
  450. package/lib/node/utils/state.d.ts.map +0 -1
  451. package/lib/sync/backfill/backfill.d.ts.map +0 -1
  452. package/lib/sync/backfill/errors.d.ts.map +0 -1
  453. package/lib/sync/backfill/index.d.ts.map +0 -1
  454. package/lib/sync/backfill/verify.d.ts.map +0 -1
  455. package/lib/sync/constants.d.ts.map +0 -1
  456. package/lib/sync/index.d.ts.map +0 -1
  457. package/lib/sync/interface.d.ts.map +0 -1
  458. package/lib/sync/options.d.ts.map +0 -1
  459. package/lib/sync/range/batch.d.ts.map +0 -1
  460. package/lib/sync/range/chain.d.ts.map +0 -1
  461. package/lib/sync/range/range.d.ts.map +0 -1
  462. package/lib/sync/range/utils/batches.d.ts.map +0 -1
  463. package/lib/sync/range/utils/chainTarget.d.ts.map +0 -1
  464. package/lib/sync/range/utils/hashBlocks.d.ts.map +0 -1
  465. package/lib/sync/range/utils/index.d.ts.map +0 -1
  466. package/lib/sync/range/utils/peerBalancer.d.ts.map +0 -1
  467. package/lib/sync/range/utils/updateChains.d.ts.map +0 -1
  468. package/lib/sync/sync.d.ts.map +0 -1
  469. package/lib/sync/types.d.ts.map +0 -1
  470. package/lib/sync/unknownBlock.d.ts.map +0 -1
  471. package/lib/sync/utils/downloadByRange.d.ts.map +0 -1
  472. package/lib/sync/utils/downloadByRoot.d.ts.map +0 -1
  473. package/lib/sync/utils/pendingBlocksTree.d.ts.map +0 -1
  474. package/lib/sync/utils/remoteSyncType.d.ts.map +0 -1
  475. package/lib/util/address.d.ts.map +0 -1
  476. package/lib/util/array.d.ts.map +0 -1
  477. package/lib/util/asyncIterableToEvents.d.ts.map +0 -1
  478. package/lib/util/binarySearch.d.ts.map +0 -1
  479. package/lib/util/bitArray.d.ts.map +0 -1
  480. package/lib/util/blobs.d.ts.map +0 -1
  481. package/lib/util/bufferPool.d.ts.map +0 -1
  482. package/lib/util/bytes.d.ts.map +0 -1
  483. package/lib/util/chunkify.d.ts.map +0 -1
  484. package/lib/util/clock.d.ts.map +0 -1
  485. package/lib/util/dataColumns.d.ts.map +0 -1
  486. package/lib/util/dependentRoot.d.ts.map +0 -1
  487. package/lib/util/enum.d.ts.map +0 -1
  488. package/lib/util/error.d.ts.map +0 -1
  489. package/lib/util/eventLoop.d.ts.map +0 -1
  490. package/lib/util/execution.d.ts.map +0 -1
  491. package/lib/util/file.d.ts.map +0 -1
  492. package/lib/util/forkChoice.d.ts.map +0 -1
  493. package/lib/util/forkName.d.ts.map +0 -1
  494. package/lib/util/graffiti.d.ts.map +0 -1
  495. package/lib/util/hex.d.ts.map +0 -1
  496. package/lib/util/index.d.ts.map +0 -1
  497. package/lib/util/ip.d.ts.map +0 -1
  498. package/lib/util/itTrigger.d.ts.map +0 -1
  499. package/lib/util/kzg.d.ts.map +0 -1
  500. package/lib/util/map.d.ts.map +0 -1
  501. package/lib/util/metadata.d.ts.map +0 -1
  502. package/lib/util/multifork.d.ts.map +0 -1
  503. package/lib/util/numpy.d.ts.map +0 -1
  504. package/lib/util/peerId.d.ts.map +0 -1
  505. package/lib/util/profile.d.ts.map +0 -1
  506. package/lib/util/promises.d.ts.map +0 -1
  507. package/lib/util/queue/errors.d.ts.map +0 -1
  508. package/lib/util/queue/fnQueue.d.ts.map +0 -1
  509. package/lib/util/queue/index.d.ts.map +0 -1
  510. package/lib/util/queue/itemQueue.d.ts.map +0 -1
  511. package/lib/util/queue/options.d.ts.map +0 -1
  512. package/lib/util/serializedCache.d.ts.map +0 -1
  513. package/lib/util/set.d.ts.map +0 -1
  514. package/lib/util/shuffle.d.ts.map +0 -1
  515. package/lib/util/sortBy.d.ts.map +0 -1
  516. package/lib/util/sszBytes.d.ts.map +0 -1
  517. package/lib/util/strictEvents.d.ts.map +0 -1
  518. package/lib/util/time.d.ts.map +0 -1
  519. package/lib/util/timeSeries.d.ts.map +0 -1
  520. package/lib/util/types.d.ts.map +0 -1
  521. package/lib/util/workerEvents.d.ts.map +0 -1
  522. package/lib/util/wrapError.d.ts.map +0 -1
  523. package/src/api/impl/api.ts +0 -26
  524. package/src/api/impl/beacon/blocks/index.ts +0 -744
  525. package/src/api/impl/beacon/blocks/utils.ts +0 -75
  526. package/src/api/impl/beacon/index.ts +0 -35
  527. package/src/api/impl/beacon/pool/index.ts +0 -314
  528. package/src/api/impl/beacon/rewards/index.ts +0 -30
  529. package/src/api/impl/beacon/state/index.ts +0 -406
  530. package/src/api/impl/beacon/state/utils.ts +0 -189
  531. package/src/api/impl/config/constants.ts +0 -127
  532. package/src/api/impl/config/index.ts +0 -59
  533. package/src/api/impl/debug/index.ts +0 -131
  534. package/src/api/impl/errors.ts +0 -50
  535. package/src/api/impl/events/index.ts +0 -33
  536. package/src/api/impl/index.ts +0 -6
  537. package/src/api/impl/lightclient/index.ts +0 -64
  538. package/src/api/impl/lodestar/index.ts +0 -257
  539. package/src/api/impl/node/index.ts +0 -88
  540. package/src/api/impl/node/utils.ts +0 -51
  541. package/src/api/impl/proof/index.ts +0 -60
  542. package/src/api/impl/types.ts +0 -17
  543. package/src/api/impl/utils.ts +0 -25
  544. package/src/api/impl/validator/index.ts +0 -1540
  545. package/src/api/impl/validator/utils.ts +0 -85
  546. package/src/api/index.ts +0 -2
  547. package/src/api/options.ts +0 -16
  548. package/src/api/rest/activeSockets.ts +0 -109
  549. package/src/api/rest/base.ts +0 -216
  550. package/src/api/rest/index.ts +0 -63
  551. package/src/api/rest/swaggerUI.ts +0 -80
  552. package/src/bun-wrappers/prometheus-gc-stats.ts +0 -7
  553. package/src/chain/ColumnReconstructionTracker.ts +0 -90
  554. package/src/chain/GetBlobsTracker.ts +0 -115
  555. package/src/chain/archiveStore/archiveStore.ts +0 -222
  556. package/src/chain/archiveStore/constants.ts +0 -5
  557. package/src/chain/archiveStore/historicalState/getHistoricalState.ts +0 -116
  558. package/src/chain/archiveStore/historicalState/historicalStateRegen.ts +0 -68
  559. package/src/chain/archiveStore/historicalState/metrics.ts +0 -214
  560. package/src/chain/archiveStore/historicalState/types.ts +0 -41
  561. package/src/chain/archiveStore/historicalState/worker.ts +0 -77
  562. package/src/chain/archiveStore/index.ts +0 -3
  563. package/src/chain/archiveStore/interface.ts +0 -75
  564. package/src/chain/archiveStore/strategies/frequencyStateArchiveStrategy.ts +0 -138
  565. package/src/chain/archiveStore/utils/archiveBlocks.ts +0 -437
  566. package/src/chain/archiveStore/utils/pruneHistory.ts +0 -56
  567. package/src/chain/archiveStore/utils/updateBackfillRange.ts +0 -50
  568. package/src/chain/balancesCache.ts +0 -52
  569. package/src/chain/beaconProposerCache.ts +0 -43
  570. package/src/chain/blocks/blockInput/blockInput.ts +0 -852
  571. package/src/chain/blocks/blockInput/errors.ts +0 -48
  572. package/src/chain/blocks/blockInput/index.ts +0 -4
  573. package/src/chain/blocks/blockInput/types.ts +0 -145
  574. package/src/chain/blocks/blockInput/utils.ts +0 -21
  575. package/src/chain/blocks/importBlock.ts +0 -597
  576. package/src/chain/blocks/index.ts +0 -179
  577. package/src/chain/blocks/types.ts +0 -101
  578. package/src/chain/blocks/utils/blowfishBanner.ts +0 -28
  579. package/src/chain/blocks/utils/chainSegment.ts +0 -29
  580. package/src/chain/blocks/utils/checkpoint.ts +0 -25
  581. package/src/chain/blocks/utils/giraffeBanner.ts +0 -30
  582. package/src/chain/blocks/utils/ownBanner.ts +0 -20
  583. package/src/chain/blocks/utils/pandaMergeTransitionBanner.ts +0 -43
  584. package/src/chain/blocks/utils/zebraBanner.ts +0 -45
  585. package/src/chain/blocks/verifyBlock.ts +0 -242
  586. package/src/chain/blocks/verifyBlocksDataAvailability.ts +0 -42
  587. package/src/chain/blocks/verifyBlocksExecutionPayloads.ts +0 -438
  588. package/src/chain/blocks/verifyBlocksSanityChecks.ts +0 -129
  589. package/src/chain/blocks/verifyBlocksSignatures.ts +0 -105
  590. package/src/chain/blocks/verifyBlocksStateTransitionOnly.ts +0 -114
  591. package/src/chain/blocks/writeBlockInputToDb.ts +0 -120
  592. package/src/chain/bls/index.ts +0 -4
  593. package/src/chain/bls/interface.ts +0 -68
  594. package/src/chain/bls/maybeBatch.ts +0 -45
  595. package/src/chain/bls/multithread/index.ts +0 -582
  596. package/src/chain/bls/multithread/jobItem.ts +0 -119
  597. package/src/chain/bls/multithread/poolSize.ts +0 -16
  598. package/src/chain/bls/multithread/types.ts +0 -38
  599. package/src/chain/bls/multithread/utils.ts +0 -19
  600. package/src/chain/bls/multithread/worker.ts +0 -114
  601. package/src/chain/bls/singleThread.ts +0 -87
  602. package/src/chain/bls/utils.ts +0 -30
  603. package/src/chain/chain.ts +0 -1354
  604. package/src/chain/emitter.ts +0 -113
  605. package/src/chain/errors/attestationError.ts +0 -194
  606. package/src/chain/errors/attesterSlashingError.ts +0 -11
  607. package/src/chain/errors/blobSidecarError.ts +0 -60
  608. package/src/chain/errors/blockError.ts +0 -166
  609. package/src/chain/errors/blsToExecutionChangeError.ts +0 -13
  610. package/src/chain/errors/dataColumnSidecarError.ts +0 -80
  611. package/src/chain/errors/gossipValidation.ts +0 -20
  612. package/src/chain/errors/index.ts +0 -10
  613. package/src/chain/errors/lightClientError.ts +0 -30
  614. package/src/chain/errors/proposerSlashingError.ts +0 -11
  615. package/src/chain/errors/syncCommitteeError.ts +0 -36
  616. package/src/chain/errors/voluntaryExitError.ts +0 -13
  617. package/src/chain/forkChoice/index.ts +0 -112
  618. package/src/chain/genesis/genesis.ts +0 -190
  619. package/src/chain/genesis/interface.ts +0 -14
  620. package/src/chain/index.ts +0 -6
  621. package/src/chain/initState.ts +0 -221
  622. package/src/chain/interface.ts +0 -280
  623. package/src/chain/lightClient/index.ts +0 -764
  624. package/src/chain/lightClient/proofs.ts +0 -85
  625. package/src/chain/lightClient/types.ts +0 -33
  626. package/src/chain/opPools/aggregatedAttestationPool.ts +0 -1063
  627. package/src/chain/opPools/attestationPool.ts +0 -282
  628. package/src/chain/opPools/index.ts +0 -5
  629. package/src/chain/opPools/opPool.ts +0 -462
  630. package/src/chain/opPools/syncCommitteeMessagePool.ts +0 -169
  631. package/src/chain/opPools/syncContributionAndProofPool.ts +0 -240
  632. package/src/chain/opPools/types.ts +0 -35
  633. package/src/chain/opPools/utils.ts +0 -65
  634. package/src/chain/options.ts +0 -138
  635. package/src/chain/prepareNextSlot.ts +0 -277
  636. package/src/chain/produceBlock/computeNewStateRoot.ts +0 -55
  637. package/src/chain/produceBlock/index.ts +0 -2
  638. package/src/chain/produceBlock/produceBlockBody.ts +0 -797
  639. package/src/chain/produceBlock/validateBlobsAndKzgCommitments.ts +0 -54
  640. package/src/chain/regen/errors.ts +0 -30
  641. package/src/chain/regen/index.ts +0 -4
  642. package/src/chain/regen/interface.ts +0 -93
  643. package/src/chain/regen/queued.ts +0 -317
  644. package/src/chain/regen/regen.ts +0 -424
  645. package/src/chain/reprocess.ts +0 -161
  646. package/src/chain/rewards/attestationsRewards.ts +0 -196
  647. package/src/chain/rewards/blockRewards.ts +0 -150
  648. package/src/chain/rewards/syncCommitteeRewards.ts +0 -58
  649. package/src/chain/seenCache/index.ts +0 -5
  650. package/src/chain/seenCache/seenAggregateAndProof.ts +0 -120
  651. package/src/chain/seenCache/seenAttestationData.ts +0 -145
  652. package/src/chain/seenCache/seenAttesters.ts +0 -58
  653. package/src/chain/seenCache/seenBlockAttesters.ts +0 -18
  654. package/src/chain/seenCache/seenBlockProposers.ts +0 -48
  655. package/src/chain/seenCache/seenCommittee.ts +0 -43
  656. package/src/chain/seenCache/seenCommitteeContribution.ts +0 -104
  657. package/src/chain/seenCache/seenGossipBlockInput.ts +0 -373
  658. package/src/chain/serializeState.ts +0 -32
  659. package/src/chain/shufflingCache.ts +0 -238
  660. package/src/chain/stateCache/blockStateCacheImpl.ts +0 -150
  661. package/src/chain/stateCache/datastore/db.ts +0 -36
  662. package/src/chain/stateCache/datastore/file.ts +0 -53
  663. package/src/chain/stateCache/datastore/index.ts +0 -2
  664. package/src/chain/stateCache/datastore/types.ts +0 -13
  665. package/src/chain/stateCache/fifoBlockStateCache.ts +0 -208
  666. package/src/chain/stateCache/inMemoryCheckpointsCache.ts +0 -198
  667. package/src/chain/stateCache/index.ts +0 -3
  668. package/src/chain/stateCache/mapMetrics.ts +0 -52
  669. package/src/chain/stateCache/persistentCheckpointsCache.ts +0 -837
  670. package/src/chain/stateCache/types.ts +0 -86
  671. package/src/chain/validation/aggregateAndProof.ts +0 -258
  672. package/src/chain/validation/attestation.ts +0 -885
  673. package/src/chain/validation/attesterSlashing.ts +0 -61
  674. package/src/chain/validation/blobSidecar.ts +0 -301
  675. package/src/chain/validation/block.ts +0 -188
  676. package/src/chain/validation/blsToExecutionChange.ts +0 -61
  677. package/src/chain/validation/dataColumnSidecar.ts +0 -381
  678. package/src/chain/validation/index.ts +0 -9
  679. package/src/chain/validation/lightClientFinalityUpdate.ts +0 -46
  680. package/src/chain/validation/lightClientOptimisticUpdate.ts +0 -68
  681. package/src/chain/validation/proposerSlashing.ts +0 -54
  682. package/src/chain/validation/signatureSets/aggregateAndProof.ts +0 -38
  683. package/src/chain/validation/signatureSets/contributionAndProof.ts +0 -27
  684. package/src/chain/validation/signatureSets/index.ts +0 -6
  685. package/src/chain/validation/signatureSets/selectionProof.ts +0 -27
  686. package/src/chain/validation/signatureSets/syncCommittee.ts +0 -22
  687. package/src/chain/validation/signatureSets/syncCommitteeContribution.ts +0 -18
  688. package/src/chain/validation/signatureSets/syncCommitteeSelectionProof.ts +0 -27
  689. package/src/chain/validation/syncCommittee.ts +0 -165
  690. package/src/chain/validation/syncCommitteeContributionAndProof.ts +0 -122
  691. package/src/chain/validation/voluntaryExit.ts +0 -58
  692. package/src/chain/validatorMonitor.ts +0 -1309
  693. package/src/constants/constants.ts +0 -15
  694. package/src/constants/index.ts +0 -2
  695. package/src/constants/network.ts +0 -52
  696. package/src/db/beacon.ts +0 -113
  697. package/src/db/buckets.ts +0 -80
  698. package/src/db/index.ts +0 -2
  699. package/src/db/interface.ts +0 -76
  700. package/src/db/options.ts +0 -7
  701. package/src/db/repositories/attesterSlashing.ts +0 -38
  702. package/src/db/repositories/backfilledRanges.ts +0 -29
  703. package/src/db/repositories/blobSidecars.ts +0 -37
  704. package/src/db/repositories/blobSidecarsArchive.ts +0 -28
  705. package/src/db/repositories/block.ts +0 -33
  706. package/src/db/repositories/blockArchive.ts +0 -170
  707. package/src/db/repositories/blockArchiveIndex.ts +0 -45
  708. package/src/db/repositories/blsToExecutionChange.ts +0 -16
  709. package/src/db/repositories/checkpointState.ts +0 -31
  710. package/src/db/repositories/dataColumnSidecar.ts +0 -49
  711. package/src/db/repositories/dataColumnSidecarArchive.ts +0 -56
  712. package/src/db/repositories/depositDataRoot.ts +0 -80
  713. package/src/db/repositories/depositEvent.ts +0 -32
  714. package/src/db/repositories/eth1Data.ts +0 -33
  715. package/src/db/repositories/index.ts +0 -20
  716. package/src/db/repositories/lightclientBestUpdate.ts +0 -41
  717. package/src/db/repositories/lightclientCheckpointHeader.ts +0 -32
  718. package/src/db/repositories/lightclientSyncCommittee.ts +0 -16
  719. package/src/db/repositories/lightclientSyncCommitteeWitness.ts +0 -77
  720. package/src/db/repositories/proposerSlashing.ts +0 -15
  721. package/src/db/repositories/stateArchive.ts +0 -69
  722. package/src/db/repositories/stateArchiveIndex.ts +0 -18
  723. package/src/db/repositories/voluntaryExit.ts +0 -15
  724. package/src/db/single/index.ts +0 -2
  725. package/src/db/single/preGenesisState.ts +0 -37
  726. package/src/db/single/preGenesisStateLastProcessedBlock.ts +0 -34
  727. package/src/eth1/errors.ts +0 -40
  728. package/src/eth1/eth1DataCache.ts +0 -26
  729. package/src/eth1/eth1DepositDataTracker.ts +0 -410
  730. package/src/eth1/eth1DepositsCache.ts +0 -141
  731. package/src/eth1/eth1MergeBlockTracker.ts +0 -328
  732. package/src/eth1/index.ts +0 -157
  733. package/src/eth1/interface.ts +0 -131
  734. package/src/eth1/options.ts +0 -28
  735. package/src/eth1/provider/eth1Provider.ts +0 -229
  736. package/src/eth1/provider/jsonRpcHttpClient.ts +0 -390
  737. package/src/eth1/provider/jwt.ts +0 -36
  738. package/src/eth1/provider/utils.ts +0 -136
  739. package/src/eth1/stream.ts +0 -75
  740. package/src/eth1/utils/depositContract.ts +0 -37
  741. package/src/eth1/utils/deposits.ts +0 -70
  742. package/src/eth1/utils/eth1Data.ts +0 -100
  743. package/src/eth1/utils/eth1DepositEvent.ts +0 -12
  744. package/src/eth1/utils/eth1Vote.ts +0 -142
  745. package/src/eth1/utils/groupDepositEventsByBlock.ts +0 -19
  746. package/src/eth1/utils/optimizeNextBlockDiffForGenesis.ts +0 -18
  747. package/src/execution/builder/cache.ts +0 -39
  748. package/src/execution/builder/http.ts +0 -229
  749. package/src/execution/builder/index.ts +0 -27
  750. package/src/execution/builder/interface.ts +0 -49
  751. package/src/execution/builder/utils.ts +0 -19
  752. package/src/execution/engine/disabled.ts +0 -35
  753. package/src/execution/engine/http.ts +0 -644
  754. package/src/execution/engine/index.ts +0 -63
  755. package/src/execution/engine/interface.ts +0 -199
  756. package/src/execution/engine/mock.ts +0 -493
  757. package/src/execution/engine/payloadIdCache.ts +0 -54
  758. package/src/execution/engine/types.ts +0 -640
  759. package/src/execution/engine/utils.ts +0 -136
  760. package/src/execution/index.ts +0 -4
  761. package/src/index.ts +0 -20
  762. package/src/metrics/index.ts +0 -4
  763. package/src/metrics/metrics/beacon.ts +0 -390
  764. package/src/metrics/metrics/lodestar.ts +0 -1870
  765. package/src/metrics/metrics.ts +0 -43
  766. package/src/metrics/nodeJsMetrics.ts +0 -19
  767. package/src/metrics/options.ts +0 -22
  768. package/src/metrics/server/http.ts +0 -114
  769. package/src/metrics/server/index.ts +0 -1
  770. package/src/metrics/utils/avgMinMax.ts +0 -87
  771. package/src/metrics/utils/gauge.ts +0 -22
  772. package/src/metrics/utils/registryMetricCreator.ts +0 -41
  773. package/src/monitoring/clientStats.ts +0 -297
  774. package/src/monitoring/index.ts +0 -2
  775. package/src/monitoring/options.ts +0 -19
  776. package/src/monitoring/properties.ts +0 -152
  777. package/src/monitoring/service.ts +0 -235
  778. package/src/monitoring/system.ts +0 -146
  779. package/src/monitoring/types.ts +0 -21
  780. package/src/network/core/events.ts +0 -59
  781. package/src/network/core/index.ts +0 -3
  782. package/src/network/core/metrics.ts +0 -304
  783. package/src/network/core/networkCore.ts +0 -599
  784. package/src/network/core/networkCoreWorker.ts +0 -176
  785. package/src/network/core/networkCoreWorkerHandler.ts +0 -284
  786. package/src/network/core/types.ts +0 -119
  787. package/src/network/discv5/index.ts +0 -132
  788. package/src/network/discv5/types.ts +0 -74
  789. package/src/network/discv5/utils.ts +0 -50
  790. package/src/network/discv5/worker.ts +0 -137
  791. package/src/network/events.ts +0 -51
  792. package/src/network/forks.ts +0 -94
  793. package/src/network/gossip/constants.ts +0 -15
  794. package/src/network/gossip/encoding.ts +0 -111
  795. package/src/network/gossip/errors.ts +0 -7
  796. package/src/network/gossip/gossipsub.ts +0 -384
  797. package/src/network/gossip/index.ts +0 -4
  798. package/src/network/gossip/interface.ts +0 -215
  799. package/src/network/gossip/metrics.ts +0 -71
  800. package/src/network/gossip/scoringParameters.ts +0 -333
  801. package/src/network/gossip/topic.ts +0 -332
  802. package/src/network/index.ts +0 -8
  803. package/src/network/interface.ts +0 -134
  804. package/src/network/libp2p/error.ts +0 -55
  805. package/src/network/libp2p/index.ts +0 -153
  806. package/src/network/metadata.ts +0 -162
  807. package/src/network/network.ts +0 -767
  808. package/src/network/networkConfig.ts +0 -12
  809. package/src/network/options.ts +0 -70
  810. package/src/network/peers/client.ts +0 -29
  811. package/src/network/peers/datastore.ts +0 -188
  812. package/src/network/peers/discover.ts +0 -647
  813. package/src/network/peers/index.ts +0 -2
  814. package/src/network/peers/peerManager.ts +0 -899
  815. package/src/network/peers/peersData.ts +0 -65
  816. package/src/network/peers/score/constants.ts +0 -34
  817. package/src/network/peers/score/index.ts +0 -4
  818. package/src/network/peers/score/interface.ts +0 -74
  819. package/src/network/peers/score/score.ts +0 -200
  820. package/src/network/peers/score/store.ts +0 -95
  821. package/src/network/peers/score/utils.ts +0 -37
  822. package/src/network/peers/utils/assertPeerRelevance.ts +0 -99
  823. package/src/network/peers/utils/enrSubnetsDeserialize.ts +0 -27
  824. package/src/network/peers/utils/getConnectedPeerIds.ts +0 -33
  825. package/src/network/peers/utils/index.ts +0 -4
  826. package/src/network/peers/utils/prioritizePeers.ts +0 -627
  827. package/src/network/peers/utils/subnetMap.ts +0 -88
  828. package/src/network/processor/aggregatorTracker.ts +0 -38
  829. package/src/network/processor/extractSlotRootFns.ts +0 -64
  830. package/src/network/processor/gossipHandlers.ts +0 -951
  831. package/src/network/processor/gossipQueues/index.ts +0 -114
  832. package/src/network/processor/gossipQueues/indexed.ts +0 -219
  833. package/src/network/processor/gossipQueues/linear.ts +0 -162
  834. package/src/network/processor/gossipQueues/types.ts +0 -57
  835. package/src/network/processor/gossipValidatorFn.ts +0 -142
  836. package/src/network/processor/index.ts +0 -496
  837. package/src/network/processor/types.ts +0 -27
  838. package/src/network/reqresp/ReqRespBeaconNode.ts +0 -373
  839. package/src/network/reqresp/handlers/beaconBlocksByRange.ts +0 -101
  840. package/src/network/reqresp/handlers/beaconBlocksByRoot.ts +0 -49
  841. package/src/network/reqresp/handlers/blobSidecarsByRange.ts +0 -114
  842. package/src/network/reqresp/handlers/blobSidecarsByRoot.ts +0 -62
  843. package/src/network/reqresp/handlers/dataColumnSidecarsByRange.ts +0 -144
  844. package/src/network/reqresp/handlers/dataColumnSidecarsByRoot.ts +0 -88
  845. package/src/network/reqresp/handlers/index.ts +0 -78
  846. package/src/network/reqresp/handlers/lightClientBootstrap.ts +0 -31
  847. package/src/network/reqresp/handlers/lightClientFinalityUpdate.ts +0 -21
  848. package/src/network/reqresp/handlers/lightClientOptimisticUpdate.ts +0 -21
  849. package/src/network/reqresp/handlers/lightClientUpdatesByRange.ts +0 -39
  850. package/src/network/reqresp/index.ts +0 -2
  851. package/src/network/reqresp/interface.ts +0 -45
  852. package/src/network/reqresp/protocols.ts +0 -146
  853. package/src/network/reqresp/rateLimit.ts +0 -112
  854. package/src/network/reqresp/score.ts +0 -70
  855. package/src/network/reqresp/types.ts +0 -174
  856. package/src/network/reqresp/utils/collect.ts +0 -84
  857. package/src/network/reqresp/utils/collectSequentialBlocksInRange.ts +0 -57
  858. package/src/network/reqresp/utils/dataColumnResponseValidation.ts +0 -99
  859. package/src/network/statusCache.ts +0 -17
  860. package/src/network/subnets/attnetsService.ts +0 -385
  861. package/src/network/subnets/index.ts +0 -2
  862. package/src/network/subnets/interface.ts +0 -66
  863. package/src/network/subnets/syncnetsService.ts +0 -147
  864. package/src/network/subnets/util.ts +0 -63
  865. package/src/network/util.ts +0 -29
  866. package/src/node/index.ts +0 -2
  867. package/src/node/nodejs.ts +0 -349
  868. package/src/node/notifier.ts +0 -206
  869. package/src/node/options.ts +0 -51
  870. package/src/node/utils/interop/deposits.ts +0 -53
  871. package/src/node/utils/interop/state.ts +0 -59
  872. package/src/node/utils/lightclient.ts +0 -7
  873. package/src/node/utils/state.ts +0 -37
  874. package/src/sync/backfill/backfill.ts +0 -893
  875. package/src/sync/backfill/errors.ts +0 -23
  876. package/src/sync/backfill/index.ts +0 -1
  877. package/src/sync/backfill/verify.ts +0 -58
  878. package/src/sync/constants.ts +0 -71
  879. package/src/sync/index.ts +0 -2
  880. package/src/sync/interface.ts +0 -55
  881. package/src/sync/options.ts +0 -45
  882. package/src/sync/range/batch.ts +0 -455
  883. package/src/sync/range/chain.ts +0 -715
  884. package/src/sync/range/range.ts +0 -354
  885. package/src/sync/range/utils/batches.ts +0 -119
  886. package/src/sync/range/utils/chainTarget.ts +0 -62
  887. package/src/sync/range/utils/hashBlocks.ts +0 -27
  888. package/src/sync/range/utils/index.ts +0 -5
  889. package/src/sync/range/utils/peerBalancer.ts +0 -184
  890. package/src/sync/range/utils/updateChains.ts +0 -66
  891. package/src/sync/sync.ts +0 -290
  892. package/src/sync/types.ts +0 -57
  893. package/src/sync/unknownBlock.ts +0 -859
  894. package/src/sync/utils/downloadByRange.ts +0 -808
  895. package/src/sync/utils/downloadByRoot.ts +0 -560
  896. package/src/sync/utils/pendingBlocksTree.ts +0 -97
  897. package/src/sync/utils/remoteSyncType.ts +0 -144
  898. package/src/util/address.ts +0 -3
  899. package/src/util/array.ts +0 -311
  900. package/src/util/asyncIterableToEvents.ts +0 -164
  901. package/src/util/binarySearch.ts +0 -48
  902. package/src/util/bitArray.ts +0 -84
  903. package/src/util/blobs.ts +0 -210
  904. package/src/util/bufferPool.ts +0 -95
  905. package/src/util/bytes.ts +0 -11
  906. package/src/util/chunkify.ts +0 -27
  907. package/src/util/clock.ts +0 -212
  908. package/src/util/dataColumns.ts +0 -415
  909. package/src/util/dependentRoot.ts +0 -47
  910. package/src/util/enum.ts +0 -17
  911. package/src/util/error.ts +0 -56
  912. package/src/util/eventLoop.ts +0 -22
  913. package/src/util/execution.ts +0 -223
  914. package/src/util/file.ts +0 -52
  915. package/src/util/forkChoice.ts +0 -5
  916. package/src/util/forkName.ts +0 -20
  917. package/src/util/graffiti.ts +0 -39
  918. package/src/util/hex.ts +0 -9
  919. package/src/util/index.ts +0 -2
  920. package/src/util/ip.ts +0 -6
  921. package/src/util/itTrigger.ts +0 -49
  922. package/src/util/kzg.ts +0 -3
  923. package/src/util/map.ts +0 -77
  924. package/src/util/metadata.ts +0 -22
  925. package/src/util/multifork.ts +0 -69
  926. package/src/util/numpy.ts +0 -8
  927. package/src/util/peerId.ts +0 -16
  928. package/src/util/profile.ts +0 -54
  929. package/src/util/promises.ts +0 -14
  930. package/src/util/queue/errors.ts +0 -14
  931. package/src/util/queue/fnQueue.ts +0 -16
  932. package/src/util/queue/index.ts +0 -4
  933. package/src/util/queue/itemQueue.ts +0 -128
  934. package/src/util/queue/options.ts +0 -37
  935. package/src/util/serializedCache.ts +0 -20
  936. package/src/util/set.ts +0 -62
  937. package/src/util/shuffle.ts +0 -21
  938. package/src/util/sortBy.ts +0 -19
  939. package/src/util/sszBytes.ts +0 -481
  940. package/src/util/strictEvents.ts +0 -8
  941. package/src/util/time.ts +0 -13
  942. package/src/util/timeSeries.ts +0 -118
  943. package/src/util/types.ts +0 -31
  944. package/src/util/workerEvents.ts +0 -142
  945. package/src/util/wrapError.ts +0 -27
@@ -1,951 +0,0 @@
1
- import {routes} from "@lodestar/api";
2
- import {BeaconConfig, ChainForkConfig} from "@lodestar/config";
3
- import {
4
- ForkName,
5
- ForkPostElectra,
6
- ForkPreElectra,
7
- ForkSeq,
8
- NUMBER_OF_COLUMNS,
9
- isForkPostElectra,
10
- } from "@lodestar/params";
11
- import {computeTimeAtSlot} from "@lodestar/state-transition";
12
- import {
13
- Root,
14
- SignedBeaconBlock,
15
- SingleAttestation,
16
- Slot,
17
- SubnetID,
18
- UintNum64,
19
- deneb,
20
- fulu,
21
- ssz,
22
- sszTypesFor,
23
- } from "@lodestar/types";
24
- import {LogLevel, Logger, prettyBytes, toHex, toRootHex} from "@lodestar/utils";
25
- import {
26
- BlockInput,
27
- BlockInputColumns,
28
- BlockInputSource,
29
- IBlockInput,
30
- isBlockInputColumns,
31
- } from "../../chain/blocks/blockInput/index.js";
32
- import {BlobSidecarValidation} from "../../chain/blocks/types.js";
33
- import {ChainEvent} from "../../chain/emitter.js";
34
- import {
35
- AttestationError,
36
- AttestationErrorCode,
37
- BlobSidecarErrorCode,
38
- BlobSidecarGossipError,
39
- BlockError,
40
- BlockErrorCode,
41
- BlockGossipError,
42
- DataColumnSidecarGossipError,
43
- GossipAction,
44
- GossipActionError,
45
- SyncCommitteeError,
46
- } from "../../chain/errors/index.js";
47
- import {IBeaconChain} from "../../chain/interface.js";
48
- import {validateGossipBlobSidecar} from "../../chain/validation/blobSidecar.js";
49
- import {validateGossipDataColumnSidecar} from "../../chain/validation/dataColumnSidecar.js";
50
- import {
51
- AggregateAndProofValidationResult,
52
- GossipAttestation,
53
- toElectraSingleAttestation,
54
- validateGossipAggregateAndProof,
55
- validateGossipAttestationsSameAttData,
56
- validateGossipAttesterSlashing,
57
- validateGossipBlock,
58
- validateGossipBlsToExecutionChange,
59
- validateGossipProposerSlashing,
60
- validateGossipSyncCommittee,
61
- validateGossipVoluntaryExit,
62
- validateSyncCommitteeGossipContributionAndProof,
63
- } from "../../chain/validation/index.js";
64
- import {validateLightClientFinalityUpdate} from "../../chain/validation/lightClientFinalityUpdate.js";
65
- import {validateLightClientOptimisticUpdate} from "../../chain/validation/lightClientOptimisticUpdate.js";
66
- import {OpSource} from "../../chain/validatorMonitor.js";
67
- import {Metrics} from "../../metrics/index.js";
68
- import {kzgCommitmentToVersionedHash} from "../../util/blobs.js";
69
- import {INetworkCore} from "../core/index.js";
70
- import {NetworkEventBus} from "../events.js";
71
- import {
72
- BatchGossipHandlers,
73
- GossipHandlerParamGeneric,
74
- GossipHandlers,
75
- GossipType,
76
- SequentialGossipHandlers,
77
- } from "../gossip/interface.js";
78
- import {sszDeserialize} from "../gossip/topic.js";
79
- import {INetwork} from "../interface.js";
80
- import {PeerAction} from "../peers/index.js";
81
- import {AggregatorTracker} from "./aggregatorTracker.js";
82
-
83
- /**
84
- * Gossip handler options as part of network options
85
- */
86
- export type GossipHandlerOpts = {
87
- /** By default pass gossip attestations to forkchoice */
88
- dontSendGossipAttestationsToForkchoice?: boolean;
89
- };
90
-
91
- export type ValidatorFnsModules = {
92
- chain: IBeaconChain;
93
- config: BeaconConfig;
94
- logger: Logger;
95
- metrics: Metrics | null;
96
- events: NetworkEventBus;
97
- aggregatorTracker: AggregatorTracker;
98
- core: INetworkCore;
99
- };
100
-
101
- const MAX_UNKNOWN_BLOCK_ROOT_RETRIES = 1;
102
- const BLOCK_AVAILABILITY_CUTOFF_MS = 3_000;
103
-
104
- /**
105
- * Gossip handlers perform validation + handling in a single function.
106
- * - This gossip handlers MUST only be registered as validator functions. No handler is registered for any topic.
107
- * - All `chain/validation/*` functions MUST throw typed GossipActionError instances so they gossip action is captured
108
- * by `getGossipValidatorFn()` try catch block.
109
- * - This gossip handlers should not let any handling errors propagate to the caller. Only validation errors must be thrown.
110
- *
111
- * Note: `libp2p/js-libp2p-interfaces` would normally indicate to register separate validator functions and handler functions.
112
- * This approach is not suitable for us because:
113
- * - We do expensive processing on the object in the validator function that we need to re-use in the handler function.
114
- * - The validator function produces extra data that is needed for the handler function. Making this data available in
115
- * the handler function scope is hard to achieve without very hacky strategies
116
- * - Ethereum Consensus gossipsub protocol strictly defined a single topic for message
117
- */
118
- export function getGossipHandlers(modules: ValidatorFnsModules, options: GossipHandlerOpts): GossipHandlers {
119
- return {...getSequentialHandlers(modules, options), ...getBatchHandlers(modules, options)};
120
- }
121
-
122
- /**
123
- * Default handlers validate gossip messages one by one.
124
- * We only have a choice to do batch validation for beacon_attestation topic.
125
- */
126
- function getSequentialHandlers(modules: ValidatorFnsModules, options: GossipHandlerOpts): SequentialGossipHandlers {
127
- const {chain, config, metrics, logger, core} = modules;
128
-
129
- async function validateBeaconBlock(
130
- signedBlock: SignedBeaconBlock,
131
- fork: ForkName,
132
- peerIdStr: string,
133
- seenTimestampSec: number
134
- ): Promise<IBlockInput> {
135
- const slot = signedBlock.message.slot;
136
- const forkTypes = config.getForkTypes(slot);
137
- const blockRootHex = toRootHex(forkTypes.BeaconBlock.hashTreeRoot(signedBlock.message));
138
- const blockShortHex = prettyBytes(blockRootHex);
139
- const delaySec = chain.clock.secFromSlot(slot, seenTimestampSec);
140
- const recvToValLatency = Date.now() / 1000 - seenTimestampSec;
141
-
142
- // always set block to seen cache for all forks so that we don't need to download it
143
- // TODO: validate block before adding to cache
144
- // tracked in https://github.com/ChainSafe/lodestar/issues/7957
145
-
146
- const logCtx = {
147
- currentSlot: chain.clock.currentSlot,
148
- peerId: peerIdStr,
149
- delaySec,
150
- recvToValLatency,
151
- };
152
-
153
- logger.debug("Received gossip block", {...logCtx});
154
-
155
- let blockInput: IBlockInput | undefined;
156
- try {
157
- await validateGossipBlock(config, chain, signedBlock, fork);
158
- blockInput = chain.seenBlockInputCache.getByBlock({
159
- block: signedBlock,
160
- blockRootHex,
161
- source: BlockInputSource.gossip,
162
- seenTimestampSec,
163
- peerIdStr,
164
- });
165
- const blockInputMeta = blockInput.getLogMeta();
166
-
167
- const recvToValidation = Date.now() / 1000 - seenTimestampSec;
168
- const validationTime = recvToValidation - recvToValLatency;
169
-
170
- metrics?.gossipBlock.gossipValidation.recvToValidation.observe(recvToValidation);
171
- metrics?.gossipBlock.gossipValidation.validationTime.observe(validationTime);
172
-
173
- logger.debug("Validated gossip block", {...blockInputMeta, ...logCtx, recvToValidation, validationTime});
174
-
175
- chain.emitter.emit(routes.events.EventType.blockGossip, {slot, block: blockRootHex});
176
-
177
- return blockInput;
178
- } catch (e) {
179
- if (e instanceof BlockGossipError) {
180
- if (e.type.code === BlockErrorCode.PARENT_UNKNOWN && blockInput) {
181
- logger.debug("Gossip block has error", {slot, root: blockShortHex, code: e.type.code});
182
- chain.emitter.emit(ChainEvent.unknownParent, {
183
- blockInput,
184
- peer: peerIdStr,
185
- source: BlockInputSource.gossip,
186
- });
187
- // throw error (don't prune the blockInput)
188
- throw e;
189
- }
190
-
191
- if (e.action === GossipAction.REJECT) {
192
- chain.persistInvalidSszValue(forkTypes.SignedBeaconBlock, signedBlock, `gossip_reject_slot_${slot}`);
193
- }
194
- }
195
-
196
- chain.seenBlockInputCache.prune(blockRootHex);
197
- throw e;
198
- }
199
- }
200
-
201
- async function validateBeaconBlob(
202
- blobSidecar: deneb.BlobSidecar,
203
- subnet: SubnetID,
204
- peerIdStr: string,
205
- seenTimestampSec: number
206
- ): Promise<BlockInput> {
207
- const blobBlockHeader = blobSidecar.signedBlockHeader.message;
208
- const slot = blobBlockHeader.slot;
209
- const fork = config.getForkName(slot);
210
- const blockRootHex = toRootHex(ssz.phase0.BeaconBlockHeader.hashTreeRoot(blobBlockHeader));
211
- const blockShortHex = prettyBytes(blockRootHex);
212
-
213
- const delaySec = chain.clock.secFromSlot(slot, seenTimestampSec);
214
- const recvToValLatency = Date.now() / 1000 - seenTimestampSec;
215
-
216
- try {
217
- await validateGossipBlobSidecar(fork, chain, blobSidecar, subnet);
218
- const blockInput = chain.seenBlockInputCache.getByBlob({
219
- blockRootHex,
220
- blobSidecar,
221
- source: BlockInputSource.gossip,
222
- seenTimestampSec,
223
- peerIdStr,
224
- });
225
- const recvToValidation = Date.now() / 1000 - seenTimestampSec;
226
- const validationTime = recvToValidation - recvToValLatency;
227
-
228
- metrics?.gossipBlob.recvToValidation.observe(recvToValidation);
229
- metrics?.gossipBlob.validationTime.observe(validationTime);
230
-
231
- if (chain.emitter.listenerCount(routes.events.EventType.blobSidecar)) {
232
- let versionedHash: Uint8Array;
233
- if (blockInput.hasBlock()) {
234
- // if block hasn't arrived yet then this will throw and need to calculate the versionedHash as a 1-off
235
- versionedHash = blockInput.getVersionedHashes()[blobSidecar.index];
236
- } else {
237
- versionedHash = kzgCommitmentToVersionedHash(blobSidecar.kzgCommitment);
238
- }
239
- chain.emitter.emit(routes.events.EventType.blobSidecar, {
240
- blockRoot: blockRootHex,
241
- slot,
242
- index: blobSidecar.index,
243
- kzgCommitment: toHex(blobSidecar.kzgCommitment),
244
- versionedHash: toHex(versionedHash),
245
- });
246
- }
247
-
248
- logger.debug("Received gossip blob", {
249
- ...blockInput.getLogMeta(),
250
- currentSlot: chain.clock.currentSlot,
251
- peerId: peerIdStr,
252
- delaySec,
253
- subnet,
254
- recvToValLatency,
255
- recvToValidation,
256
- validationTime,
257
- });
258
-
259
- return blockInput;
260
- } catch (e) {
261
- if (e instanceof BlobSidecarGossipError) {
262
- // Don't trigger this yet if full block and blobs haven't arrived yet
263
- if (e.type.code === BlobSidecarErrorCode.PARENT_UNKNOWN) {
264
- logger.debug("Gossip blob has error", {slot, root: blockShortHex, code: e.type.code});
265
- // no need to trigger `unknownBlockParent` event here, as we already did it in `validateBeaconBlock()`
266
- //
267
- // TODO(fulu): is this note above correct? Could have random blob that we see that could trigger
268
- // unknownBlockSync. And duplicate addition of a block will be deduplicated by the
269
- // BlockInputSync event handler. Check this!!
270
- // events.emit(NetworkEvent.unknownBlockParent, {blockInput, peer: peerIdStr});
271
- }
272
-
273
- if (e.action === GossipAction.REJECT) {
274
- chain.persistInvalidSszValue(
275
- ssz.deneb.BlobSidecar,
276
- blobSidecar,
277
- `gossip_reject_slot_${slot}_index_${blobSidecar.index}`
278
- );
279
- }
280
- }
281
-
282
- throw e;
283
- }
284
- }
285
-
286
- async function validateBeaconDataColumn(
287
- dataColumnSidecar: fulu.DataColumnSidecar,
288
- _dataColumnBytes: Uint8Array,
289
- gossipSubnet: SubnetID,
290
- peerIdStr: string,
291
- seenTimestampSec: number
292
- ): Promise<BlockInputColumns> {
293
- metrics?.peerDas.dataColumnSidecarProcessingRequests.inc();
294
- const dataColumnBlockHeader = dataColumnSidecar.signedBlockHeader.message;
295
- const slot = dataColumnBlockHeader.slot;
296
- const blockRootHex = toRootHex(ssz.phase0.BeaconBlockHeader.hashTreeRoot(dataColumnBlockHeader));
297
-
298
- // first check if we should even process this column (we may have already processed it via getBlobsV2)
299
- {
300
- const blockInput = chain.seenBlockInputCache.get(blockRootHex);
301
- if (blockInput && isBlockInputColumns(blockInput) && blockInput.hasColumn(dataColumnSidecar.index)) {
302
- metrics?.peerDas.dataColumnSidecarProcessingSkip.inc();
303
- logger.debug("Already have column sidecar, skipping processing", {
304
- ...blockInput.getLogMeta(),
305
- index: dataColumnSidecar.index,
306
- });
307
- return blockInput;
308
- }
309
- }
310
-
311
- const verificationTimer = metrics?.peerDas.dataColumnSidecarGossipVerificationTime.startTimer();
312
-
313
- const delaySec = chain.clock.secFromSlot(slot, seenTimestampSec);
314
- const recvToValLatency = Date.now() / 1000 - seenTimestampSec;
315
-
316
- try {
317
- await validateGossipDataColumnSidecar(chain, dataColumnSidecar, gossipSubnet, metrics);
318
- const blockInput = chain.seenBlockInputCache.getByColumn({
319
- blockRootHex,
320
- columnSidecar: dataColumnSidecar,
321
- source: BlockInputSource.gossip,
322
- seenTimestampSec,
323
- peerIdStr,
324
- });
325
-
326
- const recvToValidation = Date.now() / 1000 - seenTimestampSec;
327
- const validationTime = recvToValidation - recvToValLatency;
328
-
329
- metrics?.peerDas.dataColumnSidecarProcessingSuccesses.inc();
330
- metrics?.gossipBlob.recvToValidation.observe(recvToValidation);
331
- metrics?.gossipBlob.validationTime.observe(validationTime);
332
-
333
- if (chain.emitter.listenerCount(routes.events.EventType.dataColumnSidecar)) {
334
- chain.emitter.emit(routes.events.EventType.dataColumnSidecar, {
335
- blockRoot: blockRootHex,
336
- slot,
337
- index: dataColumnSidecar.index,
338
- kzgCommitments: dataColumnSidecar.kzgCommitments.map(toHex),
339
- });
340
- }
341
-
342
- logger.debug("Received gossip dataColumn", {
343
- ...blockInput.getLogMeta(),
344
- currentSlot: chain.clock.currentSlot,
345
- peerId: peerIdStr,
346
- delaySec,
347
- gossipSubnet,
348
- columnIndex: dataColumnSidecar.index,
349
- recvToValLatency,
350
- recvToValidation,
351
- validationTime,
352
- });
353
-
354
- return blockInput;
355
- } catch (e) {
356
- if (e instanceof DataColumnSidecarGossipError && e.action === GossipAction.REJECT) {
357
- chain.persistInvalidSszValue(
358
- ssz.fulu.DataColumnSidecar,
359
- dataColumnSidecar,
360
- `gossip_reject_slot_${slot}_index_${dataColumnSidecar.index}`
361
- );
362
- // no need to trigger `unknownBlockParent` event here, as we already did it in `validateBeaconBlock()`
363
- //
364
- // TODO(fulu): is this note above correct? Could have random column that we see that could trigger
365
- // unknownBlockSync. And duplicate addition of a block will be deduplicated by the
366
- // BlockInputSync event handler. Check this!!
367
- // events.emit(NetworkEvent.unknownBlockParent, {blockInput, peer: peerIdStr});
368
- }
369
-
370
- throw e;
371
- } finally {
372
- verificationTimer?.();
373
- }
374
- }
375
-
376
- function handleValidBeaconBlock(blockInput: IBlockInput, peerIdStr: string, seenTimestampSec: number): void {
377
- const signedBlock = blockInput.getBlock();
378
- const slot = signedBlock.message.slot;
379
-
380
- // Handler - MUST NOT `await`, to allow validation result to be propagated
381
-
382
- const delaySec = seenTimestampSec - (chain.genesisTime + slot * config.SECONDS_PER_SLOT);
383
- metrics?.gossipBlock.elapsedTimeTillReceived.observe({source: OpSource.gossip}, delaySec);
384
- chain.validatorMonitor?.registerBeaconBlock(OpSource.gossip, delaySec, signedBlock.message);
385
- if (!blockInput.hasBlockAndAllData()) {
386
- chain.logger.debug("Received gossip block, attempting fetch of unavailable data", blockInput.getLogMeta());
387
- // The data is not yet fully available, immediately trigger an aggressive pull via unknown block sync
388
- chain.emitter.emit(ChainEvent.incompleteBlockInput, {
389
- blockInput,
390
- peer: peerIdStr,
391
- source: BlockInputSource.gossip,
392
- });
393
- // immediately attempt fetch of data columns from execution engine
394
- chain.getBlobsTracker.triggerGetBlobs(blockInput);
395
- } else {
396
- metrics?.blockInputFetchStats.totalDataAvailableBlockInputs.inc();
397
- metrics?.blockInputFetchStats.totalDataAvailableBlockInputBlobs.inc(
398
- (signedBlock.message as deneb.BeaconBlock).body.blobKzgCommitments.length
399
- );
400
- }
401
-
402
- chain
403
- .processBlock(blockInput, {
404
- // block may be downloaded and processed by UnknownBlockSync
405
- ignoreIfKnown: true,
406
- // proposer signature already checked in validateBeaconBlock()
407
- validProposerSignature: true,
408
- // blobSidecars already checked in validateGossipBlobSidecars()
409
- validBlobSidecars: BlobSidecarValidation.Individual,
410
- // It's critical to keep a good number of mesh peers.
411
- // To do that, the Gossip Job Wait Time should be consistently <3s to avoid the behavior penalties in gossip
412
- // Gossip Job Wait Time depends on the BLS Job Wait Time
413
- // so `blsVerifyOnMainThread = true`: we want to verify signatures immediately without affecting the bls thread pool.
414
- // otherwise we can't utilize bls thread pool capacity and Gossip Job Wait Time can't be kept low consistently.
415
- // See https://github.com/ChainSafe/lodestar/issues/3792
416
- blsVerifyOnMainThread: true,
417
- // to track block process steps
418
- seenTimestampSec,
419
- // gossip block is validated, we want to process it asap
420
- eagerPersistBlock: true,
421
- })
422
- .then(() => {
423
- // Returns the delay between the start of `block.slot` and `current time`
424
- const delaySec = chain.clock.secFromSlot(slot);
425
- metrics?.gossipBlock.elapsedTimeTillProcessed.observe(delaySec);
426
- chain.seenBlockInputCache.prune(blockInput.blockRootHex);
427
- })
428
- .catch((e) => {
429
- // Adjust verbosity based on error type
430
- let logLevel: LogLevel;
431
-
432
- if (e instanceof BlockError) {
433
- switch (e.type.code) {
434
- case BlockErrorCode.DATA_UNAVAILABLE: {
435
- // Error is quite frequent and not critical
436
- logLevel = LogLevel.debug;
437
- break;
438
- }
439
- // ALREADY_KNOWN should not happen with ignoreIfKnown=true above
440
- // PARENT_UNKNOWN should not happen, we handled this in validateBeaconBlock() function above
441
- case BlockErrorCode.ALREADY_KNOWN:
442
- case BlockErrorCode.PARENT_UNKNOWN:
443
- case BlockErrorCode.PRESTATE_MISSING:
444
- case BlockErrorCode.EXECUTION_ENGINE_ERROR:
445
- // Errors might indicate an issue with our node or the connected EL client
446
- logLevel = LogLevel.error;
447
- break;
448
- default:
449
- // TODO: Should it use PeerId or string?
450
- core.reportPeer(peerIdStr, PeerAction.LowToleranceError, "BadGossipBlock");
451
- // Misbehaving peer, but could highlight an issue in another client
452
- logLevel = LogLevel.warn;
453
- }
454
- } else {
455
- // Any unexpected error
456
- logLevel = LogLevel.error;
457
- }
458
- metrics?.gossipBlock.processBlockErrors.inc({error: e instanceof BlockError ? e.type.code : "NOT_BLOCK_ERROR"});
459
- logger[logLevel](
460
- "Error processing block",
461
- {slot, peer: peerIdStr, blockRoot: prettyBytes(blockInput.blockRootHex)},
462
- e as Error
463
- );
464
- // TODO(fulu): Revisit when we prune block inputs
465
- chain.seenBlockInputCache.prune(blockInput.blockRootHex);
466
- });
467
- }
468
-
469
- return {
470
- [GossipType.beacon_block]: async ({
471
- gossipData,
472
- topic,
473
- peerIdStr,
474
- seenTimestampSec,
475
- }: GossipHandlerParamGeneric<GossipType.beacon_block>) => {
476
- const {serializedData} = gossipData;
477
-
478
- const signedBlock = sszDeserialize(topic, serializedData);
479
- const blockInput = await validateBeaconBlock(signedBlock, topic.boundary.fork, peerIdStr, seenTimestampSec);
480
- chain.serializedCache.set(signedBlock, serializedData);
481
- handleValidBeaconBlock(blockInput, peerIdStr, seenTimestampSec);
482
- },
483
-
484
- [GossipType.blob_sidecar]: async ({
485
- gossipData,
486
- topic,
487
- peerIdStr,
488
- seenTimestampSec,
489
- }: GossipHandlerParamGeneric<GossipType.blob_sidecar>) => {
490
- const {serializedData} = gossipData;
491
- const blobSidecar = sszDeserialize(topic, serializedData);
492
- const blobSlot = blobSidecar.signedBlockHeader.message.slot;
493
- const index = blobSidecar.index;
494
-
495
- if (config.getForkSeq(blobSlot) < ForkSeq.deneb) {
496
- throw new GossipActionError(GossipAction.REJECT, {code: "PRE_DENEB_BLOCK"});
497
- }
498
- const blockInput = await validateBeaconBlob(blobSidecar, topic.subnet, peerIdStr, seenTimestampSec);
499
- if (!blockInput.hasBlockAndAllData()) {
500
- const cutoffTimeMs = getCutoffTimeMs(chain, blobSlot, BLOCK_AVAILABILITY_CUTOFF_MS);
501
- chain.logger.debug("Received gossip blob, waiting for full data availability", {
502
- msToWait: cutoffTimeMs,
503
- blobIndex: index,
504
- ...blockInput.getLogMeta(),
505
- });
506
- blockInput.waitForAllData(cutoffTimeMs).catch((_e) => {
507
- chain.logger.debug(
508
- "Waited for data after receiving gossip blob. Cut-off reached so attempting to fetch remainder of BlockInput",
509
- {
510
- blobIndex: index,
511
- ...blockInput.getLogMeta(),
512
- }
513
- );
514
- chain.emitter.emit(ChainEvent.incompleteBlockInput, {
515
- blockInput,
516
- peer: peerIdStr,
517
- source: BlockInputSource.gossip,
518
- });
519
- });
520
- }
521
- },
522
-
523
- [GossipType.data_column_sidecar]: async ({
524
- gossipData,
525
- topic,
526
- peerIdStr,
527
- seenTimestampSec,
528
- }: GossipHandlerParamGeneric<GossipType.data_column_sidecar>) => {
529
- const {serializedData} = gossipData;
530
- const dataColumnSidecar = sszDeserialize(topic, serializedData);
531
- const dataColumnSlot = dataColumnSidecar.signedBlockHeader.message.slot;
532
- const index = dataColumnSidecar.index;
533
-
534
- if (config.getForkSeq(dataColumnSlot) < ForkSeq.fulu) {
535
- throw new GossipActionError(GossipAction.REJECT, {code: "PRE_FULU_BLOCK"});
536
- }
537
- const delaySec = chain.clock.secFromSlot(dataColumnSlot, seenTimestampSec);
538
- const blockInput = await validateBeaconDataColumn(
539
- dataColumnSidecar,
540
- serializedData,
541
- topic.subnet,
542
- peerIdStr,
543
- seenTimestampSec
544
- );
545
- const blockInputMeta = blockInput.getLogMeta();
546
- const {receivedColumns} = blockInputMeta;
547
- // it's not helpful to track every single column received
548
- // instead of that, track 1st, 8th, 16th 32th, 64th, and 128th column
549
- switch (receivedColumns) {
550
- case 1:
551
- case config.SAMPLES_PER_SLOT:
552
- case 2 * config.SAMPLES_PER_SLOT:
553
- case NUMBER_OF_COLUMNS / 4:
554
- case NUMBER_OF_COLUMNS / 2:
555
- case NUMBER_OF_COLUMNS:
556
- metrics?.dataColumns.elapsedTimeTillReceived.observe({receivedOrder: receivedColumns}, delaySec);
557
- break;
558
- }
559
- if (!blockInput.hasBlockAndAllData()) {
560
- const cutoffTimeMs = getCutoffTimeMs(chain, dataColumnSlot, BLOCK_AVAILABILITY_CUTOFF_MS);
561
- chain.logger.debug("Received gossip data column, waiting for full data availability", {
562
- msToWait: cutoffTimeMs,
563
- dataColumnIndex: index,
564
- ...blockInputMeta,
565
- });
566
- // do not await here to not delay gossip validation
567
- blockInput.waitForBlockAndAllData(cutoffTimeMs).catch((_e) => {
568
- chain.logger.debug(
569
- "Waited for data after receiving gossip column. Cut-off reached so attempting to fetch remainder of BlockInput",
570
- {
571
- dataColumnIndex: index,
572
- ...blockInputMeta,
573
- }
574
- );
575
- chain.emitter.emit(ChainEvent.incompleteBlockInput, {
576
- blockInput,
577
- peer: peerIdStr,
578
- source: BlockInputSource.gossip,
579
- });
580
- });
581
- // immediately attempt fetch of data columns from execution engine
582
- chain.getBlobsTracker.triggerGetBlobs(blockInput);
583
- // if we've received at least half of the columns, trigger reconstruction of the rest
584
- if (blockInput.columnCount >= NUMBER_OF_COLUMNS / 2) {
585
- chain.columnReconstructionTracker.triggerColumnReconstruction(blockInput);
586
- }
587
- }
588
- },
589
-
590
- [GossipType.beacon_aggregate_and_proof]: async ({
591
- gossipData,
592
- topic,
593
- seenTimestampSec,
594
- }: GossipHandlerParamGeneric<GossipType.beacon_aggregate_and_proof>) => {
595
- const {serializedData} = gossipData;
596
- let validationResult: AggregateAndProofValidationResult;
597
- const signedAggregateAndProof = sszDeserialize(topic, serializedData);
598
- const {fork} = topic.boundary;
599
-
600
- try {
601
- validationResult = await validateGossipAggregateAndProof(fork, chain, signedAggregateAndProof, serializedData);
602
- } catch (e) {
603
- if (e instanceof AttestationError && e.action === GossipAction.REJECT) {
604
- chain.persistInvalidSszValue(
605
- sszTypesFor(fork).SignedAggregateAndProof,
606
- signedAggregateAndProof,
607
- "gossip_reject"
608
- );
609
- }
610
- throw e;
611
- }
612
-
613
- // Handler
614
- const {indexedAttestation, committeeValidatorIndices, attDataRootHex} = validationResult;
615
- chain.validatorMonitor?.registerGossipAggregatedAttestation(
616
- seenTimestampSec,
617
- signedAggregateAndProof,
618
- indexedAttestation
619
- );
620
- const aggregatedAttestation = signedAggregateAndProof.message.aggregate;
621
-
622
- const insertOutcome = chain.aggregatedAttestationPool.add(
623
- aggregatedAttestation,
624
- attDataRootHex,
625
- indexedAttestation.attestingIndices.length,
626
- committeeValidatorIndices
627
- );
628
- metrics?.opPool.aggregatedAttestationPool.gossipInsertOutcome.inc({insertOutcome});
629
-
630
- if (!options.dontSendGossipAttestationsToForkchoice) {
631
- try {
632
- chain.forkChoice.onAttestation(indexedAttestation, attDataRootHex);
633
- } catch (e) {
634
- logger.debug(
635
- "Error adding gossip aggregated attestation to forkchoice",
636
- {slot: aggregatedAttestation.data.slot},
637
- e as Error
638
- );
639
- }
640
- }
641
-
642
- chain.emitter.emit(routes.events.EventType.attestation, signedAggregateAndProof.message.aggregate);
643
- },
644
-
645
- [GossipType.attester_slashing]: async ({
646
- gossipData,
647
- topic,
648
- }: GossipHandlerParamGeneric<GossipType.attester_slashing>) => {
649
- const {serializedData} = gossipData;
650
- const {fork} = topic.boundary;
651
- const attesterSlashing = sszDeserialize(topic, serializedData);
652
- await validateGossipAttesterSlashing(chain, attesterSlashing);
653
-
654
- // Handler
655
-
656
- try {
657
- chain.opPool.insertAttesterSlashing(fork, attesterSlashing);
658
- chain.forkChoice.onAttesterSlashing(attesterSlashing);
659
- } catch (e) {
660
- logger.error("Error adding attesterSlashing to pool", {}, e as Error);
661
- }
662
-
663
- chain.emitter.emit(routes.events.EventType.attesterSlashing, attesterSlashing);
664
- },
665
-
666
- [GossipType.proposer_slashing]: async ({
667
- gossipData,
668
- topic,
669
- }: GossipHandlerParamGeneric<GossipType.proposer_slashing>) => {
670
- const {serializedData} = gossipData;
671
- const proposerSlashing = sszDeserialize(topic, serializedData);
672
- await validateGossipProposerSlashing(chain, proposerSlashing);
673
-
674
- // Handler
675
-
676
- try {
677
- chain.opPool.insertProposerSlashing(proposerSlashing);
678
- } catch (e) {
679
- logger.error("Error adding attesterSlashing to pool", {}, e as Error);
680
- }
681
-
682
- chain.emitter.emit(routes.events.EventType.proposerSlashing, proposerSlashing);
683
- },
684
-
685
- [GossipType.voluntary_exit]: async ({gossipData, topic}: GossipHandlerParamGeneric<GossipType.voluntary_exit>) => {
686
- const {serializedData} = gossipData;
687
- const voluntaryExit = sszDeserialize(topic, serializedData);
688
- await validateGossipVoluntaryExit(chain, voluntaryExit);
689
-
690
- // Handler
691
-
692
- try {
693
- chain.opPool.insertVoluntaryExit(voluntaryExit);
694
- } catch (e) {
695
- logger.error("Error adding voluntaryExit to pool", {}, e as Error);
696
- }
697
-
698
- chain.emitter.emit(routes.events.EventType.voluntaryExit, voluntaryExit);
699
- },
700
-
701
- [GossipType.sync_committee_contribution_and_proof]: async ({
702
- gossipData,
703
- topic,
704
- }: GossipHandlerParamGeneric<GossipType.sync_committee_contribution_and_proof>) => {
705
- const {serializedData} = gossipData;
706
- const contributionAndProof = sszDeserialize(topic, serializedData);
707
- const {syncCommitteeParticipantIndices} = await validateSyncCommitteeGossipContributionAndProof(
708
- chain,
709
- contributionAndProof
710
- ).catch((e) => {
711
- if (e instanceof SyncCommitteeError && e.action === GossipAction.REJECT) {
712
- chain.persistInvalidSszValue(ssz.altair.SignedContributionAndProof, contributionAndProof, "gossip_reject");
713
- }
714
- throw e;
715
- });
716
-
717
- // Handler
718
- chain.validatorMonitor?.registerGossipSyncContributionAndProof(
719
- contributionAndProof.message,
720
- syncCommitteeParticipantIndices
721
- );
722
- try {
723
- const insertOutcome = chain.syncContributionAndProofPool.add(
724
- contributionAndProof.message,
725
- syncCommitteeParticipantIndices.length
726
- );
727
- metrics?.opPool.syncContributionAndProofPool.gossipInsertOutcome.inc({insertOutcome});
728
- } catch (e) {
729
- logger.error("Error adding to contributionAndProof pool", {}, e as Error);
730
- }
731
-
732
- chain.emitter.emit(routes.events.EventType.contributionAndProof, contributionAndProof);
733
- },
734
-
735
- [GossipType.sync_committee]: async ({gossipData, topic}: GossipHandlerParamGeneric<GossipType.sync_committee>) => {
736
- const {serializedData} = gossipData;
737
- const syncCommittee = sszDeserialize(topic, serializedData);
738
- const {subnet} = topic;
739
- let indexInSubcommittee = 0;
740
- try {
741
- indexInSubcommittee = (await validateGossipSyncCommittee(chain, syncCommittee, subnet)).indexInSubcommittee;
742
- } catch (e) {
743
- if (e instanceof SyncCommitteeError && e.action === GossipAction.REJECT) {
744
- chain.persistInvalidSszValue(ssz.altair.SyncCommitteeMessage, syncCommittee, "gossip_reject");
745
- }
746
- throw e;
747
- }
748
-
749
- // Handler
750
-
751
- try {
752
- const insertOutcome = chain.syncCommitteeMessagePool.add(subnet, syncCommittee, indexInSubcommittee);
753
- metrics?.opPool.syncCommitteeMessagePoolInsertOutcome.inc({insertOutcome});
754
- } catch (e) {
755
- logger.debug("Error adding to syncCommittee pool", {subnet}, e as Error);
756
- }
757
- },
758
-
759
- [GossipType.light_client_finality_update]: async ({
760
- gossipData,
761
- topic,
762
- }: GossipHandlerParamGeneric<GossipType.light_client_finality_update>) => {
763
- const {serializedData} = gossipData;
764
- const lightClientFinalityUpdate = sszDeserialize(topic, serializedData);
765
- validateLightClientFinalityUpdate(config, chain, lightClientFinalityUpdate);
766
- },
767
-
768
- [GossipType.light_client_optimistic_update]: async ({
769
- gossipData,
770
- topic,
771
- }: GossipHandlerParamGeneric<GossipType.light_client_optimistic_update>) => {
772
- const {serializedData} = gossipData;
773
- const lightClientOptimisticUpdate = sszDeserialize(topic, serializedData);
774
- validateLightClientOptimisticUpdate(config, chain, lightClientOptimisticUpdate);
775
- },
776
-
777
- // blsToExecutionChange is to be generated and validated against GENESIS_FORK_VERSION
778
- [GossipType.bls_to_execution_change]: async ({
779
- gossipData,
780
- topic,
781
- }: GossipHandlerParamGeneric<GossipType.bls_to_execution_change>) => {
782
- const {serializedData} = gossipData;
783
- const blsToExecutionChange = sszDeserialize(topic, serializedData);
784
- await validateGossipBlsToExecutionChange(chain, blsToExecutionChange);
785
-
786
- // Handler
787
- try {
788
- chain.opPool.insertBlsToExecutionChange(blsToExecutionChange);
789
- } catch (e) {
790
- logger.error("Error adding blsToExecutionChange to pool", {}, e as Error);
791
- }
792
-
793
- chain.emitter.emit(routes.events.EventType.blsToExecutionChange, blsToExecutionChange);
794
- },
795
- };
796
- }
797
-
798
- /**
799
- * For now, only beacon_attestation topic is batched.
800
- */
801
- function getBatchHandlers(modules: ValidatorFnsModules, options: GossipHandlerOpts): BatchGossipHandlers {
802
- const {chain, metrics, logger, aggregatorTracker} = modules;
803
- return {
804
- [GossipType.beacon_attestation]: async (
805
- gossipHandlerParams: GossipHandlerParamGeneric<GossipType.beacon_attestation>[]
806
- ): Promise<(null | AttestationError)[]> => {
807
- const results: (null | AttestationError)[] = [];
808
- const attestationCount = gossipHandlerParams.length;
809
- if (attestationCount === 0) {
810
- return results;
811
- }
812
- // all attestations should have same attestation data as filtered by network processor
813
- const {fork} = gossipHandlerParams[0].topic.boundary;
814
- const validationParams = gossipHandlerParams.map((param) => ({
815
- attestation: null,
816
- serializedData: param.gossipData.serializedData,
817
- attSlot: param.gossipData.msgSlot,
818
- attDataBase64: param.gossipData.indexed,
819
- subnet: param.topic.subnet,
820
- })) as GossipAttestation[];
821
- const {results: validationResults, batchableBls} = await validateGossipAttestationsSameAttData(
822
- fork,
823
- chain,
824
- validationParams
825
- );
826
- for (const [i, validationResult] of validationResults.entries()) {
827
- if (validationResult.err) {
828
- results.push(validationResult.err as AttestationError);
829
- continue;
830
- }
831
- // null means no error
832
- results.push(null);
833
-
834
- // Handler
835
- const {
836
- indexedAttestation,
837
- attDataRootHex,
838
- attestation,
839
- committeeIndex,
840
- validatorCommitteeIndex,
841
- committeeSize,
842
- } = validationResult.result;
843
- chain.validatorMonitor?.registerGossipUnaggregatedAttestation(
844
- gossipHandlerParams[i].seenTimestampSec,
845
- indexedAttestation
846
- );
847
-
848
- const {subnet} = validationResult.result;
849
- try {
850
- // Node may be subscribe to extra subnets (long-lived random subnets). For those, validate the messages
851
- // but don't add to attestation pool, to save CPU and RAM
852
- if (aggregatorTracker.shouldAggregate(subnet, indexedAttestation.data.slot)) {
853
- const insertOutcome = chain.attestationPool.add(
854
- committeeIndex,
855
- attestation,
856
- attDataRootHex,
857
- validatorCommitteeIndex,
858
- committeeSize
859
- );
860
- metrics?.opPool.attestationPool.gossipInsertOutcome.inc({insertOutcome});
861
- }
862
- } catch (e) {
863
- logger.error("Error adding unaggregated attestation to pool", {subnet}, e as Error);
864
- }
865
-
866
- if (!options.dontSendGossipAttestationsToForkchoice) {
867
- try {
868
- chain.forkChoice.onAttestation(indexedAttestation, attDataRootHex);
869
- } catch (e) {
870
- logger.debug("Error adding gossip unaggregated attestation to forkchoice", {subnet}, e as Error);
871
- }
872
- }
873
-
874
- if (isForkPostElectra(fork)) {
875
- chain.emitter.emit(
876
- routes.events.EventType.singleAttestation,
877
- attestation as SingleAttestation<ForkPostElectra>
878
- );
879
- } else {
880
- chain.emitter.emit(routes.events.EventType.attestation, attestation as SingleAttestation<ForkPreElectra>);
881
- chain.emitter.emit(
882
- routes.events.EventType.singleAttestation,
883
- toElectraSingleAttestation(
884
- attestation as SingleAttestation<ForkPreElectra>,
885
- indexedAttestation.attestingIndices[0]
886
- )
887
- );
888
- }
889
- }
890
-
891
- if (batchableBls) {
892
- metrics?.gossipAttestation.attestationBatchHistogram.observe(attestationCount);
893
- } else {
894
- metrics?.gossipAttestation.attestationNonBatchCount.inc(attestationCount);
895
- }
896
-
897
- return results;
898
- },
899
- };
900
- }
901
-
902
- /**
903
- * Retry a function if it throws error code UNKNOWN_OR_PREFINALIZED_BEACON_BLOCK_ROOT
904
- */
905
- export async function validateGossipFnRetryUnknownRoot<T>(
906
- fn: () => Promise<T>,
907
- network: INetwork,
908
- chain: IBeaconChain,
909
- slot: Slot,
910
- blockRoot: Root
911
- ): Promise<T> {
912
- let unknownBlockRootRetries = 0;
913
- while (true) {
914
- try {
915
- return await fn();
916
- } catch (e) {
917
- if (
918
- e instanceof AttestationError &&
919
- e.type.code === AttestationErrorCode.UNKNOWN_OR_PREFINALIZED_BEACON_BLOCK_ROOT
920
- ) {
921
- if (unknownBlockRootRetries === 0) {
922
- // Trigger unknown block root search here
923
- const rootHex = toRootHex(blockRoot);
924
- network.searchUnknownSlotRoot({slot, root: rootHex}, BlockInputSource.gossip);
925
- }
926
-
927
- if (unknownBlockRootRetries++ < MAX_UNKNOWN_BLOCK_ROOT_RETRIES) {
928
- const foundBlock = await chain.waitForBlock(slot, toRootHex(blockRoot));
929
- // Returns true if the block was found on time. In that case, try to get it from the fork-choice again.
930
- // Otherwise, throw the error below.
931
- if (foundBlock) {
932
- continue;
933
- }
934
- }
935
- }
936
-
937
- throw e;
938
- }
939
- }
940
- }
941
-
942
- function getCutoffTimeMs(
943
- chain: {config: ChainForkConfig; genesisTime: UintNum64; logger: Logger},
944
- blockSlot: Slot,
945
- cutoffMsFromSlotStart: number
946
- ): number {
947
- return Math.max(
948
- computeTimeAtSlot(chain.config, blockSlot, chain.genesisTime) * 1000 + cutoffMsFromSlotStart - Date.now(),
949
- 0
950
- );
951
- }