@lodestar/beacon-node 1.35.0-dev.549f58dd39 → 1.35.0-dev.56313c7299

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 (1366) hide show
  1. package/lib/api/impl/beacon/blocks/index.js +46 -58
  2. package/lib/api/impl/beacon/blocks/index.js.map +1 -1
  3. package/lib/api/impl/config/constants.d.ts +0 -5
  4. package/lib/api/impl/config/constants.js +1 -6
  5. package/lib/api/impl/config/constants.js.map +1 -1
  6. package/lib/api/impl/debug/index.js +1 -1
  7. package/lib/api/impl/debug/index.js.map +1 -1
  8. package/lib/api/impl/errors.js +0 -2
  9. package/lib/api/impl/errors.js.map +1 -1
  10. package/lib/api/impl/index.d.ts +3 -3
  11. package/lib/api/impl/index.js +3 -3
  12. package/lib/api/impl/index.js.map +1 -1
  13. package/lib/api/impl/lodestar/index.js +1 -1
  14. package/lib/api/impl/lodestar/index.js.map +1 -1
  15. package/lib/api/impl/validator/index.js +4 -7
  16. package/lib/api/impl/validator/index.js.map +1 -1
  17. package/lib/api/rest/activeSockets.js +2 -3
  18. package/lib/api/rest/activeSockets.js.map +1 -1
  19. package/lib/api/rest/base.d.ts +1 -1
  20. package/lib/api/rest/base.js +2 -6
  21. package/lib/api/rest/base.js.map +1 -1
  22. package/lib/api/rest/index.js +0 -2
  23. package/lib/api/rest/index.js.map +1 -1
  24. package/lib/api/rest/swaggerUI.js +2 -4
  25. package/lib/api/rest/swaggerUI.js.map +1 -1
  26. package/lib/chain/archiveStore/archiveStore.js +38 -49
  27. package/lib/chain/archiveStore/archiveStore.js.map +1 -1
  28. package/lib/chain/archiveStore/historicalState/historicalStateRegen.js +0 -3
  29. package/lib/chain/archiveStore/historicalState/historicalStateRegen.js.map +1 -1
  30. package/lib/chain/archiveStore/historicalState/worker.js +1 -1
  31. package/lib/chain/archiveStore/historicalState/worker.js.map +1 -1
  32. package/lib/chain/archiveStore/index.d.ts +1 -1
  33. package/lib/chain/archiveStore/index.js +1 -1
  34. package/lib/chain/archiveStore/strategies/frequencyStateArchiveStrategy.js +0 -5
  35. package/lib/chain/archiveStore/strategies/frequencyStateArchiveStrategy.js.map +1 -1
  36. package/lib/chain/balancesCache.js +3 -1
  37. package/lib/chain/balancesCache.js.map +1 -1
  38. package/lib/chain/beaconProposerCache.js +0 -1
  39. package/lib/chain/beaconProposerCache.js.map +1 -1
  40. package/lib/chain/blocks/blockInput/blockInput.d.ts +7 -19
  41. package/lib/chain/blocks/blockInput/blockInput.js +89 -133
  42. package/lib/chain/blocks/blockInput/blockInput.js.map +1 -1
  43. package/lib/chain/blocks/blockInput/index.d.ts +1 -1
  44. package/lib/chain/blocks/blockInput/index.js +1 -1
  45. package/lib/chain/blocks/blockInput/types.d.ts +10 -19
  46. package/lib/chain/blocks/blockInput/types.js +0 -1
  47. package/lib/chain/blocks/blockInput/types.js.map +1 -1
  48. package/lib/chain/blocks/blockInput/utils.d.ts +4 -0
  49. package/lib/chain/blocks/blockInput/utils.js +29 -6
  50. package/lib/chain/blocks/blockInput/utils.js.map +1 -1
  51. package/lib/chain/blocks/importBlock.js +14 -19
  52. package/lib/chain/blocks/importBlock.js.map +1 -1
  53. package/lib/chain/blocks/index.d.ts +5 -6
  54. package/lib/chain/blocks/index.js +4 -5
  55. package/lib/chain/blocks/index.js.map +1 -1
  56. package/lib/chain/blocks/types.d.ts +106 -3
  57. package/lib/chain/blocks/types.js +119 -0
  58. package/lib/chain/blocks/types.js.map +1 -1
  59. package/lib/chain/blocks/utils/chainSegment.d.ts +2 -2
  60. package/lib/chain/blocks/utils/chainSegment.js +2 -2
  61. package/lib/chain/blocks/utils/chainSegment.js.map +1 -1
  62. package/lib/chain/blocks/verifyBlock.d.ts +3 -3
  63. package/lib/chain/blocks/verifyBlock.js +14 -15
  64. package/lib/chain/blocks/verifyBlock.js.map +1 -1
  65. package/lib/chain/blocks/verifyBlocksDataAvailability.d.ts +22 -7
  66. package/lib/chain/blocks/verifyBlocksDataAvailability.js +108 -23
  67. package/lib/chain/blocks/verifyBlocksDataAvailability.js.map +1 -1
  68. package/lib/chain/blocks/verifyBlocksExecutionPayloads.d.ts +3 -4
  69. package/lib/chain/blocks/verifyBlocksExecutionPayloads.js +22 -24
  70. package/lib/chain/blocks/verifyBlocksExecutionPayloads.js.map +1 -1
  71. package/lib/chain/blocks/verifyBlocksSanityChecks.d.ts +3 -4
  72. package/lib/chain/blocks/verifyBlocksSanityChecks.js +2 -2
  73. package/lib/chain/blocks/verifyBlocksSanityChecks.js.map +1 -1
  74. package/lib/chain/blocks/verifyBlocksStateTransitionOnly.d.ts +2 -3
  75. package/lib/chain/blocks/verifyBlocksStateTransitionOnly.js +2 -2
  76. package/lib/chain/blocks/verifyBlocksStateTransitionOnly.js.map +1 -1
  77. package/lib/chain/blocks/writeBlockInputToDb.d.ts +3 -3
  78. package/lib/chain/blocks/writeBlockInputToDb.js +67 -56
  79. package/lib/chain/blocks/writeBlockInputToDb.js.map +1 -1
  80. package/lib/chain/bls/multithread/index.js +163 -168
  81. package/lib/chain/bls/multithread/index.js.map +1 -1
  82. package/lib/chain/bls/singleThread.js +0 -1
  83. package/lib/chain/bls/singleThread.js.map +1 -1
  84. package/lib/chain/chain.d.ts +11 -13
  85. package/lib/chain/chain.js +23 -81
  86. package/lib/chain/chain.js.map +1 -1
  87. package/lib/chain/emitter.d.ts +2 -43
  88. package/lib/chain/emitter.js +0 -18
  89. package/lib/chain/emitter.js.map +1 -1
  90. package/lib/chain/errors/blobSidecarError.d.ts +0 -24
  91. package/lib/chain/errors/blobSidecarError.js +0 -10
  92. package/lib/chain/errors/blobSidecarError.js.map +1 -1
  93. package/lib/chain/errors/blockError.js +0 -1
  94. package/lib/chain/errors/blockError.js.map +1 -1
  95. package/lib/chain/errors/dataColumnSidecarError.d.ts +0 -42
  96. package/lib/chain/errors/dataColumnSidecarError.js +0 -14
  97. package/lib/chain/errors/dataColumnSidecarError.js.map +1 -1
  98. package/lib/chain/errors/gossipValidation.js +0 -1
  99. package/lib/chain/errors/gossipValidation.js.map +1 -1
  100. package/lib/chain/errors/index.d.ts +2 -2
  101. package/lib/chain/errors/index.js +2 -2
  102. package/lib/chain/errors/index.js.map +1 -1
  103. package/lib/chain/forkChoice/index.js.map +1 -1
  104. package/lib/chain/genesis/genesis.js +5 -16
  105. package/lib/chain/genesis/genesis.js.map +1 -1
  106. package/lib/chain/index.d.ts +2 -2
  107. package/lib/chain/index.js +2 -2
  108. package/lib/chain/index.js.map +1 -1
  109. package/lib/chain/interface.d.ts +9 -12
  110. package/lib/chain/interface.js.map +1 -1
  111. package/lib/chain/lightClient/index.js +9 -16
  112. package/lib/chain/lightClient/index.js.map +1 -1
  113. package/lib/chain/lightClient/proofs.js.map +1 -1
  114. package/lib/chain/opPools/aggregatedAttestationPool.js +9 -14
  115. package/lib/chain/opPools/aggregatedAttestationPool.js.map +1 -1
  116. package/lib/chain/opPools/attestationPool.d.ts +3 -2
  117. package/lib/chain/opPools/attestationPool.js +7 -10
  118. package/lib/chain/opPools/attestationPool.js.map +1 -1
  119. package/lib/chain/opPools/index.d.ts +1 -1
  120. package/lib/chain/opPools/index.js +1 -1
  121. package/lib/chain/opPools/index.js.map +1 -1
  122. package/lib/chain/opPools/opPool.js +12 -10
  123. package/lib/chain/opPools/opPool.js.map +1 -1
  124. package/lib/chain/opPools/syncCommitteeMessagePool.d.ts +2 -3
  125. package/lib/chain/opPools/syncCommitteeMessagePool.js +10 -14
  126. package/lib/chain/opPools/syncCommitteeMessagePool.js.map +1 -1
  127. package/lib/chain/opPools/syncContributionAndProofPool.js +2 -5
  128. package/lib/chain/opPools/syncContributionAndProofPool.js.map +1 -1
  129. package/lib/chain/opPools/types.d.ts +1 -1
  130. package/lib/chain/opPools/types.js +1 -1
  131. package/lib/chain/opPools/types.js.map +1 -1
  132. package/lib/chain/options.js +1 -1
  133. package/lib/chain/options.js.map +1 -1
  134. package/lib/chain/prepareNextSlot.d.ts +3 -3
  135. package/lib/chain/prepareNextSlot.js +140 -145
  136. package/lib/chain/prepareNextSlot.js.map +1 -1
  137. package/lib/chain/produceBlock/produceBlockBody.d.ts +1 -1
  138. package/lib/chain/produceBlock/produceBlockBody.js +10 -3
  139. package/lib/chain/produceBlock/produceBlockBody.js.map +1 -1
  140. package/lib/chain/regen/errors.js +0 -1
  141. package/lib/chain/regen/errors.js.map +1 -1
  142. package/lib/chain/regen/index.d.ts +1 -1
  143. package/lib/chain/regen/index.js +1 -1
  144. package/lib/chain/regen/index.js.map +1 -1
  145. package/lib/chain/regen/queued.js +28 -35
  146. package/lib/chain/regen/queued.js.map +1 -1
  147. package/lib/chain/regen/regen.js +0 -1
  148. package/lib/chain/regen/regen.js.map +1 -1
  149. package/lib/chain/reprocess.js +1 -3
  150. package/lib/chain/reprocess.js.map +1 -1
  151. package/lib/chain/seenCache/index.d.ts +1 -1
  152. package/lib/chain/seenCache/index.js +1 -1
  153. package/lib/chain/seenCache/index.js.map +1 -1
  154. package/lib/chain/seenCache/seenAggregateAndProof.js +6 -7
  155. package/lib/chain/seenCache/seenAggregateAndProof.js.map +1 -1
  156. package/lib/chain/seenCache/seenAttestationData.js +2 -5
  157. package/lib/chain/seenCache/seenAttestationData.js.map +1 -1
  158. package/lib/chain/seenCache/seenAttesters.js +4 -2
  159. package/lib/chain/seenCache/seenAttesters.js.map +1 -1
  160. package/lib/chain/seenCache/seenBlockInput.d.ts +84 -0
  161. package/lib/chain/seenCache/seenBlockInput.js +225 -0
  162. package/lib/chain/seenCache/seenBlockInput.js.map +1 -0
  163. package/lib/chain/seenCache/seenBlockProposers.js +4 -2
  164. package/lib/chain/seenCache/seenBlockProposers.js.map +1 -1
  165. package/lib/chain/seenCache/seenCommittee.js +3 -1
  166. package/lib/chain/seenCache/seenCommittee.js.map +1 -1
  167. package/lib/chain/seenCache/seenCommitteeContribution.js +2 -3
  168. package/lib/chain/seenCache/seenCommitteeContribution.js.map +1 -1
  169. package/lib/chain/seenCache/seenGossipBlockInput.d.ts +78 -74
  170. package/lib/chain/seenCache/seenGossipBlockInput.js +369 -235
  171. package/lib/chain/seenCache/seenGossipBlockInput.js.map +1 -1
  172. package/lib/chain/shufflingCache.js +2 -5
  173. package/lib/chain/shufflingCache.js.map +1 -1
  174. package/lib/chain/stateCache/blockStateCacheImpl.js +7 -13
  175. package/lib/chain/stateCache/blockStateCacheImpl.js.map +1 -1
  176. package/lib/chain/stateCache/datastore/db.js +0 -1
  177. package/lib/chain/stateCache/datastore/db.js.map +1 -1
  178. package/lib/chain/stateCache/datastore/file.js +0 -1
  179. package/lib/chain/stateCache/datastore/file.js.map +1 -1
  180. package/lib/chain/stateCache/datastore/index.d.ts +1 -1
  181. package/lib/chain/stateCache/datastore/index.js +1 -1
  182. package/lib/chain/stateCache/datastore/index.js.map +1 -1
  183. package/lib/chain/stateCache/fifoBlockStateCache.js +0 -10
  184. package/lib/chain/stateCache/fifoBlockStateCache.js.map +1 -1
  185. package/lib/chain/stateCache/inMemoryCheckpointsCache.js +4 -10
  186. package/lib/chain/stateCache/inMemoryCheckpointsCache.js.map +1 -1
  187. package/lib/chain/stateCache/index.d.ts +1 -1
  188. package/lib/chain/stateCache/index.js +1 -1
  189. package/lib/chain/stateCache/index.js.map +1 -1
  190. package/lib/chain/stateCache/mapMetrics.js +4 -4
  191. package/lib/chain/stateCache/mapMetrics.js.map +1 -1
  192. package/lib/chain/stateCache/persistentCheckpointsCache.js +14 -23
  193. package/lib/chain/stateCache/persistentCheckpointsCache.js.map +1 -1
  194. package/lib/chain/validation/blobSidecar.d.ts +3 -8
  195. package/lib/chain/validation/blobSidecar.js +31 -73
  196. package/lib/chain/validation/blobSidecar.js.map +1 -1
  197. package/lib/chain/validation/dataColumnSidecar.d.ts +9 -7
  198. package/lib/chain/validation/dataColumnSidecar.js +57 -95
  199. package/lib/chain/validation/dataColumnSidecar.js.map +1 -1
  200. package/lib/chain/validation/index.d.ts +1 -1
  201. package/lib/chain/validation/index.js +1 -1
  202. package/lib/chain/validation/index.js.map +1 -1
  203. package/lib/chain/validation/lightClientFinalityUpdate.js +3 -4
  204. package/lib/chain/validation/lightClientFinalityUpdate.js.map +1 -1
  205. package/lib/chain/validation/lightClientOptimisticUpdate.d.ts +4 -6
  206. package/lib/chain/validation/lightClientOptimisticUpdate.js +11 -11
  207. package/lib/chain/validation/lightClientOptimisticUpdate.js.map +1 -1
  208. package/lib/chain/validation/signatureSets/aggregateAndProof.d.ts +2 -1
  209. package/lib/chain/validation/signatureSets/aggregateAndProof.js.map +1 -1
  210. package/lib/chain/validatorMonitor.d.ts +3 -1
  211. package/lib/chain/validatorMonitor.js +15 -22
  212. package/lib/chain/validatorMonitor.js.map +1 -1
  213. package/lib/db/beacon.js +0 -24
  214. package/lib/db/beacon.js.map +1 -1
  215. package/lib/db/buckets.d.ts +4 -4
  216. package/lib/db/buckets.js +4 -4
  217. package/lib/db/buckets.js.map +1 -1
  218. package/lib/db/index.d.ts +1 -1
  219. package/lib/db/index.js.map +1 -1
  220. package/lib/db/repositories/blobSidecars.js +1 -1
  221. package/lib/db/repositories/blobSidecars.js.map +1 -1
  222. package/lib/db/repositories/blobSidecarsArchive.js +1 -1
  223. package/lib/db/repositories/blobSidecarsArchive.js.map +1 -1
  224. package/lib/db/repositories/blockArchive.js +3 -2
  225. package/lib/db/repositories/blockArchive.js.map +1 -1
  226. package/lib/db/repositories/blockArchiveIndex.d.ts +2 -2
  227. package/lib/db/repositories/dataColumnSidecar.js +2 -2
  228. package/lib/db/repositories/dataColumnSidecar.js.map +1 -1
  229. package/lib/db/repositories/dataColumnSidecarArchive.js +2 -2
  230. package/lib/db/repositories/dataColumnSidecarArchive.js.map +1 -1
  231. package/lib/db/repositories/depositDataRoot.js +0 -1
  232. package/lib/db/repositories/depositDataRoot.js.map +1 -1
  233. package/lib/db/repositories/index.d.ts +10 -10
  234. package/lib/db/repositories/index.js +9 -9
  235. package/lib/db/repositories/index.js.map +1 -1
  236. package/lib/db/single/preGenesisState.js +0 -6
  237. package/lib/db/single/preGenesisState.js.map +1 -1
  238. package/lib/db/single/preGenesisStateLastProcessedBlock.js +0 -5
  239. package/lib/db/single/preGenesisStateLastProcessedBlock.js.map +1 -1
  240. package/lib/eth1/eth1DataCache.js +0 -2
  241. package/lib/eth1/eth1DataCache.js.map +1 -1
  242. package/lib/eth1/eth1DepositDataTracker.js +5 -18
  243. package/lib/eth1/eth1DepositDataTracker.js.map +1 -1
  244. package/lib/eth1/eth1DepositsCache.js +0 -3
  245. package/lib/eth1/eth1DepositsCache.js.map +1 -1
  246. package/lib/eth1/eth1MergeBlockTracker.js +4 -10
  247. package/lib/eth1/eth1MergeBlockTracker.js.map +1 -1
  248. package/lib/eth1/index.js +0 -2
  249. package/lib/eth1/index.js.map +1 -1
  250. package/lib/eth1/provider/eth1Provider.d.ts +2 -1
  251. package/lib/eth1/provider/eth1Provider.js +2 -6
  252. package/lib/eth1/provider/eth1Provider.js.map +1 -1
  253. package/lib/eth1/provider/jsonRpcHttpClient.d.ts +1 -1
  254. package/lib/eth1/provider/jsonRpcHttpClient.js +2 -16
  255. package/lib/eth1/provider/jsonRpcHttpClient.js.map +1 -1
  256. package/lib/eth1/provider/jwt.js.map +1 -1
  257. package/lib/eth1/provider/utils.d.ts +0 -5
  258. package/lib/eth1/provider/utils.js +1 -9
  259. package/lib/eth1/provider/utils.js.map +1 -1
  260. package/lib/eth1/utils/deposits.js.map +1 -1
  261. package/lib/execution/builder/cache.js +0 -6
  262. package/lib/execution/builder/cache.js.map +1 -1
  263. package/lib/execution/builder/http.js +8 -14
  264. package/lib/execution/builder/http.js.map +1 -1
  265. package/lib/execution/builder/index.js.map +1 -1
  266. package/lib/execution/engine/disabled.js +4 -2
  267. package/lib/execution/engine/disabled.js.map +1 -1
  268. package/lib/execution/engine/http.d.ts +2 -2
  269. package/lib/execution/engine/http.js +11 -43
  270. package/lib/execution/engine/http.js.map +1 -1
  271. package/lib/execution/engine/interface.d.ts +2 -2
  272. package/lib/execution/engine/interface.js.map +1 -1
  273. package/lib/execution/engine/mock.d.ts +0 -1
  274. package/lib/execution/engine/mock.js +12 -16
  275. package/lib/execution/engine/mock.js.map +1 -1
  276. package/lib/execution/engine/payloadIdCache.js +3 -1
  277. package/lib/execution/engine/payloadIdCache.js.map +1 -1
  278. package/lib/execution/engine/types.d.ts +1 -5
  279. package/lib/execution/engine/types.js +8 -37
  280. package/lib/execution/engine/types.js.map +1 -1
  281. package/lib/execution/engine/utils.js +3 -3
  282. package/lib/execution/engine/utils.js.map +1 -1
  283. package/lib/execution/index.d.ts +2 -2
  284. package/lib/execution/index.js +2 -2
  285. package/lib/execution/index.js.map +1 -1
  286. package/lib/index.d.ts +6 -6
  287. package/lib/index.js +5 -5
  288. package/lib/index.js.map +1 -1
  289. package/lib/metrics/index.d.ts +1 -1
  290. package/lib/metrics/index.js +1 -1
  291. package/lib/metrics/index.js.map +1 -1
  292. package/lib/metrics/metrics/beacon.d.ts +5 -11
  293. package/lib/metrics/metrics/beacon.js +20 -40
  294. package/lib/metrics/metrics/beacon.js.map +1 -1
  295. package/lib/metrics/metrics/lodestar.d.ts +14 -56
  296. package/lib/metrics/metrics/lodestar.js +10 -87
  297. package/lib/metrics/metrics/lodestar.js.map +1 -1
  298. package/lib/metrics/metrics.d.ts +1 -1
  299. package/lib/metrics/metrics.js.map +1 -1
  300. package/lib/metrics/nodeJsMetrics.js +1 -1
  301. package/lib/metrics/nodeJsMetrics.js.map +1 -1
  302. package/lib/metrics/server/http.d.ts +1 -1
  303. package/lib/metrics/utils/avgMinMax.d.ts +1 -1
  304. package/lib/metrics/utils/avgMinMax.js +6 -10
  305. package/lib/metrics/utils/avgMinMax.js.map +1 -1
  306. package/lib/metrics/utils/gauge.d.ts +1 -1
  307. package/lib/metrics/utils/gauge.js +4 -1
  308. package/lib/metrics/utils/gauge.js.map +1 -1
  309. package/lib/metrics/utils/registryMetricCreator.d.ts +1 -1
  310. package/lib/metrics/utils/registryMetricCreator.js.map +1 -1
  311. package/lib/monitoring/properties.js +0 -4
  312. package/lib/monitoring/properties.js.map +1 -1
  313. package/lib/monitoring/service.js +1 -13
  314. package/lib/monitoring/service.js.map +1 -1
  315. package/lib/monitoring/system.js +27 -25
  316. package/lib/monitoring/system.js.map +1 -1
  317. package/lib/network/core/networkCore.d.ts +2 -2
  318. package/lib/network/core/networkCore.js +50 -67
  319. package/lib/network/core/networkCore.js.map +1 -1
  320. package/lib/network/core/networkCoreWorker.js +1 -1
  321. package/lib/network/core/networkCoreWorker.js.map +1 -1
  322. package/lib/network/core/networkCoreWorkerHandler.d.ts +2 -2
  323. package/lib/network/core/networkCoreWorkerHandler.js +5 -14
  324. package/lib/network/core/networkCoreWorkerHandler.js.map +1 -1
  325. package/lib/network/discv5/index.d.ts +2 -2
  326. package/lib/network/discv5/index.js +3 -9
  327. package/lib/network/discv5/index.js.map +1 -1
  328. package/lib/network/discv5/worker.js +3 -3
  329. package/lib/network/discv5/worker.js.map +1 -1
  330. package/lib/network/events.d.ts +18 -2
  331. package/lib/network/events.js +7 -0
  332. package/lib/network/events.js.map +1 -1
  333. package/lib/network/gossip/encoding.d.ts +1 -1
  334. package/lib/network/gossip/encoding.js +2 -4
  335. package/lib/network/gossip/encoding.js.map +1 -1
  336. package/lib/network/gossip/errors.js +0 -1
  337. package/lib/network/gossip/errors.js.map +1 -1
  338. package/lib/network/gossip/gossipsub.d.ts +1 -2
  339. package/lib/network/gossip/gossipsub.js +17 -43
  340. package/lib/network/gossip/gossipsub.js.map +1 -1
  341. package/lib/network/gossip/index.d.ts +2 -2
  342. package/lib/network/gossip/index.js +2 -2
  343. package/lib/network/gossip/index.js.map +1 -1
  344. package/lib/network/gossip/interface.d.ts +2 -2
  345. package/lib/network/gossip/metrics.d.ts +7 -15
  346. package/lib/network/gossip/metrics.js +6 -16
  347. package/lib/network/gossip/metrics.js.map +1 -1
  348. package/lib/network/gossip/topic.d.ts +105 -125
  349. package/lib/network/gossip/topic.js +1 -2
  350. package/lib/network/gossip/topic.js.map +1 -1
  351. package/lib/network/index.d.ts +3 -3
  352. package/lib/network/index.js +3 -3
  353. package/lib/network/index.js.map +1 -1
  354. package/lib/network/interface.d.ts +2 -3
  355. package/lib/network/libp2p/index.js +3 -11
  356. package/lib/network/libp2p/index.js.map +1 -1
  357. package/lib/network/metadata.js +1 -6
  358. package/lib/network/metadata.js.map +1 -1
  359. package/lib/network/network.d.ts +3 -5
  360. package/lib/network/network.js +76 -92
  361. package/lib/network/network.js.map +1 -1
  362. package/lib/network/options.js +1 -1
  363. package/lib/network/options.js.map +1 -1
  364. package/lib/network/peers/datastore.d.ts +2 -2
  365. package/lib/network/peers/datastore.js +4 -10
  366. package/lib/network/peers/datastore.js.map +1 -1
  367. package/lib/network/peers/discover.js +66 -75
  368. package/lib/network/peers/discover.js.map +1 -1
  369. package/lib/network/peers/peerManager.js +130 -154
  370. package/lib/network/peers/peerManager.js.map +1 -1
  371. package/lib/network/peers/peersData.d.ts +1 -1
  372. package/lib/network/peers/peersData.js +3 -1
  373. package/lib/network/peers/peersData.js.map +1 -1
  374. package/lib/network/peers/score/index.d.ts +1 -1
  375. package/lib/network/peers/score/index.js +1 -1
  376. package/lib/network/peers/score/index.js.map +1 -1
  377. package/lib/network/peers/score/score.js +0 -6
  378. package/lib/network/peers/score/score.js.map +1 -1
  379. package/lib/network/peers/score/store.js +0 -3
  380. package/lib/network/peers/score/store.js.map +1 -1
  381. package/lib/network/peers/utils/prioritizePeers.js.map +1 -1
  382. package/lib/network/peers/utils/subnetMap.js +4 -2
  383. package/lib/network/peers/utils/subnetMap.js.map +1 -1
  384. package/lib/network/processor/aggregatorTracker.js +3 -1
  385. package/lib/network/processor/aggregatorTracker.js.map +1 -1
  386. package/lib/network/processor/gossipHandlers.js +164 -145
  387. package/lib/network/processor/gossipHandlers.js.map +1 -1
  388. package/lib/network/processor/gossipQueues/indexed.js +9 -11
  389. package/lib/network/processor/gossipQueues/indexed.js.map +1 -1
  390. package/lib/network/processor/gossipQueues/linear.js +8 -9
  391. package/lib/network/processor/gossipQueues/linear.js.map +1 -1
  392. package/lib/network/processor/index.d.ts +1 -2
  393. package/lib/network/processor/index.js +8 -21
  394. package/lib/network/processor/index.js.map +1 -1
  395. package/lib/network/reqresp/ReqRespBeaconNode.d.ts +1 -1
  396. package/lib/network/reqresp/ReqRespBeaconNode.js +2 -11
  397. package/lib/network/reqresp/ReqRespBeaconNode.js.map +1 -1
  398. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.d.ts +28 -0
  399. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.js +328 -0
  400. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.js.map +1 -0
  401. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.d.ts +49 -0
  402. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.js +499 -0
  403. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.js.map +1 -0
  404. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js.map +1 -1
  405. package/lib/network/reqresp/index.d.ts +3 -1
  406. package/lib/network/reqresp/index.js +3 -1
  407. package/lib/network/reqresp/index.js.map +1 -1
  408. package/lib/network/reqresp/rateLimit.js +2 -2
  409. package/lib/network/reqresp/rateLimit.js.map +1 -1
  410. package/lib/network/reqresp/utils/dataColumnResponseValidation.js.map +1 -1
  411. package/lib/network/statusCache.js +0 -1
  412. package/lib/network/statusCache.js.map +1 -1
  413. package/lib/network/subnets/attnetsService.js +65 -73
  414. package/lib/network/subnets/attnetsService.js.map +1 -1
  415. package/lib/network/subnets/interface.js +1 -1
  416. package/lib/network/subnets/interface.js.map +1 -1
  417. package/lib/network/subnets/syncnetsService.js +22 -29
  418. package/lib/network/subnets/syncnetsService.js.map +1 -1
  419. package/lib/network/subnets/util.js +2 -1
  420. package/lib/network/subnets/util.js.map +1 -1
  421. package/lib/node/nodejs.d.ts +1 -1
  422. package/lib/node/nodejs.js +0 -15
  423. package/lib/node/nodejs.js.map +1 -1
  424. package/lib/node/notifier.js +2 -1
  425. package/lib/node/notifier.js.map +1 -1
  426. package/lib/node/options.js.map +1 -1
  427. package/lib/node/utils/interop/state.js +2 -1
  428. package/lib/node/utils/interop/state.js.map +1 -1
  429. package/lib/sync/backfill/backfill.d.ts +1 -1
  430. package/lib/sync/backfill/backfill.js +16 -58
  431. package/lib/sync/backfill/backfill.js.map +1 -1
  432. package/lib/sync/constants.d.ts +1 -2
  433. package/lib/sync/constants.js +1 -2
  434. package/lib/sync/constants.js.map +1 -1
  435. package/lib/sync/interface.d.ts +59 -1
  436. package/lib/sync/interface.js +20 -0
  437. package/lib/sync/interface.js.map +1 -1
  438. package/lib/sync/options.d.ts +1 -1
  439. package/lib/sync/range/batch.d.ts +32 -48
  440. package/lib/sync/range/batch.js +55 -201
  441. package/lib/sync/range/batch.js.map +1 -1
  442. package/lib/sync/range/chain.d.ts +10 -15
  443. package/lib/sync/range/chain.js +70 -141
  444. package/lib/sync/range/chain.js.map +1 -1
  445. package/lib/sync/range/range.d.ts +3 -3
  446. package/lib/sync/range/range.js +54 -86
  447. package/lib/sync/range/range.js.map +1 -1
  448. package/lib/sync/range/utils/hashBlocks.d.ts +2 -2
  449. package/lib/sync/range/utils/hashBlocks.js +4 -6
  450. package/lib/sync/range/utils/hashBlocks.js.map +1 -1
  451. package/lib/sync/range/utils/peerBalancer.js +13 -18
  452. package/lib/sync/range/utils/peerBalancer.js.map +1 -1
  453. package/lib/sync/sync.d.ts +2 -1
  454. package/lib/sync/sync.js +87 -95
  455. package/lib/sync/sync.js.map +1 -1
  456. package/lib/sync/unknownBlock.d.ts +29 -42
  457. package/lib/sync/unknownBlock.js +461 -405
  458. package/lib/sync/unknownBlock.js.map +1 -1
  459. package/lib/sync/utils/pendingBlocksTree.d.ts +6 -14
  460. package/lib/sync/utils/pendingBlocksTree.js +18 -24
  461. package/lib/sync/utils/pendingBlocksTree.js.map +1 -1
  462. package/lib/util/array.js +3 -7
  463. package/lib/util/array.js.map +1 -1
  464. package/lib/util/asyncIterableToEvents.js +3 -6
  465. package/lib/util/asyncIterableToEvents.js.map +1 -1
  466. package/lib/util/binarySearch.js +0 -2
  467. package/lib/util/binarySearch.js.map +1 -1
  468. package/lib/util/blobs.d.ts +2 -2
  469. package/lib/util/blobs.js +7 -9
  470. package/lib/util/blobs.js.map +1 -1
  471. package/lib/util/bufferPool.js +2 -7
  472. package/lib/util/bufferPool.js.map +1 -1
  473. package/lib/util/clock.d.ts +1 -6
  474. package/lib/util/clock.js +18 -26
  475. package/lib/util/clock.js.map +1 -1
  476. package/lib/util/dataColumns.d.ts +10 -13
  477. package/lib/util/dataColumns.js +132 -90
  478. package/lib/util/dataColumns.js.map +1 -1
  479. package/lib/util/itTrigger.js +4 -4
  480. package/lib/util/itTrigger.js.map +1 -1
  481. package/lib/util/map.js +0 -2
  482. package/lib/util/map.js.map +1 -1
  483. package/lib/util/queue/index.d.ts +1 -1
  484. package/lib/util/queue/index.js +1 -1
  485. package/lib/util/queue/index.js.map +1 -1
  486. package/lib/util/queue/itemQueue.js +49 -52
  487. package/lib/util/queue/itemQueue.js.map +1 -1
  488. package/lib/util/serializedCache.js +3 -1
  489. package/lib/util/serializedCache.js.map +1 -1
  490. package/lib/util/set.js +0 -2
  491. package/lib/util/set.js.map +1 -1
  492. package/lib/util/sszBytes.d.ts +0 -1
  493. package/lib/util/sszBytes.js +1 -1
  494. package/lib/util/sszBytes.js.map +1 -1
  495. package/lib/util/timeSeries.js +1 -3
  496. package/lib/util/timeSeries.js.map +1 -1
  497. package/lib/util/types.d.ts +1 -1
  498. package/lib/util/wrapError.d.ts +0 -7
  499. package/package.json +23 -39
  500. package/lib/api/impl/api.d.ts.map +0 -1
  501. package/lib/api/impl/beacon/blocks/index.d.ts.map +0 -1
  502. package/lib/api/impl/beacon/blocks/utils.d.ts.map +0 -1
  503. package/lib/api/impl/beacon/index.d.ts.map +0 -1
  504. package/lib/api/impl/beacon/pool/index.d.ts.map +0 -1
  505. package/lib/api/impl/beacon/rewards/index.d.ts.map +0 -1
  506. package/lib/api/impl/beacon/state/index.d.ts.map +0 -1
  507. package/lib/api/impl/beacon/state/utils.d.ts.map +0 -1
  508. package/lib/api/impl/config/constants.d.ts.map +0 -1
  509. package/lib/api/impl/config/index.d.ts.map +0 -1
  510. package/lib/api/impl/debug/index.d.ts.map +0 -1
  511. package/lib/api/impl/errors.d.ts.map +0 -1
  512. package/lib/api/impl/events/index.d.ts.map +0 -1
  513. package/lib/api/impl/index.d.ts.map +0 -1
  514. package/lib/api/impl/lightclient/index.d.ts.map +0 -1
  515. package/lib/api/impl/lodestar/index.d.ts.map +0 -1
  516. package/lib/api/impl/node/index.d.ts.map +0 -1
  517. package/lib/api/impl/node/utils.d.ts.map +0 -1
  518. package/lib/api/impl/proof/index.d.ts.map +0 -1
  519. package/lib/api/impl/types.d.ts.map +0 -1
  520. package/lib/api/impl/utils.d.ts.map +0 -1
  521. package/lib/api/impl/validator/index.d.ts.map +0 -1
  522. package/lib/api/impl/validator/utils.d.ts.map +0 -1
  523. package/lib/api/index.d.ts.map +0 -1
  524. package/lib/api/options.d.ts.map +0 -1
  525. package/lib/api/rest/activeSockets.d.ts.map +0 -1
  526. package/lib/api/rest/base.d.ts.map +0 -1
  527. package/lib/api/rest/index.d.ts.map +0 -1
  528. package/lib/api/rest/swaggerUI.d.ts.map +0 -1
  529. package/lib/bun-wrappers/prometheus-gc-stats.d.ts +0 -2
  530. package/lib/bun-wrappers/prometheus-gc-stats.d.ts.map +0 -1
  531. package/lib/bun-wrappers/prometheus-gc-stats.js +0 -8
  532. package/lib/bun-wrappers/prometheus-gc-stats.js.map +0 -1
  533. package/lib/chain/ColumnReconstructionTracker.d.ts +0 -32
  534. package/lib/chain/ColumnReconstructionTracker.d.ts.map +0 -1
  535. package/lib/chain/ColumnReconstructionTracker.js +0 -71
  536. package/lib/chain/ColumnReconstructionTracker.js.map +0 -1
  537. package/lib/chain/GetBlobsTracker.d.ts +0 -31
  538. package/lib/chain/GetBlobsTracker.d.ts.map +0 -1
  539. package/lib/chain/GetBlobsTracker.js +0 -82
  540. package/lib/chain/GetBlobsTracker.js.map +0 -1
  541. package/lib/chain/archiveStore/archiveStore.d.ts.map +0 -1
  542. package/lib/chain/archiveStore/constants.d.ts.map +0 -1
  543. package/lib/chain/archiveStore/historicalState/getHistoricalState.d.ts.map +0 -1
  544. package/lib/chain/archiveStore/historicalState/historicalStateRegen.d.ts.map +0 -1
  545. package/lib/chain/archiveStore/historicalState/metrics.d.ts.map +0 -1
  546. package/lib/chain/archiveStore/historicalState/types.d.ts.map +0 -1
  547. package/lib/chain/archiveStore/historicalState/worker.d.ts.map +0 -1
  548. package/lib/chain/archiveStore/index.d.ts.map +0 -1
  549. package/lib/chain/archiveStore/interface.d.ts.map +0 -1
  550. package/lib/chain/archiveStore/strategies/frequencyStateArchiveStrategy.d.ts.map +0 -1
  551. package/lib/chain/archiveStore/utils/archiveBlocks.d.ts.map +0 -1
  552. package/lib/chain/archiveStore/utils/pruneHistory.d.ts.map +0 -1
  553. package/lib/chain/archiveStore/utils/updateBackfillRange.d.ts.map +0 -1
  554. package/lib/chain/balancesCache.d.ts.map +0 -1
  555. package/lib/chain/beaconProposerCache.d.ts.map +0 -1
  556. package/lib/chain/blocks/blockInput/blockInput.d.ts.map +0 -1
  557. package/lib/chain/blocks/blockInput/errors.d.ts.map +0 -1
  558. package/lib/chain/blocks/blockInput/index.d.ts.map +0 -1
  559. package/lib/chain/blocks/blockInput/types.d.ts.map +0 -1
  560. package/lib/chain/blocks/blockInput/utils.d.ts.map +0 -1
  561. package/lib/chain/blocks/importBlock.d.ts.map +0 -1
  562. package/lib/chain/blocks/index.d.ts.map +0 -1
  563. package/lib/chain/blocks/types.d.ts.map +0 -1
  564. package/lib/chain/blocks/utils/blowfishBanner.d.ts.map +0 -1
  565. package/lib/chain/blocks/utils/chainSegment.d.ts.map +0 -1
  566. package/lib/chain/blocks/utils/checkpoint.d.ts.map +0 -1
  567. package/lib/chain/blocks/utils/giraffeBanner.d.ts.map +0 -1
  568. package/lib/chain/blocks/utils/ownBanner.d.ts.map +0 -1
  569. package/lib/chain/blocks/utils/pandaMergeTransitionBanner.d.ts.map +0 -1
  570. package/lib/chain/blocks/utils/zebraBanner.d.ts.map +0 -1
  571. package/lib/chain/blocks/verifyBlock.d.ts.map +0 -1
  572. package/lib/chain/blocks/verifyBlocksDataAvailability.d.ts.map +0 -1
  573. package/lib/chain/blocks/verifyBlocksExecutionPayloads.d.ts.map +0 -1
  574. package/lib/chain/blocks/verifyBlocksSanityChecks.d.ts.map +0 -1
  575. package/lib/chain/blocks/verifyBlocksSignatures.d.ts.map +0 -1
  576. package/lib/chain/blocks/verifyBlocksStateTransitionOnly.d.ts.map +0 -1
  577. package/lib/chain/blocks/writeBlockInputToDb.d.ts.map +0 -1
  578. package/lib/chain/bls/index.d.ts.map +0 -1
  579. package/lib/chain/bls/interface.d.ts.map +0 -1
  580. package/lib/chain/bls/maybeBatch.d.ts.map +0 -1
  581. package/lib/chain/bls/multithread/index.d.ts.map +0 -1
  582. package/lib/chain/bls/multithread/jobItem.d.ts.map +0 -1
  583. package/lib/chain/bls/multithread/poolSize.d.ts.map +0 -1
  584. package/lib/chain/bls/multithread/types.d.ts.map +0 -1
  585. package/lib/chain/bls/multithread/utils.d.ts.map +0 -1
  586. package/lib/chain/bls/multithread/worker.d.ts.map +0 -1
  587. package/lib/chain/bls/singleThread.d.ts.map +0 -1
  588. package/lib/chain/bls/utils.d.ts.map +0 -1
  589. package/lib/chain/chain.d.ts.map +0 -1
  590. package/lib/chain/emitter.d.ts.map +0 -1
  591. package/lib/chain/errors/attestationError.d.ts.map +0 -1
  592. package/lib/chain/errors/attesterSlashingError.d.ts.map +0 -1
  593. package/lib/chain/errors/blobSidecarError.d.ts.map +0 -1
  594. package/lib/chain/errors/blockError.d.ts.map +0 -1
  595. package/lib/chain/errors/blsToExecutionChangeError.d.ts.map +0 -1
  596. package/lib/chain/errors/dataColumnSidecarError.d.ts.map +0 -1
  597. package/lib/chain/errors/gossipValidation.d.ts.map +0 -1
  598. package/lib/chain/errors/index.d.ts.map +0 -1
  599. package/lib/chain/errors/lightClientError.d.ts.map +0 -1
  600. package/lib/chain/errors/proposerSlashingError.d.ts.map +0 -1
  601. package/lib/chain/errors/syncCommitteeError.d.ts.map +0 -1
  602. package/lib/chain/errors/voluntaryExitError.d.ts.map +0 -1
  603. package/lib/chain/forkChoice/index.d.ts.map +0 -1
  604. package/lib/chain/genesis/genesis.d.ts.map +0 -1
  605. package/lib/chain/genesis/interface.d.ts.map +0 -1
  606. package/lib/chain/index.d.ts.map +0 -1
  607. package/lib/chain/initState.d.ts.map +0 -1
  608. package/lib/chain/interface.d.ts.map +0 -1
  609. package/lib/chain/lightClient/index.d.ts.map +0 -1
  610. package/lib/chain/lightClient/proofs.d.ts.map +0 -1
  611. package/lib/chain/lightClient/types.d.ts.map +0 -1
  612. package/lib/chain/opPools/aggregatedAttestationPool.d.ts.map +0 -1
  613. package/lib/chain/opPools/attestationPool.d.ts.map +0 -1
  614. package/lib/chain/opPools/index.d.ts.map +0 -1
  615. package/lib/chain/opPools/opPool.d.ts.map +0 -1
  616. package/lib/chain/opPools/syncCommitteeMessagePool.d.ts.map +0 -1
  617. package/lib/chain/opPools/syncContributionAndProofPool.d.ts.map +0 -1
  618. package/lib/chain/opPools/types.d.ts.map +0 -1
  619. package/lib/chain/opPools/utils.d.ts.map +0 -1
  620. package/lib/chain/options.d.ts.map +0 -1
  621. package/lib/chain/prepareNextSlot.d.ts.map +0 -1
  622. package/lib/chain/produceBlock/computeNewStateRoot.d.ts.map +0 -1
  623. package/lib/chain/produceBlock/index.d.ts.map +0 -1
  624. package/lib/chain/produceBlock/produceBlockBody.d.ts.map +0 -1
  625. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.d.ts.map +0 -1
  626. package/lib/chain/regen/errors.d.ts.map +0 -1
  627. package/lib/chain/regen/index.d.ts.map +0 -1
  628. package/lib/chain/regen/interface.d.ts.map +0 -1
  629. package/lib/chain/regen/queued.d.ts.map +0 -1
  630. package/lib/chain/regen/regen.d.ts.map +0 -1
  631. package/lib/chain/reprocess.d.ts.map +0 -1
  632. package/lib/chain/rewards/attestationsRewards.d.ts.map +0 -1
  633. package/lib/chain/rewards/blockRewards.d.ts.map +0 -1
  634. package/lib/chain/rewards/syncCommitteeRewards.d.ts.map +0 -1
  635. package/lib/chain/seenCache/index.d.ts.map +0 -1
  636. package/lib/chain/seenCache/seenAggregateAndProof.d.ts.map +0 -1
  637. package/lib/chain/seenCache/seenAttestationData.d.ts.map +0 -1
  638. package/lib/chain/seenCache/seenAttesters.d.ts.map +0 -1
  639. package/lib/chain/seenCache/seenBlockAttesters.d.ts.map +0 -1
  640. package/lib/chain/seenCache/seenBlockProposers.d.ts.map +0 -1
  641. package/lib/chain/seenCache/seenCommittee.d.ts.map +0 -1
  642. package/lib/chain/seenCache/seenCommitteeContribution.d.ts.map +0 -1
  643. package/lib/chain/seenCache/seenGossipBlockInput.d.ts.map +0 -1
  644. package/lib/chain/serializeState.d.ts.map +0 -1
  645. package/lib/chain/shufflingCache.d.ts.map +0 -1
  646. package/lib/chain/stateCache/blockStateCacheImpl.d.ts.map +0 -1
  647. package/lib/chain/stateCache/datastore/db.d.ts.map +0 -1
  648. package/lib/chain/stateCache/datastore/file.d.ts.map +0 -1
  649. package/lib/chain/stateCache/datastore/index.d.ts.map +0 -1
  650. package/lib/chain/stateCache/datastore/types.d.ts.map +0 -1
  651. package/lib/chain/stateCache/fifoBlockStateCache.d.ts.map +0 -1
  652. package/lib/chain/stateCache/inMemoryCheckpointsCache.d.ts.map +0 -1
  653. package/lib/chain/stateCache/index.d.ts.map +0 -1
  654. package/lib/chain/stateCache/mapMetrics.d.ts.map +0 -1
  655. package/lib/chain/stateCache/persistentCheckpointsCache.d.ts.map +0 -1
  656. package/lib/chain/stateCache/types.d.ts.map +0 -1
  657. package/lib/chain/validation/aggregateAndProof.d.ts.map +0 -1
  658. package/lib/chain/validation/attestation.d.ts.map +0 -1
  659. package/lib/chain/validation/attesterSlashing.d.ts.map +0 -1
  660. package/lib/chain/validation/blobSidecar.d.ts.map +0 -1
  661. package/lib/chain/validation/block.d.ts.map +0 -1
  662. package/lib/chain/validation/blsToExecutionChange.d.ts.map +0 -1
  663. package/lib/chain/validation/dataColumnSidecar.d.ts.map +0 -1
  664. package/lib/chain/validation/index.d.ts.map +0 -1
  665. package/lib/chain/validation/lightClientFinalityUpdate.d.ts.map +0 -1
  666. package/lib/chain/validation/lightClientOptimisticUpdate.d.ts.map +0 -1
  667. package/lib/chain/validation/proposerSlashing.d.ts.map +0 -1
  668. package/lib/chain/validation/signatureSets/aggregateAndProof.d.ts.map +0 -1
  669. package/lib/chain/validation/signatureSets/contributionAndProof.d.ts.map +0 -1
  670. package/lib/chain/validation/signatureSets/index.d.ts.map +0 -1
  671. package/lib/chain/validation/signatureSets/selectionProof.d.ts.map +0 -1
  672. package/lib/chain/validation/signatureSets/syncCommittee.d.ts.map +0 -1
  673. package/lib/chain/validation/signatureSets/syncCommitteeContribution.d.ts.map +0 -1
  674. package/lib/chain/validation/signatureSets/syncCommitteeSelectionProof.d.ts.map +0 -1
  675. package/lib/chain/validation/syncCommittee.d.ts.map +0 -1
  676. package/lib/chain/validation/syncCommitteeContributionAndProof.d.ts.map +0 -1
  677. package/lib/chain/validation/voluntaryExit.d.ts.map +0 -1
  678. package/lib/chain/validatorMonitor.d.ts.map +0 -1
  679. package/lib/constants/constants.d.ts.map +0 -1
  680. package/lib/constants/index.d.ts.map +0 -1
  681. package/lib/constants/network.d.ts.map +0 -1
  682. package/lib/db/beacon.d.ts.map +0 -1
  683. package/lib/db/buckets.d.ts.map +0 -1
  684. package/lib/db/index.d.ts.map +0 -1
  685. package/lib/db/interface.d.ts.map +0 -1
  686. package/lib/db/options.d.ts.map +0 -1
  687. package/lib/db/repositories/attesterSlashing.d.ts.map +0 -1
  688. package/lib/db/repositories/backfilledRanges.d.ts.map +0 -1
  689. package/lib/db/repositories/blobSidecars.d.ts.map +0 -1
  690. package/lib/db/repositories/blobSidecarsArchive.d.ts.map +0 -1
  691. package/lib/db/repositories/block.d.ts.map +0 -1
  692. package/lib/db/repositories/blockArchive.d.ts.map +0 -1
  693. package/lib/db/repositories/blockArchiveIndex.d.ts.map +0 -1
  694. package/lib/db/repositories/blsToExecutionChange.d.ts.map +0 -1
  695. package/lib/db/repositories/checkpointState.d.ts.map +0 -1
  696. package/lib/db/repositories/dataColumnSidecar.d.ts.map +0 -1
  697. package/lib/db/repositories/dataColumnSidecarArchive.d.ts.map +0 -1
  698. package/lib/db/repositories/depositDataRoot.d.ts.map +0 -1
  699. package/lib/db/repositories/depositEvent.d.ts.map +0 -1
  700. package/lib/db/repositories/eth1Data.d.ts.map +0 -1
  701. package/lib/db/repositories/index.d.ts.map +0 -1
  702. package/lib/db/repositories/lightclientBestUpdate.d.ts.map +0 -1
  703. package/lib/db/repositories/lightclientCheckpointHeader.d.ts.map +0 -1
  704. package/lib/db/repositories/lightclientSyncCommittee.d.ts.map +0 -1
  705. package/lib/db/repositories/lightclientSyncCommitteeWitness.d.ts.map +0 -1
  706. package/lib/db/repositories/proposerSlashing.d.ts.map +0 -1
  707. package/lib/db/repositories/stateArchive.d.ts.map +0 -1
  708. package/lib/db/repositories/stateArchiveIndex.d.ts.map +0 -1
  709. package/lib/db/repositories/voluntaryExit.d.ts.map +0 -1
  710. package/lib/db/single/index.d.ts.map +0 -1
  711. package/lib/db/single/preGenesisState.d.ts.map +0 -1
  712. package/lib/db/single/preGenesisStateLastProcessedBlock.d.ts.map +0 -1
  713. package/lib/eth1/errors.d.ts.map +0 -1
  714. package/lib/eth1/eth1DataCache.d.ts.map +0 -1
  715. package/lib/eth1/eth1DepositDataTracker.d.ts.map +0 -1
  716. package/lib/eth1/eth1DepositsCache.d.ts.map +0 -1
  717. package/lib/eth1/eth1MergeBlockTracker.d.ts.map +0 -1
  718. package/lib/eth1/index.d.ts.map +0 -1
  719. package/lib/eth1/interface.d.ts.map +0 -1
  720. package/lib/eth1/options.d.ts.map +0 -1
  721. package/lib/eth1/provider/eth1Provider.d.ts.map +0 -1
  722. package/lib/eth1/provider/jsonRpcHttpClient.d.ts.map +0 -1
  723. package/lib/eth1/provider/jwt.d.ts.map +0 -1
  724. package/lib/eth1/provider/utils.d.ts.map +0 -1
  725. package/lib/eth1/stream.d.ts.map +0 -1
  726. package/lib/eth1/utils/depositContract.d.ts.map +0 -1
  727. package/lib/eth1/utils/deposits.d.ts.map +0 -1
  728. package/lib/eth1/utils/eth1Data.d.ts.map +0 -1
  729. package/lib/eth1/utils/eth1DepositEvent.d.ts.map +0 -1
  730. package/lib/eth1/utils/eth1Vote.d.ts.map +0 -1
  731. package/lib/eth1/utils/groupDepositEventsByBlock.d.ts.map +0 -1
  732. package/lib/eth1/utils/optimizeNextBlockDiffForGenesis.d.ts.map +0 -1
  733. package/lib/execution/builder/cache.d.ts.map +0 -1
  734. package/lib/execution/builder/http.d.ts.map +0 -1
  735. package/lib/execution/builder/index.d.ts.map +0 -1
  736. package/lib/execution/builder/interface.d.ts.map +0 -1
  737. package/lib/execution/builder/utils.d.ts.map +0 -1
  738. package/lib/execution/engine/disabled.d.ts.map +0 -1
  739. package/lib/execution/engine/http.d.ts.map +0 -1
  740. package/lib/execution/engine/index.d.ts.map +0 -1
  741. package/lib/execution/engine/interface.d.ts.map +0 -1
  742. package/lib/execution/engine/mock.d.ts.map +0 -1
  743. package/lib/execution/engine/payloadIdCache.d.ts.map +0 -1
  744. package/lib/execution/engine/types.d.ts.map +0 -1
  745. package/lib/execution/engine/utils.d.ts.map +0 -1
  746. package/lib/execution/index.d.ts.map +0 -1
  747. package/lib/index.d.ts.map +0 -1
  748. package/lib/metrics/index.d.ts.map +0 -1
  749. package/lib/metrics/metrics/beacon.d.ts.map +0 -1
  750. package/lib/metrics/metrics/lodestar.d.ts.map +0 -1
  751. package/lib/metrics/metrics.d.ts.map +0 -1
  752. package/lib/metrics/nodeJsMetrics.d.ts.map +0 -1
  753. package/lib/metrics/options.d.ts.map +0 -1
  754. package/lib/metrics/server/http.d.ts.map +0 -1
  755. package/lib/metrics/server/index.d.ts.map +0 -1
  756. package/lib/metrics/utils/avgMinMax.d.ts.map +0 -1
  757. package/lib/metrics/utils/gauge.d.ts.map +0 -1
  758. package/lib/metrics/utils/registryMetricCreator.d.ts.map +0 -1
  759. package/lib/monitoring/clientStats.d.ts.map +0 -1
  760. package/lib/monitoring/index.d.ts.map +0 -1
  761. package/lib/monitoring/options.d.ts.map +0 -1
  762. package/lib/monitoring/properties.d.ts.map +0 -1
  763. package/lib/monitoring/service.d.ts.map +0 -1
  764. package/lib/monitoring/system.d.ts.map +0 -1
  765. package/lib/monitoring/types.d.ts.map +0 -1
  766. package/lib/network/core/events.d.ts.map +0 -1
  767. package/lib/network/core/index.d.ts.map +0 -1
  768. package/lib/network/core/metrics.d.ts.map +0 -1
  769. package/lib/network/core/networkCore.d.ts.map +0 -1
  770. package/lib/network/core/networkCoreWorker.d.ts.map +0 -1
  771. package/lib/network/core/networkCoreWorkerHandler.d.ts.map +0 -1
  772. package/lib/network/core/types.d.ts.map +0 -1
  773. package/lib/network/discv5/index.d.ts.map +0 -1
  774. package/lib/network/discv5/types.d.ts.map +0 -1
  775. package/lib/network/discv5/utils.d.ts.map +0 -1
  776. package/lib/network/discv5/worker.d.ts.map +0 -1
  777. package/lib/network/events.d.ts.map +0 -1
  778. package/lib/network/forks.d.ts.map +0 -1
  779. package/lib/network/gossip/constants.d.ts.map +0 -1
  780. package/lib/network/gossip/encoding.d.ts.map +0 -1
  781. package/lib/network/gossip/errors.d.ts.map +0 -1
  782. package/lib/network/gossip/gossipsub.d.ts.map +0 -1
  783. package/lib/network/gossip/index.d.ts.map +0 -1
  784. package/lib/network/gossip/interface.d.ts.map +0 -1
  785. package/lib/network/gossip/metrics.d.ts.map +0 -1
  786. package/lib/network/gossip/scoringParameters.d.ts.map +0 -1
  787. package/lib/network/gossip/topic.d.ts.map +0 -1
  788. package/lib/network/index.d.ts.map +0 -1
  789. package/lib/network/interface.d.ts.map +0 -1
  790. package/lib/network/libp2p/error.d.ts.map +0 -1
  791. package/lib/network/libp2p/index.d.ts.map +0 -1
  792. package/lib/network/metadata.d.ts.map +0 -1
  793. package/lib/network/network.d.ts.map +0 -1
  794. package/lib/network/networkConfig.d.ts.map +0 -1
  795. package/lib/network/options.d.ts.map +0 -1
  796. package/lib/network/peers/client.d.ts.map +0 -1
  797. package/lib/network/peers/datastore.d.ts.map +0 -1
  798. package/lib/network/peers/discover.d.ts.map +0 -1
  799. package/lib/network/peers/index.d.ts.map +0 -1
  800. package/lib/network/peers/peerManager.d.ts.map +0 -1
  801. package/lib/network/peers/peersData.d.ts.map +0 -1
  802. package/lib/network/peers/score/constants.d.ts.map +0 -1
  803. package/lib/network/peers/score/index.d.ts.map +0 -1
  804. package/lib/network/peers/score/interface.d.ts.map +0 -1
  805. package/lib/network/peers/score/score.d.ts.map +0 -1
  806. package/lib/network/peers/score/store.d.ts.map +0 -1
  807. package/lib/network/peers/score/utils.d.ts.map +0 -1
  808. package/lib/network/peers/utils/assertPeerRelevance.d.ts.map +0 -1
  809. package/lib/network/peers/utils/enrSubnetsDeserialize.d.ts.map +0 -1
  810. package/lib/network/peers/utils/getConnectedPeerIds.d.ts.map +0 -1
  811. package/lib/network/peers/utils/index.d.ts.map +0 -1
  812. package/lib/network/peers/utils/prioritizePeers.d.ts.map +0 -1
  813. package/lib/network/peers/utils/subnetMap.d.ts.map +0 -1
  814. package/lib/network/processor/aggregatorTracker.d.ts.map +0 -1
  815. package/lib/network/processor/extractSlotRootFns.d.ts.map +0 -1
  816. package/lib/network/processor/gossipHandlers.d.ts.map +0 -1
  817. package/lib/network/processor/gossipQueues/index.d.ts.map +0 -1
  818. package/lib/network/processor/gossipQueues/indexed.d.ts.map +0 -1
  819. package/lib/network/processor/gossipQueues/linear.d.ts.map +0 -1
  820. package/lib/network/processor/gossipQueues/types.d.ts.map +0 -1
  821. package/lib/network/processor/gossipValidatorFn.d.ts.map +0 -1
  822. package/lib/network/processor/index.d.ts.map +0 -1
  823. package/lib/network/processor/types.d.ts.map +0 -1
  824. package/lib/network/reqresp/ReqRespBeaconNode.d.ts.map +0 -1
  825. package/lib/network/reqresp/handlers/beaconBlocksByRange.d.ts.map +0 -1
  826. package/lib/network/reqresp/handlers/beaconBlocksByRoot.d.ts.map +0 -1
  827. package/lib/network/reqresp/handlers/blobSidecarsByRange.d.ts.map +0 -1
  828. package/lib/network/reqresp/handlers/blobSidecarsByRoot.d.ts.map +0 -1
  829. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts.map +0 -1
  830. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.d.ts.map +0 -1
  831. package/lib/network/reqresp/handlers/index.d.ts.map +0 -1
  832. package/lib/network/reqresp/handlers/lightClientBootstrap.d.ts.map +0 -1
  833. package/lib/network/reqresp/handlers/lightClientFinalityUpdate.d.ts.map +0 -1
  834. package/lib/network/reqresp/handlers/lightClientOptimisticUpdate.d.ts.map +0 -1
  835. package/lib/network/reqresp/handlers/lightClientUpdatesByRange.d.ts.map +0 -1
  836. package/lib/network/reqresp/index.d.ts.map +0 -1
  837. package/lib/network/reqresp/interface.d.ts.map +0 -1
  838. package/lib/network/reqresp/protocols.d.ts.map +0 -1
  839. package/lib/network/reqresp/rateLimit.d.ts.map +0 -1
  840. package/lib/network/reqresp/score.d.ts.map +0 -1
  841. package/lib/network/reqresp/types.d.ts.map +0 -1
  842. package/lib/network/reqresp/utils/collect.d.ts.map +0 -1
  843. package/lib/network/reqresp/utils/collectSequentialBlocksInRange.d.ts.map +0 -1
  844. package/lib/network/reqresp/utils/dataColumnResponseValidation.d.ts.map +0 -1
  845. package/lib/network/statusCache.d.ts.map +0 -1
  846. package/lib/network/subnets/attnetsService.d.ts.map +0 -1
  847. package/lib/network/subnets/index.d.ts.map +0 -1
  848. package/lib/network/subnets/interface.d.ts.map +0 -1
  849. package/lib/network/subnets/syncnetsService.d.ts.map +0 -1
  850. package/lib/network/subnets/util.d.ts.map +0 -1
  851. package/lib/network/util.d.ts.map +0 -1
  852. package/lib/node/index.d.ts.map +0 -1
  853. package/lib/node/nodejs.d.ts.map +0 -1
  854. package/lib/node/notifier.d.ts.map +0 -1
  855. package/lib/node/options.d.ts.map +0 -1
  856. package/lib/node/utils/interop/deposits.d.ts.map +0 -1
  857. package/lib/node/utils/interop/state.d.ts.map +0 -1
  858. package/lib/node/utils/lightclient.d.ts.map +0 -1
  859. package/lib/node/utils/state.d.ts.map +0 -1
  860. package/lib/sync/backfill/backfill.d.ts.map +0 -1
  861. package/lib/sync/backfill/errors.d.ts.map +0 -1
  862. package/lib/sync/backfill/index.d.ts.map +0 -1
  863. package/lib/sync/backfill/verify.d.ts.map +0 -1
  864. package/lib/sync/constants.d.ts.map +0 -1
  865. package/lib/sync/index.d.ts.map +0 -1
  866. package/lib/sync/interface.d.ts.map +0 -1
  867. package/lib/sync/options.d.ts.map +0 -1
  868. package/lib/sync/range/batch.d.ts.map +0 -1
  869. package/lib/sync/range/chain.d.ts.map +0 -1
  870. package/lib/sync/range/range.d.ts.map +0 -1
  871. package/lib/sync/range/utils/batches.d.ts.map +0 -1
  872. package/lib/sync/range/utils/chainTarget.d.ts.map +0 -1
  873. package/lib/sync/range/utils/hashBlocks.d.ts.map +0 -1
  874. package/lib/sync/range/utils/index.d.ts.map +0 -1
  875. package/lib/sync/range/utils/peerBalancer.d.ts.map +0 -1
  876. package/lib/sync/range/utils/updateChains.d.ts.map +0 -1
  877. package/lib/sync/sync.d.ts.map +0 -1
  878. package/lib/sync/types.d.ts +0 -43
  879. package/lib/sync/types.d.ts.map +0 -1
  880. package/lib/sync/types.js +0 -34
  881. package/lib/sync/types.js.map +0 -1
  882. package/lib/sync/unknownBlock.d.ts.map +0 -1
  883. package/lib/sync/utils/downloadByRange.d.ts +0 -186
  884. package/lib/sync/utils/downloadByRange.d.ts.map +0 -1
  885. package/lib/sync/utils/downloadByRange.js +0 -457
  886. package/lib/sync/utils/downloadByRange.js.map +0 -1
  887. package/lib/sync/utils/downloadByRoot.d.ts +0 -121
  888. package/lib/sync/utils/downloadByRoot.d.ts.map +0 -1
  889. package/lib/sync/utils/downloadByRoot.js +0 -346
  890. package/lib/sync/utils/downloadByRoot.js.map +0 -1
  891. package/lib/sync/utils/pendingBlocksTree.d.ts.map +0 -1
  892. package/lib/sync/utils/remoteSyncType.d.ts.map +0 -1
  893. package/lib/util/address.d.ts.map +0 -1
  894. package/lib/util/array.d.ts.map +0 -1
  895. package/lib/util/asyncIterableToEvents.d.ts.map +0 -1
  896. package/lib/util/binarySearch.d.ts.map +0 -1
  897. package/lib/util/bitArray.d.ts.map +0 -1
  898. package/lib/util/blobs.d.ts.map +0 -1
  899. package/lib/util/bufferPool.d.ts.map +0 -1
  900. package/lib/util/bytes.d.ts.map +0 -1
  901. package/lib/util/chunkify.d.ts.map +0 -1
  902. package/lib/util/clock.d.ts.map +0 -1
  903. package/lib/util/dataColumns.d.ts.map +0 -1
  904. package/lib/util/dependentRoot.d.ts.map +0 -1
  905. package/lib/util/enum.d.ts.map +0 -1
  906. package/lib/util/error.d.ts.map +0 -1
  907. package/lib/util/eventLoop.d.ts.map +0 -1
  908. package/lib/util/execution.d.ts +0 -20
  909. package/lib/util/execution.d.ts.map +0 -1
  910. package/lib/util/execution.js +0 -165
  911. package/lib/util/execution.js.map +0 -1
  912. package/lib/util/file.d.ts.map +0 -1
  913. package/lib/util/forkChoice.d.ts.map +0 -1
  914. package/lib/util/forkName.d.ts.map +0 -1
  915. package/lib/util/graffiti.d.ts.map +0 -1
  916. package/lib/util/hex.d.ts.map +0 -1
  917. package/lib/util/index.d.ts.map +0 -1
  918. package/lib/util/ip.d.ts.map +0 -1
  919. package/lib/util/itTrigger.d.ts.map +0 -1
  920. package/lib/util/kzg.d.ts.map +0 -1
  921. package/lib/util/map.d.ts.map +0 -1
  922. package/lib/util/metadata.d.ts.map +0 -1
  923. package/lib/util/multifork.d.ts.map +0 -1
  924. package/lib/util/numpy.d.ts.map +0 -1
  925. package/lib/util/peerId.d.ts.map +0 -1
  926. package/lib/util/profile.d.ts.map +0 -1
  927. package/lib/util/promises.d.ts.map +0 -1
  928. package/lib/util/queue/errors.d.ts.map +0 -1
  929. package/lib/util/queue/fnQueue.d.ts.map +0 -1
  930. package/lib/util/queue/index.d.ts.map +0 -1
  931. package/lib/util/queue/itemQueue.d.ts.map +0 -1
  932. package/lib/util/queue/options.d.ts.map +0 -1
  933. package/lib/util/serializedCache.d.ts.map +0 -1
  934. package/lib/util/set.d.ts.map +0 -1
  935. package/lib/util/shuffle.d.ts.map +0 -1
  936. package/lib/util/sortBy.d.ts.map +0 -1
  937. package/lib/util/sszBytes.d.ts.map +0 -1
  938. package/lib/util/strictEvents.d.ts.map +0 -1
  939. package/lib/util/time.d.ts.map +0 -1
  940. package/lib/util/timeSeries.d.ts.map +0 -1
  941. package/lib/util/types.d.ts.map +0 -1
  942. package/lib/util/workerEvents.d.ts.map +0 -1
  943. package/lib/util/wrapError.d.ts.map +0 -1
  944. package/src/api/impl/api.ts +0 -26
  945. package/src/api/impl/beacon/blocks/index.ts +0 -744
  946. package/src/api/impl/beacon/blocks/utils.ts +0 -75
  947. package/src/api/impl/beacon/index.ts +0 -35
  948. package/src/api/impl/beacon/pool/index.ts +0 -314
  949. package/src/api/impl/beacon/rewards/index.ts +0 -30
  950. package/src/api/impl/beacon/state/index.ts +0 -406
  951. package/src/api/impl/beacon/state/utils.ts +0 -189
  952. package/src/api/impl/config/constants.ts +0 -127
  953. package/src/api/impl/config/index.ts +0 -59
  954. package/src/api/impl/debug/index.ts +0 -131
  955. package/src/api/impl/errors.ts +0 -50
  956. package/src/api/impl/events/index.ts +0 -33
  957. package/src/api/impl/index.ts +0 -6
  958. package/src/api/impl/lightclient/index.ts +0 -64
  959. package/src/api/impl/lodestar/index.ts +0 -257
  960. package/src/api/impl/node/index.ts +0 -88
  961. package/src/api/impl/node/utils.ts +0 -51
  962. package/src/api/impl/proof/index.ts +0 -60
  963. package/src/api/impl/types.ts +0 -17
  964. package/src/api/impl/utils.ts +0 -25
  965. package/src/api/impl/validator/index.ts +0 -1540
  966. package/src/api/impl/validator/utils.ts +0 -85
  967. package/src/api/index.ts +0 -2
  968. package/src/api/options.ts +0 -16
  969. package/src/api/rest/activeSockets.ts +0 -109
  970. package/src/api/rest/base.ts +0 -216
  971. package/src/api/rest/index.ts +0 -63
  972. package/src/api/rest/swaggerUI.ts +0 -80
  973. package/src/bun-wrappers/prometheus-gc-stats.ts +0 -7
  974. package/src/chain/ColumnReconstructionTracker.ts +0 -90
  975. package/src/chain/GetBlobsTracker.ts +0 -115
  976. package/src/chain/archiveStore/archiveStore.ts +0 -222
  977. package/src/chain/archiveStore/constants.ts +0 -5
  978. package/src/chain/archiveStore/historicalState/getHistoricalState.ts +0 -116
  979. package/src/chain/archiveStore/historicalState/historicalStateRegen.ts +0 -68
  980. package/src/chain/archiveStore/historicalState/metrics.ts +0 -214
  981. package/src/chain/archiveStore/historicalState/types.ts +0 -41
  982. package/src/chain/archiveStore/historicalState/worker.ts +0 -77
  983. package/src/chain/archiveStore/index.ts +0 -3
  984. package/src/chain/archiveStore/interface.ts +0 -75
  985. package/src/chain/archiveStore/strategies/frequencyStateArchiveStrategy.ts +0 -138
  986. package/src/chain/archiveStore/utils/archiveBlocks.ts +0 -437
  987. package/src/chain/archiveStore/utils/pruneHistory.ts +0 -56
  988. package/src/chain/archiveStore/utils/updateBackfillRange.ts +0 -50
  989. package/src/chain/balancesCache.ts +0 -52
  990. package/src/chain/beaconProposerCache.ts +0 -43
  991. package/src/chain/blocks/blockInput/blockInput.ts +0 -852
  992. package/src/chain/blocks/blockInput/errors.ts +0 -48
  993. package/src/chain/blocks/blockInput/index.ts +0 -4
  994. package/src/chain/blocks/blockInput/types.ts +0 -145
  995. package/src/chain/blocks/blockInput/utils.ts +0 -21
  996. package/src/chain/blocks/importBlock.ts +0 -597
  997. package/src/chain/blocks/index.ts +0 -179
  998. package/src/chain/blocks/types.ts +0 -101
  999. package/src/chain/blocks/utils/blowfishBanner.ts +0 -28
  1000. package/src/chain/blocks/utils/chainSegment.ts +0 -29
  1001. package/src/chain/blocks/utils/checkpoint.ts +0 -25
  1002. package/src/chain/blocks/utils/giraffeBanner.ts +0 -30
  1003. package/src/chain/blocks/utils/ownBanner.ts +0 -20
  1004. package/src/chain/blocks/utils/pandaMergeTransitionBanner.ts +0 -43
  1005. package/src/chain/blocks/utils/zebraBanner.ts +0 -45
  1006. package/src/chain/blocks/verifyBlock.ts +0 -242
  1007. package/src/chain/blocks/verifyBlocksDataAvailability.ts +0 -42
  1008. package/src/chain/blocks/verifyBlocksExecutionPayloads.ts +0 -438
  1009. package/src/chain/blocks/verifyBlocksSanityChecks.ts +0 -129
  1010. package/src/chain/blocks/verifyBlocksSignatures.ts +0 -105
  1011. package/src/chain/blocks/verifyBlocksStateTransitionOnly.ts +0 -114
  1012. package/src/chain/blocks/writeBlockInputToDb.ts +0 -120
  1013. package/src/chain/bls/index.ts +0 -4
  1014. package/src/chain/bls/interface.ts +0 -68
  1015. package/src/chain/bls/maybeBatch.ts +0 -45
  1016. package/src/chain/bls/multithread/index.ts +0 -582
  1017. package/src/chain/bls/multithread/jobItem.ts +0 -119
  1018. package/src/chain/bls/multithread/poolSize.ts +0 -16
  1019. package/src/chain/bls/multithread/types.ts +0 -38
  1020. package/src/chain/bls/multithread/utils.ts +0 -19
  1021. package/src/chain/bls/multithread/worker.ts +0 -114
  1022. package/src/chain/bls/singleThread.ts +0 -87
  1023. package/src/chain/bls/utils.ts +0 -30
  1024. package/src/chain/chain.ts +0 -1354
  1025. package/src/chain/emitter.ts +0 -113
  1026. package/src/chain/errors/attestationError.ts +0 -194
  1027. package/src/chain/errors/attesterSlashingError.ts +0 -11
  1028. package/src/chain/errors/blobSidecarError.ts +0 -60
  1029. package/src/chain/errors/blockError.ts +0 -166
  1030. package/src/chain/errors/blsToExecutionChangeError.ts +0 -13
  1031. package/src/chain/errors/dataColumnSidecarError.ts +0 -80
  1032. package/src/chain/errors/gossipValidation.ts +0 -20
  1033. package/src/chain/errors/index.ts +0 -10
  1034. package/src/chain/errors/lightClientError.ts +0 -30
  1035. package/src/chain/errors/proposerSlashingError.ts +0 -11
  1036. package/src/chain/errors/syncCommitteeError.ts +0 -36
  1037. package/src/chain/errors/voluntaryExitError.ts +0 -13
  1038. package/src/chain/forkChoice/index.ts +0 -112
  1039. package/src/chain/genesis/genesis.ts +0 -190
  1040. package/src/chain/genesis/interface.ts +0 -14
  1041. package/src/chain/index.ts +0 -6
  1042. package/src/chain/initState.ts +0 -221
  1043. package/src/chain/interface.ts +0 -280
  1044. package/src/chain/lightClient/index.ts +0 -764
  1045. package/src/chain/lightClient/proofs.ts +0 -85
  1046. package/src/chain/lightClient/types.ts +0 -33
  1047. package/src/chain/opPools/aggregatedAttestationPool.ts +0 -1063
  1048. package/src/chain/opPools/attestationPool.ts +0 -282
  1049. package/src/chain/opPools/index.ts +0 -5
  1050. package/src/chain/opPools/opPool.ts +0 -462
  1051. package/src/chain/opPools/syncCommitteeMessagePool.ts +0 -169
  1052. package/src/chain/opPools/syncContributionAndProofPool.ts +0 -240
  1053. package/src/chain/opPools/types.ts +0 -35
  1054. package/src/chain/opPools/utils.ts +0 -65
  1055. package/src/chain/options.ts +0 -138
  1056. package/src/chain/prepareNextSlot.ts +0 -277
  1057. package/src/chain/produceBlock/computeNewStateRoot.ts +0 -55
  1058. package/src/chain/produceBlock/index.ts +0 -2
  1059. package/src/chain/produceBlock/produceBlockBody.ts +0 -797
  1060. package/src/chain/produceBlock/validateBlobsAndKzgCommitments.ts +0 -54
  1061. package/src/chain/regen/errors.ts +0 -30
  1062. package/src/chain/regen/index.ts +0 -4
  1063. package/src/chain/regen/interface.ts +0 -93
  1064. package/src/chain/regen/queued.ts +0 -317
  1065. package/src/chain/regen/regen.ts +0 -424
  1066. package/src/chain/reprocess.ts +0 -161
  1067. package/src/chain/rewards/attestationsRewards.ts +0 -196
  1068. package/src/chain/rewards/blockRewards.ts +0 -150
  1069. package/src/chain/rewards/syncCommitteeRewards.ts +0 -58
  1070. package/src/chain/seenCache/index.ts +0 -5
  1071. package/src/chain/seenCache/seenAggregateAndProof.ts +0 -120
  1072. package/src/chain/seenCache/seenAttestationData.ts +0 -145
  1073. package/src/chain/seenCache/seenAttesters.ts +0 -58
  1074. package/src/chain/seenCache/seenBlockAttesters.ts +0 -18
  1075. package/src/chain/seenCache/seenBlockProposers.ts +0 -48
  1076. package/src/chain/seenCache/seenCommittee.ts +0 -43
  1077. package/src/chain/seenCache/seenCommitteeContribution.ts +0 -104
  1078. package/src/chain/seenCache/seenGossipBlockInput.ts +0 -373
  1079. package/src/chain/serializeState.ts +0 -32
  1080. package/src/chain/shufflingCache.ts +0 -238
  1081. package/src/chain/stateCache/blockStateCacheImpl.ts +0 -150
  1082. package/src/chain/stateCache/datastore/db.ts +0 -36
  1083. package/src/chain/stateCache/datastore/file.ts +0 -53
  1084. package/src/chain/stateCache/datastore/index.ts +0 -2
  1085. package/src/chain/stateCache/datastore/types.ts +0 -13
  1086. package/src/chain/stateCache/fifoBlockStateCache.ts +0 -208
  1087. package/src/chain/stateCache/inMemoryCheckpointsCache.ts +0 -198
  1088. package/src/chain/stateCache/index.ts +0 -3
  1089. package/src/chain/stateCache/mapMetrics.ts +0 -52
  1090. package/src/chain/stateCache/persistentCheckpointsCache.ts +0 -837
  1091. package/src/chain/stateCache/types.ts +0 -86
  1092. package/src/chain/validation/aggregateAndProof.ts +0 -258
  1093. package/src/chain/validation/attestation.ts +0 -885
  1094. package/src/chain/validation/attesterSlashing.ts +0 -61
  1095. package/src/chain/validation/blobSidecar.ts +0 -301
  1096. package/src/chain/validation/block.ts +0 -188
  1097. package/src/chain/validation/blsToExecutionChange.ts +0 -61
  1098. package/src/chain/validation/dataColumnSidecar.ts +0 -381
  1099. package/src/chain/validation/index.ts +0 -9
  1100. package/src/chain/validation/lightClientFinalityUpdate.ts +0 -46
  1101. package/src/chain/validation/lightClientOptimisticUpdate.ts +0 -68
  1102. package/src/chain/validation/proposerSlashing.ts +0 -54
  1103. package/src/chain/validation/signatureSets/aggregateAndProof.ts +0 -38
  1104. package/src/chain/validation/signatureSets/contributionAndProof.ts +0 -27
  1105. package/src/chain/validation/signatureSets/index.ts +0 -6
  1106. package/src/chain/validation/signatureSets/selectionProof.ts +0 -27
  1107. package/src/chain/validation/signatureSets/syncCommittee.ts +0 -22
  1108. package/src/chain/validation/signatureSets/syncCommitteeContribution.ts +0 -18
  1109. package/src/chain/validation/signatureSets/syncCommitteeSelectionProof.ts +0 -27
  1110. package/src/chain/validation/syncCommittee.ts +0 -165
  1111. package/src/chain/validation/syncCommitteeContributionAndProof.ts +0 -122
  1112. package/src/chain/validation/voluntaryExit.ts +0 -58
  1113. package/src/chain/validatorMonitor.ts +0 -1309
  1114. package/src/constants/constants.ts +0 -15
  1115. package/src/constants/index.ts +0 -2
  1116. package/src/constants/network.ts +0 -52
  1117. package/src/db/beacon.ts +0 -113
  1118. package/src/db/buckets.ts +0 -80
  1119. package/src/db/index.ts +0 -2
  1120. package/src/db/interface.ts +0 -76
  1121. package/src/db/options.ts +0 -7
  1122. package/src/db/repositories/attesterSlashing.ts +0 -38
  1123. package/src/db/repositories/backfilledRanges.ts +0 -29
  1124. package/src/db/repositories/blobSidecars.ts +0 -37
  1125. package/src/db/repositories/blobSidecarsArchive.ts +0 -28
  1126. package/src/db/repositories/block.ts +0 -33
  1127. package/src/db/repositories/blockArchive.ts +0 -170
  1128. package/src/db/repositories/blockArchiveIndex.ts +0 -45
  1129. package/src/db/repositories/blsToExecutionChange.ts +0 -16
  1130. package/src/db/repositories/checkpointState.ts +0 -31
  1131. package/src/db/repositories/dataColumnSidecar.ts +0 -49
  1132. package/src/db/repositories/dataColumnSidecarArchive.ts +0 -56
  1133. package/src/db/repositories/depositDataRoot.ts +0 -80
  1134. package/src/db/repositories/depositEvent.ts +0 -32
  1135. package/src/db/repositories/eth1Data.ts +0 -33
  1136. package/src/db/repositories/index.ts +0 -20
  1137. package/src/db/repositories/lightclientBestUpdate.ts +0 -41
  1138. package/src/db/repositories/lightclientCheckpointHeader.ts +0 -32
  1139. package/src/db/repositories/lightclientSyncCommittee.ts +0 -16
  1140. package/src/db/repositories/lightclientSyncCommitteeWitness.ts +0 -77
  1141. package/src/db/repositories/proposerSlashing.ts +0 -15
  1142. package/src/db/repositories/stateArchive.ts +0 -69
  1143. package/src/db/repositories/stateArchiveIndex.ts +0 -18
  1144. package/src/db/repositories/voluntaryExit.ts +0 -15
  1145. package/src/db/single/index.ts +0 -2
  1146. package/src/db/single/preGenesisState.ts +0 -37
  1147. package/src/db/single/preGenesisStateLastProcessedBlock.ts +0 -34
  1148. package/src/eth1/errors.ts +0 -40
  1149. package/src/eth1/eth1DataCache.ts +0 -26
  1150. package/src/eth1/eth1DepositDataTracker.ts +0 -410
  1151. package/src/eth1/eth1DepositsCache.ts +0 -141
  1152. package/src/eth1/eth1MergeBlockTracker.ts +0 -328
  1153. package/src/eth1/index.ts +0 -157
  1154. package/src/eth1/interface.ts +0 -131
  1155. package/src/eth1/options.ts +0 -28
  1156. package/src/eth1/provider/eth1Provider.ts +0 -229
  1157. package/src/eth1/provider/jsonRpcHttpClient.ts +0 -390
  1158. package/src/eth1/provider/jwt.ts +0 -36
  1159. package/src/eth1/provider/utils.ts +0 -136
  1160. package/src/eth1/stream.ts +0 -75
  1161. package/src/eth1/utils/depositContract.ts +0 -37
  1162. package/src/eth1/utils/deposits.ts +0 -70
  1163. package/src/eth1/utils/eth1Data.ts +0 -100
  1164. package/src/eth1/utils/eth1DepositEvent.ts +0 -12
  1165. package/src/eth1/utils/eth1Vote.ts +0 -142
  1166. package/src/eth1/utils/groupDepositEventsByBlock.ts +0 -19
  1167. package/src/eth1/utils/optimizeNextBlockDiffForGenesis.ts +0 -18
  1168. package/src/execution/builder/cache.ts +0 -39
  1169. package/src/execution/builder/http.ts +0 -229
  1170. package/src/execution/builder/index.ts +0 -27
  1171. package/src/execution/builder/interface.ts +0 -49
  1172. package/src/execution/builder/utils.ts +0 -19
  1173. package/src/execution/engine/disabled.ts +0 -35
  1174. package/src/execution/engine/http.ts +0 -644
  1175. package/src/execution/engine/index.ts +0 -63
  1176. package/src/execution/engine/interface.ts +0 -199
  1177. package/src/execution/engine/mock.ts +0 -493
  1178. package/src/execution/engine/payloadIdCache.ts +0 -54
  1179. package/src/execution/engine/types.ts +0 -640
  1180. package/src/execution/engine/utils.ts +0 -136
  1181. package/src/execution/index.ts +0 -4
  1182. package/src/index.ts +0 -20
  1183. package/src/metrics/index.ts +0 -4
  1184. package/src/metrics/metrics/beacon.ts +0 -390
  1185. package/src/metrics/metrics/lodestar.ts +0 -1870
  1186. package/src/metrics/metrics.ts +0 -43
  1187. package/src/metrics/nodeJsMetrics.ts +0 -19
  1188. package/src/metrics/options.ts +0 -22
  1189. package/src/metrics/server/http.ts +0 -114
  1190. package/src/metrics/server/index.ts +0 -1
  1191. package/src/metrics/utils/avgMinMax.ts +0 -87
  1192. package/src/metrics/utils/gauge.ts +0 -22
  1193. package/src/metrics/utils/registryMetricCreator.ts +0 -41
  1194. package/src/monitoring/clientStats.ts +0 -297
  1195. package/src/monitoring/index.ts +0 -2
  1196. package/src/monitoring/options.ts +0 -19
  1197. package/src/monitoring/properties.ts +0 -152
  1198. package/src/monitoring/service.ts +0 -235
  1199. package/src/monitoring/system.ts +0 -146
  1200. package/src/monitoring/types.ts +0 -21
  1201. package/src/network/core/events.ts +0 -59
  1202. package/src/network/core/index.ts +0 -3
  1203. package/src/network/core/metrics.ts +0 -304
  1204. package/src/network/core/networkCore.ts +0 -599
  1205. package/src/network/core/networkCoreWorker.ts +0 -176
  1206. package/src/network/core/networkCoreWorkerHandler.ts +0 -284
  1207. package/src/network/core/types.ts +0 -119
  1208. package/src/network/discv5/index.ts +0 -132
  1209. package/src/network/discv5/types.ts +0 -74
  1210. package/src/network/discv5/utils.ts +0 -50
  1211. package/src/network/discv5/worker.ts +0 -137
  1212. package/src/network/events.ts +0 -51
  1213. package/src/network/forks.ts +0 -94
  1214. package/src/network/gossip/constants.ts +0 -15
  1215. package/src/network/gossip/encoding.ts +0 -111
  1216. package/src/network/gossip/errors.ts +0 -7
  1217. package/src/network/gossip/gossipsub.ts +0 -384
  1218. package/src/network/gossip/index.ts +0 -4
  1219. package/src/network/gossip/interface.ts +0 -215
  1220. package/src/network/gossip/metrics.ts +0 -71
  1221. package/src/network/gossip/scoringParameters.ts +0 -333
  1222. package/src/network/gossip/topic.ts +0 -332
  1223. package/src/network/index.ts +0 -8
  1224. package/src/network/interface.ts +0 -134
  1225. package/src/network/libp2p/error.ts +0 -55
  1226. package/src/network/libp2p/index.ts +0 -153
  1227. package/src/network/metadata.ts +0 -162
  1228. package/src/network/network.ts +0 -767
  1229. package/src/network/networkConfig.ts +0 -12
  1230. package/src/network/options.ts +0 -70
  1231. package/src/network/peers/client.ts +0 -29
  1232. package/src/network/peers/datastore.ts +0 -188
  1233. package/src/network/peers/discover.ts +0 -647
  1234. package/src/network/peers/index.ts +0 -2
  1235. package/src/network/peers/peerManager.ts +0 -899
  1236. package/src/network/peers/peersData.ts +0 -65
  1237. package/src/network/peers/score/constants.ts +0 -34
  1238. package/src/network/peers/score/index.ts +0 -4
  1239. package/src/network/peers/score/interface.ts +0 -74
  1240. package/src/network/peers/score/score.ts +0 -200
  1241. package/src/network/peers/score/store.ts +0 -95
  1242. package/src/network/peers/score/utils.ts +0 -37
  1243. package/src/network/peers/utils/assertPeerRelevance.ts +0 -99
  1244. package/src/network/peers/utils/enrSubnetsDeserialize.ts +0 -27
  1245. package/src/network/peers/utils/getConnectedPeerIds.ts +0 -33
  1246. package/src/network/peers/utils/index.ts +0 -4
  1247. package/src/network/peers/utils/prioritizePeers.ts +0 -627
  1248. package/src/network/peers/utils/subnetMap.ts +0 -88
  1249. package/src/network/processor/aggregatorTracker.ts +0 -38
  1250. package/src/network/processor/extractSlotRootFns.ts +0 -64
  1251. package/src/network/processor/gossipHandlers.ts +0 -951
  1252. package/src/network/processor/gossipQueues/index.ts +0 -114
  1253. package/src/network/processor/gossipQueues/indexed.ts +0 -219
  1254. package/src/network/processor/gossipQueues/linear.ts +0 -162
  1255. package/src/network/processor/gossipQueues/types.ts +0 -57
  1256. package/src/network/processor/gossipValidatorFn.ts +0 -142
  1257. package/src/network/processor/index.ts +0 -496
  1258. package/src/network/processor/types.ts +0 -27
  1259. package/src/network/reqresp/ReqRespBeaconNode.ts +0 -373
  1260. package/src/network/reqresp/handlers/beaconBlocksByRange.ts +0 -101
  1261. package/src/network/reqresp/handlers/beaconBlocksByRoot.ts +0 -49
  1262. package/src/network/reqresp/handlers/blobSidecarsByRange.ts +0 -114
  1263. package/src/network/reqresp/handlers/blobSidecarsByRoot.ts +0 -62
  1264. package/src/network/reqresp/handlers/dataColumnSidecarsByRange.ts +0 -144
  1265. package/src/network/reqresp/handlers/dataColumnSidecarsByRoot.ts +0 -88
  1266. package/src/network/reqresp/handlers/index.ts +0 -78
  1267. package/src/network/reqresp/handlers/lightClientBootstrap.ts +0 -31
  1268. package/src/network/reqresp/handlers/lightClientFinalityUpdate.ts +0 -21
  1269. package/src/network/reqresp/handlers/lightClientOptimisticUpdate.ts +0 -21
  1270. package/src/network/reqresp/handlers/lightClientUpdatesByRange.ts +0 -39
  1271. package/src/network/reqresp/index.ts +0 -2
  1272. package/src/network/reqresp/interface.ts +0 -45
  1273. package/src/network/reqresp/protocols.ts +0 -146
  1274. package/src/network/reqresp/rateLimit.ts +0 -112
  1275. package/src/network/reqresp/score.ts +0 -70
  1276. package/src/network/reqresp/types.ts +0 -174
  1277. package/src/network/reqresp/utils/collect.ts +0 -84
  1278. package/src/network/reqresp/utils/collectSequentialBlocksInRange.ts +0 -57
  1279. package/src/network/reqresp/utils/dataColumnResponseValidation.ts +0 -99
  1280. package/src/network/statusCache.ts +0 -17
  1281. package/src/network/subnets/attnetsService.ts +0 -385
  1282. package/src/network/subnets/index.ts +0 -2
  1283. package/src/network/subnets/interface.ts +0 -66
  1284. package/src/network/subnets/syncnetsService.ts +0 -147
  1285. package/src/network/subnets/util.ts +0 -63
  1286. package/src/network/util.ts +0 -29
  1287. package/src/node/index.ts +0 -2
  1288. package/src/node/nodejs.ts +0 -349
  1289. package/src/node/notifier.ts +0 -206
  1290. package/src/node/options.ts +0 -51
  1291. package/src/node/utils/interop/deposits.ts +0 -53
  1292. package/src/node/utils/interop/state.ts +0 -59
  1293. package/src/node/utils/lightclient.ts +0 -7
  1294. package/src/node/utils/state.ts +0 -37
  1295. package/src/sync/backfill/backfill.ts +0 -893
  1296. package/src/sync/backfill/errors.ts +0 -23
  1297. package/src/sync/backfill/index.ts +0 -1
  1298. package/src/sync/backfill/verify.ts +0 -58
  1299. package/src/sync/constants.ts +0 -71
  1300. package/src/sync/index.ts +0 -2
  1301. package/src/sync/interface.ts +0 -55
  1302. package/src/sync/options.ts +0 -45
  1303. package/src/sync/range/batch.ts +0 -455
  1304. package/src/sync/range/chain.ts +0 -715
  1305. package/src/sync/range/range.ts +0 -354
  1306. package/src/sync/range/utils/batches.ts +0 -119
  1307. package/src/sync/range/utils/chainTarget.ts +0 -62
  1308. package/src/sync/range/utils/hashBlocks.ts +0 -27
  1309. package/src/sync/range/utils/index.ts +0 -5
  1310. package/src/sync/range/utils/peerBalancer.ts +0 -184
  1311. package/src/sync/range/utils/updateChains.ts +0 -66
  1312. package/src/sync/sync.ts +0 -290
  1313. package/src/sync/types.ts +0 -57
  1314. package/src/sync/unknownBlock.ts +0 -859
  1315. package/src/sync/utils/downloadByRange.ts +0 -808
  1316. package/src/sync/utils/downloadByRoot.ts +0 -560
  1317. package/src/sync/utils/pendingBlocksTree.ts +0 -97
  1318. package/src/sync/utils/remoteSyncType.ts +0 -144
  1319. package/src/util/address.ts +0 -3
  1320. package/src/util/array.ts +0 -311
  1321. package/src/util/asyncIterableToEvents.ts +0 -164
  1322. package/src/util/binarySearch.ts +0 -48
  1323. package/src/util/bitArray.ts +0 -84
  1324. package/src/util/blobs.ts +0 -210
  1325. package/src/util/bufferPool.ts +0 -95
  1326. package/src/util/bytes.ts +0 -11
  1327. package/src/util/chunkify.ts +0 -27
  1328. package/src/util/clock.ts +0 -212
  1329. package/src/util/dataColumns.ts +0 -415
  1330. package/src/util/dependentRoot.ts +0 -47
  1331. package/src/util/enum.ts +0 -17
  1332. package/src/util/error.ts +0 -56
  1333. package/src/util/eventLoop.ts +0 -22
  1334. package/src/util/execution.ts +0 -223
  1335. package/src/util/file.ts +0 -52
  1336. package/src/util/forkChoice.ts +0 -5
  1337. package/src/util/forkName.ts +0 -20
  1338. package/src/util/graffiti.ts +0 -39
  1339. package/src/util/hex.ts +0 -9
  1340. package/src/util/index.ts +0 -2
  1341. package/src/util/ip.ts +0 -6
  1342. package/src/util/itTrigger.ts +0 -49
  1343. package/src/util/kzg.ts +0 -3
  1344. package/src/util/map.ts +0 -77
  1345. package/src/util/metadata.ts +0 -22
  1346. package/src/util/multifork.ts +0 -69
  1347. package/src/util/numpy.ts +0 -8
  1348. package/src/util/peerId.ts +0 -16
  1349. package/src/util/profile.ts +0 -54
  1350. package/src/util/promises.ts +0 -14
  1351. package/src/util/queue/errors.ts +0 -14
  1352. package/src/util/queue/fnQueue.ts +0 -16
  1353. package/src/util/queue/index.ts +0 -4
  1354. package/src/util/queue/itemQueue.ts +0 -128
  1355. package/src/util/queue/options.ts +0 -37
  1356. package/src/util/serializedCache.ts +0 -20
  1357. package/src/util/set.ts +0 -62
  1358. package/src/util/shuffle.ts +0 -21
  1359. package/src/util/sortBy.ts +0 -19
  1360. package/src/util/sszBytes.ts +0 -481
  1361. package/src/util/strictEvents.ts +0 -8
  1362. package/src/util/time.ts +0 -13
  1363. package/src/util/timeSeries.ts +0 -118
  1364. package/src/util/types.ts +0 -31
  1365. package/src/util/workerEvents.ts +0 -142
  1366. package/src/util/wrapError.ts +0 -27
