@aztec/archiver 0.0.1-commit.b655e406 → 0.0.1-commit.c0b82b2

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.
Files changed (214) hide show
  1. package/README.md +156 -22
  2. package/dest/archiver.d.ts +139 -0
  3. package/dest/archiver.d.ts.map +1 -0
  4. package/dest/archiver.js +699 -0
  5. package/dest/config.d.ts +30 -0
  6. package/dest/config.d.ts.map +1 -0
  7. package/dest/{archiver/config.js → config.js} +26 -5
  8. package/dest/errors.d.ts +41 -0
  9. package/dest/errors.d.ts.map +1 -0
  10. package/dest/errors.js +62 -0
  11. package/dest/factory.d.ts +9 -7
  12. package/dest/factory.d.ts.map +1 -1
  13. package/dest/factory.js +94 -13
  14. package/dest/index.d.ts +11 -4
  15. package/dest/index.d.ts.map +1 -1
  16. package/dest/index.js +9 -3
  17. package/dest/interfaces.d.ts +9 -0
  18. package/dest/interfaces.d.ts.map +1 -0
  19. package/dest/interfaces.js +3 -0
  20. package/dest/l1/bin/retrieve-calldata.d.ts +3 -0
  21. package/dest/l1/bin/retrieve-calldata.d.ts.map +1 -0
  22. package/dest/l1/bin/retrieve-calldata.js +152 -0
  23. package/dest/l1/calldata_retriever.d.ts +135 -0
  24. package/dest/l1/calldata_retriever.d.ts.map +1 -0
  25. package/dest/l1/calldata_retriever.js +402 -0
  26. package/dest/l1/data_retrieval.d.ts +88 -0
  27. package/dest/l1/data_retrieval.d.ts.map +1 -0
  28. package/dest/l1/data_retrieval.js +314 -0
  29. package/dest/l1/debug_tx.d.ts +19 -0
  30. package/dest/l1/debug_tx.d.ts.map +1 -0
  31. package/dest/l1/debug_tx.js +73 -0
  32. package/dest/l1/spire_proposer.d.ts +70 -0
  33. package/dest/l1/spire_proposer.d.ts.map +1 -0
  34. package/dest/l1/spire_proposer.js +149 -0
  35. package/dest/l1/trace_tx.d.ts +97 -0
  36. package/dest/l1/trace_tx.d.ts.map +1 -0
  37. package/dest/l1/trace_tx.js +91 -0
  38. package/dest/l1/types.d.ts +12 -0
  39. package/dest/l1/types.d.ts.map +1 -0
  40. package/dest/l1/types.js +3 -0
  41. package/dest/l1/validate_trace.d.ts +32 -0
  42. package/dest/l1/validate_trace.d.ts.map +1 -0
  43. package/dest/l1/validate_trace.js +154 -0
  44. package/dest/modules/data_source_base.d.ts +89 -0
  45. package/dest/modules/data_source_base.d.ts.map +1 -0
  46. package/dest/modules/data_source_base.js +216 -0
  47. package/dest/modules/data_store_updater.d.ts +80 -0
  48. package/dest/modules/data_store_updater.d.ts.map +1 -0
  49. package/dest/modules/data_store_updater.js +323 -0
  50. package/dest/modules/instrumentation.d.ts +50 -0
  51. package/dest/modules/instrumentation.d.ts.map +1 -0
  52. package/dest/{archiver → modules}/instrumentation.js +49 -62
  53. package/dest/modules/l1_synchronizer.d.ts +71 -0
  54. package/dest/modules/l1_synchronizer.d.ts.map +1 -0
  55. package/dest/modules/l1_synchronizer.js +1117 -0
  56. package/dest/modules/validation.d.ts +17 -0
  57. package/dest/modules/validation.d.ts.map +1 -0
  58. package/dest/{archiver → modules}/validation.js +35 -21
  59. package/dest/store/block_store.d.ts +196 -0
  60. package/dest/store/block_store.d.ts.map +1 -0
  61. package/dest/store/block_store.js +773 -0
  62. package/dest/store/contract_class_store.d.ts +18 -0
  63. package/dest/store/contract_class_store.d.ts.map +1 -0
  64. package/dest/{archiver/kv_archiver_store → store}/contract_class_store.js +13 -9
  65. package/dest/store/contract_instance_store.d.ts +24 -0
  66. package/dest/store/contract_instance_store.d.ts.map +1 -0
  67. package/dest/{archiver/kv_archiver_store → store}/contract_instance_store.js +1 -1
  68. package/dest/store/kv_archiver_store.d.ts +354 -0
  69. package/dest/store/kv_archiver_store.d.ts.map +1 -0
  70. package/dest/store/kv_archiver_store.js +464 -0
  71. package/dest/store/l2_tips_cache.d.ts +19 -0
  72. package/dest/store/l2_tips_cache.d.ts.map +1 -0
  73. package/dest/store/l2_tips_cache.js +89 -0
  74. package/dest/store/log_store.d.ts +54 -0
  75. package/dest/store/log_store.d.ts.map +1 -0
  76. package/dest/store/log_store.js +456 -0
  77. package/dest/store/message_store.d.ts +40 -0
  78. package/dest/store/message_store.d.ts.map +1 -0
  79. package/dest/{archiver/kv_archiver_store → store}/message_store.js +15 -14
  80. package/dest/structs/data_retrieval.d.ts +27 -0
  81. package/dest/structs/data_retrieval.d.ts.map +1 -0
  82. package/dest/structs/inbox_message.d.ts +15 -0
  83. package/dest/structs/inbox_message.d.ts.map +1 -0
  84. package/dest/{archiver/structs → structs}/inbox_message.js +6 -5
  85. package/dest/structs/published.d.ts +2 -0
  86. package/dest/structs/published.d.ts.map +1 -0
  87. package/dest/test/fake_l1_state.d.ts +195 -0
  88. package/dest/test/fake_l1_state.d.ts.map +1 -0
  89. package/dest/test/fake_l1_state.js +421 -0
  90. package/dest/test/index.d.ts +2 -1
  91. package/dest/test/index.d.ts.map +1 -1
  92. package/dest/test/index.js +4 -1
  93. package/dest/test/mock_archiver.d.ts +16 -8
  94. package/dest/test/mock_archiver.d.ts.map +1 -1
  95. package/dest/test/mock_archiver.js +19 -14
  96. package/dest/test/mock_l1_to_l2_message_source.d.ts +7 -6
  97. package/dest/test/mock_l1_to_l2_message_source.d.ts.map +1 -1
  98. package/dest/test/mock_l1_to_l2_message_source.js +21 -11
  99. package/dest/test/mock_l2_block_source.d.ts +54 -20
  100. package/dest/test/mock_l2_block_source.d.ts.map +1 -1
  101. package/dest/test/mock_l2_block_source.js +245 -82
  102. package/dest/test/mock_structs.d.ts +80 -4
  103. package/dest/test/mock_structs.d.ts.map +1 -1
  104. package/dest/test/mock_structs.js +145 -11
  105. package/dest/test/noop_l1_archiver.d.ts +23 -0
  106. package/dest/test/noop_l1_archiver.d.ts.map +1 -0
  107. package/dest/test/noop_l1_archiver.js +68 -0
  108. package/package.json +20 -20
  109. package/src/archiver.ts +443 -0
  110. package/src/{archiver/config.ts → config.ts} +33 -12
  111. package/src/errors.ts +102 -0
  112. package/src/factory.ts +142 -13
  113. package/src/index.ts +11 -3
  114. package/src/interfaces.ts +9 -0
  115. package/src/l1/README.md +55 -0
  116. package/src/l1/bin/retrieve-calldata.ts +194 -0
  117. package/src/l1/calldata_retriever.ts +511 -0
  118. package/src/l1/data_retrieval.ts +493 -0
  119. package/src/l1/debug_tx.ts +99 -0
  120. package/src/l1/spire_proposer.ts +152 -0
  121. package/src/l1/trace_tx.ts +128 -0
  122. package/src/l1/types.ts +13 -0
  123. package/src/l1/validate_trace.ts +229 -0
  124. package/src/modules/data_source_base.ts +328 -0
  125. package/src/modules/data_store_updater.ts +448 -0
  126. package/src/{archiver → modules}/instrumentation.ts +61 -64
  127. package/src/modules/l1_synchronizer.ts +933 -0
  128. package/src/modules/validation.ts +129 -0
  129. package/src/store/block_store.ts +1015 -0
  130. package/src/{archiver/kv_archiver_store → store}/contract_class_store.ts +13 -9
  131. package/src/{archiver/kv_archiver_store → store}/contract_instance_store.ts +2 -2
  132. package/src/store/kv_archiver_store.ts +671 -0
  133. package/src/store/l2_tips_cache.ts +89 -0
  134. package/src/store/log_store.ts +637 -0
  135. package/src/{archiver/kv_archiver_store → store}/message_store.ts +21 -18
  136. package/src/{archiver/structs → structs}/inbox_message.ts +8 -8
  137. package/src/structs/published.ts +1 -0
  138. package/src/test/fake_l1_state.ts +657 -0
  139. package/src/test/fixtures/debug_traceTransaction-multicall3.json +88 -0
  140. package/src/test/fixtures/debug_traceTransaction-multiplePropose.json +153 -0
  141. package/src/test/fixtures/debug_traceTransaction-proxied.json +122 -0
  142. package/src/test/fixtures/trace_transaction-multicall3.json +65 -0
  143. package/src/test/fixtures/trace_transaction-multiplePropose.json +319 -0
  144. package/src/test/fixtures/trace_transaction-proxied.json +128 -0
  145. package/src/test/fixtures/trace_transaction-randomRevert.json +216 -0
  146. package/src/test/index.ts +4 -0
  147. package/src/test/mock_archiver.ts +23 -16
  148. package/src/test/mock_l1_to_l2_message_source.ts +18 -11
  149. package/src/test/mock_l2_block_source.ts +299 -92
  150. package/src/test/mock_structs.ts +275 -13
  151. package/src/test/noop_l1_archiver.ts +109 -0
  152. package/dest/archiver/archiver.d.ts +0 -277
  153. package/dest/archiver/archiver.d.ts.map +0 -1
  154. package/dest/archiver/archiver.js +0 -1322
  155. package/dest/archiver/archiver_store.d.ts +0 -255
  156. package/dest/archiver/archiver_store.d.ts.map +0 -1
  157. package/dest/archiver/archiver_store.js +0 -4
  158. package/dest/archiver/archiver_store_test_suite.d.ts +0 -8
  159. package/dest/archiver/archiver_store_test_suite.d.ts.map +0 -1
  160. package/dest/archiver/archiver_store_test_suite.js +0 -1288
  161. package/dest/archiver/config.d.ts +0 -21
  162. package/dest/archiver/config.d.ts.map +0 -1
  163. package/dest/archiver/data_retrieval.d.ts +0 -79
  164. package/dest/archiver/data_retrieval.d.ts.map +0 -1
  165. package/dest/archiver/data_retrieval.js +0 -362
  166. package/dest/archiver/errors.d.ts +0 -12
  167. package/dest/archiver/errors.d.ts.map +0 -1
  168. package/dest/archiver/errors.js +0 -17
  169. package/dest/archiver/index.d.ts +0 -7
  170. package/dest/archiver/index.d.ts.map +0 -1
  171. package/dest/archiver/index.js +0 -4
  172. package/dest/archiver/instrumentation.d.ts +0 -35
  173. package/dest/archiver/instrumentation.d.ts.map +0 -1
  174. package/dest/archiver/kv_archiver_store/block_store.d.ts +0 -124
  175. package/dest/archiver/kv_archiver_store/block_store.d.ts.map +0 -1
  176. package/dest/archiver/kv_archiver_store/block_store.js +0 -370
  177. package/dest/archiver/kv_archiver_store/contract_class_store.d.ts +0 -18
  178. package/dest/archiver/kv_archiver_store/contract_class_store.d.ts.map +0 -1
  179. package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts +0 -24
  180. package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts.map +0 -1
  181. package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts +0 -168
  182. package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts.map +0 -1
  183. package/dest/archiver/kv_archiver_store/kv_archiver_store.js +0 -296
  184. package/dest/archiver/kv_archiver_store/log_store.d.ts +0 -49
  185. package/dest/archiver/kv_archiver_store/log_store.d.ts.map +0 -1
  186. package/dest/archiver/kv_archiver_store/log_store.js +0 -336
  187. package/dest/archiver/kv_archiver_store/message_store.d.ts +0 -39
  188. package/dest/archiver/kv_archiver_store/message_store.d.ts.map +0 -1
  189. package/dest/archiver/structs/data_retrieval.d.ts +0 -27
  190. package/dest/archiver/structs/data_retrieval.d.ts.map +0 -1
  191. package/dest/archiver/structs/inbox_message.d.ts +0 -15
  192. package/dest/archiver/structs/inbox_message.d.ts.map +0 -1
  193. package/dest/archiver/structs/published.d.ts +0 -2
  194. package/dest/archiver/structs/published.d.ts.map +0 -1
  195. package/dest/archiver/validation.d.ts +0 -11
  196. package/dest/archiver/validation.d.ts.map +0 -1
  197. package/dest/rpc/index.d.ts +0 -9
  198. package/dest/rpc/index.d.ts.map +0 -1
  199. package/dest/rpc/index.js +0 -15
  200. package/src/archiver/archiver.ts +0 -1722
  201. package/src/archiver/archiver_store.ts +0 -305
  202. package/src/archiver/archiver_store_test_suite.ts +0 -1263
  203. package/src/archiver/data_retrieval.ts +0 -545
  204. package/src/archiver/errors.ts +0 -26
  205. package/src/archiver/index.ts +0 -6
  206. package/src/archiver/kv_archiver_store/block_store.ts +0 -481
  207. package/src/archiver/kv_archiver_store/kv_archiver_store.ts +0 -422
  208. package/src/archiver/kv_archiver_store/log_store.ts +0 -406
  209. package/src/archiver/structs/published.ts +0 -1
  210. package/src/archiver/validation.ts +0 -99
  211. package/src/rpc/index.ts +0 -16
  212. /package/dest/{archiver/structs → structs}/data_retrieval.js +0 -0
  213. /package/dest/{archiver/structs → structs}/published.js +0 -0
  214. /package/src/{archiver/structs → structs}/data_retrieval.ts +0 -0
