@lodestar/beacon-node 1.33.0 → 1.34.0-dev.083b7cce17

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 (305) hide show
  1. package/lib/api/impl/beacon/blocks/index.js +175 -56
  2. package/lib/api/impl/beacon/blocks/index.js.map +1 -1
  3. package/lib/api/impl/beacon/pool/index.js +5 -5
  4. package/lib/api/impl/beacon/pool/index.js.map +1 -1
  5. package/lib/api/impl/beacon/state/index.js +24 -17
  6. package/lib/api/impl/beacon/state/index.js.map +1 -1
  7. package/lib/api/impl/debug/index.d.ts +1 -1
  8. package/lib/api/impl/debug/index.js +24 -1
  9. package/lib/api/impl/debug/index.js.map +1 -1
  10. package/lib/api/impl/events/index.js +1 -1
  11. package/lib/api/impl/events/index.js.map +1 -1
  12. package/lib/api/impl/validator/index.js +72 -49
  13. package/lib/api/impl/validator/index.js.map +1 -1
  14. package/lib/api/impl/validator/utils.d.ts +3 -3
  15. package/lib/api/impl/validator/utils.js +2 -2
  16. package/lib/api/impl/validator/utils.js.map +1 -1
  17. package/lib/chain/archiveStore/archiveStore.d.ts +1 -1
  18. package/lib/chain/archiveStore/archiveStore.js +2 -2
  19. package/lib/chain/archiveStore/interface.d.ts +1 -1
  20. package/lib/chain/archiveStore/utils/archiveBlocks.d.ts +1 -1
  21. package/lib/chain/archiveStore/utils/archiveBlocks.js +91 -21
  22. package/lib/chain/archiveStore/utils/archiveBlocks.js.map +1 -1
  23. package/lib/chain/beaconProposerCache.d.ts +1 -0
  24. package/lib/chain/beaconProposerCache.js +3 -0
  25. package/lib/chain/beaconProposerCache.js.map +1 -1
  26. package/lib/chain/blocks/importBlock.js +3 -2
  27. package/lib/chain/blocks/importBlock.js.map +1 -1
  28. package/lib/chain/blocks/types.d.ts +66 -23
  29. package/lib/chain/blocks/types.js +39 -5
  30. package/lib/chain/blocks/types.js.map +1 -1
  31. package/lib/chain/blocks/utils/blowfishBanner.js +1 -0
  32. package/lib/chain/blocks/utils/blowfishBanner.js.map +1 -1
  33. package/lib/chain/blocks/utils/giraffeBanner.js +1 -0
  34. package/lib/chain/blocks/utils/giraffeBanner.js.map +1 -1
  35. package/lib/chain/blocks/utils/zebraBanner.d.ts +2 -0
  36. package/lib/chain/blocks/utils/zebraBanner.js +46 -0
  37. package/lib/chain/blocks/utils/zebraBanner.js.map +1 -0
  38. package/lib/chain/blocks/verifyBlock.js +18 -5
  39. package/lib/chain/blocks/verifyBlock.js.map +1 -1
  40. package/lib/chain/blocks/verifyBlocksDataAvailability.js +21 -10
  41. package/lib/chain/blocks/verifyBlocksDataAvailability.js.map +1 -1
  42. package/lib/chain/blocks/writeBlockInputToDb.js +63 -16
  43. package/lib/chain/blocks/writeBlockInputToDb.js.map +1 -1
  44. package/lib/chain/bls/multithread/index.js +2 -2
  45. package/lib/chain/bls/multithread/index.js.map +1 -1
  46. package/lib/chain/chain.d.ts +18 -101
  47. package/lib/chain/chain.js +111 -78
  48. package/lib/chain/chain.js.map +1 -1
  49. package/lib/chain/emitter.d.ts +18 -2
  50. package/lib/chain/emitter.js +13 -0
  51. package/lib/chain/emitter.js.map +1 -1
  52. package/lib/chain/errors/dataColumnSidecarError.d.ts +69 -0
  53. package/lib/chain/errors/dataColumnSidecarError.js +21 -0
  54. package/lib/chain/errors/dataColumnSidecarError.js.map +1 -0
  55. package/lib/chain/errors/index.d.ts +1 -0
  56. package/lib/chain/errors/index.js +1 -0
  57. package/lib/chain/errors/index.js.map +1 -1
  58. package/lib/chain/forkChoice/index.d.ts +2 -1
  59. package/lib/chain/forkChoice/index.js +2 -2
  60. package/lib/chain/forkChoice/index.js.map +1 -1
  61. package/lib/chain/interface.d.ts +6 -7
  62. package/lib/chain/interface.js.map +1 -1
  63. package/lib/chain/opPools/aggregatedAttestationPool.js +13 -3
  64. package/lib/chain/opPools/aggregatedAttestationPool.js.map +1 -1
  65. package/lib/chain/opPools/attestationPool.d.ts +1 -1
  66. package/lib/chain/opPools/attestationPool.js +7 -7
  67. package/lib/chain/options.d.ts +4 -1
  68. package/lib/chain/options.js +1 -0
  69. package/lib/chain/options.js.map +1 -1
  70. package/lib/chain/prepareNextSlot.js +4 -2
  71. package/lib/chain/prepareNextSlot.js.map +1 -1
  72. package/lib/chain/produceBlock/produceBlockBody.d.ts +30 -16
  73. package/lib/chain/produceBlock/produceBlockBody.js +28 -28
  74. package/lib/chain/produceBlock/produceBlockBody.js.map +1 -1
  75. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.d.ts +6 -3
  76. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.js +28 -4
  77. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.js.map +1 -1
  78. package/lib/chain/rewards/syncCommitteeRewards.js +4 -4
  79. package/lib/chain/rewards/syncCommitteeRewards.js.map +1 -1
  80. package/lib/chain/seenCache/seenGossipBlockInput.d.ts +64 -18
  81. package/lib/chain/seenCache/seenGossipBlockInput.js +321 -53
  82. package/lib/chain/seenCache/seenGossipBlockInput.js.map +1 -1
  83. package/lib/chain/validation/aggregateAndProof.d.ts +1 -1
  84. package/lib/chain/validation/aggregateAndProof.js +8 -8
  85. package/lib/chain/validation/aggregateAndProof.js.map +1 -1
  86. package/lib/chain/validation/attestation.d.ts +3 -3
  87. package/lib/chain/validation/attestation.js +10 -10
  88. package/lib/chain/validation/attestation.js.map +1 -1
  89. package/lib/chain/validation/dataColumnSidecar.d.ts +29 -0
  90. package/lib/chain/validation/dataColumnSidecar.js +257 -0
  91. package/lib/chain/validation/dataColumnSidecar.js.map +1 -0
  92. package/lib/chain/validation/syncCommitteeContributionAndProof.js +2 -2
  93. package/lib/chain/validation/syncCommitteeContributionAndProof.js.map +1 -1
  94. package/lib/db/beacon.d.ts +3 -1
  95. package/lib/db/beacon.js +3 -1
  96. package/lib/db/beacon.js.map +1 -1
  97. package/lib/db/buckets.d.ts +3 -1
  98. package/lib/db/buckets.js +2 -0
  99. package/lib/db/buckets.js.map +1 -1
  100. package/lib/db/interface.d.ts +3 -1
  101. package/lib/db/repositories/dataColumnSidecar.d.ts +26 -0
  102. package/lib/db/repositories/dataColumnSidecar.js +39 -0
  103. package/lib/db/repositories/dataColumnSidecar.js.map +1 -0
  104. package/lib/db/repositories/dataColumnSidecarArchive.d.ts +24 -0
  105. package/lib/db/repositories/dataColumnSidecarArchive.js +39 -0
  106. package/lib/db/repositories/dataColumnSidecarArchive.js.map +1 -0
  107. package/lib/db/repositories/index.d.ts +2 -0
  108. package/lib/db/repositories/index.js +2 -0
  109. package/lib/db/repositories/index.js.map +1 -1
  110. package/lib/db/repositories/stateArchive.js +1 -1
  111. package/lib/db/repositories/stateArchive.js.map +1 -1
  112. package/lib/execution/builder/http.d.ts +20 -4
  113. package/lib/execution/builder/http.js +30 -11
  114. package/lib/execution/builder/http.js.map +1 -1
  115. package/lib/execution/builder/interface.d.ts +5 -4
  116. package/lib/execution/engine/http.d.ts +8 -5
  117. package/lib/execution/engine/http.js +65 -46
  118. package/lib/execution/engine/http.js.map +1 -1
  119. package/lib/execution/engine/interface.d.ts +6 -13
  120. package/lib/execution/engine/interface.js +1 -1
  121. package/lib/execution/engine/interface.js.map +1 -1
  122. package/lib/execution/engine/mock.d.ts +5 -1
  123. package/lib/execution/engine/mock.js +58 -15
  124. package/lib/execution/engine/mock.js.map +1 -1
  125. package/lib/execution/engine/types.d.ts +15 -5
  126. package/lib/execution/engine/types.js +8 -2
  127. package/lib/execution/engine/types.js.map +1 -1
  128. package/lib/execution/engine/utils.js +1 -1
  129. package/lib/execution/engine/utils.js.map +1 -1
  130. package/lib/metrics/metrics/beacon.d.ts +16 -28
  131. package/lib/metrics/metrics/beacon.js +66 -75
  132. package/lib/metrics/metrics/beacon.js.map +1 -1
  133. package/lib/metrics/metrics/lodestar.d.ts +31 -1
  134. package/lib/metrics/metrics/lodestar.js +63 -0
  135. package/lib/metrics/metrics/lodestar.js.map +1 -1
  136. package/lib/metrics/metrics.d.ts +2 -1
  137. package/lib/metrics/metrics.js +3 -0
  138. package/lib/metrics/metrics.js.map +1 -1
  139. package/lib/network/core/metrics.d.ts +10 -3
  140. package/lib/network/core/metrics.js +22 -4
  141. package/lib/network/core/metrics.js.map +1 -1
  142. package/lib/network/core/networkCore.d.ts +15 -4
  143. package/lib/network/core/networkCore.js +73 -24
  144. package/lib/network/core/networkCore.js.map +1 -1
  145. package/lib/network/core/networkCoreWorker.js +2 -0
  146. package/lib/network/core/networkCoreWorker.js.map +1 -1
  147. package/lib/network/core/networkCoreWorkerHandler.d.ts +5 -3
  148. package/lib/network/core/networkCoreWorkerHandler.js +7 -2
  149. package/lib/network/core/networkCoreWorkerHandler.js.map +1 -1
  150. package/lib/network/core/types.d.ts +7 -4
  151. package/lib/network/events.d.ts +4 -2
  152. package/lib/network/events.js.map +1 -1
  153. package/lib/network/gossip/gossipsub.d.ts +2 -2
  154. package/lib/network/gossip/gossipsub.js +8 -6
  155. package/lib/network/gossip/gossipsub.js.map +1 -1
  156. package/lib/network/gossip/interface.d.ts +8 -1
  157. package/lib/network/gossip/interface.js +1 -0
  158. package/lib/network/gossip/interface.js.map +1 -1
  159. package/lib/network/gossip/scoringParameters.d.ts +6 -2
  160. package/lib/network/gossip/scoringParameters.js.map +1 -1
  161. package/lib/network/gossip/topic.d.ts +2038 -1489
  162. package/lib/network/gossip/topic.js +29 -1
  163. package/lib/network/gossip/topic.js.map +1 -1
  164. package/lib/network/interface.d.ts +11 -3
  165. package/lib/network/metadata.d.ts +9 -5
  166. package/lib/network/metadata.js +26 -5
  167. package/lib/network/metadata.js.map +1 -1
  168. package/lib/network/network.d.ts +14 -4
  169. package/lib/network/network.js +73 -11
  170. package/lib/network/network.js.map +1 -1
  171. package/lib/network/networkConfig.d.ts +12 -0
  172. package/lib/network/networkConfig.js +2 -0
  173. package/lib/network/networkConfig.js.map +1 -0
  174. package/lib/network/options.d.ts +1 -0
  175. package/lib/network/options.js +7 -2
  176. package/lib/network/options.js.map +1 -1
  177. package/lib/network/peers/discover.d.ts +8 -3
  178. package/lib/network/peers/discover.js +99 -14
  179. package/lib/network/peers/discover.js.map +1 -1
  180. package/lib/network/peers/peerManager.d.ts +10 -4
  181. package/lib/network/peers/peerManager.js +108 -19
  182. package/lib/network/peers/peerManager.js.map +1 -1
  183. package/lib/network/peers/peersData.d.ts +17 -3
  184. package/lib/network/peers/peersData.js.map +1 -1
  185. package/lib/network/peers/score/interface.d.ts +1 -1
  186. package/lib/network/peers/score/score.d.ts +2 -2
  187. package/lib/network/peers/score/score.js +4 -1
  188. package/lib/network/peers/score/score.js.map +1 -1
  189. package/lib/network/peers/score/store.d.ts +3 -1
  190. package/lib/network/peers/score/store.js +6 -2
  191. package/lib/network/peers/score/store.js.map +1 -1
  192. package/lib/network/peers/utils/assertPeerRelevance.d.ts +7 -3
  193. package/lib/network/peers/utils/assertPeerRelevance.js +10 -1
  194. package/lib/network/peers/utils/assertPeerRelevance.js.map +1 -1
  195. package/lib/network/peers/utils/prioritizePeers.d.ts +19 -7
  196. package/lib/network/peers/utils/prioritizePeers.js +42 -6
  197. package/lib/network/peers/utils/prioritizePeers.js.map +1 -1
  198. package/lib/network/processor/extractSlotRootFns.js +8 -1
  199. package/lib/network/processor/extractSlotRootFns.js.map +1 -1
  200. package/lib/network/processor/gossipHandlers.js +172 -23
  201. package/lib/network/processor/gossipHandlers.js.map +1 -1
  202. package/lib/network/processor/gossipQueues/index.js +5 -0
  203. package/lib/network/processor/gossipQueues/index.js.map +1 -1
  204. package/lib/network/processor/index.js +1 -0
  205. package/lib/network/processor/index.js.map +1 -1
  206. package/lib/network/reqresp/ReqRespBeaconNode.d.ts +2 -2
  207. package/lib/network/reqresp/ReqRespBeaconNode.js +36 -14
  208. package/lib/network/reqresp/ReqRespBeaconNode.js.map +1 -1
  209. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.d.ts +24 -4
  210. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.js +261 -20
  211. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.js.map +1 -1
  212. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.d.ts +37 -6
  213. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.js +283 -28
  214. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.js.map +1 -1
  215. package/lib/network/reqresp/handlers/beaconBlocksByRange.d.ts +1 -1
  216. package/lib/network/reqresp/handlers/beaconBlocksByRange.js +3 -3
  217. package/lib/network/reqresp/handlers/beaconBlocksByRange.js.map +1 -1
  218. package/lib/network/reqresp/handlers/beaconBlocksByRoot.d.ts +2 -2
  219. package/lib/network/reqresp/handlers/beaconBlocksByRoot.js.map +1 -1
  220. package/lib/network/reqresp/handlers/blobSidecarsByRange.d.ts +2 -2
  221. package/lib/network/reqresp/handlers/blobSidecarsByRange.js +2 -3
  222. package/lib/network/reqresp/handlers/blobSidecarsByRange.js.map +1 -1
  223. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts +8 -0
  224. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js +113 -0
  225. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js.map +1 -0
  226. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.d.ts +6 -0
  227. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js +64 -0
  228. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js.map +1 -0
  229. package/lib/network/reqresp/handlers/index.js +13 -2
  230. package/lib/network/reqresp/handlers/index.js.map +1 -1
  231. package/lib/network/reqresp/protocols.d.ts +4 -0
  232. package/lib/network/reqresp/protocols.js +20 -0
  233. package/lib/network/reqresp/protocols.js.map +1 -1
  234. package/lib/network/reqresp/rateLimit.js +19 -3
  235. package/lib/network/reqresp/rateLimit.js.map +1 -1
  236. package/lib/network/reqresp/score.js +3 -0
  237. package/lib/network/reqresp/score.js.map +1 -1
  238. package/lib/network/reqresp/types.d.ts +13 -6
  239. package/lib/network/reqresp/types.js +14 -5
  240. package/lib/network/reqresp/types.js.map +1 -1
  241. package/lib/network/reqresp/utils/dataColumnResponseValidation.d.ts +16 -0
  242. package/lib/network/reqresp/utils/dataColumnResponseValidation.js +59 -0
  243. package/lib/network/reqresp/utils/dataColumnResponseValidation.js.map +1 -0
  244. package/lib/network/statusCache.d.ts +5 -5
  245. package/lib/network/statusCache.js.map +1 -1
  246. package/lib/network/subnets/interface.d.ts +3 -0
  247. package/lib/network/subnets/interface.js +14 -1
  248. package/lib/network/subnets/interface.js.map +1 -1
  249. package/lib/network/subnets/syncnetsService.js +4 -5
  250. package/lib/network/subnets/syncnetsService.js.map +1 -1
  251. package/lib/node/nodejs.js +1 -0
  252. package/lib/node/nodejs.js.map +1 -1
  253. package/lib/sync/backfill/backfill.js +1 -1
  254. package/lib/sync/backfill/backfill.js.map +1 -1
  255. package/lib/sync/constants.d.ts +18 -3
  256. package/lib/sync/constants.js +21 -3
  257. package/lib/sync/constants.js.map +1 -1
  258. package/lib/sync/interface.d.ts +2 -2
  259. package/lib/sync/interface.js +1 -1
  260. package/lib/sync/interface.js.map +1 -1
  261. package/lib/sync/range/batch.d.ts +17 -2
  262. package/lib/sync/range/batch.js +39 -7
  263. package/lib/sync/range/batch.js.map +1 -1
  264. package/lib/sync/range/chain.d.ts +15 -1
  265. package/lib/sync/range/chain.js +124 -33
  266. package/lib/sync/range/chain.js.map +1 -1
  267. package/lib/sync/range/range.d.ts +3 -2
  268. package/lib/sync/range/range.js +9 -3
  269. package/lib/sync/range/range.js.map +1 -1
  270. package/lib/sync/range/utils/chainTarget.d.ts +5 -1
  271. package/lib/sync/range/utils/chainTarget.js +26 -1
  272. package/lib/sync/range/utils/chainTarget.js.map +1 -1
  273. package/lib/sync/range/utils/peerBalancer.d.ts +19 -5
  274. package/lib/sync/range/utils/peerBalancer.js +104 -10
  275. package/lib/sync/range/utils/peerBalancer.js.map +1 -1
  276. package/lib/sync/sync.js +1 -1
  277. package/lib/sync/sync.js.map +1 -1
  278. package/lib/sync/unknownBlock.d.ts +54 -5
  279. package/lib/sync/unknownBlock.js +321 -61
  280. package/lib/sync/unknownBlock.js.map +1 -1
  281. package/lib/sync/utils/remoteSyncType.d.ts +4 -4
  282. package/lib/sync/utils/remoteSyncType.js.map +1 -1
  283. package/lib/util/blobs.d.ts +16 -4
  284. package/lib/util/blobs.js +122 -5
  285. package/lib/util/blobs.js.map +1 -1
  286. package/lib/util/dataColumns.d.ts +137 -0
  287. package/lib/util/dataColumns.js +362 -0
  288. package/lib/util/dataColumns.js.map +1 -0
  289. package/lib/util/metadata.d.ts +5 -0
  290. package/lib/util/metadata.js +10 -0
  291. package/lib/util/metadata.js.map +1 -1
  292. package/lib/util/queue/fnQueue.js +1 -1
  293. package/lib/util/queue/fnQueue.js.map +1 -1
  294. package/lib/util/queue/itemQueue.js +1 -1
  295. package/lib/util/queue/itemQueue.js.map +1 -1
  296. package/lib/util/sszBytes.d.ts +3 -0
  297. package/lib/util/sszBytes.js +40 -0
  298. package/lib/util/sszBytes.js.map +1 -1
  299. package/lib/util/types.d.ts +7 -0
  300. package/lib/util/types.js +3 -0
  301. package/lib/util/types.js.map +1 -1
  302. package/package.json +19 -20
  303. package/lib/network/reqresp/handlers/status.d.ts +0 -4
  304. package/lib/network/reqresp/handlers/status.js +0 -11
  305. package/lib/network/reqresp/handlers/status.js.map +0 -1
