@lodestar/beacon-node 1.41.0-dev.e1d339886d → 1.41.0-dev.e6c853da0e

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 (384) hide show
  1. package/lib/api/impl/beacon/blocks/index.d.ts.map +1 -1
  2. package/lib/api/impl/beacon/blocks/index.js +123 -4
  3. package/lib/api/impl/beacon/blocks/index.js.map +1 -1
  4. package/lib/api/impl/beacon/state/index.js +8 -8
  5. package/lib/api/impl/beacon/state/index.js.map +1 -1
  6. package/lib/api/impl/beacon/state/utils.d.ts +3 -4
  7. package/lib/api/impl/beacon/state/utils.d.ts.map +1 -1
  8. package/lib/api/impl/beacon/state/utils.js +5 -24
  9. package/lib/api/impl/beacon/state/utils.js.map +1 -1
  10. package/lib/api/impl/debug/index.d.ts.map +1 -1
  11. package/lib/api/impl/debug/index.js +6 -2
  12. package/lib/api/impl/debug/index.js.map +1 -1
  13. package/lib/api/impl/node/utils.d.ts +1 -1
  14. package/lib/api/impl/node/utils.d.ts.map +1 -1
  15. package/lib/api/impl/node/utils.js.map +1 -1
  16. package/lib/api/impl/validator/index.d.ts.map +1 -1
  17. package/lib/api/impl/validator/index.js +130 -16
  18. package/lib/api/impl/validator/index.js.map +1 -1
  19. package/lib/chain/archiveStore/archiveStore.d.ts +1 -0
  20. package/lib/chain/archiveStore/archiveStore.d.ts.map +1 -1
  21. package/lib/chain/archiveStore/archiveStore.js +9 -0
  22. package/lib/chain/archiveStore/archiveStore.js.map +1 -1
  23. package/lib/chain/archiveStore/historicalState/getHistoricalState.d.ts +5 -6
  24. package/lib/chain/archiveStore/historicalState/getHistoricalState.d.ts.map +1 -1
  25. package/lib/chain/archiveStore/historicalState/getHistoricalState.js +9 -10
  26. package/lib/chain/archiveStore/historicalState/getHistoricalState.js.map +1 -1
  27. package/lib/chain/archiveStore/historicalState/worker.js +3 -3
  28. package/lib/chain/archiveStore/historicalState/worker.js.map +1 -1
  29. package/lib/chain/archiveStore/utils/archiveBlocks.d.ts +3 -8
  30. package/lib/chain/archiveStore/utils/archiveBlocks.d.ts.map +1 -1
  31. package/lib/chain/archiveStore/utils/archiveBlocks.js +1 -1
  32. package/lib/chain/archiveStore/utils/archiveBlocks.js.map +1 -1
  33. package/lib/chain/archiveStore/utils/archivePayloads.d.ts +7 -0
  34. package/lib/chain/archiveStore/utils/archivePayloads.d.ts.map +1 -0
  35. package/lib/chain/archiveStore/utils/archivePayloads.js +10 -0
  36. package/lib/chain/archiveStore/utils/archivePayloads.js.map +1 -0
  37. package/lib/chain/archiveStore/utils/updateBackfillRange.js +1 -1
  38. package/lib/chain/archiveStore/utils/updateBackfillRange.js.map +1 -1
  39. package/lib/chain/blocks/blockInput/blockInput.d.ts +20 -2
  40. package/lib/chain/blocks/blockInput/blockInput.d.ts.map +1 -1
  41. package/lib/chain/blocks/blockInput/blockInput.js +47 -0
  42. package/lib/chain/blocks/blockInput/blockInput.js.map +1 -1
  43. package/lib/chain/blocks/blockInput/types.d.ts +13 -1
  44. package/lib/chain/blocks/blockInput/types.d.ts.map +1 -1
  45. package/lib/chain/blocks/blockInput/types.js +1 -0
  46. package/lib/chain/blocks/blockInput/types.js.map +1 -1
  47. package/lib/chain/blocks/importBlock.d.ts.map +1 -1
  48. package/lib/chain/blocks/importBlock.js +27 -4
  49. package/lib/chain/blocks/importBlock.js.map +1 -1
  50. package/lib/chain/blocks/index.d.ts.map +1 -1
  51. package/lib/chain/blocks/index.js +2 -1
  52. package/lib/chain/blocks/index.js.map +1 -1
  53. package/lib/chain/blocks/verifyBlocksDataAvailability.d.ts.map +1 -1
  54. package/lib/chain/blocks/verifyBlocksDataAvailability.js +3 -0
  55. package/lib/chain/blocks/verifyBlocksDataAvailability.js.map +1 -1
  56. package/lib/chain/blocks/verifyBlocksExecutionPayloads.d.ts +4 -0
  57. package/lib/chain/blocks/verifyBlocksExecutionPayloads.d.ts.map +1 -1
  58. package/lib/chain/blocks/verifyBlocksExecutionPayloads.js +5 -1
  59. package/lib/chain/blocks/verifyBlocksExecutionPayloads.js.map +1 -1
  60. package/lib/chain/blocks/verifyBlocksSanityChecks.d.ts.map +1 -1
  61. package/lib/chain/blocks/verifyBlocksSanityChecks.js +4 -1
  62. package/lib/chain/blocks/verifyBlocksSanityChecks.js.map +1 -1
  63. package/lib/chain/blocks/writeBlockInputToDb.d.ts +12 -3
  64. package/lib/chain/blocks/writeBlockInputToDb.d.ts.map +1 -1
  65. package/lib/chain/blocks/writeBlockInputToDb.js +101 -96
  66. package/lib/chain/blocks/writeBlockInputToDb.js.map +1 -1
  67. package/lib/chain/bls/multithread/index.d.ts +3 -3
  68. package/lib/chain/bls/multithread/index.d.ts.map +1 -1
  69. package/lib/chain/bls/multithread/index.js +5 -5
  70. package/lib/chain/bls/multithread/index.js.map +1 -1
  71. package/lib/chain/bls/multithread/jobItem.d.ts +2 -2
  72. package/lib/chain/bls/multithread/jobItem.d.ts.map +1 -1
  73. package/lib/chain/bls/multithread/jobItem.js +2 -2
  74. package/lib/chain/bls/multithread/jobItem.js.map +1 -1
  75. package/lib/chain/bls/singleThread.d.ts +4 -4
  76. package/lib/chain/bls/singleThread.d.ts.map +1 -1
  77. package/lib/chain/bls/singleThread.js +4 -4
  78. package/lib/chain/bls/singleThread.js.map +1 -1
  79. package/lib/chain/bls/utils.d.ts +2 -2
  80. package/lib/chain/bls/utils.d.ts.map +1 -1
  81. package/lib/chain/bls/utils.js +7 -4
  82. package/lib/chain/bls/utils.js.map +1 -1
  83. package/lib/chain/chain.d.ts +7 -10
  84. package/lib/chain/chain.d.ts.map +1 -1
  85. package/lib/chain/chain.js +43 -27
  86. package/lib/chain/chain.js.map +1 -1
  87. package/lib/chain/emitter.d.ts +5 -5
  88. package/lib/chain/emitter.d.ts.map +1 -1
  89. package/lib/chain/errors/executionPayloadEnvelope.d.ts +2 -2
  90. package/lib/chain/errors/executionPayloadEnvelope.d.ts.map +1 -1
  91. package/lib/chain/errors/executionPayloadEnvelope.js.map +1 -1
  92. package/lib/chain/forkChoice/index.d.ts.map +1 -1
  93. package/lib/chain/forkChoice/index.js +30 -24
  94. package/lib/chain/forkChoice/index.js.map +1 -1
  95. package/lib/chain/interface.d.ts +4 -6
  96. package/lib/chain/interface.d.ts.map +1 -1
  97. package/lib/chain/interface.js.map +1 -1
  98. package/lib/chain/opPools/aggregatedAttestationPool.js +1 -1
  99. package/lib/chain/opPools/aggregatedAttestationPool.js.map +1 -1
  100. package/lib/chain/options.d.ts.map +1 -1
  101. package/lib/chain/options.js.map +1 -1
  102. package/lib/chain/prepareNextSlot.js +3 -3
  103. package/lib/chain/prepareNextSlot.js.map +1 -1
  104. package/lib/chain/produceBlock/computeNewStateRoot.d.ts +10 -2
  105. package/lib/chain/produceBlock/computeNewStateRoot.d.ts.map +1 -1
  106. package/lib/chain/produceBlock/computeNewStateRoot.js +24 -2
  107. package/lib/chain/produceBlock/computeNewStateRoot.js.map +1 -1
  108. package/lib/chain/produceBlock/produceBlockBody.d.ts +22 -7
  109. package/lib/chain/produceBlock/produceBlockBody.d.ts.map +1 -1
  110. package/lib/chain/produceBlock/produceBlockBody.js +109 -10
  111. package/lib/chain/produceBlock/produceBlockBody.js.map +1 -1
  112. package/lib/chain/regen/queued.d.ts.map +1 -1
  113. package/lib/chain/regen/queued.js +4 -1
  114. package/lib/chain/regen/queued.js.map +1 -1
  115. package/lib/chain/regen/regen.d.ts.map +1 -1
  116. package/lib/chain/regen/regen.js +6 -2
  117. package/lib/chain/regen/regen.js.map +1 -1
  118. package/lib/chain/seenCache/seenGossipBlockInput.d.ts.map +1 -1
  119. package/lib/chain/seenCache/seenGossipBlockInput.js +15 -7
  120. package/lib/chain/seenCache/seenGossipBlockInput.js.map +1 -1
  121. package/lib/chain/validation/aggregateAndProof.js +1 -1
  122. package/lib/chain/validation/aggregateAndProof.js.map +1 -1
  123. package/lib/chain/validation/attestation.d.ts.map +1 -1
  124. package/lib/chain/validation/attestation.js +7 -4
  125. package/lib/chain/validation/attestation.js.map +1 -1
  126. package/lib/chain/validation/attesterSlashing.d.ts.map +1 -1
  127. package/lib/chain/validation/attesterSlashing.js +9 -2
  128. package/lib/chain/validation/attesterSlashing.js.map +1 -1
  129. package/lib/chain/validation/blobSidecar.js +2 -2
  130. package/lib/chain/validation/blobSidecar.js.map +1 -1
  131. package/lib/chain/validation/block.d.ts.map +1 -1
  132. package/lib/chain/validation/block.js +6 -3
  133. package/lib/chain/validation/block.js.map +1 -1
  134. package/lib/chain/validation/dataColumnSidecar.d.ts +2 -2
  135. package/lib/chain/validation/dataColumnSidecar.d.ts.map +1 -1
  136. package/lib/chain/validation/dataColumnSidecar.js +1 -1
  137. package/lib/chain/validation/dataColumnSidecar.js.map +1 -1
  138. package/lib/chain/validation/executionPayloadBid.js +1 -2
  139. package/lib/chain/validation/executionPayloadBid.js.map +1 -1
  140. package/lib/chain/validation/executionPayloadEnvelope.js +4 -4
  141. package/lib/chain/validation/executionPayloadEnvelope.js.map +1 -1
  142. package/lib/chain/validation/payloadAttestationMessage.js +9 -3
  143. package/lib/chain/validation/payloadAttestationMessage.js.map +1 -1
  144. package/lib/chain/validation/proposerSlashing.js +1 -1
  145. package/lib/chain/validation/proposerSlashing.js.map +1 -1
  146. package/lib/chain/validation/syncCommitteeContributionAndProof.js +1 -1
  147. package/lib/db/beacon.d.ts +3 -1
  148. package/lib/db/beacon.d.ts.map +1 -1
  149. package/lib/db/beacon.js +5 -1
  150. package/lib/db/beacon.js.map +1 -1
  151. package/lib/db/buckets.d.ts +3 -1
  152. package/lib/db/buckets.d.ts.map +1 -1
  153. package/lib/db/buckets.js +2 -0
  154. package/lib/db/buckets.js.map +1 -1
  155. package/lib/db/interface.d.ts +3 -1
  156. package/lib/db/interface.d.ts.map +1 -1
  157. package/lib/db/repositories/blockArchive.d.ts.map +1 -1
  158. package/lib/db/repositories/blockArchive.js +1 -2
  159. package/lib/db/repositories/blockArchive.js.map +1 -1
  160. package/lib/db/repositories/blockArchiveIndex.d.ts +2 -2
  161. package/lib/db/repositories/blockArchiveIndex.d.ts.map +1 -1
  162. package/lib/db/repositories/dataColumnSidecar.d.ts +5 -3
  163. package/lib/db/repositories/dataColumnSidecar.d.ts.map +1 -1
  164. package/lib/db/repositories/dataColumnSidecar.js +14 -1
  165. package/lib/db/repositories/dataColumnSidecar.js.map +1 -1
  166. package/lib/db/repositories/dataColumnSidecarArchive.d.ts +5 -3
  167. package/lib/db/repositories/dataColumnSidecarArchive.d.ts.map +1 -1
  168. package/lib/db/repositories/dataColumnSidecarArchive.js +14 -1
  169. package/lib/db/repositories/dataColumnSidecarArchive.js.map +1 -1
  170. package/lib/db/repositories/executionPayloadEnvelope.d.ts +19 -0
  171. package/lib/db/repositories/executionPayloadEnvelope.d.ts.map +1 -0
  172. package/lib/db/repositories/executionPayloadEnvelope.js +22 -0
  173. package/lib/db/repositories/executionPayloadEnvelope.js.map +1 -0
  174. package/lib/db/repositories/executionPayloadEnvelopeArchive.d.ts +18 -0
  175. package/lib/db/repositories/executionPayloadEnvelopeArchive.d.ts.map +1 -0
  176. package/lib/db/repositories/executionPayloadEnvelopeArchive.js +28 -0
  177. package/lib/db/repositories/executionPayloadEnvelopeArchive.js.map +1 -0
  178. package/lib/db/repositories/index.d.ts +2 -0
  179. package/lib/db/repositories/index.d.ts.map +1 -1
  180. package/lib/db/repositories/index.js +2 -0
  181. package/lib/db/repositories/index.js.map +1 -1
  182. package/lib/execution/engine/http.d.ts +1 -0
  183. package/lib/execution/engine/http.d.ts.map +1 -1
  184. package/lib/execution/engine/http.js +3 -0
  185. package/lib/execution/engine/http.js.map +1 -1
  186. package/lib/metrics/metrics/beacon.d.ts +1 -0
  187. package/lib/metrics/metrics/beacon.d.ts.map +1 -1
  188. package/lib/metrics/metrics/beacon.js +5 -0
  189. package/lib/metrics/metrics/beacon.js.map +1 -1
  190. package/lib/metrics/metrics/lodestar.d.ts +8 -0
  191. package/lib/metrics/metrics/lodestar.d.ts.map +1 -1
  192. package/lib/metrics/metrics/lodestar.js +14 -0
  193. package/lib/metrics/metrics/lodestar.js.map +1 -1
  194. package/lib/monitoring/service.d.ts +2 -2
  195. package/lib/monitoring/service.d.ts.map +1 -1
  196. package/lib/monitoring/service.js +3 -2
  197. package/lib/monitoring/service.js.map +1 -1
  198. package/lib/network/core/networkCore.d.ts +3 -3
  199. package/lib/network/core/networkCore.d.ts.map +1 -1
  200. package/lib/network/core/networkCore.js.map +1 -1
  201. package/lib/network/core/networkCoreWorkerHandler.d.ts +3 -3
  202. package/lib/network/core/networkCoreWorkerHandler.d.ts.map +1 -1
  203. package/lib/network/core/types.d.ts +2 -2
  204. package/lib/network/core/types.d.ts.map +1 -1
  205. package/lib/network/events.d.ts +2 -1
  206. package/lib/network/events.d.ts.map +1 -1
  207. package/lib/network/events.js.map +1 -1
  208. package/lib/network/gossip/encoding.d.ts +3 -3
  209. package/lib/network/gossip/encoding.d.ts.map +1 -1
  210. package/lib/network/gossip/encoding.js.map +1 -1
  211. package/lib/network/gossip/gossipsub.d.ts +13 -4
  212. package/lib/network/gossip/gossipsub.d.ts.map +1 -1
  213. package/lib/network/gossip/gossipsub.js +47 -20
  214. package/lib/network/gossip/gossipsub.js.map +1 -1
  215. package/lib/network/gossip/interface.d.ts +6 -6
  216. package/lib/network/gossip/interface.d.ts.map +1 -1
  217. package/lib/network/gossip/scoringParameters.d.ts +1 -1
  218. package/lib/network/gossip/scoringParameters.d.ts.map +1 -1
  219. package/lib/network/gossip/scoringParameters.js +1 -1
  220. package/lib/network/gossip/scoringParameters.js.map +1 -1
  221. package/lib/network/gossip/topic.d.ts +113 -63
  222. package/lib/network/gossip/topic.d.ts.map +1 -1
  223. package/lib/network/gossip/topic.js +2 -2
  224. package/lib/network/gossip/topic.js.map +1 -1
  225. package/lib/network/interface.d.ts +6 -5
  226. package/lib/network/interface.d.ts.map +1 -1
  227. package/lib/network/libp2p/index.d.ts +1 -1
  228. package/lib/network/libp2p/index.d.ts.map +1 -1
  229. package/lib/network/libp2p/index.js +7 -2
  230. package/lib/network/libp2p/index.js.map +1 -1
  231. package/lib/network/network.d.ts +5 -4
  232. package/lib/network/network.d.ts.map +1 -1
  233. package/lib/network/network.js +10 -1
  234. package/lib/network/network.js.map +1 -1
  235. package/lib/network/options.d.ts.map +1 -1
  236. package/lib/network/options.js +3 -0
  237. package/lib/network/options.js.map +1 -1
  238. package/lib/network/peers/datastore.d.ts +7 -5
  239. package/lib/network/peers/datastore.d.ts.map +1 -1
  240. package/lib/network/peers/datastore.js +10 -10
  241. package/lib/network/peers/datastore.js.map +1 -1
  242. package/lib/network/peers/peerManager.d.ts +3 -0
  243. package/lib/network/peers/peerManager.d.ts.map +1 -1
  244. package/lib/network/peers/peerManager.js +103 -53
  245. package/lib/network/peers/peerManager.js.map +1 -1
  246. package/lib/network/peers/utils/prioritizePeers.d.ts +3 -3
  247. package/lib/network/peers/utils/prioritizePeers.d.ts.map +1 -1
  248. package/lib/network/processor/gossipHandlers.d.ts.map +1 -1
  249. package/lib/network/processor/gossipHandlers.js +9 -2
  250. package/lib/network/processor/gossipHandlers.js.map +1 -1
  251. package/lib/network/processor/gossipValidatorFn.js +1 -1
  252. package/lib/network/processor/types.d.ts +1 -1
  253. package/lib/network/processor/types.d.ts.map +1 -1
  254. package/lib/network/reqresp/handlers/beaconBlocksByRange.d.ts.map +1 -1
  255. package/lib/network/reqresp/handlers/beaconBlocksByRange.js +3 -2
  256. package/lib/network/reqresp/handlers/beaconBlocksByRange.js.map +1 -1
  257. package/lib/network/reqresp/handlers/blobSidecarsByRange.d.ts.map +1 -1
  258. package/lib/network/reqresp/handlers/blobSidecarsByRange.js +3 -2
  259. package/lib/network/reqresp/handlers/blobSidecarsByRange.js.map +1 -1
  260. package/lib/network/reqresp/handlers/blobSidecarsByRoot.js +1 -1
  261. package/lib/network/reqresp/handlers/blobSidecarsByRoot.js.map +1 -1
  262. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts.map +1 -1
  263. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js +3 -2
  264. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js.map +1 -1
  265. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js +1 -1
  266. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js.map +1 -1
  267. package/lib/network/reqresp/score.d.ts.map +1 -1
  268. package/lib/network/reqresp/score.js +0 -1
  269. package/lib/network/reqresp/score.js.map +1 -1
  270. package/lib/network/util.js +2 -2
  271. package/lib/network/util.js.map +1 -1
  272. package/lib/node/nodejs.d.ts +3 -5
  273. package/lib/node/nodejs.d.ts.map +1 -1
  274. package/lib/node/nodejs.js +6 -4
  275. package/lib/node/nodejs.js.map +1 -1
  276. package/lib/util/blobs.d.ts +2 -2
  277. package/lib/util/blobs.d.ts.map +1 -1
  278. package/lib/util/blobs.js.map +1 -1
  279. package/lib/util/clock.d.ts +6 -0
  280. package/lib/util/clock.d.ts.map +1 -1
  281. package/lib/util/clock.js +9 -3
  282. package/lib/util/clock.js.map +1 -1
  283. package/lib/util/dataColumns.d.ts +11 -3
  284. package/lib/util/dataColumns.d.ts.map +1 -1
  285. package/lib/util/dataColumns.js +27 -0
  286. package/lib/util/dataColumns.js.map +1 -1
  287. package/lib/util/multifork.d.ts +8 -0
  288. package/lib/util/multifork.d.ts.map +1 -1
  289. package/lib/util/multifork.js +37 -0
  290. package/lib/util/multifork.js.map +1 -1
  291. package/package.json +39 -42
  292. package/src/api/impl/beacon/blocks/index.ts +147 -3
  293. package/src/api/impl/beacon/state/index.ts +8 -8
  294. package/src/api/impl/beacon/state/utils.ts +15 -29
  295. package/src/api/impl/debug/index.ts +9 -5
  296. package/src/api/impl/node/utils.ts +3 -3
  297. package/src/api/impl/validator/index.ts +153 -17
  298. package/src/chain/archiveStore/archiveStore.ts +15 -5
  299. package/src/chain/archiveStore/historicalState/getHistoricalState.ts +10 -11
  300. package/src/chain/archiveStore/historicalState/worker.ts +3 -3
  301. package/src/chain/archiveStore/utils/archiveBlocks.ts +4 -5
  302. package/src/chain/archiveStore/utils/archivePayloads.ts +15 -0
  303. package/src/chain/archiveStore/utils/updateBackfillRange.ts +1 -1
  304. package/src/chain/blocks/blockInput/blockInput.ts +68 -3
  305. package/src/chain/blocks/blockInput/types.ts +13 -0
  306. package/src/chain/blocks/importBlock.ts +35 -4
  307. package/src/chain/blocks/index.ts +2 -1
  308. package/src/chain/blocks/verifyBlocksDataAvailability.ts +3 -0
  309. package/src/chain/blocks/verifyBlocksExecutionPayloads.ts +9 -2
  310. package/src/chain/blocks/verifyBlocksSanityChecks.ts +7 -2
  311. package/src/chain/blocks/writeBlockInputToDb.ts +119 -101
  312. package/src/chain/bls/multithread/index.ts +7 -7
  313. package/src/chain/bls/multithread/jobItem.ts +3 -3
  314. package/src/chain/bls/singleThread.ts +5 -5
  315. package/src/chain/bls/utils.ts +8 -5
  316. package/src/chain/chain.ts +77 -40
  317. package/src/chain/emitter.ts +5 -5
  318. package/src/chain/errors/executionPayloadEnvelope.ts +6 -2
  319. package/src/chain/forkChoice/index.ts +39 -21
  320. package/src/chain/interface.ts +4 -11
  321. package/src/chain/opPools/aggregatedAttestationPool.ts +1 -1
  322. package/src/chain/options.ts +1 -0
  323. package/src/chain/prepareNextSlot.ts +5 -5
  324. package/src/chain/produceBlock/computeNewStateRoot.ts +35 -3
  325. package/src/chain/produceBlock/produceBlockBody.ts +162 -13
  326. package/src/chain/regen/queued.ts +7 -2
  327. package/src/chain/regen/regen.ts +9 -3
  328. package/src/chain/seenCache/seenGossipBlockInput.ts +16 -7
  329. package/src/chain/validation/aggregateAndProof.ts +1 -1
  330. package/src/chain/validation/attestation.ts +7 -4
  331. package/src/chain/validation/attesterSlashing.ts +10 -1
  332. package/src/chain/validation/blobSidecar.ts +2 -2
  333. package/src/chain/validation/block.ts +9 -4
  334. package/src/chain/validation/dataColumnSidecar.ts +3 -6
  335. package/src/chain/validation/executionPayloadBid.ts +1 -2
  336. package/src/chain/validation/executionPayloadEnvelope.ts +4 -4
  337. package/src/chain/validation/payloadAttestationMessage.ts +10 -3
  338. package/src/chain/validation/proposerSlashing.ts +1 -1
  339. package/src/chain/validation/syncCommitteeContributionAndProof.ts +1 -1
  340. package/src/db/beacon.ts +8 -0
  341. package/src/db/buckets.ts +3 -0
  342. package/src/db/interface.ts +5 -0
  343. package/src/db/repositories/blockArchive.ts +1 -2
  344. package/src/db/repositories/dataColumnSidecar.ts +18 -3
  345. package/src/db/repositories/dataColumnSidecarArchive.ts +18 -3
  346. package/src/db/repositories/executionPayloadEnvelope.ts +26 -0
  347. package/src/db/repositories/executionPayloadEnvelopeArchive.ts +32 -0
  348. package/src/db/repositories/index.ts +2 -0
  349. package/src/execution/engine/http.ts +3 -0
  350. package/src/metrics/metrics/beacon.ts +5 -0
  351. package/src/metrics/metrics/lodestar.ts +14 -0
  352. package/src/monitoring/service.ts +3 -2
  353. package/src/network/core/networkCore.ts +3 -3
  354. package/src/network/core/networkCoreWorkerHandler.ts +3 -3
  355. package/src/network/core/types.ts +2 -2
  356. package/src/network/events.ts +2 -1
  357. package/src/network/gossip/encoding.ts +3 -3
  358. package/src/network/gossip/gossipsub.ts +86 -25
  359. package/src/network/gossip/interface.ts +6 -6
  360. package/src/network/gossip/scoringParameters.ts +4 -4
  361. package/src/network/gossip/topic.ts +2 -1
  362. package/src/network/interface.ts +7 -4
  363. package/src/network/libp2p/index.ts +8 -3
  364. package/src/network/network.ts +24 -6
  365. package/src/network/options.ts +3 -0
  366. package/src/network/peers/datastore.ts +13 -10
  367. package/src/network/peers/peerManager.ts +118 -54
  368. package/src/network/peers/utils/prioritizePeers.ts +3 -3
  369. package/src/network/processor/gossipHandlers.ts +19 -4
  370. package/src/network/processor/gossipValidatorFn.ts +1 -1
  371. package/src/network/processor/types.ts +1 -1
  372. package/src/network/reqresp/handlers/beaconBlocksByRange.ts +3 -2
  373. package/src/network/reqresp/handlers/blobSidecarsByRange.ts +3 -2
  374. package/src/network/reqresp/handlers/blobSidecarsByRoot.ts +1 -1
  375. package/src/network/reqresp/handlers/dataColumnSidecarsByRange.ts +3 -2
  376. package/src/network/reqresp/handlers/dataColumnSidecarsByRoot.ts +1 -1
  377. package/src/network/reqresp/score.ts +0 -1
  378. package/src/network/util.ts +2 -2
  379. package/src/node/nodejs.ts +8 -9
  380. package/src/util/blobs.ts +3 -3
  381. package/src/util/clock.ts +9 -4
  382. package/src/util/dataColumns.ts +37 -1
  383. package/src/util/multifork.ts +45 -0
  384. package/src/util/workerEvents.ts +1 -1
