@lodestar/beacon-node 1.41.0-dev.983b1a457b → 1.41.0-dev.9939b12b53

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 (891) hide show
  1. package/lib/api/impl/api.js.map +1 -1
  2. package/lib/api/impl/beacon/blocks/index.d.ts +1 -1
  3. package/lib/api/impl/beacon/blocks/index.d.ts.map +1 -1
  4. package/lib/api/impl/beacon/blocks/index.js +132 -4
  5. package/lib/api/impl/beacon/blocks/index.js.map +1 -1
  6. package/lib/api/impl/beacon/blocks/utils.js.map +1 -1
  7. package/lib/api/impl/beacon/index.js.map +1 -1
  8. package/lib/api/impl/beacon/pool/index.d.ts +1 -1
  9. package/lib/api/impl/beacon/pool/index.d.ts.map +1 -1
  10. package/lib/api/impl/beacon/pool/index.js.map +1 -1
  11. package/lib/api/impl/beacon/rewards/index.d.ts +1 -1
  12. package/lib/api/impl/beacon/rewards/index.d.ts.map +1 -1
  13. package/lib/api/impl/beacon/rewards/index.js.map +1 -1
  14. package/lib/api/impl/beacon/state/index.d.ts +1 -1
  15. package/lib/api/impl/beacon/state/index.d.ts.map +1 -1
  16. package/lib/api/impl/beacon/state/index.js +8 -8
  17. package/lib/api/impl/beacon/state/index.js.map +1 -1
  18. package/lib/api/impl/beacon/state/utils.d.ts +3 -4
  19. package/lib/api/impl/beacon/state/utils.d.ts.map +1 -1
  20. package/lib/api/impl/beacon/state/utils.js +5 -24
  21. package/lib/api/impl/beacon/state/utils.js.map +1 -1
  22. package/lib/api/impl/config/constants.js.map +1 -1
  23. package/lib/api/impl/config/index.js.map +1 -1
  24. package/lib/api/impl/debug/index.d.ts +1 -1
  25. package/lib/api/impl/debug/index.d.ts.map +1 -1
  26. package/lib/api/impl/debug/index.js +6 -2
  27. package/lib/api/impl/debug/index.js.map +1 -1
  28. package/lib/api/impl/errors.d.ts.map +1 -1
  29. package/lib/api/impl/errors.js.map +1 -1
  30. package/lib/api/impl/events/index.d.ts +1 -1
  31. package/lib/api/impl/events/index.d.ts.map +1 -1
  32. package/lib/api/impl/events/index.js.map +1 -1
  33. package/lib/api/impl/lightclient/index.d.ts +1 -1
  34. package/lib/api/impl/lightclient/index.d.ts.map +1 -1
  35. package/lib/api/impl/lightclient/index.js.map +1 -1
  36. package/lib/api/impl/lodestar/index.d.ts +1 -1
  37. package/lib/api/impl/lodestar/index.d.ts.map +1 -1
  38. package/lib/api/impl/lodestar/index.js.map +1 -1
  39. package/lib/api/impl/node/index.js.map +1 -1
  40. package/lib/api/impl/node/utils.d.ts +1 -1
  41. package/lib/api/impl/node/utils.d.ts.map +1 -1
  42. package/lib/api/impl/node/utils.js.map +1 -1
  43. package/lib/api/impl/proof/index.js.map +1 -1
  44. package/lib/api/impl/utils.js.map +1 -1
  45. package/lib/api/impl/validator/index.d.ts.map +1 -1
  46. package/lib/api/impl/validator/index.js +134 -18
  47. package/lib/api/impl/validator/index.js.map +1 -1
  48. package/lib/api/impl/validator/utils.d.ts +1 -1
  49. package/lib/api/impl/validator/utils.d.ts.map +1 -1
  50. package/lib/api/impl/validator/utils.js.map +1 -1
  51. package/lib/api/rest/activeSockets.d.ts.map +1 -1
  52. package/lib/api/rest/activeSockets.js.map +1 -1
  53. package/lib/api/rest/base.d.ts.map +1 -1
  54. package/lib/api/rest/base.js.map +1 -1
  55. package/lib/api/rest/index.d.ts.map +1 -1
  56. package/lib/api/rest/index.js.map +1 -1
  57. package/lib/api/rest/swaggerUI.js.map +1 -1
  58. package/lib/bun-wrappers/prometheus-gc-stats.js.map +1 -1
  59. package/lib/chain/ColumnReconstructionTracker.d.ts.map +1 -1
  60. package/lib/chain/ColumnReconstructionTracker.js.map +1 -1
  61. package/lib/chain/GetBlobsTracker.d.ts.map +1 -1
  62. package/lib/chain/GetBlobsTracker.js.map +1 -1
  63. package/lib/chain/archiveStore/archiveStore.d.ts +1 -0
  64. package/lib/chain/archiveStore/archiveStore.d.ts.map +1 -1
  65. package/lib/chain/archiveStore/archiveStore.js +11 -1
  66. package/lib/chain/archiveStore/archiveStore.js.map +1 -1
  67. package/lib/chain/archiveStore/historicalState/getHistoricalState.d.ts +5 -6
  68. package/lib/chain/archiveStore/historicalState/getHistoricalState.d.ts.map +1 -1
  69. package/lib/chain/archiveStore/historicalState/getHistoricalState.js +9 -10
  70. package/lib/chain/archiveStore/historicalState/getHistoricalState.js.map +1 -1
  71. package/lib/chain/archiveStore/historicalState/historicalStateRegen.d.ts.map +1 -1
  72. package/lib/chain/archiveStore/historicalState/historicalStateRegen.js.map +1 -1
  73. package/lib/chain/archiveStore/historicalState/metrics.js.map +1 -1
  74. package/lib/chain/archiveStore/historicalState/types.js +2 -1
  75. package/lib/chain/archiveStore/historicalState/types.js.map +1 -1
  76. package/lib/chain/archiveStore/historicalState/worker.js +3 -3
  77. package/lib/chain/archiveStore/historicalState/worker.js.map +1 -1
  78. package/lib/chain/archiveStore/interface.js +2 -1
  79. package/lib/chain/archiveStore/interface.js.map +1 -1
  80. package/lib/chain/archiveStore/strategies/frequencyStateArchiveStrategy.d.ts +1 -1
  81. package/lib/chain/archiveStore/strategies/frequencyStateArchiveStrategy.d.ts.map +1 -1
  82. package/lib/chain/archiveStore/strategies/frequencyStateArchiveStrategy.js +2 -1
  83. package/lib/chain/archiveStore/strategies/frequencyStateArchiveStrategy.js.map +1 -1
  84. package/lib/chain/archiveStore/utils/archiveBlocks.d.ts +3 -8
  85. package/lib/chain/archiveStore/utils/archiveBlocks.d.ts.map +1 -1
  86. package/lib/chain/archiveStore/utils/archiveBlocks.js +1 -1
  87. package/lib/chain/archiveStore/utils/archiveBlocks.js.map +1 -1
  88. package/lib/chain/archiveStore/utils/archivePayloads.d.ts +7 -0
  89. package/lib/chain/archiveStore/utils/archivePayloads.d.ts.map +1 -0
  90. package/lib/chain/archiveStore/utils/archivePayloads.js +10 -0
  91. package/lib/chain/archiveStore/utils/archivePayloads.js.map +1 -0
  92. package/lib/chain/archiveStore/utils/pruneHistory.js.map +1 -1
  93. package/lib/chain/archiveStore/utils/updateBackfillRange.js +1 -1
  94. package/lib/chain/archiveStore/utils/updateBackfillRange.js.map +1 -1
  95. package/lib/chain/balancesCache.d.ts.map +1 -1
  96. package/lib/chain/balancesCache.js.map +1 -1
  97. package/lib/chain/beaconProposerCache.d.ts.map +1 -1
  98. package/lib/chain/beaconProposerCache.js.map +1 -1
  99. package/lib/chain/blocks/blockInput/blockInput.d.ts +25 -2
  100. package/lib/chain/blocks/blockInput/blockInput.d.ts.map +1 -1
  101. package/lib/chain/blocks/blockInput/blockInput.js +71 -0
  102. package/lib/chain/blocks/blockInput/blockInput.js.map +1 -1
  103. package/lib/chain/blocks/blockInput/errors.js +2 -1
  104. package/lib/chain/blocks/blockInput/errors.js.map +1 -1
  105. package/lib/chain/blocks/blockInput/types.d.ts +18 -1
  106. package/lib/chain/blocks/blockInput/types.d.ts.map +1 -1
  107. package/lib/chain/blocks/blockInput/types.js +5 -2
  108. package/lib/chain/blocks/blockInput/types.js.map +1 -1
  109. package/lib/chain/blocks/blockInput/utils.js.map +1 -1
  110. package/lib/chain/blocks/importBlock.d.ts.map +1 -1
  111. package/lib/chain/blocks/importBlock.js +28 -5
  112. package/lib/chain/blocks/importBlock.js.map +1 -1
  113. package/lib/chain/blocks/index.d.ts.map +1 -1
  114. package/lib/chain/blocks/index.js.map +1 -1
  115. package/lib/chain/blocks/types.js +6 -3
  116. package/lib/chain/blocks/types.js.map +1 -1
  117. package/lib/chain/blocks/utils/chainSegment.js.map +1 -1
  118. package/lib/chain/blocks/utils/checkpoint.js.map +1 -1
  119. package/lib/chain/blocks/verifyBlock.js.map +1 -1
  120. package/lib/chain/blocks/verifyBlocksDataAvailability.d.ts.map +1 -1
  121. package/lib/chain/blocks/verifyBlocksDataAvailability.js +3 -0
  122. package/lib/chain/blocks/verifyBlocksDataAvailability.js.map +1 -1
  123. package/lib/chain/blocks/verifyBlocksExecutionPayloads.d.ts +4 -0
  124. package/lib/chain/blocks/verifyBlocksExecutionPayloads.d.ts.map +1 -1
  125. package/lib/chain/blocks/verifyBlocksExecutionPayloads.js +5 -1
  126. package/lib/chain/blocks/verifyBlocksExecutionPayloads.js.map +1 -1
  127. package/lib/chain/blocks/verifyBlocksSanityChecks.d.ts.map +1 -1
  128. package/lib/chain/blocks/verifyBlocksSanityChecks.js +4 -1
  129. package/lib/chain/blocks/verifyBlocksSanityChecks.js.map +1 -1
  130. package/lib/chain/blocks/verifyBlocksSignatures.js.map +1 -1
  131. package/lib/chain/blocks/verifyBlocksStateTransitionOnly.js.map +1 -1
  132. package/lib/chain/blocks/writeBlockInputToDb.d.ts +12 -3
  133. package/lib/chain/blocks/writeBlockInputToDb.d.ts.map +1 -1
  134. package/lib/chain/blocks/writeBlockInputToDb.js +92 -98
  135. package/lib/chain/blocks/writeBlockInputToDb.js.map +1 -1
  136. package/lib/chain/bls/maybeBatch.js.map +1 -1
  137. package/lib/chain/bls/multithread/index.d.ts +3 -3
  138. package/lib/chain/bls/multithread/index.d.ts.map +1 -1
  139. package/lib/chain/bls/multithread/index.js +5 -5
  140. package/lib/chain/bls/multithread/index.js.map +1 -1
  141. package/lib/chain/bls/multithread/jobItem.d.ts +2 -2
  142. package/lib/chain/bls/multithread/jobItem.d.ts.map +1 -1
  143. package/lib/chain/bls/multithread/jobItem.js +4 -3
  144. package/lib/chain/bls/multithread/jobItem.js.map +1 -1
  145. package/lib/chain/bls/multithread/types.js +2 -1
  146. package/lib/chain/bls/multithread/types.js.map +1 -1
  147. package/lib/chain/bls/multithread/utils.js.map +1 -1
  148. package/lib/chain/bls/multithread/worker.js.map +1 -1
  149. package/lib/chain/bls/singleThread.d.ts +4 -4
  150. package/lib/chain/bls/singleThread.d.ts.map +1 -1
  151. package/lib/chain/bls/singleThread.js +4 -4
  152. package/lib/chain/bls/singleThread.js.map +1 -1
  153. package/lib/chain/bls/utils.d.ts +2 -2
  154. package/lib/chain/bls/utils.d.ts.map +1 -1
  155. package/lib/chain/bls/utils.js +7 -4
  156. package/lib/chain/bls/utils.js.map +1 -1
  157. package/lib/chain/chain.d.ts +9 -12
  158. package/lib/chain/chain.d.ts.map +1 -1
  159. package/lib/chain/chain.js +49 -30
  160. package/lib/chain/chain.js.map +1 -1
  161. package/lib/chain/emitter.d.ts +6 -8
  162. package/lib/chain/emitter.d.ts.map +1 -1
  163. package/lib/chain/emitter.js +2 -1
  164. package/lib/chain/emitter.js.map +1 -1
  165. package/lib/chain/errors/attestationError.d.ts.map +1 -1
  166. package/lib/chain/errors/attestationError.js +2 -1
  167. package/lib/chain/errors/attestationError.js.map +1 -1
  168. package/lib/chain/errors/attesterSlashingError.js +2 -1
  169. package/lib/chain/errors/attesterSlashingError.js.map +1 -1
  170. package/lib/chain/errors/blobSidecarError.js +2 -1
  171. package/lib/chain/errors/blobSidecarError.js.map +1 -1
  172. package/lib/chain/errors/blockError.d.ts.map +1 -1
  173. package/lib/chain/errors/blockError.js +2 -1
  174. package/lib/chain/errors/blockError.js.map +1 -1
  175. package/lib/chain/errors/blsToExecutionChangeError.js +2 -1
  176. package/lib/chain/errors/blsToExecutionChangeError.js.map +1 -1
  177. package/lib/chain/errors/dataColumnSidecarError.js +2 -1
  178. package/lib/chain/errors/dataColumnSidecarError.js.map +1 -1
  179. package/lib/chain/errors/executionPayloadBid.d.ts +1 -1
  180. package/lib/chain/errors/executionPayloadBid.js +2 -1
  181. package/lib/chain/errors/executionPayloadBid.js.map +1 -1
  182. package/lib/chain/errors/executionPayloadEnvelope.d.ts +2 -2
  183. package/lib/chain/errors/executionPayloadEnvelope.d.ts.map +1 -1
  184. package/lib/chain/errors/executionPayloadEnvelope.js +2 -1
  185. package/lib/chain/errors/executionPayloadEnvelope.js.map +1 -1
  186. package/lib/chain/errors/gossipValidation.d.ts.map +1 -1
  187. package/lib/chain/errors/gossipValidation.js +4 -2
  188. package/lib/chain/errors/gossipValidation.js.map +1 -1
  189. package/lib/chain/errors/lightClientError.js +4 -2
  190. package/lib/chain/errors/lightClientError.js.map +1 -1
  191. package/lib/chain/errors/payloadAttestation.d.ts +1 -1
  192. package/lib/chain/errors/payloadAttestation.js +2 -1
  193. package/lib/chain/errors/payloadAttestation.js.map +1 -1
  194. package/lib/chain/errors/proposerSlashingError.js +2 -1
  195. package/lib/chain/errors/proposerSlashingError.js.map +1 -1
  196. package/lib/chain/errors/syncCommitteeError.js +2 -1
  197. package/lib/chain/errors/syncCommitteeError.js.map +1 -1
  198. package/lib/chain/errors/voluntaryExitError.js +2 -1
  199. package/lib/chain/errors/voluntaryExitError.js.map +1 -1
  200. package/lib/chain/forkChoice/index.d.ts.map +1 -1
  201. package/lib/chain/forkChoice/index.js +32 -25
  202. package/lib/chain/forkChoice/index.js.map +1 -1
  203. package/lib/chain/initState.d.ts +1 -1
  204. package/lib/chain/initState.d.ts.map +1 -1
  205. package/lib/chain/initState.js.map +1 -1
  206. package/lib/chain/interface.d.ts +4 -6
  207. package/lib/chain/interface.d.ts.map +1 -1
  208. package/lib/chain/interface.js +2 -1
  209. package/lib/chain/interface.js.map +1 -1
  210. package/lib/chain/lightClient/index.d.ts +0 -29
  211. package/lib/chain/lightClient/index.d.ts.map +1 -1
  212. package/lib/chain/lightClient/index.js.map +1 -1
  213. package/lib/chain/lightClient/proofs.js.map +1 -1
  214. package/lib/chain/opPools/aggregatedAttestationPool.d.ts.map +1 -1
  215. package/lib/chain/opPools/aggregatedAttestationPool.js +5 -3
  216. package/lib/chain/opPools/aggregatedAttestationPool.js.map +1 -1
  217. package/lib/chain/opPools/attestationPool.d.ts.map +1 -1
  218. package/lib/chain/opPools/attestationPool.js.map +1 -1
  219. package/lib/chain/opPools/executionPayloadBidPool.d.ts.map +1 -1
  220. package/lib/chain/opPools/executionPayloadBidPool.js.map +1 -1
  221. package/lib/chain/opPools/opPool.d.ts.map +1 -1
  222. package/lib/chain/opPools/opPool.js.map +1 -1
  223. package/lib/chain/opPools/payloadAttestationPool.d.ts.map +1 -1
  224. package/lib/chain/opPools/payloadAttestationPool.js.map +1 -1
  225. package/lib/chain/opPools/syncCommitteeMessagePool.d.ts.map +1 -1
  226. package/lib/chain/opPools/syncCommitteeMessagePool.js.map +1 -1
  227. package/lib/chain/opPools/syncContributionAndProofPool.d.ts.map +1 -1
  228. package/lib/chain/opPools/syncContributionAndProofPool.js.map +1 -1
  229. package/lib/chain/opPools/types.js +4 -2
  230. package/lib/chain/opPools/types.js.map +1 -1
  231. package/lib/chain/opPools/utils.js.map +1 -1
  232. package/lib/chain/options.d.ts.map +1 -1
  233. package/lib/chain/options.js.map +1 -1
  234. package/lib/chain/prepareNextSlot.d.ts +1 -2
  235. package/lib/chain/prepareNextSlot.d.ts.map +1 -1
  236. package/lib/chain/prepareNextSlot.js +3 -3
  237. package/lib/chain/prepareNextSlot.js.map +1 -1
  238. package/lib/chain/produceBlock/computeNewStateRoot.d.ts +9 -2
  239. package/lib/chain/produceBlock/computeNewStateRoot.d.ts.map +1 -1
  240. package/lib/chain/produceBlock/computeNewStateRoot.js +25 -2
  241. package/lib/chain/produceBlock/computeNewStateRoot.js.map +1 -1
  242. package/lib/chain/produceBlock/produceBlockBody.d.ts +23 -8
  243. package/lib/chain/produceBlock/produceBlockBody.d.ts.map +1 -1
  244. package/lib/chain/produceBlock/produceBlockBody.js +124 -14
  245. package/lib/chain/produceBlock/produceBlockBody.js.map +1 -1
  246. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.js.map +1 -1
  247. package/lib/chain/regen/errors.d.ts.map +1 -1
  248. package/lib/chain/regen/errors.js +2 -1
  249. package/lib/chain/regen/errors.js.map +1 -1
  250. package/lib/chain/regen/interface.js +4 -2
  251. package/lib/chain/regen/interface.js.map +1 -1
  252. package/lib/chain/regen/queued.d.ts.map +1 -1
  253. package/lib/chain/regen/queued.js +4 -1
  254. package/lib/chain/regen/queued.js.map +1 -1
  255. package/lib/chain/regen/regen.d.ts.map +1 -1
  256. package/lib/chain/regen/regen.js +6 -2
  257. package/lib/chain/regen/regen.js.map +1 -1
  258. package/lib/chain/reprocess.d.ts.map +1 -1
  259. package/lib/chain/reprocess.js +2 -1
  260. package/lib/chain/reprocess.js.map +1 -1
  261. package/lib/chain/seenCache/seenAggregateAndProof.d.ts.map +1 -1
  262. package/lib/chain/seenCache/seenAggregateAndProof.js.map +1 -1
  263. package/lib/chain/seenCache/seenAttestationData.d.ts.map +1 -1
  264. package/lib/chain/seenCache/seenAttestationData.js +2 -1
  265. package/lib/chain/seenCache/seenAttestationData.js.map +1 -1
  266. package/lib/chain/seenCache/seenAttesters.d.ts.map +1 -1
  267. package/lib/chain/seenCache/seenAttesters.js.map +1 -1
  268. package/lib/chain/seenCache/seenBlockAttesters.d.ts.map +1 -1
  269. package/lib/chain/seenCache/seenBlockAttesters.js.map +1 -1
  270. package/lib/chain/seenCache/seenBlockProposers.d.ts.map +1 -1
  271. package/lib/chain/seenCache/seenBlockProposers.js.map +1 -1
  272. package/lib/chain/seenCache/seenCommittee.d.ts.map +1 -1
  273. package/lib/chain/seenCache/seenCommittee.js.map +1 -1
  274. package/lib/chain/seenCache/seenCommitteeContribution.d.ts.map +1 -1
  275. package/lib/chain/seenCache/seenCommitteeContribution.js.map +1 -1
  276. package/lib/chain/seenCache/seenExecutionPayloadBids.d.ts.map +1 -1
  277. package/lib/chain/seenCache/seenExecutionPayloadBids.js.map +1 -1
  278. package/lib/chain/seenCache/seenExecutionPayloadEnvelope.d.ts.map +1 -1
  279. package/lib/chain/seenCache/seenExecutionPayloadEnvelope.js.map +1 -1
  280. package/lib/chain/seenCache/seenGossipBlockInput.d.ts +7 -3
  281. package/lib/chain/seenCache/seenGossipBlockInput.d.ts.map +1 -1
  282. package/lib/chain/seenCache/seenGossipBlockInput.js +38 -16
  283. package/lib/chain/seenCache/seenGossipBlockInput.js.map +1 -1
  284. package/lib/chain/serializeState.js +1 -0
  285. package/lib/chain/serializeState.js.map +1 -1
  286. package/lib/chain/shufflingCache.d.ts.map +1 -1
  287. package/lib/chain/shufflingCache.js +2 -1
  288. package/lib/chain/shufflingCache.js.map +1 -1
  289. package/lib/chain/stateCache/datastore/db.d.ts.map +1 -1
  290. package/lib/chain/stateCache/datastore/db.js.map +1 -1
  291. package/lib/chain/stateCache/datastore/file.d.ts.map +1 -1
  292. package/lib/chain/stateCache/datastore/file.js.map +1 -1
  293. package/lib/chain/stateCache/fifoBlockStateCache.d.ts.map +1 -1
  294. package/lib/chain/stateCache/fifoBlockStateCache.js.map +1 -1
  295. package/lib/chain/stateCache/mapMetrics.d.ts.map +1 -1
  296. package/lib/chain/stateCache/mapMetrics.js.map +1 -1
  297. package/lib/chain/stateCache/persistentCheckpointsCache.d.ts +1 -41
  298. package/lib/chain/stateCache/persistentCheckpointsCache.d.ts.map +1 -1
  299. package/lib/chain/stateCache/persistentCheckpointsCache.js.map +1 -1
  300. package/lib/chain/stateCache/types.js +2 -1
  301. package/lib/chain/stateCache/types.js.map +1 -1
  302. package/lib/chain/validation/aggregateAndProof.js +1 -1
  303. package/lib/chain/validation/aggregateAndProof.js.map +1 -1
  304. package/lib/chain/validation/attestation.d.ts.map +1 -1
  305. package/lib/chain/validation/attestation.js +14 -7
  306. package/lib/chain/validation/attestation.js.map +1 -1
  307. package/lib/chain/validation/attesterSlashing.d.ts.map +1 -1
  308. package/lib/chain/validation/attesterSlashing.js +9 -2
  309. package/lib/chain/validation/attesterSlashing.js.map +1 -1
  310. package/lib/chain/validation/blobSidecar.js +2 -2
  311. package/lib/chain/validation/blobSidecar.js.map +1 -1
  312. package/lib/chain/validation/block.d.ts.map +1 -1
  313. package/lib/chain/validation/block.js +6 -3
  314. package/lib/chain/validation/block.js.map +1 -1
  315. package/lib/chain/validation/blsToExecutionChange.js.map +1 -1
  316. package/lib/chain/validation/dataColumnSidecar.d.ts +4 -3
  317. package/lib/chain/validation/dataColumnSidecar.d.ts.map +1 -1
  318. package/lib/chain/validation/dataColumnSidecar.js +125 -108
  319. package/lib/chain/validation/dataColumnSidecar.js.map +1 -1
  320. package/lib/chain/validation/executionPayloadBid.js +1 -2
  321. package/lib/chain/validation/executionPayloadBid.js.map +1 -1
  322. package/lib/chain/validation/executionPayloadEnvelope.js +4 -4
  323. package/lib/chain/validation/executionPayloadEnvelope.js.map +1 -1
  324. package/lib/chain/validation/lightClientFinalityUpdate.js.map +1 -1
  325. package/lib/chain/validation/lightClientOptimisticUpdate.js.map +1 -1
  326. package/lib/chain/validation/payloadAttestationMessage.js +9 -3
  327. package/lib/chain/validation/payloadAttestationMessage.js.map +1 -1
  328. package/lib/chain/validation/proposerSlashing.js +1 -1
  329. package/lib/chain/validation/proposerSlashing.js.map +1 -1
  330. package/lib/chain/validation/signatureSets/aggregateAndProof.js.map +1 -1
  331. package/lib/chain/validation/signatureSets/contributionAndProof.js.map +1 -1
  332. package/lib/chain/validation/signatureSets/selectionProof.js.map +1 -1
  333. package/lib/chain/validation/signatureSets/syncCommittee.js.map +1 -1
  334. package/lib/chain/validation/signatureSets/syncCommitteeContribution.js.map +1 -1
  335. package/lib/chain/validation/signatureSets/syncCommitteeSelectionProof.js.map +1 -1
  336. package/lib/chain/validation/syncCommittee.js.map +1 -1
  337. package/lib/chain/validation/syncCommitteeContributionAndProof.js +1 -1
  338. package/lib/chain/validation/syncCommitteeContributionAndProof.js.map +1 -1
  339. package/lib/chain/validation/voluntaryExit.js.map +1 -1
  340. package/lib/chain/validatorMonitor.d.ts.map +1 -1
  341. package/lib/chain/validatorMonitor.js +2 -1
  342. package/lib/chain/validatorMonitor.js.map +1 -1
  343. package/lib/constants/network.js +4 -2
  344. package/lib/constants/network.js.map +1 -1
  345. package/lib/db/beacon.d.ts +3 -1
  346. package/lib/db/beacon.d.ts.map +1 -1
  347. package/lib/db/beacon.js +5 -1
  348. package/lib/db/beacon.js.map +1 -1
  349. package/lib/db/buckets.d.ts +24 -22
  350. package/lib/db/buckets.d.ts.map +1 -1
  351. package/lib/db/buckets.js +4 -1
  352. package/lib/db/buckets.js.map +1 -1
  353. package/lib/db/index.d.ts +1 -0
  354. package/lib/db/index.d.ts.map +1 -1
  355. package/lib/db/index.js +1 -0
  356. package/lib/db/index.js.map +1 -1
  357. package/lib/db/interface.d.ts +3 -1
  358. package/lib/db/interface.d.ts.map +1 -1
  359. package/lib/db/repositories/attesterSlashing.d.ts.map +1 -1
  360. package/lib/db/repositories/attesterSlashing.js.map +1 -1
  361. package/lib/db/repositories/backfilledRanges.d.ts.map +1 -1
  362. package/lib/db/repositories/backfilledRanges.js.map +1 -1
  363. package/lib/db/repositories/blobSidecars.d.ts.map +1 -1
  364. package/lib/db/repositories/blobSidecars.js.map +1 -1
  365. package/lib/db/repositories/blobSidecarsArchive.d.ts.map +1 -1
  366. package/lib/db/repositories/blobSidecarsArchive.js.map +1 -1
  367. package/lib/db/repositories/block.d.ts.map +1 -1
  368. package/lib/db/repositories/block.js.map +1 -1
  369. package/lib/db/repositories/blockArchive.d.ts.map +1 -1
  370. package/lib/db/repositories/blockArchive.js +1 -2
  371. package/lib/db/repositories/blockArchive.js.map +1 -1
  372. package/lib/db/repositories/blockArchiveIndex.d.ts +2 -2
  373. package/lib/db/repositories/blockArchiveIndex.d.ts.map +1 -1
  374. package/lib/db/repositories/blockArchiveIndex.js.map +1 -1
  375. package/lib/db/repositories/blsToExecutionChange.d.ts.map +1 -1
  376. package/lib/db/repositories/blsToExecutionChange.js.map +1 -1
  377. package/lib/db/repositories/checkpointState.d.ts.map +1 -1
  378. package/lib/db/repositories/checkpointState.js.map +1 -1
  379. package/lib/db/repositories/dataColumnSidecar.d.ts +5 -3
  380. package/lib/db/repositories/dataColumnSidecar.d.ts.map +1 -1
  381. package/lib/db/repositories/dataColumnSidecar.js +14 -1
  382. package/lib/db/repositories/dataColumnSidecar.js.map +1 -1
  383. package/lib/db/repositories/dataColumnSidecarArchive.d.ts +5 -3
  384. package/lib/db/repositories/dataColumnSidecarArchive.d.ts.map +1 -1
  385. package/lib/db/repositories/dataColumnSidecarArchive.js +14 -1
  386. package/lib/db/repositories/dataColumnSidecarArchive.js.map +1 -1
  387. package/lib/db/repositories/executionPayloadEnvelope.d.ts +19 -0
  388. package/lib/db/repositories/executionPayloadEnvelope.d.ts.map +1 -0
  389. package/lib/db/repositories/executionPayloadEnvelope.js +22 -0
  390. package/lib/db/repositories/executionPayloadEnvelope.js.map +1 -0
  391. package/lib/db/repositories/executionPayloadEnvelopeArchive.d.ts +18 -0
  392. package/lib/db/repositories/executionPayloadEnvelopeArchive.d.ts.map +1 -0
  393. package/lib/db/repositories/executionPayloadEnvelopeArchive.js +28 -0
  394. package/lib/db/repositories/executionPayloadEnvelopeArchive.js.map +1 -0
  395. package/lib/db/repositories/index.d.ts +2 -0
  396. package/lib/db/repositories/index.d.ts.map +1 -1
  397. package/lib/db/repositories/index.js +2 -0
  398. package/lib/db/repositories/index.js.map +1 -1
  399. package/lib/db/repositories/lightclientBestUpdate.d.ts.map +1 -1
  400. package/lib/db/repositories/lightclientBestUpdate.js.map +1 -1
  401. package/lib/db/repositories/lightclientCheckpointHeader.d.ts.map +1 -1
  402. package/lib/db/repositories/lightclientCheckpointHeader.js.map +1 -1
  403. package/lib/db/repositories/lightclientSyncCommittee.d.ts.map +1 -1
  404. package/lib/db/repositories/lightclientSyncCommittee.js.map +1 -1
  405. package/lib/db/repositories/lightclientSyncCommitteeWitness.d.ts.map +1 -1
  406. package/lib/db/repositories/lightclientSyncCommitteeWitness.js.map +1 -1
  407. package/lib/db/repositories/proposerSlashing.d.ts.map +1 -1
  408. package/lib/db/repositories/proposerSlashing.js.map +1 -1
  409. package/lib/db/repositories/stateArchive.d.ts.map +1 -1
  410. package/lib/db/repositories/stateArchive.js.map +1 -1
  411. package/lib/db/repositories/stateArchiveIndex.js.map +1 -1
  412. package/lib/db/repositories/voluntaryExit.d.ts.map +1 -1
  413. package/lib/db/repositories/voluntaryExit.js.map +1 -1
  414. package/lib/execution/builder/cache.d.ts.map +1 -1
  415. package/lib/execution/builder/cache.js.map +1 -1
  416. package/lib/execution/builder/http.d.ts.map +1 -1
  417. package/lib/execution/builder/http.js +2 -1
  418. package/lib/execution/builder/http.js.map +1 -1
  419. package/lib/execution/builder/index.js.map +1 -1
  420. package/lib/execution/builder/utils.js.map +1 -1
  421. package/lib/execution/engine/disabled.d.ts.map +1 -1
  422. package/lib/execution/engine/disabled.js.map +1 -1
  423. package/lib/execution/engine/http.d.ts +1 -0
  424. package/lib/execution/engine/http.d.ts.map +1 -1
  425. package/lib/execution/engine/http.js +3 -0
  426. package/lib/execution/engine/http.js.map +1 -1
  427. package/lib/execution/engine/index.js.map +1 -1
  428. package/lib/execution/engine/interface.js +4 -2
  429. package/lib/execution/engine/interface.js.map +1 -1
  430. package/lib/execution/engine/jsonRpcHttpClient.d.ts +10 -15
  431. package/lib/execution/engine/jsonRpcHttpClient.d.ts.map +1 -1
  432. package/lib/execution/engine/jsonRpcHttpClient.js +2 -1
  433. package/lib/execution/engine/jsonRpcHttpClient.js.map +1 -1
  434. package/lib/execution/engine/jwt.js.map +1 -1
  435. package/lib/execution/engine/mock.d.ts.map +1 -1
  436. package/lib/execution/engine/mock.js.map +1 -1
  437. package/lib/execution/engine/payloadIdCache.d.ts.map +1 -1
  438. package/lib/execution/engine/payloadIdCache.js.map +1 -1
  439. package/lib/execution/engine/types.js.map +1 -1
  440. package/lib/execution/engine/utils.d.ts +1 -1
  441. package/lib/execution/engine/utils.d.ts.map +1 -1
  442. package/lib/execution/engine/utils.js.map +1 -1
  443. package/lib/metrics/metrics/beacon.d.ts +3 -1
  444. package/lib/metrics/metrics/beacon.d.ts.map +1 -1
  445. package/lib/metrics/metrics/beacon.js +14 -3
  446. package/lib/metrics/metrics/beacon.js.map +1 -1
  447. package/lib/metrics/metrics/lodestar.d.ts +21 -11
  448. package/lib/metrics/metrics/lodestar.d.ts.map +1 -1
  449. package/lib/metrics/metrics/lodestar.js +48 -24
  450. package/lib/metrics/metrics/lodestar.js.map +1 -1
  451. package/lib/metrics/metrics.js.map +1 -1
  452. package/lib/metrics/nodeJsMetrics.js.map +1 -1
  453. package/lib/metrics/server/http.d.ts +1 -1
  454. package/lib/metrics/server/http.d.ts.map +1 -1
  455. package/lib/metrics/server/http.js.map +1 -1
  456. package/lib/metrics/utils/avgMinMax.d.ts.map +1 -1
  457. package/lib/metrics/utils/avgMinMax.js.map +1 -1
  458. package/lib/metrics/utils/gauge.d.ts.map +1 -1
  459. package/lib/metrics/utils/gauge.js.map +1 -1
  460. package/lib/metrics/utils/registryMetricCreator.d.ts.map +1 -1
  461. package/lib/metrics/utils/registryMetricCreator.js.map +1 -1
  462. package/lib/monitoring/clientStats.js.map +1 -1
  463. package/lib/monitoring/properties.d.ts.map +1 -1
  464. package/lib/monitoring/properties.js.map +1 -1
  465. package/lib/monitoring/service.d.ts +2 -2
  466. package/lib/monitoring/service.d.ts.map +1 -1
  467. package/lib/monitoring/service.js +3 -2
  468. package/lib/monitoring/service.js.map +1 -1
  469. package/lib/monitoring/system.d.ts.map +1 -1
  470. package/lib/monitoring/system.js.map +1 -1
  471. package/lib/monitoring/types.js +4 -2
  472. package/lib/monitoring/types.js.map +1 -1
  473. package/lib/network/core/events.d.ts +1 -3
  474. package/lib/network/core/events.d.ts.map +1 -1
  475. package/lib/network/core/events.js +4 -2
  476. package/lib/network/core/events.js.map +1 -1
  477. package/lib/network/core/metrics.d.ts +6 -7
  478. package/lib/network/core/metrics.d.ts.map +1 -1
  479. package/lib/network/core/metrics.js.map +1 -1
  480. package/lib/network/core/networkCore.d.ts +4 -4
  481. package/lib/network/core/networkCore.d.ts.map +1 -1
  482. package/lib/network/core/networkCore.js.map +1 -1
  483. package/lib/network/core/networkCoreWorker.js.map +1 -1
  484. package/lib/network/core/networkCoreWorkerHandler.d.ts +3 -3
  485. package/lib/network/core/networkCoreWorkerHandler.d.ts.map +1 -1
  486. package/lib/network/core/networkCoreWorkerHandler.js.map +1 -1
  487. package/lib/network/core/types.d.ts +2 -2
  488. package/lib/network/core/types.d.ts.map +1 -1
  489. package/lib/network/discv5/index.d.ts +1 -3
  490. package/lib/network/discv5/index.d.ts.map +1 -1
  491. package/lib/network/discv5/index.js.map +1 -1
  492. package/lib/network/discv5/utils.d.ts +1 -1
  493. package/lib/network/discv5/utils.d.ts.map +1 -1
  494. package/lib/network/discv5/utils.js +7 -5
  495. package/lib/network/discv5/utils.js.map +1 -1
  496. package/lib/network/discv5/worker.js.map +1 -1
  497. package/lib/network/events.d.ts +3 -4
  498. package/lib/network/events.d.ts.map +1 -1
  499. package/lib/network/events.js +4 -2
  500. package/lib/network/events.js.map +1 -1
  501. package/lib/network/forks.js.map +1 -1
  502. package/lib/network/gossip/encoding.d.ts +3 -3
  503. package/lib/network/gossip/encoding.d.ts.map +1 -1
  504. package/lib/network/gossip/encoding.js.map +1 -1
  505. package/lib/network/gossip/errors.d.ts.map +1 -1
  506. package/lib/network/gossip/errors.js.map +1 -1
  507. package/lib/network/gossip/gossipsub.d.ts +13 -4
  508. package/lib/network/gossip/gossipsub.d.ts.map +1 -1
  509. package/lib/network/gossip/gossipsub.js +56 -26
  510. package/lib/network/gossip/gossipsub.js.map +1 -1
  511. package/lib/network/gossip/interface.d.ts +6 -6
  512. package/lib/network/gossip/interface.d.ts.map +1 -1
  513. package/lib/network/gossip/interface.js +4 -2
  514. package/lib/network/gossip/interface.js.map +1 -1
  515. package/lib/network/gossip/metrics.d.ts +12 -14
  516. package/lib/network/gossip/metrics.d.ts.map +1 -1
  517. package/lib/network/gossip/metrics.js.map +1 -1
  518. package/lib/network/gossip/scoringParameters.d.ts +2 -2
  519. package/lib/network/gossip/scoringParameters.d.ts.map +1 -1
  520. package/lib/network/gossip/scoringParameters.js +1 -1
  521. package/lib/network/gossip/scoringParameters.js.map +1 -1
  522. package/lib/network/gossip/topic.d.ts +3166 -3169
  523. package/lib/network/gossip/topic.d.ts.map +1 -1
  524. package/lib/network/gossip/topic.js +2 -2
  525. package/lib/network/gossip/topic.js.map +1 -1
  526. package/lib/network/interface.d.ts +6 -5
  527. package/lib/network/interface.d.ts.map +1 -1
  528. package/lib/network/libp2p/error.js +2 -1
  529. package/lib/network/libp2p/error.js.map +1 -1
  530. package/lib/network/libp2p/index.d.ts +2 -2
  531. package/lib/network/libp2p/index.d.ts.map +1 -1
  532. package/lib/network/libp2p/index.js +42 -19
  533. package/lib/network/libp2p/index.js.map +1 -1
  534. package/lib/network/metadata.d.ts +1 -0
  535. package/lib/network/metadata.d.ts.map +1 -1
  536. package/lib/network/metadata.js +5 -2
  537. package/lib/network/metadata.js.map +1 -1
  538. package/lib/network/network.d.ts +6 -5
  539. package/lib/network/network.d.ts.map +1 -1
  540. package/lib/network/network.js +11 -2
  541. package/lib/network/network.js.map +1 -1
  542. package/lib/network/options.d.ts +2 -0
  543. package/lib/network/options.d.ts.map +1 -1
  544. package/lib/network/options.js +6 -0
  545. package/lib/network/options.js.map +1 -1
  546. package/lib/network/peers/client.js +2 -1
  547. package/lib/network/peers/client.js.map +1 -1
  548. package/lib/network/peers/datastore.d.ts +7 -8
  549. package/lib/network/peers/datastore.d.ts.map +1 -1
  550. package/lib/network/peers/datastore.js +10 -10
  551. package/lib/network/peers/datastore.js.map +1 -1
  552. package/lib/network/peers/discover.d.ts +2 -7
  553. package/lib/network/peers/discover.d.ts.map +1 -1
  554. package/lib/network/peers/discover.js +45 -12
  555. package/lib/network/peers/discover.js.map +1 -1
  556. package/lib/network/peers/peerManager.d.ts +3 -1
  557. package/lib/network/peers/peerManager.d.ts.map +1 -1
  558. package/lib/network/peers/peerManager.js +103 -53
  559. package/lib/network/peers/peerManager.js.map +1 -1
  560. package/lib/network/peers/peersData.d.ts.map +1 -1
  561. package/lib/network/peers/peersData.js +2 -1
  562. package/lib/network/peers/peersData.js.map +1 -1
  563. package/lib/network/peers/score/interface.js +4 -2
  564. package/lib/network/peers/score/interface.js.map +1 -1
  565. package/lib/network/peers/score/score.d.ts.map +1 -1
  566. package/lib/network/peers/score/score.js.map +1 -1
  567. package/lib/network/peers/score/store.d.ts.map +1 -1
  568. package/lib/network/peers/score/store.js.map +1 -1
  569. package/lib/network/peers/score/utils.js.map +1 -1
  570. package/lib/network/peers/utils/assertPeerRelevance.js +2 -1
  571. package/lib/network/peers/utils/assertPeerRelevance.js.map +1 -1
  572. package/lib/network/peers/utils/enrSubnetsDeserialize.js.map +1 -1
  573. package/lib/network/peers/utils/getConnectedPeerIds.js.map +1 -1
  574. package/lib/network/peers/utils/prioritizePeers.d.ts +3 -3
  575. package/lib/network/peers/utils/prioritizePeers.d.ts.map +1 -1
  576. package/lib/network/peers/utils/prioritizePeers.js +2 -1
  577. package/lib/network/peers/utils/prioritizePeers.js.map +1 -1
  578. package/lib/network/peers/utils/subnetMap.d.ts.map +1 -1
  579. package/lib/network/peers/utils/subnetMap.js.map +1 -1
  580. package/lib/network/processor/aggregatorTracker.d.ts.map +1 -1
  581. package/lib/network/processor/aggregatorTracker.js.map +1 -1
  582. package/lib/network/processor/extractSlotRootFns.js.map +1 -1
  583. package/lib/network/processor/gossipHandlers.d.ts.map +1 -1
  584. package/lib/network/processor/gossipHandlers.js +9 -2
  585. package/lib/network/processor/gossipHandlers.js.map +1 -1
  586. package/lib/network/processor/gossipQueues/index.js.map +1 -1
  587. package/lib/network/processor/gossipQueues/indexed.d.ts.map +1 -1
  588. package/lib/network/processor/gossipQueues/indexed.js.map +1 -1
  589. package/lib/network/processor/gossipQueues/linear.d.ts.map +1 -1
  590. package/lib/network/processor/gossipQueues/linear.js.map +1 -1
  591. package/lib/network/processor/gossipQueues/types.js +4 -2
  592. package/lib/network/processor/gossipQueues/types.js.map +1 -1
  593. package/lib/network/processor/gossipValidatorFn.js +1 -1
  594. package/lib/network/processor/gossipValidatorFn.js.map +1 -1
  595. package/lib/network/processor/index.d.ts.map +1 -1
  596. package/lib/network/processor/index.js +4 -2
  597. package/lib/network/processor/index.js.map +1 -1
  598. package/lib/network/processor/types.d.ts +1 -1
  599. package/lib/network/processor/types.d.ts.map +1 -1
  600. package/lib/network/reqresp/ReqRespBeaconNode.d.ts.map +1 -1
  601. package/lib/network/reqresp/ReqRespBeaconNode.js.map +1 -1
  602. package/lib/network/reqresp/handlers/beaconBlocksByRange.d.ts.map +1 -1
  603. package/lib/network/reqresp/handlers/beaconBlocksByRange.js +3 -2
  604. package/lib/network/reqresp/handlers/beaconBlocksByRange.js.map +1 -1
  605. package/lib/network/reqresp/handlers/beaconBlocksByRoot.js.map +1 -1
  606. package/lib/network/reqresp/handlers/blobSidecarsByRange.d.ts.map +1 -1
  607. package/lib/network/reqresp/handlers/blobSidecarsByRange.js +3 -2
  608. package/lib/network/reqresp/handlers/blobSidecarsByRange.js.map +1 -1
  609. package/lib/network/reqresp/handlers/blobSidecarsByRoot.js +1 -1
  610. package/lib/network/reqresp/handlers/blobSidecarsByRoot.js.map +1 -1
  611. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts.map +1 -1
  612. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js +3 -2
  613. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js.map +1 -1
  614. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js +1 -1
  615. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js.map +1 -1
  616. package/lib/network/reqresp/handlers/index.js.map +1 -1
  617. package/lib/network/reqresp/handlers/lightClientBootstrap.js.map +1 -1
  618. package/lib/network/reqresp/handlers/lightClientFinalityUpdate.js.map +1 -1
  619. package/lib/network/reqresp/handlers/lightClientOptimisticUpdate.js.map +1 -1
  620. package/lib/network/reqresp/handlers/lightClientUpdatesByRange.js.map +1 -1
  621. package/lib/network/reqresp/interface.js +2 -1
  622. package/lib/network/reqresp/interface.js.map +1 -1
  623. package/lib/network/reqresp/protocols.d.ts.map +1 -1
  624. package/lib/network/reqresp/protocols.js.map +1 -1
  625. package/lib/network/reqresp/rateLimit.js.map +1 -1
  626. package/lib/network/reqresp/score.d.ts.map +1 -1
  627. package/lib/network/reqresp/score.js +0 -1
  628. package/lib/network/reqresp/score.js.map +1 -1
  629. package/lib/network/reqresp/types.js +4 -2
  630. package/lib/network/reqresp/types.js.map +1 -1
  631. package/lib/network/reqresp/utils/collect.d.ts +1 -1
  632. package/lib/network/reqresp/utils/collect.js.map +1 -1
  633. package/lib/network/reqresp/utils/collectSequentialBlocksInRange.d.ts +1 -1
  634. package/lib/network/reqresp/utils/collectSequentialBlocksInRange.js +2 -1
  635. package/lib/network/reqresp/utils/collectSequentialBlocksInRange.js.map +1 -1
  636. package/lib/network/reqresp/utils/dataColumnResponseValidation.d.ts +1 -1
  637. package/lib/network/reqresp/utils/dataColumnResponseValidation.d.ts.map +1 -1
  638. package/lib/network/reqresp/utils/dataColumnResponseValidation.js.map +1 -1
  639. package/lib/network/statusCache.d.ts.map +1 -1
  640. package/lib/network/statusCache.js.map +1 -1
  641. package/lib/network/subnets/attnetsService.d.ts.map +1 -1
  642. package/lib/network/subnets/attnetsService.js +2 -1
  643. package/lib/network/subnets/attnetsService.js.map +1 -1
  644. package/lib/network/subnets/interface.js.map +1 -1
  645. package/lib/network/subnets/syncnetsService.d.ts.map +1 -1
  646. package/lib/network/subnets/syncnetsService.js.map +1 -1
  647. package/lib/network/subnets/util.js.map +1 -1
  648. package/lib/network/util.js +2 -2
  649. package/lib/network/util.js.map +1 -1
  650. package/lib/node/nodejs.d.ts +4 -6
  651. package/lib/node/nodejs.d.ts.map +1 -1
  652. package/lib/node/nodejs.js +8 -5
  653. package/lib/node/nodejs.js.map +1 -1
  654. package/lib/node/notifier.js.map +1 -1
  655. package/lib/node/utils/interop/deposits.js.map +1 -1
  656. package/lib/node/utils/interop/state.d.ts +1 -1
  657. package/lib/node/utils/interop/state.d.ts.map +1 -1
  658. package/lib/node/utils/interop/state.js.map +1 -1
  659. package/lib/node/utils/lightclient.js.map +1 -1
  660. package/lib/node/utils/state.js.map +1 -1
  661. package/lib/sync/backfill/backfill.d.ts +1 -10
  662. package/lib/sync/backfill/backfill.d.ts.map +1 -1
  663. package/lib/sync/backfill/backfill.js +6 -3
  664. package/lib/sync/backfill/backfill.js.map +1 -1
  665. package/lib/sync/backfill/errors.js +2 -1
  666. package/lib/sync/backfill/errors.js.map +1 -1
  667. package/lib/sync/backfill/verify.js.map +1 -1
  668. package/lib/sync/interface.js +2 -1
  669. package/lib/sync/interface.js.map +1 -1
  670. package/lib/sync/range/batch.d.ts.map +1 -1
  671. package/lib/sync/range/batch.js +4 -2
  672. package/lib/sync/range/batch.js.map +1 -1
  673. package/lib/sync/range/chain.d.ts +0 -10
  674. package/lib/sync/range/chain.d.ts.map +1 -1
  675. package/lib/sync/range/chain.js +2 -1
  676. package/lib/sync/range/chain.js.map +1 -1
  677. package/lib/sync/range/range.d.ts +1 -3
  678. package/lib/sync/range/range.d.ts.map +1 -1
  679. package/lib/sync/range/range.js +5 -2
  680. package/lib/sync/range/range.js.map +1 -1
  681. package/lib/sync/range/utils/batches.js.map +1 -1
  682. package/lib/sync/range/utils/chainTarget.js.map +1 -1
  683. package/lib/sync/range/utils/hashBlocks.js.map +1 -1
  684. package/lib/sync/range/utils/peerBalancer.d.ts.map +1 -1
  685. package/lib/sync/range/utils/peerBalancer.js.map +1 -1
  686. package/lib/sync/range/utils/updateChains.js.map +1 -1
  687. package/lib/sync/sync.d.ts.map +1 -1
  688. package/lib/sync/sync.js.map +1 -1
  689. package/lib/sync/types.js +4 -2
  690. package/lib/sync/types.js.map +1 -1
  691. package/lib/sync/unknownBlock.d.ts +0 -14
  692. package/lib/sync/unknownBlock.d.ts.map +1 -1
  693. package/lib/sync/unknownBlock.js.map +1 -1
  694. package/lib/sync/utils/downloadByRange.d.ts +8 -5
  695. package/lib/sync/utils/downloadByRange.d.ts.map +1 -1
  696. package/lib/sync/utils/downloadByRange.js +8 -6
  697. package/lib/sync/utils/downloadByRange.js.map +1 -1
  698. package/lib/sync/utils/downloadByRoot.d.ts +8 -8
  699. package/lib/sync/utils/downloadByRoot.d.ts.map +1 -1
  700. package/lib/sync/utils/downloadByRoot.js +3 -2
  701. package/lib/sync/utils/downloadByRoot.js.map +1 -1
  702. package/lib/sync/utils/pendingBlocksTree.js.map +1 -1
  703. package/lib/sync/utils/remoteSyncType.d.ts +1 -1
  704. package/lib/sync/utils/remoteSyncType.d.ts.map +1 -1
  705. package/lib/sync/utils/remoteSyncType.js +4 -2
  706. package/lib/sync/utils/remoteSyncType.js.map +1 -1
  707. package/lib/util/address.js.map +1 -1
  708. package/lib/util/array.d.ts.map +1 -1
  709. package/lib/util/array.js.map +1 -1
  710. package/lib/util/asyncIterableToEvents.d.ts.map +1 -1
  711. package/lib/util/asyncIterableToEvents.js +2 -1
  712. package/lib/util/asyncIterableToEvents.js.map +1 -1
  713. package/lib/util/binarySearch.d.ts.map +1 -1
  714. package/lib/util/binarySearch.js.map +1 -1
  715. package/lib/util/bitArray.js +2 -1
  716. package/lib/util/bitArray.js.map +1 -1
  717. package/lib/util/blobs.d.ts +2 -2
  718. package/lib/util/blobs.d.ts.map +1 -1
  719. package/lib/util/blobs.js.map +1 -1
  720. package/lib/util/bufferPool.d.ts.map +1 -1
  721. package/lib/util/bufferPool.js +2 -1
  722. package/lib/util/bufferPool.js.map +1 -1
  723. package/lib/util/chunkify.js.map +1 -1
  724. package/lib/util/clock.d.ts +6 -0
  725. package/lib/util/clock.d.ts.map +1 -1
  726. package/lib/util/clock.js +11 -4
  727. package/lib/util/clock.js.map +1 -1
  728. package/lib/util/dataColumns.d.ts +11 -3
  729. package/lib/util/dataColumns.d.ts.map +1 -1
  730. package/lib/util/dataColumns.js +36 -3
  731. package/lib/util/dataColumns.js.map +1 -1
  732. package/lib/util/dependentRoot.js.map +1 -1
  733. package/lib/util/enum.js.map +1 -1
  734. package/lib/util/error.js.map +1 -1
  735. package/lib/util/eventLoop.js.map +1 -1
  736. package/lib/util/execution.d.ts.map +1 -1
  737. package/lib/util/execution.js +19 -9
  738. package/lib/util/execution.js.map +1 -1
  739. package/lib/util/file.js.map +1 -1
  740. package/lib/util/forkChoice.js.map +1 -1
  741. package/lib/util/forkName.js.map +1 -1
  742. package/lib/util/graffiti.js.map +1 -1
  743. package/lib/util/hex.js.map +1 -1
  744. package/lib/util/ip.js.map +1 -1
  745. package/lib/util/itTrigger.d.ts.map +1 -1
  746. package/lib/util/itTrigger.js.map +1 -1
  747. package/lib/util/map.d.ts.map +1 -1
  748. package/lib/util/map.js.map +1 -1
  749. package/lib/util/metadata.js.map +1 -1
  750. package/lib/util/multifork.d.ts +8 -0
  751. package/lib/util/multifork.d.ts.map +1 -1
  752. package/lib/util/multifork.js +37 -0
  753. package/lib/util/multifork.js.map +1 -1
  754. package/lib/util/numpy.js.map +1 -1
  755. package/lib/util/peerId.js.map +1 -1
  756. package/lib/util/profile.js +2 -1
  757. package/lib/util/profile.js.map +1 -1
  758. package/lib/util/promises.js.map +1 -1
  759. package/lib/util/queue/errors.js +2 -1
  760. package/lib/util/queue/errors.js.map +1 -1
  761. package/lib/util/queue/fnQueue.d.ts.map +1 -1
  762. package/lib/util/queue/fnQueue.js.map +1 -1
  763. package/lib/util/queue/itemQueue.d.ts.map +1 -1
  764. package/lib/util/queue/itemQueue.js.map +1 -1
  765. package/lib/util/queue/options.js +2 -1
  766. package/lib/util/queue/options.js.map +1 -1
  767. package/lib/util/serializedCache.d.ts +4 -4
  768. package/lib/util/serializedCache.d.ts.map +1 -1
  769. package/lib/util/serializedCache.js +6 -4
  770. package/lib/util/serializedCache.js.map +1 -1
  771. package/lib/util/set.d.ts.map +1 -1
  772. package/lib/util/set.js.map +1 -1
  773. package/lib/util/shuffle.js.map +1 -1
  774. package/lib/util/sortBy.js.map +1 -1
  775. package/lib/util/sszBytes.js.map +1 -1
  776. package/lib/util/time.js.map +1 -1
  777. package/lib/util/timeSeries.d.ts.map +1 -1
  778. package/lib/util/timeSeries.js.map +1 -1
  779. package/lib/util/types.d.ts.map +1 -1
  780. package/lib/util/workerEvents.d.ts +1 -1
  781. package/lib/util/workerEvents.d.ts.map +1 -1
  782. package/lib/util/workerEvents.js.map +1 -1
  783. package/lib/util/wrapError.js.map +1 -1
  784. package/package.json +42 -44
  785. package/src/api/impl/beacon/blocks/index.ts +158 -3
  786. package/src/api/impl/beacon/state/index.ts +8 -8
  787. package/src/api/impl/beacon/state/utils.ts +15 -29
  788. package/src/api/impl/debug/index.ts +9 -5
  789. package/src/api/impl/node/utils.ts +3 -3
  790. package/src/api/impl/validator/index.ts +153 -17
  791. package/src/chain/archiveStore/archiveStore.ts +15 -5
  792. package/src/chain/archiveStore/historicalState/getHistoricalState.ts +10 -11
  793. package/src/chain/archiveStore/historicalState/worker.ts +3 -3
  794. package/src/chain/archiveStore/utils/archiveBlocks.ts +4 -5
  795. package/src/chain/archiveStore/utils/archivePayloads.ts +15 -0
  796. package/src/chain/archiveStore/utils/updateBackfillRange.ts +1 -1
  797. package/src/chain/blocks/blockInput/blockInput.ts +103 -3
  798. package/src/chain/blocks/blockInput/types.ts +18 -0
  799. package/src/chain/blocks/importBlock.ts +36 -5
  800. package/src/chain/blocks/verifyBlocksDataAvailability.ts +3 -0
  801. package/src/chain/blocks/verifyBlocksExecutionPayloads.ts +9 -2
  802. package/src/chain/blocks/verifyBlocksSanityChecks.ts +7 -2
  803. package/src/chain/blocks/writeBlockInputToDb.ts +105 -104
  804. package/src/chain/bls/multithread/index.ts +7 -7
  805. package/src/chain/bls/multithread/jobItem.ts +3 -3
  806. package/src/chain/bls/singleThread.ts +5 -5
  807. package/src/chain/bls/utils.ts +8 -5
  808. package/src/chain/chain.ts +86 -47
  809. package/src/chain/emitter.ts +5 -5
  810. package/src/chain/errors/executionPayloadBid.ts +1 -1
  811. package/src/chain/errors/executionPayloadEnvelope.ts +6 -2
  812. package/src/chain/errors/payloadAttestation.ts +1 -1
  813. package/src/chain/forkChoice/index.ts +39 -21
  814. package/src/chain/interface.ts +4 -11
  815. package/src/chain/opPools/aggregatedAttestationPool.ts +1 -1
  816. package/src/chain/options.ts +1 -0
  817. package/src/chain/prepareNextSlot.ts +5 -5
  818. package/src/chain/produceBlock/computeNewStateRoot.ts +36 -3
  819. package/src/chain/produceBlock/produceBlockBody.ts +170 -14
  820. package/src/chain/regen/queued.ts +7 -2
  821. package/src/chain/regen/regen.ts +9 -3
  822. package/src/chain/seenCache/seenGossipBlockInput.ts +56 -18
  823. package/src/chain/validation/aggregateAndProof.ts +1 -1
  824. package/src/chain/validation/attestation.ts +14 -7
  825. package/src/chain/validation/attesterSlashing.ts +10 -1
  826. package/src/chain/validation/blobSidecar.ts +2 -2
  827. package/src/chain/validation/block.ts +9 -4
  828. package/src/chain/validation/dataColumnSidecar.ts +149 -132
  829. package/src/chain/validation/executionPayloadBid.ts +1 -2
  830. package/src/chain/validation/executionPayloadEnvelope.ts +4 -4
  831. package/src/chain/validation/payloadAttestationMessage.ts +10 -3
  832. package/src/chain/validation/proposerSlashing.ts +1 -1
  833. package/src/chain/validation/syncCommitteeContributionAndProof.ts +1 -1
  834. package/src/db/beacon.ts +8 -0
  835. package/src/db/buckets.ts +3 -0
  836. package/src/db/index.ts +1 -0
  837. package/src/db/interface.ts +5 -0
  838. package/src/db/repositories/blockArchive.ts +1 -2
  839. package/src/db/repositories/dataColumnSidecar.ts +18 -3
  840. package/src/db/repositories/dataColumnSidecarArchive.ts +18 -3
  841. package/src/db/repositories/executionPayloadEnvelope.ts +26 -0
  842. package/src/db/repositories/executionPayloadEnvelopeArchive.ts +32 -0
  843. package/src/db/repositories/index.ts +2 -0
  844. package/src/execution/engine/http.ts +3 -0
  845. package/src/metrics/metrics/beacon.ts +14 -3
  846. package/src/metrics/metrics/lodestar.ts +48 -24
  847. package/src/monitoring/service.ts +3 -2
  848. package/src/network/core/networkCore.ts +3 -3
  849. package/src/network/core/networkCoreWorkerHandler.ts +3 -3
  850. package/src/network/core/types.ts +2 -2
  851. package/src/network/discv5/utils.ts +5 -4
  852. package/src/network/events.ts +2 -1
  853. package/src/network/gossip/encoding.ts +3 -3
  854. package/src/network/gossip/gossipsub.ts +98 -32
  855. package/src/network/gossip/interface.ts +6 -6
  856. package/src/network/gossip/scoringParameters.ts +4 -4
  857. package/src/network/gossip/topic.ts +2 -1
  858. package/src/network/interface.ts +7 -4
  859. package/src/network/libp2p/index.ts +48 -21
  860. package/src/network/metadata.ts +1 -0
  861. package/src/network/network.ts +26 -7
  862. package/src/network/options.ts +8 -1
  863. package/src/network/peers/datastore.ts +13 -10
  864. package/src/network/peers/discover.ts +46 -11
  865. package/src/network/peers/peerManager.ts +118 -54
  866. package/src/network/peers/utils/prioritizePeers.ts +3 -3
  867. package/src/network/processor/gossipHandlers.ts +19 -4
  868. package/src/network/processor/gossipValidatorFn.ts +2 -2
  869. package/src/network/processor/types.ts +1 -1
  870. package/src/network/reqresp/ReqRespBeaconNode.ts +1 -1
  871. package/src/network/reqresp/handlers/beaconBlocksByRange.ts +4 -3
  872. package/src/network/reqresp/handlers/blobSidecarsByRange.ts +3 -2
  873. package/src/network/reqresp/handlers/blobSidecarsByRoot.ts +1 -1
  874. package/src/network/reqresp/handlers/dataColumnSidecarsByRange.ts +4 -3
  875. package/src/network/reqresp/handlers/dataColumnSidecarsByRoot.ts +2 -2
  876. package/src/network/reqresp/score.ts +0 -1
  877. package/src/network/reqresp/utils/collect.ts +1 -1
  878. package/src/network/reqresp/utils/collectSequentialBlocksInRange.ts +1 -1
  879. package/src/network/util.ts +2 -2
  880. package/src/node/nodejs.ts +8 -9
  881. package/src/sync/range/range.ts +1 -0
  882. package/src/sync/utils/downloadByRange.ts +12 -3
  883. package/src/sync/utils/downloadByRoot.ts +2 -2
  884. package/src/sync/utils/remoteSyncType.ts +1 -1
  885. package/src/util/blobs.ts +3 -3
  886. package/src/util/clock.ts +9 -4
  887. package/src/util/dataColumns.ts +43 -3
  888. package/src/util/execution.ts +23 -12
  889. package/src/util/multifork.ts +45 -0
  890. package/src/util/serializedCache.ts +7 -5
  891. package/src/util/workerEvents.ts +1 -1
