@lodestar/beacon-node 1.43.0-dev.5f9285892c → 1.43.0-dev.657dd16e61

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 (371) hide show
  1. package/lib/api/impl/beacon/blocks/index.d.ts.map +1 -1
  2. package/lib/api/impl/beacon/blocks/index.js +17 -9
  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 +45 -2
  6. package/lib/api/impl/beacon/pool/index.js.map +1 -1
  7. package/lib/api/impl/beacon/state/utils.d.ts +2 -2
  8. package/lib/api/impl/beacon/state/utils.d.ts.map +1 -1
  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 +0 -1
  12. package/lib/api/impl/debug/index.js.map +1 -1
  13. package/lib/api/impl/lodestar/index.js +1 -1
  14. package/lib/api/impl/lodestar/index.js.map +1 -1
  15. package/lib/api/impl/validator/index.d.ts.map +1 -1
  16. package/lib/api/impl/validator/index.js +68 -5
  17. package/lib/api/impl/validator/index.js.map +1 -1
  18. package/lib/chain/GetBlobsTracker.d.ts +1 -1
  19. package/lib/chain/GetBlobsTracker.d.ts.map +1 -1
  20. package/lib/chain/GetBlobsTracker.js +1 -2
  21. package/lib/chain/GetBlobsTracker.js.map +1 -1
  22. package/lib/chain/archiveStore/archiveStore.d.ts.map +1 -1
  23. package/lib/chain/archiveStore/archiveStore.js.map +1 -1
  24. package/lib/chain/archiveStore/interface.d.ts +4 -4
  25. package/lib/chain/archiveStore/interface.d.ts.map +1 -1
  26. package/lib/chain/archiveStore/strategies/frequencyStateArchiveStrategy.d.ts +4 -4
  27. package/lib/chain/archiveStore/strategies/frequencyStateArchiveStrategy.d.ts.map +1 -1
  28. package/lib/chain/archiveStore/strategies/frequencyStateArchiveStrategy.js +2 -4
  29. package/lib/chain/archiveStore/strategies/frequencyStateArchiveStrategy.js.map +1 -1
  30. package/lib/chain/archiveStore/utils/archiveBlocks.d.ts +2 -2
  31. package/lib/chain/archiveStore/utils/archiveBlocks.d.ts.map +1 -1
  32. package/lib/chain/archiveStore/utils/archiveBlocks.js +110 -58
  33. package/lib/chain/archiveStore/utils/archiveBlocks.js.map +1 -1
  34. package/lib/chain/blocks/blockInput/blockInput.d.ts +3 -0
  35. package/lib/chain/blocks/blockInput/blockInput.d.ts.map +1 -1
  36. package/lib/chain/blocks/blockInput/blockInput.js +4 -1
  37. package/lib/chain/blocks/blockInput/blockInput.js.map +1 -1
  38. package/lib/chain/blocks/importBlock.d.ts.map +1 -1
  39. package/lib/chain/blocks/importBlock.js +34 -54
  40. package/lib/chain/blocks/importBlock.js.map +1 -1
  41. package/lib/chain/blocks/importExecutionPayload.d.ts +28 -14
  42. package/lib/chain/blocks/importExecutionPayload.d.ts.map +1 -1
  43. package/lib/chain/blocks/importExecutionPayload.js +89 -89
  44. package/lib/chain/blocks/importExecutionPayload.js.map +1 -1
  45. package/lib/chain/blocks/index.d.ts +5 -3
  46. package/lib/chain/blocks/index.d.ts.map +1 -1
  47. package/lib/chain/blocks/index.js +59 -26
  48. package/lib/chain/blocks/index.js.map +1 -1
  49. package/lib/chain/blocks/payloadEnvelopeInput/payloadEnvelopeInput.d.ts +7 -0
  50. package/lib/chain/blocks/payloadEnvelopeInput/payloadEnvelopeInput.d.ts.map +1 -1
  51. package/lib/chain/blocks/payloadEnvelopeInput/payloadEnvelopeInput.js +29 -2
  52. package/lib/chain/blocks/payloadEnvelopeInput/payloadEnvelopeInput.js.map +1 -1
  53. package/lib/chain/blocks/payloadEnvelopeInput/types.d.ts +1 -0
  54. package/lib/chain/blocks/payloadEnvelopeInput/types.d.ts.map +1 -1
  55. package/lib/chain/blocks/payloadEnvelopeProcessor.d.ts +5 -0
  56. package/lib/chain/blocks/payloadEnvelopeProcessor.d.ts.map +1 -1
  57. package/lib/chain/blocks/payloadEnvelopeProcessor.js +7 -5
  58. package/lib/chain/blocks/payloadEnvelopeProcessor.js.map +1 -1
  59. package/lib/chain/blocks/types.d.ts +16 -21
  60. package/lib/chain/blocks/types.d.ts.map +1 -1
  61. package/lib/chain/blocks/utils/chainSegment.d.ts +23 -2
  62. package/lib/chain/blocks/utils/chainSegment.d.ts.map +1 -1
  63. package/lib/chain/blocks/utils/chainSegment.js +89 -12
  64. package/lib/chain/blocks/utils/chainSegment.js.map +1 -1
  65. package/lib/chain/blocks/verifyBlock.d.ts +5 -3
  66. package/lib/chain/blocks/verifyBlock.d.ts.map +1 -1
  67. package/lib/chain/blocks/verifyBlock.js +50 -7
  68. package/lib/chain/blocks/verifyBlock.js.map +1 -1
  69. package/lib/chain/blocks/verifyBlocksExecutionPayloads.d.ts +0 -4
  70. package/lib/chain/blocks/verifyBlocksExecutionPayloads.d.ts.map +1 -1
  71. package/lib/chain/blocks/verifyBlocksExecutionPayloads.js +5 -2
  72. package/lib/chain/blocks/verifyBlocksExecutionPayloads.js.map +1 -1
  73. package/lib/chain/blocks/verifyBlocksSanityChecks.d.ts +2 -1
  74. package/lib/chain/blocks/verifyBlocksSanityChecks.d.ts.map +1 -1
  75. package/lib/chain/blocks/verifyBlocksSanityChecks.js +25 -5
  76. package/lib/chain/blocks/verifyBlocksSanityChecks.js.map +1 -1
  77. package/lib/chain/blocks/verifyExecutionPayloadEnvelope.d.ts +24 -0
  78. package/lib/chain/blocks/verifyExecutionPayloadEnvelope.d.ts.map +1 -0
  79. package/lib/chain/blocks/verifyExecutionPayloadEnvelope.js +79 -0
  80. package/lib/chain/blocks/verifyExecutionPayloadEnvelope.js.map +1 -0
  81. package/lib/chain/blocks/verifyPayloadsDataAvailability.d.ts +14 -0
  82. package/lib/chain/blocks/verifyPayloadsDataAvailability.d.ts.map +1 -0
  83. package/lib/chain/blocks/verifyPayloadsDataAvailability.js +30 -0
  84. package/lib/chain/blocks/verifyPayloadsDataAvailability.js.map +1 -0
  85. package/lib/chain/blocks/writePayloadEnvelopeInputToDb.d.ts +1 -1
  86. package/lib/chain/blocks/writePayloadEnvelopeInputToDb.d.ts.map +1 -1
  87. package/lib/chain/blocks/writePayloadEnvelopeInputToDb.js +2 -11
  88. package/lib/chain/blocks/writePayloadEnvelopeInputToDb.js.map +1 -1
  89. package/lib/chain/chain.d.ts +8 -6
  90. package/lib/chain/chain.d.ts.map +1 -1
  91. package/lib/chain/chain.js +43 -43
  92. package/lib/chain/chain.js.map +1 -1
  93. package/lib/chain/emitter.d.ts +16 -15
  94. package/lib/chain/emitter.d.ts.map +1 -1
  95. package/lib/chain/emitter.js +5 -4
  96. package/lib/chain/emitter.js.map +1 -1
  97. package/lib/chain/errors/blockError.d.ts +8 -1
  98. package/lib/chain/errors/blockError.d.ts.map +1 -1
  99. package/lib/chain/errors/blockError.js +2 -0
  100. package/lib/chain/errors/blockError.js.map +1 -1
  101. package/lib/chain/errors/executionPayloadBid.d.ts +5 -0
  102. package/lib/chain/errors/executionPayloadBid.d.ts.map +1 -1
  103. package/lib/chain/errors/executionPayloadBid.js +1 -0
  104. package/lib/chain/errors/executionPayloadBid.js.map +1 -1
  105. package/lib/chain/errors/executionPayloadEnvelope.d.ts +5 -0
  106. package/lib/chain/errors/executionPayloadEnvelope.d.ts.map +1 -1
  107. package/lib/chain/errors/executionPayloadEnvelope.js +1 -0
  108. package/lib/chain/errors/executionPayloadEnvelope.js.map +1 -1
  109. package/lib/chain/errors/index.d.ts +1 -0
  110. package/lib/chain/errors/index.d.ts.map +1 -1
  111. package/lib/chain/errors/index.js +1 -0
  112. package/lib/chain/errors/index.js.map +1 -1
  113. package/lib/chain/errors/proposerPreferences.d.ts +40 -0
  114. package/lib/chain/errors/proposerPreferences.d.ts.map +1 -0
  115. package/lib/chain/errors/proposerPreferences.js +14 -0
  116. package/lib/chain/errors/proposerPreferences.js.map +1 -0
  117. package/lib/chain/forkChoice/index.d.ts.map +1 -1
  118. package/lib/chain/forkChoice/index.js +11 -19
  119. package/lib/chain/forkChoice/index.js.map +1 -1
  120. package/lib/chain/initState.d.ts.map +1 -1
  121. package/lib/chain/initState.js +6 -1
  122. package/lib/chain/initState.js.map +1 -1
  123. package/lib/chain/interface.d.ts +7 -5
  124. package/lib/chain/interface.d.ts.map +1 -1
  125. package/lib/chain/interface.js.map +1 -1
  126. package/lib/chain/opPools/payloadAttestationPool.d.ts +3 -2
  127. package/lib/chain/opPools/payloadAttestationPool.d.ts.map +1 -1
  128. package/lib/chain/opPools/payloadAttestationPool.js +26 -4
  129. package/lib/chain/opPools/payloadAttestationPool.js.map +1 -1
  130. package/lib/chain/prepareNextSlot.d.ts.map +1 -1
  131. package/lib/chain/prepareNextSlot.js +47 -23
  132. package/lib/chain/prepareNextSlot.js.map +1 -1
  133. package/lib/chain/produceBlock/computeNewStateRoot.d.ts +3 -9
  134. package/lib/chain/produceBlock/computeNewStateRoot.d.ts.map +1 -1
  135. package/lib/chain/produceBlock/computeNewStateRoot.js +5 -32
  136. package/lib/chain/produceBlock/computeNewStateRoot.js.map +1 -1
  137. package/lib/chain/produceBlock/produceBlockBody.d.ts +13 -8
  138. package/lib/chain/produceBlock/produceBlockBody.d.ts.map +1 -1
  139. package/lib/chain/produceBlock/produceBlockBody.js +68 -25
  140. package/lib/chain/produceBlock/produceBlockBody.js.map +1 -1
  141. package/lib/chain/regen/errors.d.ts +1 -11
  142. package/lib/chain/regen/errors.d.ts.map +1 -1
  143. package/lib/chain/regen/errors.js +0 -2
  144. package/lib/chain/regen/errors.js.map +1 -1
  145. package/lib/chain/regen/interface.d.ts +7 -11
  146. package/lib/chain/regen/interface.d.ts.map +1 -1
  147. package/lib/chain/regen/interface.js +1 -0
  148. package/lib/chain/regen/interface.js.map +1 -1
  149. package/lib/chain/regen/queued.d.ts +6 -10
  150. package/lib/chain/regen/queued.d.ts.map +1 -1
  151. package/lib/chain/regen/queued.js +4 -14
  152. package/lib/chain/regen/queued.js.map +1 -1
  153. package/lib/chain/regen/regen.d.ts +0 -5
  154. package/lib/chain/regen/regen.d.ts.map +1 -1
  155. package/lib/chain/regen/regen.js +1 -12
  156. package/lib/chain/regen/regen.js.map +1 -1
  157. package/lib/chain/seenCache/index.d.ts +1 -0
  158. package/lib/chain/seenCache/index.d.ts.map +1 -1
  159. package/lib/chain/seenCache/index.js +1 -0
  160. package/lib/chain/seenCache/index.js.map +1 -1
  161. package/lib/chain/seenCache/seenPayloadEnvelopeInput.d.ts +22 -6
  162. package/lib/chain/seenCache/seenPayloadEnvelopeInput.d.ts.map +1 -1
  163. package/lib/chain/seenCache/seenPayloadEnvelopeInput.js +53 -17
  164. package/lib/chain/seenCache/seenPayloadEnvelopeInput.js.map +1 -1
  165. package/lib/chain/seenCache/seenProposerPreferences.d.ts +16 -0
  166. package/lib/chain/seenCache/seenProposerPreferences.d.ts.map +1 -0
  167. package/lib/chain/seenCache/seenProposerPreferences.js +26 -0
  168. package/lib/chain/seenCache/seenProposerPreferences.js.map +1 -0
  169. package/lib/chain/stateCache/persistentCheckpointsCache.d.ts +1 -7
  170. package/lib/chain/stateCache/persistentCheckpointsCache.d.ts.map +1 -1
  171. package/lib/chain/stateCache/persistentCheckpointsCache.js +4 -9
  172. package/lib/chain/stateCache/persistentCheckpointsCache.js.map +1 -1
  173. package/lib/chain/stateCache/types.d.ts +0 -6
  174. package/lib/chain/stateCache/types.d.ts.map +1 -1
  175. package/lib/chain/stateCache/types.js.map +1 -1
  176. package/lib/chain/validation/block.d.ts.map +1 -1
  177. package/lib/chain/validation/block.js +1 -0
  178. package/lib/chain/validation/block.js.map +1 -1
  179. package/lib/chain/validation/executionPayloadBid.d.ts.map +1 -1
  180. package/lib/chain/validation/executionPayloadBid.js +24 -9
  181. package/lib/chain/validation/executionPayloadBid.js.map +1 -1
  182. package/lib/chain/validation/executionPayloadEnvelope.d.ts.map +1 -1
  183. package/lib/chain/validation/executionPayloadEnvelope.js +20 -10
  184. package/lib/chain/validation/executionPayloadEnvelope.js.map +1 -1
  185. package/lib/chain/validation/payloadAttestationMessage.d.ts.map +1 -1
  186. package/lib/chain/validation/payloadAttestationMessage.js +4 -3
  187. package/lib/chain/validation/payloadAttestationMessage.js.map +1 -1
  188. package/lib/chain/validation/proposerPreferences.d.ts +8 -0
  189. package/lib/chain/validation/proposerPreferences.d.ts.map +1 -0
  190. package/lib/chain/validation/proposerPreferences.js +91 -0
  191. package/lib/chain/validation/proposerPreferences.js.map +1 -0
  192. package/lib/db/repositories/executionPayloadEnvelopeArchive.js +1 -1
  193. package/lib/db/repositories/executionPayloadEnvelopeArchive.js.map +1 -1
  194. package/lib/execution/engine/http.d.ts.map +1 -1
  195. package/lib/execution/engine/http.js +21 -14
  196. package/lib/execution/engine/http.js.map +1 -1
  197. package/lib/execution/engine/interface.d.ts +1 -0
  198. package/lib/execution/engine/interface.d.ts.map +1 -1
  199. package/lib/execution/engine/mock.d.ts.map +1 -1
  200. package/lib/execution/engine/mock.js +6 -0
  201. package/lib/execution/engine/mock.js.map +1 -1
  202. package/lib/execution/engine/types.d.ts +20 -0
  203. package/lib/execution/engine/types.d.ts.map +1 -1
  204. package/lib/execution/engine/types.js +18 -0
  205. package/lib/execution/engine/types.js.map +1 -1
  206. package/lib/metrics/metrics/lodestar.d.ts +1 -0
  207. package/lib/metrics/metrics/lodestar.d.ts.map +1 -1
  208. package/lib/metrics/metrics/lodestar.js +4 -0
  209. package/lib/metrics/metrics/lodestar.js.map +1 -1
  210. package/lib/network/gossip/interface.d.ts +7 -1
  211. package/lib/network/gossip/interface.d.ts.map +1 -1
  212. package/lib/network/gossip/interface.js +1 -0
  213. package/lib/network/gossip/interface.js.map +1 -1
  214. package/lib/network/gossip/scoringParameters.d.ts.map +1 -1
  215. package/lib/network/gossip/scoringParameters.js +12 -1
  216. package/lib/network/gossip/scoringParameters.js.map +1 -1
  217. package/lib/network/gossip/topic.d.ts +13 -2
  218. package/lib/network/gossip/topic.d.ts.map +1 -1
  219. package/lib/network/gossip/topic.js +6 -0
  220. package/lib/network/gossip/topic.js.map +1 -1
  221. package/lib/network/interface.d.ts +1 -0
  222. package/lib/network/interface.d.ts.map +1 -1
  223. package/lib/network/network.d.ts +1 -0
  224. package/lib/network/network.d.ts.map +1 -1
  225. package/lib/network/network.js +6 -1
  226. package/lib/network/network.js.map +1 -1
  227. package/lib/network/processor/gossipHandlers.d.ts.map +1 -1
  228. package/lib/network/processor/gossipHandlers.js +60 -22
  229. package/lib/network/processor/gossipHandlers.js.map +1 -1
  230. package/lib/network/processor/gossipQueues/index.d.ts.map +1 -1
  231. package/lib/network/processor/gossipQueues/index.js +5 -0
  232. package/lib/network/processor/gossipQueues/index.js.map +1 -1
  233. package/lib/network/processor/index.d.ts.map +1 -1
  234. package/lib/network/processor/index.js +6 -5
  235. package/lib/network/processor/index.js.map +1 -1
  236. package/lib/network/reqresp/handlers/beaconBlocksByRange.d.ts.map +1 -1
  237. package/lib/network/reqresp/handlers/beaconBlocksByRange.js +14 -6
  238. package/lib/network/reqresp/handlers/beaconBlocksByRange.js.map +1 -1
  239. package/lib/network/reqresp/handlers/blobSidecarsByRange.d.ts.map +1 -1
  240. package/lib/network/reqresp/handlers/blobSidecarsByRange.js +11 -5
  241. package/lib/network/reqresp/handlers/blobSidecarsByRange.js.map +1 -1
  242. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts.map +1 -1
  243. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js +17 -5
  244. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js.map +1 -1
  245. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRange.d.ts.map +1 -1
  246. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRange.js +7 -4
  247. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRange.js.map +1 -1
  248. package/lib/node/nodejs.d.ts.map +1 -1
  249. package/lib/node/nodejs.js +6 -4
  250. package/lib/node/nodejs.js.map +1 -1
  251. package/lib/sync/constants.d.ts +3 -1
  252. package/lib/sync/constants.d.ts.map +1 -1
  253. package/lib/sync/constants.js +3 -4
  254. package/lib/sync/constants.js.map +1 -1
  255. package/lib/sync/range/batch.d.ts +28 -2
  256. package/lib/sync/range/batch.d.ts.map +1 -1
  257. package/lib/sync/range/batch.js +146 -44
  258. package/lib/sync/range/batch.js.map +1 -1
  259. package/lib/sync/range/chain.d.ts +12 -2
  260. package/lib/sync/range/chain.d.ts.map +1 -1
  261. package/lib/sync/range/chain.js +53 -9
  262. package/lib/sync/range/chain.js.map +1 -1
  263. package/lib/sync/range/range.d.ts.map +1 -1
  264. package/lib/sync/range/range.js +17 -6
  265. package/lib/sync/range/range.js.map +1 -1
  266. package/lib/sync/types.d.ts +34 -0
  267. package/lib/sync/types.d.ts.map +1 -1
  268. package/lib/sync/types.js +34 -0
  269. package/lib/sync/types.js.map +1 -1
  270. package/lib/sync/unknownBlock.d.ts +22 -1
  271. package/lib/sync/unknownBlock.d.ts.map +1 -1
  272. package/lib/sync/unknownBlock.js +604 -53
  273. package/lib/sync/unknownBlock.js.map +1 -1
  274. package/lib/sync/utils/downloadByRange.d.ts +46 -10
  275. package/lib/sync/utils/downloadByRange.d.ts.map +1 -1
  276. package/lib/sync/utils/downloadByRange.js +162 -24
  277. package/lib/sync/utils/downloadByRange.js.map +1 -1
  278. package/lib/sync/utils/downloadByRoot.d.ts.map +1 -1
  279. package/lib/sync/utils/downloadByRoot.js +16 -2
  280. package/lib/sync/utils/downloadByRoot.js.map +1 -1
  281. package/lib/sync/utils/pendingBlocksTree.d.ts +0 -1
  282. package/lib/sync/utils/pendingBlocksTree.d.ts.map +1 -1
  283. package/lib/sync/utils/pendingBlocksTree.js +0 -9
  284. package/lib/sync/utils/pendingBlocksTree.js.map +1 -1
  285. package/lib/util/sszBytes.d.ts.map +1 -1
  286. package/lib/util/sszBytes.js +20 -5
  287. package/lib/util/sszBytes.js.map +1 -1
  288. package/package.json +17 -16
  289. package/src/api/impl/beacon/blocks/index.ts +22 -9
  290. package/src/api/impl/beacon/pool/index.ts +83 -1
  291. package/src/api/impl/beacon/state/utils.ts +2 -2
  292. package/src/api/impl/debug/index.ts +0 -1
  293. package/src/api/impl/lodestar/index.ts +1 -1
  294. package/src/api/impl/validator/index.ts +84 -6
  295. package/src/chain/GetBlobsTracker.ts +1 -2
  296. package/src/chain/archiveStore/archiveStore.ts +5 -5
  297. package/src/chain/archiveStore/interface.ts +4 -4
  298. package/src/chain/archiveStore/strategies/frequencyStateArchiveStrategy.ts +6 -8
  299. package/src/chain/archiveStore/utils/archiveBlocks.ts +153 -94
  300. package/src/chain/blocks/blockInput/blockInput.ts +4 -1
  301. package/src/chain/blocks/importBlock.ts +34 -79
  302. package/src/chain/blocks/importExecutionPayload.ts +110 -102
  303. package/src/chain/blocks/index.ts +74 -24
  304. package/src/chain/blocks/payloadEnvelopeInput/payloadEnvelopeInput.ts +37 -2
  305. package/src/chain/blocks/payloadEnvelopeInput/types.ts +1 -0
  306. package/src/chain/blocks/payloadEnvelopeProcessor.ts +7 -6
  307. package/src/chain/blocks/types.ts +16 -26
  308. package/src/chain/blocks/utils/chainSegment.ts +114 -17
  309. package/src/chain/blocks/verifyBlock.ts +70 -9
  310. package/src/chain/blocks/verifyBlocksExecutionPayloads.ts +6 -4
  311. package/src/chain/blocks/verifyBlocksSanityChecks.ts +26 -7
  312. package/src/chain/blocks/verifyExecutionPayloadEnvelope.ts +134 -0
  313. package/src/chain/blocks/verifyPayloadsDataAvailability.ts +41 -0
  314. package/src/chain/blocks/writePayloadEnvelopeInputToDb.ts +9 -18
  315. package/src/chain/chain.ts +61 -58
  316. package/src/chain/emitter.ts +15 -14
  317. package/src/chain/errors/blockError.ts +4 -1
  318. package/src/chain/errors/executionPayloadBid.ts +6 -0
  319. package/src/chain/errors/executionPayloadEnvelope.ts +6 -0
  320. package/src/chain/errors/index.ts +1 -0
  321. package/src/chain/errors/proposerPreferences.ts +47 -0
  322. package/src/chain/forkChoice/index.ts +8 -24
  323. package/src/chain/initState.ts +9 -1
  324. package/src/chain/interface.ts +11 -3
  325. package/src/chain/opPools/payloadAttestationPool.ts +29 -8
  326. package/src/chain/prepareNextSlot.ts +55 -24
  327. package/src/chain/produceBlock/computeNewStateRoot.ts +6 -43
  328. package/src/chain/produceBlock/produceBlockBody.ts +91 -27
  329. package/src/chain/regen/errors.ts +1 -6
  330. package/src/chain/regen/interface.ts +7 -11
  331. package/src/chain/regen/queued.ts +8 -21
  332. package/src/chain/regen/regen.ts +2 -15
  333. package/src/chain/seenCache/index.ts +1 -0
  334. package/src/chain/seenCache/seenPayloadEnvelopeInput.ts +71 -20
  335. package/src/chain/seenCache/seenProposerPreferences.ts +32 -0
  336. package/src/chain/stateCache/persistentCheckpointsCache.ts +5 -15
  337. package/src/chain/stateCache/types.ts +0 -3
  338. package/src/chain/validation/block.ts +1 -0
  339. package/src/chain/validation/executionPayloadBid.ts +25 -8
  340. package/src/chain/validation/executionPayloadEnvelope.ts +21 -11
  341. package/src/chain/validation/payloadAttestationMessage.ts +5 -3
  342. package/src/chain/validation/proposerPreferences.ts +110 -0
  343. package/src/db/repositories/executionPayloadEnvelopeArchive.ts +1 -1
  344. package/src/execution/engine/http.ts +21 -14
  345. package/src/execution/engine/interface.ts +1 -0
  346. package/src/execution/engine/mock.ts +8 -1
  347. package/src/execution/engine/types.ts +41 -0
  348. package/src/metrics/metrics/lodestar.ts +4 -0
  349. package/src/network/gossip/interface.ts +6 -0
  350. package/src/network/gossip/scoringParameters.ts +14 -1
  351. package/src/network/gossip/topic.ts +6 -0
  352. package/src/network/interface.ts +1 -0
  353. package/src/network/network.ts +12 -1
  354. package/src/network/processor/gossipHandlers.ts +79 -27
  355. package/src/network/processor/gossipQueues/index.ts +5 -0
  356. package/src/network/processor/index.ts +6 -5
  357. package/src/network/reqresp/handlers/beaconBlocksByRange.ts +14 -6
  358. package/src/network/reqresp/handlers/blobSidecarsByRange.ts +11 -5
  359. package/src/network/reqresp/handlers/dataColumnSidecarsByRange.ts +17 -5
  360. package/src/network/reqresp/handlers/executionPayloadEnvelopesByRange.ts +7 -4
  361. package/src/node/nodejs.ts +6 -4
  362. package/src/sync/constants.ts +4 -4
  363. package/src/sync/range/batch.ts +204 -49
  364. package/src/sync/range/chain.ts +69 -11
  365. package/src/sync/range/range.ts +18 -6
  366. package/src/sync/types.ts +72 -0
  367. package/src/sync/unknownBlock.ts +762 -57
  368. package/src/sync/utils/downloadByRange.ts +272 -39
  369. package/src/sync/utils/downloadByRoot.ts +24 -2
  370. package/src/sync/utils/pendingBlocksTree.ts +0 -15
  371. package/src/util/sszBytes.ts +25 -5
