@lodestar/beacon-node 1.41.0-dev.a35cbde8b3 → 1.41.0-dev.aeab9f930d

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 (868) 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 +3 -2
  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 +33 -17
  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 +27 -4
  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 +22 -23
  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/prepareNextSlot.d.ts +1 -2
  233. package/lib/chain/prepareNextSlot.d.ts.map +1 -1
  234. package/lib/chain/prepareNextSlot.js.map +1 -1
  235. package/lib/chain/produceBlock/computeNewStateRoot.d.ts +0 -1
  236. package/lib/chain/produceBlock/computeNewStateRoot.d.ts.map +1 -1
  237. package/lib/chain/produceBlock/computeNewStateRoot.js +4 -3
  238. package/lib/chain/produceBlock/computeNewStateRoot.js.map +1 -1
  239. package/lib/chain/produceBlock/produceBlockBody.d.ts +1 -1
  240. package/lib/chain/produceBlock/produceBlockBody.d.ts.map +1 -1
  241. package/lib/chain/produceBlock/produceBlockBody.js +15 -6
  242. package/lib/chain/produceBlock/produceBlockBody.js.map +1 -1
  243. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.js.map +1 -1
  244. package/lib/chain/regen/errors.d.ts.map +1 -1
  245. package/lib/chain/regen/errors.js +2 -1
  246. package/lib/chain/regen/errors.js.map +1 -1
  247. package/lib/chain/regen/interface.js +4 -2
  248. package/lib/chain/regen/interface.js.map +1 -1
  249. package/lib/chain/regen/queued.d.ts.map +1 -1
  250. package/lib/chain/regen/queued.js +4 -1
  251. package/lib/chain/regen/queued.js.map +1 -1
  252. package/lib/chain/regen/regen.d.ts.map +1 -1
  253. package/lib/chain/regen/regen.js +6 -2
  254. package/lib/chain/regen/regen.js.map +1 -1
  255. package/lib/chain/reprocess.d.ts.map +1 -1
  256. package/lib/chain/reprocess.js +2 -1
  257. package/lib/chain/reprocess.js.map +1 -1
  258. package/lib/chain/seenCache/seenAggregateAndProof.d.ts.map +1 -1
  259. package/lib/chain/seenCache/seenAggregateAndProof.js.map +1 -1
  260. package/lib/chain/seenCache/seenAttestationData.d.ts.map +1 -1
  261. package/lib/chain/seenCache/seenAttestationData.js +2 -1
  262. package/lib/chain/seenCache/seenAttestationData.js.map +1 -1
  263. package/lib/chain/seenCache/seenAttesters.d.ts.map +1 -1
  264. package/lib/chain/seenCache/seenAttesters.js.map +1 -1
  265. package/lib/chain/seenCache/seenBlockAttesters.d.ts.map +1 -1
  266. package/lib/chain/seenCache/seenBlockAttesters.js.map +1 -1
  267. package/lib/chain/seenCache/seenBlockProposers.d.ts.map +1 -1
  268. package/lib/chain/seenCache/seenBlockProposers.js.map +1 -1
  269. package/lib/chain/seenCache/seenCommittee.d.ts.map +1 -1
  270. package/lib/chain/seenCache/seenCommittee.js.map +1 -1
  271. package/lib/chain/seenCache/seenCommitteeContribution.d.ts.map +1 -1
  272. package/lib/chain/seenCache/seenCommitteeContribution.js.map +1 -1
  273. package/lib/chain/seenCache/seenExecutionPayloadBids.d.ts.map +1 -1
  274. package/lib/chain/seenCache/seenExecutionPayloadBids.js.map +1 -1
  275. package/lib/chain/seenCache/seenExecutionPayloadEnvelope.d.ts.map +1 -1
  276. package/lib/chain/seenCache/seenExecutionPayloadEnvelope.js.map +1 -1
  277. package/lib/chain/seenCache/seenGossipBlockInput.d.ts +7 -3
  278. package/lib/chain/seenCache/seenGossipBlockInput.d.ts.map +1 -1
  279. package/lib/chain/seenCache/seenGossipBlockInput.js +38 -16
  280. package/lib/chain/seenCache/seenGossipBlockInput.js.map +1 -1
  281. package/lib/chain/serializeState.js +1 -0
  282. package/lib/chain/serializeState.js.map +1 -1
  283. package/lib/chain/shufflingCache.d.ts.map +1 -1
  284. package/lib/chain/shufflingCache.js +2 -1
  285. package/lib/chain/shufflingCache.js.map +1 -1
  286. package/lib/chain/stateCache/datastore/db.d.ts.map +1 -1
  287. package/lib/chain/stateCache/datastore/db.js.map +1 -1
  288. package/lib/chain/stateCache/datastore/file.d.ts.map +1 -1
  289. package/lib/chain/stateCache/datastore/file.js.map +1 -1
  290. package/lib/chain/stateCache/fifoBlockStateCache.d.ts.map +1 -1
  291. package/lib/chain/stateCache/fifoBlockStateCache.js.map +1 -1
  292. package/lib/chain/stateCache/mapMetrics.d.ts.map +1 -1
  293. package/lib/chain/stateCache/mapMetrics.js.map +1 -1
  294. package/lib/chain/stateCache/persistentCheckpointsCache.d.ts +1 -41
  295. package/lib/chain/stateCache/persistentCheckpointsCache.d.ts.map +1 -1
  296. package/lib/chain/stateCache/persistentCheckpointsCache.js.map +1 -1
  297. package/lib/chain/stateCache/types.js +2 -1
  298. package/lib/chain/stateCache/types.js.map +1 -1
  299. package/lib/chain/validation/aggregateAndProof.js +1 -1
  300. package/lib/chain/validation/aggregateAndProof.js.map +1 -1
  301. package/lib/chain/validation/attestation.d.ts.map +1 -1
  302. package/lib/chain/validation/attestation.js +14 -7
  303. package/lib/chain/validation/attestation.js.map +1 -1
  304. package/lib/chain/validation/attesterSlashing.d.ts.map +1 -1
  305. package/lib/chain/validation/attesterSlashing.js +9 -2
  306. package/lib/chain/validation/attesterSlashing.js.map +1 -1
  307. package/lib/chain/validation/blobSidecar.js +2 -2
  308. package/lib/chain/validation/blobSidecar.js.map +1 -1
  309. package/lib/chain/validation/block.d.ts.map +1 -1
  310. package/lib/chain/validation/block.js +6 -3
  311. package/lib/chain/validation/block.js.map +1 -1
  312. package/lib/chain/validation/blsToExecutionChange.js.map +1 -1
  313. package/lib/chain/validation/dataColumnSidecar.js +1 -1
  314. package/lib/chain/validation/dataColumnSidecar.js.map +1 -1
  315. package/lib/chain/validation/executionPayloadBid.js +1 -2
  316. package/lib/chain/validation/executionPayloadBid.js.map +1 -1
  317. package/lib/chain/validation/executionPayloadEnvelope.js +4 -4
  318. package/lib/chain/validation/executionPayloadEnvelope.js.map +1 -1
  319. package/lib/chain/validation/lightClientFinalityUpdate.js.map +1 -1
  320. package/lib/chain/validation/lightClientOptimisticUpdate.js.map +1 -1
  321. package/lib/chain/validation/payloadAttestationMessage.js +9 -3
  322. package/lib/chain/validation/payloadAttestationMessage.js.map +1 -1
  323. package/lib/chain/validation/proposerSlashing.js +1 -1
  324. package/lib/chain/validation/proposerSlashing.js.map +1 -1
  325. package/lib/chain/validation/signatureSets/aggregateAndProof.js.map +1 -1
  326. package/lib/chain/validation/signatureSets/contributionAndProof.js.map +1 -1
  327. package/lib/chain/validation/signatureSets/selectionProof.js.map +1 -1
  328. package/lib/chain/validation/signatureSets/syncCommittee.js.map +1 -1
  329. package/lib/chain/validation/signatureSets/syncCommitteeContribution.js.map +1 -1
  330. package/lib/chain/validation/signatureSets/syncCommitteeSelectionProof.js.map +1 -1
  331. package/lib/chain/validation/syncCommittee.js.map +1 -1
  332. package/lib/chain/validation/syncCommitteeContributionAndProof.js +1 -1
  333. package/lib/chain/validation/syncCommitteeContributionAndProof.js.map +1 -1
  334. package/lib/chain/validation/voluntaryExit.js.map +1 -1
  335. package/lib/chain/validatorMonitor.d.ts.map +1 -1
  336. package/lib/chain/validatorMonitor.js +2 -1
  337. package/lib/chain/validatorMonitor.js.map +1 -1
  338. package/lib/constants/network.js +4 -2
  339. package/lib/constants/network.js.map +1 -1
  340. package/lib/db/beacon.d.ts +3 -1
  341. package/lib/db/beacon.d.ts.map +1 -1
  342. package/lib/db/beacon.js +5 -1
  343. package/lib/db/beacon.js.map +1 -1
  344. package/lib/db/buckets.d.ts +24 -22
  345. package/lib/db/buckets.d.ts.map +1 -1
  346. package/lib/db/buckets.js +4 -1
  347. package/lib/db/buckets.js.map +1 -1
  348. package/lib/db/index.d.ts +1 -0
  349. package/lib/db/index.d.ts.map +1 -1
  350. package/lib/db/index.js +1 -0
  351. package/lib/db/index.js.map +1 -1
  352. package/lib/db/interface.d.ts +3 -1
  353. package/lib/db/interface.d.ts.map +1 -1
  354. package/lib/db/repositories/attesterSlashing.d.ts.map +1 -1
  355. package/lib/db/repositories/attesterSlashing.js.map +1 -1
  356. package/lib/db/repositories/backfilledRanges.d.ts.map +1 -1
  357. package/lib/db/repositories/backfilledRanges.js.map +1 -1
  358. package/lib/db/repositories/blobSidecars.d.ts.map +1 -1
  359. package/lib/db/repositories/blobSidecars.js.map +1 -1
  360. package/lib/db/repositories/blobSidecarsArchive.d.ts.map +1 -1
  361. package/lib/db/repositories/blobSidecarsArchive.js.map +1 -1
  362. package/lib/db/repositories/block.d.ts.map +1 -1
  363. package/lib/db/repositories/block.js.map +1 -1
  364. package/lib/db/repositories/blockArchive.d.ts.map +1 -1
  365. package/lib/db/repositories/blockArchive.js +1 -2
  366. package/lib/db/repositories/blockArchive.js.map +1 -1
  367. package/lib/db/repositories/blockArchiveIndex.d.ts +2 -2
  368. package/lib/db/repositories/blockArchiveIndex.d.ts.map +1 -1
  369. package/lib/db/repositories/blockArchiveIndex.js.map +1 -1
  370. package/lib/db/repositories/blsToExecutionChange.d.ts.map +1 -1
  371. package/lib/db/repositories/blsToExecutionChange.js.map +1 -1
  372. package/lib/db/repositories/checkpointState.d.ts.map +1 -1
  373. package/lib/db/repositories/checkpointState.js.map +1 -1
  374. package/lib/db/repositories/dataColumnSidecar.d.ts +5 -3
  375. package/lib/db/repositories/dataColumnSidecar.d.ts.map +1 -1
  376. package/lib/db/repositories/dataColumnSidecar.js +14 -1
  377. package/lib/db/repositories/dataColumnSidecar.js.map +1 -1
  378. package/lib/db/repositories/dataColumnSidecarArchive.d.ts +5 -3
  379. package/lib/db/repositories/dataColumnSidecarArchive.d.ts.map +1 -1
  380. package/lib/db/repositories/dataColumnSidecarArchive.js +14 -1
  381. package/lib/db/repositories/dataColumnSidecarArchive.js.map +1 -1
  382. package/lib/db/repositories/executionPayloadEnvelope.d.ts +19 -0
  383. package/lib/db/repositories/executionPayloadEnvelope.d.ts.map +1 -0
  384. package/lib/db/repositories/executionPayloadEnvelope.js +22 -0
  385. package/lib/db/repositories/executionPayloadEnvelope.js.map +1 -0
  386. package/lib/db/repositories/executionPayloadEnvelopeArchive.d.ts +18 -0
  387. package/lib/db/repositories/executionPayloadEnvelopeArchive.d.ts.map +1 -0
  388. package/lib/db/repositories/executionPayloadEnvelopeArchive.js +28 -0
  389. package/lib/db/repositories/executionPayloadEnvelopeArchive.js.map +1 -0
  390. package/lib/db/repositories/index.d.ts +2 -0
  391. package/lib/db/repositories/index.d.ts.map +1 -1
  392. package/lib/db/repositories/index.js +2 -0
  393. package/lib/db/repositories/index.js.map +1 -1
  394. package/lib/db/repositories/lightclientBestUpdate.d.ts.map +1 -1
  395. package/lib/db/repositories/lightclientBestUpdate.js.map +1 -1
  396. package/lib/db/repositories/lightclientCheckpointHeader.d.ts.map +1 -1
  397. package/lib/db/repositories/lightclientCheckpointHeader.js.map +1 -1
  398. package/lib/db/repositories/lightclientSyncCommittee.d.ts.map +1 -1
  399. package/lib/db/repositories/lightclientSyncCommittee.js.map +1 -1
  400. package/lib/db/repositories/lightclientSyncCommitteeWitness.d.ts.map +1 -1
  401. package/lib/db/repositories/lightclientSyncCommitteeWitness.js.map +1 -1
  402. package/lib/db/repositories/proposerSlashing.d.ts.map +1 -1
  403. package/lib/db/repositories/proposerSlashing.js.map +1 -1
  404. package/lib/db/repositories/stateArchive.d.ts.map +1 -1
  405. package/lib/db/repositories/stateArchive.js.map +1 -1
  406. package/lib/db/repositories/stateArchiveIndex.js.map +1 -1
  407. package/lib/db/repositories/voluntaryExit.d.ts.map +1 -1
  408. package/lib/db/repositories/voluntaryExit.js.map +1 -1
  409. package/lib/execution/builder/cache.d.ts.map +1 -1
  410. package/lib/execution/builder/cache.js.map +1 -1
  411. package/lib/execution/builder/http.d.ts.map +1 -1
  412. package/lib/execution/builder/http.js +2 -1
  413. package/lib/execution/builder/http.js.map +1 -1
  414. package/lib/execution/builder/index.js.map +1 -1
  415. package/lib/execution/builder/utils.js.map +1 -1
  416. package/lib/execution/engine/disabled.d.ts.map +1 -1
  417. package/lib/execution/engine/disabled.js.map +1 -1
  418. package/lib/execution/engine/http.d.ts +1 -0
  419. package/lib/execution/engine/http.d.ts.map +1 -1
  420. package/lib/execution/engine/http.js +3 -0
  421. package/lib/execution/engine/http.js.map +1 -1
  422. package/lib/execution/engine/index.js.map +1 -1
  423. package/lib/execution/engine/interface.js +4 -2
  424. package/lib/execution/engine/interface.js.map +1 -1
  425. package/lib/execution/engine/jsonRpcHttpClient.d.ts +10 -15
  426. package/lib/execution/engine/jsonRpcHttpClient.d.ts.map +1 -1
  427. package/lib/execution/engine/jsonRpcHttpClient.js +2 -1
  428. package/lib/execution/engine/jsonRpcHttpClient.js.map +1 -1
  429. package/lib/execution/engine/jwt.js.map +1 -1
  430. package/lib/execution/engine/mock.d.ts.map +1 -1
  431. package/lib/execution/engine/mock.js.map +1 -1
  432. package/lib/execution/engine/payloadIdCache.d.ts.map +1 -1
  433. package/lib/execution/engine/payloadIdCache.js.map +1 -1
  434. package/lib/execution/engine/types.js.map +1 -1
  435. package/lib/execution/engine/utils.d.ts +1 -1
  436. package/lib/execution/engine/utils.d.ts.map +1 -1
  437. package/lib/execution/engine/utils.js.map +1 -1
  438. package/lib/metrics/metrics/beacon.d.ts.map +1 -1
  439. package/lib/metrics/metrics/beacon.js.map +1 -1
  440. package/lib/metrics/metrics/lodestar.d.ts +11 -6
  441. package/lib/metrics/metrics/lodestar.d.ts.map +1 -1
  442. package/lib/metrics/metrics/lodestar.js +23 -10
  443. package/lib/metrics/metrics/lodestar.js.map +1 -1
  444. package/lib/metrics/metrics.js.map +1 -1
  445. package/lib/metrics/nodeJsMetrics.js.map +1 -1
  446. package/lib/metrics/server/http.d.ts +1 -1
  447. package/lib/metrics/server/http.d.ts.map +1 -1
  448. package/lib/metrics/server/http.js.map +1 -1
  449. package/lib/metrics/utils/avgMinMax.d.ts.map +1 -1
  450. package/lib/metrics/utils/avgMinMax.js.map +1 -1
  451. package/lib/metrics/utils/gauge.d.ts.map +1 -1
  452. package/lib/metrics/utils/gauge.js.map +1 -1
  453. package/lib/metrics/utils/registryMetricCreator.d.ts.map +1 -1
  454. package/lib/metrics/utils/registryMetricCreator.js.map +1 -1
  455. package/lib/monitoring/clientStats.js.map +1 -1
  456. package/lib/monitoring/properties.d.ts.map +1 -1
  457. package/lib/monitoring/properties.js.map +1 -1
  458. package/lib/monitoring/service.d.ts +2 -2
  459. package/lib/monitoring/service.d.ts.map +1 -1
  460. package/lib/monitoring/service.js +3 -2
  461. package/lib/monitoring/service.js.map +1 -1
  462. package/lib/monitoring/system.d.ts.map +1 -1
  463. package/lib/monitoring/system.js.map +1 -1
  464. package/lib/monitoring/types.js +4 -2
  465. package/lib/monitoring/types.js.map +1 -1
  466. package/lib/network/core/events.d.ts +1 -3
  467. package/lib/network/core/events.d.ts.map +1 -1
  468. package/lib/network/core/events.js +4 -2
  469. package/lib/network/core/events.js.map +1 -1
  470. package/lib/network/core/metrics.d.ts +6 -7
  471. package/lib/network/core/metrics.d.ts.map +1 -1
  472. package/lib/network/core/metrics.js.map +1 -1
  473. package/lib/network/core/networkCore.d.ts +4 -4
  474. package/lib/network/core/networkCore.d.ts.map +1 -1
  475. package/lib/network/core/networkCore.js.map +1 -1
  476. package/lib/network/core/networkCoreWorker.js.map +1 -1
  477. package/lib/network/core/networkCoreWorkerHandler.d.ts +3 -3
  478. package/lib/network/core/networkCoreWorkerHandler.d.ts.map +1 -1
  479. package/lib/network/core/networkCoreWorkerHandler.js.map +1 -1
  480. package/lib/network/core/types.d.ts +2 -2
  481. package/lib/network/core/types.d.ts.map +1 -1
  482. package/lib/network/discv5/index.d.ts +1 -3
  483. package/lib/network/discv5/index.d.ts.map +1 -1
  484. package/lib/network/discv5/index.js.map +1 -1
  485. package/lib/network/discv5/utils.js +2 -1
  486. package/lib/network/discv5/utils.js.map +1 -1
  487. package/lib/network/discv5/worker.js.map +1 -1
  488. package/lib/network/events.d.ts +3 -4
  489. package/lib/network/events.d.ts.map +1 -1
  490. package/lib/network/events.js +4 -2
  491. package/lib/network/events.js.map +1 -1
  492. package/lib/network/forks.js.map +1 -1
  493. package/lib/network/gossip/encoding.d.ts +3 -3
  494. package/lib/network/gossip/encoding.d.ts.map +1 -1
  495. package/lib/network/gossip/encoding.js.map +1 -1
  496. package/lib/network/gossip/errors.d.ts.map +1 -1
  497. package/lib/network/gossip/errors.js.map +1 -1
  498. package/lib/network/gossip/gossipsub.d.ts +13 -4
  499. package/lib/network/gossip/gossipsub.d.ts.map +1 -1
  500. package/lib/network/gossip/gossipsub.js +47 -20
  501. package/lib/network/gossip/gossipsub.js.map +1 -1
  502. package/lib/network/gossip/interface.d.ts +3 -3
  503. package/lib/network/gossip/interface.d.ts.map +1 -1
  504. package/lib/network/gossip/interface.js +4 -2
  505. package/lib/network/gossip/interface.js.map +1 -1
  506. package/lib/network/gossip/metrics.d.ts +12 -14
  507. package/lib/network/gossip/metrics.d.ts.map +1 -1
  508. package/lib/network/gossip/metrics.js.map +1 -1
  509. package/lib/network/gossip/scoringParameters.d.ts +2 -2
  510. package/lib/network/gossip/scoringParameters.d.ts.map +1 -1
  511. package/lib/network/gossip/scoringParameters.js +1 -1
  512. package/lib/network/gossip/scoringParameters.js.map +1 -1
  513. package/lib/network/gossip/topic.d.ts +3121 -3174
  514. package/lib/network/gossip/topic.d.ts.map +1 -1
  515. package/lib/network/gossip/topic.js.map +1 -1
  516. package/lib/network/interface.d.ts +3 -3
  517. package/lib/network/interface.d.ts.map +1 -1
  518. package/lib/network/libp2p/error.js +2 -1
  519. package/lib/network/libp2p/error.js.map +1 -1
  520. package/lib/network/libp2p/index.d.ts +1 -1
  521. package/lib/network/libp2p/index.d.ts.map +1 -1
  522. package/lib/network/libp2p/index.js +7 -2
  523. package/lib/network/libp2p/index.js.map +1 -1
  524. package/lib/network/metadata.d.ts.map +1 -1
  525. package/lib/network/metadata.js +4 -2
  526. package/lib/network/metadata.js.map +1 -1
  527. package/lib/network/network.d.ts +3 -3
  528. package/lib/network/network.d.ts.map +1 -1
  529. package/lib/network/network.js +2 -2
  530. package/lib/network/network.js.map +1 -1
  531. package/lib/network/options.d.ts.map +1 -1
  532. package/lib/network/options.js +3 -0
  533. package/lib/network/options.js.map +1 -1
  534. package/lib/network/peers/client.js +2 -1
  535. package/lib/network/peers/client.js.map +1 -1
  536. package/lib/network/peers/datastore.d.ts +7 -8
  537. package/lib/network/peers/datastore.d.ts.map +1 -1
  538. package/lib/network/peers/datastore.js +10 -10
  539. package/lib/network/peers/datastore.js.map +1 -1
  540. package/lib/network/peers/discover.d.ts +0 -7
  541. package/lib/network/peers/discover.d.ts.map +1 -1
  542. package/lib/network/peers/discover.js +4 -2
  543. package/lib/network/peers/discover.js.map +1 -1
  544. package/lib/network/peers/peerManager.d.ts +3 -1
  545. package/lib/network/peers/peerManager.d.ts.map +1 -1
  546. package/lib/network/peers/peerManager.js +103 -53
  547. package/lib/network/peers/peerManager.js.map +1 -1
  548. package/lib/network/peers/peersData.d.ts.map +1 -1
  549. package/lib/network/peers/peersData.js +2 -1
  550. package/lib/network/peers/peersData.js.map +1 -1
  551. package/lib/network/peers/score/interface.js +4 -2
  552. package/lib/network/peers/score/interface.js.map +1 -1
  553. package/lib/network/peers/score/score.d.ts.map +1 -1
  554. package/lib/network/peers/score/score.js.map +1 -1
  555. package/lib/network/peers/score/store.d.ts.map +1 -1
  556. package/lib/network/peers/score/store.js.map +1 -1
  557. package/lib/network/peers/score/utils.js.map +1 -1
  558. package/lib/network/peers/utils/assertPeerRelevance.js +2 -1
  559. package/lib/network/peers/utils/assertPeerRelevance.js.map +1 -1
  560. package/lib/network/peers/utils/enrSubnetsDeserialize.js.map +1 -1
  561. package/lib/network/peers/utils/getConnectedPeerIds.js.map +1 -1
  562. package/lib/network/peers/utils/prioritizePeers.d.ts +3 -3
  563. package/lib/network/peers/utils/prioritizePeers.d.ts.map +1 -1
  564. package/lib/network/peers/utils/prioritizePeers.js +2 -1
  565. package/lib/network/peers/utils/prioritizePeers.js.map +1 -1
  566. package/lib/network/peers/utils/subnetMap.d.ts.map +1 -1
  567. package/lib/network/peers/utils/subnetMap.js.map +1 -1
  568. package/lib/network/processor/aggregatorTracker.d.ts.map +1 -1
  569. package/lib/network/processor/aggregatorTracker.js.map +1 -1
  570. package/lib/network/processor/extractSlotRootFns.js.map +1 -1
  571. package/lib/network/processor/gossipHandlers.d.ts.map +1 -1
  572. package/lib/network/processor/gossipHandlers.js +4 -1
  573. package/lib/network/processor/gossipHandlers.js.map +1 -1
  574. package/lib/network/processor/gossipQueues/index.js.map +1 -1
  575. package/lib/network/processor/gossipQueues/indexed.d.ts.map +1 -1
  576. package/lib/network/processor/gossipQueues/indexed.js.map +1 -1
  577. package/lib/network/processor/gossipQueues/linear.d.ts.map +1 -1
  578. package/lib/network/processor/gossipQueues/linear.js.map +1 -1
  579. package/lib/network/processor/gossipQueues/types.js +4 -2
  580. package/lib/network/processor/gossipQueues/types.js.map +1 -1
  581. package/lib/network/processor/gossipValidatorFn.js +1 -1
  582. package/lib/network/processor/gossipValidatorFn.js.map +1 -1
  583. package/lib/network/processor/index.d.ts.map +1 -1
  584. package/lib/network/processor/index.js +4 -2
  585. package/lib/network/processor/index.js.map +1 -1
  586. package/lib/network/processor/types.d.ts +1 -1
  587. package/lib/network/processor/types.d.ts.map +1 -1
  588. package/lib/network/reqresp/ReqRespBeaconNode.d.ts.map +1 -1
  589. package/lib/network/reqresp/ReqRespBeaconNode.js.map +1 -1
  590. package/lib/network/reqresp/handlers/beaconBlocksByRange.d.ts.map +1 -1
  591. package/lib/network/reqresp/handlers/beaconBlocksByRange.js +3 -2
  592. package/lib/network/reqresp/handlers/beaconBlocksByRange.js.map +1 -1
  593. package/lib/network/reqresp/handlers/beaconBlocksByRoot.js.map +1 -1
  594. package/lib/network/reqresp/handlers/blobSidecarsByRange.d.ts.map +1 -1
  595. package/lib/network/reqresp/handlers/blobSidecarsByRange.js +3 -2
  596. package/lib/network/reqresp/handlers/blobSidecarsByRange.js.map +1 -1
  597. package/lib/network/reqresp/handlers/blobSidecarsByRoot.js +1 -1
  598. package/lib/network/reqresp/handlers/blobSidecarsByRoot.js.map +1 -1
  599. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts.map +1 -1
  600. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js +3 -2
  601. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js.map +1 -1
  602. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js +1 -1
  603. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js.map +1 -1
  604. package/lib/network/reqresp/handlers/index.js.map +1 -1
  605. package/lib/network/reqresp/handlers/lightClientBootstrap.js.map +1 -1
  606. package/lib/network/reqresp/handlers/lightClientFinalityUpdate.js.map +1 -1
  607. package/lib/network/reqresp/handlers/lightClientOptimisticUpdate.js.map +1 -1
  608. package/lib/network/reqresp/handlers/lightClientUpdatesByRange.js.map +1 -1
  609. package/lib/network/reqresp/interface.js +2 -1
  610. package/lib/network/reqresp/interface.js.map +1 -1
  611. package/lib/network/reqresp/protocols.d.ts.map +1 -1
  612. package/lib/network/reqresp/protocols.js.map +1 -1
  613. package/lib/network/reqresp/rateLimit.js.map +1 -1
  614. package/lib/network/reqresp/score.d.ts.map +1 -1
  615. package/lib/network/reqresp/score.js +0 -1
  616. package/lib/network/reqresp/score.js.map +1 -1
  617. package/lib/network/reqresp/types.js +4 -2
  618. package/lib/network/reqresp/types.js.map +1 -1
  619. package/lib/network/reqresp/utils/collect.d.ts +1 -1
  620. package/lib/network/reqresp/utils/collect.js.map +1 -1
  621. package/lib/network/reqresp/utils/collectSequentialBlocksInRange.d.ts +1 -1
  622. package/lib/network/reqresp/utils/collectSequentialBlocksInRange.js +2 -1
  623. package/lib/network/reqresp/utils/collectSequentialBlocksInRange.js.map +1 -1
  624. package/lib/network/reqresp/utils/dataColumnResponseValidation.d.ts +1 -1
  625. package/lib/network/reqresp/utils/dataColumnResponseValidation.d.ts.map +1 -1
  626. package/lib/network/reqresp/utils/dataColumnResponseValidation.js.map +1 -1
  627. package/lib/network/statusCache.d.ts.map +1 -1
  628. package/lib/network/statusCache.js.map +1 -1
  629. package/lib/network/subnets/attnetsService.d.ts.map +1 -1
  630. package/lib/network/subnets/attnetsService.js +2 -1
  631. package/lib/network/subnets/attnetsService.js.map +1 -1
  632. package/lib/network/subnets/interface.js.map +1 -1
  633. package/lib/network/subnets/syncnetsService.d.ts.map +1 -1
  634. package/lib/network/subnets/syncnetsService.js.map +1 -1
  635. package/lib/network/subnets/util.js.map +1 -1
  636. package/lib/network/util.js +2 -2
  637. package/lib/network/util.js.map +1 -1
  638. package/lib/node/nodejs.d.ts +4 -6
  639. package/lib/node/nodejs.d.ts.map +1 -1
  640. package/lib/node/nodejs.js +8 -5
  641. package/lib/node/nodejs.js.map +1 -1
  642. package/lib/node/notifier.js.map +1 -1
  643. package/lib/node/utils/interop/deposits.js.map +1 -1
  644. package/lib/node/utils/interop/state.d.ts +1 -1
  645. package/lib/node/utils/interop/state.d.ts.map +1 -1
  646. package/lib/node/utils/interop/state.js.map +1 -1
  647. package/lib/node/utils/lightclient.js.map +1 -1
  648. package/lib/node/utils/state.js.map +1 -1
  649. package/lib/sync/backfill/backfill.d.ts +1 -10
  650. package/lib/sync/backfill/backfill.d.ts.map +1 -1
  651. package/lib/sync/backfill/backfill.js +6 -3
  652. package/lib/sync/backfill/backfill.js.map +1 -1
  653. package/lib/sync/backfill/errors.js +2 -1
  654. package/lib/sync/backfill/errors.js.map +1 -1
  655. package/lib/sync/backfill/verify.js.map +1 -1
  656. package/lib/sync/interface.js +2 -1
  657. package/lib/sync/interface.js.map +1 -1
  658. package/lib/sync/range/batch.d.ts.map +1 -1
  659. package/lib/sync/range/batch.js +4 -2
  660. package/lib/sync/range/batch.js.map +1 -1
  661. package/lib/sync/range/chain.d.ts +0 -10
  662. package/lib/sync/range/chain.d.ts.map +1 -1
  663. package/lib/sync/range/chain.js +2 -1
  664. package/lib/sync/range/chain.js.map +1 -1
  665. package/lib/sync/range/range.d.ts +1 -3
  666. package/lib/sync/range/range.d.ts.map +1 -1
  667. package/lib/sync/range/range.js +4 -2
  668. package/lib/sync/range/range.js.map +1 -1
  669. package/lib/sync/range/utils/batches.js.map +1 -1
  670. package/lib/sync/range/utils/chainTarget.js.map +1 -1
  671. package/lib/sync/range/utils/hashBlocks.js.map +1 -1
  672. package/lib/sync/range/utils/peerBalancer.d.ts.map +1 -1
  673. package/lib/sync/range/utils/peerBalancer.js.map +1 -1
  674. package/lib/sync/range/utils/updateChains.js.map +1 -1
  675. package/lib/sync/sync.d.ts.map +1 -1
  676. package/lib/sync/sync.js.map +1 -1
  677. package/lib/sync/types.js +4 -2
  678. package/lib/sync/types.js.map +1 -1
  679. package/lib/sync/unknownBlock.d.ts +0 -14
  680. package/lib/sync/unknownBlock.d.ts.map +1 -1
  681. package/lib/sync/unknownBlock.js.map +1 -1
  682. package/lib/sync/utils/downloadByRange.d.ts +4 -4
  683. package/lib/sync/utils/downloadByRange.d.ts.map +1 -1
  684. package/lib/sync/utils/downloadByRange.js +2 -1
  685. package/lib/sync/utils/downloadByRange.js.map +1 -1
  686. package/lib/sync/utils/downloadByRoot.d.ts +8 -8
  687. package/lib/sync/utils/downloadByRoot.d.ts.map +1 -1
  688. package/lib/sync/utils/downloadByRoot.js +2 -1
  689. package/lib/sync/utils/downloadByRoot.js.map +1 -1
  690. package/lib/sync/utils/pendingBlocksTree.js.map +1 -1
  691. package/lib/sync/utils/remoteSyncType.d.ts +1 -1
  692. package/lib/sync/utils/remoteSyncType.d.ts.map +1 -1
  693. package/lib/sync/utils/remoteSyncType.js +4 -2
  694. package/lib/sync/utils/remoteSyncType.js.map +1 -1
  695. package/lib/util/address.js.map +1 -1
  696. package/lib/util/array.d.ts.map +1 -1
  697. package/lib/util/array.js.map +1 -1
  698. package/lib/util/asyncIterableToEvents.d.ts.map +1 -1
  699. package/lib/util/asyncIterableToEvents.js +2 -1
  700. package/lib/util/asyncIterableToEvents.js.map +1 -1
  701. package/lib/util/binarySearch.d.ts.map +1 -1
  702. package/lib/util/binarySearch.js.map +1 -1
  703. package/lib/util/bitArray.js +2 -1
  704. package/lib/util/bitArray.js.map +1 -1
  705. package/lib/util/blobs.d.ts +2 -2
  706. package/lib/util/blobs.d.ts.map +1 -1
  707. package/lib/util/blobs.js.map +1 -1
  708. package/lib/util/bufferPool.d.ts.map +1 -1
  709. package/lib/util/bufferPool.js +2 -1
  710. package/lib/util/bufferPool.js.map +1 -1
  711. package/lib/util/chunkify.js.map +1 -1
  712. package/lib/util/clock.d.ts +6 -0
  713. package/lib/util/clock.d.ts.map +1 -1
  714. package/lib/util/clock.js +11 -4
  715. package/lib/util/clock.js.map +1 -1
  716. package/lib/util/dataColumns.d.ts +3 -5
  717. package/lib/util/dataColumns.d.ts.map +1 -1
  718. package/lib/util/dataColumns.js +4 -6
  719. package/lib/util/dataColumns.js.map +1 -1
  720. package/lib/util/dependentRoot.js.map +1 -1
  721. package/lib/util/enum.js.map +1 -1
  722. package/lib/util/error.js.map +1 -1
  723. package/lib/util/eventLoop.js.map +1 -1
  724. package/lib/util/execution.js +2 -1
  725. package/lib/util/execution.js.map +1 -1
  726. package/lib/util/file.js.map +1 -1
  727. package/lib/util/forkChoice.js.map +1 -1
  728. package/lib/util/forkName.js.map +1 -1
  729. package/lib/util/graffiti.js.map +1 -1
  730. package/lib/util/hex.js.map +1 -1
  731. package/lib/util/ip.js.map +1 -1
  732. package/lib/util/itTrigger.d.ts.map +1 -1
  733. package/lib/util/itTrigger.js.map +1 -1
  734. package/lib/util/map.d.ts.map +1 -1
  735. package/lib/util/map.js.map +1 -1
  736. package/lib/util/metadata.js.map +1 -1
  737. package/lib/util/multifork.d.ts +8 -0
  738. package/lib/util/multifork.d.ts.map +1 -1
  739. package/lib/util/multifork.js +37 -0
  740. package/lib/util/multifork.js.map +1 -1
  741. package/lib/util/numpy.js.map +1 -1
  742. package/lib/util/peerId.js.map +1 -1
  743. package/lib/util/profile.js +2 -1
  744. package/lib/util/profile.js.map +1 -1
  745. package/lib/util/promises.js.map +1 -1
  746. package/lib/util/queue/errors.js +2 -1
  747. package/lib/util/queue/errors.js.map +1 -1
  748. package/lib/util/queue/fnQueue.d.ts.map +1 -1
  749. package/lib/util/queue/fnQueue.js.map +1 -1
  750. package/lib/util/queue/itemQueue.d.ts.map +1 -1
  751. package/lib/util/queue/itemQueue.js.map +1 -1
  752. package/lib/util/queue/options.js +2 -1
  753. package/lib/util/queue/options.js.map +1 -1
  754. package/lib/util/serializedCache.d.ts +4 -4
  755. package/lib/util/serializedCache.d.ts.map +1 -1
  756. package/lib/util/serializedCache.js +6 -4
  757. package/lib/util/serializedCache.js.map +1 -1
  758. package/lib/util/set.d.ts.map +1 -1
  759. package/lib/util/set.js.map +1 -1
  760. package/lib/util/shuffle.js.map +1 -1
  761. package/lib/util/sortBy.js.map +1 -1
  762. package/lib/util/sszBytes.js.map +1 -1
  763. package/lib/util/time.js.map +1 -1
  764. package/lib/util/timeSeries.d.ts.map +1 -1
  765. package/lib/util/timeSeries.js.map +1 -1
  766. package/lib/util/types.d.ts.map +1 -1
  767. package/lib/util/workerEvents.d.ts +1 -1
  768. package/lib/util/workerEvents.d.ts.map +1 -1
  769. package/lib/util/workerEvents.js.map +1 -1
  770. package/lib/util/wrapError.js.map +1 -1
  771. package/package.json +41 -44
  772. package/src/api/impl/beacon/blocks/index.ts +3 -2
  773. package/src/api/impl/beacon/state/index.ts +8 -8
  774. package/src/api/impl/beacon/state/utils.ts +15 -29
  775. package/src/api/impl/debug/index.ts +9 -5
  776. package/src/api/impl/node/utils.ts +3 -3
  777. package/src/api/impl/validator/index.ts +29 -16
  778. package/src/chain/archiveStore/archiveStore.ts +15 -5
  779. package/src/chain/archiveStore/historicalState/getHistoricalState.ts +10 -11
  780. package/src/chain/archiveStore/historicalState/worker.ts +3 -3
  781. package/src/chain/archiveStore/utils/archiveBlocks.ts +4 -5
  782. package/src/chain/archiveStore/utils/archivePayloads.ts +15 -0
  783. package/src/chain/archiveStore/utils/updateBackfillRange.ts +1 -1
  784. package/src/chain/blocks/blockInput/blockInput.ts +103 -3
  785. package/src/chain/blocks/blockInput/types.ts +18 -0
  786. package/src/chain/blocks/importBlock.ts +35 -4
  787. package/src/chain/blocks/verifyBlocksDataAvailability.ts +3 -0
  788. package/src/chain/blocks/verifyBlocksExecutionPayloads.ts +9 -2
  789. package/src/chain/blocks/verifyBlocksSanityChecks.ts +7 -2
  790. package/src/chain/blocks/writeBlockInputToDb.ts +105 -104
  791. package/src/chain/bls/multithread/index.ts +7 -7
  792. package/src/chain/bls/multithread/jobItem.ts +3 -3
  793. package/src/chain/bls/singleThread.ts +5 -5
  794. package/src/chain/bls/utils.ts +8 -5
  795. package/src/chain/chain.ts +47 -39
  796. package/src/chain/emitter.ts +5 -5
  797. package/src/chain/errors/executionPayloadBid.ts +1 -1
  798. package/src/chain/errors/executionPayloadEnvelope.ts +6 -2
  799. package/src/chain/errors/payloadAttestation.ts +1 -1
  800. package/src/chain/forkChoice/index.ts +39 -21
  801. package/src/chain/interface.ts +4 -11
  802. package/src/chain/opPools/aggregatedAttestationPool.ts +1 -1
  803. package/src/chain/produceBlock/computeNewStateRoot.ts +4 -3
  804. package/src/chain/produceBlock/produceBlockBody.ts +10 -4
  805. package/src/chain/regen/queued.ts +7 -2
  806. package/src/chain/regen/regen.ts +9 -3
  807. package/src/chain/seenCache/seenGossipBlockInput.ts +56 -18
  808. package/src/chain/validation/aggregateAndProof.ts +1 -1
  809. package/src/chain/validation/attestation.ts +14 -7
  810. package/src/chain/validation/attesterSlashing.ts +10 -1
  811. package/src/chain/validation/blobSidecar.ts +2 -2
  812. package/src/chain/validation/block.ts +9 -4
  813. package/src/chain/validation/dataColumnSidecar.ts +1 -1
  814. package/src/chain/validation/executionPayloadBid.ts +1 -2
  815. package/src/chain/validation/executionPayloadEnvelope.ts +4 -4
  816. package/src/chain/validation/payloadAttestationMessage.ts +10 -3
  817. package/src/chain/validation/proposerSlashing.ts +1 -1
  818. package/src/chain/validation/syncCommitteeContributionAndProof.ts +1 -1
  819. package/src/db/beacon.ts +8 -0
  820. package/src/db/buckets.ts +3 -0
  821. package/src/db/index.ts +1 -0
  822. package/src/db/interface.ts +5 -0
  823. package/src/db/repositories/blockArchive.ts +1 -2
  824. package/src/db/repositories/dataColumnSidecar.ts +18 -3
  825. package/src/db/repositories/dataColumnSidecarArchive.ts +18 -3
  826. package/src/db/repositories/executionPayloadEnvelope.ts +26 -0
  827. package/src/db/repositories/executionPayloadEnvelopeArchive.ts +32 -0
  828. package/src/db/repositories/index.ts +2 -0
  829. package/src/execution/engine/http.ts +3 -0
  830. package/src/metrics/metrics/lodestar.ts +23 -10
  831. package/src/monitoring/service.ts +3 -2
  832. package/src/network/core/networkCore.ts +3 -3
  833. package/src/network/core/networkCoreWorkerHandler.ts +3 -3
  834. package/src/network/core/types.ts +2 -2
  835. package/src/network/events.ts +2 -1
  836. package/src/network/gossip/encoding.ts +3 -3
  837. package/src/network/gossip/gossipsub.ts +86 -25
  838. package/src/network/gossip/interface.ts +3 -3
  839. package/src/network/gossip/scoringParameters.ts +4 -4
  840. package/src/network/interface.ts +3 -3
  841. package/src/network/libp2p/index.ts +8 -3
  842. package/src/network/network.ts +9 -6
  843. package/src/network/options.ts +3 -0
  844. package/src/network/peers/datastore.ts +13 -10
  845. package/src/network/peers/peerManager.ts +118 -54
  846. package/src/network/peers/utils/prioritizePeers.ts +3 -3
  847. package/src/network/processor/gossipHandlers.ts +12 -3
  848. package/src/network/processor/gossipValidatorFn.ts +2 -2
  849. package/src/network/processor/types.ts +1 -1
  850. package/src/network/reqresp/ReqRespBeaconNode.ts +1 -1
  851. package/src/network/reqresp/handlers/beaconBlocksByRange.ts +4 -3
  852. package/src/network/reqresp/handlers/blobSidecarsByRange.ts +3 -2
  853. package/src/network/reqresp/handlers/blobSidecarsByRoot.ts +1 -1
  854. package/src/network/reqresp/handlers/dataColumnSidecarsByRange.ts +4 -3
  855. package/src/network/reqresp/handlers/dataColumnSidecarsByRoot.ts +2 -2
  856. package/src/network/reqresp/score.ts +0 -1
  857. package/src/network/reqresp/utils/collect.ts +1 -1
  858. package/src/network/reqresp/utils/collectSequentialBlocksInRange.ts +1 -1
  859. package/src/network/util.ts +2 -2
  860. package/src/node/nodejs.ts +8 -9
  861. package/src/sync/utils/downloadByRoot.ts +1 -1
  862. package/src/sync/utils/remoteSyncType.ts +1 -1
  863. package/src/util/blobs.ts +3 -3
  864. package/src/util/clock.ts +9 -4
  865. package/src/util/dataColumns.ts +2 -7
  866. package/src/util/multifork.ts +45 -0
  867. package/src/util/serializedCache.ts +7 -5
  868. package/src/util/workerEvents.ts +1 -1
