@aztec/archiver 0.0.1-commit.9b94fc1 → 0.0.1-commit.9ee6fcc6

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 (211) hide show
  1. package/README.md +156 -22
  2. package/dest/archiver.d.ts +138 -0
  3. package/dest/archiver.d.ts.map +1 -0
  4. package/dest/archiver.js +743 -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} +23 -6
  8. package/dest/errors.d.ts +53 -0
  9. package/dest/errors.d.ts.map +1 -0
  10. package/dest/errors.js +75 -0
  11. package/dest/factory.d.ts +8 -7
  12. package/dest/factory.d.ts.map +1 -1
  13. package/dest/factory.js +99 -15
  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/{archiver → l1}/data_retrieval.js +83 -155
  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 +85 -0
  48. package/dest/modules/data_store_updater.d.ts.map +1 -0
  49. package/dest/modules/data_store_updater.js +324 -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 +72 -0
  54. package/dest/modules/l1_synchronizer.d.ts.map +1 -0
  55. package/dest/modules/l1_synchronizer.js +1147 -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 +7 -1
  59. package/dest/store/block_store.d.ts +195 -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 +17 -0
  63. package/dest/store/contract_class_store.d.ts.map +1 -0
  64. package/dest/store/contract_class_store.js +64 -0
  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 +7 -3
  68. package/dest/store/kv_archiver_store.d.ts +364 -0
  69. package/dest/store/kv_archiver_store.d.ts.map +1 -0
  70. package/dest/store/kv_archiver_store.js +477 -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 +57 -0
  75. package/dest/store/log_store.d.ts.map +1 -0
  76. package/dest/store/log_store.js +533 -0
  77. package/dest/store/message_store.d.ts +44 -0
  78. package/dest/store/message_store.d.ts.map +1 -0
  79. package/dest/{archiver/kv_archiver_store → store}/message_store.js +29 -15
  80. package/dest/{archiver/structs → structs}/data_retrieval.d.ts +1 -1
  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 +202 -0
  88. package/dest/test/fake_l1_state.d.ts.map +1 -0
  89. package/dest/test/fake_l1_state.js +455 -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 +251 -85
  102. package/dest/test/mock_structs.d.ts +83 -4
  103. package/dest/test/mock_structs.d.ts.map +1 -1
  104. package/dest/test/mock_structs.js +157 -11
  105. package/dest/test/noop_l1_archiver.d.ts +26 -0
  106. package/dest/test/noop_l1_archiver.d.ts.map +1 -0
  107. package/dest/test/noop_l1_archiver.js +72 -0
  108. package/package.json +20 -20
  109. package/src/archiver.ts +500 -0
  110. package/src/{archiver/config.ts → config.ts} +36 -13
  111. package/src/errors.ts +118 -0
  112. package/src/factory.ts +154 -17
  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/{archiver → l1}/data_retrieval.ts +143 -226
  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 +333 -0
  125. package/src/modules/data_store_updater.ts +424 -0
  126. package/src/{archiver → modules}/instrumentation.ts +63 -66
  127. package/src/modules/l1_synchronizer.ts +967 -0
  128. package/src/{archiver → modules}/validation.ts +11 -6
  129. package/src/store/block_store.ts +1018 -0
  130. package/src/store/contract_class_store.ts +82 -0
  131. package/src/{archiver/kv_archiver_store → store}/contract_instance_store.ts +10 -7
  132. package/src/store/kv_archiver_store.ts +682 -0
  133. package/src/store/l2_tips_cache.ts +89 -0
  134. package/src/store/log_store.ts +736 -0
  135. package/src/{archiver/kv_archiver_store → store}/message_store.ts +41 -19
  136. package/src/{archiver/structs → structs}/inbox_message.ts +8 -8
  137. package/src/{archiver/structs → structs}/published.ts +0 -1
  138. package/src/test/fake_l1_state.ts +698 -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 +311 -93
  150. package/src/test/mock_structs.ts +289 -13
  151. package/src/test/noop_l1_archiver.ts +115 -0
  152. package/dest/archiver/archiver.d.ts +0 -287
  153. package/dest/archiver/archiver.d.ts.map +0 -1
  154. package/dest/archiver/archiver.js +0 -1408
  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 -1289
  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/errors.d.ts +0 -12
  166. package/dest/archiver/errors.d.ts.map +0 -1
  167. package/dest/archiver/errors.js +0 -17
  168. package/dest/archiver/index.d.ts +0 -7
  169. package/dest/archiver/index.d.ts.map +0 -1
  170. package/dest/archiver/index.js +0 -4
  171. package/dest/archiver/instrumentation.d.ts +0 -35
  172. package/dest/archiver/instrumentation.d.ts.map +0 -1
  173. package/dest/archiver/kv_archiver_store/block_store.d.ts +0 -124
  174. package/dest/archiver/kv_archiver_store/block_store.d.ts.map +0 -1
  175. package/dest/archiver/kv_archiver_store/block_store.js +0 -370
  176. package/dest/archiver/kv_archiver_store/contract_class_store.d.ts +0 -18
  177. package/dest/archiver/kv_archiver_store/contract_class_store.d.ts.map +0 -1
  178. package/dest/archiver/kv_archiver_store/contract_class_store.js +0 -120
  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.map +0 -1
  190. package/dest/archiver/structs/inbox_message.d.ts +0 -15
  191. package/dest/archiver/structs/inbox_message.d.ts.map +0 -1
  192. package/dest/archiver/structs/published.d.ts +0 -3
  193. package/dest/archiver/structs/published.d.ts.map +0 -1
  194. package/dest/archiver/validation.d.ts +0 -17
  195. package/dest/archiver/validation.d.ts.map +0 -1
  196. package/dest/rpc/index.d.ts +0 -9
  197. package/dest/rpc/index.d.ts.map +0 -1
  198. package/dest/rpc/index.js +0 -15
  199. package/src/archiver/archiver.ts +0 -1858
  200. package/src/archiver/archiver_store.ts +0 -305
  201. package/src/archiver/archiver_store_test_suite.ts +0 -1264
  202. package/src/archiver/errors.ts +0 -26
  203. package/src/archiver/index.ts +0 -6
  204. package/src/archiver/kv_archiver_store/block_store.ts +0 -481
  205. package/src/archiver/kv_archiver_store/contract_class_store.ts +0 -176
  206. package/src/archiver/kv_archiver_store/kv_archiver_store.ts +0 -422
  207. package/src/archiver/kv_archiver_store/log_store.ts +0 -406
  208. package/src/rpc/index.ts +0 -16
  209. /package/dest/{archiver/structs → structs}/data_retrieval.js +0 -0
  210. /package/dest/{archiver/structs → structs}/published.js +0 -0
  211. /package/src/{archiver/structs → structs}/data_retrieval.ts +0 -0