@@ -1,9 +1,11 @@
1
1
  import {ChainForkConfig} from "@lodestar/config";
2
+ import {RequestErrorCode} from "@lodestar/reqresp";
2
3
  import {Epoch, Root, Slot} from "@lodestar/types";
3
- import {ErrorAborted, LodestarError, Logger, toRootHex} from "@lodestar/utils";
4
+ import {ErrorAborted, LodestarError, Logger, prettyPrintIndices, toRootHex} from "@lodestar/utils";
4
5
  import {isBlockInputBlobs, isBlockInputColumns} from "../../chain/blocks/blockInput/blockInput.js";
5
6
  import {BlockInputErrorCode} from "../../chain/blocks/blockInput/errors.js";
6
7
  import {IBlockInput} from "../../chain/blocks/blockInput/types.js";
8
+ import {PayloadEnvelopeInput} from "../../chain/blocks/payloadEnvelopeInput/payloadEnvelopeInput.js";
7
9
  import {BlobSidecarErrorCode} from "../../chain/errors/blobSidecarError.js";
8
10
  import {DataColumnSidecarErrorCode} from "../../chain/errors/dataColumnSidecarError.js";
9
11
  import {Metrics} from "../../metrics/metrics.js";
@@ -14,7 +16,12 @@ import {CustodyConfig} from "../../util/dataColumns.js";
14
16
  import {ItTrigger} from "../../util/itTrigger.js";
