@lodestar/beacon-node 1.34.0-dev.8cfc843bd3 → 1.34.0-dev.8d743ffafc

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 (245) 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/state/index.js +6 -12
  4. package/lib/api/impl/beacon/state/index.js.map +1 -1
  5. package/lib/api/impl/debug/index.d.ts +1 -1
  6. package/lib/api/impl/debug/index.js +24 -1
  7. package/lib/api/impl/debug/index.js.map +1 -1
  8. package/lib/api/impl/validator/index.js +41 -24
  9. package/lib/api/impl/validator/index.js.map +1 -1
  10. package/lib/chain/archiveStore/archiveStore.d.ts +1 -1
  11. package/lib/chain/archiveStore/archiveStore.js +2 -2
  12. package/lib/chain/archiveStore/interface.d.ts +1 -1
  13. package/lib/chain/archiveStore/utils/archiveBlocks.d.ts +1 -1
  14. package/lib/chain/archiveStore/utils/archiveBlocks.js +91 -23
  15. package/lib/chain/archiveStore/utils/archiveBlocks.js.map +1 -1
  16. package/lib/chain/beaconProposerCache.d.ts +1 -0
  17. package/lib/chain/beaconProposerCache.js +3 -0
  18. package/lib/chain/beaconProposerCache.js.map +1 -1
  19. package/lib/chain/blocks/importBlock.js +3 -2
  20. package/lib/chain/blocks/importBlock.js.map +1 -1
  21. package/lib/chain/blocks/types.d.ts +66 -23
  22. package/lib/chain/blocks/types.js +39 -5
  23. package/lib/chain/blocks/types.js.map +1 -1
  24. package/lib/chain/blocks/verifyBlocksDataAvailability.js +21 -10
  25. package/lib/chain/blocks/verifyBlocksDataAvailability.js.map +1 -1
  26. package/lib/chain/blocks/writeBlockInputToDb.js +89 -15
  27. package/lib/chain/blocks/writeBlockInputToDb.js.map +1 -1
  28. package/lib/chain/chain.d.ts +18 -101
  29. package/lib/chain/chain.js +91 -67
  30. package/lib/chain/chain.js.map +1 -1
  31. package/lib/chain/emitter.d.ts +18 -2
  32. package/lib/chain/emitter.js +13 -0
  33. package/lib/chain/emitter.js.map +1 -1
  34. package/lib/chain/errors/dataColumnSidecarError.d.ts +69 -0
  35. package/lib/chain/errors/dataColumnSidecarError.js +21 -0
  36. package/lib/chain/errors/dataColumnSidecarError.js.map +1 -0
  37. package/lib/chain/errors/index.d.ts +1 -0
  38. package/lib/chain/errors/index.js +1 -0
  39. package/lib/chain/errors/index.js.map +1 -1
  40. package/lib/chain/interface.d.ts +6 -7
  41. package/lib/chain/interface.js.map +1 -1
  42. package/lib/chain/options.d.ts +4 -1
  43. package/lib/chain/options.js +1 -0
  44. package/lib/chain/options.js.map +1 -1
  45. package/lib/chain/prepareNextSlot.js +2 -1
  46. package/lib/chain/prepareNextSlot.js.map +1 -1
  47. package/lib/chain/produceBlock/produceBlockBody.d.ts +30 -16
  48. package/lib/chain/produceBlock/produceBlockBody.js +28 -28
  49. package/lib/chain/produceBlock/produceBlockBody.js.map +1 -1
  50. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.d.ts +6 -3
  51. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.js +28 -4
  52. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.js.map +1 -1
  53. package/lib/chain/seenCache/seenGossipBlockInput.d.ts +64 -18
  54. package/lib/chain/seenCache/seenGossipBlockInput.js +321 -53
  55. package/lib/chain/seenCache/seenGossipBlockInput.js.map +1 -1
  56. package/lib/chain/validation/dataColumnSidecar.d.ts +29 -0
  57. package/lib/chain/validation/dataColumnSidecar.js +248 -0
  58. package/lib/chain/validation/dataColumnSidecar.js.map +1 -0
  59. package/lib/db/beacon.d.ts +3 -1
  60. package/lib/db/beacon.js +3 -1
  61. package/lib/db/beacon.js.map +1 -1
  62. package/lib/db/buckets.d.ts +3 -1
  63. package/lib/db/buckets.js +2 -0
  64. package/lib/db/buckets.js.map +1 -1
  65. package/lib/db/interface.d.ts +3 -1
  66. package/lib/db/repositories/dataColumnSidecars.d.ts +47 -0
  67. package/lib/db/repositories/dataColumnSidecars.js +40 -0
  68. package/lib/db/repositories/dataColumnSidecars.js.map +1 -0
  69. package/lib/db/repositories/dataColumnSidecarsArchive.d.ts +15 -0
  70. package/lib/db/repositories/dataColumnSidecarsArchive.js +23 -0
  71. package/lib/db/repositories/dataColumnSidecarsArchive.js.map +1 -0
  72. package/lib/db/repositories/index.d.ts +2 -0
  73. package/lib/db/repositories/index.js +2 -0
  74. package/lib/db/repositories/index.js.map +1 -1
  75. package/lib/execution/builder/http.d.ts +20 -4
  76. package/lib/execution/builder/http.js +30 -11
  77. package/lib/execution/builder/http.js.map +1 -1
  78. package/lib/execution/builder/interface.d.ts +5 -4
  79. package/lib/execution/engine/http.d.ts +8 -5
  80. package/lib/execution/engine/http.js +56 -42
  81. package/lib/execution/engine/http.js.map +1 -1
  82. package/lib/execution/engine/interface.d.ts +6 -13
  83. package/lib/execution/engine/interface.js +1 -1
  84. package/lib/execution/engine/interface.js.map +1 -1
  85. package/lib/execution/engine/mock.d.ts +1 -0
  86. package/lib/execution/engine/mock.js +5 -0
  87. package/lib/execution/engine/mock.js.map +1 -1
  88. package/lib/execution/engine/types.d.ts +12 -2
  89. package/lib/execution/engine/types.js +8 -2
  90. package/lib/execution/engine/types.js.map +1 -1
  91. package/lib/metrics/metrics/beacon.d.ts +15 -5
  92. package/lib/metrics/metrics/beacon.js +61 -14
  93. package/lib/metrics/metrics/beacon.js.map +1 -1
  94. package/lib/metrics/metrics/lodestar.d.ts +24 -1
  95. package/lib/metrics/metrics/lodestar.js +45 -0
  96. package/lib/metrics/metrics/lodestar.js.map +1 -1
  97. package/lib/network/core/metrics.d.ts +10 -3
  98. package/lib/network/core/metrics.js +22 -4
  99. package/lib/network/core/metrics.js.map +1 -1
  100. package/lib/network/core/networkCore.d.ts +15 -4
  101. package/lib/network/core/networkCore.js +73 -23
  102. package/lib/network/core/networkCore.js.map +1 -1
  103. package/lib/network/core/networkCoreWorker.js +2 -0
  104. package/lib/network/core/networkCoreWorker.js.map +1 -1
  105. package/lib/network/core/networkCoreWorkerHandler.d.ts +5 -3
  106. package/lib/network/core/networkCoreWorkerHandler.js +6 -1
  107. package/lib/network/core/networkCoreWorkerHandler.js.map +1 -1
  108. package/lib/network/core/types.d.ts +7 -4
  109. package/lib/network/events.d.ts +4 -2
  110. package/lib/network/events.js.map +1 -1
  111. package/lib/network/gossip/gossipsub.d.ts +2 -2
  112. package/lib/network/gossip/gossipsub.js +8 -6
  113. package/lib/network/gossip/gossipsub.js.map +1 -1
  114. package/lib/network/gossip/interface.d.ts +8 -1
  115. package/lib/network/gossip/interface.js +1 -0
  116. package/lib/network/gossip/interface.js.map +1 -1
  117. package/lib/network/gossip/scoringParameters.d.ts +6 -2
  118. package/lib/network/gossip/scoringParameters.js.map +1 -1
  119. package/lib/network/gossip/topic.d.ts +2005 -1456
  120. package/lib/network/gossip/topic.js +29 -1
  121. package/lib/network/gossip/topic.js.map +1 -1
  122. package/lib/network/interface.d.ts +9 -1
  123. package/lib/network/metadata.d.ts +9 -5
  124. package/lib/network/metadata.js +26 -5
  125. package/lib/network/metadata.js.map +1 -1
  126. package/lib/network/network.d.ts +12 -2
  127. package/lib/network/network.js +73 -11
  128. package/lib/network/network.js.map +1 -1
  129. package/lib/network/networkConfig.d.ts +12 -0
  130. package/lib/network/networkConfig.js +2 -0
  131. package/lib/network/networkConfig.js.map +1 -0
  132. package/lib/network/options.d.ts +1 -0
  133. package/lib/network/options.js +5 -0
  134. package/lib/network/options.js.map +1 -1
  135. package/lib/network/peers/discover.d.ts +8 -3
  136. package/lib/network/peers/discover.js +99 -14
  137. package/lib/network/peers/discover.js.map +1 -1
  138. package/lib/network/peers/peerManager.d.ts +10 -4
  139. package/lib/network/peers/peerManager.js +105 -19
  140. package/lib/network/peers/peerManager.js.map +1 -1
  141. package/lib/network/peers/peersData.d.ts +17 -3
  142. package/lib/network/peers/peersData.js.map +1 -1
  143. package/lib/network/peers/score/interface.d.ts +1 -1
  144. package/lib/network/peers/score/score.d.ts +2 -2
  145. package/lib/network/peers/score/score.js +4 -1
  146. package/lib/network/peers/score/score.js.map +1 -1
  147. package/lib/network/peers/score/store.d.ts +3 -1
  148. package/lib/network/peers/score/store.js +6 -2
  149. package/lib/network/peers/score/store.js.map +1 -1
  150. package/lib/network/peers/utils/assertPeerRelevance.d.ts +7 -3
  151. package/lib/network/peers/utils/assertPeerRelevance.js +10 -1
  152. package/lib/network/peers/utils/assertPeerRelevance.js.map +1 -1
  153. package/lib/network/peers/utils/prioritizePeers.d.ts +19 -7
  154. package/lib/network/peers/utils/prioritizePeers.js +42 -6
  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 +165 -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 +1 -0
  163. package/lib/network/processor/index.js.map +1 -1
  164. package/lib/network/reqresp/ReqRespBeaconNode.d.ts +2 -2
  165. package/lib/network/reqresp/ReqRespBeaconNode.js +36 -14
  166. package/lib/network/reqresp/ReqRespBeaconNode.js.map +1 -1
  167. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.d.ts +24 -4
  168. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.js +259 -20
  169. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.js.map +1 -1
  170. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.d.ts +32 -6
  171. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.js +283 -28
  172. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.js.map +1 -1
  173. package/lib/network/reqresp/handlers/beaconBlocksByRange.d.ts +1 -1
  174. package/lib/network/reqresp/handlers/beaconBlocksByRange.js.map +1 -1
  175. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts +8 -0
  176. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js +92 -0
  177. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js.map +1 -0
  178. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.d.ts +6 -0
  179. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js +50 -0
  180. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js.map +1 -0
  181. package/lib/network/reqresp/handlers/index.js +10 -0
  182. package/lib/network/reqresp/handlers/index.js.map +1 -1
  183. package/lib/network/reqresp/protocols.d.ts +4 -0
  184. package/lib/network/reqresp/protocols.js +20 -0
  185. package/lib/network/reqresp/protocols.js.map +1 -1
  186. package/lib/network/reqresp/rateLimit.js +10 -0
  187. package/lib/network/reqresp/rateLimit.js.map +1 -1
  188. package/lib/network/reqresp/score.js +3 -0
  189. package/lib/network/reqresp/score.js.map +1 -1
  190. package/lib/network/reqresp/types.d.ts +11 -4
  191. package/lib/network/reqresp/types.js +12 -3
  192. package/lib/network/reqresp/types.js.map +1 -1
  193. package/lib/network/statusCache.d.ts +5 -5
  194. package/lib/network/statusCache.js.map +1 -1
  195. package/lib/network/subnets/interface.d.ts +3 -0
  196. package/lib/network/subnets/interface.js +14 -1
  197. package/lib/network/subnets/interface.js.map +1 -1
  198. package/lib/network/subnets/syncnetsService.js +4 -5
  199. package/lib/network/subnets/syncnetsService.js.map +1 -1
  200. package/lib/node/nodejs.js +1 -0
  201. package/lib/node/nodejs.js.map +1 -1
  202. package/lib/sync/constants.d.ts +18 -3
  203. package/lib/sync/constants.js +21 -3
  204. package/lib/sync/constants.js.map +1 -1
  205. package/lib/sync/interface.d.ts +2 -2
  206. package/lib/sync/interface.js +1 -1
  207. package/lib/sync/interface.js.map +1 -1
  208. package/lib/sync/range/batch.d.ts +17 -2
  209. package/lib/sync/range/batch.js +39 -7
  210. package/lib/sync/range/batch.js.map +1 -1
  211. package/lib/sync/range/chain.d.ts +15 -1
  212. package/lib/sync/range/chain.js +124 -33
  213. package/lib/sync/range/chain.js.map +1 -1
  214. package/lib/sync/range/range.d.ts +3 -2
  215. package/lib/sync/range/range.js +9 -3
  216. package/lib/sync/range/range.js.map +1 -1
  217. package/lib/sync/range/utils/chainTarget.d.ts +5 -1
  218. package/lib/sync/range/utils/chainTarget.js +26 -1
  219. package/lib/sync/range/utils/chainTarget.js.map +1 -1
  220. package/lib/sync/range/utils/peerBalancer.d.ts +19 -5
  221. package/lib/sync/range/utils/peerBalancer.js +104 -10
  222. package/lib/sync/range/utils/peerBalancer.js.map +1 -1
  223. package/lib/sync/sync.js +1 -1
  224. package/lib/sync/sync.js.map +1 -1
  225. package/lib/sync/unknownBlock.d.ts +10 -2
  226. package/lib/sync/unknownBlock.js +257 -76
  227. package/lib/sync/unknownBlock.js.map +1 -1
  228. package/lib/sync/utils/remoteSyncType.d.ts +4 -4
  229. package/lib/sync/utils/remoteSyncType.js.map +1 -1
  230. package/lib/util/blobs.d.ts +16 -4
  231. package/lib/util/blobs.js +122 -5
  232. package/lib/util/blobs.js.map +1 -1
  233. package/lib/util/dataColumns.d.ts +137 -0
  234. package/lib/util/dataColumns.js +358 -0
  235. package/lib/util/dataColumns.js.map +1 -0
  236. package/lib/util/metadata.d.ts +5 -0
  237. package/lib/util/metadata.js +10 -0
  238. package/lib/util/metadata.js.map +1 -1
  239. package/lib/util/sszBytes.d.ts +1 -0
  240. package/lib/util/sszBytes.js +17 -0
  241. package/lib/util/sszBytes.js.map +1 -1
  242. package/package.json +16 -16
  243. package/lib/network/reqresp/handlers/status.d.ts +0 -4
  244. package/lib/network/reqresp/handlers/status.js +0 -11
  245. package/lib/network/reqresp/handlers/status.js.map +0 -1