@@ -7,15 +7,13 @@ export function hashBlocks(blocks, config) {
7
7
  case 0:
8
8
  return "0x";
9
9
  case 1: {
10
- const block0 = blocks[0].getBlock();
10
+ const block0 = blocks[0].block;
11
11
  return toRootHex(config.getForkTypes(block0.message.slot).SignedBeaconBlock.hashTreeRoot(block0));
12
12
  }
13
13
  default: {
14
- const block0 = blocks[0].getBlock();
15
- const blockN = blocks.at(-1)?.getBlock();
16
- return (
17
- // TODO(fulu): should we be doing checks for presence to make sure these do not blow up?
18
- toRootHex(config.getForkTypes(block0.message.slot).SignedBeaconBlock.hashTreeRoot(block0)) +
14
+ const block0 = blocks[0].block;
15
+ const blockN = blocks.at(-1)?.block;
16
+ return (toRootHex(config.getForkTypes(block0.message.slot).SignedBeaconBlock.hashTreeRoot(block0)) +
19
17
  toRootHex(config.getForkTypes(blockN.message.slot).SignedBeaconBlock.hashTreeRoot(blockN)));
20
18
  }
21
19
  }
@@ -1 +1 @@
1
- {"version":3,"file":"hashBlocks.js","sourceRoot":"","sources":["../../../../src/sync/range/utils/hashBlocks.ts"],"names":[],"mappings":"AAEA,OAAO,EAAC,SAAS,EAAC,MAAM,iBAAiB,CAAC;AAG1C;;GAEG;AACH,MAAM,UAAU,UAAU,CAAC,MAAqB,EAAE,MAAuB;IACvE,QAAQ,MAAM,CAAC,MAAM,EAAE,CAAC;QACtB,KAAK,CAAC;YACJ,OAAO,IAAI,CAAC;QACd,KAAK,CAAC,CAAC,CAAC,CAAC;YACP,MAAM,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;YACpC,OAAO,SAAS,CAAC,MAAM,CAAC,YAAY,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,iBAAiB,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC;QACpG,CAAC;QACD,OAAO,CAAC,CAAC,CAAC;YACR,MAAM,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;YACpC,MAAM,MAAM,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAuB,CAAC;YAC9D,OAAO;YACL,wFAAwF;YACxF,SAAS,CAAC,MAAM,CAAC,YAAY,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,iBAAiB,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;gBAC1F,SAAS,CAAC,MAAM,CAAC,YAAY,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,iBAAiB,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAC3F,CAAC;QACJ,CAAC;IACH,CAAC;AACH,CAAC"}
1
+ {"version":3,"file":"hashBlocks.js","sourceRoot":"","sources":["../../../../src/sync/range/utils/hashBlocks.ts"],"names":[],"mappings":"AAEA,OAAO,EAAC,SAAS,EAAC,MAAM,iBAAiB,CAAC;AAG1C;;GAEG;AACH,MAAM,UAAU,UAAU,CAAC,MAAoB,EAAE,MAAuB;IACtE,QAAQ,MAAM,CAAC,MAAM,EAAE,CAAC;QACtB,KAAK,CAAC;YACJ,OAAO,IAAI,CAAC;QACd,KAAK,CAAC,CAAC,CAAC,CAAC;YACP,MAAM,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;YAC/B,OAAO,SAAS,CAAC,MAAM,CAAC,YAAY,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,iBAAiB,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC;QACpG,CAAC;QACD,OAAO,CAAC,CAAC,CAAC;YACR,MAAM,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;YAC/B,MAAM,MAAM,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,KAA4B,CAAC;YAC3D,OAAO,CACL,SAAS,CAAC,MAAM,CAAC,YAAY,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,iBAAiB,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;gBAC1F,SAAS,CAAC,MAAM,CAAC,YAAY,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,iBAAiB,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAC3F,CAAC;QACJ,CAAC;IACH,CAAC;AACH,CAAC"}
@@ -1,4 +1,3 @@
1
- import { isForkPostFulu } from "@lodestar/params";
2
1
  import { shuffle } from "../../../util/shuffle.js";
3
2
  import { sortBy } from "../../../util/sortBy.js";
4
3
  import { MAX_CONCURRENT_REQUESTS } from "../../constants.js";
@@ -9,16 +8,12 @@ import { BatchStatus } from "../batch.js";
9
8
  * Shuffles peers only once on instantiation
10
9
  */
11
10
  export class ChainPeersBalancer {
12
- peers;
13
- activeRequestsByPeer = new Map();
14
- custodyConfig;
15
- syncType;
16
- maxConcurrentRequests;
17
11
  /**
18
12
  * No need to specify `maxConcurrentRequests` for production code
19
13
  * It is used for testing purposes to limit the number of concurrent requests
20
14
  */
21
15
  constructor(peers, batches, custodyConfig, syncType, maxConcurrentRequests = MAX_CONCURRENT_REQUESTS) {
16
+ this.activeRequestsByPeer = new Map();
22
17
  this.peers = shuffle(peers);
23
18
  this.custodyConfig = custodyConfig;
24
19
  this.syncType = syncType;
@@ -38,9 +33,8 @@ export class ChainPeersBalancer {
38
33
  if (batch.state.status !== BatchStatus.AwaitingDownload) {
39
34
  return;
40
35
  }
41
- const { columnsRequest } = batch.requests;
42
- // TODO(fulu): This is fulu specific and hinders our peer selection PreFulu
43
- const pendingDataColumns = columnsRequest?.columns ?? this.custodyConfig.sampledColumns;
36
+ const { partialDownload } = batch.state;
37
+ const pendingDataColumns = partialDownload?.pendingDataColumns ?? this.custodyConfig.sampledColumns;
44
38
  const eligiblePeers = this.filterPeers(batch, pendingDataColumns, false);
45
39
  const failedPeers = new Set(batch.getFailedPeers());
46
40
  const sortedBestPeers = sortBy(eligiblePeers, ({ syncInfo }) => (failedPeers.has(syncInfo.peerId) ? 1 : 0), // prefer peers without failed requests
@@ -82,7 +76,7 @@ export class ChainPeersBalancer {
82
76
  return eligiblePeers;
83
77
  }
84
78
  for (const peer of this.peers) {
85
- const { earliestAvailableSlot, target, peerId } = peer;
79
+ const { earliestAvailableSlot, custodyGroups, target, peerId } = peer;
86
80
  const activeRequest = this.activeRequestsByPeer.get(peerId) ?? 0;
87
81
  if (noActiveRequest && activeRequest > 0) {
88
82
  // consumer wants to find peer with no active request, but this peer has active request
@@ -92,21 +86,21 @@ export class ChainPeersBalancer {
92
86
  // consumer wants to find peer with no more than MAX_CONCURRENT_REQUESTS active requests
93
87
  continue;
94
88
  }
95
- if (target.slot < batch.startSlot) {
89
+ if (target.slot < batch.request.startSlot) {
96
90
  continue;
97
91
  }
98
- if (isForkPostFulu(batch.forkName) && this.syncType === RangeSyncType.Head) {
92
+ if (batch.isPostFulu() && this.syncType === RangeSyncType.Head) {
99
93
  // for head sync, target slot is head slot and each peer may have a different head slot
100
94
  // we don't want to retry a batch with a peer that's not as up-to-date as the previous peer
101
95
  // see https://github.com/ChainSafe/lodestar/issues/8193
102
- const blocks = batch.state?.blocks;
103
- const lastBlock = blocks?.at(-1);
104
- const lastBlockSlot = lastBlock?.slot;
96
+ const blocks = batch.state.partialDownload?.blocks;
97
+ const lastBlock = blocks?.at(-1)?.block;
98
+ const lastBlockSlot = lastBlock?.message?.slot;
105
99
  if (lastBlockSlot && lastBlockSlot > target.slot) {
106
100
  continue;
107
101
  }
108
102
  }
109
- if (!isForkPostFulu(batch.forkName)) {
103
+ if (!batch.isPostFulu()) {
110
104
  // pre-fulu logic, we don't care columns and earliestAvailableSlot
111
105
  eligiblePeers.push({ syncInfo: peer, columns: 0, hasEarliestAvailableSlots: false });
112
106
  continue;
@@ -116,10 +110,11 @@ export class ChainPeersBalancer {
116
110
  if (earliestAvailableSlot == null) {
117
111
  continue;
118
112
  }
119
- if (earliestAvailableSlot > batch.startSlot) {
113
+ if (earliestAvailableSlot > batch.request.startSlot) {
120
114
  continue;
121
115
  }
122
- const columns = peer.custodyColumns.reduce((acc, elem) => {
116
+ const peerColumns = custodyGroups;
117
+ const columns = peerColumns.reduce((acc, elem) => {
123
118
  if (requestColumns.includes(elem)) {
124
119
  acc.push(elem);
125
120
  }
@@ -1 +1 @@
1
- {"version":3,"file":"peerBalancer.js","sourceRoot":"","sources":["../../../../src/sync/range/utils/peerBalancer.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"peerBalancer.js","sourceRoot":"","sources":["../../../../src/sync/range/utils/peerBalancer.ts"],"names":[],"mappings":"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"}
@@ -1,4 +1,5 @@
1
- import { IBeaconSync, SyncChainDebugState, SyncModules, SyncState, SyncingStatus } from "./interface.js";
1
+ import { IBeaconSync, SyncModules, SyncingStatus } from "./interface.js";
2
+ import { SyncChainDebugState, SyncState } from "./interface.js";
2
3
  import { SyncOptions } from "./options.js";
3
4
  export declare class BeaconSync implements IBeaconSync {
4
5
  private readonly logger;
package/lib/sync/sync.js CHANGED
@@ -7,20 +7,95 @@ import { isOptimisticBlock } from "../util/forkChoice.js";
7
7
  import { MIN_EPOCH_TO_START_GOSSIP } from "./constants.js";
8
8
  import { SyncState, syncStateMetric } from "./interface.js";
9
9
  import { RangeSync, RangeSyncEvent, RangeSyncStatus } from "./range/range.js";
10
- import { BlockInputSync } from "./unknownBlock.js";
10
+ import { UnknownBlockSync } from "./unknownBlock.js";
11
11
  import { PeerSyncType, getPeerSyncType, peerSyncTypes } from "./utils/remoteSyncType.js";
12
12
  export class BeaconSync {
13
- logger;
14
- network;
15
- chain;
16
- metrics;
17
- opts;
18
- rangeSync;
19
- unknownBlockSync;
20
- /** For metrics only */
21
- peerSyncType = new Map();
22
- slotImportTolerance;
23
13
  constructor(opts, modules) {
14
+ /** For metrics only */
15
+ this.peerSyncType = new Map();
16
+ /**
17
+ * A peer has connected which has blocks that are unknown to us.
18
+ *
19
+ * This function handles the logic associated with the connection of a new peer. If the peer
20
+ * is sufficiently ahead of our current head, a range-sync (batch) sync is started and
21
+ * batches of blocks are queued to download from the peer. Batched blocks begin at our latest
22
+ * finalized head.
23
+ *
24
+ * If the peer is within the `SLOT_IMPORT_TOLERANCE`, then it's head is sufficiently close to
25
+ * ours that we consider it fully sync'd with respect to our current chain.
26
+ */
27
+ this.addPeer = (data) => {
28
+ const localStatus = this.chain.getStatus();
29
+ const syncType = getPeerSyncType(localStatus, data.status, this.chain.forkChoice, this.slotImportTolerance);
30
+ // For metrics only
31
+ this.peerSyncType.set(data.peer, syncType);
32
+ if (syncType === PeerSyncType.Advanced) {
33
+ this.rangeSync.addPeer(data.peer, localStatus, data.status);
34
+ }
35
+ this.updateSyncState();
36
+ };
37
+ /**
38
+ * Must be called by libp2p when a peer is removed from the peer manager
39
+ */
40
+ this.removePeer = (data) => {
41
+ this.rangeSync.removePeer(data.peer);
42
+ this.peerSyncType.delete(data.peer.toString());
43
+ };
44
+ /**
45
+ * Run this function when the sync state can potentially change.
46
+ */
47
+ this.updateSyncState = () => {
48
+ const state = this.state; // Don't run the getter twice
49
+ // We have become synced, subscribe to all the gossip core topics
50
+ if (state === SyncState.Synced && this.chain.clock.currentEpoch >= MIN_EPOCH_TO_START_GOSSIP) {
51
+ if (!this.network.isSubscribedToGossipCoreTopics()) {
52
+ this.network
53
+ .subscribeGossipCoreTopics()
54
+ .then(() => {
55
+ this.metrics?.syncSwitchGossipSubscriptions.inc({ action: "subscribed" });
56
+ this.logger.info("Subscribed gossip core topics");
57
+ })
58
+ .catch((e) => {
59
+ this.logger.error("Error subscribing to gossip core topics", {}, e);
60
+ });
61
+ }
62
+ // also start searching for unknown blocks
63
+ if (!this.unknownBlockSync.isSubscribedToNetwork()) {
64
+ this.unknownBlockSync.subscribeToNetwork();
65
+ this.metrics?.syncUnknownBlock.switchNetworkSubscriptions.inc({ action: "subscribed" });
66
+ }
67
+ }
68
+ // If we stopped being synced and fallen significantly behind, stop gossip
69
+ else if (state !== SyncState.Synced) {
70
+ const syncDiff = this.chain.clock.currentSlot - this.chain.forkChoice.getHead().slot;
71
+ if (syncDiff > this.slotImportTolerance * 2) {
72
+ if (this.network.isSubscribedToGossipCoreTopics()) {
73
+ this.logger.warn(`Node sync has fallen behind by ${syncDiff} slots`);
74
+ this.network
75
+ .unsubscribeGossipCoreTopics()
76
+ .then(() => {
77
+ this.metrics?.syncSwitchGossipSubscriptions.inc({ action: "unsubscribed" });
78
+ this.logger.info("Un-subscribed gossip core topics");
79
+ })
80
+ .catch((e) => {
81
+ this.logger.error("Error unsubscribing to gossip core topics", {}, e);
82
+ });
83
+ }
84
+ // also stop searching for unknown blocks
85
+ if (this.unknownBlockSync.isSubscribedToNetwork()) {
86
+ this.unknownBlockSync.unsubscribeFromNetwork();
87
+ this.metrics?.syncUnknownBlock.switchNetworkSubscriptions.inc({ action: "unsubscribed" });
88
+ }
89
+ }
90
+ }
91
+ };
92
+ this.onClockEpoch = () => {
93
+ // If a node witness the genesis event consider starting gossip
94
+ // Also, ensure that updateSyncState is run at least once per epoch.
95
+ // If the chain gets stuck or very overloaded it could helps to resolve the situation
96
+ // by realizing it's way behind and turning gossip off.
97
+ this.updateSyncState();
98
+ };
24
99
  const { config, chain, metrics, network, logger } = modules;
25
100
  this.opts = opts;
26
101
  this.network = network;
@@ -28,7 +103,7 @@ export class BeaconSync {
28
103
  this.metrics = metrics;
29
104
  this.logger = logger;
30
105
  this.rangeSync = new RangeSync(modules, opts);
31
- this.unknownBlockSync = new BlockInputSync(config, network, chain, logger, metrics, opts);
106
+ this.unknownBlockSync = new UnknownBlockSync(config, network, chain, logger, metrics, opts);
32
107
  this.slotImportTolerance = opts.slotImportTolerance ?? SLOTS_PER_EPOCH;
33
108
  // Subscribe to RangeSync completing a SyncChain and recompute sync state
34
109
  if (!opts.disableRangeSync) {
@@ -150,89 +225,6 @@ export class BeaconSync {
150
225
  getSyncChainsDebugState() {
151
226
  return this.rangeSync.getSyncChainsDebugState();
152
227
  }
153
- /**
154
- * A peer has connected which has blocks that are unknown to us.
155
- *
156
- * This function handles the logic associated with the connection of a new peer. If the peer
157
- * is sufficiently ahead of our current head, a range-sync (batch) sync is started and
158
- * batches of blocks are queued to download from the peer. Batched blocks begin at our latest
159
- * finalized head.
160
- *
161
- * If the peer is within the `SLOT_IMPORT_TOLERANCE`, then it's head is sufficiently close to
162
- * ours that we consider it fully sync'd with respect to our current chain.
163
- */
164
- addPeer = (data) => {
165
- const localStatus = this.chain.getStatus();
166
- const syncType = getPeerSyncType(localStatus, data.status, this.chain.forkChoice, this.slotImportTolerance);
167
- // For metrics only
168
- this.peerSyncType.set(data.peer, syncType);
169
- if (syncType === PeerSyncType.Advanced) {
170
- this.rangeSync.addPeer(data.peer, localStatus, data.status);
171
- }
172
- this.updateSyncState();
173
- };
174
- /**
175
- * Must be called by libp2p when a peer is removed from the peer manager
176
- */
177
- removePeer = (data) => {
178
- this.rangeSync.removePeer(data.peer);
179
- this.peerSyncType.delete(data.peer.toString());
180
- };
181
- /**
182
- * Run this function when the sync state can potentially change.
183
- */
184
- updateSyncState = () => {
185
- const state = this.state; // Don't run the getter twice
186
- // We have become synced, subscribe to all the gossip core topics
187
- if (state === SyncState.Synced && this.chain.clock.currentEpoch >= MIN_EPOCH_TO_START_GOSSIP) {
188
- if (!this.network.isSubscribedToGossipCoreTopics()) {
189
- this.network
190
- .subscribeGossipCoreTopics()
191
- .then(() => {
192
- this.metrics?.syncSwitchGossipSubscriptions.inc({ action: "subscribed" });
193
- this.logger.info("Subscribed gossip core topics");
194
- })
195
- .catch((e) => {
196
- this.logger.error("Error subscribing to gossip core topics", {}, e);
197
- });
198
- }
199
- // also start searching for unknown blocks
200
- if (!this.unknownBlockSync.isSubscribedToNetwork()) {
201
- this.unknownBlockSync.subscribeToNetwork();
202
- this.metrics?.blockInputSync.switchNetworkSubscriptions.inc({ action: "subscribed" });
203
- }
204
- }
205
- // If we stopped being synced and fallen significantly behind, stop gossip
206
- else if (state !== SyncState.Synced) {
207
- const syncDiff = this.chain.clock.currentSlot - this.chain.forkChoice.getHead().slot;
208
- if (syncDiff > this.slotImportTolerance * 2) {
209
- if (this.network.isSubscribedToGossipCoreTopics()) {
210
- this.logger.warn(`Node sync has fallen behind by ${syncDiff} slots`);
211
- this.network
212
- .unsubscribeGossipCoreTopics()
213
- .then(() => {
214
- this.metrics?.syncSwitchGossipSubscriptions.inc({ action: "unsubscribed" });
215
- this.logger.info("Un-subscribed gossip core topics");
216
- })
217
- .catch((e) => {
218
- this.logger.error("Error unsubscribing to gossip core topics", {}, e);
219
- });
220
- }
221
- // also stop searching for unknown blocks
222
- if (this.unknownBlockSync.isSubscribedToNetwork()) {
223
- this.unknownBlockSync.unsubscribeFromNetwork();
224
- this.metrics?.blockInputSync.switchNetworkSubscriptions.inc({ action: "unsubscribed" });
225
- }
226
- }
227
- }
228
- };
229
- onClockEpoch = () => {
230
- // If a node witness the genesis event consider starting gossip
231
- // Also, ensure that updateSyncState is run at least once per epoch.
232
- // If the chain gets stuck or very overloaded it could helps to resolve the situation
233
- // by realizing it's way behind and turning gossip off.
234
- this.updateSyncState();
235
- };
236
228
  scrapeMetrics(metrics) {
237
229
  // Compute current sync state
238
230
  metrics.syncStatus.set(syncStateMetric[this.state]);
@@ -1 +1 @@
1
- {"version":3,"file":"sync.js","sourceRoot":"","sources":["../../src/sync/sync.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"sync.js","sourceRoot":"","sources":["../../src/sync/sync.ts"],"names":[],"mappings":"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"}
@@ -1,45 +1,14 @@
1
1
  import { ChainForkConfig } from "@lodestar/config";
2
2
  import { Logger } from "@lodestar/utils";
3
- import { IBlockInput } from "../chain/blocks/blockInput/types.js";
3
+ import { BlockInput, NullBlockInput } from "../chain/blocks/types.js";
4
4
  import { IBeaconChain } from "../chain/index.js";
5
5
  import { Metrics } from "../metrics/index.js";
6
6
  import { INetwork } from "../network/index.js";
7
7
  import { PeerSyncMeta } from "../network/peers/peersData.js";
8
+ import { CustodyConfig } from "../util/dataColumns.js";
8
9
  import { PeerIdStr } from "../util/peerId.js";
9
10
  import { SyncOptions } from "./options.js";
10
- /**
11
- * BlockInputSync is a class that handles ReqResp to find blocks and data related to a specific blockRoot. The
12
- * blockRoot may have been found via object gossip, or the API. Gossip objects that can trigger a search are block,
13
- * blobs, columns, attestations, etc. In the case of blocks and data this is generally during the current slot but
14
- * can also be for items that are received late but are not fully verified and thus not in fork-choice (old blocks on
15
- * an unknown fork). It can also be triggered via an attestation (or sync committee message or any other item that
16
- * gets gossiped) that references a blockRoot that is not in fork-choice. In rare (and realistically should not happen)
17
- * situations it can get triggered via the API when the validator attempts to publish a block, attestation, aggregate
18
- * and proof or a sync committee contribution that has unknown information included (parentRoot for instance).
19
- *
20
- * The goal of the class is to make sure that all information that is necessary for import into fork-choice is pulled
21
- * from peers so that the block and data can be processed, and thus the object that triggered the search can be
22
- * referenced and validated.
23
- *
24
- * The most common case for this search is a set of block/data that comes across gossip for the current slot, during
25
- * normal chain operation, but not everything was received before the gossip cutoff window happens so it is necessary
26
- * to pull remaining data via req/resp so that fork-choice can be updated prior to making an attestation for the
27
- * current slot.
28
- *
29
- * Event sources for old UnknownBlock
30
- *
31
- * - publishBlock
32
- * - gossipHandlers
33
- * - searchUnknownSlotRoot
34
- * = produceSyncCommitteeContribution
35
- * = validateGossipFnRetryUnknownRoot
36
- * * submitPoolAttestationsV2
37
- * * publishAggregateAndProofsV2
38
- * = onPendingGossipsubMessage
39
- * * NetworkEvent.pendingGossipsubMessage
40
- * - onGossipsubMessage
41
- */
42
- export declare class BlockInputSync {
11
+ export declare class UnknownBlockSync {
43
12
  private readonly config;
44
13
  private readonly network;
45
14
  private readonly chain;
@@ -51,8 +20,11 @@ export declare class BlockInputSync {
51
20
  */
52
21
  private readonly pendingBlocks;
53
22
  private readonly knownBadBlocks;
23
+ private readonly proposerBoostSecWindow;
54
24
  private readonly maxPendingBlocks;
55
25
  private subscribedToNetworkEvents;
26
+ private engineGetBlobsCache;
27
+ private blockInputsRetryTrackerCache;
56
28
  private peerBalancer;
57
29
  constructor(config: ChainForkConfig, network: INetwork, chain: IBeaconChain, logger: Logger, metrics: Metrics | null, opts?: SyncOptions | undefined);
58
30
  subscribeToNetwork(): void;
@@ -62,17 +34,24 @@ export declare class BlockInputSync {
62
34
  /**
63
35
  * Process an unknownBlock event and register the block in `pendingBlocks` Map.
64
36
  */
65
- private onUnknownBlockRoot;
37
+ private onUnknownBlock;
66
38
  /**
67
39
  * Process an unknownBlockInput event and register the block in `pendingBlocks` Map.
68
40
  */
69
- private onIncompleteBlockInput;
41
+ private onUnknownBlockInput;
70
42
  /**
71
43
  * Process an unknownBlockParent event and register the block in `pendingBlocks` Map.
72
44
  */
73
45
  private onUnknownParent;
74
- private addByRootHex;
75
- private addByBlockInput;
46
+ /**
47
+ * When a blockInput comes with an unknown parent:
48
+ * - add the block to pendingBlocks with status downloaded or pending blockRootHex as key. This is similar to
49
+ * an `onUnknownBlock` event, but the blocks is downloaded.
50
+ * - add the parent root to pendingBlocks with status pending, parentBlockRootHex as key. This is
51
+ * the same to an `onUnknownBlock` event with parentBlockRootHex as root.
52
+ */
53
+ private addUnknownParent;
54
+ private addUnknownBlock;
76
55
  private onPeerConnected;
77
56
  private onPeerDisconnected;
78
57
  /**
@@ -95,14 +74,21 @@ export declare class BlockInputSync {
95
74
  * prefulu, will attempt a max of `MAX_ATTEMPTS_PER_BLOCK` on different peers, postfulu we may attempt more as defined in `getMaxDownloadAttempts()` function
96
75
  * Also verifies the received block root + returns the peer that provided the block for future downscoring.
97
76
  */
98
- private fetchBlockInput;
77
+ private fetchUnknownBlockRoot;
78
+ /**
79
+ * We have partial block input:
80
+ * - we have block but not have all blobs (deneb) or needed columns (fulu)
81
+ * - we don't have block and have some blobs (deneb) or some columns (fulu)
82
+ * Fetches missing block/data columns/block for the blockinput. This function returns either preData or availableData BlockInput.
83
+ */
84
+ private fetchUnavailableBlockInput;
99
85
  /**
100
86
  * Gets all descendant blocks of `block` recursively from `pendingBlocks`.
101
87
  * Assumes that if a parent block does not exist or is not processable, all descendant blocks are bad too.
102
88
  * Downscore all peers that have referenced any of this bad blocks. May report peers multiple times if they have
103
89
  * referenced more than one bad block.
104
90
  */
105
- private removeAndDownScoreAllDescendants;
91
+ private removeAndDownscoreAllDescendants;
106
92
  private removeAllDescendants;
107
93
  private getMaxDownloadAttempts;
108
94
  }
@@ -112,7 +98,8 @@ export declare class BlockInputSync {
112
98
  export declare class UnknownBlockPeerBalancer {
113
99
  readonly peersMeta: Map<PeerIdStr, PeerSyncMeta>;
114
100
  readonly activeRequests: Map<PeerIdStr, number>;
115
- constructor();
101
+ private readonly custodyConfig;
102
+ constructor(custodyConfig: CustodyConfig);
116
103
  /** Trigger on each peer re-status */
117
104
  onPeerConnected(peerId: PeerIdStr, syncMeta: PeerSyncMeta): void;
118
105
  onPeerDisconnected(peerId: PeerIdStr): void;
@@ -126,7 +113,7 @@ export declare class UnknownBlockPeerBalancer {
126
113
  * called from fetchUnavailableBlockInput() where we have either BlockInput or NullBlockInput
127
114
  * excludedPeers are the peers that we requested already so we don't want to try again
128
115
  */
129
- bestPeerForBlockInput(blockInput: IBlockInput, excludedPeers: Set<PeerIdStr>): PeerSyncMeta | null;
116
+ bestPeerForBlockInput(unavailableBlockInput: BlockInput | NullBlockInput, excludedPeers: Set<PeerIdStr>): PeerSyncMeta | null;
130
117
  /**
131
118
  * Consumers don't need to call this method directly, it is called internally by bestPeer*() methods
132
119
  * make this public for testing