@@ -1,23 +1,32 @@
1
1
  import { GENESIS_ARCHIVE_ROOT } from '@aztec/constants';
2
- import { DefaultL1ContractsConfig } from '@aztec/ethereum';
3
- import { EpochNumber, SlotNumber } from '@aztec/foundation/branded-types';
2
+ import { DefaultL1ContractsConfig } from '@aztec/ethereum/config';
3
+ import { BlockNumber, CheckpointNumber, EpochNumber, SlotNumber } from '@aztec/foundation/branded-types';
4
4
  import { Buffer32 } from '@aztec/foundation/buffer';
5
+ import { Fr } from '@aztec/foundation/curves/bn254';
5
6
  import { EthAddress } from '@aztec/foundation/eth-address';
6
- import { Fr } from '@aztec/foundation/fields';
7
7
  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,
13
+ CheckpointedL2Block,
11
14
  L2Block,
12
- L2BlockHash,
13
15
  type L2BlockSource,
14
16
  type L2Tips,
15
- PublishedL2Block,
16
- type ValidateBlockResult,
17
+ type ValidateCheckpointResult,
17
18
  } from '@aztec/stdlib/block';
19
+ import { Checkpoint, type CheckpointData, L1PublishedData, PublishedCheckpoint } from '@aztec/stdlib/checkpoint';
18
20
  import type { ContractClassPublic, ContractDataSource, ContractInstanceWithAddress } from '@aztec/stdlib/contract';