@@ -1,12 +1,25 @@
1
- import { ForkSeq } from "@lodestar/params";
1
+ import { ForkName, ForkSeq } from "@lodestar/params";
2
2
  import { computeEpochAtSlot } from "@lodestar/state-transition";
3
- import { BlobsSource, BlockSource, getBlockInput } from "../../chain/blocks/types.js";
4
- export async function beaconBlocksMaybeBlobsByRange(config, network, peerId, request, currentEpoch) {
3
+ import { ssz, } from "@lodestar/types";
4
+ import { prettyPrintIndices } from "@lodestar/utils";
5
+ import { BlobsSource, BlockInputType, BlockSource, DataColumnsSource, getBlockInput, getBlockInputDataColumns, } from "../../chain/blocks/types.js";
6
+ import { getEmptyBlockInputCacheEntry } from "../../chain/seenCache/seenGossipBlockInput.js";
7
+ import { RangeSyncType } from "../../sync/utils/remoteSyncType.js";
8
+ import { PeerAction } from "../peers/score/interface.js";
9
+ export const SyncSourceByRoot = "ByRoot";
10
+ /**
11
+ * Download blocks and blobs (prefulu) or data columns (fulu) by range.
12
+ * returns:
13
+ * - array of blocks with blobs or data columns
14
+ * - pendingDataColumns: null if all data columns are present, or array of column indexes that are missing. Also null for prefulu
15
+ */
16
+ export async function beaconBlocksMaybeBlobsByRange(config, network, peer, request, currentEpoch, partialDownload, syncSource, metrics, logger) {
17
+ const { peerId, client: peerClient, custodyGroups: peerColumns, earliestAvailableSlot } = peer;
5
18
  // Code below assumes the request is in the same epoch
6
19
  // Range sync satisfies this condition, but double check here for sanity
7
20
  const { startSlot, count } = request;
8
21
  if (count < 1) {
9
- return [];
22
+ throw Error(`Invalid count=${count} in BeaconBlocksByRangeRequest`);
10
23
  }
11
24
  const endSlot = startSlot + count - 1;
12
25
  const startEpoch = computeEpochAtSlot(startSlot);
@@ -14,26 +27,100 @@ export async function beaconBlocksMaybeBlobsByRange(config, network, peerId, req
14
27
  if (startEpoch !== endEpoch) {
15
28
  throw Error(`BeaconBlocksByRangeRequest must be in the same epoch startEpoch=${startEpoch} != endEpoch=${endEpoch}`);
16
29
  }
30
+ const forkSeq = config.getForkSeq(startSlot);
17
31
  // Note: Assumes all blocks in the same epoch
18
- if (config.getForkSeq(startSlot) < ForkSeq.deneb) {
19
- const blocks = await network.sendBeaconBlocksByRange(peerId, request);
20
- return blocks.map((block) => getBlockInput.preData(config, block.data, BlockSource.byRange));
32
+ if (forkSeq < ForkSeq.deneb) {
33
+ const beaconBlocks = await network.sendBeaconBlocksByRange(peerId, request);
34
+ if (beaconBlocks.length === 0) {
35
+ throw Error(`peerId=${peerId} peerClient=${peerClient} returned no blocks for BeaconBlocksByRangeRequest ${JSON.stringify(request)}`);
36
+ }
37
+ const blocks = beaconBlocks.map((block) => getBlockInput.preData(config, block.data, BlockSource.byRange));
38
+ return { blocks, pendingDataColumns: null };
21
39
  }
22
40
  // From Deneb
23
41
  // Only request blobs if they are recent enough
24
42
  if (startEpoch >= currentEpoch - config.MIN_EPOCHS_FOR_BLOB_SIDECARS_REQUESTS) {
25
- const [allBlocks, allBlobSidecars] = await Promise.all([
26
- network.sendBeaconBlocksByRange(peerId, request),
27
- network.sendBlobSidecarsByRange(peerId, request),
43
+ if (forkSeq < ForkSeq.fulu) {
44
+ const [allBlocks, allBlobSidecars] = await Promise.all([
45
+ network.sendBeaconBlocksByRange(peerId, request),
46
+ network.sendBlobSidecarsByRange(peerId, request),
47
+ ]);
48
+ if (allBlocks.length === 0) {
49
+ throw Error(`peerId=${peerId} peerClient=${peerClient} returns no blocks allBlobSidecars=${allBlobSidecars.length} for BeaconBlocksByRangeRequest ${JSON.stringify(request)}`);
50
+ }
51
+ const blocks = matchBlockWithBlobs(config, allBlocks, allBlobSidecars, endSlot, BlockSource.byRange, BlobsSource.byRange, syncSource);
52
+ return { blocks, pendingDataColumns: null };
53
+ }
54
+ // From fulu, get columns
55
+ const sampledColumns = network.custodyConfig.sampledColumns;
56
+ const neededColumns = partialDownload ? partialDownload.pendingDataColumns : sampledColumns;
57
+ // This should never throw. Already checking for this in ChainPeerBalancer when selecting the peer
58
+ if ((earliestAvailableSlot ?? 0) > startSlot) {
59
+ throw new Error(`earliestAvailableSlot=${earliestAvailableSlot} not respected for ByRange startSlot=${startSlot}`);
60
+ }
61
+ // get match
62
+ const columns = peerColumns.reduce((acc, elem) => {
63
+ if (neededColumns.includes(elem)) {
64
+ acc.push(elem);
65
+ }
66
+ return acc;
67
+ }, []);
68
+ if (columns.length === 0 && partialDownload !== null) {
69
+ // this peer has nothing to offer and should not have been selected for batch download
70
+ // throw error?
71
+ return partialDownload;
72
+ }
73
+ const pendingDataColumns = neededColumns.reduce((acc, elem) => {
74
+ if (!columns.includes(elem)) {
75
+ acc.push(elem);
76
+ }
77
+ return acc;
78
+ }, []);
79
+ const dataColumnRequest = { ...request, columns };
80
+ const [allBlocks, allDataColumnSidecars] = await Promise.all([
81
+ // TODO-das: investigate why partialDownload blocks is empty here
82
+ partialDownload && partialDownload.blocks.length > 0
83
+ ? partialDownload.blocks.map((blockInput) => ({ data: blockInput.block }))
84
+ : network.sendBeaconBlocksByRange(peerId, request),
85
+ columns.length === 0 ? [] : network.sendDataColumnSidecarsByRange(peerId, dataColumnRequest),
28
86
  ]);
29
- return matchBlockWithBlobs(config, allBlocks, allBlobSidecars, endSlot, BlockSource.byRange, BlobsSource.byRange);
87
+ logger?.debug("ByRange requests", {
88
+ beaconBlocksRequest: JSON.stringify(ssz.phase0.BeaconBlocksByRangeRequest.toJson(request)),
89
+ dataColumnRequest: JSON.stringify(ssz.fulu.DataColumnSidecarsByRangeRequest.toJson(dataColumnRequest)),
90
+ [`allBlocks(${allBlocks.length})`]: allBlocks.map((blk) => blk.data.message.slot).join(" "),
91
+ [`allDataColumnSidecars(${allDataColumnSidecars.length})`]: allDataColumnSidecars
92
+ .map((dCol) => `${dCol.signedBlockHeader.message.slot}:${dCol.index}`)
93
+ .join(" "),
94
+ peerColumns: prettyPrintIndices(peerColumns),
95
+ peerId,
96
+ peerClient,
97
+ prevPartialDownload: !!partialDownload,
98
+ });
99
+ if (allBlocks.length === 0) {
100
+ throw Error(`peerId=${peerId} peerClient=${peerClient} returns no blocks dataColumnSidecars=${allDataColumnSidecars.length} for BeaconBlocksByRangeRequest ${JSON.stringify(request)}`);
101
+ }
102
+ const blocks = matchBlockWithDataColumns(network, peerId, config, sampledColumns, columns, allBlocks, allDataColumnSidecars, endSlot, BlockSource.byRange, DataColumnsSource.byRange, partialDownload, peerClient, syncSource, metrics, logger);
103
+ return { blocks, pendingDataColumns: pendingDataColumns.length > 0 ? pendingDataColumns : null };
30
104
  }
105
+ logger?.verbose(`Download range is out of ${config.MIN_EPOCHS_FOR_BLOB_SIDECARS_REQUESTS} epochs, skip Blobs and DataColumnSidecars download`, {
106
+ startEpoch,
107
+ startSlot,
108
+ endSlot,
109
+ currentEpoch,
110
+ });
31
111
  // Data is out of range, only request blocks
32
112
  const blocks = await network.sendBeaconBlocksByRange(peerId, request);
33
- return blocks.map((block) => getBlockInput.outOfRangeData(config, block.data, BlockSource.byRange));
113
+ if (blocks.length === 0) {
114
+ throw Error(`peerId=${peerId} peerClient=${peerClient} returned no blocks for BeaconBlocksByRangeRequest ${JSON.stringify(request)}`);
115
+ }
116
+ return {
117
+ blocks: blocks.map((block) => getBlockInput.outOfRangeData(config, block.data, BlockSource.byRange)),
118
+ // null means all data columns are present
119
+ pendingDataColumns: null,
120
+ };
34
121
  }
35
122
  // Assumes that the blobs are in the same sequence as blocks, doesn't require block to be sorted
36
- export function matchBlockWithBlobs(config, allBlocks, allBlobSidecars, endSlot, blockSource, blobsSource) {
123
+ export function matchBlockWithBlobs(config, allBlocks, allBlobSidecars, endSlot, blockSource, blobsSource, syncSource) {
37
124
  const blockInputs = [];
38
125
  let blobSideCarIndex = 0;
39
126
  let lastMatchedSlot = -1;
@@ -50,11 +137,19 @@ export function matchBlockWithBlobs(config, allBlocks, allBlobSidecars, endSlot,
50
137
  }
51
138
  else {
52
139
  const blobSidecars = [];
53
- let blobSidecar;
54
- while (
55
- // biome-ignore lint/suspicious/noAssignInExpressions: <explanation>
56
- (blobSidecar = allBlobSidecars[blobSideCarIndex])?.signedBlockHeader.message.slot === block.data.message.slot) {
57
- blobSidecars.push(blobSidecar);
140
+ const blockRoot = config.getForkTypes(block.data.message.slot).BeaconBlock.hashTreeRoot(block.data.message);
141
+ const matchBlob = (blobSidecar) => {
142
+ if (blobSidecar === undefined) {
143
+ return false;
144
+ }
145
+ if (syncSource === RangeSyncType.Head || syncSource === SyncSourceByRoot) {
146
+ return (Buffer.compare(ssz.phase0.BeaconBlockHeader.hashTreeRoot(blobSidecar.signedBlockHeader.message), blockRoot) === 0);
147
+ }
148
+ // For finalized range sync, we can just match by slot
149
+ return blobSidecar.signedBlockHeader.message.slot === block.data.message.slot;
150
+ };
151
+ while (matchBlob(allBlobSidecars[blobSideCarIndex])) {
152
+ blobSidecars.push(allBlobSidecars[blobSideCarIndex]);
58
153
  lastMatchedSlot = block.data.message.slot;
59
154
  blobSideCarIndex++;
60
155
  }
@@ -68,7 +163,6 @@ export function matchBlockWithBlobs(config, allBlocks, allBlobSidecars, endSlot,
68
163
  blobs: blobSidecars,
69
164
  blobsSource,
70
165
  };
71
- // TODO DENEB: instead of null, pass payload in bytes
72
166
  blockInputs.push(getBlockInput.availableData(config, block.data, blockSource, blockData));
73
167
  }
74
168
  }
@@ -80,8 +174,155 @@ export function matchBlockWithBlobs(config, allBlocks, allBlobSidecars, endSlot,
80
174
  throw Error(`Unmatched blobSidecars, blocks=${allBlocks.length}, blobs=${allBlobSidecars.length} lastMatchedSlot=${lastMatchedSlot}, pending blobSidecars slots=${allBlobSidecars
81
175
  .slice(blobSideCarIndex)
82
176
  .map((blb) => blb.signedBlockHeader.message.slot)
83
- .join(",")}`);
177
+ .join(" ")}`);
178
+ }
179
+ return blockInputs;
180
+ }
181
+ export function matchBlockWithDataColumns(network, peerId, config, sampledColumns, requestedColumns, allBlocks, allDataColumnSidecars, endSlot, blockSource, dataColumnsSource, prevPartialDownload, peerClient, syncSource, metrics, logger) {
182
+ const blockInputs = [];
183
+ let dataColumnSideCarIndex = 0;
184
+ let lastMatchedSlot = -1;
185
+ const neededColumns = prevPartialDownload?.pendingDataColumns ?? sampledColumns;
186
+ const shouldHaveAllData = neededColumns.reduce((acc, elem) => acc && requestedColumns.includes(elem), true);
187
+ // Match dataColumnSideCar with the block as some blocks would have no dataColumns and hence
188
+ // would be omitted from the response. If there are any inconsitencies in the
189
+ // response, the validations during import will reject the block and hence this
190
+ // entire segment.
191
+ //
192
+ // Assuming that the blocks and blobs will come in same sorted order
193
+ for (let i = 0; i < allBlocks.length; i++) {
194
+ const block = allBlocks[i];
195
+ const forkSeq = config.getForkSeq(block.data.message.slot);
196
+ if (forkSeq < ForkSeq.fulu) {
197
+ throw Error(`Invalid block forkSeq=${forkSeq} < ForSeq.fulu for matchBlockWithDataColumns`);
198
+ }
199
+ const dataColumnSidecars = [];
200
+ const blockRoot = config.getForkTypes(block.data.message.slot).BeaconBlock.hashTreeRoot(block.data.message);
201
+ const matchDataColumnSidecar = (dataColumnSidecar) => {
202
+ if (dataColumnSidecar === undefined) {
203
+ return false;
204
+ }
205
+ if (syncSource === RangeSyncType.Head || syncSource === SyncSourceByRoot) {
206
+ return (Buffer.compare(ssz.phase0.BeaconBlockHeader.hashTreeRoot(dataColumnSidecar.signedBlockHeader.message), blockRoot) === 0);
207
+ }
208
+ // For finalized range sync, we can just match by slot
209
+ return dataColumnSidecar.signedBlockHeader.message.slot === block.data.message.slot;
210
+ };
211
+ while (matchDataColumnSidecar(allDataColumnSidecars[dataColumnSideCarIndex])) {
212
+ dataColumnSidecars.push(allDataColumnSidecars[dataColumnSideCarIndex]);
213
+ lastMatchedSlot = block.data.message.slot;
214
+ dataColumnSideCarIndex++;
215
+ }
216
+ metrics?.dataColumns.bySource.inc({ source: DataColumnsSource.byRange }, dataColumnSidecars.length);
217
+ const blobKzgCommitmentsLen = block.data.message.body.blobKzgCommitments.length;
218
+ logger?.debug("processing matchBlockWithDataColumns", {
219
+ blobKzgCommitmentsLen,
220
+ dataColumnSidecars: dataColumnSidecars.length,
221
+ shouldHaveAllData,
222
+ neededColumns: prettyPrintIndices(neededColumns),
223
+ requestedColumns: prettyPrintIndices(requestedColumns),
224
+ slot: block.data.message.slot,
225
+ dataColumnsSlots: prettyPrintIndices(dataColumnSidecars.map((dcm) => dcm.signedBlockHeader.message.slot)),
226
+ peerClient,
227
+ });
228
+ if (blobKzgCommitmentsLen === 0) {
229
+ if (dataColumnSidecars.length > 0) {
230
+ // only penalize peer with Finalized range sync or "ByRoot" sync source
231
+ if (syncSource !== RangeSyncType.Head) {
232
+ network.reportPeer(peerId, PeerAction.LowToleranceError, "Missing or mismatching dataColumnSidecars");
233
+ }
234
+ throw Error(`Missing or mismatching dataColumnSidecars from peerId=${peerId} for blockSlot=${block.data.message.slot} with blobKzgCommitmentsLen=0 dataColumnSidecars=${dataColumnSidecars.length}>0`);
235
+ }
236
+ const blockData = {
237
+ fork: config.getForkName(block.data.message.slot),
238
+ dataColumns: [],
239
+ dataColumnsBytes: [],
240
+ dataColumnsSource,
241
+ };
242
+ blockInputs.push(getBlockInput.availableData(config, block.data, blockSource, blockData));
243
+ }
244
+ else {
245
+ // Quick inspect how many blobSidecars was expected
246
+ const dataColumnIndexes = dataColumnSidecars.map((dataColumnSidecar) => dataColumnSidecar.index);
247
+ const requestedColumnsPresent = requestedColumns.reduce((acc, columnIndex) => acc && dataColumnIndexes.includes(columnIndex), true);
248
+ logger?.debug("matchBlockWithDataColumns2", {
249
+ dataColumnIndexes: prettyPrintIndices(dataColumnIndexes),
250
+ requestedColumnsPresent,
251
+ slot: block.data.message.slot,
252
+ peerClient,
253
+ });
254
+ if (dataColumnSidecars.length !== requestedColumns.length || !requestedColumnsPresent) {
255
+ logger?.debug(`Missing or mismatching dataColumnSidecars from peerId=${peerId} for blockSlot=${block.data.message.slot} with numColumns=${sampledColumns.length} dataColumnSidecars=${dataColumnSidecars.length} requestedColumnsPresent=${requestedColumnsPresent} received dataColumnIndexes=${dataColumnIndexes.join(" ")} requested=${requestedColumns.join(" ")}`, {
256
+ allBlocks: allBlocks.length,
257
+ allDataColumnSidecars: allDataColumnSidecars.length,
258
+ peerId,
259
+ blobKzgCommitmentsLen,
260
+ peerClient,
261
+ });
262
+ // only penalize peer with Finalized range sync or "ByRoot" sync source
263
+ if (syncSource !== RangeSyncType.Head) {
264
+ network.reportPeer(peerId, PeerAction.LowToleranceError, "Missing or mismatching dataColumnSidecars");
265
+ }
266
+ throw Error(`Missing or mismatching dataColumnSidecars from peerId=${peerId} for blockSlot=${block.data.message.slot} blobKzgCommitmentsLen=${blobKzgCommitmentsLen} with numColumns=${sampledColumns.length} dataColumnSidecars=${dataColumnSidecars.length} requestedColumnsPresent=${requestedColumnsPresent} received dataColumnIndexes=${dataColumnIndexes.join(" ")} requested=${requestedColumns.join(" ")}`);
267
+ }
268
+ let cachedData;
269
+ // TODO-das: investigate why partialDownload blocks is empty here
270
+ if (prevPartialDownload !== null && prevPartialDownload.blocks.length > 0) {
271
+ const prevBlockInput = prevPartialDownload.blocks[i];
272
+ if (prevBlockInput.type !== BlockInputType.dataPromise) {
273
+ throw Error(`prevBlockInput.type=${prevBlockInput.type} in prevPartialDownload`);
274
+ }
275
+ cachedData = prevBlockInput.cachedData;
276
+ }
277
+ else {
278
+ // biome-ignore lint/style/noNonNullAssertion: checked below for validity
279
+ cachedData = getEmptyBlockInputCacheEntry(config.getForkName(block.data.message.slot), -1).cachedData;
280
+ if (cachedData === undefined) {
281
+ throw Error("Invalid cachedData=undefined from getEmptyBlockInputCacheEntry");
282
+ }
283
+ }
284
+ if (cachedData.fork !== ForkName.fulu) {
285
+ throw Error("Invalid fork for cachedData on dataColumns");
286
+ }
287
+ for (const dataColumnSidecar of dataColumnSidecars) {
288
+ cachedData.dataColumnsCache.set(dataColumnSidecar.index, {
289
+ dataColumn: dataColumnSidecar,
290
+ dataColumnBytes: null,
291
+ });
292
+ }
293
+ if (shouldHaveAllData) {
294
+ const { dataColumns, dataColumnsBytes } = getBlockInputDataColumns(cachedData.dataColumnsCache, sampledColumns);
295
+ const blockData = {
296
+ fork: config.getForkName(block.data.message.slot),
297
+ dataColumns,
298
+ dataColumnsBytes,
299
+ dataColumnsSource,
300
+ };
301
+ // TODO DENEB: instead of null, pass payload in bytes
302
+ blockInputs.push(getBlockInput.availableData(config, block.data, blockSource, blockData));
303
+ }
304
+ else {
305
+ blockInputs.push(getBlockInput.dataPromise(config, block.data, blockSource, cachedData));
306
+ }
307
+ }
308
+ }
309
+ // for head sync, there could be unconsumed data column sidecars because the retried peers may have higher head
310
+ if (allDataColumnSidecars[dataColumnSideCarIndex] !== undefined &&
311
+ // If there are no data columns, the data columns request can give 1 block outside the requested range
312
+ allDataColumnSidecars[dataColumnSideCarIndex].signedBlockHeader.message.slot <= endSlot &&
313
+ // only penalize peer with Finalized range sync or "ByRoot" sync source
314
+ syncSource !== RangeSyncType.Head) {
315
+ network.reportPeer(peerId, PeerAction.LowToleranceError, "Unmatched dataColumnSidecars");
316
+ throw Error(`Unmatched dataColumnSidecars, blocks=${allBlocks.length}, blobs=${allDataColumnSidecars.length} lastMatchedSlot=${lastMatchedSlot}, pending dataColumnSidecars slots=${allDataColumnSidecars
317
+ .slice(dataColumnSideCarIndex)
318
+ .map((blb) => blb.signedBlockHeader.message.slot)
319
+ .join(" ")} endSlot=${endSlot}, peerId=${peerId}, peerClient=${peerClient}`);
84
320
  }
321
+ logger?.debug("matched BlockWithDataColumns", {
322
+ peerClient,
323
+ slots: prettyPrintIndices(blockInputs.map((b) => Number(b.block.message.slot))),
324
+ types: blockInputs.map((b) => b.type).join(" "),
325
+ });
85
326
  return blockInputs;
86
327
  }
87
328
  //# sourceMappingURL=beaconBlocksMaybeBlobsByRange.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"beaconBlocksMaybeBlobsByRange.js","sourceRoot":"","sources":["../../../src/network/reqresp/beaconBlocksMaybeBlobsByRange.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"beaconBlocksMaybeBlobsByRange.js","sourceRoot":"","sources":["../../../src/network/reqresp/beaconBlocksMaybeBlobsByRange.ts"],"names":[],"mappings":"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"}
@@ -1,18 +1,49 @@
1
1
  import { ChainForkConfig } from "@lodestar/config";
2
- import { RootHex, phase0 } from "@lodestar/types";
2
+ import { RootHex, SignedBeaconBlock } from "@lodestar/types";
3
3
  import { BlobAndProof } from "@lodestar/types/deneb";
4
- import { BlockInput, NullBlockInput } from "../../chain/blocks/types.js";
4
+ import { Logger } from "@lodestar/utils";
5
+ import { BlockInput, CachedBlobs, NullBlockInput } from "../../chain/blocks/types.js";
5
6
  import { ChainEventEmitter } from "../../chain/emitter.js";
6
7
  import { IExecutionEngine } from "../../execution/index.js";
7
8
  import { Metrics } from "../../metrics/index.js";
8
9
  import { PeerIdStr } from "../../util/peerId.js";
10
+ import { BeaconBlocksByRootRequest } from "../../util/types.js";
9
11
  import { INetwork } from "../interface.js";
10
- export declare function beaconBlocksMaybeBlobsByRoot(config: ChainForkConfig, network: INetwork, peerId: PeerIdStr, request: phase0.BeaconBlocksByRootRequest): Promise<BlockInput[]>;
11
- export declare function unavailableBeaconBlobsByRoot(config: ChainForkConfig, network: INetwork, peerId: PeerIdStr, unavailableBlockInput: BlockInput | NullBlockInput, opts: {
12
- metrics: Metrics | null;
13
- emitter: ChainEventEmitter | null;
12
+ import { PartialDownload } from "./beaconBlocksMaybeBlobsByRange.js";
13
+ /**
14
+ * Request beacon blocks by root, and blobs or data columns if available.
15
+ * return BlockInput[] along with pendingDataColumns (null for prefulu forks for postfulu where data is available)
16
+ */
17
+ export declare function beaconBlocksMaybeBlobsByRoot(config: ChainForkConfig, network: INetwork, peerId: PeerIdStr, request: BeaconBlocksByRootRequest, partialDownload: null | PartialDownload, peerClient: string, metrics: Metrics | null, logger?: Logger): Promise<{
18
+ blocks: BlockInput[];
19
+ pendingDataColumns: null | number[];
20
+ }>;
21
+ export declare function unavailableBeaconBlobsByRoot(config: ChainForkConfig, network: INetwork, peerId: PeerIdStr, peerClient: string, unavailableBlockInput: BlockInput | NullBlockInput, opts: {
22
+ logger?: Logger;
23
+ metrics?: Metrics | null;
14
24
  executionEngine: IExecutionEngine;
25
+ emitter: ChainEventEmitter;
15
26
  engineGetBlobsCache?: Map<RootHex, BlobAndProof | null>;
16
27
  blockInputsRetryTrackerCache?: Set<RootHex>;
17
28
  }): Promise<BlockInput>;
29
+ export declare function unavailableBeaconBlobsByRootPreFulu(config: ChainForkConfig, network: INetwork, peerId: PeerIdStr, unavailableBlockInput: BlockInput | NullBlockInput, block: SignedBeaconBlock, cachedData: CachedBlobs, opts: {
30
+ metrics?: Metrics | null;
31
+ emitter: ChainEventEmitter;
32
+ executionEngine: IExecutionEngine;
33
+ engineGetBlobsCache?: Map<RootHex, BlobAndProof | null>;
34
+ blockInputsRetryTrackerCache?: Set<RootHex>;
35
+ }): Promise<BlockInput>;
36
+ /**
37
+ * Download more columns for a BlockInput
38
+ * - unavailableBlockInput should have block, but not enough blobs (deneb) or data columns (fulu)
39
+ *
40
+ * This function may return data promise, and consumer should continue with fetching more blobs or columns from other peers
41
+ * see UnknownBlockSync.fetchUnavailableBlockInput()
42
+ */
43
+ export declare function unavailableBeaconBlobsByRootPostFulu(config: ChainForkConfig, network: INetwork, peerId: PeerIdStr, peerClient: string, unavailableBlockInput: BlockInput, block: SignedBeaconBlock, cachedData: NullBlockInput["cachedData"], opts: {
44
+ metrics?: Metrics | null;
45
+ executionEngine: IExecutionEngine;
46
+ emitter: ChainEventEmitter;
47
+ logger?: Logger;
48
+ }): Promise<BlockInput>;
18
49
  //# sourceMappingURL=beaconBlocksMaybeBlobsByRoot.d.ts.map