@lodestar/beacon-node 1.30.0-dev.dd729f5ece → 1.30.0-peerDAS.490e786a03

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 (276) hide show
  1. package/README.md +1 -1
  2. package/lib/api/impl/beacon/blocks/index.d.ts +1 -1
  3. package/lib/api/impl/beacon/blocks/index.js +44 -16
  4. package/lib/api/impl/beacon/blocks/index.js.map +1 -1
  5. package/lib/api/impl/beacon/blocks/utils.js +1 -1
  6. package/lib/api/impl/beacon/blocks/utils.js.map +1 -1
  7. package/lib/api/impl/beacon/pool/index.js +1 -1
  8. package/lib/api/impl/beacon/pool/index.js.map +1 -1
  9. package/lib/api/impl/beacon/state/index.js +14 -9
  10. package/lib/api/impl/beacon/state/index.js.map +1 -1
  11. package/lib/api/impl/beacon/state/utils.js +2 -2
  12. package/lib/api/impl/beacon/state/utils.js.map +1 -1
  13. package/lib/api/impl/lodestar/index.js +3 -1
  14. package/lib/api/impl/lodestar/index.js.map +1 -1
  15. package/lib/api/impl/proof/index.js +4 -2
  16. package/lib/api/impl/proof/index.js.map +1 -1
  17. package/lib/api/impl/validator/index.js +1 -21
  18. package/lib/api/impl/validator/index.js.map +1 -1
  19. package/lib/api/rest/base.js +0 -10
  20. package/lib/api/rest/base.js.map +1 -1
  21. package/lib/chain/archiveStore/archiveStore.d.ts +1 -2
  22. package/lib/chain/archiveStore/archiveStore.js +16 -15
  23. package/lib/chain/archiveStore/archiveStore.js.map +1 -1
  24. package/lib/chain/archiveStore/historicalState/worker.js +0 -2
  25. package/lib/chain/archiveStore/historicalState/worker.js.map +1 -1
  26. package/lib/chain/archiveStore/interface.d.ts +2 -1
  27. package/lib/chain/archiveStore/utils/archiveBlocks.d.ts +1 -1
  28. package/lib/chain/archiveStore/utils/archiveBlocks.js +89 -24
  29. package/lib/chain/archiveStore/utils/archiveBlocks.js.map +1 -1
  30. package/lib/chain/beaconProposerCache.d.ts +2 -3
  31. package/lib/chain/beaconProposerCache.js +4 -2
  32. package/lib/chain/beaconProposerCache.js.map +1 -1
  33. package/lib/chain/blocks/blockInput/blockInput.d.ts +164 -0
  34. package/lib/chain/blocks/blockInput/blockInput.js +522 -0
  35. package/lib/chain/blocks/blockInput/blockInput.js.map +1 -0
  36. package/lib/chain/blocks/blockInput/errors.d.ts +38 -0
  37. package/lib/chain/blocks/blockInput/errors.js +17 -0
  38. package/lib/chain/blocks/blockInput/errors.js.map +1 -0
  39. package/lib/chain/blocks/blockInput/index.d.ts +4 -0
  40. package/lib/chain/blocks/blockInput/index.js +4 -0
  41. package/lib/chain/blocks/blockInput/index.js.map +1 -0
  42. package/lib/chain/blocks/blockInput/types.d.ts +116 -0
  43. package/lib/chain/blocks/blockInput/types.js +19 -0
  44. package/lib/chain/blocks/blockInput/types.js.map +1 -0
  45. package/lib/chain/blocks/importBlock.js +56 -14
  46. package/lib/chain/blocks/importBlock.js.map +1 -1
  47. package/lib/chain/blocks/types.d.ts +65 -24
  48. package/lib/chain/blocks/types.js +39 -6
  49. package/lib/chain/blocks/types.js.map +1 -1
  50. package/lib/chain/blocks/verifyBlocksDataAvailability.js +21 -10
  51. package/lib/chain/blocks/verifyBlocksDataAvailability.js.map +1 -1
  52. package/lib/chain/blocks/writeBlockInputToDb.js +89 -15
  53. package/lib/chain/blocks/writeBlockInputToDb.js.map +1 -1
  54. package/lib/chain/bls/multithread/index.d.ts +1 -1
  55. package/lib/chain/bls/multithread/index.js +1 -3
  56. package/lib/chain/bls/multithread/index.js.map +1 -1
  57. package/lib/chain/bls/multithread/jobItem.d.ts +1 -1
  58. package/lib/chain/bls/multithread/jobItem.js +4 -12
  59. package/lib/chain/bls/multithread/jobItem.js.map +1 -1
  60. package/lib/chain/bls/multithread/worker.js +0 -1
  61. package/lib/chain/bls/multithread/worker.js.map +1 -1
  62. package/lib/chain/chain.d.ts +35 -4
  63. package/lib/chain/chain.js +28 -12
  64. package/lib/chain/chain.js.map +1 -1
  65. package/lib/chain/emitter.d.ts +18 -2
  66. package/lib/chain/emitter.js +13 -0
  67. package/lib/chain/emitter.js.map +1 -1
  68. package/lib/chain/errors/dataColumnSidecarError.d.ts +69 -0
  69. package/lib/chain/errors/dataColumnSidecarError.js +21 -0
  70. package/lib/chain/errors/dataColumnSidecarError.js.map +1 -0
  71. package/lib/chain/errors/index.d.ts +1 -0
  72. package/lib/chain/errors/index.js +1 -0
  73. package/lib/chain/errors/index.js.map +1 -1
  74. package/lib/chain/interface.d.ts +9 -3
  75. package/lib/chain/interface.js.map +1 -1
  76. package/lib/chain/options.d.ts +4 -1
  77. package/lib/chain/options.js +5 -0
  78. package/lib/chain/options.js.map +1 -1
  79. package/lib/chain/produceBlock/produceBlockBody.d.ts +4 -2
  80. package/lib/chain/produceBlock/produceBlockBody.js +11 -2
  81. package/lib/chain/produceBlock/produceBlockBody.js.map +1 -1
  82. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.d.ts +3 -2
  83. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.js +31 -2
  84. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.js.map +1 -1
  85. package/lib/chain/regen/queued.d.ts +0 -1
  86. package/lib/chain/regen/queued.js +0 -1
  87. package/lib/chain/regen/queued.js.map +1 -1
  88. package/lib/chain/seenCache/seenAttestationData.js.map +1 -1
  89. package/lib/chain/seenCache/seenGossipBlockInput.d.ts +61 -18
  90. package/lib/chain/seenCache/seenGossipBlockInput.js +254 -53
  91. package/lib/chain/seenCache/seenGossipBlockInput.js.map +1 -1
  92. package/lib/chain/validation/dataColumnSidecar.d.ts +28 -0
  93. package/lib/chain/validation/dataColumnSidecar.js +245 -0
  94. package/lib/chain/validation/dataColumnSidecar.js.map +1 -0
  95. package/lib/chain/validatorMonitor.d.ts +3 -3
  96. package/lib/chain/validatorMonitor.js +273 -56
  97. package/lib/chain/validatorMonitor.js.map +1 -1
  98. package/lib/db/beacon.d.ts +3 -1
  99. package/lib/db/beacon.js +3 -1
  100. package/lib/db/beacon.js.map +1 -1
  101. package/lib/db/buckets.d.ts +3 -1
  102. package/lib/db/buckets.js +2 -0
  103. package/lib/db/buckets.js.map +1 -1
  104. package/lib/db/interface.d.ts +3 -1
  105. package/lib/db/repositories/dataColumnSidecars.d.ts +47 -0
  106. package/lib/db/repositories/dataColumnSidecars.js +40 -0
  107. package/lib/db/repositories/dataColumnSidecars.js.map +1 -0
  108. package/lib/db/repositories/dataColumnSidecarsArchive.d.ts +15 -0
  109. package/lib/db/repositories/dataColumnSidecarsArchive.js +23 -0
  110. package/lib/db/repositories/dataColumnSidecarsArchive.js.map +1 -0
  111. package/lib/db/repositories/index.d.ts +2 -0
  112. package/lib/db/repositories/index.js +2 -0
  113. package/lib/db/repositories/index.js.map +1 -1
  114. package/lib/eth1/provider/eth1Provider.js +1 -2
  115. package/lib/eth1/provider/eth1Provider.js.map +1 -1
  116. package/lib/eth1/provider/jsonRpcHttpClient.js +1 -2
  117. package/lib/eth1/provider/jsonRpcHttpClient.js.map +1 -1
  118. package/lib/execution/engine/http.d.ts +5 -3
  119. package/lib/execution/engine/http.js +68 -31
  120. package/lib/execution/engine/http.js.map +1 -1
  121. package/lib/execution/engine/interface.d.ts +4 -2
  122. package/lib/execution/engine/interface.js +1 -1
  123. package/lib/execution/engine/interface.js.map +1 -1
  124. package/lib/execution/engine/mock.d.ts +1 -0
  125. package/lib/execution/engine/mock.js +5 -0
  126. package/lib/execution/engine/mock.js.map +1 -1
  127. package/lib/execution/engine/payloadIdCache.d.ts +0 -3
  128. package/lib/execution/engine/payloadIdCache.js +1 -2
  129. package/lib/execution/engine/payloadIdCache.js.map +1 -1
  130. package/lib/execution/engine/types.d.ts +10 -0
  131. package/lib/execution/engine/types.js +6 -0
  132. package/lib/execution/engine/types.js.map +1 -1
  133. package/lib/execution/engine/utils.js +1 -1
  134. package/lib/execution/engine/utils.js.map +1 -1
  135. package/lib/metrics/metrics/beacon.d.ts +8 -0
  136. package/lib/metrics/metrics/beacon.js +27 -0
  137. package/lib/metrics/metrics/beacon.js.map +1 -1
  138. package/lib/metrics/metrics/lodestar.d.ts +4 -100
  139. package/lib/metrics/metrics/lodestar.js +5 -307
  140. package/lib/metrics/metrics/lodestar.js.map +1 -1
  141. package/lib/metrics/metrics.d.ts +2 -1
  142. package/lib/metrics/metrics.js +3 -0
  143. package/lib/metrics/metrics.js.map +1 -1
  144. package/lib/monitoring/service.js +1 -2
  145. package/lib/monitoring/service.js.map +1 -1
  146. package/lib/monitoring/system.js +0 -1
  147. package/lib/monitoring/system.js.map +1 -1
  148. package/lib/network/core/metrics.d.ts +11 -3
  149. package/lib/network/core/metrics.js +26 -4
  150. package/lib/network/core/metrics.js.map +1 -1
  151. package/lib/network/core/networkCore.d.ts +9 -1
  152. package/lib/network/core/networkCore.js +38 -33
  153. package/lib/network/core/networkCore.js.map +1 -1
  154. package/lib/network/core/networkCoreWorker.js +2 -0
  155. package/lib/network/core/networkCoreWorker.js.map +1 -1
  156. package/lib/network/core/networkCoreWorkerHandler.d.ts +8 -4
  157. package/lib/network/core/networkCoreWorkerHandler.js +7 -0
  158. package/lib/network/core/networkCoreWorkerHandler.js.map +1 -1
  159. package/lib/network/core/types.d.ts +5 -1
  160. package/lib/network/events.d.ts +3 -1
  161. package/lib/network/events.js.map +1 -1
  162. package/lib/network/gossip/interface.d.ts +8 -1
  163. package/lib/network/gossip/interface.js +1 -0
  164. package/lib/network/gossip/interface.js.map +1 -1
  165. package/lib/network/gossip/topic.d.ts +1419 -1374
  166. package/lib/network/gossip/topic.js +20 -1
  167. package/lib/network/gossip/topic.js.map +1 -1
  168. package/lib/network/interface.d.ts +13 -1
  169. package/lib/network/libp2p/index.js +1 -1
  170. package/lib/network/libp2p/index.js.map +1 -1
  171. package/lib/network/metadata.d.ts +10 -6
  172. package/lib/network/metadata.js +23 -4
  173. package/lib/network/metadata.js.map +1 -1
  174. package/lib/network/network.d.ts +12 -2
  175. package/lib/network/network.js +59 -7
  176. package/lib/network/network.js.map +1 -1
  177. package/lib/network/networkConfig.d.ts +23 -0
  178. package/lib/network/networkConfig.js +32 -0
  179. package/lib/network/networkConfig.js.map +1 -0
  180. package/lib/network/options.d.ts +18 -0
  181. package/lib/network/options.js +2 -0
  182. package/lib/network/options.js.map +1 -1
  183. package/lib/network/peers/discover.d.ts +15 -6
  184. package/lib/network/peers/discover.js +139 -15
  185. package/lib/network/peers/discover.js.map +1 -1
  186. package/lib/network/peers/peerManager.d.ts +11 -2
  187. package/lib/network/peers/peerManager.js +119 -11
  188. package/lib/network/peers/peerManager.js.map +1 -1
  189. package/lib/network/peers/peersData.d.ts +9 -2
  190. package/lib/network/peers/peersData.js.map +1 -1
  191. package/lib/network/peers/score/interface.d.ts +2 -2
  192. package/lib/network/peers/score/interface.js.map +1 -1
  193. package/lib/network/peers/score/score.d.ts +2 -2
  194. package/lib/network/peers/score/score.js +4 -1
  195. package/lib/network/peers/score/score.js.map +1 -1
  196. package/lib/network/peers/score/store.d.ts +5 -2
  197. package/lib/network/peers/score/store.js +7 -3
  198. package/lib/network/peers/score/store.js.map +1 -1
  199. package/lib/network/peers/utils/prioritizePeers.d.ts +36 -5
  200. package/lib/network/peers/utils/prioritizePeers.js +79 -7
  201. package/lib/network/peers/utils/prioritizePeers.js.map +1 -1
  202. package/lib/network/processor/extractSlotRootFns.js +8 -1
  203. package/lib/network/processor/extractSlotRootFns.js.map +1 -1
  204. package/lib/network/processor/gossipHandlers.js +157 -9
  205. package/lib/network/processor/gossipHandlers.js.map +1 -1
  206. package/lib/network/processor/gossipQueues/index.js +5 -0
  207. package/lib/network/processor/gossipQueues/index.js.map +1 -1
  208. package/lib/network/processor/index.d.ts +1 -1
  209. package/lib/network/processor/index.js +5 -1
  210. package/lib/network/processor/index.js.map +1 -1
  211. package/lib/network/reqresp/ReqRespBeaconNode.js +23 -5
  212. package/lib/network/reqresp/ReqRespBeaconNode.js.map +1 -1
  213. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.d.ts +14 -5
  214. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.js +199 -14
  215. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.js.map +1 -1
  216. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.d.ts +32 -5
  217. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.js +280 -26
  218. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.js.map +1 -1
  219. package/lib/network/reqresp/handlers/beaconBlocksByRange.d.ts +1 -1
  220. package/lib/network/reqresp/handlers/beaconBlocksByRange.js.map +1 -1
  221. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts +8 -0
  222. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js +106 -0
  223. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js.map +1 -0
  224. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.d.ts +6 -0
  225. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js +57 -0
  226. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js.map +1 -0
  227. package/lib/network/reqresp/handlers/index.js +10 -0
  228. package/lib/network/reqresp/handlers/index.js.map +1 -1
  229. package/lib/network/reqresp/protocols.d.ts +3 -0
  230. package/lib/network/reqresp/protocols.js +15 -0
  231. package/lib/network/reqresp/protocols.js.map +1 -1
  232. package/lib/network/reqresp/rateLimit.js +11 -1
  233. package/lib/network/reqresp/rateLimit.js.map +1 -1
  234. package/lib/network/reqresp/types.d.ts +13 -6
  235. package/lib/network/reqresp/types.js +9 -2
  236. package/lib/network/reqresp/types.js.map +1 -1
  237. package/lib/network/subnets/interface.d.ts +3 -0
  238. package/lib/network/subnets/interface.js +14 -1
  239. package/lib/network/subnets/interface.js.map +1 -1
  240. package/lib/network/subnets/syncnetsService.js +4 -5
  241. package/lib/network/subnets/syncnetsService.js.map +1 -1
  242. package/lib/node/nodejs.js +4 -3
  243. package/lib/node/nodejs.js.map +1 -1
  244. package/lib/sync/interface.d.ts +2 -2
  245. package/lib/sync/interface.js +1 -1
  246. package/lib/sync/interface.js.map +1 -1
  247. package/lib/sync/range/batch.d.ts +8 -2
  248. package/lib/sync/range/batch.js +19 -7
  249. package/lib/sync/range/batch.js.map +1 -1
  250. package/lib/sync/range/chain.d.ts +7 -2
  251. package/lib/sync/range/chain.js +45 -21
  252. package/lib/sync/range/chain.js.map +1 -1
  253. package/lib/sync/range/range.js +3 -3
  254. package/lib/sync/range/range.js.map +1 -1
  255. package/lib/sync/range/utils/peerBalancer.d.ts +4 -1
  256. package/lib/sync/range/utils/peerBalancer.js +20 -2
  257. package/lib/sync/range/utils/peerBalancer.js.map +1 -1
  258. package/lib/sync/unknownBlock.d.ts +8 -1
  259. package/lib/sync/unknownBlock.js +222 -62
  260. package/lib/sync/unknownBlock.js.map +1 -1
  261. package/lib/util/blobs.d.ts +13 -1
  262. package/lib/util/blobs.js +44 -1
  263. package/lib/util/blobs.js.map +1 -1
  264. package/lib/util/dataColumns.d.ts +111 -0
  265. package/lib/util/dataColumns.js +277 -0
  266. package/lib/util/dataColumns.js.map +1 -0
  267. package/lib/util/kzg.d.ts +9 -21
  268. package/lib/util/kzg.js +12 -90
  269. package/lib/util/kzg.js.map +1 -1
  270. package/lib/util/metadata.d.ts +4 -0
  271. package/lib/util/metadata.js +7 -0
  272. package/lib/util/metadata.js.map +1 -1
  273. package/lib/util/sszBytes.d.ts +1 -0
  274. package/lib/util/sszBytes.js +17 -0
  275. package/lib/util/sszBytes.js.map +1 -1
  276. package/package.json +22 -22
