@lodestar/beacon-node 1.33.0-peerDAS.e03bda542e → 1.33.0-rc.0
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 +26 -66
- package/lib/api/impl/beacon/blocks/index.js.map +1 -1
- package/lib/api/impl/debug/index.d.ts +1 -1
- package/lib/api/impl/debug/index.js +1 -24
- package/lib/api/impl/debug/index.js.map +1 -1
- package/lib/chain/archiveStore/archiveStore.d.ts +1 -1
- package/lib/chain/archiveStore/archiveStore.js +2 -2
- package/lib/chain/archiveStore/interface.d.ts +1 -1
- package/lib/chain/archiveStore/utils/archiveBlocks.d.ts +1 -1
- package/lib/chain/archiveStore/utils/archiveBlocks.js +23 -88
- package/lib/chain/archiveStore/utils/archiveBlocks.js.map +1 -1
- package/lib/chain/beaconProposerCache.d.ts +0 -1
- package/lib/chain/beaconProposerCache.js +0 -3
- package/lib/chain/beaconProposerCache.js.map +1 -1
- package/lib/chain/blocks/importBlock.js +3 -8
- package/lib/chain/blocks/importBlock.js.map +1 -1
- package/lib/chain/blocks/types.d.ts +24 -67
- package/lib/chain/blocks/types.js +6 -40
- package/lib/chain/blocks/types.js.map +1 -1
- package/lib/chain/blocks/verifyBlocksDataAvailability.js +10 -21
- package/lib/chain/blocks/verifyBlocksDataAvailability.js.map +1 -1
- package/lib/chain/blocks/writeBlockInputToDb.js +15 -89
- package/lib/chain/blocks/writeBlockInputToDb.js.map +1 -1
- package/lib/chain/chain.d.ts +5 -16
- package/lib/chain/chain.js +6 -34
- package/lib/chain/chain.js.map +1 -1
- package/lib/chain/emitter.d.ts +2 -18
- package/lib/chain/emitter.js +0 -13
- package/lib/chain/emitter.js.map +1 -1
- package/lib/chain/errors/index.d.ts +0 -1
- package/lib/chain/errors/index.js +0 -1
- package/lib/chain/errors/index.js.map +1 -1
- package/lib/chain/interface.d.ts +4 -10
- package/lib/chain/interface.js.map +1 -1
- package/lib/chain/options.d.ts +1 -4
- package/lib/chain/options.js +1 -5
- package/lib/chain/options.js.map +1 -1
- package/lib/chain/prepareNextSlot.js +1 -1
- package/lib/chain/prepareNextSlot.js.map +1 -1
- package/lib/chain/produceBlock/produceBlockBody.d.ts +2 -4
- package/lib/chain/produceBlock/produceBlockBody.js +2 -7
- package/lib/chain/produceBlock/produceBlockBody.js.map +1 -1
- package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.d.ts +2 -3
- package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.js +2 -25
- package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.js.map +1 -1
- package/lib/chain/seenCache/seenGossipBlockInput.d.ts +18 -64
- package/lib/chain/seenCache/seenGossipBlockInput.js +53 -321
- package/lib/chain/seenCache/seenGossipBlockInput.js.map +1 -1
- package/lib/constants/network.d.ts +1 -0
- package/lib/constants/network.js +2 -0
- package/lib/constants/network.js.map +1 -1
- package/lib/db/beacon.d.ts +1 -3
- package/lib/db/beacon.js +1 -3
- package/lib/db/beacon.js.map +1 -1
- package/lib/db/buckets.d.ts +1 -3
- package/lib/db/buckets.js +0 -2
- package/lib/db/buckets.js.map +1 -1
- package/lib/db/interface.d.ts +1 -3
- package/lib/db/repositories/index.d.ts +0 -2
- package/lib/db/repositories/index.js +0 -2
- package/lib/db/repositories/index.js.map +1 -1
- package/lib/execution/engine/http.d.ts +3 -5
- package/lib/execution/engine/http.js +31 -70
- package/lib/execution/engine/http.js.map +1 -1
- package/lib/execution/engine/interface.d.ts +2 -4
- package/lib/execution/engine/interface.js +1 -1
- package/lib/execution/engine/interface.js.map +1 -1
- package/lib/execution/engine/mock.d.ts +0 -1
- package/lib/execution/engine/mock.js +0 -5
- package/lib/execution/engine/mock.js.map +1 -1
- package/lib/execution/engine/types.d.ts +0 -10
- package/lib/execution/engine/types.js +0 -6
- package/lib/execution/engine/types.js.map +1 -1
- package/lib/metrics/metrics/beacon.d.ts +1 -15
- package/lib/metrics/metrics/beacon.js +1 -58
- package/lib/metrics/metrics/beacon.js.map +1 -1
- package/lib/metrics/metrics/lodestar.d.ts +1 -23
- package/lib/metrics/metrics/lodestar.js +0 -39
- package/lib/metrics/metrics/lodestar.js.map +1 -1
- package/lib/network/core/metrics.d.ts +3 -10
- package/lib/network/core/metrics.js +4 -22
- package/lib/network/core/metrics.js.map +1 -1
- package/lib/network/core/networkCore.d.ts +3 -8
- package/lib/network/core/networkCore.js +10 -24
- package/lib/network/core/networkCore.js.map +1 -1
- package/lib/network/core/networkCoreWorker.js +0 -1
- package/lib/network/core/networkCoreWorker.js.map +1 -1
- package/lib/network/core/networkCoreWorkerHandler.d.ts +3 -4
- package/lib/network/core/networkCoreWorkerHandler.js +0 -4
- package/lib/network/core/networkCoreWorkerHandler.js.map +1 -1
- package/lib/network/core/types.d.ts +4 -6
- package/lib/network/events.d.ts +2 -4
- package/lib/network/events.js.map +1 -1
- package/lib/network/gossip/interface.d.ts +1 -8
- package/lib/network/gossip/interface.js +0 -1
- package/lib/network/gossip/interface.js.map +1 -1
- package/lib/network/gossip/topic.d.ts +1497 -1513
- package/lib/network/gossip/topic.js +1 -20
- package/lib/network/gossip/topic.js.map +1 -1
- package/lib/network/interface.d.ts +1 -13
- package/lib/network/metadata.d.ts +5 -9
- package/lib/network/metadata.js +5 -25
- package/lib/network/metadata.js.map +1 -1
- package/lib/network/network.d.ts +2 -12
- package/lib/network/network.js +8 -59
- package/lib/network/network.js.map +1 -1
- package/lib/network/options.js +0 -5
- package/lib/network/options.js.map +1 -1
- package/lib/network/peers/discover.d.ts +5 -9
- package/lib/network/peers/discover.js +23 -108
- package/lib/network/peers/discover.js.map +1 -1
- package/lib/network/peers/peerManager.d.ts +4 -10
- package/lib/network/peers/peerManager.js +46 -101
- package/lib/network/peers/peerManager.js.map +1 -1
- package/lib/network/peers/peersData.d.ts +3 -17
- package/lib/network/peers/peersData.js.map +1 -1
- package/lib/network/peers/score/constants.d.ts +3 -1
- package/lib/network/peers/score/constants.js +3 -1
- package/lib/network/peers/score/constants.js.map +1 -1
- package/lib/network/peers/score/interface.d.ts +6 -1
- package/lib/network/peers/score/interface.js.map +1 -1
- package/lib/network/peers/score/score.d.ts +7 -2
- package/lib/network/peers/score/score.js +35 -5
- package/lib/network/peers/score/score.js.map +1 -1
- package/lib/network/peers/score/store.d.ts +10 -3
- package/lib/network/peers/score/store.js +15 -6
- package/lib/network/peers/score/store.js.map +1 -1
- package/lib/network/peers/utils/assertPeerRelevance.d.ts +3 -7
- package/lib/network/peers/utils/assertPeerRelevance.js +1 -10
- package/lib/network/peers/utils/assertPeerRelevance.js.map +1 -1
- package/lib/network/peers/utils/prioritizePeers.d.ts +7 -18
- package/lib/network/peers/utils/prioritizePeers.js +7 -43
- package/lib/network/peers/utils/prioritizePeers.js.map +1 -1
- package/lib/network/processor/extractSlotRootFns.js +1 -8
- package/lib/network/processor/extractSlotRootFns.js.map +1 -1
- package/lib/network/processor/gossipHandlers.js +9 -156
- package/lib/network/processor/gossipHandlers.js.map +1 -1
- package/lib/network/processor/gossipQueues/index.js +0 -5
- package/lib/network/processor/gossipQueues/index.js.map +1 -1
- package/lib/network/processor/index.js +0 -1
- package/lib/network/processor/index.js.map +1 -1
- package/lib/network/reqresp/ReqRespBeaconNode.d.ts +2 -2
- package/lib/network/reqresp/ReqRespBeaconNode.js +10 -33
- package/lib/network/reqresp/ReqRespBeaconNode.js.map +1 -1
- package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.d.ts +5 -16
- package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.js +14 -204
- package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.js.map +1 -1
- package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.d.ts +6 -32
- package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.js +28 -283
- 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/index.js +0 -10
- package/lib/network/reqresp/handlers/index.js.map +1 -1
- package/lib/network/reqresp/handlers/status.js +2 -3
- package/lib/network/reqresp/handlers/status.js.map +1 -1
- package/lib/network/reqresp/protocols.d.ts +0 -4
- package/lib/network/reqresp/protocols.js +0 -20
- package/lib/network/reqresp/protocols.js.map +1 -1
- package/lib/network/reqresp/rateLimit.js +1 -11
- package/lib/network/reqresp/rateLimit.js.map +1 -1
- package/lib/network/reqresp/types.d.ts +8 -15
- package/lib/network/reqresp/types.js +3 -10
- package/lib/network/reqresp/types.js.map +1 -1
- package/lib/network/statusCache.d.ts +5 -5
- package/lib/network/statusCache.js.map +1 -1
- package/lib/network/subnets/interface.d.ts +0 -3
- package/lib/network/subnets/interface.js +1 -14
- package/lib/network/subnets/interface.js.map +1 -1
- package/lib/network/subnets/syncnetsService.js +5 -4
- package/lib/network/subnets/syncnetsService.js.map +1 -1
- package/lib/node/nodejs.js +0 -1
- package/lib/node/nodejs.js.map +1 -1
- package/lib/sync/constants.d.ts +1 -1
- package/lib/sync/constants.js +1 -4
- package/lib/sync/constants.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 +2 -16
- package/lib/sync/range/batch.js +7 -38
- package/lib/sync/range/batch.js.map +1 -1
- package/lib/sync/range/chain.d.ts +1 -16
- package/lib/sync/range/chain.js +30 -110
- package/lib/sync/range/chain.js.map +1 -1
- package/lib/sync/range/range.d.ts +2 -3
- package/lib/sync/range/range.js +3 -9
- package/lib/sync/range/range.js.map +1 -1
- package/lib/sync/range/utils/chainTarget.d.ts +1 -5
- package/lib/sync/range/utils/chainTarget.js +1 -26
- package/lib/sync/range/utils/chainTarget.js.map +1 -1
- package/lib/sync/range/utils/peerBalancer.d.ts +5 -12
- package/lib/sync/range/utils/peerBalancer.js +10 -69
- package/lib/sync/range/utils/peerBalancer.js.map +1 -1
- package/lib/sync/unknownBlock.d.ts +1 -8
- package/lib/sync/unknownBlock.js +69 -226
- package/lib/sync/unknownBlock.js.map +1 -1
- package/lib/sync/utils/remoteSyncType.d.ts +4 -4
- package/lib/sync/utils/remoteSyncType.js.map +1 -1
- package/lib/util/blobs.d.ts +1 -18
- package/lib/util/blobs.js +1 -104
- package/lib/util/blobs.js.map +1 -1
- package/lib/util/metadata.d.ts +0 -4
- package/lib/util/metadata.js +0 -7
- package/lib/util/metadata.js.map +1 -1
- package/lib/util/sszBytes.d.ts +0 -1
- package/lib/util/sszBytes.js +0 -17
- package/lib/util/sszBytes.js.map +1 -1
- package/package.json +14 -14
- package/lib/chain/errors/dataColumnSidecarError.d.ts +0 -69
- package/lib/chain/errors/dataColumnSidecarError.js +0 -21
- package/lib/chain/errors/dataColumnSidecarError.js.map +0 -1
- package/lib/chain/validation/dataColumnSidecar.d.ts +0 -28
- package/lib/chain/validation/dataColumnSidecar.js +0 -248
- package/lib/chain/validation/dataColumnSidecar.js.map +0 -1
- package/lib/db/repositories/dataColumnSidecars.d.ts +0 -47
- package/lib/db/repositories/dataColumnSidecars.js +0 -40
- package/lib/db/repositories/dataColumnSidecars.js.map +0 -1
- package/lib/db/repositories/dataColumnSidecarsArchive.d.ts +0 -15
- package/lib/db/repositories/dataColumnSidecarsArchive.js +0 -23
- package/lib/db/repositories/dataColumnSidecarsArchive.js.map +0 -1
- package/lib/network/networkConfig.d.ts +0 -22
- package/lib/network/networkConfig.js +0 -29
- package/lib/network/networkConfig.js.map +0 -1
- package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts +0 -8
- package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js +0 -106
- package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js.map +0 -1
- package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.d.ts +0 -6
- package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js +0 -57
- package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js.map +0 -1
- package/lib/util/dataColumns.d.ts +0 -132
- package/lib/util/dataColumns.js +0 -353
- package/lib/util/dataColumns.js.map +0 -1
|
@@ -1,21 +1,12 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { ForkName, NUMBER_OF_COLUMNS, isForkPostDeneb } from "@lodestar/params";
|
|
1
|
+
import { isForkPostDeneb } from "@lodestar/params";
|
|
3
2
|
import { ssz } from "@lodestar/types";
|
|
4
|
-
import { pruneSetToMax } from "@lodestar/utils";
|
|
5
|
-
import {
|
|
6
|
-
import { callInNextEventLoop } from "../../util/eventLoop.js";
|
|
7
|
-
import { BlobsSource, BlockSource, DataColumnsSource, GossipedInputType, getBlockInput, getBlockInputBlobs, getBlockInputDataColumns, } from "../blocks/types.js";
|
|
8
|
-
import { ChainEvent } from "../emitter.js";
|
|
9
|
-
import { DataColumnSidecarErrorCode, DataColumnSidecarGossipError } from "../errors/dataColumnSidecarError.js";
|
|
10
|
-
import { GossipAction } from "../errors/gossipValidation.js";
|
|
3
|
+
import { pruneSetToMax, toRootHex } from "@lodestar/utils";
|
|
4
|
+
import { BlobsSource, BlockSource, GossipedInputType, getBlockInput, getBlockInputBlobs, } from "../blocks/types.js";
|
|
11
5
|
export var BlockInputAvailabilitySource;
|
|
12
6
|
(function (BlockInputAvailabilitySource) {
|
|
13
7
|
BlockInputAvailabilitySource["GOSSIP"] = "gossip";
|
|
14
|
-
BlockInputAvailabilitySource["RECOVERED"] = "recovered";
|
|
15
8
|
BlockInputAvailabilitySource["UNKNOWN_SYNC"] = "unknown_sync";
|
|
16
9
|
})(BlockInputAvailabilitySource || (BlockInputAvailabilitySource = {}));
|
|
17
|
-
// TODO(fulu): dedup with gossipHandlers.ts
|
|
18
|
-
const BLOCK_AVAILABILITY_CUTOFF_MS = 3_000;
|
|
19
10
|
const MAX_GOSSIPINPUT_CACHE = 5;
|
|
20
11
|
/**
|
|
21
12
|
* For predeneb, SeenGossipBlockInput only tracks and caches block so that we don't need to download known block
|
|
@@ -29,14 +20,8 @@ const MAX_GOSSIPINPUT_CACHE = 5;
|
|
|
29
20
|
* block are seen by SeenGossipBlockInput
|
|
30
21
|
*/
|
|
31
22
|
export class SeenGossipBlockInput {
|
|
32
|
-
constructor(
|
|
23
|
+
constructor() {
|
|
33
24
|
this.blockInputCache = new Map();
|
|
34
|
-
this.globalCacheId = 0;
|
|
35
|
-
this.custodyConfig = custodyConfig;
|
|
36
|
-
this.executionEngine = executionEngine;
|
|
37
|
-
this.clock = clock;
|
|
38
|
-
this.emitter = emitter;
|
|
39
|
-
this.logger = logger;
|
|
40
25
|
}
|
|
41
26
|
prune() {
|
|
42
27
|
pruneSetToMax(this.blockInputCache, MAX_GOSSIPINPUT_CACHE);
|
|
@@ -44,30 +29,6 @@ export class SeenGossipBlockInput {
|
|
|
44
29
|
hasBlock(blockRoot) {
|
|
45
30
|
return this.blockInputCache.has(blockRoot);
|
|
46
31
|
}
|
|
47
|
-
/**
|
|
48
|
-
* Intended to be used for gossip validation, specifically this check:
|
|
49
|
-
* [IGNORE] The sidecar is the first sidecar for the tuple (block_header.slot, block_header.proposer_index,
|
|
50
|
-
* sidecar.index) with valid header signature, sidecar inclusion proof, and kzg proof
|
|
51
|
-
*/
|
|
52
|
-
hasDataColumnSidecar(sidecar) {
|
|
53
|
-
const blockRoot = ssz.phase0.BeaconBlockHeader.hashTreeRoot(sidecar.signedBlockHeader.message);
|
|
54
|
-
const blockRootHex = toHexString(blockRoot);
|
|
55
|
-
const blockCache = this.blockInputCache.get(blockRootHex);
|
|
56
|
-
if (blockCache === undefined) {
|
|
57
|
-
return false;
|
|
58
|
-
}
|
|
59
|
-
if (blockCache.cachedData === undefined || blockCache.cachedData.fork !== ForkName.fulu) {
|
|
60
|
-
return false;
|
|
61
|
-
}
|
|
62
|
-
const existingSidecar = blockCache.cachedData.dataColumnsCache.get(sidecar.index);
|
|
63
|
-
if (!existingSidecar) {
|
|
64
|
-
return false;
|
|
65
|
-
}
|
|
66
|
-
return (sidecar.signedBlockHeader.message.slot === existingSidecar.dataColumn.signedBlockHeader.message.slot &&
|
|
67
|
-
sidecar.index === existingSidecar.dataColumn.index &&
|
|
68
|
-
sidecar.signedBlockHeader.message.proposerIndex ===
|
|
69
|
-
existingSidecar.dataColumn.signedBlockHeader.message.proposerIndex);
|
|
70
|
-
}
|
|
71
32
|
getGossipBlockInput(config, gossipedInput, metrics) {
|
|
72
33
|
let blockHex;
|
|
73
34
|
let blockCache;
|
|
@@ -75,59 +36,21 @@ export class SeenGossipBlockInput {
|
|
|
75
36
|
if (gossipedInput.type === GossipedInputType.block) {
|
|
76
37
|
const { signedBlock } = gossipedInput;
|
|
77
38
|
fork = config.getForkName(signedBlock.message.slot);
|
|
78
|
-
blockHex =
|
|
79
|
-
blockCache = this.blockInputCache.get(blockHex) ?? getEmptyBlockInputCacheEntry(fork
|
|
39
|
+
blockHex = toRootHex(config.getForkTypes(signedBlock.message.slot).BeaconBlock.hashTreeRoot(signedBlock.message));
|
|
40
|
+
blockCache = this.blockInputCache.get(blockHex) ?? getEmptyBlockInputCacheEntry(fork);
|
|
80
41
|
blockCache.block = signedBlock;
|
|
81
42
|
}
|
|
82
|
-
else
|
|
43
|
+
else {
|
|
83
44
|
const { blobSidecar } = gossipedInput;
|
|
84
45
|
const blockRoot = ssz.phase0.BeaconBlockHeader.hashTreeRoot(blobSidecar.signedBlockHeader.message);
|
|
85
46
|
fork = config.getForkName(blobSidecar.signedBlockHeader.message.slot);
|
|
86
|
-
blockHex =
|
|
87
|
-
blockCache = this.blockInputCache.get(blockHex) ?? getEmptyBlockInputCacheEntry(fork
|
|
88
|
-
if (blockCache.cachedData?.fork !== ForkName.deneb && blockCache.cachedData?.fork !== ForkName.electra) {
|
|
89
|
-
throw Error(`blob data at non deneb/electra fork=${blockCache.fork}`);
|
|
90
|
-
}
|
|
47
|
+
blockHex = toRootHex(blockRoot);
|
|
48
|
+
blockCache = this.blockInputCache.get(blockHex) ?? getEmptyBlockInputCacheEntry(fork);
|
|
91
49
|
// TODO: freetheblobs check if its the same blob or a duplicate and throw/take actions
|
|
92
50
|
blockCache.cachedData?.blobsCache.set(blobSidecar.index, blobSidecar);
|
|
93
51
|
}
|
|
94
|
-
else if (gossipedInput.type === GossipedInputType.dataColumn) {
|
|
95
|
-
const { dataColumnSidecar, dataColumnBytes } = gossipedInput;
|
|
96
|
-
const blockRoot = ssz.phase0.BeaconBlockHeader.hashTreeRoot(dataColumnSidecar.signedBlockHeader.message);
|
|
97
|
-
fork = config.getForkName(dataColumnSidecar.signedBlockHeader.message.slot);
|
|
98
|
-
blockHex = toHexString(blockRoot);
|
|
99
|
-
blockCache = this.blockInputCache.get(blockHex) ?? getEmptyBlockInputCacheEntry(fork, ++this.globalCacheId);
|
|
100
|
-
if (blockCache.cachedData?.fork !== ForkName.fulu) {
|
|
101
|
-
throw Error(`data column data at non fulu fork=${blockCache.fork}`);
|
|
102
|
-
}
|
|
103
|
-
if (this.hasDataColumnSidecar(dataColumnSidecar)) {
|
|
104
|
-
throw new DataColumnSidecarGossipError(GossipAction.IGNORE, {
|
|
105
|
-
code: DataColumnSidecarErrorCode.ALREADY_KNOWN,
|
|
106
|
-
slot: dataColumnSidecar.signedBlockHeader.message.slot,
|
|
107
|
-
columnIdx: dataColumnSidecar.index,
|
|
108
|
-
});
|
|
109
|
-
}
|
|
110
|
-
blockCache.cachedData?.dataColumnsCache.set(dataColumnSidecar.index, {
|
|
111
|
-
dataColumn: dataColumnSidecar,
|
|
112
|
-
// easily splice out the unsigned message as blob is a fixed length type
|
|
113
|
-
dataColumnBytes: dataColumnBytes?.slice(0, dataColumnBytes.length) ?? null,
|
|
114
|
-
});
|
|
115
|
-
}
|
|
116
|
-
else {
|
|
117
|
-
// somehow helps resolve typescript that all types have been exausted
|
|
118
|
-
throw Error("Invalid gossipedInput type");
|
|
119
|
-
}
|
|
120
52
|
if (!this.blockInputCache.has(blockHex)) {
|
|
121
53
|
this.blockInputCache.set(blockHex, blockCache);
|
|
122
|
-
callInNextEventLoop(() => {
|
|
123
|
-
getDataColumnsFromExecution(config, this.custodyConfig, this.executionEngine, this.emitter, blockCache, metrics)
|
|
124
|
-
.then((_success) => {
|
|
125
|
-
// TODO: (@matthewkeil) add metrics collection point here
|
|
126
|
-
})
|
|
127
|
-
.catch((error) => {
|
|
128
|
-
this.logger.error("Error getting data columns from execution", { blockHex }, error);
|
|
129
|
-
});
|
|
130
|
-
});
|
|
131
54
|
}
|
|
132
55
|
const { block: signedBlock, blockInputPromise, resolveBlockInput, cachedData } = blockCache;
|
|
133
56
|
if (signedBlock !== undefined) {
|
|
@@ -140,217 +63,54 @@ export class SeenGossipBlockInput {
|
|
|
140
63
|
if (cachedData === undefined || !isForkPostDeneb(cachedData.fork)) {
|
|
141
64
|
throw Error("Missing or Invalid fork cached Data for post-deneb block");
|
|
142
65
|
}
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
throw Error(`Received more blobs=${blobsCache.size} than commitments=${blobKzgCommitments.length} for ${blockInfo}`);
|
|
151
|
-
}
|
|
152
|
-
if (blobKzgCommitments.length === blobsCache.size) {
|
|
153
|
-
const allBlobs = getBlockInputBlobs(blobsCache);
|
|
154
|
-
const { blobs } = allBlobs;
|
|
155
|
-
const blockData = {
|
|
156
|
-
fork: cachedData.fork,
|
|
157
|
-
...allBlobs,
|
|
158
|
-
blobsSource: BlobsSource.gossip,
|
|
159
|
-
};
|
|
160
|
-
resolveAvailability(blockData);
|
|
161
|
-
metrics?.syncUnknownBlock.resolveAvailabilitySource.inc({ source: BlockInputAvailabilitySource.GOSSIP });
|
|
162
|
-
const blockInput = getBlockInput.availableData(config, signedBlock, BlockSource.gossip, blockData);
|
|
163
|
-
resolveBlockInput(blockInput);
|
|
164
|
-
return {
|
|
165
|
-
blockInput,
|
|
166
|
-
blockInputMeta: { pending: null, haveBlobs: blobs.length, expectedBlobs: blobKzgCommitments.length },
|
|
167
|
-
};
|
|
168
|
-
}
|
|
169
|
-
const blockInput = getBlockInput.dataPromise(config, signedBlock, BlockSource.gossip, cachedData);
|
|
170
|
-
resolveBlockInput(blockInput);
|
|
171
|
-
return {
|
|
172
|
-
blockInput,
|
|
173
|
-
blockInputMeta: {
|
|
174
|
-
pending: GossipedInputType.blob,
|
|
175
|
-
haveBlobs: blobsCache.size,
|
|
176
|
-
expectedBlobs: blobKzgCommitments.length,
|
|
177
|
-
},
|
|
178
|
-
};
|
|
66
|
+
const { blobsCache, resolveAvailability } = cachedData;
|
|
67
|
+
// block is available, check if all blobs have shown up
|
|
68
|
+
const { slot, body } = signedBlock.message;
|
|
69
|
+
const { blobKzgCommitments } = body;
|
|
70
|
+
const blockInfo = `blockHex=${blockHex}, slot=${slot}`;
|
|
71
|
+
if (blobKzgCommitments.length < blobsCache.size) {
|
|
72
|
+
throw Error(`Received more blobs=${blobsCache.size} than commitments=${blobKzgCommitments.length} for ${blockInfo}`);
|
|
179
73
|
}
|
|
180
|
-
if (
|
|
181
|
-
const
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
throw Error(`Received more dataColumns=${dataColumnsCache.size} than columns=${NUMBER_OF_COLUMNS} for ${blockInfo}`);
|
|
187
|
-
}
|
|
188
|
-
// get the custody columns and see if we have got all the requisite columns
|
|
189
|
-
const blobKzgCommitmentsLen = signedBlock.message.body.blobKzgCommitments.length;
|
|
190
|
-
if (blobKzgCommitmentsLen === 0) {
|
|
191
|
-
const blockData = {
|
|
192
|
-
fork: cachedData.fork,
|
|
193
|
-
dataColumns: [],
|
|
194
|
-
dataColumnsBytes: [],
|
|
195
|
-
dataColumnsSource: DataColumnsSource.gossip,
|
|
196
|
-
};
|
|
197
|
-
resolveAvailability(blockData);
|
|
198
|
-
metrics?.syncUnknownBlock.resolveAvailabilitySource.inc({ source: BlockInputAvailabilitySource.GOSSIP });
|
|
199
|
-
const blockInput = getBlockInput.availableData(config, signedBlock, BlockSource.gossip, blockData);
|
|
200
|
-
resolveBlockInput(blockInput);
|
|
201
|
-
return {
|
|
202
|
-
blockInput,
|
|
203
|
-
blockInputMeta: { pending: null, haveColumns: 0, expectedColumns: 0 },
|
|
204
|
-
};
|
|
205
|
-
}
|
|
206
|
-
const resolveAvailabilityAndBlockInput = (source) => {
|
|
207
|
-
const allDataColumns = getBlockInputDataColumns(dataColumnsCache, this.custodyConfig.sampledColumns);
|
|
208
|
-
const blockData = {
|
|
209
|
-
fork: cachedData.fork,
|
|
210
|
-
...allDataColumns,
|
|
211
|
-
dataColumnsSource: DataColumnsSource.gossip,
|
|
212
|
-
};
|
|
213
|
-
resolveAvailability(blockData);
|
|
214
|
-
// TODO(das): should not use syncUnknownBlock metrics here
|
|
215
|
-
metrics?.syncUnknownBlock.resolveAvailabilitySource.inc({ source });
|
|
216
|
-
metrics?.dataColumns.bySource.inc({ source: DataColumnsSource.gossip });
|
|
217
|
-
const blockInput = getBlockInput.availableData(config, signedBlock, BlockSource.gossip, blockData);
|
|
218
|
-
resolveBlockInput(blockInput);
|
|
219
|
-
return blockInput;
|
|
220
|
-
};
|
|
221
|
-
const columnCount = dataColumnsCache.size;
|
|
222
|
-
if (
|
|
223
|
-
// only try to recover all columns with "--supernode"
|
|
224
|
-
this.custodyConfig.sampledColumns.length === NUMBER_OF_COLUMNS &&
|
|
225
|
-
columnCount >= NUMBER_OF_COLUMNS / 2 &&
|
|
226
|
-
columnCount < NUMBER_OF_COLUMNS &&
|
|
227
|
-
!calledRecover &&
|
|
228
|
-
// doing recover right away is not efficient because it may delay data_column_sidecar validation
|
|
229
|
-
this.clock.secFromSlot(slot) * 1000 >= BLOCK_AVAILABILITY_CUTOFF_MS) {
|
|
230
|
-
// should call once per slot
|
|
231
|
-
cachedData.calledRecover = true;
|
|
232
|
-
callInNextEventLoop(async () => {
|
|
233
|
-
const logCtx = {
|
|
234
|
-
blockHex,
|
|
235
|
-
slot,
|
|
236
|
-
dataColumns: dataColumnsCache.size,
|
|
237
|
-
};
|
|
238
|
-
const recoverResult = await recoverDataColumnSidecars(dataColumnsCache, this.clock, metrics).catch((e) => {
|
|
239
|
-
this.logger.error("Error recovering data column sidecars", logCtx, e);
|
|
240
|
-
return RecoverResult.Failed;
|
|
241
|
-
});
|
|
242
|
-
metrics?.recoverDataColumnSidecars.reconstructionResult.inc({ result: recoverResult });
|
|
243
|
-
switch (recoverResult) {
|
|
244
|
-
case RecoverResult.SuccessResolved: {
|
|
245
|
-
resolveAvailabilityAndBlockInput(BlockInputAvailabilitySource.RECOVERED);
|
|
246
|
-
// Publish columns if and only if subscribed to them
|
|
247
|
-
const sampledColumns = this.custodyConfig.sampledColumns.map((columnIndex) => {
|
|
248
|
-
const dataColumn = dataColumnsCache.get(columnIndex)?.dataColumn;
|
|
249
|
-
if (!dataColumn) {
|
|
250
|
-
throw Error(`After recover, missing data column for index=${columnIndex} in cache`);
|
|
251
|
-
}
|
|
252
|
-
return dataColumn;
|
|
253
|
-
});
|
|
254
|
-
// for columns that we already seen, it will be ignored through `ignoreDuplicatePublishError` gossip option
|
|
255
|
-
this.emitter.emit(ChainEvent.publishDataColumns, sampledColumns);
|
|
256
|
-
this.logger.verbose("Recovered data column sidecars and resolved availability", logCtx);
|
|
257
|
-
break;
|
|
258
|
-
}
|
|
259
|
-
case RecoverResult.SuccessLate:
|
|
260
|
-
this.logger.verbose("Recovered data column sidecars but it's late to resolve availability", logCtx);
|
|
261
|
-
break;
|
|
262
|
-
case RecoverResult.Failed:
|
|
263
|
-
this.logger.verbose("Failed to recover data column sidecars", logCtx);
|
|
264
|
-
break;
|
|
265
|
-
case RecoverResult.NotAttemptedFull:
|
|
266
|
-
this.logger.verbose("Did not attempt because we have full column sidecars", logCtx);
|
|
267
|
-
break;
|
|
268
|
-
case RecoverResult.NotAttemptedLessThanHalf:
|
|
269
|
-
this.logger.verbose("Did not attempt because we have too few column sidecars", logCtx);
|
|
270
|
-
break;
|
|
271
|
-
default:
|
|
272
|
-
break;
|
|
273
|
-
}
|
|
274
|
-
});
|
|
275
|
-
}
|
|
276
|
-
if (hasSampledDataColumns(this.custodyConfig, dataColumnsCache)) {
|
|
277
|
-
const blockInput = resolveAvailabilityAndBlockInput(BlockInputAvailabilitySource.GOSSIP);
|
|
278
|
-
const allDataColumns = getBlockInputDataColumns(dataColumnsCache, this.custodyConfig.sampledColumns);
|
|
279
|
-
const { dataColumns } = allDataColumns;
|
|
280
|
-
return {
|
|
281
|
-
blockInput,
|
|
282
|
-
blockInputMeta: {
|
|
283
|
-
pending: null,
|
|
284
|
-
haveColumns: dataColumns.length,
|
|
285
|
-
expectedColumns: this.custodyConfig.sampledColumns.length,
|
|
286
|
-
},
|
|
287
|
-
};
|
|
288
|
-
}
|
|
289
|
-
const blockInput = getBlockInput.dataPromise(config, signedBlock, BlockSource.gossip, cachedData);
|
|
74
|
+
if (blobKzgCommitments.length === blobsCache.size) {
|
|
75
|
+
const allBlobs = getBlockInputBlobs(blobsCache);
|
|
76
|
+
const blockData = { ...allBlobs, blobsSource: BlobsSource.gossip, fork: cachedData.fork };
|
|
77
|
+
resolveAvailability(blockData);
|
|
78
|
+
metrics?.syncUnknownBlock.resolveAvailabilitySource.inc({ source: BlockInputAvailabilitySource.GOSSIP });
|
|
79
|
+
const blockInput = getBlockInput.availableData(config, signedBlock, BlockSource.gossip, blockData);
|
|
290
80
|
resolveBlockInput(blockInput);
|
|
291
81
|
return {
|
|
292
82
|
blockInput,
|
|
293
|
-
blockInputMeta: {
|
|
294
|
-
pending: GossipedInputType.dataColumn,
|
|
295
|
-
haveColumns: dataColumnsCache.size,
|
|
296
|
-
expectedColumns: this.custodyConfig.sampledColumns.length,
|
|
297
|
-
},
|
|
83
|
+
blockInputMeta: { pending: null, haveBlobs: allBlobs.blobs.length, expectedBlobs: blobKzgCommitments.length },
|
|
298
84
|
};
|
|
299
85
|
}
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
// will need to wait for the block to showup
|
|
303
|
-
if (cachedData === undefined) {
|
|
304
|
-
throw Error("Missing cachedData for deneb+ blobs");
|
|
305
|
-
}
|
|
306
|
-
if (cachedData.fork === ForkName.deneb || cachedData.fork === ForkName.electra) {
|
|
307
|
-
const { blobsCache } = cachedData;
|
|
86
|
+
const blockInput = getBlockInput.dataPromise(config, signedBlock, BlockSource.gossip, cachedData);
|
|
87
|
+
resolveBlockInput(blockInput);
|
|
308
88
|
return {
|
|
309
|
-
blockInput
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
89
|
+
blockInput,
|
|
90
|
+
blockInputMeta: {
|
|
91
|
+
pending: GossipedInputType.blob,
|
|
92
|
+
haveBlobs: blobsCache.size,
|
|
93
|
+
expectedBlobs: blobKzgCommitments.length,
|
|
314
94
|
},
|
|
315
|
-
blockInputMeta: { pending: GossipedInputType.block, haveBlobs: blobsCache.size, expectedBlobs: null },
|
|
316
95
|
};
|
|
317
96
|
}
|
|
318
|
-
if (fork === ForkName.fulu) {
|
|
319
|
-
const { dataColumnsCache } = cachedData;
|
|
320
|
-
return {
|
|
321
|
-
blockInput: {
|
|
322
|
-
block: null,
|
|
323
|
-
blockRootHex: blockHex,
|
|
324
|
-
cachedData,
|
|
325
|
-
blockInputPromise,
|
|
326
|
-
},
|
|
327
|
-
blockInputMeta: { pending: GossipedInputType.block, haveColumns: dataColumnsCache.size, expectedColumns: null },
|
|
328
|
-
};
|
|
329
|
-
}
|
|
330
|
-
throw Error(`invalid fork=${fork} data not implemented`);
|
|
331
|
-
/**
|
|
332
|
-
* TODO: @matthewkeil this code was unreachable. Commented to remove lint error but need to verify the condition
|
|
333
|
-
* again to make sure this is not necessary before deleting it
|
|
334
|
-
*
|
|
335
|
-
* DO NOT DELETE until verified can be removed
|
|
336
|
-
*/
|
|
337
97
|
// will need to wait for the block to showup
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
98
|
+
if (cachedData === undefined) {
|
|
99
|
+
throw Error("Missing cachedData for deneb+ blobs");
|
|
100
|
+
}
|
|
101
|
+
const { blobsCache } = cachedData;
|
|
102
|
+
return {
|
|
103
|
+
blockInput: {
|
|
104
|
+
block: null,
|
|
105
|
+
blockRootHex: blockHex,
|
|
106
|
+
cachedData,
|
|
107
|
+
blockInputPromise,
|
|
108
|
+
},
|
|
109
|
+
blockInputMeta: { pending: GossipedInputType.block, haveBlobs: blobsCache.size, expectedBlobs: null },
|
|
110
|
+
};
|
|
351
111
|
}
|
|
352
112
|
}
|
|
353
|
-
|
|
113
|
+
function getEmptyBlockInputCacheEntry(fork) {
|
|
354
114
|
// Capture both the promise and its callbacks for blockInput and final availability
|
|
355
115
|
// It is not spec'ed but in tests in Firefox and NodeJS the promise constructor is run immediately
|
|
356
116
|
let resolveBlockInput = null;
|
|
@@ -363,43 +123,15 @@ export function getEmptyBlockInputCacheEntry(fork, globalCacheId) {
|
|
|
363
123
|
if (!isForkPostDeneb(fork)) {
|
|
364
124
|
return { fork, blockInputPromise, resolveBlockInput };
|
|
365
125
|
}
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
throw Error("Promise Constructor was not executed immediately");
|
|
373
|
-
}
|
|
374
|
-
const blobsCache = new Map();
|
|
375
|
-
const cachedData = {
|
|
376
|
-
fork,
|
|
377
|
-
blobsCache,
|
|
378
|
-
availabilityPromise,
|
|
379
|
-
resolveAvailability,
|
|
380
|
-
cacheId: ++globalCacheId,
|
|
381
|
-
};
|
|
382
|
-
return { fork, blockInputPromise, resolveBlockInput, cachedData };
|
|
383
|
-
}
|
|
384
|
-
if (fork === ForkName.fulu) {
|
|
385
|
-
let resolveAvailability = null;
|
|
386
|
-
const availabilityPromise = new Promise((resolveCB) => {
|
|
387
|
-
resolveAvailability = resolveCB;
|
|
388
|
-
});
|
|
389
|
-
if (resolveAvailability === null) {
|
|
390
|
-
throw Error("Promise Constructor was not executed immediately");
|
|
391
|
-
}
|
|
392
|
-
const dataColumnsCache = new Map();
|
|
393
|
-
const cachedData = {
|
|
394
|
-
fork,
|
|
395
|
-
dataColumnsCache,
|
|
396
|
-
availabilityPromise,
|
|
397
|
-
resolveAvailability,
|
|
398
|
-
cacheId: ++globalCacheId,
|
|
399
|
-
calledRecover: false,
|
|
400
|
-
};
|
|
401
|
-
return { fork, blockInputPromise, resolveBlockInput, cachedData };
|
|
126
|
+
let resolveAvailability = null;
|
|
127
|
+
const availabilityPromise = new Promise((resolveCB) => {
|
|
128
|
+
resolveAvailability = resolveCB;
|
|
129
|
+
});
|
|
130
|
+
if (resolveAvailability === null) {
|
|
131
|
+
throw Error("Promise Constructor was not executed immediately");
|
|
402
132
|
}
|
|
403
|
-
|
|
133
|
+
const blobsCache = new Map();
|
|
134
|
+
const cachedData = { fork, blobsCache, availabilityPromise, resolveAvailability };
|
|
135
|
+
return { fork, blockInputPromise, resolveBlockInput, cachedData };
|
|
404
136
|
}
|
|
405
137
|
//# 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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"}
|
|
@@ -13,6 +13,7 @@ export declare const GOSSIP_MAX_SIZE_BELLATRIX: number;
|
|
|
13
13
|
export declare const MAX_CHUNK_SIZE: number;
|
|
14
14
|
export declare const MAX_CHUNK_SIZE_BELLATRIX: number;
|
|
15
15
|
export declare enum GoodByeReasonCode {
|
|
16
|
+
INBOUND_DISCONNECT = -1,
|
|
16
17
|
CLIENT_SHUTDOWN = 1,
|
|
17
18
|
IRRELEVANT_NETWORK = 2,
|
|
18
19
|
ERROR = 3,
|
package/lib/constants/network.js
CHANGED
|
@@ -15,6 +15,7 @@ export const MAX_CHUNK_SIZE = 2 ** 20;
|
|
|
15
15
|
export const MAX_CHUNK_SIZE_BELLATRIX = 10 * MAX_CHUNK_SIZE;
|
|
16
16
|
export var GoodByeReasonCode;
|
|
17
17
|
(function (GoodByeReasonCode) {
|
|
18
|
+
GoodByeReasonCode[GoodByeReasonCode["INBOUND_DISCONNECT"] = -1] = "INBOUND_DISCONNECT";
|
|
18
19
|
GoodByeReasonCode[GoodByeReasonCode["CLIENT_SHUTDOWN"] = 1] = "CLIENT_SHUTDOWN";
|
|
19
20
|
GoodByeReasonCode[GoodByeReasonCode["IRRELEVANT_NETWORK"] = 2] = "IRRELEVANT_NETWORK";
|
|
20
21
|
GoodByeReasonCode[GoodByeReasonCode["ERROR"] = 3] = "ERROR";
|
|
@@ -23,6 +24,7 @@ export var GoodByeReasonCode;
|
|
|
23
24
|
GoodByeReasonCode[GoodByeReasonCode["BANNED"] = 251] = "BANNED";
|
|
24
25
|
})(GoodByeReasonCode || (GoodByeReasonCode = {}));
|
|
25
26
|
export const GOODBYE_KNOWN_CODES = {
|
|
27
|
+
"-1": "InboundDisconnect",
|
|
26
28
|
0: "Unknown",
|
|
27
29
|
// spec-defined codes
|
|
28
30
|
1: "Client shutdown",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"network.js","sourceRoot":"","sources":["../../src/constants/network.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,mBAAmB;AAEnB;;GAEG;AACH,MAAM,CAAC,MAAM,kCAAkC,GAAG,EAAE,CAAC;AAErD,gEAAgE;AAChE,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,IAAI,EAAE,CAAC;AACvC,MAAM,CAAC,MAAM,yBAAyB,GAAG,EAAE,GAAG,eAAe,CAAC;AAC9D,2EAA2E;AAC3E,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,IAAI,EAAE,CAAC;AACtC,MAAM,CAAC,MAAM,wBAAwB,GAAG,EAAE,GAAG,cAAc,CAAC;AAE5D,MAAM,CAAN,IAAY,
|
|
1
|
+
{"version":3,"file":"network.js","sourceRoot":"","sources":["../../src/constants/network.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,mBAAmB;AAEnB;;GAEG;AACH,MAAM,CAAC,MAAM,kCAAkC,GAAG,EAAE,CAAC;AAErD,gEAAgE;AAChE,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,IAAI,EAAE,CAAC;AACvC,MAAM,CAAC,MAAM,yBAAyB,GAAG,EAAE,GAAG,eAAe,CAAC;AAC9D,2EAA2E;AAC3E,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,IAAI,EAAE,CAAC;AACtC,MAAM,CAAC,MAAM,wBAAwB,GAAG,EAAE,GAAG,cAAc,CAAC;AAE5D,MAAM,CAAN,IAAY,iBAQX;AARD,WAAY,iBAAiB;IAC3B,sFAAuB,CAAA;IACvB,+EAAmB,CAAA;IACnB,qFAAsB,CAAA;IACtB,2DAAS,CAAA;IACT,+EAAoB,CAAA;IACpB,6EAAmB,CAAA;IACnB,+DAAY,CAAA;AACd,CAAC,EARW,iBAAiB,KAAjB,iBAAiB,QAQ5B;AAED,MAAM,CAAC,MAAM,mBAAmB,GAA2B;IACzD,IAAI,EAAE,mBAAmB;IACzB,CAAC,EAAE,SAAS;IAEZ,qBAAqB;IACrB,CAAC,EAAE,iBAAiB;IACpB,CAAC,EAAE,oBAAoB;IACvB,CAAC,EAAE,sBAAsB;IAEzB,qBAAqB;IACrB,GAAG,EAAE,0BAA0B;IAE/B,2BAA2B;IAC3B,GAAG,EAAE,2BAA2B;IAChC,GAAG,EAAE,oBAAoB;IACzB,GAAG,EAAE,uBAAuB;CAC7B,CAAC;AAEF,qDAAqD;AACrD,MAAM,CAAN,IAAY,WAGX;AAHD,WAAY,WAAW;IACrB,iDAAkC,CAAA;IAClC,mDAAoC,CAAA;AACtC,CAAC,EAHW,WAAW,KAAX,WAAW,QAGtB"}
|
package/lib/db/beacon.d.ts
CHANGED
|
@@ -2,7 +2,7 @@ import { ChainForkConfig } from "@lodestar/config";
|
|
|
2
2
|
import { Db, LevelDbControllerMetrics } from "@lodestar/db";
|
|
3
3
|
import { IBeaconDb } from "./interface.js";
|
|
4
4
|
import { CheckpointStateRepository } from "./repositories/checkpointState.js";
|
|
5
|
-
import { AttesterSlashingRepository, BLSToExecutionChangeRepository, BackfilledRanges, BestLightClientUpdateRepository, BlobSidecarsArchiveRepository, BlobSidecarsRepository, BlockArchiveRepository, BlockRepository, CheckpointHeaderRepository,
|
|
5
|
+
import { AttesterSlashingRepository, BLSToExecutionChangeRepository, BackfilledRanges, BestLightClientUpdateRepository, BlobSidecarsArchiveRepository, BlobSidecarsRepository, BlockArchiveRepository, BlockRepository, CheckpointHeaderRepository, DepositDataRootRepository, DepositEventRepository, Eth1DataRepository, ProposerSlashingRepository, StateArchiveRepository, SyncCommitteeRepository, SyncCommitteeWitnessRepository, VoluntaryExitRepository } from "./repositories/index.js";
|
|
6
6
|
import { PreGenesisState, PreGenesisStateLastProcessedBlock } from "./single/index.js";
|
|
7
7
|
export type BeaconDbModules = {
|
|
8
8
|
config: ChainForkConfig;
|
|
@@ -14,8 +14,6 @@ export declare class BeaconDb implements IBeaconDb {
|
|
|
14
14
|
blockArchive: BlockArchiveRepository;
|
|
15
15
|
blobSidecars: BlobSidecarsRepository;
|
|
16
16
|
blobSidecarsArchive: BlobSidecarsArchiveRepository;
|
|
17
|
-
dataColumnSidecars: DataColumnSidecarsRepository;
|
|
18
|
-
dataColumnSidecarsArchive: DataColumnSidecarsArchiveRepository;
|
|
19
17
|
stateArchive: StateArchiveRepository;
|
|
20
18
|
checkpointState: CheckpointStateRepository;
|
|
21
19
|
voluntaryExit: VoluntaryExitRepository;
|
package/lib/db/beacon.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { CheckpointStateRepository } from "./repositories/checkpointState.js";
|
|
2
|
-
import { AttesterSlashingRepository, BLSToExecutionChangeRepository, BackfilledRanges, BestLightClientUpdateRepository, BlobSidecarsArchiveRepository, BlobSidecarsRepository, BlockArchiveRepository, BlockRepository, CheckpointHeaderRepository,
|
|
2
|
+
import { AttesterSlashingRepository, BLSToExecutionChangeRepository, BackfilledRanges, BestLightClientUpdateRepository, BlobSidecarsArchiveRepository, BlobSidecarsRepository, BlockArchiveRepository, BlockRepository, CheckpointHeaderRepository, DepositDataRootRepository, DepositEventRepository, Eth1DataRepository, ProposerSlashingRepository, StateArchiveRepository, SyncCommitteeRepository, SyncCommitteeWitnessRepository, VoluntaryExitRepository, } from "./repositories/index.js";
|
|
3
3
|
import { PreGenesisState, PreGenesisStateLastProcessedBlock } from "./single/index.js";
|
|
4
4
|
export class BeaconDb {
|
|
5
5
|
constructor(config, db) {
|
|
@@ -9,8 +9,6 @@ export class BeaconDb {
|
|
|
9
9
|
this.blockArchive = new BlockArchiveRepository(config, db);
|
|
10
10
|
this.blobSidecars = new BlobSidecarsRepository(config, db);
|
|
11
11
|
this.blobSidecarsArchive = new BlobSidecarsArchiveRepository(config, db);
|
|
12
|
-
this.dataColumnSidecars = new DataColumnSidecarsRepository(config, db);
|
|
13
|
-
this.dataColumnSidecarsArchive = new DataColumnSidecarsArchiveRepository(config, db);
|
|
14
12
|
this.stateArchive = new StateArchiveRepository(config, db);
|
|
15
13
|
this.checkpointState = new CheckpointStateRepository(config, db);
|
|
16
14
|
this.voluntaryExit = new VoluntaryExitRepository(config, db);
|
package/lib/db/beacon.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"beacon.js","sourceRoot":"","sources":["../../src/db/beacon.ts"],"names":[],"mappings":"AAGA,OAAO,EAAC,yBAAyB,EAAC,MAAM,mCAAmC,CAAC;AAC5E,OAAO,EACL,0BAA0B,EAC1B,8BAA8B,EAC9B,gBAAgB,EAChB,+BAA+B,EAC/B,6BAA6B,EAC7B,sBAAsB,EACtB,sBAAsB,EACtB,eAAe,EACf,0BAA0B,EAC1B,
|
|
1
|
+
{"version":3,"file":"beacon.js","sourceRoot":"","sources":["../../src/db/beacon.ts"],"names":[],"mappings":"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"}
|
package/lib/db/buckets.d.ts
CHANGED
|
@@ -24,9 +24,7 @@ export declare enum Bucket {
|
|
|
24
24
|
lightClient_syncCommitteeWitness = 51,// BlockRoot -> SyncCommitteeWitness
|
|
25
25
|
lightClient_syncCommittee = 52,// Root(altair.SyncCommittee) -> altair.SyncCommittee
|
|
26
26
|
lightClient_checkpointHeader = 53,// BlockRoot -> phase0.BeaconBlockHeader
|
|
27
|
-
lightClient_bestLightClientUpdate = 56
|
|
28
|
-
allForks_dataColumnSidecars = 57,// FULU BeaconBlockRoot -> DataColumnSidecars
|
|
29
|
-
allForks_dataColumnSidecarsArchive = 58
|
|
27
|
+
lightClient_bestLightClientUpdate = 56
|
|
30
28
|
}
|
|
31
29
|
export declare function getBucketNameByValue<T extends Bucket>(enumValue: T): keyof typeof Bucket;
|
|
32
30
|
//# sourceMappingURL=buckets.d.ts.map
|
package/lib/db/buckets.js
CHANGED
|
@@ -54,8 +54,6 @@ export var Bucket;
|
|
|
54
54
|
// 54 was for bestPartialLightClientUpdate, allocate a fresh one
|
|
55
55
|
// lightClient_bestLightClientUpdate = 55, // SyncPeriod -> LightClientUpdate // DEPRECATED on v1.5.0
|
|
56
56
|
Bucket[Bucket["lightClient_bestLightClientUpdate"] = 56] = "lightClient_bestLightClientUpdate";
|
|
57
|
-
Bucket[Bucket["allForks_dataColumnSidecars"] = 57] = "allForks_dataColumnSidecars";
|
|
58
|
-
Bucket[Bucket["allForks_dataColumnSidecarsArchive"] = 58] = "allForks_dataColumnSidecarsArchive";
|
|
59
57
|
})(Bucket || (Bucket = {}));
|
|
60
58
|
export function getBucketNameByValue(enumValue) {
|
|
61
59
|
const keys = Object.keys(Bucket).filter((x) => {
|
package/lib/db/buckets.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"buckets.js","sourceRoot":"","sources":["../../src/db/buckets.ts"],"names":[],"mappings":"AAAA,2CAA2C;AAC3C,MAAM,CAAN,IAAY,
|
|
1
|
+
{"version":3,"file":"buckets.js","sourceRoot":"","sources":["../../src/db/buckets.ts"],"names":[],"mappings":"AAAA,2CAA2C;AAC3C,MAAM,CAAN,IAAY,MA8DX;AA9DD,WAAY,MAAM;IAChB,eAAe;IACf,mBAAmB;IACnB,qEAAyB,CAAA;IACzB,qBAAqB;IACrB,uDAAkB,CAAA;IAClB,mBAAmB;IACnB,qEAAyB,CAAA;IACzB,qCAAqC;IACrC,6FAAqC,CAAA;IACrC,iFAA+B,CAAA;IAC/B,kBAAkB;IAClB,mDAAmD;IACnD,kBAAkB;IAClB,yDAAmB,CAAA;IACnB,8CAA8C;IAC9C,yDAAmB,CAAA;IACnB,kBAAkB;IAClB,yDAAmB,CAAA;IACnB,qEAAyB,CAAA;IAEzB,UAAU;IACV,oDAAoD;IACpD,oFAAoF;IACpF,gEAAuB,CAAA;IACvB,kDAAgB,CAAA;IAChB,0EAA4B,CAAA;IAC5B,8EAA8B,CAAA;IAC9B,oFAAiC,CAAA;IACjC,oBAAoB;IACpB,4EAA6B,CAAA;IAE7B,oFAAoF;IACpF,kEAAwB,CAAA;IAExB,kFAAgC,CAAA;IAEhC,sEAA0B,CAAA;IAC1B,oFAAiC,CAAA;IAEjC,wEAA2B,CAAA;IAC3B,4GAA6C,CAAA;IAE7C,qBAAqB;IACrB,qEAAqE;IACrE,8DAA8D;IAC9D,iEAAiE;IACjE,uEAAuE;IACvE,6DAA6D;IAC7D,sEAAsE;IACtE,4DAA4D;IAE5D,8DAAsB,CAAA;IAEtB,2CAA2C;IAC3C,4FAAqC,CAAA;IACrC,8EAA8B,CAAA;IAC9B,yCAAyC;IACzC,oFAAiC,CAAA;IACjC,gEAAgE;IAChE,qGAAqG;IACrG,8FAAsC,CAAA;AACxC,CAAC,EA9DW,MAAM,KAAN,MAAM,QA8DjB;AAED,MAAM,UAAU,oBAAoB,CAAmB,SAAY;IACjE,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE;QAC5C,IAAI,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;YAC9B,OAAO,MAAM,CAAC,CAAwB,CAAC,KAAK,SAAS,CAAC;QACxD,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC,CAA4B,CAAC;IAC9B,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACpB,OAAO,IAAI,CAAC,CAAC,CAAC,CAAC;IACjB,CAAC;IACD,MAAM,IAAI,KAAK,CAAC,2BAA2B,GAAG,SAAS,CAAC,CAAC;AAC3D,CAAC"}
|
package/lib/db/interface.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { LevelDbControllerMetrics } from "@lodestar/db";
|
|
2
2
|
import { CheckpointStateRepository } from "./repositories/checkpointState.js";
|
|
3
|
-
import { AttesterSlashingRepository, BLSToExecutionChangeRepository, BackfilledRanges, BestLightClientUpdateRepository, BlobSidecarsArchiveRepository, BlobSidecarsRepository, BlockArchiveRepository, BlockRepository, CheckpointHeaderRepository,
|
|
3
|
+
import { AttesterSlashingRepository, BLSToExecutionChangeRepository, BackfilledRanges, BestLightClientUpdateRepository, BlobSidecarsArchiveRepository, BlobSidecarsRepository, BlockArchiveRepository, BlockRepository, CheckpointHeaderRepository, DepositDataRootRepository, DepositEventRepository, Eth1DataRepository, ProposerSlashingRepository, StateArchiveRepository, SyncCommitteeRepository, SyncCommitteeWitnessRepository, VoluntaryExitRepository } from "./repositories/index.js";
|
|
4
4
|
import { PreGenesisState, PreGenesisStateLastProcessedBlock } from "./single/index.js";
|
|
5
5
|
/**
|
|
6
6
|
* The DB service manages the data layer of the beacon chain
|
|
@@ -12,8 +12,6 @@ export interface IBeaconDb {
|
|
|
12
12
|
blockArchive: BlockArchiveRepository;
|
|
13
13
|
blobSidecars: BlobSidecarsRepository;
|
|
14
14
|
blobSidecarsArchive: BlobSidecarsArchiveRepository;
|
|
15
|
-
dataColumnSidecars: DataColumnSidecarsRepository;
|
|
16
|
-
dataColumnSidecarsArchive: DataColumnSidecarsArchiveRepository;
|
|
17
15
|
stateArchive: StateArchiveRepository;
|
|
18
16
|
checkpointState: CheckpointStateRepository;
|
|
19
17
|
voluntaryExit: VoluntaryExitRepository;
|