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