15
17
  import {PeerIdStr} from "../../util/peerId.js";
16
18
  import {WarnResult, wrapError} from "../../util/wrapError.js";
17
- import {BATCH_BUFFER_SIZE, EPOCHS_PER_BATCH, MAX_LOOK_AHEAD_EPOCHS} from "../constants.js";
19
+ import {
20
+ BATCH_BUFFER_SIZE,
21
+ EPOCHS_PER_BATCH,
22
+ MAX_LOOK_AHEAD_EPOCHS,
23
+ RATE_LIMITED_PEER_BACKOFF_MS,
24
+ } from "../constants.js";
18
25
  import {DownloadByRangeError, DownloadByRangeErrorCode} from "../utils/downloadByRange.js";
19
26
  import {RangeSyncType} from "../utils/remoteSyncType.js";
20
27
  import {Batch, BatchError, BatchErrorCode, BatchMetadata, BatchStatus} from "./batch.js";
@@ -44,13 +51,19 @@ export type SyncChainFns = {
44
51
  * Must return if ALL blocks are processed successfully
45
52
  * If SOME blocks are processed must throw BlockProcessorError()
46
53
  */
47
- processChainSegment: (blocks: IBlockInput[], syncType: RangeSyncType) => Promise<void>;
54
+ processChainSegment: (
55
+ blocks: IBlockInput[],
56
+ payloadEnvelopes: Map<Slot, PayloadEnvelopeInput> | null,
57
+ syncType: RangeSyncType
58
+ ) => Promise<void>;
48
59
  /** Must download blocks, and validate their range */
49
60
  downloadByRange: (
50
61
  peer: PeerSyncMeta,
51
62
  batch: Batch,
52
63
  syncType: RangeSyncType
53
- ) => Promise<WarnResult<IBlockInput[], DownloadByRangeError>>;
64
+ ) => Promise<
65
+ WarnResult<{blocks: IBlockInput[]; payloadEnvelopes: Map<Slot, PayloadEnvelopeInput> | null}, DownloadByRangeError>
66
+ >;
54
67
  /** Report peer for negative actions. Decouples from the full network instance */