@@ -1,22 +1,27 @@
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
- PublishedL2Block,
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
21
  import { EmptyL1RollupConstants, type L1RollupConstants, getSlotRangeForEpoch } from '@aztec/stdlib/epoch-helpers';
19
- import { type BlockHeader, TxHash, TxReceipt, TxStatus } from '@aztec/stdlib/tx';
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';
20
25
  import type { UInt64 } from '@aztec/stdlib/types';
21
26
 
22
27
  /**
@@ -24,29 +29,57 @@ import type { UInt64 } from '@aztec/stdlib/types';
24
29
  */
25
30
  export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
26
31
  protected l2Blocks: L2Block[] = [];
32
+ protected checkpointList: Checkpoint[] = [];
27
33
 
28
34
  private provenBlockNumber: number = 0;
29
35
  private finalizedBlockNumber: number = 0;
36
+ private checkpointedBlockNumber: number = 0;
30
37
 
31
38
  private log = createLogger('archiver:mock_l2_block_source');
32
39
 
40
+ /** Creates blocks grouped into single-block checkpoints. */
33
41
  public async createBlocks(numBlocks: number) {
34
- for (let i = 0; i < numBlocks; i++) {
35
- const blockNum = this.l2Blocks.length + 1;
36
- const block = await L2Block.random(blockNum);
37
- this.l2Blocks.push(block);
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);
38
59
  }
