@lodestar/beacon-node 1.35.0-dev.21ba2777a9 → 1.35.0-dev.36a31f3a2f

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