@@ -1,11 +1,23 @@
1
1
  import { ChainForkConfig } from "@lodestar/config";
2
2
  import { ForkName } from "@lodestar/params";
3
- import { BeaconBlockBody, SignedBeaconBlock, deneb } from "@lodestar/types";
3
+ import { BeaconBlockBody, SignedBeaconBlock, deneb, fulu } from "@lodestar/types";
4
4
  type VersionHash = Uint8Array;
5
5
  export declare function kzgCommitmentToVersionedHash(kzgCommitment: deneb.KZGCommitment): VersionHash;
6
6
  export declare function computeInclusionProof(fork: ForkName, body: BeaconBlockBody, index: number): deneb.KzgCommitmentInclusionProof;
7
- export declare function computeBlobSidecars(config: ChainForkConfig, signedBlock: SignedBeaconBlock, contents: deneb.Contents & {
8
- kzgCommitmentInclusionProofs?: deneb.KzgCommitmentInclusionProof[];
9
- }): deneb.BlobSidecars;
7
+ /**
8
+ * SPEC FUNCTION get_blob_sidecars
9
+ * https://github.com/ethereum/consensus-specs/blob/v1.6.0-alpha.4/specs/deneb/validator.md#sidecar
10
+ */
11
+ export declare function getBlobSidecars(config: ChainForkConfig, signedBlock: SignedBeaconBlock, blobs: deneb.Blobs, proofs: deneb.KZGProofs): deneb.BlobSidecars;
12
+ /**
13
+ * If the node obtains 50%+ of all the columns, it SHOULD reconstruct the full data matrix via the recover_matrix helper
14
+ * See https://github.com/ethereum/consensus-specs/blob/v1.6.0-alpha.4/specs/fulu/das-core.md#recover_matrix
15
+ */
16
+ export declare function recoverDataColumnSidecars(partialSidecars: Map<number, fulu.DataColumnSidecar>): Promise<fulu.DataColumnSidecars | null>;
17
+ /**
18
+ * Reconstruct blobs from a set of data columns, at least 50%+ of all the columns
19
+ * must be provided to allow to reconstruct the full data matrix
20
+ */
21
+ export declare function reconstructBlobs(sidecars: fulu.DataColumnSidecars): Promise<deneb.Blobs>;
10
22
  export {};
