@aztec/archiver 0.76.4 → 0.77.0-testnet-ignition.21
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 +22 -10
- package/dest/archiver/archiver.d.ts.map +1 -1
- package/dest/archiver/archiver.js +762 -713
- package/dest/archiver/archiver_store.d.ts +20 -7
- package/dest/archiver/archiver_store.d.ts.map +1 -1
- package/dest/archiver/archiver_store.js +4 -2
- package/dest/archiver/archiver_store_test_suite.d.ts +2 -2
- package/dest/archiver/archiver_store_test_suite.d.ts.map +1 -1
- package/dest/archiver/archiver_store_test_suite.js +398 -227
- package/dest/archiver/config.d.ts +1 -1
- package/dest/archiver/config.d.ts.map +1 -1
- package/dest/archiver/config.js +10 -12
- package/dest/archiver/data_retrieval.d.ts +17 -14
- package/dest/archiver/data_retrieval.d.ts.map +1 -1
- package/dest/archiver/data_retrieval.js +90 -88
- package/dest/archiver/errors.js +1 -2
- package/dest/archiver/index.d.ts +1 -1
- package/dest/archiver/index.d.ts.map +1 -1
- package/dest/archiver/index.js +0 -1
- package/dest/archiver/instrumentation.d.ts +3 -1
- package/dest/archiver/instrumentation.d.ts.map +1 -1
- package/dest/archiver/instrumentation.js +37 -17
- package/dest/archiver/kv_archiver_store/block_store.d.ts +5 -3
- package/dest/archiver/kv_archiver_store/block_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/block_store.js +125 -130
- package/dest/archiver/kv_archiver_store/contract_class_store.d.ts +2 -1
- package/dest/archiver/kv_archiver_store/contract_class_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/contract_class_store.js +45 -37
- package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts +10 -2
- package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/contract_instance_store.js +54 -15
- package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts +16 -9
- package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/kv_archiver_store.js +143 -160
- package/dest/archiver/kv_archiver_store/log_store.d.ts +5 -3
- package/dest/archiver/kv_archiver_store/log_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/log_store.js +296 -255
- package/dest/archiver/kv_archiver_store/message_store.d.ts +3 -3
- package/dest/archiver/kv_archiver_store/message_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/message_store.js +45 -50
- package/dest/archiver/kv_archiver_store/nullifier_store.d.ts +2 -2
- package/dest/archiver/kv_archiver_store/nullifier_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/nullifier_store.js +36 -43
- package/dest/archiver/memory_archiver_store/l1_to_l2_message_store.d.ts +2 -2
- package/dest/archiver/memory_archiver_store/l1_to_l2_message_store.d.ts.map +1 -1
- package/dest/archiver/memory_archiver_store/l1_to_l2_message_store.js +17 -26
- package/dest/archiver/memory_archiver_store/memory_archiver_store.d.ts +16 -7
- package/dest/archiver/memory_archiver_store/memory_archiver_store.d.ts.map +1 -1
- package/dest/archiver/memory_archiver_store/memory_archiver_store.js +287 -247
- package/dest/archiver/structs/data_retrieval.js +5 -2
- package/dest/archiver/structs/published.js +1 -2
- package/dest/factory.d.ts +20 -6
- package/dest/factory.d.ts.map +1 -1
- package/dest/factory.js +54 -30
- package/dest/index.js +0 -1
- package/dest/rpc/index.d.ts +2 -1
- package/dest/rpc/index.d.ts.map +1 -1
- package/dest/rpc/index.js +8 -4
- package/dest/test/index.js +0 -1
- package/dest/test/mock_archiver.d.ts +3 -2
- package/dest/test/mock_archiver.d.ts.map +1 -1
- package/dest/test/mock_archiver.js +8 -13
- package/dest/test/mock_l1_to_l2_message_source.d.ts +2 -2
- package/dest/test/mock_l1_to_l2_message_source.d.ts.map +1 -1
- package/dest/test/mock_l1_to_l2_message_source.js +4 -4
- package/dest/test/mock_l2_block_source.d.ts +5 -3
- package/dest/test/mock_l2_block_source.d.ts.map +1 -1
- package/dest/test/mock_l2_block_source.js +71 -68
- package/package.json +15 -16
- package/src/archiver/archiver.ts +149 -89
- package/src/archiver/archiver_store.ts +27 -27
- package/src/archiver/archiver_store_test_suite.ts +22 -15
- package/src/archiver/config.ts +1 -1
- package/src/archiver/data_retrieval.ts +32 -44
- package/src/archiver/index.ts +1 -1
- package/src/archiver/instrumentation.ts +11 -1
- package/src/archiver/kv_archiver_store/block_store.ts +10 -4
- package/src/archiver/kv_archiver_store/contract_class_store.ts +9 -9
- package/src/archiver/kv_archiver_store/contract_instance_store.ts +81 -3
- package/src/archiver/kv_archiver_store/kv_archiver_store.ts +44 -29
- package/src/archiver/kv_archiver_store/log_store.ts +56 -32
- package/src/archiver/kv_archiver_store/message_store.ts +4 -3
- package/src/archiver/kv_archiver_store/nullifier_store.ts +3 -2
- package/src/archiver/memory_archiver_store/l1_to_l2_message_store.ts +3 -3
- package/src/archiver/memory_archiver_store/memory_archiver_store.ts +110 -57
- package/src/factory.ts +44 -25
- package/src/rpc/index.ts +2 -6
- package/src/test/mock_archiver.ts +3 -2
- package/src/test/mock_l1_to_l2_message_source.ts +2 -2
- package/src/test/mock_l2_block_source.ts +16 -15
|
@@ -1,43 +1,59 @@
|
|
|
1
1
|
import { createLogger } from '@aztec/foundation/log';
|
|
2
|
-
import { Attributes, LmdbMetrics, Metrics, ValueType
|
|
2
|
+
import { Attributes, LmdbMetrics, Metrics, ValueType } from '@aztec/telemetry-client';
|
|
3
3
|
export class ArchiverInstrumentation {
|
|
4
|
-
|
|
4
|
+
telemetry;
|
|
5
|
+
tracer;
|
|
6
|
+
blockHeight;
|
|
7
|
+
txCount;
|
|
8
|
+
syncDuration;
|
|
9
|
+
l1BlocksSynced;
|
|
10
|
+
l1BlockHeight;
|
|
11
|
+
proofsSubmittedDelay;
|
|
12
|
+
proofsSubmittedCount;
|
|
13
|
+
dbMetrics;
|
|
14
|
+
pruneCount;
|
|
15
|
+
log;
|
|
16
|
+
constructor(telemetry, lmdbStats){
|
|
5
17
|
this.telemetry = telemetry;
|
|
6
18
|
this.log = createLogger('archiver:instrumentation');
|
|
7
19
|
this.tracer = telemetry.getTracer('Archiver');
|
|
8
20
|
const meter = telemetry.getMeter('Archiver');
|
|
9
21
|
this.blockHeight = meter.createGauge(Metrics.ARCHIVER_BLOCK_HEIGHT, {
|
|
10
22
|
description: 'The height of the latest block processed by the archiver',
|
|
11
|
-
valueType: ValueType.INT
|
|
23
|
+
valueType: ValueType.INT
|
|
12
24
|
});
|
|
13
25
|
this.txCount = meter.createUpDownCounter(Metrics.ARCHIVER_TX_COUNT, {
|
|
14
26
|
description: 'The total number of transactions',
|
|
15
|
-
valueType: ValueType.INT
|
|
27
|
+
valueType: ValueType.INT
|
|
16
28
|
});
|
|
17
29
|
this.syncDuration = meter.createHistogram(Metrics.ARCHIVER_SYNC_DURATION, {
|
|
18
30
|
unit: 'ms',
|
|
19
31
|
description: 'Duration to sync a block',
|
|
20
|
-
valueType: ValueType.INT
|
|
32
|
+
valueType: ValueType.INT
|
|
21
33
|
});
|
|
22
34
|
this.proofsSubmittedCount = meter.createUpDownCounter(Metrics.ARCHIVER_ROLLUP_PROOF_COUNT, {
|
|
23
35
|
description: 'Number of proofs submitted',
|
|
24
|
-
valueType: ValueType.INT
|
|
36
|
+
valueType: ValueType.INT
|
|
25
37
|
});
|
|
26
38
|
this.proofsSubmittedDelay = meter.createHistogram(Metrics.ARCHIVER_ROLLUP_PROOF_DELAY, {
|
|
27
39
|
unit: 'ms',
|
|
28
40
|
description: 'Time after a block is submitted until its proof is published',
|
|
29
|
-
valueType: ValueType.INT
|
|
41
|
+
valueType: ValueType.INT
|
|
30
42
|
});
|
|
31
43
|
this.l1BlocksSynced = meter.createUpDownCounter(Metrics.ARCHIVER_L1_BLOCKS_SYNCED, {
|
|
32
44
|
description: 'Number of blocks synced from L1',
|
|
33
|
-
valueType: ValueType.INT
|
|
45
|
+
valueType: ValueType.INT
|
|
46
|
+
});
|
|
47
|
+
this.l1BlockHeight = meter.createGauge(Metrics.ARCHIVER_L1_BLOCK_HEIGHT, {
|
|
48
|
+
description: 'The height of the latest L1 block processed by the archiver',
|
|
49
|
+
valueType: ValueType.INT
|
|
34
50
|
});
|
|
35
51
|
this.dbMetrics = new LmdbMetrics(meter, {
|
|
36
|
-
[Attributes.DB_DATA_TYPE]: 'archiver'
|
|
52
|
+
[Attributes.DB_DATA_TYPE]: 'archiver'
|
|
37
53
|
}, lmdbStats);
|
|
38
54
|
this.pruneCount = meter.createUpDownCounter(Metrics.ARCHIVER_PRUNE_COUNT, {
|
|
39
55
|
description: 'Number of prunes detected',
|
|
40
|
-
valueType: ValueType.INT
|
|
56
|
+
valueType: ValueType.INT
|
|
41
57
|
});
|
|
42
58
|
}
|
|
43
59
|
static async new(telemetry, lmdbStats) {
|
|
@@ -51,9 +67,9 @@ export class ArchiverInstrumentation {
|
|
|
51
67
|
}
|
|
52
68
|
processNewBlocks(syncTimePerBlock, blocks) {
|
|
53
69
|
this.syncDuration.record(Math.ceil(syncTimePerBlock));
|
|
54
|
-
this.blockHeight.record(Math.max(...blocks.map(b
|
|
70
|
+
this.blockHeight.record(Math.max(...blocks.map((b)=>b.number)));
|
|
55
71
|
this.l1BlocksSynced.add(blocks.length);
|
|
56
|
-
for (const block of blocks)
|
|
72
|
+
for (const block of blocks){
|
|
57
73
|
this.txCount.add(block.body.txEffects.length);
|
|
58
74
|
}
|
|
59
75
|
}
|
|
@@ -61,19 +77,23 @@ export class ArchiverInstrumentation {
|
|
|
61
77
|
this.pruneCount.add(1);
|
|
62
78
|
}
|
|
63
79
|
updateLastProvenBlock(blockNumber) {
|
|
64
|
-
this.blockHeight.record(blockNumber, {
|
|
80
|
+
this.blockHeight.record(blockNumber, {
|
|
81
|
+
[Attributes.STATUS]: 'proven'
|
|
82
|
+
});
|
|
65
83
|
}
|
|
66
84
|
processProofsVerified(logs) {
|
|
67
|
-
for (const log of logs)
|
|
85
|
+
for (const log of logs){
|
|
68
86
|
this.log.debug('Recording proof verified event', log);
|
|
69
87
|
this.proofsSubmittedCount.add(1, {
|
|
70
88
|
[Attributes.ROLLUP_PROVER_ID]: log.proverId,
|
|
71
|
-
[Attributes.PROOF_TIMED_OUT]: log.delay > 20n * 60n * 1000n
|
|
89
|
+
[Attributes.PROOF_TIMED_OUT]: log.delay > 20n * 60n * 1000n
|
|
72
90
|
});
|
|
73
91
|
this.proofsSubmittedDelay.record(Math.ceil(Number(log.delay)), {
|
|
74
|
-
[Attributes.ROLLUP_PROVER_ID]: log.proverId
|
|
92
|
+
[Attributes.ROLLUP_PROVER_ID]: log.proverId
|
|
75
93
|
});
|
|
76
94
|
}
|
|
77
95
|
}
|
|
96
|
+
updateL1BlockHeight(blockNumber) {
|
|
97
|
+
this.l1BlockHeight.record(Number(blockNumber));
|
|
98
|
+
}
|
|
78
99
|
}
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5zdHJ1bWVudGF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FyY2hpdmVyL2luc3RydW1lbnRhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDckQsT0FBTyxFQUNMLFVBQVUsRUFHVixXQUFXLEVBRVgsT0FBTyxFQUlQLFNBQVMsR0FDVixNQUFNLHlCQUF5QixDQUFDO0FBRWpDLE1BQU0sT0FBTyx1QkFBdUI7SUFjbEMsWUFBNEIsU0FBMEIsRUFBRSxTQUE2QjtRQUF6RCxjQUFTLEdBQVQsU0FBUyxDQUFpQjtRQUY5QyxRQUFHLEdBQUcsWUFBWSxDQUFDLDBCQUEwQixDQUFDLENBQUM7UUFHckQsSUFBSSxDQUFDLE1BQU0sR0FBRyxTQUFTLENBQUMsU0FBUyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQzlDLE1BQU0sS0FBSyxHQUFHLFNBQVMsQ0FBQyxRQUFRLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDN0MsSUFBSSxDQUFDLFdBQVcsR0FBRyxLQUFLLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxxQkFBcUIsRUFBRTtZQUNsRSxXQUFXLEVBQUUsMERBQTBEO1lBQ3ZFLFNBQVMsRUFBRSxTQUFTLENBQUMsR0FBRztTQUN6QixDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsT0FBTyxHQUFHLEtBQUssQ0FBQyxtQkFBbUIsQ0FBQyxPQUFPLENBQUMsaUJBQWlCLEVBQUU7WUFDbEUsV0FBVyxFQUFFLGtDQUFrQztZQUMvQyxTQUFTLEVBQUUsU0FBUyxDQUFDLEdBQUc7U0FDekIsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLFlBQVksR0FBRyxLQUFLLENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxzQkFBc0IsRUFBRTtZQUN4RSxJQUFJLEVBQUUsSUFBSTtZQUNWLFdBQVcsRUFBRSwwQkFBMEI7WUFDdkMsU0FBUyxFQUFFLFNBQVMsQ0FBQyxH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
|
|
@@ -1,7 +1,9 @@
|
|
|
1
|
-
import { type InBlock, L2Block, type TxEffect, type TxHash, TxReceipt } from '@aztec/circuit-types';
|
|
2
|
-
import { type AztecAddress, BlockHeader } from '@aztec/circuits.js';
|
|
3
1
|
import type { AztecAsyncKVStore } from '@aztec/kv-store';
|
|
4
|
-
import {
|
|
2
|
+
import type { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
3
|
+
import { type InBlock, L2Block } from '@aztec/stdlib/block';
|
|
4
|
+
import { BlockHeader, TxEffect, TxHash, TxReceipt } from '@aztec/stdlib/tx';
|
|
5
|
+
import type { L1Published } from '../structs/published.js';
|
|
6
|
+
export { type TxEffect, type TxHash, TxReceipt } from '@aztec/stdlib/tx';
|
|
5
7
|
/**
|
|
6
8
|
* LMDB implementation of the ArchiverDataStore interface.
|
|
7
9
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"block_store.d.ts","sourceRoot":"","sources":["../../../src/archiver/kv_archiver_store/block_store.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"block_store.d.ts","sourceRoot":"","sources":["../../../src/archiver/kv_archiver_store/block_store.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,iBAAiB,EAA6C,MAAM,iBAAiB,CAAC;AACpG,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAChE,OAAO,EAAQ,KAAK,OAAO,EAAE,OAAO,EAAe,MAAM,qBAAqB,CAAC;AAE/E,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAE5E,OAAO,KAAK,EAAE,WAAW,EAAmB,MAAM,yBAAyB,CAAC;AAE5E,OAAO,EAAE,KAAK,QAAQ,EAAE,KAAK,MAAM,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAUzE;;GAEG;AACH,qBAAa,UAAU;;IAwBT,OAAO,CAAC,EAAE;gBAAF,EAAE,EAAE,iBAAiB;IAUzC;;;;OAIG;IACG,SAAS,CAAC,MAAM,EAAE,WAAW,CAAC,OAAO,CAAC,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC;IA0BjE;;;;;;OAMG;IACG,YAAY,CAAC,IAAI,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM;IA0BvD;;;;;OAKG;IACI,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,qBAAqB,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;IAO3F;;;;OAIG;IACG,QAAQ,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,SAAS,CAAC;IAS9E;;;;;OAKG;IACI,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,qBAAqB,CAAC,WAAW,CAAC;YAM1E,wBAAwB;IAgBtC;;;;OAIG;IACG,WAAW,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,SAAS,CAAC;IAkBzE;;;;OAIG;IACG,mBAAmB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,GAAG,SAAS,CAAC;IAmBzE;;;;OAIG;IACH,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,WAAW,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,GAAG,SAAS,CAAC;IAI1F;;;;OAIG;IACH,mBAAmB,CAAC,eAAe,EAAE,YAAY,GAAG,OAAO,CAAC,CAAC,WAAW,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,GAAG,SAAS,CAAC;IAI7G;;;OAGG;IACG,uBAAuB,IAAI,OAAO,CAAC,MAAM,CAAC;IAKhD;;;OAGG;IACH,uBAAuB,IAAI,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC;IAItD,uBAAuB,CAAC,aAAa,EAAE,MAAM;IAIvC,sBAAsB,IAAI,OAAO,CAAC,MAAM,CAAC;IAI/C,sBAAsB,CAAC,WAAW,EAAE,MAAM;IAI1C,sBAAsB,IAAI,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC;IAIrD,sBAAsB,CAAC,WAAW,EAAE,MAAM;CAe3C"}
|
|
@@ -1,125 +1,118 @@
|
|
|
1
|
-
|
|
2
|
-
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
|
-
import { Body, L2Block, L2BlockHash, TxReceipt } from '@aztec/circuit-types';
|
|
4
|
-
import { AppendOnlyTreeSnapshot, BlockHeader, INITIAL_L2_BLOCK_NUM } from '@aztec/circuits.js';
|
|
1
|
+
import { INITIAL_L2_BLOCK_NUM } from '@aztec/constants';
|
|
5
2
|
import { toArray } from '@aztec/foundation/iterable';
|
|
6
3
|
import { createLogger } from '@aztec/foundation/log';
|
|
4
|
+
import { Body, L2Block, L2BlockHash } from '@aztec/stdlib/block';
|
|
5
|
+
import { AppendOnlyTreeSnapshot } from '@aztec/stdlib/trees';
|
|
6
|
+
import { BlockHeader, TxReceipt } from '@aztec/stdlib/tx';
|
|
7
|
+
export { TxReceipt } from '@aztec/stdlib/tx';
|
|
7
8
|
/**
|
|
8
9
|
* LMDB implementation of the ArchiverDataStore interface.
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
10
|
+
*/ export class BlockStore {
|
|
11
|
+
db;
|
|
12
|
+
/** Map block number to block data */ #blocks;
|
|
13
|
+
/** Map block hash to block body */ #blockBodies;
|
|
14
|
+
/** Stores L1 block number in which the last processed L2 block was included */ #lastSynchedL1Block;
|
|
15
|
+
/** Stores l2 block number of the last proven block */ #lastProvenL2Block;
|
|
16
|
+
/** Stores l2 epoch number of the last proven epoch */ #lastProvenL2Epoch;
|
|
17
|
+
/** Index mapping transaction hash (as a string) to its location in a block */ #txIndex;
|
|
18
|
+
/** Index mapping a contract's address (as a string) to its location in a block */ #contractIndex;
|
|
19
|
+
#log;
|
|
20
|
+
constructor(db){
|
|
13
21
|
this.db = db;
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
/** Stores l2 epoch number of the last proven epoch */
|
|
23
|
-
_BlockStore_lastProvenL2Epoch.set(this, void 0);
|
|
24
|
-
/** Index mapping transaction hash (as a string) to its location in a block */
|
|
25
|
-
_BlockStore_txIndex.set(this, void 0);
|
|
26
|
-
/** Index mapping a contract's address (as a string) to its location in a block */
|
|
27
|
-
_BlockStore_contractIndex.set(this, void 0);
|
|
28
|
-
_BlockStore_log.set(this, createLogger('archiver:block_store'));
|
|
29
|
-
__classPrivateFieldSet(this, _BlockStore_blocks, db.openMap('archiver_blocks'), "f");
|
|
30
|
-
__classPrivateFieldSet(this, _BlockStore_blockBodies, db.openMap('archiver_block_bodies'), "f");
|
|
31
|
-
__classPrivateFieldSet(this, _BlockStore_txIndex, db.openMap('archiver_tx_index'), "f");
|
|
32
|
-
__classPrivateFieldSet(this, _BlockStore_contractIndex, db.openMap('archiver_contract_index'), "f");
|
|
33
|
-
__classPrivateFieldSet(this, _BlockStore_lastSynchedL1Block, db.openSingleton('archiver_last_synched_l1_block'), "f");
|
|
34
|
-
__classPrivateFieldSet(this, _BlockStore_lastProvenL2Block, db.openSingleton('archiver_last_proven_l2_block'), "f");
|
|
35
|
-
__classPrivateFieldSet(this, _BlockStore_lastProvenL2Epoch, db.openSingleton('archiver_last_proven_l2_epoch'), "f");
|
|
22
|
+
this.#log = createLogger('archiver:block_store');
|
|
23
|
+
this.#blocks = db.openMap('archiver_blocks');
|
|
24
|
+
this.#blockBodies = db.openMap('archiver_block_bodies');
|
|
25
|
+
this.#txIndex = db.openMap('archiver_tx_index');
|
|
26
|
+
this.#contractIndex = db.openMap('archiver_contract_index');
|
|
27
|
+
this.#lastSynchedL1Block = db.openSingleton('archiver_last_synched_l1_block');
|
|
28
|
+
this.#lastProvenL2Block = db.openSingleton('archiver_last_proven_l2_block');
|
|
29
|
+
this.#lastProvenL2Epoch = db.openSingleton('archiver_last_proven_l2_epoch');
|
|
36
30
|
}
|
|
37
31
|
/**
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
async addBlocks(blocks) {
|
|
32
|
+
* Append new blocks to the store's list.
|
|
33
|
+
* @param blocks - The L2 blocks to be added to the store.
|
|
34
|
+
* @returns True if the operation is successful.
|
|
35
|
+
*/ async addBlocks(blocks) {
|
|
43
36
|
if (blocks.length === 0) {
|
|
44
37
|
return true;
|
|
45
38
|
}
|
|
46
|
-
return await this.db.transactionAsync(async ()
|
|
47
|
-
for (const block of blocks)
|
|
48
|
-
await
|
|
39
|
+
return await this.db.transactionAsync(async ()=>{
|
|
40
|
+
for (const block of blocks){
|
|
41
|
+
await this.#blocks.set(block.data.number, {
|
|
49
42
|
header: block.data.header.toBuffer(),
|
|
50
43
|
archive: block.data.archive.toBuffer(),
|
|
51
|
-
l1: block.l1
|
|
44
|
+
l1: block.l1
|
|
52
45
|
});
|
|
53
|
-
for
|
|
46
|
+
for(let i = 0; i < block.data.body.txEffects.length; i++){
|
|
54
47
|
const txEffect = block.data.body.txEffects[i];
|
|
55
|
-
await
|
|
48
|
+
await this.#txIndex.set(txEffect.txHash.toString(), [
|
|
49
|
+
block.data.number,
|
|
50
|
+
i
|
|
51
|
+
]);
|
|
56
52
|
}
|
|
57
|
-
await
|
|
53
|
+
await this.#blockBodies.set((await block.data.hash()).toString(), block.data.body.toBuffer());
|
|
58
54
|
}
|
|
59
|
-
await
|
|
55
|
+
await this.#lastSynchedL1Block.set(blocks[blocks.length - 1].l1.blockNumber);
|
|
60
56
|
return true;
|
|
61
57
|
});
|
|
62
58
|
}
|
|
63
59
|
/**
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
return await this.db.transactionAsync(async () => {
|
|
60
|
+
* Unwinds blocks from the database
|
|
61
|
+
* @param from - The tip of the chain, passed for verification purposes,
|
|
62
|
+
* ensuring that we don't end up deleting something we did not intend
|
|
63
|
+
* @param blocksToUnwind - The number of blocks we are to unwind
|
|
64
|
+
* @returns True if the operation is successful
|
|
65
|
+
*/ async unwindBlocks(from, blocksToUnwind) {
|
|
66
|
+
return await this.db.transactionAsync(async ()=>{
|
|
72
67
|
const last = await this.getSynchedL2BlockNumber();
|
|
73
68
|
if (from !== last) {
|
|
74
69
|
throw new Error(`Can only unwind blocks from the tip (requested ${from} but current tip is ${last})`);
|
|
75
70
|
}
|
|
76
|
-
for
|
|
71
|
+
for(let i = 0; i < blocksToUnwind; i++){
|
|
77
72
|
const blockNumber = from - i;
|
|
78
73
|
const block = await this.getBlock(blockNumber);
|
|
79
74
|
if (block === undefined) {
|
|
80
|
-
|
|
75
|
+
this.#log.warn(`Cannot remove block ${blockNumber} from the store since we don't have it`);
|
|
76
|
+
continue;
|
|
81
77
|
}
|
|
82
|
-
await
|
|
83
|
-
await Promise.all(block.data.body.txEffects.map(tx
|
|
78
|
+
await this.#blocks.delete(block.data.number);
|
|
79
|
+
await Promise.all(block.data.body.txEffects.map((tx)=>this.#txIndex.delete(tx.txHash.toString())));
|
|
84
80
|
const blockHash = (await block.data.hash()).toString();
|
|
85
|
-
await
|
|
86
|
-
|
|
81
|
+
await this.#blockBodies.delete(blockHash);
|
|
82
|
+
this.#log.debug(`Unwound block ${blockNumber} ${blockHash}`);
|
|
87
83
|
}
|
|
88
84
|
return true;
|
|
89
85
|
});
|
|
90
86
|
}
|
|
91
87
|
/**
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
for await (const blockStorage of __classPrivateFieldGet(this, _BlockStore_blocks, "f").valuesAsync(__classPrivateFieldGet(this, _BlockStore_instances, "m", _BlockStore_computeBlockRange).call(this, start, limit))) {
|
|
88
|
+
* Gets up to `limit` amount of L2 blocks starting from `from`.
|
|
89
|
+
* @param start - Number of the first block to return (inclusive).
|
|
90
|
+
* @param limit - The number of blocks to return.
|
|
91
|
+
* @returns The requested L2 blocks
|
|
92
|
+
*/ async *getBlocks(start, limit) {
|
|
93
|
+
for await (const blockStorage of this.#blocks.valuesAsync(this.#computeBlockRange(start, limit))){
|
|
99
94
|
const block = await this.getBlockFromBlockStorage(blockStorage);
|
|
100
95
|
yield block;
|
|
101
96
|
}
|
|
102
97
|
}
|
|
103
98
|
/**
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
const blockStorage = await __classPrivateFieldGet(this, _BlockStore_blocks, "f").getAsync(blockNumber);
|
|
99
|
+
* Gets an L2 block.
|
|
100
|
+
* @param blockNumber - The number of the block to return.
|
|
101
|
+
* @returns The requested L2 block.
|
|
102
|
+
*/ async getBlock(blockNumber) {
|
|
103
|
+
const blockStorage = await this.#blocks.getAsync(blockNumber);
|
|
110
104
|
if (!blockStorage || !blockStorage.header) {
|
|
111
105
|
return Promise.resolve(undefined);
|
|
112
106
|
}
|
|
113
107
|
return this.getBlockFromBlockStorage(blockStorage);
|
|
114
108
|
}
|
|
115
109
|
/**
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
for await (const blockStorage of __classPrivateFieldGet(this, _BlockStore_blocks, "f").valuesAsync(__classPrivateFieldGet(this, _BlockStore_instances, "m", _BlockStore_computeBlockRange).call(this, start, limit))) {
|
|
110
|
+
* Gets the headers for a sequence of L2 blocks.
|
|
111
|
+
* @param start - Number of the first block to return (inclusive).
|
|
112
|
+
* @param limit - The number of blocks to return.
|
|
113
|
+
* @returns The requested L2 block headers
|
|
114
|
+
*/ async *getBlockHeaders(start, limit) {
|
|
115
|
+
for await (const blockStorage of this.#blocks.valuesAsync(this.#computeBlockRange(start, limit))){
|
|
123
116
|
yield BlockHeader.fromBuffer(blockStorage.header);
|
|
124
117
|
}
|
|
125
118
|
}
|
|
@@ -127,21 +120,23 @@ export class BlockStore {
|
|
|
127
120
|
const header = BlockHeader.fromBuffer(blockStorage.header);
|
|
128
121
|
const archive = AppendOnlyTreeSnapshot.fromBuffer(blockStorage.archive);
|
|
129
122
|
const blockHash = (await header.hash()).toString();
|
|
130
|
-
const blockBodyBuffer = await
|
|
123
|
+
const blockBodyBuffer = await this.#blockBodies.getAsync(blockHash);
|
|
131
124
|
if (blockBodyBuffer === undefined) {
|
|
132
125
|
throw new Error(`Could not retrieve body for block ${header.globalVariables.blockNumber.toNumber()} ${blockHash}`);
|
|
133
126
|
}
|
|
134
127
|
const body = Body.fromBuffer(blockBodyBuffer);
|
|
135
128
|
const l2Block = new L2Block(archive, header, body);
|
|
136
|
-
return {
|
|
129
|
+
return {
|
|
130
|
+
data: l2Block,
|
|
131
|
+
l1: blockStorage.l1
|
|
132
|
+
};
|
|
137
133
|
}
|
|
138
134
|
/**
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
const [blockNumber, txIndex] = (await this.getTxLocation(txHash)) ?? [];
|
|
135
|
+
* Gets a tx effect.
|
|
136
|
+
* @param txHash - The txHash of the tx corresponding to the tx effect.
|
|
137
|
+
* @returns The requested tx effect (or undefined if not found).
|
|
138
|
+
*/ async getTxEffect(txHash) {
|
|
139
|
+
const [blockNumber, txIndex] = await this.getTxLocation(txHash) ?? [];
|
|
145
140
|
if (typeof blockNumber !== 'number' || typeof txIndex !== 'number') {
|
|
146
141
|
return undefined;
|
|
147
142
|
}
|
|
@@ -152,77 +147,77 @@ export class BlockStore {
|
|
|
152
147
|
return {
|
|
153
148
|
data: block.data.body.txEffects[txIndex],
|
|
154
149
|
l2BlockNumber: block.data.number,
|
|
155
|
-
l2BlockHash: (await block.data.hash()).toString()
|
|
150
|
+
l2BlockHash: (await block.data.hash()).toString()
|
|
156
151
|
};
|
|
157
152
|
}
|
|
158
153
|
/**
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
const [blockNumber, txIndex] = (await this.getTxLocation(txHash)) ?? [];
|
|
154
|
+
* Gets a receipt of a settled tx.
|
|
155
|
+
* @param txHash - The hash of a tx we try to get the receipt for.
|
|
156
|
+
* @returns The requested tx receipt (or undefined if not found).
|
|
157
|
+
*/ async getSettledTxReceipt(txHash) {
|
|
158
|
+
const [blockNumber, txIndex] = await this.getTxLocation(txHash) ?? [];
|
|
165
159
|
if (typeof blockNumber !== 'number' || typeof txIndex !== 'number') {
|
|
166
160
|
return undefined;
|
|
167
161
|
}
|
|
168
|
-
const block =
|
|
162
|
+
const block = await this.getBlock(blockNumber);
|
|
169
163
|
const tx = block.data.body.txEffects[txIndex];
|
|
170
164
|
return new TxReceipt(txHash, TxReceipt.statusFromRevertCode(tx.revertCode), '', tx.transactionFee.toBigInt(), L2BlockHash.fromField(await block.data.hash()), block.data.number);
|
|
171
165
|
}
|
|
172
166
|
/**
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
return __classPrivateFieldGet(this, _BlockStore_txIndex, "f").getAsync(txHash.toString());
|
|
167
|
+
* Looks up which block included the requested tx effect.
|
|
168
|
+
* @param txHash - The txHash of the tx.
|
|
169
|
+
* @returns The block number and index of the tx.
|
|
170
|
+
*/ getTxLocation(txHash) {
|
|
171
|
+
return this.#txIndex.getAsync(txHash.toString());
|
|
179
172
|
}
|
|
180
173
|
/**
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
return __classPrivateFieldGet(this, _BlockStore_contractIndex, "f").getAsync(contractAddress.toString());
|
|
174
|
+
* Looks up which block deployed a particular contract.
|
|
175
|
+
* @param contractAddress - The address of the contract to look up.
|
|
176
|
+
* @returns The block number and index of the contract.
|
|
177
|
+
*/ getContractLocation(contractAddress) {
|
|
178
|
+
return this.#contractIndex.getAsync(contractAddress.toString());
|
|
187
179
|
}
|
|
188
180
|
/**
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
181
|
+
* Gets the number of the latest L2 block processed.
|
|
182
|
+
* @returns The number of the latest L2 block processed.
|
|
183
|
+
*/ async getSynchedL2BlockNumber() {
|
|
184
|
+
const [lastBlockNumber] = await toArray(this.#blocks.keysAsync({
|
|
185
|
+
reverse: true,
|
|
186
|
+
limit: 1
|
|
187
|
+
}));
|
|
194
188
|
return typeof lastBlockNumber === 'number' ? lastBlockNumber : INITIAL_L2_BLOCK_NUM - 1;
|
|
195
189
|
}
|
|
196
190
|
/**
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
return __classPrivateFieldGet(this, _BlockStore_lastSynchedL1Block, "f").getAsync();
|
|
191
|
+
* Gets the most recent L1 block processed.
|
|
192
|
+
* @returns The L1 block that published the latest L2 block
|
|
193
|
+
*/ getSynchedL1BlockNumber() {
|
|
194
|
+
return this.#lastSynchedL1Block.getAsync();
|
|
202
195
|
}
|
|
203
196
|
setSynchedL1BlockNumber(l1BlockNumber) {
|
|
204
|
-
return
|
|
197
|
+
return this.#lastSynchedL1Block.set(l1BlockNumber);
|
|
205
198
|
}
|
|
206
199
|
async getProvenL2BlockNumber() {
|
|
207
|
-
return
|
|
200
|
+
return await this.#lastProvenL2Block.getAsync() ?? 0;
|
|
208
201
|
}
|
|
209
202
|
setProvenL2BlockNumber(blockNumber) {
|
|
210
|
-
return
|
|
203
|
+
return this.#lastProvenL2Block.set(blockNumber);
|
|
211
204
|
}
|
|
212
205
|
getProvenL2EpochNumber() {
|
|
213
|
-
return
|
|
206
|
+
return this.#lastProvenL2Epoch.getAsync();
|
|
214
207
|
}
|
|
215
208
|
setProvenL2EpochNumber(epochNumber) {
|
|
216
|
-
return
|
|
217
|
-
}
|
|
218
|
-
}
|
|
219
|
-
_BlockStore_blocks = new WeakMap(), _BlockStore_blockBodies = new WeakMap(), _BlockStore_lastSynchedL1Block = new WeakMap(), _BlockStore_lastProvenL2Block = new WeakMap(), _BlockStore_lastProvenL2Epoch = new WeakMap(), _BlockStore_txIndex = new WeakMap(), _BlockStore_contractIndex = new WeakMap(), _BlockStore_log = new WeakMap(), _BlockStore_instances = new WeakSet(), _BlockStore_computeBlockRange = function _BlockStore_computeBlockRange(start, limit) {
|
|
220
|
-
if (limit < 1) {
|
|
221
|
-
throw new Error(`Invalid limit: ${limit}`);
|
|
209
|
+
return this.#lastProvenL2Epoch.set(epochNumber);
|
|
222
210
|
}
|
|
223
|
-
|
|
224
|
-
|
|
211
|
+
#computeBlockRange(start, limit) {
|
|
212
|
+
if (limit < 1) {
|
|
213
|
+
throw new Error(`Invalid limit: ${limit}`);
|
|
214
|
+
}
|
|
215
|
+
if (start < INITIAL_L2_BLOCK_NUM) {
|
|
216
|
+
throw new Error(`Invalid start: ${start}`);
|
|
217
|
+
}
|
|
218
|
+
return {
|
|
219
|
+
start,
|
|
220
|
+
limit
|
|
221
|
+
};
|
|
225
222
|
}
|
|
226
|
-
|
|
227
|
-
};
|
|
228
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"block_store.js","sourceRoot":"","sources":["../../../src/archiver/kv_archiver_store/block_store.ts"],"names":[],"mappings":"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"}
|
|
223
|
+
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { Fr } from '@aztec/foundation/fields';
|
|
2
2
|
import type { AztecAsyncKVStore } from '@aztec/kv-store';
|
|
3
|
+
import type { ContractClassPublic, ExecutablePrivateFunctionWithMembershipProof, UnconstrainedFunctionWithMembershipProof } from '@aztec/stdlib/contract';
|
|
3
4
|
/**
|
|
4
5
|
* LMDB implementation of the ArchiverDataStore interface.
|
|
5
6
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"contract_class_store.d.ts","sourceRoot":"","sources":["../../../src/archiver/kv_archiver_store/contract_class_store.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"contract_class_store.d.ts","sourceRoot":"","sources":["../../../src/archiver/kv_archiver_store/contract_class_store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAG9C,OAAO,KAAK,EAAE,iBAAiB,EAAiB,MAAM,iBAAiB,CAAC;AAExE,OAAO,KAAK,EACV,mBAAmB,EAEnB,4CAA4C,EAC5C,wCAAwC,EACzC,MAAM,wBAAwB,CAAC;AAGhC;;GAEG;AACH,qBAAa,kBAAkB;;IAIjB,OAAO,CAAC,EAAE;gBAAF,EAAE,EAAE,iBAAiB;IAKnC,gBAAgB,CACpB,aAAa,EAAE,mBAAmB,EAClC,kBAAkB,EAAE,EAAE,EACtB,WAAW,EAAE,MAAM,GAClB,OAAO,CAAC,IAAI,CAAC;IAQV,qBAAqB,CAAC,aAAa,EAAE,mBAAmB,EAAE,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ7F,gBAAgB,CAAC,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,mBAAmB,GAAG,SAAS,CAAC;IAKlE,qBAAqB,CAAC,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,EAAE,GAAG,SAAS,CAAC;IAKtD,mBAAmB,IAAI,OAAO,CAAC,EAAE,EAAE,CAAC;IAIpC,YAAY,CAChB,eAAe,EAAE,EAAE,EACnB,mBAAmB,EAAE,4CAA4C,EAAE,EACnE,yBAAyB,EAAE,wCAAwC,EAAE,GACpE,OAAO,CAAC,OAAO,CAAC;CA4BpB"}
|