@lodestar/beacon-node 1.31.0-peerDAS.d70dab2e57 → 1.31.0-rc.1

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 (204) hide show
  1. package/lib/api/impl/beacon/blocks/index.js +14 -40
  2. package/lib/api/impl/beacon/blocks/index.js.map +1 -1
  3. package/lib/chain/archiveStore/archiveStore.d.ts +1 -1
  4. package/lib/chain/archiveStore/archiveStore.js +2 -2
  5. package/lib/chain/archiveStore/interface.d.ts +1 -1
  6. package/lib/chain/archiveStore/utils/archiveBlocks.d.ts +1 -1
  7. package/lib/chain/archiveStore/utils/archiveBlocks.js +23 -88
  8. package/lib/chain/archiveStore/utils/archiveBlocks.js.map +1 -1
  9. package/lib/chain/beaconProposerCache.d.ts +0 -1
  10. package/lib/chain/beaconProposerCache.js +0 -3
  11. package/lib/chain/beaconProposerCache.js.map +1 -1
  12. package/lib/chain/blocks/importBlock.js +15 -56
  13. package/lib/chain/blocks/importBlock.js.map +1 -1
  14. package/lib/chain/blocks/types.d.ts +24 -65
  15. package/lib/chain/blocks/types.js +6 -39
  16. package/lib/chain/blocks/types.js.map +1 -1
  17. package/lib/chain/blocks/verifyBlocksDataAvailability.js +10 -21
  18. package/lib/chain/blocks/verifyBlocksDataAvailability.js.map +1 -1
  19. package/lib/chain/blocks/writeBlockInputToDb.js +15 -89
  20. package/lib/chain/blocks/writeBlockInputToDb.js.map +1 -1
  21. package/lib/chain/chain.d.ts +4 -12
  22. package/lib/chain/chain.js +2 -20
  23. package/lib/chain/chain.js.map +1 -1
  24. package/lib/chain/emitter.d.ts +2 -18
  25. package/lib/chain/emitter.js +0 -13
  26. package/lib/chain/emitter.js.map +1 -1
  27. package/lib/chain/errors/index.d.ts +0 -1
  28. package/lib/chain/errors/index.js +0 -1
  29. package/lib/chain/errors/index.js.map +1 -1
  30. package/lib/chain/interface.d.ts +3 -9
  31. package/lib/chain/interface.js.map +1 -1
  32. package/lib/chain/options.d.ts +1 -4
  33. package/lib/chain/options.js +0 -4
  34. package/lib/chain/options.js.map +1 -1
  35. package/lib/chain/produceBlock/produceBlockBody.d.ts +2 -4
  36. package/lib/chain/produceBlock/produceBlockBody.js +2 -11
  37. package/lib/chain/produceBlock/produceBlockBody.js.map +1 -1
  38. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.d.ts +2 -3
  39. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.js +2 -31
  40. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.js.map +1 -1
  41. package/lib/chain/seenCache/seenGossipBlockInput.d.ts +18 -61
  42. package/lib/chain/seenCache/seenGossipBlockInput.js +53 -254
  43. package/lib/chain/seenCache/seenGossipBlockInput.js.map +1 -1
  44. package/lib/db/beacon.d.ts +1 -3
  45. package/lib/db/beacon.js +1 -3
  46. package/lib/db/beacon.js.map +1 -1
  47. package/lib/db/buckets.d.ts +1 -3
  48. package/lib/db/buckets.js +0 -2
  49. package/lib/db/buckets.js.map +1 -1
  50. package/lib/db/interface.d.ts +1 -3
  51. package/lib/db/repositories/index.d.ts +0 -2
  52. package/lib/db/repositories/index.js +0 -2
  53. package/lib/db/repositories/index.js.map +1 -1
  54. package/lib/execution/engine/http.d.ts +3 -5
  55. package/lib/execution/engine/http.js +31 -68
  56. package/lib/execution/engine/http.js.map +1 -1
  57. package/lib/execution/engine/interface.d.ts +2 -4
  58. package/lib/execution/engine/interface.js +1 -1
  59. package/lib/execution/engine/interface.js.map +1 -1
  60. package/lib/execution/engine/mock.d.ts +0 -1
  61. package/lib/execution/engine/mock.js +0 -5
  62. package/lib/execution/engine/mock.js.map +1 -1
  63. package/lib/execution/engine/types.d.ts +0 -10
  64. package/lib/execution/engine/types.js +0 -6
  65. package/lib/execution/engine/types.js.map +1 -1
  66. package/lib/metrics/metrics/beacon.d.ts +0 -8
  67. package/lib/metrics/metrics/beacon.js +0 -27
  68. package/lib/metrics/metrics/beacon.js.map +1 -1
  69. package/lib/network/core/metrics.d.ts +3 -10
  70. package/lib/network/core/metrics.js +4 -22
  71. package/lib/network/core/metrics.js.map +1 -1
  72. package/lib/network/core/networkCore.d.ts +0 -6
  73. package/lib/network/core/networkCore.js +8 -20
  74. package/lib/network/core/networkCore.js.map +1 -1
  75. package/lib/network/core/networkCoreWorker.js +0 -2
  76. package/lib/network/core/networkCoreWorker.js.map +1 -1
  77. package/lib/network/core/networkCoreWorkerHandler.d.ts +0 -2
  78. package/lib/network/core/networkCoreWorkerHandler.js +0 -7
  79. package/lib/network/core/networkCoreWorkerHandler.js.map +1 -1
  80. package/lib/network/core/types.d.ts +0 -4
  81. package/lib/network/events.d.ts +1 -3
  82. package/lib/network/events.js.map +1 -1
  83. package/lib/network/gossip/interface.d.ts +1 -8
  84. package/lib/network/gossip/interface.js +0 -1
  85. package/lib/network/gossip/interface.js.map +1 -1
  86. package/lib/network/gossip/topic.d.ts +1497 -1513
  87. package/lib/network/gossip/topic.js +1 -20
  88. package/lib/network/gossip/topic.js.map +1 -1
  89. package/lib/network/interface.d.ts +1 -13
  90. package/lib/network/metadata.d.ts +6 -10
  91. package/lib/network/metadata.js +4 -23
  92. package/lib/network/metadata.js.map +1 -1
  93. package/lib/network/network.d.ts +1 -12
  94. package/lib/network/network.js +4 -57
  95. package/lib/network/network.js.map +1 -1
  96. package/lib/network/options.js +0 -2
  97. package/lib/network/options.js.map +1 -1
  98. package/lib/network/peers/discover.d.ts +3 -16
  99. package/lib/network/peers/discover.js +13 -139
  100. package/lib/network/peers/discover.js.map +1 -1
  101. package/lib/network/peers/peerManager.d.ts +2 -10
  102. package/lib/network/peers/peerManager.js +10 -96
  103. package/lib/network/peers/peerManager.js.map +1 -1
  104. package/lib/network/peers/peersData.d.ts +2 -8
  105. package/lib/network/peers/peersData.js.map +1 -1
  106. package/lib/network/peers/score/interface.d.ts +1 -1
  107. package/lib/network/peers/score/score.d.ts +2 -2
  108. package/lib/network/peers/score/score.js +1 -4
  109. package/lib/network/peers/score/score.js.map +1 -1
  110. package/lib/network/peers/score/store.d.ts +1 -3
  111. package/lib/network/peers/score/store.js +2 -6
  112. package/lib/network/peers/score/store.js.map +1 -1
  113. package/lib/network/peers/utils/prioritizePeers.d.ts +4 -15
  114. package/lib/network/peers/utils/prioritizePeers.js +5 -30
  115. package/lib/network/peers/utils/prioritizePeers.js.map +1 -1
  116. package/lib/network/processor/extractSlotRootFns.js +1 -8
  117. package/lib/network/processor/extractSlotRootFns.js.map +1 -1
  118. package/lib/network/processor/gossipHandlers.js +8 -154
  119. package/lib/network/processor/gossipHandlers.js.map +1 -1
  120. package/lib/network/processor/gossipQueues/index.js +0 -5
  121. package/lib/network/processor/gossipQueues/index.js.map +1 -1
  122. package/lib/network/processor/index.js +0 -1
  123. package/lib/network/processor/index.js.map +1 -1
  124. package/lib/network/reqresp/ReqRespBeaconNode.js +3 -21
  125. package/lib/network/reqresp/ReqRespBeaconNode.js.map +1 -1
  126. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.d.ts +5 -14
  127. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.js +14 -199
  128. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.js.map +1 -1
  129. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.d.ts +5 -32
  130. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.js +26 -280
  131. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.js.map +1 -1
  132. package/lib/network/reqresp/handlers/beaconBlocksByRange.d.ts +1 -1
  133. package/lib/network/reqresp/handlers/beaconBlocksByRange.js.map +1 -1
  134. package/lib/network/reqresp/handlers/index.js +0 -10
  135. package/lib/network/reqresp/handlers/index.js.map +1 -1
  136. package/lib/network/reqresp/protocols.d.ts +0 -3
  137. package/lib/network/reqresp/protocols.js +0 -15
  138. package/lib/network/reqresp/protocols.js.map +1 -1
  139. package/lib/network/reqresp/rateLimit.js +1 -11
  140. package/lib/network/reqresp/rateLimit.js.map +1 -1
  141. package/lib/network/reqresp/types.d.ts +6 -13
  142. package/lib/network/reqresp/types.js +2 -9
  143. package/lib/network/reqresp/types.js.map +1 -1
  144. package/lib/network/subnets/interface.d.ts +0 -3
  145. package/lib/network/subnets/interface.js +1 -14
  146. package/lib/network/subnets/interface.js.map +1 -1
  147. package/lib/network/subnets/syncnetsService.js +5 -4
  148. package/lib/network/subnets/syncnetsService.js.map +1 -1
  149. package/lib/node/nodejs.js +2 -3
  150. package/lib/node/nodejs.js.map +1 -1
  151. package/lib/sync/interface.d.ts +2 -2
  152. package/lib/sync/interface.js +1 -1
  153. package/lib/sync/interface.js.map +1 -1
  154. package/lib/sync/range/batch.d.ts +2 -8
  155. package/lib/sync/range/batch.js +7 -19
  156. package/lib/sync/range/batch.js.map +1 -1
  157. package/lib/sync/range/chain.d.ts +2 -7
  158. package/lib/sync/range/chain.js +21 -45
  159. package/lib/sync/range/chain.js.map +1 -1
  160. package/lib/sync/range/range.js +3 -3
  161. package/lib/sync/range/range.js.map +1 -1
  162. package/lib/sync/range/utils/peerBalancer.d.ts +1 -4
  163. package/lib/sync/range/utils/peerBalancer.js +2 -20
  164. package/lib/sync/range/utils/peerBalancer.js.map +1 -1
  165. package/lib/sync/unknownBlock.d.ts +1 -8
  166. package/lib/sync/unknownBlock.js +62 -222
  167. package/lib/sync/unknownBlock.js.map +1 -1
  168. package/lib/util/blobs.d.ts +1 -13
  169. package/lib/util/blobs.js +1 -44
  170. package/lib/util/blobs.js.map +1 -1
  171. package/lib/util/kzg.d.ts +21 -9
  172. package/lib/util/kzg.js +88 -12
  173. package/lib/util/kzg.js.map +1 -1
  174. package/lib/util/metadata.d.ts +0 -4
  175. package/lib/util/metadata.js +0 -7
  176. package/lib/util/metadata.js.map +1 -1
  177. package/lib/util/sszBytes.d.ts +0 -1
  178. package/lib/util/sszBytes.js +0 -17
  179. package/lib/util/sszBytes.js.map +1 -1
  180. package/package.json +15 -15
  181. package/lib/chain/errors/dataColumnSidecarError.d.ts +0 -69
  182. package/lib/chain/errors/dataColumnSidecarError.js +0 -21
  183. package/lib/chain/errors/dataColumnSidecarError.js.map +0 -1
  184. package/lib/chain/validation/dataColumnSidecar.d.ts +0 -28
  185. package/lib/chain/validation/dataColumnSidecar.js +0 -245
  186. package/lib/chain/validation/dataColumnSidecar.js.map +0 -1
  187. package/lib/db/repositories/dataColumnSidecars.d.ts +0 -47
  188. package/lib/db/repositories/dataColumnSidecars.js +0 -40
  189. package/lib/db/repositories/dataColumnSidecars.js.map +0 -1
  190. package/lib/db/repositories/dataColumnSidecarsArchive.d.ts +0 -15
  191. package/lib/db/repositories/dataColumnSidecarsArchive.js +0 -23
  192. package/lib/db/repositories/dataColumnSidecarsArchive.js.map +0 -1
  193. package/lib/network/networkConfig.d.ts +0 -23
  194. package/lib/network/networkConfig.js +0 -32
  195. package/lib/network/networkConfig.js.map +0 -1
  196. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts +0 -8
  197. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js +0 -106
  198. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js.map +0 -1
  199. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.d.ts +0 -6
  200. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js +0 -57
  201. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js.map +0 -1
  202. package/lib/util/dataColumns.d.ts +0 -111
  203. package/lib/util/dataColumns.js +0 -277
  204. package/lib/util/dataColumns.js.map +0 -1
