@aztec/archiver 0.0.1-commit.96bb3f7 → 0.0.1-commit.96dac018d
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 +139 -0
- package/dest/archiver.d.ts.map +1 -0
- package/dest/archiver.js +699 -0
- package/dest/{archiver/config.d.ts → config.d.ts} +9 -1
- package/dest/config.d.ts.map +1 -0
- package/dest/{archiver/config.js → config.js} +9 -0
- package/dest/errors.d.ts +41 -0
- package/dest/errors.d.ts.map +1 -0
- package/dest/{archiver/errors.js → errors.js} +8 -0
- package/dest/factory.d.ts +9 -7
- package/dest/factory.d.ts.map +1 -1
- package/dest/factory.js +91 -11
- 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/{archiver/l1 → l1}/bin/retrieve-calldata.d.ts +1 -1
- package/dest/l1/bin/retrieve-calldata.d.ts.map +1 -0
- package/dest/{archiver/l1 → l1}/bin/retrieve-calldata.js +35 -32
- 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 +85 -0
- package/dest/l1/data_retrieval.d.ts.map +1 -0
- package/dest/{archiver/l1 → l1}/data_retrieval.js +43 -66
- package/dest/{archiver/l1 → l1}/debug_tx.d.ts +1 -1
- package/dest/l1/debug_tx.d.ts.map +1 -0
- package/dest/{archiver/l1 → l1}/spire_proposer.d.ts +5 -5
- package/dest/l1/spire_proposer.d.ts.map +1 -0
- package/dest/{archiver/l1 → l1}/spire_proposer.js +9 -17
- package/dest/{archiver/l1 → l1}/trace_tx.d.ts +1 -1
- package/dest/l1/trace_tx.d.ts.map +1 -0
- package/dest/l1/types.d.ts +12 -0
- package/dest/l1/types.d.ts.map +1 -0
- package/dest/{archiver/l1 → l1}/validate_trace.d.ts +6 -3
- package/dest/l1/validate_trace.d.ts.map +1 -0
- package/dest/{archiver/l1 → l1}/validate_trace.js +13 -9
- 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 +80 -0
- package/dest/modules/data_store_updater.d.ts.map +1 -0
- package/dest/modules/data_store_updater.js +323 -0
- package/dest/modules/instrumentation.d.ts +50 -0
- package/dest/modules/instrumentation.d.ts.map +1 -0
- package/dest/{archiver → modules}/instrumentation.js +36 -12
- package/dest/modules/l1_synchronizer.d.ts +71 -0
- package/dest/modules/l1_synchronizer.d.ts.map +1 -0
- package/dest/modules/l1_synchronizer.js +1117 -0
- package/dest/{archiver → modules}/validation.d.ts +1 -1
- package/dest/modules/validation.d.ts.map +1 -0
- package/dest/{archiver → modules}/validation.js +6 -0
- package/dest/store/block_store.d.ts +196 -0
- package/dest/store/block_store.d.ts.map +1 -0
- package/dest/{archiver/kv_archiver_store → store}/block_store.js +207 -60
- 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 +12 -8
- 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 +354 -0
- package/dest/store/kv_archiver_store.d.ts.map +1 -0
- package/dest/store/kv_archiver_store.js +464 -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 +54 -0
- package/dest/store/log_store.d.ts.map +1 -0
- package/dest/{archiver/kv_archiver_store → store}/log_store.js +146 -91
- package/dest/{archiver/kv_archiver_store → store}/message_store.d.ts +1 -1
- package/dest/store/message_store.d.ts.map +1 -0
- package/dest/{archiver/structs → structs}/data_retrieval.d.ts +1 -1
- 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}/published.d.ts +1 -1
- package/dest/structs/published.d.ts.map +1 -0
- package/dest/test/fake_l1_state.d.ts +195 -0
- package/dest/test/fake_l1_state.d.ts.map +1 -0
- package/dest/test/fake_l1_state.js +421 -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 +2 -2
- package/dest/test/mock_archiver.d.ts.map +1 -1
- package/dest/test/mock_archiver.js +3 -3
- package/dest/test/mock_l2_block_source.d.ts +35 -17
- package/dest/test/mock_l2_block_source.d.ts.map +1 -1
- package/dest/test/mock_l2_block_source.js +177 -74
- package/dest/test/mock_structs.d.ts +78 -3
- package/dest/test/mock_structs.d.ts.map +1 -1
- package/dest/test/mock_structs.js +140 -7
- 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 +16 -17
- package/src/archiver.ts +443 -0
- package/src/{archiver/config.ts → config.ts} +11 -0
- package/src/{archiver/errors.ts → errors.ts} +12 -0
- package/src/factory.ts +139 -11
- package/src/index.ts +11 -3
- package/src/interfaces.ts +9 -0
- package/src/l1/README.md +55 -0
- package/src/{archiver/l1 → l1}/bin/retrieve-calldata.ts +45 -33
- package/src/l1/calldata_retriever.ts +511 -0
- package/src/{archiver/l1 → l1}/data_retrieval.ts +61 -88
- package/src/{archiver/l1 → l1}/spire_proposer.ts +7 -15
- package/src/{archiver/l1 → l1}/validate_trace.ts +24 -6
- package/src/modules/data_source_base.ts +328 -0
- package/src/modules/data_store_updater.ts +448 -0
- package/src/{archiver → modules}/instrumentation.ts +46 -14
- package/src/modules/l1_synchronizer.ts +933 -0
- package/src/{archiver → modules}/validation.ts +5 -0
- package/src/{archiver/kv_archiver_store → store}/block_store.ts +258 -93
- package/src/{archiver/kv_archiver_store → store}/contract_class_store.ts +12 -8
- package/src/{archiver/kv_archiver_store → store}/contract_instance_store.ts +1 -1
- package/src/{archiver/kv_archiver_store → store}/kv_archiver_store.ts +267 -38
- package/src/store/l2_tips_cache.ts +89 -0
- package/src/{archiver/kv_archiver_store → store}/log_store.ts +242 -121
- package/src/test/fake_l1_state.ts +657 -0
- package/src/test/index.ts +4 -0
- package/src/test/mock_archiver.ts +4 -3
- package/src/test/mock_l2_block_source.ts +218 -90
- package/src/test/mock_structs.ts +269 -8
- package/src/test/noop_l1_archiver.ts +109 -0
- package/dest/archiver/archiver.d.ts +0 -307
- package/dest/archiver/archiver.d.ts.map +0 -1
- package/dest/archiver/archiver.js +0 -2102
- package/dest/archiver/archiver_store.d.ts +0 -315
- 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 -2770
- package/dest/archiver/config.d.ts.map +0 -1
- package/dest/archiver/errors.d.ts +0 -36
- package/dest/archiver/errors.d.ts.map +0 -1
- 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 -37
- package/dest/archiver/instrumentation.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/block_store.d.ts +0 -164
- package/dest/archiver/kv_archiver_store/block_store.d.ts.map +0 -1
- 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 -159
- 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 -316
- package/dest/archiver/kv_archiver_store/log_store.d.ts +0 -45
- package/dest/archiver/kv_archiver_store/log_store.d.ts.map +0 -1
- package/dest/archiver/kv_archiver_store/message_store.d.ts.map +0 -1
- package/dest/archiver/l1/bin/retrieve-calldata.d.ts.map +0 -1
- package/dest/archiver/l1/calldata_retriever.d.ts +0 -112
- package/dest/archiver/l1/calldata_retriever.d.ts.map +0 -1
- package/dest/archiver/l1/calldata_retriever.js +0 -471
- package/dest/archiver/l1/data_retrieval.d.ts +0 -90
- package/dest/archiver/l1/data_retrieval.d.ts.map +0 -1
- package/dest/archiver/l1/debug_tx.d.ts.map +0 -1
- package/dest/archiver/l1/spire_proposer.d.ts.map +0 -1
- package/dest/archiver/l1/trace_tx.d.ts.map +0 -1
- package/dest/archiver/l1/types.d.ts +0 -12
- package/dest/archiver/l1/types.d.ts.map +0 -1
- package/dest/archiver/l1/validate_trace.d.ts.map +0 -1
- 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.map +0 -1
- 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 -2265
- package/src/archiver/archiver_store.ts +0 -380
- package/src/archiver/archiver_store_test_suite.ts +0 -2842
- package/src/archiver/index.ts +0 -6
- package/src/archiver/l1/README.md +0 -98
- package/src/archiver/l1/calldata_retriever.ts +0 -641
- package/src/rpc/index.ts +0 -16
- /package/dest/{archiver/l1 → l1}/debug_tx.js +0 -0
- /package/dest/{archiver/l1 → l1}/trace_tx.js +0 -0
- /package/dest/{archiver/l1 → l1}/types.js +0 -0
- /package/dest/{archiver/kv_archiver_store → store}/message_store.js +0 -0
- /package/dest/{archiver/structs → structs}/data_retrieval.js +0 -0
- /package/dest/{archiver/structs → structs}/inbox_message.js +0 -0
- /package/dest/{archiver/structs → structs}/published.js +0 -0
- /package/src/{archiver/l1 → l1}/debug_tx.ts +0 -0
- /package/src/{archiver/l1 → l1}/trace_tx.ts +0 -0
- /package/src/{archiver/l1 → l1}/types.ts +0 -0
- /package/src/{archiver/kv_archiver_store → store}/message_store.ts +0 -0
- /package/src/{archiver/structs → structs}/data_retrieval.ts +0 -0
- /package/src/{archiver/structs → structs}/inbox_message.ts +0 -0
- /package/src/{archiver/structs → structs}/published.ts +0 -0
|
@@ -8,19 +8,20 @@ import { createLogger } from '@aztec/foundation/log';
|
|
|
8
8
|
import type { FunctionSelector } from '@aztec/stdlib/abi';
|
|
9
9
|
import type { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
10
10
|
import {
|
|
11
|
+
type BlockData,
|
|
12
|
+
BlockHash,
|
|
11
13
|
CheckpointedL2Block,
|
|
12
14
|
L2Block,
|
|
13
|
-
L2BlockHash,
|
|
14
|
-
L2BlockNew,
|
|
15
15
|
type L2BlockSource,
|
|
16
16
|
type L2Tips,
|
|
17
|
-
PublishedL2Block,
|
|
18
17
|
type ValidateCheckpointResult,
|
|
19
18
|
} from '@aztec/stdlib/block';
|
|
20
|
-
import { type
|
|
19
|
+
import { Checkpoint, type CheckpointData, L1PublishedData, PublishedCheckpoint } from '@aztec/stdlib/checkpoint';
|
|
21
20
|
import type { ContractClassPublic, ContractDataSource, ContractInstanceWithAddress } from '@aztec/stdlib/contract';
|
|
22
21
|
import { EmptyL1RollupConstants, type L1RollupConstants, getSlotRangeForEpoch } from '@aztec/stdlib/epoch-helpers';
|
|
23
|
-
import {
|
|
22
|
+
import { computeCheckpointOutHash } from '@aztec/stdlib/messaging';
|
|
23
|
+
import { CheckpointHeader } from '@aztec/stdlib/rollup';
|
|
24
|
+
import { type BlockHeader, TxExecutionResult, TxHash, TxReceipt, TxStatus } from '@aztec/stdlib/tx';
|
|
24
25
|
import type { UInt64 } from '@aztec/stdlib/types';
|
|
25
26
|
|
|
26
27
|
/**
|
|
@@ -28,6 +29,7 @@ import type { UInt64 } from '@aztec/stdlib/types';
|
|
|
28
29
|
*/
|
|
29
30
|
export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
30
31
|
protected l2Blocks: L2Block[] = [];
|
|
32
|
+
protected checkpointList: Checkpoint[] = [];
|
|
31
33
|
|
|
32
34
|
private provenBlockNumber: number = 0;
|
|
33
35
|
private finalizedBlockNumber: number = 0;
|
|
@@ -35,23 +37,49 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
35
37
|
|
|
36
38
|
private log = createLogger('archiver:mock_l2_block_source');
|
|
37
39
|
|
|
40
|
+
/** Creates blocks grouped into single-block checkpoints. */
|
|
38
41
|
public async createBlocks(numBlocks: number) {
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
42
|
+
await this.createCheckpoints(numBlocks, 1);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
/** Creates checkpoints, each containing `blocksPerCheckpoint` blocks. */
|
|
46
|
+
public async createCheckpoints(numCheckpoints: number, blocksPerCheckpoint: number = 1) {
|
|
47
|
+
for (let c = 0; c < numCheckpoints; c++) {
|
|
48
|
+
const checkpointNum = CheckpointNumber(this.checkpointList.length + 1);
|
|
49
|
+
const startBlockNum = this.l2Blocks.length + 1;
|
|
50
|
+
const slotNumber = SlotNumber(Number(checkpointNum));
|
|
51
|
+
const checkpoint = await Checkpoint.random(checkpointNum, {
|
|
52
|
+
numBlocks: blocksPerCheckpoint,
|
|
53
|
+
startBlockNumber: startBlockNum,
|
|
54
|
+
slotNumber,
|
|
55
|
+
checkpointNumber: checkpointNum,
|
|
56
|
+
});
|
|
57
|
+
this.checkpointList.push(checkpoint);
|
|
58
|
+
this.l2Blocks.push(...checkpoint.blocks);
|
|
43
59
|
}
|
|
44
60
|
|
|
45
|
-
this.log.verbose(
|
|
61
|
+
this.log.verbose(
|
|
62
|
+
`Created ${numCheckpoints} checkpoints with ${blocksPerCheckpoint} blocks each in the mock L2 block source`,
|
|
63
|
+
);
|
|
46
64
|
}
|
|
47
65
|
|
|
48
|
-
public
|
|
66
|
+
public addProposedBlocks(blocks: L2Block[]) {
|
|
49
67
|
this.l2Blocks.push(...blocks);
|
|
50
|
-
this.log.verbose(`Added ${blocks.length} blocks to the mock L2 block source`);
|
|
68
|
+
this.log.verbose(`Added ${blocks.length} proposed blocks to the mock L2 block source`);
|
|
51
69
|
}
|
|
52
70
|
|
|
53
71
|
public removeBlocks(numBlocks: number) {
|
|
54
72
|
this.l2Blocks = this.l2Blocks.slice(0, -numBlocks);
|
|
73
|
+
const maxBlockNum = this.l2Blocks.length;
|
|
74
|
+
// Remove any checkpoint whose last block is beyond the remaining blocks.
|
|
75
|
+
this.checkpointList = this.checkpointList.filter(c => {
|
|
76
|
+
const lastBlockNum = c.blocks[0].number + c.blocks.length - 1;
|
|
77
|
+
return lastBlockNum <= maxBlockNum;
|
|
78
|
+
});
|
|
79
|
+
// Keep tip numbers consistent with remaining blocks.
|
|
80
|
+
this.checkpointedBlockNumber = Math.min(this.checkpointedBlockNumber, maxBlockNum);
|
|
81
|
+
this.provenBlockNumber = Math.min(this.provenBlockNumber, maxBlockNum);
|
|
82
|
+
this.finalizedBlockNumber = Math.min(this.finalizedBlockNumber, maxBlockNum);
|
|
55
83
|
this.log.verbose(`Removed ${numBlocks} blocks from the mock L2 block source`);
|
|
56
84
|
}
|
|
57
85
|
|
|
@@ -67,7 +95,33 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
67
95
|
}
|
|
68
96
|
|
|
69
97
|
public setCheckpointedBlockNumber(checkpointedBlockNumber: number) {
|
|
98
|
+
const prevCheckpointed = this.checkpointedBlockNumber;
|
|
70
99
|
this.checkpointedBlockNumber = checkpointedBlockNumber;
|
|
100
|
+
// Auto-create single-block checkpoints for newly checkpointed blocks that don't have one yet.
|
|
101
|
+
// This handles blocks added via addProposedBlocks that are now being marked as checkpointed.
|
|
102
|
+
const newCheckpoints: Checkpoint[] = [];
|
|
103
|
+
for (let blockNum = prevCheckpointed + 1; blockNum <= checkpointedBlockNumber; blockNum++) {
|
|
104
|
+
const block = this.l2Blocks[blockNum - 1];
|
|
105
|
+
if (!block) {
|
|
106
|
+
continue;
|
|
107
|
+
}
|
|
108
|
+
if (this.checkpointList.some(c => c.blocks.some(b => b.number === block.number))) {
|
|
109
|
+
continue;
|
|
110
|
+
}
|
|
111
|
+
const checkpointNum = CheckpointNumber(this.checkpointList.length + newCheckpoints.length + 1);
|
|
112
|
+
const checkpoint = new Checkpoint(
|
|
113
|
+
block.archive,
|
|
114
|
+
CheckpointHeader.random({ slotNumber: block.header.globalVariables.slotNumber }),
|
|
115
|
+
[block],
|
|
116
|
+
checkpointNum,
|
|
117
|
+
);
|
|
118
|
+
newCheckpoints.push(checkpoint);
|
|
119
|
+
}
|
|
120
|
+
// Insert new checkpoints in order by number.
|
|
121
|
+
if (newCheckpoints.length > 0) {
|
|
122
|
+
this.checkpointList.push(...newCheckpoints);
|
|
123
|
+
this.checkpointList.sort((a, b) => a.number - b.number);
|
|
124
|
+
}
|
|
71
125
|
}
|
|
72
126
|
|
|
73
127
|
/**
|
|
@@ -98,6 +152,14 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
98
152
|
return Promise.resolve(BlockNumber(this.provenBlockNumber));
|
|
99
153
|
}
|
|
100
154
|
|
|
155
|
+
public getCheckpointedL2BlockNumber() {
|
|
156
|
+
return Promise.resolve(BlockNumber(this.checkpointedBlockNumber));
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
public getFinalizedL2BlockNumber() {
|
|
160
|
+
return Promise.resolve(BlockNumber(this.finalizedBlockNumber));
|
|
161
|
+
}
|
|
162
|
+
|
|
101
163
|
public getCheckpointedBlock(number: BlockNumber): Promise<CheckpointedL2Block | undefined> {
|
|
102
164
|
if (number > this.checkpointedBlockNumber) {
|
|
103
165
|
return Promise.resolve(undefined);
|
|
@@ -106,20 +168,10 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
106
168
|
if (!block) {
|
|
107
169
|
return Promise.resolve(undefined);
|
|
108
170
|
}
|
|
109
|
-
|
|
110
|
-
CheckpointNumber(number),
|
|
111
|
-
block.toL2Block(),
|
|
112
|
-
new L1PublishedData(BigInt(number), BigInt(number), `0x${number.toString(16).padStart(64, '0')}`),
|
|
113
|
-
[],
|
|
114
|
-
);
|
|
115
|
-
return Promise.resolve(checkpointedBlock);
|
|
171
|
+
return Promise.resolve(this.toCheckpointedBlock(block));
|
|
116
172
|
}
|
|
117
173
|
|
|
118
|
-
public async getCheckpointedBlocks(
|
|
119
|
-
from: BlockNumber,
|
|
120
|
-
limit: number,
|
|
121
|
-
_proven?: boolean,
|
|
122
|
-
): Promise<CheckpointedL2Block[]> {
|
|
174
|
+
public async getCheckpointedBlocks(from: BlockNumber, limit: number): Promise<CheckpointedL2Block[]> {
|
|
123
175
|
const result: CheckpointedL2Block[] = [];
|
|
124
176
|
for (let i = 0; i < limit; i++) {
|
|
125
177
|
const blockNum = from + i;
|
|
@@ -139,8 +191,9 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
139
191
|
* @param number - The block number to return (inclusive).
|
|
140
192
|
* @returns The requested L2 block.
|
|
141
193
|
*/
|
|
142
|
-
public getBlock(number: number) {
|
|
143
|
-
|
|
194
|
+
public getBlock(number: number): Promise<L2Block | undefined> {
|
|
195
|
+
const block = this.l2Blocks[number - 1];
|
|
196
|
+
return Promise.resolve(block);
|
|
144
197
|
}
|
|
145
198
|
|
|
146
199
|
/**
|
|
@@ -148,9 +201,9 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
148
201
|
* @param number - The block number to return.
|
|
149
202
|
* @returns The requested L2 block.
|
|
150
203
|
*/
|
|
151
|
-
public
|
|
204
|
+
public getL2Block(number: BlockNumber): Promise<L2Block | undefined> {
|
|
152
205
|
const block = this.l2Blocks[number - 1];
|
|
153
|
-
return Promise.resolve(block
|
|
206
|
+
return Promise.resolve(block);
|
|
154
207
|
}
|
|
155
208
|
|
|
156
209
|
/**
|
|
@@ -159,73 +212,60 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
159
212
|
* @param limit - The maximum number of blocks to return.
|
|
160
213
|
* @returns The requested mocked L2 blocks.
|
|
161
214
|
*/
|
|
162
|
-
public getBlocks(from: number, limit: number
|
|
163
|
-
return Promise.resolve(
|
|
164
|
-
this.l2Blocks
|
|
165
|
-
.slice(from - 1, from - 1 + limit)
|
|
166
|
-
.filter(b => !proven || this.provenBlockNumber === undefined || b.number <= this.provenBlockNumber),
|
|
167
|
-
);
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
public async getPublishedCheckpoints(from: CheckpointNumber, limit: number) {
|
|
171
|
-
// TODO: Implement this properly. This only works when we have one block per checkpoint.
|
|
172
|
-
return (await this.getPublishedBlocks(from, limit)).map(block => block.toPublishedCheckpoint());
|
|
215
|
+
public getBlocks(from: number, limit: number): Promise<L2Block[]> {
|
|
216
|
+
return Promise.resolve(this.l2Blocks.slice(from - 1, from - 1 + limit));
|
|
173
217
|
}
|
|
174
218
|
|
|
175
|
-
public
|
|
176
|
-
|
|
177
|
-
return
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
public async getPublishedBlocks(from: number, limit: number, proven?: boolean) {
|
|
181
|
-
const blocks = await this.getBlocks(from, limit, proven);
|
|
182
|
-
return blocks.map(block =>
|
|
183
|
-
PublishedL2Block.fromFields({
|
|
184
|
-
block,
|
|
185
|
-
l1: new L1PublishedData(BigInt(block.number), BigInt(block.number), Buffer32.random().toString()),
|
|
186
|
-
attestations: [],
|
|
187
|
-
}),
|
|
219
|
+
public getCheckpoints(from: CheckpointNumber, limit: number) {
|
|
220
|
+
const checkpoints = this.checkpointList.slice(from - 1, from - 1 + limit);
|
|
221
|
+
return Promise.resolve(
|
|
222
|
+
checkpoints.map(checkpoint => new PublishedCheckpoint(checkpoint, this.mockL1DataForCheckpoint(checkpoint), [])),
|
|
188
223
|
);
|
|
189
224
|
}
|
|
190
225
|
|
|
191
|
-
|
|
192
|
-
const
|
|
193
|
-
return
|
|
226
|
+
public getCheckpointByArchive(archive: Fr): Promise<Checkpoint | undefined> {
|
|
227
|
+
const checkpoint = this.checkpointList.find(c => c.archive.root.equals(archive));
|
|
228
|
+
return Promise.resolve(checkpoint);
|
|
194
229
|
}
|
|
195
230
|
|
|
196
|
-
public async
|
|
231
|
+
public async getCheckpointedBlockByHash(blockHash: BlockHash): Promise<CheckpointedL2Block | undefined> {
|
|
197
232
|
for (const block of this.l2Blocks) {
|
|
198
233
|
const hash = await block.hash();
|
|
199
234
|
if (hash.equals(blockHash)) {
|
|
200
|
-
return
|
|
201
|
-
block,
|
|
202
|
-
l1: new L1PublishedData(BigInt(block.number), BigInt(block.number), Buffer32.random().toString()),
|
|
203
|
-
attestations: [],
|
|
204
|
-
});
|
|
235
|
+
return this.toCheckpointedBlock(block);
|
|
205
236
|
}
|
|
206
237
|
}
|
|
207
238
|
return undefined;
|
|
208
239
|
}
|
|
209
240
|
|
|
210
|
-
public
|
|
241
|
+
public getCheckpointedBlockByArchive(archive: Fr): Promise<CheckpointedL2Block | undefined> {
|
|
211
242
|
const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
|
|
212
243
|
if (!block) {
|
|
213
244
|
return Promise.resolve(undefined);
|
|
214
245
|
}
|
|
215
|
-
return Promise.resolve(
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
246
|
+
return Promise.resolve(this.toCheckpointedBlock(block));
|
|
247
|
+
}
|
|
248
|
+
|
|
249
|
+
public async getL2BlockByHash(blockHash: BlockHash): Promise<L2Block | undefined> {
|
|
250
|
+
for (const block of this.l2Blocks) {
|
|
251
|
+
const hash = await block.hash();
|
|
252
|
+
if (hash.equals(blockHash)) {
|
|
253
|
+
return block;
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
return undefined;
|
|
257
|
+
}
|
|
258
|
+
|
|
259
|
+
public getL2BlockByArchive(archive: Fr): Promise<L2Block | undefined> {
|
|
260
|
+
const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
|
|
261
|
+
return Promise.resolve(block);
|
|
222
262
|
}
|
|
223
263
|
|
|
224
|
-
public async getBlockHeaderByHash(blockHash:
|
|
264
|
+
public async getBlockHeaderByHash(blockHash: BlockHash): Promise<BlockHeader | undefined> {
|
|
225
265
|
for (const block of this.l2Blocks) {
|
|
226
266
|
const hash = await block.hash();
|
|
227
267
|
if (hash.equals(blockHash)) {
|
|
228
|
-
return block.
|
|
268
|
+
return block.header;
|
|
229
269
|
}
|
|
230
270
|
}
|
|
231
271
|
return undefined;
|
|
@@ -233,31 +273,80 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
233
273
|
|
|
234
274
|
public getBlockHeaderByArchive(archive: Fr): Promise<BlockHeader | undefined> {
|
|
235
275
|
const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
|
|
236
|
-
return Promise.resolve(block?.
|
|
276
|
+
return Promise.resolve(block?.header);
|
|
277
|
+
}
|
|
278
|
+
|
|
279
|
+
public async getBlockData(number: BlockNumber): Promise<BlockData | undefined> {
|
|
280
|
+
const block = this.l2Blocks[number - 1];
|
|
281
|
+
if (!block) {
|
|
282
|
+
return undefined;
|
|
283
|
+
}
|
|
284
|
+
return {
|
|
285
|
+
header: block.header,
|
|
286
|
+
archive: block.archive,
|
|
287
|
+
blockHash: await block.hash(),
|
|
288
|
+
checkpointNumber: block.checkpointNumber,
|
|
289
|
+
indexWithinCheckpoint: block.indexWithinCheckpoint,
|
|
290
|
+
};
|
|
291
|
+
}
|
|
292
|
+
|
|
293
|
+
public async getBlockDataByArchive(archive: Fr): Promise<BlockData | undefined> {
|
|
294
|
+
const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
|
|
295
|
+
if (!block) {
|
|
296
|
+
return undefined;
|
|
297
|
+
}
|
|
298
|
+
return {
|
|
299
|
+
header: block.header,
|
|
300
|
+
archive: block.archive,
|
|
301
|
+
blockHash: await block.hash(),
|
|
302
|
+
checkpointNumber: block.checkpointNumber,
|
|
303
|
+
indexWithinCheckpoint: block.indexWithinCheckpoint,
|
|
304
|
+
};
|
|
237
305
|
}
|
|
238
306
|
|
|
239
307
|
getBlockHeader(number: number | 'latest'): Promise<BlockHeader | undefined> {
|
|
240
|
-
return Promise.resolve(this.l2Blocks.at(typeof number === 'number' ? number - 1 : -1)?.
|
|
308
|
+
return Promise.resolve(this.l2Blocks.at(typeof number === 'number' ? number - 1 : -1)?.header);
|
|
241
309
|
}
|
|
242
310
|
|
|
243
311
|
getCheckpointsForEpoch(epochNumber: EpochNumber): Promise<Checkpoint[]> {
|
|
244
|
-
|
|
245
|
-
return this.getBlocksForEpoch(epochNumber).then(blocks => blocks.map(b => b.toCheckpoint()));
|
|
312
|
+
return Promise.resolve(this.getCheckpointsInEpoch(epochNumber));
|
|
246
313
|
}
|
|
247
314
|
|
|
248
|
-
|
|
249
|
-
const
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
315
|
+
getCheckpointsDataForEpoch(epochNumber: EpochNumber): Promise<CheckpointData[]> {
|
|
316
|
+
const checkpoints = this.getCheckpointsInEpoch(epochNumber);
|
|
317
|
+
return Promise.resolve(
|
|
318
|
+
checkpoints.map(
|
|
319
|
+
(checkpoint): CheckpointData => ({
|
|
320
|
+
checkpointNumber: checkpoint.number,
|
|
321
|
+
header: checkpoint.header,
|
|
322
|
+
archive: checkpoint.archive,
|
|
323
|
+
checkpointOutHash: computeCheckpointOutHash(
|
|
324
|
+
checkpoint.blocks.map(b => b.body.txEffects.map(tx => tx.l2ToL1Msgs)),
|
|
325
|
+
),
|
|
326
|
+
startBlock: checkpoint.blocks[0].number,
|
|
327
|
+
blockCount: checkpoint.blocks.length,
|
|
328
|
+
attestations: [],
|
|
329
|
+
l1: this.mockL1DataForCheckpoint(checkpoint),
|
|
330
|
+
}),
|
|
331
|
+
),
|
|
332
|
+
);
|
|
333
|
+
}
|
|
334
|
+
|
|
335
|
+
getCheckpointedBlocksForEpoch(epochNumber: EpochNumber): Promise<CheckpointedL2Block[]> {
|
|
336
|
+
const checkpoints = this.getCheckpointsInEpoch(epochNumber);
|
|
337
|
+
return Promise.resolve(
|
|
338
|
+
checkpoints.flatMap(checkpoint => checkpoint.blocks.map(block => this.toCheckpointedBlock(block))),
|
|
339
|
+
);
|
|
340
|
+
}
|
|
341
|
+
|
|
342
|
+
getBlocksForSlot(slotNumber: SlotNumber): Promise<L2Block[]> {
|
|
343
|
+
const blocks = this.l2Blocks.filter(b => b.header.globalVariables.slotNumber === slotNumber);
|
|
255
344
|
return Promise.resolve(blocks);
|
|
256
345
|
}
|
|
257
346
|
|
|
258
|
-
async
|
|
259
|
-
const
|
|
260
|
-
return
|
|
347
|
+
async getCheckpointedBlockHeadersForEpoch(epochNumber: EpochNumber): Promise<BlockHeader[]> {
|
|
348
|
+
const checkpointedBlocks = await this.getCheckpointedBlocksForEpoch(epochNumber);
|
|
349
|
+
return checkpointedBlocks.map(b => b.block.header);
|
|
261
350
|
}
|
|
262
351
|
|
|
263
352
|
/**
|
|
@@ -276,7 +365,7 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
276
365
|
return {
|
|
277
366
|
data: txEffect,
|
|
278
367
|
l2BlockNumber: block.number,
|
|
279
|
-
l2BlockHash:
|
|
368
|
+
l2BlockHash: await block.hash(),
|
|
280
369
|
txIndexInBlock: block.body.txEffects.indexOf(txEffect),
|
|
281
370
|
};
|
|
282
371
|
}
|
|
@@ -290,12 +379,14 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
290
379
|
for (const block of this.l2Blocks) {
|
|
291
380
|
for (const txEffect of block.body.txEffects) {
|
|
292
381
|
if (txEffect.txHash.equals(txHash)) {
|
|
382
|
+
// In mock, assume all txs are checkpointed with successful execution
|
|
293
383
|
return new TxReceipt(
|
|
294
384
|
txHash,
|
|
295
|
-
TxStatus.
|
|
296
|
-
|
|
385
|
+
TxStatus.CHECKPOINTED,
|
|
386
|
+
TxExecutionResult.SUCCESS,
|
|
387
|
+
undefined,
|
|
297
388
|
txEffect.transactionFee.toBigInt(),
|
|
298
|
-
|
|
389
|
+
await block.hash(),
|
|
299
390
|
block.number,
|
|
300
391
|
);
|
|
301
392
|
}
|
|
@@ -336,7 +427,10 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
336
427
|
|
|
337
428
|
const makeTipId = (blockId: typeof latestBlockId) => ({
|
|
338
429
|
block: blockId,
|
|
339
|
-
checkpoint: {
|
|
430
|
+
checkpoint: {
|
|
431
|
+
number: this.findCheckpointNumberForBlock(blockId.number) ?? CheckpointNumber(0),
|
|
432
|
+
hash: blockId.hash,
|
|
433
|
+
},
|
|
340
434
|
});
|
|
341
435
|
|
|
342
436
|
return {
|
|
@@ -424,4 +518,38 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
|
|
|
424
518
|
getPendingChainValidationStatus(): Promise<ValidateCheckpointResult> {
|
|
425
519
|
return Promise.resolve({ valid: true });
|
|
426
520
|
}
|
|
521
|
+
|
|
522
|
+
/** Returns checkpoints whose slot falls within the given epoch. */
|
|
523
|
+
private getCheckpointsInEpoch(epochNumber: EpochNumber): Checkpoint[] {
|
|
524
|
+
const epochDuration = DefaultL1ContractsConfig.aztecEpochDuration;
|
|
525
|
+
const [start, end] = getSlotRangeForEpoch(epochNumber, { epochDuration });
|
|
526
|
+
return this.checkpointList.filter(c => c.header.slotNumber >= start && c.header.slotNumber <= end);
|
|
527
|
+
}
|
|
528
|
+
|
|
529
|
+
/** Creates a mock L1PublishedData for a checkpoint. */
|
|
530
|
+
private mockL1DataForCheckpoint(checkpoint: Checkpoint): L1PublishedData {
|
|
531
|
+
return new L1PublishedData(BigInt(checkpoint.number), BigInt(checkpoint.number), Buffer32.random().toString());
|
|
532
|
+
}
|
|
533
|
+
|
|
534
|
+
/** Creates a CheckpointedL2Block from a block using stored checkpoint info. */
|
|
535
|
+
private toCheckpointedBlock(block: L2Block): CheckpointedL2Block {
|
|
536
|
+
const checkpoint = this.checkpointList.find(c => c.blocks.some(b => b.number === block.number));
|
|
537
|
+
const checkpointNumber = checkpoint?.number ?? block.checkpointNumber;
|
|
538
|
+
return new CheckpointedL2Block(
|
|
539
|
+
checkpointNumber,
|
|
540
|
+
block,
|
|
541
|
+
new L1PublishedData(
|
|
542
|
+
BigInt(block.number),
|
|
543
|
+
BigInt(block.number),
|
|
544
|
+
`0x${block.number.toString(16).padStart(64, '0')}`,
|
|
545
|
+
),
|
|
546
|
+
[],
|
|
547
|
+
);
|
|
548
|
+
}
|
|
549
|
+
|
|
550
|
+
/** Finds the checkpoint number for a block, or undefined if the block is not in any checkpoint. */
|
|
551
|
+
private findCheckpointNumberForBlock(blockNumber: BlockNumber): CheckpointNumber | undefined {
|
|
552
|
+
const checkpoint = this.checkpointList.find(c => c.blocks.some(b => b.number === blockNumber));
|
|
553
|
+
return checkpoint?.number;
|
|
554
|
+
}
|
|
427
555
|
}
|