11
23
  //# sourceMappingURL=blobs.d.ts.map
package/lib/util/blobs.js CHANGED
@@ -1,8 +1,9 @@
1
1
  import { digest as sha256Digest } from "@chainsafe/as-sha256";
2
2
  import { Tree } from "@chainsafe/persistent-merkle-tree";
3
- import { KZG_COMMITMENT_GINDEX0, VERSIONED_HASH_VERSION_KZG } from "@lodestar/params";
3
+ import { BYTES_PER_CELL, BYTES_PER_FIELD_ELEMENT, CELLS_PER_EXT_BLOB, FIELD_ELEMENTS_PER_BLOB, KZG_COMMITMENT_GINDEX0, NUMBER_OF_COLUMNS, VERSIONED_HASH_VERSION_KZG, } from "@lodestar/params";
4
4
  import { signedBlockToSignedHeader } from "@lodestar/state-transition";
5
5
  import { ssz } from "@lodestar/types";
6
+ import { kzg } from "./kzg.js";
6
7
  export function kzgCommitmentToVersionedHash(kzgCommitment) {
7
8
  const hash = sha256Digest(kzgCommitment);
8
9
  // Equivalent to `VERSIONED_HASH_VERSION_KZG + hash(kzg_commitment)[1:]`
@@ -14,7 +15,11 @@ export function computeInclusionProof(fork, body, index) {
14
15
  const commitmentGindex = KZG_COMMITMENT_GINDEX0 + index;
15
16
  return new Tree(bodyView.node).getSingleProof(BigInt(commitmentGindex));
16
17
  }
17
- export function computeBlobSidecars(config, signedBlock, contents) {
18
+ /**
19
+ * SPEC FUNCTION get_blob_sidecars
20
+ * https://github.com/ethereum/consensus-specs/blob/v1.6.0-alpha.4/specs/deneb/validator.md#sidecar
21
+ */
22
+ export function getBlobSidecars(config, signedBlock, blobs, proofs) {
18
23
  const blobKzgCommitments = signedBlock.message.body.blobKzgCommitments;
19
24
  if (blobKzgCommitments === undefined) {
20
25
  throw Error("Invalid block with missing blobKzgCommitments for computeBlobSidecars");
@@ -22,10 +27,122 @@ export function computeBlobSidecars(config, signedBlock, contents) {
22
27
  const signedBlockHeader = signedBlockToSignedHeader(config, signedBlock);
23
28
  const fork = config.getForkName(signedBlockHeader.message.slot);
24
29
  return blobKzgCommitments.map((kzgCommitment, index) => {
25
- const blob = contents.blobs[index];
26
- const kzgProof = contents.kzgProofs[index];
27
- const kzgCommitmentInclusionProof = contents.kzgCommitmentInclusionProofs?.[index] ?? computeInclusionProof(fork, signedBlock.message.body, index);
30
+ const blob = blobs[index];
31
+ const kzgProof = proofs[index];
32
+ const kzgCommitmentInclusionProof = computeInclusionProof(fork, signedBlock.message.body, index);
28
33
  return { index, blob, kzgCommitment, kzgProof, signedBlockHeader, kzgCommitmentInclusionProof };
29
34
  });
30
35
  }
36
+ /**
37
+ * If the node obtains 50%+ of all the columns, it SHOULD reconstruct the full data matrix via the recover_matrix helper
38
+ * See https://github.com/ethereum/consensus-specs/blob/v1.6.0-alpha.4/specs/fulu/das-core.md#recover_matrix
39
+ */
40
+ export async function recoverDataColumnSidecars(partialSidecars) {
41
+ const columnCount = partialSidecars.size;
42
+ if (columnCount < NUMBER_OF_COLUMNS / 2) {
43
+ // We don't have enough columns to recover
44
+ return null;
45
+ }
46
+ if (columnCount === NUMBER_OF_COLUMNS) {
47
+ // full columns, no need to recover
48
+ return Array.from(partialSidecars.values());
49
+ }
50
+ const firstDataColumn = partialSidecars.values().next().value;
51
+ if (firstDataColumn == null) {
52
+ // should not happen because we check the size of the cache before this
53
+ throw new Error("No data column found in cache to recover from");
54
+ }
55
+ const blobCount = firstDataColumn.kzgCommitments.length;
56
+ const fullColumns = Array.from({ length: NUMBER_OF_COLUMNS }, () => new Array(blobCount));
57
+ const blobProofs = Array.from({ length: blobCount });
58
+ // https://github.com/ethereum/consensus-specs/blob/v1.6.0-alpha.4/specs/fulu/das-core.md#recover_matrix
59
+ const cellsAndProofs = await Promise.all(blobProofs.map((_, blobIndex) => {
60
+ const cellIndices = [];
61
+ const cells = [];
62
+ for (const [columnIndex, dataColumn] of partialSidecars.entries()) {
63
+ cellIndices.push(columnIndex);
64
+ cells.push(dataColumn.column[blobIndex]);
65
+ }
66
+ // recovered cells and proofs are of the same row/blob, their length should be NUMBER_OF_COLUMNS
67
+ return kzg.asyncRecoverCellsAndKzgProofs(cellIndices, cells);
68
+ }));
69
+ for (let blobIndex = 0; blobIndex < blobCount; blobIndex++) {
70
+ const recoveredCells = cellsAndProofs[blobIndex].cells;
71
+ blobProofs[blobIndex] = cellsAndProofs[blobIndex].proofs;
72
+ for (let columnIndex = 0; columnIndex < NUMBER_OF_COLUMNS; columnIndex++) {
73
+ fullColumns[columnIndex][blobIndex] = recoveredCells[columnIndex];
74
+ }
75
+ }
76
+ const result = new Array(NUMBER_OF_COLUMNS);
77
+ for (let columnIndex = 0; columnIndex < NUMBER_OF_COLUMNS; columnIndex++) {
78
+ let sidecar = partialSidecars.get(columnIndex);
79
+ if (sidecar) {
80
+ // We already have this column
81
+ result[columnIndex] = sidecar;
82
+ continue;
83
+ }
84
+ sidecar = {
85
+ index: columnIndex,
86
+ column: fullColumns[columnIndex],
87
+ kzgCommitments: firstDataColumn.kzgCommitments,
88
+ kzgProofs: Array.from({ length: blobCount }, (_, rowIndex) => blobProofs[rowIndex][columnIndex]),
89
+ signedBlockHeader: firstDataColumn.signedBlockHeader,
90
+ kzgCommitmentsInclusionProof: firstDataColumn.kzgCommitmentsInclusionProof,
91
+ };
92
+ result[columnIndex] = sidecar;
93
+ }
94
+ return result;
95
+ }
96
+ /**
97
+ * Reconstruct blobs from a set of data columns, at least 50%+ of all the columns
98
+ * must be provided to allow to reconstruct the full data matrix
99
+ */
100
+ export async function reconstructBlobs(sidecars) {
101
+ if (sidecars.length < NUMBER_OF_COLUMNS / 2) {
102
+ throw Error(`Expected at least ${NUMBER_OF_COLUMNS / 2} data columns to reconstruct blobs, received ${sidecars.length}`);
103
+ }
104
+ let fullSidecars;
105
+ if (sidecars.length === NUMBER_OF_COLUMNS) {
106
+ // Full columns, no need to recover
107
+ fullSidecars = sidecars;
108
+ }
109
+ else {
110
+ const sidecarsByIndex = new Map(sidecars.map((sc) => [sc.index, sc]));
111
+ const recoveredSidecars = await recoverDataColumnSidecars(sidecarsByIndex);
112
+ if (recoveredSidecars === null) {
113
+ // Should not happen because we check the column count above
114
+ throw Error("Failed to reconstruct the full data matrix");
115
+ }
116
+ fullSidecars = recoveredSidecars;
117
+ }
118
+ const blobCount = fullSidecars[0].column.length;
119
+ const blobs = new Array(blobCount);
120
+ const ordered = fullSidecars.slice().sort((a, b) => a.index - b.index);
121
+ for (let row = 0; row < blobCount; row++) {
122
+ // 128 cells that make up one "extended blob" row
123
+ const cells = ordered.map((col) => col.column[row]);
124
+ blobs[row] = cellsToBlob(cells);
125
+ }
126
+ return blobs;
127
+ }
128
+ /**
129
+ * Concatenate the systematic half (columns 0‑63) of a row of cells into
130
+ * the original 131072 byte blob. The parity half (64‑127) is ignored as
131
+ * it is only needed for erasure‑coding recovery when columns are missing.
132
+ */
133
+ function cellsToBlob(cells) {
134
+ if (cells.length !== CELLS_PER_EXT_BLOB) {
135
+ throw Error(`Expected ${CELLS_PER_EXT_BLOB} cells to reconstruct blob, received ${cells.length}`);
136
+ }
137
+ const blob = new Uint8Array(BYTES_PER_FIELD_ELEMENT * FIELD_ELEMENTS_PER_BLOB);
138
+ // Only the first 64 cells hold the original bytes
139
+ for (let i = 0; i < CELLS_PER_EXT_BLOB / 2; i++) {
140
+ const cell = cells[i];
141
+ if (cell.length !== BYTES_PER_CELL) {
142
+ throw Error(`Cell ${i} has incorrect byte size ${cell.length} != ${BYTES_PER_CELL}`);
143
+ }
144
+ blob.set(cell, i * BYTES_PER_CELL);
145
+ }
146
+ return blob;
147
+ }
31
148
  //# sourceMappingURL=blobs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"blobs.js","sourceRoot":"","sources":["../../src/util/blobs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,MAAM,IAAI,YAAY,EAAC,MAAM,sBAAsB,CAAC;AAC5D,OAAO,EAAC,IAAI,EAAC,MAAM,mCAAmC,CAAC;AAEvD,OAAO,EAAoB,sBAAsB,EAAE,0BAA0B,EAAC,MAAM,kBAAkB,CAAC;AACvG,OAAO,EAAC,yBAAyB,EAAC,MAAM,4BAA4B,CAAC;AACrE,OAAO,EAAyD,GAAG,EAAC,MAAM,iBAAiB,CAAC;AAI5F,MAAM,UAAU,4BAA4B,CAAC,aAAkC;IAC7E,MAAM,IAAI,GAAG,YAAY,CAAC,aAAa,CAAC,CAAC;IACzC,wEAAwE;IACxE,IAAI,CAAC,CAAC,CAAC,GAAG,0BAA0B,CAAC;IACrC,OAAO,IAAI,CAAC;AACd,CAAC;AAED,MAAM,UAAU,qBAAqB,CACnC,IAAc,EACd,IAAqB,EACrB,KAAa;IAEb,MAAM,QAAQ,GAAI,GAAG,CAAC,IAAI,CAAC,CAAC,eAA2D,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IACrG,MAAM,gBAAgB,GAAG,sBAAsB,GAAG,KAAK,CAAC;IACxD,OAAO,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,cAAc,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC;AAC1E,CAAC;AAED,MAAM,UAAU,mBAAmB,CACjC,MAAuB,EACvB,WAA8B,EAC9B,QAA+F;IAE/F,MAAM,kBAAkB,GAAI,WAAuC,CAAC,OAAO,CAAC,IAAI,CAAC,kBAAkB,CAAC;IACpG,IAAI,kBAAkB,KAAK,SAAS,EAAE,CAAC;QACrC,MAAM,KAAK,CAAC,uEAAuE,CAAC,CAAC;IACvF,CAAC;IAED,MAAM,iBAAiB,GAAG,yBAAyB,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IACzE,MAAM,IAAI,GAAG,MAAM,CAAC,WAAW,CAAC,iBAAiB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAEhE,OAAO,kBAAkB,CAAC,GAAG,CAAC,CAAC,aAAa,EAAE,KAAK,EAAE,EAAE;QACrD,MAAM,IAAI,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACnC,MAAM,QAAQ,GAAG,QAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAC3C,MAAM,2BAA2B,GAC/B,QAAQ,CAAC,4BAA4B,EAAE,CAAC,KAAK,CAAC,IAAI,qBAAqB,CAAC,IAAI,EAAE,WAAW,CAAC,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QAEjH,OAAO,EAAC,KAAK,EAAE,IAAI,EAAE,aAAa,EAAE,QAAQ,EAAE,iBAAiB,EAAE,2BAA2B,EAAC,CAAC;IAChG,CAAC,CAAC,CAAC;AACL,CAAC"}
1
+ {"version":3,"file":"blobs.js","sourceRoot":"","sources":["../../src/util/blobs.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,137 @@
1
+ import { ChainForkConfig } from "@lodestar/config";
2
+ import { ForkName, ForkPostFulu } from "@lodestar/params";
3
+ import { BeaconBlockBody, ColumnIndex, CustodyIndex, SignedBeaconBlock, SignedBeaconBlockHeader, deneb, fulu } from "@lodestar/types";
4
+ import { DataColumnsCacheMap } from "../chain/blocks/types.js";
5
+ import { ChainEventEmitter } from "../chain/emitter.js";
6
+ import { BlockInputCacheType } from "../chain/seenCache/seenGossipBlockInput.js";
7
+ import { IExecutionEngine } from "../execution/engine/interface.js";
8
+ import { Metrics } from "../metrics/metrics.js";
9
+ import { NodeId } from "../network/subnets/index.js";
10
+ import { IClock } from "./clock.js";
11
+ export declare enum RecoverResult {
12
+ NotAttemptedLessThanHalf = "not_attempted_less_than_half",
13
+ NotAttemptedFull = "not_attempted_full",
14
+ SuccessResolved = "success_resolved",
15
+ SuccessLate = "success_late",
16
+ Failed = "failed"
17
+ }
18
+ export type CustodyConfigOpts = {
19
+ nodeId: NodeId;
20
+ config: ChainForkConfig;
21
+ initialCustodyGroupCount?: number;
22
+ };
23
+ export declare class CustodyConfig {
24
+ /**
25
+ * The number of custody groups the node should subscribe to
26
+ */
27
+ targetCustodyGroupCount: number;
28
+ /**
29
+ * The custody columns the node should subscribe to
30
+ */
31
+ custodyColumns: ColumnIndex[];
32
+ /**
33
+ * Custody columns map which column maps to which index in the array of columns custodied
34
+ * with zero representing it is not custodied
35
+ */
36
+ custodyColumnsIndex: Uint8Array;
37
+ /**
38
+ * The number of custody groups the node will sample
39
+ */
40
+ sampledGroupCount: number;
41
+ /**
42
+ * Custody groups sampled by the node as part of custody sampling
43
+ */
44
+ sampleGroups: CustodyIndex[];
45
+ /**
46
+ * Data columns sampled by the node as part of custody sampling
47
+ * https://github.com/ethereum/consensus-specs/blob/v1.6.0-alpha.4/specs/fulu/das-core.md#custody-sampling
48
+ *
49
+ * TODO: Consider race conditions if this updates during sync/backfill
50
+ */
51
+ sampledColumns: ColumnIndex[];
52
+ /**
53
+ * Subnets sampled by the node as part of custody sampling
54
+ */
55
+ sampledSubnets: number[];
56
+ private config;
57
+ private nodeId;
58
+ constructor(opts: CustodyConfigOpts);
59
+ updateTargetCustodyGroupCount(targetCustodyGroupCount: number): void;
60
+ private getCustodyColumnsIndex;
61
+ }
62
+ /**
63
+ * Calculate the number of custody groups the node should subscribe to based on the node's effective balance
64
+ *
65
+ * SPEC FUNCTION
66
+ * https://github.com/ethereum/consensus-specs/blob/v1.6.0-alpha.3/specs/fulu/validator.md#validator-custody
67
+ */
68
+ export declare function getValidatorsCustodyRequirement(config: ChainForkConfig, effectiveBalances: number[]): number;
69
+ /**
70
+ * Converts a custody group to an array of column indices. Should be 1-1 as long there are 128
71
+ * columns and 128 custody groups.
72
+ *
73
+ * SPEC FUNCTION
74
+ * https://github.com/ethereum/consensus-specs/blob/v1.6.0-alpha.4/specs/fulu/das-core.md#compute_columns_for_custody_group
75
+ */
76
+ export declare function computeColumnsForCustodyGroup(config: ChainForkConfig, custodyIndex: CustodyIndex): ColumnIndex[];
77
+ /**
78
+ * Converts nodeId and a the number of custody groups to an array of custody indices. Indexes must be
79
+ * further converted to column indices
80
+ *
81
+ * SPEC FUNCTION
82
+ * https://github.com/ethereum/consensus-specs/blob/v1.6.0-alpha.4/specs/fulu/das-core.md#get_custody_groups
83
+ */
84
+ export declare function getCustodyGroups(config: ChainForkConfig, nodeId: NodeId, custodyGroupCount: number): CustodyIndex[];
85
+ export declare function computeKzgCommitmentsInclusionProof(fork: ForkName, body: BeaconBlockBody): fulu.KzgCommitmentsInclusionProof;
86
+ export declare function getDataColumns(config: ChainForkConfig, nodeId: NodeId, custodyGroupCount: number): ColumnIndex[];
87
+ /**
88
+ * Computes the cells for each blob and combines them with cell proofs.
89
+ * Similar to the computeMatrix function described below.
90
+ *
91
+ * SPEC FUNCTION (note: spec currently computes proofs, but we already have them)
92
+ * https://github.com/ethereum/consensus-specs/blob/v1.6.0-alpha.4/specs/fulu/das-core.md#compute_matrix
93
+ */
94
+ export declare function getCellsAndProofs(blobBundles: fulu.BlobAndProofV2[]): {
95
+ cells: Uint8Array[];
96
+ proofs: Uint8Array[];
97
+ }[];
98
+ /**
99
+ * Given a signed block header and the commitments, inclusion proof, cells/proofs associated with
100
+ * each blob in the block, assemble the sidecars which can be distributed to peers.
101
+ *
102
+ * SPEC FUNCTION
103
+ * https://github.com/ethereum/consensus-specs/blob/v1.6.0-alpha.4/specs/fulu/validator.md#get_data_column_sidecars
104
+ */
105
+ export declare function getDataColumnSidecars(signedBlockHeader: SignedBeaconBlockHeader, kzgCommitments: deneb.KZGCommitment[], kzgCommitmentsInclusionProof: fulu.KzgCommitmentsInclusionProof, cellsAndKzgProofs: {
106
+ cells: Uint8Array[];
107
+ proofs: Uint8Array[];
108
+ }[]): fulu.DataColumnSidecars;
109
+ /**
110
+ * Given a signed block and the cells/proofs associated with each blob in the
111
+ * block, assemble the sidecars which can be distributed to peers.
112
+ *
113
+ * SPEC FUNCTION
114
+ * https://github.com/ethereum/consensus-specs/blob/v1.6.0-alpha.4/specs/fulu/validator.md#get_data_column_sidecars_from_block
115
+ */
116
+ export declare function getDataColumnSidecarsFromBlock(config: ChainForkConfig, signedBlock: SignedBeaconBlock<ForkPostFulu>, cellsAndKzgProofs: {
117
+ cells: Uint8Array[];
118
+ proofs: Uint8Array[];
119
+ }[]): fulu.DataColumnSidecars;
120
+ /**
121
+ * Given a DataColumnSidecar and the cells/proofs associated with each blob corresponding
122
+ * to the commitments it contains, assemble all sidecars for distribution to peers.
123
+ *
124
+ * SPEC FUNCTION
125
+ * https://github.com/ethereum/consensus-specs/blob/v1.6.0-alpha.4/specs/fulu/validator.md#get_data_column_sidecars_from_column_sidecar
126
+ */
127
+ export declare function getDataColumnSidecarsFromColumnSidecar(sidecar: fulu.DataColumnSidecar, cellsAndKzgProofs: {
128
+ cells: Uint8Array[];
129
+ proofs: Uint8Array[];
130
+ }[]): fulu.DataColumnSidecars;
131
+ /**
132
+ * If we receive more than half of NUMBER_OF_COLUMNS (64) we should recover all remaining columns
133
+ */
134
+ export declare function recoverDataColumnSidecars(dataColumnCache: DataColumnsCacheMap, clock: IClock, metrics: Metrics | null): Promise<RecoverResult>;
135
+ export declare function hasSampledDataColumns(custodyConfig: CustodyConfig, dataColumnCache: DataColumnsCacheMap): boolean;
136
+ export declare function getDataColumnsFromExecution(config: ChainForkConfig, custodyConfig: CustodyConfig, executionEngine: IExecutionEngine, emitter: ChainEventEmitter, blockCache: BlockInputCacheType, metrics: Metrics | null): Promise<boolean>;
137
+ //# sourceMappingURL=dataColumns.d.ts.map