19
- import { EmptyL1RollupConstants, type L1RollupConstants, getSlotRangeForEpoch } from '@aztec/stdlib/epoch-helpers';
20
- import { type BlockHeader, TxHash, TxReceipt, TxStatus } from '@aztec/stdlib/tx';
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';
21
30
  import type { UInt64 } from '@aztec/stdlib/types';
22
31
 
23
32
  /**
@@ -25,29 +34,63 @@ import type { UInt64 } from '@aztec/stdlib/types';
25
34
  */
26
35
  export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
27
36
  protected l2Blocks: L2Block[] = [];
37
+ protected checkpointList: Checkpoint[] = [];
28
38
 
29
39
  private provenBlockNumber: number = 0;
30
40
  private finalizedBlockNumber: number = 0;
41
+ private checkpointedBlockNumber: number = 0;
31
42
 
32
43
  private log = createLogger('archiver:mock_l2_block_source');
33
44
 
45
+ /** Creates blocks grouped into single-block checkpoints. */
34
46
  public async createBlocks(numBlocks: number) {
35
- for (let i = 0; i < numBlocks; i++) {
36
- const blockNum = this.l2Blocks.length + 1;
37
- const block = await L2Block.random(blockNum);
38
- this.l2Blocks.push(block);
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);
39
70
  }
40
71
 
41
- this.log.verbose(`Created ${numBlocks} blocks in the mock L2 block source`);
72
+ this.log.verbose(
73
+ `Created ${numCheckpoints} checkpoints with ${blocksPerCheckpoint} blocks each in the mock L2 block source`,
74
+ );
42
75
  }
43
76
 
