@lodestar/beacon-node 1.29.0-dev.f87bd54721 → 1.29.0-peerDAS.97104b75a4

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 (232) hide show
  1. package/lib/api/impl/beacon/blocks/index.js +37 -14
  2. package/lib/api/impl/beacon/blocks/index.js.map +1 -1
  3. package/lib/api/impl/beacon/pool/index.js +1 -1
  4. package/lib/api/impl/beacon/pool/index.js.map +1 -1
  5. package/lib/api/impl/beacon/state/index.js +0 -12
  6. package/lib/api/impl/beacon/state/index.js.map +1 -1
  7. package/lib/api/impl/validator/index.js +4 -14
  8. package/lib/api/impl/validator/index.js.map +1 -1
  9. package/lib/chain/archiveStore/historicalState/worker.js +0 -12
  10. package/lib/chain/archiveStore/historicalState/worker.js.map +1 -1
  11. package/lib/chain/archiveStore/utils/archiveBlocks.js +56 -21
  12. package/lib/chain/archiveStore/utils/archiveBlocks.js.map +1 -1
  13. package/lib/chain/beaconProposerCache.d.ts +1 -0
  14. package/lib/chain/beaconProposerCache.js +3 -0
  15. package/lib/chain/beaconProposerCache.js.map +1 -1
  16. package/lib/chain/blocks/importBlock.js +56 -14
  17. package/lib/chain/blocks/importBlock.js.map +1 -1
  18. package/lib/chain/blocks/types.d.ts +67 -26
  19. package/lib/chain/blocks/types.js +39 -6
  20. package/lib/chain/blocks/types.js.map +1 -1
  21. package/lib/chain/blocks/verifyBlocksDataAvailability.js +21 -10
  22. package/lib/chain/blocks/verifyBlocksDataAvailability.js.map +1 -1
  23. package/lib/chain/blocks/writeBlockInputToDb.js +88 -15
  24. package/lib/chain/blocks/writeBlockInputToDb.js.map +1 -1
  25. package/lib/chain/chain.d.ts +28 -1
  26. package/lib/chain/chain.js +22 -7
  27. package/lib/chain/chain.js.map +1 -1
  28. package/lib/chain/emitter.d.ts +18 -2
  29. package/lib/chain/emitter.js +13 -0
  30. package/lib/chain/emitter.js.map +1 -1
  31. package/lib/chain/errors/dataColumnSidecarError.d.ts +27 -0
  32. package/lib/chain/errors/dataColumnSidecarError.js +12 -0
  33. package/lib/chain/errors/dataColumnSidecarError.js.map +1 -0
  34. package/lib/chain/errors/index.d.ts +1 -0
  35. package/lib/chain/errors/index.js +1 -0
  36. package/lib/chain/errors/index.js.map +1 -1
  37. package/lib/chain/interface.d.ts +2 -0
  38. package/lib/chain/interface.js.map +1 -1
  39. package/lib/chain/opPools/aggregatedAttestationPool.d.ts +6 -4
  40. package/lib/chain/opPools/aggregatedAttestationPool.js +48 -76
  41. package/lib/chain/opPools/aggregatedAttestationPool.js.map +1 -1
  42. package/lib/chain/opPools/attestationPool.d.ts +2 -4
  43. package/lib/chain/opPools/attestationPool.js +3 -4
  44. package/lib/chain/opPools/attestationPool.js.map +1 -1
  45. package/lib/chain/options.d.ts +3 -0
  46. package/lib/chain/options.js +4 -0
  47. package/lib/chain/options.js.map +1 -1
  48. package/lib/chain/seenCache/seenGossipBlockInput.d.ts +55 -18
  49. package/lib/chain/seenCache/seenGossipBlockInput.js +293 -51
  50. package/lib/chain/seenCache/seenGossipBlockInput.js.map +1 -1
  51. package/lib/chain/validation/dataColumnSidecar.d.ts +8 -0
  52. package/lib/chain/validation/dataColumnSidecar.js +91 -0
  53. package/lib/chain/validation/dataColumnSidecar.js.map +1 -0
  54. package/lib/db/beacon.d.ts +3 -1
  55. package/lib/db/beacon.js +3 -1
  56. package/lib/db/beacon.js.map +1 -1
  57. package/lib/db/buckets.d.ts +3 -1
  58. package/lib/db/buckets.js +2 -0
  59. package/lib/db/buckets.js.map +1 -1
  60. package/lib/db/interface.d.ts +3 -1
  61. package/lib/db/repositories/dataColumnSidecars.d.ts +47 -0
  62. package/lib/db/repositories/dataColumnSidecars.js +40 -0
  63. package/lib/db/repositories/dataColumnSidecars.js.map +1 -0
  64. package/lib/db/repositories/dataColumnSidecarsArchive.d.ts +15 -0
  65. package/lib/db/repositories/dataColumnSidecarsArchive.js +23 -0
  66. package/lib/db/repositories/dataColumnSidecarsArchive.js.map +1 -0
  67. package/lib/db/repositories/index.d.ts +2 -0
  68. package/lib/db/repositories/index.js +2 -0
  69. package/lib/db/repositories/index.js.map +1 -1
  70. package/lib/execution/engine/http.d.ts +5 -3
  71. package/lib/execution/engine/http.js +48 -24
  72. package/lib/execution/engine/http.js.map +1 -1
  73. package/lib/execution/engine/interface.d.ts +4 -2
  74. package/lib/execution/engine/interface.js +1 -1
  75. package/lib/execution/engine/interface.js.map +1 -1
  76. package/lib/execution/engine/mock.d.ts +1 -0
  77. package/lib/execution/engine/mock.js +4 -0
  78. package/lib/execution/engine/mock.js.map +1 -1
  79. package/lib/execution/engine/types.d.ts +8 -0
  80. package/lib/execution/engine/types.js +6 -0
  81. package/lib/execution/engine/types.js.map +1 -1
  82. package/lib/metrics/metrics/beacon.d.ts +7 -0
  83. package/lib/metrics/metrics/beacon.js +23 -0
  84. package/lib/metrics/metrics/beacon.js.map +1 -1
  85. package/lib/metrics/metrics/lodestar.d.ts +10 -21
  86. package/lib/metrics/metrics/lodestar.js +28 -64
  87. package/lib/metrics/metrics/lodestar.js.map +1 -1
  88. package/lib/metrics/validatorMonitor.js +1 -1
  89. package/lib/metrics/validatorMonitor.js.map +1 -1
  90. package/lib/network/core/metrics.d.ts +14 -4
  91. package/lib/network/core/metrics.js +23 -0
  92. package/lib/network/core/metrics.js.map +1 -1
  93. package/lib/network/core/networkCore.d.ts +9 -3
  94. package/lib/network/core/networkCore.js +23 -17
  95. package/lib/network/core/networkCore.js.map +1 -1
  96. package/lib/network/core/networkCoreWorker.js +5 -5
  97. package/lib/network/core/networkCoreWorker.js.map +1 -1
  98. package/lib/network/core/networkCoreWorkerHandler.d.ts +4 -2
  99. package/lib/network/core/networkCoreWorkerHandler.js +10 -3
  100. package/lib/network/core/networkCoreWorkerHandler.js.map +1 -1
  101. package/lib/network/core/types.d.ts +5 -1
  102. package/lib/network/discv5/index.d.ts +3 -2
  103. package/lib/network/discv5/index.js +5 -4
  104. package/lib/network/discv5/index.js.map +1 -1
  105. package/lib/network/discv5/types.d.ts +1 -1
  106. package/lib/network/discv5/worker.js +6 -7
  107. package/lib/network/discv5/worker.js.map +1 -1
  108. package/lib/network/events.d.ts +3 -1
  109. package/lib/network/events.js.map +1 -1
  110. package/lib/network/gossip/gossipsub.js +0 -4
  111. package/lib/network/gossip/gossipsub.js.map +1 -1
  112. package/lib/network/gossip/interface.d.ts +8 -1
  113. package/lib/network/gossip/interface.js +1 -0
  114. package/lib/network/gossip/interface.js.map +1 -1
  115. package/lib/network/gossip/topic.d.ts +1189 -1289
  116. package/lib/network/gossip/topic.js +20 -1
  117. package/lib/network/gossip/topic.js.map +1 -1
  118. package/lib/network/interface.d.ts +17 -4
  119. package/lib/network/libp2p/index.d.ts +2 -2
  120. package/lib/network/libp2p/index.js +9 -9
  121. package/lib/network/libp2p/index.js.map +1 -1
  122. package/lib/network/metadata.d.ts +10 -6
  123. package/lib/network/metadata.js +20 -4
  124. package/lib/network/metadata.js.map +1 -1
  125. package/lib/network/network.d.ts +20 -6
  126. package/lib/network/network.js +63 -11
  127. package/lib/network/network.js.map +1 -1
  128. package/lib/network/networkConfig.d.ts +23 -0
  129. package/lib/network/networkConfig.js +32 -0
  130. package/lib/network/networkConfig.js.map +1 -0
  131. package/lib/network/options.js +2 -0
  132. package/lib/network/options.js.map +1 -1
  133. package/lib/network/peers/datastore.d.ts +1 -2
  134. package/lib/network/peers/datastore.js +1 -1
  135. package/lib/network/peers/datastore.js.map +1 -1
  136. package/lib/network/peers/discover.d.ts +19 -7
  137. package/lib/network/peers/discover.js +148 -18
  138. package/lib/network/peers/discover.js.map +1 -1
  139. package/lib/network/peers/peerManager.d.ts +11 -9
  140. package/lib/network/peers/peerManager.js +96 -10
  141. package/lib/network/peers/peerManager.js.map +1 -1
  142. package/lib/network/peers/peersData.d.ts +8 -2
  143. package/lib/network/peers/peersData.js.map +1 -1
  144. package/lib/network/peers/score/interface.d.ts +1 -1
  145. package/lib/network/peers/score/score.d.ts +2 -2
  146. package/lib/network/peers/score/score.js +4 -1
  147. package/lib/network/peers/score/score.js.map +1 -1
  148. package/lib/network/peers/score/store.d.ts +3 -1
  149. package/lib/network/peers/score/store.js +6 -2
  150. package/lib/network/peers/score/store.js.map +1 -1
  151. package/lib/network/peers/utils/getConnectedPeerIds.js +2 -2
  152. package/lib/network/peers/utils/getConnectedPeerIds.js.map +1 -1
  153. package/lib/network/peers/utils/prioritizePeers.d.ts +15 -4
  154. package/lib/network/peers/utils/prioritizePeers.js +28 -5
  155. package/lib/network/peers/utils/prioritizePeers.js.map +1 -1
  156. package/lib/network/processor/extractSlotRootFns.js +8 -1
  157. package/lib/network/processor/extractSlotRootFns.js.map +1 -1
  158. package/lib/network/processor/gossipHandlers.js +154 -16
  159. package/lib/network/processor/gossipHandlers.js.map +1 -1
  160. package/lib/network/processor/gossipQueues/index.js +5 -0
  161. package/lib/network/processor/gossipQueues/index.js.map +1 -1
  162. package/lib/network/processor/index.js +5 -1
  163. package/lib/network/processor/index.js.map +1 -1
  164. package/lib/network/reqresp/ReqRespBeaconNode.js +21 -3
  165. package/lib/network/reqresp/ReqRespBeaconNode.js.map +1 -1
  166. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.d.ts +14 -5
  167. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.js +194 -14
  168. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.js.map +1 -1
  169. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.d.ts +28 -5
  170. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.js +254 -26
  171. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.js.map +1 -1
  172. package/lib/network/reqresp/handlers/beaconBlocksByRange.d.ts +1 -1
  173. package/lib/network/reqresp/handlers/beaconBlocksByRange.js.map +1 -1
  174. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts +8 -0
  175. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js +106 -0
  176. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js.map +1 -0
  177. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.d.ts +6 -0
  178. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js +58 -0
  179. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js.map +1 -0
  180. package/lib/network/reqresp/handlers/index.js +10 -0
  181. package/lib/network/reqresp/handlers/index.js.map +1 -1
  182. package/lib/network/reqresp/protocols.d.ts +3 -0
  183. package/lib/network/reqresp/protocols.js +15 -0
  184. package/lib/network/reqresp/protocols.js.map +1 -1
  185. package/lib/network/reqresp/rateLimit.js +11 -1
  186. package/lib/network/reqresp/rateLimit.js.map +1 -1
  187. package/lib/network/reqresp/types.d.ts +13 -6
  188. package/lib/network/reqresp/types.js +8 -1
  189. package/lib/network/reqresp/types.js.map +1 -1
  190. package/lib/network/subnets/interface.d.ts +2 -0
  191. package/lib/network/subnets/interface.js +16 -1
  192. package/lib/network/subnets/interface.js.map +1 -1
  193. package/lib/network/subnets/syncnetsService.js +4 -5
  194. package/lib/network/subnets/syncnetsService.js.map +1 -1
  195. package/lib/network/util.d.ts +1 -4
  196. package/lib/network/util.js +2 -2
  197. package/lib/network/util.js.map +1 -1
  198. package/lib/node/nodejs.d.ts +5 -3
  199. package/lib/node/nodejs.js +6 -4
  200. package/lib/node/nodejs.js.map +1 -1
  201. package/lib/sync/interface.d.ts +2 -2
  202. package/lib/sync/interface.js +1 -1
  203. package/lib/sync/interface.js.map +1 -1
  204. package/lib/sync/range/batch.d.ts +8 -2
  205. package/lib/sync/range/batch.js +16 -7
  206. package/lib/sync/range/batch.js.map +1 -1
  207. package/lib/sync/range/chain.d.ts +7 -2
  208. package/lib/sync/range/chain.js +45 -21
  209. package/lib/sync/range/chain.js.map +1 -1
  210. package/lib/sync/range/range.js +3 -3
  211. package/lib/sync/range/range.js.map +1 -1
  212. package/lib/sync/range/utils/peerBalancer.d.ts +4 -1
  213. package/lib/sync/range/utils/peerBalancer.js +20 -2
  214. package/lib/sync/range/utils/peerBalancer.js.map +1 -1
  215. package/lib/sync/unknownBlock.d.ts +8 -1
  216. package/lib/sync/unknownBlock.js +223 -63
  217. package/lib/sync/unknownBlock.js.map +1 -1
  218. package/lib/util/blobs.d.ts +12 -1
  219. package/lib/util/blobs.js +40 -1
  220. package/lib/util/blobs.js.map +1 -1
  221. package/lib/util/dataColumns.d.ts +105 -0
  222. package/lib/util/dataColumns.js +189 -0
  223. package/lib/util/dataColumns.js.map +1 -0
  224. package/lib/util/kzg.d.ts +9 -21
  225. package/lib/util/kzg.js +12 -88
  226. package/lib/util/kzg.js.map +1 -1
  227. package/lib/util/peerId.js +1 -1
  228. package/lib/util/peerId.js.map +1 -1
  229. package/lib/util/sszBytes.d.ts +1 -0
  230. package/lib/util/sszBytes.js +17 -0
  231. package/lib/util/sszBytes.js.map +1 -1
  232. package/package.json +33 -32
