@lodestar/beacon-node 1.42.0-dev.1d50253953 → 1.42.0-dev.2219bb0cb8

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 (494) hide show
  1. package/lib/api/impl/beacon/blocks/index.d.ts.map +1 -1
  2. package/lib/api/impl/beacon/blocks/index.js +45 -13
  3. package/lib/api/impl/beacon/blocks/index.js.map +1 -1
  4. package/lib/api/impl/beacon/pool/index.d.ts.map +1 -1
  5. package/lib/api/impl/beacon/pool/index.js +5 -1
  6. package/lib/api/impl/beacon/pool/index.js.map +1 -1
  7. package/lib/api/impl/beacon/state/index.d.ts.map +1 -1
  8. package/lib/api/impl/beacon/state/index.js +38 -40
  9. package/lib/api/impl/beacon/state/index.js.map +1 -1
  10. package/lib/api/impl/beacon/state/utils.d.ts +4 -4
  11. package/lib/api/impl/beacon/state/utils.d.ts.map +1 -1
  12. package/lib/api/impl/beacon/state/utils.js +7 -10
  13. package/lib/api/impl/beacon/state/utils.js.map +1 -1
  14. package/lib/api/impl/debug/index.js.map +1 -1
  15. package/lib/api/impl/lodestar/index.d.ts.map +1 -1
  16. package/lib/api/impl/lodestar/index.js +8 -6
  17. package/lib/api/impl/lodestar/index.js.map +1 -1
  18. package/lib/api/impl/proof/index.d.ts.map +1 -1
  19. package/lib/api/impl/proof/index.js +2 -6
  20. package/lib/api/impl/proof/index.js.map +1 -1
  21. package/lib/api/impl/validator/index.d.ts.map +1 -1
  22. package/lib/api/impl/validator/index.js +35 -29
  23. package/lib/api/impl/validator/index.js.map +1 -1
  24. package/lib/api/impl/validator/utils.d.ts +2 -2
  25. package/lib/api/impl/validator/utils.d.ts.map +1 -1
  26. package/lib/api/impl/validator/utils.js +3 -3
  27. package/lib/api/impl/validator/utils.js.map +1 -1
  28. package/lib/chain/ColumnReconstructionTracker.d.ts +2 -1
  29. package/lib/chain/ColumnReconstructionTracker.d.ts.map +1 -1
  30. package/lib/chain/ColumnReconstructionTracker.js +5 -5
  31. package/lib/chain/ColumnReconstructionTracker.js.map +1 -1
  32. package/lib/chain/GetBlobsTracker.d.ts +2 -1
  33. package/lib/chain/GetBlobsTracker.d.ts.map +1 -1
  34. package/lib/chain/GetBlobsTracker.js +14 -12
  35. package/lib/chain/GetBlobsTracker.js.map +1 -1
  36. package/lib/chain/archiveStore/archiveStore.d.ts.map +1 -1
  37. package/lib/chain/archiveStore/archiveStore.js +1 -0
  38. package/lib/chain/archiveStore/archiveStore.js.map +1 -1
  39. package/lib/chain/archiveStore/historicalState/getHistoricalState.d.ts +3 -7
  40. package/lib/chain/archiveStore/historicalState/getHistoricalState.d.ts.map +1 -1
  41. package/lib/chain/archiveStore/historicalState/getHistoricalState.js +8 -26
  42. package/lib/chain/archiveStore/historicalState/getHistoricalState.js.map +1 -1
  43. package/lib/chain/archiveStore/historicalState/historicalStateRegen.d.ts +2 -2
  44. package/lib/chain/archiveStore/historicalState/historicalStateRegen.d.ts.map +1 -1
  45. package/lib/chain/archiveStore/historicalState/historicalStateRegen.js +1 -0
  46. package/lib/chain/archiveStore/historicalState/historicalStateRegen.js.map +1 -1
  47. package/lib/chain/archiveStore/historicalState/types.d.ts +2 -0
  48. package/lib/chain/archiveStore/historicalState/types.d.ts.map +1 -1
  49. package/lib/chain/archiveStore/historicalState/types.js.map +1 -1
  50. package/lib/chain/archiveStore/historicalState/worker.js +1 -3
  51. package/lib/chain/archiveStore/historicalState/worker.js.map +1 -1
  52. package/lib/chain/archiveStore/interface.d.ts +1 -0
  53. package/lib/chain/archiveStore/interface.d.ts.map +1 -1
  54. package/lib/chain/balancesCache.d.ts +2 -2
  55. package/lib/chain/balancesCache.d.ts.map +1 -1
  56. package/lib/chain/balancesCache.js +4 -4
  57. package/lib/chain/balancesCache.js.map +1 -1
  58. package/lib/chain/blocks/blockInput/blockInput.d.ts +5 -5
  59. package/lib/chain/blocks/blockInput/blockInput.d.ts.map +1 -1
  60. package/lib/chain/blocks/blockInput/blockInput.js.map +1 -1
  61. package/lib/chain/blocks/blockInput/types.d.ts +5 -4
  62. package/lib/chain/blocks/blockInput/types.d.ts.map +1 -1
  63. package/lib/chain/blocks/blockInput/types.js +1 -0
  64. package/lib/chain/blocks/blockInput/types.js.map +1 -1
  65. package/lib/chain/blocks/importBlock.d.ts +3 -3
  66. package/lib/chain/blocks/importBlock.d.ts.map +1 -1
  67. package/lib/chain/blocks/importBlock.js +37 -23
  68. package/lib/chain/blocks/importBlock.js.map +1 -1
  69. package/lib/chain/blocks/importExecutionPayload.d.ts +10 -8
  70. package/lib/chain/blocks/importExecutionPayload.d.ts.map +1 -1
  71. package/lib/chain/blocks/importExecutionPayload.js +87 -51
  72. package/lib/chain/blocks/importExecutionPayload.js.map +1 -1
  73. package/lib/chain/blocks/index.d.ts.map +1 -1
  74. package/lib/chain/blocks/index.js +3 -2
  75. package/lib/chain/blocks/index.js.map +1 -1
  76. package/lib/chain/blocks/payloadEnvelopeInput/payloadEnvelopeInput.d.ts +14 -6
  77. package/lib/chain/blocks/payloadEnvelopeInput/payloadEnvelopeInput.d.ts.map +1 -1
  78. package/lib/chain/blocks/payloadEnvelopeInput/payloadEnvelopeInput.js +33 -2
  79. package/lib/chain/blocks/payloadEnvelopeInput/payloadEnvelopeInput.js.map +1 -1
  80. package/lib/chain/blocks/payloadEnvelopeInput/types.d.ts +2 -1
  81. package/lib/chain/blocks/payloadEnvelopeInput/types.d.ts.map +1 -1
  82. package/lib/chain/blocks/types.d.ts +21 -15
  83. package/lib/chain/blocks/types.d.ts.map +1 -1
  84. package/lib/chain/blocks/types.js.map +1 -1
  85. package/lib/chain/blocks/utils/checkpoint.d.ts +2 -2
  86. package/lib/chain/blocks/utils/checkpoint.d.ts.map +1 -1
  87. package/lib/chain/blocks/utils/checkpoint.js.map +1 -1
  88. package/lib/chain/blocks/verifyBlock.d.ts +2 -2
  89. package/lib/chain/blocks/verifyBlock.d.ts.map +1 -1
  90. package/lib/chain/blocks/verifyBlock.js +4 -4
  91. package/lib/chain/blocks/verifyBlock.js.map +1 -1
  92. package/lib/chain/blocks/verifyBlocksExecutionPayloads.d.ts +5 -5
  93. package/lib/chain/blocks/verifyBlocksExecutionPayloads.d.ts.map +1 -1
  94. package/lib/chain/blocks/verifyBlocksExecutionPayloads.js +5 -4
  95. package/lib/chain/blocks/verifyBlocksExecutionPayloads.js.map +1 -1
  96. package/lib/chain/blocks/verifyBlocksSignatures.d.ts +2 -2
  97. package/lib/chain/blocks/verifyBlocksSignatures.d.ts.map +1 -1
  98. package/lib/chain/blocks/verifyBlocksSignatures.js +4 -2
  99. package/lib/chain/blocks/verifyBlocksSignatures.js.map +1 -1
  100. package/lib/chain/blocks/verifyBlocksStateTransitionOnly.d.ts +3 -3
  101. package/lib/chain/blocks/verifyBlocksStateTransitionOnly.d.ts.map +1 -1
  102. package/lib/chain/blocks/verifyBlocksStateTransitionOnly.js +3 -3
  103. package/lib/chain/blocks/verifyBlocksStateTransitionOnly.js.map +1 -1
  104. package/lib/chain/chain.d.ts +16 -14
  105. package/lib/chain/chain.d.ts.map +1 -1
  106. package/lib/chain/chain.js +123 -66
  107. package/lib/chain/chain.js.map +1 -1
  108. package/lib/chain/emitter.d.ts +31 -9
  109. package/lib/chain/emitter.d.ts.map +1 -1
  110. package/lib/chain/emitter.js +12 -3
  111. package/lib/chain/emitter.js.map +1 -1
  112. package/lib/chain/errors/blockError.d.ts +15 -5
  113. package/lib/chain/errors/blockError.d.ts.map +1 -1
  114. package/lib/chain/errors/blockError.js +4 -0
  115. package/lib/chain/errors/blockError.js.map +1 -1
  116. package/lib/chain/errors/dataColumnSidecarError.d.ts +31 -1
  117. package/lib/chain/errors/dataColumnSidecarError.d.ts.map +1 -1
  118. package/lib/chain/errors/dataColumnSidecarError.js +7 -0
  119. package/lib/chain/errors/dataColumnSidecarError.js.map +1 -1
  120. package/lib/chain/forkChoice/index.d.ts +4 -4
  121. package/lib/chain/forkChoice/index.d.ts.map +1 -1
  122. package/lib/chain/forkChoice/index.js +30 -24
  123. package/lib/chain/forkChoice/index.js.map +1 -1
  124. package/lib/chain/initState.d.ts +2 -2
  125. package/lib/chain/initState.d.ts.map +1 -1
  126. package/lib/chain/initState.js +1 -1
  127. package/lib/chain/initState.js.map +1 -1
  128. package/lib/chain/interface.d.ts +16 -14
  129. package/lib/chain/interface.d.ts.map +1 -1
  130. package/lib/chain/interface.js.map +1 -1
  131. package/lib/chain/lightClient/index.d.ts +2 -2
  132. package/lib/chain/lightClient/index.d.ts.map +1 -1
  133. package/lib/chain/lightClient/index.js +11 -4
  134. package/lib/chain/lightClient/index.js.map +1 -1
  135. package/lib/chain/opPools/aggregatedAttestationPool.d.ts +6 -6
  136. package/lib/chain/opPools/aggregatedAttestationPool.d.ts.map +1 -1
  137. package/lib/chain/opPools/aggregatedAttestationPool.js +13 -13
  138. package/lib/chain/opPools/aggregatedAttestationPool.js.map +1 -1
  139. package/lib/chain/opPools/executionPayloadBidPool.d.ts +2 -2
  140. package/lib/chain/opPools/executionPayloadBidPool.d.ts.map +1 -1
  141. package/lib/chain/opPools/executionPayloadBidPool.js +2 -2
  142. package/lib/chain/opPools/executionPayloadBidPool.js.map +1 -1
  143. package/lib/chain/opPools/opPool.d.ts +3 -3
  144. package/lib/chain/opPools/opPool.d.ts.map +1 -1
  145. package/lib/chain/opPools/opPool.js +7 -7
  146. package/lib/chain/opPools/opPool.js.map +1 -1
  147. package/lib/chain/opPools/utils.d.ts +2 -2
  148. package/lib/chain/opPools/utils.d.ts.map +1 -1
  149. package/lib/chain/opPools/utils.js +1 -1
  150. package/lib/chain/opPools/utils.js.map +1 -1
  151. package/lib/chain/options.d.ts +1 -0
  152. package/lib/chain/options.d.ts.map +1 -1
  153. package/lib/chain/options.js +1 -0
  154. package/lib/chain/options.js.map +1 -1
  155. package/lib/chain/prepareNextSlot.d.ts +2 -2
  156. package/lib/chain/prepareNextSlot.d.ts.map +1 -1
  157. package/lib/chain/prepareNextSlot.js +10 -4
  158. package/lib/chain/prepareNextSlot.js.map +1 -1
  159. package/lib/chain/produceBlock/computeNewStateRoot.d.ts +4 -4
  160. package/lib/chain/produceBlock/computeNewStateRoot.d.ts.map +1 -1
  161. package/lib/chain/produceBlock/computeNewStateRoot.js +9 -10
  162. package/lib/chain/produceBlock/computeNewStateRoot.js.map +1 -1
  163. package/lib/chain/produceBlock/produceBlockBody.d.ts +7 -7
  164. package/lib/chain/produceBlock/produceBlockBody.d.ts.map +1 -1
  165. package/lib/chain/produceBlock/produceBlockBody.js +32 -17
  166. package/lib/chain/produceBlock/produceBlockBody.js.map +1 -1
  167. package/lib/chain/regen/interface.d.ts +13 -13
  168. package/lib/chain/regen/interface.d.ts.map +1 -1
  169. package/lib/chain/regen/queued.d.ts +14 -14
  170. package/lib/chain/regen/queued.d.ts.map +1 -1
  171. package/lib/chain/regen/queued.js.map +1 -1
  172. package/lib/chain/regen/regen.d.ts +6 -5
  173. package/lib/chain/regen/regen.d.ts.map +1 -1
  174. package/lib/chain/regen/regen.js +6 -6
  175. package/lib/chain/regen/regen.js.map +1 -1
  176. package/lib/chain/seenCache/seenGossipBlockInput.d.ts +1 -1
  177. package/lib/chain/seenCache/seenGossipBlockInput.d.ts.map +1 -1
  178. package/lib/chain/seenCache/seenGossipBlockInput.js +2 -2
  179. package/lib/chain/seenCache/seenGossipBlockInput.js.map +1 -1
  180. package/lib/chain/seenCache/seenPayloadEnvelopeInput.d.ts +1 -1
  181. package/lib/chain/seenCache/seenPayloadEnvelopeInput.d.ts.map +1 -1
  182. package/lib/chain/seenCache/seenPayloadEnvelopeInput.js +2 -2
  183. package/lib/chain/seenCache/seenPayloadEnvelopeInput.js.map +1 -1
  184. package/lib/chain/serializeState.d.ts +2 -2
  185. package/lib/chain/serializeState.d.ts.map +1 -1
  186. package/lib/chain/serializeState.js +1 -1
  187. package/lib/chain/serializeState.js.map +1 -1
  188. package/lib/chain/shufflingCache.d.ts +2 -2
  189. package/lib/chain/shufflingCache.d.ts.map +1 -1
  190. package/lib/chain/shufflingCache.js +3 -4
  191. package/lib/chain/shufflingCache.js.map +1 -1
  192. package/lib/chain/stateCache/fifoBlockStateCache.d.ts +6 -6
  193. package/lib/chain/stateCache/fifoBlockStateCache.d.ts.map +1 -1
  194. package/lib/chain/stateCache/fifoBlockStateCache.js.map +1 -1
  195. package/lib/chain/stateCache/persistentCheckpointsCache.d.ts +11 -11
  196. package/lib/chain/stateCache/persistentCheckpointsCache.d.ts.map +1 -1
  197. package/lib/chain/stateCache/persistentCheckpointsCache.js +12 -16
  198. package/lib/chain/stateCache/persistentCheckpointsCache.js.map +1 -1
  199. package/lib/chain/stateCache/types.d.ts +14 -14
  200. package/lib/chain/stateCache/types.d.ts.map +1 -1
  201. package/lib/chain/stateCache/types.js.map +1 -1
  202. package/lib/chain/validation/attesterSlashing.js +3 -3
  203. package/lib/chain/validation/attesterSlashing.js.map +1 -1
  204. package/lib/chain/validation/blobSidecar.js +1 -1
  205. package/lib/chain/validation/blobSidecar.js.map +1 -1
  206. package/lib/chain/validation/block.d.ts.map +1 -1
  207. package/lib/chain/validation/block.js +28 -6
  208. package/lib/chain/validation/block.js.map +1 -1
  209. package/lib/chain/validation/blsToExecutionChange.js +2 -2
  210. package/lib/chain/validation/blsToExecutionChange.js.map +1 -1
  211. package/lib/chain/validation/dataColumnSidecar.d.ts +11 -4
  212. package/lib/chain/validation/dataColumnSidecar.d.ts.map +1 -1
  213. package/lib/chain/validation/dataColumnSidecar.js +185 -6
  214. package/lib/chain/validation/dataColumnSidecar.js.map +1 -1
  215. package/lib/chain/validation/executionPayloadBid.d.ts.map +1 -1
  216. package/lib/chain/validation/executionPayloadBid.js +10 -7
  217. package/lib/chain/validation/executionPayloadBid.js.map +1 -1
  218. package/lib/chain/validation/executionPayloadEnvelope.d.ts.map +1 -1
  219. package/lib/chain/validation/executionPayloadEnvelope.js +7 -3
  220. package/lib/chain/validation/executionPayloadEnvelope.js.map +1 -1
  221. package/lib/chain/validation/payloadAttestationMessage.js +5 -3
  222. package/lib/chain/validation/payloadAttestationMessage.js.map +1 -1
  223. package/lib/chain/validation/proposerSlashing.js +1 -1
  224. package/lib/chain/validation/proposerSlashing.js.map +1 -1
  225. package/lib/chain/validation/signatureSets/contributionAndProof.d.ts +2 -2
  226. package/lib/chain/validation/signatureSets/contributionAndProof.d.ts.map +1 -1
  227. package/lib/chain/validation/signatureSets/contributionAndProof.js +1 -1
  228. package/lib/chain/validation/signatureSets/contributionAndProof.js.map +1 -1
  229. package/lib/chain/validation/signatureSets/syncCommittee.d.ts +2 -2
  230. package/lib/chain/validation/signatureSets/syncCommittee.d.ts.map +1 -1
  231. package/lib/chain/validation/signatureSets/syncCommittee.js +1 -1
  232. package/lib/chain/validation/signatureSets/syncCommittee.js.map +1 -1
  233. package/lib/chain/validation/signatureSets/syncCommitteeContribution.d.ts +2 -2
  234. package/lib/chain/validation/signatureSets/syncCommitteeContribution.d.ts.map +1 -1
  235. package/lib/chain/validation/signatureSets/syncCommitteeContribution.js.map +1 -1
  236. package/lib/chain/validation/signatureSets/syncCommitteeSelectionProof.d.ts +2 -2
  237. package/lib/chain/validation/signatureSets/syncCommitteeSelectionProof.d.ts.map +1 -1
  238. package/lib/chain/validation/signatureSets/syncCommitteeSelectionProof.js +1 -1
  239. package/lib/chain/validation/signatureSets/syncCommitteeSelectionProof.js.map +1 -1
  240. package/lib/chain/validation/syncCommittee.d.ts +4 -4
  241. package/lib/chain/validation/syncCommittee.d.ts.map +1 -1
  242. package/lib/chain/validation/syncCommittee.js +17 -12
  243. package/lib/chain/validation/syncCommittee.js.map +1 -1
  244. package/lib/chain/validation/syncCommitteeContributionAndProof.d.ts.map +1 -1
  245. package/lib/chain/validation/syncCommitteeContributionAndProof.js +5 -2
  246. package/lib/chain/validation/syncCommitteeContributionAndProof.js.map +1 -1
  247. package/lib/chain/validation/voluntaryExit.d.ts.map +1 -1
  248. package/lib/chain/validation/voluntaryExit.js +3 -3
  249. package/lib/chain/validation/voluntaryExit.js.map +1 -1
  250. package/lib/chain/validatorMonitor.d.ts +3 -3
  251. package/lib/chain/validatorMonitor.d.ts.map +1 -1
  252. package/lib/chain/validatorMonitor.js +11 -9
  253. package/lib/chain/validatorMonitor.js.map +1 -1
  254. package/lib/db/buckets.d.ts +2 -2
  255. package/lib/db/buckets.d.ts.map +1 -1
  256. package/lib/db/buckets.js +2 -2
  257. package/lib/db/buckets.js.map +1 -1
  258. package/lib/db/repositories/blockArchiveIndex.d.ts +2 -2
  259. package/lib/db/repositories/blockArchiveIndex.d.ts.map +1 -1
  260. package/lib/db/repositories/dataColumnSidecar.d.ts.map +1 -1
  261. package/lib/db/repositories/dataColumnSidecar.js +4 -2
  262. package/lib/db/repositories/dataColumnSidecar.js.map +1 -1
  263. package/lib/db/repositories/dataColumnSidecarArchive.d.ts.map +1 -1
  264. package/lib/db/repositories/dataColumnSidecarArchive.js +4 -2
  265. package/lib/db/repositories/dataColumnSidecarArchive.js.map +1 -1
  266. package/lib/metrics/metrics/lodestar.d.ts +32 -4
  267. package/lib/metrics/metrics/lodestar.d.ts.map +1 -1
  268. package/lib/metrics/metrics/lodestar.js +52 -15
  269. package/lib/metrics/metrics/lodestar.js.map +1 -1
  270. package/lib/network/gossip/encoding.d.ts.map +1 -1
  271. package/lib/network/gossip/encoding.js +15 -0
  272. package/lib/network/gossip/encoding.js.map +1 -1
  273. package/lib/network/interface.d.ts +7 -4
  274. package/lib/network/interface.d.ts.map +1 -1
  275. package/lib/network/libp2p/index.d.ts.map +1 -1
  276. package/lib/network/libp2p/index.js +22 -11
  277. package/lib/network/libp2p/index.js.map +1 -1
  278. package/lib/network/network.d.ts +7 -4
  279. package/lib/network/network.d.ts.map +1 -1
  280. package/lib/network/network.js +12 -3
  281. package/lib/network/network.js.map +1 -1
  282. package/lib/network/options.d.ts.map +1 -1
  283. package/lib/network/options.js +7 -2
  284. package/lib/network/options.js.map +1 -1
  285. package/lib/network/processor/extractSlotRootFns.d.ts +1 -1
  286. package/lib/network/processor/extractSlotRootFns.d.ts.map +1 -1
  287. package/lib/network/processor/extractSlotRootFns.js +25 -5
  288. package/lib/network/processor/extractSlotRootFns.js.map +1 -1
  289. package/lib/network/processor/gossipHandlers.d.ts.map +1 -1
  290. package/lib/network/processor/gossipHandlers.js +269 -80
  291. package/lib/network/processor/gossipHandlers.js.map +1 -1
  292. package/lib/network/processor/index.d.ts +22 -7
  293. package/lib/network/processor/index.d.ts.map +1 -1
  294. package/lib/network/processor/index.js +313 -80
  295. package/lib/network/processor/index.js.map +1 -1
  296. package/lib/network/reqresp/ReqRespBeaconNode.d.ts.map +1 -1
  297. package/lib/network/reqresp/ReqRespBeaconNode.js +9 -0
  298. package/lib/network/reqresp/ReqRespBeaconNode.js.map +1 -1
  299. package/lib/network/reqresp/handlers/beaconBlocksByRange.d.ts.map +1 -1
  300. package/lib/network/reqresp/handlers/beaconBlocksByRange.js +2 -1
  301. package/lib/network/reqresp/handlers/beaconBlocksByRange.js.map +1 -1
  302. package/lib/network/reqresp/handlers/beaconBlocksByRoot.d.ts.map +1 -1
  303. package/lib/network/reqresp/handlers/beaconBlocksByRoot.js +2 -0
  304. package/lib/network/reqresp/handlers/beaconBlocksByRoot.js.map +1 -1
  305. package/lib/network/reqresp/handlers/blobSidecarsByRange.d.ts +2 -2
  306. package/lib/network/reqresp/handlers/blobSidecarsByRange.d.ts.map +1 -1
  307. package/lib/network/reqresp/handlers/blobSidecarsByRange.js +7 -3
  308. package/lib/network/reqresp/handlers/blobSidecarsByRange.js.map +1 -1
  309. package/lib/network/reqresp/handlers/blobSidecarsByRoot.d.ts.map +1 -1
  310. package/lib/network/reqresp/handlers/blobSidecarsByRoot.js +6 -0
  311. package/lib/network/reqresp/handlers/blobSidecarsByRoot.js.map +1 -1
  312. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts +2 -2
  313. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts.map +1 -1
  314. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js +7 -3
  315. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js.map +1 -1
  316. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRange.d.ts +8 -0
  317. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRange.d.ts.map +1 -0
  318. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRange.js +70 -0
  319. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRange.js.map +1 -0
  320. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRoot.d.ts +6 -0
  321. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRoot.d.ts.map +1 -0
  322. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRoot.js +23 -0
  323. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRoot.js.map +1 -0
  324. package/lib/network/reqresp/handlers/index.d.ts.map +1 -1
  325. package/lib/network/reqresp/handlers/index.js +11 -1
  326. package/lib/network/reqresp/handlers/index.js.map +1 -1
  327. package/lib/network/reqresp/protocols.d.ts +2 -0
  328. package/lib/network/reqresp/protocols.d.ts.map +1 -1
  329. package/lib/network/reqresp/protocols.js +10 -0
  330. package/lib/network/reqresp/protocols.js.map +1 -1
  331. package/lib/network/reqresp/rateLimit.d.ts.map +1 -1
  332. package/lib/network/reqresp/rateLimit.js +8 -0
  333. package/lib/network/reqresp/rateLimit.js.map +1 -1
  334. package/lib/network/reqresp/score.d.ts.map +1 -1
  335. package/lib/network/reqresp/score.js +2 -0
  336. package/lib/network/reqresp/score.js.map +1 -1
  337. package/lib/network/reqresp/types.d.ts +10 -4
  338. package/lib/network/reqresp/types.d.ts.map +1 -1
  339. package/lib/network/reqresp/types.js +16 -4
  340. package/lib/network/reqresp/types.js.map +1 -1
  341. package/lib/node/nodejs.d.ts +2 -2
  342. package/lib/node/nodejs.d.ts.map +1 -1
  343. package/lib/node/nodejs.js +3 -3
  344. package/lib/node/nodejs.js.map +1 -1
  345. package/lib/node/notifier.d.ts.map +1 -1
  346. package/lib/node/notifier.js +3 -3
  347. package/lib/node/notifier.js.map +1 -1
  348. package/lib/sync/backfill/backfill.d.ts +2 -2
  349. package/lib/sync/backfill/backfill.d.ts.map +1 -1
  350. package/lib/sync/backfill/backfill.js +2 -2
  351. package/lib/sync/backfill/backfill.js.map +1 -1
  352. package/lib/sync/unknownBlock.d.ts +3 -9
  353. package/lib/sync/unknownBlock.d.ts.map +1 -1
  354. package/lib/sync/unknownBlock.js +10 -43
  355. package/lib/sync/unknownBlock.js.map +1 -1
  356. package/lib/sync/utils/downloadByRange.d.ts +3 -3
  357. package/lib/sync/utils/downloadByRange.d.ts.map +1 -1
  358. package/lib/sync/utils/downloadByRange.js +4 -2
  359. package/lib/sync/utils/downloadByRange.js.map +1 -1
  360. package/lib/sync/utils/downloadByRoot.d.ts +3 -3
  361. package/lib/sync/utils/downloadByRoot.d.ts.map +1 -1
  362. package/lib/sync/utils/downloadByRoot.js +10 -5
  363. package/lib/sync/utils/downloadByRoot.js.map +1 -1
  364. package/lib/util/blobs.d.ts +3 -3
  365. package/lib/util/blobs.d.ts.map +1 -1
  366. package/lib/util/blobs.js +21 -10
  367. package/lib/util/blobs.js.map +1 -1
  368. package/lib/util/dataColumns.d.ts +18 -11
  369. package/lib/util/dataColumns.d.ts.map +1 -1
  370. package/lib/util/dataColumns.js +51 -17
  371. package/lib/util/dataColumns.js.map +1 -1
  372. package/lib/util/execution.d.ts +6 -2
  373. package/lib/util/execution.d.ts.map +1 -1
  374. package/lib/util/execution.js +49 -25
  375. package/lib/util/execution.js.map +1 -1
  376. package/lib/util/sszBytes.d.ts +25 -1
  377. package/lib/util/sszBytes.d.ts.map +1 -1
  378. package/lib/util/sszBytes.js +189 -2
  379. package/lib/util/sszBytes.js.map +1 -1
  380. package/lib/util/types.d.ts +2 -0
  381. package/lib/util/types.d.ts.map +1 -1
  382. package/lib/util/types.js +1 -0
  383. package/lib/util/types.js.map +1 -1
  384. package/package.json +16 -16
  385. package/src/api/impl/beacon/blocks/index.ts +62 -16
  386. package/src/api/impl/beacon/pool/index.ts +5 -1
  387. package/src/api/impl/beacon/state/index.ts +43 -55
  388. package/src/api/impl/beacon/state/utils.ts +11 -25
  389. package/src/api/impl/debug/index.ts +2 -2
  390. package/src/api/impl/lodestar/index.ts +8 -8
  391. package/src/api/impl/proof/index.ts +2 -9
  392. package/src/api/impl/validator/index.ts +38 -43
  393. package/src/api/impl/validator/utils.ts +4 -7
  394. package/src/chain/ColumnReconstructionTracker.ts +6 -5
  395. package/src/chain/GetBlobsTracker.ts +14 -12
  396. package/src/chain/archiveStore/archiveStore.ts +1 -0
  397. package/src/chain/archiveStore/historicalState/getHistoricalState.ts +10 -39
  398. package/src/chain/archiveStore/historicalState/historicalStateRegen.ts +2 -1
  399. package/src/chain/archiveStore/historicalState/types.ts +2 -0
  400. package/src/chain/archiveStore/historicalState/worker.ts +1 -4
  401. package/src/chain/archiveStore/interface.ts +1 -0
  402. package/src/chain/balancesCache.ts +5 -11
  403. package/src/chain/blocks/blockInput/blockInput.ts +8 -8
  404. package/src/chain/blocks/blockInput/types.ts +5 -4
  405. package/src/chain/blocks/importBlock.ts +50 -31
  406. package/src/chain/blocks/importExecutionPayload.ts +98 -62
  407. package/src/chain/blocks/index.ts +3 -2
  408. package/src/chain/blocks/payloadEnvelopeInput/payloadEnvelopeInput.ts +53 -12
  409. package/src/chain/blocks/payloadEnvelopeInput/types.ts +2 -1
  410. package/src/chain/blocks/types.ts +26 -15
  411. package/src/chain/blocks/utils/checkpoint.ts +2 -2
  412. package/src/chain/blocks/verifyBlock.ts +5 -10
  413. package/src/chain/blocks/verifyBlocksExecutionPayloads.ts +10 -14
  414. package/src/chain/blocks/verifyBlocksSignatures.ts +10 -3
  415. package/src/chain/blocks/verifyBlocksStateTransitionOnly.ts +6 -8
  416. package/src/chain/chain.ts +167 -98
  417. package/src/chain/emitter.ts +27 -9
  418. package/src/chain/errors/blockError.ts +11 -5
  419. package/src/chain/errors/dataColumnSidecarError.ts +32 -1
  420. package/src/chain/forkChoice/index.ts +35 -41
  421. package/src/chain/initState.ts +7 -2
  422. package/src/chain/interface.ts +21 -15
  423. package/src/chain/lightClient/index.ts +17 -18
  424. package/src/chain/opPools/aggregatedAttestationPool.ts +20 -21
  425. package/src/chain/opPools/executionPayloadBidPool.ts +3 -3
  426. package/src/chain/opPools/opPool.ts +13 -14
  427. package/src/chain/opPools/utils.ts +3 -3
  428. package/src/chain/options.ts +2 -0
  429. package/src/chain/prepareNextSlot.ts +14 -8
  430. package/src/chain/produceBlock/computeNewStateRoot.ts +13 -16
  431. package/src/chain/produceBlock/produceBlockBody.ts +51 -48
  432. package/src/chain/regen/interface.ts +13 -17
  433. package/src/chain/regen/queued.ts +16 -20
  434. package/src/chain/regen/regen.ts +16 -17
  435. package/src/chain/seenCache/seenGossipBlockInput.ts +2 -2
  436. package/src/chain/seenCache/seenPayloadEnvelopeInput.ts +2 -2
  437. package/src/chain/serializeState.ts +3 -3
  438. package/src/chain/shufflingCache.ts +5 -7
  439. package/src/chain/stateCache/fifoBlockStateCache.ts +7 -7
  440. package/src/chain/stateCache/persistentCheckpointsCache.ts +27 -42
  441. package/src/chain/stateCache/types.ts +14 -18
  442. package/src/chain/validation/attesterSlashing.ts +3 -3
  443. package/src/chain/validation/blobSidecar.ts +1 -1
  444. package/src/chain/validation/block.ts +31 -10
  445. package/src/chain/validation/blsToExecutionChange.ts +2 -2
  446. package/src/chain/validation/dataColumnSidecar.ts +231 -8
  447. package/src/chain/validation/executionPayloadBid.ts +10 -10
  448. package/src/chain/validation/executionPayloadEnvelope.ts +7 -4
  449. package/src/chain/validation/payloadAttestationMessage.ts +6 -4
  450. package/src/chain/validation/proposerSlashing.ts +1 -1
  451. package/src/chain/validation/signatureSets/contributionAndProof.ts +2 -7
  452. package/src/chain/validation/signatureSets/syncCommittee.ts +2 -7
  453. package/src/chain/validation/signatureSets/syncCommitteeContribution.ts +2 -2
  454. package/src/chain/validation/signatureSets/syncCommitteeSelectionProof.ts +2 -7
  455. package/src/chain/validation/syncCommittee.ts +25 -20
  456. package/src/chain/validation/syncCommitteeContributionAndProof.ts +9 -10
  457. package/src/chain/validation/voluntaryExit.ts +3 -8
  458. package/src/chain/validatorMonitor.ts +15 -13
  459. package/src/db/buckets.ts +2 -2
  460. package/src/db/repositories/dataColumnSidecar.ts +4 -2
  461. package/src/db/repositories/dataColumnSidecarArchive.ts +4 -2
  462. package/src/metrics/metrics/lodestar.ts +57 -19
  463. package/src/network/gossip/encoding.ts +16 -0
  464. package/src/network/interface.ts +18 -4
  465. package/src/network/libp2p/index.ts +24 -13
  466. package/src/network/network.ts +39 -8
  467. package/src/network/options.ts +7 -2
  468. package/src/network/processor/extractSlotRootFns.ts +32 -6
  469. package/src/network/processor/gossipHandlers.ts +334 -94
  470. package/src/network/processor/index.ts +395 -92
  471. package/src/network/reqresp/ReqRespBeaconNode.ts +13 -0
  472. package/src/network/reqresp/handlers/beaconBlocksByRange.ts +3 -1
  473. package/src/network/reqresp/handlers/beaconBlocksByRoot.ts +3 -0
  474. package/src/network/reqresp/handlers/blobSidecarsByRange.ts +15 -3
  475. package/src/network/reqresp/handlers/blobSidecarsByRoot.ts +11 -0
  476. package/src/network/reqresp/handlers/dataColumnSidecarsByRange.ts +19 -3
  477. package/src/network/reqresp/handlers/executionPayloadEnvelopesByRange.ts +96 -0
  478. package/src/network/reqresp/handlers/executionPayloadEnvelopesByRoot.ts +34 -0
  479. package/src/network/reqresp/handlers/index.ts +12 -0
  480. package/src/network/reqresp/protocols.ts +12 -0
  481. package/src/network/reqresp/rateLimit.ts +18 -0
  482. package/src/network/reqresp/score.ts +2 -0
  483. package/src/network/reqresp/types.ts +26 -5
  484. package/src/node/nodejs.ts +6 -5
  485. package/src/node/notifier.ts +5 -6
  486. package/src/sync/backfill/backfill.ts +3 -3
  487. package/src/sync/unknownBlock.ts +13 -53
  488. package/src/sync/utils/downloadByRange.ts +9 -7
  489. package/src/sync/utils/downloadByRoot.ts +16 -12
  490. package/src/util/blobs.ts +35 -15
  491. package/src/util/dataColumns.ts +69 -25
  492. package/src/util/execution.ts +49 -30
  493. package/src/util/sszBytes.ts +245 -3
  494. package/src/util/types.ts +6 -0
