@aztec/archiver 0.51.0 → 0.52.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dest/archiver/archiver.d.ts +10 -4
- package/dest/archiver/archiver.d.ts.map +1 -1
- package/dest/archiver/archiver.js +87 -41
- package/dest/archiver/archiver_store.d.ts +7 -4
- package/dest/archiver/archiver_store.d.ts.map +1 -1
- package/dest/archiver/archiver_store_test_suite.d.ts.map +1 -1
- package/dest/archiver/archiver_store_test_suite.js +46 -34
- package/dest/archiver/data_retrieval.d.ts +3 -14
- package/dest/archiver/data_retrieval.d.ts.map +1 -1
- package/dest/archiver/data_retrieval.js +8 -8
- package/dest/archiver/eth_log_handlers.d.ts +8 -6
- package/dest/archiver/eth_log_handlers.d.ts.map +1 -1
- package/dest/archiver/eth_log_handlers.js +25 -16
- package/dest/archiver/index.d.ts +1 -0
- package/dest/archiver/index.d.ts.map +1 -1
- package/dest/archiver/index.js +1 -1
- package/dest/archiver/instrumentation.d.ts +10 -0
- package/dest/archiver/instrumentation.d.ts.map +1 -1
- package/dest/archiver/instrumentation.js +32 -2
- package/dest/archiver/kv_archiver_store/block_body_store.d.ts +1 -1
- package/dest/archiver/kv_archiver_store/block_body_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/block_store.d.ts +5 -7
- package/dest/archiver/kv_archiver_store/block_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/block_store.js +20 -28
- package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts +5 -4
- package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/kv_archiver_store.js +10 -6
- package/dest/archiver/kv_archiver_store/message_store.d.ts +1 -1
- package/dest/archiver/kv_archiver_store/message_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/proven_store.d.ts +14 -0
- package/dest/archiver/kv_archiver_store/proven_store.d.ts.map +1 -0
- package/dest/archiver/kv_archiver_store/proven_store.js +30 -0
- package/dest/archiver/memory_archiver_store/memory_archiver_store.d.ts +6 -4
- package/dest/archiver/memory_archiver_store/memory_archiver_store.d.ts.map +1 -1
- package/dest/archiver/memory_archiver_store/memory_archiver_store.js +16 -10
- package/dest/archiver/structs/data_retrieval.d.ts +27 -0
- package/dest/archiver/structs/data_retrieval.d.ts.map +1 -0
- package/dest/archiver/structs/data_retrieval.js +2 -0
- package/dest/archiver/structs/published.d.ts +11 -0
- package/dest/archiver/structs/published.d.ts.map +1 -0
- package/dest/archiver/structs/published.js +2 -0
- package/dest/index.d.ts.map +1 -1
- package/dest/index.js +3 -2
- package/package.json +10 -10
- package/src/archiver/archiver.ts +115 -53
- package/src/archiver/archiver_store.ts +7 -4
- package/src/archiver/archiver_store_test_suite.ts +66 -54
- package/src/archiver/data_retrieval.ts +13 -25
- package/src/archiver/eth_log_handlers.ts +32 -19
- package/src/archiver/index.ts +1 -0
- package/src/archiver/instrumentation.ts +39 -1
- package/src/archiver/kv_archiver_store/block_body_store.ts +1 -1
- package/src/archiver/kv_archiver_store/block_store.ts +24 -33
- package/src/archiver/kv_archiver_store/kv_archiver_store.ts +12 -7
- package/src/archiver/kv_archiver_store/message_store.ts +1 -1
- package/src/archiver/kv_archiver_store/proven_store.ts +34 -0
- package/src/archiver/memory_archiver_store/memory_archiver_store.ts +24 -15
- package/src/archiver/structs/data_retrieval.ts +27 -0
- package/src/archiver/structs/published.ts +11 -0
- package/src/index.ts +2 -1
|
@@ -48,6 +48,7 @@ export class MemoryArchiverStore {
|
|
|
48
48
|
this.lastL1BlockNewBlocks = 0n;
|
|
49
49
|
this.lastL1BlockNewBlockBodies = 0n;
|
|
50
50
|
this.lastL1BlockNewMessages = 0n;
|
|
51
|
+
this.lastL1BlockNewProvenLogs = 0n;
|
|
51
52
|
this.lastProvenL2BlockNumber = 0;
|
|
52
53
|
}
|
|
53
54
|
getContractClass(id) {
|
|
@@ -97,9 +98,12 @@ export class MemoryArchiverStore {
|
|
|
97
98
|
* @returns True if the operation is successful.
|
|
98
99
|
*/
|
|
99
100
|
addBlocks(blocks) {
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
101
|
+
if (blocks.length === 0) {
|
|
102
|
+
return Promise.resolve(true);
|
|
103
|
+
}
|
|
104
|
+
this.lastL1BlockNewBlocks = blocks[blocks.length - 1].l1.blockNumber;
|
|
105
|
+
this.l2Blocks.push(...blocks);
|
|
106
|
+
this.txEffects.push(...blocks.flatMap(b => b.data.body.txEffects));
|
|
103
107
|
return Promise.resolve(true);
|
|
104
108
|
}
|
|
105
109
|
/**
|
|
@@ -201,9 +205,9 @@ export class MemoryArchiverStore {
|
|
|
201
205
|
*/
|
|
202
206
|
getSettledTxReceipt(txHash) {
|
|
203
207
|
for (const block of this.l2Blocks) {
|
|
204
|
-
for (const txEffect of block.body.txEffects) {
|
|
208
|
+
for (const txEffect of block.data.body.txEffects) {
|
|
205
209
|
if (txEffect.txHash.equals(txHash)) {
|
|
206
|
-
return Promise.resolve(new TxReceipt(txHash, TxReceipt.statusFromRevertCode(txEffect.revertCode), '', txEffect.transactionFee.toBigInt(), block.hash().toBuffer(), block.number));
|
|
210
|
+
return Promise.resolve(new TxReceipt(txHash, TxReceipt.statusFromRevertCode(txEffect.revertCode), '', txEffect.transactionFee.toBigInt(), block.data.hash().toBuffer(), block.data.number));
|
|
207
211
|
}
|
|
208
212
|
}
|
|
209
213
|
}
|
|
@@ -296,9 +300,9 @@ export class MemoryArchiverStore {
|
|
|
296
300
|
const txLogs = blockLogs.txLogs[txIndexInBlock].unrollLogs();
|
|
297
301
|
for (; logIndexInTx < txLogs.length; logIndexInTx++) {
|
|
298
302
|
const log = txLogs[logIndexInTx];
|
|
299
|
-
if ((!txHash || block.body.txEffects[txIndexInBlock].txHash.equals(txHash)) &&
|
|
303
|
+
if ((!txHash || block.data.body.txEffects[txIndexInBlock].txHash.equals(txHash)) &&
|
|
300
304
|
(!contractAddress || log.contractAddress.equals(contractAddress))) {
|
|
301
|
-
logs.push(new ExtendedUnencryptedL2Log(new LogId(block.number, txIndexInBlock, logIndexInTx), log));
|
|
305
|
+
logs.push(new ExtendedUnencryptedL2Log(new LogId(block.data.number, txIndexInBlock, logIndexInTx), log));
|
|
302
306
|
if (logs.length === this.maxLogs) {
|
|
303
307
|
return Promise.resolve({
|
|
304
308
|
logs,
|
|
@@ -324,13 +328,14 @@ export class MemoryArchiverStore {
|
|
|
324
328
|
if (this.l2Blocks.length === 0) {
|
|
325
329
|
return Promise.resolve(INITIAL_L2_BLOCK_NUM - 1);
|
|
326
330
|
}
|
|
327
|
-
return Promise.resolve(this.l2Blocks[this.l2Blocks.length - 1].number);
|
|
331
|
+
return Promise.resolve(this.l2Blocks[this.l2Blocks.length - 1].data.number);
|
|
328
332
|
}
|
|
329
333
|
getProvenL2BlockNumber() {
|
|
330
334
|
return Promise.resolve(this.lastProvenL2BlockNumber);
|
|
331
335
|
}
|
|
332
336
|
setProvenL2BlockNumber(l2BlockNumber) {
|
|
333
|
-
this.lastProvenL2BlockNumber = l2BlockNumber;
|
|
337
|
+
this.lastProvenL2BlockNumber = l2BlockNumber.retrievedData;
|
|
338
|
+
this.lastL1BlockNewProvenLogs = l2BlockNumber.lastProcessedL1BlockNumber;
|
|
334
339
|
return Promise.resolve();
|
|
335
340
|
}
|
|
336
341
|
getSynchPoint() {
|
|
@@ -338,6 +343,7 @@ export class MemoryArchiverStore {
|
|
|
338
343
|
blocksSynchedTo: this.lastL1BlockNewBlocks,
|
|
339
344
|
messagesSynchedTo: this.lastL1BlockNewMessages,
|
|
340
345
|
blockBodiesSynchedTo: this.lastL1BlockNewBlockBodies,
|
|
346
|
+
provenLogsSynchedTo: this.lastL1BlockNewProvenLogs,
|
|
341
347
|
});
|
|
342
348
|
}
|
|
343
349
|
addContractArtifact(address, contract) {
|
|
@@ -348,4 +354,4 @@ export class MemoryArchiverStore {
|
|
|
348
354
|
return Promise.resolve(this.contractArtifacts.get(address.toString()));
|
|
349
355
|
}
|
|
350
356
|
}
|
|
351
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVtb3J5X2FyY2hpdmVyX3N0b3JlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2FyY2hpdmVyL21lbW9yeV9hcmNoaXZlcl9zdG9yZS9tZW1vcnlfYXJjaGl2ZXJfc3RvcmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUlMLHdCQUF3QixFQU94QixLQUFLLEVBQ0wsT0FBTyxFQUdQLFNBQVMsR0FFVixNQUFNLHNCQUFzQixDQUFDO0FBQzlCLE9BQU8sRUFBRSxFQUFFLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQVk5RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUVqRTs7R0FFRztBQUNILE1BQU0sT0FBTyxtQkFBbUI7SUFzRDlCO0lBQ0Usa0ZBQWtGO0lBQ2xFLE9BQWU7UUFBZixZQUFPLEdBQVAsT0FBTyxDQUFRO1FBdkRqQzs7V0FFRztRQUNLLGFBQVEsR0FBYyxFQUFFLENBQUM7UUFFakM7O1dBRUc7UUFDSyxrQkFBYSxHQUFzQixJQUFJLEdBQUcsRUFBRSxDQUFDO1FBRXJEOztXQUVHO1FBQ0ssY0FBUyxHQUFlLEVBQUUsQ0FBQztRQUVuQzs7O1dBR0c7UUFDSyw4QkFBeUIsR0FBaUMsRUFBRSxDQUFDO1FBRXJFOzs7V0FHRztRQUNLLDBCQUFxQixHQUE2QixFQUFFLENBQUM7UUFFN0Q7OztXQUdHO1FBQ0ssNEJBQXVCLEdBQStCLEVBQUUsQ0FBQztRQUVqRTs7V0FFRztRQUNLLG1CQUFjLEdBQUcsSUFBSSxrQkFBa0IsRUFBRSxDQUFDO1FBRTFDLHNCQUFpQixHQUFrQyxJQUFJLEdBQUcsRUFBRSxDQUFDO1FBRTdELG9CQUFlLEdBQXFDLElBQUksR0FBRyxFQUFFLENBQUM7UUFFOUQscUJBQWdCLEdBQWdFLElBQUksR0FBRyxFQUFFLENBQUM7UUFFMUYsMkJBQXNCLEdBQTRELElBQUksR0FBRyxFQUFFLENBQUM7UUFFNUYsc0JBQWlCLEdB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
|
|
357
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVtb3J5X2FyY2hpdmVyX3N0b3JlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2FyY2hpdmVyL21lbW9yeV9hcmNoaXZlcl9zdG9yZS9tZW1vcnlfYXJjaGl2ZXJfc3RvcmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUlMLHdCQUF3QixFQU94QixLQUFLLEVBQ0wsT0FBTyxFQUdQLFNBQVMsR0FFVixNQUFNLHNCQUFzQixDQUFDO0FBQzlCLE9BQU8sRUFBRSxFQUFFLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQWE5RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUVqRTs7R0FFRztBQUNILE1BQU0sT0FBTyxtQkFBbUI7SUF3RDlCO0lBQ0Usa0ZBQWtGO0lBQ2xFLE9BQWU7UUFBZixZQUFPLEdBQVAsT0FBTyxDQUFRO1FBekRqQzs7V0FFRztRQUNLLGFBQVEsR0FBMkIsRUFBRSxDQUFDO1FBRTlDOztXQUVHO1FBQ0ssa0JBQWEsR0FBc0IsSUFBSSxHQUFHLEVBQUUsQ0FBQztRQUVyRDs7V0FFRztRQUNLLGNBQVMsR0FBZSxFQUFFLENBQUM7UUFFbkM7OztXQUdHO1FBQ0ssOEJBQXlCLEdBQWlDLEVBQUUsQ0FBQztRQUVyRTs7O1dBR0c7UUFDSywwQkFBcUIsR0FBNkIsRUFBRSxDQUFDO1FBRTdEOzs7V0FHRztRQUNLLDRCQUF1QixHQUErQixFQUFFLENBQUM7UUFFakU7O1dBRUc7UUFDSyxtQkFBYyxHQUFHLElBQUksa0JBQWtCLEVBQUUsQ0FBQztRQUUxQyxzQkFBaUIsR0FBa0MsSUFBSSxHQUFHLEVBQUUsQ0FBQztRQUU3RCxvQkFBZSxHQUFxQyxJQUFJLEdBQUcsRUFBRSxDQUFDO1FBRTlELHFCQUFnQixHQUFnRSxJQUFJLEdBQUcsRUFBRSxDQUFDO1FBRTFGLDJCQUFzQixHQUE0RCxJQUFJLEdBQUcsRUFBRSxDQUFDO1FBRTVGLHNCQUFpQixH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
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Data retrieved from logs
|
|
3
|
+
*/
|
|
4
|
+
export type DataRetrieval<T> = {
|
|
5
|
+
/**
|
|
6
|
+
* Blocknumber of the last L1 block from which we obtained data.
|
|
7
|
+
*/
|
|
8
|
+
lastProcessedL1BlockNumber: bigint;
|
|
9
|
+
/**
|
|
10
|
+
* The data returned.
|
|
11
|
+
*/
|
|
12
|
+
retrievedData: T[];
|
|
13
|
+
};
|
|
14
|
+
/**
|
|
15
|
+
* Data retrieved from logs
|
|
16
|
+
*/
|
|
17
|
+
export type SingletonDataRetrieval<T> = {
|
|
18
|
+
/**
|
|
19
|
+
* Blocknumber of the last L1 block from which we obtained data.
|
|
20
|
+
*/
|
|
21
|
+
lastProcessedL1BlockNumber: bigint;
|
|
22
|
+
/**
|
|
23
|
+
* The data returned.
|
|
24
|
+
*/
|
|
25
|
+
retrievedData: T;
|
|
26
|
+
};
|
|
27
|
+
//# sourceMappingURL=data_retrieval.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"data_retrieval.d.ts","sourceRoot":"","sources":["../../../src/archiver/structs/data_retrieval.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,MAAM,MAAM,aAAa,CAAC,CAAC,IAAI;IAC7B;;OAEG;IACH,0BAA0B,EAAE,MAAM,CAAC;IACnC;;OAEG;IACH,aAAa,EAAE,CAAC,EAAE,CAAC;CACpB,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,sBAAsB,CAAC,CAAC,IAAI;IACtC;;OAEG;IACH,0BAA0B,EAAE,MAAM,CAAC;IACnC;;OAEG;IACH,aAAa,EAAE,CAAC,CAAC;CAClB,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/** Extends a type with L1 published info (block number, hash, and timestamp) */
|
|
2
|
+
export type L1Published<T> = {
|
|
3
|
+
data: T;
|
|
4
|
+
l1: L1PublishedData;
|
|
5
|
+
};
|
|
6
|
+
export type L1PublishedData = {
|
|
7
|
+
blockNumber: bigint;
|
|
8
|
+
timestamp: bigint;
|
|
9
|
+
blockHash: string;
|
|
10
|
+
};
|
|
11
|
+
//# sourceMappingURL=published.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"published.d.ts","sourceRoot":"","sources":["../../../src/archiver/structs/published.ts"],"names":[],"mappings":"AAAA,gFAAgF;AAChF,MAAM,MAAM,WAAW,CAAC,CAAC,IAAI;IAC3B,IAAI,EAAE,CAAC,CAAC;IACR,EAAE,EAAE,eAAe,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG;IAC5B,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC"}
|
package/dest/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAWA,cAAc,qBAAqB,CAAC;AACpC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,cAAc,CAAC;AAG7B,OAAO,EAAE,6BAA6B,EAAE,MAAM,8BAA8B,CAAC"}
|
package/dest/index.js
CHANGED
|
@@ -4,6 +4,7 @@ import { NoopTelemetryClient } from '@aztec/telemetry-client/noop';
|
|
|
4
4
|
import { createPublicClient, http } from 'viem';
|
|
5
5
|
import { localhost } from 'viem/chains';
|
|
6
6
|
import { Archiver, getArchiverConfigFromEnv } from './archiver/index.js';
|
|
7
|
+
import { ArchiverInstrumentation } from './archiver/instrumentation.js';
|
|
7
8
|
import { MemoryArchiverStore } from './archiver/memory_archiver_store/memory_archiver_store.js';
|
|
8
9
|
export * from './archiver/index.js';
|
|
9
10
|
export * from './rpc/index.js';
|
|
@@ -23,7 +24,7 @@ async function main() {
|
|
|
23
24
|
transport: http(rpcUrl),
|
|
24
25
|
});
|
|
25
26
|
const archiverStore = new MemoryArchiverStore(1000);
|
|
26
|
-
const archiver = new Archiver(publicClient, l1Contracts.rollupAddress, l1Contracts.availabilityOracleAddress, l1Contracts.inboxAddress, l1Contracts.registryAddress, archiverStore, 1000, new NoopTelemetryClient());
|
|
27
|
+
const archiver = new Archiver(publicClient, l1Contracts.rollupAddress, l1Contracts.availabilityOracleAddress, l1Contracts.inboxAddress, l1Contracts.registryAddress, archiverStore, 1000, new ArchiverInstrumentation(new NoopTelemetryClient()));
|
|
27
28
|
const shutdown = async () => {
|
|
28
29
|
await archiver.stop();
|
|
29
30
|
process.exit(0);
|
|
@@ -39,4 +40,4 @@ if (process.argv[1] === fileURLToPath(import.meta.url).replace(/\/index\.js$/, '
|
|
|
39
40
|
process.exit(1);
|
|
40
41
|
});
|
|
41
42
|
}
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDMUQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3RELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBRW5FLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxJQUFJLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDaEQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUV4QyxPQUFPLEVBQUUsUUFBUSxFQUFFLHdCQUF3QixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDekUsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDeEUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sMkRBQTJELENBQUM7QUFFaEcsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsY0FBYyxDQUFDO0FBRTdCLHdJQUF3STtBQUN4SSxPQUFPLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUU3RSxNQUFNLEdBQUcsR0FBRyxpQkFBaUIsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0FBRWhEOztHQUVHO0FBQ0gseUNBQXlDO0FBQ3pDLEtBQUssVUFBVSxJQUFJO0lBQ2pCLE1BQU0sTUFBTSxHQUFHLHdCQUF3QixFQUFFLENBQUM7SUFDMUMsTUFBTSxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsV0FBVyxFQUFFLEdBQUcsTUFBTSxDQUFDO0lBRWpELE1BQU0sWUFBWSxHQUFHLGtCQUFrQixDQUFDO1FBQ3RDLEtBQUssRUFBRSxTQUFTO1FBQ2hCLFNBQVMsRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDO0tBQ3hCLENBQUMsQ0FBQztJQUVILE1BQU0sYUFBYSxHQUFHLElBQUksbUJBQW1CLENBQUMsSUFBSSxDQUFDLENBQUM7SUFFcEQsTUFBTSxRQUFRLEdBQUcsSUFBSSxRQUFRLENBQzNCLFlBQVksRUFDWixXQUFXLENBQUMsYUFBYSxFQUN6QixXQUFXLENBQUMseUJBQXlCLEVBQ3JDLFdBQVcsQ0FBQyxZQUFZLEVBQ3hCLFdBQVcsQ0FBQyxlQUFlLEVBQzNCLGFBQWEsRUFDYixJQUFJLEVBQ0osSUFBSSx1QkFBdUIsQ0FBQyxJQUFJLG1CQUFtQixFQUFFLENBQUMsQ0FDdkQsQ0FBQztJQUVGLE1BQU0sUUFBUSxHQUFHLEtBQUssSUFBSSxFQUFFO1FBQzFCLE1BQU0sUUFBUSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3RCLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDbEIsQ0FBQyxDQUFDO0lBQ0YsT0FBTyxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsUUFBUSxDQUFDLENBQUM7SUFDakMsT0FBTyxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsUUFBUSxDQUFDLENBQUM7QUFDcEMsQ0FBQztBQUVELGlFQUFpRTtBQUNqRSxJQUFJLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssYUFBYSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsT0FBTyxDQUFDLGNBQWMsRUFBRSxFQUFFLENBQUMsRUFBRSxDQUFDO0lBQ25GLG1FQUFtRTtJQUNuRSxJQUFJLEVBQUUsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLEVBQUU7UUFDakIsR0FBRyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUNmLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDbEIsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDIn0=
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@aztec/archiver",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.52.0",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"exports": "./dest/index.js",
|
|
6
6
|
"typedocOptions": {
|
|
@@ -58,15 +58,15 @@
|
|
|
58
58
|
]
|
|
59
59
|
},
|
|
60
60
|
"dependencies": {
|
|
61
|
-
"@aztec/circuit-types": "0.
|
|
62
|
-
"@aztec/circuits.js": "0.
|
|
63
|
-
"@aztec/ethereum": "0.
|
|
64
|
-
"@aztec/foundation": "0.
|
|
65
|
-
"@aztec/kv-store": "0.
|
|
66
|
-
"@aztec/l1-artifacts": "0.
|
|
67
|
-
"@aztec/protocol-contracts": "0.
|
|
68
|
-
"@aztec/telemetry-client": "0.
|
|
69
|
-
"@aztec/types": "0.
|
|
61
|
+
"@aztec/circuit-types": "0.52.0",
|
|
62
|
+
"@aztec/circuits.js": "0.52.0",
|
|
63
|
+
"@aztec/ethereum": "0.52.0",
|
|
64
|
+
"@aztec/foundation": "0.52.0",
|
|
65
|
+
"@aztec/kv-store": "0.52.0",
|
|
66
|
+
"@aztec/l1-artifacts": "0.52.0",
|
|
67
|
+
"@aztec/protocol-contracts": "0.52.0",
|
|
68
|
+
"@aztec/telemetry-client": "0.52.0",
|
|
69
|
+
"@aztec/types": "0.52.0",
|
|
70
70
|
"debug": "^4.3.4",
|
|
71
71
|
"lodash.groupby": "^4.6.0",
|
|
72
72
|
"lodash.omit": "^4.5.0",
|
package/src/archiver/archiver.ts
CHANGED
|
@@ -24,6 +24,7 @@ import {
|
|
|
24
24
|
import { createEthereumChain } from '@aztec/ethereum';
|
|
25
25
|
import { type ContractArtifact } from '@aztec/foundation/abi';
|
|
26
26
|
import { type AztecAddress } from '@aztec/foundation/aztec-address';
|
|
27
|
+
import { compactArray, unique } from '@aztec/foundation/collection';
|
|
27
28
|
import { type EthAddress } from '@aztec/foundation/eth-address';
|
|
28
29
|
import { Fr } from '@aztec/foundation/fields';
|
|
29
30
|
import { type DebugLogger, createDebugLogger } from '@aztec/foundation/log';
|
|
@@ -46,13 +47,15 @@ import { type Chain, type HttpTransport, type PublicClient, createPublicClient,
|
|
|
46
47
|
import { type ArchiverDataStore } from './archiver_store.js';
|
|
47
48
|
import { type ArchiverConfig } from './config.js';
|
|
48
49
|
import {
|
|
49
|
-
type DataRetrieval,
|
|
50
50
|
retrieveBlockBodiesFromAvailabilityOracle,
|
|
51
51
|
retrieveBlockMetadataFromRollup,
|
|
52
52
|
retrieveL1ToL2Messages,
|
|
53
53
|
retrieveL2ProofVerifiedEvents,
|
|
54
54
|
} from './data_retrieval.js';
|
|
55
|
+
import { getL1BlockTime } from './eth_log_handlers.js';
|
|
55
56
|
import { ArchiverInstrumentation } from './instrumentation.js';
|
|
57
|
+
import { type SingletonDataRetrieval } from './structs/data_retrieval.js';
|
|
58
|
+
import { type L1Published } from './structs/published.js';
|
|
56
59
|
|
|
57
60
|
/**
|
|
58
61
|
* Helper interface to combine all sources this archiver implementation provides.
|
|
@@ -70,9 +73,6 @@ export class Archiver implements ArchiveSource {
|
|
|
70
73
|
*/
|
|
71
74
|
private runningPromise?: RunningPromise;
|
|
72
75
|
|
|
73
|
-
/** Capture runtime metrics */
|
|
74
|
-
private instrumentation: ArchiverInstrumentation;
|
|
75
|
-
|
|
76
76
|
/**
|
|
77
77
|
* Creates a new instance of the Archiver.
|
|
78
78
|
* @param publicClient - A client for interacting with the Ethereum node.
|
|
@@ -91,11 +91,9 @@ export class Archiver implements ArchiveSource {
|
|
|
91
91
|
private readonly registryAddress: EthAddress,
|
|
92
92
|
private readonly store: ArchiverDataStore,
|
|
93
93
|
private readonly pollingIntervalMs = 10_000,
|
|
94
|
-
|
|
94
|
+
private readonly instrumentation: ArchiverInstrumentation,
|
|
95
95
|
private readonly log: DebugLogger = createDebugLogger('aztec:archiver'),
|
|
96
|
-
) {
|
|
97
|
-
this.instrumentation = new ArchiverInstrumentation(telemetry);
|
|
98
|
-
}
|
|
96
|
+
) {}
|
|
99
97
|
|
|
100
98
|
/**
|
|
101
99
|
* Creates a new instance of the Archiver and blocks until it syncs from chain.
|
|
@@ -125,7 +123,7 @@ export class Archiver implements ArchiveSource {
|
|
|
125
123
|
config.l1Contracts.registryAddress,
|
|
126
124
|
archiverStore,
|
|
127
125
|
config.archiverPollingIntervalMS,
|
|
128
|
-
telemetry,
|
|
126
|
+
new ArchiverInstrumentation(telemetry),
|
|
129
127
|
);
|
|
130
128
|
await archiver.start(blockUntilSynced);
|
|
131
129
|
return archiver;
|
|
@@ -177,17 +175,25 @@ export class Archiver implements ArchiveSource {
|
|
|
177
175
|
*
|
|
178
176
|
* This code does not handle reorgs.
|
|
179
177
|
*/
|
|
180
|
-
const { blockBodiesSynchedTo, blocksSynchedTo, messagesSynchedTo } =
|
|
178
|
+
const { blockBodiesSynchedTo, blocksSynchedTo, messagesSynchedTo, provenLogsSynchedTo } =
|
|
179
|
+
await this.store.getSynchPoint();
|
|
181
180
|
const currentL1BlockNumber = await this.publicClient.getBlockNumber();
|
|
182
181
|
|
|
183
182
|
if (
|
|
184
183
|
currentL1BlockNumber <= blocksSynchedTo &&
|
|
185
184
|
currentL1BlockNumber <= messagesSynchedTo &&
|
|
186
|
-
currentL1BlockNumber <= blockBodiesSynchedTo
|
|
185
|
+
currentL1BlockNumber <= blockBodiesSynchedTo &&
|
|
186
|
+
currentL1BlockNumber <= provenLogsSynchedTo
|
|
187
187
|
) {
|
|
188
188
|
// chain hasn't moved forward
|
|
189
189
|
// or it's been rolled back
|
|
190
|
-
this.log.debug(`Nothing to sync`, {
|
|
190
|
+
this.log.debug(`Nothing to sync`, {
|
|
191
|
+
currentL1BlockNumber,
|
|
192
|
+
blocksSynchedTo,
|
|
193
|
+
messagesSynchedTo,
|
|
194
|
+
provenLogsSynchedTo,
|
|
195
|
+
blockBodiesSynchedTo,
|
|
196
|
+
});
|
|
191
197
|
return;
|
|
192
198
|
}
|
|
193
199
|
|
|
@@ -249,9 +255,9 @@ export class Archiver implements ArchiveSource {
|
|
|
249
255
|
);
|
|
250
256
|
await this.store.addBlockBodies(retrievedBlockBodies);
|
|
251
257
|
|
|
252
|
-
// Now that we have block bodies we will retrieve block metadata and build L2 blocks from the bodies and
|
|
253
|
-
|
|
254
|
-
let
|
|
258
|
+
// Now that we have block bodies we will retrieve block metadata and build L2 blocks from the bodies and the metadata
|
|
259
|
+
let retrievedBlocks: L1Published<L2Block>[];
|
|
260
|
+
let lastProcessedL1BlockNumber: bigint;
|
|
255
261
|
{
|
|
256
262
|
// @todo @LHerskind Investigate how necessary that nextExpectedL2BlockNum really is.
|
|
257
263
|
// Also, I would expect it to break horribly if we have a reorg.
|
|
@@ -265,9 +271,7 @@ export class Archiver implements ArchiveSource {
|
|
|
265
271
|
nextExpectedL2BlockNum,
|
|
266
272
|
);
|
|
267
273
|
|
|
268
|
-
const retrievedBodyHashes = retrievedBlockMetadata.
|
|
269
|
-
([header]) => header.contentCommitment.txsEffectsHash,
|
|
270
|
-
);
|
|
274
|
+
const retrievedBodyHashes = retrievedBlockMetadata.map(([header]) => header.contentCommitment.txsEffectsHash);
|
|
271
275
|
|
|
272
276
|
// @note @LHerskind We will occasionally be hitting this point BEFORE, we have actually retrieved the bodies.
|
|
273
277
|
// The main reason this have not been an issue earlier is because:
|
|
@@ -276,16 +280,16 @@ export class Archiver implements ArchiveSource {
|
|
|
276
280
|
// ii) We have been lucky that latency have been small enough to not matter.
|
|
277
281
|
const blockBodiesFromStore = await this.store.getBlockBodies(retrievedBodyHashes);
|
|
278
282
|
|
|
279
|
-
if (retrievedBlockMetadata.
|
|
283
|
+
if (retrievedBlockMetadata.length !== blockBodiesFromStore.length) {
|
|
280
284
|
this.log.warn('Block headers length does not equal block bodies length');
|
|
281
285
|
}
|
|
282
286
|
|
|
283
|
-
const blocks: L2Block[] = [];
|
|
284
|
-
for (let i = 0; i < retrievedBlockMetadata.
|
|
285
|
-
const [header, archive] = retrievedBlockMetadata
|
|
287
|
+
const blocks: L1Published<L2Block>[] = [];
|
|
288
|
+
for (let i = 0; i < retrievedBlockMetadata.length; i++) {
|
|
289
|
+
const [header, archive, l1] = retrievedBlockMetadata[i];
|
|
286
290
|
const blockBody = blockBodiesFromStore[i];
|
|
287
291
|
if (blockBody) {
|
|
288
|
-
blocks.push(new L2Block(archive, header, blockBody));
|
|
292
|
+
blocks.push({ data: new L2Block(archive, header, blockBody), l1 });
|
|
289
293
|
} else {
|
|
290
294
|
this.log.warn(`Block body not found for block ${header.globalVariables.blockNumber.toBigInt()}.`);
|
|
291
295
|
}
|
|
@@ -297,62 +301,63 @@ export class Archiver implements ArchiveSource {
|
|
|
297
301
|
} and ${currentL1BlockNumber}.`,
|
|
298
302
|
);
|
|
299
303
|
|
|
300
|
-
retrievedBlocks =
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
+
retrievedBlocks = blocks;
|
|
305
|
+
lastProcessedL1BlockNumber =
|
|
306
|
+
retrievedBlockMetadata.length > 0
|
|
307
|
+
? retrievedBlockMetadata[retrievedBlockMetadata.length - 1][2].blockNumber
|
|
308
|
+
: blocksSynchedTo;
|
|
304
309
|
}
|
|
305
310
|
|
|
306
311
|
this.log.debug(
|
|
307
|
-
`Processing retrieved blocks ${retrievedBlocks
|
|
308
|
-
.map(b => b.number)
|
|
309
|
-
.join(',')} with last processed L1 block ${
|
|
312
|
+
`Processing retrieved blocks ${retrievedBlocks
|
|
313
|
+
.map(b => b.data.number)
|
|
314
|
+
.join(',')} with last processed L1 block ${lastProcessedL1BlockNumber}`,
|
|
310
315
|
);
|
|
311
316
|
|
|
312
317
|
await Promise.all(
|
|
313
|
-
retrievedBlocks.
|
|
314
|
-
const noteEncryptedLogs = block.body.noteEncryptedLogs;
|
|
315
|
-
const encryptedLogs = block.body.encryptedLogs;
|
|
316
|
-
const unencryptedLogs = block.body.unencryptedLogs;
|
|
317
|
-
return this.store.addLogs(noteEncryptedLogs, encryptedLogs, unencryptedLogs, block.number);
|
|
318
|
+
retrievedBlocks.map(block => {
|
|
319
|
+
const noteEncryptedLogs = block.data.body.noteEncryptedLogs;
|
|
320
|
+
const encryptedLogs = block.data.body.encryptedLogs;
|
|
321
|
+
const unencryptedLogs = block.data.body.unencryptedLogs;
|
|
322
|
+
return this.store.addLogs(noteEncryptedLogs, encryptedLogs, unencryptedLogs, block.data.number);
|
|
318
323
|
}),
|
|
319
324
|
);
|
|
320
325
|
|
|
321
326
|
// Unroll all logs emitted during the retrieved blocks and extract any contract classes and instances from them
|
|
322
327
|
await Promise.all(
|
|
323
|
-
retrievedBlocks.
|
|
324
|
-
const blockLogs = block.body.txEffects
|
|
328
|
+
retrievedBlocks.map(async block => {
|
|
329
|
+
const blockLogs = block.data.body.txEffects
|
|
325
330
|
.flatMap(txEffect => (txEffect ? [txEffect.unencryptedLogs] : []))
|
|
326
331
|
.flatMap(txLog => txLog.unrollLogs());
|
|
327
|
-
await this.storeRegisteredContractClasses(blockLogs, block.number);
|
|
328
|
-
await this.storeDeployedContractInstances(blockLogs, block.number);
|
|
329
|
-
await this.storeBroadcastedIndividualFunctions(blockLogs, block.number);
|
|
332
|
+
await this.storeRegisteredContractClasses(blockLogs, block.data.number);
|
|
333
|
+
await this.storeDeployedContractInstances(blockLogs, block.data.number);
|
|
334
|
+
await this.storeBroadcastedIndividualFunctions(blockLogs, block.data.number);
|
|
330
335
|
}),
|
|
331
336
|
);
|
|
332
337
|
|
|
333
|
-
if (retrievedBlocks.
|
|
338
|
+
if (retrievedBlocks.length > 0) {
|
|
334
339
|
const timer = new Timer();
|
|
335
340
|
await this.store.addBlocks(retrievedBlocks);
|
|
336
341
|
this.instrumentation.processNewBlocks(
|
|
337
|
-
timer.ms() / retrievedBlocks.
|
|
338
|
-
retrievedBlocks.
|
|
342
|
+
timer.ms() / retrievedBlocks.length,
|
|
343
|
+
retrievedBlocks.map(b => b.data),
|
|
339
344
|
);
|
|
340
|
-
const lastL2BlockNumber = retrievedBlocks
|
|
341
|
-
this.log.verbose(`Processed ${retrievedBlocks.
|
|
345
|
+
const lastL2BlockNumber = retrievedBlocks[retrievedBlocks.length - 1].data.number;
|
|
346
|
+
this.log.verbose(`Processed ${retrievedBlocks.length} new L2 blocks up to ${lastL2BlockNumber}`);
|
|
342
347
|
}
|
|
343
348
|
|
|
344
349
|
// Fetch the logs for proven blocks in the block range and update the last proven block number.
|
|
345
|
-
|
|
346
|
-
|
|
350
|
+
if (currentL1BlockNumber > provenLogsSynchedTo) {
|
|
351
|
+
await this.updateLastProvenL2Block(provenLogsSynchedTo + 1n, currentL1BlockNumber);
|
|
352
|
+
}
|
|
347
353
|
|
|
348
|
-
if (retrievedBlocks.
|
|
354
|
+
if (retrievedBlocks.length > 0 || blockUntilSynced) {
|
|
349
355
|
(blockUntilSynced ? this.log.info : this.log.verbose)(`Synced to L1 block ${currentL1BlockNumber}`);
|
|
350
356
|
}
|
|
351
357
|
}
|
|
352
358
|
|
|
353
359
|
private async updateLastProvenL2Block(fromBlock: bigint, toBlock: bigint) {
|
|
354
360
|
const logs = await retrieveL2ProofVerifiedEvents(this.publicClient, this.rollupAddress, fromBlock, toBlock);
|
|
355
|
-
|
|
356
361
|
const lastLog = logs[logs.length - 1];
|
|
357
362
|
if (!lastLog) {
|
|
358
363
|
return;
|
|
@@ -363,14 +368,71 @@ export class Archiver implements ArchiveSource {
|
|
|
363
368
|
throw new Error(`Missing argument blockNumber from L2ProofVerified event`);
|
|
364
369
|
}
|
|
365
370
|
|
|
371
|
+
await this.emitProofVerifiedMetrics(logs);
|
|
372
|
+
|
|
366
373
|
const currentProvenBlockNumber = await this.store.getProvenL2BlockNumber();
|
|
367
374
|
if (provenBlockNumber > currentProvenBlockNumber) {
|
|
375
|
+
// Update the last proven block number
|
|
368
376
|
this.log.verbose(`Updated last proven block number from ${currentProvenBlockNumber} to ${provenBlockNumber}`);
|
|
369
|
-
await this.store.setProvenL2BlockNumber(
|
|
377
|
+
await this.store.setProvenL2BlockNumber({
|
|
378
|
+
retrievedData: Number(provenBlockNumber),
|
|
379
|
+
lastProcessedL1BlockNumber: lastLog.l1BlockNumber,
|
|
380
|
+
});
|
|
370
381
|
this.instrumentation.updateLastProvenBlock(Number(provenBlockNumber));
|
|
382
|
+
} else {
|
|
383
|
+
// We set the last processed L1 block number to the last L1 block number in the range to avoid duplicate processing
|
|
384
|
+
await this.store.setProvenL2BlockNumber({
|
|
385
|
+
retrievedData: Number(currentProvenBlockNumber),
|
|
386
|
+
lastProcessedL1BlockNumber: lastLog.l1BlockNumber,
|
|
387
|
+
});
|
|
371
388
|
}
|
|
372
389
|
}
|
|
373
390
|
|
|
391
|
+
/**
|
|
392
|
+
* Emits as metrics the block number proven, who proved it, and how much time passed since it was submitted.
|
|
393
|
+
* @param logs - The ProofVerified logs to emit metrics for, as collected from `retrieveL2ProofVerifiedEvents`.
|
|
394
|
+
**/
|
|
395
|
+
private async emitProofVerifiedMetrics(logs: { l1BlockNumber: bigint; l2BlockNumber: bigint; proverId: Fr }[]) {
|
|
396
|
+
if (!logs.length || !this.instrumentation.isEnabled()) {
|
|
397
|
+
return;
|
|
398
|
+
}
|
|
399
|
+
|
|
400
|
+
const l1BlockTimes = new Map(
|
|
401
|
+
await Promise.all(
|
|
402
|
+
unique(logs.map(log => log.l1BlockNumber)).map(
|
|
403
|
+
async blockNumber => [blockNumber, await getL1BlockTime(this.publicClient, blockNumber)] as const,
|
|
404
|
+
),
|
|
405
|
+
),
|
|
406
|
+
);
|
|
407
|
+
|
|
408
|
+
// Collect L2 block times for all the blocks verified, this is the time in which the block proven was
|
|
409
|
+
// originally submitted to L1, using the L1 timestamp of the transaction.
|
|
410
|
+
const getL2BlockTime = async (blockNumber: bigint) =>
|
|
411
|
+
(await this.store.getBlocks(Number(blockNumber), 1))[0]?.l1.timestamp;
|
|
412
|
+
|
|
413
|
+
const l2BlockTimes = new Map(
|
|
414
|
+
await Promise.all(
|
|
415
|
+
unique(logs.map(log => log.l2BlockNumber)).map(
|
|
416
|
+
async blockNumber => [blockNumber, await getL2BlockTime(blockNumber)] as const,
|
|
417
|
+
),
|
|
418
|
+
),
|
|
419
|
+
);
|
|
420
|
+
|
|
421
|
+
// Emit the prover id and the time difference between block submission and proof.
|
|
422
|
+
this.instrumentation.processProofsVerified(
|
|
423
|
+
compactArray(
|
|
424
|
+
logs.map(log => {
|
|
425
|
+
const l1BlockTime = l1BlockTimes.get(log.l1BlockNumber)!;
|
|
426
|
+
const l2BlockTime = l2BlockTimes.get(log.l2BlockNumber);
|
|
427
|
+
if (!l2BlockTime) {
|
|
428
|
+
return undefined;
|
|
429
|
+
}
|
|
430
|
+
return { ...log, delay: l1BlockTime - l2BlockTime, proverId: log.proverId.toString() };
|
|
431
|
+
}),
|
|
432
|
+
),
|
|
433
|
+
);
|
|
434
|
+
}
|
|
435
|
+
|
|
374
436
|
/**
|
|
375
437
|
* Extracts and stores contract classes out of ContractClassRegistered events emitted by the class registerer contract.
|
|
376
438
|
* @param allLogs - All logs emitted in a bunch of blocks.
|
|
@@ -469,7 +531,7 @@ export class Archiver implements ArchiveSource {
|
|
|
469
531
|
const limitWithProven = proven
|
|
470
532
|
? Math.min(limit, Math.max((await this.store.getProvenL2BlockNumber()) - from + 1, 0))
|
|
471
533
|
: limit;
|
|
472
|
-
return limitWithProven === 0 ? [] : this.store.getBlocks(from, limitWithProven);
|
|
534
|
+
return limitWithProven === 0 ? [] : (await this.store.getBlocks(from, limitWithProven)).map(b => b.data);
|
|
473
535
|
}
|
|
474
536
|
|
|
475
537
|
/**
|
|
@@ -483,7 +545,7 @@ export class Archiver implements ArchiveSource {
|
|
|
483
545
|
number = await this.store.getSynchedL2BlockNumber();
|
|
484
546
|
}
|
|
485
547
|
const blocks = await this.store.getBlocks(number, 1);
|
|
486
|
-
return blocks.length === 0 ? undefined : blocks[0];
|
|
548
|
+
return blocks.length === 0 ? undefined : blocks[0].data;
|
|
487
549
|
}
|
|
488
550
|
|
|
489
551
|
public getTxEffect(txHash: TxHash): Promise<TxEffect | undefined> {
|
|
@@ -552,7 +614,7 @@ export class Archiver implements ArchiveSource {
|
|
|
552
614
|
}
|
|
553
615
|
|
|
554
616
|
/** Forcefully updates the last proven block number. Use for testing. */
|
|
555
|
-
public setProvenBlockNumber(block: number): Promise<void> {
|
|
617
|
+
public setProvenBlockNumber(block: SingletonDataRetrieval<number>): Promise<void> {
|
|
556
618
|
return this.store.setProvenL2BlockNumber(block);
|
|
557
619
|
}
|
|
558
620
|
|
|
@@ -24,7 +24,8 @@ import {
|
|
|
24
24
|
type UnconstrainedFunctionWithMembershipProof,
|
|
25
25
|
} from '@aztec/types/contracts';
|
|
26
26
|
|
|
27
|
-
import { type DataRetrieval } from './data_retrieval.js';
|
|
27
|
+
import { type DataRetrieval, type SingletonDataRetrieval } from './structs/data_retrieval.js';
|
|
28
|
+
import { type L1Published } from './structs/published.js';
|
|
28
29
|
|
|
29
30
|
/**
|
|
30
31
|
* Represents the latest L1 block processed by the archiver for various objects in L2.
|
|
@@ -36,6 +37,8 @@ export type ArchiverL1SynchPoint = {
|
|
|
36
37
|
blockBodiesSynchedTo: bigint;
|
|
37
38
|
/** Number of the last L1 block that added L1 -> L2 messages from the Inbox. */
|
|
38
39
|
messagesSynchedTo: bigint;
|
|
40
|
+
/** Number of the last L1 block that added a new proven block. */
|
|
41
|
+
provenLogsSynchedTo: bigint;
|
|
39
42
|
};
|
|
40
43
|
|
|
41
44
|
/**
|
|
@@ -48,7 +51,7 @@ export interface ArchiverDataStore {
|
|
|
48
51
|
* @param blocks - The L2 blocks to be added to the store and the last processed L1 block.
|
|
49
52
|
* @returns True if the operation is successful.
|
|
50
53
|
*/
|
|
51
|
-
addBlocks(blocks:
|
|
54
|
+
addBlocks(blocks: L1Published<L2Block>[]): Promise<boolean>;
|
|
52
55
|
|
|
53
56
|
/**
|
|
54
57
|
* Append new block bodies to the store's list.
|
|
@@ -71,7 +74,7 @@ export interface ArchiverDataStore {
|
|
|
71
74
|
* @param limit - The number of blocks to return.
|
|
72
75
|
* @returns The requested L2 blocks.
|
|
73
76
|
*/
|
|
74
|
-
getBlocks(from: number, limit: number): Promise<L2Block[]>;
|
|
77
|
+
getBlocks(from: number, limit: number): Promise<L1Published<L2Block>[]>;
|
|
75
78
|
|
|
76
79
|
/**
|
|
77
80
|
* Gets a tx effect.
|
|
@@ -160,7 +163,7 @@ export interface ArchiverDataStore {
|
|
|
160
163
|
* Stores the number of the latest proven L2 block processed.
|
|
161
164
|
* @param l2BlockNumber - The number of the latest proven L2 block processed.
|
|
162
165
|
*/
|
|
163
|
-
setProvenL2BlockNumber(l2BlockNumber: number): Promise<void>;
|
|
166
|
+
setProvenL2BlockNumber(l2BlockNumber: SingletonDataRetrieval<number>): Promise<void>;
|
|
164
167
|
|
|
165
168
|
/**
|
|
166
169
|
* Gets the synch point of the archiver
|