@lodestar/beacon-node 1.35.0-dev.ba92bd8a88 → 1.35.0-dev.c0078a16b5

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 (902) 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/chain/archiveStore/historicalState/historicalStateRegen.js +0 -1
  5. package/lib/chain/archiveStore/historicalState/historicalStateRegen.js.map +1 -1
  6. package/lib/chain/archiveStore/historicalState/worker.js +1 -1
  7. package/lib/chain/archiveStore/historicalState/worker.js.map +1 -1
  8. package/lib/chain/bls/multithread/index.js +0 -1
  9. package/lib/chain/bls/multithread/index.js.map +1 -1
  10. package/lib/chain/emitter.d.ts +2 -2
  11. package/lib/db/buckets.d.ts +4 -4
  12. package/lib/db/buckets.js +4 -4
  13. package/lib/db/buckets.js.map +1 -1
  14. package/lib/db/repositories/blobSidecars.js +1 -1
  15. package/lib/db/repositories/blobSidecars.js.map +1 -1
  16. package/lib/db/repositories/blobSidecarsArchive.js +1 -1
  17. package/lib/db/repositories/blobSidecarsArchive.js.map +1 -1
  18. package/lib/db/repositories/blockArchiveIndex.d.ts +2 -2
  19. package/lib/db/repositories/dataColumnSidecar.js +1 -1
  20. package/lib/db/repositories/dataColumnSidecar.js.map +1 -1
  21. package/lib/db/repositories/dataColumnSidecarArchive.js +1 -1
  22. package/lib/db/repositories/dataColumnSidecarArchive.js.map +1 -1
  23. package/lib/network/core/networkCoreWorkerHandler.js +3 -9
  24. package/lib/network/core/networkCoreWorkerHandler.js.map +1 -1
  25. package/lib/network/discv5/index.js +1 -4
  26. package/lib/network/discv5/index.js.map +1 -1
  27. package/lib/network/gossip/gossipsub.d.ts +0 -1
  28. package/lib/network/gossip/gossipsub.js +16 -35
  29. package/lib/network/gossip/gossipsub.js.map +1 -1
  30. package/lib/network/gossip/metrics.d.ts +7 -15
  31. package/lib/network/gossip/metrics.js +6 -16
  32. package/lib/network/gossip/metrics.js.map +1 -1
  33. package/lib/network/libp2p/index.js +1 -9
  34. package/lib/network/libp2p/index.js.map +1 -1
  35. package/lib/network/metadata.js +1 -2
  36. package/lib/network/metadata.js.map +1 -1
  37. package/lib/network/network.js +4 -2
  38. package/lib/network/network.js.map +1 -1
  39. package/lib/network/peers/datastore.d.ts +2 -2
  40. package/lib/network/peers/datastore.js +2 -2
  41. package/lib/network/peers/datastore.js.map +1 -1
  42. package/lib/network/processor/index.d.ts +1 -1
  43. package/lib/network/processor/index.js +3 -2
  44. package/lib/network/processor/index.js.map +1 -1
  45. package/lib/sync/types.d.ts +1 -0
  46. package/lib/sync/types.js.map +1 -1
  47. package/lib/sync/unknownBlock.js +14 -12
  48. package/lib/sync/unknownBlock.js.map +1 -1
  49. package/lib/sync/utils/downloadByRoot.d.ts +1 -3
  50. package/lib/sync/utils/downloadByRoot.js +5 -32
  51. package/lib/sync/utils/downloadByRoot.js.map +1 -1
  52. package/lib/util/blobs.js +3 -5
  53. package/lib/util/blobs.js.map +1 -1
  54. package/lib/util/execution.js +2 -19
  55. package/lib/util/execution.js.map +1 -1
  56. package/package.json +22 -32
  57. package/lib/api/impl/api.d.ts.map +0 -1
  58. package/lib/api/impl/beacon/blocks/index.d.ts.map +0 -1
  59. package/lib/api/impl/beacon/blocks/utils.d.ts.map +0 -1
  60. package/lib/api/impl/beacon/index.d.ts.map +0 -1
  61. package/lib/api/impl/beacon/pool/index.d.ts.map +0 -1
  62. package/lib/api/impl/beacon/rewards/index.d.ts.map +0 -1
  63. package/lib/api/impl/beacon/state/index.d.ts.map +0 -1
  64. package/lib/api/impl/beacon/state/utils.d.ts.map +0 -1
  65. package/lib/api/impl/config/constants.d.ts.map +0 -1
  66. package/lib/api/impl/config/index.d.ts.map +0 -1
  67. package/lib/api/impl/debug/index.d.ts.map +0 -1
  68. package/lib/api/impl/errors.d.ts.map +0 -1
  69. package/lib/api/impl/events/index.d.ts.map +0 -1
  70. package/lib/api/impl/index.d.ts.map +0 -1
  71. package/lib/api/impl/lightclient/index.d.ts.map +0 -1
  72. package/lib/api/impl/lodestar/index.d.ts.map +0 -1
  73. package/lib/api/impl/node/index.d.ts.map +0 -1
  74. package/lib/api/impl/node/utils.d.ts.map +0 -1
  75. package/lib/api/impl/proof/index.d.ts.map +0 -1
  76. package/lib/api/impl/types.d.ts.map +0 -1
  77. package/lib/api/impl/utils.d.ts.map +0 -1
  78. package/lib/api/impl/validator/index.d.ts.map +0 -1
  79. package/lib/api/impl/validator/utils.d.ts.map +0 -1
  80. package/lib/api/index.d.ts.map +0 -1
  81. package/lib/api/options.d.ts.map +0 -1
  82. package/lib/api/rest/activeSockets.d.ts.map +0 -1
  83. package/lib/api/rest/base.d.ts.map +0 -1
  84. package/lib/api/rest/index.d.ts.map +0 -1
  85. package/lib/api/rest/swaggerUI.d.ts.map +0 -1
  86. package/lib/bun-wrappers/prometheus-gc-stats.d.ts.map +0 -1
  87. package/lib/chain/ColumnReconstructionTracker.d.ts.map +0 -1
  88. package/lib/chain/GetBlobsTracker.d.ts.map +0 -1
  89. package/lib/chain/archiveStore/archiveStore.d.ts.map +0 -1
  90. package/lib/chain/archiveStore/constants.d.ts.map +0 -1
  91. package/lib/chain/archiveStore/historicalState/getHistoricalState.d.ts.map +0 -1
  92. package/lib/chain/archiveStore/historicalState/historicalStateRegen.d.ts.map +0 -1
  93. package/lib/chain/archiveStore/historicalState/metrics.d.ts.map +0 -1
  94. package/lib/chain/archiveStore/historicalState/types.d.ts.map +0 -1
  95. package/lib/chain/archiveStore/historicalState/worker.d.ts.map +0 -1
  96. package/lib/chain/archiveStore/index.d.ts.map +0 -1
  97. package/lib/chain/archiveStore/interface.d.ts.map +0 -1
  98. package/lib/chain/archiveStore/strategies/frequencyStateArchiveStrategy.d.ts.map +0 -1
  99. package/lib/chain/archiveStore/utils/archiveBlocks.d.ts.map +0 -1
  100. package/lib/chain/archiveStore/utils/pruneHistory.d.ts.map +0 -1
  101. package/lib/chain/archiveStore/utils/updateBackfillRange.d.ts.map +0 -1
  102. package/lib/chain/balancesCache.d.ts.map +0 -1
  103. package/lib/chain/beaconProposerCache.d.ts.map +0 -1
  104. package/lib/chain/blocks/blockInput/blockInput.d.ts.map +0 -1
  105. package/lib/chain/blocks/blockInput/errors.d.ts.map +0 -1
  106. package/lib/chain/blocks/blockInput/index.d.ts.map +0 -1
  107. package/lib/chain/blocks/blockInput/types.d.ts.map +0 -1
  108. package/lib/chain/blocks/blockInput/utils.d.ts.map +0 -1
  109. package/lib/chain/blocks/importBlock.d.ts.map +0 -1
  110. package/lib/chain/blocks/index.d.ts.map +0 -1
  111. package/lib/chain/blocks/types.d.ts.map +0 -1
  112. package/lib/chain/blocks/utils/blowfishBanner.d.ts.map +0 -1
  113. package/lib/chain/blocks/utils/chainSegment.d.ts.map +0 -1
  114. package/lib/chain/blocks/utils/checkpoint.d.ts.map +0 -1
  115. package/lib/chain/blocks/utils/giraffeBanner.d.ts.map +0 -1
  116. package/lib/chain/blocks/utils/ownBanner.d.ts.map +0 -1
  117. package/lib/chain/blocks/utils/pandaMergeTransitionBanner.d.ts.map +0 -1
  118. package/lib/chain/blocks/utils/zebraBanner.d.ts.map +0 -1
  119. package/lib/chain/blocks/verifyBlock.d.ts.map +0 -1
  120. package/lib/chain/blocks/verifyBlocksDataAvailability.d.ts.map +0 -1
  121. package/lib/chain/blocks/verifyBlocksExecutionPayloads.d.ts.map +0 -1
  122. package/lib/chain/blocks/verifyBlocksSanityChecks.d.ts.map +0 -1
  123. package/lib/chain/blocks/verifyBlocksSignatures.d.ts.map +0 -1
  124. package/lib/chain/blocks/verifyBlocksStateTransitionOnly.d.ts.map +0 -1
  125. package/lib/chain/blocks/writeBlockInputToDb.d.ts.map +0 -1
  126. package/lib/chain/bls/index.d.ts.map +0 -1
  127. package/lib/chain/bls/interface.d.ts.map +0 -1
  128. package/lib/chain/bls/maybeBatch.d.ts.map +0 -1
  129. package/lib/chain/bls/multithread/index.d.ts.map +0 -1
  130. package/lib/chain/bls/multithread/jobItem.d.ts.map +0 -1
  131. package/lib/chain/bls/multithread/poolSize.d.ts.map +0 -1
  132. package/lib/chain/bls/multithread/types.d.ts.map +0 -1
  133. package/lib/chain/bls/multithread/utils.d.ts.map +0 -1
  134. package/lib/chain/bls/multithread/worker.d.ts.map +0 -1
  135. package/lib/chain/bls/singleThread.d.ts.map +0 -1
  136. package/lib/chain/bls/utils.d.ts.map +0 -1
  137. package/lib/chain/chain.d.ts.map +0 -1
  138. package/lib/chain/emitter.d.ts.map +0 -1
  139. package/lib/chain/errors/attestationError.d.ts.map +0 -1
  140. package/lib/chain/errors/attesterSlashingError.d.ts.map +0 -1
  141. package/lib/chain/errors/blobSidecarError.d.ts.map +0 -1
  142. package/lib/chain/errors/blockError.d.ts.map +0 -1
  143. package/lib/chain/errors/blsToExecutionChangeError.d.ts.map +0 -1
  144. package/lib/chain/errors/dataColumnSidecarError.d.ts.map +0 -1
  145. package/lib/chain/errors/gossipValidation.d.ts.map +0 -1
  146. package/lib/chain/errors/index.d.ts.map +0 -1
  147. package/lib/chain/errors/lightClientError.d.ts.map +0 -1
  148. package/lib/chain/errors/proposerSlashingError.d.ts.map +0 -1
  149. package/lib/chain/errors/syncCommitteeError.d.ts.map +0 -1
  150. package/lib/chain/errors/voluntaryExitError.d.ts.map +0 -1
  151. package/lib/chain/forkChoice/index.d.ts.map +0 -1
  152. package/lib/chain/genesis/genesis.d.ts.map +0 -1
  153. package/lib/chain/genesis/interface.d.ts.map +0 -1
  154. package/lib/chain/index.d.ts.map +0 -1
  155. package/lib/chain/initState.d.ts.map +0 -1
  156. package/lib/chain/interface.d.ts.map +0 -1
  157. package/lib/chain/lightClient/index.d.ts.map +0 -1
  158. package/lib/chain/lightClient/proofs.d.ts.map +0 -1
  159. package/lib/chain/lightClient/types.d.ts.map +0 -1
  160. package/lib/chain/opPools/aggregatedAttestationPool.d.ts.map +0 -1
  161. package/lib/chain/opPools/attestationPool.d.ts.map +0 -1
  162. package/lib/chain/opPools/index.d.ts.map +0 -1
  163. package/lib/chain/opPools/opPool.d.ts.map +0 -1
  164. package/lib/chain/opPools/syncCommitteeMessagePool.d.ts.map +0 -1
  165. package/lib/chain/opPools/syncContributionAndProofPool.d.ts.map +0 -1
  166. package/lib/chain/opPools/types.d.ts.map +0 -1
  167. package/lib/chain/opPools/utils.d.ts.map +0 -1
  168. package/lib/chain/options.d.ts.map +0 -1
  169. package/lib/chain/prepareNextSlot.d.ts.map +0 -1
  170. package/lib/chain/produceBlock/computeNewStateRoot.d.ts.map +0 -1
  171. package/lib/chain/produceBlock/index.d.ts.map +0 -1
  172. package/lib/chain/produceBlock/produceBlockBody.d.ts.map +0 -1
  173. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.d.ts.map +0 -1
  174. package/lib/chain/regen/errors.d.ts.map +0 -1
  175. package/lib/chain/regen/index.d.ts.map +0 -1
  176. package/lib/chain/regen/interface.d.ts.map +0 -1
  177. package/lib/chain/regen/queued.d.ts.map +0 -1
  178. package/lib/chain/regen/regen.d.ts.map +0 -1
  179. package/lib/chain/reprocess.d.ts.map +0 -1
  180. package/lib/chain/rewards/attestationsRewards.d.ts.map +0 -1
  181. package/lib/chain/rewards/blockRewards.d.ts.map +0 -1
  182. package/lib/chain/rewards/syncCommitteeRewards.d.ts.map +0 -1
  183. package/lib/chain/seenCache/index.d.ts.map +0 -1
  184. package/lib/chain/seenCache/seenAggregateAndProof.d.ts.map +0 -1
  185. package/lib/chain/seenCache/seenAttestationData.d.ts.map +0 -1
  186. package/lib/chain/seenCache/seenAttesters.d.ts.map +0 -1
  187. package/lib/chain/seenCache/seenBlockAttesters.d.ts.map +0 -1
  188. package/lib/chain/seenCache/seenBlockProposers.d.ts.map +0 -1
  189. package/lib/chain/seenCache/seenCommittee.d.ts.map +0 -1
  190. package/lib/chain/seenCache/seenCommitteeContribution.d.ts.map +0 -1
  191. package/lib/chain/seenCache/seenGossipBlockInput.d.ts.map +0 -1
  192. package/lib/chain/serializeState.d.ts.map +0 -1
  193. package/lib/chain/shufflingCache.d.ts.map +0 -1
  194. package/lib/chain/stateCache/blockStateCacheImpl.d.ts.map +0 -1
  195. package/lib/chain/stateCache/datastore/db.d.ts.map +0 -1
  196. package/lib/chain/stateCache/datastore/file.d.ts.map +0 -1
  197. package/lib/chain/stateCache/datastore/index.d.ts.map +0 -1
  198. package/lib/chain/stateCache/datastore/types.d.ts.map +0 -1
  199. package/lib/chain/stateCache/fifoBlockStateCache.d.ts.map +0 -1
  200. package/lib/chain/stateCache/inMemoryCheckpointsCache.d.ts.map +0 -1
  201. package/lib/chain/stateCache/index.d.ts.map +0 -1
  202. package/lib/chain/stateCache/mapMetrics.d.ts.map +0 -1
  203. package/lib/chain/stateCache/persistentCheckpointsCache.d.ts.map +0 -1
  204. package/lib/chain/stateCache/types.d.ts.map +0 -1
  205. package/lib/chain/validation/aggregateAndProof.d.ts.map +0 -1
  206. package/lib/chain/validation/attestation.d.ts.map +0 -1
  207. package/lib/chain/validation/attesterSlashing.d.ts.map +0 -1
  208. package/lib/chain/validation/blobSidecar.d.ts.map +0 -1
  209. package/lib/chain/validation/block.d.ts.map +0 -1
  210. package/lib/chain/validation/blsToExecutionChange.d.ts.map +0 -1
  211. package/lib/chain/validation/dataColumnSidecar.d.ts.map +0 -1
  212. package/lib/chain/validation/index.d.ts.map +0 -1
  213. package/lib/chain/validation/lightClientFinalityUpdate.d.ts.map +0 -1
  214. package/lib/chain/validation/lightClientOptimisticUpdate.d.ts.map +0 -1
  215. package/lib/chain/validation/proposerSlashing.d.ts.map +0 -1
  216. package/lib/chain/validation/signatureSets/aggregateAndProof.d.ts.map +0 -1
  217. package/lib/chain/validation/signatureSets/contributionAndProof.d.ts.map +0 -1
  218. package/lib/chain/validation/signatureSets/index.d.ts.map +0 -1
  219. package/lib/chain/validation/signatureSets/selectionProof.d.ts.map +0 -1
  220. package/lib/chain/validation/signatureSets/syncCommittee.d.ts.map +0 -1
  221. package/lib/chain/validation/signatureSets/syncCommitteeContribution.d.ts.map +0 -1
  222. package/lib/chain/validation/signatureSets/syncCommitteeSelectionProof.d.ts.map +0 -1
  223. package/lib/chain/validation/syncCommittee.d.ts.map +0 -1
  224. package/lib/chain/validation/syncCommitteeContributionAndProof.d.ts.map +0 -1
  225. package/lib/chain/validation/voluntaryExit.d.ts.map +0 -1
  226. package/lib/chain/validatorMonitor.d.ts.map +0 -1
  227. package/lib/constants/constants.d.ts.map +0 -1
  228. package/lib/constants/index.d.ts.map +0 -1
  229. package/lib/constants/network.d.ts.map +0 -1
  230. package/lib/db/beacon.d.ts.map +0 -1
  231. package/lib/db/buckets.d.ts.map +0 -1
  232. package/lib/db/index.d.ts.map +0 -1
  233. package/lib/db/interface.d.ts.map +0 -1
  234. package/lib/db/options.d.ts.map +0 -1
  235. package/lib/db/repositories/attesterSlashing.d.ts.map +0 -1
  236. package/lib/db/repositories/backfilledRanges.d.ts.map +0 -1
  237. package/lib/db/repositories/blobSidecars.d.ts.map +0 -1
  238. package/lib/db/repositories/blobSidecarsArchive.d.ts.map +0 -1
  239. package/lib/db/repositories/block.d.ts.map +0 -1
  240. package/lib/db/repositories/blockArchive.d.ts.map +0 -1
  241. package/lib/db/repositories/blockArchiveIndex.d.ts.map +0 -1
  242. package/lib/db/repositories/blsToExecutionChange.d.ts.map +0 -1
  243. package/lib/db/repositories/checkpointState.d.ts.map +0 -1
  244. package/lib/db/repositories/dataColumnSidecar.d.ts.map +0 -1
  245. package/lib/db/repositories/dataColumnSidecarArchive.d.ts.map +0 -1
  246. package/lib/db/repositories/depositDataRoot.d.ts.map +0 -1
  247. package/lib/db/repositories/depositEvent.d.ts.map +0 -1
  248. package/lib/db/repositories/eth1Data.d.ts.map +0 -1
  249. package/lib/db/repositories/index.d.ts.map +0 -1
  250. package/lib/db/repositories/lightclientBestUpdate.d.ts.map +0 -1
  251. package/lib/db/repositories/lightclientCheckpointHeader.d.ts.map +0 -1
  252. package/lib/db/repositories/lightclientSyncCommittee.d.ts.map +0 -1
  253. package/lib/db/repositories/lightclientSyncCommitteeWitness.d.ts.map +0 -1
  254. package/lib/db/repositories/proposerSlashing.d.ts.map +0 -1
  255. package/lib/db/repositories/stateArchive.d.ts.map +0 -1
  256. package/lib/db/repositories/stateArchiveIndex.d.ts.map +0 -1
  257. package/lib/db/repositories/voluntaryExit.d.ts.map +0 -1
  258. package/lib/db/single/index.d.ts.map +0 -1
  259. package/lib/db/single/preGenesisState.d.ts.map +0 -1
  260. package/lib/db/single/preGenesisStateLastProcessedBlock.d.ts.map +0 -1
  261. package/lib/eth1/errors.d.ts.map +0 -1
  262. package/lib/eth1/eth1DataCache.d.ts.map +0 -1
  263. package/lib/eth1/eth1DepositDataTracker.d.ts.map +0 -1
  264. package/lib/eth1/eth1DepositsCache.d.ts.map +0 -1
  265. package/lib/eth1/eth1MergeBlockTracker.d.ts.map +0 -1
  266. package/lib/eth1/index.d.ts.map +0 -1
  267. package/lib/eth1/interface.d.ts.map +0 -1
  268. package/lib/eth1/options.d.ts.map +0 -1
  269. package/lib/eth1/provider/eth1Provider.d.ts.map +0 -1
  270. package/lib/eth1/provider/jsonRpcHttpClient.d.ts.map +0 -1
  271. package/lib/eth1/provider/jwt.d.ts.map +0 -1
  272. package/lib/eth1/provider/utils.d.ts.map +0 -1
  273. package/lib/eth1/stream.d.ts.map +0 -1
  274. package/lib/eth1/utils/depositContract.d.ts.map +0 -1
  275. package/lib/eth1/utils/deposits.d.ts.map +0 -1
  276. package/lib/eth1/utils/eth1Data.d.ts.map +0 -1
  277. package/lib/eth1/utils/eth1DepositEvent.d.ts.map +0 -1
  278. package/lib/eth1/utils/eth1Vote.d.ts.map +0 -1
  279. package/lib/eth1/utils/groupDepositEventsByBlock.d.ts.map +0 -1
  280. package/lib/eth1/utils/optimizeNextBlockDiffForGenesis.d.ts.map +0 -1
  281. package/lib/execution/builder/cache.d.ts.map +0 -1
  282. package/lib/execution/builder/http.d.ts.map +0 -1
  283. package/lib/execution/builder/index.d.ts.map +0 -1
  284. package/lib/execution/builder/interface.d.ts.map +0 -1
  285. package/lib/execution/builder/utils.d.ts.map +0 -1
  286. package/lib/execution/engine/disabled.d.ts.map +0 -1
  287. package/lib/execution/engine/http.d.ts.map +0 -1
  288. package/lib/execution/engine/index.d.ts.map +0 -1
  289. package/lib/execution/engine/interface.d.ts.map +0 -1
  290. package/lib/execution/engine/mock.d.ts.map +0 -1
  291. package/lib/execution/engine/payloadIdCache.d.ts.map +0 -1
  292. package/lib/execution/engine/types.d.ts.map +0 -1
  293. package/lib/execution/engine/utils.d.ts.map +0 -1
  294. package/lib/execution/index.d.ts.map +0 -1
  295. package/lib/index.d.ts.map +0 -1
  296. package/lib/metrics/index.d.ts.map +0 -1
  297. package/lib/metrics/metrics/beacon.d.ts.map +0 -1
  298. package/lib/metrics/metrics/lodestar.d.ts.map +0 -1
  299. package/lib/metrics/metrics.d.ts.map +0 -1
  300. package/lib/metrics/nodeJsMetrics.d.ts.map +0 -1
  301. package/lib/metrics/options.d.ts.map +0 -1
  302. package/lib/metrics/server/http.d.ts.map +0 -1
  303. package/lib/metrics/server/index.d.ts.map +0 -1
  304. package/lib/metrics/utils/avgMinMax.d.ts.map +0 -1
  305. package/lib/metrics/utils/gauge.d.ts.map +0 -1
  306. package/lib/metrics/utils/registryMetricCreator.d.ts.map +0 -1
  307. package/lib/monitoring/clientStats.d.ts.map +0 -1
  308. package/lib/monitoring/index.d.ts.map +0 -1
  309. package/lib/monitoring/options.d.ts.map +0 -1
  310. package/lib/monitoring/properties.d.ts.map +0 -1
  311. package/lib/monitoring/service.d.ts.map +0 -1
  312. package/lib/monitoring/system.d.ts.map +0 -1
  313. package/lib/monitoring/types.d.ts.map +0 -1
  314. package/lib/network/core/events.d.ts.map +0 -1
  315. package/lib/network/core/index.d.ts.map +0 -1
  316. package/lib/network/core/metrics.d.ts.map +0 -1
  317. package/lib/network/core/networkCore.d.ts.map +0 -1
  318. package/lib/network/core/networkCoreWorker.d.ts.map +0 -1
  319. package/lib/network/core/networkCoreWorkerHandler.d.ts.map +0 -1
  320. package/lib/network/core/types.d.ts.map +0 -1
  321. package/lib/network/discv5/index.d.ts.map +0 -1
  322. package/lib/network/discv5/types.d.ts.map +0 -1
  323. package/lib/network/discv5/utils.d.ts.map +0 -1
  324. package/lib/network/discv5/worker.d.ts.map +0 -1
  325. package/lib/network/events.d.ts.map +0 -1
  326. package/lib/network/forks.d.ts.map +0 -1
  327. package/lib/network/gossip/constants.d.ts.map +0 -1
  328. package/lib/network/gossip/encoding.d.ts.map +0 -1
  329. package/lib/network/gossip/errors.d.ts.map +0 -1
  330. package/lib/network/gossip/gossipsub.d.ts.map +0 -1
  331. package/lib/network/gossip/index.d.ts.map +0 -1
  332. package/lib/network/gossip/interface.d.ts.map +0 -1
  333. package/lib/network/gossip/metrics.d.ts.map +0 -1
  334. package/lib/network/gossip/scoringParameters.d.ts.map +0 -1
  335. package/lib/network/gossip/topic.d.ts.map +0 -1
  336. package/lib/network/index.d.ts.map +0 -1
  337. package/lib/network/interface.d.ts.map +0 -1
  338. package/lib/network/libp2p/error.d.ts.map +0 -1
  339. package/lib/network/libp2p/index.d.ts.map +0 -1
  340. package/lib/network/metadata.d.ts.map +0 -1
  341. package/lib/network/network.d.ts.map +0 -1
  342. package/lib/network/networkConfig.d.ts.map +0 -1
  343. package/lib/network/options.d.ts.map +0 -1
  344. package/lib/network/peers/client.d.ts.map +0 -1
  345. package/lib/network/peers/datastore.d.ts.map +0 -1
  346. package/lib/network/peers/discover.d.ts.map +0 -1
  347. package/lib/network/peers/index.d.ts.map +0 -1
  348. package/lib/network/peers/peerManager.d.ts.map +0 -1
  349. package/lib/network/peers/peersData.d.ts.map +0 -1
  350. package/lib/network/peers/score/constants.d.ts.map +0 -1
  351. package/lib/network/peers/score/index.d.ts.map +0 -1
  352. package/lib/network/peers/score/interface.d.ts.map +0 -1
  353. package/lib/network/peers/score/score.d.ts.map +0 -1
  354. package/lib/network/peers/score/store.d.ts.map +0 -1
  355. package/lib/network/peers/score/utils.d.ts.map +0 -1
  356. package/lib/network/peers/utils/assertPeerRelevance.d.ts.map +0 -1
  357. package/lib/network/peers/utils/enrSubnetsDeserialize.d.ts.map +0 -1
  358. package/lib/network/peers/utils/getConnectedPeerIds.d.ts.map +0 -1
  359. package/lib/network/peers/utils/index.d.ts.map +0 -1
  360. package/lib/network/peers/utils/prioritizePeers.d.ts.map +0 -1
  361. package/lib/network/peers/utils/subnetMap.d.ts.map +0 -1
  362. package/lib/network/processor/aggregatorTracker.d.ts.map +0 -1
  363. package/lib/network/processor/extractSlotRootFns.d.ts.map +0 -1
  364. package/lib/network/processor/gossipHandlers.d.ts.map +0 -1
  365. package/lib/network/processor/gossipQueues/index.d.ts.map +0 -1
  366. package/lib/network/processor/gossipQueues/indexed.d.ts.map +0 -1
  367. package/lib/network/processor/gossipQueues/linear.d.ts.map +0 -1
  368. package/lib/network/processor/gossipQueues/types.d.ts.map +0 -1
  369. package/lib/network/processor/gossipValidatorFn.d.ts.map +0 -1
  370. package/lib/network/processor/index.d.ts.map +0 -1
  371. package/lib/network/processor/types.d.ts.map +0 -1
  372. package/lib/network/reqresp/ReqRespBeaconNode.d.ts.map +0 -1
  373. package/lib/network/reqresp/handlers/beaconBlocksByRange.d.ts.map +0 -1
  374. package/lib/network/reqresp/handlers/beaconBlocksByRoot.d.ts.map +0 -1
  375. package/lib/network/reqresp/handlers/blobSidecarsByRange.d.ts.map +0 -1
  376. package/lib/network/reqresp/handlers/blobSidecarsByRoot.d.ts.map +0 -1
  377. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts.map +0 -1
  378. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.d.ts.map +0 -1
  379. package/lib/network/reqresp/handlers/index.d.ts.map +0 -1
  380. package/lib/network/reqresp/handlers/lightClientBootstrap.d.ts.map +0 -1
  381. package/lib/network/reqresp/handlers/lightClientFinalityUpdate.d.ts.map +0 -1
  382. package/lib/network/reqresp/handlers/lightClientOptimisticUpdate.d.ts.map +0 -1
  383. package/lib/network/reqresp/handlers/lightClientUpdatesByRange.d.ts.map +0 -1
  384. package/lib/network/reqresp/index.d.ts.map +0 -1
  385. package/lib/network/reqresp/interface.d.ts.map +0 -1
  386. package/lib/network/reqresp/protocols.d.ts.map +0 -1
  387. package/lib/network/reqresp/rateLimit.d.ts.map +0 -1
  388. package/lib/network/reqresp/score.d.ts.map +0 -1
  389. package/lib/network/reqresp/types.d.ts.map +0 -1
  390. package/lib/network/reqresp/utils/collect.d.ts.map +0 -1
  391. package/lib/network/reqresp/utils/collectSequentialBlocksInRange.d.ts.map +0 -1
  392. package/lib/network/reqresp/utils/dataColumnResponseValidation.d.ts.map +0 -1
  393. package/lib/network/statusCache.d.ts.map +0 -1
  394. package/lib/network/subnets/attnetsService.d.ts.map +0 -1
  395. package/lib/network/subnets/index.d.ts.map +0 -1
  396. package/lib/network/subnets/interface.d.ts.map +0 -1
  397. package/lib/network/subnets/syncnetsService.d.ts.map +0 -1
  398. package/lib/network/subnets/util.d.ts.map +0 -1
  399. package/lib/network/util.d.ts.map +0 -1
  400. package/lib/node/index.d.ts.map +0 -1
  401. package/lib/node/nodejs.d.ts.map +0 -1
  402. package/lib/node/notifier.d.ts.map +0 -1
  403. package/lib/node/options.d.ts.map +0 -1
  404. package/lib/node/utils/interop/deposits.d.ts.map +0 -1
  405. package/lib/node/utils/interop/state.d.ts.map +0 -1
  406. package/lib/node/utils/lightclient.d.ts.map +0 -1
  407. package/lib/node/utils/state.d.ts.map +0 -1
  408. package/lib/sync/backfill/backfill.d.ts.map +0 -1
  409. package/lib/sync/backfill/errors.d.ts.map +0 -1
  410. package/lib/sync/backfill/index.d.ts.map +0 -1
  411. package/lib/sync/backfill/verify.d.ts.map +0 -1
  412. package/lib/sync/constants.d.ts.map +0 -1
  413. package/lib/sync/index.d.ts.map +0 -1
  414. package/lib/sync/interface.d.ts.map +0 -1
  415. package/lib/sync/options.d.ts.map +0 -1
  416. package/lib/sync/range/batch.d.ts.map +0 -1
  417. package/lib/sync/range/chain.d.ts.map +0 -1
  418. package/lib/sync/range/range.d.ts.map +0 -1
  419. package/lib/sync/range/utils/batches.d.ts.map +0 -1
  420. package/lib/sync/range/utils/chainTarget.d.ts.map +0 -1
  421. package/lib/sync/range/utils/hashBlocks.d.ts.map +0 -1
  422. package/lib/sync/range/utils/index.d.ts.map +0 -1
  423. package/lib/sync/range/utils/peerBalancer.d.ts.map +0 -1
  424. package/lib/sync/range/utils/updateChains.d.ts.map +0 -1
  425. package/lib/sync/sync.d.ts.map +0 -1
  426. package/lib/sync/types.d.ts.map +0 -1
  427. package/lib/sync/unknownBlock.d.ts.map +0 -1
  428. package/lib/sync/utils/downloadByRange.d.ts.map +0 -1
  429. package/lib/sync/utils/downloadByRoot.d.ts.map +0 -1
  430. package/lib/sync/utils/pendingBlocksTree.d.ts.map +0 -1
  431. package/lib/sync/utils/remoteSyncType.d.ts.map +0 -1
  432. package/lib/util/address.d.ts.map +0 -1
  433. package/lib/util/array.d.ts.map +0 -1
  434. package/lib/util/asyncIterableToEvents.d.ts.map +0 -1
  435. package/lib/util/binarySearch.d.ts.map +0 -1
  436. package/lib/util/bitArray.d.ts.map +0 -1
  437. package/lib/util/blobs.d.ts.map +0 -1
  438. package/lib/util/bufferPool.d.ts.map +0 -1
  439. package/lib/util/bytes.d.ts.map +0 -1
  440. package/lib/util/chunkify.d.ts.map +0 -1
  441. package/lib/util/clock.d.ts.map +0 -1
  442. package/lib/util/dataColumns.d.ts.map +0 -1
  443. package/lib/util/dependentRoot.d.ts.map +0 -1
  444. package/lib/util/enum.d.ts.map +0 -1
  445. package/lib/util/error.d.ts.map +0 -1
  446. package/lib/util/eventLoop.d.ts.map +0 -1
  447. package/lib/util/execution.d.ts.map +0 -1
  448. package/lib/util/file.d.ts.map +0 -1
  449. package/lib/util/forkChoice.d.ts.map +0 -1
  450. package/lib/util/forkName.d.ts.map +0 -1
  451. package/lib/util/graffiti.d.ts.map +0 -1
  452. package/lib/util/hex.d.ts.map +0 -1
  453. package/lib/util/index.d.ts.map +0 -1
  454. package/lib/util/ip.d.ts.map +0 -1
  455. package/lib/util/itTrigger.d.ts.map +0 -1
  456. package/lib/util/kzg.d.ts.map +0 -1
  457. package/lib/util/map.d.ts.map +0 -1
  458. package/lib/util/metadata.d.ts.map +0 -1
  459. package/lib/util/multifork.d.ts.map +0 -1
  460. package/lib/util/numpy.d.ts.map +0 -1
  461. package/lib/util/peerId.d.ts.map +0 -1
  462. package/lib/util/profile.d.ts.map +0 -1
  463. package/lib/util/promises.d.ts.map +0 -1
  464. package/lib/util/queue/errors.d.ts.map +0 -1
  465. package/lib/util/queue/fnQueue.d.ts.map +0 -1
  466. package/lib/util/queue/index.d.ts.map +0 -1
  467. package/lib/util/queue/itemQueue.d.ts.map +0 -1
  468. package/lib/util/queue/options.d.ts.map +0 -1
  469. package/lib/util/serializedCache.d.ts.map +0 -1
  470. package/lib/util/set.d.ts.map +0 -1
  471. package/lib/util/shuffle.d.ts.map +0 -1
  472. package/lib/util/sortBy.d.ts.map +0 -1
  473. package/lib/util/sszBytes.d.ts.map +0 -1
  474. package/lib/util/strictEvents.d.ts.map +0 -1
  475. package/lib/util/time.d.ts.map +0 -1
  476. package/lib/util/timeSeries.d.ts.map +0 -1
  477. package/lib/util/types.d.ts.map +0 -1
  478. package/lib/util/workerEvents.d.ts.map +0 -1
  479. package/lib/util/wrapError.d.ts.map +0 -1
  480. package/src/api/impl/api.ts +0 -26
  481. package/src/api/impl/beacon/blocks/index.ts +0 -744
  482. package/src/api/impl/beacon/blocks/utils.ts +0 -75
  483. package/src/api/impl/beacon/index.ts +0 -35
  484. package/src/api/impl/beacon/pool/index.ts +0 -314
  485. package/src/api/impl/beacon/rewards/index.ts +0 -30
  486. package/src/api/impl/beacon/state/index.ts +0 -406
  487. package/src/api/impl/beacon/state/utils.ts +0 -189
  488. package/src/api/impl/config/constants.ts +0 -127
  489. package/src/api/impl/config/index.ts +0 -59
  490. package/src/api/impl/debug/index.ts +0 -131
  491. package/src/api/impl/errors.ts +0 -50
  492. package/src/api/impl/events/index.ts +0 -33
  493. package/src/api/impl/index.ts +0 -6
  494. package/src/api/impl/lightclient/index.ts +0 -64
  495. package/src/api/impl/lodestar/index.ts +0 -257
  496. package/src/api/impl/node/index.ts +0 -88
  497. package/src/api/impl/node/utils.ts +0 -51
  498. package/src/api/impl/proof/index.ts +0 -60
  499. package/src/api/impl/types.ts +0 -17
  500. package/src/api/impl/utils.ts +0 -25
  501. package/src/api/impl/validator/index.ts +0 -1538
  502. package/src/api/impl/validator/utils.ts +0 -85
  503. package/src/api/index.ts +0 -2
  504. package/src/api/options.ts +0 -16
  505. package/src/api/rest/activeSockets.ts +0 -109
  506. package/src/api/rest/base.ts +0 -216
  507. package/src/api/rest/index.ts +0 -63
  508. package/src/api/rest/swaggerUI.ts +0 -80
  509. package/src/bun-wrappers/prometheus-gc-stats.ts +0 -7
  510. package/src/chain/ColumnReconstructionTracker.ts +0 -90
  511. package/src/chain/GetBlobsTracker.ts +0 -115
  512. package/src/chain/archiveStore/archiveStore.ts +0 -222
  513. package/src/chain/archiveStore/constants.ts +0 -5
  514. package/src/chain/archiveStore/historicalState/getHistoricalState.ts +0 -116
  515. package/src/chain/archiveStore/historicalState/historicalStateRegen.ts +0 -68
  516. package/src/chain/archiveStore/historicalState/metrics.ts +0 -214
  517. package/src/chain/archiveStore/historicalState/types.ts +0 -41
  518. package/src/chain/archiveStore/historicalState/worker.ts +0 -77
  519. package/src/chain/archiveStore/index.ts +0 -3
  520. package/src/chain/archiveStore/interface.ts +0 -75
  521. package/src/chain/archiveStore/strategies/frequencyStateArchiveStrategy.ts +0 -138
  522. package/src/chain/archiveStore/utils/archiveBlocks.ts +0 -437
  523. package/src/chain/archiveStore/utils/pruneHistory.ts +0 -56
  524. package/src/chain/archiveStore/utils/updateBackfillRange.ts +0 -50
  525. package/src/chain/balancesCache.ts +0 -52
  526. package/src/chain/beaconProposerCache.ts +0 -43
  527. package/src/chain/blocks/blockInput/blockInput.ts +0 -851
  528. package/src/chain/blocks/blockInput/errors.ts +0 -48
  529. package/src/chain/blocks/blockInput/index.ts +0 -4
  530. package/src/chain/blocks/blockInput/types.ts +0 -145
  531. package/src/chain/blocks/blockInput/utils.ts +0 -21
  532. package/src/chain/blocks/importBlock.ts +0 -603
  533. package/src/chain/blocks/index.ts +0 -179
  534. package/src/chain/blocks/types.ts +0 -101
  535. package/src/chain/blocks/utils/blowfishBanner.ts +0 -28
  536. package/src/chain/blocks/utils/chainSegment.ts +0 -29
  537. package/src/chain/blocks/utils/checkpoint.ts +0 -25
  538. package/src/chain/blocks/utils/giraffeBanner.ts +0 -30
  539. package/src/chain/blocks/utils/ownBanner.ts +0 -20
  540. package/src/chain/blocks/utils/pandaMergeTransitionBanner.ts +0 -43
  541. package/src/chain/blocks/utils/zebraBanner.ts +0 -45
  542. package/src/chain/blocks/verifyBlock.ts +0 -242
  543. package/src/chain/blocks/verifyBlocksDataAvailability.ts +0 -34
  544. package/src/chain/blocks/verifyBlocksExecutionPayloads.ts +0 -438
  545. package/src/chain/blocks/verifyBlocksSanityChecks.ts +0 -129
  546. package/src/chain/blocks/verifyBlocksSignatures.ts +0 -105
  547. package/src/chain/blocks/verifyBlocksStateTransitionOnly.ts +0 -114
  548. package/src/chain/blocks/writeBlockInputToDb.ts +0 -128
  549. package/src/chain/bls/index.ts +0 -4
  550. package/src/chain/bls/interface.ts +0 -68
  551. package/src/chain/bls/maybeBatch.ts +0 -45
  552. package/src/chain/bls/multithread/index.ts +0 -582
  553. package/src/chain/bls/multithread/jobItem.ts +0 -119
  554. package/src/chain/bls/multithread/poolSize.ts +0 -16
  555. package/src/chain/bls/multithread/types.ts +0 -38
  556. package/src/chain/bls/multithread/utils.ts +0 -19
  557. package/src/chain/bls/multithread/worker.ts +0 -114
  558. package/src/chain/bls/singleThread.ts +0 -87
  559. package/src/chain/bls/utils.ts +0 -30
  560. package/src/chain/chain.ts +0 -1365
  561. package/src/chain/emitter.ts +0 -113
  562. package/src/chain/errors/attestationError.ts +0 -194
  563. package/src/chain/errors/attesterSlashingError.ts +0 -11
  564. package/src/chain/errors/blobSidecarError.ts +0 -60
  565. package/src/chain/errors/blockError.ts +0 -166
  566. package/src/chain/errors/blsToExecutionChangeError.ts +0 -13
  567. package/src/chain/errors/dataColumnSidecarError.ts +0 -80
  568. package/src/chain/errors/gossipValidation.ts +0 -20
  569. package/src/chain/errors/index.ts +0 -10
  570. package/src/chain/errors/lightClientError.ts +0 -30
  571. package/src/chain/errors/proposerSlashingError.ts +0 -11
  572. package/src/chain/errors/syncCommitteeError.ts +0 -36
  573. package/src/chain/errors/voluntaryExitError.ts +0 -13
  574. package/src/chain/forkChoice/index.ts +0 -112
  575. package/src/chain/genesis/genesis.ts +0 -190
  576. package/src/chain/genesis/interface.ts +0 -14
  577. package/src/chain/index.ts +0 -6
  578. package/src/chain/initState.ts +0 -221
  579. package/src/chain/interface.ts +0 -280
  580. package/src/chain/lightClient/index.ts +0 -764
  581. package/src/chain/lightClient/proofs.ts +0 -85
  582. package/src/chain/lightClient/types.ts +0 -33
  583. package/src/chain/opPools/aggregatedAttestationPool.ts +0 -1063
  584. package/src/chain/opPools/attestationPool.ts +0 -283
  585. package/src/chain/opPools/index.ts +0 -5
  586. package/src/chain/opPools/opPool.ts +0 -462
  587. package/src/chain/opPools/syncCommitteeMessagePool.ts +0 -167
  588. package/src/chain/opPools/syncContributionAndProofPool.ts +0 -240
  589. package/src/chain/opPools/types.ts +0 -35
  590. package/src/chain/opPools/utils.ts +0 -65
  591. package/src/chain/options.ts +0 -138
  592. package/src/chain/prepareNextSlot.ts +0 -277
  593. package/src/chain/produceBlock/computeNewStateRoot.ts +0 -55
  594. package/src/chain/produceBlock/index.ts +0 -2
  595. package/src/chain/produceBlock/produceBlockBody.ts +0 -797
  596. package/src/chain/produceBlock/validateBlobsAndKzgCommitments.ts +0 -54
  597. package/src/chain/regen/errors.ts +0 -30
  598. package/src/chain/regen/index.ts +0 -4
  599. package/src/chain/regen/interface.ts +0 -93
  600. package/src/chain/regen/queued.ts +0 -317
  601. package/src/chain/regen/regen.ts +0 -424
  602. package/src/chain/reprocess.ts +0 -161
  603. package/src/chain/rewards/attestationsRewards.ts +0 -196
  604. package/src/chain/rewards/blockRewards.ts +0 -150
  605. package/src/chain/rewards/syncCommitteeRewards.ts +0 -58
  606. package/src/chain/seenCache/index.ts +0 -5
  607. package/src/chain/seenCache/seenAggregateAndProof.ts +0 -120
  608. package/src/chain/seenCache/seenAttestationData.ts +0 -145
  609. package/src/chain/seenCache/seenAttesters.ts +0 -58
  610. package/src/chain/seenCache/seenBlockAttesters.ts +0 -18
  611. package/src/chain/seenCache/seenBlockProposers.ts +0 -48
  612. package/src/chain/seenCache/seenCommittee.ts +0 -43
  613. package/src/chain/seenCache/seenCommitteeContribution.ts +0 -104
  614. package/src/chain/seenCache/seenGossipBlockInput.ts +0 -373
  615. package/src/chain/serializeState.ts +0 -32
  616. package/src/chain/shufflingCache.ts +0 -238
  617. package/src/chain/stateCache/blockStateCacheImpl.ts +0 -150
  618. package/src/chain/stateCache/datastore/db.ts +0 -36
  619. package/src/chain/stateCache/datastore/file.ts +0 -53
  620. package/src/chain/stateCache/datastore/index.ts +0 -2
  621. package/src/chain/stateCache/datastore/types.ts +0 -13
  622. package/src/chain/stateCache/fifoBlockStateCache.ts +0 -208
  623. package/src/chain/stateCache/inMemoryCheckpointsCache.ts +0 -198
  624. package/src/chain/stateCache/index.ts +0 -3
  625. package/src/chain/stateCache/mapMetrics.ts +0 -52
  626. package/src/chain/stateCache/persistentCheckpointsCache.ts +0 -835
  627. package/src/chain/stateCache/types.ts +0 -86
  628. package/src/chain/validation/aggregateAndProof.ts +0 -258
  629. package/src/chain/validation/attestation.ts +0 -885
  630. package/src/chain/validation/attesterSlashing.ts +0 -61
  631. package/src/chain/validation/blobSidecar.ts +0 -301
  632. package/src/chain/validation/block.ts +0 -188
  633. package/src/chain/validation/blsToExecutionChange.ts +0 -61
  634. package/src/chain/validation/dataColumnSidecar.ts +0 -381
  635. package/src/chain/validation/index.ts +0 -9
  636. package/src/chain/validation/lightClientFinalityUpdate.ts +0 -45
  637. package/src/chain/validation/lightClientOptimisticUpdate.ts +0 -67
  638. package/src/chain/validation/proposerSlashing.ts +0 -54
  639. package/src/chain/validation/signatureSets/aggregateAndProof.ts +0 -38
  640. package/src/chain/validation/signatureSets/contributionAndProof.ts +0 -27
  641. package/src/chain/validation/signatureSets/index.ts +0 -6
  642. package/src/chain/validation/signatureSets/selectionProof.ts +0 -27
  643. package/src/chain/validation/signatureSets/syncCommittee.ts +0 -22
  644. package/src/chain/validation/signatureSets/syncCommitteeContribution.ts +0 -18
  645. package/src/chain/validation/signatureSets/syncCommitteeSelectionProof.ts +0 -27
  646. package/src/chain/validation/syncCommittee.ts +0 -165
  647. package/src/chain/validation/syncCommitteeContributionAndProof.ts +0 -122
  648. package/src/chain/validation/voluntaryExit.ts +0 -58
  649. package/src/chain/validatorMonitor.ts +0 -1299
  650. package/src/constants/constants.ts +0 -15
  651. package/src/constants/index.ts +0 -2
  652. package/src/constants/network.ts +0 -52
  653. package/src/db/beacon.ts +0 -113
  654. package/src/db/buckets.ts +0 -80
  655. package/src/db/index.ts +0 -2
  656. package/src/db/interface.ts +0 -76
  657. package/src/db/options.ts +0 -7
  658. package/src/db/repositories/attesterSlashing.ts +0 -38
  659. package/src/db/repositories/backfilledRanges.ts +0 -29
  660. package/src/db/repositories/blobSidecars.ts +0 -37
  661. package/src/db/repositories/blobSidecarsArchive.ts +0 -28
  662. package/src/db/repositories/block.ts +0 -33
  663. package/src/db/repositories/blockArchive.ts +0 -170
  664. package/src/db/repositories/blockArchiveIndex.ts +0 -45
  665. package/src/db/repositories/blsToExecutionChange.ts +0 -16
  666. package/src/db/repositories/checkpointState.ts +0 -31
  667. package/src/db/repositories/dataColumnSidecar.ts +0 -49
  668. package/src/db/repositories/dataColumnSidecarArchive.ts +0 -56
  669. package/src/db/repositories/depositDataRoot.ts +0 -80
  670. package/src/db/repositories/depositEvent.ts +0 -32
  671. package/src/db/repositories/eth1Data.ts +0 -33
  672. package/src/db/repositories/index.ts +0 -20
  673. package/src/db/repositories/lightclientBestUpdate.ts +0 -41
  674. package/src/db/repositories/lightclientCheckpointHeader.ts +0 -32
  675. package/src/db/repositories/lightclientSyncCommittee.ts +0 -16
  676. package/src/db/repositories/lightclientSyncCommitteeWitness.ts +0 -77
  677. package/src/db/repositories/proposerSlashing.ts +0 -15
  678. package/src/db/repositories/stateArchive.ts +0 -69
  679. package/src/db/repositories/stateArchiveIndex.ts +0 -18
  680. package/src/db/repositories/voluntaryExit.ts +0 -15
  681. package/src/db/single/index.ts +0 -2
  682. package/src/db/single/preGenesisState.ts +0 -37
  683. package/src/db/single/preGenesisStateLastProcessedBlock.ts +0 -34
  684. package/src/eth1/errors.ts +0 -40
  685. package/src/eth1/eth1DataCache.ts +0 -26
  686. package/src/eth1/eth1DepositDataTracker.ts +0 -410
  687. package/src/eth1/eth1DepositsCache.ts +0 -141
  688. package/src/eth1/eth1MergeBlockTracker.ts +0 -328
  689. package/src/eth1/index.ts +0 -157
  690. package/src/eth1/interface.ts +0 -131
  691. package/src/eth1/options.ts +0 -28
  692. package/src/eth1/provider/eth1Provider.ts +0 -229
  693. package/src/eth1/provider/jsonRpcHttpClient.ts +0 -390
  694. package/src/eth1/provider/jwt.ts +0 -36
  695. package/src/eth1/provider/utils.ts +0 -136
  696. package/src/eth1/stream.ts +0 -75
  697. package/src/eth1/utils/depositContract.ts +0 -37
  698. package/src/eth1/utils/deposits.ts +0 -70
  699. package/src/eth1/utils/eth1Data.ts +0 -100
  700. package/src/eth1/utils/eth1DepositEvent.ts +0 -12
  701. package/src/eth1/utils/eth1Vote.ts +0 -142
  702. package/src/eth1/utils/groupDepositEventsByBlock.ts +0 -19
  703. package/src/eth1/utils/optimizeNextBlockDiffForGenesis.ts +0 -18
  704. package/src/execution/builder/cache.ts +0 -39
  705. package/src/execution/builder/http.ts +0 -229
  706. package/src/execution/builder/index.ts +0 -27
  707. package/src/execution/builder/interface.ts +0 -49
  708. package/src/execution/builder/utils.ts +0 -19
  709. package/src/execution/engine/disabled.ts +0 -35
  710. package/src/execution/engine/http.ts +0 -644
  711. package/src/execution/engine/index.ts +0 -63
  712. package/src/execution/engine/interface.ts +0 -199
  713. package/src/execution/engine/mock.ts +0 -493
  714. package/src/execution/engine/payloadIdCache.ts +0 -54
  715. package/src/execution/engine/types.ts +0 -640
  716. package/src/execution/engine/utils.ts +0 -136
  717. package/src/execution/index.ts +0 -4
  718. package/src/index.ts +0 -20
  719. package/src/metrics/index.ts +0 -4
  720. package/src/metrics/metrics/beacon.ts +0 -390
  721. package/src/metrics/metrics/lodestar.ts +0 -1870
  722. package/src/metrics/metrics.ts +0 -43
  723. package/src/metrics/nodeJsMetrics.ts +0 -19
  724. package/src/metrics/options.ts +0 -22
  725. package/src/metrics/server/http.ts +0 -114
  726. package/src/metrics/server/index.ts +0 -1
  727. package/src/metrics/utils/avgMinMax.ts +0 -87
  728. package/src/metrics/utils/gauge.ts +0 -22
  729. package/src/metrics/utils/registryMetricCreator.ts +0 -41
  730. package/src/monitoring/clientStats.ts +0 -297
  731. package/src/monitoring/index.ts +0 -2
  732. package/src/monitoring/options.ts +0 -19
  733. package/src/monitoring/properties.ts +0 -152
  734. package/src/monitoring/service.ts +0 -235
  735. package/src/monitoring/system.ts +0 -146
  736. package/src/monitoring/types.ts +0 -21
  737. package/src/network/core/events.ts +0 -59
  738. package/src/network/core/index.ts +0 -3
  739. package/src/network/core/metrics.ts +0 -304
  740. package/src/network/core/networkCore.ts +0 -599
  741. package/src/network/core/networkCoreWorker.ts +0 -176
  742. package/src/network/core/networkCoreWorkerHandler.ts +0 -284
  743. package/src/network/core/types.ts +0 -119
  744. package/src/network/discv5/index.ts +0 -132
  745. package/src/network/discv5/types.ts +0 -74
  746. package/src/network/discv5/utils.ts +0 -50
  747. package/src/network/discv5/worker.ts +0 -137
  748. package/src/network/events.ts +0 -51
  749. package/src/network/forks.ts +0 -94
  750. package/src/network/gossip/constants.ts +0 -15
  751. package/src/network/gossip/encoding.ts +0 -111
  752. package/src/network/gossip/errors.ts +0 -7
  753. package/src/network/gossip/gossipsub.ts +0 -384
  754. package/src/network/gossip/index.ts +0 -4
  755. package/src/network/gossip/interface.ts +0 -215
  756. package/src/network/gossip/metrics.ts +0 -71
  757. package/src/network/gossip/scoringParameters.ts +0 -333
  758. package/src/network/gossip/topic.ts +0 -332
  759. package/src/network/index.ts +0 -8
  760. package/src/network/interface.ts +0 -134
  761. package/src/network/libp2p/error.ts +0 -55
  762. package/src/network/libp2p/index.ts +0 -153
  763. package/src/network/metadata.ts +0 -162
  764. package/src/network/network.ts +0 -767
  765. package/src/network/networkConfig.ts +0 -12
  766. package/src/network/options.ts +0 -70
  767. package/src/network/peers/client.ts +0 -29
  768. package/src/network/peers/datastore.ts +0 -188
  769. package/src/network/peers/discover.ts +0 -647
  770. package/src/network/peers/index.ts +0 -2
  771. package/src/network/peers/peerManager.ts +0 -899
  772. package/src/network/peers/peersData.ts +0 -65
  773. package/src/network/peers/score/constants.ts +0 -34
  774. package/src/network/peers/score/index.ts +0 -4
  775. package/src/network/peers/score/interface.ts +0 -74
  776. package/src/network/peers/score/score.ts +0 -200
  777. package/src/network/peers/score/store.ts +0 -95
  778. package/src/network/peers/score/utils.ts +0 -37
  779. package/src/network/peers/utils/assertPeerRelevance.ts +0 -99
  780. package/src/network/peers/utils/enrSubnetsDeserialize.ts +0 -27
  781. package/src/network/peers/utils/getConnectedPeerIds.ts +0 -33
  782. package/src/network/peers/utils/index.ts +0 -4
  783. package/src/network/peers/utils/prioritizePeers.ts +0 -627
  784. package/src/network/peers/utils/subnetMap.ts +0 -88
  785. package/src/network/processor/aggregatorTracker.ts +0 -38
  786. package/src/network/processor/extractSlotRootFns.ts +0 -64
  787. package/src/network/processor/gossipHandlers.ts +0 -951
  788. package/src/network/processor/gossipQueues/index.ts +0 -114
  789. package/src/network/processor/gossipQueues/indexed.ts +0 -219
  790. package/src/network/processor/gossipQueues/linear.ts +0 -162
  791. package/src/network/processor/gossipQueues/types.ts +0 -57
  792. package/src/network/processor/gossipValidatorFn.ts +0 -142
  793. package/src/network/processor/index.ts +0 -496
  794. package/src/network/processor/types.ts +0 -27
  795. package/src/network/reqresp/ReqRespBeaconNode.ts +0 -373
  796. package/src/network/reqresp/handlers/beaconBlocksByRange.ts +0 -101
  797. package/src/network/reqresp/handlers/beaconBlocksByRoot.ts +0 -49
  798. package/src/network/reqresp/handlers/blobSidecarsByRange.ts +0 -114
  799. package/src/network/reqresp/handlers/blobSidecarsByRoot.ts +0 -62
  800. package/src/network/reqresp/handlers/dataColumnSidecarsByRange.ts +0 -144
  801. package/src/network/reqresp/handlers/dataColumnSidecarsByRoot.ts +0 -88
  802. package/src/network/reqresp/handlers/index.ts +0 -78
  803. package/src/network/reqresp/handlers/lightClientBootstrap.ts +0 -31
  804. package/src/network/reqresp/handlers/lightClientFinalityUpdate.ts +0 -21
  805. package/src/network/reqresp/handlers/lightClientOptimisticUpdate.ts +0 -21
  806. package/src/network/reqresp/handlers/lightClientUpdatesByRange.ts +0 -39
  807. package/src/network/reqresp/index.ts +0 -2
  808. package/src/network/reqresp/interface.ts +0 -45
  809. package/src/network/reqresp/protocols.ts +0 -146
  810. package/src/network/reqresp/rateLimit.ts +0 -112
  811. package/src/network/reqresp/score.ts +0 -70
  812. package/src/network/reqresp/types.ts +0 -174
  813. package/src/network/reqresp/utils/collect.ts +0 -84
  814. package/src/network/reqresp/utils/collectSequentialBlocksInRange.ts +0 -57
  815. package/src/network/reqresp/utils/dataColumnResponseValidation.ts +0 -99
  816. package/src/network/statusCache.ts +0 -17
  817. package/src/network/subnets/attnetsService.ts +0 -385
  818. package/src/network/subnets/index.ts +0 -2
  819. package/src/network/subnets/interface.ts +0 -66
  820. package/src/network/subnets/syncnetsService.ts +0 -147
  821. package/src/network/subnets/util.ts +0 -63
  822. package/src/network/util.ts +0 -29
  823. package/src/node/index.ts +0 -2
  824. package/src/node/nodejs.ts +0 -349
  825. package/src/node/notifier.ts +0 -206
  826. package/src/node/options.ts +0 -51
  827. package/src/node/utils/interop/deposits.ts +0 -53
  828. package/src/node/utils/interop/state.ts +0 -59
  829. package/src/node/utils/lightclient.ts +0 -7
  830. package/src/node/utils/state.ts +0 -37
  831. package/src/sync/backfill/backfill.ts +0 -893
  832. package/src/sync/backfill/errors.ts +0 -23
  833. package/src/sync/backfill/index.ts +0 -1
  834. package/src/sync/backfill/verify.ts +0 -58
  835. package/src/sync/constants.ts +0 -71
  836. package/src/sync/index.ts +0 -2
  837. package/src/sync/interface.ts +0 -55
  838. package/src/sync/options.ts +0 -45
  839. package/src/sync/range/batch.ts +0 -455
  840. package/src/sync/range/chain.ts +0 -715
  841. package/src/sync/range/range.ts +0 -354
  842. package/src/sync/range/utils/batches.ts +0 -119
  843. package/src/sync/range/utils/chainTarget.ts +0 -62
  844. package/src/sync/range/utils/hashBlocks.ts +0 -27
  845. package/src/sync/range/utils/index.ts +0 -5
  846. package/src/sync/range/utils/peerBalancer.ts +0 -184
  847. package/src/sync/range/utils/updateChains.ts +0 -66
  848. package/src/sync/sync.ts +0 -290
  849. package/src/sync/types.ts +0 -57
  850. package/src/sync/unknownBlock.ts +0 -859
  851. package/src/sync/utils/downloadByRange.ts +0 -808
  852. package/src/sync/utils/downloadByRoot.ts +0 -560
  853. package/src/sync/utils/pendingBlocksTree.ts +0 -97
  854. package/src/sync/utils/remoteSyncType.ts +0 -144
  855. package/src/util/address.ts +0 -3
  856. package/src/util/array.ts +0 -311
  857. package/src/util/asyncIterableToEvents.ts +0 -164
  858. package/src/util/binarySearch.ts +0 -48
  859. package/src/util/bitArray.ts +0 -84
  860. package/src/util/blobs.ts +0 -210
  861. package/src/util/bufferPool.ts +0 -95
  862. package/src/util/bytes.ts +0 -11
  863. package/src/util/chunkify.ts +0 -27
  864. package/src/util/clock.ts +0 -204
  865. package/src/util/dataColumns.ts +0 -415
  866. package/src/util/dependentRoot.ts +0 -47
  867. package/src/util/enum.ts +0 -17
  868. package/src/util/error.ts +0 -56
  869. package/src/util/eventLoop.ts +0 -22
  870. package/src/util/execution.ts +0 -223
  871. package/src/util/file.ts +0 -52
  872. package/src/util/forkChoice.ts +0 -5
  873. package/src/util/forkName.ts +0 -20
  874. package/src/util/graffiti.ts +0 -39
  875. package/src/util/hex.ts +0 -9
  876. package/src/util/index.ts +0 -2
  877. package/src/util/ip.ts +0 -6
  878. package/src/util/itTrigger.ts +0 -49
  879. package/src/util/kzg.ts +0 -3
  880. package/src/util/map.ts +0 -77
  881. package/src/util/metadata.ts +0 -22
  882. package/src/util/multifork.ts +0 -69
  883. package/src/util/numpy.ts +0 -8
  884. package/src/util/peerId.ts +0 -16
  885. package/src/util/profile.ts +0 -54
  886. package/src/util/promises.ts +0 -14
  887. package/src/util/queue/errors.ts +0 -14
  888. package/src/util/queue/fnQueue.ts +0 -16
  889. package/src/util/queue/index.ts +0 -4
  890. package/src/util/queue/itemQueue.ts +0 -128
  891. package/src/util/queue/options.ts +0 -37
  892. package/src/util/serializedCache.ts +0 -20
  893. package/src/util/set.ts +0 -62
  894. package/src/util/shuffle.ts +0 -21
  895. package/src/util/sortBy.ts +0 -19
  896. package/src/util/sszBytes.ts +0 -481
  897. package/src/util/strictEvents.ts +0 -8
  898. package/src/util/time.ts +0 -13
  899. package/src/util/timeSeries.ts +0 -118
  900. package/src/util/types.ts +0 -31
  901. package/src/util/workerEvents.ts +0 -142
  902. 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
- }