@aztec/archiver 0.55.1 → 0.57.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 +27 -25
- package/dest/archiver/archiver.d.ts.map +1 -1
- package/dest/archiver/archiver.js +391 -169
- package/dest/archiver/archiver_store.d.ts +47 -23
- 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 +75 -42
- package/dest/archiver/config.js +6 -6
- package/dest/archiver/data_retrieval.d.ts +32 -5
- package/dest/archiver/data_retrieval.d.ts.map +1 -1
- package/dest/archiver/data_retrieval.js +126 -16
- package/dest/archiver/epoch_helpers.d.ts +15 -0
- package/dest/archiver/epoch_helpers.d.ts.map +1 -0
- package/dest/archiver/epoch_helpers.js +23 -0
- package/dest/archiver/kv_archiver_store/block_store.d.ts +22 -3
- package/dest/archiver/kv_archiver_store/block_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/block_store.js +75 -12
- 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 +11 -4
- package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts +1 -0
- package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/contract_instance_store.js +4 -1
- package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts +31 -23
- package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/kv_archiver_store.js +65 -38
- package/dest/archiver/kv_archiver_store/log_store.d.ts +4 -5
- package/dest/archiver/kv_archiver_store/log_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/log_store.js +18 -14
- package/dest/archiver/kv_archiver_store/message_store.d.ts +2 -0
- package/dest/archiver/kv_archiver_store/message_store.d.ts.map +1 -1
- package/dest/archiver/kv_archiver_store/message_store.js +18 -8
- package/dest/archiver/memory_archiver_store/l1_to_l2_message_store.d.ts +1 -0
- 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 +4 -1
- package/dest/archiver/memory_archiver_store/memory_archiver_store.d.ts +23 -39
- package/dest/archiver/memory_archiver_store/memory_archiver_store.d.ts.map +1 -1
- package/dest/archiver/memory_archiver_store/memory_archiver_store.js +132 -91
- package/dest/index.d.ts +0 -1
- package/dest/index.d.ts.map +1 -1
- package/dest/index.js +2 -2
- package/dest/test/index.d.ts +2 -0
- package/dest/test/index.d.ts.map +1 -0
- package/dest/test/index.js +2 -0
- package/dest/test/mock_l2_block_source.d.ts +73 -0
- package/dest/test/mock_l2_block_source.d.ts.map +1 -0
- package/dest/test/mock_l2_block_source.js +134 -0
- package/package.json +15 -11
- package/src/archiver/archiver.ts +531 -248
- package/src/archiver/archiver_store.ts +53 -31
- package/src/archiver/archiver_store_test_suite.ts +93 -81
- package/src/archiver/config.ts +5 -5
- package/src/archiver/data_retrieval.ts +189 -30
- package/src/archiver/epoch_helpers.ts +26 -0
- package/src/archiver/kv_archiver_store/block_store.ts +87 -12
- package/src/archiver/kv_archiver_store/contract_class_store.ts +18 -5
- package/src/archiver/kv_archiver_store/contract_instance_store.ts +4 -0
- package/src/archiver/kv_archiver_store/kv_archiver_store.ts +74 -47
- package/src/archiver/kv_archiver_store/log_store.ts +18 -18
- package/src/archiver/kv_archiver_store/message_store.ts +18 -5
- package/src/archiver/memory_archiver_store/l1_to_l2_message_store.ts +4 -0
- package/src/archiver/memory_archiver_store/memory_archiver_store.ts +155 -108
- package/src/index.ts +1 -2
- package/src/test/index.ts +1 -0
- package/src/test/mock_l2_block_source.ts +165 -0
- package/dest/archiver/eth_log_handlers.d.ts +0 -59
- package/dest/archiver/eth_log_handlers.d.ts.map +0 -1
- package/dest/archiver/eth_log_handlers.js +0 -155
- package/dest/archiver/kv_archiver_store/block_body_store.d.ts +0 -34
- package/dest/archiver/kv_archiver_store/block_body_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/block_body_store.js +0 -65
- package/dest/archiver/kv_archiver_store/proven_store.d.ts +0 -14
- package/dest/archiver/kv_archiver_store/proven_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/proven_store.js +0 -30
- package/src/archiver/eth_log_handlers.ts +0 -213
- package/src/archiver/kv_archiver_store/block_body_store.ts +0 -74
- package/src/archiver/kv_archiver_store/proven_store.ts +0 -34
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"contract_instance_store.d.ts","sourceRoot":"","sources":["../../../src/archiver/kv_archiver_store/contract_instance_store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,YAAY,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,EAAE,KAAK,YAAY,EAAiB,MAAM,iBAAiB,CAAC;AACnE,OAAO,EAAE,KAAK,2BAA2B,EAAgC,MAAM,wBAAwB,CAAC;AAExG;;GAEG;AACH,qBAAa,qBAAqB;;gBAGpB,EAAE,EAAE,YAAY;IAI5B,mBAAmB,CAAC,gBAAgB,EAAE,2BAA2B,GAAG,OAAO,CAAC,IAAI,CAAC;IAOjF,mBAAmB,CAAC,OAAO,EAAE,YAAY,GAAG,2BAA2B,GAAG,SAAS;CAIpF"}
|
|
1
|
+
{"version":3,"file":"contract_instance_store.d.ts","sourceRoot":"","sources":["../../../src/archiver/kv_archiver_store/contract_instance_store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,YAAY,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,EAAE,KAAK,YAAY,EAAiB,MAAM,iBAAiB,CAAC;AACnE,OAAO,EAAE,KAAK,2BAA2B,EAAgC,MAAM,wBAAwB,CAAC;AAExG;;GAEG;AACH,qBAAa,qBAAqB;;gBAGpB,EAAE,EAAE,YAAY;IAI5B,mBAAmB,CAAC,gBAAgB,EAAE,2BAA2B,GAAG,OAAO,CAAC,IAAI,CAAC;IAOjF,sBAAsB,CAAC,gBAAgB,EAAE,2BAA2B,GAAG,OAAO,CAAC,IAAI,CAAC;IAIpF,mBAAmB,CAAC,OAAO,EAAE,YAAY,GAAG,2BAA2B,GAAG,SAAS;CAIpF"}
|
|
@@ -12,10 +12,13 @@ export class ContractInstanceStore {
|
|
|
12
12
|
addContractInstance(contractInstance) {
|
|
13
13
|
return __classPrivateFieldGet(this, _ContractInstanceStore_contractInstances, "f").set(contractInstance.address.toString(), new SerializableContractInstance(contractInstance).toBuffer());
|
|
14
14
|
}
|
|
15
|
+
deleteContractInstance(contractInstance) {
|
|
16
|
+
return __classPrivateFieldGet(this, _ContractInstanceStore_contractInstances, "f").delete(contractInstance.address.toString());
|
|
17
|
+
}
|
|
15
18
|
getContractInstance(address) {
|
|
16
19
|
const contractInstance = __classPrivateFieldGet(this, _ContractInstanceStore_contractInstances, "f").get(address.toString());
|
|
17
20
|
return contractInstance && SerializableContractInstance.fromBuffer(contractInstance).withAddress(address);
|
|
18
21
|
}
|
|
19
22
|
}
|
|
20
23
|
_ContractInstanceStore_contractInstances = new WeakMap();
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udHJhY3RfaW5zdGFuY2Vfc3RvcmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXJjaGl2ZXIva3ZfYXJjaGl2ZXJfc3RvcmUvY29udHJhY3RfaW5zdGFuY2Vfc3RvcmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFFQSxPQUFPLEVBQW9DLDRCQUE0QixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFeEc7O0dBRUc7QUFDSCxNQUFNLE9BQU8scUJBQXFCO0lBR2hDLFlBQVksRUFBZ0I7UUFGNUIsMkRBQTZDO1FBRzNDLHVCQUFBLElBQUksNENBQXNCLEVBQUUsQ0FBQyxPQUFPLENBQUMsNkJBQTZCLENBQUMsTUFBQSxDQUFDO0lBQ3RFLENBQUM7SUFFRCxtQkFBbUIsQ0FBQyxnQkFBNkM7UUFDL0QsT0FBTyx1QkFBQSxJQUFJLGdEQUFtQixDQUFDLEdBQUcsQ0FDaEMsZ0JBQWdCLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRSxFQUNuQyxJQUFJLDRCQUE0QixDQUFDLGdCQUFnQixDQUFDLENBQUMsUUFBUSxFQUFFLENBQzlELENBQUM7SUFDSixDQUFDO0lBRUQsc0JBQXNCLENBQUMsZ0JBQTZDO1FBQ2xFLE9BQU8sdUJBQUEsSUFBSSxnREFBbUIsQ0FBQyxNQUFNLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUM7SUFDN0UsQ0FBQztJQUVELG1CQUFtQixDQUFDLE9BQXFCO1FBQ3ZDLE1BQU0sZ0JBQWdCLEdBQUcsdUJBQUEsSUFBSSxnREFBbUIsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUM7UUFDekUsT0FBTyxnQkFBZ0IsSUFBSSw0QkFBNEIsQ0FBQyxVQUFVLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDNUcsQ0FBQztDQUNGIn0=
|
|
@@ -1,12 +1,11 @@
|
|
|
1
|
-
|
|
2
|
-
import { type
|
|
3
|
-
import { type Fr } from '@aztec/circuits.js';
|
|
1
|
+
import { type FromLogType, type GetUnencryptedLogsResponse, type InboxLeaf, type L2Block, type L2BlockL2Logs, type LogFilter, type LogType, type TxEffect, type TxHash, type TxReceipt } from '@aztec/circuit-types';
|
|
2
|
+
import { type Fr, type Header } from '@aztec/circuits.js';
|
|
4
3
|
import { type ContractArtifact } from '@aztec/foundation/abi';
|
|
5
4
|
import { type AztecAddress } from '@aztec/foundation/aztec-address';
|
|
6
5
|
import { type AztecKVStore } from '@aztec/kv-store';
|
|
7
6
|
import { type ContractClassPublic, type ContractInstanceWithAddress, type ExecutablePrivateFunctionWithMembershipProof, type UnconstrainedFunctionWithMembershipProof } from '@aztec/types/contracts';
|
|
8
7
|
import { type ArchiverDataStore, type ArchiverL1SynchPoint } from '../archiver_store.js';
|
|
9
|
-
import { type DataRetrieval
|
|
8
|
+
import { type DataRetrieval } from '../structs/data_retrieval.js';
|
|
10
9
|
import { type L1Published } from '../structs/published.js';
|
|
11
10
|
/**
|
|
12
11
|
* LMDB implementation of the ArchiverDataStore interface.
|
|
@@ -19,28 +18,25 @@ export declare class KVArchiverDataStore implements ArchiverDataStore {
|
|
|
19
18
|
getContractClass(id: Fr): Promise<ContractClassPublic | undefined>;
|
|
20
19
|
getContractClassIds(): Promise<Fr[]>;
|
|
21
20
|
getContractInstance(address: AztecAddress): Promise<ContractInstanceWithAddress | undefined>;
|
|
22
|
-
addContractClasses(data: ContractClassPublic[],
|
|
21
|
+
addContractClasses(data: ContractClassPublic[], blockNumber: number): Promise<boolean>;
|
|
22
|
+
deleteContractClasses(data: ContractClassPublic[], blockNumber: number): Promise<boolean>;
|
|
23
23
|
addFunctions(contractClassId: Fr, privateFunctions: ExecutablePrivateFunctionWithMembershipProof[], unconstrainedFunctions: UnconstrainedFunctionWithMembershipProof[]): Promise<boolean>;
|
|
24
24
|
addContractInstances(data: ContractInstanceWithAddress[], _blockNumber: number): Promise<boolean>;
|
|
25
|
-
|
|
26
|
-
* Append new block bodies to the store's list.
|
|
27
|
-
* @param blockBodies - The L2 block bodies to be added to the store.
|
|
28
|
-
* @returns True if the operation is successful.
|
|
29
|
-
*/
|
|
30
|
-
addBlockBodies(blockBodies: DataRetrieval<Body>): Promise<boolean>;
|
|
31
|
-
/**
|
|
32
|
-
* Gets block bodies that have the same txHashes as we supply.
|
|
33
|
-
*
|
|
34
|
-
* @param txsEffectsHashes - A list of txsEffectsHashes (body hashes).
|
|
35
|
-
* @returns The requested L2 block bodies
|
|
36
|
-
*/
|
|
37
|
-
getBlockBodies(txsEffectsHashes: Buffer[]): Promise<(Body | undefined)[]>;
|
|
25
|
+
deleteContractInstances(data: ContractInstanceWithAddress[], _blockNumber: number): Promise<boolean>;
|
|
38
26
|
/**
|
|
39
27
|
* Append new blocks to the store's list.
|
|
40
28
|
* @param blocks - The L2 blocks to be added to the store and the last processed L1 block.
|
|
41
29
|
* @returns True if the operation is successful.
|
|
42
30
|
*/
|
|
43
31
|
addBlocks(blocks: L1Published<L2Block>[]): Promise<boolean>;
|
|
32
|
+
/**
|
|
33
|
+
* Unwinds blocks from the database
|
|
34
|
+
* @param from - The tip of the chain, passed for verification purposes,
|
|
35
|
+
* ensuring that we don't end up deleting something we did not intend
|
|
36
|
+
* @param blocksToUnwind - The number of blocks we are to unwind
|
|
37
|
+
* @returns True if the operation is successful
|
|
38
|
+
*/
|
|
39
|
+
unwindBlocks(from: number, blocksToUnwind: number): Promise<boolean>;
|
|
44
40
|
/**
|
|
45
41
|
* Gets up to `limit` amount of L2 blocks starting from `from`.
|
|
46
42
|
*
|
|
@@ -49,6 +45,14 @@ export declare class KVArchiverDataStore implements ArchiverDataStore {
|
|
|
49
45
|
* @returns The requested L2 blocks
|
|
50
46
|
*/
|
|
51
47
|
getBlocks(start: number, limit: number): Promise<L1Published<L2Block>[]>;
|
|
48
|
+
/**
|
|
49
|
+
* Gets up to `limit` amount of L2 blocks headers starting from `from`.
|
|
50
|
+
*
|
|
51
|
+
* @param start - Number of the first block to return (inclusive).
|
|
52
|
+
* @param limit - The number of blocks to return.
|
|
53
|
+
* @returns The requested L2 blocks
|
|
54
|
+
*/
|
|
55
|
+
getBlockHeaders(start: number, limit: number): Promise<Header[]>;
|
|
52
56
|
/**
|
|
53
57
|
* Gets a tx effect.
|
|
54
58
|
* @param txHash - The txHash of the tx corresponding to the tx effect.
|
|
@@ -63,12 +67,12 @@ export declare class KVArchiverDataStore implements ArchiverDataStore {
|
|
|
63
67
|
getSettledTxReceipt(txHash: TxHash): Promise<TxReceipt | undefined>;
|
|
64
68
|
/**
|
|
65
69
|
* Append new logs to the store's list.
|
|
66
|
-
* @param
|
|
67
|
-
* @param unencryptedLogs - The type of the logs to be added to the store.
|
|
68
|
-
* @param blockNumber - The block for which to add the logs.
|
|
70
|
+
* @param blocks - The blocks for which to add the logs.
|
|
69
71
|
* @returns True if the operation is successful.
|
|
70
72
|
*/
|
|
71
|
-
addLogs(
|
|
73
|
+
addLogs(blocks: L2Block[]): Promise<boolean>;
|
|
74
|
+
deleteLogs(blocks: L2Block[]): Promise<boolean>;
|
|
75
|
+
getTotalL1ToL2MessageCount(): Promise<bigint>;
|
|
72
76
|
/**
|
|
73
77
|
* Append L1 to L2 messages to the store.
|
|
74
78
|
* @param messages - The L1 to L2 messages to be added to the store and the last processed L1 block.
|
|
@@ -108,7 +112,11 @@ export declare class KVArchiverDataStore implements ArchiverDataStore {
|
|
|
108
112
|
*/
|
|
109
113
|
getSynchedL2BlockNumber(): Promise<number>;
|
|
110
114
|
getProvenL2BlockNumber(): Promise<number>;
|
|
111
|
-
|
|
115
|
+
getProvenL2EpochNumber(): Promise<number | undefined>;
|
|
116
|
+
setProvenL2BlockNumber(blockNumber: number): Promise<void>;
|
|
117
|
+
setProvenL2EpochNumber(epochNumber: number): Promise<void>;
|
|
118
|
+
setBlockSynchedL1BlockNumber(l1BlockNumber: bigint): Promise<void>;
|
|
119
|
+
setMessageSynchedL1BlockNumber(l1BlockNumber: bigint): Promise<void>;
|
|
112
120
|
/**
|
|
113
121
|
* Gets the last L1 block number processed by the archiver
|
|
114
122
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"kv_archiver_store.d.ts","sourceRoot":"","sources":["../../../src/archiver/kv_archiver_store/kv_archiver_store.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"kv_archiver_store.d.ts","sourceRoot":"","sources":["../../../src/archiver/kv_archiver_store/kv_archiver_store.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,31 +1,25 @@
|
|
|
1
|
-
var
|
|
1
|
+
var _KVArchiverDataStore_blockStore, _KVArchiverDataStore_logStore, _KVArchiverDataStore_messageStore, _KVArchiverDataStore_contractClassStore, _KVArchiverDataStore_contractInstanceStore, _KVArchiverDataStore_contractArtifactStore, _KVArchiverDataStore_log;
|
|
2
2
|
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
3
|
import { createDebugLogger } from '@aztec/foundation/log';
|
|
4
|
-
import { BlockBodyStore } from './block_body_store.js';
|
|
5
4
|
import { BlockStore } from './block_store.js';
|
|
6
5
|
import { ContractArtifactsStore } from './contract_artifacts_store.js';
|
|
7
6
|
import { ContractClassStore } from './contract_class_store.js';
|
|
8
7
|
import { ContractInstanceStore } from './contract_instance_store.js';
|
|
9
8
|
import { LogStore } from './log_store.js';
|
|
10
9
|
import { MessageStore } from './message_store.js';
|
|
11
|
-
import { ProvenStore } from './proven_store.js';
|
|
12
10
|
/**
|
|
13
11
|
* LMDB implementation of the ArchiverDataStore interface.
|
|
14
12
|
*/
|
|
15
13
|
export class KVArchiverDataStore {
|
|
16
14
|
constructor(db, logsMaxPageSize = 1000) {
|
|
17
|
-
_KVArchiverDataStore_blockBodyStore.set(this, void 0);
|
|
18
15
|
_KVArchiverDataStore_blockStore.set(this, void 0);
|
|
19
|
-
_KVArchiverDataStore_provenStore.set(this, void 0);
|
|
20
16
|
_KVArchiverDataStore_logStore.set(this, void 0);
|
|
21
17
|
_KVArchiverDataStore_messageStore.set(this, void 0);
|
|
22
18
|
_KVArchiverDataStore_contractClassStore.set(this, void 0);
|
|
23
19
|
_KVArchiverDataStore_contractInstanceStore.set(this, void 0);
|
|
24
20
|
_KVArchiverDataStore_contractArtifactStore.set(this, void 0);
|
|
25
21
|
_KVArchiverDataStore_log.set(this, createDebugLogger('aztec:archiver:data-store'));
|
|
26
|
-
__classPrivateFieldSet(this,
|
|
27
|
-
__classPrivateFieldSet(this, _KVArchiverDataStore_blockStore, new BlockStore(db, __classPrivateFieldGet(this, _KVArchiverDataStore_blockBodyStore, "f")), "f");
|
|
28
|
-
__classPrivateFieldSet(this, _KVArchiverDataStore_provenStore, new ProvenStore(db), "f");
|
|
22
|
+
__classPrivateFieldSet(this, _KVArchiverDataStore_blockStore, new BlockStore(db), "f");
|
|
29
23
|
__classPrivateFieldSet(this, _KVArchiverDataStore_logStore, new LogStore(db, __classPrivateFieldGet(this, _KVArchiverDataStore_blockStore, "f"), logsMaxPageSize), "f");
|
|
30
24
|
__classPrivateFieldSet(this, _KVArchiverDataStore_messageStore, new MessageStore(db), "f");
|
|
31
25
|
__classPrivateFieldSet(this, _KVArchiverDataStore_contractClassStore, new ContractClassStore(db), "f");
|
|
@@ -47,8 +41,11 @@ export class KVArchiverDataStore {
|
|
|
47
41
|
getContractInstance(address) {
|
|
48
42
|
return Promise.resolve(__classPrivateFieldGet(this, _KVArchiverDataStore_contractInstanceStore, "f").getContractInstance(address));
|
|
49
43
|
}
|
|
50
|
-
async addContractClasses(data,
|
|
51
|
-
return (await Promise.all(data.map(c => __classPrivateFieldGet(this, _KVArchiverDataStore_contractClassStore, "f").addContractClass(c)))).every(Boolean);
|
|
44
|
+
async addContractClasses(data, blockNumber) {
|
|
45
|
+
return (await Promise.all(data.map(c => __classPrivateFieldGet(this, _KVArchiverDataStore_contractClassStore, "f").addContractClass(c, blockNumber)))).every(Boolean);
|
|
46
|
+
}
|
|
47
|
+
async deleteContractClasses(data, blockNumber) {
|
|
48
|
+
return (await Promise.all(data.map(c => __classPrivateFieldGet(this, _KVArchiverDataStore_contractClassStore, "f").deleteContractClasses(c, blockNumber)))).every(Boolean);
|
|
52
49
|
}
|
|
53
50
|
addFunctions(contractClassId, privateFunctions, unconstrainedFunctions) {
|
|
54
51
|
return __classPrivateFieldGet(this, _KVArchiverDataStore_contractClassStore, "f").addFunctions(contractClassId, privateFunctions, unconstrainedFunctions);
|
|
@@ -56,22 +53,8 @@ export class KVArchiverDataStore {
|
|
|
56
53
|
async addContractInstances(data, _blockNumber) {
|
|
57
54
|
return (await Promise.all(data.map(c => __classPrivateFieldGet(this, _KVArchiverDataStore_contractInstanceStore, "f").addContractInstance(c)))).every(Boolean);
|
|
58
55
|
}
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
* @param blockBodies - The L2 block bodies to be added to the store.
|
|
62
|
-
* @returns True if the operation is successful.
|
|
63
|
-
*/
|
|
64
|
-
addBlockBodies(blockBodies) {
|
|
65
|
-
return __classPrivateFieldGet(this, _KVArchiverDataStore_blockBodyStore, "f").addBlockBodies(blockBodies);
|
|
66
|
-
}
|
|
67
|
-
/**
|
|
68
|
-
* Gets block bodies that have the same txHashes as we supply.
|
|
69
|
-
*
|
|
70
|
-
* @param txsEffectsHashes - A list of txsEffectsHashes (body hashes).
|
|
71
|
-
* @returns The requested L2 block bodies
|
|
72
|
-
*/
|
|
73
|
-
getBlockBodies(txsEffectsHashes) {
|
|
74
|
-
return __classPrivateFieldGet(this, _KVArchiverDataStore_blockBodyStore, "f").getBlockBodies(txsEffectsHashes);
|
|
56
|
+
async deleteContractInstances(data, _blockNumber) {
|
|
57
|
+
return (await Promise.all(data.map(c => __classPrivateFieldGet(this, _KVArchiverDataStore_contractInstanceStore, "f").deleteContractInstance(c)))).every(Boolean);
|
|
75
58
|
}
|
|
76
59
|
/**
|
|
77
60
|
* Append new blocks to the store's list.
|
|
@@ -81,6 +64,16 @@ export class KVArchiverDataStore {
|
|
|
81
64
|
addBlocks(blocks) {
|
|
82
65
|
return __classPrivateFieldGet(this, _KVArchiverDataStore_blockStore, "f").addBlocks(blocks);
|
|
83
66
|
}
|
|
67
|
+
/**
|
|
68
|
+
* Unwinds blocks from the database
|
|
69
|
+
* @param from - The tip of the chain, passed for verification purposes,
|
|
70
|
+
* ensuring that we don't end up deleting something we did not intend
|
|
71
|
+
* @param blocksToUnwind - The number of blocks we are to unwind
|
|
72
|
+
* @returns True if the operation is successful
|
|
73
|
+
*/
|
|
74
|
+
unwindBlocks(from, blocksToUnwind) {
|
|
75
|
+
return __classPrivateFieldGet(this, _KVArchiverDataStore_blockStore, "f").unwindBlocks(from, blocksToUnwind);
|
|
76
|
+
}
|
|
84
77
|
/**
|
|
85
78
|
* Gets up to `limit` amount of L2 blocks starting from `from`.
|
|
86
79
|
*
|
|
@@ -97,6 +90,22 @@ export class KVArchiverDataStore {
|
|
|
97
90
|
return Promise.reject(err);
|
|
98
91
|
}
|
|
99
92
|
}
|
|
93
|
+
/**
|
|
94
|
+
* Gets up to `limit` amount of L2 blocks headers starting from `from`.
|
|
95
|
+
*
|
|
96
|
+
* @param start - Number of the first block to return (inclusive).
|
|
97
|
+
* @param limit - The number of blocks to return.
|
|
98
|
+
* @returns The requested L2 blocks
|
|
99
|
+
*/
|
|
100
|
+
getBlockHeaders(start, limit) {
|
|
101
|
+
try {
|
|
102
|
+
return Promise.resolve(Array.from(__classPrivateFieldGet(this, _KVArchiverDataStore_blockStore, "f").getBlockHeaders(start, limit)));
|
|
103
|
+
}
|
|
104
|
+
catch (err) {
|
|
105
|
+
// this function is sync so if any errors are thrown we need to make sure they're passed on as rejected Promises
|
|
106
|
+
return Promise.reject(err);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
100
109
|
/**
|
|
101
110
|
* Gets a tx effect.
|
|
102
111
|
* @param txHash - The txHash of the tx corresponding to the tx effect.
|
|
@@ -115,13 +124,17 @@ export class KVArchiverDataStore {
|
|
|
115
124
|
}
|
|
116
125
|
/**
|
|
117
126
|
* Append new logs to the store's list.
|
|
118
|
-
* @param
|
|
119
|
-
* @param unencryptedLogs - The type of the logs to be added to the store.
|
|
120
|
-
* @param blockNumber - The block for which to add the logs.
|
|
127
|
+
* @param blocks - The blocks for which to add the logs.
|
|
121
128
|
* @returns True if the operation is successful.
|
|
122
129
|
*/
|
|
123
|
-
addLogs(
|
|
124
|
-
return __classPrivateFieldGet(this, _KVArchiverDataStore_logStore, "f").addLogs(
|
|
130
|
+
addLogs(blocks) {
|
|
131
|
+
return __classPrivateFieldGet(this, _KVArchiverDataStore_logStore, "f").addLogs(blocks);
|
|
132
|
+
}
|
|
133
|
+
deleteLogs(blocks) {
|
|
134
|
+
return __classPrivateFieldGet(this, _KVArchiverDataStore_logStore, "f").deleteLogs(blocks);
|
|
135
|
+
}
|
|
136
|
+
getTotalL1ToL2MessageCount() {
|
|
137
|
+
return Promise.resolve(__classPrivateFieldGet(this, _KVArchiverDataStore_messageStore, "f").getTotalL1ToL2MessageCount());
|
|
125
138
|
}
|
|
126
139
|
/**
|
|
127
140
|
* Append L1 to L2 messages to the store.
|
|
@@ -189,10 +202,26 @@ export class KVArchiverDataStore {
|
|
|
189
202
|
return Promise.resolve(__classPrivateFieldGet(this, _KVArchiverDataStore_blockStore, "f").getSynchedL2BlockNumber());
|
|
190
203
|
}
|
|
191
204
|
getProvenL2BlockNumber() {
|
|
192
|
-
return Promise.resolve(__classPrivateFieldGet(this,
|
|
205
|
+
return Promise.resolve(__classPrivateFieldGet(this, _KVArchiverDataStore_blockStore, "f").getProvenL2BlockNumber());
|
|
206
|
+
}
|
|
207
|
+
getProvenL2EpochNumber() {
|
|
208
|
+
return Promise.resolve(__classPrivateFieldGet(this, _KVArchiverDataStore_blockStore, "f").getProvenL2EpochNumber());
|
|
209
|
+
}
|
|
210
|
+
setProvenL2BlockNumber(blockNumber) {
|
|
211
|
+
__classPrivateFieldGet(this, _KVArchiverDataStore_blockStore, "f").setProvenL2BlockNumber(blockNumber);
|
|
212
|
+
return Promise.resolve();
|
|
213
|
+
}
|
|
214
|
+
setProvenL2EpochNumber(epochNumber) {
|
|
215
|
+
__classPrivateFieldGet(this, _KVArchiverDataStore_blockStore, "f").setProvenL2EpochNumber(epochNumber);
|
|
216
|
+
return Promise.resolve();
|
|
217
|
+
}
|
|
218
|
+
setBlockSynchedL1BlockNumber(l1BlockNumber) {
|
|
219
|
+
__classPrivateFieldGet(this, _KVArchiverDataStore_blockStore, "f").setSynchedL1BlockNumber(l1BlockNumber);
|
|
220
|
+
return Promise.resolve();
|
|
193
221
|
}
|
|
194
|
-
|
|
195
|
-
|
|
222
|
+
setMessageSynchedL1BlockNumber(l1BlockNumber) {
|
|
223
|
+
__classPrivateFieldGet(this, _KVArchiverDataStore_messageStore, "f").setSynchedL1BlockNumber(l1BlockNumber);
|
|
224
|
+
return Promise.resolve();
|
|
196
225
|
}
|
|
197
226
|
/**
|
|
198
227
|
* Gets the last L1 block number processed by the archiver
|
|
@@ -200,11 +229,9 @@ export class KVArchiverDataStore {
|
|
|
200
229
|
getSynchPoint() {
|
|
201
230
|
return Promise.resolve({
|
|
202
231
|
blocksSynchedTo: __classPrivateFieldGet(this, _KVArchiverDataStore_blockStore, "f").getSynchedL1BlockNumber(),
|
|
203
|
-
blockBodiesSynchedTo: __classPrivateFieldGet(this, _KVArchiverDataStore_blockBodyStore, "f").getSynchedL1BlockNumber(),
|
|
204
232
|
messagesSynchedTo: __classPrivateFieldGet(this, _KVArchiverDataStore_messageStore, "f").getSynchedL1BlockNumber(),
|
|
205
|
-
provenLogsSynchedTo: __classPrivateFieldGet(this, _KVArchiverDataStore_provenStore, "f").getSynchedL1BlockNumber(),
|
|
206
233
|
});
|
|
207
234
|
}
|
|
208
235
|
}
|
|
209
|
-
|
|
210
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
236
|
+
_KVArchiverDataStore_blockStore = new WeakMap(), _KVArchiverDataStore_logStore = new WeakMap(), _KVArchiverDataStore_messageStore = new WeakMap(), _KVArchiverDataStore_contractClassStore = new WeakMap(), _KVArchiverDataStore_contractInstanceStore = new WeakMap(), _KVArchiverDataStore_contractArtifactStore = new WeakMap(), _KVArchiverDataStore_log = new WeakMap();
|
|
237
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv_archiver_store.js","sourceRoot":"","sources":["../../../src/archiver/kv_archiver_store/kv_archiver_store.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { type FromLogType, type GetUnencryptedLogsResponse, type L2Block, type L2BlockL2Logs, type LogFilter, LogType } from '@aztec/circuit-types';
|
|
2
2
|
import { type AztecKVStore } from '@aztec/kv-store';
|
|
3
3
|
import { type BlockStore } from './block_store.js';
|
|
4
4
|
/**
|
|
@@ -11,12 +11,11 @@ export declare class LogStore {
|
|
|
11
11
|
constructor(db: AztecKVStore, blockStore: BlockStore, logsMaxPageSize?: number);
|
|
12
12
|
/**
|
|
13
13
|
* Append new logs to the store's list.
|
|
14
|
-
* @param
|
|
15
|
-
* @param unencryptedLogs - The type of the logs to be added to the store.
|
|
16
|
-
* @param blockNumber - The block for which to add the logs.
|
|
14
|
+
* @param blocks - The blocks for which to add the logs.
|
|
17
15
|
* @returns True if the operation is successful.
|
|
18
16
|
*/
|
|
19
|
-
addLogs(
|
|
17
|
+
addLogs(blocks: L2Block[]): Promise<boolean>;
|
|
18
|
+
deleteLogs(blocks: L2Block[]): Promise<boolean>;
|
|
20
19
|
/**
|
|
21
20
|
* Gets up to `limit` amount of logs starting from `from`.
|
|
22
21
|
* @param start - Number of the L2 block to which corresponds the first logs to be returned.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"log_store.d.ts","sourceRoot":"","sources":["../../../src/archiver/kv_archiver_store/log_store.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"log_store.d.ts","sourceRoot":"","sources":["../../../src/archiver/kv_archiver_store/log_store.ts"],"names":[],"mappings":"AAAA,OAAO,EAIL,KAAK,WAAW,EAChB,KAAK,0BAA0B,EAC/B,KAAK,OAAO,EACZ,KAAK,aAAa,EAClB,KAAK,SAAS,EAEd,OAAO,EAGR,MAAM,sBAAsB,CAAC;AAG9B,OAAO,EAAE,KAAK,YAAY,EAAiB,MAAM,iBAAiB,CAAC;AAEnE,OAAO,EAAE,KAAK,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAEnD;;GAEG;AACH,qBAAa,QAAQ;;IAOP,OAAO,CAAC,EAAE;IAAgB,OAAO,CAAC,UAAU;gBAApC,EAAE,EAAE,YAAY,EAAU,UAAU,EAAE,UAAU,EAAE,eAAe,GAAE,MAAa;IAQpG;;;;OAIG;IACH,OAAO,CAAC,MAAM,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC;IAY5C,UAAU,CAAC,MAAM,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC;IAY/C;;;;;;OAMG;IACF,OAAO,CAAC,QAAQ,SAAS,OAAO,EAC/B,KAAK,EAAE,MAAM,EACb,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,QAAQ,GAChB,gBAAgB,CAAC,aAAa,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC,CAAC;IA6BzD;;;;OAIG;IACH,kBAAkB,CAAC,MAAM,EAAE,SAAS,GAAG,0BAA0B;CAqHlE"}
|
|
@@ -23,22 +23,26 @@ export class LogStore {
|
|
|
23
23
|
}
|
|
24
24
|
/**
|
|
25
25
|
* Append new logs to the store's list.
|
|
26
|
-
* @param
|
|
27
|
-
* @param unencryptedLogs - The type of the logs to be added to the store.
|
|
28
|
-
* @param blockNumber - The block for which to add the logs.
|
|
26
|
+
* @param blocks - The blocks for which to add the logs.
|
|
29
27
|
* @returns True if the operation is successful.
|
|
30
28
|
*/
|
|
31
|
-
addLogs(
|
|
29
|
+
addLogs(blocks) {
|
|
32
30
|
return this.db.transaction(() => {
|
|
33
|
-
|
|
34
|
-
void __classPrivateFieldGet(this, _LogStore_noteEncryptedLogs, "f").set(
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
31
|
+
blocks.forEach(block => {
|
|
32
|
+
void __classPrivateFieldGet(this, _LogStore_noteEncryptedLogs, "f").set(block.number, block.body.noteEncryptedLogs.toBuffer());
|
|
33
|
+
void __classPrivateFieldGet(this, _LogStore_encryptedLogs, "f").set(block.number, block.body.encryptedLogs.toBuffer());
|
|
34
|
+
void __classPrivateFieldGet(this, _LogStore_unencryptedLogs, "f").set(block.number, block.body.unencryptedLogs.toBuffer());
|
|
35
|
+
});
|
|
36
|
+
return true;
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
deleteLogs(blocks) {
|
|
40
|
+
return this.db.transaction(() => {
|
|
41
|
+
blocks.forEach(block => {
|
|
42
|
+
void __classPrivateFieldGet(this, _LogStore_noteEncryptedLogs, "f").delete(block.number);
|
|
43
|
+
void __classPrivateFieldGet(this, _LogStore_encryptedLogs, "f").delete(block.number);
|
|
44
|
+
void __classPrivateFieldGet(this, _LogStore_unencryptedLogs, "f").delete(block.number);
|
|
45
|
+
});
|
|
42
46
|
return true;
|
|
43
47
|
});
|
|
44
48
|
}
|
|
@@ -174,4 +178,4 @@ _LogStore_noteEncryptedLogs = new WeakMap(), _LogStore_encryptedLogs = new WeakM
|
|
|
174
178
|
}
|
|
175
179
|
return L2BlockL2Logs.fromBuffer(buffer);
|
|
176
180
|
};
|
|
177
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
181
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"log_store.js","sourceRoot":"","sources":["../../../src/archiver/kv_archiver_store/log_store.ts"],"names":[],"mappings":"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"}
|
|
@@ -9,11 +9,13 @@ export declare class MessageStore {
|
|
|
9
9
|
#private;
|
|
10
10
|
private db;
|
|
11
11
|
constructor(db: AztecKVStore);
|
|
12
|
+
getTotalL1ToL2MessageCount(): bigint;
|
|
12
13
|
/**
|
|
13
14
|
* Gets the last L1 block number that emitted new messages.
|
|
14
15
|
* @returns The last L1 block number processed
|
|
15
16
|
*/
|
|
16
17
|
getSynchedL1BlockNumber(): bigint | undefined;
|
|
18
|
+
setSynchedL1BlockNumber(l1BlockNumber: bigint): void;
|
|
17
19
|
/**
|
|
18
20
|
* Append L1 to L2 messages to the store.
|
|
19
21
|
* @param messages - The L1 to L2 messages to be added to the store and the last processed L1 block.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"message_store.d.ts","sourceRoot":"","sources":["../../../src/archiver/kv_archiver_store/message_store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EACL,EAAE,EAIH,MAAM,oBAAoB,CAAC;AAE5B,OAAO,EAAE,KAAK,YAAY,EAAsC,MAAM,iBAAiB,CAAC;AAExF,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAElE;;GAEG;AACH,qBAAa,YAAY;;
|
|
1
|
+
{"version":3,"file":"message_store.d.ts","sourceRoot":"","sources":["../../../src/archiver/kv_archiver_store/message_store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EACL,EAAE,EAIH,MAAM,oBAAoB,CAAC;AAE5B,OAAO,EAAE,KAAK,YAAY,EAAsC,MAAM,iBAAiB,CAAC;AAExF,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAElE;;GAEG;AACH,qBAAa,YAAY;;IAUX,OAAO,CAAC,EAAE;gBAAF,EAAE,EAAE,YAAY;IAOpC,0BAA0B,IAAI,MAAM;IAIpC;;;OAGG;IACH,uBAAuB,IAAI,MAAM,GAAG,SAAS;IAI7C,uBAAuB,CAAC,aAAa,EAAE,MAAM;IAI7C;;;;OAIG;IACH,iBAAiB,CAAC,QAAQ,EAAE,aAAa,CAAC,SAAS,CAAC,GAAG,OAAO,CAAC,OAAO,CAAC;IAgCvE;;;;;OAKG;IACH,qBAAqB,CAAC,aAAa,EAAE,EAAE,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC;IAMzF,iBAAiB,CAAC,WAAW,EAAE,MAAM,GAAG,EAAE,EAAE;CAoB7C"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var _MessageStore_l1ToL2Messages, _MessageStore_l1ToL2MessageIndices,
|
|
1
|
+
var _MessageStore_l1ToL2Messages, _MessageStore_l1ToL2MessageIndices, _MessageStore_lastSynchedL1Block, _MessageStore_totalMessageCount, _MessageStore_log, _MessageStore_l1ToL2MessagesSubtreeSize;
|
|
2
2
|
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
3
|
import { Fr, INITIAL_L2_BLOCK_NUM, L1_TO_L2_MSG_SUBTREE_HEIGHT, NUMBER_OF_L1_L2_MESSAGES_PER_ROLLUP, } from '@aztec/circuits.js';
|
|
4
4
|
import { createDebugLogger } from '@aztec/foundation/log';
|
|
@@ -10,19 +10,27 @@ export class MessageStore {
|
|
|
10
10
|
this.db = db;
|
|
11
11
|
_MessageStore_l1ToL2Messages.set(this, void 0);
|
|
12
12
|
_MessageStore_l1ToL2MessageIndices.set(this, void 0); // We store array of bigints here because there can be duplicate messages
|
|
13
|
-
|
|
13
|
+
_MessageStore_lastSynchedL1Block.set(this, void 0);
|
|
14
|
+
_MessageStore_totalMessageCount.set(this, void 0);
|
|
14
15
|
_MessageStore_log.set(this, createDebugLogger('aztec:archiver:message_store'));
|
|
15
16
|
_MessageStore_l1ToL2MessagesSubtreeSize.set(this, 2 ** L1_TO_L2_MSG_SUBTREE_HEIGHT);
|
|
16
17
|
__classPrivateFieldSet(this, _MessageStore_l1ToL2Messages, db.openMap('archiver_l1_to_l2_messages'), "f");
|
|
17
18
|
__classPrivateFieldSet(this, _MessageStore_l1ToL2MessageIndices, db.openMap('archiver_l1_to_l2_message_indices'), "f");
|
|
18
|
-
__classPrivateFieldSet(this,
|
|
19
|
+
__classPrivateFieldSet(this, _MessageStore_lastSynchedL1Block, db.openSingleton('archiver_last_l1_block_new_messages'), "f");
|
|
20
|
+
__classPrivateFieldSet(this, _MessageStore_totalMessageCount, db.openSingleton('archiver_l1_to_l2_message_count'), "f");
|
|
21
|
+
}
|
|
22
|
+
getTotalL1ToL2MessageCount() {
|
|
23
|
+
return __classPrivateFieldGet(this, _MessageStore_totalMessageCount, "f").get() ?? 0n;
|
|
19
24
|
}
|
|
20
25
|
/**
|
|
21
26
|
* Gets the last L1 block number that emitted new messages.
|
|
22
27
|
* @returns The last L1 block number processed
|
|
23
28
|
*/
|
|
24
29
|
getSynchedL1BlockNumber() {
|
|
25
|
-
return __classPrivateFieldGet(this,
|
|
30
|
+
return __classPrivateFieldGet(this, _MessageStore_lastSynchedL1Block, "f").get();
|
|
31
|
+
}
|
|
32
|
+
setSynchedL1BlockNumber(l1BlockNumber) {
|
|
33
|
+
void __classPrivateFieldGet(this, _MessageStore_lastSynchedL1Block, "f").set(l1BlockNumber);
|
|
26
34
|
}
|
|
27
35
|
/**
|
|
28
36
|
* Append L1 to L2 messages to the store.
|
|
@@ -31,11 +39,11 @@ export class MessageStore {
|
|
|
31
39
|
*/
|
|
32
40
|
addL1ToL2Messages(messages) {
|
|
33
41
|
return this.db.transaction(() => {
|
|
34
|
-
const lastL1BlockNumber = __classPrivateFieldGet(this,
|
|
42
|
+
const lastL1BlockNumber = __classPrivateFieldGet(this, _MessageStore_lastSynchedL1Block, "f").get() ?? 0n;
|
|
35
43
|
if (lastL1BlockNumber >= messages.lastProcessedL1BlockNumber) {
|
|
36
44
|
return false;
|
|
37
45
|
}
|
|
38
|
-
void __classPrivateFieldGet(this,
|
|
46
|
+
void __classPrivateFieldGet(this, _MessageStore_lastSynchedL1Block, "f").set(messages.lastProcessedL1BlockNumber);
|
|
39
47
|
for (const message of messages.retrievedData) {
|
|
40
48
|
if (message.index >= __classPrivateFieldGet(this, _MessageStore_l1ToL2MessagesSubtreeSize, "f")) {
|
|
41
49
|
throw new Error(`Message index ${message.index} out of subtree range`);
|
|
@@ -48,6 +56,8 @@ export class MessageStore {
|
|
|
48
56
|
indices.push(indexInTheWholeTree);
|
|
49
57
|
void __classPrivateFieldGet(this, _MessageStore_l1ToL2MessageIndices, "f").set(message.leaf.toString(), indices);
|
|
50
58
|
}
|
|
59
|
+
const lastTotalMessageCount = this.getTotalL1ToL2MessageCount();
|
|
60
|
+
void __classPrivateFieldGet(this, _MessageStore_totalMessageCount, "f").set(lastTotalMessageCount + BigInt(messages.retrievedData.length));
|
|
51
61
|
return true;
|
|
52
62
|
});
|
|
53
63
|
}
|
|
@@ -84,5 +94,5 @@ export class MessageStore {
|
|
|
84
94
|
return messages;
|
|
85
95
|
}
|
|
86
96
|
}
|
|
87
|
-
_MessageStore_l1ToL2Messages = new WeakMap(), _MessageStore_l1ToL2MessageIndices = new WeakMap(),
|
|
88
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
97
|
+
_MessageStore_l1ToL2Messages = new WeakMap(), _MessageStore_l1ToL2MessageIndices = new WeakMap(), _MessageStore_lastSynchedL1Block = new WeakMap(), _MessageStore_totalMessageCount = new WeakMap(), _MessageStore_log = new WeakMap(), _MessageStore_l1ToL2MessagesSubtreeSize = new WeakMap();
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVzc2FnZV9zdG9yZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcmNoaXZlci9rdl9hcmNoaXZlcl9zdG9yZS9tZXNzYWdlX3N0b3JlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQ0EsT0FBTyxFQUNMLEVBQUUsRUFDRixvQkFBb0IsRUFDcEIsMkJBQTJCLEVBQzNCLG1DQUFtQyxHQUNwQyxNQUFNLG9CQUFvQixDQUFDO0FBQzVCLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBSzFEOztHQUVHO0FBQ0gsTUFBTSxPQUFPLFlBQVk7SUFVdkIsWUFBb0IsRUFBZ0I7UUFBaEIsT0FBRSxHQUFGLEVBQUUsQ0FBYztRQVRwQywrQ0FBMEM7UUFDMUMscURBQWtELENBQUMseUVBQXlFO1FBQzVILG1EQUE0QztRQUM1QyxrREFBMkM7UUFFM0MsNEJBQU8saUJBQWlCLENBQUMsOEJBQThCLENBQUMsRUFBQztRQUV6RCxrREFBNkIsQ0FBQyxJQUFJLDJCQUEyQixFQUFDO1FBRzVELHVCQUFBLElBQUksZ0NBQW1CLEVBQUUsQ0FBQyxPQUFPLENBQUMsNEJBQTRCLENBQUMsTUFBQSxDQUFDO1FBQ2hFLHVCQUFBLElBQUksc0NBQXlCLEVBQUUsQ0FBQyxPQUFPLENBQUMsbUNBQW1DLENBQUMsTUFBQSxDQUFDO1FBQzdFLHVCQUFBLElBQUksb0NBQXVCLEVBQUUsQ0FBQyxhQUFhLENBQUMscUNBQXFDLENBQUMsTUFBQSxDQUFDO1FBQ25GLHVCQUFBLElBQUksbUNBQXNCLEVBQUUsQ0FBQyxhQUFhLENBQUMsaUNBQWlDLENBQUMsTUFBQSxDQUFDO0lBQ2hGLENBQUM7SUFFRCwwQkFBMEI7UUFDeEIsT0FBTyx1QkFBQSxJQUFJLHVDQUFtQixDQUFDLEdBQUcsRUFBRSxJQUFJLEVBQUUsQ0FBQztJQUM3QyxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsdUJBQXVCO1FBQ3JCLE9BQU8sdUJBQUEsSUFBSSx3Q0FB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
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"l1_to_l2_message_store.d.ts","sourceRoot":"","sources":["../../../src/archiver/memory_archiver_store/l1_to_l2_message_store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAMtD,OAAO,EAAE,KAAK,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAEnD;;GAEG;AACH,qBAAa,kBAAkB;;IAC7B;;OAEG;IACH,SAAS,CAAC,KAAK,EAAE,GAAG,CAAC,MAAM,EAAE,EAAE,CAAC,CAAa;;IAM7C,UAAU,CAAC,OAAO,EAAE,SAAS;IAQ7B,WAAW,CAAC,WAAW,EAAE,MAAM,GAAG,EAAE,EAAE;IAqBtC;;;;;OAKG;IACH,eAAe,CAAC,aAAa,EAAE,EAAE,EAAE,UAAU,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS;CAe3E"}
|
|
1
|
+
{"version":3,"file":"l1_to_l2_message_store.d.ts","sourceRoot":"","sources":["../../../src/archiver/memory_archiver_store/l1_to_l2_message_store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAMtD,OAAO,EAAE,KAAK,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAEnD;;GAEG;AACH,qBAAa,kBAAkB;;IAC7B;;OAEG;IACH,SAAS,CAAC,KAAK,EAAE,GAAG,CAAC,MAAM,EAAE,EAAE,CAAC,CAAa;;IAM7C,0BAA0B,IAAI,MAAM;IAIpC,UAAU,CAAC,OAAO,EAAE,SAAS;IAQ7B,WAAW,CAAC,WAAW,EAAE,MAAM,GAAG,EAAE,EAAE;IAqBtC;;;;;OAKG;IACH,eAAe,CAAC,aAAa,EAAE,EAAE,EAAE,UAAU,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS;CAe3E"}
|