@lodestar/beacon-node 1.42.0-dev.4411584fd8 → 1.42.0-dev.5007abf468

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 (405) hide show
  1. package/lib/api/impl/beacon/blocks/index.d.ts.map +1 -1
  2. package/lib/api/impl/beacon/blocks/index.js +36 -17
  3. package/lib/api/impl/beacon/blocks/index.js.map +1 -1
  4. package/lib/api/impl/beacon/pool/index.js +1 -1
  5. package/lib/api/impl/beacon/pool/index.js.map +1 -1
  6. package/lib/api/impl/beacon/state/index.d.ts.map +1 -1
  7. package/lib/api/impl/beacon/state/index.js +27 -32
  8. package/lib/api/impl/beacon/state/index.js.map +1 -1
  9. package/lib/api/impl/beacon/state/utils.d.ts +4 -4
  10. package/lib/api/impl/beacon/state/utils.d.ts.map +1 -1
  11. package/lib/api/impl/beacon/state/utils.js +7 -10
  12. package/lib/api/impl/beacon/state/utils.js.map +1 -1
  13. package/lib/api/impl/lodestar/index.d.ts.map +1 -1
  14. package/lib/api/impl/lodestar/index.js +4 -6
  15. package/lib/api/impl/lodestar/index.js.map +1 -1
  16. package/lib/api/impl/proof/index.d.ts.map +1 -1
  17. package/lib/api/impl/proof/index.js +2 -6
  18. package/lib/api/impl/proof/index.js.map +1 -1
  19. package/lib/api/impl/validator/index.d.ts.map +1 -1
  20. package/lib/api/impl/validator/index.js +27 -27
  21. package/lib/api/impl/validator/index.js.map +1 -1
  22. package/lib/api/impl/validator/utils.d.ts +2 -2
  23. package/lib/api/impl/validator/utils.d.ts.map +1 -1
  24. package/lib/api/impl/validator/utils.js +3 -3
  25. package/lib/api/impl/validator/utils.js.map +1 -1
  26. package/lib/chain/archiveStore/historicalState/getHistoricalState.d.ts +2 -6
  27. package/lib/chain/archiveStore/historicalState/getHistoricalState.d.ts.map +1 -1
  28. package/lib/chain/archiveStore/historicalState/getHistoricalState.js +3 -23
  29. package/lib/chain/archiveStore/historicalState/getHistoricalState.js.map +1 -1
  30. package/lib/chain/archiveStore/historicalState/worker.js +1 -0
  31. package/lib/chain/archiveStore/historicalState/worker.js.map +1 -1
  32. package/lib/chain/balancesCache.d.ts +2 -2
  33. package/lib/chain/balancesCache.d.ts.map +1 -1
  34. package/lib/chain/balancesCache.js +4 -4
  35. package/lib/chain/balancesCache.js.map +1 -1
  36. package/lib/chain/blocks/blockInput/types.d.ts +4 -3
  37. package/lib/chain/blocks/blockInput/types.d.ts.map +1 -1
  38. package/lib/chain/blocks/blockInput/types.js +1 -0
  39. package/lib/chain/blocks/blockInput/types.js.map +1 -1
  40. package/lib/chain/blocks/importBlock.d.ts +3 -3
  41. package/lib/chain/blocks/importBlock.d.ts.map +1 -1
  42. package/lib/chain/blocks/importBlock.js +27 -11
  43. package/lib/chain/blocks/importBlock.js.map +1 -1
  44. package/lib/chain/blocks/importExecutionPayload.d.ts +48 -0
  45. package/lib/chain/blocks/importExecutionPayload.d.ts.map +1 -0
  46. package/lib/chain/blocks/importExecutionPayload.js +158 -0
  47. package/lib/chain/blocks/importExecutionPayload.js.map +1 -0
  48. package/lib/chain/blocks/index.js +1 -1
  49. package/lib/chain/blocks/index.js.map +1 -1
  50. package/lib/chain/blocks/payloadEnvelopeInput/index.d.ts +3 -0
  51. package/lib/chain/blocks/payloadEnvelopeInput/index.d.ts.map +1 -0
  52. package/lib/chain/blocks/payloadEnvelopeInput/index.js +3 -0
  53. package/lib/chain/blocks/payloadEnvelopeInput/index.js.map +1 -0
  54. package/lib/chain/blocks/payloadEnvelopeInput/payloadEnvelopeInput.d.ts +80 -0
  55. package/lib/chain/blocks/payloadEnvelopeInput/payloadEnvelopeInput.d.ts.map +1 -0
  56. package/lib/chain/blocks/payloadEnvelopeInput/payloadEnvelopeInput.js +248 -0
  57. package/lib/chain/blocks/payloadEnvelopeInput/payloadEnvelopeInput.js.map +1 -0
  58. package/lib/chain/blocks/payloadEnvelopeInput/types.d.ts +29 -0
  59. package/lib/chain/blocks/payloadEnvelopeInput/types.d.ts.map +1 -0
  60. package/lib/chain/blocks/payloadEnvelopeInput/types.js +11 -0
  61. package/lib/chain/blocks/payloadEnvelopeInput/types.js.map +1 -0
  62. package/lib/chain/blocks/payloadEnvelopeProcessor.d.ts +15 -0
  63. package/lib/chain/blocks/payloadEnvelopeProcessor.d.ts.map +1 -0
  64. package/lib/chain/blocks/payloadEnvelopeProcessor.js +46 -0
  65. package/lib/chain/blocks/payloadEnvelopeProcessor.js.map +1 -0
  66. package/lib/chain/blocks/types.d.ts +9 -2
  67. package/lib/chain/blocks/types.d.ts.map +1 -1
  68. package/lib/chain/blocks/types.js.map +1 -1
  69. package/lib/chain/blocks/utils/checkpoint.d.ts +2 -2
  70. package/lib/chain/blocks/utils/checkpoint.d.ts.map +1 -1
  71. package/lib/chain/blocks/utils/checkpoint.js.map +1 -1
  72. package/lib/chain/blocks/verifyBlock.d.ts +2 -2
  73. package/lib/chain/blocks/verifyBlock.d.ts.map +1 -1
  74. package/lib/chain/blocks/verifyBlock.js +4 -4
  75. package/lib/chain/blocks/verifyBlock.js.map +1 -1
  76. package/lib/chain/blocks/verifyBlocksExecutionPayloads.d.ts +3 -3
  77. package/lib/chain/blocks/verifyBlocksExecutionPayloads.d.ts.map +1 -1
  78. package/lib/chain/blocks/verifyBlocksExecutionPayloads.js +3 -3
  79. package/lib/chain/blocks/verifyBlocksExecutionPayloads.js.map +1 -1
  80. package/lib/chain/blocks/verifyBlocksSignatures.d.ts +2 -2
  81. package/lib/chain/blocks/verifyBlocksSignatures.d.ts.map +1 -1
  82. package/lib/chain/blocks/verifyBlocksSignatures.js +1 -1
  83. package/lib/chain/blocks/verifyBlocksSignatures.js.map +1 -1
  84. package/lib/chain/blocks/verifyBlocksStateTransitionOnly.d.ts +3 -3
  85. package/lib/chain/blocks/verifyBlocksStateTransitionOnly.d.ts.map +1 -1
  86. package/lib/chain/blocks/verifyBlocksStateTransitionOnly.js +3 -3
  87. package/lib/chain/blocks/verifyBlocksStateTransitionOnly.js.map +1 -1
  88. package/lib/chain/blocks/writePayloadEnvelopeInputToDb.d.ts +12 -0
  89. package/lib/chain/blocks/writePayloadEnvelopeInputToDb.d.ts.map +1 -0
  90. package/lib/chain/blocks/writePayloadEnvelopeInputToDb.js +40 -0
  91. package/lib/chain/blocks/writePayloadEnvelopeInputToDb.js.map +1 -0
  92. package/lib/chain/chain.d.ts +19 -14
  93. package/lib/chain/chain.d.ts.map +1 -1
  94. package/lib/chain/chain.js +75 -42
  95. package/lib/chain/chain.js.map +1 -1
  96. package/lib/chain/emitter.d.ts +2 -2
  97. package/lib/chain/emitter.d.ts.map +1 -1
  98. package/lib/chain/errors/blockError.d.ts +4 -4
  99. package/lib/chain/errors/blockError.d.ts.map +1 -1
  100. package/lib/chain/errors/executionPayloadEnvelope.d.ts +12 -2
  101. package/lib/chain/errors/executionPayloadEnvelope.d.ts.map +1 -1
  102. package/lib/chain/errors/executionPayloadEnvelope.js +3 -1
  103. package/lib/chain/errors/executionPayloadEnvelope.js.map +1 -1
  104. package/lib/chain/forkChoice/index.d.ts +4 -4
  105. package/lib/chain/forkChoice/index.d.ts.map +1 -1
  106. package/lib/chain/forkChoice/index.js +27 -33
  107. package/lib/chain/forkChoice/index.js.map +1 -1
  108. package/lib/chain/initState.d.ts +2 -2
  109. package/lib/chain/initState.d.ts.map +1 -1
  110. package/lib/chain/initState.js +1 -1
  111. package/lib/chain/initState.js.map +1 -1
  112. package/lib/chain/interface.d.ts +17 -15
  113. package/lib/chain/interface.d.ts.map +1 -1
  114. package/lib/chain/lightClient/index.d.ts +2 -2
  115. package/lib/chain/lightClient/index.d.ts.map +1 -1
  116. package/lib/chain/lightClient/index.js +4 -4
  117. package/lib/chain/lightClient/index.js.map +1 -1
  118. package/lib/chain/opPools/aggregatedAttestationPool.d.ts +6 -6
  119. package/lib/chain/opPools/aggregatedAttestationPool.d.ts.map +1 -1
  120. package/lib/chain/opPools/aggregatedAttestationPool.js +10 -13
  121. package/lib/chain/opPools/aggregatedAttestationPool.js.map +1 -1
  122. package/lib/chain/opPools/opPool.d.ts +3 -3
  123. package/lib/chain/opPools/opPool.d.ts.map +1 -1
  124. package/lib/chain/opPools/opPool.js +7 -7
  125. package/lib/chain/opPools/opPool.js.map +1 -1
  126. package/lib/chain/opPools/utils.d.ts +2 -2
  127. package/lib/chain/opPools/utils.d.ts.map +1 -1
  128. package/lib/chain/opPools/utils.js +1 -1
  129. package/lib/chain/opPools/utils.js.map +1 -1
  130. package/lib/chain/prepareNextSlot.d.ts +2 -2
  131. package/lib/chain/prepareNextSlot.d.ts.map +1 -1
  132. package/lib/chain/prepareNextSlot.js +3 -3
  133. package/lib/chain/prepareNextSlot.js.map +1 -1
  134. package/lib/chain/produceBlock/computeNewStateRoot.d.ts +4 -4
  135. package/lib/chain/produceBlock/computeNewStateRoot.d.ts.map +1 -1
  136. package/lib/chain/produceBlock/computeNewStateRoot.js +8 -4
  137. package/lib/chain/produceBlock/computeNewStateRoot.js.map +1 -1
  138. package/lib/chain/produceBlock/produceBlockBody.d.ts +5 -5
  139. package/lib/chain/produceBlock/produceBlockBody.d.ts.map +1 -1
  140. package/lib/chain/produceBlock/produceBlockBody.js +12 -16
  141. package/lib/chain/produceBlock/produceBlockBody.js.map +1 -1
  142. package/lib/chain/regen/interface.d.ts +15 -13
  143. package/lib/chain/regen/interface.d.ts.map +1 -1
  144. package/lib/chain/regen/interface.js +2 -0
  145. package/lib/chain/regen/interface.js.map +1 -1
  146. package/lib/chain/regen/queued.d.ts +14 -14
  147. package/lib/chain/regen/queued.d.ts.map +1 -1
  148. package/lib/chain/regen/queued.js.map +1 -1
  149. package/lib/chain/regen/regen.d.ts +6 -5
  150. package/lib/chain/regen/regen.d.ts.map +1 -1
  151. package/lib/chain/regen/regen.js +6 -6
  152. package/lib/chain/regen/regen.js.map +1 -1
  153. package/lib/chain/seenCache/index.d.ts +1 -1
  154. package/lib/chain/seenCache/index.d.ts.map +1 -1
  155. package/lib/chain/seenCache/index.js +1 -1
  156. package/lib/chain/seenCache/index.js.map +1 -1
  157. package/lib/chain/seenCache/seenGossipBlockInput.js +2 -2
  158. package/lib/chain/seenCache/seenGossipBlockInput.js.map +1 -1
  159. package/lib/chain/seenCache/seenPayloadEnvelopeInput.d.ts +38 -0
  160. package/lib/chain/seenCache/seenPayloadEnvelopeInput.d.ts.map +1 -0
  161. package/lib/chain/seenCache/seenPayloadEnvelopeInput.js +76 -0
  162. package/lib/chain/seenCache/seenPayloadEnvelopeInput.js.map +1 -0
  163. package/lib/chain/serializeState.d.ts +2 -2
  164. package/lib/chain/serializeState.d.ts.map +1 -1
  165. package/lib/chain/serializeState.js +1 -1
  166. package/lib/chain/serializeState.js.map +1 -1
  167. package/lib/chain/shufflingCache.d.ts +2 -2
  168. package/lib/chain/shufflingCache.d.ts.map +1 -1
  169. package/lib/chain/shufflingCache.js +3 -4
  170. package/lib/chain/shufflingCache.js.map +1 -1
  171. package/lib/chain/stateCache/fifoBlockStateCache.d.ts +6 -6
  172. package/lib/chain/stateCache/fifoBlockStateCache.d.ts.map +1 -1
  173. package/lib/chain/stateCache/fifoBlockStateCache.js.map +1 -1
  174. package/lib/chain/stateCache/persistentCheckpointsCache.d.ts +11 -11
  175. package/lib/chain/stateCache/persistentCheckpointsCache.d.ts.map +1 -1
  176. package/lib/chain/stateCache/persistentCheckpointsCache.js +12 -16
  177. package/lib/chain/stateCache/persistentCheckpointsCache.js.map +1 -1
  178. package/lib/chain/stateCache/types.d.ts +14 -14
  179. package/lib/chain/stateCache/types.d.ts.map +1 -1
  180. package/lib/chain/stateCache/types.js.map +1 -1
  181. package/lib/chain/validation/attesterSlashing.js +3 -3
  182. package/lib/chain/validation/attesterSlashing.js.map +1 -1
  183. package/lib/chain/validation/blobSidecar.js +1 -1
  184. package/lib/chain/validation/blobSidecar.js.map +1 -1
  185. package/lib/chain/validation/block.d.ts.map +1 -1
  186. package/lib/chain/validation/block.js +3 -3
  187. package/lib/chain/validation/block.js.map +1 -1
  188. package/lib/chain/validation/blsToExecutionChange.js +2 -2
  189. package/lib/chain/validation/blsToExecutionChange.js.map +1 -1
  190. package/lib/chain/validation/dataColumnSidecar.js +1 -1
  191. package/lib/chain/validation/dataColumnSidecar.js.map +1 -1
  192. package/lib/chain/validation/executionPayloadBid.d.ts.map +1 -1
  193. package/lib/chain/validation/executionPayloadBid.js +4 -4
  194. package/lib/chain/validation/executionPayloadBid.js.map +1 -1
  195. package/lib/chain/validation/executionPayloadEnvelope.d.ts.map +1 -1
  196. package/lib/chain/validation/executionPayloadEnvelope.js +29 -19
  197. package/lib/chain/validation/executionPayloadEnvelope.js.map +1 -1
  198. package/lib/chain/validation/payloadAttestationMessage.d.ts.map +1 -1
  199. package/lib/chain/validation/payloadAttestationMessage.js +1 -2
  200. package/lib/chain/validation/payloadAttestationMessage.js.map +1 -1
  201. package/lib/chain/validation/proposerSlashing.js +1 -1
  202. package/lib/chain/validation/proposerSlashing.js.map +1 -1
  203. package/lib/chain/validation/signatureSets/contributionAndProof.d.ts +2 -2
  204. package/lib/chain/validation/signatureSets/contributionAndProof.d.ts.map +1 -1
  205. package/lib/chain/validation/signatureSets/contributionAndProof.js +1 -1
  206. package/lib/chain/validation/signatureSets/contributionAndProof.js.map +1 -1
  207. package/lib/chain/validation/signatureSets/syncCommittee.d.ts +2 -2
  208. package/lib/chain/validation/signatureSets/syncCommittee.d.ts.map +1 -1
  209. package/lib/chain/validation/signatureSets/syncCommittee.js +1 -1
  210. package/lib/chain/validation/signatureSets/syncCommittee.js.map +1 -1
  211. package/lib/chain/validation/signatureSets/syncCommitteeContribution.d.ts +2 -2
  212. package/lib/chain/validation/signatureSets/syncCommitteeContribution.d.ts.map +1 -1
  213. package/lib/chain/validation/signatureSets/syncCommitteeContribution.js.map +1 -1
  214. package/lib/chain/validation/signatureSets/syncCommitteeSelectionProof.d.ts +2 -2
  215. package/lib/chain/validation/signatureSets/syncCommitteeSelectionProof.d.ts.map +1 -1
  216. package/lib/chain/validation/signatureSets/syncCommitteeSelectionProof.js +1 -1
  217. package/lib/chain/validation/signatureSets/syncCommitteeSelectionProof.js.map +1 -1
  218. package/lib/chain/validation/syncCommittee.d.ts +4 -4
  219. package/lib/chain/validation/syncCommittee.d.ts.map +1 -1
  220. package/lib/chain/validation/syncCommittee.js +13 -12
  221. package/lib/chain/validation/syncCommittee.js.map +1 -1
  222. package/lib/chain/validation/syncCommitteeContributionAndProof.d.ts.map +1 -1
  223. package/lib/chain/validation/syncCommitteeContributionAndProof.js +1 -1
  224. package/lib/chain/validation/syncCommitteeContributionAndProof.js.map +1 -1
  225. package/lib/chain/validation/voluntaryExit.d.ts.map +1 -1
  226. package/lib/chain/validation/voluntaryExit.js +3 -3
  227. package/lib/chain/validation/voluntaryExit.js.map +1 -1
  228. package/lib/chain/validatorMonitor.d.ts +5 -4
  229. package/lib/chain/validatorMonitor.d.ts.map +1 -1
  230. package/lib/chain/validatorMonitor.js +12 -7
  231. package/lib/chain/validatorMonitor.js.map +1 -1
  232. package/lib/metrics/metrics/lodestar.d.ts +40 -4
  233. package/lib/metrics/metrics/lodestar.d.ts.map +1 -1
  234. package/lib/metrics/metrics/lodestar.js +93 -15
  235. package/lib/metrics/metrics/lodestar.js.map +1 -1
  236. package/lib/network/gossip/encoding.d.ts.map +1 -1
  237. package/lib/network/gossip/encoding.js +15 -0
  238. package/lib/network/gossip/encoding.js.map +1 -1
  239. package/lib/network/interface.d.ts +4 -2
  240. package/lib/network/interface.d.ts.map +1 -1
  241. package/lib/network/libp2p/index.d.ts.map +1 -1
  242. package/lib/network/libp2p/index.js +5 -0
  243. package/lib/network/libp2p/index.js.map +1 -1
  244. package/lib/network/network.d.ts +4 -2
  245. package/lib/network/network.d.ts.map +1 -1
  246. package/lib/network/network.js +9 -3
  247. package/lib/network/network.js.map +1 -1
  248. package/lib/network/processor/extractSlotRootFns.d.ts +1 -1
  249. package/lib/network/processor/extractSlotRootFns.d.ts.map +1 -1
  250. package/lib/network/processor/extractSlotRootFns.js +15 -5
  251. package/lib/network/processor/extractSlotRootFns.js.map +1 -1
  252. package/lib/network/processor/gossipHandlers.d.ts.map +1 -1
  253. package/lib/network/processor/gossipHandlers.js +39 -9
  254. package/lib/network/processor/gossipHandlers.js.map +1 -1
  255. package/lib/network/processor/index.d.ts +12 -7
  256. package/lib/network/processor/index.d.ts.map +1 -1
  257. package/lib/network/processor/index.js +99 -78
  258. package/lib/network/processor/index.js.map +1 -1
  259. package/lib/network/reqresp/ReqRespBeaconNode.d.ts.map +1 -1
  260. package/lib/network/reqresp/ReqRespBeaconNode.js +9 -0
  261. package/lib/network/reqresp/ReqRespBeaconNode.js.map +1 -1
  262. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRange.d.ts +8 -0
  263. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRange.d.ts.map +1 -0
  264. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRange.js +69 -0
  265. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRange.js.map +1 -0
  266. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRoot.d.ts +6 -0
  267. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRoot.d.ts.map +1 -0
  268. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRoot.js +28 -0
  269. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRoot.js.map +1 -0
  270. package/lib/network/reqresp/handlers/index.d.ts.map +1 -1
  271. package/lib/network/reqresp/handlers/index.js +11 -1
  272. package/lib/network/reqresp/handlers/index.js.map +1 -1
  273. package/lib/network/reqresp/protocols.d.ts +2 -0
  274. package/lib/network/reqresp/protocols.d.ts.map +1 -1
  275. package/lib/network/reqresp/protocols.js +10 -0
  276. package/lib/network/reqresp/protocols.js.map +1 -1
  277. package/lib/network/reqresp/rateLimit.d.ts.map +1 -1
  278. package/lib/network/reqresp/rateLimit.js +8 -0
  279. package/lib/network/reqresp/rateLimit.js.map +1 -1
  280. package/lib/network/reqresp/score.d.ts.map +1 -1
  281. package/lib/network/reqresp/score.js +2 -0
  282. package/lib/network/reqresp/score.js.map +1 -1
  283. package/lib/network/reqresp/types.d.ts +8 -2
  284. package/lib/network/reqresp/types.d.ts.map +1 -1
  285. package/lib/network/reqresp/types.js +7 -1
  286. package/lib/network/reqresp/types.js.map +1 -1
  287. package/lib/node/nodejs.d.ts +2 -2
  288. package/lib/node/nodejs.d.ts.map +1 -1
  289. package/lib/node/nodejs.js +1 -4
  290. package/lib/node/nodejs.js.map +1 -1
  291. package/lib/node/notifier.d.ts.map +1 -1
  292. package/lib/node/notifier.js +3 -3
  293. package/lib/node/notifier.js.map +1 -1
  294. package/lib/sync/backfill/backfill.d.ts +2 -2
  295. package/lib/sync/backfill/backfill.d.ts.map +1 -1
  296. package/lib/sync/backfill/backfill.js +2 -2
  297. package/lib/sync/backfill/backfill.js.map +1 -1
  298. package/lib/sync/unknownBlock.d.ts +3 -9
  299. package/lib/sync/unknownBlock.d.ts.map +1 -1
  300. package/lib/sync/unknownBlock.js +8 -41
  301. package/lib/sync/unknownBlock.js.map +1 -1
  302. package/lib/util/sszBytes.d.ts +4 -1
  303. package/lib/util/sszBytes.d.ts.map +1 -1
  304. package/lib/util/sszBytes.js +69 -12
  305. package/lib/util/sszBytes.js.map +1 -1
  306. package/lib/util/types.d.ts +2 -0
  307. package/lib/util/types.d.ts.map +1 -1
  308. package/lib/util/types.js +1 -0
  309. package/lib/util/types.js.map +1 -1
  310. package/package.json +16 -16
  311. package/src/api/impl/beacon/blocks/index.ts +37 -18
  312. package/src/api/impl/beacon/pool/index.ts +1 -1
  313. package/src/api/impl/beacon/state/index.ts +29 -41
  314. package/src/api/impl/beacon/state/utils.ts +11 -25
  315. package/src/api/impl/lodestar/index.ts +4 -8
  316. package/src/api/impl/proof/index.ts +2 -9
  317. package/src/api/impl/validator/index.ts +29 -41
  318. package/src/api/impl/validator/utils.ts +4 -7
  319. package/src/chain/archiveStore/historicalState/getHistoricalState.ts +6 -36
  320. package/src/chain/archiveStore/historicalState/worker.ts +1 -0
  321. package/src/chain/balancesCache.ts +5 -11
  322. package/src/chain/blocks/blockInput/types.ts +4 -3
  323. package/src/chain/blocks/importBlock.ts +47 -16
  324. package/src/chain/blocks/importExecutionPayload.ts +236 -0
  325. package/src/chain/blocks/index.ts +1 -1
  326. package/src/chain/blocks/payloadEnvelopeInput/index.ts +2 -0
  327. package/src/chain/blocks/payloadEnvelopeInput/payloadEnvelopeInput.ts +336 -0
  328. package/src/chain/blocks/payloadEnvelopeInput/types.ts +33 -0
  329. package/src/chain/blocks/payloadEnvelopeProcessor.ts +61 -0
  330. package/src/chain/blocks/types.ts +10 -2
  331. package/src/chain/blocks/utils/checkpoint.ts +2 -2
  332. package/src/chain/blocks/verifyBlock.ts +5 -10
  333. package/src/chain/blocks/verifyBlocksExecutionPayloads.ts +5 -10
  334. package/src/chain/blocks/verifyBlocksSignatures.ts +3 -3
  335. package/src/chain/blocks/verifyBlocksStateTransitionOnly.ts +6 -8
  336. package/src/chain/blocks/writePayloadEnvelopeInputToDb.ts +55 -0
  337. package/src/chain/chain.ts +112 -70
  338. package/src/chain/emitter.ts +2 -2
  339. package/src/chain/errors/blockError.ts +4 -4
  340. package/src/chain/errors/executionPayloadEnvelope.ts +6 -2
  341. package/src/chain/forkChoice/index.ts +33 -52
  342. package/src/chain/initState.ts +7 -2
  343. package/src/chain/interface.ts +18 -16
  344. package/src/chain/lightClient/index.ts +9 -22
  345. package/src/chain/opPools/aggregatedAttestationPool.ts +15 -21
  346. package/src/chain/opPools/opPool.ts +13 -14
  347. package/src/chain/opPools/utils.ts +3 -3
  348. package/src/chain/prepareNextSlot.ts +6 -8
  349. package/src/chain/produceBlock/computeNewStateRoot.ts +11 -10
  350. package/src/chain/produceBlock/produceBlockBody.ts +22 -49
  351. package/src/chain/regen/interface.ts +15 -17
  352. package/src/chain/regen/queued.ts +16 -20
  353. package/src/chain/regen/regen.ts +16 -17
  354. package/src/chain/seenCache/index.ts +1 -1
  355. package/src/chain/seenCache/seenGossipBlockInput.ts +2 -2
  356. package/src/chain/seenCache/seenPayloadEnvelopeInput.ts +106 -0
  357. package/src/chain/serializeState.ts +3 -3
  358. package/src/chain/shufflingCache.ts +5 -7
  359. package/src/chain/stateCache/fifoBlockStateCache.ts +7 -7
  360. package/src/chain/stateCache/persistentCheckpointsCache.ts +27 -42
  361. package/src/chain/stateCache/types.ts +14 -18
  362. package/src/chain/validation/attesterSlashing.ts +3 -3
  363. package/src/chain/validation/blobSidecar.ts +1 -1
  364. package/src/chain/validation/block.ts +2 -4
  365. package/src/chain/validation/blsToExecutionChange.ts +2 -2
  366. package/src/chain/validation/dataColumnSidecar.ts +1 -1
  367. package/src/chain/validation/executionPayloadBid.ts +3 -7
  368. package/src/chain/validation/executionPayloadEnvelope.ts +36 -29
  369. package/src/chain/validation/payloadAttestationMessage.ts +2 -4
  370. package/src/chain/validation/proposerSlashing.ts +1 -1
  371. package/src/chain/validation/signatureSets/contributionAndProof.ts +2 -7
  372. package/src/chain/validation/signatureSets/syncCommittee.ts +2 -7
  373. package/src/chain/validation/signatureSets/syncCommitteeContribution.ts +2 -2
  374. package/src/chain/validation/signatureSets/syncCommitteeSelectionProof.ts +2 -7
  375. package/src/chain/validation/syncCommittee.ts +21 -20
  376. package/src/chain/validation/syncCommitteeContributionAndProof.ts +5 -10
  377. package/src/chain/validation/voluntaryExit.ts +3 -8
  378. package/src/chain/validatorMonitor.ts +22 -11
  379. package/src/metrics/metrics/lodestar.ts +100 -19
  380. package/src/network/gossip/encoding.ts +16 -0
  381. package/src/network/interface.ts +15 -2
  382. package/src/network/libp2p/index.ts +5 -0
  383. package/src/network/network.ts +32 -4
  384. package/src/network/processor/extractSlotRootFns.ts +19 -6
  385. package/src/network/processor/gossipHandlers.ts +45 -8
  386. package/src/network/processor/index.ts +110 -89
  387. package/src/network/reqresp/ReqRespBeaconNode.ts +13 -0
  388. package/src/network/reqresp/handlers/executionPayloadEnvelopesByRange.ts +94 -0
  389. package/src/network/reqresp/handlers/executionPayloadEnvelopesByRoot.ts +43 -0
  390. package/src/network/reqresp/handlers/index.ts +12 -0
  391. package/src/network/reqresp/protocols.ts +12 -0
  392. package/src/network/reqresp/rateLimit.ts +18 -0
  393. package/src/network/reqresp/score.ts +2 -0
  394. package/src/network/reqresp/types.ts +13 -0
  395. package/src/node/nodejs.ts +3 -5
  396. package/src/node/notifier.ts +4 -10
  397. package/src/sync/backfill/backfill.ts +3 -3
  398. package/src/sync/unknownBlock.ts +10 -50
  399. package/src/util/sszBytes.ts +90 -10
  400. package/src/util/types.ts +6 -0
  401. package/lib/chain/seenCache/seenExecutionPayloadEnvelope.d.ts +0 -15
  402. package/lib/chain/seenCache/seenExecutionPayloadEnvelope.d.ts.map +0 -1
  403. package/lib/chain/seenCache/seenExecutionPayloadEnvelope.js +0 -28
  404. package/lib/chain/seenCache/seenExecutionPayloadEnvelope.js.map +0 -1
  405. package/src/chain/seenCache/seenExecutionPayloadEnvelope.ts +0 -34
