@aztec/archiver 0.0.1-commit.b655e406 → 0.0.1-commit.b6e433891
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 +156 -22
- package/dest/archiver.d.ts +138 -0
- package/dest/archiver.d.ts.map +1 -0
- package/dest/archiver.js +732 -0
- package/dest/config.d.ts +30 -0
- package/dest/config.d.ts.map +1 -0
- package/dest/{archiver/config.js → config.js} +28 -6
- package/dest/errors.d.ts +53 -0
- package/dest/errors.d.ts.map +1 -0
- package/dest/errors.js +75 -0
- package/dest/factory.d.ts +8 -7
- package/dest/factory.d.ts.map +1 -1
- package/dest/factory.js +93 -10
- package/dest/index.d.ts +11 -4
- package/dest/index.d.ts.map +1 -1
- package/dest/index.js +9 -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 +152 -0
- package/dest/l1/calldata_retriever.d.ts +135 -0
- package/dest/l1/calldata_retriever.d.ts.map +1 -0
- package/dest/l1/calldata_retriever.js +402 -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 +314 -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 +149 -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 +89 -0
- package/dest/modules/data_source_base.d.ts.map +1 -0
- package/dest/modules/data_source_base.js +216 -0
- package/dest/modules/data_store_updater.d.ts +88 -0
- package/dest/modules/data_store_updater.d.ts.map +1 -0
- package/dest/modules/data_store_updater.js +342 -0
- package/dest/modules/instrumentation.d.ts +50 -0
- package/dest/modules/instrumentation.d.ts.map +1 -0
- package/dest/{archiver → modules}/instrumentation.js +49 -62
- package/dest/modules/l1_synchronizer.d.ts +72 -0
- package/dest/modules/l1_synchronizer.d.ts.map +1 -0
- package/dest/modules/l1_synchronizer.js +1147 -0
- package/dest/modules/validation.d.ts +17 -0
- package/dest/modules/validation.d.ts.map +1 -0
- package/dest/{archiver → modules}/validation.js +35 -21
- package/dest/store/block_store.d.ts +195 -0
- package/dest/store/block_store.d.ts.map +1 -0
- package/dest/store/block_store.js +773 -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 +13 -9
- package/dest/store/contract_instance_store.d.ts +24 -0
- package/dest/store/contract_instance_store.d.ts.map +1 -0
- package/dest/{archiver/kv_archiver_store → store}/contract_instance_store.js +1 -1
- package/dest/store/kv_archiver_store.d.ts +367 -0
- package/dest/store/kv_archiver_store.d.ts.map +1 -0
- package/dest/store/kv_archiver_store.js +481 -0
- package/dest/store/l2_tips_cache.d.ts +19 -0
- package/dest/store/l2_tips_cache.d.ts.map +1 -0
- package/dest/store/l2_tips_cache.js +89 -0
- package/dest/store/log_store.d.ts +57 -0
- package/dest/store/log_store.d.ts.map +1 -0
- package/dest/store/log_store.js +533 -0
- package/dest/store/message_store.d.ts +44 -0
- package/dest/store/message_store.d.ts.map +1 -0
- package/dest/{archiver/kv_archiver_store → store}/message_store.js +29 -15
- 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/{archiver/structs → structs}/inbox_message.js +6 -5
- package/dest/structs/published.d.ts +2 -0
- package/dest/structs/published.d.ts.map +1 -0
- package/dest/test/fake_l1_state.d.ts +202 -0
- package/dest/test/fake_l1_state.d.ts.map +1 -0
- package/dest/test/fake_l1_state.js +455 -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 +19 -14
- package/dest/test/mock_l1_to_l2_message_source.d.ts +7 -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 +21 -11
- package/dest/test/mock_l2_block_source.d.ts +55 -20
- package/dest/test/mock_l2_block_source.d.ts.map +1 -1
- package/dest/test/mock_l2_block_source.js +251 -85
- package/dest/test/mock_structs.d.ts +83 -4
- package/dest/test/mock_structs.d.ts.map +1 -1
- package/dest/test/mock_structs.js +157 -11
- package/dest/test/noop_l1_archiver.d.ts +26 -0
- package/dest/test/noop_l1_archiver.d.ts.map +1 -0
- package/dest/test/noop_l1_archiver.js +72 -0
- package/package.json +20 -20
- package/src/archiver.ts +486 -0
- package/src/{archiver/config.ts → config.ts} +41 -13
- package/src/errors.ts +118 -0
- package/src/factory.ts +144 -12
- package/src/index.ts +11 -3
- package/src/interfaces.ts +9 -0
- package/src/l1/README.md +55 -0
- package/src/l1/bin/retrieve-calldata.ts +194 -0
- package/src/l1/calldata_retriever.ts +511 -0
- package/src/l1/data_retrieval.ts +493 -0
- package/src/l1/debug_tx.ts +99 -0
- package/src/l1/spire_proposer.ts +152 -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 +333 -0
- package/src/modules/data_store_updater.ts +464 -0
- package/src/{archiver → modules}/instrumentation.ts +61 -64
- package/src/modules/l1_synchronizer.ts +967 -0
- package/src/modules/validation.ts +129 -0
- package/src/store/block_store.ts +1018 -0
- package/src/{archiver/kv_archiver_store → store}/contract_class_store.ts +13 -9
- package/src/{archiver/kv_archiver_store → store}/contract_instance_store.ts +2 -2
- package/src/store/kv_archiver_store.ts +697 -0
- package/src/store/l2_tips_cache.ts +89 -0
- package/src/store/log_store.ts +736 -0
- package/src/{archiver/kv_archiver_store → store}/message_store.ts +41 -19
- package/src/{archiver/structs → structs}/inbox_message.ts +8 -8
- package/src/structs/published.ts +1 -0
- package/src/test/fake_l1_state.ts +698 -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 +23 -16
- package/src/test/mock_l1_to_l2_message_source.ts +18 -11
- package/src/test/mock_l2_block_source.ts +312 -93
- package/src/test/mock_structs.ts +289 -13
- package/src/test/noop_l1_archiver.ts +115 -0
- package/dest/archiver/archiver.d.ts +0 -277
- package/dest/archiver/archiver.d.ts.map +0 -1
- package/dest/archiver/archiver.js +0 -1322
- package/dest/archiver/archiver_store.d.ts +0 -255
- 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 -1288
- package/dest/archiver/config.d.ts +0 -21
- package/dest/archiver/config.d.ts.map +0 -1
- package/dest/archiver/data_retrieval.d.ts +0 -79
- package/dest/archiver/data_retrieval.d.ts.map +0 -1
- package/dest/archiver/data_retrieval.js +0 -362
- package/dest/archiver/errors.d.ts +0 -12
- package/dest/archiver/errors.d.ts.map +0 -1
- package/dest/archiver/errors.js +0 -17
- package/dest/archiver/index.d.ts +0 -7
- package/dest/archiver/index.d.ts.map +0 -1
- package/dest/archiver/index.js +0 -4
- package/dest/archiver/instrumentation.d.ts +0 -35
- package/dest/archiver/instrumentation.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/block_store.d.ts +0 -124
- package/dest/archiver/kv_archiver_store/block_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/block_store.js +0 -370
- 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 -24
- package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts +0 -168
- 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 -296
- 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 -336
- package/dest/archiver/kv_archiver_store/message_store.d.ts +0 -39
- package/dest/archiver/kv_archiver_store/message_store.d.ts.map +0 -1
- 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/inbox_message.d.ts +0 -15
- package/dest/archiver/structs/inbox_message.d.ts.map +0 -1
- package/dest/archiver/structs/published.d.ts +0 -2
- package/dest/archiver/structs/published.d.ts.map +0 -1
- package/dest/archiver/validation.d.ts +0 -11
- package/dest/archiver/validation.d.ts.map +0 -1
- package/dest/rpc/index.d.ts +0 -9
- package/dest/rpc/index.d.ts.map +0 -1
- package/dest/rpc/index.js +0 -15
- package/src/archiver/archiver.ts +0 -1722
- package/src/archiver/archiver_store.ts +0 -305
- package/src/archiver/archiver_store_test_suite.ts +0 -1263
- package/src/archiver/data_retrieval.ts +0 -545
- package/src/archiver/errors.ts +0 -26
- package/src/archiver/index.ts +0 -6
- package/src/archiver/kv_archiver_store/block_store.ts +0 -481
- package/src/archiver/kv_archiver_store/kv_archiver_store.ts +0 -422
- package/src/archiver/kv_archiver_store/log_store.ts +0 -406
- package/src/archiver/structs/published.ts +0 -1
- package/src/archiver/validation.ts +0 -99
- package/src/rpc/index.ts +0 -16
- /package/dest/{archiver/structs → structs}/data_retrieval.js +0 -0
- /package/dest/{archiver/structs → structs}/published.js +0 -0
- /package/src/{archiver/structs → structs}/data_retrieval.ts +0 -0
|
@@ -1,22 +1,32 @@
|
|
|
1
1
|
import { GENESIS_ARCHIVE_ROOT } from '@aztec/constants';
|
|
2
|
-
import { DefaultL1ContractsConfig } from '@aztec/ethereum';
|
|
2
|
+
import { DefaultL1ContractsConfig } from '@aztec/ethereum/config';
|
|
3
|
+
import { BlockNumber, CheckpointNumber, EpochNumber, SlotNumber } from '@aztec/foundation/branded-types';
|
|
3
4
|
import { Buffer32 } from '@aztec/foundation/buffer';
|
|
5
|
+
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
4
6
|
import { EthAddress } from '@aztec/foundation/eth-address';
|
|
5
|
-
import { Fr } from '@aztec/foundation/fields';
|
|
6
7
|
import { createLogger } from '@aztec/foundation/log';
|
|
7
8
|
import type { FunctionSelector } from '@aztec/stdlib/abi';
|
|
8
9
|
import type { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
9
10
|
import {
|
|
11
|
+
type BlockData,
|
|
12
|
+
BlockHash,
|
|
13
|
+
CheckpointedL2Block,
|
|
10
14
|
L2Block,
|
|
11
|
-
L2BlockHash,
|
|
12
15
|
type L2BlockSource,
|
|
13
16
|
type L2Tips,
|
|
14
|
-
|
|
15
|
-
type ValidateBlockResult,
|
|
17
|
+
type ValidateCheckpointResult,
|
|
16
18
|
} from '@aztec/stdlib/block';
|
|
19
|
+
import { Checkpoint, type CheckpointData, L1PublishedData, PublishedCheckpoint } from '@aztec/stdlib/checkpoint';
|
|
17
20
|
import type { ContractClassPublic, ContractDataSource, ContractInstanceWithAddress } from '@aztec/stdlib/contract';
|
|
18
|
-
import {
|
|
19
|
-
|
|
21
|
+
import {
|
|
22
|
+
EmptyL1RollupConstants,
|
|
23
|
+
type L1RollupConstants,
|
|
24
|
+
getEpochAtSlot,
|
|
25
|
+
getSlotRangeForEpoch,
|
|
26
|
+
} from '@aztec/stdlib/epoch-helpers';
|
|
27
|
+
import { computeCheckpointOutHash } from '@aztec/stdlib/messaging';
|
|
28
|
+
import { CheckpointHeader } from '@aztec/stdlib/rollup';
|
|
29
|
+
import { type BlockHeader, TxExecutionResult, TxHash, TxReceipt, TxStatus } from '@aztec/stdlib/tx';
|
|
20
30
|
import type { UInt64 } from '@aztec/stdlib/types';
|
|
21
31
|
|
|
22
32
|
/**
|
|
@@ -24,29 +34,63 @@ import type { UInt64 } from '@aztec/stdlib/types';
|
|
|
24
34
|
*/
|
|
25
35
|
export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
26
36
|
protected l2Blocks: L2Block[] = [];
|
|
37
|
+
protected checkpointList: Checkpoint[] = [];
|
|
27
38
|
|
|
28
39
|
private provenBlockNumber: number = 0;
|
|
29
40
|
private finalizedBlockNumber: number = 0;
|
|
41
|
+
private checkpointedBlockNumber: number = 0;
|
|
30
42
|
|
|
31
43
|
private log = createLogger('archiver:mock_l2_block_source');
|
|
32
44
|
|
|
45
|
+
/** Creates blocks grouped into single-block checkpoints. */
|
|
33
46
|
public async createBlocks(numBlocks: number) {
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
47
|
+
await this.createCheckpoints(numBlocks, 1);
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
public getCheckpointNumber(): Promise<CheckpointNumber> {
|
|
51
|
+
return Promise.resolve(
|
|
52
|
+
this.checkpointList.length === 0 ? CheckpointNumber.ZERO : CheckpointNumber(this.checkpointList.length),
|
|
53
|
+
);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
/** Creates checkpoints, each containing `blocksPerCheckpoint` blocks. */
|
|
57
|
+
public async createCheckpoints(numCheckpoints: number, blocksPerCheckpoint: number = 1) {
|
|
58
|
+
for (let c = 0; c < numCheckpoints; c++) {
|
|
59
|
+
const checkpointNum = CheckpointNumber(this.checkpointList.length + 1);
|
|
60
|
+
const startBlockNum = this.l2Blocks.length + 1;
|
|
61
|
+
const slotNumber = SlotNumber(Number(checkpointNum));
|
|
62
|
+
const checkpoint = await Checkpoint.random(checkpointNum, {
|
|
63
|
+
numBlocks: blocksPerCheckpoint,
|
|
64
|
+
startBlockNumber: startBlockNum,
|
|
65
|
+
slotNumber,
|
|
66
|
+
checkpointNumber: checkpointNum,
|
|
67
|
+
});
|
|
68
|
+
this.checkpointList.push(checkpoint);
|
|
69
|
+
this.l2Blocks.push(...checkpoint.blocks);
|
|
38
70
|
}
|
|
39
71
|
|
|
40
|
-
this.log.verbose(
|
|
72
|
+
this.log.verbose(
|
|
73
|
+
`Created ${numCheckpoints} checkpoints with ${blocksPerCheckpoint} blocks each in the mock L2 block source`,
|
|
74
|
+
);
|
|
41
75
|
}
|
|
42
76
|
|
|
43
|
-
public
|
|
77
|
+
public addProposedBlocks(blocks: L2Block[]) {
|
|
44
78
|
this.l2Blocks.push(...blocks);
|
|
45
|
-
this.log.verbose(`Added ${blocks.length} blocks to the mock L2 block source`);
|
|
79
|
+
this.log.verbose(`Added ${blocks.length} proposed blocks to the mock L2 block source`);
|
|
46
80
|
}
|
|
47
81
|
|
|
48
82
|
public removeBlocks(numBlocks: number) {
|
|
49
83
|
this.l2Blocks = this.l2Blocks.slice(0, -numBlocks);
|
|
84
|
+
const maxBlockNum = this.l2Blocks.length;
|
|
85
|
+
// Remove any checkpoint whose last block is beyond the remaining blocks.
|
|
86
|
+
this.checkpointList = this.checkpointList.filter(c => {
|
|
87
|
+
const lastBlockNum = c.blocks[0].number + c.blocks.length - 1;
|
|
88
|
+
return lastBlockNum <= maxBlockNum;
|
|
89
|
+
});
|
|
90
|
+
// Keep tip numbers consistent with remaining blocks.
|
|
91
|
+
this.checkpointedBlockNumber = Math.min(this.checkpointedBlockNumber, maxBlockNum);
|
|
92
|
+
this.provenBlockNumber = Math.min(this.provenBlockNumber, maxBlockNum);
|
|
93
|
+
this.finalizedBlockNumber = Math.min(this.finalizedBlockNumber, maxBlockNum);
|
|
50
94
|
this.log.verbose(`Removed ${numBlocks} blocks from the mock L2 block source`);
|
|
51
95
|
}
|
|
52
96
|
|
|
@@ -61,6 +105,36 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
61
105
|
this.finalizedBlockNumber = finalizedBlockNumber;
|
|
62
106
|
}
|
|
63
107
|
|
|
108
|
+
public setCheckpointedBlockNumber(checkpointedBlockNumber: number) {
|
|
109
|
+
const prevCheckpointed = this.checkpointedBlockNumber;
|
|
110
|
+
this.checkpointedBlockNumber = checkpointedBlockNumber;
|
|
111
|
+
// Auto-create single-block checkpoints for newly checkpointed blocks that don't have one yet.
|
|
112
|
+
// This handles blocks added via addProposedBlocks that are now being marked as checkpointed.
|
|
113
|
+
const newCheckpoints: Checkpoint[] = [];
|
|
114
|
+
for (let blockNum = prevCheckpointed + 1; blockNum <= checkpointedBlockNumber; blockNum++) {
|
|
115
|
+
const block = this.l2Blocks[blockNum - 1];
|
|
116
|
+
if (!block) {
|
|
117
|
+
continue;
|
|
118
|
+
}
|
|
119
|
+
if (this.checkpointList.some(c => c.blocks.some(b => b.number === block.number))) {
|
|
120
|
+
continue;
|
|
121
|
+
}
|
|
122
|
+
const checkpointNum = CheckpointNumber(this.checkpointList.length + newCheckpoints.length + 1);
|
|
123
|
+
const checkpoint = new Checkpoint(
|
|
124
|
+
block.archive,
|
|
125
|
+
CheckpointHeader.random({ slotNumber: block.header.globalVariables.slotNumber }),
|
|
126
|
+
[block],
|
|
127
|
+
checkpointNum,
|
|
128
|
+
);
|
|
129
|
+
newCheckpoints.push(checkpoint);
|
|
130
|
+
}
|
|
131
|
+
// Insert new checkpoints in order by number.
|
|
132
|
+
if (newCheckpoints.length > 0) {
|
|
133
|
+
this.checkpointList.push(...newCheckpoints);
|
|
134
|
+
this.checkpointList.sort((a, b) => a.number - b.number);
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
|
|
64
138
|
/**
|
|
65
139
|
* Method to fetch the rollup contract address at the base-layer.
|
|
66
140
|
* @returns The rollup address.
|
|
@@ -82,11 +156,45 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
82
156
|
* @returns In this mock instance, returns the number of L2 blocks that we've mocked.
|
|
83
157
|
*/
|
|
84
158
|
public getBlockNumber() {
|
|
85
|
-
return Promise.resolve(this.l2Blocks.length);
|
|
159
|
+
return Promise.resolve(BlockNumber(this.l2Blocks.length));
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
public getProvenBlockNumber() {
|
|
163
|
+
return Promise.resolve(BlockNumber(this.provenBlockNumber));
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
public getCheckpointedL2BlockNumber() {
|
|
167
|
+
return Promise.resolve(BlockNumber(this.checkpointedBlockNumber));
|
|
86
168
|
}
|
|
87
169
|
|
|
88
|
-
public
|
|
89
|
-
return Promise.resolve(this.
|
|
170
|
+
public getFinalizedL2BlockNumber() {
|
|
171
|
+
return Promise.resolve(BlockNumber(this.finalizedBlockNumber));
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
public getCheckpointedBlock(number: BlockNumber): Promise<CheckpointedL2Block | undefined> {
|
|
175
|
+
if (number > this.checkpointedBlockNumber) {
|
|
176
|
+
return Promise.resolve(undefined);
|
|
177
|
+
}
|
|
178
|
+
const block = this.l2Blocks[number - 1];
|
|
179
|
+
if (!block) {
|
|
180
|
+
return Promise.resolve(undefined);
|
|
181
|
+
}
|
|
182
|
+
return Promise.resolve(this.toCheckpointedBlock(block));
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
public async getCheckpointedBlocks(from: BlockNumber, limit: number): Promise<CheckpointedL2Block[]> {
|
|
186
|
+
const result: CheckpointedL2Block[] = [];
|
|
187
|
+
for (let i = 0; i < limit; i++) {
|
|
188
|
+
const blockNum = from + i;
|
|
189
|
+
if (blockNum > this.checkpointedBlockNumber) {
|
|
190
|
+
break;
|
|
191
|
+
}
|
|
192
|
+
const block = await this.getCheckpointedBlock(BlockNumber(blockNum));
|
|
193
|
+
if (block) {
|
|
194
|
+
result.push(block);
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
return result;
|
|
90
198
|
}
|
|
91
199
|
|
|
92
200
|
/**
|
|
@@ -94,8 +202,19 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
94
202
|
* @param number - The block number to return (inclusive).
|
|
95
203
|
* @returns The requested L2 block.
|
|
96
204
|
*/
|
|
97
|
-
public getBlock(number: number) {
|
|
98
|
-
|
|
205
|
+
public getBlock(number: number): Promise<L2Block | undefined> {
|
|
206
|
+
const block = this.l2Blocks[number - 1];
|
|
207
|
+
return Promise.resolve(block);
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
/**
|
|
211
|
+
* Gets an L2 block (new format).
|
|
212
|
+
* @param number - The block number to return.
|
|
213
|
+
* @returns The requested L2 block.
|
|
214
|
+
*/
|
|
215
|
+
public getL2Block(number: BlockNumber): Promise<L2Block | undefined> {
|
|
216
|
+
const block = this.l2Blocks[number - 1];
|
|
217
|
+
return Promise.resolve(block);
|
|
99
218
|
}
|
|
100
219
|
|
|
101
220
|
/**
|
|
@@ -104,70 +223,60 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
104
223
|
* @param limit - The maximum number of blocks to return.
|
|
105
224
|
* @returns The requested mocked L2 blocks.
|
|
106
225
|
*/
|
|
107
|
-
public getBlocks(from: number, limit: number
|
|
226
|
+
public getBlocks(from: number, limit: number): Promise<L2Block[]> {
|
|
227
|
+
return Promise.resolve(this.l2Blocks.slice(from - 1, from - 1 + limit));
|
|
228
|
+
}
|
|
229
|
+
|
|
230
|
+
public getCheckpoints(from: CheckpointNumber, limit: number) {
|
|
231
|
+
const checkpoints = this.checkpointList.slice(from - 1, from - 1 + limit);
|
|
108
232
|
return Promise.resolve(
|
|
109
|
-
this.
|
|
110
|
-
.slice(from - 1, from - 1 + limit)
|
|
111
|
-
.filter(b => !proven || this.provenBlockNumber === undefined || b.number <= this.provenBlockNumber),
|
|
233
|
+
checkpoints.map(checkpoint => new PublishedCheckpoint(checkpoint, this.mockL1DataForCheckpoint(checkpoint), [])),
|
|
112
234
|
);
|
|
113
235
|
}
|
|
114
236
|
|
|
115
|
-
public
|
|
116
|
-
const
|
|
117
|
-
return
|
|
118
|
-
PublishedL2Block.fromFields({
|
|
119
|
-
block,
|
|
120
|
-
l1: {
|
|
121
|
-
blockNumber: BigInt(block.number),
|
|
122
|
-
blockHash: Buffer32.random().toString(),
|
|
123
|
-
timestamp: BigInt(block.number),
|
|
124
|
-
},
|
|
125
|
-
attestations: [],
|
|
126
|
-
}),
|
|
127
|
-
);
|
|
237
|
+
public getCheckpointByArchive(archive: Fr): Promise<Checkpoint | undefined> {
|
|
238
|
+
const checkpoint = this.checkpointList.find(c => c.archive.root.equals(archive));
|
|
239
|
+
return Promise.resolve(checkpoint);
|
|
128
240
|
}
|
|
129
241
|
|
|
130
|
-
public async
|
|
242
|
+
public async getCheckpointedBlockByHash(blockHash: BlockHash): Promise<CheckpointedL2Block | undefined> {
|
|
131
243
|
for (const block of this.l2Blocks) {
|
|
132
244
|
const hash = await block.hash();
|
|
133
245
|
if (hash.equals(blockHash)) {
|
|
134
|
-
return
|
|
135
|
-
block,
|
|
136
|
-
l1: {
|
|
137
|
-
blockNumber: BigInt(block.number),
|
|
138
|
-
blockHash: Buffer32.random().toString(),
|
|
139
|
-
timestamp: BigInt(block.number),
|
|
140
|
-
},
|
|
141
|
-
attestations: [],
|
|
142
|
-
});
|
|
246
|
+
return this.toCheckpointedBlock(block);
|
|
143
247
|
}
|
|
144
248
|
}
|
|
145
249
|
return undefined;
|
|
146
250
|
}
|
|
147
251
|
|
|
148
|
-
public
|
|
252
|
+
public getCheckpointedBlockByArchive(archive: Fr): Promise<CheckpointedL2Block | undefined> {
|
|
149
253
|
const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
|
|
150
254
|
if (!block) {
|
|
151
255
|
return Promise.resolve(undefined);
|
|
152
256
|
}
|
|
153
|
-
return Promise.resolve(
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
257
|
+
return Promise.resolve(this.toCheckpointedBlock(block));
|
|
258
|
+
}
|
|
259
|
+
|
|
260
|
+
public async getL2BlockByHash(blockHash: BlockHash): Promise<L2Block | undefined> {
|
|
261
|
+
for (const block of this.l2Blocks) {
|
|
262
|
+
const hash = await block.hash();
|
|
263
|
+
if (hash.equals(blockHash)) {
|
|
264
|
+
return block;
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
return undefined;
|
|
268
|
+
}
|
|
269
|
+
|
|
270
|
+
public getL2BlockByArchive(archive: Fr): Promise<L2Block | undefined> {
|
|
271
|
+
const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
|
|
272
|
+
return Promise.resolve(block);
|
|
164
273
|
}
|
|
165
274
|
|
|
166
|
-
public async getBlockHeaderByHash(blockHash:
|
|
275
|
+
public async getBlockHeaderByHash(blockHash: BlockHash): Promise<BlockHeader | undefined> {
|
|
167
276
|
for (const block of this.l2Blocks) {
|
|
168
277
|
const hash = await block.hash();
|
|
169
278
|
if (hash.equals(blockHash)) {
|
|
170
|
-
return block.
|
|
279
|
+
return block.header;
|
|
171
280
|
}
|
|
172
281
|
}
|
|
173
282
|
return undefined;
|
|
@@ -175,26 +284,80 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
175
284
|
|
|
176
285
|
public getBlockHeaderByArchive(archive: Fr): Promise<BlockHeader | undefined> {
|
|
177
286
|
const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
|
|
178
|
-
return Promise.resolve(block?.
|
|
287
|
+
return Promise.resolve(block?.header);
|
|
288
|
+
}
|
|
289
|
+
|
|
290
|
+
public async getBlockData(number: BlockNumber): Promise<BlockData | undefined> {
|
|
291
|
+
const block = this.l2Blocks[number - 1];
|
|
292
|
+
if (!block) {
|
|
293
|
+
return undefined;
|
|
294
|
+
}
|
|
295
|
+
return {
|
|
296
|
+
header: block.header,
|
|
297
|
+
archive: block.archive,
|
|
298
|
+
blockHash: await block.hash(),
|
|
299
|
+
checkpointNumber: block.checkpointNumber,
|
|
300
|
+
indexWithinCheckpoint: block.indexWithinCheckpoint,
|
|
301
|
+
};
|
|
302
|
+
}
|
|
303
|
+
|
|
304
|
+
public async getBlockDataByArchive(archive: Fr): Promise<BlockData | undefined> {
|
|
305
|
+
const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
|
|
306
|
+
if (!block) {
|
|
307
|
+
return undefined;
|
|
308
|
+
}
|
|
309
|
+
return {
|
|
310
|
+
header: block.header,
|
|
311
|
+
archive: block.archive,
|
|
312
|
+
blockHash: await block.hash(),
|
|
313
|
+
checkpointNumber: block.checkpointNumber,
|
|
314
|
+
indexWithinCheckpoint: block.indexWithinCheckpoint,
|
|
315
|
+
};
|
|
179
316
|
}
|
|
180
317
|
|
|
181
318
|
getBlockHeader(number: number | 'latest'): Promise<BlockHeader | undefined> {
|
|
182
|
-
return Promise.resolve(this.l2Blocks.at(typeof number === 'number' ? number - 1 : -1)?.
|
|
319
|
+
return Promise.resolve(this.l2Blocks.at(typeof number === 'number' ? number - 1 : -1)?.header);
|
|
183
320
|
}
|
|
184
321
|
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
322
|
+
getCheckpointsForEpoch(epochNumber: EpochNumber): Promise<Checkpoint[]> {
|
|
323
|
+
return Promise.resolve(this.getCheckpointsInEpoch(epochNumber));
|
|
324
|
+
}
|
|
325
|
+
|
|
326
|
+
getCheckpointsDataForEpoch(epochNumber: EpochNumber): Promise<CheckpointData[]> {
|
|
327
|
+
const checkpoints = this.getCheckpointsInEpoch(epochNumber);
|
|
328
|
+
return Promise.resolve(
|
|
329
|
+
checkpoints.map(
|
|
330
|
+
(checkpoint): CheckpointData => ({
|
|
331
|
+
checkpointNumber: checkpoint.number,
|
|
332
|
+
header: checkpoint.header,
|
|
333
|
+
archive: checkpoint.archive,
|
|
334
|
+
checkpointOutHash: computeCheckpointOutHash(
|
|
335
|
+
checkpoint.blocks.map(b => b.body.txEffects.map(tx => tx.l2ToL1Msgs)),
|
|
336
|
+
),
|
|
337
|
+
startBlock: checkpoint.blocks[0].number,
|
|
338
|
+
blockCount: checkpoint.blocks.length,
|
|
339
|
+
attestations: [],
|
|
340
|
+
l1: this.mockL1DataForCheckpoint(checkpoint),
|
|
341
|
+
}),
|
|
342
|
+
),
|
|
343
|
+
);
|
|
344
|
+
}
|
|
345
|
+
|
|
346
|
+
getCheckpointedBlocksForEpoch(epochNumber: EpochNumber): Promise<CheckpointedL2Block[]> {
|
|
347
|
+
const checkpoints = this.getCheckpointsInEpoch(epochNumber);
|
|
348
|
+
return Promise.resolve(
|
|
349
|
+
checkpoints.flatMap(checkpoint => checkpoint.blocks.map(block => this.toCheckpointedBlock(block))),
|
|
350
|
+
);
|
|
351
|
+
}
|
|
352
|
+
|
|
353
|
+
getBlocksForSlot(slotNumber: SlotNumber): Promise<L2Block[]> {
|
|
354
|
+
const blocks = this.l2Blocks.filter(b => b.header.globalVariables.slotNumber === slotNumber);
|
|
192
355
|
return Promise.resolve(blocks);
|
|
193
356
|
}
|
|
194
357
|
|
|
195
|
-
async
|
|
196
|
-
const
|
|
197
|
-
return
|
|
358
|
+
async getCheckpointedBlockHeadersForEpoch(epochNumber: EpochNumber): Promise<BlockHeader[]> {
|
|
359
|
+
const checkpointedBlocks = await this.getCheckpointedBlocksForEpoch(epochNumber);
|
|
360
|
+
return checkpointedBlocks.map(b => b.block.header);
|
|
198
361
|
}
|
|
199
362
|
|
|
200
363
|
/**
|
|
@@ -213,7 +376,7 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
213
376
|
return {
|
|
214
377
|
data: txEffect,
|
|
215
378
|
l2BlockNumber: block.number,
|
|
216
|
-
l2BlockHash:
|
|
379
|
+
l2BlockHash: await block.hash(),
|
|
217
380
|
txIndexInBlock: block.body.txEffects.indexOf(txEffect),
|
|
218
381
|
};
|
|
219
382
|
}
|
|
@@ -227,13 +390,16 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
227
390
|
for (const block of this.l2Blocks) {
|
|
228
391
|
for (const txEffect of block.body.txEffects) {
|
|
229
392
|
if (txEffect.txHash.equals(txHash)) {
|
|
393
|
+
// In mock, assume all txs are checkpointed with successful execution
|
|
230
394
|
return new TxReceipt(
|
|
231
395
|
txHash,
|
|
232
|
-
TxStatus.
|
|
233
|
-
|
|
396
|
+
TxStatus.CHECKPOINTED,
|
|
397
|
+
TxExecutionResult.SUCCESS,
|
|
398
|
+
undefined,
|
|
234
399
|
txEffect.transactionFee.toBigInt(),
|
|
235
|
-
|
|
400
|
+
await block.hash(),
|
|
236
401
|
block.number,
|
|
402
|
+
getEpochAtSlot(block.slot, EmptyL1RollupConstants),
|
|
237
403
|
);
|
|
238
404
|
}
|
|
239
405
|
}
|
|
@@ -242,41 +408,60 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
242
408
|
}
|
|
243
409
|
|
|
244
410
|
async getL2Tips(): Promise<L2Tips> {
|
|
245
|
-
const [latest, proven, finalized] = [
|
|
411
|
+
const [latest, proven, finalized, checkpointed] = [
|
|
246
412
|
await this.getBlockNumber(),
|
|
247
413
|
await this.getProvenBlockNumber(),
|
|
248
414
|
this.finalizedBlockNumber,
|
|
415
|
+
this.checkpointedBlockNumber,
|
|
249
416
|
] as const;
|
|
250
417
|
|
|
251
418
|
const latestBlock = this.l2Blocks[latest - 1];
|
|
252
419
|
const provenBlock = this.l2Blocks[proven - 1];
|
|
253
420
|
const finalizedBlock = this.l2Blocks[finalized - 1];
|
|
421
|
+
const checkpointedBlock = this.l2Blocks[checkpointed - 1];
|
|
254
422
|
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
423
|
+
const latestBlockId = {
|
|
424
|
+
number: BlockNumber(latest),
|
|
425
|
+
hash: (await latestBlock?.hash())?.toString(),
|
|
426
|
+
};
|
|
427
|
+
const provenBlockId = {
|
|
428
|
+
number: BlockNumber(proven),
|
|
429
|
+
hash: (await provenBlock?.hash())?.toString(),
|
|
430
|
+
};
|
|
431
|
+
const finalizedBlockId = {
|
|
432
|
+
number: BlockNumber(finalized),
|
|
433
|
+
hash: (await finalizedBlock?.hash())?.toString(),
|
|
434
|
+
};
|
|
435
|
+
const checkpointedBlockId = {
|
|
436
|
+
number: BlockNumber(checkpointed),
|
|
437
|
+
hash: (await checkpointedBlock?.hash())?.toString(),
|
|
438
|
+
};
|
|
439
|
+
|
|
440
|
+
const makeTipId = (blockId: typeof latestBlockId) => ({
|
|
441
|
+
block: blockId,
|
|
442
|
+
checkpoint: {
|
|
443
|
+
number: this.findCheckpointNumberForBlock(blockId.number) ?? CheckpointNumber(0),
|
|
444
|
+
hash: blockId.hash,
|
|
267
445
|
},
|
|
446
|
+
});
|
|
447
|
+
|
|
448
|
+
return {
|
|
449
|
+
proposed: latestBlockId,
|
|
450
|
+
checkpointed: makeTipId(checkpointedBlockId),
|
|
451
|
+
proven: makeTipId(provenBlockId),
|
|
452
|
+
finalized: makeTipId(finalizedBlockId),
|
|
268
453
|
};
|
|
269
454
|
}
|
|
270
455
|
|
|
271
|
-
|
|
456
|
+
getSyncedL2EpochNumber(): Promise<EpochNumber> {
|
|
272
457
|
throw new Error('Method not implemented.');
|
|
273
458
|
}
|
|
274
459
|
|
|
275
|
-
|
|
460
|
+
getSyncedL2SlotNumber(): Promise<SlotNumber> {
|
|
276
461
|
throw new Error('Method not implemented.');
|
|
277
462
|
}
|
|
278
463
|
|
|
279
|
-
isEpochComplete(_epochNumber:
|
|
464
|
+
isEpochComplete(_epochNumber: EpochNumber): Promise<boolean> {
|
|
280
465
|
throw new Error('Method not implemented.');
|
|
281
466
|
}
|
|
282
467
|
|
|
@@ -342,7 +527,41 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
342
527
|
return Promise.resolve(false);
|
|
343
528
|
}
|
|
344
529
|
|
|
345
|
-
getPendingChainValidationStatus(): Promise<
|
|
530
|
+
getPendingChainValidationStatus(): Promise<ValidateCheckpointResult> {
|
|
346
531
|
return Promise.resolve({ valid: true });
|
|
347
532
|
}
|
|
533
|
+
|
|
534
|
+
/** Returns checkpoints whose slot falls within the given epoch. */
|
|
535
|
+
private getCheckpointsInEpoch(epochNumber: EpochNumber): Checkpoint[] {
|
|
536
|
+
const epochDuration = DefaultL1ContractsConfig.aztecEpochDuration;
|
|
537
|
+
const [start, end] = getSlotRangeForEpoch(epochNumber, { epochDuration });
|
|
538
|
+
return this.checkpointList.filter(c => c.header.slotNumber >= start && c.header.slotNumber <= end);
|
|
539
|
+
}
|
|
540
|
+
|
|
541
|
+
/** Creates a mock L1PublishedData for a checkpoint. */
|
|
542
|
+
private mockL1DataForCheckpoint(checkpoint: Checkpoint): L1PublishedData {
|
|
543
|
+
return new L1PublishedData(BigInt(checkpoint.number), BigInt(checkpoint.number), Buffer32.random().toString());
|
|
544
|
+
}
|
|
545
|
+
|
|
546
|
+
/** Creates a CheckpointedL2Block from a block using stored checkpoint info. */
|
|
547
|
+
private toCheckpointedBlock(block: L2Block): CheckpointedL2Block {
|
|
548
|
+
const checkpoint = this.checkpointList.find(c => c.blocks.some(b => b.number === block.number));
|
|
549
|
+
const checkpointNumber = checkpoint?.number ?? block.checkpointNumber;
|
|
550
|
+
return new CheckpointedL2Block(
|
|
551
|
+
checkpointNumber,
|
|
552
|
+
block,
|
|
553
|
+
new L1PublishedData(
|
|
554
|
+
BigInt(block.number),
|
|
555
|
+
BigInt(block.number),
|
|
556
|
+
`0x${block.number.toString(16).padStart(64, '0')}`,
|
|
557
|
+
),
|
|
558
|
+
[],
|
|
559
|
+
);
|
|
560
|
+
}
|
|
561
|
+
|
|
562
|
+
/** Finds the checkpoint number for a block, or undefined if the block is not in any checkpoint. */
|
|
563
|
+
private findCheckpointNumberForBlock(blockNumber: BlockNumber): CheckpointNumber | undefined {
|
|
564
|
+
const checkpoint = this.checkpointList.find(c => c.blocks.some(b => b.number === blockNumber));
|
|
565
|
+
return checkpoint?.number;
|
|
566
|
+
}
|
|
348
567
|
}
|