55
68
  reportPeer: (peer: PeerIdStr, action: PeerAction, actionName: string) => void;
56
69
  /** Gets current peer custodyColumns and earliestAvailableSlot */
@@ -133,6 +146,12 @@ export class SyncChain {
133
146
  /** Sorted map of batches undergoing some kind of processing. */
134
147
  private readonly batches = new Map<Epoch, Batch>();
135
148
  private readonly peerset = new Map<PeerIdStr, ChainTarget>();
149
+ /**
150
+ * Tracks peers that have rate-limited us, mapped to the timestamp (ms) until which we should avoid them.
151
+ * This is a sync-layer optimization to avoid assigning batches to backed-off peers.
152
+ * The reqresp SelfRateLimiter independently enforces backoff at the protocol level as a safety net.
153
+ */
154
+ private readonly rateLimitedPeers = new Map<PeerIdStr, number>();
136
155
 
137
156
  private readonly logger: Logger;
138
157
  private readonly config: ChainForkConfig;
@@ -215,12 +234,14 @@ export class SyncChain {
215
234
  */
216
235
  stopSyncing(): void {
217
236
  this.status = SyncChainStatus.Stopped;
237
+ this.logger.debug("SyncChain stopSyncing", {id: this.logId});
218
238
  }
219
239
 
220
240
  /**
221
241
  * Permanently remove this chain. Throws the main AsyncIterable
222
242
  */
223
243
  remove(): void {
244
+ this.logger.debug("SyncChain remove", {id: this.logId});
224
245
  this.batchProcessor.end(new ErrorAborted("SyncChain"));
225
246
  }
226
247
 
@@ -239,6 +260,7 @@ export class SyncChain {
239
260
  */
240
261
  removePeer(peerId: PeerIdStr): boolean {
241
262
  const deleted = this.peerset.delete(peerId);
263
+ this.rateLimitedPeers.delete(peerId);
242
264
  this.computeTarget();
243
265
  return deleted;
244
266
  }
@@ -374,8 +396,18 @@ export class SyncChain {
374
396
  return;
375
397
  }
376
398
 
399
+ const now = Date.now();
377
400
  const peersSyncInfo: PeerSyncInfo[] = [];
378
401
  for (const [peerId, target] of this.peerset.entries()) {
402
+ // Skip peers that are currently in rate-limit backoff
403
+ const rateLimitedUntil = this.rateLimitedPeers.get(peerId);
404
+ if (rateLimitedUntil !== undefined) {
405
+ if (now < rateLimitedUntil) {
406
+ continue;
407
+ }
408
+ this.rateLimitedPeers.delete(peerId);
409
+ }
410
+
379
411
  try {
380
412
  peersSyncInfo.push({...this.getConnectedPeerSyncMeta(peerId), target});
381
413
  } catch (e) {
@@ -507,7 +539,14 @@ export class SyncChain {
507
539
  {id: this.logId, ...batch.getMetadata(), peer: prettyPrintPeerIdStr(peer.peerId)},
508
540
  res.err
509
541
  );
510
- batch.downloadingError(peer.peerId); // Throws after MAX_DOWNLOAD_ATTEMPTS
542
+ if (errCode === RequestErrorCode.RESP_RATE_LIMITED || errCode === RequestErrorCode.REQUEST_SELF_RATE_LIMITED) {
543
+ // Peer rate-limited us — don't count as a failed download attempt and mark peer for backoff
544
+ this.rateLimitedPeers.set(peer.peerId, Date.now() + RATE_LIMITED_PEER_BACKOFF_MS);
545
+ batch.downloadingRateLimited();
546
+ this.triggerBatchDownloader();
547
+ } else {
548
+ batch.downloadingError(peer.peerId); // Throws after MAX_DOWNLOAD_ATTEMPTS
549
+ }
511
550
  } else {
512
551
  this.logger.verbose("Batch download success", {
513
552
  id: this.logId,
@@ -516,7 +555,8 @@ export class SyncChain {
516
555
  });
517
556
  this.metrics?.syncRange.downloadByRange.success.inc();
518
557
  const {warnings, result} = res.result;
519
- const downloadSuccessOutput = batch.downloadingSuccess(peer.peerId, result);
558
+ const {blocks: downloadedBlocks, payloadEnvelopes} = result;
559
+ const downloadSuccessOutput = batch.downloadingSuccess(peer.peerId, downloadedBlocks, payloadEnvelopes);
520
560
  const logMeta: Record<string, number> = {
521
561
  blockCount: downloadSuccessOutput.blocks.length,
522
562
  };
@@ -526,7 +566,7 @@ export class SyncChain {
526
566
  this.metrics?.syncRange.downloadByRange.warn.inc({client: peer.client, code: warning.type.code});
527
567
  this.logger.debug(
528
568
  "Batch downloaded with warning",
529
- {id: this.logId, epoch: batch.startEpoch, ...logMeta, peer: prettyPrintPeerIdStr(peer.peerId)},
569
+ {id: this.logId, ...batch.getMetadata(), ...logMeta, peer: prettyPrintPeerIdStr(peer.peerId)},
530
570
  warning
531
571
  );
532
572
  }
@@ -552,10 +592,17 @@ export class SyncChain {
552
592
  // the flow will continue to call triggerBatchDownloader() below
553
593
  }
554
594
 
595
+ const blockSlots = downloadSuccessOutput.blocks.map((b) => b.slot);
596
+ const envelopeSlots = downloadSuccessOutput.payloadEnvelopes
597
+ ? Array.from(downloadSuccessOutput.payloadEnvelopes.keys())
598
+ : null;
599
+
555
600
  this.logger.debug(logMessage, {
556
601
  id: this.logId,
557
- epoch: batch.startEpoch,
602
+ ...batch.getMetadata(),
558
603
  ...logMeta,
604
+ blockSlots: prettyPrintIndices(blockSlots),
605
+ ...(envelopeSlots ? {envelopeSlots: prettyPrintIndices(envelopeSlots)} : {}),
559
606
  peer: prettyPrintPeerIdStr(peer.peerId),
560
607
  });
561
608
  }
@@ -578,13 +625,24 @@ export class SyncChain {
578
625
  * Sends `batch` to the processor. Note: batch may be empty
579
626
  */
580
627
  private async processBatch(batch: Batch): Promise<void> {
581
- const blocks = batch.startProcessing();
628
+ const {blocks, payloadEnvelopes, peers} = batch.startProcessing();
629
+
630
+ const logCtx = {
631
+ id: this.logId,
632
+ ...batch.getMetadata(),
633
+ blockCount: blocks.length,
634
+ blockSlots: prettyPrintIndices(blocks.map((b) => b.slot)),
635
+ ...(payloadEnvelopes ? {envelopeSlots: prettyPrintIndices(Array.from(payloadEnvelopes.keys()))} : {}),
636
+ peers: peers.map(prettyPrintPeerIdStr).join(","),
637
+ };
638
+ this.logger.verbose("Processing batch", logCtx);
582
639
 
583
640
  // wrapError ensures to never call both batch success() and batch error()
584
- const res = await wrapError(this.processChainSegment(blocks, this.syncType));
641
+ const res = await wrapError(this.processChainSegment(blocks, payloadEnvelopes, this.syncType));
585
642
 
586
643
  if (!res.err) {
587
644
  batch.processingSuccess();
645
+ this.logger.verbose("Processed batch", {...logCtx, ...batch.getMetadata()});
588
646
 
589
647
  // If the processed batch is not empty, validate previous AwaitingValidation blocks.
590
648
  if (blocks.length > 0) {
@@ -594,7 +652,7 @@ export class SyncChain {
594
652
  // Potentially process next AwaitingProcessing batch
595
653
  this.triggerBatchProcessor();
596
654
  } else {
597
- this.logger.verbose("Batch process error", {id: this.logId, ...batch.getMetadata()}, res.err);
655
+ this.logger.verbose("Batch process error", logCtx, res.err);
598
656
  batch.processingError(res.err); // Throws after MAX_BATCH_PROCESSING_ATTEMPTS
599
657
 
600
658
  // At least one block was successfully verified and imported, so we can be sure all
@@ -172,7 +172,7 @@ export class RangeSync extends (EventEmitter as {new (): RangeSyncEmitter}) {
172
172
  }
173
173
 
174
174
  /** Convenience method for `SyncChain` */
175
- private processChainSegment: SyncChainFns["processChainSegment"] = async (blocks, syncType) => {
175
+ private processChainSegment: SyncChainFns["processChainSegment"] = async (blocks, payloadEnvelopes, syncType) => {
176
176
  // Not trusted, verify signatures
177
177
  const flags: ImportBlockOpts = {
178
178
  // Only skip importing attestations for finalized sync. For head sync attestation are valuable.
@@ -192,9 +192,15 @@ export class RangeSync extends (EventEmitter as {new (): RangeSyncEmitter}) {
192
192
 
193
193
  if (this.opts?.disableProcessAsChainSegment) {
194
194
  // Should only be used for debugging or testing
195
- for (const block of blocks) await this.chain.processBlock(block, flags);
195
+ for (const block of blocks) {
196
+ await this.chain.processBlock(block, flags);
197
+ const payloadEnvelope = payloadEnvelopes?.get(block.slot);
198
+ if (payloadEnvelope) {
199
+ await this.chain.processExecutionPayload(payloadEnvelope);
200
+ }
201
+ }
196
202
  } else {
197
- await this.chain.processChainSegment(blocks, flags);
203
+ await this.chain.processChainSegment(blocks, payloadEnvelopes, flags);
198
204
  }
199
205
  };
200
206
 
@@ -209,13 +215,19 @@ export class RangeSync extends (EventEmitter as {new (): RangeSyncEmitter}) {
209
215
  peerDasMetrics: this.chain.metrics?.peerDas,
210
216
  ...batch.getRequestsForPeer(peer),
211
217
  });
212
- const cached = cacheByRangeResponses({
218
+ const {responses, payloadEnvelopes: downloadedPayloadEnvelopes} = result;
219
+ const {blocks, payloadEnvelopes} = cacheByRangeResponses({
213
220
  cache: this.chain.seenBlockInputCache,
221
+ seenPayloadEnvelopeInputCache: this.chain.seenPayloadEnvelopeInputCache,
214
222
  peerIdStr: peer.peerId,
215
- responses: result,
223
+ responses,
216
224
  batchBlocks,
225
+ downloadedPayloadEnvelopes,
226
+ existingPayloadEnvelopes: batch.getPayloadEnvelopes(),
227
+ custodyConfig: this.chain.custodyConfig,
228
+ seenTimestampSec: Date.now() / 1000,
217
229
  });
218
- return {result: cached, warnings};
230
+ return {result: {blocks, payloadEnvelopes}, warnings};
219
231
  };
220
232
 
221
233
  private pruneBlockInputs: SyncChainFns["pruneBlockInputs"] = (blocks: IBlockInput[]) => {
package/src/sync/types.ts CHANGED
@@ -1,5 +1,8 @@
1
1
  import {RootHex, Slot} from "@lodestar/types";
2
+ import {SignedExecutionPayloadEnvelope} from "@lodestar/types/gloas";
3
+ import {toRootHex} from "@lodestar/utils";
2
4
  import {IBlockInput} from "../chain/blocks/blockInput/index.js";
5
+ import {PayloadEnvelopeInput} from "../chain/blocks/payloadEnvelopeInput/payloadEnvelopeInput.js";
3
6
 
4
7
  export enum PendingBlockType {
5
8
  /**
@@ -26,6 +29,14 @@ export enum PendingBlockInputStatus {
26
29
  processing = "processing",
27
30
  }
28
31
 
32
+ export enum PendingPayloadInputStatus {
33
+ pending = "pending",
34
+ fetching = "fetching",
35
+ waitingForBlock = "waiting_for_block",
36
+ downloaded = "downloaded",
37
+ processing = "processing",
38
+ }
39
+
29
40
  export type PendingBlockInput = {
30
41
  status: PendingBlockInputStatus;
31
42
  blockInput: IBlockInput;
@@ -44,10 +55,47 @@ export type PendingRootHex = {
44
55
 
45
56
  export type BlockInputSyncCacheItem = PendingBlockInput | PendingRootHex;
46
57
 
58
+ export type PendingPayloadInput = {
59
+ status:
60
+ | PendingPayloadInputStatus.pending
61
+ | PendingPayloadInputStatus.fetching
62
+ | PendingPayloadInputStatus.downloaded
63
+ | PendingPayloadInputStatus.processing;
64
+ payloadInput: PayloadEnvelopeInput;
65
+ timeAddedSec: number;
66
+ timeSyncedSec?: number;
67
+ peerIdStrings: Set<string>;
68
+ };
69
+
70
+ export type PendingPayloadRootHex = {
71
+ status: PendingPayloadInputStatus.pending | PendingPayloadInputStatus.fetching;
72
+ rootHex: RootHex;
73
+ timeAddedSec: number;
74
+ timeSyncedSec?: number;
75
+ peerIdStrings: Set<string>;
76
+ };
77
+
78
+ export type PendingPayloadEnvelope = {
79
+ status: PendingPayloadInputStatus.waitingForBlock;
80
+ envelope: SignedExecutionPayloadEnvelope;
81
+ timeAddedSec: number;
82
+ peerIdStrings: Set<string>;
83
+ };
84
+
85
+ export type PayloadSyncCacheItem = PendingPayloadInput | PendingPayloadRootHex | PendingPayloadEnvelope;
86
+
47
87
  export function isPendingBlockInput(pending: BlockInputSyncCacheItem): pending is PendingBlockInput {
48
88
  return "blockInput" in pending;
49
89
  }
50
90
 
91
+ export function isPendingPayloadInput(pending: PayloadSyncCacheItem): pending is PendingPayloadInput {
92
+ return "payloadInput" in pending;
93
+ }
94
+
95
+ export function isPendingPayloadEnvelope(pending: PayloadSyncCacheItem): pending is PendingPayloadEnvelope {
96
+ return "envelope" in pending;
97
+ }
98
+
51
99
  export function getBlockInputSyncCacheItemRootHex(block: BlockInputSyncCacheItem): RootHex {
52
100
  return isPendingBlockInput(block) ? block.blockInput.blockRootHex : block.rootHex;
53
101
  }
@@ -55,3 +103,27 @@ export function getBlockInputSyncCacheItemRootHex(block: BlockInputSyncCacheItem
55
103
  export function getBlockInputSyncCacheItemSlot(block: BlockInputSyncCacheItem): Slot | string {
56
104
  return isPendingBlockInput(block) ? block.blockInput.slot : "unknown";
57
105
  }
106
+
107
+ export function getPayloadSyncCacheItemRootHex(payload: PayloadSyncCacheItem): RootHex {
108
+ if (isPendingPayloadInput(payload)) {
109
+ return payload.payloadInput.blockRootHex;
110
+ }
111
+
112
+ if (isPendingPayloadEnvelope(payload)) {
113
+ return toRootHex(payload.envelope.message.beaconBlockRoot);
114
+ }
115
+
116
+ return payload.rootHex;
117
+ }
118
+
119
+ export function getPayloadSyncCacheItemSlot(payload: PayloadSyncCacheItem): Slot | string {
120
+ if (isPendingPayloadInput(payload)) {
121
+ return payload.payloadInput.slot;
122
+ }
123
+
124
+ if (isPendingPayloadEnvelope(payload)) {
125
+ return payload.envelope.message.payload.slotNumber;
126
+ }
127
+
128
+ return "unknown";
129
+ }