@lodestar/beacon-node 1.34.0-dev.d5a4e7a09c → 1.34.0-dev.d9fc7bb103

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 (264) hide show
  1. package/lib/api/impl/beacon/blocks/index.js +162 -55
  2. package/lib/api/impl/beacon/blocks/index.js.map +1 -1
  3. package/lib/api/impl/beacon/pool/index.js +3 -3
  4. package/lib/api/impl/beacon/pool/index.js.map +1 -1
  5. package/lib/api/impl/beacon/state/index.js +15 -16
  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/validator/index.js +37 -26
  11. package/lib/api/impl/validator/index.js.map +1 -1
  12. package/lib/api/impl/validator/utils.d.ts +3 -3
  13. package/lib/api/impl/validator/utils.js +2 -2
  14. package/lib/api/impl/validator/utils.js.map +1 -1
  15. package/lib/chain/archiveStore/archiveStore.d.ts +1 -1
  16. package/lib/chain/archiveStore/archiveStore.js +2 -2
  17. package/lib/chain/archiveStore/interface.d.ts +1 -1
  18. package/lib/chain/archiveStore/utils/archiveBlocks.d.ts +1 -1
  19. package/lib/chain/archiveStore/utils/archiveBlocks.js +89 -22
  20. package/lib/chain/archiveStore/utils/archiveBlocks.js.map +1 -1
  21. package/lib/chain/beaconProposerCache.d.ts +1 -0
  22. package/lib/chain/beaconProposerCache.js +3 -0
  23. package/lib/chain/beaconProposerCache.js.map +1 -1
  24. package/lib/chain/blocks/importBlock.js +3 -2
  25. package/lib/chain/blocks/importBlock.js.map +1 -1
  26. package/lib/chain/blocks/types.d.ts +66 -23
  27. package/lib/chain/blocks/types.js +39 -5
  28. package/lib/chain/blocks/types.js.map +1 -1
  29. package/lib/chain/blocks/utils/zebraBanner.d.ts +2 -0
  30. package/lib/chain/blocks/utils/zebraBanner.js +45 -0
  31. package/lib/chain/blocks/utils/zebraBanner.js.map +1 -0
  32. package/lib/chain/blocks/verifyBlock.js +18 -5
  33. package/lib/chain/blocks/verifyBlock.js.map +1 -1
  34. package/lib/chain/blocks/verifyBlocksDataAvailability.js +21 -10
  35. package/lib/chain/blocks/verifyBlocksDataAvailability.js.map +1 -1
  36. package/lib/chain/blocks/writeBlockInputToDb.js +63 -16
  37. package/lib/chain/blocks/writeBlockInputToDb.js.map +1 -1
  38. package/lib/chain/chain.d.ts +18 -101
  39. package/lib/chain/chain.js +107 -68
  40. package/lib/chain/chain.js.map +1 -1
  41. package/lib/chain/emitter.d.ts +18 -2
  42. package/lib/chain/emitter.js +13 -0
  43. package/lib/chain/emitter.js.map +1 -1
  44. package/lib/chain/errors/dataColumnSidecarError.d.ts +69 -0
  45. package/lib/chain/errors/dataColumnSidecarError.js +21 -0
  46. package/lib/chain/errors/dataColumnSidecarError.js.map +1 -0
  47. package/lib/chain/errors/index.d.ts +1 -0
  48. package/lib/chain/errors/index.js +1 -0
  49. package/lib/chain/errors/index.js.map +1 -1
  50. package/lib/chain/interface.d.ts +6 -7
  51. package/lib/chain/interface.js.map +1 -1
  52. package/lib/chain/options.d.ts +4 -1
  53. package/lib/chain/options.js +1 -0
  54. package/lib/chain/options.js.map +1 -1
  55. package/lib/chain/prepareNextSlot.js +2 -1
  56. package/lib/chain/prepareNextSlot.js.map +1 -1
  57. package/lib/chain/produceBlock/produceBlockBody.d.ts +30 -16
  58. package/lib/chain/produceBlock/produceBlockBody.js +28 -28
  59. package/lib/chain/produceBlock/produceBlockBody.js.map +1 -1
  60. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.d.ts +6 -3
  61. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.js +28 -4
  62. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.js.map +1 -1
  63. package/lib/chain/seenCache/seenGossipBlockInput.d.ts +64 -18
  64. package/lib/chain/seenCache/seenGossipBlockInput.js +321 -53
  65. package/lib/chain/seenCache/seenGossipBlockInput.js.map +1 -1
  66. package/lib/chain/validation/dataColumnSidecar.d.ts +29 -0
  67. package/lib/chain/validation/dataColumnSidecar.js +248 -0
  68. package/lib/chain/validation/dataColumnSidecar.js.map +1 -0
  69. package/lib/db/beacon.d.ts +3 -1
  70. package/lib/db/beacon.js +3 -1
  71. package/lib/db/beacon.js.map +1 -1
  72. package/lib/db/buckets.d.ts +3 -1
  73. package/lib/db/buckets.js +2 -0
  74. package/lib/db/buckets.js.map +1 -1
  75. package/lib/db/interface.d.ts +3 -1
  76. package/lib/db/repositories/dataColumnSidecar.d.ts +26 -0
  77. package/lib/db/repositories/dataColumnSidecar.js +39 -0
  78. package/lib/db/repositories/dataColumnSidecar.js.map +1 -0
  79. package/lib/db/repositories/dataColumnSidecarArchive.d.ts +24 -0
  80. package/lib/db/repositories/dataColumnSidecarArchive.js +39 -0
  81. package/lib/db/repositories/dataColumnSidecarArchive.js.map +1 -0
  82. package/lib/db/repositories/index.d.ts +2 -0
  83. package/lib/db/repositories/index.js +2 -0
  84. package/lib/db/repositories/index.js.map +1 -1
  85. package/lib/execution/builder/http.d.ts +20 -4
  86. package/lib/execution/builder/http.js +30 -11
  87. package/lib/execution/builder/http.js.map +1 -1
  88. package/lib/execution/builder/interface.d.ts +5 -4
  89. package/lib/execution/engine/http.d.ts +8 -5
  90. package/lib/execution/engine/http.js +56 -42
  91. package/lib/execution/engine/http.js.map +1 -1
  92. package/lib/execution/engine/interface.d.ts +6 -13
  93. package/lib/execution/engine/interface.js +1 -1
  94. package/lib/execution/engine/interface.js.map +1 -1
  95. package/lib/execution/engine/mock.d.ts +1 -0
  96. package/lib/execution/engine/mock.js +5 -0
  97. package/lib/execution/engine/mock.js.map +1 -1
  98. package/lib/execution/engine/types.d.ts +12 -2
  99. package/lib/execution/engine/types.js +8 -2
  100. package/lib/execution/engine/types.js.map +1 -1
  101. package/lib/metrics/metrics/beacon.d.ts +15 -5
  102. package/lib/metrics/metrics/beacon.js +61 -14
  103. package/lib/metrics/metrics/beacon.js.map +1 -1
  104. package/lib/metrics/metrics/lodestar.d.ts +29 -1
  105. package/lib/metrics/metrics/lodestar.js +59 -0
  106. package/lib/metrics/metrics/lodestar.js.map +1 -1
  107. package/lib/network/core/metrics.d.ts +10 -3
  108. package/lib/network/core/metrics.js +22 -4
  109. package/lib/network/core/metrics.js.map +1 -1
  110. package/lib/network/core/networkCore.d.ts +15 -4
  111. package/lib/network/core/networkCore.js +73 -23
  112. package/lib/network/core/networkCore.js.map +1 -1
  113. package/lib/network/core/networkCoreWorker.js +2 -0
  114. package/lib/network/core/networkCoreWorker.js.map +1 -1
  115. package/lib/network/core/networkCoreWorkerHandler.d.ts +5 -3
  116. package/lib/network/core/networkCoreWorkerHandler.js +6 -1
  117. package/lib/network/core/networkCoreWorkerHandler.js.map +1 -1
  118. package/lib/network/core/types.d.ts +7 -4
  119. package/lib/network/events.d.ts +4 -2
  120. package/lib/network/events.js.map +1 -1
  121. package/lib/network/gossip/gossipsub.d.ts +2 -2
  122. package/lib/network/gossip/gossipsub.js +8 -6
  123. package/lib/network/gossip/gossipsub.js.map +1 -1
  124. package/lib/network/gossip/interface.d.ts +8 -1
  125. package/lib/network/gossip/interface.js +1 -0
  126. package/lib/network/gossip/interface.js.map +1 -1
  127. package/lib/network/gossip/scoringParameters.d.ts +6 -2
  128. package/lib/network/gossip/scoringParameters.js.map +1 -1
  129. package/lib/network/gossip/topic.d.ts +2033 -1484
  130. package/lib/network/gossip/topic.js +29 -1
  131. package/lib/network/gossip/topic.js.map +1 -1
  132. package/lib/network/interface.d.ts +11 -3
  133. package/lib/network/metadata.d.ts +9 -5
  134. package/lib/network/metadata.js +26 -5
  135. package/lib/network/metadata.js.map +1 -1
  136. package/lib/network/network.d.ts +14 -4
  137. package/lib/network/network.js +73 -11
  138. package/lib/network/network.js.map +1 -1
  139. package/lib/network/networkConfig.d.ts +12 -0
  140. package/lib/network/networkConfig.js +2 -0
  141. package/lib/network/networkConfig.js.map +1 -0
  142. package/lib/network/options.d.ts +1 -0
  143. package/lib/network/options.js +5 -0
  144. package/lib/network/options.js.map +1 -1
  145. package/lib/network/peers/discover.d.ts +8 -3
  146. package/lib/network/peers/discover.js +99 -14
  147. package/lib/network/peers/discover.js.map +1 -1
  148. package/lib/network/peers/peerManager.d.ts +10 -4
  149. package/lib/network/peers/peerManager.js +105 -19
  150. package/lib/network/peers/peerManager.js.map +1 -1
  151. package/lib/network/peers/peersData.d.ts +17 -3
  152. package/lib/network/peers/peersData.js.map +1 -1
  153. package/lib/network/peers/score/interface.d.ts +1 -1
  154. package/lib/network/peers/score/score.d.ts +2 -2
  155. package/lib/network/peers/score/score.js +4 -1
  156. package/lib/network/peers/score/score.js.map +1 -1
  157. package/lib/network/peers/score/store.d.ts +3 -1
  158. package/lib/network/peers/score/store.js +6 -2
  159. package/lib/network/peers/score/store.js.map +1 -1
  160. package/lib/network/peers/utils/assertPeerRelevance.d.ts +7 -3
  161. package/lib/network/peers/utils/assertPeerRelevance.js +10 -1
  162. package/lib/network/peers/utils/assertPeerRelevance.js.map +1 -1
  163. package/lib/network/peers/utils/prioritizePeers.d.ts +19 -7
  164. package/lib/network/peers/utils/prioritizePeers.js +42 -6
  165. package/lib/network/peers/utils/prioritizePeers.js.map +1 -1
  166. package/lib/network/processor/extractSlotRootFns.js +8 -1
  167. package/lib/network/processor/extractSlotRootFns.js.map +1 -1
  168. package/lib/network/processor/gossipHandlers.js +165 -16
  169. package/lib/network/processor/gossipHandlers.js.map +1 -1
  170. package/lib/network/processor/gossipQueues/index.js +5 -0
  171. package/lib/network/processor/gossipQueues/index.js.map +1 -1
  172. package/lib/network/processor/index.js +1 -0
  173. package/lib/network/processor/index.js.map +1 -1
  174. package/lib/network/reqresp/ReqRespBeaconNode.d.ts +2 -2
  175. package/lib/network/reqresp/ReqRespBeaconNode.js +36 -14
  176. package/lib/network/reqresp/ReqRespBeaconNode.js.map +1 -1
  177. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.d.ts +24 -4
  178. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.js +259 -20
  179. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.js.map +1 -1
  180. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.d.ts +37 -6
  181. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.js +283 -28
  182. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.js.map +1 -1
  183. package/lib/network/reqresp/handlers/beaconBlocksByRange.d.ts +1 -1
  184. package/lib/network/reqresp/handlers/beaconBlocksByRange.js +3 -3
  185. package/lib/network/reqresp/handlers/beaconBlocksByRange.js.map +1 -1
  186. package/lib/network/reqresp/handlers/beaconBlocksByRoot.d.ts +2 -2
  187. package/lib/network/reqresp/handlers/beaconBlocksByRoot.js.map +1 -1
  188. package/lib/network/reqresp/handlers/blobSidecarsByRange.d.ts +2 -2
  189. package/lib/network/reqresp/handlers/blobSidecarsByRange.js +2 -3
  190. package/lib/network/reqresp/handlers/blobSidecarsByRange.js.map +1 -1
  191. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts +8 -0
  192. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js +73 -0
  193. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js.map +1 -0
  194. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.d.ts +6 -0
  195. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js +36 -0
  196. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js.map +1 -0
  197. package/lib/network/reqresp/handlers/index.js +13 -2
  198. package/lib/network/reqresp/handlers/index.js.map +1 -1
  199. package/lib/network/reqresp/protocols.d.ts +4 -0
  200. package/lib/network/reqresp/protocols.js +20 -0
  201. package/lib/network/reqresp/protocols.js.map +1 -1
  202. package/lib/network/reqresp/rateLimit.js +19 -3
  203. package/lib/network/reqresp/rateLimit.js.map +1 -1
  204. package/lib/network/reqresp/score.js +3 -0
  205. package/lib/network/reqresp/score.js.map +1 -1
  206. package/lib/network/reqresp/types.d.ts +13 -6
  207. package/lib/network/reqresp/types.js +14 -5
  208. package/lib/network/reqresp/types.js.map +1 -1
  209. package/lib/network/statusCache.d.ts +5 -5
  210. package/lib/network/statusCache.js.map +1 -1
  211. package/lib/network/subnets/interface.d.ts +3 -0
  212. package/lib/network/subnets/interface.js +14 -1
  213. package/lib/network/subnets/interface.js.map +1 -1
  214. package/lib/network/subnets/syncnetsService.js +4 -5
  215. package/lib/network/subnets/syncnetsService.js.map +1 -1
  216. package/lib/node/nodejs.js +1 -0
  217. package/lib/node/nodejs.js.map +1 -1
  218. package/lib/sync/constants.d.ts +18 -3
  219. package/lib/sync/constants.js +21 -3
  220. package/lib/sync/constants.js.map +1 -1
  221. package/lib/sync/interface.d.ts +2 -2
  222. package/lib/sync/interface.js +1 -1
  223. package/lib/sync/interface.js.map +1 -1
  224. package/lib/sync/range/batch.d.ts +17 -2
  225. package/lib/sync/range/batch.js +39 -7
  226. package/lib/sync/range/batch.js.map +1 -1
  227. package/lib/sync/range/chain.d.ts +15 -1
  228. package/lib/sync/range/chain.js +124 -33
  229. package/lib/sync/range/chain.js.map +1 -1
  230. package/lib/sync/range/range.d.ts +3 -2
  231. package/lib/sync/range/range.js +9 -3
  232. package/lib/sync/range/range.js.map +1 -1
  233. package/lib/sync/range/utils/chainTarget.d.ts +5 -1
  234. package/lib/sync/range/utils/chainTarget.js +26 -1
  235. package/lib/sync/range/utils/chainTarget.js.map +1 -1
  236. package/lib/sync/range/utils/peerBalancer.d.ts +19 -5
  237. package/lib/sync/range/utils/peerBalancer.js +104 -10
  238. package/lib/sync/range/utils/peerBalancer.js.map +1 -1
  239. package/lib/sync/sync.js +1 -1
  240. package/lib/sync/sync.js.map +1 -1
  241. package/lib/sync/unknownBlock.d.ts +54 -5
  242. package/lib/sync/unknownBlock.js +321 -61
  243. package/lib/sync/unknownBlock.js.map +1 -1
  244. package/lib/sync/utils/remoteSyncType.d.ts +4 -4
  245. package/lib/sync/utils/remoteSyncType.js.map +1 -1
  246. package/lib/util/blobs.d.ts +16 -4
  247. package/lib/util/blobs.js +122 -5
  248. package/lib/util/blobs.js.map +1 -1
  249. package/lib/util/dataColumns.d.ts +137 -0
  250. package/lib/util/dataColumns.js +358 -0
  251. package/lib/util/dataColumns.js.map +1 -0
  252. package/lib/util/metadata.d.ts +5 -0
  253. package/lib/util/metadata.js +10 -0
  254. package/lib/util/metadata.js.map +1 -1
  255. package/lib/util/sszBytes.d.ts +1 -0
  256. package/lib/util/sszBytes.js +17 -0
  257. package/lib/util/sszBytes.js.map +1 -1
  258. package/lib/util/types.d.ts +7 -0
  259. package/lib/util/types.js +3 -0
  260. package/lib/util/types.js.map +1 -1
  261. package/package.json +18 -18
  262. package/lib/network/reqresp/handlers/status.d.ts +0 -4
  263. package/lib/network/reqresp/handlers/status.js +0 -11
  264. package/lib/network/reqresp/handlers/status.js.map +0 -1