@@ -1,10 +1,13 @@
1
1
  import {ChainForkConfig} from "@lodestar/config";
2
- import {ProtoBlock, getSafeExecutionBlockHash} from "@lodestar/fork-choice";
2
+ import {IForkChoice, ProtoBlock, getSafeExecutionBlockHash} from "@lodestar/fork-choice";
3
3
  import {
4
+ BUILDER_INDEX_SELF_BUILD,
4
5
  ForkName,
5
6
  ForkPostBellatrix,
7
+ ForkPostCapella,
6
8
  ForkPostDeneb,
7
9
  ForkPostFulu,
10
+ ForkPostGloas,
8
11
  ForkPreGloas,
9
12
  ForkSeq,
10
13
  isForkPostAltair,
@@ -16,6 +19,8 @@ import {
16
19
  CachedBeaconStateBellatrix,
17
20
  CachedBeaconStateCapella,
18
21
  CachedBeaconStateExecutions,
22
+ CachedBeaconStateGloas,
23
+ G2_POINT_AT_INFINITY,
19
24
  computeTimeAtSlot,
20
25
  getExpectedWithdrawals,
21
26
  getRandaoMix,
@@ -42,6 +47,7 @@ import {
42
47
  deneb,
43
48
  electra,
44
49
  fulu,
50
+ gloas,
45
51
  } from "@lodestar/types";
46
52
  import {Logger, fromHex, sleep, toHex, toPubkeyHex, toRootHex} from "@lodestar/utils";
47
53
  import {ZERO_HASH_HEX} from "../../constants/index.js";
@@ -99,6 +105,20 @@ export type AssembledBodyType<T extends BlockType> = T extends BlockType.Full
99
105
  : BlindedBeaconBlockBody;
100
106
  export type AssembledBlockType<T extends BlockType> = T extends BlockType.Full ? BeaconBlock : BlindedBeaconBlock;
101
107
 
108
+ export type ProduceFullGloas = {
109
+ type: BlockType.Full;
110
+ fork: ForkPostGloas;
111
+ executionPayload: ExecutionPayload<ForkPostGloas>;
112
+ executionRequests: electra.ExecutionRequests;
113
+ blobsBundle: BlobsBundle<ForkPostGloas>;
114
+ cells: fulu.Cell[][];
115
+ /**
116
+ * Cached envelope state root computed during block production.
117
+ * This is the state root after running `processExecutionPayloadEnvelope` on the
118
+ * post-block state, and later used to construct the `ExecutionPayloadEnvelope`.
119
+ */
120
+ envelopeStateRoot: Root;
121
+ };
102
122
  export type ProduceFullFulu = {
103
123
  type: BlockType.Full;
104
124
  fork: ForkPostFulu;
@@ -131,6 +151,7 @@ export type ProduceBlinded = {
131
151
 
132
152
  /** The result of local block production, everything that's not the block itself */
133
153
  export type ProduceResult =
154
+ | ProduceFullGloas
134
155
  | ProduceFullFulu
135
156
  | ProduceFullDeneb
136
157
  | ProduceFullBellatrix
@@ -180,12 +201,112 @@ export async function produceBlockBody<T extends BlockType>(
180
201
  this.logger.verbose("Producing beacon block body", logMeta);
181
202
 
182
203
  if (isForkPostGloas(fork)) {
183
- // TODO GLOAS: Set body.signedExecutionPayloadBid and body.payloadAttestation
204
+ // TODO GLOAS: support non self-building here, the block type differentiation between
205
+ // full and blinded no longer makes sense in gloas, it might be a good idea to move
206
+ // this into a completely separate function and have pre/post gloas more separated
207
+ const gloasState = currentState as CachedBeaconStateGloas;
208
+ const safeBlockHash = getSafeExecutionBlockHash(this.forkChoice);
209
+ const finalizedBlockHash = this.forkChoice.getFinalizedBlock().executionPayloadBlockHash ?? ZERO_HASH_HEX;
210
+ const feeRecipient = requestedFeeRecipient ?? this.beaconProposerCache.getOrDefault(proposerIndex);
211
+
212
+ const endExecutionPayload = this.metrics?.executionBlockProductionTimeSteps.startTimer();
213
+
214
+ this.logger.verbose("Preparing execution payload from engine", {
215
+ slot: blockSlot,
216
+ parentBlockRoot: toRootHex(parentBlockRoot),
217
+ feeRecipient,
218
+ });
219
+
220
+ // Get execution payload from EL
221
+ const prepareRes = await prepareExecutionPayload(
222
+ this,
223
+ this.logger,
224
+ fork,
225
+ parentBlockRoot,
226
+ safeBlockHash,
227
+ finalizedBlockHash ?? ZERO_HASH_HEX,
228
+ gloasState,
229
+ feeRecipient
230
+ );
231
+
232
+ const {prepType, payloadId} = prepareRes;
233
+ Object.assign(logMeta, {executionPayloadPrepType: prepType});
234
+
235
+ if (prepType !== PayloadPreparationType.Cached) {
236
+ await sleep(PAYLOAD_GENERATION_TIME_MS);
237
+ }
238
+
239
+ this.logger.verbose("Fetching execution payload from engine", {slot: blockSlot, payloadId});
240
+ const payloadRes = await this.executionEngine.getPayload(fork, payloadId);
241
+
242
+ endExecutionPayload?.({step: BlockProductionStep.executionPayload});
243
+
244
+ const {executionPayload, blobsBundle, executionRequests} = payloadRes;
245
+ executionPayloadValue = payloadRes.executionPayloadValue;
246
+ shouldOverrideBuilder = payloadRes.shouldOverrideBuilder;
247
+
248
+ if (blobsBundle === undefined) {
249
+ throw Error(`Missing blobsBundle response from getPayload at fork=${fork}`);
250
+ }
251
+ if (executionRequests === undefined) {
252
+ throw Error(`Missing executionRequests response from getPayload at fork=${fork}`);
253
+ }
254
+
255
+ const cells = blobsBundle.blobs.map((blob) => kzg.computeCells(blob));
256
+ if (this.opts.sanityCheckExecutionEngineBlobs) {
257
+ await validateCellsAndKzgCommitments(blobsBundle.commitments, blobsBundle.proofs, cells);
258
+ }
259
+
260
+ // Create self-build execution payload bid
261
+ const bid: gloas.ExecutionPayloadBid = {
262
+ parentBlockHash: gloasState.latestBlockHash,
263
+ parentBlockRoot: parentBlockRoot,
264
+ blockHash: executionPayload.blockHash,
265
+ prevRandao: getRandaoMix(gloasState, gloasState.epochCtx.epoch),
266
+ feeRecipient: executionPayload.feeRecipient,
267
+ gasLimit: BigInt(executionPayload.gasLimit),
268
+ builderIndex: BUILDER_INDEX_SELF_BUILD,
269
+ slot: blockSlot,
270
+ value: 0,
271
+ executionPayment: 0,
272
+ blobKzgCommitments: blobsBundle.commitments,
273
+ };
274
+ const signedBid: gloas.SignedExecutionPayloadBid = {
275
+ message: bid,
276
+ signature: G2_POINT_AT_INFINITY,
277
+ };
278
+
184
279
  const commonBlockBody = await commonBlockBodyPromise;
185
- blockBody = Object.assign({}, commonBlockBody) as AssembledBodyType<T>;
186
- executionPayloadValue = BigInt(0);
280
+ const gloasBody = Object.assign({}, commonBlockBody) as gloas.BeaconBlockBody;
281
+ gloasBody.signedExecutionPayloadBid = signedBid;
282
+ // TODO GLOAS: Get payload attestations from pool for previous slot
283
+ gloasBody.payloadAttestations = [];
284
+ blockBody = gloasBody as AssembledBodyType<T>;
285
+
286
+ // Store execution payload data required to construct execution payload envelope later
287
+ const gloasResult = produceResult as ProduceFullGloas;
288
+ gloasResult.executionPayload = executionPayload as ExecutionPayload<ForkPostGloas>;
289
+ gloasResult.executionRequests = executionRequests;
290
+ gloasResult.blobsBundle = blobsBundle;
291
+ gloasResult.cells = cells;
292
+
293
+ const fetchedTime = Date.now() / 1000 - computeTimeAtSlot(this.config, blockSlot, this.genesisTime);
294
+ this.metrics?.blockPayload.payloadFetchedTime.observe({prepType}, fetchedTime);
295
+ this.logger.verbose("Produced block with self-build bid", {
296
+ slot: blockSlot,
297
+ executionPayloadValue,
298
+ prepType,
299
+ payloadId,
300
+ fetchedTime,
301
+ executionBlockHash: toRootHex(executionPayload.blockHash),
302
+ blobs: blobsBundle.commitments.length,
303
+ });
187
304
 
188
- // We don't deal with blinded blocks, execution engine, blobs and execution requests post-gloas
305
+ Object.assign(logMeta, {
306
+ transactions: executionPayload.transactions.length,
307
+ blobs: blobsBundle.commitments.length,
308
+ shouldOverrideBuilder,
309
+ });
189
310
  } else if (isForkPostBellatrix(fork)) {
190
311
  const safeBlockHash = getSafeExecutionBlockHash(this.forkChoice);
191
312
  const finalizedBlockHash = this.forkChoice.getFinalizedBlock().executionPayloadBlockHash ?? ZERO_HASH_HEX;
@@ -447,8 +568,14 @@ export async function produceBlockBody<T extends BlockType>(
447
568
  });
448
569
  }
449
570
 
450
- if (ForkSeq[fork] >= ForkSeq.capella) {
451
- const {blsToExecutionChanges, executionPayload} = blockBody as capella.BeaconBlockBody;
571
+ if (ForkSeq[fork] >= ForkSeq.gloas) {
572
+ const {blsToExecutionChanges, payloadAttestations} = blockBody as BeaconBlockBody<ForkPostGloas>;
573
+ Object.assign(logMeta, {
574
+ blsToExecutionChanges: blsToExecutionChanges.length,
575
+ payloadAttestations: payloadAttestations.length,
576
+ });
577
+ } else if (ForkSeq[fork] >= ForkSeq.capella) {
578
+ const {blsToExecutionChanges, executionPayload} = blockBody as BeaconBlockBody<ForkPostCapella & ForkPreGloas>;
452
579
  Object.assign(logMeta, {
453
580
  blsToExecutionChanges: blsToExecutionChanges.length,
454
581
  });
@@ -480,10 +607,12 @@ export async function prepareExecutionPayload(
480
607
  parentBlockRoot: Root,
481
608
  safeBlockHash: RootHex,
482
609
  finalizedBlockHash: RootHex,
483
- state: CachedBeaconStateExecutions,
610
+ state: CachedBeaconStateExecutions | CachedBeaconStateGloas,
484
611
  suggestedFeeRecipient: string
485
612
  ): Promise<{prepType: PayloadPreparationType; payloadId: PayloadId}> {
486
- const parentHash = state.latestExecutionPayloadHeader.blockHash;
613
+ const parentHash = isForkPostGloas(fork)
614
+ ? (state as CachedBeaconStateGloas).latestBlockHash
615
+ : (state as CachedBeaconStateExecutions).latestExecutionPayloadHeader.blockHash;
487
616
  const timestamp = computeTimeAtSlot(chain.config, state.slot, state.genesisTime);
488
617
  const prevRandao = getRandaoMix(state, state.epochCtx.epoch);
489
618
 
@@ -568,25 +697,45 @@ export function getPayloadAttributesForSSE(
568
697
  fork: ForkPostBellatrix,
569
698
  chain: {
570
699
  config: ChainForkConfig;
700
+ forkChoice: IForkChoice;
571
701
  },
572
702
  {
573
703
  prepareState,
574
704
  prepareSlot,
575
705
  parentBlockRoot,
576
706
  feeRecipient,
577
- }: {prepareState: CachedBeaconStateExecutions; prepareSlot: Slot; parentBlockRoot: Root; feeRecipient: string}
707
+ }: {
708
+ prepareState: CachedBeaconStateExecutions | CachedBeaconStateGloas;
709
+ prepareSlot: Slot;
710
+ parentBlockRoot: Root;
711
+ feeRecipient: string;
712
+ }
578
713
  ): SSEPayloadAttributes {
579
- const parentHash = prepareState.latestExecutionPayloadHeader.blockHash;
714
+ const parentHash = isForkPostGloas(fork)
715
+ ? (prepareState as CachedBeaconStateGloas).latestBlockHash
716
+ : (prepareState as CachedBeaconStateExecutions).latestExecutionPayloadHeader.blockHash;
580
717
  const payloadAttributes = preparePayloadAttributes(fork, chain, {
581
718
  prepareState,
582
719
  prepareSlot,
583
720
  parentBlockRoot,
584
721
  feeRecipient,
585
722
  });
723
+
724
+ let parentBlockNumber: number;
725
+ if (isForkPostGloas(fork)) {
726
+ const parentBlock = chain.forkChoice.getBlockHexAndBlockHash(toRootHex(parentBlockRoot), toRootHex(parentHash));
727
+ if (parentBlock?.executionPayloadBlockHash == null) {
728
+ throw Error(`Parent block not found in fork choice root=${toRootHex(parentBlockRoot)}`);
729
+ }
730
+ parentBlockNumber = parentBlock.executionPayloadNumber;
731
+ } else {
732
+ parentBlockNumber = (prepareState as CachedBeaconStateExecutions).latestExecutionPayloadHeader.blockNumber;
733
+ }
734
+
586
735
  const ssePayloadAttributes: SSEPayloadAttributes = {
587
736
  proposerIndex: prepareState.epochCtx.getBeaconProposer(prepareSlot),
588
737
  proposalSlot: prepareSlot,
589
- parentBlockNumber: prepareState.latestExecutionPayloadHeader.blockNumber,
738
+ parentBlockNumber,
590
739
  parentBlockRoot,
591
740
  parentBlockHash: parentHash,
592
741
  payloadAttributes,
@@ -605,7 +754,7 @@ function preparePayloadAttributes(
605
754
  parentBlockRoot,
606
755
  feeRecipient,
607
756
  }: {
608
- prepareState: CachedBeaconStateExecutions;
757
+ prepareState: CachedBeaconStateExecutions | CachedBeaconStateGloas;
609
758
  prepareSlot: Slot;
610
759
  parentBlockRoot: Root;
611
760
  feeRecipient: string;
@@ -1,7 +1,7 @@
1
1
  import {routes} from "@lodestar/api";
2
2
  import {IForkChoice, ProtoBlock} from "@lodestar/fork-choice";
3
3
  import {CachedBeaconStateAllForks, computeEpochAtSlot} from "@lodestar/state-transition";
4
- import {BeaconBlock, Epoch, RootHex, Slot, phase0} from "@lodestar/types";
4
+ import {BeaconBlock, Epoch, RootHex, Slot, isGloasBeaconBlock, phase0} from "@lodestar/types";
5
5
  import {Logger, toRootHex} from "@lodestar/utils";
6
6
  import {Metrics} from "../../metrics/index.js";
7
7
  import {JobItemQueue} from "../../util/queue/index.js";
@@ -88,7 +88,12 @@ export class QueuedStateRegenerator implements IStateRegenerator {
88
88
  */
89
89
  getPreStateSync(block: BeaconBlock): CachedBeaconStateAllForks | null {
90
90
  const parentRoot = toRootHex(block.parentRoot);
91
- const parentBlock = this.forkChoice.getBlockHex(parentRoot);
91
+ const parentBlock = isGloasBeaconBlock(block)
92
+ ? this.forkChoice.getBlockHexAndBlockHash(
93
+ parentRoot,
94
+ toRootHex(block.body.signedExecutionPayloadBid.message.parentBlockHash)
95
+ )
96
+ : this.forkChoice.getBlockHexDefaultStatus(parentRoot);
92
97
  if (!parentBlock) {
93
98
  throw new RegenError({
94
99
  code: RegenErrorCode.BLOCK_NOT_IN_FORKCHOICE,
@@ -11,7 +11,7 @@ import {
11
11
  processSlots,
12
12
  stateTransition,
13
13
  } from "@lodestar/state-transition";
14
- import {BeaconBlock, RootHex, SignedBeaconBlock, Slot} from "@lodestar/types";
14
+ import {BeaconBlock, RootHex, SignedBeaconBlock, Slot, isGloasBeaconBlock} from "@lodestar/types";
15
15
  import {Logger, fromHex, toRootHex} from "@lodestar/utils";
16
16
  import {IBeaconDb} from "../../db/index.js";
17
17
  import {Metrics} from "../../metrics/index.js";
@@ -58,7 +58,13 @@ export class StateRegenerator implements IStateRegeneratorInternal {
58
58
  opts: StateRegenerationOpts,
59
59
  regenCaller: RegenCaller
60
60
  ): Promise<CachedBeaconStateAllForks> {
61
- const parentBlock = this.modules.forkChoice.getBlock(block.parentRoot);
61
+ const parentRoot = toRootHex(block.parentRoot);
62
+ const parentBlock = isGloasBeaconBlock(block)
63
+ ? this.modules.forkChoice.getBlockHexAndBlockHash(
64
+ parentRoot,
65
+ toRootHex(block.body.signedExecutionPayloadBid.message.parentBlockHash)
66
+ )
67
+ : this.modules.forkChoice.getBlockHexDefaultStatus(parentRoot);
62
68
  if (!parentBlock) {
63
69
  throw new RegenError({
64
70
  code: RegenErrorCode.BLOCK_NOT_IN_FORKCHOICE,
@@ -152,7 +158,7 @@ export class StateRegenerator implements IStateRegeneratorInternal {
152
158
 
153
159
  const getSeedStateTimer = this.modules.metrics?.regenGetState.getSeedState.startTimer({caller});
154
160
  // iterateAncestorBlocks only returns ancestor blocks, not the block itself
155
- for (const b of this.modules.forkChoice.iterateAncestorBlocks(block.blockRoot)) {
161
+ for (const b of this.modules.forkChoice.iterateAncestorBlocks(block.blockRoot, block.payloadStatus)) {
156
162
  state = this.modules.blockStateCache.get(b.stateRoot);
157
163
  if (state) {
158
164
  break;
@@ -3,6 +3,7 @@ import {CheckpointWithHex} from "@lodestar/fork-choice";
3
3
  import {
4
4
  ForkName,
5
5
  ForkPostFulu,
6
+ ForkPostGloas,
6
7
  ForkPreGloas,
7
8
  SLOTS_PER_EPOCH,
8
9
  isForkPostDeneb,
@@ -20,6 +21,7 @@ import {
20
21
  BlockInput,
21
22
  BlockInputBlobs,
22
23
  BlockInputColumns,
24
+ BlockInputNoData,
23
25
  BlockInputPreData,
24
26
  BlockWithSource,
25
27
  DAType,
@@ -179,12 +181,19 @@ export class SeenBlockInput {
179
181
  if (!blockInput) {
180
182
  const {forkName, daOutOfRange} = this.buildCommonProps(block.message.slot);
181
183
 
182
- // TODO GLOAS: Implement
183
184
  if (isForkPostGloas(forkName)) {
184
- throw Error("Not implemented");
185
- }
186
- // Pre-deneb
187
- if (!isForkPostDeneb(forkName)) {
185
+ // Post-gloas
186
+ blockInput = BlockInputNoData.createFromBlock({
187
+ block: block as SignedBeaconBlock<ForkPostGloas>,
188
+ blockRootHex,
189
+ daOutOfRange,
190
+ forkName,
191
+ source,
192
+ seenTimestampSec,
193
+ peerIdStr,
194
+ });
195
+ } else if (!isForkPostDeneb(forkName)) {
196
+ // Pre-deneb
188
197
  blockInput = BlockInputPreData.createFromBlock({
189
198
  block,
190
199
  blockRootHex,
@@ -194,8 +203,8 @@ export class SeenBlockInput {
194
203
  seenTimestampSec,
195
204
  peerIdStr,
196
205
  });
197
- // Fulu Only
198
206
  } else if (isForkPostFulu(forkName)) {
207
+ // Fulu Only
199
208
  blockInput = BlockInputColumns.createFromBlock({
200
209
  block: block as SignedBeaconBlock<ForkPostFulu & ForkPreGloas>,
201
210
  blockRootHex,
@@ -207,8 +216,8 @@ export class SeenBlockInput {
207
216
  seenTimestampSec,
208
217
  peerIdStr,
209
218
  });
210
- // Deneb and Electra
211
219
  } else {
220
+ // Deneb and Electra
212
221
  blockInput = BlockInputBlobs.createFromBlock({
213
222
  block: block as SignedBeaconBlock<ForkBlobsDA>,
214
223
  blockRootHex,
@@ -81,7 +81,7 @@ async function validateAggregateAndProof(
81
81
  });
82
82
  }
83
83
  // [REJECT] `aggregate.data.index == 0` if `block.slot == aggregate.data.slot`.
84
- const block = chain.forkChoice.getBlock(attData.beaconBlockRoot);
84
+ const block = chain.forkChoice.getBlockDefaultStatus(attData.beaconBlockRoot);
85
85
 
86
86
  // If block is unknown, we don't handle it here. It will throw error later on at `verifyHeadBlockAndTargetRoot()`
87
87
  if (block !== null && block.slot === attData.slot && attData.index !== 0) {
@@ -143,7 +143,10 @@ export async function validateGossipAttestationsSameAttData(
143
143
  if (batchableBls) {
144
144
  // all signature sets should have same signing root since we filtered in network processor
145
145
  signatureValids = await chain.bls.verifySignatureSetsSameMessage(
146
- signatureSets.map((set) => ({publicKey: chain.index2pubkey[set.index], signature: set.signature})),
146
+ signatureSets.map((set) => {
147
+ const publicKey = chain.pubkeyCache.getOrThrow(set.index);
148
+ return {publicKey, signature: set.signature};
149
+ }),
147
150
  signatureSets[0].signingRoot
148
151
  );
149
152
  } else {
@@ -183,7 +186,7 @@ export async function validateGossipAttestationsSameAttData(
183
186
  chain.seenAttesters.add(targetEpoch, validatorIndex);
184
187
  } else {
185
188
  step0ResultOrErrors[oldIndex] = {
186
- err: new AttestationError(GossipAction.IGNORE, {
189
+ err: new AttestationError(GossipAction.REJECT, {
187
190
  code: AttestationErrorCode.INVALID_SIGNATURE,
188
191
  }),
189
192
  };
@@ -304,7 +307,7 @@ async function validateAttestationNoSignatureCheck(
304
307
  }
305
308
 
306
309
  // [REJECT] `attestation.data.index == 0` if `block.slot == attestation.data.slot`.
307
- const block = chain.forkChoice.getBlock(attData.beaconBlockRoot);
310
+ const block = chain.forkChoice.getBlockDefaultStatus(attData.beaconBlockRoot);
308
311
 
309
312
  // block being null will be handled by `verifyHeadBlockAndTargetRoot`
310
313
  if (block !== null && block.slot === attSlot && attData.index !== 0) {
@@ -753,7 +756,7 @@ export function getAttestationDataSigningRoot(config: BeaconConfig, data: phase0
753
756
  function verifyHeadBlockIsKnown(chain: IBeaconChain, beaconBlockRoot: Root): ProtoBlock {
754
757
  // TODO (LH): Enforce a maximum skip distance for unaggregated attestations.
755
758
 
756
- const headBlock = chain.forkChoice.getBlock(beaconBlockRoot);
759
+ const headBlock = chain.forkChoice.getBlockDefaultStatus(beaconBlockRoot);
757
760
  if (headBlock === null) {
758
761
  throw new AttestationError(GossipAction.IGNORE, {
759
762
  code: AttestationErrorCode.UNKNOWN_OR_PREFINALIZED_BEACON_BLOCK_ROOT,
@@ -2,6 +2,7 @@ import {
2
2
  assertValidAttesterSlashing,
3
3
  getAttesterSlashableIndices,
4
4
  getAttesterSlashingSignatureSets,
5
+ isSlashableValidator,
5
6
  } from "@lodestar/state-transition";
6
7
  import {AttesterSlashing} from "@lodestar/types";
7
8
  import {AttesterSlashingError, AttesterSlashingErrorCode, GossipAction} from "../errors/index.js";
@@ -45,7 +46,7 @@ export async function validateAttesterSlashing(
45
46
  // verifySignature = false, verified in batch below
46
47
  assertValidAttesterSlashing(
47
48
  chain.config,
48
- chain.index2pubkey,
49
+ chain.pubkeyCache,
49
50
  state.slot,
50
51
  state.validators.length,
51
52
  attesterSlashing,
@@ -58,6 +59,14 @@ export async function validateAttesterSlashing(
58
59
  });
59
60
  }
60
61
 
62
+ const currentEpoch = state.epochCtx.epoch;
63
+ if (!intersectingIndices.some((index) => isSlashableValidator(state.validators.getReadonly(index), currentEpoch))) {
64
+ throw new AttesterSlashingError(GossipAction.REJECT, {
65
+ code: AttesterSlashingErrorCode.INVALID,
66
+ error: Error("AttesterSlashing has no slashable validators"),
67
+ });
68
+ }
69
+
61
70
  const signatureSets = getAttesterSlashingSignatureSets(chain.config, state.slot, attesterSlashing);
62
71
  if (!(await chain.bls.verifySignatureSets(signatureSets, {batchable: true, priority: prioritizeBls}))) {
63
72
  throw new AttesterSlashingError(GossipAction.REJECT, {
@@ -78,7 +78,7 @@ export async function validateGossipBlobSidecar(
78
78
  // already know this block.
79
79
  const blockRoot = ssz.phase0.BeaconBlockHeader.hashTreeRoot(blobSidecar.signedBlockHeader.message);
80
80
  const blockHex = toRootHex(blockRoot);
81
- if (chain.forkChoice.getBlockHex(blockHex) !== null) {
81
+ if (chain.forkChoice.getBlockHexDefaultStatus(blockHex) !== null) {
82
82
  throw new BlobSidecarGossipError(GossipAction.IGNORE, {code: BlobSidecarErrorCode.ALREADY_KNOWN, root: blockHex});
83
83
  }
84
84
 
@@ -89,7 +89,7 @@ export async function validateGossipBlobSidecar(
89
89
  // gossip and non-gossip sources) (a client MAY queue blocks for processing once the parent block is
90
90
  // retrieved).
91
91
  const parentRoot = toRootHex(blobSidecar.signedBlockHeader.message.parentRoot);
92
- const parentBlock = chain.forkChoice.getBlockHex(parentRoot);
92
+ const parentBlock = chain.forkChoice.getBlockHexDefaultStatus(parentRoot);
93
93
  if (parentBlock === null) {
94
94
  // If fork choice does *not* consider the parent to be a descendant of the finalized block,
95
95
  // then there are two more cases:
@@ -9,7 +9,7 @@ import {
9
9
  isExecutionEnabled,
10
10
  isExecutionStateType,
11
11
  } from "@lodestar/state-transition";
12
- import {SignedBeaconBlock, deneb, gloas} from "@lodestar/types";
12
+ import {SignedBeaconBlock, deneb, gloas, isGloasBeaconBlock} from "@lodestar/types";
13
13
  import {byteArrayEquals, sleep, toRootHex} from "@lodestar/utils";
14
14
  import {BlockErrorCode, BlockGossipError, GossipAction} from "../errors/index.js";
15
15
  import {IBeaconChain} from "../interface.js";
@@ -56,7 +56,7 @@ export async function validateGossipBlock(
56
56
  // check, we will load the parent and state from disk only to find out later that we
57
57
  // already know this block.
58
58
  const blockRoot = toRootHex(config.getForkTypes(blockSlot).BeaconBlock.hashTreeRoot(block));
59
- if (chain.forkChoice.getBlockHex(blockRoot) !== null) {
59
+ if (chain.forkChoice.getBlockHexDefaultStatus(blockRoot) !== null) {
60
60
  throw new BlockGossipError(GossipAction.IGNORE, {code: BlockErrorCode.ALREADY_KNOWN, root: blockRoot});
61
61
  }
62
62
 
@@ -72,7 +72,12 @@ export async function validateGossipBlock(
72
72
  // [REJECT] The current finalized_checkpoint is an ancestor of block -- i.e.
73
73
  // get_ancestor(store, block.parent_root, compute_start_slot_at_epoch(store.finalized_checkpoint.epoch)) == store.finalized_checkpoint.root
74
74
  const parentRoot = toRootHex(block.parentRoot);
75
- const parentBlock = chain.forkChoice.getBlockHex(parentRoot);
75
+ const parentBlock = isGloasBeaconBlock(block)
76
+ ? chain.forkChoice.getBlockHexAndBlockHash(
77
+ parentRoot,
78
+ toRootHex(block.body.signedExecutionPayloadBid.message.parentBlockHash)
79
+ )
80
+ : chain.forkChoice.getBlockHexDefaultStatus(parentRoot);
76
81
  if (parentBlock === null) {
77
82
  // If fork choice does *not* consider the parent to be a descendant of the finalized block,
78
83
  // then there are two more cases:
@@ -104,7 +109,7 @@ export async function validateGossipBlock(
104
109
 
105
110
  // [REJECT] The block is from a higher slot than its parent.
106
111
  if (parentBlock.slot >= blockSlot) {
107
- throw new BlockGossipError(GossipAction.IGNORE, {
112
+ throw new BlockGossipError(GossipAction.REJECT, {
108
113
  code: BlockErrorCode.NOT_LATER_THAN_PARENT,
109
114
  parentSlot: parentBlock.slot,
110
115
  slot: blockSlot,
@@ -10,7 +10,7 @@ import {
10
10
  getBlockHeaderProposerSignatureSetByHeaderSlot,
11
11
  getBlockHeaderProposerSignatureSetByParentStateSlot,
12
12
  } from "@lodestar/state-transition";
13
- import {Root, Slot, SubnetID, fulu, ssz} from "@lodestar/types";
13
+ import {DataColumnSidecar, Root, Slot, SubnetID, fulu, ssz} from "@lodestar/types";
14
14
  import {byteArrayEquals, toRootHex, verifyMerkleBranch} from "@lodestar/utils";
15
15
  import {Metrics} from "../../metrics/metrics.js";
16
16
  import {kzg} from "../../util/kzg.js";
@@ -73,7 +73,7 @@ export async function validateGossipDataColumnSidecar(
73
73
  // 6) [IGNORE] The sidecar's block's parent (defined by block_header.parent_root) has been seen (via gossip
74
74
  // or non-gossip sources)
75
75
  const parentRoot = toRootHex(blockHeader.parentRoot);
76
- const parentBlock = chain.forkChoice.getBlockHex(parentRoot);
76
+ const parentBlock = chain.forkChoice.getBlockHexDefaultStatus(parentRoot);
77
77
  if (parentBlock === null) {
78
78
  // If fork choice does *not* consider the parent to be a descendant of the finalized block,
79
79
  // then there are two more cases:
@@ -457,9 +457,6 @@ export async function validateBlockDataColumnSidecars(
457
457
  * SPEC FUNCTION
458
458
  * https://github.com/ethereum/consensus-specs/blob/v1.6.0-alpha.4/specs/fulu/p2p-interface.md#compute_subnet_for_data_column_sidecar
459
459
  */
460
- export function computeSubnetForDataColumnSidecar(
461
- config: ChainConfig,
462
- columnSidecar: fulu.DataColumnSidecar
463
- ): SubnetID {
460
+ export function computeSubnetForDataColumnSidecar(config: ChainConfig, columnSidecar: DataColumnSidecar): SubnetID {
464
461
  return columnSidecar.index % config.DATA_COLUMN_SIDECAR_SUBNET_COUNT;
465
462
  }
@@ -113,8 +113,7 @@ async function validateExecutionPayloadBid(
113
113
 
114
114
  // [IGNORE] `bid.parent_block_root` is the hash tree root of a known beacon
115
115
  // block in fork choice.
116
- const block = chain.forkChoice.getBlock(bid.parentBlockRoot);
117
- if (block === null) {
116
+ if (!chain.forkChoice.hasBlock(bid.parentBlockRoot)) {
118
117
  throw new ExecutionPayloadBidError(GossipAction.IGNORE, {
119
118
  code: ExecutionPayloadBidErrorCode.UNKNOWN_BLOCK_ROOT,
120
119
  parentBlockRoot: parentBlockRootHex,
@@ -37,7 +37,7 @@ async function validateExecutionPayloadEnvelope(
37
37
  // the block is retrieved).
38
38
  // TODO GLOAS: Need to review this, we should queue the envelope for later
39
39
  // processing if the block is not yet known, otherwise we would ignore it here
40
- const block = chain.forkChoice.getBlock(envelope.beaconBlockRoot);
40
+ const block = chain.forkChoice.getBlockDefaultStatus(envelope.beaconBlockRoot);
41
41
  if (block === null) {
42
42
  throw new ExecutionPayloadEnvelopeError(GossipAction.IGNORE, {
43
43
  code: ExecutionPayloadEnvelopeErrorCode.BLOCK_ROOT_UNKNOWN,
@@ -79,7 +79,7 @@ async function validateExecutionPayloadEnvelope(
79
79
  });
80
80
  }
81
81
 
82
- if (block.builderIndex === undefined || block.blockHashHex === undefined) {
82
+ if (block.builderIndex == null || block.blockHashFromBid == null) {
83
83
  // This indicates this block is a pre-gloas block which is wrong
84
84
  throw new ExecutionPayloadEnvelopeError(GossipAction.IGNORE, {
85
85
  code: ExecutionPayloadEnvelopeErrorCode.CACHE_FAIL,
@@ -97,11 +97,11 @@ async function validateExecutionPayloadEnvelope(
97
97
  }
98
98
 
99
99
  // [REJECT] `payload.block_hash == bid.block_hash`
100
- if (toRootHex(payload.blockHash) !== block.blockHashHex) {
100
+ if (toRootHex(payload.blockHash) !== block.blockHashFromBid) {
101
101
  throw new ExecutionPayloadEnvelopeError(GossipAction.REJECT, {
102
102
  code: ExecutionPayloadEnvelopeErrorCode.BLOCK_HASH_MISMATCH,
103
103
  envelopeBlockHash: toRootHex(payload.blockHash),
104
- bidBlockHash: block.blockHashHex,
104
+ bidBlockHash: block.blockHashFromBid,
105
105
  });
106
106
  }
107
107
 
@@ -59,8 +59,7 @@ async function validatePayloadAttestationMessage(
59
59
  // [IGNORE] The message's block `data.beacon_block_root` has been seen (via
60
60
  // gossip or non-gossip sources) (a client MAY queue attestation for processing
61
61
  // once the block is retrieved. Note a client might want to request payload after).
62
- const block = chain.forkChoice.getBlock(data.beaconBlockRoot);
63
- if (block === null) {
62
+ if (!chain.forkChoice.hasBlock(data.beaconBlockRoot)) {
64
63
  throw new PayloadAttestationError(GossipAction.IGNORE, {
65
64
  code: PayloadAttestationErrorCode.UNKNOWN_BLOCK_ROOT,
66
65
  blockRoot: toRootHex(data.beaconBlockRoot),
@@ -87,8 +86,16 @@ async function validatePayloadAttestationMessage(
87
86
  }
88
87
 
89
88
  // [REJECT] `payload_attestation_message.signature` is valid with respect to the validator's public key.
89
+ const validatorPubkey = chain.pubkeyCache.get(validatorIndex);
90
+ if (!validatorPubkey) {
91
+ throw new PayloadAttestationError(GossipAction.REJECT, {
92
+ code: PayloadAttestationErrorCode.INVALID_ATTESTER,
93
+ attesterIndex: validatorIndex,
94
+ });
95
+ }
96
+
90
97
  const signatureSet = createSingleSignatureSetFromComponents(
91
- chain.index2pubkey[validatorIndex],
98
+ validatorPubkey,
92
99
  getPayloadAttestationDataSigningRoot(chain.config, data),
93
100
  payloadAttestationMessage.signature
94
101
  );
@@ -37,7 +37,7 @@ async function validateProposerSlashing(
37
37
  try {
38
38
  const proposer = state.validators.getReadonly(proposerSlashing.signedHeader1.message.proposerIndex);
39
39
  // verifySignature = false, verified in batch below
40
- assertValidProposerSlashing(chain.config, chain.index2pubkey, state.slot, proposerSlashing, proposer, false);
40
+ assertValidProposerSlashing(chain.config, chain.pubkeyCache, state.slot, proposerSlashing, proposer, false);
41
41
  } catch (e) {
42
42
  throw new ProposerSlashingError(GossipAction.REJECT, {
43
43
  code: ProposerSlashingErrorCode.INVALID,
@@ -106,7 +106,7 @@ export async function validateSyncCommitteeGossipContributionAndProof(
106
106
  /**
107
107
  * Retrieve pubkeys in contribution aggregate using epochCtx:
108
108
  * - currSyncCommitteeIndexes cache
109
- * - index2pubkey cache
109
+ * - pubkeyCache
110
110
  */
111
111
  function getContributionIndices(
112
112
  state: CachedBeaconStateAltair,