@@ -10,11 +10,13 @@ import {
10
10
  getBlockHeaderProposerSignatureSetByHeaderSlot,
11
11
  getBlockHeaderProposerSignatureSetByParentStateSlot,
12
12
  } from "@lodestar/state-transition";
13
- import {DataColumnSidecar, Root, Slot, SubnetID, fulu, ssz} from "@lodestar/types";
13
+ import {DataColumnSidecar, Root, Slot, SubnetID, fulu, gloas, ssz} from "@lodestar/types";
14
14
  import {byteArrayEquals, toRootHex, verifyMerkleBranch} from "@lodestar/utils";
15
15
  import {BeaconMetrics} from "../../metrics/metrics/beacon.js";
16
16
  import {Metrics} from "../../metrics/metrics.js";
17
+ import {getDataColumnSidecarSlot} from "../../util/dataColumns.js";
17
18
  import {kzg} from "../../util/kzg.js";
19
+ import {PayloadEnvelopeInput} from "../blocks/payloadEnvelopeInput/index.js";
18
20
  import {
19
21
  DataColumnSidecarErrorCode,
20
22
  DataColumnSidecarGossipError,
@@ -26,7 +28,7 @@ import {RegenCaller} from "../regen/interface.js";
26
28
 
27
29
  // SPEC FUNCTION
28
30
  // https://github.com/ethereum/consensus-specs/blob/v1.6.0-alpha.4/specs/fulu/p2p-interface.md#data_column_sidecar_subnet_id
29
- export async function validateGossipDataColumnSidecar(
31
+ export async function validateGossipFuluDataColumnSidecar(
30
32
  chain: IBeaconChain,
31
33
  dataColumnSidecar: fulu.DataColumnSidecar,
32
34
  gossipSubnet: SubnetID,
@@ -36,7 +38,7 @@ export async function validateGossipDataColumnSidecar(
36
38
  const blockRootHex = toRootHex(ssz.phase0.BeaconBlockHeader.hashTreeRoot(blockHeader));
37
39
 
38
40
  // 1) [REJECT] The sidecar is valid as verified by verify_data_column_sidecar
39
- verifyDataColumnSidecar(chain.config, dataColumnSidecar);
41
+ verifyFuluDataColumnSidecar(chain.config, dataColumnSidecar);
40
42
 
41
43
  // 2) [REJECT] The sidecar is for the correct subnet -- i.e. compute_subnet_for_data_column_sidecar(sidecar.index) == subnet_id
42
44
  if (computeSubnetForDataColumnSidecar(chain.config, dataColumnSidecar) !== gossipSubnet) {
@@ -122,7 +124,7 @@ export async function validateGossipDataColumnSidecar(
122
124
  // while proposers for the block's branch are calculated -- in such a case do not REJECT, instead IGNORE
123
125
  // this message.
124
126
  const proposerIndex = blockHeader.proposerIndex;
125
- const expectedProposerIndex = blockState.epochCtx.getBeaconProposer(blockHeader.slot);
127
+ const expectedProposerIndex = blockState.getBeaconProposer(blockHeader.slot);
126
128
 
127
129
  if (proposerIndex !== expectedProposerIndex) {
128
130
  throw new DataColumnSidecarGossipError(GossipAction.REJECT, {
@@ -203,11 +205,75 @@ export async function validateGossipDataColumnSidecar(
203
205
  // -- Handled in seenGossipBlockInput
204
206
  }
205
207
 
208
+ // SPEC FUNCTION
209
+ // https://github.com/ethereum/consensus-specs/blob/v1.7.0-alpha.3/specs/gloas/p2p-interface.md#data_column_sidecar_subnet_id
210
+ export async function validateGossipGloasDataColumnSidecar(
211
+ chain: IBeaconChain,
212
+ payloadInput: PayloadEnvelopeInput,
213
+ dataColumnSidecar: gloas.DataColumnSidecar,
214
+ gossipSubnet: SubnetID,
215
+ metrics: Metrics | null
216
+ ): Promise<void> {
217
+ const blockRootHex = toRootHex(dataColumnSidecar.beaconBlockRoot);
218
+ const block = chain.forkChoice.getBlockHexDefaultStatus(blockRootHex);
219
+
220
+ // [IGNORE] A valid block for the sidecar's `slot` has been seen.
221
+ if (block === null) {
222
+ throw new DataColumnSidecarGossipError(GossipAction.IGNORE, {
223
+ code: DataColumnSidecarErrorCode.BLOCK_UNKNOWN,
224
+ blockRoot: blockRootHex,
225
+ slot: dataColumnSidecar.slot,
226
+ });
227
+ }
228
+
229
+ // [REJECT] The sidecar slot matches the slot of the block with root beacon_block_root.
230
+ if (block.slot !== dataColumnSidecar.slot) {
231
+ throw new DataColumnSidecarGossipError(GossipAction.REJECT, {
232
+ code: DataColumnSidecarErrorCode.INCORRECT_SIDECAR_SLOT,
233
+ columnIndex: dataColumnSidecar.index,
234
+ expected: block.slot,
235
+ actual: dataColumnSidecar.slot,
236
+ });
237
+ }
238
+
239
+ // [REJECT] The sidecar must pass verify_data_column_sidecar against the block commitments
240
+ const kzgCommitments = payloadInput.getBlobKzgCommitments();
241
+ verifyGloasDataColumnSidecar(dataColumnSidecar, kzgCommitments);
242
+
243
+ // [REJECT] The sidecar must be on the correct subnet
244
+ if (computeSubnetForDataColumnSidecar(chain.config, dataColumnSidecar) !== gossipSubnet) {
245
+ throw new DataColumnSidecarGossipError(GossipAction.REJECT, {
246
+ code: DataColumnSidecarErrorCode.INVALID_SUBNET,
247
+ columnIndex: dataColumnSidecar.index,
248
+ gossipSubnet,
249
+ });
250
+ }
251
+
252
+ // [REJECT] The sidecar kzg proofs must verify
253
+ const kzgProofTimer = metrics?.peerDas.dataColumnSidecarKzgProofsVerificationTime.startTimer();
254
+ try {
255
+ await verifyDataColumnSidecarKzgProofs(
256
+ kzgCommitments,
257
+ Array.from({length: dataColumnSidecar.column.length}, () => dataColumnSidecar.index),
258
+ dataColumnSidecar.column,
259
+ dataColumnSidecar.kzgProofs
260
+ );
261
+ } catch {
262
+ throw new DataColumnSidecarGossipError(GossipAction.REJECT, {
263
+ code: DataColumnSidecarErrorCode.INVALID_KZG_PROOF,
264
+ slot: dataColumnSidecar.slot,
265
+ columnIndex: dataColumnSidecar.index,
266
+ });
267
+ } finally {
268
+ kzgProofTimer?.();
269
+ }
270
+ }
271
+
206
272
  /**
207
273
  * SPEC FUNCTION
208
274
  * https://github.com/ethereum/consensus-specs/blob/v1.6.0-alpha.4/specs/fulu/p2p-interface.md#verify_data_column_sidecar
209
275
  */
210
- function verifyDataColumnSidecar(config: ChainForkConfig, dataColumnSidecar: fulu.DataColumnSidecar): void {
276
+ function verifyFuluDataColumnSidecar(config: ChainForkConfig, dataColumnSidecar: fulu.DataColumnSidecar): void {
211
277
  if (dataColumnSidecar.index >= NUMBER_OF_COLUMNS) {
212
278
  throw new DataColumnSidecarGossipError(GossipAction.REJECT, {
213
279
  code: DataColumnSidecarErrorCode.INVALID_INDEX,
@@ -250,6 +316,41 @@ function verifyDataColumnSidecar(config: ChainForkConfig, dataColumnSidecar: ful
250
316
  }
251
317
  }
252
318
 
319
+ /**
320
+ * SPEC FUNCTION
321
+ * https://github.com/ethereum/consensus-specs/blob/v1.7.0-alpha.3/specs/gloas/p2p-interface.md#modified-verify_data_column_sidecar
322
+ */
323
+ function verifyGloasDataColumnSidecar(dataColumnSidecar: gloas.DataColumnSidecar, kzgCommitments: Uint8Array[]): void {
324
+ const slot = getDataColumnSidecarSlot(dataColumnSidecar);
325
+ if (dataColumnSidecar.index >= NUMBER_OF_COLUMNS) {
326
+ throw new DataColumnSidecarGossipError(GossipAction.REJECT, {
327
+ code: DataColumnSidecarErrorCode.INVALID_INDEX,
328
+ slot,
329
+ columnIndex: dataColumnSidecar.index,
330
+ });
331
+ }
332
+
333
+ if (dataColumnSidecar.column.length === 0) {
334
+ throw new DataColumnSidecarGossipError(GossipAction.REJECT, {
335
+ code: DataColumnSidecarErrorCode.NO_COMMITMENTS,
336
+ slot,
337
+ columnIndex: dataColumnSidecar.index,
338
+ });
339
+ }
340
+
341
+ if (
342
+ dataColumnSidecar.column.length !== kzgCommitments.length ||
343
+ dataColumnSidecar.column.length !== dataColumnSidecar.kzgProofs.length
344
+ ) {
345
+ throw new DataColumnSidecarGossipError(GossipAction.REJECT, {
346
+ code: DataColumnSidecarErrorCode.MISMATCHED_LENGTHS,
347
+ columnLength: dataColumnSidecar.column.length,
348
+ commitmentsLength: kzgCommitments.length,
349
+ proofsLength: dataColumnSidecar.kzgProofs.length,
350
+ });
351
+ }
352
+ }
353
+
253
354
  /**
254
355
  * SPEC FUNCTION
255
356
  * https://github.com/ethereum/consensus-specs/blob/v1.6.0-alpha.4/specs/fulu/p2p-interface.md#verify_data_column_sidecar_kzg_proofs
@@ -287,19 +388,19 @@ export function verifyDataColumnSidecarInclusionProof(dataColumnSidecar: fulu.Da
287
388
  }
288
389
 
289
390
  /**
290
- * Validate a subset of data column sidecars in a block
391
+ * Validate a subset of fulu data column sidecars against a block
291
392
  *
292
393
  * Requires the block to be known to the node
293
394
  *
294
395
  * NOTE: chain is optional to skip signature verification. Helpful for testing purposes and so that can control whether
295
396
  * signature gets checked depending on the reqresp method that is being checked
296
397
  */
297
- export async function validateBlockDataColumnSidecars(
398
+ export async function validateFuluBlockDataColumnSidecars(
298
399
  chain: IBeaconChain | null,
299
400
  blockSlot: Slot,
300
401
  blockRoot: Root,
301
402
  blockBlobCount: number,
302
- dataColumnSidecars: fulu.DataColumnSidecars,
403
+ dataColumnSidecars: fulu.DataColumnSidecar[],
303
404
  metrics?: BeaconMetrics["peerDas"] | null
304
405
  ): Promise<void> {
305
406
  metrics?.dataColumnSidecarProcessingRequests.inc(dataColumnSidecars.length);
@@ -467,6 +568,128 @@ export async function validateBlockDataColumnSidecars(
467
568
  "DataColumnSidecar has invalid KZG proof batch"
468
569
  );
469
570
  }
571
+
572
+ metrics?.dataColumnSidecarProcessingSuccesses.inc();
573
+ } finally {
574
+ verificationTimer?.();
575
+ }
576
+ }
577
+
578
+ /**
579
+ * Validate a subset of gloas data column sidecars against a block
580
+ * Gloas sidecars don't carry signed block headers, kzg commitments, or inclusion proofs
581
+ */
582
+ export async function validateGloasBlockDataColumnSidecars(
583
+ blockSlot: Slot,
584
+ blockRoot: Root,
585
+ blockKzgCommitments: Uint8Array[],
586
+ dataColumnSidecars: gloas.DataColumnSidecar[],
587
+ metrics?: BeaconMetrics["peerDas"] | null
588
+ ): Promise<void> {
589
+ metrics?.dataColumnSidecarProcessingRequests.inc(dataColumnSidecars.length);
590
+ const verificationTimer = metrics?.dataColumnSidecarGossipVerificationTime.startTimer();
591
+ try {
592
+ if (dataColumnSidecars.length === 0) {
593
+ return;
594
+ }
595
+
596
+ if (blockKzgCommitments.length === 0) {
597
+ throw new DataColumnSidecarValidationError(
598
+ {
599
+ code: DataColumnSidecarErrorCode.INCORRECT_SIDECAR_COUNT,
600
+ slot: blockSlot,
601
+ expected: 0,
602
+ actual: dataColumnSidecars.length,
603
+ },
604
+ "Block has no blob commitments but data column sidecars were provided"
605
+ );
606
+ }
607
+
608
+ const commitments: Uint8Array[] = [];
609
+ const cellIndices: number[] = [];
610
+ const cells: Uint8Array[] = [];
611
+ const proofs: Uint8Array[] = [];
612
+ for (const columnSidecar of dataColumnSidecars) {
613
+ if (columnSidecar.slot !== blockSlot) {
614
+ throw new DataColumnSidecarValidationError({
615
+ code: DataColumnSidecarErrorCode.INCORRECT_SIDECAR_SLOT,
616
+ columnIndex: columnSidecar.index,
617
+ expected: blockSlot,
618
+ actual: columnSidecar.slot,
619
+ });
620
+ }
621
+
622
+ if (!byteArrayEquals(columnSidecar.beaconBlockRoot, blockRoot)) {
623
+ throw new DataColumnSidecarValidationError({
624
+ code: DataColumnSidecarErrorCode.INCORRECT_BLOCK,
625
+ slot: blockSlot,
626
+ columnIndex: columnSidecar.index,
627
+ expected: toRootHex(blockRoot),
628
+ actual: toRootHex(columnSidecar.beaconBlockRoot),
629
+ });
630
+ }
631
+
632
+ if (columnSidecar.index >= NUMBER_OF_COLUMNS) {
633
+ throw new DataColumnSidecarValidationError(
634
+ {
635
+ code: DataColumnSidecarErrorCode.INVALID_INDEX,
636
+ slot: blockSlot,
637
+ columnIndex: columnSidecar.index,
638
+ },
639
+ "DataColumnSidecar has invalid index"
640
+ );
641
+ }
642
+
643
+ if (columnSidecar.column.length !== blockKzgCommitments.length) {
644
+ throw new DataColumnSidecarValidationError({
645
+ code: DataColumnSidecarErrorCode.INCORRECT_CELL_COUNT,
646
+ slot: blockSlot,
647
+ columnIndex: columnSidecar.index,
648
+ expected: blockKzgCommitments.length,
649
+ actual: columnSidecar.column.length,
650
+ });
651
+ }
652
+
653
+ if (columnSidecar.column.length !== columnSidecar.kzgProofs.length) {
654
+ throw new DataColumnSidecarValidationError({
655
+ code: DataColumnSidecarErrorCode.INCORRECT_KZG_PROOF_COUNT,
656
+ slot: blockSlot,
657
+ columnIndex: columnSidecar.index,
658
+ expected: columnSidecar.column.length,
659
+ actual: columnSidecar.kzgProofs.length,
660
+ });
661
+ }
662
+
663
+ commitments.push(...blockKzgCommitments);
664
+ cellIndices.push(...Array.from({length: columnSidecar.column.length}, () => columnSidecar.index));
665
+ cells.push(...columnSidecar.column);
666
+ proofs.push(...columnSidecar.kzgProofs);
667
+ }
668
+
669
+ let reason: string | undefined;
670
+ // batch verification for the cases: downloadByRange and downloadByRoot
671
+ const kzgVerificationTimer = metrics?.kzgVerificationDataColumnBatchTime.startTimer();
672
+ try {
673
+ const valid = await kzg.asyncVerifyCellKzgProofBatch(commitments, cellIndices, cells, proofs);
674
+ if (!valid) {
675
+ reason = "Invalid KZG proof batch";
676
+ }
677
+ } catch (e) {
678
+ reason = (e as Error).message;
679
+ } finally {
680
+ kzgVerificationTimer?.();
681
+ }
682
+ if (reason !== undefined) {
683
+ throw new DataColumnSidecarValidationError(
684
+ {
685
+ code: DataColumnSidecarErrorCode.INVALID_KZG_PROOF_BATCH,
686
+ slot: blockSlot,
687
+ reason,
688
+ },
689
+ "DataColumnSidecar has invalid KZG proof batch"
690
+ );
691
+ }
692
+
470
693
  metrics?.dataColumnSidecarProcessingSuccesses.inc();
471
694
  } finally {
472
695
  verificationTimer?.();
@@ -1,10 +1,9 @@
1
1
  import {PublicKey} from "@chainsafe/blst";
2
2
  import {
3
- CachedBeaconStateGloas,
4
- canBuilderCoverBid,
5
3
  createSingleSignatureSetFromComponents,
6
4
  getExecutionPayloadBidSigningRoot,
7
5
  isActiveBuilder,
6
+ isStatePostGloas,
8
7
  } from "@lodestar/state-transition";
9
8
  import {gloas} from "@lodestar/types";
10
9
  import {toRootHex} from "@lodestar/utils";
@@ -33,9 +32,10 @@ async function validateExecutionPayloadBid(
33
32
  const bid = signedExecutionPayloadBid.message;
34
33
  const parentBlockRootHex = toRootHex(bid.parentBlockRoot);
35
34
  const parentBlockHashHex = toRootHex(bid.parentBlockHash);
36
- const state = (await chain.getHeadStateAtCurrentEpoch(
37
- RegenCaller.validateGossipExecutionPayloadBid
38
- )) as CachedBeaconStateGloas;
35
+ const state = await chain.getHeadStateAtCurrentEpoch(RegenCaller.validateGossipExecutionPayloadBid);
36
+ if (!isStatePostGloas(state)) {
37
+ throw new Error(`Expected gloas+ state for execution payload bid validation, got fork=${state.forkName}`);
38
+ }
39
39
 
40
40
  // [IGNORE] `bid.slot` is the current slot or the next slot.
41
41
  const currentSlot = chain.clock.currentSlot;
@@ -53,7 +53,7 @@ async function validateExecutionPayloadBid(
53
53
 
54
54
  // [REJECT] `bid.builder_index` is a valid/active builder index -- i.e.
55
55
  // `is_active_builder(state, bid.builder_index)` returns `True`.
56
- const builder = state.builders.getReadonly(bid.builderIndex);
56
+ const builder = state.getBuilder(bid.builderIndex);
57
57
  if (!isActiveBuilder(builder, state.finalizedCheckpoint.epoch)) {
58
58
  throw new ExecutionPayloadBidError(GossipAction.REJECT, {
59
59
  code: ExecutionPayloadBidErrorCode.BUILDER_NOT_ELIGIBLE,
@@ -87,9 +87,9 @@ async function validateExecutionPayloadBid(
87
87
  });
88
88
  }
89
89
 
90
- // [IGNORE] this bid is the highest value bid seen for the corresponding slot
91
- // and the given parent block hash.
92
- const bestBid = chain.executionPayloadBidPool.getBestBid(parentBlockRootHex, parentBlockHashHex, bid.slot);
90
+ // [IGNORE] this bid is the highest value bid seen for the tuple
91
+ // `(bid.slot, bid.parent_block_hash, bid.parent_block_root)`.
92
+ const bestBid = chain.executionPayloadBidPool.getBestBid(bid.slot, parentBlockHashHex, parentBlockRootHex);
93
93
  if (bestBid !== null && bestBid.value >= bid.value) {
94
94
  throw new ExecutionPayloadBidError(GossipAction.IGNORE, {
95
95
  code: ExecutionPayloadBidErrorCode.BID_TOO_LOW,
@@ -99,7 +99,7 @@ async function validateExecutionPayloadBid(
99
99
  }
100
100
  // [IGNORE] `bid.value` is less or equal than the builder's excess balance --
101
101
  // i.e. `can_builder_cover_bid(state, builder_index, amount)` returns `True`.
102
- if (!canBuilderCoverBid(state, bid.builderIndex, bid.value)) {
102
+ if (!state.canBuilderCoverBid(bid.builderIndex, bid.value)) {
103
103
  throw new ExecutionPayloadBidError(GossipAction.IGNORE, {
104
104
  code: ExecutionPayloadBidErrorCode.BID_TOO_HIGH,
105
105
  bidValue: bid.value,
@@ -1,9 +1,8 @@
1
1
  import {PayloadStatus} from "@lodestar/fork-choice";
2
2
  import {
3
- BeaconStateView,
4
- CachedBeaconStateGloas,
5
3
  computeStartSlotAtEpoch,
6
4
  getExecutionPayloadEnvelopeSignatureSet,
5
+ isStatePostGloas,
7
6
  } from "@lodestar/state-transition";
8
7
  import {gloas} from "@lodestar/types";
9
8
  import {toRootHex} from "@lodestar/utils";
@@ -118,12 +117,16 @@ async function validateExecutionPayloadEnvelope(
118
117
  slot: envelope.slot,
119
118
  });
120
119
  });
120
+ if (!isStatePostGloas(blockState)) {
121
+ throw new Error(`Expected gloas+ state for execution payload envelope validation, got fork=${blockState.forkName}`);
122
+ }
121
123
 
122
- const state = blockState as CachedBeaconStateGloas;
124
+ // [REJECT] `signed_execution_payload_envelope.signature` is valid as verified
125
+ // by `verify_execution_payload_envelope_signature`.
123
126
  const signatureSet = getExecutionPayloadEnvelopeSignatureSet(
124
127
  chain.config,
125
128
  chain.pubkeyCache,
126
- new BeaconStateView(state),
129
+ blockState,
127
130
  executionPayloadEnvelope,
128
131
  payloadInput.proposerIndex
129
132
  );
@@ -1,8 +1,8 @@
1
1
  import {
2
- CachedBeaconStateGloas,
3
2
  computeEpochAtSlot,
4
3
  createSingleSignatureSetFromComponents,
5
4
  getPayloadAttestationDataSigningRoot,
5
+ isStatePostGloas,
6
6
  } from "@lodestar/state-transition";
7
7
  import {RootHex, gloas, ssz} from "@lodestar/types";
8
8
  import {toRootHex} from "@lodestar/utils";
@@ -66,7 +66,10 @@ async function validatePayloadAttestationMessage(
66
66
  });
67
67
  }
68
68
 
69
- const state = chain.getHeadState() as CachedBeaconStateGloas;
69
+ const state = chain.getHeadState();
70
+ if (!isStatePostGloas(state)) {
71
+ throw new Error(`Expected gloas+ state for payload attestation validation, got fork=${state.forkName}`);
72
+ }
70
73
 
71
74
  // [REJECT] The message's block `data.beacon_block_root` passes validation.
72
75
  // TODO GLOAS: implement this. Technically if we cannot get proto block from fork choice,
@@ -75,8 +78,7 @@ async function validatePayloadAttestationMessage(
75
78
  // [REJECT] The message's validator index is within the payload committee in
76
79
  // `get_ptc(state, data.slot)`. The `state` is the head state corresponding to
77
80
  // processing the block up to the current slot as determined by the fork choice.
78
- const ptc = state.epochCtx.getPayloadTimelinessCommittee(data.slot);
79
- const validatorCommitteeIndex = ptc.indexOf(validatorIndex);
81
+ const validatorCommitteeIndex = state.getIndexInPayloadTimelinessCommittee(validatorIndex, data.slot);
80
82
 
81
83
  if (validatorCommitteeIndex === -1) {
82
84
  throw new PayloadAttestationError(GossipAction.REJECT, {
@@ -35,7 +35,7 @@ async function validateProposerSlashing(
35
35
 
36
36
  // [REJECT] All of the conditions within process_proposer_slashing pass validation.
37
37
  try {
38
- const proposer = state.validators.getReadonly(proposerSlashing.signedHeader1.message.proposerIndex);
38
+ const proposer = state.getValidator(proposerSlashing.signedHeader1.message.proposerIndex);
39
39
  // verifySignature = false, verified in batch below
40
40
  assertValidProposerSlashing(chain.config, chain.pubkeyCache, state.slot, proposerSlashing, proposer, false);
41
41
  } catch (e) {
@@ -1,16 +1,11 @@
1
1
  import {BeaconConfig} from "@lodestar/config";
2
2
  import {DOMAIN_CONTRIBUTION_AND_PROOF} from "@lodestar/params";
3
- import {
4
- CachedBeaconStateAllForks,
5
- ISignatureSet,
6
- SignatureSetType,
7
- computeSigningRoot,
8
- } from "@lodestar/state-transition";
3
+ import {IBeaconStateView, ISignatureSet, SignatureSetType, computeSigningRoot} from "@lodestar/state-transition";
9
4
  import {altair, ssz} from "@lodestar/types";
10
5
 
11
6
  export function getContributionAndProofSignatureSet(
12
7
  config: BeaconConfig,
13
- state: CachedBeaconStateAllForks,
8
+ state: IBeaconStateView,
14
9
  signedContributionAndProof: altair.SignedContributionAndProof
15
10
  ): ISignatureSet {
16
11
  const domain = config.getDomain(
@@ -1,16 +1,11 @@
1
1
  import {BeaconConfig} from "@lodestar/config";
2
2
  import {DOMAIN_SYNC_COMMITTEE} from "@lodestar/params";
3
- import {
4
- CachedBeaconStateAllForks,
5
- ISignatureSet,
6
- SignatureSetType,
7
- computeSigningRoot,
8
- } from "@lodestar/state-transition";
3
+ import {IBeaconStateView, ISignatureSet, SignatureSetType, computeSigningRoot} from "@lodestar/state-transition";
9
4
  import {altair, ssz} from "@lodestar/types";
10
5
 
11
6
  export function getSyncCommitteeSignatureSet(
12
7
  config: BeaconConfig,
13
- state: CachedBeaconStateAllForks,
8
+ state: IBeaconStateView,
14
9
  syncCommittee: altair.SyncCommitteeMessage
15
10
  ): ISignatureSet {
16
11
  const domain = config.getDomain(state.slot, DOMAIN_SYNC_COMMITTEE, syncCommittee.slot);
@@ -1,11 +1,11 @@
1
1
  import {BeaconConfig} from "@lodestar/config";
2
2
  import {DOMAIN_SYNC_COMMITTEE} from "@lodestar/params";
3
- import {CachedBeaconStateAltair, ISignatureSet, SignatureSetType, computeSigningRoot} from "@lodestar/state-transition";
3
+ import {IBeaconStateView, ISignatureSet, SignatureSetType, computeSigningRoot} from "@lodestar/state-transition";
4
4
  import {altair, ssz} from "@lodestar/types";
5
5
 
6
6
  export function getSyncCommitteeContributionSignatureSet(
7
7
  config: BeaconConfig,
8
- state: CachedBeaconStateAltair,
8
+ state: IBeaconStateView,
9
9
  contribution: altair.SyncCommitteeContribution,
10
10
  participantIndices: number[]
11
11
  ): ISignatureSet {
@@ -1,16 +1,11 @@
1
1
  import {BeaconConfig} from "@lodestar/config";
2
2
  import {DOMAIN_SYNC_COMMITTEE_SELECTION_PROOF} from "@lodestar/params";
3
- import {
4
- CachedBeaconStateAllForks,
5
- ISignatureSet,
6
- SignatureSetType,
7
- computeSigningRoot,
8
- } from "@lodestar/state-transition";
3
+ import {IBeaconStateView, ISignatureSet, SignatureSetType, computeSigningRoot} from "@lodestar/state-transition";
9
4
  import {altair, ssz} from "@lodestar/types";
10
5
 
11
6
  export function getSyncCommitteeSelectionProofSignatureSet(
12
7
  config: BeaconConfig,
13
- state: CachedBeaconStateAllForks,
8
+ state: IBeaconStateView,
14
9
  contributionAndProof: altair.ContributionAndProof
15
10
  ): ISignatureSet {
16
11
  const slot = contributionAndProof.contribution.slot;
@@ -1,5 +1,5 @@
1
1
  import {SYNC_COMMITTEE_SUBNET_COUNT, SYNC_COMMITTEE_SUBNET_SIZE} from "@lodestar/params";
2
- import {CachedBeaconStateAllForks} from "@lodestar/state-transition";
2
+ import {IBeaconStateView, isStatePostAltair} from "@lodestar/state-transition";
3
3
  import {SubnetID, altair} from "@lodestar/types";
4
4
  import {toRootHex} from "@lodestar/utils";
5
5
  import {GossipAction, SyncCommitteeError, SyncCommitteeErrorCode} from "../errors/index.js";
@@ -15,12 +15,12 @@ export async function validateGossipSyncCommittee(
15
15
  chain: IBeaconChain,
16
16
  syncCommittee: altair.SyncCommitteeMessage,
17
17
  subnet: SubnetID
18
- ): Promise<{indexInSubcommittee: IndexInSubcommittee}> {
18
+ ): Promise<{indicesInSubcommittee: IndexInSubcommittee[]}> {
19
19
  const {slot, validatorIndex, beaconBlockRoot} = syncCommittee;
20
20
  const messageRoot = toRootHex(beaconBlockRoot);
21
21
 
22
22
  const headState = chain.getHeadState();
23
- const indexInSubcommittee = validateGossipSyncCommitteeExceptSig(chain, headState, subnet, syncCommittee);
23
+ const indicesInSubcommittee = validateGossipSyncCommitteeExceptSig(chain, headState, subnet, syncCommittee);
24
24
 
25
25
  // [IGNORE] The signature's slot is for the current slot, i.e. sync_committee_signature.slot == current_slot.
26
26
  // > Checked in validateGossipSyncCommitteeExceptSig()
@@ -68,12 +68,12 @@ export async function validateGossipSyncCommittee(
68
68
  // Register this valid item as seen
69
69
  chain.seenSyncCommitteeMessages.add(slot, subnet, validatorIndex, messageRoot);
70
70
 
71
- return {indexInSubcommittee};
71
+ return {indicesInSubcommittee};
72
72
  }
73
73
 
74
74
  export async function validateApiSyncCommittee(
75
75
  chain: IBeaconChain,
76
- headState: CachedBeaconStateAllForks,
76
+ headState: IBeaconStateView,
77
77
  syncCommittee: altair.SyncCommitteeMessage
78
78
  ): Promise<void> {
79
79
  const prioritizeBls = true;
@@ -85,7 +85,7 @@ export async function validateApiSyncCommittee(
85
85
  */
86
86
  async function validateSyncCommitteeSigOnly(
87
87
  chain: IBeaconChain,
88
- headState: CachedBeaconStateAllForks,
88
+ headState: IBeaconStateView,
89
89
  syncCommittee: altair.SyncCommitteeMessage,
90
90
  prioritizeBls = false
91
91
  ): Promise<void> {
@@ -102,10 +102,10 @@ async function validateSyncCommitteeSigOnly(
102
102
  */
103
103
  export function validateGossipSyncCommitteeExceptSig(
104
104
  chain: IBeaconChain,
105
- headState: CachedBeaconStateAllForks,
105
+ headState: IBeaconStateView,
106
106
  subnet: SubnetID,
107
107
  data: Pick<altair.SyncCommitteeMessage, "slot" | "validatorIndex">
108
- ): IndexInSubcommittee {
108
+ ): IndexInSubcommittee[] {
109
109
  const {slot, validatorIndex} = data;
110
110
  // [IGNORE] The signature's slot is for the current slot, i.e. sync_committee_signature.slot == current_slot.
111
111
  // (with a MAXIMUM_GOSSIP_CLOCK_DISPARITY allowance)
@@ -127,39 +127,44 @@ export function validateGossipSyncCommitteeExceptSig(
127
127
 
128
128
  // [REJECT] The subnet_id is valid for the given validator, i.e. subnet_id in compute_subnets_for_sync_committee(state, sync_committee_signature.validator_index).
129
129
  // Note this validation implies the validator is part of the broader current sync committee along with the correct subcommittee.
130
- const indexInSubcommittee = getIndexInSubcommittee(headState, subnet, data);
131
- if (indexInSubcommittee === null) {
130
+ const indicesInSubcommittee = getIndicesInSubcommittee(headState, subnet, data);
131
+ if (indicesInSubcommittee === null) {
132
132
  throw new SyncCommitteeError(GossipAction.REJECT, {
133
133
  code: SyncCommitteeErrorCode.VALIDATOR_NOT_IN_SYNC_COMMITTEE,
134
134
  validatorIndex,
135
135
  });
136
136
  }
137
137
 
138
- return indexInSubcommittee;
138
+ return indicesInSubcommittee;
139
139
  }
140
140
 
141
141
  /**
142
- * Returns the IndexInSubcommittee of the given `subnet`.
143
- * Returns `null` if not part of the sync committee or not part of the given `subnet`
142
+ * Returns all IndexInSubcommittee positions of the given `subnet`.
143
+ * Returns `null` if not part of the sync committee or not part of the given `subnet`.
144
+ * A validator may appear multiple times in the same subcommittee.
144
145
  */
145
- function getIndexInSubcommittee(
146
- headState: CachedBeaconStateAllForks,
146
+ function getIndicesInSubcommittee(
147
+ headState: IBeaconStateView,
147
148
  subnet: SubnetID,
148
149
  data: Pick<altair.SyncCommitteeMessage, "slot" | "validatorIndex">
149
- ): IndexInSubcommittee | null {
150
- const syncCommittee = headState.epochCtx.getIndexedSyncCommittee(data.slot);
150
+ ): IndexInSubcommittee[] | null {
151
+ if (!isStatePostAltair(headState)) {
152
+ return null;
153
+ }
154
+
155
+ const syncCommittee = headState.getIndexedSyncCommittee(data.slot);
151
156
  const indexesInCommittee = syncCommittee.validatorIndexMap.get(data.validatorIndex);
152
157
  if (indexesInCommittee === undefined) {
153
158
  // Not part of the sync committee
154
159
  return null;
155
160
  }
156
161
 
162
+ const indices: IndexInSubcommittee[] = [];
157
163
  for (const indexInCommittee of indexesInCommittee) {
158
164
  if (Math.floor(indexInCommittee / SYNC_COMMITTEE_SUBNET_SIZE) === subnet) {
159
- return indexInCommittee % SYNC_COMMITTEE_SUBNET_SIZE;
165
+ indices.push(indexInCommittee % SYNC_COMMITTEE_SUBNET_SIZE);
160
166
  }
161
167
  }
162
168
 
163
- // Not part of this specific subnet
164
- return null;
169
+ return indices.length > 0 ? indices : null;
165
170
  }