@@ -1,9 +1,16 @@
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 { Logger } from "@lodestar/utils";
5
+ import { IExecutionEngine } from "../../execution/index.js";
3
6
  import { Metrics } from "../../metrics/index.js";
4
- import { BlockInput, GossipedInputType, NullBlockInput } from "../blocks/types.js";
7
+ import { IClock } from "../../util/clock.js";
8
+ import { CustodyConfig } from "../../util/dataColumns.js";
9
+ import { BlockInput, CachedData, GossipedInputType, NullBlockInput } from "../blocks/types.js";
10
+ import { ChainEventEmitter } from "../emitter.js";
5
11
  export declare enum BlockInputAvailabilitySource {
6
12
  GOSSIP = "gossip",
13
+ RECOVERED = "recovered",
7
14
  UNKNOWN_SYNC = "unknown_sync"
8
15
  }
9
16
  type GossipedBlockInput = {
@@ -12,7 +19,46 @@ type GossipedBlockInput = {
12
19
  } | {
13
20
  type: GossipedInputType.blob;
14
21
  blobSidecar: deneb.BlobSidecar;
22
+ } | {
23
+ type: GossipedInputType.dataColumn;
24
+ dataColumnSidecar: fulu.DataColumnSidecar;
25
+ dataColumnBytes: Uint8Array | null;
26
+ };
27
+ export type BlockInputCacheType = {
28
+ fork: ForkName;
29
+ block?: SignedBeaconBlock;
30
+ cachedData?: CachedData;
31
+ blockInputPromise: Promise<BlockInput>;
32
+ resolveBlockInput: (blockInput: BlockInput) => void;
33
+ };
34
+ type GossipBlockInputResponseWithBlock = {
35
+ blockInput: BlockInput;
36
+ blockInputMeta: {
37
+ pending: GossipedInputType.blob | null;
38
+ haveBlobs: number;
39
+ expectedBlobs: number;
40
+ } | {
41
+ pending: GossipedInputType.dataColumn | null;
42
+ haveColumns: number;
43
+ expectedColumns: number;
44
+ };
45
+ };
46
+ type BlockInputPendingBlock = {
47
+ pending: GossipedInputType.block;
15
48
  };
49
+ export type BlockInputMetaPendingBlockWithBlobs = BlockInputPendingBlock & {
50
+ haveBlobs: number;
51
+ expectedBlobs: null;
52
+ };
53
+ type BlockInputMetaPendingBlockWithColumns = BlockInputPendingBlock & {
54
+ haveColumns: number;
55
+ expectedColumns: null;
56
+ };
57
+ type GossipBlockInputResponseWithNullBlock = {
58
+ blockInput: NullBlockInput;
59
+ blockInputMeta: BlockInputMetaPendingBlockWithBlobs | BlockInputMetaPendingBlockWithColumns;
60
+ };
61
+ type GossipBlockInputResponse = GossipBlockInputResponseWithBlock | GossipBlockInputResponseWithNullBlock;
16
62
  /**
17
63
  * For predeneb, SeenGossipBlockInput only tracks and caches block so that we don't need to download known block
18
64
  * roots. From deneb, it serves same purpose plus tracks and caches the live blobs and blocks on the network to
@@ -25,24 +71,24 @@ type GossipedBlockInput = {
25
71
  * block are seen by SeenGossipBlockInput
26
72
  */
27
73
  export declare class SeenGossipBlockInput {
28
- private blockInputCache;
74
+ private readonly blockInputCache;
75
+ private readonly custodyConfig;
76
+ private readonly executionEngine;
77
+ private readonly clock;
78
+ private readonly emitter;
79
+ private readonly logger;
80
+ constructor(custodyConfig: CustodyConfig, executionEngine: IExecutionEngine, emitter: ChainEventEmitter, clock: IClock, logger: Logger);
81
+ globalCacheId: number;
29
82
  prune(): void;
30
83
  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
- };
84
+ /**
85
+ * Intended to be used for gossip validation, specifically this check:
86
+ * [IGNORE] The sidecar is the first sidecar for the tuple (block_header.slot, block_header.proposer_index,
87
+ * sidecar.index) with valid header signature, sidecar inclusion proof, and kzg proof
88
+ */
89
+ hasDataColumnSidecar(sidecar: fulu.DataColumnSidecar): boolean;
90
+ getGossipBlockInput(config: ChainForkConfig, gossipedInput: GossipedBlockInput, metrics: Metrics | null): GossipBlockInputResponse;
46
91
  }