39
60
 
40
- this.log.verbose(`Created ${numBlocks} blocks in the mock L2 block source`);
61
+ this.log.verbose(
62
+ `Created ${numCheckpoints} checkpoints with ${blocksPerCheckpoint} blocks each in the mock L2 block source`,
63
+ );
41
64
  }
42
65
 
43
- public addBlocks(blocks: L2Block[]) {
66
+ public addProposedBlocks(blocks: L2Block[]) {
44
67
  this.l2Blocks.push(...blocks);
45
- 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`);
46
69
  }
47
70
 
48
71
  public removeBlocks(numBlocks: number) {
49
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);
50
83
  this.log.verbose(`Removed ${numBlocks} blocks from the mock L2 block source`);
51
84
  }
52
85
 
@@ -61,6 +94,36 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
61
94
  this.finalizedBlockNumber = finalizedBlockNumber;
62
95
  }
63
96
 
97
+ public setCheckpointedBlockNumber(checkpointedBlockNumber: number) {
98
+ const prevCheckpointed = this.checkpointedBlockNumber;
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
+ }
125
+ }
126
+
64
127
  /**
65
128
  * Method to fetch the rollup contract address at the base-layer.
66
129
  * @returns The rollup address.
@@ -82,11 +145,45 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
82
145
  * @returns In this mock instance, returns the number of L2 blocks that we've mocked.
83
146
  */
84
147
  public getBlockNumber() {
85
- return Promise.resolve(this.l2Blocks.length);
148
+ return Promise.resolve(BlockNumber(this.l2Blocks.length));
149
+ }
150
+
151
+ public getProvenBlockNumber() {
152
+ return Promise.resolve(BlockNumber(this.provenBlockNumber));
153
+ }
154
+
155
+ public getCheckpointedL2BlockNumber() {
156
+ return Promise.resolve(BlockNumber(this.checkpointedBlockNumber));
86
157
  }
87
158
 
88
- public getProvenBlockNumber(): Promise<number> {
89
- return Promise.resolve(this.provenBlockNumber);
159
+ public getFinalizedL2BlockNumber() {
160
+ return Promise.resolve(BlockNumber(this.finalizedBlockNumber));
161
+ }
162
+
163
+ public getCheckpointedBlock(number: BlockNumber): Promise<CheckpointedL2Block | undefined> {
164
+ if (number > this.checkpointedBlockNumber) {
165
+ return Promise.resolve(undefined);
166
+ }
167
+ const block = this.l2Blocks[number - 1];
168
+ if (!block) {
169
+ return Promise.resolve(undefined);
170
+ }
171
+ return Promise.resolve(this.toCheckpointedBlock(block));
172
+ }
173
+
174
+ public async getCheckpointedBlocks(from: BlockNumber, limit: number): Promise<CheckpointedL2Block[]> {
175
+ const result: CheckpointedL2Block[] = [];
176
+ for (let i = 0; i < limit; i++) {
177
+ const blockNum = from + i;
178
+ if (blockNum > this.checkpointedBlockNumber) {
179
+ break;
180
+ }
181
+ const block = await this.getCheckpointedBlock(BlockNumber(blockNum));
182
+ if (block) {
183
+ result.push(block);
184
+ }
185
+ }
186
+ return result;
90
187
  }
91
188
 
92
189
  /**
@@ -94,8 +191,19 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
94
191
  * @param number - The block number to return (inclusive).
95
192
  * @returns The requested L2 block.
96
193
  */
97
- public getBlock(number: number) {
98
- return Promise.resolve(this.l2Blocks[number - 1]);
194
+ public getBlock(number: number): Promise<L2Block | undefined> {
195
+ const block = this.l2Blocks[number - 1];
196
+ return Promise.resolve(block);
197
+ }
198
+
199
+ /**
200
+ * Gets an L2 block (new format).
201
+ * @param number - The block number to return.
202
+ * @returns The requested L2 block.
203
+ */
204
+ public getL2Block(number: BlockNumber): Promise<L2Block | undefined> {
205
+ const block = this.l2Blocks[number - 1];
206
+ return Promise.resolve(block);
99
207
  }
100
208
 
101
209
  /**
@@ -104,70 +212,60 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
104
212
  * @param limit - The maximum number of blocks to return.
105
213
  * @returns The requested mocked L2 blocks.
106
214
  */
107
- public getBlocks(from: number, limit: number, proven?: boolean) {
215
+ public getBlocks(from: number, limit: number): Promise<L2Block[]> {
216
+ return Promise.resolve(this.l2Blocks.slice(from - 1, from - 1 + limit));
217
+ }
218
+
219
+ public getCheckpoints(from: CheckpointNumber, limit: number) {
220
+ const checkpoints = this.checkpointList.slice(from - 1, from - 1 + limit);
108
221
  return Promise.resolve(
109
- this.l2Blocks
110
- .slice(from - 1, from - 1 + limit)
111
- .filter(b => !proven || this.provenBlockNumber === undefined || b.number <= this.provenBlockNumber),
222
+ checkpoints.map(checkpoint => new PublishedCheckpoint(checkpoint, this.mockL1DataForCheckpoint(checkpoint), [])),
112
223
  );
113
224
  }
114
225
 
115
- public async getPublishedBlocks(from: number, limit: number, proven?: boolean) {
116
- const blocks = await this.getBlocks(from, limit, proven);
117
- return blocks.map(block =>
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
- );
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);
128
229
  }
129
230
 
130
- public async getPublishedBlockByHash(blockHash: Fr): Promise<PublishedL2Block | undefined> {
231
+ public async getCheckpointedBlockByHash(blockHash: BlockHash): Promise<CheckpointedL2Block | undefined> {
131
232
  for (const block of this.l2Blocks) {
132
233
  const hash = await block.hash();
133
234
  if (hash.equals(blockHash)) {
134
- return PublishedL2Block.fromFields({
135
- block,
136
- l1: {
137
- blockNumber: BigInt(block.number),
138
- blockHash: Buffer32.random().toString(),
139
- timestamp: BigInt(block.number),
140
- },
141
- attestations: [],
142
- });
235
+ return this.toCheckpointedBlock(block);
143
236
  }
144
237
  }
145
238
  return undefined;
146
239
  }
147
240
 
148
- public getPublishedBlockByArchive(archive: Fr): Promise<PublishedL2Block | undefined> {
241
+ public getCheckpointedBlockByArchive(archive: Fr): Promise<CheckpointedL2Block | undefined> {
149
242
  const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
150
243
  if (!block) {
151
244
  return Promise.resolve(undefined);
152
245
  }
153
- return Promise.resolve(
154
- PublishedL2Block.fromFields({
155
- block,
156
- l1: {
157
- blockNumber: BigInt(block.number),
158
- blockHash: Buffer32.random().toString(),
159
- timestamp: BigInt(block.number),
160
- },
161
- attestations: [],
162
- }),
163
- );
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);
164
262
  }
165
263
 
166
- public async getBlockHeaderByHash(blockHash: Fr): Promise<BlockHeader | undefined> {
264
+ public async getBlockHeaderByHash(blockHash: BlockHash): Promise<BlockHeader | undefined> {
167
265
  for (const block of this.l2Blocks) {
168
266
  const hash = await block.hash();
169
267
  if (hash.equals(blockHash)) {
170
- return block.getBlockHeader();
268
+ return block.header;
171
269
  }
172
270
  }
173
271
  return undefined;
@@ -175,26 +273,80 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
175
273
 
176
274
  public getBlockHeaderByArchive(archive: Fr): Promise<BlockHeader | undefined> {
177
275
  const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
178
- return Promise.resolve(block?.getBlockHeader());
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
+ };
179
305
  }
180
306
 
181
307
  getBlockHeader(number: number | 'latest'): Promise<BlockHeader | undefined> {
182
- return Promise.resolve(this.l2Blocks.at(typeof number === 'number' ? number - 1 : -1)?.getBlockHeader());
308
+ return Promise.resolve(this.l2Blocks.at(typeof number === 'number' ? number - 1 : -1)?.header);
183
309
  }
184
310
 
185
- getBlocksForEpoch(epochNumber: bigint): Promise<L2Block[]> {
186
- const epochDuration = DefaultL1ContractsConfig.aztecEpochDuration;
187
- const [start, end] = getSlotRangeForEpoch(epochNumber, { epochDuration });
188
- const blocks = this.l2Blocks.filter(b => {
189
- const slot = b.header.globalVariables.slotNumber.toBigInt();
190
- return slot >= start && slot <= end;
191
- });
311
+ getCheckpointsForEpoch(epochNumber: EpochNumber): Promise<Checkpoint[]> {
312
+ return Promise.resolve(this.getCheckpointsInEpoch(epochNumber));
313
+ }
314
+
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);
192
344
  return Promise.resolve(blocks);
193
345
  }
194
346
 
195
- async getBlockHeadersForEpoch(epochNumber: bigint): Promise<BlockHeader[]> {
196
- const blocks = await this.getBlocksForEpoch(epochNumber);
197
- return blocks.map(b => b.getBlockHeader());
347
+ async getCheckpointedBlockHeadersForEpoch(epochNumber: EpochNumber): Promise<BlockHeader[]> {
348
+ const checkpointedBlocks = await this.getCheckpointedBlocksForEpoch(epochNumber);
349
+ return checkpointedBlocks.map(b => b.block.header);
198
350
  }
199
351
 
200
352
  /**
@@ -213,7 +365,7 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
213
365
  return {
214
366
  data: txEffect,
215
367
  l2BlockNumber: block.number,
216
- l2BlockHash: L2BlockHash.fromField(await block.hash()),
368
+ l2BlockHash: await block.hash(),
217
369
  txIndexInBlock: block.body.txEffects.indexOf(txEffect),
218
370
  };
219
371
  }
@@ -227,12 +379,14 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
227
379
  for (const block of this.l2Blocks) {
228
380
  for (const txEffect of block.body.txEffects) {
229
381
  if (txEffect.txHash.equals(txHash)) {
382
+ // In mock, assume all txs are checkpointed with successful execution
230
383
  return new TxReceipt(
231
384
  txHash,
232
- TxStatus.SUCCESS,
233
- '',
385
+ TxStatus.CHECKPOINTED,
386
+ TxExecutionResult.SUCCESS,
387
+ undefined,
234
388
  txEffect.transactionFee.toBigInt(),
235
- L2BlockHash.fromField(await block.hash()),
389
+ await block.hash(),
236
390
  block.number,
237
391
  );
238
392
  }
@@ -242,41 +396,60 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
242
396
  }
243
397
 
244
398
  async getL2Tips(): Promise<L2Tips> {
245
- const [latest, proven, finalized] = [
399
+ const [latest, proven, finalized, checkpointed] = [
246
400
  await this.getBlockNumber(),
247
401
  await this.getProvenBlockNumber(),
248
402
  this.finalizedBlockNumber,
403
+ this.checkpointedBlockNumber,
249
404
  ] as const;
250
405
 
251
406
  const latestBlock = this.l2Blocks[latest - 1];
252
407
  const provenBlock = this.l2Blocks[proven - 1];
253
408
  const finalizedBlock = this.l2Blocks[finalized - 1];
409
+ const checkpointedBlock = this.l2Blocks[checkpointed - 1];
254
410
 
255
- return {
256
- latest: {
257
- number: latest,
258
- hash: (await latestBlock?.hash())?.toString(),
259
- },
260
- proven: {
261
- number: proven,
262
- hash: (await provenBlock?.hash())?.toString(),
263
- },
264
- finalized: {
265
- number: finalized,
266
- hash: (await finalizedBlock?.hash())?.toString(),
411
+ const latestBlockId = {
412
+ number: BlockNumber(latest),
413
+ hash: (await latestBlock?.hash())?.toString(),
414
+ };
415
+ const provenBlockId = {
416
+ number: BlockNumber(proven),
417
+ hash: (await provenBlock?.hash())?.toString(),
418
+ };
419
+ const finalizedBlockId = {
420
+ number: BlockNumber(finalized),
421
+ hash: (await finalizedBlock?.hash())?.toString(),
422
+ };
423
+ const checkpointedBlockId = {
424
+ number: BlockNumber(checkpointed),
425
+ hash: (await checkpointedBlock?.hash())?.toString(),
426
+ };
427
+
428
+ const makeTipId = (blockId: typeof latestBlockId) => ({
429
+ block: blockId,
430
+ checkpoint: {
431
+ number: this.findCheckpointNumberForBlock(blockId.number) ?? CheckpointNumber(0),
432
+ hash: blockId.hash,
267
433
  },
434
+ });
435
+
436
+ return {
437
+ proposed: latestBlockId,
438
+ checkpointed: makeTipId(checkpointedBlockId),
439
+ proven: makeTipId(provenBlockId),
440
+ finalized: makeTipId(finalizedBlockId),
268
441
  };
269
442
  }
270
443
 
271
- getL2EpochNumber(): Promise<bigint> {
444
+ getL2EpochNumber(): Promise<EpochNumber> {
272
445
  throw new Error('Method not implemented.');
273
446
  }
274
447
 
275
- getL2SlotNumber(): Promise<bigint> {
448
+ getL2SlotNumber(): Promise<SlotNumber> {
276
449
  throw new Error('Method not implemented.');
277
450
  }
278
451
 
279
- isEpochComplete(_epochNumber: bigint): Promise<boolean> {
452
+ isEpochComplete(_epochNumber: EpochNumber): Promise<boolean> {
280
453
  throw new Error('Method not implemented.');
281
454
  }
282
455
 
@@ -342,7 +515,41 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
342
515
  return Promise.resolve(false);
343
516
  }
344
517
 
345
- getPendingChainValidationStatus(): Promise<ValidateBlockResult> {
518
+ getPendingChainValidationStatus(): Promise<ValidateCheckpointResult> {
346
519
  return Promise.resolve({ valid: true });
347
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
+ }
348
555
  }