@aztec/archiver 0.19.0 → 0.21.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/dest/archiver/archiver.d.ts +12 -1
- package/dest/archiver/archiver.d.ts.map +1 -1
- package/dest/archiver/archiver.js +42 -2
- package/dest/archiver/archiver_store.d.ts +25 -0
- 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 +30 -1
- package/dest/archiver/config.d.ts.map +1 -1
- package/dest/archiver/config.js +5 -3
- package/dest/archiver/data_retrieval.js +1 -1
- package/dest/archiver/eth_log_handlers.d.ts +5 -5
- package/dest/archiver/eth_log_handlers.d.ts.map +1 -1
- package/dest/archiver/eth_log_handlers.js +12 -6
- package/dest/archiver/index.d.ts +1 -1
- package/dest/archiver/index.d.ts.map +1 -1
- package/dest/archiver/index.js +2 -2
- package/dest/archiver/kv_archiver_store/block_store.d.ts +59 -0
- package/dest/archiver/kv_archiver_store/block_store.d.ts.map +1 -0
- package/dest/archiver/kv_archiver_store/block_store.js +139 -0
- package/dest/archiver/kv_archiver_store/contract_class_store.d.ts +13 -0
- package/dest/archiver/kv_archiver_store/contract_class_store.d.ts.map +1 -0
- package/dest/archiver/kv_archiver_store/contract_class_store.js +21 -0
- package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts +13 -0
- package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts.map +1 -0
- package/dest/archiver/kv_archiver_store/contract_instance_store.js +21 -0
- package/dest/archiver/kv_archiver_store/contract_store.d.ts +46 -0
- package/dest/archiver/kv_archiver_store/contract_store.d.ts.map +1 -0
- package/dest/archiver/kv_archiver_store/contract_store.js +81 -0
- package/dest/archiver/{lmdb_archiver_store.d.ts → kv_archiver_store/kv_archiver_store.d.ts} +19 -12
- package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts.map +1 -0
- package/dest/archiver/kv_archiver_store/kv_archiver_store.js +225 -0
- package/dest/archiver/kv_archiver_store/log_store.d.ts +35 -0
- package/dest/archiver/kv_archiver_store/log_store.d.ts.map +1 -0
- package/dest/archiver/kv_archiver_store/log_store.js +131 -0
- package/dest/archiver/kv_archiver_store/message_store.d.ts +53 -0
- package/dest/archiver/kv_archiver_store/message_store.d.ts.map +1 -0
- package/dest/archiver/kv_archiver_store/message_store.js +138 -0
- package/dest/archiver/memory_archiver_store/l1_to_l2_message_store.js +1 -1
- package/dest/archiver/memory_archiver_store/memory_archiver_store.d.ts +7 -0
- package/dest/archiver/memory_archiver_store/memory_archiver_store.d.ts.map +1 -1
- package/dest/archiver/memory_archiver_store/memory_archiver_store.js +21 -1
- package/dest/index.d.ts +1 -0
- package/dest/index.d.ts.map +1 -1
- package/dest/index.js +2 -1
- package/dest/rpc/archiver_client.d.ts +3 -0
- package/dest/rpc/archiver_client.d.ts.map +1 -0
- package/dest/rpc/archiver_client.js +15 -0
- package/dest/rpc/archiver_server.d.ts +9 -0
- package/dest/rpc/archiver_server.d.ts.map +1 -0
- package/dest/rpc/archiver_server.js +22 -0
- package/dest/rpc/index.d.ts +3 -0
- package/dest/rpc/index.d.ts.map +1 -0
- package/dest/rpc/index.js +3 -0
- package/package.json +10 -9
- package/dest/archiver/lmdb_archiver_store.d.ts.map +0 -1
- package/dest/archiver/lmdb_archiver_store.js +0 -528
|
@@ -2,7 +2,7 @@ import { ContractData, EncodedContractFunction, ExtendedContractData, L1Actor, L
|
|
|
2
2
|
import { AztecAddress } from '@aztec/foundation/aztec-address';
|
|
3
3
|
import { EthAddress } from '@aztec/foundation/eth-address';
|
|
4
4
|
import { Fr, Point } from '@aztec/foundation/fields';
|
|
5
|
-
import { BufferReader } from '@aztec/foundation/serialize';
|
|
5
|
+
import { BufferReader, numToUInt32BE } from '@aztec/foundation/serialize';
|
|
6
6
|
import { ContractDeploymentEmitterAbi, InboxAbi, RollupAbi } from '@aztec/l1-artifacts';
|
|
7
7
|
import { decodeFunctionData, getAbiItem, getAddress, hexToBytes } from 'viem';
|
|
8
8
|
/**
|
|
@@ -42,12 +42,12 @@ export function processCancelledL1ToL2MessagesLogs(logs) {
|
|
|
42
42
|
export async function processBlockLogs(publicClient, expectedL2BlockNumber, logs) {
|
|
43
43
|
const retrievedBlocks = [];
|
|
44
44
|
for (const log of logs) {
|
|
45
|
-
const blockNum = log.args.
|
|
45
|
+
const blockNum = log.args.blockNumber;
|
|
46
46
|
if (blockNum !== expectedL2BlockNumber) {
|
|
47
47
|
throw new Error('Block number mismatch. Expected: ' + expectedL2BlockNumber + ' but got: ' + blockNum + '.');
|
|
48
48
|
}
|
|
49
49
|
// TODO: Fetch blocks from calldata in parallel
|
|
50
|
-
const newBlock = await getBlockFromCallData(publicClient, log.transactionHash, log.args.
|
|
50
|
+
const newBlock = await getBlockFromCallData(publicClient, log.transactionHash, log.args.blockNumber);
|
|
51
51
|
newBlock.setL1BlockNumber(log.blockNumber);
|
|
52
52
|
retrievedBlocks.push(newBlock);
|
|
53
53
|
expectedL2BlockNumber++;
|
|
@@ -73,8 +73,14 @@ async function getBlockFromCallData(publicClient, txHash, l2BlockNum) {
|
|
|
73
73
|
if (functionName !== 'process') {
|
|
74
74
|
throw new Error(`Unexpected method called ${functionName}`);
|
|
75
75
|
}
|
|
76
|
-
const [,
|
|
77
|
-
const
|
|
76
|
+
const [headerHex, archiveRootHex, , bodyHex] = args;
|
|
77
|
+
const blockBuffer = Buffer.concat([
|
|
78
|
+
Buffer.from(hexToBytes(headerHex)),
|
|
79
|
+
Buffer.from(hexToBytes(archiveRootHex)), // L2Block.archive.root
|
|
80
|
+
numToUInt32BE(Number(l2BlockNum)), // L2Block.archive.nextAvailableLeafIndex
|
|
81
|
+
Buffer.from(hexToBytes(bodyHex)),
|
|
82
|
+
]);
|
|
83
|
+
const block = L2Block.fromBufferWithLogs(blockBuffer);
|
|
78
84
|
if (BigInt(block.number) !== l2BlockNum) {
|
|
79
85
|
throw new Error(`Block number mismatch: expected ${l2BlockNum} but got ${block.number}`);
|
|
80
86
|
}
|
|
@@ -191,4 +197,4 @@ export async function getL1ToL2MessageCancelledLogs(publicClient, inboxAddress,
|
|
|
191
197
|
toBlock: toBlock + 1n, // the toBlock argument in getLogs is exclusive
|
|
192
198
|
});
|
|
193
199
|
}
|
|
194
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
200
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXRoX2xvZ19oYW5kbGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9hcmNoaXZlci9ldGhfbG9nX2hhbmRsZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxZQUFZLEVBQ1osdUJBQXVCLEVBQ3ZCLG9CQUFvQixFQUNwQixPQUFPLEVBQ1AsYUFBYSxFQUNiLE9BQU8sRUFDUCxPQUFPLEdBQ1IsTUFBTSxzQkFBc0IsQ0FBQztBQUM5QixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDL0QsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQzNELE9BQU8sRUFBRSxFQUFFLEVBQUUsS0FBSyxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDckQsT0FBTyxFQUFFLFlBQVksRUFBRSxhQUFhLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUMxRSxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsUUFBUSxFQUFFLFNBQVMsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRXhGLE9BQU8sRUFBMEIsa0JBQWtCLEVBQUUsVUFBVSxFQUFFLFVBQVUsRUFBRSxVQUFVLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFdEc7Ozs7R0FJRztBQUNILE1BQU0sVUFBVSxvQ0FBb0MsQ0FDbEQsSUFBNkU7SUFFN0UsTUFBTSxjQUFjLEdBQThCLEVBQUUsQ0FBQztJQUNyRCxLQUFLLE1BQU0sR0FBRyxJQUFJLElBQUksRUFBRSxDQUFDO1FBQ3ZCLE1BQU0sRUFBRSxNQUFNLEVBQUUsYUFBYSxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLFFBQVEsRUFBRSxHQUFHLEVBQUUsUUFBUSxFQUFFLEdBQ3hHLEdBQUcsQ0FBQyxJQUFJLENBQUM7UUFDWCxjQUFjLENBQUMsSUFBSSxDQUFDO1lBQ2xCLElBQUksYUFBYSxDQUNmLElBQUksT0FBTyxDQUFDLFVBQVUsQ0FBQyxV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
|
package/dest/archiver/index.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
export * from './archiver.js';
|
|
2
2
|
export * from './config.js';
|
|
3
3
|
export { MemoryArchiverStore } from './memory_archiver_store/memory_archiver_store.js';
|
|
4
|
-
export { LMDBArchiverStore } from './lmdb_archiver_store.js';
|
|
5
4
|
export { ArchiverDataStore } from './archiver_store.js';
|
|
5
|
+
export { KVArchiverDataStore } from './kv_archiver_store/kv_archiver_store.js';
|
|
6
6
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/archiver/index.ts"],"names":[],"mappings":"AAAA,cAAc,eAAe,CAAC;AAC9B,cAAc,aAAa,CAAC;AAC5B,OAAO,EAAE,mBAAmB,EAAE,MAAM,kDAAkD,CAAC;AACvF,OAAO,EAAE,iBAAiB,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/archiver/index.ts"],"names":[],"mappings":"AAAA,cAAc,eAAe,CAAC;AAC9B,cAAc,aAAa,CAAC;AAC5B,OAAO,EAAE,mBAAmB,EAAE,MAAM,kDAAkD,CAAC;AACvF,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,EAAE,mBAAmB,EAAE,MAAM,0CAA0C,CAAC"}
|
package/dest/archiver/index.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
export * from './archiver.js';
|
|
2
2
|
export * from './config.js';
|
|
3
3
|
export { MemoryArchiverStore } from './memory_archiver_store/memory_archiver_store.js';
|
|
4
|
-
export {
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
4
|
+
export { KVArchiverDataStore } from './kv_archiver_store/kv_archiver_store.js';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYXJjaGl2ZXIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxhQUFhLENBQUM7QUFDNUIsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sa0RBQWtELENBQUM7QUFFdkYsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sMENBQTBDLENBQUMifQ==
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { L2Block, L2Tx, TxHash } from '@aztec/circuit-types';
|
|
2
|
+
import { AztecAddress } from '@aztec/circuits.js';
|
|
3
|
+
import { AztecKVStore } from '@aztec/kv-store';
|
|
4
|
+
/**
|
|
5
|
+
* LMDB implementation of the ArchiverDataStore interface.
|
|
6
|
+
*/
|
|
7
|
+
export declare class BlockStore {
|
|
8
|
+
#private;
|
|
9
|
+
private db;
|
|
10
|
+
constructor(db: AztecKVStore);
|
|
11
|
+
/**
|
|
12
|
+
* Append new blocks to the store's list.
|
|
13
|
+
* @param blocks - The L2 blocks to be added to the store.
|
|
14
|
+
* @returns True if the operation is successful.
|
|
15
|
+
*/
|
|
16
|
+
addBlocks(blocks: L2Block[]): Promise<boolean>;
|
|
17
|
+
/**
|
|
18
|
+
* Gets up to `limit` amount of L2 blocks starting from `from`.
|
|
19
|
+
* @param start - Number of the first block to return (inclusive).
|
|
20
|
+
* @param limit - The number of blocks to return.
|
|
21
|
+
* @returns The requested L2 blocks, without logs attached
|
|
22
|
+
*/
|
|
23
|
+
getBlocks(start: number, limit: number): IterableIterator<L2Block>;
|
|
24
|
+
/**
|
|
25
|
+
* Gets an L2 block.
|
|
26
|
+
* @param blockNumber - The number of the block to return.
|
|
27
|
+
* @returns The requested L2 block, without logs attached
|
|
28
|
+
*/
|
|
29
|
+
getBlock(blockNumber: number): L2Block | undefined;
|
|
30
|
+
/**
|
|
31
|
+
* Gets an l2 tx.
|
|
32
|
+
* @param txHash - The txHash of the l2 tx.
|
|
33
|
+
* @returns The requested L2 tx.
|
|
34
|
+
*/
|
|
35
|
+
getL2Tx(txHash: TxHash): L2Tx | undefined;
|
|
36
|
+
/**
|
|
37
|
+
* Looks up which block included the requested L2 tx.
|
|
38
|
+
* @param txHash - The txHash of the l2 tx.
|
|
39
|
+
* @returns The block number and index of the tx.
|
|
40
|
+
*/
|
|
41
|
+
getL2TxLocation(txHash: TxHash): [blockNumber: number, txIndex: number] | undefined;
|
|
42
|
+
/**
|
|
43
|
+
* Looks up which block deployed a particular contract.
|
|
44
|
+
* @param contractAddress - The address of the contract to look up.
|
|
45
|
+
* @returns The block number and index of the contract.
|
|
46
|
+
*/
|
|
47
|
+
getContractLocation(contractAddress: AztecAddress): [blockNumber: number, index: number] | undefined;
|
|
48
|
+
/**
|
|
49
|
+
* Gets the number of the latest L2 block processed.
|
|
50
|
+
* @returns The number of the latest L2 block processed.
|
|
51
|
+
*/
|
|
52
|
+
getBlockNumber(): number;
|
|
53
|
+
/**
|
|
54
|
+
* Gets the most recent L1 block processed.
|
|
55
|
+
* @returns The L1 block that published the latest L2 block
|
|
56
|
+
*/
|
|
57
|
+
getL1BlockNumber(): bigint;
|
|
58
|
+
}
|
|
59
|
+
//# sourceMappingURL=block_store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"block_store.d.ts","sourceRoot":"","sources":["../../../src/archiver/kv_archiver_store/block_store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAwB,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AACnF,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAElD,OAAO,EAAE,YAAY,EAAmB,MAAM,iBAAiB,CAAC;AAWhE;;GAEG;AACH,qBAAa,UAAU;;IAYT,OAAO,CAAC,EAAE;gBAAF,EAAE,EAAE,YAAY;IAOpC;;;;OAIG;IACH,SAAS,CAAC,MAAM,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC;IA8B9C;;;;;OAKG;IACF,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,gBAAgB,CAAC,OAAO,CAAC;IAMnE;;;;OAIG;IACH,QAAQ,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,GAAG,SAAS;IAWlD;;;;OAIG;IACH,OAAO,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS;IAUzC;;;;OAIG;IACH,eAAe,CAAC,MAAM,EAAE,MAAM,GAAG,CAAC,WAAW,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,GAAG,SAAS;IAInF;;;;OAIG;IACH,mBAAmB,CAAC,eAAe,EAAE,YAAY,GAAG,CAAC,WAAW,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,GAAG,SAAS;IAIpG;;;OAGG;IACH,cAAc,IAAI,MAAM;IAKxB;;;OAGG;IACH,gBAAgB,IAAI,MAAM;CAsB3B"}
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
var _BlockStore_instances, _BlockStore_blocks, _BlockStore_txIndex, _BlockStore_contractIndex, _BlockStore_log, _BlockStore_computeBlockRange;
|
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
|
+
import { INITIAL_L2_BLOCK_NUM, L2Block } from '@aztec/circuit-types';
|
|
4
|
+
import { createDebugLogger } from '@aztec/foundation/log';
|
|
5
|
+
/**
|
|
6
|
+
* LMDB implementation of the ArchiverDataStore interface.
|
|
7
|
+
*/
|
|
8
|
+
export class BlockStore {
|
|
9
|
+
constructor(db) {
|
|
10
|
+
_BlockStore_instances.add(this);
|
|
11
|
+
this.db = db;
|
|
12
|
+
/** Map block number to block data */
|
|
13
|
+
_BlockStore_blocks.set(this, void 0);
|
|
14
|
+
/** Index mapping transaction hash (as a string) to its location in a block */
|
|
15
|
+
_BlockStore_txIndex.set(this, void 0);
|
|
16
|
+
/** Index mapping a contract's address (as a string) to its location in a block */
|
|
17
|
+
_BlockStore_contractIndex.set(this, void 0);
|
|
18
|
+
_BlockStore_log.set(this, createDebugLogger('aztec:archiver:block_store'));
|
|
19
|
+
__classPrivateFieldSet(this, _BlockStore_blocks, db.openMap('archiver_blocks'), "f");
|
|
20
|
+
__classPrivateFieldSet(this, _BlockStore_txIndex, db.openMap('archiver_tx_index'), "f");
|
|
21
|
+
__classPrivateFieldSet(this, _BlockStore_contractIndex, db.openMap('archiver_contract_index'), "f");
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Append new blocks to the store's list.
|
|
25
|
+
* @param blocks - The L2 blocks to be added to the store.
|
|
26
|
+
* @returns True if the operation is successful.
|
|
27
|
+
*/
|
|
28
|
+
addBlocks(blocks) {
|
|
29
|
+
return this.db.transaction(() => {
|
|
30
|
+
for (const block of blocks) {
|
|
31
|
+
void __classPrivateFieldGet(this, _BlockStore_blocks, "f").set(block.number, {
|
|
32
|
+
blockNumber: block.number,
|
|
33
|
+
block: block.toBuffer(),
|
|
34
|
+
l1BlockNumber: block.getL1BlockNumber(),
|
|
35
|
+
blockHash: block.getBlockHash(),
|
|
36
|
+
});
|
|
37
|
+
for (const [i, tx] of block.getTxs().entries()) {
|
|
38
|
+
if (tx.txHash.isZero()) {
|
|
39
|
+
continue;
|
|
40
|
+
}
|
|
41
|
+
void __classPrivateFieldGet(this, _BlockStore_txIndex, "f").set(tx.txHash.toString(), [block.number, i]);
|
|
42
|
+
}
|
|
43
|
+
for (const [i, contractData] of block.newContractData.entries()) {
|
|
44
|
+
if (contractData.contractAddress.isZero()) {
|
|
45
|
+
continue;
|
|
46
|
+
}
|
|
47
|
+
void __classPrivateFieldGet(this, _BlockStore_contractIndex, "f").set(contractData.contractAddress.toString(), [block.number, i]);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
return true;
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Gets up to `limit` amount of L2 blocks starting from `from`.
|
|
55
|
+
* @param start - Number of the first block to return (inclusive).
|
|
56
|
+
* @param limit - The number of blocks to return.
|
|
57
|
+
* @returns The requested L2 blocks, without logs attached
|
|
58
|
+
*/
|
|
59
|
+
*getBlocks(start, limit) {
|
|
60
|
+
for (const blockCtx of __classPrivateFieldGet(this, _BlockStore_blocks, "f").values(__classPrivateFieldGet(this, _BlockStore_instances, "m", _BlockStore_computeBlockRange).call(this, start, limit))) {
|
|
61
|
+
yield L2Block.fromBuffer(blockCtx.block, blockCtx.blockHash);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Gets an L2 block.
|
|
66
|
+
* @param blockNumber - The number of the block to return.
|
|
67
|
+
* @returns The requested L2 block, without logs attached
|
|
68
|
+
*/
|
|
69
|
+
getBlock(blockNumber) {
|
|
70
|
+
const blockCtx = __classPrivateFieldGet(this, _BlockStore_blocks, "f").get(blockNumber);
|
|
71
|
+
if (!blockCtx || !blockCtx.block) {
|
|
72
|
+
return undefined;
|
|
73
|
+
}
|
|
74
|
+
const block = L2Block.fromBuffer(blockCtx.block, blockCtx.blockHash);
|
|
75
|
+
return block;
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Gets an l2 tx.
|
|
79
|
+
* @param txHash - The txHash of the l2 tx.
|
|
80
|
+
* @returns The requested L2 tx.
|
|
81
|
+
*/
|
|
82
|
+
getL2Tx(txHash) {
|
|
83
|
+
const [blockNumber, txIndex] = this.getL2TxLocation(txHash) ?? [];
|
|
84
|
+
if (typeof blockNumber !== 'number' || typeof txIndex !== 'number') {
|
|
85
|
+
return undefined;
|
|
86
|
+
}
|
|
87
|
+
const block = this.getBlock(blockNumber);
|
|
88
|
+
return block?.getTx(txIndex);
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Looks up which block included the requested L2 tx.
|
|
92
|
+
* @param txHash - The txHash of the l2 tx.
|
|
93
|
+
* @returns The block number and index of the tx.
|
|
94
|
+
*/
|
|
95
|
+
getL2TxLocation(txHash) {
|
|
96
|
+
return __classPrivateFieldGet(this, _BlockStore_txIndex, "f").get(txHash.toString());
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* Looks up which block deployed a particular contract.
|
|
100
|
+
* @param contractAddress - The address of the contract to look up.
|
|
101
|
+
* @returns The block number and index of the contract.
|
|
102
|
+
*/
|
|
103
|
+
getContractLocation(contractAddress) {
|
|
104
|
+
return __classPrivateFieldGet(this, _BlockStore_contractIndex, "f").get(contractAddress.toString());
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* Gets the number of the latest L2 block processed.
|
|
108
|
+
* @returns The number of the latest L2 block processed.
|
|
109
|
+
*/
|
|
110
|
+
getBlockNumber() {
|
|
111
|
+
const [lastBlockNumber] = __classPrivateFieldGet(this, _BlockStore_blocks, "f").keys({ reverse: true, limit: 1 });
|
|
112
|
+
return typeof lastBlockNumber === 'number' ? lastBlockNumber : INITIAL_L2_BLOCK_NUM - 1;
|
|
113
|
+
}
|
|
114
|
+
/**
|
|
115
|
+
* Gets the most recent L1 block processed.
|
|
116
|
+
* @returns The L1 block that published the latest L2 block
|
|
117
|
+
*/
|
|
118
|
+
getL1BlockNumber() {
|
|
119
|
+
const [lastBlock] = __classPrivateFieldGet(this, _BlockStore_blocks, "f").values({ reverse: true, limit: 1 });
|
|
120
|
+
if (!lastBlock) {
|
|
121
|
+
return 0n;
|
|
122
|
+
}
|
|
123
|
+
else {
|
|
124
|
+
return lastBlock.l1BlockNumber;
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
_BlockStore_blocks = 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) {
|
|
129
|
+
if (limit < 1) {
|
|
130
|
+
throw new Error(`Invalid limit: ${limit}`);
|
|
131
|
+
}
|
|
132
|
+
if (start < INITIAL_L2_BLOCK_NUM) {
|
|
133
|
+
__classPrivateFieldGet(this, _BlockStore_log, "f").call(this, `Clamping start block ${start} to ${INITIAL_L2_BLOCK_NUM}`);
|
|
134
|
+
start = INITIAL_L2_BLOCK_NUM;
|
|
135
|
+
}
|
|
136
|
+
const end = start + limit;
|
|
137
|
+
return { start, end };
|
|
138
|
+
};
|
|
139
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxvY2tfc3RvcmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXJjaGl2ZXIva3ZfYXJjaGl2ZXJfc3RvcmUvYmxvY2tfc3RvcmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsT0FBTyxFQUFnQixNQUFNLHNCQUFzQixDQUFDO0FBRW5GLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBWTFEOztHQUVHO0FBQ0gsTUFBTSxPQUFPLFVBQVU7SUFZckIsWUFBb0IsRUFBZ0I7O1FBQWhCLE9BQUUsR0FBRixFQUFFLENBQWM7UUFYcEMscUNBQXFDO1FBQ3JDLHFDQUF3QztRQUV4Qyw4RUFBOEU7UUFDOUUsc0NBQTRDO1FBRTVDLGtGQUFrRjtRQUNsRiw0Q0FBa0Q7UUFFbEQsMEJBQU8saUJBQWlCLENBQUMsNEJBQTRCLENBQUMsRUFBQztRQUdyRCx1QkFBQSxJQUFJLHNCQUFXLEVBQUUsQ0FBQyxPQUFPLENBQUMsaUJBQWlCLENBQUMsTUFBQSxDQUFDO1FBRTdDLHVCQUFBLElBQUksdUJBQVksRUFBRSxDQUFDLE9BQU8sQ0FBQyxtQkFBbUIsQ0FBQyxNQUFBLENBQUM7UUFDaEQsdUJBQUEsSUFBSSw2QkFBa0IsRUFBRSxDQUFDLE9BQU8sQ0FBQyx5QkFBeUIsQ0FBQyxNQUFBLENBQUM7SUFDOUQsQ0FBQztJQUVEOzs7O09BSUc7SUFDSCxTQUFTLENBQUMsTUFBaUI7UUFDekIsT0FBTyxJQUFJLENBQUMsRUFBRSxDQUFDLFdBQVcsQ0FBQyxHQUFHLEVBQUU7WUFDOUIsS0FBSyxNQUFNLEtBQUssSUFBSSxNQUFNLEVBQUUsQ0FBQztnQkFDM0IsS0FBSyx1QkFBQSxJQUFJLDBCQUFRLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUU7b0JBQ2xDLFdBQVcsRUFBRSxLQUFLLENBQUMsTUFBTTtvQkFDekIsS0FBSyxFQUFFLEtBQUssQ0FBQyxR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
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Fr } from '@aztec/foundation/fields';
|
|
2
|
+
import { AztecKVStore } from '@aztec/kv-store';
|
|
3
|
+
import { ContractClassWithId } from '@aztec/types/contracts';
|
|
4
|
+
/**
|
|
5
|
+
* LMDB implementation of the ArchiverDataStore interface.
|
|
6
|
+
*/
|
|
7
|
+
export declare class ContractClassStore {
|
|
8
|
+
#private;
|
|
9
|
+
constructor(db: AztecKVStore);
|
|
10
|
+
addContractClass(contractClass: ContractClassWithId): Promise<boolean>;
|
|
11
|
+
getContractClass(id: Fr): ContractClassWithId | undefined;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=contract_class_store.d.ts.map
|
|
@@ -0,0 +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,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAC9C,OAAO,EAAE,YAAY,EAAY,MAAM,iBAAiB,CAAC;AACzD,OAAO,EAAE,mBAAmB,EAA6B,MAAM,wBAAwB,CAAC;AAExF;;GAEG;AACH,qBAAa,kBAAkB;;gBAGjB,EAAE,EAAE,YAAY;IAI5B,gBAAgB,CAAC,aAAa,EAAE,mBAAmB,GAAG,OAAO,CAAC,OAAO,CAAC;IAOtE,gBAAgB,CAAC,EAAE,EAAE,EAAE,GAAG,mBAAmB,GAAG,SAAS;CAI1D"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
var _ContractClassStore_contractClasses;
|
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
|
+
import { SerializableContractClass } from '@aztec/types/contracts';
|
|
4
|
+
/**
|
|
5
|
+
* LMDB implementation of the ArchiverDataStore interface.
|
|
6
|
+
*/
|
|
7
|
+
export class ContractClassStore {
|
|
8
|
+
constructor(db) {
|
|
9
|
+
_ContractClassStore_contractClasses.set(this, void 0);
|
|
10
|
+
__classPrivateFieldSet(this, _ContractClassStore_contractClasses, db.openMap('archiver_contract_classes'), "f");
|
|
11
|
+
}
|
|
12
|
+
addContractClass(contractClass) {
|
|
13
|
+
return __classPrivateFieldGet(this, _ContractClassStore_contractClasses, "f").set(contractClass.id.toString(), new SerializableContractClass(contractClass).toBuffer());
|
|
14
|
+
}
|
|
15
|
+
getContractClass(id) {
|
|
16
|
+
const contractClass = __classPrivateFieldGet(this, _ContractClassStore_contractClasses, "f").get(id.toString());
|
|
17
|
+
return contractClass && SerializableContractClass.fromBuffer(contractClass).withId(id);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
_ContractClassStore_contractClasses = new WeakMap();
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udHJhY3RfY2xhc3Nfc3RvcmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXJjaGl2ZXIva3ZfYXJjaGl2ZXJfc3RvcmUvY29udHJhY3RfY2xhc3Nfc3RvcmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFFQSxPQUFPLEVBQXVCLHlCQUF5QixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFeEY7O0dBRUc7QUFDSCxNQUFNLE9BQU8sa0JBQWtCO0lBRzdCLFlBQVksRUFBZ0I7UUFGNUIsc0RBQTJDO1FBR3pDLHVCQUFBLElBQUksdUNBQW9CLEVBQUUsQ0FBQyxPQUFPLENBQUMsMkJBQTJCLENBQUMsTUFBQSxDQUFDO0lBQ2xFLENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxhQUFrQztRQUNqRCxPQUFPLHVCQUFBLElBQUksMkNBQWlCLENBQUMsR0FBRyxDQUM5QixhQUFhLENBQUMsRUFBRSxDQUFDLFFBQVEsRUFBRSxFQUMzQixJQUFJLHlCQUF5QixDQUFDLGFBQWEsQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUN4RCxDQUFDO0lBQ0osQ0FBQztJQUVELGdCQUFnQixDQUFDLEVBQU07UUFDckIsTUFBTSxhQUFhLEdBQUcsdUJBQUEsSUFBSSwyQ0FBaUIsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUM7UUFDL0QsT0FBTyxhQUFhLElBQUkseUJBQXlCLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUN6RixDQUFDO0NBQ0YifQ==
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { AztecAddress } from '@aztec/circuits.js';
|
|
2
|
+
import { AztecKVStore } from '@aztec/kv-store';
|
|
3
|
+
import { ContractInstanceWithAddress } from '@aztec/types/contracts';
|
|
4
|
+
/**
|
|
5
|
+
* LMDB implementation of the ArchiverDataStore interface.
|
|
6
|
+
*/
|
|
7
|
+
export declare class ContractInstanceStore {
|
|
8
|
+
#private;
|
|
9
|
+
constructor(db: AztecKVStore);
|
|
10
|
+
addContractInstance(contractInstance: ContractInstanceWithAddress): Promise<boolean>;
|
|
11
|
+
getContractInstance(address: AztecAddress): ContractInstanceWithAddress | undefined;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=contract_instance_store.d.ts.map
|
|
@@ -0,0 +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,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAY,MAAM,iBAAiB,CAAC;AACzD,OAAO,EAAE,2BAA2B,EAAgC,MAAM,wBAAwB,CAAC;AAEnG;;GAEG;AACH,qBAAa,qBAAqB;;gBAGpB,EAAE,EAAE,YAAY;IAI5B,mBAAmB,CAAC,gBAAgB,EAAE,2BAA2B,GAAG,OAAO,CAAC,OAAO,CAAC;IAOpF,mBAAmB,CAAC,OAAO,EAAE,YAAY,GAAG,2BAA2B,GAAG,SAAS;CAIpF"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
var _ContractInstanceStore_contractInstances;
|
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
|
+
import { SerializableContractInstance } from '@aztec/types/contracts';
|
|
4
|
+
/**
|
|
5
|
+
* LMDB implementation of the ArchiverDataStore interface.
|
|
6
|
+
*/
|
|
7
|
+
export class ContractInstanceStore {
|
|
8
|
+
constructor(db) {
|
|
9
|
+
_ContractInstanceStore_contractInstances.set(this, void 0);
|
|
10
|
+
__classPrivateFieldSet(this, _ContractInstanceStore_contractInstances, db.openMap('archiver_contract_instances'), "f");
|
|
11
|
+
}
|
|
12
|
+
addContractInstance(contractInstance) {
|
|
13
|
+
return __classPrivateFieldGet(this, _ContractInstanceStore_contractInstances, "f").set(contractInstance.address.toString(), new SerializableContractInstance(contractInstance).toBuffer());
|
|
14
|
+
}
|
|
15
|
+
getContractInstance(address) {
|
|
16
|
+
const contractInstance = __classPrivateFieldGet(this, _ContractInstanceStore_contractInstances, "f").get(address.toString());
|
|
17
|
+
return contractInstance && SerializableContractInstance.fromBuffer(contractInstance).withAddress(address);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
_ContractInstanceStore_contractInstances = new WeakMap();
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udHJhY3RfaW5zdGFuY2Vfc3RvcmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXJjaGl2ZXIva3ZfYXJjaGl2ZXJfc3RvcmUvY29udHJhY3RfaW5zdGFuY2Vfc3RvcmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFFQSxPQUFPLEVBQStCLDRCQUE0QixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFbkc7O0dBRUc7QUFDSCxNQUFNLE9BQU8scUJBQXFCO0lBR2hDLFlBQVksRUFBZ0I7UUFGNUIsMkRBQTZDO1FBRzNDLHVCQUFBLElBQUksNENBQXNCLEVBQUUsQ0FBQyxPQUFPLENBQUMsNkJBQTZCLENBQUMsTUFBQSxDQUFDO0lBQ3RFLENBQUM7SUFFRCxtQkFBbUIsQ0FBQyxnQkFBNkM7UUFDL0QsT0FBTyx1QkFBQSxJQUFJLGdEQUFtQixDQUFDLEdBQUcsQ0FDaEMsZ0JBQWdCLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRSxFQUNuQyxJQUFJLDRCQUE0QixDQUFDLGdCQUFnQixDQUFDLENBQUMsUUFBUSxFQUFFLENBQzlELENBQUM7SUFDSixDQUFDO0lBRUQsbUJBQW1CLENBQUMsT0FBcUI7UUFDdkMsTUFBTSxnQkFBZ0IsR0FBRyx1QkFBQSxJQUFJLGdEQUFtQixDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQztRQUN6RSxPQUFPLGdCQUFnQixJQUFJLDRCQUE0QixDQUFDLFVBQVUsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUM1RyxDQUFDO0NBQ0YifQ==
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { ContractData, ExtendedContractData } from '@aztec/circuit-types';
|
|
2
|
+
import { AztecAddress } from '@aztec/foundation/aztec-address';
|
|
3
|
+
import { AztecKVStore } from '@aztec/kv-store';
|
|
4
|
+
import { BlockStore } from './block_store.js';
|
|
5
|
+
/**
|
|
6
|
+
* LMDB implementation of the ArchiverDataStore interface.
|
|
7
|
+
*/
|
|
8
|
+
export declare class ContractStore {
|
|
9
|
+
#private;
|
|
10
|
+
private db;
|
|
11
|
+
constructor(db: AztecKVStore, blockStore: BlockStore);
|
|
12
|
+
/**
|
|
13
|
+
* Add new extended contract data from an L2 block to the store's list.
|
|
14
|
+
* @param data - List of contracts' data to be added.
|
|
15
|
+
* @param blockNum - Number of the L2 block the contract data was deployed in.
|
|
16
|
+
* @returns True if the operation is successful.
|
|
17
|
+
*/
|
|
18
|
+
addExtendedContractData(data: ExtendedContractData[], blockNum: number): Promise<boolean>;
|
|
19
|
+
/**
|
|
20
|
+
* Get the extended contract data for this contract.
|
|
21
|
+
* @param contractAddress - The contract data address.
|
|
22
|
+
* @returns The extended contract data or undefined if not found.
|
|
23
|
+
*/
|
|
24
|
+
getExtendedContractData(contractAddress: AztecAddress): ExtendedContractData | undefined;
|
|
25
|
+
/**
|
|
26
|
+
* Lookup all extended contract data in an L2 block.
|
|
27
|
+
* @param blockNumber - The block number to get all contract data from.
|
|
28
|
+
* @returns All extended contract data in the block (if found).
|
|
29
|
+
*/
|
|
30
|
+
getExtendedContractDataInBlock(blockNumber: number): Array<ExtendedContractData>;
|
|
31
|
+
/**
|
|
32
|
+
* Get basic info for an L2 contract.
|
|
33
|
+
* Contains contract address & the ethereum portal address.
|
|
34
|
+
* @param contractAddress - The contract data address.
|
|
35
|
+
* @returns ContractData with the portal address (if we didn't throw an error).
|
|
36
|
+
*/
|
|
37
|
+
getContractData(contractAddress: AztecAddress): ContractData | undefined;
|
|
38
|
+
/**
|
|
39
|
+
* Get basic info for an all L2 contracts deployed in a block.
|
|
40
|
+
* Contains contract address & the ethereum portal address.
|
|
41
|
+
* @param blockNumber - Number of the L2 block where contracts were deployed.
|
|
42
|
+
* @returns ContractData with the portal address (if we didn't throw an error).
|
|
43
|
+
*/
|
|
44
|
+
getContractDataInBlock(blockNumber: number): ContractData[];
|
|
45
|
+
}
|
|
46
|
+
//# sourceMappingURL=contract_store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contract_store.d.ts","sourceRoot":"","sources":["../../../src/archiver/kv_archiver_store/contract_store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAC1E,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AAE/D,OAAO,EAAE,YAAY,EAAY,MAAM,iBAAiB,CAAC;AAEzD,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAE9C;;GAEG;AACH,qBAAa,aAAa;;IAKZ,OAAO,CAAC,EAAE;gBAAF,EAAE,EAAE,YAAY,EAAE,UAAU,EAAE,UAAU;IAK5D;;;;;OAKG;IACH,uBAAuB,CAAC,IAAI,EAAE,oBAAoB,EAAE,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAOzF;;;;OAIG;IACH,uBAAuB,CAAC,eAAe,EAAE,YAAY,GAAG,oBAAoB,GAAG,SAAS;IAiBxF;;;;OAIG;IACH,8BAA8B,CAAC,WAAW,EAAE,MAAM,GAAG,KAAK,CAAC,oBAAoB,CAAC;IAMhF;;;;;OAKG;IACH,eAAe,CAAC,eAAe,EAAE,YAAY,GAAG,YAAY,GAAG,SAAS;IAUxE;;;;;OAKG;IACH,sBAAsB,CAAC,WAAW,EAAE,MAAM,GAAG,YAAY,EAAE;CAI5D"}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
var _ContractStore_blockStore, _ContractStore_extendedContractData, _ContractStore_log;
|
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
|
+
import { ExtendedContractData } from '@aztec/circuit-types';
|
|
4
|
+
import { createDebugLogger } from '@aztec/foundation/log';
|
|
5
|
+
/**
|
|
6
|
+
* LMDB implementation of the ArchiverDataStore interface.
|
|
7
|
+
*/
|
|
8
|
+
export class ContractStore {
|
|
9
|
+
constructor(db, blockStore) {
|
|
10
|
+
this.db = db;
|
|
11
|
+
_ContractStore_blockStore.set(this, void 0);
|
|
12
|
+
_ContractStore_extendedContractData.set(this, void 0);
|
|
13
|
+
_ContractStore_log.set(this, createDebugLogger('aztec:archiver:contract_store'));
|
|
14
|
+
__classPrivateFieldSet(this, _ContractStore_extendedContractData, db.openMap('archiver_extended_contract_data'), "f");
|
|
15
|
+
__classPrivateFieldSet(this, _ContractStore_blockStore, blockStore, "f");
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Add new extended contract data from an L2 block to the store's list.
|
|
19
|
+
* @param data - List of contracts' data to be added.
|
|
20
|
+
* @param blockNum - Number of the L2 block the contract data was deployed in.
|
|
21
|
+
* @returns True if the operation is successful.
|
|
22
|
+
*/
|
|
23
|
+
addExtendedContractData(data, blockNum) {
|
|
24
|
+
return __classPrivateFieldGet(this, _ContractStore_extendedContractData, "f").swap(blockNum, (existingData = []) => {
|
|
25
|
+
existingData.push(...data.map(d => d.toBuffer()));
|
|
26
|
+
return existingData;
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Get the extended contract data for this contract.
|
|
31
|
+
* @param contractAddress - The contract data address.
|
|
32
|
+
* @returns The extended contract data or undefined if not found.
|
|
33
|
+
*/
|
|
34
|
+
getExtendedContractData(contractAddress) {
|
|
35
|
+
const [blockNumber, _] = __classPrivateFieldGet(this, _ContractStore_blockStore, "f").getContractLocation(contractAddress) ?? [];
|
|
36
|
+
if (typeof blockNumber !== 'number') {
|
|
37
|
+
return undefined;
|
|
38
|
+
}
|
|
39
|
+
for (const contract of __classPrivateFieldGet(this, _ContractStore_extendedContractData, "f").get(blockNumber) ?? []) {
|
|
40
|
+
const extendedContractData = ExtendedContractData.fromBuffer(contract);
|
|
41
|
+
if (extendedContractData.contractData.contractAddress.equals(contractAddress)) {
|
|
42
|
+
return extendedContractData;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
return undefined;
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Lookup all extended contract data in an L2 block.
|
|
49
|
+
* @param blockNumber - The block number to get all contract data from.
|
|
50
|
+
* @returns All extended contract data in the block (if found).
|
|
51
|
+
*/
|
|
52
|
+
getExtendedContractDataInBlock(blockNumber) {
|
|
53
|
+
return (__classPrivateFieldGet(this, _ContractStore_extendedContractData, "f").get(blockNumber) ?? []).map(contract => ExtendedContractData.fromBuffer(contract));
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Get basic info for an L2 contract.
|
|
57
|
+
* Contains contract address & the ethereum portal address.
|
|
58
|
+
* @param contractAddress - The contract data address.
|
|
59
|
+
* @returns ContractData with the portal address (if we didn't throw an error).
|
|
60
|
+
*/
|
|
61
|
+
getContractData(contractAddress) {
|
|
62
|
+
const [blockNumber, index] = __classPrivateFieldGet(this, _ContractStore_blockStore, "f").getContractLocation(contractAddress) ?? [];
|
|
63
|
+
if (typeof blockNumber !== 'number' || typeof index !== 'number') {
|
|
64
|
+
return undefined;
|
|
65
|
+
}
|
|
66
|
+
const block = __classPrivateFieldGet(this, _ContractStore_blockStore, "f").getBlock(blockNumber);
|
|
67
|
+
return block?.newContractData[index];
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* Get basic info for an all L2 contracts deployed in a block.
|
|
71
|
+
* Contains contract address & the ethereum portal address.
|
|
72
|
+
* @param blockNumber - Number of the L2 block where contracts were deployed.
|
|
73
|
+
* @returns ContractData with the portal address (if we didn't throw an error).
|
|
74
|
+
*/
|
|
75
|
+
getContractDataInBlock(blockNumber) {
|
|
76
|
+
const block = __classPrivateFieldGet(this, _ContractStore_blockStore, "f").getBlock(blockNumber);
|
|
77
|
+
return block?.newContractData ?? [];
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
_ContractStore_blockStore = new WeakMap(), _ContractStore_extendedContractData = new WeakMap(), _ContractStore_log = new WeakMap();
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udHJhY3Rfc3RvcmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXJjaGl2ZXIva3ZfYXJjaGl2ZXJfc3RvcmUvY29udHJhY3Rfc3RvcmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxPQUFPLEVBQWdCLG9CQUFvQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFMUUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFLMUQ7O0dBRUc7QUFDSCxNQUFNLE9BQU8sYUFBYTtJQUt4QixZQUFvQixFQUFnQixFQUFFLFVBQXNCO1FBQXhDLE9BQUUsR0FBRixFQUFFLENBQWM7UUFKcEMsNENBQXdCO1FBQ3hCLHNEQUFrRDtRQUNsRCw2QkFBTyxpQkFBaUIsQ0FBQywrQkFBK0IsQ0FBQyxFQUFDO1FBR3hELHVCQUFBLElBQUksdUNBQXlCLEVBQUUsQ0FBQyxPQUFPLENBQUMsaUNBQWlDLENBQUMsTUFBQSxDQUFDO1FBQzNFLHVCQUFBLElBQUksNkJBQWUsVUFBVSxNQUFBLENBQUM7SUFDaEMsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gsdUJBQXVCLENBQUMsSUFBNEIsRUFBRSxRQUFnQjtRQUNwRSxPQUFPLHVCQUFBLElBQUksMkNBQXNCLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDLFlBQVksR0FBRyxFQUFFLEVBQUUsRUFBRTtZQUNyRSxZQUFZLENBQUMsSUFBSSxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDLENBQUM7WUFDbEQsT0FBTyxZQUFZLENBQUM7UUFDdEIsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQ7Ozs7T0FJRztJQUNILHVCQUF1QixDQUFDLGVBQTZCO1FBQ25ELE1BQU0sQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDLEdBQUcsdUJBQUEsSUFBSSxpQ0FBWSxDQUFDLG1CQUFtQixDQUFDLGVBQWUsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUVyRixJQUFJLE9BQU8sV0FBVyxLQUFLLFFBQVEsRUFBRSxDQUFDO1lBQ3BDLE9BQU8sU0FBUyxDQUFDO1FBQ25CLENBQUM7UUFFRCxLQUFLLE1BQU0sUUFBUSxJQUFJLHVCQUFBLElBQUksMkNBQXNCLENBQUMsR0FBRyxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDO1lBQ3pFLE1BQU0sb0JBQW9CLEdBQUcsb0JBQW9CLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBQ3ZFLElBQUksb0JBQW9CLENBQUMsWUFBWSxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsZUFBZSxDQUFDLEVBQUUsQ0FBQztnQkFDOUUsT0FBTyxvQkFBb0IsQ0FBQztZQUM5QixDQUFDO1FBQ0gsQ0FBQztRQUVELE9BQU8sU0FBUyxDQUFDO0lBQ25CLENBQUM7SUFFRDs7OztPQUlHO0lBQ0gsOEJBQThCLENBQUMsV0FBbUI7UUFDaEQsT0FBTyxDQUFDLHVCQUFBLElBQUksMkNBQXNCLENBQUMsR0FBRyxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUN4RSxvQkFBb0IsQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLENBQzFDLENBQUM7SUFDSixDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCxlQUFlLENBQUMsZUFBNkI7UUFDM0MsTUFBTSxDQUFDLFdBQVcsRUFBRSxLQUFLLENBQUMsR0FBRyx1QkFBQSxJQUFJLGlDQUFZLENBQUMsbUJBQW1CLENBQUMsZUFBZSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3pGLElBQUksT0FBTyxXQUFXLEtBQUssUUFBUSxJQUFJLE9BQU8sS0FBSyxLQUFLLFFBQVEsRUFBRSxDQUFDO1lBQ2pFLE9BQU8sU0FBUyxDQUFDO1FBQ25CLENBQUM7UUFFRCxNQUFNLEtBQUssR0FBRyx1QkFBQSxJQUFJLGlDQUFZLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQ3JELE9BQU8sS0FBSyxFQUFFLGVBQWUsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN2QyxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCxzQkFBc0IsQ0FBQyxXQUFtQjtRQUN4QyxNQUFNLEtBQUssR0FBRyx1QkFBQSxJQUFJLGlDQUFZLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQ3JELE9BQU8sS0FBSyxFQUFFLGVBQWUsSUFBSSxFQUFFLENBQUM7SUFDdEMsQ0FBQztDQUNGIn0=
|
|
@@ -1,15 +1,19 @@
|
|
|
1
1
|
import { ContractData, ExtendedContractData, GetUnencryptedLogsResponse, L1ToL2Message, L2Block, L2BlockL2Logs, L2Tx, LogFilter, LogType, TxHash } from '@aztec/circuit-types';
|
|
2
2
|
import { Fr } from '@aztec/circuits.js';
|
|
3
3
|
import { AztecAddress } from '@aztec/foundation/aztec-address';
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
4
|
+
import { AztecKVStore } from '@aztec/kv-store';
|
|
5
|
+
import { ContractClassWithId, ContractInstanceWithAddress } from '@aztec/types/contracts';
|
|
6
|
+
import { ArchiverDataStore, ArchiverL1SynchPoint } from '../archiver_store.js';
|
|
6
7
|
/**
|
|
7
8
|
* LMDB implementation of the ArchiverDataStore interface.
|
|
8
9
|
*/
|
|
9
|
-
export declare class
|
|
10
|
+
export declare class KVArchiverDataStore implements ArchiverDataStore {
|
|
10
11
|
#private;
|
|
11
|
-
constructor(db:
|
|
12
|
-
|
|
12
|
+
constructor(db: AztecKVStore, logsMaxPageSize?: number);
|
|
13
|
+
getContractClass(id: Fr): Promise<ContractClassWithId | undefined>;
|
|
14
|
+
getContractInstance(address: AztecAddress): Promise<ContractInstanceWithAddress | undefined>;
|
|
15
|
+
addContractClasses(data: ContractClassWithId[], _blockNumber: number): Promise<boolean>;
|
|
16
|
+
addContractInstances(data: ContractInstanceWithAddress[], _blockNumber: number): Promise<boolean>;
|
|
13
17
|
/**
|
|
14
18
|
* Append new blocks to the store's list.
|
|
15
19
|
* @param blocks - The L2 blocks to be added to the store.
|
|
@@ -18,9 +22,11 @@ export declare class LMDBArchiverStore implements ArchiverDataStore {
|
|
|
18
22
|
addBlocks(blocks: L2Block[]): Promise<boolean>;
|
|
19
23
|
/**
|
|
20
24
|
* Gets up to `limit` amount of L2 blocks starting from `from`.
|
|
25
|
+
* The blocks returned do not contain any logs.
|
|
26
|
+
*
|
|
21
27
|
* @param start - Number of the first block to return (inclusive).
|
|
22
28
|
* @param limit - The number of blocks to return.
|
|
23
|
-
* @returns The requested L2 blocks
|
|
29
|
+
* @returns The requested L2 blocks, without any logs attached
|
|
24
30
|
*/
|
|
25
31
|
getBlocks(start: number, limit: number): Promise<L2Block[]>;
|
|
26
32
|
/**
|
|
@@ -46,15 +52,16 @@ export declare class LMDBArchiverStore implements ArchiverDataStore {
|
|
|
46
52
|
addPendingL1ToL2Messages(messages: L1ToL2Message[], l1BlockNumber: bigint): Promise<boolean>;
|
|
47
53
|
/**
|
|
48
54
|
* Remove pending L1 to L2 messages from the store (if they were cancelled).
|
|
49
|
-
* @param
|
|
55
|
+
* @param messages - The message keys to be removed from the store.
|
|
50
56
|
* @param l1BlockNumber - The L1 block number for which to remove the messages.
|
|
51
57
|
* @returns True if the operation is successful.
|
|
52
58
|
*/
|
|
53
|
-
cancelPendingL1ToL2Messages(
|
|
59
|
+
cancelPendingL1ToL2Messages(messages: Fr[], l1BlockNumber: bigint): Promise<boolean>;
|
|
54
60
|
/**
|
|
55
61
|
* Messages that have been published in an L2 block are confirmed.
|
|
56
62
|
* Add them to the confirmed store, also remove them from the pending store.
|
|
57
63
|
* @param entryKeys - The message keys to be removed from the store.
|
|
64
|
+
* @param blockNumber - The block for which to add the messages.
|
|
58
65
|
* @returns True if the operation is successful.
|
|
59
66
|
*/
|
|
60
67
|
confirmL1ToL2Messages(entryKeys: Fr[]): Promise<boolean>;
|
|
@@ -99,10 +106,10 @@ export declare class LMDBArchiverStore implements ArchiverDataStore {
|
|
|
99
106
|
getExtendedContractData(contractAddress: AztecAddress): Promise<ExtendedContractData | undefined>;
|
|
100
107
|
/**
|
|
101
108
|
* Lookup all extended contract data in an L2 block.
|
|
102
|
-
* @param
|
|
109
|
+
* @param blockNumber - The block number to get all contract data from.
|
|
103
110
|
* @returns All extended contract data in the block (if found).
|
|
104
111
|
*/
|
|
105
|
-
getExtendedContractDataInBlock(
|
|
112
|
+
getExtendedContractDataInBlock(blockNumber: number): Promise<ExtendedContractData[]>;
|
|
106
113
|
/**
|
|
107
114
|
* Get basic info for an L2 contract.
|
|
108
115
|
* Contains contract address & the ethereum portal address.
|
|
@@ -116,7 +123,7 @@ export declare class LMDBArchiverStore implements ArchiverDataStore {
|
|
|
116
123
|
* @param blockNumber - Number of the L2 block where contracts were deployed.
|
|
117
124
|
* @returns ContractData with the portal address (if we didn't throw an error).
|
|
118
125
|
*/
|
|
119
|
-
getContractDataInBlock(blockNumber: number): Promise<ContractData[]
|
|
126
|
+
getContractDataInBlock(blockNumber: number): Promise<ContractData[]>;
|
|
120
127
|
/**
|
|
121
128
|
* Gets the number of the latest L2 block processed.
|
|
122
129
|
* @returns The number of the latest L2 block processed.
|
|
@@ -127,4 +134,4 @@ export declare class LMDBArchiverStore implements ArchiverDataStore {
|
|
|
127
134
|
*/
|
|
128
135
|
getL1BlockNumber(): Promise<ArchiverL1SynchPoint>;
|
|
129
136
|
}
|
|
130
|
-
//# sourceMappingURL=
|
|
137
|
+
//# sourceMappingURL=kv_archiver_store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"kv_archiver_store.d.ts","sourceRoot":"","sources":["../../../src/archiver/kv_archiver_store/kv_archiver_store.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,YAAY,EACZ,oBAAoB,EACpB,0BAA0B,EAC1B,aAAa,EACb,OAAO,EACP,aAAa,EACb,IAAI,EACJ,SAAS,EACT,OAAO,EACP,MAAM,EACP,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,EAAE,EAAE,MAAM,oBAAoB,CAAC;AACxC,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AAE/D,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,mBAAmB,EAAE,2BAA2B,EAAE,MAAM,wBAAwB,CAAC;AAE1F,OAAO,EAAE,iBAAiB,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAQ/E;;GAEG;AACH,qBAAa,mBAAoB,YAAW,iBAAiB;;gBAU/C,EAAE,EAAE,YAAY,EAAE,eAAe,GAAE,MAAa;IAS5D,gBAAgB,CAAC,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,mBAAmB,GAAG,SAAS,CAAC;IAIlE,mBAAmB,CAAC,OAAO,EAAE,YAAY,GAAG,OAAO,CAAC,2BAA2B,GAAG,SAAS,CAAC;IAItF,kBAAkB,CAAC,IAAI,EAAE,mBAAmB,EAAE,EAAE,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAIvF,oBAAoB,CAAC,IAAI,EAAE,2BAA2B,EAAE,EAAE,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAIvG;;;;OAIG;IACH,SAAS,CAAC,MAAM,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC;IAI9C;;;;;;;OAOG;IACH,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAS3D;;;;OAIG;IACH,OAAO,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,GAAG,SAAS,CAAC;IAIlD;;;;;;OAMG;IACH,OAAO,CACL,aAAa,EAAE,aAAa,GAAG,SAAS,EACxC,eAAe,EAAE,aAAa,GAAG,SAAS,EAC1C,WAAW,EAAE,MAAM,GAClB,OAAO,CAAC,OAAO,CAAC;IAInB;;;;;OAKG;IACH,wBAAwB,CAAC,QAAQ,EAAE,aAAa,EAAE,EAAE,aAAa,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAI5F;;;;;OAKG;IACH,2BAA2B,CAAC,QAAQ,EAAE,EAAE,EAAE,EAAE,aAAa,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAIpF;;;;;;OAMG;IACH,qBAAqB,CAAC,SAAS,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC;IAIxD;;;;OAIG;IACH,2BAA2B,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,EAAE,EAAE,CAAC;IAIzD;;;;OAIG;IACH,yBAAyB,CAAC,UAAU,EAAE,EAAE,GAAG,OAAO,CAAC,aAAa,CAAC;IAQjE;;;;;;OAMG;IACH,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC;IAQjF;;;;OAIG;IACH,kBAAkB,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,0BAA0B,CAAC;IAQ1E;;;;;OAKG;IACH,uBAAuB,CAAC,IAAI,EAAE,oBAAoB,EAAE,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAIzF;;;;OAIG;IACH,uBAAuB,CAAC,eAAe,EAAE,YAAY,GAAG,OAAO,CAAC,oBAAoB,GAAG,SAAS,CAAC;IAIjG;;;;OAIG;IACH,8BAA8B,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,oBAAoB,EAAE,CAAC;IAIpF;;;;;OAKG;IACH,eAAe,CAAC,eAAe,EAAE,YAAY,GAAG,OAAO,CAAC,YAAY,GAAG,SAAS,CAAC;IAIjF;;;;;OAKG;IACH,sBAAsB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;IAIpE;;;OAGG;IACH,cAAc,IAAI,OAAO,CAAC,MAAM,CAAC;IAIjC;;OAEG;IACH,gBAAgB,IAAI,OAAO,CAAC,oBAAoB,CAAC;CASlD"}
|