92
+ export declare function getEmptyBlockInputCacheEntry(fork: ForkName, globalCacheId: number): BlockInputCacheType;
47
93
  export {};
48
94
  //# sourceMappingURL=seenGossipBlockInput.d.ts.map
@@ -1,12 +1,21 @@
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 { RecoverResult, getDataColumnsFromExecution, hasSampledDataColumns, recoverDataColumnSidecars, } from "../../util/dataColumns.js";
6
+ import { callInNextEventLoop } from "../../util/eventLoop.js";
7
+ import { BlobsSource, BlockSource, DataColumnsSource, GossipedInputType, getBlockInput, getBlockInputBlobs, getBlockInputDataColumns, } from "../blocks/types.js";
8
+ import { ChainEvent } from "../emitter.js";
9
+ import { DataColumnSidecarErrorCode, DataColumnSidecarGossipError } from "../errors/dataColumnSidecarError.js";
10
+ import { GossipAction } from "../errors/gossipValidation.js";
5
11
  export var BlockInputAvailabilitySource;
6
12
  (function (BlockInputAvailabilitySource) {
7
13
  BlockInputAvailabilitySource["GOSSIP"] = "gossip";
14
+ BlockInputAvailabilitySource["RECOVERED"] = "recovered";
8
15
  BlockInputAvailabilitySource["UNKNOWN_SYNC"] = "unknown_sync";
9
16
  })(BlockInputAvailabilitySource || (BlockInputAvailabilitySource = {}));