@@ -1,12 +1,14 @@
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 { BlobsSource, BlockInputType, BlockSource, DataColumnsSource, getBlockInput, getBlockInputDataColumns, } from "../../chain/blocks/types.js";
5
+ import { getEmptyBlockInputCacheEntry } from "../../chain/seenCache/seenGossipBlockInput.js";
6
+ export async function beaconBlocksMaybeBlobsByRange(config, network, peerId, request, currentEpoch, partialDownload, peerClient, logger) {
5
7
  // Code below assumes the request is in the same epoch
6
8
  // Range sync satisfies this condition, but double check here for sanity
7
9
  const { startSlot, count } = request;
8
10
  if (count < 1) {
9
- return [];
11
+ return { blocks: [], pendingDataColumns: null };
10
12
  }
11
13
  const endSlot = startSlot + count - 1;
12
14
  const startEpoch = computeEpochAtSlot(startSlot);
@@ -14,23 +16,83 @@ export async function beaconBlocksMaybeBlobsByRange(config, network, peerId, req
14
16
  if (startEpoch !== endEpoch) {
15
17
  throw Error(`BeaconBlocksByRangeRequest must be in the same epoch startEpoch=${startEpoch} != endEpoch=${endEpoch}`);
16
18
  }
19
+ const forkSeq = config.getForkSeq(startSlot);
17
20
  // 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));
21
+ if (forkSeq < ForkSeq.deneb) {
22
+ const beaconBlocks = await network.sendBeaconBlocksByRange(peerId, request);
23
+ const blocks = beaconBlocks.map((block) => getBlockInput.preData(config, block.data, BlockSource.byRange));
24
+ return { blocks, pendingDataColumns: null };
21
25
  }
22
26
  // From Deneb
23
27
  // Only request blobs if they are recent enough
24
28
  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),
29
+ if (forkSeq < ForkSeq.fulu) {
30
+ const [allBlocks, allBlobSidecars] = await Promise.all([
31
+ network.sendBeaconBlocksByRange(peerId, request),
32
+ network.sendBlobSidecarsByRange(peerId, request),
33
+ ]);
34
+ const blocks = matchBlockWithBlobs(config, allBlocks, allBlobSidecars, endSlot, BlockSource.byRange, BlobsSource.byRange);
35
+ return { blocks, pendingDataColumns: null };
36
+ }
37
+ // get columns
38
+ const sampledColumns = network.custodyConfig.sampledColumns;
39
+ const neededColumns = partialDownload ? partialDownload.pendingDataColumns : sampledColumns;
40
+ const peerColumns = network.getConnectedPeerCustody(peerId);
41
+ // get match
42
+ const columns = peerColumns.reduce((acc, elem) => {
43
+ if (neededColumns.includes(elem)) {
44
+ acc.push(elem);
45
+ }
46
+ return acc;
47
+ }, []);
48
+ if (columns.length === 0 && partialDownload !== null) {
49
+ // this peer has nothing to offer and should not have been selected for batch download
50
+ // throw error?
51
+ return partialDownload;
52
+ }
53
+ const pendingDataColumns = neededColumns.reduce((acc, elem) => {
54
+ if (!columns.includes(elem)) {
55
+ acc.push(elem);
56
+ }
57
+ return acc;
58
+ }, []);
59
+ const dataColumnRequest = { ...request, columns };
60
+ const [allBlocks, allDataColumnSidecars] = await Promise.all([
61
+ // TODO-das: investigate why partialDownload blocks is empty here
62
+ partialDownload && partialDownload.blocks.length > 0
63
+ ? partialDownload.blocks.map((blockInput) => ({ data: blockInput.block }))
64
+ : network.sendBeaconBlocksByRange(peerId, request),
65
+ columns.length === 0 ? [] : network.sendDataColumnSidecarsByRange(peerId, dataColumnRequest),
28
66
  ]);
29
- return matchBlockWithBlobs(config, allBlocks, allBlobSidecars, endSlot, BlockSource.byRange, BlobsSource.byRange);
67
+ logger?.debug("ByRange requests", {
68
+ beaconBlocksRequest: JSON.stringify(ssz.phase0.BeaconBlocksByRangeRequest.toJson(request)),
69
+ dataColumnRequest: JSON.stringify(ssz.fulu.DataColumnSidecarsByRangeRequest.toJson(dataColumnRequest)),
70
+ [`allBlocks(${allBlocks.length})`]: allBlocks.map((blk) => blk.data.message.slot).join(" "),
71
+ [`allDataColumnSidecars(${allDataColumnSidecars.length})`]: allDataColumnSidecars
72
+ .map((dCol) => `${dCol.signedBlockHeader.message.slot}:${dCol.index}`)
73
+ .join(" "),
74
+ peerColumns: peerColumns.join(" "),
75
+ peerId,
76
+ peerClient,
77
+ prevPartialDownload: !!partialDownload,
78
+ });
79
+ const blocks = matchBlockWithDataColumns(network, peerId, config, sampledColumns, columns, allBlocks, allDataColumnSidecars, endSlot, BlockSource.byRange, DataColumnsSource.byRange, partialDownload, peerClient, logger);
80
+ return { blocks, pendingDataColumns: pendingDataColumns.length > 0 ? pendingDataColumns : null };
30
81
  }
