@aztec/archiver 0.0.0-test.0 → 0.0.1-commit.023c3e5
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 +164 -9
- package/dest/archiver.d.ts +136 -0
- package/dest/archiver.d.ts.map +1 -0
- package/dest/archiver.js +781 -0
- package/dest/config.d.ts +30 -0
- package/dest/config.d.ts.map +1 -0
- package/dest/config.js +71 -0
- package/dest/errors.d.ts +41 -0
- package/dest/errors.d.ts.map +1 -0
- package/dest/errors.js +62 -0
- package/dest/factory.d.ts +13 -16
- package/dest/factory.d.ts.map +1 -1
- package/dest/factory.js +103 -55
- package/dest/index.d.ts +10 -4
- package/dest/index.d.ts.map +1 -1
- package/dest/index.js +8 -3
- package/dest/interfaces.d.ts +9 -0
- package/dest/interfaces.d.ts.map +1 -0
- package/dest/interfaces.js +3 -0
- package/dest/l1/bin/retrieve-calldata.d.ts +3 -0
- package/dest/l1/bin/retrieve-calldata.d.ts.map +1 -0
- package/dest/l1/bin/retrieve-calldata.js +149 -0
- package/dest/l1/calldata_retriever.d.ts +112 -0
- package/dest/l1/calldata_retriever.d.ts.map +1 -0
- package/dest/l1/calldata_retriever.js +471 -0
- package/dest/l1/data_retrieval.d.ts +88 -0
- package/dest/l1/data_retrieval.d.ts.map +1 -0
- package/dest/l1/data_retrieval.js +312 -0
- package/dest/l1/debug_tx.d.ts +19 -0
- package/dest/l1/debug_tx.d.ts.map +1 -0
- package/dest/l1/debug_tx.js +73 -0
- package/dest/l1/spire_proposer.d.ts +70 -0
- package/dest/l1/spire_proposer.d.ts.map +1 -0
- package/dest/l1/spire_proposer.js +157 -0
- package/dest/l1/trace_tx.d.ts +97 -0
- package/dest/l1/trace_tx.d.ts.map +1 -0
- package/dest/l1/trace_tx.js +91 -0
- package/dest/l1/types.d.ts +12 -0
- package/dest/l1/types.d.ts.map +1 -0
- package/dest/l1/types.js +3 -0
- package/dest/l1/validate_trace.d.ts +32 -0
- package/dest/l1/validate_trace.d.ts.map +1 -0
- package/dest/l1/validate_trace.js +154 -0
- package/dest/modules/data_source_base.d.ts +84 -0
- package/dest/modules/data_source_base.d.ts.map +1 -0
- package/dest/modules/data_source_base.js +260 -0
- package/dest/modules/data_store_updater.d.ts +73 -0
- package/dest/modules/data_store_updater.d.ts.map +1 -0
- package/dest/modules/data_store_updater.js +302 -0
- package/dest/modules/instrumentation.d.ts +37 -0
- package/dest/modules/instrumentation.d.ts.map +1 -0
- package/dest/modules/instrumentation.js +110 -0
- package/dest/modules/l1_synchronizer.d.ts +75 -0
- package/dest/modules/l1_synchronizer.d.ts.map +1 -0
- package/dest/modules/l1_synchronizer.js +1112 -0
- package/dest/modules/validation.d.ts +17 -0
- package/dest/modules/validation.d.ts.map +1 -0
- package/dest/modules/validation.js +104 -0
- package/dest/store/block_store.d.ts +192 -0
- package/dest/store/block_store.d.ts.map +1 -0
- package/dest/store/block_store.js +721 -0
- package/dest/store/contract_class_store.d.ts +18 -0
- package/dest/store/contract_class_store.d.ts.map +1 -0
- package/dest/{archiver/kv_archiver_store → store}/contract_class_store.js +25 -27
- package/dest/store/contract_instance_store.d.ts +24 -0
- package/dest/store/contract_instance_store.d.ts.map +1 -0
- package/dest/store/contract_instance_store.js +77 -0
- package/dest/store/kv_archiver_store.d.ts +340 -0
- package/dest/store/kv_archiver_store.d.ts.map +1 -0
- package/dest/store/kv_archiver_store.js +446 -0
- package/dest/store/log_store.d.ts +54 -0
- package/dest/store/log_store.d.ts.map +1 -0
- package/dest/store/log_store.js +436 -0
- package/dest/store/message_store.d.ts +40 -0
- package/dest/store/message_store.d.ts.map +1 -0
- package/dest/store/message_store.js +188 -0
- package/dest/structs/data_retrieval.d.ts +27 -0
- package/dest/structs/data_retrieval.d.ts.map +1 -0
- package/dest/structs/inbox_message.d.ts +15 -0
- package/dest/structs/inbox_message.d.ts.map +1 -0
- package/dest/structs/inbox_message.js +39 -0
- package/dest/structs/published.d.ts +2 -0
- package/dest/structs/published.d.ts.map +1 -0
- package/dest/structs/published.js +1 -0
- package/dest/test/fake_l1_state.d.ts +190 -0
- package/dest/test/fake_l1_state.d.ts.map +1 -0
- package/dest/test/fake_l1_state.js +383 -0
- package/dest/test/index.d.ts +2 -1
- package/dest/test/index.d.ts.map +1 -1
- package/dest/test/index.js +4 -1
- package/dest/test/mock_archiver.d.ts +16 -8
- package/dest/test/mock_archiver.d.ts.map +1 -1
- package/dest/test/mock_archiver.js +18 -14
- package/dest/test/mock_l1_to_l2_message_source.d.ts +9 -6
- package/dest/test/mock_l1_to_l2_message_source.d.ts.map +1 -1
- package/dest/test/mock_l1_to_l2_message_source.js +30 -7
- package/dest/test/mock_l2_block_source.d.ts +62 -16
- package/dest/test/mock_l2_block_source.d.ts.map +1 -1
- package/dest/test/mock_l2_block_source.js +263 -32
- package/dest/test/mock_structs.d.ts +85 -0
- package/dest/test/mock_structs.d.ts.map +1 -0
- package/dest/test/mock_structs.js +171 -0
- package/dest/test/noop_l1_archiver.d.ts +23 -0
- package/dest/test/noop_l1_archiver.d.ts.map +1 -0
- package/dest/test/noop_l1_archiver.js +68 -0
- package/package.json +31 -33
- package/src/archiver.ts +543 -0
- package/src/config.ts +95 -0
- package/src/errors.ts +102 -0
- package/src/factory.ts +144 -71
- package/src/index.ts +10 -3
- package/src/interfaces.ts +9 -0
- package/src/l1/README.md +98 -0
- package/src/l1/bin/retrieve-calldata.ts +187 -0
- package/src/l1/calldata_retriever.ts +641 -0
- package/src/l1/data_retrieval.ts +495 -0
- package/src/l1/debug_tx.ts +99 -0
- package/src/l1/spire_proposer.ts +160 -0
- package/src/l1/trace_tx.ts +128 -0
- package/src/l1/types.ts +13 -0
- package/src/l1/validate_trace.ts +229 -0
- package/src/modules/data_source_base.ts +367 -0
- package/src/modules/data_store_updater.ts +423 -0
- package/src/modules/instrumentation.ts +157 -0
- package/src/modules/l1_synchronizer.ts +930 -0
- package/src/modules/validation.ts +129 -0
- package/src/store/block_store.ts +966 -0
- package/src/{archiver/kv_archiver_store → store}/contract_class_store.ts +26 -32
- package/src/{archiver/kv_archiver_store → store}/contract_instance_store.ts +37 -29
- package/src/store/kv_archiver_store.ts +639 -0
- package/src/store/log_store.ts +575 -0
- package/src/store/message_store.ts +261 -0
- package/src/structs/inbox_message.ts +41 -0
- package/src/structs/published.ts +1 -0
- package/src/test/fake_l1_state.ts +599 -0
- package/src/test/fixtures/debug_traceTransaction-multicall3.json +88 -0
- package/src/test/fixtures/debug_traceTransaction-multiplePropose.json +153 -0
- package/src/test/fixtures/debug_traceTransaction-proxied.json +122 -0
- package/src/test/fixtures/trace_transaction-multicall3.json +65 -0
- package/src/test/fixtures/trace_transaction-multiplePropose.json +319 -0
- package/src/test/fixtures/trace_transaction-proxied.json +128 -0
- package/src/test/fixtures/trace_transaction-randomRevert.json +216 -0
- package/src/test/index.ts +4 -0
- package/src/test/mock_archiver.ts +22 -16
- package/src/test/mock_l1_to_l2_message_source.ts +26 -8
- package/src/test/mock_l2_block_source.ts +313 -42
- package/src/test/mock_structs.ts +311 -0
- package/src/test/noop_l1_archiver.ts +109 -0
- package/dest/archiver/archiver.d.ts +0 -197
- package/dest/archiver/archiver.d.ts.map +0 -1
- package/dest/archiver/archiver.js +0 -900
- package/dest/archiver/archiver_store.d.ts +0 -220
- package/dest/archiver/archiver_store.d.ts.map +0 -1
- package/dest/archiver/archiver_store.js +0 -4
- package/dest/archiver/archiver_store_test_suite.d.ts +0 -8
- package/dest/archiver/archiver_store_test_suite.d.ts.map +0 -1
- package/dest/archiver/archiver_store_test_suite.js +0 -794
- package/dest/archiver/config.d.ts +0 -37
- package/dest/archiver/config.d.ts.map +0 -1
- package/dest/archiver/config.js +0 -46
- package/dest/archiver/data_retrieval.d.ts +0 -74
- package/dest/archiver/data_retrieval.d.ts.map +0 -1
- package/dest/archiver/data_retrieval.js +0 -283
- package/dest/archiver/errors.d.ts +0 -4
- package/dest/archiver/errors.d.ts.map +0 -1
- package/dest/archiver/errors.js +0 -5
- package/dest/archiver/index.d.ts +0 -8
- package/dest/archiver/index.d.ts.map +0 -1
- package/dest/archiver/index.js +0 -5
- package/dest/archiver/instrumentation.d.ts +0 -29
- package/dest/archiver/instrumentation.d.ts.map +0 -1
- package/dest/archiver/instrumentation.js +0 -99
- package/dest/archiver/kv_archiver_store/block_store.d.ts +0 -87
- package/dest/archiver/kv_archiver_store/block_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/block_store.js +0 -217
- package/dest/archiver/kv_archiver_store/contract_class_store.d.ts +0 -18
- package/dest/archiver/kv_archiver_store/contract_class_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts +0 -21
- package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/contract_instance_store.js +0 -63
- package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts +0 -153
- package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/kv_archiver_store.js +0 -254
- package/dest/archiver/kv_archiver_store/log_store.d.ts +0 -49
- package/dest/archiver/kv_archiver_store/log_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/log_store.js +0 -364
- package/dest/archiver/kv_archiver_store/message_store.d.ts +0 -33
- package/dest/archiver/kv_archiver_store/message_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/message_store.js +0 -85
- package/dest/archiver/kv_archiver_store/nullifier_store.d.ts +0 -12
- package/dest/archiver/kv_archiver_store/nullifier_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/nullifier_store.js +0 -73
- package/dest/archiver/memory_archiver_store/l1_to_l2_message_store.d.ts +0 -23
- package/dest/archiver/memory_archiver_store/l1_to_l2_message_store.d.ts.map +0 -1
- package/dest/archiver/memory_archiver_store/l1_to_l2_message_store.js +0 -49
- package/dest/archiver/memory_archiver_store/memory_archiver_store.d.ts +0 -175
- package/dest/archiver/memory_archiver_store/memory_archiver_store.d.ts.map +0 -1
- package/dest/archiver/memory_archiver_store/memory_archiver_store.js +0 -636
- package/dest/archiver/structs/data_retrieval.d.ts +0 -27
- package/dest/archiver/structs/data_retrieval.d.ts.map +0 -1
- package/dest/archiver/structs/published.d.ts +0 -11
- package/dest/archiver/structs/published.d.ts.map +0 -1
- package/dest/archiver/structs/published.js +0 -1
- package/dest/rpc/index.d.ts +0 -10
- package/dest/rpc/index.d.ts.map +0 -1
- package/dest/rpc/index.js +0 -18
- package/src/archiver/archiver.ts +0 -1181
- package/src/archiver/archiver_store.ts +0 -263
- package/src/archiver/archiver_store_test_suite.ts +0 -810
- package/src/archiver/config.ts +0 -92
- package/src/archiver/data_retrieval.ts +0 -422
- package/src/archiver/errors.ts +0 -5
- package/src/archiver/index.ts +0 -7
- package/src/archiver/instrumentation.ts +0 -132
- package/src/archiver/kv_archiver_store/block_store.ts +0 -283
- package/src/archiver/kv_archiver_store/kv_archiver_store.ts +0 -358
- package/src/archiver/kv_archiver_store/log_store.ts +0 -444
- package/src/archiver/kv_archiver_store/message_store.ts +0 -102
- package/src/archiver/kv_archiver_store/nullifier_store.ts +0 -97
- package/src/archiver/memory_archiver_store/l1_to_l2_message_store.ts +0 -61
- package/src/archiver/memory_archiver_store/memory_archiver_store.ts +0 -801
- package/src/archiver/structs/published.ts +0 -11
- package/src/rpc/index.ts +0 -20
- /package/dest/{archiver/structs → structs}/data_retrieval.js +0 -0
- /package/src/{archiver/structs → structs}/data_retrieval.ts +0 -0
|
@@ -1,18 +1,29 @@
|
|
|
1
|
+
import { BlockNumber, CheckpointNumber, EpochNumber, SlotNumber } from '@aztec/foundation/branded-types';
|
|
2
|
+
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
1
3
|
import { EthAddress } from '@aztec/foundation/eth-address';
|
|
2
|
-
import
|
|
4
|
+
import type { FunctionSelector } from '@aztec/stdlib/abi';
|
|
5
|
+
import type { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
6
|
+
import { BlockHash, CheckpointedL2Block, L2Block, type L2BlockSource, type L2Tips, type ValidateCheckpointResult } from '@aztec/stdlib/block';
|
|
7
|
+
import { Checkpoint, PublishedCheckpoint } from '@aztec/stdlib/checkpoint';
|
|
8
|
+
import type { ContractClassPublic, ContractDataSource, ContractInstanceWithAddress } from '@aztec/stdlib/contract';
|
|
3
9
|
import { type L1RollupConstants } from '@aztec/stdlib/epoch-helpers';
|
|
4
10
|
import { type BlockHeader, TxHash, TxReceipt } from '@aztec/stdlib/tx';
|
|
11
|
+
import type { UInt64 } from '@aztec/stdlib/types';
|
|
5
12
|
/**
|
|
6
13
|
* A mocked implementation of L2BlockSource to be used in tests.
|
|
7
14
|
*/
|
|
8
|
-
export declare class MockL2BlockSource implements L2BlockSource {
|
|
15
|
+
export declare class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
9
16
|
protected l2Blocks: L2Block[];
|
|
10
17
|
private provenBlockNumber;
|
|
18
|
+
private finalizedBlockNumber;
|
|
19
|
+
private checkpointedBlockNumber;
|
|
11
20
|
private log;
|
|
12
21
|
createBlocks(numBlocks: number): Promise<void>;
|
|
13
|
-
|
|
22
|
+
addProposedBlocks(blocks: L2Block[]): void;
|
|
14
23
|
removeBlocks(numBlocks: number): void;
|
|
15
24
|
setProvenBlockNumber(provenBlockNumber: number): void;
|
|
25
|
+
setFinalizedBlockNumber(finalizedBlockNumber: number): void;
|
|
26
|
+
setCheckpointedBlockNumber(checkpointedBlockNumber: number): void;
|
|
16
27
|
/**
|
|
17
28
|
* Method to fetch the rollup contract address at the base-layer.
|
|
18
29
|
* @returns The rollup address.
|
|
@@ -27,32 +38,54 @@ export declare class MockL2BlockSource implements L2BlockSource {
|
|
|
27
38
|
* Gets the number of the latest L2 block processed by the block source implementation.
|
|
28
39
|
* @returns In this mock instance, returns the number of L2 blocks that we've mocked.
|
|
29
40
|
*/
|
|
30
|
-
getBlockNumber(): Promise<
|
|
31
|
-
getProvenBlockNumber(): Promise<
|
|
41
|
+
getBlockNumber(): Promise<BlockNumber>;
|
|
42
|
+
getProvenBlockNumber(): Promise<BlockNumber>;
|
|
43
|
+
getCheckpointedL2BlockNumber(): Promise<BlockNumber>;
|
|
44
|
+
getFinalizedL2BlockNumber(): Promise<BlockNumber>;
|
|
45
|
+
getCheckpointedBlock(number: BlockNumber): Promise<CheckpointedL2Block | undefined>;
|
|
46
|
+
getCheckpointedBlocks(from: BlockNumber, limit: number): Promise<CheckpointedL2Block[]>;
|
|
32
47
|
/**
|
|
33
48
|
* Gets an l2 block.
|
|
34
49
|
* @param number - The block number to return (inclusive).
|
|
35
50
|
* @returns The requested L2 block.
|
|
36
51
|
*/
|
|
37
|
-
getBlock(number: number): Promise<L2Block>;
|
|
52
|
+
getBlock(number: number): Promise<L2Block | undefined>;
|
|
53
|
+
/**
|
|
54
|
+
* Gets an L2 block (new format).
|
|
55
|
+
* @param number - The block number to return.
|
|
56
|
+
* @returns The requested L2 block.
|
|
57
|
+
*/
|
|
58
|
+
getL2Block(number: BlockNumber): Promise<L2Block | undefined>;
|
|
38
59
|
/**
|
|
39
60
|
* Gets up to `limit` amount of L2 blocks starting from `from`.
|
|
40
61
|
* @param from - Number of the first block to return (inclusive).
|
|
41
62
|
* @param limit - The maximum number of blocks to return.
|
|
42
63
|
* @returns The requested mocked L2 blocks.
|
|
43
64
|
*/
|
|
44
|
-
getBlocks(from: number, limit: number
|
|
65
|
+
getBlocks(from: number, limit: number): Promise<L2Block[]>;
|
|
66
|
+
getCheckpoints(from: CheckpointNumber, limit: number): Promise<PublishedCheckpoint[]>;
|
|
67
|
+
getCheckpointByArchive(archive: Fr): Promise<Checkpoint | undefined>;
|
|
68
|
+
getCheckpointedBlockByHash(blockHash: BlockHash): Promise<CheckpointedL2Block | undefined>;
|
|
69
|
+
getCheckpointedBlockByArchive(archive: Fr): Promise<CheckpointedL2Block | undefined>;
|
|
70
|
+
getL2BlockByHash(blockHash: BlockHash): Promise<L2Block | undefined>;
|
|
71
|
+
getL2BlockByArchive(archive: Fr): Promise<L2Block | undefined>;
|
|
72
|
+
getBlockHeaderByHash(blockHash: BlockHash): Promise<BlockHeader | undefined>;
|
|
73
|
+
getBlockHeaderByArchive(archive: Fr): Promise<BlockHeader | undefined>;
|
|
45
74
|
getBlockHeader(number: number | 'latest'): Promise<BlockHeader | undefined>;
|
|
46
|
-
|
|
75
|
+
getCheckpointsForEpoch(epochNumber: EpochNumber): Promise<Checkpoint[]>;
|
|
76
|
+
getCheckpointedBlocksForEpoch(epochNumber: EpochNumber): Promise<CheckpointedL2Block[]>;
|
|
77
|
+
getBlocksForSlot(slotNumber: SlotNumber): Promise<L2Block[]>;
|
|
78
|
+
getCheckpointedBlockHeadersForEpoch(epochNumber: EpochNumber): Promise<BlockHeader[]>;
|
|
47
79
|
/**
|
|
48
80
|
* Gets a tx effect.
|
|
49
|
-
* @param txHash - The hash of
|
|
50
|
-
* @returns The requested tx effect.
|
|
81
|
+
* @param txHash - The hash of the tx corresponding to the tx effect.
|
|
82
|
+
* @returns The requested tx effect with block info (or undefined if not found).
|
|
51
83
|
*/
|
|
52
84
|
getTxEffect(txHash: TxHash): Promise<{
|
|
53
85
|
data: import("@aztec/stdlib/tx").TxEffect;
|
|
54
|
-
l2BlockNumber:
|
|
55
|
-
l2BlockHash:
|
|
86
|
+
l2BlockNumber: BlockNumber;
|
|
87
|
+
l2BlockHash: BlockHash;
|
|
88
|
+
txIndexInBlock: number;
|
|
56
89
|
} | undefined>;
|
|
57
90
|
/**
|
|
58
91
|
* Gets a receipt of a settled tx.
|
|
@@ -61,10 +94,14 @@ export declare class MockL2BlockSource implements L2BlockSource {
|
|
|
61
94
|
*/
|
|
62
95
|
getSettledTxReceipt(txHash: TxHash): Promise<TxReceipt | undefined>;
|
|
63
96
|
getL2Tips(): Promise<L2Tips>;
|
|
64
|
-
getL2EpochNumber(): Promise<
|
|
65
|
-
getL2SlotNumber(): Promise<
|
|
66
|
-
isEpochComplete(_epochNumber:
|
|
97
|
+
getL2EpochNumber(): Promise<EpochNumber>;
|
|
98
|
+
getL2SlotNumber(): Promise<SlotNumber>;
|
|
99
|
+
isEpochComplete(_epochNumber: EpochNumber): Promise<boolean>;
|
|
67
100
|
getL1Constants(): Promise<L1RollupConstants>;
|
|
101
|
+
getGenesisValues(): Promise<{
|
|
102
|
+
genesisArchiveRoot: Fr;
|
|
103
|
+
}>;
|
|
104
|
+
getL1Timestamp(): Promise<bigint>;
|
|
68
105
|
/**
|
|
69
106
|
* Starts the block source. In this mock implementation, this is a noop.
|
|
70
107
|
* @returns A promise that signals the initialization of the l2 block source on completion.
|
|
@@ -75,5 +112,14 @@ export declare class MockL2BlockSource implements L2BlockSource {
|
|
|
75
112
|
* @returns A promise that signals the l2 block source is now stopped.
|
|
76
113
|
*/
|
|
77
114
|
stop(): Promise<void>;
|
|
115
|
+
getContractClass(_id: Fr): Promise<ContractClassPublic | undefined>;
|
|
116
|
+
getBytecodeCommitment(_id: Fr): Promise<Fr | undefined>;
|
|
117
|
+
getContract(_address: AztecAddress, _timestamp?: UInt64): Promise<ContractInstanceWithAddress | undefined>;
|
|
118
|
+
getContractClassIds(): Promise<Fr[]>;
|
|
119
|
+
getDebugFunctionName(_address: AztecAddress, _selector: FunctionSelector): Promise<string | undefined>;
|
|
120
|
+
registerContractFunctionSignatures(_signatures: string[]): Promise<void>;
|
|
121
|
+
syncImmediate(): Promise<void>;
|
|
122
|
+
isPendingChainInvalid(): Promise<boolean>;
|
|
123
|
+
getPendingChainValidationStatus(): Promise<ValidateCheckpointResult>;
|
|
78
124
|
}
|
|
79
|
-
//# sourceMappingURL=
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9ja19sMl9ibG9ja19zb3VyY2UuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90ZXN0L21vY2tfbDJfYmxvY2tfc291cmNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxXQUFXLEVBQUUsZ0JBQWdCLEVBQUUsV0FBVyxFQUFFLFVBQVUsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBRXpHLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNwRCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFFM0QsT0FBTyxLQUFLLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUMxRCxPQUFPLEtBQUssRUFBRSxZQUFZLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUNoRSxPQUFPLEVBQ0wsU0FBUyxFQUNULG1CQUFtQixFQUNuQixPQUFPLEVBQ1AsS0FBSyxhQUFhLEVBQ2xCLEtBQUssTUFBTSxFQUNYLEtBQUssd0JBQXdCLEVBQzlCLE1BQU0scUJBQXFCLENBQUM7QUFDN0IsT0FBTyxFQUFFLFVBQVUsRUFBbUIsbUJBQW1CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUM1RixPQUFPLEtBQUssRUFBRSxtQkFBbUIsRUFBRSxrQkFBa0IsRUFBRSwyQkFBMkIsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ25ILE9BQU8sRUFBMEIsS0FBSyxpQkFBaUIsRUFBd0IsTUFBTSw2QkFBNkIsQ0FBQztBQUNuSCxPQUFPLEVBQUUsS0FBSyxXQUFXLEVBQXFCLE1BQU0sRUFBRSxTQUFTLEVBQVksTUFBTSxrQkFBa0IsQ0FBQztBQUNwRyxPQUFPLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUVsRDs7R0FFRztBQUNILHFCQUFhLGlCQUFrQixZQUFXLGFBQWEsRUFBRSxrQkFBa0I7SUFDekUsU0FBUyxDQUFDLFFBQVEsRUFBRSxPQUFPLEVBQUUs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
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mock_l2_block_source.d.ts","sourceRoot":"","sources":["../../src/test/mock_l2_block_source.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"mock_l2_block_source.d.ts","sourceRoot":"","sources":["../../src/test/mock_l2_block_source.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,gBAAgB,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAEzG,OAAO,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AACpD,OAAO,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAE3D,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAChE,OAAO,EACL,SAAS,EACT,mBAAmB,EACnB,OAAO,EACP,KAAK,aAAa,EAClB,KAAK,MAAM,EACX,KAAK,wBAAwB,EAC9B,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,UAAU,EAAmB,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAC5F,OAAO,KAAK,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,2BAA2B,EAAE,MAAM,wBAAwB,CAAC;AACnH,OAAO,EAA0B,KAAK,iBAAiB,EAAwB,MAAM,6BAA6B,CAAC;AACnH,OAAO,EAAE,KAAK,WAAW,EAAqB,MAAM,EAAE,SAAS,EAAY,MAAM,kBAAkB,CAAC;AACpG,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAElD;;GAEG;AACH,qBAAa,iBAAkB,YAAW,aAAa,EAAE,kBAAkB;IACzE,SAAS,CAAC,QAAQ,EAAE,OAAO,EAAE,CAAM;IAEnC,OAAO,CAAC,iBAAiB,CAAa;IACtC,OAAO,CAAC,oBAAoB,CAAa;IACzC,OAAO,CAAC,uBAAuB,CAAa;IAE5C,OAAO,CAAC,GAAG,CAAiD;IAE/C,YAAY,CAAC,SAAS,EAAE,MAAM,iBAQ1C;IAEM,iBAAiB,CAAC,MAAM,EAAE,OAAO,EAAE,QAGzC;IAEM,YAAY,CAAC,SAAS,EAAE,MAAM,QAGpC;IAEM,oBAAoB,CAAC,iBAAiB,EAAE,MAAM,QAEpD;IAEM,uBAAuB,CAAC,oBAAoB,EAAE,MAAM,QAK1D;IAEM,0BAA0B,CAAC,uBAAuB,EAAE,MAAM,QAEhE;IAED;;;OAGG;IACH,gBAAgB,IAAI,OAAO,CAAC,UAAU,CAAC,CAEtC;IAED;;;OAGG;IACH,kBAAkB,IAAI,OAAO,CAAC,UAAU,CAAC,CAExC;IAED;;;OAGG;IACI,cAAc,yBAEpB;IAEM,oBAAoB,yBAE1B;IAEM,4BAA4B,yBAElC;IAEM,yBAAyB,yBAE/B;IAEM,oBAAoB,CAAC,MAAM,EAAE,WAAW,GAAG,OAAO,CAAC,mBAAmB,GAAG,SAAS,CAAC,CAezF;IAEY,qBAAqB,CAAC,IAAI,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,mBAAmB,EAAE,CAAC,CAanG;IAED;;;;OAIG;IACI,QAAQ,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,GAAG,SAAS,CAAC,CAG5D;IAED;;;;OAIG;IACI,UAAU,CAAC,MAAM,EAAE,WAAW,GAAG,OAAO,CAAC,OAAO,GAAG,SAAS,CAAC,CAGnE;IAED;;;;;OAKG;IACI,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC,CAEhE;IAEM,cAAc,CAAC,IAAI,EAAE,gBAAgB,EAAE,KAAK,EAAE,MAAM,kCAe1D;IAEY,sBAAsB,CAAC,OAAO,EAAE,EAAE,GAAG,OAAO,CAAC,UAAU,GAAG,SAAS,CAAC,CAUhF;IAEY,0BAA0B,CAAC,SAAS,EAAE,SAAS,GAAG,OAAO,CAAC,mBAAmB,GAAG,SAAS,CAAC,CAatG;IAEM,6BAA6B,CAAC,OAAO,EAAE,EAAE,GAAG,OAAO,CAAC,mBAAmB,GAAG,SAAS,CAAC,CAa1F;IAEY,gBAAgB,CAAC,SAAS,EAAE,SAAS,GAAG,OAAO,CAAC,OAAO,GAAG,SAAS,CAAC,CAQhF;IAEM,mBAAmB,CAAC,OAAO,EAAE,EAAE,GAAG,OAAO,CAAC,OAAO,GAAG,SAAS,CAAC,CAGpE;IAEY,oBAAoB,CAAC,SAAS,EAAE,SAAS,GAAG,OAAO,CAAC,WAAW,GAAG,SAAS,CAAC,CAQxF;IAEM,uBAAuB,CAAC,OAAO,EAAE,EAAE,GAAG,OAAO,CAAC,WAAW,GAAG,SAAS,CAAC,CAG5E;IAED,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,QAAQ,GAAG,OAAO,CAAC,WAAW,GAAG,SAAS,CAAC,CAE1E;IAED,sBAAsB,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC,CAgBtE;IAED,6BAA6B,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,mBAAmB,EAAE,CAAC,CAiBtF;IAED,gBAAgB,CAAC,UAAU,EAAE,UAAU,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC,CAG3D;IAEK,mCAAmC,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC,CAG1F;IAED;;;;OAIG;IACU,WAAW,CAAC,MAAM,EAAE,MAAM;;;;;mBActC;IAED;;;;OAIG;IACU,mBAAmB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,GAAG,SAAS,CAAC,CAkB/E;IAEK,SAAS,IAAI,OAAO,CAAC,MAAM,CAAC,CAyCjC;IAED,gBAAgB,IAAI,OAAO,CAAC,WAAW,CAAC,CAEvC;IAED,eAAe,IAAI,OAAO,CAAC,UAAU,CAAC,CAErC;IAED,eAAe,CAAC,YAAY,EAAE,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC,CAE3D;IAED,cAAc,IAAI,OAAO,CAAC,iBAAiB,CAAC,CAE3C;IAED,gBAAgB,IAAI,OAAO,CAAC;QAAE,kBAAkB,EAAE,EAAE,CAAA;KAAE,CAAC,CAEtD;IAED,cAAc,IAAI,OAAO,CAAC,MAAM,CAAC,CAEhC;IAED;;;OAGG;IACI,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,CAG5B;IAED;;;OAGG;IACI,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,CAG3B;IAED,gBAAgB,CAAC,GAAG,EAAE,EAAE,GAAG,OAAO,CAAC,mBAAmB,GAAG,SAAS,CAAC,CAElE;IAED,qBAAqB,CAAC,GAAG,EAAE,EAAE,GAAG,OAAO,CAAC,EAAE,GAAG,SAAS,CAAC,CAEtD;IAED,WAAW,CAAC,QAAQ,EAAE,YAAY,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,2BAA2B,GAAG,SAAS,CAAC,CAEzG;IAED,mBAAmB,IAAI,OAAO,CAAC,EAAE,EAAE,CAAC,CAEnC;IAED,oBAAoB,CAAC,QAAQ,EAAE,YAAY,EAAE,SAAS,EAAE,gBAAgB,GAAG,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC,CAErG;IAED,kCAAkC,CAAC,WAAW,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAEvE;IAED,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC,CAE7B;IAED,qBAAqB,IAAI,OAAO,CAAC,OAAO,CAAC,CAExC;IAED,+BAA+B,IAAI,OAAO,CAAC,wBAAwB,CAAC,CAEnE;CACF"}
|
|
@@ -1,26 +1,35 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { GENESIS_ARCHIVE_ROOT } from '@aztec/constants';
|
|
2
|
+
import { DefaultL1ContractsConfig } from '@aztec/ethereum/config';
|
|
3
|
+
import { BlockNumber, CheckpointNumber, SlotNumber } from '@aztec/foundation/branded-types';
|
|
4
|
+
import { Buffer32 } from '@aztec/foundation/buffer';
|
|
5
|
+
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
2
6
|
import { EthAddress } from '@aztec/foundation/eth-address';
|
|
3
7
|
import { createLogger } from '@aztec/foundation/log';
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
8
|
+
import { CheckpointedL2Block, L2Block } from '@aztec/stdlib/block';
|
|
9
|
+
import { Checkpoint, L1PublishedData, PublishedCheckpoint } from '@aztec/stdlib/checkpoint';
|
|
10
|
+
import { EmptyL1RollupConstants, getSlotRangeForEpoch } from '@aztec/stdlib/epoch-helpers';
|
|
11
|
+
import { TxExecutionResult, TxReceipt, TxStatus } from '@aztec/stdlib/tx';
|
|
7
12
|
/**
|
|
8
13
|
* A mocked implementation of L2BlockSource to be used in tests.
|
|
9
14
|
*/ export class MockL2BlockSource {
|
|
10
15
|
l2Blocks = [];
|
|
11
16
|
provenBlockNumber = 0;
|
|
17
|
+
finalizedBlockNumber = 0;
|
|
18
|
+
checkpointedBlockNumber = 0;
|
|
12
19
|
log = createLogger('archiver:mock_l2_block_source');
|
|
13
20
|
async createBlocks(numBlocks) {
|
|
14
21
|
for(let i = 0; i < numBlocks; i++){
|
|
15
22
|
const blockNum = this.l2Blocks.length + 1;
|
|
16
|
-
const block = await L2Block.random(blockNum)
|
|
23
|
+
const block = await L2Block.random(BlockNumber(blockNum), {
|
|
24
|
+
slotNumber: SlotNumber(blockNum)
|
|
25
|
+
});
|
|
17
26
|
this.l2Blocks.push(block);
|
|
18
27
|
}
|
|
19
28
|
this.log.verbose(`Created ${numBlocks} blocks in the mock L2 block source`);
|
|
20
29
|
}
|
|
21
|
-
|
|
30
|
+
addProposedBlocks(blocks) {
|
|
22
31
|
this.l2Blocks.push(...blocks);
|
|
23
|
-
this.log.verbose(`Added ${blocks.length} blocks to the mock L2 block source`);
|
|
32
|
+
this.log.verbose(`Added ${blocks.length} proposed blocks to the mock L2 block source`);
|
|
24
33
|
}
|
|
25
34
|
removeBlocks(numBlocks) {
|
|
26
35
|
this.l2Blocks = this.l2Blocks.slice(0, -numBlocks);
|
|
@@ -29,6 +38,15 @@ import { TxReceipt, TxStatus } from '@aztec/stdlib/tx';
|
|
|
29
38
|
setProvenBlockNumber(provenBlockNumber) {
|
|
30
39
|
this.provenBlockNumber = provenBlockNumber;
|
|
31
40
|
}
|
|
41
|
+
setFinalizedBlockNumber(finalizedBlockNumber) {
|
|
42
|
+
if (finalizedBlockNumber > this.provenBlockNumber) {
|
|
43
|
+
this.provenBlockNumber = finalizedBlockNumber;
|
|
44
|
+
}
|
|
45
|
+
this.finalizedBlockNumber = finalizedBlockNumber;
|
|
46
|
+
}
|
|
47
|
+
setCheckpointedBlockNumber(checkpointedBlockNumber) {
|
|
48
|
+
this.checkpointedBlockNumber = checkpointedBlockNumber;
|
|
49
|
+
}
|
|
32
50
|
/**
|
|
33
51
|
* Method to fetch the rollup contract address at the base-layer.
|
|
34
52
|
* @returns The rollup address.
|
|
@@ -45,44 +63,199 @@ import { TxReceipt, TxStatus } from '@aztec/stdlib/tx';
|
|
|
45
63
|
* Gets the number of the latest L2 block processed by the block source implementation.
|
|
46
64
|
* @returns In this mock instance, returns the number of L2 blocks that we've mocked.
|
|
47
65
|
*/ getBlockNumber() {
|
|
48
|
-
return Promise.resolve(this.l2Blocks.length);
|
|
66
|
+
return Promise.resolve(BlockNumber(this.l2Blocks.length));
|
|
49
67
|
}
|
|
50
68
|
getProvenBlockNumber() {
|
|
51
|
-
return Promise.resolve(this.provenBlockNumber);
|
|
69
|
+
return Promise.resolve(BlockNumber(this.provenBlockNumber));
|
|
70
|
+
}
|
|
71
|
+
getCheckpointedL2BlockNumber() {
|
|
72
|
+
return Promise.resolve(BlockNumber(this.checkpointedBlockNumber));
|
|
73
|
+
}
|
|
74
|
+
getFinalizedL2BlockNumber() {
|
|
75
|
+
return Promise.resolve(BlockNumber(this.finalizedBlockNumber));
|
|
76
|
+
}
|
|
77
|
+
getCheckpointedBlock(number) {
|
|
78
|
+
if (number > this.checkpointedBlockNumber) {
|
|
79
|
+
return Promise.resolve(undefined);
|
|
80
|
+
}
|
|
81
|
+
const block = this.l2Blocks[number - 1];
|
|
82
|
+
if (!block) {
|
|
83
|
+
return Promise.resolve(undefined);
|
|
84
|
+
}
|
|
85
|
+
const checkpointedBlock = new CheckpointedL2Block(CheckpointNumber.fromBlockNumber(number), block, new L1PublishedData(BigInt(number), BigInt(number), `0x${number.toString(16).padStart(64, '0')}`), []);
|
|
86
|
+
return Promise.resolve(checkpointedBlock);
|
|
87
|
+
}
|
|
88
|
+
async getCheckpointedBlocks(from, limit) {
|
|
89
|
+
const result = [];
|
|
90
|
+
for(let i = 0; i < limit; i++){
|
|
91
|
+
const blockNum = from + i;
|
|
92
|
+
if (blockNum > this.checkpointedBlockNumber) {
|
|
93
|
+
break;
|
|
94
|
+
}
|
|
95
|
+
const block = await this.getCheckpointedBlock(BlockNumber(blockNum));
|
|
96
|
+
if (block) {
|
|
97
|
+
result.push(block);
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
return result;
|
|
52
101
|
}
|
|
53
102
|
/**
|
|
54
103
|
* Gets an l2 block.
|
|
55
104
|
* @param number - The block number to return (inclusive).
|
|
56
105
|
* @returns The requested L2 block.
|
|
57
106
|
*/ getBlock(number) {
|
|
58
|
-
|
|
107
|
+
const block = this.l2Blocks[number - 1];
|
|
108
|
+
return Promise.resolve(block);
|
|
109
|
+
}
|
|
110
|
+
/**
|
|
111
|
+
* Gets an L2 block (new format).
|
|
112
|
+
* @param number - The block number to return.
|
|
113
|
+
* @returns The requested L2 block.
|
|
114
|
+
*/ getL2Block(number) {
|
|
115
|
+
const block = this.l2Blocks[number - 1];
|
|
116
|
+
return Promise.resolve(block);
|
|
59
117
|
}
|
|
60
118
|
/**
|
|
61
119
|
* Gets up to `limit` amount of L2 blocks starting from `from`.
|
|
62
120
|
* @param from - Number of the first block to return (inclusive).
|
|
63
121
|
* @param limit - The maximum number of blocks to return.
|
|
64
122
|
* @returns The requested mocked L2 blocks.
|
|
65
|
-
*/ getBlocks(from, limit
|
|
66
|
-
return Promise.resolve(this.l2Blocks.slice(from - 1, from - 1 + limit)
|
|
123
|
+
*/ getBlocks(from, limit) {
|
|
124
|
+
return Promise.resolve(this.l2Blocks.slice(from - 1, from - 1 + limit));
|
|
125
|
+
}
|
|
126
|
+
getCheckpoints(from, limit) {
|
|
127
|
+
// TODO(mbps): Implement this properly. This only works when we have one block per checkpoint.
|
|
128
|
+
const blocks = this.l2Blocks.slice(from - 1, from - 1 + limit);
|
|
129
|
+
return Promise.all(blocks.map(async (block)=>{
|
|
130
|
+
// Create a checkpoint from the block - manually construct since L2Block doesn't have toCheckpoint()
|
|
131
|
+
const checkpoint = await Checkpoint.random(block.checkpointNumber, {
|
|
132
|
+
numBlocks: 1
|
|
133
|
+
});
|
|
134
|
+
checkpoint.blocks = [
|
|
135
|
+
block
|
|
136
|
+
];
|
|
137
|
+
return new PublishedCheckpoint(checkpoint, new L1PublishedData(BigInt(block.number), BigInt(block.number), Buffer32.random().toString()), []);
|
|
138
|
+
}));
|
|
139
|
+
}
|
|
140
|
+
async getCheckpointByArchive(archive) {
|
|
141
|
+
// TODO(mbps): Implement this properly. This only works when we have one block per checkpoint.
|
|
142
|
+
const block = this.l2Blocks.find((b)=>b.archive.root.equals(archive));
|
|
143
|
+
if (!block) {
|
|
144
|
+
return undefined;
|
|
145
|
+
}
|
|
146
|
+
// Create a checkpoint from the block - manually construct since L2Block doesn't have toCheckpoint()
|
|
147
|
+
const checkpoint = await Checkpoint.random(block.checkpointNumber, {
|
|
148
|
+
numBlocks: 1
|
|
149
|
+
});
|
|
150
|
+
checkpoint.blocks = [
|
|
151
|
+
block
|
|
152
|
+
];
|
|
153
|
+
return checkpoint;
|
|
154
|
+
}
|
|
155
|
+
async getCheckpointedBlockByHash(blockHash) {
|
|
156
|
+
for (const block of this.l2Blocks){
|
|
157
|
+
const hash = await block.hash();
|
|
158
|
+
if (hash.equals(blockHash)) {
|
|
159
|
+
return CheckpointedL2Block.fromFields({
|
|
160
|
+
checkpointNumber: CheckpointNumber.fromBlockNumber(block.number),
|
|
161
|
+
block,
|
|
162
|
+
l1: new L1PublishedData(BigInt(block.number), BigInt(block.number), Buffer32.random().toString()),
|
|
163
|
+
attestations: []
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
return undefined;
|
|
168
|
+
}
|
|
169
|
+
getCheckpointedBlockByArchive(archive) {
|
|
170
|
+
const block = this.l2Blocks.find((b)=>b.archive.root.equals(archive));
|
|
171
|
+
if (!block) {
|
|
172
|
+
return Promise.resolve(undefined);
|
|
173
|
+
}
|
|
174
|
+
return Promise.resolve(CheckpointedL2Block.fromFields({
|
|
175
|
+
checkpointNumber: CheckpointNumber.fromBlockNumber(block.number),
|
|
176
|
+
block,
|
|
177
|
+
l1: new L1PublishedData(BigInt(block.number), BigInt(block.number), Buffer32.random().toString()),
|
|
178
|
+
attestations: []
|
|
179
|
+
}));
|
|
180
|
+
}
|
|
181
|
+
async getL2BlockByHash(blockHash) {
|
|
182
|
+
for (const block of this.l2Blocks){
|
|
183
|
+
const hash = await block.hash();
|
|
184
|
+
if (hash.equals(blockHash)) {
|
|
185
|
+
return block;
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
return undefined;
|
|
189
|
+
}
|
|
190
|
+
getL2BlockByArchive(archive) {
|
|
191
|
+
const block = this.l2Blocks.find((b)=>b.archive.root.equals(archive));
|
|
192
|
+
return Promise.resolve(block);
|
|
193
|
+
}
|
|
194
|
+
async getBlockHeaderByHash(blockHash) {
|
|
195
|
+
for (const block of this.l2Blocks){
|
|
196
|
+
const hash = await block.hash();
|
|
197
|
+
if (hash.equals(blockHash)) {
|
|
198
|
+
return block.header;
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
return undefined;
|
|
202
|
+
}
|
|
203
|
+
getBlockHeaderByArchive(archive) {
|
|
204
|
+
const block = this.l2Blocks.find((b)=>b.archive.root.equals(archive));
|
|
205
|
+
return Promise.resolve(block?.header);
|
|
67
206
|
}
|
|
68
207
|
getBlockHeader(number) {
|
|
69
208
|
return Promise.resolve(this.l2Blocks.at(typeof number === 'number' ? number - 1 : -1)?.header);
|
|
70
209
|
}
|
|
71
|
-
|
|
210
|
+
getCheckpointsForEpoch(epochNumber) {
|
|
211
|
+
// TODO(mbps): Implement this properly. This only works when we have one block per checkpoint.
|
|
212
|
+
const epochDuration = DefaultL1ContractsConfig.aztecEpochDuration;
|
|
213
|
+
const [start, end] = getSlotRangeForEpoch(epochNumber, {
|
|
214
|
+
epochDuration
|
|
215
|
+
});
|
|
216
|
+
const blocks = this.l2Blocks.filter((b)=>{
|
|
217
|
+
const slot = b.header.globalVariables.slotNumber;
|
|
218
|
+
return slot >= start && slot <= end;
|
|
219
|
+
});
|
|
220
|
+
// Create checkpoints from blocks - manually construct since L2Block doesn't have toCheckpoint()
|
|
221
|
+
return Promise.all(blocks.map(async (block)=>{
|
|
222
|
+
const checkpoint = await Checkpoint.random(block.checkpointNumber, {
|
|
223
|
+
numBlocks: 1
|
|
224
|
+
});
|
|
225
|
+
checkpoint.blocks = [
|
|
226
|
+
block
|
|
227
|
+
];
|
|
228
|
+
return checkpoint;
|
|
229
|
+
}));
|
|
230
|
+
}
|
|
231
|
+
getCheckpointedBlocksForEpoch(epochNumber) {
|
|
72
232
|
const epochDuration = DefaultL1ContractsConfig.aztecEpochDuration;
|
|
73
233
|
const [start, end] = getSlotRangeForEpoch(epochNumber, {
|
|
74
234
|
epochDuration
|
|
75
235
|
});
|
|
76
236
|
const blocks = this.l2Blocks.filter((b)=>{
|
|
77
|
-
const slot = b.header.globalVariables.slotNumber
|
|
237
|
+
const slot = b.header.globalVariables.slotNumber;
|
|
78
238
|
return slot >= start && slot <= end;
|
|
79
239
|
});
|
|
240
|
+
return Promise.resolve(blocks.map((block)=>CheckpointedL2Block.fromFields({
|
|
241
|
+
checkpointNumber: CheckpointNumber.fromBlockNumber(block.number),
|
|
242
|
+
block,
|
|
243
|
+
l1: new L1PublishedData(BigInt(block.number), BigInt(block.number), Buffer32.random().toString()),
|
|
244
|
+
attestations: []
|
|
245
|
+
})));
|
|
246
|
+
}
|
|
247
|
+
getBlocksForSlot(slotNumber) {
|
|
248
|
+
const blocks = this.l2Blocks.filter((b)=>b.header.globalVariables.slotNumber === slotNumber);
|
|
80
249
|
return Promise.resolve(blocks);
|
|
81
250
|
}
|
|
251
|
+
async getCheckpointedBlockHeadersForEpoch(epochNumber) {
|
|
252
|
+
const checkpointedBlocks = await this.getCheckpointedBlocksForEpoch(epochNumber);
|
|
253
|
+
return checkpointedBlocks.map((b)=>b.block.header);
|
|
254
|
+
}
|
|
82
255
|
/**
|
|
83
256
|
* Gets a tx effect.
|
|
84
|
-
* @param txHash - The hash of
|
|
85
|
-
* @returns The requested tx effect.
|
|
257
|
+
* @param txHash - The hash of the tx corresponding to the tx effect.
|
|
258
|
+
* @returns The requested tx effect with block info (or undefined if not found).
|
|
86
259
|
*/ async getTxEffect(txHash) {
|
|
87
260
|
const match = this.l2Blocks.flatMap((b)=>b.body.txEffects.map((tx)=>[
|
|
88
261
|
tx,
|
|
@@ -95,7 +268,8 @@ import { TxReceipt, TxStatus } from '@aztec/stdlib/tx';
|
|
|
95
268
|
return {
|
|
96
269
|
data: txEffect,
|
|
97
270
|
l2BlockNumber: block.number,
|
|
98
|
-
l2BlockHash:
|
|
271
|
+
l2BlockHash: await block.hash(),
|
|
272
|
+
txIndexInBlock: block.body.txEffects.indexOf(txEffect)
|
|
99
273
|
};
|
|
100
274
|
}
|
|
101
275
|
/**
|
|
@@ -106,34 +280,52 @@ import { TxReceipt, TxStatus } from '@aztec/stdlib/tx';
|
|
|
106
280
|
for (const block of this.l2Blocks){
|
|
107
281
|
for (const txEffect of block.body.txEffects){
|
|
108
282
|
if (txEffect.txHash.equals(txHash)) {
|
|
109
|
-
|
|
283
|
+
// In mock, assume all txs are checkpointed with successful execution
|
|
284
|
+
return new TxReceipt(txHash, TxStatus.CHECKPOINTED, TxExecutionResult.SUCCESS, undefined, txEffect.transactionFee.toBigInt(), await block.hash(), block.number);
|
|
110
285
|
}
|
|
111
286
|
}
|
|
112
287
|
}
|
|
113
288
|
return undefined;
|
|
114
289
|
}
|
|
115
290
|
async getL2Tips() {
|
|
116
|
-
const [latest, proven, finalized] = [
|
|
291
|
+
const [latest, proven, finalized, checkpointed] = [
|
|
117
292
|
await this.getBlockNumber(),
|
|
118
293
|
await this.getProvenBlockNumber(),
|
|
119
|
-
|
|
294
|
+
this.finalizedBlockNumber,
|
|
295
|
+
this.checkpointedBlockNumber
|
|
120
296
|
];
|
|
121
297
|
const latestBlock = this.l2Blocks[latest - 1];
|
|
122
298
|
const provenBlock = this.l2Blocks[proven - 1];
|
|
123
299
|
const finalizedBlock = this.l2Blocks[finalized - 1];
|
|
300
|
+
const checkpointedBlock = this.l2Blocks[checkpointed - 1];
|
|
301
|
+
const latestBlockId = {
|
|
302
|
+
number: BlockNumber(latest),
|
|
303
|
+
hash: (await latestBlock?.hash())?.toString()
|
|
304
|
+
};
|
|
305
|
+
const provenBlockId = {
|
|
306
|
+
number: BlockNumber(proven),
|
|
307
|
+
hash: (await provenBlock?.hash())?.toString()
|
|
308
|
+
};
|
|
309
|
+
const finalizedBlockId = {
|
|
310
|
+
number: BlockNumber(finalized),
|
|
311
|
+
hash: (await finalizedBlock?.hash())?.toString()
|
|
312
|
+
};
|
|
313
|
+
const checkpointedBlockId = {
|
|
314
|
+
number: BlockNumber(checkpointed),
|
|
315
|
+
hash: (await checkpointedBlock?.hash())?.toString()
|
|
316
|
+
};
|
|
317
|
+
const makeTipId = (blockId)=>({
|
|
318
|
+
block: blockId,
|
|
319
|
+
checkpoint: {
|
|
320
|
+
number: CheckpointNumber.fromBlockNumber(blockId.number),
|
|
321
|
+
hash: blockId.hash
|
|
322
|
+
}
|
|
323
|
+
});
|
|
124
324
|
return {
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
proven: {
|
|
130
|
-
number: proven,
|
|
131
|
-
hash: (await provenBlock?.hash())?.toString()
|
|
132
|
-
},
|
|
133
|
-
finalized: {
|
|
134
|
-
number: finalized,
|
|
135
|
-
hash: (await finalizedBlock?.hash())?.toString()
|
|
136
|
-
}
|
|
325
|
+
proposed: latestBlockId,
|
|
326
|
+
checkpointed: makeTipId(checkpointedBlockId),
|
|
327
|
+
proven: makeTipId(provenBlockId),
|
|
328
|
+
finalized: makeTipId(finalizedBlockId)
|
|
137
329
|
};
|
|
138
330
|
}
|
|
139
331
|
getL2EpochNumber() {
|
|
@@ -146,18 +338,57 @@ import { TxReceipt, TxStatus } from '@aztec/stdlib/tx';
|
|
|
146
338
|
throw new Error('Method not implemented.');
|
|
147
339
|
}
|
|
148
340
|
getL1Constants() {
|
|
341
|
+
return Promise.resolve(EmptyL1RollupConstants);
|
|
342
|
+
}
|
|
343
|
+
getGenesisValues() {
|
|
344
|
+
return Promise.resolve({
|
|
345
|
+
genesisArchiveRoot: new Fr(GENESIS_ARCHIVE_ROOT)
|
|
346
|
+
});
|
|
347
|
+
}
|
|
348
|
+
getL1Timestamp() {
|
|
149
349
|
throw new Error('Method not implemented.');
|
|
150
350
|
}
|
|
151
351
|
/**
|
|
152
352
|
* Starts the block source. In this mock implementation, this is a noop.
|
|
153
353
|
* @returns A promise that signals the initialization of the l2 block source on completion.
|
|
154
354
|
*/ start() {
|
|
355
|
+
this.log.verbose('Starting mock L2 block source');
|
|
155
356
|
return Promise.resolve();
|
|
156
357
|
}
|
|
157
358
|
/**
|
|
158
359
|
* Stops the block source. In this mock implementation, this is a noop.
|
|
159
360
|
* @returns A promise that signals the l2 block source is now stopped.
|
|
160
361
|
*/ stop() {
|
|
362
|
+
this.log.verbose('Stopping mock L2 block source');
|
|
363
|
+
return Promise.resolve();
|
|
364
|
+
}
|
|
365
|
+
getContractClass(_id) {
|
|
366
|
+
return Promise.resolve(undefined);
|
|
367
|
+
}
|
|
368
|
+
getBytecodeCommitment(_id) {
|
|
369
|
+
return Promise.resolve(undefined);
|
|
370
|
+
}
|
|
371
|
+
getContract(_address, _timestamp) {
|
|
372
|
+
return Promise.resolve(undefined);
|
|
373
|
+
}
|
|
374
|
+
getContractClassIds() {
|
|
375
|
+
return Promise.resolve([]);
|
|
376
|
+
}
|
|
377
|
+
getDebugFunctionName(_address, _selector) {
|
|
378
|
+
return Promise.resolve(undefined);
|
|
379
|
+
}
|
|
380
|
+
registerContractFunctionSignatures(_signatures) {
|
|
161
381
|
return Promise.resolve();
|
|
162
382
|
}
|
|
383
|
+
syncImmediate() {
|
|
384
|
+
return Promise.resolve();
|
|
385
|
+
}
|
|
386
|
+
isPendingChainInvalid() {
|
|
387
|
+
return Promise.resolve(false);
|
|
388
|
+
}
|
|
389
|
+
getPendingChainValidationStatus() {
|
|
390
|
+
return Promise.resolve({
|
|
391
|
+
valid: true
|
|
392
|
+
});
|
|
393
|
+
}
|
|
163
394
|
}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import { CheckpointNumber } from '@aztec/foundation/branded-types';
|
|
2
|
+
import { Buffer16 } from '@aztec/foundation/buffer';
|
|
3
|
+
import type { Secp256k1Signer } from '@aztec/foundation/crypto/secp256k1-signer';
|
|
4
|
+
import { EthAddress } from '@aztec/foundation/eth-address';
|
|
5
|
+
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
6
|
+
import { Checkpoint, L1PublishedData, PublishedCheckpoint } from '@aztec/stdlib/checkpoint';
|
|
7
|
+
import { PrivateLog, PublicLog, SiloedTag, Tag } from '@aztec/stdlib/logs';
|
|
8
|
+
import { AppendOnlyTreeSnapshot } from '@aztec/stdlib/trees';
|
|
9
|
+
import { StateReference } from '@aztec/stdlib/tx';
|
|
10
|
+
import { type InboxMessage } from '../structs/inbox_message.js';
|
|
11
|
+
export declare function makeInboxMessage(previousRollingHash?: Buffer16, overrides?: Partial<InboxMessage>): InboxMessage;
|
|
12
|
+
export declare function makeInboxMessages(totalCount: number, opts?: {
|
|
13
|
+
initialHash?: Buffer16;
|
|
14
|
+
initialCheckpointNumber?: CheckpointNumber;
|
|
15
|
+
messagesPerCheckpoint?: number;
|
|
16
|
+
overrideFn?: (msg: InboxMessage, index: number) => InboxMessage;
|
|
17
|
+
}): InboxMessage[];
|
|
18
|
+
/** Creates inbox messages distributed across multiple blocks with proper checkpoint numbering. */
|
|
19
|
+
export declare function makeInboxMessagesWithFullBlocks(blockCount: number, opts?: {
|
|
20
|
+
initialCheckpointNumber?: CheckpointNumber;
|
|
21
|
+
}): InboxMessage[];
|
|
22
|
+
/** Creates a deterministic block hash from a block number. */
|
|
23
|
+
export declare function makeBlockHash(blockNumber: number): `0x${string}`;
|
|
24
|
+
/**
|
|
25
|
+
* Creates a StateReference with properly calculated noteHashTree.nextAvailableLeafIndex.
|
|
26
|
+
* This ensures LogStore's dataStartIndexForBlock calculation doesn't produce negative values.
|
|
27
|
+
*/
|
|
28
|
+
export declare function makeStateForBlock(blockNumber: number, txsPerBlock: number): StateReference;
|
|
29
|
+
/** Creates L1PublishedData with deterministic values based on l1BlockNumber. */
|
|
30
|
+
export declare function makeL1PublishedData(l1BlockNumber: number): L1PublishedData;
|
|
31
|
+
/** Wraps a Checkpoint with L1 published data and random attestations. */
|
|
32
|
+
export declare function makePublishedCheckpoint(checkpoint: Checkpoint, l1BlockNumber: number, attestationCount?: number): PublishedCheckpoint;
|
|
33
|
+
export interface MakeChainedCheckpointsOptions {
|
|
34
|
+
/** Number of L2 blocks per checkpoint. Default: 1 */
|
|
35
|
+
blocksPerCheckpoint?: number;
|
|
36
|
+
/** Number of transactions per block. Default: 4 */
|
|
37
|
+
txsPerBlock?: number;
|
|
38
|
+
/** Starting checkpoint number. Default: CheckpointNumber(1) */
|
|
39
|
+
startCheckpointNumber?: CheckpointNumber;
|
|
40
|
+
/** Starting block number. Default: 1 */
|
|
41
|
+
startBlockNumber?: number;
|
|
42
|
+
/** Starting L1 block number. Default: 10 */
|
|
43
|
+
startL1BlockNumber?: number;
|
|
44
|
+
/** Previous archive to chain from. Default: undefined */
|
|
45
|
+
previousArchive?: AppendOnlyTreeSnapshot;
|
|
46
|
+
/** Optional function to provide per-checkpoint overrides */
|
|
47
|
+
makeCheckpointOptions?: (cpNumber: CheckpointNumber) => Partial<Parameters<typeof Checkpoint.random>[1]>;
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Creates multiple checkpoints with properly chained archives.
|
|
51
|
+
* Each checkpoint's blocks have their lastArchive set to the previous block's archive,
|
|
52
|
+
* ensuring archive chain continuity for testing.
|
|
53
|
+
*/
|
|
54
|
+
export declare function makeChainedCheckpoints(count: number, options?: MakeChainedCheckpointsOptions): Promise<PublishedCheckpoint[]>;
|
|
55
|
+
/**
|
|
56
|
+
* Creates a PublishedCheckpoint with attestations signed by the provided signers.
|
|
57
|
+
* Useful for testing attestation validation.
|
|
58
|
+
*/
|
|
59
|
+
export declare function makeSignedPublishedCheckpoint(checkpoint: Checkpoint, signers: Secp256k1Signer[], committee: EthAddress[], l1BlockNumber?: number): PublishedCheckpoint;
|
|
60
|
+
/** Creates a deterministic SiloedTag for private log testing. */
|
|
61
|
+
export declare function makePrivateLogTag(blockNumber: number, txIndex: number, logIndex: number): SiloedTag;
|
|
62
|
+
/** Creates a PrivateLog with fields derived from the tag. */
|
|
63
|
+
export declare function makePrivateLog(tag: SiloedTag): PrivateLog;
|
|
64
|
+
/** Creates multiple private logs for a transaction. */
|
|
65
|
+
export declare function mockPrivateLogs(blockNumber: number, txIndex: number, numLogsPerTx: number): PrivateLog[];
|
|
66
|
+
/** Creates a deterministic Tag for public log testing. */
|
|
67
|
+
export declare function makePublicLogTag(blockNumber: number, txIndex: number, logIndex: number): Tag;
|
|
68
|
+
/** Creates a PublicLog with fields derived from the tag. */
|
|
69
|
+
export declare function makePublicLog(tag: Tag, contractAddress?: AztecAddress): PublicLog;
|
|
70
|
+
/** Creates multiple public logs for a transaction. */
|
|
71
|
+
export declare function makePublicLogs(blockNumber: number, txIndex: number, numLogsPerTx: number, contractAddress?: AztecAddress): PublicLog[];
|
|
72
|
+
export interface MockCheckpointWithLogsOptions {
|
|
73
|
+
previousArchive?: AppendOnlyTreeSnapshot;
|
|
74
|
+
numTxsPerBlock?: number;
|
|
75
|
+
privateLogs?: {
|
|
76
|
+
numLogsPerTx: number;
|
|
77
|
+
};
|
|
78
|
+
publicLogs?: {
|
|
79
|
+
numLogsPerTx: number;
|
|
80
|
+
contractAddress?: AztecAddress;
|
|
81
|
+
};
|
|
82
|
+
}
|
|
83
|
+
/** Creates a checkpoint with specified logs on each tx effect. */
|
|
84
|
+
export declare function makeCheckpointWithLogs(blockNumber: number, options?: MockCheckpointWithLogsOptions): Promise<PublishedCheckpoint>;
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9ja19zdHJ1Y3RzLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdGVzdC9tb2NrX3N0cnVjdHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBTUEsT0FBTyxFQUFlLGdCQUFnQixFQUF5QixNQUFNLGlDQUFpQyxDQUFDO0FBQ3ZHLE9BQU8sRUFBRSxRQUFRLEVBQVksTUFBTSwwQkFBMEIsQ0FBQztBQUc5RCxPQUFPLEtBQUssRUFBRSxlQUFlLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQztBQUVqRixPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDM0QsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBRTNELE9BQU8sRUFBRSxVQUFVLEVBQUUsZUFBZSxFQUFFLG1CQUFtQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDNUYsT0FBTyxFQUFFLFVBQVUsRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLEdBQUcsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBSzNFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQzdELE9BQU8sRUFBeUIsY0FBYyxFQUFZLE1BQU0sa0JBQWtCLENBQUM7QUFFbkYsT0FBTyxFQUFFLEtBQUssWUFBWSxFQUFxQixNQUFNLDZCQUE2QixDQUFDO0FBRW5GLHdCQUFnQixnQkFBZ0IsQ0FDOUIsbUJBQW1CLFdBQWdCLEVBQ25DLFNBQVMsR0FBRSxPQUFPLENBQUMsWUFBWSxDQUFNLEdBQ3BDLFlBQVksQ0FnQmQ7QUFFRCx3QkFBZ0IsaUJBQWlCLENBQy9CLFVBQVUsRUFBRSxNQUFNLEVBQ2xCLElBQUksR0FBRTtJQUNKLFdBQVcsQ0FBQyxFQUFFLFFBQVEsQ0FBQztJQUN2Qix1QkFBdUIsQ0FBQyxFQUFFLGdCQUFnQixDQUFDO0lBQzNDLHFCQUFxQixDQUFDLEVBQUUsTUFBTSxDQUFDO0lBQy9CLFVBQVUsQ0FBQyxFQUFFLENBQUMsR0FBRyxF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
|