@@ -1,7 +1,11 @@
1
1
  import { ChainForkConfig } from "@lodestar/config";
2
- import { RootHex, SignedBeaconBlock, deneb } from "@lodestar/types";
2
+ import { ForkName } from "@lodestar/params";
3
+ import { RootHex, SignedBeaconBlock, deneb, fulu } from "@lodestar/types";
4
+ import { IExecutionEngine } from "../../execution/index.js";
3
5
  import { Metrics } from "../../metrics/index.js";
4
- import { BlockInput, GossipedInputType, NullBlockInput } from "../blocks/types.js";
6
+ import { CustodyConfig } from "../../util/dataColumns.js";
7
+ import { BlockInput, CachedData, GossipedInputType, NullBlockInput } from "../blocks/types.js";
8
+ import { ChainEventEmitter } from "../emitter.js";
5
9
  export declare enum BlockInputAvailabilitySource {
6
10
  GOSSIP = "gossip",
7
11
  UNKNOWN_SYNC = "unknown_sync"
@@ -12,7 +16,46 @@ type GossipedBlockInput = {
12
16
  } | {
13
17
  type: GossipedInputType.blob;
14
18
  blobSidecar: deneb.BlobSidecar;
19
+ } | {
20
+ type: GossipedInputType.dataColumn;
21
+ dataColumnSidecar: fulu.DataColumnSidecar;
22
+ dataColumnBytes: Uint8Array | null;
23
+ };
24
+ type BlockInputCacheType = {
25
+ fork: ForkName;
26
+ block?: SignedBeaconBlock;
27
+ cachedData?: CachedData;
28
+ blockInputPromise: Promise<BlockInput>;
29
+ resolveBlockInput: (blockInput: BlockInput) => void;
30
+ };
31
+ type GossipBlockInputResponseWithBlock = {
32
+ blockInput: BlockInput;
33
+ blockInputMeta: {
34
+ pending: GossipedInputType.blob | null;
35
+ haveBlobs: number;
36
+ expectedBlobs: number;
37
+ } | {
38
+ pending: GossipedInputType.dataColumn | null;
39
+ haveColumns: number;
40
+ expectedColumns: number;
41
+ };
42
+ };
43
+ type BlockInputPendingBlock = {
44
+ pending: GossipedInputType.block;
15
45
  };
46
+ export type BlockInputMetaPendingBlockWithBlobs = BlockInputPendingBlock & {
47
+ haveBlobs: number;
48
+ expectedBlobs: null;
49
+ };
50
+ type BlockInputMetaPendingBlockWithColumns = BlockInputPendingBlock & {
51
+ haveColumns: number;
52
+ expectedColumns: null;
53
+ };
54
+ type GossipBlockInputResponseWithNullBlock = {
55
+ blockInput: NullBlockInput;
56
+ blockInputMeta: BlockInputMetaPendingBlockWithBlobs | BlockInputMetaPendingBlockWithColumns;
57
+ };
58
+ type GossipBlockInputResponse = GossipBlockInputResponseWithBlock | GossipBlockInputResponseWithNullBlock;
16
59
  /**
17
60
  * For predeneb, SeenGossipBlockInput only tracks and caches block so that we don't need to download known block
18
61
  * roots. From deneb, it serves same purpose plus tracks and caches the live blobs and blocks on the network to
@@ -25,24 +68,18 @@ type GossipedBlockInput = {
25
68
  * block are seen by SeenGossipBlockInput
26
69
  */
27
70
  export declare class SeenGossipBlockInput {
28
- private blockInputCache;
71
+ private readonly blockInputCache;
72
+ private readonly custodyConfig;
73
+ private readonly executionEngine;
74
+ private readonly emitter;
75
+ constructor(custodyConfig: CustodyConfig, executionEngine: IExecutionEngine, emitter: ChainEventEmitter);
76
+ globalCacheId: number;
29
77
  prune(): void;
30
78
  hasBlock(blockRoot: RootHex): boolean;
31
- getGossipBlockInput(config: ChainForkConfig, gossipedInput: GossipedBlockInput, metrics: Metrics | null): {
32
- blockInput: BlockInput;
33
- blockInputMeta: {
34
- pending: GossipedInputType.blob | null;
35
- haveBlobs: number;
36
- expectedBlobs: number;
37
- };
38
- } | {
39
- blockInput: NullBlockInput;
40
- blockInputMeta: {
41
- pending: GossipedInputType.block;
42
- haveBlobs: number;
43
- expectedBlobs: null;
44
- };
45
- };
79
+ getGossipBlockInput(config: ChainForkConfig, gossipedInput: GossipedBlockInput, metrics: Metrics | null): GossipBlockInputResponse;
80
+ private hasSampledDataColumns;
81
+ private reconstructColumns;
46
82
  }
83
+ export declare function getEmptyBlockInputCacheEntry(fork: ForkName, globalCacheId: number): BlockInputCacheType;
47
84
  export {};
48
85
  //# sourceMappingURL=seenGossipBlockInput.d.ts.map
@@ -1,7 +1,12 @@
1
- import { isForkPostDeneb } from "@lodestar/params";
1
+ import { toHexString } from "@chainsafe/ssz";
2
+ import { ForkName, NUMBER_OF_COLUMNS, isForkPostDeneb } from "@lodestar/params";
2
3
  import { ssz } from "@lodestar/types";
3
- import { pruneSetToMax, toRootHex } from "@lodestar/utils";
4
- import { BlobsSource, BlockSource, GossipedInputType, getBlockInput, getBlockInputBlobs, } from "../blocks/types.js";
4
+ import { pruneSetToMax } from "@lodestar/utils";
5
+ import { kzgCommitmentToVersionedHash } from "../../util/blobs.js";
6
+ import { getCellsAndProofs, getDataColumnSidecarsFromBlock, getDataColumnSidecarsFromColumnSidecar, } from "../../util/dataColumns.js";
7
+ import { callInNextEventLoop } from "../../util/eventLoop.js";
8
+ import { BlobsSource, BlockSource, DataColumnsSource, GossipedInputType, getBlockInput, getBlockInputBlobs, getBlockInputDataColumns, } from "../blocks/types.js";
9
+ import { ChainEvent } from "../emitter.js";
5
10
  export var BlockInputAvailabilitySource;
6
11
  (function (BlockInputAvailabilitySource) {
7
12
  BlockInputAvailabilitySource["GOSSIP"] = "gossip";
@@ -20,8 +25,12 @@ const MAX_GOSSIPINPUT_CACHE = 5;
20
25
  * block are seen by SeenGossipBlockInput
21
26
  */
22
27
  export class SeenGossipBlockInput {
23
- constructor() {
28
+ constructor(custodyConfig, executionEngine, emitter) {
24
29
  this.blockInputCache = new Map();
30
+ this.globalCacheId = 0;
31
+ this.custodyConfig = custodyConfig;
32
+ this.executionEngine = executionEngine;
33
+ this.emitter = emitter;
25
34
  }
26
35
  prune() {
27
36
  pruneSetToMax(this.blockInputCache, MAX_GOSSIPINPUT_CACHE);
@@ -36,21 +45,47 @@ export class SeenGossipBlockInput {
36
45
  if (gossipedInput.type === GossipedInputType.block) {
37
46
  const { signedBlock } = gossipedInput;
38
47
  fork = config.getForkName(signedBlock.message.slot);
39
- blockHex = toRootHex(config.getForkTypes(signedBlock.message.slot).BeaconBlock.hashTreeRoot(signedBlock.message));
40
- blockCache = this.blockInputCache.get(blockHex) ?? getEmptyBlockInputCacheEntry(fork);
48
+ blockHex = toHexString(config.getForkTypes(signedBlock.message.slot).BeaconBlock.hashTreeRoot(signedBlock.message));
49
+ blockCache = this.blockInputCache.get(blockHex) ?? getEmptyBlockInputCacheEntry(fork, ++this.globalCacheId);
41
50
  blockCache.block = signedBlock;
42
51
  }
43
- else {
52
+ else if (gossipedInput.type === GossipedInputType.blob) {
44
53
  const { blobSidecar } = gossipedInput;
45
54
  const blockRoot = ssz.phase0.BeaconBlockHeader.hashTreeRoot(blobSidecar.signedBlockHeader.message);
46
55
  fork = config.getForkName(blobSidecar.signedBlockHeader.message.slot);
47
- blockHex = toRootHex(blockRoot);
48
- blockCache = this.blockInputCache.get(blockHex) ?? getEmptyBlockInputCacheEntry(fork);
56
+ blockHex = toHexString(blockRoot);
57
+ blockCache = this.blockInputCache.get(blockHex) ?? getEmptyBlockInputCacheEntry(fork, ++this.globalCacheId);
58
+ if (blockCache.cachedData?.fork !== ForkName.deneb) {
59
+ throw Error(`blob data at non deneb fork=${blockCache.fork}`);
60
+ }
49
61
  // TODO: freetheblobs check if its the same blob or a duplicate and throw/take actions
50
62
  blockCache.cachedData?.blobsCache.set(blobSidecar.index, blobSidecar);
51
63
  }
64
+ else if (gossipedInput.type === GossipedInputType.dataColumn) {
65
+ const { dataColumnSidecar, dataColumnBytes } = gossipedInput;
66
+ const blockRoot = ssz.phase0.BeaconBlockHeader.hashTreeRoot(dataColumnSidecar.signedBlockHeader.message);
67
+ fork = config.getForkName(dataColumnSidecar.signedBlockHeader.message.slot);
68
+ blockHex = toHexString(blockRoot);
69
+ blockCache = this.blockInputCache.get(blockHex) ?? getEmptyBlockInputCacheEntry(fork, ++this.globalCacheId);
70
+ if (blockCache.cachedData?.fork !== ForkName.fulu) {
71
+ throw Error(`blob data at non fulu fork=${blockCache.fork}`);
72
+ }
73
+ // TODO: freetheblobs check if its the same blob or a duplicate and throw/take actions
74
+ blockCache.cachedData?.dataColumnsCache.set(dataColumnSidecar.index, {
75
+ dataColumn: dataColumnSidecar,
76
+ // easily splice out the unsigned message as blob is a fixed length type
77
+ dataColumnBytes: dataColumnBytes?.slice(0, dataColumnBytes.length) ?? null,
78
+ });
79
+ }
80
+ else {
81
+ // somehow helps resolve typescript that all types have been exausted
82
+ throw Error("Invalid gossipedInput type");
83
+ }
52
84
  if (!this.blockInputCache.has(blockHex)) {
53
85
  this.blockInputCache.set(blockHex, blockCache);
86
+ callInNextEventLoop(() => {
87
+ this.reconstructColumns(config, blockHex);
88
+ });
54
89
  }
55
90
  const { block: signedBlock, blockInputPromise, resolveBlockInput, cachedData } = blockCache;
56
91
  if (signedBlock !== undefined) {
@@ -63,54 +98,234 @@ export class SeenGossipBlockInput {
63
98
  if (cachedData === undefined || !isForkPostDeneb(cachedData.fork)) {
64
99
  throw Error("Missing or Invalid fork cached Data for post-deneb block");
65
100
  }
66
- const { blobsCache, resolveAvailability } = cachedData;
67
- // block is available, check if all blobs have shown up
68
- const { slot, body } = signedBlock.message;
69
- const { blobKzgCommitments } = body;
70
- const blockInfo = `blockHex=${blockHex}, slot=${slot}`;
71
- if (blobKzgCommitments.length < blobsCache.size) {
72
- throw Error(`Received more blobs=${blobsCache.size} than commitments=${blobKzgCommitments.length} for ${blockInfo}`);
101
+ if (cachedData.fork === ForkName.deneb || cachedData.fork === ForkName.electra) {
102
+ const { blobsCache, resolveAvailability } = cachedData;
103
+ // block is available, check if all blobs have shown up
104
+ const { slot, body } = signedBlock.message;
105
+ const { blobKzgCommitments } = body;
106
+ const blockInfo = `blockHex=${blockHex}, slot=${slot}`;
107
+ if (blobKzgCommitments.length < blobsCache.size) {
108
+ throw Error(`Received more blobs=${blobsCache.size} than commitments=${blobKzgCommitments.length} for ${blockInfo}`);
109
+ }
110
+ if (blobKzgCommitments.length === blobsCache.size) {
111
+ const allBlobs = getBlockInputBlobs(blobsCache);
112
+ const { blobs } = allBlobs;
113
+ const blockData = {
114
+ fork: cachedData.fork,
115
+ ...allBlobs,
116
+ blobsSource: BlobsSource.gossip,
117
+ };
118
+ resolveAvailability(blockData);
119
+ metrics?.syncUnknownBlock.resolveAvailabilitySource.inc({ source: BlockInputAvailabilitySource.GOSSIP });
120
+ const blockInput = getBlockInput.availableData(config, signedBlock, BlockSource.gossip, blockData);
121
+ resolveBlockInput(blockInput);
122
+ return {
123
+ blockInput,
124
+ blockInputMeta: { pending: null, haveBlobs: blobs.length, expectedBlobs: blobKzgCommitments.length },
125
+ };
126
+ }
127
+ const blockInput = getBlockInput.dataPromise(config, signedBlock, BlockSource.gossip, cachedData);
128
+ resolveBlockInput(blockInput);
129
+ return {
130
+ blockInput,
131
+ blockInputMeta: {
132
+ pending: GossipedInputType.blob,
133
+ haveBlobs: blobsCache.size,
134
+ expectedBlobs: blobKzgCommitments.length,
135
+ },
136
+ };
73
137
  }
74
- if (blobKzgCommitments.length === blobsCache.size) {
75
- const allBlobs = getBlockInputBlobs(blobsCache);
76
- const blockData = { ...allBlobs, blobsSource: BlobsSource.gossip, fork: cachedData.fork };
77
- resolveAvailability(blockData);
78
- metrics?.syncUnknownBlock.resolveAvailabilitySource.inc({ source: BlockInputAvailabilitySource.GOSSIP });
79
- const blockInput = getBlockInput.availableData(config, signedBlock, BlockSource.gossip, blockData);
138
+ if (cachedData.fork === ForkName.fulu) {
139
+ const { dataColumnsCache, resolveAvailability } = cachedData;
140
+ // block is available, check if all blobs have shown up
141
+ const { slot } = signedBlock.message;
142
+ const blockInfo = `blockHex=${blockHex}, slot=${slot}`;
143
+ if (NUMBER_OF_COLUMNS < dataColumnsCache.size) {
144
+ throw Error(`Received more dataColumns=${dataColumnsCache.size} than columns=${NUMBER_OF_COLUMNS} for ${blockInfo}`);
145
+ }
146
+ // get the custody columns and see if we have got all the requisite columns
147
+ const blobKzgCommitmentsLen = signedBlock.message.body.blobKzgCommitments.length;
148
+ if (blobKzgCommitmentsLen === 0) {
149
+ const blockData = {
150
+ fork: cachedData.fork,
151
+ dataColumns: [],
152
+ dataColumnsBytes: [],
153
+ dataColumnsSource: DataColumnsSource.gossip,
154
+ };
155
+ resolveAvailability(blockData);
156
+ metrics?.syncUnknownBlock.resolveAvailabilitySource.inc({ source: BlockInputAvailabilitySource.GOSSIP });
157
+ const blockInput = getBlockInput.availableData(config, signedBlock, BlockSource.gossip, blockData);
158
+ resolveBlockInput(blockInput);
159
+ return {
160
+ blockInput,
161
+ blockInputMeta: { pending: null, haveColumns: 0, expectedColumns: 0 },
162
+ };
163
+ }
164
+ if (this.hasSampledDataColumns(dataColumnsCache)) {
165
+ const allDataColumns = getBlockInputDataColumns(dataColumnsCache, this.custodyConfig.sampledColumns);
166
+ metrics?.syncUnknownBlock.resolveAvailabilitySource.inc({ source: BlockInputAvailabilitySource.GOSSIP });
167
+ const { dataColumns } = allDataColumns;
168
+ const blockData = {
169
+ fork: cachedData.fork,
170
+ ...allDataColumns,
171
+ dataColumnsSource: DataColumnsSource.gossip,
172
+ };
173
+ resolveAvailability(blockData);
174
+ metrics?.syncUnknownBlock.resolveAvailabilitySource.inc({ source: BlockInputAvailabilitySource.GOSSIP });
175
+ const blockInput = getBlockInput.availableData(config, signedBlock, BlockSource.gossip, blockData);
176
+ resolveBlockInput(blockInput);
177
+ return {
178
+ blockInput,
179
+ blockInputMeta: {
180
+ pending: null,
181
+ haveColumns: dataColumns.length,
182
+ expectedColumns: this.custodyConfig.sampledColumns.length,
183
+ },
184
+ };
185
+ }
186
+ const blockInput = getBlockInput.dataPromise(config, signedBlock, BlockSource.gossip, cachedData);
80
187
  resolveBlockInput(blockInput);
81
188
  return {
82
189
  blockInput,
83
- blockInputMeta: { pending: null, haveBlobs: allBlobs.blobs.length, expectedBlobs: blobKzgCommitments.length },
190
+ blockInputMeta: {
191
+ pending: GossipedInputType.dataColumn,
192
+ haveColumns: dataColumnsCache.size,
193
+ expectedColumns: this.custodyConfig.sampledColumns.length,
194
+ },
84
195
  };
85
196
  }
86
- const blockInput = getBlockInput.dataPromise(config, signedBlock, BlockSource.gossip, cachedData);
87
- resolveBlockInput(blockInput);
197
+ throw Error(`Invalid fork=${fork}`);
198
+ }
199
+ // will need to wait for the block to showup
200
+ if (cachedData === undefined) {
201
+ throw Error("Missing cachedData for deneb+ blobs");
202
+ }
203
+ if (cachedData.fork === ForkName.deneb || cachedData.fork === ForkName.electra) {
204
+ const { blobsCache } = cachedData;
88
205
  return {
89
- blockInput,
90
- blockInputMeta: {
91
- pending: GossipedInputType.blob,
92
- haveBlobs: blobsCache.size,
93
- expectedBlobs: blobKzgCommitments.length,
206
+ blockInput: {
207
+ block: null,
208
+ blockRootHex: blockHex,
209
+ cachedData,
210
+ blockInputPromise,
94
211
  },
212
+ blockInputMeta: { pending: GossipedInputType.block, haveBlobs: blobsCache.size, expectedBlobs: null },
95
213
  };
96
214
  }
215
+ if (fork === ForkName.fulu) {
216
+ const { dataColumnsCache } = cachedData;
217
+ return {
218
+ blockInput: {
219
+ block: null,
220
+ blockRootHex: blockHex,
221
+ cachedData,
222
+ blockInputPromise,
223
+ },
224
+ blockInputMeta: { pending: GossipedInputType.block, haveColumns: dataColumnsCache.size, expectedColumns: null },
225
+ };
226
+ }
227
+ throw Error(`invalid fork=${fork} data not implemented`);
228
+ /**
229
+ * TODO: @matthewkeil this code was unreachable. Commented to remove lint error but need to verify the condition
230
+ * again to make sure this is not necessary before deleting it
231
+ *
232
+ * DO NOT DELETE until verified can be removed
233
+ */
97
234
  // will need to wait for the block to showup
98
- if (cachedData === undefined) {
99
- throw Error("Missing cachedData for deneb+ blobs");
235
+ // if (cachedData === undefined) {
236
+ // throw Error("Missing cachedData for deneb+ blobs");
237
+ // }
238
+ // const {blobsCache} = cachedData as CachedBlobs;
239
+ // return {
240
+ // blockInput: {
241
+ // block: null,
242
+ // blockRootHex: blockHex,
243
+ // cachedData: cachedData as CachedData,
244
+ // blockInputPromise,
245
+ // },
246
+ // blockInputMeta: {pending: GossipedInputType.block, haveBlobs: blobsCache.size, expectedBlobs: null},
247
+ // };
248
+ }
249
+ hasSampledDataColumns(dataColumnCache) {
250
+ return (dataColumnCache.size >= this.custodyConfig.sampledColumns.length &&
251
+ this.custodyConfig.sampledColumns.reduce((acc, columnIndex) => acc && dataColumnCache.has(columnIndex), true));
252
+ }
253
+ async reconstructColumns(config, blockRoot) {
254
+ const blockCache = this.blockInputCache.get(blockRoot);
255
+ if (blockCache === undefined || blockCache.fork !== ForkName.fulu) {
256
+ return;
257
+ }
258
+ if (!blockCache.cachedData) {
259
+ // this condition should never get hit... just a sanity check
260
+ throw new Error("invalid blockCache");
261
+ }
262
+ // If already have all columns, exit
263
+ if (blockCache.cachedData.fork !== ForkName.fulu ||
264
+ this.hasSampledDataColumns(blockCache.cachedData.dataColumnsCache)) {
265
+ return;
266
+ }
267
+ let commitments;
268
+ if (blockCache.block) {
269
+ const block = blockCache.block;
270
+ commitments = block.message.body.blobKzgCommitments;
271
+ }
272
+ else {
273
+ const firstSidecar = blockCache.cachedData.dataColumnsCache.values().next().value;
274
+ commitments = firstSidecar?.dataColumn.kzgCommitments;
100
275
  }
101
- const { blobsCache } = cachedData;
102
- return {
103
- blockInput: {
104
- block: null,
105
- blockRootHex: blockHex,
106
- cachedData,
107
- blockInputPromise,
108
- },
109
- blockInputMeta: { pending: GossipedInputType.block, haveBlobs: blobsCache.size, expectedBlobs: null },
276
+ if (!commitments) {
277
+ throw new Error("blockInputCache missing both block and cachedData");
278
+ }
279
+ // Process KZG commitments into versioned hashes
280
+ const versionedHashes = commitments.map(kzgCommitmentToVersionedHash);
281
+ // Return if block has no blobs
282
+ if (versionedHashes.length === 0) {
283
+ return;
284
+ }
285
+ // Get blobs from execution engine
286
+ const blobs = await this.executionEngine.getBlobs(blockCache.fork, versionedHashes);
287
+ // Execution engine was unable to find one or more blobs
288
+ if (blobs === null) {
289
+ return;
290
+ }
291
+ // Return if we received all data columns while waiting for getBlobs
292
+ if (this.hasSampledDataColumns(blockCache.cachedData.dataColumnsCache)) {
293
+ return;
294
+ }
295
+ let dataColumnSidecars;
296
+ const cellsAndProofs = getCellsAndProofs(blobs);
297
+ if (blockCache.block) {
298
+ dataColumnSidecars = getDataColumnSidecarsFromBlock(config, blockCache.block, cellsAndProofs);
299
+ }
300
+ else {
301
+ const firstSidecar = blockCache.cachedData.dataColumnsCache.values().next().value;
302
+ if (!firstSidecar) {
303
+ throw new Error("blockInputCache missing both block and data column sidecar");
304
+ }
305
+ dataColumnSidecars = getDataColumnSidecarsFromColumnSidecar(firstSidecar.dataColumn, cellsAndProofs);
306
+ }
307
+ // Publish columns if and only if subscribed to them
308
+ const sampledColumns = this.custodyConfig.sampledColumns.map((columnIndex) => dataColumnSidecars[columnIndex]);
309
+ this.emitter.emit(ChainEvent.publishDataColumns, sampledColumns);
310
+ for (const column of sampledColumns) {
311
+ blockCache.cachedData.dataColumnsCache.set(column.index, { dataColumn: column, dataColumnBytes: null });
312
+ }
313
+ const allDataColumns = getBlockInputDataColumns(blockCache.cachedData.dataColumnsCache, this.custodyConfig.sampledColumns);
314
+ // TODO: Add metrics
315
+ // metrics?.syncUnknownBlock.resolveAvailabilitySource.inc({source: BlockInputAvailabilitySource.GOSSIP});
316
+ const blockData = {
317
+ fork: blockCache.cachedData.fork,
318
+ ...allDataColumns,
319
+ dataColumnsSource: DataColumnsSource.gossip,
110
320
  };
321
+ blockCache.cachedData.resolveAvailability(blockData);
322
+ if (blockCache.block !== undefined) {
323
+ const blockInput = getBlockInput.availableData(config, blockCache.block, BlockSource.gossip, blockData);
324
+ blockCache.resolveBlockInput(blockInput);
325
+ }
111
326
  }
112
327
  }
113
- function getEmptyBlockInputCacheEntry(fork) {
328
+ export function getEmptyBlockInputCacheEntry(fork, globalCacheId) {
114
329
  // Capture both the promise and its callbacks for blockInput and final availability
115
330
  // It is not spec'ed but in tests in Firefox and NodeJS the promise constructor is run immediately
116
331
  let resolveBlockInput = null;
@@ -123,15 +338,42 @@ function getEmptyBlockInputCacheEntry(fork) {
123
338
  if (!isForkPostDeneb(fork)) {
124
339
  return { fork, blockInputPromise, resolveBlockInput };
125
340
  }
126
- let resolveAvailability = null;
127
- const availabilityPromise = new Promise((resolveCB) => {
128
- resolveAvailability = resolveCB;
129
- });
130
- if (resolveAvailability === null) {
131
- throw Error("Promise Constructor was not executed immediately");
341
+ if (fork === ForkName.deneb || fork === ForkName.electra) {
342
+ let resolveAvailability = null;
343
+ const availabilityPromise = new Promise((resolveCB) => {
344
+ resolveAvailability = resolveCB;
345
+ });
346
+ if (resolveAvailability === null) {
347
+ throw Error("Promise Constructor was not executed immediately");
348
+ }
349
+ const blobsCache = new Map();
350
+ const cachedData = {
351
+ fork,
352
+ blobsCache,
353
+ availabilityPromise,
354
+ resolveAvailability,
355
+ cacheId: ++globalCacheId,
356
+ };
357
+ return { fork, blockInputPromise, resolveBlockInput, cachedData };
358
+ }
359
+ if (fork === ForkName.fulu) {
360
+ let resolveAvailability = null;
361
+ const availabilityPromise = new Promise((resolveCB) => {
362
+ resolveAvailability = resolveCB;
363
+ });
364
+ if (resolveAvailability === null) {
365
+ throw Error("Promise Constructor was not executed immediately");
366
+ }
367
+ const dataColumnsCache = new Map();
368
+ const cachedData = {
369
+ fork,
370
+ dataColumnsCache,
371
+ availabilityPromise,
372
+ resolveAvailability,
373
+ cacheId: ++globalCacheId,
374
+ };
375
+ return { fork, blockInputPromise, resolveBlockInput, cachedData };
132
376
  }
133
- const blobsCache = new Map();
134
- const cachedData = { fork, blobsCache, availabilityPromise, resolveAvailability };
135
- return { fork, blockInputPromise, resolveBlockInput, cachedData };
377
+ throw Error(`Invalid fork=${fork} for getEmptyBlockInputCacheEntry`);
136
378
  }
137
379
  //# sourceMappingURL=seenGossipBlockInput.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"seenGossipBlockInput.js","sourceRoot":"","sources":["../../../src/chain/seenCache/seenGossipBlockInput.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"seenGossipBlockInput.js","sourceRoot":"","sources":["../../../src/chain/seenCache/seenGossipBlockInput.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ import { Root, Slot, deneb, fulu } from "@lodestar/types";
2
+ import { Metrics } from "../../metrics/metrics.js";
3
+ import { IBeaconChain } from "../interface.js";
4
+ export declare function validateGossipDataColumnSidecar(chain: IBeaconChain, dataColumnSideCar: fulu.DataColumnSidecar, gossipIndex: number): Promise<void>;
5
+ export declare function validateDataColumnsSidecars(blockSlot: Slot, blockRoot: Root, blockKzgCommitments: deneb.BlobKzgCommitments, dataColumnSidecars: fulu.DataColumnSidecars, metrics: Metrics | null, opts?: {
6
+ skipProofsCheck: boolean;
7
+ }): void;
8
+ //# sourceMappingURL=dataColumnSidecar.d.ts.map
@@ -0,0 +1,91 @@
1
+ import { DATA_COLUMN_SIDECAR_SUBNET_COUNT, KZG_COMMITMENTS_INCLUSION_PROOF_DEPTH, KZG_COMMITMENTS_SUBTREE_INDEX, NUMBER_OF_COLUMNS, } from "@lodestar/params";
2
+ import { ssz } from "@lodestar/types";
3
+ import { toHex, verifyMerkleBranch } from "@lodestar/utils";
4
+ import { byteArrayEquals } from "../../util/bytes.js";
5
+ import { ckzg } from "../../util/kzg.js";
6
+ import { DataColumnSidecarErrorCode, DataColumnSidecarGossipError } from "../errors/dataColumnSidecarError.js";
7
+ import { GossipAction } from "../errors/gossipValidation.js";
8
+ export async function validateGossipDataColumnSidecar(chain, dataColumnSideCar, gossipIndex) {
9
+ const dataColumnSlot = dataColumnSideCar.signedBlockHeader.message.slot;
10
+ if (dataColumnSideCar.index > NUMBER_OF_COLUMNS ||
11
+ dataColumnSideCar.index % DATA_COLUMN_SIDECAR_SUBNET_COUNT !== gossipIndex) {
12
+ throw new DataColumnSidecarGossipError(GossipAction.REJECT, {
13
+ code: DataColumnSidecarErrorCode.INVALID_INDEX,
14
+ columnIndex: dataColumnSideCar.index,
15
+ gossipIndex,
16
+ });
17
+ }
18
+ // [IGNORE] The sidecar is not from a future slot (with a MAXIMUM_GOSSIP_CLOCK_DISPARITY allowance) --
19
+ // i.e. validate that sidecar.slot <= current_slot (a client MAY queue future blocks for processing at
20
+ // the appropriate slot).
21
+ const currentSlotWithGossipDisparity = chain.clock.currentSlotWithGossipDisparity;
22
+ if (currentSlotWithGossipDisparity < dataColumnSlot) {
23
+ throw new DataColumnSidecarGossipError(GossipAction.IGNORE, {
24
+ code: DataColumnSidecarErrorCode.FUTURE_SLOT,
25
+ currentSlot: currentSlotWithGossipDisparity,
26
+ blockSlot: dataColumnSlot,
27
+ });
28
+ }
29
+ if (!validateInclusionProof(dataColumnSideCar, chain.metrics)) {
30
+ throw new DataColumnSidecarGossipError(GossipAction.REJECT, {
31
+ code: DataColumnSidecarErrorCode.INCLUSION_PROOF_INVALID,
32
+ slot: dataColumnSideCar.signedBlockHeader.message.slot,
33
+ columnIdx: dataColumnSideCar.index,
34
+ });
35
+ }
36
+ }
37
+ export function validateDataColumnsSidecars(blockSlot, blockRoot, blockKzgCommitments, dataColumnSidecars, metrics, opts = { skipProofsCheck: false }) {
38
+ const commitmentBytes = [];
39
+ const cellIndices = [];
40
+ const cells = [];
41
+ const proofBytes = [];
42
+ for (let sidecarsIndex = 0; sidecarsIndex < dataColumnSidecars.length; sidecarsIndex++) {
43
+ const columnSidecar = dataColumnSidecars[sidecarsIndex];
44
+ const { index: columnIndex, column, kzgCommitments, kzgProofs } = columnSidecar;
45
+ const columnBlockHeader = columnSidecar.signedBlockHeader.message;
46
+ const columnBlockRoot = ssz.phase0.BeaconBlockHeader.hashTreeRoot(columnBlockHeader);
47
+ if (columnBlockHeader.slot !== blockSlot ||
48
+ !byteArrayEquals(columnBlockRoot, blockRoot) ||
49
+ kzgCommitments.length === 0 ||
50
+ blockKzgCommitments.length === 0 ||
51
+ blockKzgCommitments.length !== kzgCommitments.length ||
52
+ blockKzgCommitments
53
+ .map((commitment, i) => byteArrayEquals(commitment, kzgCommitments[i]))
54
+ .filter((result) => result === false).length) {
55
+ throw new Error(`Invalid data column sidecar slot=${columnBlockHeader.slot} columnBlockRoot=${toHex(columnBlockRoot)} columnIndex=${columnIndex} for the block blockRoot=${toHex(blockRoot)} slot=${blockSlot} sidecarsIndex=${sidecarsIndex}`);
56
+ }
57
+ if (columnIndex >= NUMBER_OF_COLUMNS) {
58
+ throw new Error(`Invalid data sidecar columnIndex=${columnIndex} in slot=${blockSlot} blockRoot=${toHex(blockRoot)} sidecarsIndex=${sidecarsIndex}`);
59
+ }
60
+ if (column.length !== kzgCommitments.length || column.length !== kzgProofs.length) {
61
+ throw new Error(`Invalid data sidecar array lengths for columnIndex=${columnIndex} in slot=${blockSlot} blockRoot=${toHex(blockRoot)}`);
62
+ }
63
+ commitmentBytes.push(...kzgCommitments);
64
+ cellIndices.push(...Array.from({ length: column.length }, () => columnIndex));
65
+ cells.push(...column);
66
+ proofBytes.push(...kzgProofs);
67
+ }
68
+ if (opts.skipProofsCheck) {
69
+ return;
70
+ }
71
+ let valid;
72
+ try {
73
+ const timer = metrics?.peerDas.kzgVerificationDataColumnBatchTime.startTimer();
74
+ valid = ckzg.verifyCellKzgProofBatch(commitmentBytes, cellIndices, cells, proofBytes);
75
+ timer?.();
76
+ }
77
+ catch (err) {
78
+ err.message = `Error in verifyCellKzgProofBatch for slot=${blockSlot} blockRoot=${toHex(blockRoot)}`;
79
+ throw err;
80
+ }
81
+ if (!valid) {
82
+ throw new Error(`Invalid data column sidecars in slot=${blockSlot} blockRoot=${toHex(blockRoot)}`);
83
+ }
84
+ }
85
+ function validateInclusionProof(dataColumnSidecar, metrics) {
86
+ const timer = metrics?.peerDas.dataColumnSidecarInclusionProofVerificationTime.startTimer();
87
+ const result = verifyMerkleBranch(ssz.deneb.BlobKzgCommitments.hashTreeRoot(dataColumnSidecar.kzgCommitments), dataColumnSidecar.kzgCommitmentsInclusionProof, KZG_COMMITMENTS_INCLUSION_PROOF_DEPTH, KZG_COMMITMENTS_SUBTREE_INDEX, dataColumnSidecar.signedBlockHeader.message.bodyRoot);
88
+ timer?.();
89
+ return result;
90
+ }
91
+ //# sourceMappingURL=dataColumnSidecar.js.map