@aztec/archiver 0.0.1-commit.96dac018d → 0.0.1-commit.993d240
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/README.md +19 -11
- package/dest/archiver.d.ts +36 -17
- package/dest/archiver.d.ts.map +1 -1
- package/dest/archiver.js +257 -75
- package/dest/config.d.ts +6 -3
- package/dest/config.d.ts.map +1 -1
- package/dest/config.js +23 -15
- package/dest/errors.d.ts +55 -9
- package/dest/errors.d.ts.map +1 -1
- package/dest/errors.js +81 -14
- package/dest/factory.d.ts +13 -9
- package/dest/factory.d.ts.map +1 -1
- package/dest/factory.js +47 -35
- package/dest/index.d.ts +11 -3
- package/dest/index.d.ts.map +1 -1
- package/dest/index.js +10 -2
- package/dest/l1/calldata_retriever.d.ts +2 -1
- package/dest/l1/calldata_retriever.d.ts.map +1 -1
- package/dest/l1/calldata_retriever.js +15 -5
- package/dest/l1/data_retrieval.d.ts +24 -12
- package/dest/l1/data_retrieval.d.ts.map +1 -1
- package/dest/l1/data_retrieval.js +36 -37
- package/dest/l1/trace_tx.d.ts +12 -66
- package/dest/l1/trace_tx.d.ts.map +1 -1
- package/dest/l1/validate_historical_logs.d.ts +23 -0
- package/dest/l1/validate_historical_logs.d.ts.map +1 -0
- package/dest/l1/validate_historical_logs.js +108 -0
- package/dest/modules/contract_data_source_adapter.d.ts +25 -0
- package/dest/modules/contract_data_source_adapter.d.ts.map +1 -0
- package/dest/modules/contract_data_source_adapter.js +40 -0
- package/dest/modules/data_source_base.d.ts +70 -46
- package/dest/modules/data_source_base.d.ts.map +1 -1
- package/dest/modules/data_source_base.js +270 -135
- package/dest/modules/data_store_updater.d.ts +42 -17
- package/dest/modules/data_store_updater.d.ts.map +1 -1
- package/dest/modules/data_store_updater.js +191 -122
- package/dest/modules/instrumentation.d.ts +7 -2
- package/dest/modules/instrumentation.d.ts.map +1 -1
- package/dest/modules/instrumentation.js +25 -7
- package/dest/modules/l1_synchronizer.d.ts +12 -6
- package/dest/modules/l1_synchronizer.d.ts.map +1 -1
- package/dest/modules/l1_synchronizer.js +432 -205
- package/dest/modules/validation.d.ts +4 -3
- package/dest/modules/validation.d.ts.map +1 -1
- package/dest/modules/validation.js +6 -6
- package/dest/store/block_store.d.ts +174 -70
- package/dest/store/block_store.d.ts.map +1 -1
- package/dest/store/block_store.js +696 -250
- package/dest/store/contract_class_store.d.ts +17 -4
- package/dest/store/contract_class_store.d.ts.map +1 -1
- package/dest/store/contract_class_store.js +24 -68
- package/dest/store/contract_instance_store.d.ts +28 -1
- package/dest/store/contract_instance_store.d.ts.map +1 -1
- package/dest/store/contract_instance_store.js +37 -2
- package/dest/store/data_stores.d.ts +68 -0
- package/dest/store/data_stores.d.ts.map +1 -0
- package/dest/store/data_stores.js +54 -0
- package/dest/store/function_names_cache.d.ts +17 -0
- package/dest/store/function_names_cache.d.ts.map +1 -0
- package/dest/store/function_names_cache.js +30 -0
- package/dest/store/l2_tips_cache.d.ts +13 -7
- package/dest/store/l2_tips_cache.d.ts.map +1 -1
- package/dest/store/l2_tips_cache.js +13 -76
- package/dest/store/log_store.d.ts +42 -37
- package/dest/store/log_store.d.ts.map +1 -1
- package/dest/store/log_store.js +262 -408
- package/dest/store/log_store_codec.d.ts +70 -0
- package/dest/store/log_store_codec.d.ts.map +1 -0
- package/dest/store/log_store_codec.js +101 -0
- package/dest/store/message_store.d.ts +11 -1
- package/dest/store/message_store.d.ts.map +1 -1
- package/dest/store/message_store.js +51 -9
- package/dest/test/fake_l1_state.d.ts +20 -1
- package/dest/test/fake_l1_state.d.ts.map +1 -1
- package/dest/test/fake_l1_state.js +114 -18
- package/dest/test/mock_l1_to_l2_message_source.d.ts +1 -1
- package/dest/test/mock_l1_to_l2_message_source.d.ts.map +1 -1
- package/dest/test/mock_l1_to_l2_message_source.js +2 -1
- package/dest/test/mock_l2_block_source.d.ts +52 -46
- package/dest/test/mock_l2_block_source.d.ts.map +1 -1
- package/dest/test/mock_l2_block_source.js +246 -170
- package/dest/test/mock_structs.d.ts +4 -1
- package/dest/test/mock_structs.d.ts.map +1 -1
- package/dest/test/mock_structs.js +13 -1
- package/dest/test/noop_l1_archiver.d.ts +12 -6
- package/dest/test/noop_l1_archiver.d.ts.map +1 -1
- package/dest/test/noop_l1_archiver.js +26 -9
- package/package.json +14 -14
- package/src/archiver.ts +313 -75
- package/src/config.ts +32 -12
- package/src/errors.ts +122 -21
- package/src/factory.ts +54 -29
- package/src/index.ts +18 -2
- package/src/l1/calldata_retriever.ts +16 -5
- package/src/l1/data_retrieval.ts +52 -53
- package/src/l1/validate_historical_logs.ts +140 -0
- package/src/modules/contract_data_source_adapter.ts +55 -0
- package/src/modules/data_source_base.ts +336 -171
- package/src/modules/data_store_updater.ts +224 -154
- package/src/modules/instrumentation.ts +28 -8
- package/src/modules/l1_synchronizer.ts +572 -248
- package/src/modules/validation.ts +10 -9
- package/src/store/block_store.ts +865 -290
- package/src/store/contract_class_store.ts +31 -103
- package/src/store/contract_instance_store.ts +51 -5
- package/src/store/data_stores.ts +104 -0
- package/src/store/function_names_cache.ts +37 -0
- package/src/store/l2_tips_cache.ts +16 -70
- package/src/store/log_store.ts +301 -559
- package/src/store/log_store_codec.ts +132 -0
- package/src/store/message_store.ts +60 -10
- package/src/structs/inbox_message.ts +1 -1
- package/src/test/fake_l1_state.ts +142 -29
- package/src/test/mock_l1_to_l2_message_source.ts +1 -0
- package/src/test/mock_l2_block_source.ts +309 -205
- package/src/test/mock_structs.ts +20 -6
- package/src/test/noop_l1_archiver.ts +39 -9
- package/dest/store/kv_archiver_store.d.ts +0 -354
- package/dest/store/kv_archiver_store.d.ts.map +0 -1
- package/dest/store/kv_archiver_store.js +0 -464
- package/src/store/kv_archiver_store.ts +0 -671
|
@@ -1,216 +1,351 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { BlockNumber } from '@aztec/foundation/branded-types';
|
|
3
|
-
import {
|
|
1
|
+
import { INITIAL_L2_BLOCK_NUM } from '@aztec/constants';
|
|
2
|
+
import { BlockNumber, CheckpointNumber, IndexWithinCheckpoint } from '@aztec/foundation/branded-types';
|
|
3
|
+
import { Body, L2Block } from '@aztec/stdlib/block';
|
|
4
4
|
import { Checkpoint, PublishedCheckpoint } from '@aztec/stdlib/checkpoint';
|
|
5
|
-
import { getSlotRangeForEpoch } from '@aztec/stdlib/epoch-helpers';
|
|
5
|
+
import { getEpochAtSlot, getEpochNumberAtTimestamp, getLastL1SlotTimestampForL2Slot, getProofSubmissionDeadlineEpoch, getSlotRangeForEpoch } from '@aztec/stdlib/epoch-helpers';
|
|
6
|
+
import { AppendOnlyTreeSnapshot } from '@aztec/stdlib/trees';
|
|
6
7
|
/**
|
|
7
|
-
* Abstract base class implementing ArchiverDataSource using a
|
|
8
|
-
* Provides implementations for all
|
|
9
|
-
*
|
|
8
|
+
* Abstract base class implementing ArchiverDataSource using a bundle of archiver substores.
|
|
9
|
+
* Provides implementations for all read-side methods and declares abstract methods for
|
|
10
|
+
* L1-dependent functionality that subclasses must implement.
|
|
10
11
|
*/ export class ArchiverDataSourceBase {
|
|
11
|
-
|
|
12
|
+
stores;
|
|
12
13
|
l1Constants;
|
|
13
|
-
|
|
14
|
-
|
|
14
|
+
/** The injected genesis block header. */ initialHeader;
|
|
15
|
+
/** Precomputed hash of the initial header, exposed via {@link getGenesisBlockHash}. */ initialBlockHash;
|
|
16
|
+
/** Archive root after block 0 was appended — read from L1 (`Rollup.getGenesisArchiveTreeRoot`). */ genesisArchiveRoot;
|
|
17
|
+
/** Memoized synthetic genesis block — callers rely on referential identity for caching. */ genesisBlock;
|
|
18
|
+
/** Memoized synthetic genesis block data — kept consistent with {@link genesisBlock}. */ genesisBlockData;
|
|
19
|
+
constructor(stores, l1Constants, initialHeader, initialBlockHash, genesisArchiveRoot){
|
|
20
|
+
this.stores = stores;
|
|
15
21
|
this.l1Constants = l1Constants;
|
|
22
|
+
this.initialHeader = initialHeader;
|
|
23
|
+
this.initialBlockHash = initialBlockHash;
|
|
24
|
+
this.genesisArchiveRoot = genesisArchiveRoot;
|
|
25
|
+
const genesisArchive = new AppendOnlyTreeSnapshot(genesisArchiveRoot, 1);
|
|
26
|
+
this.genesisBlock = new L2Block(genesisArchive, initialHeader, Body.empty(), CheckpointNumber.ZERO, IndexWithinCheckpoint(0));
|
|
27
|
+
this.genesisBlockData = {
|
|
28
|
+
header: initialHeader,
|
|
29
|
+
archive: genesisArchive,
|
|
30
|
+
blockHash: initialBlockHash,
|
|
31
|
+
checkpointNumber: CheckpointNumber.ZERO,
|
|
32
|
+
indexWithinCheckpoint: IndexWithinCheckpoint(0)
|
|
33
|
+
};
|
|
16
34
|
}
|
|
17
|
-
|
|
18
|
-
return this.
|
|
19
|
-
}
|
|
20
|
-
getSynchedCheckpointNumber() {
|
|
21
|
-
return this.store.getSynchedCheckpointNumber();
|
|
35
|
+
/** Returns the precomputed hash of the genesis block header. */ getGenesisBlockHash() {
|
|
36
|
+
return this.initialBlockHash;
|
|
22
37
|
}
|
|
23
|
-
|
|
24
|
-
return this.
|
|
38
|
+
/** Returns the synthetic genesis L2Block (memoized — same instance across calls). */ getGenesisBlock() {
|
|
39
|
+
return this.genesisBlock;
|
|
25
40
|
}
|
|
26
|
-
|
|
27
|
-
return this.
|
|
41
|
+
/** Returns genesis block data (memoized — same instance across calls). */ getGenesisBlockData() {
|
|
42
|
+
return this.genesisBlockData;
|
|
28
43
|
}
|
|
29
|
-
|
|
30
|
-
|
|
44
|
+
/**
|
|
45
|
+
* Type guard distinguishing the genesis sentinel from a {@link ResolvedBlockQuery}.
|
|
46
|
+
* `resolveBlockQuery` already rewrites every genesis-matching shape to the sentinel,
|
|
47
|
+
* so callers only need this single sync check.
|
|
48
|
+
*/ isGenesisBlockQuery(query) {
|
|
49
|
+
return 'genesis' in query;
|
|
31
50
|
}
|
|
32
|
-
async
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
return undefined;
|
|
51
|
+
async isPruneDueAtSlot(slot) {
|
|
52
|
+
if (!this.l1Constants) {
|
|
53
|
+
throw new Error('isPruneDueAtSlot requires l1Constants');
|
|
36
54
|
}
|
|
37
|
-
const
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
55
|
+
const tips = await this.getL2Tips();
|
|
56
|
+
const proven = tips.proven.checkpoint.number;
|
|
57
|
+
const pending = tips.checkpointed.checkpoint.number;
|
|
58
|
+
if (pending === proven) {
|
|
59
|
+
return false;
|
|
60
|
+
}
|
|
61
|
+
const oldestUnproven = await this.getCheckpointData({
|
|
62
|
+
number: CheckpointNumber(Number(proven) + 1)
|
|
63
|
+
});
|
|
64
|
+
if (!oldestUnproven) {
|
|
65
|
+
return false;
|
|
66
|
+
}
|
|
67
|
+
const slotTs = getLastL1SlotTimestampForL2Slot(slot, this.l1Constants);
|
|
68
|
+
const slotEpoch = getEpochNumberAtTimestamp(slotTs, this.l1Constants);
|
|
69
|
+
const oldestUnprovenEpoch = getEpochAtSlot(oldestUnproven.header.slotNumber, this.l1Constants);
|
|
70
|
+
const deadlineEpoch = getProofSubmissionDeadlineEpoch(oldestUnprovenEpoch, this.l1Constants);
|
|
71
|
+
return slotEpoch >= deadlineEpoch;
|
|
42
72
|
}
|
|
43
|
-
|
|
44
|
-
return this.
|
|
73
|
+
getCheckpointNumber() {
|
|
74
|
+
return this.stores.blocks.getLatestCheckpointNumber();
|
|
45
75
|
}
|
|
46
|
-
|
|
47
|
-
return this.
|
|
76
|
+
getProvenCheckpointNumber() {
|
|
77
|
+
return this.stores.blocks.getProvenCheckpointNumber();
|
|
48
78
|
}
|
|
49
|
-
async
|
|
50
|
-
if (
|
|
51
|
-
|
|
79
|
+
async getBlockNumber(query) {
|
|
80
|
+
if (!query) {
|
|
81
|
+
return this.stores.blocks.getLatestL2BlockNumber();
|
|
52
82
|
}
|
|
53
|
-
|
|
83
|
+
const resolved = await this.resolveBlockQuery(query);
|
|
84
|
+
if (resolved === undefined) {
|
|
54
85
|
return undefined;
|
|
55
86
|
}
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
87
|
+
if (this.isGenesisBlockQuery(resolved)) {
|
|
88
|
+
return BlockNumber.ZERO;
|
|
89
|
+
}
|
|
90
|
+
return this.stores.blocks.getBlockNumber(resolved);
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Resolves a {@link CheckpointQuery} to a concrete `CheckpointNumber`, or undefined when the
|
|
94
|
+
* query refers to a position that has no checkpoint yet (e.g. `{ slot }` not found).
|
|
95
|
+
*/ resolveCheckpointQuery(query) {
|
|
96
|
+
if ('number' in query) {
|
|
97
|
+
return Promise.resolve(query.number);
|
|
98
|
+
}
|
|
99
|
+
if ('slot' in query) {
|
|
100
|
+
return this.stores.blocks.getCheckpointNumberBySlot(query.slot);
|
|
101
|
+
}
|
|
102
|
+
// tag variant
|
|
103
|
+
switch(query.tag){
|
|
104
|
+
case 'checkpointed':
|
|
105
|
+
return this.stores.blocks.getLatestCheckpointNumber();
|
|
106
|
+
case 'proven':
|
|
107
|
+
return this.stores.blocks.getProvenCheckpointNumber();
|
|
108
|
+
case 'finalized':
|
|
109
|
+
return this.stores.blocks.getFinalizedCheckpointNumber();
|
|
59
110
|
}
|
|
60
|
-
return checkpoint.header;
|
|
61
111
|
}
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
112
|
+
/**
|
|
113
|
+
* Resolves a {@link CheckpointsQuery} to a concrete `{from, limit}` pair used by BlockStore,
|
|
114
|
+
* or undefined when the epoch has no checkpoints.
|
|
115
|
+
*/ async resolveCheckpointsQuery(query) {
|
|
116
|
+
if ('from' in query) {
|
|
117
|
+
return query;
|
|
118
|
+
}
|
|
119
|
+
const numbers = await this.getCheckpointNumbersForEpoch(query.epoch);
|
|
120
|
+
if (numbers.length === 0) {
|
|
65
121
|
return undefined;
|
|
66
122
|
}
|
|
67
|
-
return
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
123
|
+
return {
|
|
124
|
+
from: numbers[0],
|
|
125
|
+
limit: numbers.length
|
|
126
|
+
};
|
|
71
127
|
}
|
|
72
|
-
|
|
73
|
-
|
|
128
|
+
async getCheckpoint(query) {
|
|
129
|
+
const number = await this.resolveCheckpointQuery(query);
|
|
130
|
+
if (number === undefined || number === 0) {
|
|
131
|
+
return undefined;
|
|
132
|
+
}
|
|
133
|
+
const data = await this.stores.blocks.getCheckpointData(number);
|
|
134
|
+
if (!data) {
|
|
135
|
+
return undefined;
|
|
136
|
+
}
|
|
137
|
+
return this.getPublishedCheckpointFromCheckpointData(data);
|
|
74
138
|
}
|
|
75
|
-
|
|
76
|
-
|
|
139
|
+
async getCheckpoints(query) {
|
|
140
|
+
const resolved = await this.resolveCheckpointsQuery(query);
|
|
141
|
+
if (!resolved) {
|
|
142
|
+
return [];
|
|
143
|
+
}
|
|
144
|
+
const checkpoints = await this.stores.blocks.getRangeOfCheckpoints(resolved.from, resolved.limit);
|
|
145
|
+
return Promise.all(checkpoints.map((ch)=>this.getPublishedCheckpointFromCheckpointData(ch)));
|
|
77
146
|
}
|
|
78
|
-
|
|
79
|
-
|
|
147
|
+
async getCheckpointData(query) {
|
|
148
|
+
const number = await this.resolveCheckpointQuery(query);
|
|
149
|
+
if (number === undefined || number === 0) {
|
|
150
|
+
return undefined;
|
|
151
|
+
}
|
|
152
|
+
return this.stores.blocks.getCheckpointData(number);
|
|
80
153
|
}
|
|
81
|
-
|
|
82
|
-
|
|
154
|
+
async getCheckpointsData(query) {
|
|
155
|
+
const resolved = await this.resolveCheckpointsQuery(query);
|
|
156
|
+
if (!resolved) {
|
|
157
|
+
return [];
|
|
158
|
+
}
|
|
159
|
+
return this.stores.blocks.getRangeOfCheckpoints(resolved.from, resolved.limit);
|
|
83
160
|
}
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
number = await this.store.getLatestBlockNumber();
|
|
161
|
+
getProposedCheckpointData(query) {
|
|
162
|
+
if (!query || 'tag' in query) {
|
|
163
|
+
return this.stores.blocks.getLastProposedCheckpoint();
|
|
88
164
|
}
|
|
89
|
-
if (number
|
|
90
|
-
return
|
|
165
|
+
if ('number' in query) {
|
|
166
|
+
return this.stores.blocks.getProposedCheckpointByNumber(query.number);
|
|
91
167
|
}
|
|
92
|
-
|
|
93
|
-
return publishedBlock;
|
|
168
|
+
return this.stores.blocks.getProposedCheckpointBySlot(query.slot);
|
|
94
169
|
}
|
|
95
170
|
getTxEffect(txHash) {
|
|
96
|
-
return this.
|
|
171
|
+
return this.stores.blocks.getTxEffect(txHash);
|
|
97
172
|
}
|
|
98
173
|
getSettledTxReceipt(txHash) {
|
|
99
|
-
return this.
|
|
174
|
+
return this.stores.blocks.getSettledTxReceipt(txHash, this.l1Constants);
|
|
100
175
|
}
|
|
101
176
|
isPendingChainInvalid() {
|
|
102
177
|
return this.getPendingChainValidationStatus().then((status)=>!status.valid);
|
|
103
178
|
}
|
|
104
179
|
async getPendingChainValidationStatus() {
|
|
105
|
-
return await this.
|
|
180
|
+
return await this.stores.blocks.getPendingChainValidationStatus() ?? {
|
|
106
181
|
valid: true
|
|
107
182
|
};
|
|
108
183
|
}
|
|
109
|
-
getPrivateLogsByTags(
|
|
110
|
-
return this.
|
|
184
|
+
getPrivateLogsByTags(query) {
|
|
185
|
+
return this.stores.logs.getPrivateLogsByTags(query);
|
|
111
186
|
}
|
|
112
|
-
|
|
113
|
-
return this.
|
|
114
|
-
}
|
|
115
|
-
getPublicLogs(filter) {
|
|
116
|
-
return this.store.getPublicLogs(filter);
|
|
117
|
-
}
|
|
118
|
-
getContractClassLogs(filter) {
|
|
119
|
-
return this.store.getContractClassLogs(filter);
|
|
187
|
+
getPublicLogsByTags(query) {
|
|
188
|
+
return this.stores.logs.getPublicLogsByTags(query);
|
|
120
189
|
}
|
|
121
190
|
getContractClass(id) {
|
|
122
|
-
return this.
|
|
191
|
+
return this.stores.contractClasses.getContractClass(id);
|
|
123
192
|
}
|
|
124
193
|
getBytecodeCommitment(id) {
|
|
125
|
-
return this.
|
|
194
|
+
return this.stores.contractClasses.getBytecodeCommitment(id);
|
|
126
195
|
}
|
|
127
196
|
async getContract(address, maybeTimestamp) {
|
|
128
197
|
let timestamp;
|
|
129
198
|
if (maybeTimestamp === undefined) {
|
|
130
|
-
const
|
|
131
|
-
|
|
132
|
-
|
|
199
|
+
const latestBlockData = await this.getBlockData({
|
|
200
|
+
tag: 'proposed'
|
|
201
|
+
});
|
|
202
|
+
timestamp = latestBlockData ? latestBlockData.header.globalVariables.timestamp : 0n;
|
|
133
203
|
} else {
|
|
134
204
|
timestamp = maybeTimestamp;
|
|
135
205
|
}
|
|
136
|
-
return this.
|
|
206
|
+
return this.stores.contractInstances.getContractInstance(address, timestamp);
|
|
137
207
|
}
|
|
138
208
|
getContractClassIds() {
|
|
139
|
-
return this.
|
|
209
|
+
return this.stores.contractClasses.getContractClassIds();
|
|
140
210
|
}
|
|
141
|
-
getDebugFunctionName(
|
|
142
|
-
return this.
|
|
211
|
+
/** Looks up a public function name given a selector. */ getDebugFunctionName(_address, selector) {
|
|
212
|
+
return Promise.resolve(this.stores.functionNames.get(selector));
|
|
143
213
|
}
|
|
144
|
-
registerContractFunctionSignatures(signatures) {
|
|
145
|
-
return this.
|
|
214
|
+
/** Register public function signatures so they can be looked up by selector. */ registerContractFunctionSignatures(signatures) {
|
|
215
|
+
return this.stores.functionNames.register(signatures);
|
|
146
216
|
}
|
|
147
217
|
getL1ToL2Messages(checkpointNumber) {
|
|
148
|
-
return this.
|
|
218
|
+
return this.stores.messages.getL1ToL2Messages(checkpointNumber);
|
|
149
219
|
}
|
|
150
220
|
getL1ToL2MessageIndex(l1ToL2Message) {
|
|
151
|
-
return this.
|
|
152
|
-
}
|
|
153
|
-
async getCheckpoints(checkpointNumber, limit) {
|
|
154
|
-
const checkpoints = await this.store.getRangeOfCheckpoints(checkpointNumber, limit);
|
|
155
|
-
return Promise.all(checkpoints.map((ch)=>this.getPublishedCheckpointFromCheckpointData(ch)));
|
|
221
|
+
return this.stores.messages.getL1ToL2MessageIndex(l1ToL2Message);
|
|
156
222
|
}
|
|
157
223
|
async getPublishedCheckpointFromCheckpointData(checkpoint) {
|
|
158
|
-
const blocksForCheckpoint = await this.
|
|
224
|
+
const blocksForCheckpoint = await this.stores.blocks.getBlocksForCheckpoint(checkpoint.checkpointNumber);
|
|
159
225
|
if (!blocksForCheckpoint) {
|
|
160
226
|
throw new Error(`Blocks for checkpoint ${checkpoint.checkpointNumber} not found`);
|
|
161
227
|
}
|
|
162
|
-
const fullCheckpoint = new Checkpoint(checkpoint.archive, checkpoint.header, blocksForCheckpoint, checkpoint.checkpointNumber);
|
|
228
|
+
const fullCheckpoint = new Checkpoint(checkpoint.archive, checkpoint.header, blocksForCheckpoint, checkpoint.checkpointNumber, checkpoint.feeAssetPriceModifier);
|
|
163
229
|
return new PublishedCheckpoint(fullCheckpoint, checkpoint.l1, checkpoint.attestations);
|
|
164
230
|
}
|
|
165
231
|
getBlocksForSlot(slotNumber) {
|
|
166
|
-
return this.
|
|
167
|
-
}
|
|
168
|
-
async getCheckpointedBlocksForEpoch(epochNumber) {
|
|
169
|
-
const checkpointsData = await this.getCheckpointsDataForEpoch(epochNumber);
|
|
170
|
-
const blocks = await Promise.all(checkpointsData.flatMap((checkpoint)=>range(checkpoint.blockCount, checkpoint.startBlock).map((blockNumber)=>this.getCheckpointedBlock(BlockNumber(blockNumber)))));
|
|
171
|
-
return blocks.filter(isDefined);
|
|
172
|
-
}
|
|
173
|
-
async getCheckpointedBlockHeadersForEpoch(epochNumber) {
|
|
174
|
-
const checkpointsData = await this.getCheckpointsDataForEpoch(epochNumber);
|
|
175
|
-
const blocks = await Promise.all(checkpointsData.flatMap((checkpoint)=>range(checkpoint.blockCount, checkpoint.startBlock).map((blockNumber)=>this.getBlockHeader(BlockNumber(blockNumber)))));
|
|
176
|
-
return blocks.filter(isDefined);
|
|
177
|
-
}
|
|
178
|
-
async getCheckpointsForEpoch(epochNumber) {
|
|
179
|
-
const checkpointsData = await this.getCheckpointsDataForEpoch(epochNumber);
|
|
180
|
-
return Promise.all(checkpointsData.map((data)=>this.getPublishedCheckpointFromCheckpointData(data).then((p)=>p.checkpoint)));
|
|
232
|
+
return this.stores.blocks.getBlocksForSlot(slotNumber);
|
|
181
233
|
}
|
|
182
|
-
/** Returns checkpoint
|
|
234
|
+
/** Returns just the checkpoint numbers for all checkpoints whose slot falls within the given epoch. */ getCheckpointNumbersForEpoch(epochNumber) {
|
|
183
235
|
if (!this.l1Constants) {
|
|
184
236
|
throw new Error('L1 constants not set');
|
|
185
237
|
}
|
|
186
238
|
const [start, end] = getSlotRangeForEpoch(epochNumber, this.l1Constants);
|
|
187
|
-
return this.
|
|
239
|
+
return this.stores.blocks.getCheckpointNumbersForSlotRange(start, end);
|
|
188
240
|
}
|
|
189
|
-
async getBlock(
|
|
190
|
-
|
|
191
|
-
if (
|
|
192
|
-
|
|
241
|
+
async getBlock(query) {
|
|
242
|
+
const resolved = await this.resolveBlockQuery(query);
|
|
243
|
+
if (resolved === undefined) {
|
|
244
|
+
return undefined;
|
|
245
|
+
}
|
|
246
|
+
if (this.isGenesisBlockQuery(resolved)) {
|
|
247
|
+
return this.getGenesisBlock();
|
|
193
248
|
}
|
|
194
|
-
|
|
249
|
+
return this.stores.blocks.getBlock(resolved);
|
|
250
|
+
}
|
|
251
|
+
/**
|
|
252
|
+
* Range queries iterate physical blocks only; the genesis block is NOT prepended.
|
|
253
|
+
* `L2BlockStream` consumers (`world-state.handleL2Blocks`, etc.) emit `blocks-added` events for
|
|
254
|
+
* real blocks and would be surprised by a synthetic block 0. Use {@link getBlock} or
|
|
255
|
+
* {@link getBlockData} for genesis-aware single-block lookups.
|
|
256
|
+
*/ async getBlocks(query) {
|
|
257
|
+
const resolved = await this.resolveBlocksQuery(query);
|
|
258
|
+
return resolved ? this.stores.blocks.getBlocks(resolved) : [];
|
|
259
|
+
}
|
|
260
|
+
async getBlockData(query) {
|
|
261
|
+
const resolved = await this.resolveBlockQuery(query);
|
|
262
|
+
if (resolved === undefined) {
|
|
195
263
|
return undefined;
|
|
196
264
|
}
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
return this.
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
265
|
+
if (this.isGenesisBlockQuery(resolved)) {
|
|
266
|
+
return this.getGenesisBlockData();
|
|
267
|
+
}
|
|
268
|
+
return this.stores.blocks.getBlockData(resolved);
|
|
269
|
+
}
|
|
270
|
+
/** See {@link getBlocks} — range queries do not prepend the genesis block. */ async getBlocksData(query) {
|
|
271
|
+
const resolved = await this.resolveBlocksQuery(query);
|
|
272
|
+
return resolved ? this.stores.blocks.getBlocksData(resolved) : [];
|
|
273
|
+
}
|
|
274
|
+
/**
|
|
275
|
+
* Resolves a {@link BlockQuery} to either the genesis sentinel or a {@link ResolvedBlockQuery}
|
|
276
|
+
* understood by BlockStore. Detects every shape that points at block 0 — `{number:0}`,
|
|
277
|
+
* `{hash}` matching the initial header, `{archive}` matching the post-genesis archive root,
|
|
278
|
+
* and `{tag}` resolving to 0 — and rewrites them to the sentinel so callers branch once.
|
|
279
|
+
*/ async resolveBlockQuery(query) {
|
|
280
|
+
if ('number' in query) {
|
|
281
|
+
return query.number === BlockNumber.ZERO ? {
|
|
282
|
+
genesis: true
|
|
283
|
+
} : query;
|
|
284
|
+
}
|
|
285
|
+
if ('hash' in query) {
|
|
286
|
+
return query.hash.equals(this.initialBlockHash) ? {
|
|
287
|
+
genesis: true
|
|
288
|
+
} : query;
|
|
289
|
+
}
|
|
290
|
+
if ('archive' in query) {
|
|
291
|
+
return query.archive.equals(this.genesisArchiveRoot) ? {
|
|
292
|
+
genesis: true
|
|
293
|
+
} : query;
|
|
294
|
+
}
|
|
295
|
+
const number = await this.resolveBlockTag(query.tag);
|
|
296
|
+
if (number === BlockNumber.ZERO) {
|
|
297
|
+
return {
|
|
298
|
+
genesis: true
|
|
299
|
+
};
|
|
300
|
+
}
|
|
301
|
+
return {
|
|
302
|
+
number
|
|
303
|
+
};
|
|
207
304
|
}
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
305
|
+
/** Maps a {@link BlockTag} to the matching block number for the current chain state. */ resolveBlockTag(tag) {
|
|
306
|
+
switch(tag){
|
|
307
|
+
case 'latest':
|
|
308
|
+
case 'proposed':
|
|
309
|
+
return this.stores.blocks.getLatestL2BlockNumber();
|
|
310
|
+
case 'checkpointed':
|
|
311
|
+
return this.stores.blocks.getCheckpointedL2BlockNumber();
|
|
312
|
+
case 'proven':
|
|
313
|
+
return this.stores.blocks.getProvenBlockNumber();
|
|
314
|
+
case 'finalized':
|
|
315
|
+
return this.stores.blocks.getFinalizedL2BlockNumber();
|
|
316
|
+
}
|
|
211
317
|
}
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
318
|
+
/**
|
|
319
|
+
* Converts an epoch-based BlocksQuery to a from/limit query using l1Constants.
|
|
320
|
+
* Returns undefined when the epoch has no checkpoints, so callers can return [] without
|
|
321
|
+
* entering BlockStore. Reads only the two endpoint checkpoints rather than the whole epoch.
|
|
322
|
+
*/ async resolveBlocksQuery(query) {
|
|
323
|
+
if (!('epoch' in query)) {
|
|
324
|
+
if (query.from < INITIAL_L2_BLOCK_NUM) {
|
|
325
|
+
throw new Error(`getBlocks/getBlocksData: 'from' must be >= ${INITIAL_L2_BLOCK_NUM}, got ${query.from}. ` + `Use getBlock({number:0})/getBlockData({number:0}) for genesis-aware single-block lookups.`);
|
|
326
|
+
}
|
|
327
|
+
return query;
|
|
328
|
+
}
|
|
329
|
+
const checkpointNumbers = await this.getCheckpointNumbersForEpoch(query.epoch);
|
|
330
|
+
if (checkpointNumbers.length === 0) {
|
|
331
|
+
return undefined;
|
|
332
|
+
}
|
|
333
|
+
const firstNumber = checkpointNumbers[0];
|
|
334
|
+
const lastNumber = checkpointNumbers[checkpointNumbers.length - 1];
|
|
335
|
+
const first = await this.stores.blocks.getCheckpointData(firstNumber);
|
|
336
|
+
if (!first) {
|
|
337
|
+
return undefined;
|
|
338
|
+
}
|
|
339
|
+
const last = firstNumber === lastNumber ? first : await this.stores.blocks.getCheckpointData(lastNumber);
|
|
340
|
+
if (!last) {
|
|
341
|
+
return undefined;
|
|
342
|
+
}
|
|
343
|
+
const from = BlockNumber(first.startBlock);
|
|
344
|
+
const limit = last.startBlock + last.blockCount - first.startBlock;
|
|
345
|
+
return {
|
|
346
|
+
from,
|
|
347
|
+
limit,
|
|
348
|
+
onlyCheckpointed: true
|
|
349
|
+
};
|
|
215
350
|
}
|
|
216
351
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { BlockNumber, CheckpointNumber } from '@aztec/foundation/branded-types';
|
|
2
|
-
import type { L2Block, ValidateCheckpointResult } from '@aztec/stdlib/block';
|
|
3
|
-
import type
|
|
4
|
-
import type {
|
|
2
|
+
import type { CommitteeAttestation, L2Block, ValidateCheckpointResult } from '@aztec/stdlib/block';
|
|
3
|
+
import { type L1PublishedData, type ProposedCheckpointInput, type PublishedCheckpoint } from '@aztec/stdlib/checkpoint';
|
|
4
|
+
import type { ArchiverDataStores } from '../store/data_stores.js';
|
|
5
5
|
import type { L2TipsCache } from '../store/l2_tips_cache.js';
|
|
6
6
|
/** Result of adding checkpoints with information about any pruned blocks. */
|
|
7
7
|
type ReconcileCheckpointsResult = {
|
|
@@ -12,33 +12,42 @@ type ReconcileCheckpointsResult = {
|
|
|
12
12
|
};
|
|
13
13
|
/** Archiver helper module to handle updates to the data store. */
|
|
14
14
|
export declare class ArchiverDataStoreUpdater {
|
|
15
|
-
private
|
|
15
|
+
private stores;
|
|
16
16
|
private l2TipsCache?;
|
|
17
|
+
private opts;
|
|
17
18
|
private readonly log;
|
|
18
|
-
constructor(
|
|
19
|
+
constructor(stores: ArchiverDataStores, l2TipsCache?: L2TipsCache | undefined, opts?: {
|
|
20
|
+
rollupManaLimit?: number;
|
|
21
|
+
});
|
|
19
22
|
/**
|
|
20
|
-
* Adds proposed
|
|
21
|
-
*
|
|
22
|
-
* Extracts ContractClassPublished, ContractInstancePublished, ContractInstanceUpdated events
|
|
23
|
-
* and individually broadcasted functions from the block logs.
|
|
23
|
+
* Adds a proposed block to the store with contract class/instance extraction from logs.
|
|
24
|
+
* This is an uncheckpointed block that has been proposed by the sequencer but not yet included in a checkpoint on L1.
|
|
25
|
+
* Extracts ContractClassPublished, ContractInstancePublished, ContractInstanceUpdated events from the block logs.
|
|
24
26
|
*
|
|
25
|
-
* @param
|
|
27
|
+
* @param block - The proposed L2 block to add.
|
|
26
28
|
* @param pendingChainValidationStatus - Optional validation status to set.
|
|
27
29
|
* @returns True if the operation is successful.
|
|
28
30
|
*/
|
|
29
|
-
|
|
31
|
+
addProposedBlock(block: L2Block, pendingChainValidationStatus?: ValidateCheckpointResult): Promise<boolean>;
|
|
30
32
|
/**
|
|
31
33
|
* Reconciles local blocks with incoming checkpoints from L1.
|
|
32
34
|
* Adds new checkpoints to the store with contract class/instance extraction from logs.
|
|
33
35
|
* Prunes any local blocks that conflict with checkpoint data (by comparing archive roots).
|
|
34
|
-
* Extracts ContractClassPublished, ContractInstancePublished, ContractInstanceUpdated events
|
|
35
|
-
*
|
|
36
|
+
* Extracts ContractClassPublished, ContractInstancePublished, ContractInstanceUpdated events from the checkpoint block logs.
|
|
37
|
+
* If `promoteProposed` is supplied, the proposed-checkpoint promotion runs inside the same transaction
|
|
38
|
+
* as the added checkpoints so both updates are applied atomically.
|
|
36
39
|
*
|
|
37
|
-
* @param checkpoints - The published checkpoints to add.
|
|
40
|
+
* @param checkpoints - The published checkpoints to add (excluding any being promoted from proposed).
|
|
38
41
|
* @param pendingChainValidationStatus - Optional validation status to set.
|
|
42
|
+
* @param promoteProposed - Optional promotion of the current proposed checkpoint (fast path when blocks are already local).
|
|
39
43
|
* @returns Result with information about any pruned blocks.
|
|
40
44
|
*/
|
|
41
|
-
addCheckpoints(checkpoints: PublishedCheckpoint[], pendingChainValidationStatus?: ValidateCheckpointResult
|
|
45
|
+
addCheckpoints(checkpoints: PublishedCheckpoint[], pendingChainValidationStatus?: ValidateCheckpointResult, promoteProposed?: {
|
|
46
|
+
l1: L1PublishedData;
|
|
47
|
+
attestations: CommitteeAttestation[];
|
|
48
|
+
checkpoint: PublishedCheckpoint;
|
|
49
|
+
}, evictProposedFrom?: CheckpointNumber): Promise<ReconcileCheckpointsResult>;
|
|
50
|
+
addProposedCheckpoint(proposedCheckpoint: ProposedCheckpointInput): Promise<void>;
|
|
42
51
|
private pruneMismatchingLocalBlocks;
|
|
43
52
|
/**
|
|
44
53
|
* Removes all uncheckpointed blocks strictly after the specified block number and cleans up associated contract data.
|
|
@@ -50,6 +59,18 @@ export declare class ArchiverDataStoreUpdater {
|
|
|
50
59
|
* @throws Error if any block to be removed is checkpointed.
|
|
51
60
|
*/
|
|
52
61
|
removeUncheckpointedBlocksAfter(blockNumber: BlockNumber): Promise<L2Block[]>;
|
|
62
|
+
/**
|
|
63
|
+
* Removes all blocks without a proposed checkpoint strictly after the specified block number and cleans up associated contract data.
|
|
64
|
+
* This handles removal of provisionally added blocks along with their contract classes/instances.
|
|
65
|
+
* Verifies that each block being removed is not part of a stored checkpoint (proposed or not).
|
|
66
|
+
* This differs from `removeUncheckpointedBlocksAfter` in that it also checks proposed checkpoints.
|
|
67
|
+
*
|
|
68
|
+
* @param blockNumber - Remove all blocks with number greater than this.
|
|
69
|
+
* @returns The removed blocks.
|
|
70
|
+
* @throws Error if any block to be removed is checkpointed.
|
|
71
|
+
*/
|
|
72
|
+
removeBlocksWithoutProposedCheckpointAfter(blockNumber: BlockNumber): Promise<L2Block[]>;
|
|
73
|
+
private evictProposedCheckpointsForPrunedBlocks;
|
|
53
74
|
private removeBlocksAfter;
|
|
54
75
|
/**
|
|
55
76
|
* Removes all checkpoints after the given checkpoint number.
|
|
@@ -66,6 +87,11 @@ export declare class ArchiverDataStoreUpdater {
|
|
|
66
87
|
* @param checkpointNumber - The checkpoint number to set as proven.
|
|
67
88
|
*/
|
|
68
89
|
setProvenCheckpointNumber(checkpointNumber: CheckpointNumber): Promise<void>;
|
|
90
|
+
/**
|
|
91
|
+
* Updates the finalized checkpoint number and refreshes the L2 tips cache.
|
|
92
|
+
* @param checkpointNumber - The checkpoint number to set as finalized.
|
|
93
|
+
*/
|
|
94
|
+
setFinalizedCheckpointNumber(checkpointNumber: CheckpointNumber): Promise<void>;
|
|
69
95
|
/** Extracts and stores contract data from a single block. */
|
|
70
96
|
private addContractDataToDb;
|
|
71
97
|
/** Removes contract data associated with a block. */
|
|
@@ -74,7 +100,6 @@ export declare class ArchiverDataStoreUpdater {
|
|
|
74
100
|
private updatePublishedContractClasses;
|
|
75
101
|
private updateDeployedContractInstances;
|
|
76
102
|
private updateUpdatedContractInstances;
|
|
77
|
-
private storeBroadcastedIndividualFunctions;
|
|
78
103
|
}
|
|
79
104
|
export {};
|
|
80
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
105
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YV9zdG9yZV91cGRhdGVyLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbW9kdWxlcy9kYXRhX3N0b3JlX3VwZGF0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBUWhGLE9BQU8sS0FBSyxFQUFFLG9CQUFvQixFQUFFLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ25HLE9BQU8sRUFDTCxLQUFLLGVBQWUsRUFDcEIsS0FBSyx1QkFBdUIsRUFDNUIsS0FBSyxtQkFBbUIsRUFFekIsTUFBTSwwQkFBMEIsQ0FBQztBQVNsQyxPQUFPLEtBQUssRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ2xFLE9BQU8sS0FBSyxFQUFFLFdBQVcsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBUTdELDZFQUE2RTtBQUM3RSxLQUFLLDBCQUEwQixHQUFHO0lBQ2hDLG1FQUFtRTtJQUNuRSxZQUFZLEVBQUUsT0FBTyxFQUFFLEdBQUcsU0FBUyxDQUFDO0lBQ3BDLGlGQUFpRjtJQUNqRiw4QkFBOEIsRUFBRSxXQUFXLEdBQUcsU0FBUyxDQUFDO0NBQ3pELENBQUM7QUFFRixrRUFBa0U7QUFDbEUscUJBQWEsd0JBQXdCO0lBSWpDLE9BQU8sQ0FBQyxNQUFNO0lBQ2QsT0FBTyxDQUFDLFdBQVcsQ0FBQztJQUNwQixPQUFPLENBQUMsSUFBSTtJQUxkLE9BQU8sQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUEwQztJQUU5RCxZQUNVLE1BQU0sRUFBRSxrQkFBa0IsRUFDMUIsV0FBVyxDQUFDLHlCQUFhLEVBQ3pCLElBQUksR0FBRTtRQUFFLGVBQWUsQ0FBQyxFQUFFLE1BQU0sQ0FBQTtLQUFPLEVBQzdDO0lBRUo7Ozs7Ozs7O09BUUc7SUFDVSxnQkFBZ0IsQ0FDM0IsS0FBSyxFQUFFLE9BQU8sRUFDZCw0QkFBNEIsQ0FBQyxFQUFFLHdCQUF3QixHQUN0RCxPQUFPLENBQUMsT0FBTyxDQUFDLENBa0JsQjtJQUVEOzs7Ozs7Ozs7Ozs7T0FZRztJQUNVLGNBQWMsQ0FDekIsV0FBVyxFQUFFLG1CQUFtQixFQUFFLEVBQ2xDLDRCQUE0QixDQUFDLEVBQUUsd0JBQXdCLEVBQ3ZELGVBQWUsQ0FBQyxFQUFFO1FBQ2hCLEVBQUUsRUFBRSxlQUFlLENBQUM7UUFDcEIsWUFBWSxFQUFFLG9CQUFvQixFQUFFLENBQUM7UUFDckMsVUFBVSxFQUFFLG1CQUFtQixDQUFDO0tBQ2pDLEVBQ0QsaUJBQWlCLENBQUMsRUFBRSxnQkFBZ0IsR0FDbkMsT0FBTyxDQUFDLDBCQUEwQixDQUFDLENBOENyQztJQUVZLHFCQUFxQixDQUFDLGtCQUFrQixFQUFFLHVCQUF1QixpQkFNN0U7WUFnQmEsMkJBQTJCO0lBdUV6Qzs7Ozs7Ozs7T0FRRztJQUNVLCtCQUErQixDQUFDLFdBQVcsRUFBRSxXQUFXLEdBQUcsT0FBTyxDQUFDLE9BQU8sRUFBRSxDQUFDLENBaUJ6RjtJQUVEOzs7Ozs7Ozs7T0FTRztJQUNVLDBDQUEwQyxDQUFDLFdBQVcsRUFBRSxXQUFXLEdBQUcsT0FBTyxDQUFDLE9BQU8sRUFBRSxDQUFDLENBY3BHO1lBT2EsdUNBQXVDO1lBWXZDLGlCQUFpQjtJQWEvQjs7Ozs7Ozs7T0FRRztJQUNVLHNCQUFzQixDQUFDLGdCQUFnQixFQUFFLGdCQUFnQixHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FnQnhGO0lBRUQ7OztPQUdHO0lBQ1UseUJBQXlCLENBQUMsZ0JBQWdCLEVBQUUsZ0JBQWdCLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUt4RjtJQUVEOzs7T0FHRztJQUNVLDRCQUE0QixDQUFDLGdCQUFnQixFQUFFLGdCQUFnQixHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FLM0Y7SUFFRCw2REFBNkQ7SUFDN0QsT0FBTyxDQUFDLG1CQUFtQjtJQUkzQixxREFBcUQ7SUFDckQsT0FBTyxDQUFDLHdCQUF3QjtZQUtsQixzQkFBc0I7WUFpQnRCLDhCQUE4QjtZQStDOUIsK0JBQStCO1lBMEMvQiw4QkFBOEI7Q0FzQjdDIn0=
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"data_store_updater.d.ts","sourceRoot":"","sources":["../../src/modules/data_store_updater.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;
|
|
1
|
+
{"version":3,"file":"data_store_updater.d.ts","sourceRoot":"","sources":["../../src/modules/data_store_updater.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AAQhF,OAAO,KAAK,EAAE,oBAAoB,EAAE,OAAO,EAAE,wBAAwB,EAAE,MAAM,qBAAqB,CAAC;AACnG,OAAO,EACL,KAAK,eAAe,EACpB,KAAK,uBAAuB,EAC5B,KAAK,mBAAmB,EAEzB,MAAM,0BAA0B,CAAC;AASlC,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAClE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AAQ7D,6EAA6E;AAC7E,KAAK,0BAA0B,GAAG;IAChC,mEAAmE;IACnE,YAAY,EAAE,OAAO,EAAE,GAAG,SAAS,CAAC;IACpC,iFAAiF;IACjF,8BAA8B,EAAE,WAAW,GAAG,SAAS,CAAC;CACzD,CAAC;AAEF,kEAAkE;AAClE,qBAAa,wBAAwB;IAIjC,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,WAAW,CAAC;IACpB,OAAO,CAAC,IAAI;IALd,OAAO,CAAC,QAAQ,CAAC,GAAG,CAA0C;IAE9D,YACU,MAAM,EAAE,kBAAkB,EAC1B,WAAW,CAAC,yBAAa,EACzB,IAAI,GAAE;QAAE,eAAe,CAAC,EAAE,MAAM,CAAA;KAAO,EAC7C;IAEJ;;;;;;;;OAQG;IACU,gBAAgB,CAC3B,KAAK,EAAE,OAAO,EACd,4BAA4B,CAAC,EAAE,wBAAwB,GACtD,OAAO,CAAC,OAAO,CAAC,CAkBlB;IAED;;;;;;;;;;;;OAYG;IACU,cAAc,CACzB,WAAW,EAAE,mBAAmB,EAAE,EAClC,4BAA4B,CAAC,EAAE,wBAAwB,EACvD,eAAe,CAAC,EAAE;QAChB,EAAE,EAAE,eAAe,CAAC;QACpB,YAAY,EAAE,oBAAoB,EAAE,CAAC;QACrC,UAAU,EAAE,mBAAmB,CAAC;KACjC,EACD,iBAAiB,CAAC,EAAE,gBAAgB,GACnC,OAAO,CAAC,0BAA0B,CAAC,CA8CrC;IAEY,qBAAqB,CAAC,kBAAkB,EAAE,uBAAuB,iBAM7E;YAgBa,2BAA2B;IAuEzC;;;;;;;;OAQG;IACU,+BAA+B,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC,CAiBzF;IAED;;;;;;;;;OASG;IACU,0CAA0C,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC,CAcpG;YAOa,uCAAuC;YAYvC,iBAAiB;IAa/B;;;;;;;;OAQG;IACU,sBAAsB,CAAC,gBAAgB,EAAE,gBAAgB,GAAG,OAAO,CAAC,OAAO,CAAC,CAgBxF;IAED;;;OAGG;IACU,yBAAyB,CAAC,gBAAgB,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC,CAKxF;IAED;;;OAGG;IACU,4BAA4B,CAAC,gBAAgB,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC,CAK3F;IAED,6DAA6D;IAC7D,OAAO,CAAC,mBAAmB;IAI3B,qDAAqD;IACrD,OAAO,CAAC,wBAAwB;YAKlB,sBAAsB;YAiBtB,8BAA8B;YA+C9B,+BAA+B;YA0C/B,8BAA8B;CAsB7C"}
|