@lodestar/beacon-node 1.35.0-dev.91dadf81de → 1.35.0-dev.955e9f89ed

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 (1276) 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/errors.js +0 -2
  7. package/lib/api/impl/errors.js.map +1 -1
  8. package/lib/api/impl/index.d.ts +3 -3
  9. package/lib/api/impl/index.js +3 -3
  10. package/lib/api/impl/index.js.map +1 -1
  11. package/lib/api/impl/validator/index.js +3 -5
  12. package/lib/api/impl/validator/index.js.map +1 -1
  13. package/lib/api/rest/activeSockets.js +2 -3
  14. package/lib/api/rest/activeSockets.js.map +1 -1
  15. package/lib/api/rest/base.d.ts +1 -1
  16. package/lib/api/rest/base.js +2 -6
  17. package/lib/api/rest/base.js.map +1 -1
  18. package/lib/api/rest/index.js +0 -2
  19. package/lib/api/rest/index.js.map +1 -1
  20. package/lib/api/rest/swaggerUI.js +2 -4
  21. package/lib/api/rest/swaggerUI.js.map +1 -1
  22. package/lib/chain/ColumnReconstructionTracker.d.ts +2 -2
  23. package/lib/chain/ColumnReconstructionTracker.js +12 -34
  24. package/lib/chain/ColumnReconstructionTracker.js.map +1 -1
  25. package/lib/chain/GetBlobsTracker.d.ts +2 -2
  26. package/lib/chain/GetBlobsTracker.js +8 -28
  27. package/lib/chain/GetBlobsTracker.js.map +1 -1
  28. package/lib/chain/archiveStore/archiveStore.js +38 -49
  29. package/lib/chain/archiveStore/archiveStore.js.map +1 -1
  30. package/lib/chain/archiveStore/historicalState/historicalStateRegen.js +0 -3
  31. package/lib/chain/archiveStore/historicalState/historicalStateRegen.js.map +1 -1
  32. package/lib/chain/archiveStore/historicalState/worker.js +1 -1
  33. package/lib/chain/archiveStore/historicalState/worker.js.map +1 -1
  34. package/lib/chain/archiveStore/index.d.ts +1 -1
  35. package/lib/chain/archiveStore/index.js +1 -1
  36. package/lib/chain/archiveStore/strategies/frequencyStateArchiveStrategy.js +0 -5
  37. package/lib/chain/archiveStore/strategies/frequencyStateArchiveStrategy.js.map +1 -1
  38. package/lib/chain/balancesCache.js +3 -1
  39. package/lib/chain/balancesCache.js.map +1 -1
  40. package/lib/chain/beaconProposerCache.js +0 -1
  41. package/lib/chain/beaconProposerCache.js.map +1 -1
  42. package/lib/chain/blocks/blockInput/blockInput.js +8 -19
  43. package/lib/chain/blocks/blockInput/blockInput.js.map +1 -1
  44. package/lib/chain/blocks/blockInput/index.d.ts +1 -1
  45. package/lib/chain/blocks/blockInput/index.js +1 -1
  46. package/lib/chain/blocks/importBlock.js +3 -4
  47. package/lib/chain/blocks/importBlock.js.map +1 -1
  48. package/lib/chain/blocks/index.d.ts +1 -1
  49. package/lib/chain/blocks/index.js +0 -1
  50. package/lib/chain/blocks/index.js.map +1 -1
  51. package/lib/chain/blocks/verifyBlocksDataAvailability.js +1 -8
  52. package/lib/chain/blocks/verifyBlocksDataAvailability.js.map +1 -1
  53. package/lib/chain/blocks/verifyBlocksExecutionPayloads.d.ts +1 -1
  54. package/lib/chain/blocks/verifyBlocksExecutionPayloads.js.map +1 -1
  55. package/lib/chain/bls/multithread/index.js +163 -168
  56. package/lib/chain/bls/multithread/index.js.map +1 -1
  57. package/lib/chain/bls/singleThread.js +0 -1
  58. package/lib/chain/bls/singleThread.js.map +1 -1
  59. package/lib/chain/chain.d.ts +6 -6
  60. package/lib/chain/chain.js +20 -64
  61. package/lib/chain/chain.js.map +1 -1
  62. package/lib/chain/emitter.d.ts +2 -2
  63. package/lib/chain/emitter.js.map +1 -1
  64. package/lib/chain/errors/blockError.js +0 -1
  65. package/lib/chain/errors/blockError.js.map +1 -1
  66. package/lib/chain/errors/gossipValidation.js +0 -1
  67. package/lib/chain/errors/gossipValidation.js.map +1 -1
  68. package/lib/chain/errors/index.d.ts +2 -2
  69. package/lib/chain/errors/index.js +2 -2
  70. package/lib/chain/errors/index.js.map +1 -1
  71. package/lib/chain/forkChoice/index.js.map +1 -1
  72. package/lib/chain/genesis/genesis.js +5 -16
  73. package/lib/chain/genesis/genesis.js.map +1 -1
  74. package/lib/chain/index.d.ts +2 -2
  75. package/lib/chain/index.js +2 -2
  76. package/lib/chain/index.js.map +1 -1
  77. package/lib/chain/interface.d.ts +4 -4
  78. package/lib/chain/interface.js.map +1 -1
  79. package/lib/chain/lightClient/index.js +9 -16
  80. package/lib/chain/lightClient/index.js.map +1 -1
  81. package/lib/chain/lightClient/proofs.js.map +1 -1
  82. package/lib/chain/opPools/aggregatedAttestationPool.js +9 -14
  83. package/lib/chain/opPools/aggregatedAttestationPool.js.map +1 -1
  84. package/lib/chain/opPools/attestationPool.d.ts +3 -2
  85. package/lib/chain/opPools/attestationPool.js +7 -10
  86. package/lib/chain/opPools/attestationPool.js.map +1 -1
  87. package/lib/chain/opPools/index.d.ts +1 -1
  88. package/lib/chain/opPools/index.js +1 -1
  89. package/lib/chain/opPools/index.js.map +1 -1
  90. package/lib/chain/opPools/opPool.js +12 -10
  91. package/lib/chain/opPools/opPool.js.map +1 -1
  92. package/lib/chain/opPools/syncCommitteeMessagePool.d.ts +2 -3
  93. package/lib/chain/opPools/syncCommitteeMessagePool.js +10 -14
  94. package/lib/chain/opPools/syncCommitteeMessagePool.js.map +1 -1
  95. package/lib/chain/opPools/syncContributionAndProofPool.js +2 -5
  96. package/lib/chain/opPools/syncContributionAndProofPool.js.map +1 -1
  97. package/lib/chain/opPools/types.d.ts +1 -1
  98. package/lib/chain/opPools/types.js +1 -1
  99. package/lib/chain/opPools/types.js.map +1 -1
  100. package/lib/chain/options.js +1 -1
  101. package/lib/chain/options.js.map +1 -1
  102. package/lib/chain/prepareNextSlot.d.ts +3 -3
  103. package/lib/chain/prepareNextSlot.js +140 -145
  104. package/lib/chain/prepareNextSlot.js.map +1 -1
  105. package/lib/chain/produceBlock/produceBlockBody.d.ts +1 -1
  106. package/lib/chain/produceBlock/produceBlockBody.js +10 -3
  107. package/lib/chain/produceBlock/produceBlockBody.js.map +1 -1
  108. package/lib/chain/regen/errors.js +0 -1
  109. package/lib/chain/regen/errors.js.map +1 -1
  110. package/lib/chain/regen/index.d.ts +1 -1
  111. package/lib/chain/regen/index.js +1 -1
  112. package/lib/chain/regen/index.js.map +1 -1
  113. package/lib/chain/regen/queued.js +28 -35
  114. package/lib/chain/regen/queued.js.map +1 -1
  115. package/lib/chain/regen/regen.js +0 -1
  116. package/lib/chain/regen/regen.js.map +1 -1
  117. package/lib/chain/reprocess.js +1 -3
  118. package/lib/chain/reprocess.js.map +1 -1
  119. package/lib/chain/seenCache/seenAggregateAndProof.js +6 -7
  120. package/lib/chain/seenCache/seenAggregateAndProof.js.map +1 -1
  121. package/lib/chain/seenCache/seenAttestationData.js +2 -5
  122. package/lib/chain/seenCache/seenAttestationData.js.map +1 -1
  123. package/lib/chain/seenCache/seenAttesters.js +4 -2
  124. package/lib/chain/seenCache/seenAttesters.js.map +1 -1
  125. package/lib/chain/seenCache/seenBlockProposers.js +4 -2
  126. package/lib/chain/seenCache/seenBlockProposers.js.map +1 -1
  127. package/lib/chain/seenCache/seenCommittee.js +3 -1
  128. package/lib/chain/seenCache/seenCommittee.js.map +1 -1
  129. package/lib/chain/seenCache/seenCommitteeContribution.js +2 -3
  130. package/lib/chain/seenCache/seenCommitteeContribution.js.map +1 -1
  131. package/lib/chain/seenCache/seenGossipBlockInput.js +13 -20
  132. package/lib/chain/seenCache/seenGossipBlockInput.js.map +1 -1
  133. package/lib/chain/shufflingCache.js +2 -5
  134. package/lib/chain/shufflingCache.js.map +1 -1
  135. package/lib/chain/stateCache/blockStateCacheImpl.js +7 -13
  136. package/lib/chain/stateCache/blockStateCacheImpl.js.map +1 -1
  137. package/lib/chain/stateCache/datastore/db.js +0 -1
  138. package/lib/chain/stateCache/datastore/db.js.map +1 -1
  139. package/lib/chain/stateCache/datastore/file.js +0 -1
  140. package/lib/chain/stateCache/datastore/file.js.map +1 -1
  141. package/lib/chain/stateCache/datastore/index.d.ts +1 -1
  142. package/lib/chain/stateCache/datastore/index.js +1 -1
  143. package/lib/chain/stateCache/datastore/index.js.map +1 -1
  144. package/lib/chain/stateCache/fifoBlockStateCache.js +0 -10
  145. package/lib/chain/stateCache/fifoBlockStateCache.js.map +1 -1
  146. package/lib/chain/stateCache/inMemoryCheckpointsCache.js +4 -10
  147. package/lib/chain/stateCache/inMemoryCheckpointsCache.js.map +1 -1
  148. package/lib/chain/stateCache/index.d.ts +1 -1
  149. package/lib/chain/stateCache/index.js +1 -1
  150. package/lib/chain/stateCache/index.js.map +1 -1
  151. package/lib/chain/stateCache/mapMetrics.js +4 -4
  152. package/lib/chain/stateCache/mapMetrics.js.map +1 -1
  153. package/lib/chain/stateCache/persistentCheckpointsCache.js +14 -23
  154. package/lib/chain/stateCache/persistentCheckpointsCache.js.map +1 -1
  155. package/lib/chain/validation/blobSidecar.js.map +1 -1
  156. package/lib/chain/validation/dataColumnSidecar.js +1 -1
  157. package/lib/chain/validation/dataColumnSidecar.js.map +1 -1
  158. package/lib/chain/validation/index.d.ts +1 -1
  159. package/lib/chain/validation/index.js +1 -1
  160. package/lib/chain/validation/index.js.map +1 -1
  161. package/lib/chain/validation/lightClientFinalityUpdate.js +3 -4
  162. package/lib/chain/validation/lightClientFinalityUpdate.js.map +1 -1
  163. package/lib/chain/validation/lightClientOptimisticUpdate.d.ts +4 -6
  164. package/lib/chain/validation/lightClientOptimisticUpdate.js +11 -11
  165. package/lib/chain/validation/lightClientOptimisticUpdate.js.map +1 -1
  166. package/lib/chain/validation/signatureSets/aggregateAndProof.d.ts +2 -1
  167. package/lib/chain/validation/signatureSets/aggregateAndProof.js.map +1 -1
  168. package/lib/chain/validatorMonitor.d.ts +3 -1
  169. package/lib/chain/validatorMonitor.js +15 -22
  170. package/lib/chain/validatorMonitor.js.map +1 -1
  171. package/lib/db/beacon.js +0 -24
  172. package/lib/db/beacon.js.map +1 -1
  173. package/lib/db/buckets.d.ts +4 -4
  174. package/lib/db/buckets.js +4 -4
  175. package/lib/db/buckets.js.map +1 -1
  176. package/lib/db/index.d.ts +1 -1
  177. package/lib/db/index.js.map +1 -1
  178. package/lib/db/repositories/blobSidecars.js +1 -1
  179. package/lib/db/repositories/blobSidecars.js.map +1 -1
  180. package/lib/db/repositories/blobSidecarsArchive.js +1 -1
  181. package/lib/db/repositories/blobSidecarsArchive.js.map +1 -1
  182. package/lib/db/repositories/blockArchive.js +3 -2
  183. package/lib/db/repositories/blockArchive.js.map +1 -1
  184. package/lib/db/repositories/blockArchiveIndex.d.ts +2 -2
  185. package/lib/db/repositories/dataColumnSidecar.js +2 -2
  186. package/lib/db/repositories/dataColumnSidecar.js.map +1 -1
  187. package/lib/db/repositories/dataColumnSidecarArchive.js +2 -2
  188. package/lib/db/repositories/dataColumnSidecarArchive.js.map +1 -1
  189. package/lib/db/repositories/depositDataRoot.js +0 -1
  190. package/lib/db/repositories/depositDataRoot.js.map +1 -1
  191. package/lib/db/repositories/index.d.ts +10 -10
  192. package/lib/db/repositories/index.js +9 -9
  193. package/lib/db/repositories/index.js.map +1 -1
  194. package/lib/db/single/preGenesisState.js +0 -6
  195. package/lib/db/single/preGenesisState.js.map +1 -1
  196. package/lib/db/single/preGenesisStateLastProcessedBlock.js +0 -5
  197. package/lib/db/single/preGenesisStateLastProcessedBlock.js.map +1 -1
  198. package/lib/eth1/eth1DataCache.js +0 -2
  199. package/lib/eth1/eth1DataCache.js.map +1 -1
  200. package/lib/eth1/eth1DepositDataTracker.js +5 -18
  201. package/lib/eth1/eth1DepositDataTracker.js.map +1 -1
  202. package/lib/eth1/eth1DepositsCache.js +0 -3
  203. package/lib/eth1/eth1DepositsCache.js.map +1 -1
  204. package/lib/eth1/eth1MergeBlockTracker.js +4 -10
  205. package/lib/eth1/eth1MergeBlockTracker.js.map +1 -1
  206. package/lib/eth1/index.js +0 -2
  207. package/lib/eth1/index.js.map +1 -1
  208. package/lib/eth1/provider/eth1Provider.d.ts +2 -1
  209. package/lib/eth1/provider/eth1Provider.js +2 -6
  210. package/lib/eth1/provider/eth1Provider.js.map +1 -1
  211. package/lib/eth1/provider/jsonRpcHttpClient.d.ts +1 -1
  212. package/lib/eth1/provider/jsonRpcHttpClient.js +2 -16
  213. package/lib/eth1/provider/jsonRpcHttpClient.js.map +1 -1
  214. package/lib/eth1/provider/jwt.js.map +1 -1
  215. package/lib/eth1/utils/deposits.js.map +1 -1
  216. package/lib/execution/builder/cache.js +0 -6
  217. package/lib/execution/builder/cache.js.map +1 -1
  218. package/lib/execution/builder/http.js +8 -14
  219. package/lib/execution/builder/http.js.map +1 -1
  220. package/lib/execution/builder/index.js.map +1 -1
  221. package/lib/execution/engine/disabled.js +4 -2
  222. package/lib/execution/engine/disabled.js.map +1 -1
  223. package/lib/execution/engine/http.js +8 -23
  224. package/lib/execution/engine/http.js.map +1 -1
  225. package/lib/execution/engine/interface.js.map +1 -1
  226. package/lib/execution/engine/mock.d.ts +0 -1
  227. package/lib/execution/engine/mock.js +12 -16
  228. package/lib/execution/engine/mock.js.map +1 -1
  229. package/lib/execution/engine/payloadIdCache.js +3 -1
  230. package/lib/execution/engine/payloadIdCache.js.map +1 -1
  231. package/lib/execution/engine/types.d.ts +1 -0
  232. package/lib/execution/engine/types.js.map +1 -1
  233. package/lib/execution/engine/utils.js +3 -3
  234. package/lib/execution/engine/utils.js.map +1 -1
  235. package/lib/execution/index.d.ts +2 -2
  236. package/lib/execution/index.js +2 -2
  237. package/lib/execution/index.js.map +1 -1
  238. package/lib/index.d.ts +6 -6
  239. package/lib/index.js +5 -5
  240. package/lib/index.js.map +1 -1
  241. package/lib/metrics/index.d.ts +1 -1
  242. package/lib/metrics/index.js +1 -1
  243. package/lib/metrics/index.js.map +1 -1
  244. package/lib/metrics/metrics/lodestar.d.ts +2 -7
  245. package/lib/metrics/metrics/lodestar.js +4 -13
  246. package/lib/metrics/metrics/lodestar.js.map +1 -1
  247. package/lib/metrics/metrics.d.ts +1 -1
  248. package/lib/metrics/metrics.js.map +1 -1
  249. package/lib/metrics/nodeJsMetrics.js +1 -1
  250. package/lib/metrics/nodeJsMetrics.js.map +1 -1
  251. package/lib/metrics/server/http.d.ts +1 -1
  252. package/lib/metrics/utils/avgMinMax.d.ts +1 -1
  253. package/lib/metrics/utils/avgMinMax.js +6 -10
  254. package/lib/metrics/utils/avgMinMax.js.map +1 -1
  255. package/lib/metrics/utils/gauge.d.ts +1 -1
  256. package/lib/metrics/utils/gauge.js +4 -1
  257. package/lib/metrics/utils/gauge.js.map +1 -1
  258. package/lib/metrics/utils/registryMetricCreator.d.ts +1 -1
  259. package/lib/metrics/utils/registryMetricCreator.js.map +1 -1
  260. package/lib/monitoring/properties.js +0 -4
  261. package/lib/monitoring/properties.js.map +1 -1
  262. package/lib/monitoring/service.js +1 -13
  263. package/lib/monitoring/service.js.map +1 -1
  264. package/lib/monitoring/system.js +27 -25
  265. package/lib/monitoring/system.js.map +1 -1
  266. package/lib/network/core/networkCore.d.ts +2 -2
  267. package/lib/network/core/networkCore.js +50 -67
  268. package/lib/network/core/networkCore.js.map +1 -1
  269. package/lib/network/core/networkCoreWorker.js +1 -1
  270. package/lib/network/core/networkCoreWorker.js.map +1 -1
  271. package/lib/network/core/networkCoreWorkerHandler.d.ts +2 -2
  272. package/lib/network/core/networkCoreWorkerHandler.js +5 -14
  273. package/lib/network/core/networkCoreWorkerHandler.js.map +1 -1
  274. package/lib/network/discv5/index.d.ts +2 -2
  275. package/lib/network/discv5/index.js +3 -9
  276. package/lib/network/discv5/index.js.map +1 -1
  277. package/lib/network/discv5/worker.js +3 -3
  278. package/lib/network/discv5/worker.js.map +1 -1
  279. package/lib/network/gossip/encoding.d.ts +1 -1
  280. package/lib/network/gossip/encoding.js +2 -4
  281. package/lib/network/gossip/encoding.js.map +1 -1
  282. package/lib/network/gossip/errors.js +0 -1
  283. package/lib/network/gossip/errors.js.map +1 -1
  284. package/lib/network/gossip/gossipsub.d.ts +1 -2
  285. package/lib/network/gossip/gossipsub.js +17 -43
  286. package/lib/network/gossip/gossipsub.js.map +1 -1
  287. package/lib/network/gossip/index.d.ts +2 -2
  288. package/lib/network/gossip/index.js +2 -2
  289. package/lib/network/gossip/index.js.map +1 -1
  290. package/lib/network/gossip/interface.d.ts +2 -2
  291. package/lib/network/gossip/metrics.d.ts +7 -15
  292. package/lib/network/gossip/metrics.js +6 -16
  293. package/lib/network/gossip/metrics.js.map +1 -1
  294. package/lib/network/gossip/topic.d.ts +105 -125
  295. package/lib/network/gossip/topic.js +1 -2
  296. package/lib/network/gossip/topic.js.map +1 -1
  297. package/lib/network/index.d.ts +3 -3
  298. package/lib/network/index.js +3 -3
  299. package/lib/network/index.js.map +1 -1
  300. package/lib/network/interface.d.ts +1 -1
  301. package/lib/network/libp2p/index.js +3 -11
  302. package/lib/network/libp2p/index.js.map +1 -1
  303. package/lib/network/metadata.js +1 -6
  304. package/lib/network/metadata.js.map +1 -1
  305. package/lib/network/network.d.ts +2 -2
  306. package/lib/network/network.js +77 -89
  307. package/lib/network/network.js.map +1 -1
  308. package/lib/network/peers/datastore.d.ts +2 -2
  309. package/lib/network/peers/datastore.js +4 -10
  310. package/lib/network/peers/datastore.js.map +1 -1
  311. package/lib/network/peers/discover.js +66 -75
  312. package/lib/network/peers/discover.js.map +1 -1
  313. package/lib/network/peers/peerManager.js +125 -145
  314. package/lib/network/peers/peerManager.js.map +1 -1
  315. package/lib/network/peers/peersData.js +3 -1
  316. package/lib/network/peers/peersData.js.map +1 -1
  317. package/lib/network/peers/score/index.d.ts +1 -1
  318. package/lib/network/peers/score/index.js +1 -1
  319. package/lib/network/peers/score/index.js.map +1 -1
  320. package/lib/network/peers/score/score.js +0 -6
  321. package/lib/network/peers/score/score.js.map +1 -1
  322. package/lib/network/peers/score/store.js +0 -3
  323. package/lib/network/peers/score/store.js.map +1 -1
  324. package/lib/network/peers/utils/prioritizePeers.js.map +1 -1
  325. package/lib/network/peers/utils/subnetMap.js +4 -2
  326. package/lib/network/peers/utils/subnetMap.js.map +1 -1
  327. package/lib/network/processor/aggregatorTracker.js +3 -1
  328. package/lib/network/processor/aggregatorTracker.js.map +1 -1
  329. package/lib/network/processor/gossipHandlers.js +7 -3
  330. package/lib/network/processor/gossipHandlers.js.map +1 -1
  331. package/lib/network/processor/gossipQueues/indexed.js +9 -11
  332. package/lib/network/processor/gossipQueues/indexed.js.map +1 -1
  333. package/lib/network/processor/gossipQueues/linear.js +8 -9
  334. package/lib/network/processor/gossipQueues/linear.js.map +1 -1
  335. package/lib/network/processor/index.d.ts +1 -1
  336. package/lib/network/processor/index.js +8 -18
  337. package/lib/network/processor/index.js.map +1 -1
  338. package/lib/network/reqresp/ReqRespBeaconNode.d.ts +1 -1
  339. package/lib/network/reqresp/ReqRespBeaconNode.js +2 -11
  340. package/lib/network/reqresp/ReqRespBeaconNode.js.map +1 -1
  341. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js.map +1 -1
  342. package/lib/network/reqresp/index.d.ts +1 -1
  343. package/lib/network/reqresp/index.js +1 -1
  344. package/lib/network/reqresp/index.js.map +1 -1
  345. package/lib/network/reqresp/rateLimit.js +2 -2
  346. package/lib/network/reqresp/rateLimit.js.map +1 -1
  347. package/lib/network/reqresp/utils/dataColumnResponseValidation.js.map +1 -1
  348. package/lib/network/statusCache.js +0 -1
  349. package/lib/network/statusCache.js.map +1 -1
  350. package/lib/network/subnets/attnetsService.js +65 -73
  351. package/lib/network/subnets/attnetsService.js.map +1 -1
  352. package/lib/network/subnets/interface.js +1 -1
  353. package/lib/network/subnets/interface.js.map +1 -1
  354. package/lib/network/subnets/syncnetsService.js +22 -29
  355. package/lib/network/subnets/syncnetsService.js.map +1 -1
  356. package/lib/network/subnets/util.js +2 -1
  357. package/lib/network/subnets/util.js.map +1 -1
  358. package/lib/node/nodejs.d.ts +1 -1
  359. package/lib/node/nodejs.js +0 -15
  360. package/lib/node/nodejs.js.map +1 -1
  361. package/lib/node/notifier.js +2 -1
  362. package/lib/node/notifier.js.map +1 -1
  363. package/lib/node/options.js.map +1 -1
  364. package/lib/node/utils/interop/state.js +2 -1
  365. package/lib/node/utils/interop/state.js.map +1 -1
  366. package/lib/sync/backfill/backfill.d.ts +1 -1
  367. package/lib/sync/backfill/backfill.js +16 -58
  368. package/lib/sync/backfill/backfill.js.map +1 -1
  369. package/lib/sync/range/batch.d.ts +2 -2
  370. package/lib/sync/range/batch.js +11 -20
  371. package/lib/sync/range/batch.js.map +1 -1
  372. package/lib/sync/range/chain.d.ts +1 -1
  373. package/lib/sync/range/chain.js +8 -33
  374. package/lib/sync/range/chain.js.map +1 -1
  375. package/lib/sync/range/range.d.ts +1 -1
  376. package/lib/sync/range/range.js +70 -76
  377. package/lib/sync/range/range.js.map +1 -1
  378. package/lib/sync/range/utils/peerBalancer.js +1 -5
  379. package/lib/sync/range/utils/peerBalancer.js.map +1 -1
  380. package/lib/sync/sync.d.ts +2 -1
  381. package/lib/sync/sync.js +85 -93
  382. package/lib/sync/sync.js.map +1 -1
  383. package/lib/sync/types.d.ts +1 -0
  384. package/lib/sync/types.js.map +1 -1
  385. package/lib/sync/unknownBlock.d.ts +1 -0
  386. package/lib/sync/unknownBlock.js +172 -181
  387. package/lib/sync/unknownBlock.js.map +1 -1
  388. package/lib/sync/utils/downloadByRange.d.ts +1 -1
  389. package/lib/sync/utils/downloadByRoot.d.ts +2 -4
  390. package/lib/sync/utils/downloadByRoot.js +9 -36
  391. package/lib/sync/utils/downloadByRoot.js.map +1 -1
  392. package/lib/util/array.js +3 -7
  393. package/lib/util/array.js.map +1 -1
  394. package/lib/util/asyncIterableToEvents.js +3 -6
  395. package/lib/util/asyncIterableToEvents.js.map +1 -1
  396. package/lib/util/binarySearch.js +0 -2
  397. package/lib/util/binarySearch.js.map +1 -1
  398. package/lib/util/blobs.js +3 -5
  399. package/lib/util/blobs.js.map +1 -1
  400. package/lib/util/bufferPool.js +2 -7
  401. package/lib/util/bufferPool.js.map +1 -1
  402. package/lib/util/clock.d.ts +1 -6
  403. package/lib/util/clock.js +18 -26
  404. package/lib/util/clock.js.map +1 -1
  405. package/lib/util/dataColumns.d.ts +15 -9
  406. package/lib/util/dataColumns.js +29 -50
  407. package/lib/util/dataColumns.js.map +1 -1
  408. package/lib/util/execution.d.ts +3 -12
  409. package/lib/util/execution.js +13 -47
  410. package/lib/util/execution.js.map +1 -1
  411. package/lib/util/itTrigger.js +4 -4
  412. package/lib/util/itTrigger.js.map +1 -1
  413. package/lib/util/map.js +0 -2
  414. package/lib/util/map.js.map +1 -1
  415. package/lib/util/queue/index.d.ts +1 -1
  416. package/lib/util/queue/index.js +1 -1
  417. package/lib/util/queue/index.js.map +1 -1
  418. package/lib/util/queue/itemQueue.js +49 -52
  419. package/lib/util/queue/itemQueue.js.map +1 -1
  420. package/lib/util/serializedCache.js +3 -1
  421. package/lib/util/serializedCache.js.map +1 -1
  422. package/lib/util/set.js +0 -2
  423. package/lib/util/set.js.map +1 -1
  424. package/lib/util/timeSeries.js +1 -3
  425. package/lib/util/timeSeries.js.map +1 -1
  426. package/lib/util/types.d.ts +1 -1
  427. package/package.json +23 -39
  428. package/lib/api/impl/api.d.ts.map +0 -1
  429. package/lib/api/impl/beacon/blocks/index.d.ts.map +0 -1
  430. package/lib/api/impl/beacon/blocks/utils.d.ts.map +0 -1
  431. package/lib/api/impl/beacon/index.d.ts.map +0 -1
  432. package/lib/api/impl/beacon/pool/index.d.ts.map +0 -1
  433. package/lib/api/impl/beacon/rewards/index.d.ts.map +0 -1
  434. package/lib/api/impl/beacon/state/index.d.ts.map +0 -1
  435. package/lib/api/impl/beacon/state/utils.d.ts.map +0 -1
  436. package/lib/api/impl/config/constants.d.ts.map +0 -1
  437. package/lib/api/impl/config/index.d.ts.map +0 -1
  438. package/lib/api/impl/debug/index.d.ts.map +0 -1
  439. package/lib/api/impl/errors.d.ts.map +0 -1
  440. package/lib/api/impl/events/index.d.ts.map +0 -1
  441. package/lib/api/impl/index.d.ts.map +0 -1
  442. package/lib/api/impl/lightclient/index.d.ts.map +0 -1
  443. package/lib/api/impl/lodestar/index.d.ts.map +0 -1
  444. package/lib/api/impl/node/index.d.ts.map +0 -1
  445. package/lib/api/impl/node/utils.d.ts.map +0 -1
  446. package/lib/api/impl/proof/index.d.ts.map +0 -1
  447. package/lib/api/impl/types.d.ts.map +0 -1
  448. package/lib/api/impl/utils.d.ts.map +0 -1
  449. package/lib/api/impl/validator/index.d.ts.map +0 -1
  450. package/lib/api/impl/validator/utils.d.ts.map +0 -1
  451. package/lib/api/index.d.ts.map +0 -1
  452. package/lib/api/options.d.ts.map +0 -1
  453. package/lib/api/rest/activeSockets.d.ts.map +0 -1
  454. package/lib/api/rest/base.d.ts.map +0 -1
  455. package/lib/api/rest/index.d.ts.map +0 -1
  456. package/lib/api/rest/swaggerUI.d.ts.map +0 -1
  457. package/lib/bun-wrappers/prometheus-gc-stats.d.ts +0 -2
  458. package/lib/bun-wrappers/prometheus-gc-stats.d.ts.map +0 -1
  459. package/lib/bun-wrappers/prometheus-gc-stats.js +0 -8
  460. package/lib/bun-wrappers/prometheus-gc-stats.js.map +0 -1
  461. package/lib/chain/ColumnReconstructionTracker.d.ts.map +0 -1
  462. package/lib/chain/GetBlobsTracker.d.ts.map +0 -1
  463. package/lib/chain/archiveStore/archiveStore.d.ts.map +0 -1
  464. package/lib/chain/archiveStore/constants.d.ts.map +0 -1
  465. package/lib/chain/archiveStore/historicalState/getHistoricalState.d.ts.map +0 -1
  466. package/lib/chain/archiveStore/historicalState/historicalStateRegen.d.ts.map +0 -1
  467. package/lib/chain/archiveStore/historicalState/metrics.d.ts.map +0 -1
  468. package/lib/chain/archiveStore/historicalState/types.d.ts.map +0 -1
  469. package/lib/chain/archiveStore/historicalState/worker.d.ts.map +0 -1
  470. package/lib/chain/archiveStore/index.d.ts.map +0 -1
  471. package/lib/chain/archiveStore/interface.d.ts.map +0 -1
  472. package/lib/chain/archiveStore/strategies/frequencyStateArchiveStrategy.d.ts.map +0 -1
  473. package/lib/chain/archiveStore/utils/archiveBlocks.d.ts.map +0 -1
  474. package/lib/chain/archiveStore/utils/pruneHistory.d.ts.map +0 -1
  475. package/lib/chain/archiveStore/utils/updateBackfillRange.d.ts.map +0 -1
  476. package/lib/chain/balancesCache.d.ts.map +0 -1
  477. package/lib/chain/beaconProposerCache.d.ts.map +0 -1
  478. package/lib/chain/blocks/blockInput/blockInput.d.ts.map +0 -1
  479. package/lib/chain/blocks/blockInput/errors.d.ts.map +0 -1
  480. package/lib/chain/blocks/blockInput/index.d.ts.map +0 -1
  481. package/lib/chain/blocks/blockInput/types.d.ts.map +0 -1
  482. package/lib/chain/blocks/blockInput/utils.d.ts.map +0 -1
  483. package/lib/chain/blocks/importBlock.d.ts.map +0 -1
  484. package/lib/chain/blocks/index.d.ts.map +0 -1
  485. package/lib/chain/blocks/types.d.ts.map +0 -1
  486. package/lib/chain/blocks/utils/blowfishBanner.d.ts.map +0 -1
  487. package/lib/chain/blocks/utils/chainSegment.d.ts.map +0 -1
  488. package/lib/chain/blocks/utils/checkpoint.d.ts.map +0 -1
  489. package/lib/chain/blocks/utils/giraffeBanner.d.ts.map +0 -1
  490. package/lib/chain/blocks/utils/ownBanner.d.ts.map +0 -1
  491. package/lib/chain/blocks/utils/pandaMergeTransitionBanner.d.ts.map +0 -1
  492. package/lib/chain/blocks/utils/zebraBanner.d.ts.map +0 -1
  493. package/lib/chain/blocks/verifyBlock.d.ts.map +0 -1
  494. package/lib/chain/blocks/verifyBlocksDataAvailability.d.ts.map +0 -1
  495. package/lib/chain/blocks/verifyBlocksExecutionPayloads.d.ts.map +0 -1
  496. package/lib/chain/blocks/verifyBlocksSanityChecks.d.ts.map +0 -1
  497. package/lib/chain/blocks/verifyBlocksSignatures.d.ts.map +0 -1
  498. package/lib/chain/blocks/verifyBlocksStateTransitionOnly.d.ts.map +0 -1
  499. package/lib/chain/blocks/writeBlockInputToDb.d.ts.map +0 -1
  500. package/lib/chain/bls/index.d.ts.map +0 -1
  501. package/lib/chain/bls/interface.d.ts.map +0 -1
  502. package/lib/chain/bls/maybeBatch.d.ts.map +0 -1
  503. package/lib/chain/bls/multithread/index.d.ts.map +0 -1
  504. package/lib/chain/bls/multithread/jobItem.d.ts.map +0 -1
  505. package/lib/chain/bls/multithread/poolSize.d.ts.map +0 -1
  506. package/lib/chain/bls/multithread/types.d.ts.map +0 -1
  507. package/lib/chain/bls/multithread/utils.d.ts.map +0 -1
  508. package/lib/chain/bls/multithread/worker.d.ts.map +0 -1
  509. package/lib/chain/bls/singleThread.d.ts.map +0 -1
  510. package/lib/chain/bls/utils.d.ts.map +0 -1
  511. package/lib/chain/chain.d.ts.map +0 -1
  512. package/lib/chain/emitter.d.ts.map +0 -1
  513. package/lib/chain/errors/attestationError.d.ts.map +0 -1
  514. package/lib/chain/errors/attesterSlashingError.d.ts.map +0 -1
  515. package/lib/chain/errors/blobSidecarError.d.ts.map +0 -1
  516. package/lib/chain/errors/blockError.d.ts.map +0 -1
  517. package/lib/chain/errors/blsToExecutionChangeError.d.ts.map +0 -1
  518. package/lib/chain/errors/dataColumnSidecarError.d.ts.map +0 -1
  519. package/lib/chain/errors/gossipValidation.d.ts.map +0 -1
  520. package/lib/chain/errors/index.d.ts.map +0 -1
  521. package/lib/chain/errors/lightClientError.d.ts.map +0 -1
  522. package/lib/chain/errors/proposerSlashingError.d.ts.map +0 -1
  523. package/lib/chain/errors/syncCommitteeError.d.ts.map +0 -1
  524. package/lib/chain/errors/voluntaryExitError.d.ts.map +0 -1
  525. package/lib/chain/forkChoice/index.d.ts.map +0 -1
  526. package/lib/chain/genesis/genesis.d.ts.map +0 -1
  527. package/lib/chain/genesis/interface.d.ts.map +0 -1
  528. package/lib/chain/index.d.ts.map +0 -1
  529. package/lib/chain/initState.d.ts.map +0 -1
  530. package/lib/chain/interface.d.ts.map +0 -1
  531. package/lib/chain/lightClient/index.d.ts.map +0 -1
  532. package/lib/chain/lightClient/proofs.d.ts.map +0 -1
  533. package/lib/chain/lightClient/types.d.ts.map +0 -1
  534. package/lib/chain/opPools/aggregatedAttestationPool.d.ts.map +0 -1
  535. package/lib/chain/opPools/attestationPool.d.ts.map +0 -1
  536. package/lib/chain/opPools/index.d.ts.map +0 -1
  537. package/lib/chain/opPools/opPool.d.ts.map +0 -1
  538. package/lib/chain/opPools/syncCommitteeMessagePool.d.ts.map +0 -1
  539. package/lib/chain/opPools/syncContributionAndProofPool.d.ts.map +0 -1
  540. package/lib/chain/opPools/types.d.ts.map +0 -1
  541. package/lib/chain/opPools/utils.d.ts.map +0 -1
  542. package/lib/chain/options.d.ts.map +0 -1
  543. package/lib/chain/prepareNextSlot.d.ts.map +0 -1
  544. package/lib/chain/produceBlock/computeNewStateRoot.d.ts.map +0 -1
  545. package/lib/chain/produceBlock/index.d.ts.map +0 -1
  546. package/lib/chain/produceBlock/produceBlockBody.d.ts.map +0 -1
  547. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.d.ts.map +0 -1
  548. package/lib/chain/regen/errors.d.ts.map +0 -1
  549. package/lib/chain/regen/index.d.ts.map +0 -1
  550. package/lib/chain/regen/interface.d.ts.map +0 -1
  551. package/lib/chain/regen/queued.d.ts.map +0 -1
  552. package/lib/chain/regen/regen.d.ts.map +0 -1
  553. package/lib/chain/reprocess.d.ts.map +0 -1
  554. package/lib/chain/rewards/attestationsRewards.d.ts.map +0 -1
  555. package/lib/chain/rewards/blockRewards.d.ts.map +0 -1
  556. package/lib/chain/rewards/syncCommitteeRewards.d.ts.map +0 -1
  557. package/lib/chain/seenCache/index.d.ts.map +0 -1
  558. package/lib/chain/seenCache/seenAggregateAndProof.d.ts.map +0 -1
  559. package/lib/chain/seenCache/seenAttestationData.d.ts.map +0 -1
  560. package/lib/chain/seenCache/seenAttesters.d.ts.map +0 -1
  561. package/lib/chain/seenCache/seenBlockAttesters.d.ts.map +0 -1
  562. package/lib/chain/seenCache/seenBlockProposers.d.ts.map +0 -1
  563. package/lib/chain/seenCache/seenCommittee.d.ts.map +0 -1
  564. package/lib/chain/seenCache/seenCommitteeContribution.d.ts.map +0 -1
  565. package/lib/chain/seenCache/seenGossipBlockInput.d.ts.map +0 -1
  566. package/lib/chain/serializeState.d.ts.map +0 -1
  567. package/lib/chain/shufflingCache.d.ts.map +0 -1
  568. package/lib/chain/stateCache/blockStateCacheImpl.d.ts.map +0 -1
  569. package/lib/chain/stateCache/datastore/db.d.ts.map +0 -1
  570. package/lib/chain/stateCache/datastore/file.d.ts.map +0 -1
  571. package/lib/chain/stateCache/datastore/index.d.ts.map +0 -1
  572. package/lib/chain/stateCache/datastore/types.d.ts.map +0 -1
  573. package/lib/chain/stateCache/fifoBlockStateCache.d.ts.map +0 -1
  574. package/lib/chain/stateCache/inMemoryCheckpointsCache.d.ts.map +0 -1
  575. package/lib/chain/stateCache/index.d.ts.map +0 -1
  576. package/lib/chain/stateCache/mapMetrics.d.ts.map +0 -1
  577. package/lib/chain/stateCache/persistentCheckpointsCache.d.ts.map +0 -1
  578. package/lib/chain/stateCache/types.d.ts.map +0 -1
  579. package/lib/chain/validation/aggregateAndProof.d.ts.map +0 -1
  580. package/lib/chain/validation/attestation.d.ts.map +0 -1
  581. package/lib/chain/validation/attesterSlashing.d.ts.map +0 -1
  582. package/lib/chain/validation/blobSidecar.d.ts.map +0 -1
  583. package/lib/chain/validation/block.d.ts.map +0 -1
  584. package/lib/chain/validation/blsToExecutionChange.d.ts.map +0 -1
  585. package/lib/chain/validation/dataColumnSidecar.d.ts.map +0 -1
  586. package/lib/chain/validation/index.d.ts.map +0 -1
  587. package/lib/chain/validation/lightClientFinalityUpdate.d.ts.map +0 -1
  588. package/lib/chain/validation/lightClientOptimisticUpdate.d.ts.map +0 -1
  589. package/lib/chain/validation/proposerSlashing.d.ts.map +0 -1
  590. package/lib/chain/validation/signatureSets/aggregateAndProof.d.ts.map +0 -1
  591. package/lib/chain/validation/signatureSets/contributionAndProof.d.ts.map +0 -1
  592. package/lib/chain/validation/signatureSets/index.d.ts.map +0 -1
  593. package/lib/chain/validation/signatureSets/selectionProof.d.ts.map +0 -1
  594. package/lib/chain/validation/signatureSets/syncCommittee.d.ts.map +0 -1
  595. package/lib/chain/validation/signatureSets/syncCommitteeContribution.d.ts.map +0 -1
  596. package/lib/chain/validation/signatureSets/syncCommitteeSelectionProof.d.ts.map +0 -1
  597. package/lib/chain/validation/syncCommittee.d.ts.map +0 -1
  598. package/lib/chain/validation/syncCommitteeContributionAndProof.d.ts.map +0 -1
  599. package/lib/chain/validation/voluntaryExit.d.ts.map +0 -1
  600. package/lib/chain/validatorMonitor.d.ts.map +0 -1
  601. package/lib/constants/constants.d.ts.map +0 -1
  602. package/lib/constants/index.d.ts.map +0 -1
  603. package/lib/constants/network.d.ts.map +0 -1
  604. package/lib/db/beacon.d.ts.map +0 -1
  605. package/lib/db/buckets.d.ts.map +0 -1
  606. package/lib/db/index.d.ts.map +0 -1
  607. package/lib/db/interface.d.ts.map +0 -1
  608. package/lib/db/options.d.ts.map +0 -1
  609. package/lib/db/repositories/attesterSlashing.d.ts.map +0 -1
  610. package/lib/db/repositories/backfilledRanges.d.ts.map +0 -1
  611. package/lib/db/repositories/blobSidecars.d.ts.map +0 -1
  612. package/lib/db/repositories/blobSidecarsArchive.d.ts.map +0 -1
  613. package/lib/db/repositories/block.d.ts.map +0 -1
  614. package/lib/db/repositories/blockArchive.d.ts.map +0 -1
  615. package/lib/db/repositories/blockArchiveIndex.d.ts.map +0 -1
  616. package/lib/db/repositories/blsToExecutionChange.d.ts.map +0 -1
  617. package/lib/db/repositories/checkpointState.d.ts.map +0 -1
  618. package/lib/db/repositories/dataColumnSidecar.d.ts.map +0 -1
  619. package/lib/db/repositories/dataColumnSidecarArchive.d.ts.map +0 -1
  620. package/lib/db/repositories/depositDataRoot.d.ts.map +0 -1
  621. package/lib/db/repositories/depositEvent.d.ts.map +0 -1
  622. package/lib/db/repositories/eth1Data.d.ts.map +0 -1
  623. package/lib/db/repositories/index.d.ts.map +0 -1
  624. package/lib/db/repositories/lightclientBestUpdate.d.ts.map +0 -1
  625. package/lib/db/repositories/lightclientCheckpointHeader.d.ts.map +0 -1
  626. package/lib/db/repositories/lightclientSyncCommittee.d.ts.map +0 -1
  627. package/lib/db/repositories/lightclientSyncCommitteeWitness.d.ts.map +0 -1
  628. package/lib/db/repositories/proposerSlashing.d.ts.map +0 -1
  629. package/lib/db/repositories/stateArchive.d.ts.map +0 -1
  630. package/lib/db/repositories/stateArchiveIndex.d.ts.map +0 -1
  631. package/lib/db/repositories/voluntaryExit.d.ts.map +0 -1
  632. package/lib/db/single/index.d.ts.map +0 -1
  633. package/lib/db/single/preGenesisState.d.ts.map +0 -1
  634. package/lib/db/single/preGenesisStateLastProcessedBlock.d.ts.map +0 -1
  635. package/lib/eth1/errors.d.ts.map +0 -1
  636. package/lib/eth1/eth1DataCache.d.ts.map +0 -1
  637. package/lib/eth1/eth1DepositDataTracker.d.ts.map +0 -1
  638. package/lib/eth1/eth1DepositsCache.d.ts.map +0 -1
  639. package/lib/eth1/eth1MergeBlockTracker.d.ts.map +0 -1
  640. package/lib/eth1/index.d.ts.map +0 -1
  641. package/lib/eth1/interface.d.ts.map +0 -1
  642. package/lib/eth1/options.d.ts.map +0 -1
  643. package/lib/eth1/provider/eth1Provider.d.ts.map +0 -1
  644. package/lib/eth1/provider/jsonRpcHttpClient.d.ts.map +0 -1
  645. package/lib/eth1/provider/jwt.d.ts.map +0 -1
  646. package/lib/eth1/provider/utils.d.ts.map +0 -1
  647. package/lib/eth1/stream.d.ts.map +0 -1
  648. package/lib/eth1/utils/depositContract.d.ts.map +0 -1
  649. package/lib/eth1/utils/deposits.d.ts.map +0 -1
  650. package/lib/eth1/utils/eth1Data.d.ts.map +0 -1
  651. package/lib/eth1/utils/eth1DepositEvent.d.ts.map +0 -1
  652. package/lib/eth1/utils/eth1Vote.d.ts.map +0 -1
  653. package/lib/eth1/utils/groupDepositEventsByBlock.d.ts.map +0 -1
  654. package/lib/eth1/utils/optimizeNextBlockDiffForGenesis.d.ts.map +0 -1
  655. package/lib/execution/builder/cache.d.ts.map +0 -1
  656. package/lib/execution/builder/http.d.ts.map +0 -1
  657. package/lib/execution/builder/index.d.ts.map +0 -1
  658. package/lib/execution/builder/interface.d.ts.map +0 -1
  659. package/lib/execution/builder/utils.d.ts.map +0 -1
  660. package/lib/execution/engine/disabled.d.ts.map +0 -1
  661. package/lib/execution/engine/http.d.ts.map +0 -1
  662. package/lib/execution/engine/index.d.ts.map +0 -1
  663. package/lib/execution/engine/interface.d.ts.map +0 -1
  664. package/lib/execution/engine/mock.d.ts.map +0 -1
  665. package/lib/execution/engine/payloadIdCache.d.ts.map +0 -1
  666. package/lib/execution/engine/types.d.ts.map +0 -1
  667. package/lib/execution/engine/utils.d.ts.map +0 -1
  668. package/lib/execution/index.d.ts.map +0 -1
  669. package/lib/index.d.ts.map +0 -1
  670. package/lib/metrics/index.d.ts.map +0 -1
  671. package/lib/metrics/metrics/beacon.d.ts.map +0 -1
  672. package/lib/metrics/metrics/lodestar.d.ts.map +0 -1
  673. package/lib/metrics/metrics.d.ts.map +0 -1
  674. package/lib/metrics/nodeJsMetrics.d.ts.map +0 -1
  675. package/lib/metrics/options.d.ts.map +0 -1
  676. package/lib/metrics/server/http.d.ts.map +0 -1
  677. package/lib/metrics/server/index.d.ts.map +0 -1
  678. package/lib/metrics/utils/avgMinMax.d.ts.map +0 -1
  679. package/lib/metrics/utils/gauge.d.ts.map +0 -1
  680. package/lib/metrics/utils/registryMetricCreator.d.ts.map +0 -1
  681. package/lib/monitoring/clientStats.d.ts.map +0 -1
  682. package/lib/monitoring/index.d.ts.map +0 -1
  683. package/lib/monitoring/options.d.ts.map +0 -1
  684. package/lib/monitoring/properties.d.ts.map +0 -1
  685. package/lib/monitoring/service.d.ts.map +0 -1
  686. package/lib/monitoring/system.d.ts.map +0 -1
  687. package/lib/monitoring/types.d.ts.map +0 -1
  688. package/lib/network/core/events.d.ts.map +0 -1
  689. package/lib/network/core/index.d.ts.map +0 -1
  690. package/lib/network/core/metrics.d.ts.map +0 -1
  691. package/lib/network/core/networkCore.d.ts.map +0 -1
  692. package/lib/network/core/networkCoreWorker.d.ts.map +0 -1
  693. package/lib/network/core/networkCoreWorkerHandler.d.ts.map +0 -1
  694. package/lib/network/core/types.d.ts.map +0 -1
  695. package/lib/network/discv5/index.d.ts.map +0 -1
  696. package/lib/network/discv5/types.d.ts.map +0 -1
  697. package/lib/network/discv5/utils.d.ts.map +0 -1
  698. package/lib/network/discv5/worker.d.ts.map +0 -1
  699. package/lib/network/events.d.ts.map +0 -1
  700. package/lib/network/forks.d.ts.map +0 -1
  701. package/lib/network/gossip/constants.d.ts.map +0 -1
  702. package/lib/network/gossip/encoding.d.ts.map +0 -1
  703. package/lib/network/gossip/errors.d.ts.map +0 -1
  704. package/lib/network/gossip/gossipsub.d.ts.map +0 -1
  705. package/lib/network/gossip/index.d.ts.map +0 -1
  706. package/lib/network/gossip/interface.d.ts.map +0 -1
  707. package/lib/network/gossip/metrics.d.ts.map +0 -1
  708. package/lib/network/gossip/scoringParameters.d.ts.map +0 -1
  709. package/lib/network/gossip/topic.d.ts.map +0 -1
  710. package/lib/network/index.d.ts.map +0 -1
  711. package/lib/network/interface.d.ts.map +0 -1
  712. package/lib/network/libp2p/error.d.ts.map +0 -1
  713. package/lib/network/libp2p/index.d.ts.map +0 -1
  714. package/lib/network/metadata.d.ts.map +0 -1
  715. package/lib/network/network.d.ts.map +0 -1
  716. package/lib/network/networkConfig.d.ts.map +0 -1
  717. package/lib/network/options.d.ts.map +0 -1
  718. package/lib/network/peers/client.d.ts.map +0 -1
  719. package/lib/network/peers/datastore.d.ts.map +0 -1
  720. package/lib/network/peers/discover.d.ts.map +0 -1
  721. package/lib/network/peers/index.d.ts.map +0 -1
  722. package/lib/network/peers/peerManager.d.ts.map +0 -1
  723. package/lib/network/peers/peersData.d.ts.map +0 -1
  724. package/lib/network/peers/score/constants.d.ts.map +0 -1
  725. package/lib/network/peers/score/index.d.ts.map +0 -1
  726. package/lib/network/peers/score/interface.d.ts.map +0 -1
  727. package/lib/network/peers/score/score.d.ts.map +0 -1
  728. package/lib/network/peers/score/store.d.ts.map +0 -1
  729. package/lib/network/peers/score/utils.d.ts.map +0 -1
  730. package/lib/network/peers/utils/assertPeerRelevance.d.ts.map +0 -1
  731. package/lib/network/peers/utils/enrSubnetsDeserialize.d.ts.map +0 -1
  732. package/lib/network/peers/utils/getConnectedPeerIds.d.ts.map +0 -1
  733. package/lib/network/peers/utils/index.d.ts.map +0 -1
  734. package/lib/network/peers/utils/prioritizePeers.d.ts.map +0 -1
  735. package/lib/network/peers/utils/subnetMap.d.ts.map +0 -1
  736. package/lib/network/processor/aggregatorTracker.d.ts.map +0 -1
  737. package/lib/network/processor/extractSlotRootFns.d.ts.map +0 -1
  738. package/lib/network/processor/gossipHandlers.d.ts.map +0 -1
  739. package/lib/network/processor/gossipQueues/index.d.ts.map +0 -1
  740. package/lib/network/processor/gossipQueues/indexed.d.ts.map +0 -1
  741. package/lib/network/processor/gossipQueues/linear.d.ts.map +0 -1
  742. package/lib/network/processor/gossipQueues/types.d.ts.map +0 -1
  743. package/lib/network/processor/gossipValidatorFn.d.ts.map +0 -1
  744. package/lib/network/processor/index.d.ts.map +0 -1
  745. package/lib/network/processor/types.d.ts.map +0 -1
  746. package/lib/network/reqresp/ReqRespBeaconNode.d.ts.map +0 -1
  747. package/lib/network/reqresp/handlers/beaconBlocksByRange.d.ts.map +0 -1
  748. package/lib/network/reqresp/handlers/beaconBlocksByRoot.d.ts.map +0 -1
  749. package/lib/network/reqresp/handlers/blobSidecarsByRange.d.ts.map +0 -1
  750. package/lib/network/reqresp/handlers/blobSidecarsByRoot.d.ts.map +0 -1
  751. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts.map +0 -1
  752. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.d.ts.map +0 -1
  753. package/lib/network/reqresp/handlers/index.d.ts.map +0 -1
  754. package/lib/network/reqresp/handlers/lightClientBootstrap.d.ts.map +0 -1
  755. package/lib/network/reqresp/handlers/lightClientFinalityUpdate.d.ts.map +0 -1
  756. package/lib/network/reqresp/handlers/lightClientOptimisticUpdate.d.ts.map +0 -1
  757. package/lib/network/reqresp/handlers/lightClientUpdatesByRange.d.ts.map +0 -1
  758. package/lib/network/reqresp/index.d.ts.map +0 -1
  759. package/lib/network/reqresp/interface.d.ts.map +0 -1
  760. package/lib/network/reqresp/protocols.d.ts.map +0 -1
  761. package/lib/network/reqresp/rateLimit.d.ts.map +0 -1
  762. package/lib/network/reqresp/score.d.ts.map +0 -1
  763. package/lib/network/reqresp/types.d.ts.map +0 -1
  764. package/lib/network/reqresp/utils/collect.d.ts.map +0 -1
  765. package/lib/network/reqresp/utils/collectSequentialBlocksInRange.d.ts.map +0 -1
  766. package/lib/network/reqresp/utils/dataColumnResponseValidation.d.ts.map +0 -1
  767. package/lib/network/statusCache.d.ts.map +0 -1
  768. package/lib/network/subnets/attnetsService.d.ts.map +0 -1
  769. package/lib/network/subnets/index.d.ts.map +0 -1
  770. package/lib/network/subnets/interface.d.ts.map +0 -1
  771. package/lib/network/subnets/syncnetsService.d.ts.map +0 -1
  772. package/lib/network/subnets/util.d.ts.map +0 -1
  773. package/lib/network/util.d.ts.map +0 -1
  774. package/lib/node/index.d.ts.map +0 -1
  775. package/lib/node/nodejs.d.ts.map +0 -1
  776. package/lib/node/notifier.d.ts.map +0 -1
  777. package/lib/node/options.d.ts.map +0 -1
  778. package/lib/node/utils/interop/deposits.d.ts.map +0 -1
  779. package/lib/node/utils/interop/state.d.ts.map +0 -1
  780. package/lib/node/utils/lightclient.d.ts.map +0 -1
  781. package/lib/node/utils/state.d.ts.map +0 -1
  782. package/lib/sync/backfill/backfill.d.ts.map +0 -1
  783. package/lib/sync/backfill/errors.d.ts.map +0 -1
  784. package/lib/sync/backfill/index.d.ts.map +0 -1
  785. package/lib/sync/backfill/verify.d.ts.map +0 -1
  786. package/lib/sync/constants.d.ts.map +0 -1
  787. package/lib/sync/index.d.ts.map +0 -1
  788. package/lib/sync/interface.d.ts.map +0 -1
  789. package/lib/sync/options.d.ts.map +0 -1
  790. package/lib/sync/range/batch.d.ts.map +0 -1
  791. package/lib/sync/range/chain.d.ts.map +0 -1
  792. package/lib/sync/range/range.d.ts.map +0 -1
  793. package/lib/sync/range/utils/batches.d.ts.map +0 -1
  794. package/lib/sync/range/utils/chainTarget.d.ts.map +0 -1
  795. package/lib/sync/range/utils/hashBlocks.d.ts.map +0 -1
  796. package/lib/sync/range/utils/index.d.ts.map +0 -1
  797. package/lib/sync/range/utils/peerBalancer.d.ts.map +0 -1
  798. package/lib/sync/range/utils/updateChains.d.ts.map +0 -1
  799. package/lib/sync/sync.d.ts.map +0 -1
  800. package/lib/sync/types.d.ts.map +0 -1
  801. package/lib/sync/unknownBlock.d.ts.map +0 -1
  802. package/lib/sync/utils/downloadByRange.d.ts.map +0 -1
  803. package/lib/sync/utils/downloadByRoot.d.ts.map +0 -1
  804. package/lib/sync/utils/pendingBlocksTree.d.ts.map +0 -1
  805. package/lib/sync/utils/remoteSyncType.d.ts.map +0 -1
  806. package/lib/util/address.d.ts.map +0 -1
  807. package/lib/util/array.d.ts.map +0 -1
  808. package/lib/util/asyncIterableToEvents.d.ts.map +0 -1
  809. package/lib/util/binarySearch.d.ts.map +0 -1
  810. package/lib/util/bitArray.d.ts.map +0 -1
  811. package/lib/util/blobs.d.ts.map +0 -1
  812. package/lib/util/bufferPool.d.ts.map +0 -1
  813. package/lib/util/bytes.d.ts.map +0 -1
  814. package/lib/util/chunkify.d.ts.map +0 -1
  815. package/lib/util/clock.d.ts.map +0 -1
  816. package/lib/util/dataColumns.d.ts.map +0 -1
  817. package/lib/util/dependentRoot.d.ts.map +0 -1
  818. package/lib/util/enum.d.ts.map +0 -1
  819. package/lib/util/error.d.ts.map +0 -1
  820. package/lib/util/eventLoop.d.ts.map +0 -1
  821. package/lib/util/execution.d.ts.map +0 -1
  822. package/lib/util/file.d.ts.map +0 -1
  823. package/lib/util/forkChoice.d.ts.map +0 -1
  824. package/lib/util/forkName.d.ts.map +0 -1
  825. package/lib/util/graffiti.d.ts.map +0 -1
  826. package/lib/util/hex.d.ts.map +0 -1
  827. package/lib/util/index.d.ts.map +0 -1
  828. package/lib/util/ip.d.ts.map +0 -1
  829. package/lib/util/itTrigger.d.ts.map +0 -1
  830. package/lib/util/kzg.d.ts.map +0 -1
  831. package/lib/util/map.d.ts.map +0 -1
  832. package/lib/util/metadata.d.ts.map +0 -1
  833. package/lib/util/multifork.d.ts.map +0 -1
  834. package/lib/util/numpy.d.ts.map +0 -1
  835. package/lib/util/peerId.d.ts.map +0 -1
  836. package/lib/util/profile.d.ts.map +0 -1
  837. package/lib/util/promises.d.ts.map +0 -1
  838. package/lib/util/queue/errors.d.ts.map +0 -1
  839. package/lib/util/queue/fnQueue.d.ts.map +0 -1
  840. package/lib/util/queue/index.d.ts.map +0 -1
  841. package/lib/util/queue/itemQueue.d.ts.map +0 -1
  842. package/lib/util/queue/options.d.ts.map +0 -1
  843. package/lib/util/serializedCache.d.ts.map +0 -1
  844. package/lib/util/set.d.ts.map +0 -1
  845. package/lib/util/shuffle.d.ts.map +0 -1
  846. package/lib/util/sortBy.d.ts.map +0 -1
  847. package/lib/util/sszBytes.d.ts.map +0 -1
  848. package/lib/util/strictEvents.d.ts.map +0 -1
  849. package/lib/util/time.d.ts.map +0 -1
  850. package/lib/util/timeSeries.d.ts.map +0 -1
  851. package/lib/util/types.d.ts.map +0 -1
  852. package/lib/util/workerEvents.d.ts.map +0 -1
  853. package/lib/util/wrapError.d.ts.map +0 -1
  854. package/src/api/impl/api.ts +0 -26
  855. package/src/api/impl/beacon/blocks/index.ts +0 -744
  856. package/src/api/impl/beacon/blocks/utils.ts +0 -75
  857. package/src/api/impl/beacon/index.ts +0 -35
  858. package/src/api/impl/beacon/pool/index.ts +0 -314
  859. package/src/api/impl/beacon/rewards/index.ts +0 -30
  860. package/src/api/impl/beacon/state/index.ts +0 -406
  861. package/src/api/impl/beacon/state/utils.ts +0 -189
  862. package/src/api/impl/config/constants.ts +0 -127
  863. package/src/api/impl/config/index.ts +0 -59
  864. package/src/api/impl/debug/index.ts +0 -131
  865. package/src/api/impl/errors.ts +0 -50
  866. package/src/api/impl/events/index.ts +0 -33
  867. package/src/api/impl/index.ts +0 -6
  868. package/src/api/impl/lightclient/index.ts +0 -64
  869. package/src/api/impl/lodestar/index.ts +0 -257
  870. package/src/api/impl/node/index.ts +0 -88
  871. package/src/api/impl/node/utils.ts +0 -51
  872. package/src/api/impl/proof/index.ts +0 -60
  873. package/src/api/impl/types.ts +0 -17
  874. package/src/api/impl/utils.ts +0 -25
  875. package/src/api/impl/validator/index.ts +0 -1540
  876. package/src/api/impl/validator/utils.ts +0 -85
  877. package/src/api/index.ts +0 -2
  878. package/src/api/options.ts +0 -16
  879. package/src/api/rest/activeSockets.ts +0 -109
  880. package/src/api/rest/base.ts +0 -216
  881. package/src/api/rest/index.ts +0 -63
  882. package/src/api/rest/swaggerUI.ts +0 -80
  883. package/src/bun-wrappers/prometheus-gc-stats.ts +0 -7
  884. package/src/chain/ColumnReconstructionTracker.ts +0 -90
  885. package/src/chain/GetBlobsTracker.ts +0 -115
  886. package/src/chain/archiveStore/archiveStore.ts +0 -222
  887. package/src/chain/archiveStore/constants.ts +0 -5
  888. package/src/chain/archiveStore/historicalState/getHistoricalState.ts +0 -116
  889. package/src/chain/archiveStore/historicalState/historicalStateRegen.ts +0 -68
  890. package/src/chain/archiveStore/historicalState/metrics.ts +0 -214
  891. package/src/chain/archiveStore/historicalState/types.ts +0 -41
  892. package/src/chain/archiveStore/historicalState/worker.ts +0 -77
  893. package/src/chain/archiveStore/index.ts +0 -3
  894. package/src/chain/archiveStore/interface.ts +0 -75
  895. package/src/chain/archiveStore/strategies/frequencyStateArchiveStrategy.ts +0 -138
  896. package/src/chain/archiveStore/utils/archiveBlocks.ts +0 -437
  897. package/src/chain/archiveStore/utils/pruneHistory.ts +0 -56
  898. package/src/chain/archiveStore/utils/updateBackfillRange.ts +0 -50
  899. package/src/chain/balancesCache.ts +0 -52
  900. package/src/chain/beaconProposerCache.ts +0 -43
  901. package/src/chain/blocks/blockInput/blockInput.ts +0 -852
  902. package/src/chain/blocks/blockInput/errors.ts +0 -48
  903. package/src/chain/blocks/blockInput/index.ts +0 -4
  904. package/src/chain/blocks/blockInput/types.ts +0 -145
  905. package/src/chain/blocks/blockInput/utils.ts +0 -21
  906. package/src/chain/blocks/importBlock.ts +0 -597
  907. package/src/chain/blocks/index.ts +0 -179
  908. package/src/chain/blocks/types.ts +0 -101
  909. package/src/chain/blocks/utils/blowfishBanner.ts +0 -28
  910. package/src/chain/blocks/utils/chainSegment.ts +0 -29
  911. package/src/chain/blocks/utils/checkpoint.ts +0 -25
  912. package/src/chain/blocks/utils/giraffeBanner.ts +0 -30
  913. package/src/chain/blocks/utils/ownBanner.ts +0 -20
  914. package/src/chain/blocks/utils/pandaMergeTransitionBanner.ts +0 -43
  915. package/src/chain/blocks/utils/zebraBanner.ts +0 -45
  916. package/src/chain/blocks/verifyBlock.ts +0 -242
  917. package/src/chain/blocks/verifyBlocksDataAvailability.ts +0 -42
  918. package/src/chain/blocks/verifyBlocksExecutionPayloads.ts +0 -438
  919. package/src/chain/blocks/verifyBlocksSanityChecks.ts +0 -129
  920. package/src/chain/blocks/verifyBlocksSignatures.ts +0 -105
  921. package/src/chain/blocks/verifyBlocksStateTransitionOnly.ts +0 -114
  922. package/src/chain/blocks/writeBlockInputToDb.ts +0 -128
  923. package/src/chain/bls/index.ts +0 -4
  924. package/src/chain/bls/interface.ts +0 -68
  925. package/src/chain/bls/maybeBatch.ts +0 -45
  926. package/src/chain/bls/multithread/index.ts +0 -582
  927. package/src/chain/bls/multithread/jobItem.ts +0 -119
  928. package/src/chain/bls/multithread/poolSize.ts +0 -16
  929. package/src/chain/bls/multithread/types.ts +0 -38
  930. package/src/chain/bls/multithread/utils.ts +0 -19
  931. package/src/chain/bls/multithread/worker.ts +0 -114
  932. package/src/chain/bls/singleThread.ts +0 -87
  933. package/src/chain/bls/utils.ts +0 -30
  934. package/src/chain/chain.ts +0 -1354
  935. package/src/chain/emitter.ts +0 -113
  936. package/src/chain/errors/attestationError.ts +0 -194
  937. package/src/chain/errors/attesterSlashingError.ts +0 -11
  938. package/src/chain/errors/blobSidecarError.ts +0 -60
  939. package/src/chain/errors/blockError.ts +0 -166
  940. package/src/chain/errors/blsToExecutionChangeError.ts +0 -13
  941. package/src/chain/errors/dataColumnSidecarError.ts +0 -80
  942. package/src/chain/errors/gossipValidation.ts +0 -20
  943. package/src/chain/errors/index.ts +0 -10
  944. package/src/chain/errors/lightClientError.ts +0 -30
  945. package/src/chain/errors/proposerSlashingError.ts +0 -11
  946. package/src/chain/errors/syncCommitteeError.ts +0 -36
  947. package/src/chain/errors/voluntaryExitError.ts +0 -13
  948. package/src/chain/forkChoice/index.ts +0 -112
  949. package/src/chain/genesis/genesis.ts +0 -190
  950. package/src/chain/genesis/interface.ts +0 -14
  951. package/src/chain/index.ts +0 -6
  952. package/src/chain/initState.ts +0 -221
  953. package/src/chain/interface.ts +0 -280
  954. package/src/chain/lightClient/index.ts +0 -764
  955. package/src/chain/lightClient/proofs.ts +0 -85
  956. package/src/chain/lightClient/types.ts +0 -33
  957. package/src/chain/opPools/aggregatedAttestationPool.ts +0 -1063
  958. package/src/chain/opPools/attestationPool.ts +0 -282
  959. package/src/chain/opPools/index.ts +0 -5
  960. package/src/chain/opPools/opPool.ts +0 -462
  961. package/src/chain/opPools/syncCommitteeMessagePool.ts +0 -169
  962. package/src/chain/opPools/syncContributionAndProofPool.ts +0 -240
  963. package/src/chain/opPools/types.ts +0 -35
  964. package/src/chain/opPools/utils.ts +0 -65
  965. package/src/chain/options.ts +0 -138
  966. package/src/chain/prepareNextSlot.ts +0 -277
  967. package/src/chain/produceBlock/computeNewStateRoot.ts +0 -55
  968. package/src/chain/produceBlock/index.ts +0 -2
  969. package/src/chain/produceBlock/produceBlockBody.ts +0 -797
  970. package/src/chain/produceBlock/validateBlobsAndKzgCommitments.ts +0 -54
  971. package/src/chain/regen/errors.ts +0 -30
  972. package/src/chain/regen/index.ts +0 -4
  973. package/src/chain/regen/interface.ts +0 -93
  974. package/src/chain/regen/queued.ts +0 -317
  975. package/src/chain/regen/regen.ts +0 -424
  976. package/src/chain/reprocess.ts +0 -161
  977. package/src/chain/rewards/attestationsRewards.ts +0 -196
  978. package/src/chain/rewards/blockRewards.ts +0 -150
  979. package/src/chain/rewards/syncCommitteeRewards.ts +0 -58
  980. package/src/chain/seenCache/index.ts +0 -5
  981. package/src/chain/seenCache/seenAggregateAndProof.ts +0 -120
  982. package/src/chain/seenCache/seenAttestationData.ts +0 -145
  983. package/src/chain/seenCache/seenAttesters.ts +0 -58
  984. package/src/chain/seenCache/seenBlockAttesters.ts +0 -18
  985. package/src/chain/seenCache/seenBlockProposers.ts +0 -48
  986. package/src/chain/seenCache/seenCommittee.ts +0 -43
  987. package/src/chain/seenCache/seenCommitteeContribution.ts +0 -104
  988. package/src/chain/seenCache/seenGossipBlockInput.ts +0 -373
  989. package/src/chain/serializeState.ts +0 -32
  990. package/src/chain/shufflingCache.ts +0 -238
  991. package/src/chain/stateCache/blockStateCacheImpl.ts +0 -150
  992. package/src/chain/stateCache/datastore/db.ts +0 -36
  993. package/src/chain/stateCache/datastore/file.ts +0 -53
  994. package/src/chain/stateCache/datastore/index.ts +0 -2
  995. package/src/chain/stateCache/datastore/types.ts +0 -13
  996. package/src/chain/stateCache/fifoBlockStateCache.ts +0 -208
  997. package/src/chain/stateCache/inMemoryCheckpointsCache.ts +0 -198
  998. package/src/chain/stateCache/index.ts +0 -3
  999. package/src/chain/stateCache/mapMetrics.ts +0 -52
  1000. package/src/chain/stateCache/persistentCheckpointsCache.ts +0 -837
  1001. package/src/chain/stateCache/types.ts +0 -86
  1002. package/src/chain/validation/aggregateAndProof.ts +0 -258
  1003. package/src/chain/validation/attestation.ts +0 -885
  1004. package/src/chain/validation/attesterSlashing.ts +0 -61
  1005. package/src/chain/validation/blobSidecar.ts +0 -301
  1006. package/src/chain/validation/block.ts +0 -188
  1007. package/src/chain/validation/blsToExecutionChange.ts +0 -61
  1008. package/src/chain/validation/dataColumnSidecar.ts +0 -381
  1009. package/src/chain/validation/index.ts +0 -9
  1010. package/src/chain/validation/lightClientFinalityUpdate.ts +0 -46
  1011. package/src/chain/validation/lightClientOptimisticUpdate.ts +0 -68
  1012. package/src/chain/validation/proposerSlashing.ts +0 -54
  1013. package/src/chain/validation/signatureSets/aggregateAndProof.ts +0 -38
  1014. package/src/chain/validation/signatureSets/contributionAndProof.ts +0 -27
  1015. package/src/chain/validation/signatureSets/index.ts +0 -6
  1016. package/src/chain/validation/signatureSets/selectionProof.ts +0 -27
  1017. package/src/chain/validation/signatureSets/syncCommittee.ts +0 -22
  1018. package/src/chain/validation/signatureSets/syncCommitteeContribution.ts +0 -18
  1019. package/src/chain/validation/signatureSets/syncCommitteeSelectionProof.ts +0 -27
  1020. package/src/chain/validation/syncCommittee.ts +0 -165
  1021. package/src/chain/validation/syncCommitteeContributionAndProof.ts +0 -122
  1022. package/src/chain/validation/voluntaryExit.ts +0 -58
  1023. package/src/chain/validatorMonitor.ts +0 -1309
  1024. package/src/constants/constants.ts +0 -15
  1025. package/src/constants/index.ts +0 -2
  1026. package/src/constants/network.ts +0 -52
  1027. package/src/db/beacon.ts +0 -113
  1028. package/src/db/buckets.ts +0 -80
  1029. package/src/db/index.ts +0 -2
  1030. package/src/db/interface.ts +0 -76
  1031. package/src/db/options.ts +0 -7
  1032. package/src/db/repositories/attesterSlashing.ts +0 -38
  1033. package/src/db/repositories/backfilledRanges.ts +0 -29
  1034. package/src/db/repositories/blobSidecars.ts +0 -37
  1035. package/src/db/repositories/blobSidecarsArchive.ts +0 -28
  1036. package/src/db/repositories/block.ts +0 -33
  1037. package/src/db/repositories/blockArchive.ts +0 -170
  1038. package/src/db/repositories/blockArchiveIndex.ts +0 -45
  1039. package/src/db/repositories/blsToExecutionChange.ts +0 -16
  1040. package/src/db/repositories/checkpointState.ts +0 -31
  1041. package/src/db/repositories/dataColumnSidecar.ts +0 -49
  1042. package/src/db/repositories/dataColumnSidecarArchive.ts +0 -56
  1043. package/src/db/repositories/depositDataRoot.ts +0 -80
  1044. package/src/db/repositories/depositEvent.ts +0 -32
  1045. package/src/db/repositories/eth1Data.ts +0 -33
  1046. package/src/db/repositories/index.ts +0 -20
  1047. package/src/db/repositories/lightclientBestUpdate.ts +0 -41
  1048. package/src/db/repositories/lightclientCheckpointHeader.ts +0 -32
  1049. package/src/db/repositories/lightclientSyncCommittee.ts +0 -16
  1050. package/src/db/repositories/lightclientSyncCommitteeWitness.ts +0 -77
  1051. package/src/db/repositories/proposerSlashing.ts +0 -15
  1052. package/src/db/repositories/stateArchive.ts +0 -69
  1053. package/src/db/repositories/stateArchiveIndex.ts +0 -18
  1054. package/src/db/repositories/voluntaryExit.ts +0 -15
  1055. package/src/db/single/index.ts +0 -2
  1056. package/src/db/single/preGenesisState.ts +0 -37
  1057. package/src/db/single/preGenesisStateLastProcessedBlock.ts +0 -34
  1058. package/src/eth1/errors.ts +0 -40
  1059. package/src/eth1/eth1DataCache.ts +0 -26
  1060. package/src/eth1/eth1DepositDataTracker.ts +0 -410
  1061. package/src/eth1/eth1DepositsCache.ts +0 -141
  1062. package/src/eth1/eth1MergeBlockTracker.ts +0 -328
  1063. package/src/eth1/index.ts +0 -157
  1064. package/src/eth1/interface.ts +0 -131
  1065. package/src/eth1/options.ts +0 -28
  1066. package/src/eth1/provider/eth1Provider.ts +0 -229
  1067. package/src/eth1/provider/jsonRpcHttpClient.ts +0 -390
  1068. package/src/eth1/provider/jwt.ts +0 -36
  1069. package/src/eth1/provider/utils.ts +0 -136
  1070. package/src/eth1/stream.ts +0 -75
  1071. package/src/eth1/utils/depositContract.ts +0 -37
  1072. package/src/eth1/utils/deposits.ts +0 -70
  1073. package/src/eth1/utils/eth1Data.ts +0 -100
  1074. package/src/eth1/utils/eth1DepositEvent.ts +0 -12
  1075. package/src/eth1/utils/eth1Vote.ts +0 -142
  1076. package/src/eth1/utils/groupDepositEventsByBlock.ts +0 -19
  1077. package/src/eth1/utils/optimizeNextBlockDiffForGenesis.ts +0 -18
  1078. package/src/execution/builder/cache.ts +0 -39
  1079. package/src/execution/builder/http.ts +0 -229
  1080. package/src/execution/builder/index.ts +0 -27
  1081. package/src/execution/builder/interface.ts +0 -49
  1082. package/src/execution/builder/utils.ts +0 -19
  1083. package/src/execution/engine/disabled.ts +0 -35
  1084. package/src/execution/engine/http.ts +0 -644
  1085. package/src/execution/engine/index.ts +0 -63
  1086. package/src/execution/engine/interface.ts +0 -199
  1087. package/src/execution/engine/mock.ts +0 -493
  1088. package/src/execution/engine/payloadIdCache.ts +0 -54
  1089. package/src/execution/engine/types.ts +0 -640
  1090. package/src/execution/engine/utils.ts +0 -136
  1091. package/src/execution/index.ts +0 -4
  1092. package/src/index.ts +0 -20
  1093. package/src/metrics/index.ts +0 -4
  1094. package/src/metrics/metrics/beacon.ts +0 -390
  1095. package/src/metrics/metrics/lodestar.ts +0 -1870
  1096. package/src/metrics/metrics.ts +0 -43
  1097. package/src/metrics/nodeJsMetrics.ts +0 -19
  1098. package/src/metrics/options.ts +0 -22
  1099. package/src/metrics/server/http.ts +0 -114
  1100. package/src/metrics/server/index.ts +0 -1
  1101. package/src/metrics/utils/avgMinMax.ts +0 -87
  1102. package/src/metrics/utils/gauge.ts +0 -22
  1103. package/src/metrics/utils/registryMetricCreator.ts +0 -41
  1104. package/src/monitoring/clientStats.ts +0 -297
  1105. package/src/monitoring/index.ts +0 -2
  1106. package/src/monitoring/options.ts +0 -19
  1107. package/src/monitoring/properties.ts +0 -152
  1108. package/src/monitoring/service.ts +0 -235
  1109. package/src/monitoring/system.ts +0 -146
  1110. package/src/monitoring/types.ts +0 -21
  1111. package/src/network/core/events.ts +0 -59
  1112. package/src/network/core/index.ts +0 -3
  1113. package/src/network/core/metrics.ts +0 -304
  1114. package/src/network/core/networkCore.ts +0 -599
  1115. package/src/network/core/networkCoreWorker.ts +0 -176
  1116. package/src/network/core/networkCoreWorkerHandler.ts +0 -284
  1117. package/src/network/core/types.ts +0 -119
  1118. package/src/network/discv5/index.ts +0 -132
  1119. package/src/network/discv5/types.ts +0 -74
  1120. package/src/network/discv5/utils.ts +0 -50
  1121. package/src/network/discv5/worker.ts +0 -137
  1122. package/src/network/events.ts +0 -51
  1123. package/src/network/forks.ts +0 -94
  1124. package/src/network/gossip/constants.ts +0 -15
  1125. package/src/network/gossip/encoding.ts +0 -111
  1126. package/src/network/gossip/errors.ts +0 -7
  1127. package/src/network/gossip/gossipsub.ts +0 -384
  1128. package/src/network/gossip/index.ts +0 -4
  1129. package/src/network/gossip/interface.ts +0 -215
  1130. package/src/network/gossip/metrics.ts +0 -71
  1131. package/src/network/gossip/scoringParameters.ts +0 -333
  1132. package/src/network/gossip/topic.ts +0 -332
  1133. package/src/network/index.ts +0 -8
  1134. package/src/network/interface.ts +0 -134
  1135. package/src/network/libp2p/error.ts +0 -55
  1136. package/src/network/libp2p/index.ts +0 -153
  1137. package/src/network/metadata.ts +0 -162
  1138. package/src/network/network.ts +0 -767
  1139. package/src/network/networkConfig.ts +0 -12
  1140. package/src/network/options.ts +0 -70
  1141. package/src/network/peers/client.ts +0 -29
  1142. package/src/network/peers/datastore.ts +0 -188
  1143. package/src/network/peers/discover.ts +0 -647
  1144. package/src/network/peers/index.ts +0 -2
  1145. package/src/network/peers/peerManager.ts +0 -899
  1146. package/src/network/peers/peersData.ts +0 -65
  1147. package/src/network/peers/score/constants.ts +0 -34
  1148. package/src/network/peers/score/index.ts +0 -4
  1149. package/src/network/peers/score/interface.ts +0 -74
  1150. package/src/network/peers/score/score.ts +0 -200
  1151. package/src/network/peers/score/store.ts +0 -95
  1152. package/src/network/peers/score/utils.ts +0 -37
  1153. package/src/network/peers/utils/assertPeerRelevance.ts +0 -99
  1154. package/src/network/peers/utils/enrSubnetsDeserialize.ts +0 -27
  1155. package/src/network/peers/utils/getConnectedPeerIds.ts +0 -33
  1156. package/src/network/peers/utils/index.ts +0 -4
  1157. package/src/network/peers/utils/prioritizePeers.ts +0 -627
  1158. package/src/network/peers/utils/subnetMap.ts +0 -88
  1159. package/src/network/processor/aggregatorTracker.ts +0 -38
  1160. package/src/network/processor/extractSlotRootFns.ts +0 -64
  1161. package/src/network/processor/gossipHandlers.ts +0 -951
  1162. package/src/network/processor/gossipQueues/index.ts +0 -114
  1163. package/src/network/processor/gossipQueues/indexed.ts +0 -219
  1164. package/src/network/processor/gossipQueues/linear.ts +0 -162
  1165. package/src/network/processor/gossipQueues/types.ts +0 -57
  1166. package/src/network/processor/gossipValidatorFn.ts +0 -142
  1167. package/src/network/processor/index.ts +0 -496
  1168. package/src/network/processor/types.ts +0 -27
  1169. package/src/network/reqresp/ReqRespBeaconNode.ts +0 -373
  1170. package/src/network/reqresp/handlers/beaconBlocksByRange.ts +0 -101
  1171. package/src/network/reqresp/handlers/beaconBlocksByRoot.ts +0 -49
  1172. package/src/network/reqresp/handlers/blobSidecarsByRange.ts +0 -114
  1173. package/src/network/reqresp/handlers/blobSidecarsByRoot.ts +0 -62
  1174. package/src/network/reqresp/handlers/dataColumnSidecarsByRange.ts +0 -144
  1175. package/src/network/reqresp/handlers/dataColumnSidecarsByRoot.ts +0 -88
  1176. package/src/network/reqresp/handlers/index.ts +0 -78
  1177. package/src/network/reqresp/handlers/lightClientBootstrap.ts +0 -31
  1178. package/src/network/reqresp/handlers/lightClientFinalityUpdate.ts +0 -21
  1179. package/src/network/reqresp/handlers/lightClientOptimisticUpdate.ts +0 -21
  1180. package/src/network/reqresp/handlers/lightClientUpdatesByRange.ts +0 -39
  1181. package/src/network/reqresp/index.ts +0 -2
  1182. package/src/network/reqresp/interface.ts +0 -45
  1183. package/src/network/reqresp/protocols.ts +0 -146
  1184. package/src/network/reqresp/rateLimit.ts +0 -112
  1185. package/src/network/reqresp/score.ts +0 -70
  1186. package/src/network/reqresp/types.ts +0 -174
  1187. package/src/network/reqresp/utils/collect.ts +0 -84
  1188. package/src/network/reqresp/utils/collectSequentialBlocksInRange.ts +0 -57
  1189. package/src/network/reqresp/utils/dataColumnResponseValidation.ts +0 -99
  1190. package/src/network/statusCache.ts +0 -17
  1191. package/src/network/subnets/attnetsService.ts +0 -385
  1192. package/src/network/subnets/index.ts +0 -2
  1193. package/src/network/subnets/interface.ts +0 -66
  1194. package/src/network/subnets/syncnetsService.ts +0 -147
  1195. package/src/network/subnets/util.ts +0 -63
  1196. package/src/network/util.ts +0 -29
  1197. package/src/node/index.ts +0 -2
  1198. package/src/node/nodejs.ts +0 -349
  1199. package/src/node/notifier.ts +0 -206
  1200. package/src/node/options.ts +0 -51
  1201. package/src/node/utils/interop/deposits.ts +0 -53
  1202. package/src/node/utils/interop/state.ts +0 -59
  1203. package/src/node/utils/lightclient.ts +0 -7
  1204. package/src/node/utils/state.ts +0 -37
  1205. package/src/sync/backfill/backfill.ts +0 -893
  1206. package/src/sync/backfill/errors.ts +0 -23
  1207. package/src/sync/backfill/index.ts +0 -1
  1208. package/src/sync/backfill/verify.ts +0 -58
  1209. package/src/sync/constants.ts +0 -71
  1210. package/src/sync/index.ts +0 -2
  1211. package/src/sync/interface.ts +0 -55
  1212. package/src/sync/options.ts +0 -45
  1213. package/src/sync/range/batch.ts +0 -455
  1214. package/src/sync/range/chain.ts +0 -715
  1215. package/src/sync/range/range.ts +0 -354
  1216. package/src/sync/range/utils/batches.ts +0 -119
  1217. package/src/sync/range/utils/chainTarget.ts +0 -62
  1218. package/src/sync/range/utils/hashBlocks.ts +0 -27
  1219. package/src/sync/range/utils/index.ts +0 -5
  1220. package/src/sync/range/utils/peerBalancer.ts +0 -184
  1221. package/src/sync/range/utils/updateChains.ts +0 -66
  1222. package/src/sync/sync.ts +0 -290
  1223. package/src/sync/types.ts +0 -57
  1224. package/src/sync/unknownBlock.ts +0 -859
  1225. package/src/sync/utils/downloadByRange.ts +0 -808
  1226. package/src/sync/utils/downloadByRoot.ts +0 -560
  1227. package/src/sync/utils/pendingBlocksTree.ts +0 -97
  1228. package/src/sync/utils/remoteSyncType.ts +0 -144
  1229. package/src/util/address.ts +0 -3
  1230. package/src/util/array.ts +0 -311
  1231. package/src/util/asyncIterableToEvents.ts +0 -164
  1232. package/src/util/binarySearch.ts +0 -48
  1233. package/src/util/bitArray.ts +0 -84
  1234. package/src/util/blobs.ts +0 -210
  1235. package/src/util/bufferPool.ts +0 -95
  1236. package/src/util/bytes.ts +0 -11
  1237. package/src/util/chunkify.ts +0 -27
  1238. package/src/util/clock.ts +0 -212
  1239. package/src/util/dataColumns.ts +0 -415
  1240. package/src/util/dependentRoot.ts +0 -47
  1241. package/src/util/enum.ts +0 -17
  1242. package/src/util/error.ts +0 -56
  1243. package/src/util/eventLoop.ts +0 -22
  1244. package/src/util/execution.ts +0 -223
  1245. package/src/util/file.ts +0 -52
  1246. package/src/util/forkChoice.ts +0 -5
  1247. package/src/util/forkName.ts +0 -20
  1248. package/src/util/graffiti.ts +0 -39
  1249. package/src/util/hex.ts +0 -9
  1250. package/src/util/index.ts +0 -2
  1251. package/src/util/ip.ts +0 -6
  1252. package/src/util/itTrigger.ts +0 -49
  1253. package/src/util/kzg.ts +0 -3
  1254. package/src/util/map.ts +0 -77
  1255. package/src/util/metadata.ts +0 -22
  1256. package/src/util/multifork.ts +0 -69
  1257. package/src/util/numpy.ts +0 -8
  1258. package/src/util/peerId.ts +0 -16
  1259. package/src/util/profile.ts +0 -54
  1260. package/src/util/promises.ts +0 -14
  1261. package/src/util/queue/errors.ts +0 -14
  1262. package/src/util/queue/fnQueue.ts +0 -16
  1263. package/src/util/queue/index.ts +0 -4
  1264. package/src/util/queue/itemQueue.ts +0 -128
  1265. package/src/util/queue/options.ts +0 -37
  1266. package/src/util/serializedCache.ts +0 -20
  1267. package/src/util/set.ts +0 -62
  1268. package/src/util/shuffle.ts +0 -21
  1269. package/src/util/sortBy.ts +0 -19
  1270. package/src/util/sszBytes.ts +0 -481
  1271. package/src/util/strictEvents.ts +0 -8
  1272. package/src/util/time.ts +0 -13
  1273. package/src/util/timeSeries.ts +0 -118
  1274. package/src/util/types.ts +0 -31
  1275. package/src/util/workerEvents.ts +0 -142
  1276. package/src/util/wrapError.ts +0 -27