@@ -1,21 +0,0 @@
1
- import { GossipActionError } from "./gossipValidation.js";
2
- export var DataColumnSidecarErrorCode;
3
- (function (DataColumnSidecarErrorCode) {
4
- DataColumnSidecarErrorCode["INVALID_INDEX"] = "DATA_COLUMN_SIDECAR_ERROR_INVALID_INDEX";
5
- DataColumnSidecarErrorCode["NO_COMMITMENTS"] = "DATA_COLUMN_SIDECAR_ERROR_NO_COMMITMENTS";
6
- DataColumnSidecarErrorCode["MISMATCHED_LENGTHS"] = "DATA_COLUMN_SIDECAR_ERROR_MISMATCHED_LENGTHS";
7
- DataColumnSidecarErrorCode["INVALID_SUBNET"] = "DATA_COLUMN_SIDECAR_ERROR_INVALID_SUBNET";
8
- DataColumnSidecarErrorCode["INVALID_KZG_PROOF"] = "DATA_COLUMN_SIDECAR_ERROR_INVALID_KZG_PROOF";
9
- // following errors are adapted from the block errors
10
- DataColumnSidecarErrorCode["ALREADY_KNOWN"] = "DATA_COLUMN_SIDECAR_ERROR_ALREADY_KNOWN";
11
- DataColumnSidecarErrorCode["FUTURE_SLOT"] = "DATA_COLUMN_SIDECAR_ERROR_FUTURE_SLOT";
12
- DataColumnSidecarErrorCode["WOULD_REVERT_FINALIZED_SLOT"] = "DATA_COLUMN_SIDECAR_ERROR_WOULD_REVERT_FINALIZED_SLOT";
13
- DataColumnSidecarErrorCode["PARENT_UNKNOWN"] = "DATA_COLUMN_SIDECAR_ERROR_PARENT_UNKNOWN";
14
- DataColumnSidecarErrorCode["NOT_LATER_THAN_PARENT"] = "DATA_COLUMN_SIDECAR_ERROR_NOT_LATER_THAN_PARENT";
15
- DataColumnSidecarErrorCode["PROPOSAL_SIGNATURE_INVALID"] = "DATA_COLUMN_SIDECAR_ERROR_PROPOSAL_SIGNATURE_INVALID";
16
- DataColumnSidecarErrorCode["INCLUSION_PROOF_INVALID"] = "DATA_COLUMN_SIDECAR_ERROR_INCLUSION_PROOF_INVALID";
17
- DataColumnSidecarErrorCode["INCORRECT_PROPOSER"] = "DATA_COLUMN_SIDECAR_ERROR_INCORRECT_PROPOSER";
18
- })(DataColumnSidecarErrorCode || (DataColumnSidecarErrorCode = {}));
19
- export class DataColumnSidecarGossipError extends GossipActionError {
20
- }
21
- //# sourceMappingURL=dataColumnSidecarError.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"dataColumnSidecarError.js","sourceRoot":"","sources":["../../../src/chain/errors/dataColumnSidecarError.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,iBAAiB,EAAC,MAAM,uBAAuB,CAAC;AAExD,MAAM,CAAN,IAAY,0BAgBX;AAhBD,WAAY,0BAA0B;IACpC,uFAAyD,CAAA;IACzD,yFAA2D,CAAA;IAC3D,iGAAmE,CAAA;IACnE,yFAA2D,CAAA;IAC3D,+FAAiE,CAAA;IAEjE,qDAAqD;IACrD,uFAAyD,CAAA;IACzD,mFAAqD,CAAA;IACrD,mHAAqF,CAAA;IACrF,yFAA2D,CAAA;IAC3D,uGAAyE,CAAA;IACzE,iHAAmF,CAAA;IACnF,2GAA6E,CAAA;IAC7E,iGAAmE,CAAA;AACrE,CAAC,EAhBW,0BAA0B,KAA1B,0BAA0B,QAgBrC;AAsBD,MAAM,OAAO,4BAA6B,SAAQ,iBAA6C;CAAG"}
@@ -1,28 +0,0 @@
1
- import { Root, Slot, SubnetID, 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, gossipSubnet: SubnetID): 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
- /**
9
- * SPEC FUNCTION
10
- * https://github.com/ethereum/consensus-specs/blob/dev/specs/fulu/p2p-interface.md#verify_data_column_sidecar
11
- */
12
- export declare function verifyDataColumnSidecar(dataColumnSidecar: fulu.DataColumnSidecar): void;
13
- /**
14
- * SPEC FUNCTION
15
- * https://github.com/ethereum/consensus-specs/blob/dev/specs/fulu/p2p-interface.md#verify_data_column_sidecar_kzg_proofs
16
- */
17
- export declare function verifyDataColumnSidecarKzgProofs(commitments: Uint8Array[], cellIndices: number[], cells: Uint8Array[], proofs: Uint8Array[]): void;
18
- /**
19
- * SPEC FUNCTION
20
- * https://github.com/ethereum/consensus-specs/blob/dev/specs/fulu/p2p-interface.md#verify_data_column_sidecar_inclusion_proof
21
- */
22
- export declare function verifyDataColumnSidecarInclusionProof(dataColumnSidecar: fulu.DataColumnSidecar): boolean;
23
- /**
24
- * SPEC FUNCTION
25
- * https://github.com/ethereum/consensus-specs/blob/dev/specs/fulu/p2p-interface.md#compute_subnet_for_data_column_sidecar
26
- */
27
- export declare function computeSubnetForDataColumnSidecar(columnSidecar: fulu.DataColumnSidecar): SubnetID;
28
- //# sourceMappingURL=dataColumnSidecar.d.ts.map
@@ -1,245 +0,0 @@
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, toRootHex, verifyMerkleBranch } from "@lodestar/utils";
4
- import { computeStartSlotAtEpoch, getBlockHeaderProposerSignatureSet } from "@lodestar/state-transition";
5
- import { byteArrayEquals } from "../../util/bytes.js";
6
- import { ckzg } from "../../util/kzg.js";
7
- import { DataColumnSidecarErrorCode, DataColumnSidecarGossipError } from "../errors/dataColumnSidecarError.js";
8
- import { GossipAction } from "../errors/gossipValidation.js";
9
- import { RegenCaller } from "../regen/interface.js";
10
- // SPEC FUNCTION
11
- // https://github.com/ethereum/consensus-specs/blob/dev/specs/fulu/p2p-interface.md#data_column_sidecar_subnet_id
12
- export async function validateGossipDataColumnSidecar(chain, dataColumnSidecar, gossipSubnet) {
13
- const blockHeader = dataColumnSidecar.signedBlockHeader.message;
14
- // 1) [REJECT] The sidecar is valid as verified by verify_data_column_sidecar
15
- verifyDataColumnSidecar(dataColumnSidecar);
16
- // 2) [REJECT] The sidecar is for the correct subnet -- i.e. compute_subnet_for_data_column_sidecar(sidecar.index) == subnet_id
17
- if (computeSubnetForDataColumnSidecar(dataColumnSidecar) !== gossipSubnet) {
18
- throw new DataColumnSidecarGossipError(GossipAction.REJECT, {
19
- code: DataColumnSidecarErrorCode.INVALID_SUBNET,
20
- columnIdx: dataColumnSidecar.index,
21
- gossipSubnet: gossipSubnet,
22
- });
23
- }
24
- // 3) [IGNORE] The sidecar is not from a future slot (with a MAXIMUM_GOSSIP_CLOCK_DISPARITY allowance)
25
- // -- i.e. validate that sidecar.slot <= current_slot (a client MAY queue future blocks
26
- // for processing at the appropriate slot).
27
- const currentSlotWithGossipDisparity = chain.clock.currentSlotWithGossipDisparity;
28
- if (currentSlotWithGossipDisparity < blockHeader.slot) {
29
- throw new DataColumnSidecarGossipError(GossipAction.IGNORE, {
30
- code: DataColumnSidecarErrorCode.FUTURE_SLOT,
31
- currentSlot: currentSlotWithGossipDisparity,
32
- blockSlot: blockHeader.slot,
33
- });
34
- }
35
- // 4) [IGNORE] The sidecar is from a slot greater than the latest finalized slot -- i.e. validate that
36
- // sidecar.slot > compute_start_slot_at_epoch(state.finalized_checkpoint.epoch)
37
- const finalizedCheckpoint = chain.forkChoice.getFinalizedCheckpoint();
38
- const finalizedSlot = computeStartSlotAtEpoch(finalizedCheckpoint.epoch);
39
- if (blockHeader.slot <= finalizedSlot) {
40
- throw new DataColumnSidecarGossipError(GossipAction.IGNORE, {
41
- code: DataColumnSidecarErrorCode.WOULD_REVERT_FINALIZED_SLOT,
42
- blockSlot: blockHeader.slot,
43
- finalizedSlot,
44
- });
45
- }
46
- // 6) [IGNORE] The sidecar's block's parent (defined by block_header.parent_root) has been seen (via gossip
47
- // or non-gossip sources)
48
- const parentRoot = toRootHex(blockHeader.parentRoot);
49
- const parentBlock = chain.forkChoice.getBlockHex(parentRoot);
50
- if (parentBlock === null) {
51
- // If fork choice does *not* consider the parent to be a descendant of the finalized block,
52
- // then there are two more cases:
53
- //
54
- // 1. We have the parent stored in our database. Because fork-choice has confirmed the
55
- // parent is *not* in our post-finalization DAG, all other blocks must be either
56
- // pre-finalization or conflicting with finalization.
57
- // 2. The parent is unknown to us, we probably want to download it since it might actually
58
- // descend from the finalized root.
59
- // (Non-Lighthouse): Since we prune all blocks non-descendant from finalized checking the `db.block` database won't be useful to guard
60
- // against known bad fork blocks, so we throw PARENT_UNKNOWN for cases (1) and (2)
61
- throw new DataColumnSidecarGossipError(GossipAction.IGNORE, {
62
- code: DataColumnSidecarErrorCode.PARENT_UNKNOWN,
63
- parentRoot,
64
- });
65
- }
66
- // 8) [REJECT] The sidecar is from a higher slot than the sidecar's block's parent
67
- if (parentBlock.slot >= blockHeader.slot) {
68
- throw new DataColumnSidecarGossipError(GossipAction.REJECT, {
69
- code: DataColumnSidecarErrorCode.NOT_LATER_THAN_PARENT,
70
- parentSlot: parentBlock.slot,
71
- slot: blockHeader.slot,
72
- });
73
- }
74
- // getBlockSlotState also checks for whether the current finalized checkpoint is an ancestor of the block.
75
- // As a result, we throw an IGNORE (whereas the spec says we should REJECT for this scenario).
76
- // this is something we should change this in the future to make the code airtight to the spec.
77
- // 7) [REJECT] The sidecar's block's parent passes validation.
78
- const blockState = await chain.regen
79
- .getBlockSlotState(parentRoot, blockHeader.slot, { dontTransferCache: true }, RegenCaller.validateGossipBlock)
80
- .catch(() => {
81
- throw new DataColumnSidecarGossipError(GossipAction.IGNORE, {
82
- code: DataColumnSidecarErrorCode.PARENT_UNKNOWN,
83
- parentRoot,
84
- });
85
- });
86
- // 5) [REJECT] The proposer signature of sidecar.signed_block_header, is valid with respect to the block_header.proposer_index pubkey.
87
- const signatureSet = getBlockHeaderProposerSignatureSet(blockState, dataColumnSidecar.signedBlockHeader);
88
- // Don't batch so verification is not delayed
89
- if (!(await chain.bls.verifySignatureSets([signatureSet], {
90
- verifyOnMainThread: blockHeader.slot > chain.forkChoice.getHead().slot,
91
- }))) {
92
- throw new DataColumnSidecarGossipError(GossipAction.REJECT, {
93
- code: DataColumnSidecarErrorCode.PROPOSAL_SIGNATURE_INVALID,
94
- });
95
- }
96
- // 9) [REJECT] The current finalized_checkpoint is an ancestor of the sidecar's block
97
- // -- i.e. get_checkpoint_block(store, block_header.parent_root, store.finalized_checkpoint.epoch)
98
- // == store.finalized_checkpoint.root
99
- // Handled by 7)
100
- // 10) [REJECT] The sidecar's kzg_commitments field inclusion proof is valid as verified by
101
- // verify_data_column_sidecar_inclusion_proof
102
- // TODO: Can cache result on (commitments, proof, header) in the future
103
- if (!verifyDataColumnSidecarInclusionProof(dataColumnSidecar)) {
104
- throw new DataColumnSidecarGossipError(GossipAction.REJECT, {
105
- code: DataColumnSidecarErrorCode.INCLUSION_PROOF_INVALID,
106
- slot: dataColumnSidecar.signedBlockHeader.message.slot,
107
- columnIdx: dataColumnSidecar.index,
108
- });
109
- }
110
- // 11) [REJECT] The sidecar's column data is valid as verified by verify_data_column_sidecar_kzg_proofs
111
- try {
112
- verifyDataColumnSidecarKzgProofs(dataColumnSidecar.kzgCommitments, Array.from({ length: dataColumnSidecar.column.length }, () => dataColumnSidecar.index), dataColumnSidecar.column, dataColumnSidecar.kzgProofs);
113
- }
114
- catch {
115
- throw new DataColumnSidecarGossipError(GossipAction.REJECT, {
116
- code: DataColumnSidecarErrorCode.INVALID_KZG_PROOF,
117
- slot: blockHeader.slot,
118
- columnIdx: dataColumnSidecar.index,
119
- });
120
- }
121
- // 12) [IGNORE] The sidecar is the first sidecar for the tuple (block_header.slot, block_header.proposer_index,
122
- // sidecar.index) with valid header signature, sidecar inclusion proof, and kzg proof
123
- // -- Handled in seenGossipBlockInput
124
- // 13) [REJECT] The sidecar is proposed by the expected proposer_index for the block's slot in the context of the current
125
- // shuffling (defined by block_header.parent_root/block_header.slot). If the proposer_index cannot
126
- // immediately be verified against the expected shuffling, the sidecar MAY be queued for later processing
127
- // while proposers for the block's branch are calculated -- in such a case do not REJECT, instead IGNORE
128
- // this message.
129
- const proposerIndex = blockHeader.proposerIndex;
130
- const expectedProposerIndex = blockState.epochCtx.getBeaconProposer(blockHeader.slot);
131
- if (proposerIndex !== expectedProposerIndex) {
132
- throw new DataColumnSidecarGossipError(GossipAction.REJECT, {
133
- code: DataColumnSidecarErrorCode.INCORRECT_PROPOSER,
134
- actualProposerIndex: proposerIndex,
135
- expectedProposerIndex,
136
- });
137
- }
138
- }
139
- export function validateDataColumnsSidecars(blockSlot, blockRoot, blockKzgCommitments, dataColumnSidecars, metrics, opts = { skipProofsCheck: false }) {
140
- const commitmentBytes = [];
141
- const cellIndices = [];
142
- const cells = [];
143
- const proofBytes = [];
144
- for (let sidecarsIndex = 0; sidecarsIndex < dataColumnSidecars.length; sidecarsIndex++) {
145
- const columnSidecar = dataColumnSidecars[sidecarsIndex];
146
- const { index: columnIndex, column, kzgCommitments, kzgProofs } = columnSidecar;
147
- const columnBlockHeader = columnSidecar.signedBlockHeader.message;
148
- const columnBlockRoot = ssz.phase0.BeaconBlockHeader.hashTreeRoot(columnBlockHeader);
149
- if (columnBlockHeader.slot !== blockSlot ||
150
- !byteArrayEquals(columnBlockRoot, blockRoot) ||
151
- kzgCommitments.length === 0 ||
152
- blockKzgCommitments.length === 0 ||
153
- blockKzgCommitments.length !== kzgCommitments.length ||
154
- blockKzgCommitments
155
- .map((commitment, i) => byteArrayEquals(commitment, kzgCommitments[i]))
156
- .filter((result) => result === false).length) {
157
- 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}`);
158
- }
159
- if (columnIndex >= NUMBER_OF_COLUMNS) {
160
- throw new Error(`Invalid data sidecar columnIndex=${columnIndex} in slot=${blockSlot} blockRoot=${toHex(blockRoot)} sidecarsIndex=${sidecarsIndex}`);
161
- }
162
- if (column.length !== kzgCommitments.length || column.length !== kzgProofs.length) {
163
- throw new Error(`Invalid data sidecar array lengths for columnIndex=${columnIndex} in slot=${blockSlot} blockRoot=${toHex(blockRoot)}`);
164
- }
165
- commitmentBytes.push(...kzgCommitments);
166
- cellIndices.push(...Array.from({ length: column.length }, () => columnIndex));
167
- cells.push(...column);
168
- proofBytes.push(...kzgProofs);
169
- }
170
- if (opts.skipProofsCheck) {
171
- return;
172
- }
173
- let valid;
174
- try {
175
- const timer = metrics?.peerDas.kzgVerificationDataColumnBatchTime.startTimer();
176
- valid = ckzg.verifyCellKzgProofBatch(commitmentBytes, cellIndices, cells, proofBytes);
177
- timer?.();
178
- }
179
- catch (err) {
180
- err.message = `Error in verifyCellKzgProofBatch for slot=${blockSlot} blockRoot=${toHex(blockRoot)}`;
181
- throw err;
182
- }
183
- if (!valid) {
184
- throw new Error(`Invalid data column sidecars in slot=${blockSlot} blockRoot=${toHex(blockRoot)}`);
185
- }
186
- }
187
- /**
188
- * SPEC FUNCTION
189
- * https://github.com/ethereum/consensus-specs/blob/dev/specs/fulu/p2p-interface.md#verify_data_column_sidecar
190
- */
191
- export function verifyDataColumnSidecar(dataColumnSidecar) {
192
- if (dataColumnSidecar.index >= NUMBER_OF_COLUMNS) {
193
- throw new DataColumnSidecarGossipError(GossipAction.REJECT, {
194
- code: DataColumnSidecarErrorCode.INVALID_INDEX,
195
- columnIdx: dataColumnSidecar.index,
196
- });
197
- }
198
- if (dataColumnSidecar.kzgCommitments.length === 0) {
199
- throw new DataColumnSidecarGossipError(GossipAction.REJECT, {
200
- code: DataColumnSidecarErrorCode.NO_COMMITMENTS,
201
- columnIdx: dataColumnSidecar.index,
202
- });
203
- }
204
- if (dataColumnSidecar.column.length !== dataColumnSidecar.kzgCommitments.length ||
205
- dataColumnSidecar.column.length !== dataColumnSidecar.kzgProofs.length) {
206
- throw new DataColumnSidecarGossipError(GossipAction.REJECT, {
207
- code: DataColumnSidecarErrorCode.MISMATCHED_LENGTHS,
208
- columnLength: dataColumnSidecar.column.length,
209
- commitmentsLength: dataColumnSidecar.kzgCommitments.length,
210
- proofsLength: dataColumnSidecar.kzgProofs.length,
211
- });
212
- }
213
- }
214
- /**
215
- * SPEC FUNCTION
216
- * https://github.com/ethereum/consensus-specs/blob/dev/specs/fulu/p2p-interface.md#verify_data_column_sidecar_kzg_proofs
217
- */
218
- export function verifyDataColumnSidecarKzgProofs(commitments, cellIndices, cells, proofs) {
219
- let valid;
220
- try {
221
- valid = ckzg.verifyCellKzgProofBatch(commitments, cellIndices, cells, proofs);
222
- }
223
- catch (e) {
224
- e.message = `Error on verifyCellKzgProofBatch: ${e.message}`;
225
- throw e;
226
- }
227
- if (!valid) {
228
- throw Error("Invalid verifyCellKzgProofBatch");
229
- }
230
- }
231
- /**
232
- * SPEC FUNCTION
233
- * https://github.com/ethereum/consensus-specs/blob/dev/specs/fulu/p2p-interface.md#verify_data_column_sidecar_inclusion_proof
234
- */
235
- export function verifyDataColumnSidecarInclusionProof(dataColumnSidecar) {
236
- return verifyMerkleBranch(ssz.deneb.BlobKzgCommitments.hashTreeRoot(dataColumnSidecar.kzgCommitments), dataColumnSidecar.kzgCommitmentsInclusionProof, KZG_COMMITMENTS_INCLUSION_PROOF_DEPTH, KZG_COMMITMENTS_SUBTREE_INDEX, dataColumnSidecar.signedBlockHeader.message.bodyRoot);
237
- }
238
- /**
239
- * SPEC FUNCTION
240
- * https://github.com/ethereum/consensus-specs/blob/dev/specs/fulu/p2p-interface.md#compute_subnet_for_data_column_sidecar
241
- */
242
- export function computeSubnetForDataColumnSidecar(columnSidecar) {
243
- return columnSidecar.index % DATA_COLUMN_SIDECAR_SUBNET_COUNT;
244
- }
245
- //# sourceMappingURL=dataColumnSidecar.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"dataColumnSidecar.js","sourceRoot":"","sources":["../../../src/chain/validation/dataColumnSidecar.ts"],"names":[],"mappings":"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"}
@@ -1,47 +0,0 @@
1
- import { ByteVectorType, ContainerType, ValueOf } from "@chainsafe/ssz";
2
- import { ChainForkConfig } from "@lodestar/config";
3
- import { Db, Repository } from "@lodestar/db";
4
- export declare const dataColumnSidecarsWrapperSsz: ContainerType<{
5
- blockRoot: ByteVectorType;
6
- slot: import("@chainsafe/ssz").UintNumberType;
7
- dataColumnsLen: import("@chainsafe/ssz").UintNumberType;
8
- dataColumnsSize: import("@chainsafe/ssz").UintNumberType;
9
- dataColumnsIndex: ByteVectorType;
10
- dataColumnSidecars: import("@chainsafe/ssz").ListCompositeType<ContainerType<{
11
- index: import("@chainsafe/ssz").UintNumberType;
12
- column: import("@chainsafe/ssz").ListCompositeType<import("@chainsafe/ssz").ByteVectorType>;
13
- kzgCommitments: import("@chainsafe/ssz").ListCompositeType<import("@chainsafe/ssz").ByteVectorType>;
14
- kzgProofs: import("@chainsafe/ssz").ListCompositeType<import("@chainsafe/ssz").ByteVectorType>;
15
- signedBlockHeader: ContainerType<{
16
- message: ContainerType<{
17
- slot: import("@chainsafe/ssz").UintNumberType;
18
- proposerIndex: import("@chainsafe/ssz").UintNumberType;
19
- parentRoot: import("@chainsafe/ssz").ByteVectorType;
20
- stateRoot: import("@chainsafe/ssz").ByteVectorType;
21
- bodyRoot: import("@chainsafe/ssz").ByteVectorType;
22
- }>;
23
- signature: import("@chainsafe/ssz").ByteVectorType;
24
- }>;
25
- kzgCommitmentsInclusionProof: import("@chainsafe/ssz").VectorCompositeType<import("@chainsafe/ssz").ByteVectorType>;
26
- }>>;
27
- }>;
28
- export type DataColumnSidecarsWrapper = ValueOf<typeof dataColumnSidecarsWrapperSsz>;
29
- export declare const BLOCK_ROOT_IN_WRAPPER_INDEX = 0;
30
- export declare const BLOCK_SLOT_IN_WRAPPER_INDEX = 32;
31
- export declare const NUM_COLUMNS_IN_WRAPPER_INDEX = 40;
32
- export declare const COLUMN_SIZE_IN_WRAPPER_INDEX = 41;
33
- export declare const CUSTODY_COLUMNS_IN_IN_WRAPPER_INDEX = 49;
34
- export declare const DATA_COLUMN_SIDECARS_IN_WRAPPER_INDEX: number;
35
- /**
36
- * dataColumnSidecarsWrapper by block root (= hash_tree_root(SignedBeaconBlock.message))
37
- *
38
- * Used to store unfinalized DataColumnSidecars
39
- */
40
- export declare class DataColumnSidecarsRepository extends Repository<Uint8Array, DataColumnSidecarsWrapper> {
41
- constructor(config: ChainForkConfig, db: Db);
42
- /**
43
- * Id is hashTreeRoot of unsigned BeaconBlock
44
- */
45
- getId(value: DataColumnSidecarsWrapper): Uint8Array;
46
- }
47
- //# sourceMappingURL=dataColumnSidecars.d.ts.map
@@ -1,40 +0,0 @@
1
- import { ByteVectorType, ContainerType } from "@chainsafe/ssz";
2
- import { Repository } from "@lodestar/db";
3
- import { NUMBER_OF_COLUMNS } from "@lodestar/params";
4
- import { ssz } from "@lodestar/types";
5
- import { Bucket, getBucketNameByValue } from "../buckets.js";
6
- export const dataColumnSidecarsWrapperSsz = new ContainerType({
7
- blockRoot: ssz.Root,
8
- slot: ssz.Slot,
9
- dataColumnsLen: ssz.Uint8,
10
- dataColumnsSize: ssz.UintNum64,
11
- // // each byte[i] tells what index (1 based) the column i is stored, 0 means not custodied
12
- // max value to represent will be 128 which can be represented in a byte
13
- dataColumnsIndex: new ByteVectorType(NUMBER_OF_COLUMNS),
14
- dataColumnSidecars: ssz.fulu.DataColumnSidecars,
15
- }, { typeName: "DataColumnSidecarsWrapper", jsonCase: "eth2" });
16
- export const BLOCK_ROOT_IN_WRAPPER_INDEX = 0;
17
- export const BLOCK_SLOT_IN_WRAPPER_INDEX = 32;
18
- export const NUM_COLUMNS_IN_WRAPPER_INDEX = 40;
19
- export const COLUMN_SIZE_IN_WRAPPER_INDEX = 41;
20
- export const CUSTODY_COLUMNS_IN_IN_WRAPPER_INDEX = 49;
21
- export const DATA_COLUMN_SIDECARS_IN_WRAPPER_INDEX = CUSTODY_COLUMNS_IN_IN_WRAPPER_INDEX + NUMBER_OF_COLUMNS + 4;
22
- /**
23
- * dataColumnSidecarsWrapper by block root (= hash_tree_root(SignedBeaconBlock.message))
24
- *
25
- * Used to store unfinalized DataColumnSidecars
26
- */
27
- export class DataColumnSidecarsRepository extends Repository {
28
- constructor(config, db) {
29
- const bucket = Bucket.allForks_dataColumnSidecars;
30
- super(config, db, bucket, dataColumnSidecarsWrapperSsz, getBucketNameByValue(bucket));
31
- }
32
- /**
33
- * Id is hashTreeRoot of unsigned BeaconBlock
34
- */
35
- getId(value) {
36
- const { blockRoot } = value;
37
- return blockRoot;
38
- }
39
- }
40
- //# sourceMappingURL=dataColumnSidecars.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"dataColumnSidecars.js","sourceRoot":"","sources":["../../../src/db/repositories/dataColumnSidecars.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,cAAc,EAAE,aAAa,EAAU,MAAM,gBAAgB,CAAC;AAEtE,OAAO,EAAK,UAAU,EAAC,MAAM,cAAc,CAAC;AAC5C,OAAO,EAAC,iBAAiB,EAAC,MAAM,kBAAkB,CAAC;AACnD,OAAO,EAAC,GAAG,EAAC,MAAM,iBAAiB,CAAC;AAEpC,OAAO,EAAC,MAAM,EAAE,oBAAoB,EAAC,MAAM,eAAe,CAAC;AAE3D,MAAM,CAAC,MAAM,4BAA4B,GAAG,IAAI,aAAa,CAC3D;IACE,SAAS,EAAE,GAAG,CAAC,IAAI;IACnB,IAAI,EAAE,GAAG,CAAC,IAAI;IACd,cAAc,EAAE,GAAG,CAAC,KAAK;IACzB,eAAe,EAAE,GAAG,CAAC,SAAS;IAC9B,2FAA2F;IAC3F,wEAAwE;IACxE,gBAAgB,EAAE,IAAI,cAAc,CAAC,iBAAiB,CAAC;IACvD,kBAAkB,EAAE,GAAG,CAAC,IAAI,CAAC,kBAAkB;CAChD,EACD,EAAC,QAAQ,EAAE,2BAA2B,EAAE,QAAQ,EAAE,MAAM,EAAC,CAC1D,CAAC;AAGF,MAAM,CAAC,MAAM,2BAA2B,GAAG,CAAC,CAAC;AAC7C,MAAM,CAAC,MAAM,2BAA2B,GAAG,EAAE,CAAC;AAC9C,MAAM,CAAC,MAAM,4BAA4B,GAAG,EAAE,CAAC;AAC/C,MAAM,CAAC,MAAM,4BAA4B,GAAG,EAAE,CAAC;AAC/C,MAAM,CAAC,MAAM,mCAAmC,GAAG,EAAE,CAAC;AACtD,MAAM,CAAC,MAAM,qCAAqC,GAAG,mCAAmC,GAAG,iBAAiB,GAAG,CAAC,CAAC;AAEjH;;;;GAIG;AACH,MAAM,OAAO,4BAA6B,SAAQ,UAAiD;IACjG,YAAY,MAAuB,EAAE,EAAM;QACzC,MAAM,MAAM,GAAG,MAAM,CAAC,2BAA2B,CAAC;QAClD,KAAK,CAAC,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,4BAA4B,EAAE,oBAAoB,CAAC,MAAM,CAAC,CAAC,CAAC;IACxF,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,KAAgC;QACpC,MAAM,EAAC,SAAS,EAAC,GAAG,KAAK,CAAC;QAC1B,OAAO,SAAS,CAAC;IACnB,CAAC;CACF"}
@@ -1,15 +0,0 @@
1
- import { ChainForkConfig } from "@lodestar/config";
2
- import { Db, Repository } from "@lodestar/db";
3
- import { Slot } from "@lodestar/types";
4
- import { DataColumnSidecarsWrapper } from "./dataColumnSidecars.js";
5
- /**
6
- * dataColumnSidecarsWrapper by slot
7
- *
8
- * Used to store finalized DataColumnSidecars
9
- */
10
- export declare class DataColumnSidecarsArchiveRepository extends Repository<Slot, DataColumnSidecarsWrapper> {
11
- constructor(config: ChainForkConfig, db: Db);
12
- getId(value: DataColumnSidecarsWrapper): Slot;
13
- decodeKey(data: Uint8Array): number;
14
- }
15
- //# sourceMappingURL=dataColumnSidecarsArchive.d.ts.map
@@ -1,23 +0,0 @@
1
- import { Repository } from "@lodestar/db";
2
- import { bytesToInt } from "@lodestar/utils";
3
- import { Bucket, getBucketNameByValue } from "../buckets.js";
4
- import { dataColumnSidecarsWrapperSsz } from "./dataColumnSidecars.js";
5
- /**
6
- * dataColumnSidecarsWrapper by slot
7
- *
8
- * Used to store finalized DataColumnSidecars
9
- */
10
- export class DataColumnSidecarsArchiveRepository extends Repository {
11
- constructor(config, db) {
12
- const bucket = Bucket.allForks_dataColumnSidecarsArchive;
13
- super(config, db, bucket, dataColumnSidecarsWrapperSsz, getBucketNameByValue(bucket));
14
- }
15
- // Handle key as slot
16
- getId(value) {
17
- return value.slot;
18
- }
19
- decodeKey(data) {
20
- return bytesToInt(super.decodeKey(data), "be");
21
- }
22
- }
23
- //# sourceMappingURL=dataColumnSidecarsArchive.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"dataColumnSidecarsArchive.js","sourceRoot":"","sources":["../../../src/db/repositories/dataColumnSidecarsArchive.ts"],"names":[],"mappings":"AACA,OAAO,EAAK,UAAU,EAAC,MAAM,cAAc,CAAC;AAE5C,OAAO,EAAC,UAAU,EAAC,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAC,MAAM,EAAE,oBAAoB,EAAC,MAAM,eAAe,CAAC;AAC3D,OAAO,EAA4B,4BAA4B,EAAC,MAAM,yBAAyB,CAAC;AAEhG;;;;GAIG;AACH,MAAM,OAAO,mCAAoC,SAAQ,UAA2C;IAClG,YAAY,MAAuB,EAAE,EAAM;QACzC,MAAM,MAAM,GAAG,MAAM,CAAC,kCAAkC,CAAC;QACzD,KAAK,CAAC,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,4BAA4B,EAAE,oBAAoB,CAAC,MAAM,CAAC,CAAC,CAAC;IACxF,CAAC;IAED,qBAAqB;IAErB,KAAK,CAAC,KAAgC;QACpC,OAAO,KAAK,CAAC,IAAI,CAAC;IACpB,CAAC;IAED,SAAS,CAAC,IAAgB;QACxB,OAAO,UAAU,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,CAA0B,EAAE,IAAI,CAAC,CAAC;IAC1E,CAAC;CACF"}
@@ -1,23 +0,0 @@
1
- import { PeerId } from "@libp2p/interface";
2
- import { BeaconConfig } from "@lodestar/config";
3
- import { CustodyConfig } from "../util/dataColumns.js";
4
- import { NodeId } from "./subnets/interface.js";
5
- /**
6
- * Store shared data for different modules in the network stack.
7
- * TODO: consider moving similar shared data, for example PeersData, under NetworkConfig.
8
- */
9
- export declare class NetworkConfig {
10
- private readonly nodeId;
11
- private readonly config;
12
- private readonly custodyConfig;
13
- constructor(peerId: PeerId, config: BeaconConfig);
14
- getConfig(): BeaconConfig;
15
- getNodeId(): NodeId;
16
- /**
17
- * Consumer should never mutate returned CustodyConfig
18
- */
19
- getCustodyConfig(): CustodyConfig;
20
- setTargetGroupCount(count: number): void;
21
- setAdvertisedGroupCount(count: number): void;
22
- }
23
- //# sourceMappingURL=networkConfig.d.ts.map
@@ -1,32 +0,0 @@
1
- import { CustodyConfig } from "../util/dataColumns.js";
2
- import { computeNodeId } from "./subnets/interface.js";
3
- /**
4
- * Store shared data for different modules in the network stack.
5
- * TODO: consider moving similar shared data, for example PeersData, under NetworkConfig.
6
- */
7
- export class NetworkConfig {
8
- constructor(peerId, config) {
9
- this.nodeId = computeNodeId(peerId);
10
- this.config = config;
11
- this.custodyConfig = new CustodyConfig(this.nodeId, config);
12
- }
13
- getConfig() {
14
- return this.config;
15
- }
16
- getNodeId() {
17
- return this.nodeId;
18
- }
19
- /**
20
- * Consumer should never mutate returned CustodyConfig
21
- */
22
- getCustodyConfig() {
23
- return this.custodyConfig;
24
- }
25
- setTargetGroupCount(count) {
26
- this.custodyConfig.updateTargetCustodyGroupCount(count);
27
- }
28
- setAdvertisedGroupCount(count) {
29
- this.custodyConfig.updateAdvertisedCustodyGroupCount(count);
30
- }
31
- }
32
- //# sourceMappingURL=networkConfig.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"networkConfig.js","sourceRoot":"","sources":["../../src/network/networkConfig.ts"],"names":[],"mappings":"AAEA,OAAO,EAAC,aAAa,EAAC,MAAM,wBAAwB,CAAC;AACrD,OAAO,EAAS,aAAa,EAAC,MAAM,wBAAwB,CAAC;AAE7D;;;GAGG;AACH,MAAM,OAAO,aAAa;IAKxB,YAAY,MAAc,EAAE,MAAoB;QAC9C,IAAI,CAAC,MAAM,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;QACpC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,aAAa,GAAG,IAAI,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC9D,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED;;OAEG;IACH,gBAAgB;QACd,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAED,mBAAmB,CAAC,KAAa;QAC/B,IAAI,CAAC,aAAa,CAAC,6BAA6B,CAAC,KAAK,CAAC,CAAC;IAC1D,CAAC;IAED,uBAAuB,CAAC,KAAa;QACnC,IAAI,CAAC,aAAa,CAAC,iCAAiC,CAAC,KAAK,CAAC,CAAC;IAC9D,CAAC;CACF"}
@@ -1,8 +0,0 @@
1
- import { ResponseOutgoing } from "@lodestar/reqresp";
2
- import { ColumnIndex, Slot, fulu } from "@lodestar/types";
3
- import { IBeaconChain } from "../../../chain/index.js";
4
- import { IBeaconDb } from "../../../db/index.js";
5
- export declare function onDataColumnSidecarsByRange(request: fulu.DataColumnSidecarsByRangeRequest, chain: IBeaconChain, db: IBeaconDb): AsyncIterable<ResponseOutgoing>;
6
- export declare function iterateDataColumnBytesFromWrapper(chain: IBeaconChain, dataColumnSidecarsBytesWrapped: Uint8Array, blockSlot: Slot, columns: ColumnIndex[]): Iterable<ResponseOutgoing>;
7
- export declare function validateDataColumnSidecarsByRangeRequest(request: fulu.DataColumnSidecarsByRangeRequest): fulu.DataColumnSidecarsByRangeRequest;
8
- //# sourceMappingURL=dataColumnSidecarsByRange.d.ts.map
@@ -1,106 +0,0 @@
1
- import { GENESIS_SLOT, MAX_REQUEST_BLOCKS_DENEB, NUMBER_OF_COLUMNS } from "@lodestar/params";
2
- import { RespStatus, ResponseError } from "@lodestar/reqresp";
3
- import { ssz } from "@lodestar/types";
4
- import { fromHex } from "@lodestar/utils";
5
- import { COLUMN_SIZE_IN_WRAPPER_INDEX, CUSTODY_COLUMNS_IN_IN_WRAPPER_INDEX, DATA_COLUMN_SIDECARS_IN_WRAPPER_INDEX, NUM_COLUMNS_IN_WRAPPER_INDEX, } from "../../../db/repositories/dataColumnSidecars.js";
6
- export async function* onDataColumnSidecarsByRange(request, chain, db) {
7
- // Non-finalized range of blobs
8
- const { startSlot, count, columns } = validateDataColumnSidecarsByRangeRequest(request);
9
- const endSlot = startSlot + count;
10
- const finalized = db.dataColumnSidecarsArchive;
11
- const unfinalized = db.dataColumnSidecars;
12
- const finalizedSlot = chain.forkChoice.getFinalizedBlock().slot;
13
- // console.log(
14
- // `incoming onDataColumnSidecarsByRange startSlot=${startSlot}, count=${count}, columns=${columns.join(" ")} finalizedSlot=${finalizedSlot} endSlot=${endSlot}`
15
- // );
16
- // Finalized range of blobs
17
- if (startSlot <= finalizedSlot) {
18
- // console.log(`serving onDataColumnSidecarsByRange finalized startSlot=${startSlot} finalizedSlot=${finalizedSlot}`);
19
- // Chain of blobs won't change
20
- for await (const { key, value: dataColumnSideCarsBytesWrapped } of finalized.binaryEntriesStream({
21
- gte: startSlot,
22
- lt: endSlot,
23
- })) {
24
- yield* iterateDataColumnBytesFromWrapper(chain, dataColumnSideCarsBytesWrapped, finalized.decodeKey(key), columns);
25
- }
26
- }
27
- // Non-finalized range of blobs
28
- if (endSlot > finalizedSlot) {
29
- // console.log(`serving onDataColumnSidecarsByRange unfinalized endSlot=${endSlot} finalizedSlot=${finalizedSlot}`);
30
- const headRoot = chain.forkChoice.getHeadRoot();
31
- // TODO DENEB: forkChoice should mantain an array of canonical blocks, and change only on reorg
32
- const headChain = chain.forkChoice.getAllAncestorBlocks(headRoot);
33
- // Iterate head chain with ascending block numbers
34
- for (let i = headChain.length - 1; i >= 0; i--) {
35
- const block = headChain[i];
36
- // Must include only blobs in the range requested
37
- if (block.slot >= startSlot && block.slot < endSlot) {
38
- // Note: Here the forkChoice head may change due to a re-org, so the headChain reflects the canonical chain
39
- // at the time of the start of the request. Spec is clear the chain of blobs must be consistent, but on
40
- // re-org there's no need to abort the request
41
- // Spec: https://github.com/ethereum/consensus-specs/blob/a1e46d1ae47dd9d097725801575b46907c12a1f8/specs/eip4844/p2p-interface.md#blobssidecarsbyrange-v1
42
- const blobSideCarsBytesWrapped = await unfinalized.getBinary(fromHex(block.blockRoot));
43
- if (!blobSideCarsBytesWrapped) {
44
- // console.log(`error onDataColumnSidecarsByRange No item for root ${block.blockRoot} slot ${block.slot}`);
45
- // Handle the same to onBeaconBlocksByRange
46
- throw new ResponseError(RespStatus.SERVER_ERROR, `No item for root ${block.blockRoot} slot ${block.slot}`);
47
- }
48
- yield* iterateDataColumnBytesFromWrapper(chain, blobSideCarsBytesWrapped, block.slot, columns);
49
- }
50
- // If block is after endSlot, stop iterating
51
- else if (block.slot >= endSlot) {
52
- // console.log(`breaking away onDataColumnSidecarsByRange block.slot=${block.slot} endSlot=${endSlot}`);
53
- break;
54
- }
55
- }
56
- }
57
- }
58
- export function* iterateDataColumnBytesFromWrapper(chain, dataColumnSidecarsBytesWrapped, blockSlot, columns) {
59
- const retrivedColumnsLen = ssz.Uint8.deserialize(dataColumnSidecarsBytesWrapped.slice(NUM_COLUMNS_IN_WRAPPER_INDEX, COLUMN_SIZE_IN_WRAPPER_INDEX));
60
- const retrievedColumnsSizeBytes = dataColumnSidecarsBytesWrapped.slice(COLUMN_SIZE_IN_WRAPPER_INDEX, CUSTODY_COLUMNS_IN_IN_WRAPPER_INDEX);
61
- const columnsSize = ssz.UintNum64.deserialize(retrievedColumnsSizeBytes);
62
- const dataColumnsIndex = dataColumnSidecarsBytesWrapped.slice(CUSTODY_COLUMNS_IN_IN_WRAPPER_INDEX, CUSTODY_COLUMNS_IN_IN_WRAPPER_INDEX + NUMBER_OF_COLUMNS);
63
- const allDataColumnSidecarsBytes = dataColumnSidecarsBytesWrapped.slice(DATA_COLUMN_SIDECARS_IN_WRAPPER_INDEX + 4 * retrivedColumnsLen);
64
- const columnsLen = allDataColumnSidecarsBytes.length / columnsSize;
65
- // const storedColumns = Array.from({length: NUMBER_OF_COLUMNS}, (_v, i) => i).filter((i) => dataColumnsIndex[i] > 0);
66
- // console.log(
67
- // `onDataColumnSidecarsByRange: slot=${blockSlot} columnsSize=${columnsSize} columnsLen=${columnsLen} retrivedColumnsLen=${retrivedColumnsLen} toredColumnsNum=${allDataColumnSidecarsBytes.length / columnsSize}, storedColumns=${storedColumns.join(" ")}`
68
- // );
69
- // no columns possibly no blob
70
- if (columnsLen === 0) {
71
- return;
72
- }
73
- const fork = chain.config.getForkName(blockSlot);
74
- for (const index of columns) {
75
- // get the index at which the column is
76
- const dataIndex = (dataColumnsIndex[index] ?? 0) - 1;
77
- if (dataIndex < 0) {
78
- throw new ResponseError(RespStatus.SERVER_ERROR, `dataColumnSidecar index=${index} dataIndex=${dataIndex} not custodied`);
79
- }
80
- const dataColumnSidecarBytes = allDataColumnSidecarsBytes.slice(dataIndex * columnsSize, (dataIndex + 1) * columnsSize);
81
- if (dataColumnSidecarBytes.length !== columnsSize) {
82
- throw new ResponseError(RespStatus.SERVER_ERROR, `Invalid dataColumnSidecar index=${index} dataIndex=${dataIndex} bytes length=${dataColumnSidecarBytes.length} expected=${columnsSize} for slot ${blockSlot} blobsLen=${columnsLen}`);
83
- }
84
- // console.log(`iterate onDataColumnSidecarsByRange blockSlot=${blockSlot} index=${index} dataIndex=${dataIndex}`);
85
- yield {
86
- data: dataColumnSidecarBytes,
87
- fork,
88
- };
89
- }
90
- }
91
- export function validateDataColumnSidecarsByRangeRequest(request) {
92
- const { startSlot, columns } = request;
93
- let { count } = request;
94
- if (count < 1) {
95
- throw new ResponseError(RespStatus.INVALID_REQUEST, "count < 1");
96
- }
97
- // TODO: validate against MIN_EPOCHS_FOR_BLOCK_REQUESTS
98
- if (startSlot < GENESIS_SLOT) {
99
- throw new ResponseError(RespStatus.INVALID_REQUEST, "startSlot < genesis");
100
- }
101
- if (count > MAX_REQUEST_BLOCKS_DENEB) {
102
- count = MAX_REQUEST_BLOCKS_DENEB;
103
- }
104
- return { startSlot, count, columns };
105
- }
106
- //# sourceMappingURL=dataColumnSidecarsByRange.js.map