@@ -23,7 +23,7 @@ export declare function wireEventsOnWorkerThread<EventData>(mainEventName: strin
23
23
  export declare function wireEventsOnMainThread<EventData>(mainEventName: string, events: StrictEventEmitterSingleArg<EventData>, worker: Pick<Worker, "on" | "postMessage">, metrics: Metrics | null, isWorkerToMain: {
24
24
  [K in keyof EventData]: EventDirection;
25
25
  }): void;
26
- export declare function terminateWorkerThread({ worker, retryMs, retryCount, logger, }: {
26
+ export declare function terminateWorkerThread({ worker, retryMs, retryCount, logger }: {
27
27
  worker: Thread;
28
28
  retryMs: number;
29
29
  retryCount: number;
@@ -1 +1 @@
1
- {"version":3,"file":"workerEvents.d.ts","sourceRoot":"","sources":["../../src/util/workerEvents.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,WAAW,EAAE,MAAM,EAAC,MAAM,qBAAqB,CAAC;AAExD,OAAO,EAAC,MAAM,EAAC,MAAM,oBAAoB,CAAC;AAC1C,OAAO,EAAC,MAAM,EAAC,MAAM,kBAAkB,CAAC;AAExC,OAAO,EAAC,OAAO,EAAC,MAAM,uBAAuB,CAAC;AAC9C,OAAO,EAAC,wBAAwB,EAAC,MAAM,4BAA4B,CAAC;AACpE,OAAO,EAAC,cAAc,EAAe,MAAM,sBAAsB,CAAC;AAClE,OAAO,EAAC,2BAA2B,EAAC,MAAM,mBAAmB,CAAC;AAI9D,MAAM,MAAM,iBAAiB,CAAC,SAAS,IAAI;IACzC,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,SAAS,CAAC;IACvB,MAAM,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACzB,IAAI,EAAE,SAAS,CAAC,MAAM,SAAS,CAAC,CAAC;CAClC,CAAC;AAEF;;;;;GAKG;AACH,wBAAgB,wBAAwB,CAAC,SAAS,EAChD,aAAa,EAAE,MAAM,EACrB,MAAM,EAAE,2BAA2B,CAAC,SAAS,CAAC,EAC9C,UAAU,EAAE,WAAW,EACvB,OAAO,EAAE,wBAAwB,GAAG,IAAI,EACxC,cAAc,EAAE;KAAE,CAAC,IAAI,MAAM,SAAS,GAAG,cAAc;CAAC,GACvD,IAAI,CAuCN;AAED,wBAAgB,sBAAsB,CAAC,SAAS,EAC9C,aAAa,EAAE,MAAM,EACrB,MAAM,EAAE,2BAA2B,CAAC,SAAS,CAAC,EAC9C,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,GAAG,aAAa,CAAC,EAC1C,OAAO,EAAE,OAAO,GAAG,IAAI,EACvB,cAAc,EAAE;KAAE,CAAC,IAAI,MAAM,SAAS,GAAG,cAAc;CAAC,GACvD,IAAI,CAiCN;AAED,wBAAsB,qBAAqB,CAAC,EAC1C,MAAM,EACN,OAAO,EACP,UAAU,EACV,MAAM,GACP,EAAE;IACD,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB,GAAG,OAAO,CAAC,IAAI,CAAC,CAmBhB"}
1
+ {"version":3,"file":"workerEvents.d.ts","sourceRoot":"","sources":["../../src/util/workerEvents.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,WAAW,EAAE,MAAM,EAAC,MAAM,qBAAqB,CAAC;AAExD,OAAO,EAAC,MAAM,EAAC,MAAM,oBAAoB,CAAC;AAC1C,OAAO,EAAC,MAAM,EAAC,MAAM,kBAAkB,CAAC;AAExC,OAAO,EAAC,OAAO,EAAC,MAAM,uBAAuB,CAAC;AAC9C,OAAO,EAAC,wBAAwB,EAAC,MAAM,4BAA4B,CAAC;AACpE,OAAO,EAAC,cAAc,EAAe,MAAM,sBAAsB,CAAC;AAClE,OAAO,EAAC,2BAA2B,EAAC,MAAM,mBAAmB,CAAC;AAI9D,MAAM,MAAM,iBAAiB,CAAC,SAAS,IAAI;IACzC,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,SAAS,CAAC;IACvB,MAAM,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACzB,IAAI,EAAE,SAAS,CAAC,MAAM,SAAS,CAAC,CAAC;CAClC,CAAC;AAEF;;;;;GAKG;AACH,wBAAgB,wBAAwB,CAAC,SAAS,EAChD,aAAa,EAAE,MAAM,EACrB,MAAM,EAAE,2BAA2B,CAAC,SAAS,CAAC,EAC9C,UAAU,EAAE,WAAW,EACvB,OAAO,EAAE,wBAAwB,GAAG,IAAI,EACxC,cAAc,EAAE;KAAE,CAAC,IAAI,MAAM,SAAS,GAAG,cAAc;CAAC,GACvD,IAAI,CAuCN;AAED,wBAAgB,sBAAsB,CAAC,SAAS,EAC9C,aAAa,EAAE,MAAM,EACrB,MAAM,EAAE,2BAA2B,CAAC,SAAS,CAAC,EAC9C,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,GAAG,aAAa,CAAC,EAC1C,OAAO,EAAE,OAAO,GAAG,IAAI,EACvB,cAAc,EAAE;KAAE,CAAC,IAAI,MAAM,SAAS,GAAG,cAAc;CAAC,GACvD,IAAI,CAiCN;AAED,wBAAsB,qBAAqB,CAAC,EAC1C,MAAM,EACN,OAAO,EACP,UAAU,EACV,MAAM,EACP,EAAE;IACD,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB,GAAG,OAAO,CAAC,IAAI,CAAC,CAmBhB"}
@@ -1 +1 @@
1
- {"version":3,"file":"workerEvents.js","sourceRoot":"","sources":["../../src/util/workerEvents.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"workerEvents.js","sourceRoot":"","sources":["../../src/util/workerEvents.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"wrapError.js","sourceRoot":"","sources":["../../src/util/wrapError.ts"],"names":[],"mappings":"AAEA;;;;;;;;;;;;GAYG;AACH,MAAM,CAAC,KAAK,UAAU,SAAS,CAAI,OAAmB;IACpD,IAAI,CAAC;QACH,OAAO,EAAC,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,OAAO,EAAC,CAAC;IAC5C,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO,EAAC,GAAG,EAAE,GAAY,EAAC,CAAC;IAC7B,CAAC;AACH,CAAC"}
1
+ {"version":3,"file":"wrapError.js","sourceRoot":"","sources":["../../src/util/wrapError.ts"],"names":[],"mappings":"AAEA;;;;;;;;;;;;GAYG;AACH,MAAM,CAAC,KAAK,UAAU,SAAS,CAAI,OAAmB,EAAsB;IAC1E,IAAI,CAAC;QACH,OAAO,EAAC,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,OAAO,EAAC,CAAC;IAC5C,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO,EAAC,GAAG,EAAE,GAAY,EAAC,CAAC;IAC7B,CAAC;AAAA,CACF"}
package/package.json CHANGED
@@ -11,7 +11,7 @@
11
11
  "bugs": {
12
12
  "url": "https://github.com/ChainSafe/lodestar/issues"
13
13
  },
14
- "version": "1.41.0-dev.983b1a457b",
14
+ "version": "1.41.0-dev.9939b12b53",
15
15
  "type": "module",
16
16
  "exports": {
17
17
  ".": {
@@ -87,11 +87,11 @@
87
87
  ],
88
88
  "scripts": {
89
89
  "clean": "rm -rf lib && rm -f *.tsbuildinfo",
90
- "build": "tsc -p tsconfig.build.json",
90
+ "build": "tsgo -p tsconfig.build.json",
91
91
  "build:watch": "pnpm run build --watch",
92
92
  "build:release": "pnpm clean && pnpm run build",
93
93
  "check-build": "node -e \"(async function() { await import('./lib/index.js') })()\"",
94
- "check-types": "tsc",
94
+ "check-types": "tsgo",
95
95
  "lint": "biome check src/ test/",
96
96
  "lint:fix": "pnpm run lint --write",
97
97
  "test": "pnpm test:unit && pnpm test:e2e",
@@ -110,10 +110,10 @@
110
110
  "dependencies": {
111
111
  "@chainsafe/as-sha256": "^1.2.0",
112
112
  "@chainsafe/blst": "^2.2.0",
113
- "@chainsafe/discv5": "^11.0.4",
114
- "@chainsafe/enr": "^5.0.1",
115
- "@chainsafe/libp2p-gossipsub": "^14.1.2",
116
- "@chainsafe/libp2p-noise": "^16.1.5",
113
+ "@chainsafe/discv5": "^12.0.1",
114
+ "@chainsafe/enr": "^6.0.1",
115
+ "@chainsafe/libp2p-noise": "^17.0.0",
116
+ "@chainsafe/libp2p-quic": "^2.0.0",
117
117
  "@chainsafe/persistent-merkle-tree": "^1.2.1",
118
118
  "@chainsafe/prometheus-gc-stats": "^1.0.0",
119
119
  "@chainsafe/pubkey-index-map": "^3.0.0",
@@ -125,39 +125,38 @@
125
125
  "@fastify/cors": "^10.0.1",
126
126
  "@fastify/swagger": "^9.0.0",
127
127
  "@fastify/swagger-ui": "^5.0.1",
128
- "@libp2p/bootstrap": "^11.0.32",
129
- "@libp2p/crypto": "^5.0.15",
130
- "@libp2p/identify": "^3.0.27",
131
- "@libp2p/interface": "^2.7.0",
132
- "@libp2p/mdns": "^11.0.32",
133
- "@libp2p/mplex": "^11.0.32",
134
- "@libp2p/peer-id": "^5.1.0",
135
- "@libp2p/prometheus-metrics": "^4.3.15",
136
- "@libp2p/tcp": "^10.1.8",
137
- "@lodestar/api": "^1.41.0-dev.983b1a457b",
138
- "@lodestar/config": "^1.41.0-dev.983b1a457b",
139
- "@lodestar/db": "^1.41.0-dev.983b1a457b",
140
- "@lodestar/fork-choice": "^1.41.0-dev.983b1a457b",
141
- "@lodestar/light-client": "^1.41.0-dev.983b1a457b",
142
- "@lodestar/logger": "^1.41.0-dev.983b1a457b",
143
- "@lodestar/params": "^1.41.0-dev.983b1a457b",
144
- "@lodestar/reqresp": "^1.41.0-dev.983b1a457b",
145
- "@lodestar/state-transition": "^1.41.0-dev.983b1a457b",
146
- "@lodestar/types": "^1.41.0-dev.983b1a457b",
147
- "@lodestar/utils": "^1.41.0-dev.983b1a457b",
148
- "@lodestar/validator": "^1.41.0-dev.983b1a457b",
149
- "@multiformats/multiaddr": "^12.1.3",
150
- "datastore-core": "^10.0.2",
151
- "datastore-fs": "^10.0.6",
152
- "datastore-level": "^11.0.3",
128
+ "@libp2p/bootstrap": "^12.0.14",
129
+ "@libp2p/crypto": "^5.1.13",
130
+ "@libp2p/gossipsub": "^15.0.15",
131
+ "@libp2p/identify": "^4.0.13",
132
+ "@libp2p/interface": "^3.1.0",
133
+ "@libp2p/mdns": "^12.0.14",
134
+ "@libp2p/mplex": "^12.0.14",
135
+ "@libp2p/peer-id": "^6.0.4",
136
+ "@libp2p/prometheus-metrics": "^5.0.14",
137
+ "@libp2p/tcp": "^11.0.13",
138
+ "@lodestar/api": "^1.41.0-dev.9939b12b53",
139
+ "@lodestar/config": "^1.41.0-dev.9939b12b53",
140
+ "@lodestar/db": "^1.41.0-dev.9939b12b53",
141
+ "@lodestar/fork-choice": "^1.41.0-dev.9939b12b53",
142
+ "@lodestar/light-client": "^1.41.0-dev.9939b12b53",
143
+ "@lodestar/logger": "^1.41.0-dev.9939b12b53",
144
+ "@lodestar/params": "^1.41.0-dev.9939b12b53",
145
+ "@lodestar/reqresp": "^1.41.0-dev.9939b12b53",
146
+ "@lodestar/state-transition": "^1.41.0-dev.9939b12b53",
147
+ "@lodestar/types": "^1.41.0-dev.9939b12b53",
148
+ "@lodestar/utils": "^1.41.0-dev.9939b12b53",
149
+ "@lodestar/validator": "^1.41.0-dev.9939b12b53",
150
+ "@multiformats/multiaddr": "^13.0.1",
151
+ "datastore-core": "^11.0.2",
152
+ "datastore-fs": "^11.0.2",
153
+ "datastore-level": "^12.0.2",
153
154
  "deepmerge": "^4.3.1",
154
- "fastify": "^5.7.4",
155
- "interface-datastore": "^8.3.0",
156
- "it-all": "^3.0.4",
157
- "it-pipe": "^3.0.1",
155
+ "fastify": "^5.8.1",
156
+ "interface-datastore": "^9.0.2",
158
157
  "jwt-simple": "0.5.6",
159
- "libp2p": "2.9.0",
160
- "multiformats": "^11.0.1",
158
+ "libp2p": "3.1.6",
159
+ "multiformats": "^13.4.2",
161
160
  "prom-client": "^15.1.0",
162
161
  "qs": "^6.11.1",
163
162
  "strict-event-emitter-types": "^2.0.0",
@@ -167,14 +166,13 @@
167
166
  },
168
167
  "devDependencies": {
169
168
  "@chainsafe/swap-or-not-shuffle": "^1.2.1",
170
- "@libp2p/interface-internal": "^2.3.18",
171
- "@libp2p/logger": "^5.1.21",
172
- "@lodestar/spec-test-util": "^1.41.0-dev.983b1a457b",
169
+ "@libp2p/interface-internal": "^3.0.13",
170
+ "@libp2p/logger": "^6.2.2",
171
+ "@libp2p/utils": "^7.0.13",
172
+ "@lodestar/spec-test-util": "^1.41.0-dev.9939b12b53",
173
173
  "@types/js-yaml": "^4.0.5",
174
174
  "@types/qs": "^6.9.7",
175
175
  "@types/tmp": "^0.2.3",
176
- "it-drain": "^3.0.3",
177
- "it-pair": "^2.0.6",
178
176
  "js-yaml": "^4.1.0",
179
177
  "rewiremock": "^3.14.5",
180
178
  "rimraf": "^4.4.1",
@@ -188,5 +186,5 @@
188
186
  "beacon",
189
187
  "blockchain"
190
188
  ],
191
- "gitHead": "d0034e9223f28c09795b995a40b444854b43ac27"
189
+ "gitHead": "7c7673dc183b06b98e957b426f675af262af91b2"
192
190
  }
@@ -1,6 +1,8 @@
1
1
  import {routes} from "@lodestar/api";
2
2
  import {ApiError, ApplicationMethods} from "@lodestar/api/server";
3
+ import {PayloadStatus} from "@lodestar/fork-choice";
3
4
  import {
5
+ BUILDER_INDEX_SELF_BUILD,
4
6
  ForkPostBellatrix,
5
7
  ForkPostFulu,
6
8
  ForkPreGloas,
@@ -27,6 +29,7 @@ import {
27
29
  WithOptionalBytes,
28
30
  deneb,
29
31
  fulu,
32
+ gloas,
30
33
  isDenebBlockContents,
31
34
  sszTypesFor,
32
35
  } from "@lodestar/types";
@@ -42,6 +45,7 @@ import {
42
45
  ProduceFullBellatrix,
43
46
  ProduceFullDeneb,
44
47
  ProduceFullFulu,
48
+ ProduceFullGloas,
45
49
  } from "../../../../chain/produceBlock/index.js";
46
50
  import {validateGossipBlock} from "../../../../chain/validation/block.js";
47
51
  import {OpSource} from "../../../../chain/validatorMonitor.js";
@@ -51,7 +55,7 @@ import {
51
55
  kzgCommitmentToVersionedHash,
52
56
  reconstructBlobs,
53
57
  } from "../../../../util/blobs.js";
54
- import {getDataColumnSidecarsFromBlock} from "../../../../util/dataColumns.js";
58
+ import {getDataColumnSidecarsForGloas, getDataColumnSidecarsFromBlock} from "../../../../util/dataColumns.js";
55
59
  import {isOptimisticBlock} from "../../../../util/forkChoice.js";
56
60
  import {kzg} from "../../../../util/kzg.js";
57
61
  import {promiseAllMaybeAsync} from "../../../../util/promises.js";
@@ -93,6 +97,7 @@ export function getBeaconBlockApi({
93
97
  const fork = config.getForkName(slot);
94
98
  const blockRoot = toRootHex(chain.config.getForkTypes(slot).BeaconBlock.hashTreeRoot(signedBlock.message));
95
99
 
100
+ // TODO GLOAS: handle new BlockInput type
96
101
  const blockForImport = chain.seenBlockInputCache.getByBlock({
97
102
  block: signedBlock,
98
103
  source: BlockInputSource.api,
@@ -201,7 +206,7 @@ export function getBeaconBlockApi({
201
206
  case routes.beacon.BroadcastValidation.consensus: {
202
207
  // check if this beacon node produced the block else run validations
203
208
  if (!blockLocallyProduced) {
204
- const parentBlock = chain.forkChoice.getBlock(signedBlock.message.parentRoot);
209
+ const parentBlock = chain.forkChoice.getBlockDefaultStatus(signedBlock.message.parentRoot);
205
210
  if (parentBlock === null) {
206
211
  chain.emitter.emit(ChainEvent.unknownParent, {
207
212
  blockInput: blockForImport,
@@ -309,7 +314,9 @@ export function getBeaconBlockApi({
309
314
  ];
310
315
  const sentPeersArr = await promiseAllMaybeAsync<number | void>(publishPromises);
311
316
 
312
- if (isForkPostFulu(fork)) {
317
+ if (isForkPostGloas(fork)) {
318
+ // After gloas, data columns are not published with the block but when publishing the execution payload envelope
319
+ } else if (isForkPostFulu(fork)) {
313
320
  let columnsPublishedWithZeroPeers = 0;
314
321
  // sent peers per topic are logged in network.publishGossip(), here we only track metrics for it
315
322
  // starting from fulu, we have to push to 128 subnets so need to make sure we have enough sent peers per topic
@@ -632,6 +639,143 @@ export function getBeaconBlockApi({
632
639
  await publishBlock(args, context, opts);
633
640
  },
634
641
 
642
+ async publishExecutionPayloadEnvelope({signedExecutionPayloadEnvelope}) {
643
+ const seenTimestampSec = Date.now() / 1000;
644
+ const envelope = signedExecutionPayloadEnvelope.message;
645
+ const slot = envelope.slot;
646
+ const fork = config.getForkName(slot);
647
+ const blockRootHex = toRootHex(envelope.beaconBlockRoot);
648
+
649
+ if (!isForkPostGloas(fork)) {
650
+ throw new ApiError(400, `publishExecutionPayloadEnvelope not supported for pre-gloas fork=${fork}`);
651
+ }
652
+
653
+ // TODO GLOAS: review checks, do we want to implement `broadcast_validation`?
654
+ const block = chain.forkChoice.getBlockHex(blockRootHex, PayloadStatus.EMPTY);
655
+ if (block === null) {
656
+ throw new ApiError(404, `Block not found for beacon block root ${blockRootHex}`);
657
+ }
658
+ if (block.slot !== slot) {
659
+ throw new ApiError(400, `Envelope slot ${slot} does not match block slot ${block.slot}`);
660
+ }
661
+
662
+ const isSelfBuild = envelope.builderIndex === BUILDER_INDEX_SELF_BUILD;
663
+ let dataColumnSidecars: gloas.DataColumnSidecars = [];
664
+
665
+ if (isSelfBuild) {
666
+ // For self-builds, construct and publish data column sidecars from cached block production data
667
+ const cachedResult = chain.blockProductionCache.get(blockRootHex) as ProduceFullGloas | undefined;
668
+ if (cachedResult === undefined) {
669
+ throw new ApiError(404, `No cached block production result found for block root ${blockRootHex}`);
670
+ }
671
+ if (!isForkPostGloas(cachedResult.fork)) {
672
+ throw new ApiError(400, `Cached block production result is for pre-gloas fork=${cachedResult.fork}`);
673
+ }
674
+ if (cachedResult.type !== BlockType.Full) {
675
+ throw new ApiError(400, "Cached block production result is not full block");
676
+ }
677
+
678
+ if (cachedResult.cells && cachedResult.blobsBundle.commitments.length > 0) {
679
+ const cellsAndProofs = cachedResult.cells.map((rowCells, rowIndex) => ({
680
+ cells: rowCells,
681
+ proofs: cachedResult.blobsBundle.proofs.slice(
682
+ rowIndex * NUMBER_OF_COLUMNS,
683
+ (rowIndex + 1) * NUMBER_OF_COLUMNS
684
+ ),
685
+ }));
686
+
687
+ dataColumnSidecars = getDataColumnSidecarsForGloas(slot, envelope.beaconBlockRoot, cellsAndProofs);
688
+ }
689
+ } else {
690
+ // TODO GLOAS: will this api be used by builders or only for self-building?
691
+ }
692
+
693
+ // TODO GLOAS: Verify execution payload envelope signature
694
+ // For self-builds, the proposer signs with their own validator key
695
+ // For external builders, verify using the builder's registered pubkey
696
+ // Use verify_execution_payload_envelope_signature(state, signed_envelope)
697
+
698
+ // TODO GLOAS: Process execution payload via state transition
699
+ // Call process_execution_payload(state, signed_envelope, execution_engine)
700
+
701
+ // TODO GLOAS: Update fork choice with the execution payload
702
+ // Call on_execution_payload(store, signed_envelope) to update fork choice state
703
+
704
+ // TODO GLOAS: Add envelope and data columns to block input via seenBlockInputCache
705
+ // and trigger block import (Gloas block import requires both beacon block and envelope)
706
+
707
+ const valLogMeta = {
708
+ slot,
709
+ blockRoot: blockRootHex,
710
+ builderIndex: envelope.builderIndex,
711
+ isSelfBuild,
712
+ dataColumns: dataColumnSidecars.length,
713
+ };
714
+
715
+ // If called near a slot boundary (e.g. late in slot N-1), hold briefly so gossip aligns with slot N.
716
+ const msToBlockSlot = computeTimeAtSlot(config, slot, chain.genesisTime) * 1000 - Date.now();
717
+ if (msToBlockSlot <= MAX_API_CLOCK_DISPARITY_MS && msToBlockSlot > 0) {
718
+ await sleep(msToBlockSlot);
719
+ }
720
+
721
+ const delaySec = seenTimestampSec - computeTimeAtSlot(config, slot, chain.genesisTime);
722
+ metrics?.gossipExecutionPayloadEnvelope.elapsedTimeTillReceived.observe({source: OpSource.api}, delaySec);
723
+
724
+ chain.logger.info("Publishing execution payload envelope", valLogMeta);
725
+
726
+ // Publish envelope and data columns
727
+ const publishPromises = [
728
+ // Gossip the signed execution payload envelope first
729
+ () => network.publishSignedExecutionPayloadEnvelope(signedExecutionPayloadEnvelope),
730
+ // For self-builds, publish all data column sidecars
731
+ ...dataColumnSidecars.map((dataColumnSidecar) => () => network.publishDataColumnSidecar(dataColumnSidecar)),
732
+ ];
733
+
734
+ const sentPeersArr = await promiseAllMaybeAsync<number | void>(publishPromises);
735
+
736
+ // Track metrics for data column publishing
737
+ if (dataColumnSidecars.length > 0) {
738
+ let columnsPublishedWithZeroPeers = 0;
739
+ // Skip first entry (envelope), track data columns
740
+ for (let i = 1; i < sentPeersArr.length; i++) {
741
+ const sentPeers = sentPeersArr[i] as number;
742
+ metrics?.dataColumns.sentPeersPerSubnet.observe(sentPeers);
743
+ if (sentPeers === 0) {
744
+ columnsPublishedWithZeroPeers++;
745
+ }
746
+ }
747
+ if (columnsPublishedWithZeroPeers > 0) {
748
+ chain.logger.warn("Published data columns to 0 peers, increased risk of reorg", {
749
+ slot,
750
+ blockRoot: blockRootHex,
751
+ columns: columnsPublishedWithZeroPeers,
752
+ });
753
+ }
754
+
755
+ metrics?.dataColumns.bySource.inc({source: BlockInputSource.api}, dataColumnSidecars.length);
756
+
757
+ if (chain.emitter.listenerCount(routes.events.EventType.dataColumnSidecar)) {
758
+ // TODO GLOAS: revisit this, we likely don't wanna emit KZG commitments anymore
759
+ const cachedResult = chain.blockProductionCache.get(blockRootHex) as ProduceFullGloas | undefined;
760
+ const kzgCommitments = cachedResult?.blobsBundle.commitments.map(toHex) ?? [];
761
+ for (const dataColumnSidecar of dataColumnSidecars) {
762
+ chain.emitter.emit(routes.events.EventType.dataColumnSidecar, {
763
+ blockRoot: blockRootHex,
764
+ slot,
765
+ index: dataColumnSidecar.index,
766
+ kzgCommitments,
767
+ });
768
+ }
769
+ }
770
+ }
771
+
772
+ chain.logger.info("Published execution payload envelope", {
773
+ ...valLogMeta,
774
+ delaySec,
775
+ sentPeers: (sentPeersArr[0] as number) ?? 0,
776
+ });
777
+ },
778
+
635
779
  async getBlobSidecars({blockId, indices}) {
636
780
  assertUniqueItems(indices, "Duplicate indices provided");
637
781
 
@@ -671,11 +815,18 @@ export function getBeaconBlockApi({
671
815
  }
672
816
 
673
817
  const indicesToReconstruct = indices ?? Array.from({length: blobCount}, (_, i) => i);
818
+
819
+ const timer = metrics?.recoverBlobSidecars.reconstructionTime.startTimer();
674
820
  const blobs = await reconstructBlobs(dataColumnSidecars, indicesToReconstruct);
821
+ timer?.();
822
+ metrics?.recoverBlobSidecars.blobsReconstructed.inc(indicesToReconstruct.length);
823
+
675
824
  const signedBlockHeader = signedBlockToSignedHeader(config, block);
676
825
 
677
826
  data = await Promise.all(
678
827
  indicesToReconstruct.map(async (index, i) => {
828
+ // record per column computation time
829
+ const compTimer = metrics?.peerDas.dataColumnSidecarComputationTime.startTimer();
679
830
  // Reconstruct blob sidecar from blob
680
831
  const kzgCommitment = blobKzgCommitments[index];
681
832
  const blob = blobs[i]; // Use i since blobs only contains requested indices
@@ -685,6 +836,7 @@ export function getBeaconBlockApi({
685
836
  block.message.body,
686
837
  index
687
838
  );
839
+ compTimer?.();
688
840
  return {index, blob, kzgCommitment, kzgProof, signedBlockHeader, kzgCommitmentInclusionProof};
689
841
  })
690
842
  );
@@ -766,7 +918,10 @@ export function getBeaconBlockApi({
766
918
  indicesToReconstruct = Array.from({length: blobCount}, (_, i) => i);
767
919
  }
768
920
 
921
+ const timer = metrics?.peerDas.dataColumnsReconstructionTime.startTimer();
769
922
  blobs = await reconstructBlobs(dataColumnSidecars, indicesToReconstruct);
923
+ timer?.();
924
+ metrics?.peerDas.reconstructedColumns.inc(indicesToReconstruct.length);
770
925
  } else {
771
926
  blobs = [];
772
927
  }
@@ -95,14 +95,14 @@ export function getBeaconStateApi({
95
95
  const {state, executionOptimistic, finalized} = await getState(stateId);
96
96
  const currentEpoch = getCurrentEpoch(state);
97
97
  const {validators, balances} = state; // Get the validators sub tree once for all the loop
98
- const {pubkey2index} = chain;
98
+ const {pubkeyCache} = chain;
99
99
 
100
100
  const validatorResponses: routes.beacon.ValidatorResponse[] = [];
101
101
  if (validatorIds.length) {
102
102
  assertUniqueItems(validatorIds, "Duplicate validator IDs provided");
103
103
 
104
104
  for (const id of validatorIds) {
105
- const resp = getStateValidatorIndex(id, state, pubkey2index);
105
+ const resp = getStateValidatorIndex(id, state, pubkeyCache);
106
106
  if (resp.valid) {
107
107
  const validatorIndex = resp.validatorIndex;
108
108
  const validator = validators.getReadonly(validatorIndex);
@@ -127,7 +127,7 @@ export function getBeaconStateApi({
127
127
  if (statuses.length) {
128
128
  assertUniqueItems(statuses, "Duplicate statuses provided");
129
129
 
130
- const validatorsByStatus = filterStateValidatorsByStatus(statuses, state, pubkey2index, currentEpoch);
130
+ const validatorsByStatus = filterStateValidatorsByStatus(statuses, state, pubkeyCache, currentEpoch);
131
131
  return {
132
132
  data: validatorsByStatus,
133
133
  meta: {executionOptimistic, finalized},
@@ -154,7 +154,7 @@ export function getBeaconStateApi({
154
154
 
155
155
  async postStateValidatorIdentities({stateId, validatorIds = []}) {
156
156
  const {state, executionOptimistic, finalized} = await getState(stateId);
157
- const {pubkey2index} = chain;
157
+ const {pubkeyCache} = chain;
158
158
 
159
159
  let validatorIdentities: routes.beacon.ValidatorIdentities;
160
160
 
@@ -163,7 +163,7 @@ export function getBeaconStateApi({
163
163
 
164
164
  validatorIdentities = [];
165
165
  for (const id of validatorIds) {
166
- const resp = getStateValidatorIndex(id, state, pubkey2index);
166
+ const resp = getStateValidatorIndex(id, state, pubkeyCache);
167
167
  if (resp.valid) {
168
168
  const index = resp.validatorIndex;
169
169
  const {pubkey, activationEpoch} = state.validators.getReadonly(index);
@@ -187,9 +187,9 @@ export function getBeaconStateApi({
187
187
 
188
188
  async getStateValidator({stateId, validatorId}) {
189
189
  const {state, executionOptimistic, finalized} = await getState(stateId);
190
- const {pubkey2index} = chain;
190
+ const {pubkeyCache} = chain;
191
191
 
192
- const resp = getStateValidatorIndex(validatorId, state, pubkey2index);
192
+ const resp = getStateValidatorIndex(validatorId, state, pubkeyCache);
193
193
  if (!resp.valid) {
194
194
  throw new ApiError(resp.code, resp.reason);
195
195
  }
@@ -214,7 +214,7 @@ export function getBeaconStateApi({
214
214
 
215
215
  const balances: routes.beacon.ValidatorBalance[] = [];
216
216
  for (const id of validatorIds) {
217
- const resp = getStateValidatorIndex(id, state, chain.pubkey2index);
217
+ const resp = getStateValidatorIndex(id, state, chain.pubkeyCache);
218
218
 
219
219
  if (resp.valid) {
220
220
  balances.push({
@@ -1,9 +1,17 @@
1
- import {PubkeyIndexMap} from "@chainsafe/pubkey-index-map";
2
1
  import {routes} from "@lodestar/api";
3
2
  import {CheckpointWithHex, IForkChoice} from "@lodestar/fork-choice";
4
3
  import {GENESIS_SLOT} from "@lodestar/params";
5
- import {BeaconStateAllForks, CachedBeaconStateAllForks} from "@lodestar/state-transition";
6
- import {BLSPubkey, Epoch, RootHex, Slot, ValidatorIndex, getValidatorStatus, phase0} from "@lodestar/types";
4
+ import {BeaconStateAllForks, CachedBeaconStateAllForks, PubkeyCache} from "@lodestar/state-transition";
5
+ import {
6
+ BLSPubkey,
7
+ Epoch,
8
+ RootHex,
9
+ Slot,
10
+ ValidatorIndex,
11
+ getValidatorStatus,
12
+ mapToGeneralStatus,
13
+ phase0,
14
+ } from "@lodestar/types";
7
15
  import {fromHex} from "@lodestar/utils";
8
16
  import {IBeaconChain} from "../../../../chain/index.js";
9
17
  import {ApiError, ValidationError} from "../../errors.js";
@@ -65,28 +73,6 @@ export async function getStateResponseWithRegen(
65
73
  return res;
66
74
  }
67
75
 
68
- type GeneralValidatorStatus = "active" | "pending" | "exited" | "withdrawal";
69
-
70
- function mapToGeneralStatus(subStatus: routes.beacon.ValidatorStatus): GeneralValidatorStatus {
71
- switch (subStatus) {
72
- case "active_ongoing":
73
- case "active_exiting":
74
- case "active_slashed":
75
- return "active";
76
- case "pending_initialized":
77
- case "pending_queued":
78
- return "pending";
79
- case "exited_slashed":
80
- case "exited_unslashed":
81
- return "exited";
82
- case "withdrawal_possible":
83
- case "withdrawal_done":
84
- return "withdrawal";
85
- default:
86
- throw new Error(`Unknown substatus: ${subStatus}`);
87
- }
88
- }
89
-
90
76
  export function toValidatorResponse(
91
77
  index: ValidatorIndex,
92
78
  validator: phase0.Validator,
@@ -104,7 +90,7 @@ export function toValidatorResponse(
104
90
  export function filterStateValidatorsByStatus(
105
91
  statuses: string[],
106
92
  state: BeaconStateAllForks,
107
- pubkey2index: PubkeyIndexMap,
93
+ pubkeyCache: PubkeyCache,
108
94
  currentEpoch: Epoch
109
95
  ): routes.beacon.ValidatorResponse[] {
110
96
  const responses: routes.beacon.ValidatorResponse[] = [];
@@ -115,7 +101,7 @@ export function filterStateValidatorsByStatus(
115
101
  const validatorStatus = getValidatorStatus(validator, currentEpoch);
116
102
  const generalStatus = mapToGeneralStatus(validatorStatus);
117
103
 
118
- const resp = getStateValidatorIndex(validator.pubkey, state, pubkey2index);
104
+ const resp = getStateValidatorIndex(validator.pubkey, state, pubkeyCache);
119
105
  if (resp.valid && (statusSet.has(validatorStatus) || statusSet.has(generalStatus))) {
120
106
  responses.push(
121
107
  toValidatorResponse(resp.validatorIndex, validator, state.balances.get(resp.validatorIndex), currentEpoch)
@@ -132,7 +118,7 @@ type StateValidatorIndexResponse =
132
118
  export function getStateValidatorIndex(
133
119
  id: routes.beacon.ValidatorId | BLSPubkey,
134
120
  state: BeaconStateAllForks,
135
- pubkey2index: PubkeyIndexMap
121
+ pubkeyCache: PubkeyCache
136
122
  ): StateValidatorIndexResponse {
137
123
  if (typeof id === "string") {
138
124
  // mutate `id` and fallthrough to below
@@ -160,7 +146,7 @@ export function getStateValidatorIndex(
160
146
  }
161
147
 
162
148
  // typeof id === Uint8Array
163
- const validatorIndex = pubkey2index.get(id);
149
+ const validatorIndex = pubkeyCache.getIndex(id);
164
150
  if (validatorIndex === null) {
165
151
  return {valid: false, code: 404, reason: "Validator pubkey not found in state"};
166
152
  }
@@ -1,9 +1,10 @@
1
1
  import {routes} from "@lodestar/api";
2
2
  import {ApplicationMethods} from "@lodestar/api/server";
3
3
  import {ExecutionStatus} from "@lodestar/fork-choice";
4
- import {ZERO_HASH_HEX, isForkPostDeneb, isForkPostFulu} from "@lodestar/params";
5
- import {BeaconState, deneb, fulu, sszTypesFor} from "@lodestar/types";
4
+ import {ForkPostDeneb, ZERO_HASH_HEX, isForkPostDeneb, isForkPostFulu} from "@lodestar/params";
5
+ import {BeaconState, DataColumnSidecars, type SignedBeaconBlock, sszTypesFor} from "@lodestar/types";
6
6
  import {toRootHex} from "@lodestar/utils";
7
+ import {getBlobKzgCommitments} from "../../../util/dataColumns.js";
7
8
  import {isOptimisticBlock} from "../../../util/forkChoice.js";
8
9
  import {getStateSlotFromBytes} from "../../../util/multifork.js";
9
10
  import {getBlockResponse} from "../beacon/blocks/utils.js";
@@ -42,6 +43,7 @@ export function getDebugApi({
42
43
  validity: (() => {
43
44
  switch (node.executionStatus) {
44
45
  case ExecutionStatus.Valid:
46
+ case ExecutionStatus.PayloadSeparated:
45
47
  return "valid";
46
48
  case ExecutionStatus.Invalid:
47
49
  return "invalid";
@@ -96,10 +98,10 @@ export function getDebugApi({
96
98
  const fork = config.getForkName(block.message.slot);
97
99
  const blockRoot = sszTypesFor(fork).BeaconBlock.hashTreeRoot(block.message);
98
100
 
99
- let dataColumnSidecars: fulu.DataColumnSidecars;
101
+ let dataColumnSidecars: DataColumnSidecars;
100
102
 
101
103
  const blobCount = isForkPostDeneb(fork)
102
- ? (block.message.body as deneb.BeaconBlockBody).blobKzgCommitments.length
104
+ ? getBlobKzgCommitments(fork, block as SignedBeaconBlock<ForkPostDeneb>).length
103
105
  : 0;
104
106
 
105
107
  if (isForkPostFulu(fork) && blobCount > 0) {
@@ -115,7 +117,9 @@ export function getDebugApi({
115
117
  }
116
118
 
117
119
  return {
118
- data: indices ? dataColumnSidecars.filter(({index}) => indices.includes(index)) : dataColumnSidecars,
120
+ data: (indices
121
+ ? dataColumnSidecars.filter(({index}) => indices.includes(index))
122
+ : dataColumnSidecars) as DataColumnSidecars,
119
123
  meta: {
120
124
  executionOptimistic,
121
125
  finalized,
@@ -1,4 +1,4 @@
1
- import {Connection, StreamStatus} from "@libp2p/interface";
1
+ import type {Connection, ConnectionStatus} from "@libp2p/interface";
2
2
  import {routes} from "@lodestar/api";
3
3
 
4
4
  /**
@@ -24,7 +24,7 @@ export function formatNodePeer(peerIdStr: string, connections: Connection[]): ro
24
24
  * - Otherwise, the first closed connection
25
25
  */
26
26
  export function getRelevantConnection(connections: Connection[]): Connection | null {
27
- const byStatus = new Map<StreamStatus, Connection>();
27
+ const byStatus = new Map<ConnectionStatus, Connection>();
28
28
  for (const conn of connections) {
29
29
  if (conn.status === "open") return conn;
30
30
  if (!byStatus.has(conn.status)) byStatus.set(conn.status, conn);
@@ -37,7 +37,7 @@ export function getRelevantConnection(connections: Connection[]): Connection | n
37
37
  * Map libp2p connection status to the API's peer state notation
38
38
  * @param status
39
39
  */
40
- function getPeerState(status: StreamStatus): routes.node.PeerState {
40
+ function getPeerState(status: ConnectionStatus): routes.node.PeerState {
41
41
  switch (status) {
42
42
  case "open":
43
43
  return "connected";