@aztec/archiver 0.0.0-test.1 → 0.0.1-commit.03f7ef2
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 +27 -6
- package/dest/archiver/archiver.d.ts +201 -94
- package/dest/archiver/archiver.d.ts.map +1 -1
- package/dest/archiver/archiver.js +1141 -396
- package/dest/archiver/archiver_store.d.ts +171 -83
- package/dest/archiver/archiver_store.d.ts.map +1 -1
- package/dest/archiver/archiver_store_test_suite.d.ts +1 -1
- package/dest/archiver/archiver_store_test_suite.d.ts.map +1 -1
- package/dest/archiver/archiver_store_test_suite.js +2389 -393
- package/dest/archiver/config.d.ts +7 -22
- package/dest/archiver/config.d.ts.map +1 -1
- package/dest/archiver/config.js +30 -14
- package/dest/archiver/errors.d.ts +33 -1
- package/dest/archiver/errors.d.ts.map +1 -1
- package/dest/archiver/errors.js +49 -0
- package/dest/archiver/index.d.ts +3 -4
- package/dest/archiver/index.d.ts.map +1 -1
- package/dest/archiver/index.js +1 -2
- package/dest/archiver/instrumentation.d.ts +14 -6
- package/dest/archiver/instrumentation.d.ts.map +1 -1
- package/dest/archiver/instrumentation.js +69 -17
- package/dest/archiver/kv_archiver_store/block_store.d.ts +91 -21
- package/dest/archiver/kv_archiver_store/block_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/block_store.js +476 -86
- package/dest/archiver/kv_archiver_store/contract_class_store.d.ts +4 -4
- package/dest/archiver/kv_archiver_store/contract_class_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/contract_class_store.js +13 -19
- package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts +12 -9
- package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/contract_instance_store.js +30 -16
- package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts +80 -75
- package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/kv_archiver_store.js +142 -83
- package/dest/archiver/kv_archiver_store/log_store.d.ts +12 -16
- package/dest/archiver/kv_archiver_store/log_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/log_store.js +153 -113
- package/dest/archiver/kv_archiver_store/message_store.d.ts +25 -18
- package/dest/archiver/kv_archiver_store/message_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/message_store.js +152 -49
- package/dest/archiver/l1/bin/retrieve-calldata.d.ts +3 -0
- package/dest/archiver/l1/bin/retrieve-calldata.d.ts.map +1 -0
- package/dest/archiver/l1/bin/retrieve-calldata.js +149 -0
- package/dest/archiver/l1/calldata_retriever.d.ts +112 -0
- package/dest/archiver/l1/calldata_retriever.d.ts.map +1 -0
- package/dest/archiver/l1/calldata_retriever.js +471 -0
- package/dest/archiver/l1/data_retrieval.d.ts +90 -0
- package/dest/archiver/l1/data_retrieval.d.ts.map +1 -0
- package/dest/archiver/l1/data_retrieval.js +331 -0
- package/dest/archiver/l1/debug_tx.d.ts +19 -0
- package/dest/archiver/l1/debug_tx.d.ts.map +1 -0
- package/dest/archiver/l1/debug_tx.js +73 -0
- package/dest/archiver/l1/spire_proposer.d.ts +70 -0
- package/dest/archiver/l1/spire_proposer.d.ts.map +1 -0
- package/dest/archiver/l1/spire_proposer.js +157 -0
- package/dest/archiver/l1/trace_tx.d.ts +97 -0
- package/dest/archiver/l1/trace_tx.d.ts.map +1 -0
- package/dest/archiver/l1/trace_tx.js +91 -0
- package/dest/archiver/l1/types.d.ts +12 -0
- package/dest/archiver/l1/types.d.ts.map +1 -0
- package/dest/archiver/l1/types.js +3 -0
- package/dest/archiver/l1/validate_trace.d.ts +29 -0
- package/dest/archiver/l1/validate_trace.d.ts.map +1 -0
- package/dest/archiver/l1/validate_trace.js +150 -0
- package/dest/archiver/structs/data_retrieval.d.ts +1 -1
- package/dest/archiver/structs/inbox_message.d.ts +15 -0
- package/dest/archiver/structs/inbox_message.d.ts.map +1 -0
- package/dest/archiver/structs/inbox_message.js +39 -0
- package/dest/archiver/structs/published.d.ts +2 -11
- package/dest/archiver/structs/published.d.ts.map +1 -1
- package/dest/archiver/structs/published.js +1 -1
- package/dest/archiver/validation.d.ts +17 -0
- package/dest/archiver/validation.d.ts.map +1 -0
- package/dest/archiver/validation.js +98 -0
- package/dest/factory.d.ts +9 -14
- package/dest/factory.d.ts.map +1 -1
- package/dest/factory.js +22 -52
- package/dest/index.d.ts +2 -2
- package/dest/index.d.ts.map +1 -1
- package/dest/index.js +1 -1
- package/dest/rpc/index.d.ts +2 -3
- package/dest/rpc/index.d.ts.map +1 -1
- package/dest/rpc/index.js +1 -4
- package/dest/test/index.d.ts +1 -1
- package/dest/test/mock_archiver.d.ts +16 -8
- package/dest/test/mock_archiver.d.ts.map +1 -1
- package/dest/test/mock_archiver.js +19 -14
- package/dest/test/mock_l1_to_l2_message_source.d.ts +9 -6
- package/dest/test/mock_l1_to_l2_message_source.d.ts.map +1 -1
- package/dest/test/mock_l1_to_l2_message_source.js +21 -7
- package/dest/test/mock_l2_block_source.d.ts +52 -13
- package/dest/test/mock_l2_block_source.d.ts.map +1 -1
- package/dest/test/mock_l2_block_source.js +140 -15
- package/dest/test/mock_structs.d.ts +10 -0
- package/dest/test/mock_structs.d.ts.map +1 -0
- package/dest/test/mock_structs.js +38 -0
- package/package.json +29 -30
- package/src/archiver/archiver.ts +1477 -501
- package/src/archiver/archiver_store.ts +197 -88
- package/src/archiver/archiver_store_test_suite.ts +2403 -350
- package/src/archiver/config.ts +38 -46
- package/src/archiver/errors.ts +85 -0
- package/src/archiver/index.ts +2 -3
- package/src/archiver/instrumentation.ts +91 -22
- package/src/archiver/kv_archiver_store/block_store.ts +640 -101
- package/src/archiver/kv_archiver_store/contract_class_store.ts +14 -24
- package/src/archiver/kv_archiver_store/contract_instance_store.ts +36 -28
- package/src/archiver/kv_archiver_store/kv_archiver_store.ts +193 -113
- package/src/archiver/kv_archiver_store/log_store.ts +205 -127
- package/src/archiver/kv_archiver_store/message_store.ts +213 -54
- package/src/archiver/l1/README.md +98 -0
- package/src/archiver/l1/bin/retrieve-calldata.ts +182 -0
- package/src/archiver/l1/calldata_retriever.ts +641 -0
- package/src/archiver/l1/data_retrieval.ts +512 -0
- package/src/archiver/l1/debug_tx.ts +99 -0
- package/src/archiver/l1/spire_proposer.ts +160 -0
- package/src/archiver/l1/trace_tx.ts +128 -0
- package/src/archiver/l1/types.ts +13 -0
- package/src/archiver/l1/validate_trace.ts +211 -0
- package/src/archiver/structs/inbox_message.ts +41 -0
- package/src/archiver/structs/published.ts +1 -11
- package/src/archiver/validation.ts +124 -0
- package/src/factory.ts +28 -69
- package/src/index.ts +1 -1
- package/src/rpc/index.ts +1 -5
- package/src/test/fixtures/debug_traceTransaction-multicall3.json +88 -0
- package/src/test/fixtures/debug_traceTransaction-multiplePropose.json +153 -0
- package/src/test/fixtures/debug_traceTransaction-proxied.json +122 -0
- package/src/test/fixtures/trace_transaction-multicall3.json +65 -0
- package/src/test/fixtures/trace_transaction-multiplePropose.json +319 -0
- package/src/test/fixtures/trace_transaction-proxied.json +128 -0
- package/src/test/fixtures/trace_transaction-randomRevert.json +216 -0
- package/src/test/mock_archiver.ts +22 -16
- package/src/test/mock_l1_to_l2_message_source.ts +20 -8
- package/src/test/mock_l2_block_source.ts +186 -21
- package/src/test/mock_structs.ts +50 -0
- package/dest/archiver/data_retrieval.d.ts +0 -74
- package/dest/archiver/data_retrieval.d.ts.map +0 -1
- package/dest/archiver/data_retrieval.js +0 -283
- package/dest/archiver/kv_archiver_store/nullifier_store.d.ts +0 -12
- package/dest/archiver/kv_archiver_store/nullifier_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/nullifier_store.js +0 -73
- package/dest/archiver/memory_archiver_store/l1_to_l2_message_store.d.ts +0 -23
- package/dest/archiver/memory_archiver_store/l1_to_l2_message_store.d.ts.map +0 -1
- package/dest/archiver/memory_archiver_store/l1_to_l2_message_store.js +0 -49
- package/dest/archiver/memory_archiver_store/memory_archiver_store.d.ts +0 -175
- package/dest/archiver/memory_archiver_store/memory_archiver_store.d.ts.map +0 -1
- package/dest/archiver/memory_archiver_store/memory_archiver_store.js +0 -636
- package/src/archiver/data_retrieval.ts +0 -422
- package/src/archiver/kv_archiver_store/nullifier_store.ts +0 -97
- package/src/archiver/memory_archiver_store/l1_to_l2_message_store.ts +0 -61
- package/src/archiver/memory_archiver_store/memory_archiver_store.ts +0 -801
|
@@ -1,20 +1,23 @@
|
|
|
1
1
|
import { toArray } from '@aztec/foundation/iterable';
|
|
2
2
|
import { createLogger } from '@aztec/foundation/log';
|
|
3
3
|
import { FunctionSelector } from '@aztec/stdlib/abi';
|
|
4
|
+
import { L2BlockHash } from '@aztec/stdlib/block';
|
|
5
|
+
import { join } from 'path';
|
|
4
6
|
import { BlockStore } from './block_store.js';
|
|
5
7
|
import { ContractClassStore } from './contract_class_store.js';
|
|
6
8
|
import { ContractInstanceStore } from './contract_instance_store.js';
|
|
7
9
|
import { LogStore } from './log_store.js';
|
|
8
10
|
import { MessageStore } from './message_store.js';
|
|
9
|
-
|
|
11
|
+
export const ARCHIVER_DB_VERSION = 5;
|
|
12
|
+
export const MAX_FUNCTION_SIGNATURES = 1000;
|
|
13
|
+
export const MAX_FUNCTION_NAME_LEN = 256;
|
|
10
14
|
/**
|
|
11
15
|
* LMDB implementation of the ArchiverDataStore interface.
|
|
12
16
|
*/ export class KVArchiverDataStore {
|
|
13
17
|
db;
|
|
14
|
-
static SCHEMA_VERSION =
|
|
18
|
+
static SCHEMA_VERSION = ARCHIVER_DB_VERSION;
|
|
15
19
|
#blockStore;
|
|
16
20
|
#logStore;
|
|
17
|
-
#nullifierStore;
|
|
18
21
|
#messageStore;
|
|
19
22
|
#contractClassStore;
|
|
20
23
|
#contractInstanceStore;
|
|
@@ -29,19 +32,36 @@ import { NullifierStore } from './nullifier_store.js';
|
|
|
29
32
|
this.#messageStore = new MessageStore(db);
|
|
30
33
|
this.#contractClassStore = new ContractClassStore(db);
|
|
31
34
|
this.#contractInstanceStore = new ContractInstanceStore(db);
|
|
32
|
-
this.#nullifierStore = new NullifierStore(db);
|
|
33
35
|
}
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
36
|
+
transactionAsync(callback) {
|
|
37
|
+
return this.db.transactionAsync(callback);
|
|
38
|
+
}
|
|
39
|
+
getBlockNumber() {
|
|
40
|
+
return this.#blockStore.getLatestL2BlockNumber();
|
|
41
|
+
}
|
|
42
|
+
async getContract(address, maybeTimestamp) {
|
|
43
|
+
const [header] = await this.getBlockHeaders(await this.getBlockNumber(), 1);
|
|
44
|
+
const timestamp = maybeTimestamp ?? header.globalVariables.timestamp;
|
|
45
|
+
return this.getContractInstance(address, timestamp);
|
|
46
|
+
}
|
|
47
|
+
async backupTo(path, compress = true) {
|
|
48
|
+
await this.db.backupTo(path, compress);
|
|
49
|
+
return join(path, 'data.mdb');
|
|
50
|
+
}
|
|
51
|
+
close() {
|
|
52
|
+
return this.db.close();
|
|
53
|
+
}
|
|
54
|
+
getDebugFunctionName(_address, selector) {
|
|
38
55
|
return Promise.resolve(this.functionNames.get(selector.toString()));
|
|
39
56
|
}
|
|
40
|
-
async registerContractFunctionSignatures(
|
|
57
|
+
async registerContractFunctionSignatures(signatures) {
|
|
41
58
|
for (const sig of signatures){
|
|
59
|
+
if (this.functionNames.size > MAX_FUNCTION_SIGNATURES) {
|
|
60
|
+
return;
|
|
61
|
+
}
|
|
42
62
|
try {
|
|
43
63
|
const selector = await FunctionSelector.fromSignature(sig);
|
|
44
|
-
this.functionNames.set(selector.toString(), sig.slice(0, sig.indexOf('(')));
|
|
64
|
+
this.functionNames.set(selector.toString(), sig.slice(0, sig.indexOf('(')).slice(0, MAX_FUNCTION_NAME_LEN));
|
|
45
65
|
} catch {
|
|
46
66
|
this.#log.warn(`Failed to parse signature: ${sig}. Ignoring`);
|
|
47
67
|
}
|
|
@@ -53,9 +73,11 @@ import { NullifierStore } from './nullifier_store.js';
|
|
|
53
73
|
getContractClassIds() {
|
|
54
74
|
return this.#contractClassStore.getContractClassIds();
|
|
55
75
|
}
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
76
|
+
getContractInstance(address, timestamp) {
|
|
77
|
+
return this.#contractInstanceStore.getContractInstance(address, timestamp);
|
|
78
|
+
}
|
|
79
|
+
getContractInstanceDeploymentBlockNumber(address) {
|
|
80
|
+
return this.#contractInstanceStore.getContractInstanceDeploymentBlockNumber(address);
|
|
59
81
|
}
|
|
60
82
|
async addContractClasses(data, bytecodeCommitments, blockNumber) {
|
|
61
83
|
return (await Promise.all(data.map((c, i)=>this.#contractClassStore.addContractClass(c, bytecodeCommitments[i], blockNumber)))).every(Boolean);
|
|
@@ -66,45 +88,66 @@ import { NullifierStore } from './nullifier_store.js';
|
|
|
66
88
|
getBytecodeCommitment(contractClassId) {
|
|
67
89
|
return this.#contractClassStore.getBytecodeCommitment(contractClassId);
|
|
68
90
|
}
|
|
69
|
-
addFunctions(contractClassId, privateFunctions,
|
|
70
|
-
return this.#contractClassStore.addFunctions(contractClassId, privateFunctions,
|
|
91
|
+
addFunctions(contractClassId, privateFunctions, utilityFunctions) {
|
|
92
|
+
return this.#contractClassStore.addFunctions(contractClassId, privateFunctions, utilityFunctions);
|
|
71
93
|
}
|
|
72
|
-
async addContractInstances(data,
|
|
73
|
-
return (await Promise.all(data.map((c)=>this.#contractInstanceStore.addContractInstance(c)))).every(Boolean);
|
|
94
|
+
async addContractInstances(data, blockNumber) {
|
|
95
|
+
return (await Promise.all(data.map((c)=>this.#contractInstanceStore.addContractInstance(c, blockNumber)))).every(Boolean);
|
|
74
96
|
}
|
|
75
97
|
async deleteContractInstances(data, _blockNumber) {
|
|
76
98
|
return (await Promise.all(data.map((c)=>this.#contractInstanceStore.deleteContractInstance(c)))).every(Boolean);
|
|
77
99
|
}
|
|
78
|
-
async addContractInstanceUpdates(data,
|
|
79
|
-
return (await Promise.all(data.map((update, logIndex)=>this.#contractInstanceStore.addContractInstanceUpdate(update,
|
|
100
|
+
async addContractInstanceUpdates(data, timestamp) {
|
|
101
|
+
return (await Promise.all(data.map((update, logIndex)=>this.#contractInstanceStore.addContractInstanceUpdate(update, timestamp, logIndex)))).every(Boolean);
|
|
80
102
|
}
|
|
81
|
-
async deleteContractInstanceUpdates(data,
|
|
82
|
-
return (await Promise.all(data.map((update, logIndex)=>this.#contractInstanceStore.deleteContractInstanceUpdate(update,
|
|
103
|
+
async deleteContractInstanceUpdates(data, timestamp) {
|
|
104
|
+
return (await Promise.all(data.map((update, logIndex)=>this.#contractInstanceStore.deleteContractInstanceUpdate(update, timestamp, logIndex)))).every(Boolean);
|
|
83
105
|
}
|
|
84
106
|
/**
|
|
85
107
|
* Append new blocks to the store's list.
|
|
86
108
|
* @param blocks - The L2 blocks to be added to the store and the last processed L1 block.
|
|
87
109
|
* @returns True if the operation is successful.
|
|
88
|
-
*/ addBlocks(blocks) {
|
|
89
|
-
return this.#blockStore.addBlocks(blocks);
|
|
110
|
+
*/ addBlocks(blocks, opts = {}) {
|
|
111
|
+
return this.#blockStore.addBlocks(blocks, opts);
|
|
112
|
+
}
|
|
113
|
+
getRangeOfCheckpoints(from, limit) {
|
|
114
|
+
return this.#blockStore.getRangeOfCheckpoints(from, limit);
|
|
115
|
+
}
|
|
116
|
+
getLatestBlockNumber() {
|
|
117
|
+
return this.#blockStore.getLatestBlockNumber();
|
|
90
118
|
}
|
|
91
119
|
/**
|
|
92
|
-
* Unwinds
|
|
120
|
+
* Unwinds checkpoints from the database
|
|
93
121
|
* @param from - The tip of the chain, passed for verification purposes,
|
|
94
122
|
* ensuring that we don't end up deleting something we did not intend
|
|
95
|
-
* @param
|
|
123
|
+
* @param checkpointsToUnwind - The number of checkpoints we are to unwind
|
|
96
124
|
* @returns True if the operation is successful
|
|
97
|
-
*/
|
|
98
|
-
return this.#blockStore.
|
|
125
|
+
*/ unwindCheckpoints(from, checkpointsToUnwind) {
|
|
126
|
+
return this.#blockStore.unwindCheckpoints(from, checkpointsToUnwind);
|
|
99
127
|
}
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
return
|
|
128
|
+
addCheckpoints(checkpoints) {
|
|
129
|
+
return this.#blockStore.addCheckpoints(checkpoints);
|
|
130
|
+
}
|
|
131
|
+
getCheckpointedBlock(number) {
|
|
132
|
+
return this.#blockStore.getCheckpointedBlock(number);
|
|
133
|
+
}
|
|
134
|
+
getCheckpointedBlockByHash(blockHash) {
|
|
135
|
+
return this.#blockStore.getCheckpointedBlockByHash(blockHash);
|
|
136
|
+
}
|
|
137
|
+
getCheckpointedBlockByArchive(archive) {
|
|
138
|
+
return this.#blockStore.getCheckpointedBlockByArchive(archive);
|
|
139
|
+
}
|
|
140
|
+
getBlock(number) {
|
|
141
|
+
return this.#blockStore.getBlock(number);
|
|
142
|
+
}
|
|
143
|
+
getBlockByHash(blockHash) {
|
|
144
|
+
return this.#blockStore.getBlockByHash(L2BlockHash.fromField(blockHash));
|
|
145
|
+
}
|
|
146
|
+
getBlockByArchive(archive) {
|
|
147
|
+
return this.#blockStore.getBlockByArchive(archive);
|
|
148
|
+
}
|
|
149
|
+
getBlocks(from, limit) {
|
|
150
|
+
return toArray(this.#blockStore.getBlocks(from, limit));
|
|
108
151
|
}
|
|
109
152
|
/**
|
|
110
153
|
* Gets up to `limit` amount of L2 blocks headers starting from `from`.
|
|
@@ -115,10 +158,16 @@ import { NullifierStore } from './nullifier_store.js';
|
|
|
115
158
|
*/ getBlockHeaders(start, limit) {
|
|
116
159
|
return toArray(this.#blockStore.getBlockHeaders(start, limit));
|
|
117
160
|
}
|
|
161
|
+
getBlockHeaderByHash(blockHash) {
|
|
162
|
+
return this.#blockStore.getBlockHeaderByHash(L2BlockHash.fromField(blockHash));
|
|
163
|
+
}
|
|
164
|
+
getBlockHeaderByArchive(archive) {
|
|
165
|
+
return this.#blockStore.getBlockHeaderByArchive(archive);
|
|
166
|
+
}
|
|
118
167
|
/**
|
|
119
168
|
* Gets a tx effect.
|
|
120
|
-
* @param txHash - The
|
|
121
|
-
* @returns The requested tx effect (or undefined if not found).
|
|
169
|
+
* @param txHash - The hash of the tx corresponding to the tx effect.
|
|
170
|
+
* @returns The requested tx effect with block info (or undefined if not found).
|
|
122
171
|
*/ getTxEffect(txHash) {
|
|
123
172
|
return this.#blockStore.getTxEffect(txHash);
|
|
124
173
|
}
|
|
@@ -139,26 +188,15 @@ import { NullifierStore } from './nullifier_store.js';
|
|
|
139
188
|
deleteLogs(blocks) {
|
|
140
189
|
return this.#logStore.deleteLogs(blocks);
|
|
141
190
|
}
|
|
142
|
-
/**
|
|
143
|
-
* Append new nullifiers to the store's list.
|
|
144
|
-
* @param blocks - The blocks for which to add the nullifiers.
|
|
145
|
-
* @returns True if the operation is successful.
|
|
146
|
-
*/ addNullifiers(blocks) {
|
|
147
|
-
return this.#nullifierStore.addNullifiers(blocks);
|
|
148
|
-
}
|
|
149
|
-
deleteNullifiers(blocks) {
|
|
150
|
-
return this.#nullifierStore.deleteNullifiers(blocks);
|
|
151
|
-
}
|
|
152
|
-
findNullifiersIndexesWithBlock(blockNumber, nullifiers) {
|
|
153
|
-
return this.#nullifierStore.findNullifiersIndexesWithBlock(blockNumber, nullifiers);
|
|
154
|
-
}
|
|
155
191
|
getTotalL1ToL2MessageCount() {
|
|
156
192
|
return this.#messageStore.getTotalL1ToL2MessageCount();
|
|
157
193
|
}
|
|
194
|
+
getLastL1ToL2Message() {
|
|
195
|
+
return this.#messageStore.getLastMessage();
|
|
196
|
+
}
|
|
158
197
|
/**
|
|
159
198
|
* Append L1 to L2 messages to the store.
|
|
160
|
-
* @param messages - The L1 to L2 messages to be added to the store
|
|
161
|
-
* @returns True if the operation is successful.
|
|
199
|
+
* @param messages - The L1 to L2 messages to be added to the store.
|
|
162
200
|
*/ addL1ToL2Messages(messages) {
|
|
163
201
|
return this.#messageStore.addL1ToL2Messages(messages);
|
|
164
202
|
}
|
|
@@ -170,28 +208,22 @@ import { NullifierStore } from './nullifier_store.js';
|
|
|
170
208
|
return this.#messageStore.getL1ToL2MessageIndex(l1ToL2Message);
|
|
171
209
|
}
|
|
172
210
|
/**
|
|
173
|
-
* Gets L1 to L2 message (to be) included in a given
|
|
174
|
-
* @param
|
|
211
|
+
* Gets L1 to L2 message (to be) included in a given checkpoint.
|
|
212
|
+
* @param checkpointNumber - Checkpoint number to get messages for.
|
|
175
213
|
* @returns The L1 to L2 messages/leaves of the messages subtree (throws if not found).
|
|
176
|
-
*/ getL1ToL2Messages(
|
|
177
|
-
return this.#messageStore.getL1ToL2Messages(
|
|
214
|
+
*/ getL1ToL2Messages(checkpointNumber) {
|
|
215
|
+
return this.#messageStore.getL1ToL2Messages(checkpointNumber);
|
|
178
216
|
}
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
return this.#logStore.getPrivateLogs(from, limit);
|
|
217
|
+
getPrivateLogsByTags(tags) {
|
|
218
|
+
try {
|
|
219
|
+
return this.#logStore.getPrivateLogsByTags(tags);
|
|
220
|
+
} catch (err) {
|
|
221
|
+
return Promise.reject(err);
|
|
222
|
+
}
|
|
186
223
|
}
|
|
187
|
-
|
|
188
|
-
* Gets all logs that match any of the received tags (i.e. logs with their first field equal to a tag).
|
|
189
|
-
* @param tags - The tags to filter the logs by.
|
|
190
|
-
* @returns For each received tag, an array of matching logs is returned. An empty array implies no logs match
|
|
191
|
-
* that tag.
|
|
192
|
-
*/ getLogsByTags(tags) {
|
|
224
|
+
getPublicLogsByTagsFromContract(contractAddress, tags) {
|
|
193
225
|
try {
|
|
194
|
-
return this.#logStore.
|
|
226
|
+
return this.#logStore.getPublicLogsByTagsFromContract(contractAddress, tags);
|
|
195
227
|
} catch (err) {
|
|
196
228
|
return Promise.reject(err);
|
|
197
229
|
}
|
|
@@ -218,30 +250,27 @@ import { NullifierStore } from './nullifier_store.js';
|
|
|
218
250
|
return Promise.reject(err);
|
|
219
251
|
}
|
|
220
252
|
}
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
* @returns The number of the latest L2 block processed.
|
|
224
|
-
*/ getSynchedL2BlockNumber() {
|
|
225
|
-
return this.#blockStore.getSynchedL2BlockNumber();
|
|
226
|
-
}
|
|
227
|
-
getProvenL2BlockNumber() {
|
|
228
|
-
return this.#blockStore.getProvenL2BlockNumber();
|
|
253
|
+
getProvenCheckpointNumber() {
|
|
254
|
+
return this.#blockStore.getProvenCheckpointNumber();
|
|
229
255
|
}
|
|
230
|
-
async
|
|
231
|
-
await this.#blockStore.
|
|
256
|
+
async setProvenCheckpointNumber(checkpointNumber) {
|
|
257
|
+
await this.#blockStore.setProvenCheckpointNumber(checkpointNumber);
|
|
232
258
|
}
|
|
233
259
|
async setBlockSynchedL1BlockNumber(l1BlockNumber) {
|
|
234
260
|
await this.#blockStore.setSynchedL1BlockNumber(l1BlockNumber);
|
|
235
261
|
}
|
|
236
|
-
async
|
|
237
|
-
await this.#messageStore.
|
|
262
|
+
async setMessageSynchedL1Block(l1Block) {
|
|
263
|
+
await this.#messageStore.setSynchedL1Block(l1Block);
|
|
264
|
+
}
|
|
265
|
+
getProvenBlockNumber() {
|
|
266
|
+
return this.#blockStore.getProvenBlockNumber();
|
|
238
267
|
}
|
|
239
268
|
/**
|
|
240
269
|
* Gets the last L1 block number processed by the archiver
|
|
241
270
|
*/ async getSynchPoint() {
|
|
242
271
|
const [blocksSynchedTo, messagesSynchedTo] = await Promise.all([
|
|
243
272
|
this.#blockStore.getSynchedL1BlockNumber(),
|
|
244
|
-
this.#messageStore.
|
|
273
|
+
this.#messageStore.getSynchedL1Block()
|
|
245
274
|
]);
|
|
246
275
|
return {
|
|
247
276
|
blocksSynchedTo,
|
|
@@ -251,4 +280,34 @@ import { NullifierStore } from './nullifier_store.js';
|
|
|
251
280
|
estimateSize() {
|
|
252
281
|
return this.db.estimateSize();
|
|
253
282
|
}
|
|
283
|
+
rollbackL1ToL2MessagesToCheckpoint(targetCheckpointNumber) {
|
|
284
|
+
return this.#messageStore.rollbackL1ToL2MessagesToCheckpoint(targetCheckpointNumber);
|
|
285
|
+
}
|
|
286
|
+
iterateL1ToL2Messages(range = {}) {
|
|
287
|
+
return this.#messageStore.iterateL1ToL2Messages(range);
|
|
288
|
+
}
|
|
289
|
+
removeL1ToL2Messages(startIndex) {
|
|
290
|
+
return this.#messageStore.removeL1ToL2Messages(startIndex);
|
|
291
|
+
}
|
|
292
|
+
getPendingChainValidationStatus() {
|
|
293
|
+
return this.#blockStore.getPendingChainValidationStatus();
|
|
294
|
+
}
|
|
295
|
+
setPendingChainValidationStatus(status) {
|
|
296
|
+
return this.#blockStore.setPendingChainValidationStatus(status);
|
|
297
|
+
}
|
|
298
|
+
getCheckpointedL2BlockNumber() {
|
|
299
|
+
return this.#blockStore.getCheckpointedL2BlockNumber();
|
|
300
|
+
}
|
|
301
|
+
getSynchedCheckpointNumber() {
|
|
302
|
+
return this.#blockStore.getLatestCheckpointNumber();
|
|
303
|
+
}
|
|
304
|
+
async setCheckpointSynchedL1BlockNumber(l1BlockNumber) {
|
|
305
|
+
await this.#blockStore.setSynchedL1BlockNumber(l1BlockNumber);
|
|
306
|
+
}
|
|
307
|
+
getBlocksForCheckpoint(checkpointNumber) {
|
|
308
|
+
return this.#blockStore.getBlocksForCheckpoint(checkpointNumber);
|
|
309
|
+
}
|
|
310
|
+
getCheckpointData(checkpointNumber) {
|
|
311
|
+
return this.#blockStore.getCheckpointData(checkpointNumber);
|
|
312
|
+
}
|
|
254
313
|
}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import type { Fr } from '@aztec/foundation/fields';
|
|
2
1
|
import type { AztecAsyncKVStore } from '@aztec/kv-store';
|
|
3
|
-
import type {
|
|
2
|
+
import type { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
3
|
+
import { L2BlockNew } from '@aztec/stdlib/block';
|
|
4
4
|
import type { GetContractClassLogsResponse, GetPublicLogsResponse } from '@aztec/stdlib/interfaces/client';
|
|
5
|
-
import { type LogFilter,
|
|
5
|
+
import { type LogFilter, type SiloedTag, Tag, TxScopedL2Log } from '@aztec/stdlib/logs';
|
|
6
6
|
import type { BlockStore } from './block_store.js';
|
|
7
7
|
/**
|
|
8
8
|
* A store for logs
|
|
@@ -17,22 +17,18 @@ export declare class LogStore {
|
|
|
17
17
|
* @param blocks - The blocks for which to add the logs.
|
|
18
18
|
* @returns True if the operation is successful.
|
|
19
19
|
*/
|
|
20
|
-
addLogs(blocks:
|
|
21
|
-
deleteLogs(blocks:
|
|
20
|
+
addLogs(blocks: L2BlockNew[]): Promise<boolean>;
|
|
21
|
+
deleteLogs(blocks: L2BlockNew[]): Promise<boolean>;
|
|
22
22
|
/**
|
|
23
|
-
*
|
|
24
|
-
*
|
|
25
|
-
* @param limit - The maximum number of blocks to retrieve logs from.
|
|
26
|
-
* @returns An array of private logs from the specified range of blocks.
|
|
23
|
+
* Gets all private logs that match any of the `tags`. For each tag, an array of matching logs is returned. An empty
|
|
24
|
+
* array implies no logs match that tag.
|
|
27
25
|
*/
|
|
28
|
-
|
|
26
|
+
getPrivateLogsByTags(tags: SiloedTag[]): Promise<TxScopedL2Log[][]>;
|
|
29
27
|
/**
|
|
30
|
-
* Gets all logs that match any of the
|
|
31
|
-
*
|
|
32
|
-
* @returns For each received tag, an array of matching logs is returned. An empty array implies no logs match
|
|
33
|
-
* that tag.
|
|
28
|
+
* Gets all public logs that match any of the `tags` from the specified contract. For each tag, an array of matching
|
|
29
|
+
* logs is returned. An empty array implies no logs match that tag.
|
|
34
30
|
*/
|
|
35
|
-
|
|
31
|
+
getPublicLogsByTagsFromContract(contractAddress: AztecAddress, tags: Tag[]): Promise<TxScopedL2Log[][]>;
|
|
36
32
|
/**
|
|
37
33
|
* Gets public logs based on the provided filter.
|
|
38
34
|
* @param filter - The filter to apply to the logs.
|
|
@@ -46,4 +42,4 @@ export declare class LogStore {
|
|
|
46
42
|
*/
|
|
47
43
|
getContractClassLogs(filter: LogFilter): Promise<GetContractClassLogsResponse>;
|
|
48
44
|
}
|
|
49
|
-
//# sourceMappingURL=
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nX3N0b3JlLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXJjaGl2ZXIva3ZfYXJjaGl2ZXJfc3RvcmUvbG9nX3N0b3JlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUtBLE9BQU8sS0FBSyxFQUFFLGlCQUFpQixFQUFpQixNQUFNLGlCQUFpQixDQUFDO0FBQ3hFLE9BQU8sS0FBSyxFQUFFLFlBQVksRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ2hFLE9BQU8sRUFBZSxVQUFVLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUM5RCxPQUFPLEtBQUssRUFBRSw0QkFBNEIsRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQzNHLE9BQU8sRUFJTCxLQUFLLFNBQVMsRUFHZCxLQUFLLFNBQVMsRUFDZCxHQUFHLEVBQ0gsYUFBYSxFQUNkLE1BQU0sb0JBQW9CLENBQUM7QUFFNUIsT0FBTyxLQUFLLEVBQUUsVUFBVSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFbkQ7O0dBRUc7QUFDSCxxQkFBYSxRQUFROztJQWFqQixPQUFPLENBQUMsRUFBRTtJQUNWLE9BQU8sQ0FBQyxVQUFVO0lBRnBCLFlBQ1UsRUFBRSxFQUFFLGlCQUFpQixFQUNyQixVQUFVLEVBQUUsVUFBVSxFQUM5QixlQUFlLEdBQUUsTUFBYSxFQVUvQjtJQXFHRDs7OztPQUlHO0lBQ0csT0FBTyxDQUFDLE1BQU0sRUFBRSxVQUFVLEVBQUUsR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLENBbUZwRDtJQWdCRCxVQUFVLENBQUMsTUFBTSxFQUFFLFVBQVUsRUFBRSxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0EyQmpEO0lBRUQ7OztPQUdHO0lBQ0csb0JBQW9CLENBQUMsSUFBSSxFQUFFLFNBQVMsRUFBRSxHQUFHLE9BQU8sQ0FBQyxhQUFhLEVBQUUsRUFBRSxDQUFDLENBSXhFO0lBRUQ7OztPQUdHO0lBQ0csK0JBQStCLENBQUMsZUFBZSxFQUFFLFlBQVksRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLEdBQUcsT0FBTyxDQUFDLGFBQWEsRUFBRSxFQUFFLENBQUMsQ0FRNUc7SUFFRDs7OztPQUlHO0lBQ0gsYUFBYSxDQUFDLE1BQU0sRUFBRSxTQUFTLEdBQUcsT0FBTyxDQUFDLHFCQUFxQixDQUFDLENBUS9EO0lBNkVEOzs7O09BSUc7SUFDSCxvQkFBb0IsQ0FBQyxNQUFNLEVBQUUsU0FBUyxHQUFHLE9BQU8sQ0FBQyw0QkFBNEIsQ0FBQyxDQVE3RTtDQTZHRiJ9
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"log_store.d.ts","sourceRoot":"","sources":["../../../src/archiver/kv_archiver_store/log_store.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"log_store.d.ts","sourceRoot":"","sources":["../../../src/archiver/kv_archiver_store/log_store.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,iBAAiB,EAAiB,MAAM,iBAAiB,CAAC;AACxE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAChE,OAAO,EAAe,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC9D,OAAO,KAAK,EAAE,4BAA4B,EAAE,qBAAqB,EAAE,MAAM,iCAAiC,CAAC;AAC3G,OAAO,EAIL,KAAK,SAAS,EAGd,KAAK,SAAS,EACd,GAAG,EACH,aAAa,EACd,MAAM,oBAAoB,CAAC;AAE5B,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAEnD;;GAEG;AACH,qBAAa,QAAQ;;IAajB,OAAO,CAAC,EAAE;IACV,OAAO,CAAC,UAAU;IAFpB,YACU,EAAE,EAAE,iBAAiB,EACrB,UAAU,EAAE,UAAU,EAC9B,eAAe,GAAE,MAAa,EAU/B;IAqGD;;;;OAIG;IACG,OAAO,CAAC,MAAM,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC,CAmFpD;IAgBD,UAAU,CAAC,MAAM,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC,CA2BjD;IAED;;;OAGG;IACG,oBAAoB,CAAC,IAAI,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,aAAa,EAAE,EAAE,CAAC,CAIxE;IAED;;;OAGG;IACG,+BAA+B,CAAC,eAAe,EAAE,YAAY,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,aAAa,EAAE,EAAE,CAAC,CAQ5G;IAED;;;;OAIG;IACH,aAAa,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,qBAAqB,CAAC,CAQ/D;IA6ED;;;;OAIG;IACH,oBAAoB,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,4BAA4B,CAAC,CAQ7E;CA6GF"}
|