@aztec/archiver 0.0.0-test.1 → 0.0.1-commit.1142ef1
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 +204 -94
- package/dest/archiver/archiver.d.ts.map +1 -1
- package/dest/archiver/archiver.js +1616 -414
- package/dest/archiver/archiver_store.d.ts +178 -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 +2373 -397
- 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 +45 -41
- package/dest/archiver/kv_archiver_store/block_store.d.ts +98 -21
- package/dest/archiver/kv_archiver_store/block_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/block_store.js +495 -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 +81 -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 +145 -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 +151 -114
- 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 +30 -7
- package/dest/test/mock_l2_block_source.d.ts +56 -13
- package/dest/test/mock_l2_block_source.d.ts.map +1 -1
- package/dest/test/mock_l2_block_source.js +196 -25
- 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 +1596 -512
- package/src/archiver/archiver_store.ts +205 -88
- package/src/archiver/archiver_store_test_suite.ts +2386 -354
- 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 +65 -45
- package/src/archiver/kv_archiver_store/block_store.ts +668 -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 +197 -113
- package/src/archiver/kv_archiver_store/log_store.ts +204 -132
- 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 +26 -8
- package/src/test/mock_l2_block_source.ts +254 -31
- 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,69 @@ 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));
|
|
151
|
+
}
|
|
152
|
+
getCheckpointedBlocks(from, limit) {
|
|
153
|
+
return toArray(this.#blockStore.getCheckpointedBlocks(from, limit));
|
|
108
154
|
}
|
|
109
155
|
/**
|
|
110
156
|
* Gets up to `limit` amount of L2 blocks headers starting from `from`.
|
|
@@ -115,10 +161,16 @@ import { NullifierStore } from './nullifier_store.js';
|
|
|
115
161
|
*/ getBlockHeaders(start, limit) {
|
|
116
162
|
return toArray(this.#blockStore.getBlockHeaders(start, limit));
|
|
117
163
|
}
|
|
164
|
+
getBlockHeaderByHash(blockHash) {
|
|
165
|
+
return this.#blockStore.getBlockHeaderByHash(L2BlockHash.fromField(blockHash));
|
|
166
|
+
}
|
|
167
|
+
getBlockHeaderByArchive(archive) {
|
|
168
|
+
return this.#blockStore.getBlockHeaderByArchive(archive);
|
|
169
|
+
}
|
|
118
170
|
/**
|
|
119
171
|
* Gets a tx effect.
|
|
120
|
-
* @param txHash - The
|
|
121
|
-
* @returns The requested tx effect (or undefined if not found).
|
|
172
|
+
* @param txHash - The hash of the tx corresponding to the tx effect.
|
|
173
|
+
* @returns The requested tx effect with block info (or undefined if not found).
|
|
122
174
|
*/ getTxEffect(txHash) {
|
|
123
175
|
return this.#blockStore.getTxEffect(txHash);
|
|
124
176
|
}
|
|
@@ -139,26 +191,15 @@ import { NullifierStore } from './nullifier_store.js';
|
|
|
139
191
|
deleteLogs(blocks) {
|
|
140
192
|
return this.#logStore.deleteLogs(blocks);
|
|
141
193
|
}
|
|
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
194
|
getTotalL1ToL2MessageCount() {
|
|
156
195
|
return this.#messageStore.getTotalL1ToL2MessageCount();
|
|
157
196
|
}
|
|
197
|
+
getLastL1ToL2Message() {
|
|
198
|
+
return this.#messageStore.getLastMessage();
|
|
199
|
+
}
|
|
158
200
|
/**
|
|
159
201
|
* 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.
|
|
202
|
+
* @param messages - The L1 to L2 messages to be added to the store.
|
|
162
203
|
*/ addL1ToL2Messages(messages) {
|
|
163
204
|
return this.#messageStore.addL1ToL2Messages(messages);
|
|
164
205
|
}
|
|
@@ -170,28 +211,22 @@ import { NullifierStore } from './nullifier_store.js';
|
|
|
170
211
|
return this.#messageStore.getL1ToL2MessageIndex(l1ToL2Message);
|
|
171
212
|
}
|
|
172
213
|
/**
|
|
173
|
-
* Gets L1 to L2 message (to be) included in a given
|
|
174
|
-
* @param
|
|
214
|
+
* Gets L1 to L2 message (to be) included in a given checkpoint.
|
|
215
|
+
* @param checkpointNumber - Checkpoint number to get messages for.
|
|
175
216
|
* @returns The L1 to L2 messages/leaves of the messages subtree (throws if not found).
|
|
176
|
-
*/ getL1ToL2Messages(
|
|
177
|
-
return this.#messageStore.getL1ToL2Messages(
|
|
217
|
+
*/ getL1ToL2Messages(checkpointNumber) {
|
|
218
|
+
return this.#messageStore.getL1ToL2Messages(checkpointNumber);
|
|
178
219
|
}
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
return this.#logStore.getPrivateLogs(from, limit);
|
|
220
|
+
getPrivateLogsByTags(tags) {
|
|
221
|
+
try {
|
|
222
|
+
return this.#logStore.getPrivateLogsByTags(tags);
|
|
223
|
+
} catch (err) {
|
|
224
|
+
return Promise.reject(err);
|
|
225
|
+
}
|
|
186
226
|
}
|
|
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) {
|
|
227
|
+
getPublicLogsByTagsFromContract(contractAddress, tags) {
|
|
193
228
|
try {
|
|
194
|
-
return this.#logStore.
|
|
229
|
+
return this.#logStore.getPublicLogsByTagsFromContract(contractAddress, tags);
|
|
195
230
|
} catch (err) {
|
|
196
231
|
return Promise.reject(err);
|
|
197
232
|
}
|
|
@@ -218,30 +253,27 @@ import { NullifierStore } from './nullifier_store.js';
|
|
|
218
253
|
return Promise.reject(err);
|
|
219
254
|
}
|
|
220
255
|
}
|
|
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();
|
|
256
|
+
getProvenCheckpointNumber() {
|
|
257
|
+
return this.#blockStore.getProvenCheckpointNumber();
|
|
229
258
|
}
|
|
230
|
-
async
|
|
231
|
-
await this.#blockStore.
|
|
259
|
+
async setProvenCheckpointNumber(checkpointNumber) {
|
|
260
|
+
await this.#blockStore.setProvenCheckpointNumber(checkpointNumber);
|
|
232
261
|
}
|
|
233
262
|
async setBlockSynchedL1BlockNumber(l1BlockNumber) {
|
|
234
263
|
await this.#blockStore.setSynchedL1BlockNumber(l1BlockNumber);
|
|
235
264
|
}
|
|
236
|
-
async
|
|
237
|
-
await this.#messageStore.
|
|
265
|
+
async setMessageSynchedL1Block(l1Block) {
|
|
266
|
+
await this.#messageStore.setSynchedL1Block(l1Block);
|
|
267
|
+
}
|
|
268
|
+
getProvenBlockNumber() {
|
|
269
|
+
return this.#blockStore.getProvenBlockNumber();
|
|
238
270
|
}
|
|
239
271
|
/**
|
|
240
272
|
* Gets the last L1 block number processed by the archiver
|
|
241
273
|
*/ async getSynchPoint() {
|
|
242
274
|
const [blocksSynchedTo, messagesSynchedTo] = await Promise.all([
|
|
243
275
|
this.#blockStore.getSynchedL1BlockNumber(),
|
|
244
|
-
this.#messageStore.
|
|
276
|
+
this.#messageStore.getSynchedL1Block()
|
|
245
277
|
]);
|
|
246
278
|
return {
|
|
247
279
|
blocksSynchedTo,
|
|
@@ -251,4 +283,34 @@ import { NullifierStore } from './nullifier_store.js';
|
|
|
251
283
|
estimateSize() {
|
|
252
284
|
return this.db.estimateSize();
|
|
253
285
|
}
|
|
286
|
+
rollbackL1ToL2MessagesToCheckpoint(targetCheckpointNumber) {
|
|
287
|
+
return this.#messageStore.rollbackL1ToL2MessagesToCheckpoint(targetCheckpointNumber);
|
|
288
|
+
}
|
|
289
|
+
iterateL1ToL2Messages(range = {}) {
|
|
290
|
+
return this.#messageStore.iterateL1ToL2Messages(range);
|
|
291
|
+
}
|
|
292
|
+
removeL1ToL2Messages(startIndex) {
|
|
293
|
+
return this.#messageStore.removeL1ToL2Messages(startIndex);
|
|
294
|
+
}
|
|
295
|
+
getPendingChainValidationStatus() {
|
|
296
|
+
return this.#blockStore.getPendingChainValidationStatus();
|
|
297
|
+
}
|
|
298
|
+
setPendingChainValidationStatus(status) {
|
|
299
|
+
return this.#blockStore.setPendingChainValidationStatus(status);
|
|
300
|
+
}
|
|
301
|
+
getCheckpointedL2BlockNumber() {
|
|
302
|
+
return this.#blockStore.getCheckpointedL2BlockNumber();
|
|
303
|
+
}
|
|
304
|
+
getSynchedCheckpointNumber() {
|
|
305
|
+
return this.#blockStore.getLatestCheckpointNumber();
|
|
306
|
+
}
|
|
307
|
+
async setCheckpointSynchedL1BlockNumber(l1BlockNumber) {
|
|
308
|
+
await this.#blockStore.setSynchedL1BlockNumber(l1BlockNumber);
|
|
309
|
+
}
|
|
310
|
+
getBlocksForCheckpoint(checkpointNumber) {
|
|
311
|
+
return this.#blockStore.getBlocksForCheckpoint(checkpointNumber);
|
|
312
|
+
}
|
|
313
|
+
getCheckpointData(checkpointNumber) {
|
|
314
|
+
return this.#blockStore.getCheckpointData(checkpointNumber);
|
|
315
|
+
}
|
|
254
316
|
}
|
|
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nX3N0b3JlLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXJjaGl2ZXIva3ZfYXJjaGl2ZXJfc3RvcmUvbG9nX3N0b3JlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUtBLE9BQU8sS0FBSyxFQUFFLGlCQUFpQixFQUFpQixNQUFNLGlCQUFpQixDQUFDO0FBQ3hFLE9BQU8sS0FBSyxFQUFFLFlBQVksRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ2hFLE9BQU8sRUFBZSxVQUFVLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUM5RCxPQUFPLEtBQUssRUFBRSw0QkFBNEIsRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQzNHLE9BQU8sRUFJTCxLQUFLLFNBQVMsRUFHZCxLQUFLLFNBQVMsRUFDZCxHQUFHLEVBQ0gsYUFBYSxFQUNkLE1BQU0sb0JBQW9CLENBQUM7QUFFNUIsT0FBTyxLQUFLLEVBQUUsVUFBVSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFbkQ7O0dBRUc7QUFDSCxxQkFBYSxRQUFROztJQWFqQixPQUFPLENBQUMsRUFBRTtJQUNWLE9BQU8sQ0FBQyxVQUFVO0lBRnBCLFlBQ1UsRUFBRSxFQUFFLGlCQUFpQixFQUNyQixVQUFVLEVBQUUsVUFBVSxFQUM5QixlQUFlLEdBQUUsTUFBYSxFQVUvQjtJQStGRDs7OztPQUlHO0lBQ0gsT0FBTyxDQUFDLE1BQU0sRUFBRSxVQUFVLEVBQUUsR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLENBbUY5QztJQWdCRCxVQUFVLENBQUMsTUFBTSxFQUFFLFVBQVUsRUFBRSxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0EyQmpEO0lBRUQ7OztPQUdHO0lBQ0csb0JBQW9CLENBQUMsSUFBSSxFQUFFLFNBQVMsRUFBRSxHQUFHLE9BQU8sQ0FBQyxhQUFhLEVBQUUsRUFBRSxDQUFDLENBSXhFO0lBRUQ7OztPQUdHO0lBQ0csK0JBQStCLENBQUMsZUFBZSxFQUFFLFlBQVksRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLEdBQUcsT0FBTyxDQUFDLGFBQWEsRUFBRSxFQUFFLENBQUMsQ0FRNUc7SUFFRDs7OztPQUlHO0lBQ0gsYUFBYSxDQUFDLE1BQU0sRUFBRSxTQUFTLEdBQUcsT0FBTyxDQUFDLHFCQUFxQixDQUFDLENBUS9EO0lBNkVEOzs7O09BSUc7SUFDSCxvQkFBb0IsQ0FBQyxNQUFNLEVBQUUsU0FBUyxHQUFHLE9BQU8sQ0FBQyw0QkFBNEIsQ0FBQyxDQVE3RTtDQTZHRiJ9
|
|
@@ -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;IA+FD;;;;OAIG;IACH,OAAO,CAAC,MAAM,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC,CAmF9C;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"}
|