17
+ // TODO(fulu): dedup with gossipHandlers.ts
18
+ const BLOCK_AVAILABILITY_CUTOFF_MS = 3_000;
10
19
  const MAX_GOSSIPINPUT_CACHE = 5;
11
20
  /**
12
21
  * For predeneb, SeenGossipBlockInput only tracks and caches block so that we don't need to download known block
@@ -20,8 +29,14 @@ const MAX_GOSSIPINPUT_CACHE = 5;
20
29
  * block are seen by SeenGossipBlockInput
21
30
  */
22
31
  export class SeenGossipBlockInput {
23
- constructor() {
32
+ constructor(custodyConfig, executionEngine, emitter, clock, logger) {
24
33
  this.blockInputCache = new Map();
34
+ this.globalCacheId = 0;
35
+ this.custodyConfig = custodyConfig;
36
+ this.executionEngine = executionEngine;
37
+ this.clock = clock;
38
+ this.emitter = emitter;
39
+ this.logger = logger;
25
40
  }
26
41
  prune() {
27
42
  pruneSetToMax(this.blockInputCache, MAX_GOSSIPINPUT_CACHE);
@@ -29,6 +44,30 @@ export class SeenGossipBlockInput {
29
44
  hasBlock(blockRoot) {
30
45
  return this.blockInputCache.has(blockRoot);
31
46
  }
47
+ /**
48
+ * Intended to be used for gossip validation, specifically this check:
49
+ * [IGNORE] The sidecar is the first sidecar for the tuple (block_header.slot, block_header.proposer_index,
50
+ * sidecar.index) with valid header signature, sidecar inclusion proof, and kzg proof
51
+ */
52
+ hasDataColumnSidecar(sidecar) {
53
+ const blockRoot = ssz.phase0.BeaconBlockHeader.hashTreeRoot(sidecar.signedBlockHeader.message);
54
+ const blockRootHex = toHexString(blockRoot);
55
+ const blockCache = this.blockInputCache.get(blockRootHex);
56
+ if (blockCache === undefined) {
57
+ return false;
58
+ }
59
+ if (blockCache.cachedData === undefined || blockCache.cachedData.fork !== ForkName.fulu) {
60
+ return false;
61
+ }
62
+ const existingSidecar = blockCache.cachedData.dataColumnsCache.get(sidecar.index);
63
+ if (!existingSidecar) {
64
+ return false;
65
+ }
66
+ return (sidecar.signedBlockHeader.message.slot === existingSidecar.dataColumn.signedBlockHeader.message.slot &&
67
+ sidecar.index === existingSidecar.dataColumn.index &&
68
+ sidecar.signedBlockHeader.message.proposerIndex ===
69
+ existingSidecar.dataColumn.signedBlockHeader.message.proposerIndex);
70
+ }
32
71
  getGossipBlockInput(config, gossipedInput, metrics) {
33
72
  let blockHex;
34
73
  let blockCache;
@@ -36,21 +75,59 @@ export class SeenGossipBlockInput {
36
75
  if (gossipedInput.type === GossipedInputType.block) {
37
76
  const { signedBlock } = gossipedInput;
38
77
  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);
78
+ blockHex = toHexString(config.getForkTypes(signedBlock.message.slot).BeaconBlock.hashTreeRoot(signedBlock.message));
79
+ blockCache = this.blockInputCache.get(blockHex) ?? getEmptyBlockInputCacheEntry(fork, ++this.globalCacheId);
41
80
  blockCache.block = signedBlock;
42
81
  }
43
- else {
82
+ else if (gossipedInput.type === GossipedInputType.blob) {
44
83
  const { blobSidecar } = gossipedInput;
45
84
  const blockRoot = ssz.phase0.BeaconBlockHeader.hashTreeRoot(blobSidecar.signedBlockHeader.message);
46
85
  fork = config.getForkName(blobSidecar.signedBlockHeader.message.slot);
47
- blockHex = toRootHex(blockRoot);
48
- blockCache = this.blockInputCache.get(blockHex) ?? getEmptyBlockInputCacheEntry(fork);
86
+ blockHex = toHexString(blockRoot);
87
+ blockCache = this.blockInputCache.get(blockHex) ?? getEmptyBlockInputCacheEntry(fork, ++this.globalCacheId);
88
+ if (blockCache.cachedData?.fork !== ForkName.deneb && blockCache.cachedData?.fork !== ForkName.electra) {
89
+ throw Error(`blob data at non deneb/electra fork=${blockCache.fork}`);
90
+ }
49
91
  // TODO: freetheblobs check if its the same blob or a duplicate and throw/take actions
50
92
  blockCache.cachedData?.blobsCache.set(blobSidecar.index, blobSidecar);
51
93
  }
94
+ else if (gossipedInput.type === GossipedInputType.dataColumn) {
95
+ const { dataColumnSidecar, dataColumnBytes } = gossipedInput;
96
+ const blockRoot = ssz.phase0.BeaconBlockHeader.hashTreeRoot(dataColumnSidecar.signedBlockHeader.message);
97
+ fork = config.getForkName(dataColumnSidecar.signedBlockHeader.message.slot);
98
+ blockHex = toHexString(blockRoot);
99
+ blockCache = this.blockInputCache.get(blockHex) ?? getEmptyBlockInputCacheEntry(fork, ++this.globalCacheId);
100
+ if (blockCache.cachedData?.fork !== ForkName.fulu) {
101
+ throw Error(`data column data at non fulu fork=${blockCache.fork}`);
102
+ }
103
+ if (this.hasDataColumnSidecar(dataColumnSidecar)) {
104
+ throw new DataColumnSidecarGossipError(GossipAction.IGNORE, {
105
+ code: DataColumnSidecarErrorCode.ALREADY_KNOWN,
106
+ slot: dataColumnSidecar.signedBlockHeader.message.slot,
107
+ columnIdx: dataColumnSidecar.index,
108
+ });
109
+ }
110
+ blockCache.cachedData?.dataColumnsCache.set(dataColumnSidecar.index, {
111
+ dataColumn: dataColumnSidecar,
112
+ // easily splice out the unsigned message as blob is a fixed length type
113
+ dataColumnBytes: dataColumnBytes?.slice(0, dataColumnBytes.length) ?? null,
114
+ });
115
+ }
116
+ else {
117
+ // somehow helps resolve typescript that all types have been exausted
118
+ throw Error("Invalid gossipedInput type");
119
+ }
52
120
  if (!this.blockInputCache.has(blockHex)) {
53
121
  this.blockInputCache.set(blockHex, blockCache);
122
+ callInNextEventLoop(() => {
123
+ getDataColumnsFromExecution(config, this.custodyConfig, this.executionEngine, this.emitter, blockCache, metrics)
124
+ .then((_success) => {
125
+ // TODO: (@matthewkeil) add metrics collection point here
126
+ })
127
+ .catch((error) => {
128
+ this.logger.warn("Error getting data columns from execution", { blockHex }, error);
129
+ });
130
+ });
54
131
  }
55
132
  const { block: signedBlock, blockInputPromise, resolveBlockInput, cachedData } = blockCache;
56
133
  if (signedBlock !== undefined) {
@@ -63,54 +140,217 @@ export class SeenGossipBlockInput {
63
140
  if (cachedData === undefined || !isForkPostDeneb(cachedData.fork)) {
64
141
  throw Error("Missing or Invalid fork cached Data for post-deneb block");
65
142
  }
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}`);
143
+ if (cachedData.fork === ForkName.deneb || cachedData.fork === ForkName.electra) {
144
+ const { blobsCache, resolveAvailability } = cachedData;
145
+ // block is available, check if all blobs have shown up
146
+ const { slot, body } = signedBlock.message;
147
+ const { blobKzgCommitments } = body;
148
+ const blockInfo = `blockHex=${blockHex}, slot=${slot}`;
149
+ if (blobKzgCommitments.length < blobsCache.size) {
150
+ throw Error(`Received more blobs=${blobsCache.size} than commitments=${blobKzgCommitments.length} for ${blockInfo}`);
151
+ }
152
+ if (blobKzgCommitments.length === blobsCache.size) {
153
+ const allBlobs = getBlockInputBlobs(blobsCache);
154
+ const { blobs } = allBlobs;
155
+ const blockData = {
156
+ fork: cachedData.fork,
157
+ ...allBlobs,
158
+ blobsSource: BlobsSource.gossip,
159
+ };
160
+ resolveAvailability(blockData);
161
+ metrics?.syncUnknownBlock.resolveAvailabilitySource.inc({ source: BlockInputAvailabilitySource.GOSSIP });
162
+ const blockInput = getBlockInput.availableData(config, signedBlock, BlockSource.gossip, blockData);
163
+ resolveBlockInput(blockInput);
164
+ return {
165
+ blockInput,
166
+ blockInputMeta: { pending: null, haveBlobs: blobs.length, expectedBlobs: blobKzgCommitments.length },
167
+ };
168
+ }
169
+ const blockInput = getBlockInput.dataPromise(config, signedBlock, BlockSource.gossip, cachedData);
170
+ resolveBlockInput(blockInput);
171
+ return {
172
+ blockInput,
173
+ blockInputMeta: {
174
+ pending: GossipedInputType.blob,
175
+ haveBlobs: blobsCache.size,
176
+ expectedBlobs: blobKzgCommitments.length,
177
+ },
178
+ };
73
179
  }
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);
180
+ if (cachedData.fork === ForkName.fulu) {
181
+ const { dataColumnsCache, resolveAvailability, calledRecover } = cachedData;
182
+ // block is available, check if all blobs have shown up
183
+ const { slot } = signedBlock.message;
184
+ const blockInfo = `blockHex=${blockHex}, slot=${slot}`;
185
+ if (NUMBER_OF_COLUMNS < dataColumnsCache.size) {
186
+ throw Error(`Received more dataColumns=${dataColumnsCache.size} than columns=${NUMBER_OF_COLUMNS} for ${blockInfo}`);
187
+ }
188
+ // get the custody columns and see if we have got all the requisite columns
189
+ const blobKzgCommitmentsLen = signedBlock.message.body.blobKzgCommitments.length;
190
+ if (blobKzgCommitmentsLen === 0) {
191
+ const blockData = {
192
+ fork: cachedData.fork,
193
+ dataColumns: [],
194
+ dataColumnsBytes: [],
195
+ dataColumnsSource: DataColumnsSource.gossip,
196
+ };
197
+ resolveAvailability(blockData);
198
+ metrics?.syncUnknownBlock.resolveAvailabilitySource.inc({ source: BlockInputAvailabilitySource.GOSSIP });
199
+ const blockInput = getBlockInput.availableData(config, signedBlock, BlockSource.gossip, blockData);
200
+ resolveBlockInput(blockInput);
201
+ return {
202
+ blockInput,
203
+ blockInputMeta: { pending: null, haveColumns: 0, expectedColumns: 0 },
204
+ };
205
+ }
206
+ const resolveAvailabilityAndBlockInput = (source) => {
207
+ const allDataColumns = getBlockInputDataColumns(dataColumnsCache, this.custodyConfig.sampledColumns);
208
+ const blockData = {
209
+ fork: cachedData.fork,
210
+ ...allDataColumns,
211
+ dataColumnsSource: DataColumnsSource.gossip,
212
+ };
213
+ resolveAvailability(blockData);
214
+ // TODO(das): should not use syncUnknownBlock metrics here
215
+ metrics?.syncUnknownBlock.resolveAvailabilitySource.inc({ source });
216
+ metrics?.dataColumns.bySource.inc({ source: DataColumnsSource.gossip });
217
+ const blockInput = getBlockInput.availableData(config, signedBlock, BlockSource.gossip, blockData);
218
+ resolveBlockInput(blockInput);
219
+ return blockInput;
220
+ };
221
+ const columnCount = dataColumnsCache.size;
222
+ if (
223
+ // only try to recover all columns with "--supernode"
224
+ this.custodyConfig.sampledColumns.length === NUMBER_OF_COLUMNS &&
225
+ columnCount >= NUMBER_OF_COLUMNS / 2 &&
226
+ columnCount < NUMBER_OF_COLUMNS &&
227
+ !calledRecover &&
228
+ // doing recover right away is not efficient because it may delay data_column_sidecar validation
229
+ this.clock.secFromSlot(slot) * 1000 >= BLOCK_AVAILABILITY_CUTOFF_MS) {
230
+ // should call once per slot
231
+ cachedData.calledRecover = true;
232
+ callInNextEventLoop(async () => {
233
+ const logCtx = {
234
+ blockHex,
235
+ slot,
236
+ dataColumns: dataColumnsCache.size,
237
+ };
238
+ const recoverResult = await recoverDataColumnSidecars(dataColumnsCache, this.clock, metrics).catch((e) => {
239
+ this.logger.error("Error recovering data column sidecars", logCtx, e);
240
+ return RecoverResult.Failed;
241
+ });
242
+ metrics?.recoverDataColumnSidecars.reconstructionResult.inc({ result: recoverResult });
243
+ switch (recoverResult) {
244
+ case RecoverResult.SuccessResolved: {
245
+ resolveAvailabilityAndBlockInput(BlockInputAvailabilitySource.RECOVERED);
246
+ // Publish columns if and only if subscribed to them
247
+ const sampledColumns = this.custodyConfig.sampledColumns.map((columnIndex) => {
248
+ const dataColumn = dataColumnsCache.get(columnIndex)?.dataColumn;
249
+ if (!dataColumn) {
250
+ throw Error(`After recover, missing data column for index=${columnIndex} in cache`);
251
+ }
252
+ return dataColumn;
253
+ });
254
+ // for columns that we already seen, it will be ignored through `ignoreDuplicatePublishError` gossip option
255
+ this.emitter.emit(ChainEvent.publishDataColumns, sampledColumns);
256
+ this.logger.verbose("Recovered data column sidecars and resolved availability", logCtx);
257
+ break;
258
+ }
259
+ case RecoverResult.SuccessLate:
260
+ this.logger.verbose("Recovered data column sidecars but it's late to resolve availability", logCtx);
261
+ break;
262
+ case RecoverResult.Failed:
263
+ this.logger.verbose("Failed to recover data column sidecars", logCtx);
264
+ break;
265
+ case RecoverResult.NotAttemptedFull:
266
+ this.logger.verbose("Did not attempt because we have full column sidecars", logCtx);
267
+ break;
268
+ case RecoverResult.NotAttemptedLessThanHalf:
269
+ this.logger.verbose("Did not attempt because we have too few column sidecars", logCtx);
270
+ break;
271
+ default:
272
+ break;
273
+ }
274
+ });
275
+ }
276
+ if (hasSampledDataColumns(this.custodyConfig, dataColumnsCache)) {
277
+ const blockInput = resolveAvailabilityAndBlockInput(BlockInputAvailabilitySource.GOSSIP);
278
+ const allDataColumns = getBlockInputDataColumns(dataColumnsCache, this.custodyConfig.sampledColumns);
279
+ const { dataColumns } = allDataColumns;
280
+ return {
281
+ blockInput,
282
+ blockInputMeta: {
283
+ pending: null,
284
+ haveColumns: dataColumns.length,
285
+ expectedColumns: this.custodyConfig.sampledColumns.length,
286
+ },
287
+ };
288
+ }
289
+ const blockInput = getBlockInput.dataPromise(config, signedBlock, BlockSource.gossip, cachedData);
80
290
  resolveBlockInput(blockInput);
81
291
  return {
82
292
  blockInput,
83
- blockInputMeta: { pending: null, haveBlobs: allBlobs.blobs.length, expectedBlobs: blobKzgCommitments.length },
293
+ blockInputMeta: {
294
+ pending: GossipedInputType.dataColumn,
295
+ haveColumns: dataColumnsCache.size,
296
+ expectedColumns: this.custodyConfig.sampledColumns.length,
297
+ },
84
298
  };
85
299
  }
86
- const blockInput = getBlockInput.dataPromise(config, signedBlock, BlockSource.gossip, cachedData);
87
- resolveBlockInput(blockInput);
88
- return {
89
- blockInput,
90
- blockInputMeta: {
91
- pending: GossipedInputType.blob,
92
- haveBlobs: blobsCache.size,
93
- expectedBlobs: blobKzgCommitments.length,
94
- },
95
- };
300
+ throw Error(`Invalid fork=${fork}`);
96
301
  }
97
302
  // will need to wait for the block to showup
98
303
  if (cachedData === undefined) {
99
304
  throw Error("Missing cachedData for deneb+ blobs");
100
305
  }
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 },
110
- };
306
+ if (cachedData.fork === ForkName.deneb || cachedData.fork === ForkName.electra) {
307
+ const { blobsCache } = cachedData;
308
+ return {
309
+ blockInput: {
310
+ block: null,
311
+ blockRootHex: blockHex,
312
+ cachedData,
313
+ blockInputPromise,
314
+ },
315
+ blockInputMeta: { pending: GossipedInputType.block, haveBlobs: blobsCache.size, expectedBlobs: null },
316
+ };
317
+ }
318
+ if (fork === ForkName.fulu) {
319
+ const { dataColumnsCache } = cachedData;
320
+ return {
321
+ blockInput: {
322
+ block: null,
323
+ blockRootHex: blockHex,
324
+ cachedData,
325
+ blockInputPromise,
326
+ },
327
+ blockInputMeta: { pending: GossipedInputType.block, haveColumns: dataColumnsCache.size, expectedColumns: null },
328
+ };
329
+ }
330
+ throw Error(`invalid fork=${fork} data not implemented`);
331
+ /**
332
+ * TODO: @matthewkeil this code was unreachable. Commented to remove lint error but need to verify the condition
333
+ * again to make sure this is not necessary before deleting it
334
+ *
335
+ * DO NOT DELETE until verified can be removed
336
+ */
337
+ // will need to wait for the block to showup
338
+ // if (cachedData === undefined) {
339
+ // throw Error("Missing cachedData for deneb+ blobs");
340
+ // }
341
+ // const {blobsCache} = cachedData as CachedBlobs;
342
+ // return {
343
+ // blockInput: {
344
+ // block: null,
345
+ // blockRootHex: blockHex,
346
+ // cachedData: cachedData as CachedData,
347
+ // blockInputPromise,
348
+ // },
349
+ // blockInputMeta: {pending: GossipedInputType.block, haveBlobs: blobsCache.size, expectedBlobs: null},
350
+ // };
111
351
  }
112
352
  }
113
- function getEmptyBlockInputCacheEntry(fork) {
353
+ export function getEmptyBlockInputCacheEntry(fork, globalCacheId) {
114
354
  // Capture both the promise and its callbacks for blockInput and final availability
115
355
  // It is not spec'ed but in tests in Firefox and NodeJS the promise constructor is run immediately
116
356
  let resolveBlockInput = null;
@@ -123,15 +363,43 @@ function getEmptyBlockInputCacheEntry(fork) {
123
363
  if (!isForkPostDeneb(fork)) {
124
364
  return { fork, blockInputPromise, resolveBlockInput };
125
365
  }
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");
366
+ if (fork === ForkName.deneb || fork === ForkName.electra) {
367
+ let resolveAvailability = null;
368
+ const availabilityPromise = new Promise((resolveCB) => {
369
+ resolveAvailability = resolveCB;
370
+ });
371
+ if (resolveAvailability === null) {
372
+ throw Error("Promise Constructor was not executed immediately");
373
+ }
374
+ const blobsCache = new Map();
375
+ const cachedData = {
376
+ fork,
377
+ blobsCache,
378
+ availabilityPromise,
379
+ resolveAvailability,
380
+ cacheId: ++globalCacheId,
381
+ };
382
+ return { fork, blockInputPromise, resolveBlockInput, cachedData };
383
+ }
384
+ if (fork === ForkName.fulu) {
385
+ let resolveAvailability = null;
386
+ const availabilityPromise = new Promise((resolveCB) => {
387
+ resolveAvailability = resolveCB;
388
+ });
389
+ if (resolveAvailability === null) {
390
+ throw Error("Promise Constructor was not executed immediately");
391
+ }
392
+ const dataColumnsCache = new Map();
393
+ const cachedData = {
394
+ fork,
395
+ dataColumnsCache,
396
+ availabilityPromise,
397
+ resolveAvailability,
398
+ cacheId: ++globalCacheId,
399
+ calledRecover: false,
400
+ };
401
+ return { fork, blockInputPromise, resolveBlockInput, cachedData };
132
402
  }
133
- const blobsCache = new Map();
134
- const cachedData = { fork, blobsCache, availabilityPromise, resolveAvailability };
135
- return { fork, blockInputPromise, resolveBlockInput, cachedData };
403
+ throw Error(`Invalid fork=${fork} for getEmptyBlockInputCacheEntry`);
136
404
  }
137
405
  //# 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,29 @@
1
+ import { ChainConfig } from "@lodestar/config";
2
+ import { Root, Slot, SubnetID, deneb, fulu } from "@lodestar/types";
3
+ import { Metrics } from "../../metrics/metrics.js";
4
+ import { IBeaconChain } from "../interface.js";
5
+ export declare function validateGossipDataColumnSidecar(chain: IBeaconChain, dataColumnSidecar: fulu.DataColumnSidecar, gossipSubnet: SubnetID, metrics: Metrics | null): Promise<void>;
6
+ export declare function validateDataColumnsSidecars(blockSlot: Slot, blockRoot: Root, blockKzgCommitments: deneb.BlobKzgCommitments, dataColumnSidecars: fulu.DataColumnSidecars, metrics: Metrics | null, opts?: {
7
+ skipProofsCheck: boolean;
8
+ }): Promise<void>;
9
+ /**
10
+ * SPEC FUNCTION
11
+ * https://github.com/ethereum/consensus-specs/blob/v1.6.0-alpha.4/specs/fulu/p2p-interface.md#verify_data_column_sidecar
12
+ */
13
+ export declare function verifyDataColumnSidecar(dataColumnSidecar: fulu.DataColumnSidecar): void;
14
+ /**
15
+ * SPEC FUNCTION
16
+ * https://github.com/ethereum/consensus-specs/blob/v1.6.0-alpha.4/specs/fulu/p2p-interface.md#verify_data_column_sidecar_kzg_proofs
17
+ */
18
+ export declare function verifyDataColumnSidecarKzgProofs(commitments: Uint8Array[], cellIndices: number[], cells: Uint8Array[], proofs: Uint8Array[]): Promise<void>;
19
+ /**
20
+ * SPEC FUNCTION
21
+ * https://github.com/ethereum/consensus-specs/blob/v1.6.0-alpha.4/specs/fulu/p2p-interface.md#verify_data_column_sidecar_inclusion_proof
22
+ */
23
+ export declare function verifyDataColumnSidecarInclusionProof(dataColumnSidecar: fulu.DataColumnSidecar): boolean;
24
+ /**
25
+ * SPEC FUNCTION
26
+ * https://github.com/ethereum/consensus-specs/blob/v1.6.0-alpha.4/specs/fulu/p2p-interface.md#compute_subnet_for_data_column_sidecar
27
+ */
28
+ export declare function computeSubnetForDataColumnSidecar(config: ChainConfig, columnSidecar: fulu.DataColumnSidecar): SubnetID;
29
+ //# sourceMappingURL=dataColumnSidecar.d.ts.map