44
- public addBlocks(blocks: L2Block[]) {
77
+ public addProposedBlocks(blocks: L2Block[]) {
45
78
  this.l2Blocks.push(...blocks);
46
- 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`);
47
80
  }
48
81
 
49
82
  public removeBlocks(numBlocks: number) {
50
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);
51
94
  this.log.verbose(`Removed ${numBlocks} blocks from the mock L2 block source`);
52
95
  }
53
96
 
@@ -62,6 +105,36 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
62
105
  this.finalizedBlockNumber = finalizedBlockNumber;
63
106
  }
64
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
+
65
138
  /**
66
139
  * Method to fetch the rollup contract address at the base-layer.
67
140
  * @returns The rollup address.
@@ -83,11 +156,45 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
83
156
  * @returns In this mock instance, returns the number of L2 blocks that we've mocked.
84
157
  */
85
158
  public getBlockNumber() {
86
- 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));
87
168
  }
88
169
 
89
- public getProvenBlockNumber(): Promise<number> {
90
- return Promise.resolve(this.provenBlockNumber);
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;
91
198
  }
92
199
 
93
200
  /**
@@ -95,8 +202,19 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
95
202
  * @param number - The block number to return (inclusive).
96
203
  * @returns The requested L2 block.
97
204
  */
98
- public getBlock(number: number) {
99
- return Promise.resolve(this.l2Blocks[number - 1]);
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);
100
218
  }
101
219
 
102
220
  /**
@@ -105,70 +223,60 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
105
223
  * @param limit - The maximum number of blocks to return.
106
224
  * @returns The requested mocked L2 blocks.
107
225
  */
108
- public getBlocks(from: number, limit: number, proven?: boolean) {
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);
109
232
  return Promise.resolve(
110
- this.l2Blocks
111
- .slice(from - 1, from - 1 + limit)
112
- .filter(b => !proven || this.provenBlockNumber === undefined || b.number <= this.provenBlockNumber),
233
+ checkpoints.map(checkpoint => new PublishedCheckpoint(checkpoint, this.mockL1DataForCheckpoint(checkpoint), [])),
113
234
  );
114
235
  }
115
236
 
116
- public async getPublishedBlocks(from: number, limit: number, proven?: boolean) {
117
- const blocks = await this.getBlocks(from, limit, proven);
118
- return blocks.map(block =>
119
- PublishedL2Block.fromFields({
120
- block,
121
- l1: {
122
- blockNumber: BigInt(block.number),
123
- blockHash: Buffer32.random().toString(),
124
- timestamp: BigInt(block.number),
125
- },
126
- attestations: [],
127
- }),
128
- );
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);
129
240
  }
130
241
 
131
- public async getPublishedBlockByHash(blockHash: Fr): Promise<PublishedL2Block | undefined> {
242
+ public async getCheckpointedBlockByHash(blockHash: BlockHash): Promise<CheckpointedL2Block | undefined> {
132
243
  for (const block of this.l2Blocks) {
133
244
  const hash = await block.hash();
134
245
  if (hash.equals(blockHash)) {
135
- return PublishedL2Block.fromFields({
136
- block,
137
- l1: {
138
- blockNumber: BigInt(block.number),
139
- blockHash: Buffer32.random().toString(),
140
- timestamp: BigInt(block.number),
141
- },
142
- attestations: [],
143
- });
246
+ return this.toCheckpointedBlock(block);
144
247
  }
145
248
  }
146
249
  return undefined;
147
250
  }
148
251
 
149
- public getPublishedBlockByArchive(archive: Fr): Promise<PublishedL2Block | undefined> {
252
+ public getCheckpointedBlockByArchive(archive: Fr): Promise<CheckpointedL2Block | undefined> {
150
253
  const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
151
254
  if (!block) {
152
255
  return Promise.resolve(undefined);
153
256
  }
154
- return Promise.resolve(
155
- PublishedL2Block.fromFields({
156
- block,
157
- l1: {
158
- blockNumber: BigInt(block.number),
159
- blockHash: Buffer32.random().toString(),
160
- timestamp: BigInt(block.number),
161
- },
162
- attestations: [],
163
- }),
164
- );
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);
165
273
  }
166
274
 
167
- public async getBlockHeaderByHash(blockHash: Fr): Promise<BlockHeader | undefined> {
275
+ public async getBlockHeaderByHash(blockHash: BlockHash): Promise<BlockHeader | undefined> {
168
276
  for (const block of this.l2Blocks) {
169
277
  const hash = await block.hash();
170
278
  if (hash.equals(blockHash)) {
171
- return block.getBlockHeader();
279
+ return block.header;
172
280
  }
173
281
  }
174
282
  return undefined;
@@ -176,26 +284,80 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
176
284
 
177
285
  public getBlockHeaderByArchive(archive: Fr): Promise<BlockHeader | undefined> {
178
286
  const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
179
- return Promise.resolve(block?.getBlockHeader());
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
+ };
180
316
  }
181
317
 
182
318
  getBlockHeader(number: number | 'latest'): Promise<BlockHeader | undefined> {
183
- return Promise.resolve(this.l2Blocks.at(typeof number === 'number' ? number - 1 : -1)?.getBlockHeader());
319
+ return Promise.resolve(this.l2Blocks.at(typeof number === 'number' ? number - 1 : -1)?.header);
184
320
  }
185
321
 
186
- getBlocksForEpoch(epochNumber: EpochNumber): Promise<L2Block[]> {
187
- const epochDuration = DefaultL1ContractsConfig.aztecEpochDuration;
188
- const [start, end] = getSlotRangeForEpoch(epochNumber, { epochDuration });
189
- const blocks = this.l2Blocks.filter(b => {
190
- const slot = b.header.globalVariables.slotNumber;
191
- return slot >= start && slot <= end;
192
- });
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);
193
355
  return Promise.resolve(blocks);
194
356
  }
195
357
 
196
- async getBlockHeadersForEpoch(epochNumber: EpochNumber): Promise<BlockHeader[]> {
197
- const blocks = await this.getBlocksForEpoch(epochNumber);
198
- return blocks.map(b => b.getBlockHeader());
358
+ async getCheckpointedBlockHeadersForEpoch(epochNumber: EpochNumber): Promise<BlockHeader[]> {
359
+ const checkpointedBlocks = await this.getCheckpointedBlocksForEpoch(epochNumber);
360
+ return checkpointedBlocks.map(b => b.block.header);
199
361
  }
200
362
 
201
363
  /**
@@ -214,7 +376,7 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
214
376
  return {
215
377
  data: txEffect,
216
378
  l2BlockNumber: block.number,
217
- l2BlockHash: L2BlockHash.fromField(await block.hash()),
379
+ l2BlockHash: await block.hash(),
218
380
  txIndexInBlock: block.body.txEffects.indexOf(txEffect),
219
381
  };
220
382
  }
@@ -228,13 +390,16 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
228
390
  for (const block of this.l2Blocks) {
229
391
  for (const txEffect of block.body.txEffects) {
230
392
  if (txEffect.txHash.equals(txHash)) {
393
+ // In mock, assume all txs are checkpointed with successful execution
231
394
  return new TxReceipt(
232
395
  txHash,
233
- TxStatus.SUCCESS,
234
- '',
396
+ TxStatus.CHECKPOINTED,
397
+ TxExecutionResult.SUCCESS,
398
+ undefined,
235
399
  txEffect.transactionFee.toBigInt(),
236
- L2BlockHash.fromField(await block.hash()),
400
+ await block.hash(),
237
401
  block.number,
402
+ getEpochAtSlot(block.slot, EmptyL1RollupConstants),
238
403
  );
239
404
  }
240
405
  }
@@ -243,37 +408,56 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
243
408
  }
244
409
 
245
410
  async getL2Tips(): Promise<L2Tips> {
246
- const [latest, proven, finalized] = [
411
+ const [latest, proven, finalized, checkpointed] = [
247
412
  await this.getBlockNumber(),
248
413
  await this.getProvenBlockNumber(),
249
414
  this.finalizedBlockNumber,
415
+ this.checkpointedBlockNumber,
250
416
  ] as const;
251
417
 
252
418
  const latestBlock = this.l2Blocks[latest - 1];
253
419
  const provenBlock = this.l2Blocks[proven - 1];
254
420
  const finalizedBlock = this.l2Blocks[finalized - 1];
421
+ const checkpointedBlock = this.l2Blocks[checkpointed - 1];
255
422
 
256
- return {
257
- latest: {
258
- number: latest,
259
- hash: (await latestBlock?.hash())?.toString(),
260
- },
261
- proven: {
262
- number: proven,
263
- hash: (await provenBlock?.hash())?.toString(),
264
- },
265
- finalized: {
266
- number: finalized,
267
- hash: (await finalizedBlock?.hash())?.toString(),
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,
268
445
  },
446
+ });
447
+
448
+ return {
449
+ proposed: latestBlockId,
450
+ checkpointed: makeTipId(checkpointedBlockId),
451
+ proven: makeTipId(provenBlockId),
452
+ finalized: makeTipId(finalizedBlockId),
269
453
  };
270
454
  }
271
455
 
272
- getL2EpochNumber(): Promise<EpochNumber> {
456
+ getSyncedL2EpochNumber(): Promise<EpochNumber> {
273
457
  throw new Error('Method not implemented.');
274
458
  }
275
459
 
276
- getL2SlotNumber(): Promise<SlotNumber> {
460
+ getSyncedL2SlotNumber(): Promise<SlotNumber> {
277
461
  throw new Error('Method not implemented.');
278
462
  }
279
463
 
@@ -343,7 +527,41 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
343
527
  return Promise.resolve(false);
344
528
  }
345
529
 
346
- getPendingChainValidationStatus(): Promise<ValidateBlockResult> {
530
+ getPendingChainValidationStatus(): Promise<ValidateCheckpointResult> {
347
531
  return Promise.resolve({ valid: true });
348
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
+ }
349
567
  }