82
+ logger?.verbose(`Download range is out of ${config.MIN_EPOCHS_FOR_BLOB_SIDECARS_REQUESTS} epochs, skip Blobs and DataColumnSidecars download`, {
83
+ startEpoch,
84
+ startSlot,
85
+ endSlot,
86
+ currentEpoch,
87
+ });
31
88
  // Data is out of range, only request blocks
32
89
  const blocks = await network.sendBeaconBlocksByRange(peerId, request);
33
- return blocks.map((block) => getBlockInput.outOfRangeData(config, block.data, BlockSource.byRange));
90
+ return {
91
+ blocks: blocks.map((block) => getBlockInput.outOfRangeData(config, block.data, BlockSource.byRange)),
92
+ // TODO: (@matthewkeil) this was a merge conflict when rebased on electra. Should this be a null or an empty array? Should it
93
+ // depend on which fork we are in? Need to revisit
94
+ pendingDataColumns: null,
95
+ };
34
96
  }
35
97
  // Assumes that the blobs are in the same sequence as blocks, doesn't require block to be sorted
36
98
  export function matchBlockWithBlobs(config, allBlocks, allBlobSidecars, endSlot, blockSource, blobsSource) {
@@ -68,7 +130,6 @@ export function matchBlockWithBlobs(config, allBlocks, allBlobSidecars, endSlot,
68
130
  blobs: blobSidecars,
69
131
  blobsSource,
70
132
  };
71
- // TODO DENEB: instead of null, pass payload in bytes
72
133
  blockInputs.push(getBlockInput.availableData(config, block.data, blockSource, blockData));
73
134
  }