@@ -1,7 +1,7 @@
1
1
  import type {ChainForkConfig} from "@lodestar/config";
2
2
  import {MaybeValidExecutionStatus} from "@lodestar/fork-choice";
3
3
  import {ForkSeq} from "@lodestar/params";
4
- import {CachedBeaconStateAllForks, DataAvailabilityStatus, computeEpochAtSlot} from "@lodestar/state-transition";
4
+ import {DataAvailabilityStatus, IBeaconStateView, computeEpochAtSlot} from "@lodestar/state-transition";
5
5
  import type {IndexedAttestation, Slot, fulu} from "@lodestar/types";
6
6
  import {IBlockInput} from "./blockInput/types.js";
7
7
 
@@ -41,6 +41,14 @@ export enum BlobSidecarValidation {
41
41
  Full,
42
42
  }
43
43
 
44
+ export type ImportPayloadOpts = {
45
+ /**
46
+ * Set to true if envelope signature was already verified (e.g., during gossip/API validation).
47
+ * When false/undefined, signature will be verified during import.
48
+ */
49
+ validSignature?: boolean;
50
+ };
51
+
44
52
  export type ImportBlockOpts = {
45
53
  /**
46
54
  * TEMP: Review if this is safe, Lighthouse always imports attestations even in finalized sync.
@@ -85,7 +93,7 @@ export type ImportBlockOpts = {
85
93
  */
86
94
  export type FullyVerifiedBlock = {
87
95
  blockInput: IBlockInput;
88
- postState: CachedBeaconStateAllForks;
96
+ postState: IBeaconStateView;
89
97
  parentBlockSlot: Slot;
90
98
  proposerBalanceDelta: number;
91
99
  /**
@@ -1,12 +1,12 @@
1
1
  import {SLOTS_PER_EPOCH} from "@lodestar/params";
2
- import {CachedBeaconStateAllForks, computeEpochAtSlot} from "@lodestar/state-transition";
2
+ import {IBeaconStateView, computeEpochAtSlot} from "@lodestar/state-transition";
3
3
  import {phase0, ssz} from "@lodestar/types";
4
4
  import {ZERO_HASH} from "../../../constants/index.js";
5
5
 
6
6
  /**
7
7
  * Compute a Checkpoint type from `state.latestBlockHeader`
8
8
  */
9
- export function getCheckpointFromState(checkpointState: CachedBeaconStateAllForks): phase0.Checkpoint {
9
+ export function getCheckpointFromState(checkpointState: IBeaconStateView): phase0.Checkpoint {
10
10
  const slot = checkpointState.slot;
11
11
 
12
12
  if (slot % SLOTS_PER_EPOCH !== 0) {
@@ -1,11 +1,6 @@
1
1
  import {ExecutionStatus, ProtoBlock} from "@lodestar/fork-choice";
2
2
  import {ForkName, isForkPostFulu} from "@lodestar/params";
3
- import {
4
- CachedBeaconStateAllForks,
5
- DataAvailabilityStatus,
6
- computeEpochAtSlot,
7
- isStateValidatorsNodesPopulated,
8
- } from "@lodestar/state-transition";
3
+ import {DataAvailabilityStatus, IBeaconStateView, computeEpochAtSlot} from "@lodestar/state-transition";
9
4
  import {IndexedAttestation, deneb} from "@lodestar/types";
10
5
  import type {BeaconChain} from "../chain.js";
11
6
  import {BlockError, BlockErrorCode} from "../errors/index.js";
@@ -39,7 +34,7 @@ export async function verifyBlocksInEpoch(
39
34
  blockInputs: IBlockInput[],
40
35
  opts: BlockProcessOpts & ImportBlockOpts
41
36
  ): Promise<{
42
- postStates: CachedBeaconStateAllForks[];
37
+ postStates: IBeaconStateView[];
43
38
  proposerBalanceDeltas: number[];
44
39
  segmentExecStatus: SegmentExecStatus;
45
40
  dataAvailabilityStatuses: DataAvailabilityStatus[];
@@ -78,10 +73,10 @@ export async function verifyBlocksInEpoch(
78
73
  // otherwise it may fail to get indexed attestations from shuffling cache later
79
74
  this.shufflingCache.processState(preState0);
80
75
 
81
- if (!isStateValidatorsNodesPopulated(preState0)) {
76
+ if (!preState0.isStateValidatorsNodesPopulated()) {
82
77
  this.logger.verbose("verifyBlocksInEpoch preState0 SSZ cache stats", {
83
78
  slot: preState0.slot,
84
- cache: isStateValidatorsNodesPopulated(preState0),
79
+ cache: preState0.isStateValidatorsNodesPopulated(),
85
80
  clonedCount: preState0.clonedCount,
86
81
  clonedCountWithTransferCache: preState0.clonedCountWithTransferCache,
87
82
  createdWithTransferCache: preState0.createdWithTransferCache,
@@ -110,7 +105,7 @@ export async function verifyBlocksInEpoch(
110
105
  for (const [i, block] of blocks.entries()) {
111
106
  indexedAttestationsByBlock[i] = block.message.body.attestations.map((attestation) => {
112
107
  const attEpoch = computeEpochAtSlot(attestation.data.slot);
113
- const decisionRoot = preState0.epochCtx.getShufflingDecisionRoot(attEpoch);
108
+ const decisionRoot = preState0.getShufflingDecisionRoot(attEpoch);
114
109
  return this.shufflingCache.getIndexedAttestation(attEpoch, decisionRoot, fork, attestation);
115
110
  });
116
111
  }
@@ -8,12 +8,7 @@ import {
8
8
  ProtoBlock,
9
9
  } from "@lodestar/fork-choice";
10
10
  import {ForkSeq} from "@lodestar/params";
11
- import {
12
- CachedBeaconStateAllForks,
13
- isExecutionBlockBodyType,
14
- isExecutionEnabled,
15
- isExecutionStateType,
16
- } from "@lodestar/state-transition";
11
+ import {IBeaconStateView, isExecutionBlockBodyType} from "@lodestar/state-transition";
17
12
  import {bellatrix, electra} from "@lodestar/types";
18
13
  import {ErrorAborted, Logger, toRootHex} from "@lodestar/utils";
19
14
  import {ExecutionPayloadStatus, IExecutionEngine} from "../../execution/engine/interface.js";
@@ -63,7 +58,7 @@ export async function verifyBlocksExecutionPayload(
63
58
  chain: VerifyBlockExecutionPayloadModules,
64
59
  parentBlock: ProtoBlock,
65
60
  blockInputs: IBlockInput[],
66
- preState0: CachedBeaconStateAllForks,
61
+ preState0: IBeaconStateView,
67
62
  signal: AbortSignal,
68
63
  opts: BlockProcessOpts & ImportBlockOpts
69
64
  ): Promise<SegmentExecStatus> {
@@ -146,7 +141,7 @@ export async function verifyBlocksExecutionPayload(
146
141
  export async function verifyBlockExecutionPayload(
147
142
  chain: VerifyBlockExecutionPayloadModules,
148
143
  blockInput: IBlockInput,
149
- preState0: CachedBeaconStateAllForks
144
+ preState0: IBeaconStateView
150
145
  ): Promise<VerifyBlockExecutionResponse> {
151
146
  const block = blockInput.getBlock();
152
147
 
@@ -157,9 +152,9 @@ export async function verifyBlockExecutionPayload(
157
152
 
158
153
  /** Not null if execution is enabled */
159
154
  const executionPayloadEnabled =
160
- isExecutionStateType(preState0) &&
155
+ preState0.isExecutionStateType &&
161
156
  isExecutionBlockBodyType(block.message.body) &&
162
- isExecutionEnabled(preState0, block.message)
157
+ preState0.isExecutionEnabled(block.message)
163
158
  ? block.message.body.executionPayload
164
159
  : null;
165
160
 
@@ -1,5 +1,5 @@
1
1
  import {BeaconConfig} from "@lodestar/config";
2
- import {CachedBeaconStateAllForks, getBlockSignatureSets} from "@lodestar/state-transition";
2
+ import {IBeaconStateView, getBlockSignatureSets} from "@lodestar/state-transition";
3
3
  import {IndexedAttestation, SignedBeaconBlock} from "@lodestar/types";
4
4
  import {Logger} from "@lodestar/utils";
5
5
  import {Metrics} from "../../metrics/metrics.js";
@@ -20,14 +20,14 @@ export async function verifyBlocksSignatures(
20
20
  bls: IBlsVerifier,
21
21
  logger: Logger,
22
22
  metrics: Metrics | null,
23
- preState0: CachedBeaconStateAllForks,
23
+ preState0: IBeaconStateView,
24
24
  blocks: SignedBeaconBlock[],
25
25
  indexedAttestationsByBlock: IndexedAttestation[][],
26
26
  opts: ImportBlockOpts
27
27
  ): Promise<{verifySignaturesTime: number}> {
28
28
  const isValidPromises: Promise<boolean>[] = [];
29
29
  const recvToValLatency = Date.now() / 1000 - (opts.seenTimestampSec ?? Date.now() / 1000);
30
- const currentSyncCommitteeIndexed = preState0.epochCtx.currentSyncCommitteeIndexed;
30
+ const currentSyncCommitteeIndexed = preState0.currentSyncCommitteeIndexed;
31
31
 
32
32
  // Verifies signatures after running state transition, so all SyncCommittee signed roots are known at this point.
33
33
  // We must ensure block.slot <= state.slot before running getAllBlockSignatureSets().
@@ -1,9 +1,8 @@
1
1
  import {
2
- CachedBeaconStateAllForks,
3
2
  DataAvailabilityStatus,
4
3
  ExecutionPayloadStatus,
4
+ IBeaconStateView,
5
5
  StateHashTreeRootSource,
6
- stateTransition,
7
6
  } from "@lodestar/state-transition";
8
7
  import {ErrorAborted, Logger, byteArrayEquals} from "@lodestar/utils";
9
8
  import {Metrics} from "../../metrics/index.js";
@@ -23,7 +22,7 @@ import {ImportBlockOpts} from "./types.js";
23
22
  * - Check state root matches
24
23
  */
25
24
  export async function verifyBlocksStateTransitionOnly(
26
- preState0: CachedBeaconStateAllForks,
25
+ preState0: IBeaconStateView,
27
26
  blocks: IBlockInput[],
28
27
  dataAvailabilityStatuses: DataAvailabilityStatus[],
29
28
  logger: Logger,
@@ -31,8 +30,8 @@ export async function verifyBlocksStateTransitionOnly(
31
30
  validatorMonitor: ValidatorMonitor | null,
32
31
  signal: AbortSignal,
33
32
  opts: BlockProcessOpts & ImportBlockOpts
34
- ): Promise<{postStates: CachedBeaconStateAllForks[]; proposerBalanceDeltas: number[]; verifyStateTime: number}> {
35
- const postStates: CachedBeaconStateAllForks[] = [];
33
+ ): Promise<{postStates: IBeaconStateView[]; proposerBalanceDeltas: number[]; verifyStateTime: number}> {
34
+ const postStates: IBeaconStateView[] = [];
36
35
  const proposerBalanceDeltas: number[] = [];
37
36
  const recvToValLatency = Date.now() / 1000 - (opts.seenTimestampSec ?? Date.now() / 1000);
38
37
 
@@ -45,8 +44,7 @@ export async function verifyBlocksStateTransitionOnly(
45
44
  // STFN - per_slot_processing() + per_block_processing()
46
45
  // NOTE: `regen.getPreState()` should have dialed forward the state already caching checkpoint states
47
46
  const useBlsBatchVerify = !opts?.disableBlsBatchVerify;
48
- const postState = stateTransition(
49
- preState,
47
+ const postState = preState.stateTransition(
50
48
  block,
51
49
  {
52
50
  // NOTE: Assume valid for now while sending payload to execution engine in parallel
@@ -84,7 +82,7 @@ export async function verifyBlocksStateTransitionOnly(
84
82
 
85
83
  // For metric block profitability
86
84
  const proposerIndex = block.message.proposerIndex;
87
- proposerBalanceDeltas[i] = postState.balances.get(proposerIndex) - preState.balances.get(proposerIndex);
85
+ proposerBalanceDeltas[i] = postState.getBalance(proposerIndex) - preState.getBalance(proposerIndex);
88
86
 
89
87
  // If blocks are invalid in execution the main promise could resolve before this loop ends.
90
88
  // In that case stop processing blocks and return early.
@@ -0,0 +1,55 @@
1
+ import {BeaconChain} from "../chain.js";
2
+ import {PayloadEnvelopeInput} from "../seenCache/seenPayloadEnvelopeInput.js";
3
+ import {writeDataColumnsToDb} from "./writeBlockInputToDb.js";
4
+
5
+ /**
6
+ * Persists payload envelope data to DB. This operation must be eventually completed if a payload is imported.
7
+ *
8
+ * TODO GLOAS: Persist envelope metadata (stateRoot, executionRequests, builderIndex, etc.) without the full
9
+ * execution payload body — only keep the blockHash reference. The EL already stores the payload.
10
+ * See https://github.com/ChainSafe/lodestar/issues/5671
11
+ */
12
+ export async function writePayloadEnvelopeInputToDb(
13
+ this: BeaconChain,
14
+ payloadInput: PayloadEnvelopeInput
15
+ ): Promise<void> {
16
+ const envelope = payloadInput.getPayloadEnvelope();
17
+ const blockRootHex = payloadInput.blockRootHex;
18
+
19
+ const envelopeBytes = this.serializedCache.get(envelope);
20
+ const envelopePromise = envelopeBytes
21
+ ? this.db.executionPayloadEnvelope.putBinary(this.db.executionPayloadEnvelope.getId(envelope), envelopeBytes)
22
+ : this.db.executionPayloadEnvelope.add(envelope);
23
+
24
+ // Write envelope and data columns in parallel (reuses shared column writing logic)
25
+ await Promise.all([envelopePromise, writeDataColumnsToDb.call(this, payloadInput)]);
26
+ this.logger.debug("Persisted payload envelope to db", {
27
+ slot: payloadInput.slot,
28
+ root: blockRootHex,
29
+ });
30
+ }
31
+
32
+ export async function persistPayloadEnvelopeInput(
33
+ this: BeaconChain,
34
+ payloadInput: PayloadEnvelopeInput
35
+ ): Promise<void> {
36
+ await writePayloadEnvelopeInputToDb
37
+ .call(this, payloadInput)
38
+ .catch((e) => {
39
+ this.logger.error(
40
+ "Error persisting payload envelope in hot db",
41
+ {
42
+ slot: payloadInput.slot,
43
+ root: payloadInput.blockRootHex,
44
+ },
45
+ e
46
+ );
47
+ })
48
+ .finally(() => {
49
+ this.seenPayloadEnvelopeInputCache.prune(payloadInput.blockRootHex);
50
+ this.logger.debug("Pruned payload envelope input", {
51
+ slot: payloadInput.slot,
52
+ root: payloadInput.blockRootHex,
53
+ });
54
+ });
55
+ }