@@ -1,410 +0,0 @@
1
- import {ChainForkConfig} from "@lodestar/config";
2
- import {
3
- BeaconStateAllForks,
4
- CachedBeaconStateAllForks,
5
- CachedBeaconStateElectra,
6
- becomesNewEth1Data,
7
- } from "@lodestar/state-transition";
8
- import {phase0, ssz} from "@lodestar/types";
9
- import {ErrorAborted, Logger, TimeoutError, fromHex, isErrorAborted, sleep} from "@lodestar/utils";
10
- import {IBeaconDb} from "../db/index.js";
11
- import {Metrics} from "../metrics/index.js";
12
- import {Eth1DataCache} from "./eth1DataCache.js";
13
- import {Eth1DepositsCache} from "./eth1DepositsCache.js";
14
- import {Eth1DataAndDeposits, EthJsonRpcBlockRaw, IEth1Provider} from "./interface.js";
15
- import {Eth1Options} from "./options.js";
16
- import {parseEth1Block} from "./provider/eth1Provider.js";
17
- import {HttpRpcError} from "./provider/jsonRpcHttpClient.js";
18
- import {isJsonRpcTruncatedError} from "./provider/utils.js";
19
- import {getDeposits} from "./utils/deposits.js";
20
- import {getEth1VotesToConsider, pickEth1Vote} from "./utils/eth1Vote.js";
21
-
22
- const MAX_BLOCKS_PER_BLOCK_QUERY = 1000;
23
- const MIN_BLOCKS_PER_BLOCK_QUERY = 10;
24
-
25
- const MAX_BLOCKS_PER_LOG_QUERY = 1000;
26
- const MIN_BLOCKS_PER_LOG_QUERY = 10;
27
-
28
- /** Eth1 blocks happen every 14s approx, not need to update too often once synced */
29
- const AUTO_UPDATE_PERIOD_MS = 60 * 1000;
30
- /** Prevent infinite loops */
31
- const MIN_UPDATE_PERIOD_MS = 1 * 1000;
32
- /** Milliseconds to wait after getting 429 Too Many Requests */
33
- const RATE_LIMITED_WAIT_MS = 30 * 1000;
34
- /** Min time to wait on auto update loop on unknown error */
35
- const MIN_WAIT_ON_ERROR_MS = 1 * 1000;
36
-
37
- /** Number of blocks to download if the node detects it is lagging behind due to an inaccurate
38
- relationship between block-number-based follow distance and time-based follow distance. */
39
- const ETH1_FOLLOW_DISTANCE_DELTA_IF_SLOW = 32;
40
-
41
- /** The absolute minimum follow distance to enforce when downloading catchup batches, from LH */
42
- const ETH_MIN_FOLLOW_DISTANCE = 64;
43
-
44
- export type Eth1DepositDataTrackerModules = {
45
- config: ChainForkConfig;
46
- db: IBeaconDb;
47
- metrics: Metrics | null;
48
- logger: Logger;
49
- signal: AbortSignal;
50
- };
51
-
52
- /**
53
- * Main class handling eth1 data fetching, processing and storing
54
- * Upon instantiation, starts fetching deposits and blocks at regular intervals
55
- */
56
- export class Eth1DepositDataTracker {
57
- private config: ChainForkConfig;
58
- private logger: Logger;
59
- private signal: AbortSignal;
60
- private readonly metrics: Metrics | null;
61
-
62
- // Internal modules, state
63
- private depositsCache: Eth1DepositsCache;
64
- private eth1DataCache: Eth1DataCache;
65
- private lastProcessedDepositBlockNumber: number | null = null;
66
-
67
- /** Dynamically adjusted follow distance */
68
- private eth1FollowDistance: number;
69
- /** Dynamically adjusted batch size to fetch deposit logs */
70
- private eth1GetBlocksBatchSizeDynamic = MAX_BLOCKS_PER_BLOCK_QUERY;
71
- /** Dynamically adjusted batch size to fetch deposit logs */
72
- private eth1GetLogsBatchSizeDynamic = MAX_BLOCKS_PER_LOG_QUERY;
73
- private readonly forcedEth1DataVote: phase0.Eth1Data | null;
74
- /** To stop `runAutoUpdate()` in addition to AbortSignal */
75
- private stopPolling: boolean;
76
-
77
- constructor(
78
- opts: Eth1Options,
79
- {config, db, metrics, logger, signal}: Eth1DepositDataTrackerModules,
80
- private readonly eth1Provider: IEth1Provider
81
- ) {
82
- this.config = config;
83
- this.metrics = metrics;
84
- this.logger = logger;
85
- this.signal = signal;
86
- this.eth1Provider = eth1Provider;
87
- this.depositsCache = new Eth1DepositsCache(opts, config, db);
88
- this.eth1DataCache = new Eth1DataCache(config, db);
89
- this.eth1FollowDistance = config.ETH1_FOLLOW_DISTANCE;
90
- this.stopPolling = false;
91
-
92
- this.forcedEth1DataVote = opts.forcedEth1DataVote
93
- ? ssz.phase0.Eth1Data.deserialize(fromHex(opts.forcedEth1DataVote))
94
- : null;
95
-
96
- if (opts.depositContractDeployBlock === undefined) {
97
- this.logger.warn("No depositContractDeployBlock provided");
98
- }
99
-
100
- if (metrics) {
101
- // Set constant value once
102
- metrics?.eth1.eth1FollowDistanceSecondsConfig.set(config.SECONDS_PER_ETH1_BLOCK * config.ETH1_FOLLOW_DISTANCE);
103
- metrics.eth1.eth1FollowDistanceDynamic.addCollect(() => {
104
- metrics.eth1.eth1FollowDistanceDynamic.set(this.eth1FollowDistance);
105
- metrics.eth1.eth1GetBlocksBatchSizeDynamic.set(this.eth1GetBlocksBatchSizeDynamic);
106
- metrics.eth1.eth1GetLogsBatchSizeDynamic.set(this.eth1GetLogsBatchSizeDynamic);
107
- });
108
- }
109
-
110
- if (opts.enabled) {
111
- this.runAutoUpdate().catch((e: Error) => {
112
- if (!(e instanceof ErrorAborted)) {
113
- this.logger.error("Error on eth1 loop", {}, e);
114
- }
115
- });
116
- }
117
- }
118
-
119
- isPollingEth1Data(): boolean {
120
- return !this.stopPolling;
121
- }
122
-
123
- stopPollingEth1Data(): void {
124
- this.stopPolling = true;
125
- }
126
-
127
- /**
128
- * Return eth1Data and deposits ready for block production for a given state
129
- */
130
- async getEth1DataAndDeposits(state: CachedBeaconStateAllForks): Promise<Eth1DataAndDeposits> {
131
- if (
132
- state.epochCtx.isPostElectra() &&
133
- state.eth1DepositIndex >= (state as CachedBeaconStateElectra).depositRequestsStartIndex
134
- ) {
135
- // No need to poll eth1Data since Electra deprecates the mechanism after depositRequestsStartIndex is reached
136
- return {eth1Data: state.eth1Data, deposits: []};
137
- }
138
- const eth1Data = this.forcedEth1DataVote ?? (await this.getEth1Data(state));
139
- const deposits = await this.getDeposits(state, eth1Data);
140
- return {eth1Data, deposits};
141
- }
142
-
143
- /**
144
- * Returns an eth1Data vote for a given state.
145
- * Requires internal caches to be updated regularly to return good results
146
- */
147
- private async getEth1Data(state: BeaconStateAllForks): Promise<phase0.Eth1Data> {
148
- try {
149
- const eth1VotesToConsider = await getEth1VotesToConsider(
150
- this.config,
151
- state,
152
- this.eth1DataCache.get.bind(this.eth1DataCache)
153
- );
154
- return pickEth1Vote(state, eth1VotesToConsider);
155
- } catch (e) {
156
- // Note: In case there's a DB issue, don't stop a block proposal. Just vote for current eth1Data
157
- this.logger.error("CRITICAL: Error reading valid votes, voting for current eth1Data", {}, e as Error);
158
- return state.eth1Data;
159
- }
160
- }
161
-
162
- /**
163
- * Returns deposits to be included for a given state and eth1Data vote.
164
- * Requires internal caches to be updated regularly to return good results
165
- */
166
- private async getDeposits(
167
- state: CachedBeaconStateAllForks,
168
- eth1DataVote: phase0.Eth1Data
169
- ): Promise<phase0.Deposit[]> {
170
- // No new deposits have to be included, continue
171
- if (eth1DataVote.depositCount === state.eth1DepositIndex) {
172
- return [];
173
- }
174
-
175
- // TODO: Review if this is optimal
176
- // Convert to view first to hash once and compare hashes
177
- const eth1DataVoteView = ssz.phase0.Eth1Data.toViewDU(eth1DataVote);
178
-
179
- // Eth1 data may change due to the vote included in this block
180
- const newEth1Data = becomesNewEth1Data(state, eth1DataVoteView) ? eth1DataVoteView : state.eth1Data;
181
- return getDeposits(state, newEth1Data, this.depositsCache.get.bind(this.depositsCache));
182
- }
183
-
184
- /**
185
- * Abortable async setInterval that runs its callback once at max between `ms` at minimum
186
- */
187
- private async runAutoUpdate(): Promise<void> {
188
- let lastRunMs = 0;
189
-
190
- while (!this.signal.aborted && !this.stopPolling) {
191
- lastRunMs = Date.now();
192
-
193
- try {
194
- const hasCaughtUp = await this.update();
195
-
196
- this.metrics?.eth1.depositTrackerIsCaughtup.set(hasCaughtUp ? 1 : 0);
197
-
198
- if (hasCaughtUp) {
199
- const sleepTimeMs = Math.max(AUTO_UPDATE_PERIOD_MS + lastRunMs - Date.now(), MIN_UPDATE_PERIOD_MS);
200
- await sleep(sleepTimeMs, this.signal);
201
- }
202
- } catch (e) {
203
- this.metrics?.eth1.depositTrackerUpdateErrors.inc(1);
204
-
205
- // From Infura: 429 Too Many Requests
206
- if (e instanceof HttpRpcError && e.status === 429) {
207
- this.logger.debug("Eth1 provider rate limited", {}, e);
208
- await sleep(RATE_LIMITED_WAIT_MS, this.signal);
209
- // only log error if state switched from online to some other state
210
- } else if (!isErrorAborted(e)) {
211
- await sleep(MIN_WAIT_ON_ERROR_MS, this.signal);
212
- }
213
- }
214
- }
215
- }
216
-
217
- /**
218
- * Update the deposit and block cache, returning an error if either fail
219
- * @returns true if it has catched up to the remote follow block
220
- */
221
- private async update(): Promise<boolean> {
222
- const remoteHighestBlock = await this.eth1Provider.getBlockNumber();
223
- this.metrics?.eth1.remoteHighestBlock.set(remoteHighestBlock);
224
-
225
- const remoteFollowBlock = remoteHighestBlock - this.eth1FollowDistance;
226
-
227
- // If remoteFollowBlock is not at or beyond deployBlock, there is no need to
228
- // fetch and track any deposit data yet
229
- if (remoteFollowBlock < (this.eth1Provider.deployBlock ?? 0)) return true;
230
-
231
- const hasCaughtUpDeposits = await this.updateDepositCache(remoteFollowBlock);
232
- const hasCaughtUpBlocks = await this.updateBlockCache(remoteFollowBlock);
233
- return hasCaughtUpDeposits && hasCaughtUpBlocks;
234
- }
235
-
236
- /**
237
- * Fetch deposit events from remote eth1 node up to follow-distance block
238
- * @returns true if it has catched up to the remote follow block
239
- */
240
- private async updateDepositCache(remoteFollowBlock: number): Promise<boolean> {
241
- const lastProcessedDepositBlockNumber = await this.getLastProcessedDepositBlockNumber();
242
- // The DB may contain deposits from a different chain making lastProcessedDepositBlockNumber > current chain tip
243
- // The Math.min() fixes those rare scenarios where fromBlock > toBlock
244
- const fromBlock = Math.min(remoteFollowBlock, this.getFromBlockToFetch(lastProcessedDepositBlockNumber));
245
- const toBlock = Math.min(remoteFollowBlock, fromBlock + this.eth1GetLogsBatchSizeDynamic - 1);
246
-
247
- let depositEvents: phase0.DepositEvent[];
248
- try {
249
- depositEvents = await this.eth1Provider.getDepositEvents(fromBlock, toBlock);
250
- // Increase the batch size linearly even if we scale down exponentially (half each time)
251
- this.eth1GetLogsBatchSizeDynamic = Math.min(
252
- MAX_BLOCKS_PER_LOG_QUERY,
253
- this.eth1GetLogsBatchSizeDynamic + MIN_BLOCKS_PER_LOG_QUERY
254
- );
255
- } catch (e) {
256
- if (isJsonRpcTruncatedError(e as Error) || e instanceof TimeoutError) {
257
- this.eth1GetLogsBatchSizeDynamic = Math.max(
258
- MIN_BLOCKS_PER_LOG_QUERY,
259
- Math.floor(this.eth1GetLogsBatchSizeDynamic / 2)
260
- );
261
- }
262
- throw e;
263
- }
264
-
265
- this.logger.verbose("Fetched deposits", {depositCount: depositEvents.length, fromBlock, toBlock});
266
- this.metrics?.eth1.depositEventsFetched.inc(depositEvents.length);
267
-
268
- await this.depositsCache.add(depositEvents);
269
- // Store the `toBlock` since that block may not contain
270
- this.lastProcessedDepositBlockNumber = toBlock;
271
- this.metrics?.eth1.lastProcessedDepositBlockNumber.set(toBlock);
272
-
273
- return toBlock >= remoteFollowBlock;
274
- }
275
-
276
- /**
277
- * Fetch block headers from a remote eth1 node up to follow-distance block
278
- *
279
- * depositRoot and depositCount are inferred from already fetched deposits.
280
- * Calling get_deposit_root() and the smart contract for a non-latest block requires an
281
- * archive node, something most users don't have access too.
282
- * @returns true if it has catched up to the remote follow timestamp
283
- */
284
- private async updateBlockCache(remoteFollowBlock: number): Promise<boolean> {
285
- const lastCachedBlock = await this.eth1DataCache.getHighestCachedBlockNumber();
286
- // lastProcessedDepositBlockNumber sets the upper bound of the possible block range to fetch in this update
287
- const lastProcessedDepositBlockNumber = await this.getLastProcessedDepositBlockNumber();
288
- // lowestEventBlockNumber set a lower bound of possible block range to fetch in this update
289
- const lowestEventBlockNumber = await this.depositsCache.getLowestDepositEventBlockNumber();
290
-
291
- // We are all caught up if:
292
- // 1. If lowestEventBlockNumber is null = no deposits have been fetch or found yet.
293
- // So there's not useful blocks to fetch until at least 1 deposit is found.
294
- // 2. If the remoteFollowBlock is behind the lowestEventBlockNumber. This can happen
295
- // if the EL's data was wiped and restarted. Not exiting here would other wise
296
- // cause a NO_DEPOSITS_FOR_BLOCK_RANGE error
297
- if (
298
- lowestEventBlockNumber === null ||
299
- lastProcessedDepositBlockNumber === null ||
300
- remoteFollowBlock < lowestEventBlockNumber
301
- ) {
302
- return true;
303
- }
304
-
305
- // Cap the upper limit of fromBlock with remoteFollowBlock in case deployBlock is set to a different network value
306
- const fromBlock = Math.min(
307
- remoteFollowBlock,
308
- // Fetch from the last cached block or the lowest known deposit block number
309
- Math.max(this.getFromBlockToFetch(lastCachedBlock), lowestEventBlockNumber)
310
- );
311
- const toBlock = Math.min(
312
- remoteFollowBlock,
313
- fromBlock + this.eth1GetBlocksBatchSizeDynamic - 1, // Block range is inclusive
314
- lastProcessedDepositBlockNumber
315
- );
316
-
317
- let blocksRaw: EthJsonRpcBlockRaw[];
318
- try {
319
- blocksRaw = await this.eth1Provider.getBlocksByNumber(fromBlock, toBlock);
320
- // Increase the batch size linearly even if we scale down exponentially (half each time)
321
- this.eth1GetBlocksBatchSizeDynamic = Math.min(
322
- MAX_BLOCKS_PER_BLOCK_QUERY,
323
- this.eth1GetBlocksBatchSizeDynamic + MIN_BLOCKS_PER_BLOCK_QUERY
324
- );
325
- } catch (e) {
326
- if (isJsonRpcTruncatedError(e as Error) || e instanceof TimeoutError) {
327
- this.eth1GetBlocksBatchSizeDynamic = Math.max(
328
- MIN_BLOCKS_PER_BLOCK_QUERY,
329
- Math.floor(this.eth1GetBlocksBatchSizeDynamic / 2)
330
- );
331
- }
332
- throw e;
333
- }
334
- const blocks = blocksRaw.map(parseEth1Block);
335
-
336
- this.logger.verbose("Fetched eth1 blocks", {blockCount: blocks.length, fromBlock, toBlock});
337
- this.metrics?.eth1.blocksFetched.inc(blocks.length);
338
- this.metrics?.eth1.lastFetchedBlockBlockNumber.set(toBlock);
339
- const lastBlock = blocks.at(-1);
340
- if (lastBlock) {
341
- this.metrics?.eth1.lastFetchedBlockTimestamp.set(lastBlock.timestamp);
342
- }
343
-
344
- const eth1Datas = await this.depositsCache.getEth1DataForBlocks(blocks, lastProcessedDepositBlockNumber);
345
- await this.eth1DataCache.add(eth1Datas);
346
-
347
- // Note: ETH1_FOLLOW_DISTANCE_SECONDS = ETH1_FOLLOW_DISTANCE * SECONDS_PER_ETH1_BLOCK
348
- // Deposit tracker must fetch blocks and deposits up to ETH1_FOLLOW_DISTANCE_SECONDS,
349
- // measured in time not blocks. To vote on valid votes it must populate up to the time based follow distance.
350
- // If it assumes SECONDS_PER_ETH1_BLOCK but block times are:
351
- // - slower: Cache will not contain all blocks
352
- // - faster: Cache will contain all required blocks + some ahead of timed follow distance
353
- //
354
- // For mainnet we must fetch blocks up until block.timestamp < now - 28672 sec. Based on follow distance:
355
- // Block times | actual follow distance
356
- // 14 | 2048
357
- // 20 | 1434
358
- // 30 | 956
359
- // 60 | 478
360
- //
361
- // So if after fetching the block at ETH1_FOLLOW_DISTANCE, but it's timestamp is not greater than
362
- // ETH1_FOLLOW_DISTANCE_SECONDS, reduce the ETH1_FOLLOW_DISTANCE by a small delta and fetch more blocks.
363
- // Otherwise if the last fetched block if above ETH1_FOLLOW_DISTANCE_SECONDS, reduce ETH1_FOLLOW_DISTANCE.
364
-
365
- if (toBlock < remoteFollowBlock) {
366
- return false;
367
- }
368
-
369
- if (!lastBlock) {
370
- return true;
371
- }
372
-
373
- const remoteFollowBlockTimestamp =
374
- Math.round(Date.now() / 1000) - this.config.SECONDS_PER_ETH1_BLOCK * this.config.ETH1_FOLLOW_DISTANCE;
375
- const blockAfterTargetTimestamp = blocks.find((block) => block.timestamp >= remoteFollowBlockTimestamp);
376
-
377
- if (blockAfterTargetTimestamp) {
378
- // Catched up to target timestamp, increase eth1FollowDistance. Limit max config.ETH1_FOLLOW_DISTANCE.
379
- // If the block that's right above the timestamp has been fetched now, use it to compute the precise delta.
380
- const delta = Math.max(lastBlock.blockNumber - blockAfterTargetTimestamp.blockNumber, 1);
381
- this.eth1FollowDistance = Math.min(this.eth1FollowDistance + delta, this.config.ETH1_FOLLOW_DISTANCE);
382
-
383
- return true;
384
- }
385
- // Blocks are slower than expected, reduce eth1FollowDistance. Limit min CATCHUP_MIN_FOLLOW_DISTANCE
386
- const delta =
387
- this.eth1FollowDistance -
388
- Math.max(this.eth1FollowDistance - ETH1_FOLLOW_DISTANCE_DELTA_IF_SLOW, ETH_MIN_FOLLOW_DISTANCE);
389
- this.eth1FollowDistance = this.eth1FollowDistance - delta;
390
-
391
- // Even if the blocks are slow, when we are all caught up as there is no
392
- // further possibility to reduce follow distance, we need to call it quits
393
- // for now, else it leads to an incessant poll on the EL
394
- return delta === 0;
395
- }
396
-
397
- private getFromBlockToFetch(lastCachedBlock: number | null): number {
398
- if (lastCachedBlock === null) {
399
- return this.eth1Provider.deployBlock ?? 0;
400
- }
401
- return lastCachedBlock + 1;
402
- }
403
-
404
- private async getLastProcessedDepositBlockNumber(): Promise<number | null> {
405
- if (this.lastProcessedDepositBlockNumber === null) {
406
- this.lastProcessedDepositBlockNumber = await this.depositsCache.getHighestDepositEventBlockNumber();
407
- }
408
- return this.lastProcessedDepositBlockNumber;
409
- }
410
- }
@@ -1,141 +0,0 @@
1
- import {byteArrayEquals} from "@chainsafe/ssz";
2
- import {ChainForkConfig} from "@lodestar/config";
3
- import {FilterOptions} from "@lodestar/db";
4
- import {phase0, ssz} from "@lodestar/types";
5
- import {IBeaconDb} from "../db/index.js";
6
- import {Eth1Error, Eth1ErrorCode} from "./errors.js";
7
- import {Eth1Block} from "./interface.js";
8
- import {getDepositsWithProofs} from "./utils/deposits.js";
9
- import {getEth1DataForBlocks} from "./utils/eth1Data.js";
10
- import {assertConsecutiveDeposits} from "./utils/eth1DepositEvent.js";
11
-
12
- export class Eth1DepositsCache {
13
- unsafeAllowDepositDataOverwrite: boolean;
14
- db: IBeaconDb;
15
- config: ChainForkConfig;
16
-
17
- constructor(opts: {unsafeAllowDepositDataOverwrite?: boolean}, config: ChainForkConfig, db: IBeaconDb) {
18
- this.config = config;
19
- this.db = db;
20
- this.unsafeAllowDepositDataOverwrite = opts.unsafeAllowDepositDataOverwrite ?? false;
21
- }
22
-
23
- /**
24
- * Returns a list of `Deposit` objects, within the given deposit index `range`.
25
- *
26
- * The `depositCount` is used to generate the proofs for the `Deposits`. For example, if we
27
- * have 100 proofs, but the Ethereum Consensus chain only acknowledges 50 of them, we must produce our
28
- * proofs with respect to a tree size of 50.
29
- */
30
- async get(indexRange: FilterOptions<number>, eth1Data: phase0.Eth1Data): Promise<phase0.Deposit[]> {
31
- const depositEvents = await this.db.depositEvent.values(indexRange);
32
- const depositRootTree = await this.db.depositDataRoot.getDepositRootTree();
33
- return getDepositsWithProofs(depositEvents, depositRootTree, eth1Data);
34
- }
35
-
36
- /**
37
- * Add log to cache
38
- * This function enforces that `logs` are imported one-by-one with consecutive indexes
39
- */
40
- async add(depositEvents: phase0.DepositEvent[]): Promise<void> {
41
- assertConsecutiveDeposits(depositEvents);
42
-
43
- const lastLog = await this.db.depositEvent.lastValue();
44
- const firstEvent = depositEvents[0];
45
-
46
- // Check, validate and skip if we got any deposit events already present in DB
47
- // This can happen if the remote eth1/EL resets its head in these four scenarios:
48
- // 1. Remote eth1/EL resynced/restarted from head behind its previous head pre-merge
49
- // 2. In a post merge scenario, Lodestar restarted from finalized state from DB which
50
- // generally is a few epochs behind the last synced head. This causes eth1 tracker to reset
51
- // and refetch the deposits as the lodestar syncs further along (Post merge there is 1-1
52
- // correspondence between EL and CL blocks)
53
- // 3. The EL reorged beyond the eth1 follow distance.
54
- //
55
- // While 1. & 2. are benign and we handle them below by checking if the duplicate log fetched
56
- // is same as one written in DB. Refer to this issue for some data dump of how this happens
57
- // https://github.com/ChainSafe/lodestar/issues/3674
58
- //
59
- // If the duplicate log fetched is not same as written in DB then its probablu scenario 3.
60
- // which would be a catastrophic event for the network (or we messed up real bad!!!).
61
- //
62
- // So we provide for a way to overwrite this log without deleting full db via
63
- // --unsafeAllowDepositDataOverwrite cli flag which will just overwrite the previous tracker data
64
- // if any. This option as indicated by its name is unsafe and to be only used if you know what
65
- // you are doing.
66
- if (lastLog !== null && firstEvent !== undefined) {
67
- const newIndex = firstEvent.index;
68
- const lastLogIndex = lastLog.index;
69
-
70
- if (!this.unsafeAllowDepositDataOverwrite && firstEvent.index <= lastLog.index) {
71
- // lastLogIndex - newIndex + 1 events are duplicate since this is a consecutive log
72
- // as asserted by assertConsecutiveDeposits. Splice those events out from depositEvents.
73
- const skipEvents = depositEvents.splice(0, lastLogIndex - newIndex + 1);
74
- // After splicing skipEvents will contain duplicate events to be checked and validated
75
- // and rest of the remaining events in depositEvents could be safely written to DB and
76
- // move the tracker along.
77
- for (const depositEvent of skipEvents) {
78
- const prevDBSerializedEvent = await this.db.depositEvent.getBinary(depositEvent.index);
79
- if (!prevDBSerializedEvent) {
80
- throw new Eth1Error({code: Eth1ErrorCode.MISSING_DEPOSIT_LOG, newIndex, lastLogIndex});
81
- }
82
- const serializedEvent = ssz.phase0.DepositEvent.serialize(depositEvent);
83
- if (!byteArrayEquals(prevDBSerializedEvent, serializedEvent)) {
84
- throw new Eth1Error({code: Eth1ErrorCode.DUPLICATE_DISTINCT_LOG, newIndex, lastLogIndex});
85
- }
86
- }
87
- } else if (newIndex > lastLogIndex + 1) {
88
- // deposit events need to be consective, the way we fetch our tracker. If the deposit event
89
- // is not consecutive it means either our tracker, or the corresponding eth1/EL
90
- // node or the database has messed up. All these failures are critical and the tracker
91
- // shouldn't proceed without the resolution of this error.
92
- throw new Eth1Error({code: Eth1ErrorCode.NON_CONSECUTIVE_LOGS, newIndex, lastLogIndex});
93
- }
94
- }
95
-
96
- const depositRoots = depositEvents.map((depositEvent) => ({
97
- index: depositEvent.index,
98
- root: ssz.phase0.DepositData.hashTreeRoot(depositEvent.depositData),
99
- }));
100
-
101
- // Store events after verifying that data is consecutive
102
- // depositDataRoot will throw if adding non consecutive roots
103
- await this.db.depositDataRoot.batchPutValues(depositRoots);
104
- await this.db.depositEvent.batchPutValues(depositEvents);
105
- }
106
-
107
- /**
108
- * Appends partial eth1 data (depositRoot, depositCount) in a block range (inclusive)
109
- * Returned array is sequential and ascending in blockNumber
110
- * @param fromBlock
111
- * @param toBlock
112
- */
113
- async getEth1DataForBlocks(
114
- blocks: Eth1Block[],
115
- lastProcessedDepositBlockNumber: number | null
116
- ): Promise<(phase0.Eth1Data & Eth1Block)[]> {
117
- const highestBlock = blocks.at(-1)?.blockNumber;
118
- return getEth1DataForBlocks(
119
- blocks,
120
- this.db.depositEvent.valuesStream({lte: highestBlock, reverse: true}),
121
- await this.db.depositDataRoot.getDepositRootTree(),
122
- lastProcessedDepositBlockNumber
123
- );
124
- }
125
-
126
- /**
127
- * Returns the highest blockNumber stored in DB if any
128
- */
129
- async getHighestDepositEventBlockNumber(): Promise<number | null> {
130
- const latestEvent = await this.db.depositEvent.lastValue();
131
- return latestEvent?.blockNumber || null;
132
- }
133
-
134
- /**
135
- * Returns the lowest blockNumber stored in DB if any
136
- */
137
- async getLowestDepositEventBlockNumber(): Promise<number | null> {
138
- const firstEvent = await this.db.depositEvent.firstValue();
139
- return firstEvent?.blockNumber || null;
140
- }
141
- }