74
135
  }
@@ -80,8 +141,132 @@ export function matchBlockWithBlobs(config, allBlocks, allBlobSidecars, endSlot,
80
141
  throw Error(`Unmatched blobSidecars, blocks=${allBlocks.length}, blobs=${allBlobSidecars.length} lastMatchedSlot=${lastMatchedSlot}, pending blobSidecars slots=${allBlobSidecars
81
142
  .slice(blobSideCarIndex)
82
143
  .map((blb) => blb.signedBlockHeader.message.slot)
83
- .join(",")}`);
144
+ .join(" ")}`);
145
+ }
146
+ return blockInputs;
147
+ }
148
+ export function matchBlockWithDataColumns(_network, peerId, config, sampledColumns, requestedColumns, allBlocks, allDataColumnSidecars, endSlot, blockSource, dataColumnsSource, prevPartialDownload, peerClient, logger) {
149
+ const blockInputs = [];
150
+ let dataColumnSideCarIndex = 0;
151
+ let lastMatchedSlot = -1;
152
+ const neededColumns = prevPartialDownload?.pendingDataColumns ?? sampledColumns;
153
+ const shouldHaveAllData = neededColumns.reduce((acc, elem) => acc && requestedColumns.includes(elem), true);
154
+ // Match dataColumnSideCar with the block as some blocks would have no dataColumns and hence
155
+ // would be omitted from the response. If there are any inconsitencies in the
156
+ // response, the validations during import will reject the block and hence this
157
+ // entire segment.
158
+ //
159
+ // Assuming that the blocks and blobs will come in same sorted order
160
+ for (let i = 0; i < allBlocks.length; i++) {
161
+ const block = allBlocks[i];
162
+ const forkSeq = config.getForkSeq(block.data.message.slot);
163
+ if (forkSeq < ForkSeq.fulu) {
164
+ throw Error(`Invalid block forkSeq=${forkSeq} < ForSeq.fulu for matchBlockWithDataColumns`);
165
+ }
166
+ const dataColumnSidecars = [];
167
+ while (allDataColumnSidecars[dataColumnSideCarIndex]?.signedBlockHeader.message.slot === block.data.message.slot) {
168
+ dataColumnSidecars.push(allDataColumnSidecars[dataColumnSideCarIndex]);
169
+ lastMatchedSlot = block.data.message.slot;
170
+ dataColumnSideCarIndex++;
171
+ }
172
+ const blobKzgCommitmentsLen = block.data.message.body.blobKzgCommitments.length;
173
+ logger?.debug("processing matchBlockWithDataColumns", {
174
+ blobKzgCommitmentsLen,
175
+ dataColumnSidecars: dataColumnSidecars.length,
176
+ shouldHaveAllData,
177
+ neededColumns: neededColumns.join(" "),
178
+ requestedColumns: requestedColumns.join(" "),
179
+ slot: block.data.message.slot,
180
+ dataColumnsSlots: dataColumnSidecars.map((dcm) => dcm.signedBlockHeader.message.slot).join(" "),
181
+ peerClient,
182
+ });
183
+ if (blobKzgCommitmentsLen === 0) {
184
+ if (dataColumnSidecars.length > 0) {
185
+ throw Error(`Missing or mismatching dataColumnSidecars from peerId=${peerId} for blockSlot=${block.data.message.slot} with blobKzgCommitmentsLen=0 dataColumnSidecars=${dataColumnSidecars.length}>0`);
186
+ }
187
+ const blockData = {
188
+ fork: config.getForkName(block.data.message.slot),
189
+ dataColumns: [],
190
+ dataColumnsBytes: [],
191
+ dataColumnsSource,
192
+ };
193
+ blockInputs.push(getBlockInput.availableData(config, block.data, blockSource, blockData));
194
+ }
195
+ else {
196
+ // Quick inspect how many blobSidecars was expected
197
+ const dataColumnIndexes = dataColumnSidecars.map((dataColumnSidecar) => dataColumnSidecar.index);
198
+ const requestedColumnsPresent = requestedColumns.reduce((acc, columnIndex) => acc && dataColumnIndexes.includes(columnIndex), true);
199
+ logger?.debug("matchBlockWithDataColumns2", {
200
+ dataColumnIndexes: dataColumnIndexes.join(" "),
201
+ requestedColumnsPresent,
202
+ slot: block.data.message.slot,
203
+ peerClient,
204
+ });
205
+ if (dataColumnSidecars.length !== requestedColumns.length || !requestedColumnsPresent) {
206
+ 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(" ")}`, {
207
+ allBlocks: allBlocks.length,
208
+ allDataColumnSidecars: allDataColumnSidecars.length,
209
+ peerId,
210
+ blobKzgCommitmentsLen,
211
+ peerClient,
212
+ });
213
+ 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(" ")}`);
214
+ }
215
+ let cachedData;
216
+ // TODO-das: investigate why partialDownload blocks is empty here
217
+ if (prevPartialDownload !== null && prevPartialDownload.blocks.length > 0) {
218
+ const prevBlockInput = prevPartialDownload.blocks[i];
219
+ if (prevBlockInput.type !== BlockInputType.dataPromise) {
220
+ throw Error(`prevBlockInput.type=${prevBlockInput.type} in prevPartialDownload`);
221
+ }
222
+ cachedData = prevBlockInput.cachedData;
223
+ }
224
+ else {
225
+ // biome-ignore lint/style/noNonNullAssertion: checked below for validity
226
+ cachedData = getEmptyBlockInputCacheEntry(config.getForkName(block.data.message.slot), -1).cachedData;
227
+ if (cachedData === undefined) {
228
+ throw Error("Invalid cachedData=undefined from getEmptyBlockInputCacheEntry");
229
+ }
230
+ }
231
+ if (cachedData.fork !== ForkName.fulu) {
232
+ throw Error("Invalid fork for cachedData on dataColumns");
233
+ }
234
+ for (const dataColumnSidecar of dataColumnSidecars) {
235
+ cachedData.dataColumnsCache.set(dataColumnSidecar.index, {
236
+ dataColumn: dataColumnSidecar,
237
+ dataColumnBytes: null,
238
+ });
239
+ }
240
+ if (shouldHaveAllData) {
241
+ const { dataColumns, dataColumnsBytes } = getBlockInputDataColumns(cachedData.dataColumnsCache, sampledColumns);
242
+ const blockData = {
243
+ fork: config.getForkName(block.data.message.slot),
244
+ dataColumns,
245
+ dataColumnsBytes,
246
+ dataColumnsSource,
247
+ };
248
+ // TODO DENEB: instead of null, pass payload in bytes
249
+ blockInputs.push(getBlockInput.availableData(config, block.data, blockSource, blockData));
250
+ }
251
+ else {
252
+ blockInputs.push(getBlockInput.dataPromise(config, block.data, blockSource, cachedData));
253
+ }
254
+ }
255
+ }
256
+ // If there are still unconsumed blobs this means that the response was inconsistent
257
+ // and matching was wrong and hence we should throw error
258
+ if (allDataColumnSidecars[dataColumnSideCarIndex] !== undefined &&
259
+ // If there are no data columns, the data columns request can give 1 block outside the requested range
260
+ allDataColumnSidecars[dataColumnSideCarIndex].signedBlockHeader.message.slot <= endSlot) {
261
+ throw Error(`Unmatched blobSidecars, blocks=${allBlocks.length}, blobs=${allDataColumnSidecars.length} lastMatchedSlot=${lastMatchedSlot}, pending blobSidecars slots=${allDataColumnSidecars
262
+ .slice(dataColumnSideCarIndex)
263
+ .map((blb) => blb.signedBlockHeader.message.slot)
264
+ .join(" ")}`);
84
265
  }
266
+ logger?.debug("matched BlockWithDataColumns", {
267
+ peerClient,
268
+ blockInputs: blockInputs.map((bInpt) => `${bInpt.block.message.slot}=${bInpt.type}`).join(" "),
269
+ });
85
270
  return blockInputs;
86
271
  }
87
272
  //# sourceMappingURL=beaconBlocksMaybeBlobsByRange.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"beaconBlocksMaybeBlobsByRange.js","sourceRoot":"","sources":["../../../src/network/reqresp/beaconBlocksMaybeBlobsByRange.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,OAAO,EAAC,MAAM,kBAAkB,CAAC;AACzC,OAAO,EAAC,kBAAkB,EAAC,MAAM,4BAA4B,CAAC;AAG9D,OAAO,EAAC,WAAW,EAAmC,WAAW,EAAE,aAAa,EAAC,MAAM,6BAA6B,CAAC;AAIrH,MAAM,CAAC,KAAK,UAAU,6BAA6B,CACjD,MAAuB,EACvB,OAAiB,EACjB,MAAiB,EACjB,OAA0C,EAC1C,YAAmB;IAEnB,sDAAsD;IACtD,wEAAwE;IACxE,MAAM,EAAC,SAAS,EAAE,KAAK,EAAC,GAAG,OAAO,CAAC;IACnC,IAAI,KAAK,GAAG,CAAC,EAAE,CAAC;QACd,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,MAAM,OAAO,GAAG,SAAS,GAAG,KAAK,GAAG,CAAC,CAAC;IAEtC,MAAM,UAAU,GAAG,kBAAkB,CAAC,SAAS,CAAC,CAAC;IACjD,MAAM,QAAQ,GAAG,kBAAkB,CAAC,OAAO,CAAC,CAAC;IAC7C,IAAI,UAAU,KAAK,QAAQ,EAAE,CAAC;QAC5B,MAAM,KAAK,CACT,mEAAmE,UAAU,gBAAgB,QAAQ,EAAE,CACxG,CAAC;IACJ,CAAC;IAED,6CAA6C;IAC7C,IAAI,MAAM,CAAC,UAAU,CAAC,SAAS,CAAC,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;QACjD,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,uBAAuB,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QACtE,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,EAAE,KAAK,CAAC,IAAI,EAAE,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC;IAC/F,CAAC;IAED,aAAa;IACb,+CAA+C;IAC/C,IAAI,UAAU,IAAI,YAAY,GAAG,MAAM,CAAC,qCAAqC,EAAE,CAAC;QAC9E,MAAM,CAAC,SAAS,EAAE,eAAe,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;YACrD,OAAO,CAAC,uBAAuB,CAAC,MAAM,EAAE,OAAO,CAAC;YAChD,OAAO,CAAC,uBAAuB,CAAC,MAAM,EAAE,OAAO,CAAC;SACjD,CAAC,CAAC;QAEH,OAAO,mBAAmB,CAAC,MAAM,EAAE,SAAS,EAAE,eAAe,EAAE,OAAO,EAAE,WAAW,CAAC,OAAO,EAAE,WAAW,CAAC,OAAO,CAAC,CAAC;IACpH,CAAC;IAED,4CAA4C;IAC5C,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,uBAAuB,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACtE,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,aAAa,CAAC,cAAc,CAAC,MAAM,EAAE,KAAK,CAAC,IAAI,EAAE,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC;AACtG,CAAC;AAED,gGAAgG;AAChG,MAAM,UAAU,mBAAmB,CACjC,MAAuB,EACvB,SAAyC,EACzC,eAAoC,EACpC,OAAa,EACb,WAAwB,EACxB,WAAwB;IAExB,MAAM,WAAW,GAAiB,EAAE,CAAC;IACrC,IAAI,gBAAgB,GAAG,CAAC,CAAC;IACzB,IAAI,eAAe,GAAG,CAAC,CAAC,CAAC;IAEzB,gFAAgF;IAChF,6EAA6E;IAC7E,+EAA+E;IAC/E,kBAAkB;IAClB,EAAE;IACF,oEAAoE;IACpE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QAC1C,MAAM,KAAK,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;QAC3B,IAAI,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;YAC/D,WAAW,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,EAAE,KAAK,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC;QAC3E,CAAC;aAAM,CAAC;YACN,MAAM,YAAY,GAAwB,EAAE,CAAC;YAE7C,IAAI,WAA8B,CAAC;YACnC;YACE,oEAAoE;YACpE,CAAC,WAAW,GAAG,eAAe,CAAC,gBAAgB,CAAC,CAAC,EAAE,iBAAiB,CAAC,OAAO,CAAC,IAAI,KAAK,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAC7G,CAAC;gBACD,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;gBAC/B,eAAe,GAAG,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;gBAC1C,gBAAgB,EAAE,CAAC;YACrB,CAAC;YAED,mDAAmD;YACnD,MAAM,qBAAqB,GAAI,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,IAA8B,CAAC,kBAAkB,CAAC,MAAM,CAAC;YAC3G,IAAI,qBAAqB,KAAK,YAAY,CAAC,MAAM,EAAE,CAAC;gBAClD,MAAM,KAAK,CACT,sCAAsC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,+BAA+B,qBAAqB,iBAAiB,YAAY,CAAC,MAAM,EAAE,CACxJ,CAAC;YACJ,CAAC;YAED,MAAM,SAAS,GAAG;gBAChB,IAAI,EAAE,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;gBACjD,KAAK,EAAE,YAAY;gBACnB,WAAW;aACW,CAAC;YAEzB,qDAAqD;YACrD,WAAW,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,MAAM,EAAE,KAAK,CAAC,IAAI,EAAE,WAAW,EAAE,SAAS,CAAC,CAAC,CAAC;QAC5F,CAAC;IACH,CAAC;IAED,oFAAoF;IACpF,yDAAyD;IACzD,IACE,eAAe,CAAC,gBAAgB,CAAC,KAAK,SAAS;QAC/C,wFAAwF;QACxF,eAAe,CAAC,gBAAgB,CAAC,CAAC,iBAAiB,CAAC,OAAO,CAAC,IAAI,IAAI,OAAO,EAC3E,CAAC;QACD,MAAM,KAAK,CACT,kCAAkC,SAAS,CAAC,MAAM,WAChD,eAAe,CAAC,MAClB,oBAAoB,eAAe,gCAAgC,eAAe;aAC/E,KAAK,CAAC,gBAAgB,CAAC;aACvB,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,iBAAiB,CAAC,OAAO,CAAC,IAAI,CAAC;aAChD,IAAI,CAAC,GAAG,CAAC,EAAE,CACf,CAAC;IACJ,CAAC;IACD,OAAO,WAAW,CAAC;AACrB,CAAC"}
1
+ {"version":3,"file":"beaconBlocksMaybeBlobsByRange.js","sourceRoot":"","sources":["../../../src/network/reqresp/beaconBlocksMaybeBlobsByRange.ts"],"names":[],"mappings":"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"}
@@ -1,16 +1,43 @@
1
1
  import { ChainForkConfig } from "@lodestar/config";
2
- import { RootHex, phase0 } from "@lodestar/types";
2
+ import { RootHex, SignedBeaconBlock, phase0 } 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";
6
+ import { ChainEventEmitter } from "../../chain/emitter.js";
5
7
  import { IExecutionEngine } from "../../execution/index.js";
6
8
  import { Metrics } from "../../metrics/index.js";
7
9
  import { PeerIdStr } from "../../util/peerId.js";
8
10
  import { INetwork } from "../interface.js";
9
- export declare function beaconBlocksMaybeBlobsByRoot(config: ChainForkConfig, network: INetwork, peerId: PeerIdStr, request: phase0.BeaconBlocksByRootRequest): Promise<BlockInput[]>;
10
- export declare function unavailableBeaconBlobsByRoot(config: ChainForkConfig, network: INetwork, peerId: PeerIdStr, unavailableBlockInput: BlockInput | NullBlockInput, opts: {
11
- metrics: Metrics | null;
11
+ import { PartialDownload } from "./beaconBlocksMaybeBlobsByRange.js";
12
+ export declare function beaconBlocksMaybeBlobsByRoot(config: ChainForkConfig, network: INetwork, peerId: PeerIdStr, request: phase0.BeaconBlocksByRootRequest, partialDownload: null | PartialDownload, peerClient: string, logger?: Logger): Promise<{
13
+ blocks: BlockInput[];
14
+ pendingDataColumns: null | number[];
15
+ }>;
16
+ export declare function unavailableBeaconBlobsByRoot(config: ChainForkConfig, network: INetwork, peerId: PeerIdStr, peerClient: string, unavailableBlockInput: BlockInput | NullBlockInput, opts: {
17
+ logger?: Logger;
18
+ metrics?: Metrics | null;
12
19
  executionEngine: IExecutionEngine;
20
+ emitter: ChainEventEmitter;
13
21
  engineGetBlobsCache?: Map<RootHex, BlobAndProof | null>;
14
22
  blockInputsRetryTrackerCache?: Set<RootHex>;
15
23
  }): Promise<BlockInput>;
24
+ export declare function unavailableBeaconBlobsByRootPreFulu(config: ChainForkConfig, network: INetwork, peerId: PeerIdStr, unavailableBlockInput: BlockInput | NullBlockInput, block: SignedBeaconBlock, cachedData: CachedBlobs, opts: {
25
+ metrics?: Metrics | null;
26
+ executionEngine: IExecutionEngine;
27
+ engineGetBlobsCache?: Map<RootHex, BlobAndProof | null>;
28
+ blockInputsRetryTrackerCache?: Set<RootHex>;
29
+ }): Promise<BlockInput>;
30
+ /**
31
+ * Download more columns for a BlockInput
32
+ * - unavailableBlockInput should have block, but not enough blobs (deneb) or data columns (fulu)
33
+ *
34
+ * This function may return data promise, and consumer should continue with fetching more blobs or columns from other peers
35
+ * see UnknownBlockSync.fetchUnavailableBlockInput()
36
+ */
37
+ export declare function unavailableBeaconBlobsByRootPostFulu(config: ChainForkConfig, network: INetwork, peerId: PeerIdStr, peerClient: string, unavailableBlockInput: BlockInput, block: SignedBeaconBlock, cachedData: NullBlockInput["cachedData"], opts: {
38
+ metrics?: Metrics | null;
39
+ executionEngine: IExecutionEngine;
40
+ emitter: ChainEventEmitter;
41
+ logger?: Logger;
42
+ }): Promise<BlockInput>;
16
43
  //# sourceMappingURL=beaconBlocksMaybeBlobsByRoot.d.ts.map