package/src/db/buckets.ts CHANGED
@@ -69,6 +69,9 @@ export enum Bucket {
69
69
 
70
70
  fulu_dataColumnSidecars = 57, // FULU BeaconBlockRoot -> DataColumnSidecars
71
71
  fulu_dataColumnSidecarsArchive = 58, // FULU BeaconBlockSlot -> DataColumnSidecars
72
+
73
+ gloas_executionPayloadEnvelope = 59, // GLOAS BeaconBlockRoot -> SignedExecutionPayloadEnvelope
74
+ gloas_executionPayloadEnvelopeArchive = 60, // GLOAS Slot -> SignedExecutionPayloadEnvelope
72
75
  }
73
76
 
74
77
  export function getBucketNameByValue<T extends Bucket>(enumValue: T): keyof typeof Bucket {
package/src/db/index.ts CHANGED
@@ -1,2 +1,3 @@
1
1
  export {BeaconDb} from "./beacon.js";
2
+ export {Bucket} from "./buckets.js";
2
3
  export type {IBeaconDb} from "./interface.js";
@@ -12,6 +12,8 @@ import {
12
12
  CheckpointHeaderRepository,
13
13
  DataColumnSidecarArchiveRepository,
14
14
  DataColumnSidecarRepository,
15
+ ExecutionPayloadEnvelopeArchiveRepository,
16
+ ExecutionPayloadEnvelopeRepository,
15
17
  ProposerSlashingRepository,
16
18
  StateArchiveRepository,
17
19
  SyncCommitteeRepository,
@@ -35,6 +37,9 @@ export interface IBeaconDb {
35
37
  dataColumnSidecar: DataColumnSidecarRepository;
36
38
  dataColumnSidecarArchive: DataColumnSidecarArchiveRepository;
37
39
 
40
+ executionPayloadEnvelope: ExecutionPayloadEnvelopeRepository;
41
+ executionPayloadEnvelopeArchive: ExecutionPayloadEnvelopeArchiveRepository;
42
+
38
43
  // finalized states
39
44
  stateArchive: StateArchiveRepository;
40
45
  // checkpoint states
@@ -1,4 +1,3 @@
1
- import all from "it-all";
2
1
  import {ChainForkConfig} from "@lodestar/config";
3
2
  import {Db, FilterOptions, KeyValue, Repository} from "@lodestar/db";
4
3
  import {Root, SignedBeaconBlock, Slot, ssz} from "@lodestar/types";
@@ -121,7 +120,7 @@ export class BlockArchiveRepository extends Repository<Slot, SignedBeaconBlock>
121
120
  }
122
121
 
123
122
  async values(opts?: BlockFilterOptions): Promise<SignedBeaconBlock[]> {
124
- return all(this.valuesStream(opts));
123
+ return await Array.fromAsync(this.valuesStream(opts));
125
124
  }
126
125
 
127
126
  // INDEX
@@ -1,7 +1,8 @@
1
1
  import {ChainForkConfig} from "@lodestar/config";
2
2
  import {Db, PrefixedRepository, decodeNumberForDbKey, encodeNumberForDbKey} from "@lodestar/db";
3
3
  import {NUMBER_OF_COLUMNS} from "@lodestar/params";
4
- import {ColumnIndex, Root, fulu, ssz} from "@lodestar/types";
4
+ import {ColumnIndex, DataColumnSidecar, Root, isGloasDataColumnSidecar, ssz} from "@lodestar/types";
5
+ import {isGloasDataColumnSidecarBytes} from "../../util/multifork.js";
5
6
  import {Bucket, getBucketNameByValue} from "../buckets.js";
6
7
 
7
8
  const COLUMN_INDEX_BYTE_SIZE = 2;
@@ -15,7 +16,7 @@ type BlockRoot = Root;
15
16
  *
16
17
  * Indexed data by `blockRoot` + `columnIndex`
17
18
  */
18
- export class DataColumnSidecarRepository extends PrefixedRepository<BlockRoot, ColumnIndex, fulu.DataColumnSidecar> {
19
+ export class DataColumnSidecarRepository extends PrefixedRepository<BlockRoot, ColumnIndex, DataColumnSidecar> {
19
20
  constructor(config: ChainForkConfig, db: Db) {
20
21
  const bucket = Bucket.fulu_dataColumnSidecars;
21
22
  super(config, db, bucket, ssz.fulu.DataColumnSidecar, getBucketNameByValue(bucket));
@@ -24,10 +25,24 @@ export class DataColumnSidecarRepository extends PrefixedRepository<BlockRoot, C
24
25
  /**
25
26
  * Id is hashTreeRoot of unsigned BeaconBlock
26
27
  */
27
- getId(value: fulu.DataColumnSidecar): ColumnIndex {
28
+ getId(value: DataColumnSidecar): ColumnIndex {
28
29
  return value.index;
29
30
  }
30
31
 
32
+ encodeValue(value: DataColumnSidecar): Uint8Array {
33
+ if (isGloasDataColumnSidecar(value)) {
34
+ return ssz.gloas.DataColumnSidecar.serialize(value);
35
+ }
36
+ return ssz.fulu.DataColumnSidecar.serialize(value);
37
+ }
38
+
39
+ decodeValue(data: Uint8Array): DataColumnSidecar {
40
+ if (isGloasDataColumnSidecarBytes(data)) {
41
+ return ssz.gloas.DataColumnSidecar.deserialize(data);
42
+ }
43
+ return ssz.fulu.DataColumnSidecar.deserialize(data);
44
+ }
45
+
31
46
  encodeKeyRaw(prefix: BlockRoot, id: ColumnIndex): Uint8Array {
32
47
  return Buffer.concat([prefix, encodeNumberForDbKey(id, COLUMN_INDEX_BYTE_SIZE)]);
33
48
  }
@@ -1,7 +1,8 @@
1
1
  import {ChainForkConfig} from "@lodestar/config";
2
2
  import {Db, PrefixedRepository, decodeNumberForDbKey, encodeNumberForDbKey} from "@lodestar/db";
3
3
  import {NUMBER_OF_COLUMNS} from "@lodestar/params";
4
- import {ColumnIndex, Slot, fulu, ssz} from "@lodestar/types";
4
+ import {ColumnIndex, DataColumnSidecar, Slot, isGloasDataColumnSidecar, ssz} from "@lodestar/types";
5
+ import {isGloasDataColumnSidecarBytes} from "../../util/multifork.js";
5
6
  import {Bucket, getBucketNameByValue} from "../buckets.js";
6
7
 
7
8
  const COLUMN_INDEX_BYTE_SIZE = 2;
@@ -13,7 +14,7 @@ const SLOT_BYTE_SIZE = 8;
13
14
  *
14
15
  * Indexed data by `slot` + `columnIndex`
15
16
  */
16
- export class DataColumnSidecarArchiveRepository extends PrefixedRepository<Slot, ColumnIndex, fulu.DataColumnSidecar> {
17
+ export class DataColumnSidecarArchiveRepository extends PrefixedRepository<Slot, ColumnIndex, DataColumnSidecar> {
17
18
  constructor(config: ChainForkConfig, db: Db) {
18
19
  const bucket = Bucket.fulu_dataColumnSidecarsArchive;
19
20
  super(config, db, bucket, ssz.fulu.DataColumnSidecar, getBucketNameByValue(bucket));
@@ -22,10 +23,24 @@ export class DataColumnSidecarArchiveRepository extends PrefixedRepository<Slot,
22
23
  /**
23
24
  * Id is hashTreeRoot of unsigned BeaconBlock
24
25
  */
25
- getId(value: fulu.DataColumnSidecar): ColumnIndex {
26
+ getId(value: DataColumnSidecar): ColumnIndex {
26
27
  return value.index;
27
28
  }
28
29
 
30
+ encodeValue(value: DataColumnSidecar): Uint8Array {
31
+ if (isGloasDataColumnSidecar(value)) {
32
+ return ssz.gloas.DataColumnSidecar.serialize(value);
33
+ }
34
+ return ssz.fulu.DataColumnSidecar.serialize(value);
35
+ }
36
+
37
+ decodeValue(data: Uint8Array): DataColumnSidecar {
38
+ if (isGloasDataColumnSidecarBytes(data)) {
39
+ return ssz.gloas.DataColumnSidecar.deserialize(data);
40
+ }
41
+ return ssz.fulu.DataColumnSidecar.deserialize(data);
42
+ }
43
+
29
44
  encodeKeyRaw(prefix: Slot, id: ColumnIndex): Uint8Array {
30
45
  return Buffer.concat([
31
46
  encodeNumberForDbKey(prefix, SLOT_BYTE_SIZE),
@@ -0,0 +1,26 @@
1
+ import {ChainForkConfig} from "@lodestar/config";
2
+ import {Db, Repository} from "@lodestar/db";
3
+ import {Root, gloas, ssz} from "@lodestar/types";
4
+ import {Bucket, getBucketNameByValue} from "../buckets.js";
5
+
6
+ type BlockRoot = Root;
7
+
8
+ /**
9
+ * Used to store unfinalized `SignedExecutionPayloadEnvelope`
10
+ *
11
+ * Indexed by beacon block root (root of the beacon block that contains the bid)
12
+ */
13
+ export class ExecutionPayloadEnvelopeRepository extends Repository<BlockRoot, gloas.SignedExecutionPayloadEnvelope> {
14
+ constructor(config: ChainForkConfig, db: Db) {
15
+ const bucket = Bucket.gloas_executionPayloadEnvelope;
16
+ super(config, db, bucket, ssz.gloas.SignedExecutionPayloadEnvelope, getBucketNameByValue(bucket));
17
+ }
18
+
19
+ /**
20
+ * Id is the beacon block root (not execution payload hash)
21
+ * This allows correlation with the block that contains the bid
22
+ */
23
+ getId(value: gloas.SignedExecutionPayloadEnvelope): BlockRoot {
24
+ return value.message.beaconBlockRoot;
25
+ }
26
+ }
@@ -0,0 +1,32 @@
1
+ import {ChainForkConfig} from "@lodestar/config";
2
+ import {BUCKET_LENGTH, Db, Repository, encodeKey as encodeDbKey} from "@lodestar/db";
3
+ import {Slot, gloas, ssz} from "@lodestar/types";
4
+ import {bytesToInt} from "@lodestar/utils";
5
+ import {Bucket, getBucketNameByValue} from "../buckets.js";
6
+
7
+ /**
8
+ * Used to store finalized `SignedExecutionPayloadEnvelope`
9
+ *
10
+ * Indexed by slot for chronological archival
11
+ */
12
+ export class ExecutionPayloadEnvelopeArchiveRepository extends Repository<Slot, gloas.SignedExecutionPayloadEnvelope> {
13
+ constructor(config: ChainForkConfig, db: Db) {
14
+ const bucket = Bucket.gloas_executionPayloadEnvelopeArchive;
15
+ super(config, db, bucket, ssz.gloas.SignedExecutionPayloadEnvelope, getBucketNameByValue(bucket));
16
+ }
17
+
18
+ /**
19
+ * Id is the slot from the envelope
20
+ */
21
+ getId(value: gloas.SignedExecutionPayloadEnvelope): Slot {
22
+ return value.message.slot;
23
+ }
24
+
25
+ encodeKey(id: Slot): Uint8Array {
26
+ return encodeDbKey(this.bucket, id);
27
+ }
28
+
29
+ decodeKey(data: Uint8Array): number {
30
+ return bytesToInt(data.subarray(BUCKET_LENGTH), "be");
31
+ }
32
+ }
@@ -8,6 +8,8 @@ export {BlockArchiveRepository} from "./blockArchive.js";
8
8
  export {BLSToExecutionChangeRepository} from "./blsToExecutionChange.js";
9
9
  export {DataColumnSidecarRepository} from "./dataColumnSidecar.js";
10
10
  export {DataColumnSidecarArchiveRepository} from "./dataColumnSidecarArchive.js";
11
+ export {ExecutionPayloadEnvelopeRepository} from "./executionPayloadEnvelope.js";
12
+ export {ExecutionPayloadEnvelopeArchiveRepository} from "./executionPayloadEnvelopeArchive.js";
11
13
  export {BestLightClientUpdateRepository} from "./lightclientBestUpdate.js";
12
14
  export {CheckpointHeaderRepository} from "./lightclientCheckpointHeader.js";
13
15
  export {SyncCommitteeRepository} from "./lightclientSyncCommittee.js";
@@ -128,6 +128,7 @@ const getClientVersionOpts: ReqOpts = {routeId: "getClientVersion"};
128
128
  */
129
129
  export class ExecutionEngineHttp implements IExecutionEngine {
130
130
  private logger: Logger;
131
+ private metrics: Metrics | null;
131
132
 
132
133
  // The default state is ONLINE, it will be updated to SYNCING once we receive the first payload
133
134
  // This assumption is better than the OFFLINE state, since we can't be sure if the EL is offline and being offline may trigger some notifications
@@ -167,6 +168,7 @@ export class ExecutionEngineHttp implements IExecutionEngine {
167
168
  metrics?.engineHttpProcessorQueue
168
169
  );
169
170
  this.logger = logger;
171
+ this.metrics = metrics ?? null;
170
172
 
171
173
  this.rpc.emitter.on(JsonRpcHttpClientEvent.ERROR, ({error}) => {
172
174
  this.updateEngineState(getExecutionEngineState({payloadError: error, oldState: this.state}));
@@ -369,6 +371,7 @@ export class ExecutionEngineHttp implements IExecutionEngine {
369
371
  } = await request;
370
372
 
371
373
  this.updateEngineState(getExecutionEngineState({payloadStatus: status, oldState: this.state}));
374
+ this.metrics?.engineNotifyForkchoiceUpdateResult.inc({result: status});
372
375
 
373
376
  switch (status) {
374
377
  case ExecutionPayloadStatus.VALID:
@@ -928,6 +928,11 @@ export function createLodestarMetrics(
928
928
  help: "The total result of calling notifyNewPayload execution engine api",
929
929
  labelNames: ["result"],
930
930
  }),
931
+ engineNotifyForkchoiceUpdateResult: register.gauge<{result: ExecutionPayloadStatus}>({
932
+ name: "lodestar_execution_engine_notify_forkchoice_update_result_total",
933
+ help: "The total result of calling notifyForkchoiceUpdate execution engine api",
934
+ labelNames: ["result"],
935
+ }),
931
936
  backfillSync: {
932
937
  backfilledTillSlot: register.gauge({
933
938
  name: "lodestar_backfill_till_slot",
@@ -1456,29 +1461,37 @@ export function createLodestarMetrics(
1456
1461
  name: "lodestar_seen_block_input_cache_size",
1457
1462
  help: "Number of cached BlockInputs",
1458
1463
  }),
1459
- duplicateBlockCount: register.gauge<{source: BlockInputSource}>({
1460
- name: "lodestar_seen_block_input_cache_duplicate_block_count",
1464
+ serializedObjectRefs: register.gauge({
1465
+ name: "lodestar_seen_block_input_cache_serialized_object_refs",
1466
+ help: "Number of serialized-cache object refs retained by cached BlockInputs",
1467
+ }),
1468
+ duplicateBlockCount: register.counter<{source: BlockInputSource}>({
1469
+ name: "lodestar_seen_block_input_cache_duplicate_block_total",
1461
1470
  help: "Total number of duplicate blocks that pass validation and attempt to be cached but are known",
1462
1471
  labelNames: ["source"],
1463
1472
  }),
1464
- duplicateBlobCount: register.gauge<{source: BlockInputSource}>({
1465
- name: "lodestar_seen_block_input_cache_duplicate_blob_count",
1473
+ duplicateBlobCount: register.counter<{source: BlockInputSource}>({
1474
+ name: "lodestar_seen_block_input_cache_duplicate_blob_total",
1466
1475
  help: "Total number of duplicate blobs that pass validation and attempt to be cached but are known",
1467
1476
  labelNames: ["source"],
1468
1477
  }),
1469
- duplicateColumnCount: register.gauge<{source: BlockInputSource}>({
1470
- name: "lodestar_seen_block_input_cache_duplicate_column_count",
1478
+ duplicateColumnCount: register.counter<{source: BlockInputSource}>({
1479
+ name: "lodestar_seen_block_input_cache_duplicate_column_total",
1471
1480
  help: "Total number of duplicate columns that pass validation and attempt to be cached but are known",
1472
1481
  labelNames: ["source"],
1473
1482
  }),
1474
- createdByBlock: register.gauge({
1475
- name: "lodestar_seen_block_input_cache_items_created_by_block",
1483
+ createdByBlock: register.counter({
1484
+ name: "lodestar_seen_block_input_cache_items_created_by_block_total",
1476
1485
  help: "Number of BlockInputs created via a block being seen first",
1477
1486
  }),
1478
- createdByBlob: register.gauge({
1479
- name: "lodestar_seen_block_input_cache_items_created_by_blob",
1487
+ createdByBlob: register.counter({
1488
+ name: "lodestar_seen_block_input_cache_items_created_by_blob_total",
1480
1489
  help: "Number of BlockInputs created via a blob being seen first",
1481
1490
  }),
1491
+ createdByColumn: register.counter({
1492
+ name: "lodestar_seen_block_input_cache_items_created_by_column_total",
1493
+ help: "Number of BlockInputs created via a data column being seen first",
1494
+ }),
1482
1495
  },
1483
1496
  },
1484
1497
 
@@ -89,9 +89,9 @@ export class MonitoringService {
89
89
  }
90
90
 
91
91
  /**
92
- * Stop sending client stats
92
+ * Stop sending client stats and wait for any pending request to complete
93
93
  */
94
- close(): void {
94
+ async close(): Promise<void> {
95
95
  if (this.status === Status.Closed) return;
96
96
  this.status = Status.Closed;
97
97
 
@@ -103,6 +103,7 @@ export class MonitoringService {
103
103
  }
104
104
  if (this.pendingRequest) {
105
105
  this.fetchAbortController?.abort(FetchAbortReason.Close);
106
+ await this.pendingRequest;
106
107
  }
107
108
  }
108
109
 
@@ -1,8 +1,8 @@
1
- import {Connection, PrivateKey} from "@libp2p/interface";
1
+ import type {PeerScoreStatsDump} from "@libp2p/gossipsub/score";
2
+ import type {PublishOpts} from "@libp2p/gossipsub/types";
3
+ import type {Connection, PrivateKey} from "@libp2p/interface";
2
4
  import {peerIdFromPrivateKey} from "@libp2p/peer-id";
3
5
  import {multiaddr} from "@multiformats/multiaddr";
4
- import {PeerScoreStatsDump} from "@chainsafe/libp2p-gossipsub/score";
5
- import {PublishOpts} from "@chainsafe/libp2p-gossipsub/types";
6
6
  import {routes} from "@lodestar/api";
7
7
  import {BeaconConfig, ForkBoundary} from "@lodestar/config";
8
8
  import type {LoggerNode} from "@lodestar/logger/node";
@@ -1,9 +1,9 @@
1
1
  import path from "node:path";
2
2
  import workerThreads from "node:worker_threads";
3
3
  import {privateKeyToProtobuf} from "@libp2p/crypto/keys";
4
- import {PrivateKey} from "@libp2p/interface";
5
- import {PeerScoreStatsDump} from "@chainsafe/libp2p-gossipsub/score";
6
- import {PublishOpts} from "@chainsafe/libp2p-gossipsub/types";
4
+ import type {PeerScoreStatsDump} from "@libp2p/gossipsub/score";
5
+ import type {PublishOpts} from "@libp2p/gossipsub/types";
6
+ import type {PrivateKey} from "@libp2p/interface";
7
7
  import {ModuleThread, Thread, Worker, spawn} from "@chainsafe/threads";
8
8
  import {routes} from "@lodestar/api";
9
9
  import {BeaconConfig, chainConfigToJson} from "@lodestar/config";
@@ -1,5 +1,5 @@
1
- import {PeerScoreStatsDump} from "@chainsafe/libp2p-gossipsub/score";
2
- import {PublishOpts} from "@chainsafe/libp2p-gossipsub/types";
1
+ import type {PeerScoreStatsDump} from "@libp2p/gossipsub/score";
2
+ import type {PublishOpts} from "@libp2p/gossipsub/types";
3
3
  import {routes} from "@lodestar/api";
4
4
  import {SpecJson} from "@lodestar/config";
5
5
  import {LoggerNodeOpts} from "@lodestar/logger/node";
@@ -1,5 +1,6 @@
1
1
  import {EventEmitter} from "node:events";
2
- import {PeerId, TopicValidatorResult} from "@libp2p/interface";
2
+ import type {TopicValidatorResult} from "@libp2p/gossipsub";
3
+ import type {PeerId} from "@libp2p/interface";
3
4
  import {CustodyIndex, Status} from "@lodestar/types";
4
5
  import {PeerIdStr} from "../util/peerId.js";
5
6
  import {StrictEventEmitterSingleArg} from "../util/strictEvents.js";
@@ -1,9 +1,9 @@
1
- import {Message} from "@libp2p/interface";
1
+ import type {Message} from "@libp2p/gossipsub";
2
+ import type {RPC} from "@libp2p/gossipsub/message";
3
+ import type {DataTransform} from "@libp2p/gossipsub/types";
2
4
  // snappyjs is better for compression for smaller payloads
3
5
  import xxhashFactory from "xxhash-wasm";
4
6
  import {digest} from "@chainsafe/as-sha256";
5
- import {RPC} from "@chainsafe/libp2p-gossipsub/message";
6
- import {DataTransform} from "@chainsafe/libp2p-gossipsub/types";
7
7
  import snappyWasm from "@chainsafe/snappy-wasm";
8
8
  import {ForkName} from "@lodestar/params";
9
9
  import {intToBytes} from "@lodestar/utils";
@@ -1,10 +1,18 @@
1
+ import {
2
+ type GossipSub,
3
+ type GossipSubEvents,
4
+ type PublishResult,
5
+ StrictNoSign,
6
+ type TopicValidatorResult,
7
+ gossipsub,
8
+ } from "@libp2p/gossipsub";
9
+ import type {MetricsRegister, TopicLabel, TopicStrToLabel} from "@libp2p/gossipsub/metrics";
10
+ import type {PeerScoreParams, PeerScoreStatsDump} from "@libp2p/gossipsub/score";
11
+ import type {AddrInfo, PublishOpts, TopicStr} from "@libp2p/gossipsub/types";
12
+ import type {PeerId} from "@libp2p/interface";
1
13
  import {peerIdFromString} from "@libp2p/peer-id";
2
14
  import {multiaddr} from "@multiformats/multiaddr";
3
15
  import {ENR} from "@chainsafe/enr";
4
- import {GossipSub, GossipsubEvents} from "@chainsafe/libp2p-gossipsub";
5
- import {MetricsRegister, TopicLabel, TopicStrToLabel} from "@chainsafe/libp2p-gossipsub/metrics";
6
- import {PeerScoreParams} from "@chainsafe/libp2p-gossipsub/score";
7
- import {AddrInfo, SignaturePolicy, TopicStr} from "@chainsafe/libp2p-gossipsub/types";
8
16
  import {routes} from "@lodestar/api";
9
17
  import {BeaconConfig, ForkBoundary} from "@lodestar/config";
10
18
  import {ATTESTATION_SUBNET_COUNT, SLOTS_PER_EPOCH, SYNC_COMMITTEE_SUBNET_COUNT} from "@lodestar/params";
@@ -69,6 +77,24 @@ export type Eth2GossipsubOpts = {
69
77
 
70
78
  export type ForkBoundaryLabel = string;
71
79
 
80
+ // Many of the internal properties we need are not available on the public interface,
81
+ // so we create an extended type here to avoid excessive type assertions throughout the codebase.
82
+ // Mind that any updates to the gossipsub package may require updates to this type.
83
+ type GossipSubInternal = GossipSub & {
84
+ mesh: Map<string, Set<string>>;
85
+ peers: Map<string, PeerId>;
86
+ score: {score: (peerIdStr: string) => number};
87
+ direct: Set<string>;
88
+ topics: Map<string, Set<string>>;
89
+ start: () => Promise<void>;
90
+ stop: () => Promise<void>;
91
+ publish: (topic: TopicStr, data: Uint8Array, opts?: PublishOpts) => Promise<PublishResult>;
92
+ getMeshPeers: (topic: TopicStr) => string[];
93
+ dumpPeerScoreStats: () => PeerScoreStatsDump;
94
+ getScore: (peerIdStr: string) => number;
95
+ reportMessageValidationResult: (msgId: string, propagationSource: string, acceptance: TopicValidatorResult) => void;
96
+ };
97
+
72
98
  /**
73
99
  * Wrapper around js-libp2p-gossipsub with the following extensions:
74
100
  * - Eth2 message id
@@ -82,13 +108,14 @@ export type ForkBoundaryLabel = string;
82
108
  *
83
109
  * See https://github.com/ethereum/consensus-specs/blob/v1.1.10/specs/phase0/p2p-interface.md#the-gossip-domain-gossipsub
84
110
  */
85
- export class Eth2Gossipsub extends GossipSub {
111
+ export class Eth2Gossipsub {
86
112
  readonly scoreParams: Partial<PeerScoreParams>;
87
113
  private readonly config: BeaconConfig;
88
114
  private readonly logger: Logger;
89
115
  private readonly peersData: PeersData;
90
116
  private readonly events: NetworkEventBus;
91
117
  private readonly libp2p: Libp2p;
118
+ private readonly gossipsub: GossipSubInternal;
92
119
 
93
120
  // Internal caches
94
121
  private readonly gossipTopicCache: GossipTopicCache;
@@ -103,9 +130,6 @@ export class Eth2Gossipsub extends GossipSub {
103
130
  let metrics: Eth2GossipsubMetrics | null = null;
104
131
  if (metricsRegister) {
105
132
  metrics = createEth2GossipsubMetrics(metricsRegister);
106
- metrics.gossipMesh.peersByType.addCollect(() =>
107
- this.onScrapeLodestarMetrics(metrics as Eth2GossipsubMetrics, networkConfig)
108
- );
109
133
  }
110
134
 
111
135
  // Parse direct peers from multiaddr strings to AddrInfo objects
@@ -113,8 +137,8 @@ export class Eth2Gossipsub extends GossipSub {
113
137
 
114
138
  // Gossipsub parameters defined here:
115
139
  // https://github.com/ethereum/consensus-specs/blob/v1.1.10/specs/phase0/p2p-interface.md#the-gossip-domain-gossipsub
116
- super(modules.libp2p.services.components, {
117
- globalSignaturePolicy: SignaturePolicy.StrictNoSign,
140
+ const gossipsubInstance = gossipsub({
141
+ globalSignaturePolicy: StrictNoSign,
118
142
  allowPublishToZeroTopicPeers: allowPublishToZeroPeers,
119
143
  D: gossipsubD ?? GOSSIP_D,
120
144
  Dlo: gossipsubDLow ?? GOSSIP_D_LOW,
@@ -155,7 +179,12 @@ export class Eth2Gossipsub extends GossipSub {
155
179
  // This should be large enough to not send IDONTWANT for "small" messages
156
180
  // See https://github.com/ChainSafe/lodestar/pull/7077#issuecomment-2383679472
157
181
  idontwantMinDataSize: 16829,
158
- });
182
+ })(modules.libp2p.services.components) as GossipSubInternal;
183
+
184
+ if (metrics) {
185
+ metrics.gossipMesh.peersByType.addCollect(() => this.onScrapeLodestarMetrics(metrics, networkConfig));
186
+ }
187
+ this.gossipsub = gossipsubInstance;
159
188
  this.scoreParams = scoreParams;
160
189
  this.config = config;
161
190
  this.logger = logger;
@@ -164,7 +193,7 @@ export class Eth2Gossipsub extends GossipSub {
164
193
  this.libp2p = modules.libp2p;
165
194
  this.gossipTopicCache = gossipTopicCache;
166
195
 
167
- this.addEventListener("gossipsub:message", this.onGossipsubMessage.bind(this));
196
+ this.gossipsub.addEventListener("gossipsub:message", this.onGossipsubMessage.bind(this));
168
197
  this.events.on(NetworkEvent.gossipMessageValidationResult, this.onValidationResult.bind(this));
169
198
 
170
199
  // Having access to this data is CRUCIAL for debugging. While this is a massive log, it must not be deleted.
@@ -174,6 +203,38 @@ export class Eth2Gossipsub extends GossipSub {
174
203
  }
175
204
  }
176
205
 
206
+ async start(): Promise<void> {
207
+ await this.gossipsub.start();
208
+ }
209
+
210
+ async stop(): Promise<void> {
211
+ await this.gossipsub.stop();
212
+ }
213
+
214
+ get mesh(): Map<string, Set<string>> {
215
+ return this.gossipsub.mesh;
216
+ }
217
+
218
+ getTopics(): TopicStr[] {
219
+ return this.gossipsub.getTopics();
220
+ }
221
+
222
+ getMeshPeers(topic: TopicStr): string[] {
223
+ return this.gossipsub.getMeshPeers(topic);
224
+ }
225
+
226
+ publish(topic: TopicStr, data: Uint8Array, opts?: PublishOpts): Promise<PublishResult> {
227
+ return this.gossipsub.publish(topic, data, opts);
228
+ }
229
+
230
+ dumpPeerScoreStats(): PeerScoreStatsDump {
231
+ return this.gossipsub.dumpPeerScoreStats();
232
+ }
233
+
234
+ getScore(peerIdStr: string): number {
235
+ return this.gossipsub.getScore(peerIdStr);
236
+ }
237
+
177
238
  /**
178
239
  * Subscribe to a `GossipTopic`
179
240
  */
@@ -183,7 +244,7 @@ export class Eth2Gossipsub extends GossipSub {
183
244
  this.gossipTopicCache.setTopic(topicStr, topic);
184
245
 
185
246
  this.logger.verbose("Subscribe to gossipsub topic", {topic: topicStr});
186
- this.subscribe(topicStr);
247
+ this.gossipsub.subscribe(topicStr);
187
248
  }
188
249
 
189
250
  /**
@@ -192,15 +253,14 @@ export class Eth2Gossipsub extends GossipSub {
192
253
  unsubscribeTopic(topic: GossipTopic): void {
193
254
  const topicStr = stringifyGossipTopic(this.config, topic);
194
255
  this.logger.verbose("Unsubscribe to gossipsub topic", {topic: topicStr});
195
- this.unsubscribe(topicStr);
256
+ this.gossipsub.unsubscribe(topicStr);
196
257
  }
197
258
 
198
259
  private onScrapeLodestarMetrics(metrics: Eth2GossipsubMetrics, networkConfig: NetworkConfig): void {
199
- const mesh = this.mesh;
200
- // biome-ignore lint/complexity/useLiteralKeys: `topics` is a private attribute
201
- const topics = this["topics"] as Map<string, Set<string>>;
202
- const peers = this.peers;
203
- const score = this.score;
260
+ const mesh = this.gossipsub.mesh;
261
+ const topics = this.gossipsub.topics;
262
+ const peers = this.gossipsub.peers;
263
+ const score = this.gossipsub.score;
204
264
  const meshPeersByClient = new Map<string, number>();
205
265
  const meshPeerIdStrs = new Set<string>();
206
266
 
@@ -305,7 +365,7 @@ export class Eth2Gossipsub extends GossipSub {
305
365
  metrics.gossipPeer.score.set(gossipScores);
306
366
  }
307
367
 
308
- private onGossipsubMessage(event: GossipsubEvents["gossipsub:message"]): void {
368
+ private onGossipsubMessage(event: GossipSubEvents["gossipsub:message"]): void {
309
369
  const {propagationSource, msgId, msg} = event.detail;
310
370
 
311
371
  // Also validates that the topicStr is known
@@ -341,7 +401,7 @@ export class Eth2Gossipsub extends GossipSub {
341
401
  // Without this we'll have huge event loop lag
342
402
  // See https://github.com/ChainSafe/lodestar/issues/5604
343
403
  callInNextEventLoop(() => {
344
- this.reportMessageValidationResult(data.msgId, data.propagationSource, data.acceptance);
404
+ this.gossipsub.reportMessageValidationResult(data.msgId, data.propagationSource, data.acceptance);
345
405
  });
346
406
  }
347
407
 
@@ -379,7 +439,7 @@ export class Eth2Gossipsub extends GossipSub {
379
439
  }
380
440
 
381
441
  // Add to direct peers set only after addresses are stored
382
- this.direct.add(peerIdStr);
442
+ this.gossipsub.direct.add(peerIdStr);
383
443
 
384
444
  this.logger.info("Added direct peer via API", {peerId: peerIdStr});
385
445
  return peerIdStr;
@@ -389,7 +449,7 @@ export class Eth2Gossipsub extends GossipSub {
389
449
  * Remove a peer from direct peers.
390
450
  */
391
451
  removeDirectPeer(peerIdStr: string): boolean {
392
- const removed = this.direct.delete(peerIdStr);
452
+ const removed = this.gossipsub.direct.delete(peerIdStr);
393
453
  if (removed) {
394
454
  this.logger.info("Removed direct peer via API", {peerId: peerIdStr});
395
455
  }
@@ -400,7 +460,7 @@ export class Eth2Gossipsub extends GossipSub {
400
460
  * Get list of current direct peer IDs.
401
461
  */
402
462
  getDirectPeers(): string[] {
403
- return Array.from(this.direct);
463
+ return Array.from(this.gossipsub.direct);
404
464
  }
405
465
  }
406
466
 
@@ -498,7 +558,8 @@ export function parseDirectPeers(directPeerStrs: routes.lodestar.DirectPeer[], l
498
558
  try {
499
559
  const ma = multiaddr(peerStr);
500
560
 
501
- const peerIdStr = ma.getPeerId();
561
+ const peerIdComponent = ma.getComponents().findLast((component) => component.name === "p2p");
562
+ const peerIdStr = peerIdComponent?.value;
502
563
  if (!peerIdStr) {
503
564
  logger.warn("Direct peer multiaddr must contain /p2p/ component with peer ID", {multiaddr: peerStr});
504
565
  continue;
@@ -1,6 +1,6 @@
1
- import {Message, TopicValidatorResult} from "@libp2p/interface";
2
- import {Libp2p} from "libp2p";
3
- import {PeerIdStr} from "@chainsafe/libp2p-gossipsub/types";
1
+ import type {Message, TopicValidatorResult} from "@libp2p/gossipsub";
2
+ import type {PeerIdStr} from "@libp2p/gossipsub/types";
3
+ import type {Libp2p} from "libp2p";
4
4
  import {BeaconConfig, ForkBoundary} from "@lodestar/config";
5
5
  import {
6
6
  AttesterSlashing,
@@ -1,9 +1,9 @@
1
1
  import {
2
- PeerScoreParams,
3
- PeerScoreThresholds,
4
- TopicScoreParams,
2
+ type PeerScoreParams,
3
+ type PeerScoreThresholds,
4
+ type TopicScoreParams,
5
5
  defaultTopicScoreParams,
6
- } from "@chainsafe/libp2p-gossipsub/score";
6
+ } from "@libp2p/gossipsub/score";
7
7
  import {BeaconConfig} from "@lodestar/config";
8
8
  import {ATTESTATION_SUBNET_COUNT, PTC_SIZE, SLOTS_PER_EPOCH, TARGET_AGGREGATORS_PER_COMMITTEE} from "@lodestar/params";
9
9
  import {computeCommitteeCount} from "@lodestar/state-transition";
@@ -1,5 +1,5 @@
1
- import {Identify} from "@libp2p/identify";
2
- import {
1
+ import type {Identify} from "@libp2p/identify";
2
+ import type {
3
3
  ComponentLogger,
4
4
  ConnectionGater,
5
5
  ConnectionProtector,
@@ -16,7 +16,7 @@ import {
16
16
  } from "@libp2p/interface";
17
17
  import type {AddressManager, ConnectionManager, Registrar, TransportManager} from "@libp2p/interface-internal";
18
18
  import type {Datastore} from "interface-datastore";
19
- import {Libp2p as ILibp2p} from "libp2p";
19
+ import type {Libp2p as ILibp2p} from "libp2p";
20
20
  import {
21
21
  AttesterSlashing,
22
22
  DataColumnSidecar,