@aztec/archiver 0.0.1-commit.5daedc8 → 0.0.1-commit.6201a7b05

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 (218) hide show
  1. package/README.md +162 -22
  2. package/dest/archiver.d.ts +147 -0
  3. package/dest/archiver.d.ts.map +1 -0
  4. package/dest/archiver.js +788 -0
  5. package/dest/config.d.ts +32 -0
  6. package/dest/config.d.ts.map +1 -0
  7. package/dest/config.js +83 -0
  8. package/dest/errors.d.ts +92 -0
  9. package/dest/errors.d.ts.map +1 -0
  10. package/dest/errors.js +136 -0
  11. package/dest/factory.d.ts +8 -7
  12. package/dest/factory.d.ts.map +1 -1
  13. package/dest/factory.js +100 -15
  14. package/dest/index.d.ts +12 -4
  15. package/dest/index.d.ts.map +1 -1
  16. package/dest/index.js +10 -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 +136 -0
  24. package/dest/l1/calldata_retriever.d.ts.map +1 -0
  25. package/dest/l1/calldata_retriever.js +408 -0
  26. package/dest/l1/data_retrieval.d.ts +97 -0
  27. package/dest/l1/data_retrieval.d.ts.map +1 -0
  28. package/dest/{archiver → l1}/data_retrieval.js +86 -165
  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_historical_logs.d.ts +23 -0
  42. package/dest/l1/validate_historical_logs.d.ts.map +1 -0
  43. package/dest/l1/validate_historical_logs.js +108 -0
  44. package/dest/l1/validate_trace.d.ts +32 -0
  45. package/dest/l1/validate_trace.d.ts.map +1 -0
  46. package/dest/l1/validate_trace.js +154 -0
  47. package/dest/modules/data_source_base.d.ts +95 -0
  48. package/dest/modules/data_source_base.d.ts.map +1 -0
  49. package/dest/modules/data_source_base.js +234 -0
  50. package/dest/modules/data_store_updater.d.ts +93 -0
  51. package/dest/modules/data_store_updater.d.ts.map +1 -0
  52. package/dest/modules/data_store_updater.js +345 -0
  53. package/dest/modules/instrumentation.d.ts +55 -0
  54. package/dest/modules/instrumentation.d.ts.map +1 -0
  55. package/dest/modules/instrumentation.js +143 -0
  56. package/dest/modules/l1_synchronizer.d.ts +77 -0
  57. package/dest/modules/l1_synchronizer.d.ts.map +1 -0
  58. package/dest/modules/l1_synchronizer.js +1265 -0
  59. package/dest/modules/validation.d.ts +18 -0
  60. package/dest/modules/validation.d.ts.map +1 -0
  61. package/dest/{archiver → modules}/validation.js +13 -7
  62. package/dest/store/block_store.d.ts +262 -0
  63. package/dest/store/block_store.d.ts.map +1 -0
  64. package/dest/store/block_store.js +1048 -0
  65. package/dest/store/contract_class_store.d.ts +17 -0
  66. package/dest/store/contract_class_store.d.ts.map +1 -0
  67. package/dest/store/contract_class_store.js +64 -0
  68. package/dest/store/contract_instance_store.d.ts +24 -0
  69. package/dest/store/contract_instance_store.d.ts.map +1 -0
  70. package/dest/{archiver/kv_archiver_store → store}/contract_instance_store.js +7 -3
  71. package/dest/store/kv_archiver_store.d.ts +401 -0
  72. package/dest/store/kv_archiver_store.d.ts.map +1 -0
  73. package/dest/store/kv_archiver_store.js +525 -0
  74. package/dest/store/l2_tips_cache.d.ts +20 -0
  75. package/dest/store/l2_tips_cache.d.ts.map +1 -0
  76. package/dest/store/l2_tips_cache.js +109 -0
  77. package/dest/store/log_store.d.ts +57 -0
  78. package/dest/store/log_store.d.ts.map +1 -0
  79. package/dest/store/log_store.js +531 -0
  80. package/dest/store/message_store.d.ts +44 -0
  81. package/dest/store/message_store.d.ts.map +1 -0
  82. package/dest/{archiver/kv_archiver_store → store}/message_store.js +36 -23
  83. package/dest/{archiver/structs → structs}/data_retrieval.d.ts +1 -1
  84. package/dest/structs/data_retrieval.d.ts.map +1 -0
  85. package/dest/structs/inbox_message.d.ts +15 -0
  86. package/dest/structs/inbox_message.d.ts.map +1 -0
  87. package/dest/{archiver/structs → structs}/inbox_message.js +6 -5
  88. package/dest/structs/published.d.ts +2 -0
  89. package/dest/structs/published.d.ts.map +1 -0
  90. package/dest/test/fake_l1_state.d.ts +214 -0
  91. package/dest/test/fake_l1_state.d.ts.map +1 -0
  92. package/dest/test/fake_l1_state.js +517 -0
  93. package/dest/test/index.d.ts +2 -1
  94. package/dest/test/index.d.ts.map +1 -1
  95. package/dest/test/index.js +4 -1
  96. package/dest/test/mock_archiver.d.ts +16 -8
  97. package/dest/test/mock_archiver.d.ts.map +1 -1
  98. package/dest/test/mock_archiver.js +19 -14
  99. package/dest/test/mock_l1_to_l2_message_source.d.ts +7 -6
  100. package/dest/test/mock_l1_to_l2_message_source.d.ts.map +1 -1
  101. package/dest/test/mock_l1_to_l2_message_source.js +23 -12
  102. package/dest/test/mock_l2_block_source.d.ts +68 -20
  103. package/dest/test/mock_l2_block_source.d.ts.map +1 -1
  104. package/dest/test/mock_l2_block_source.js +298 -85
  105. package/dest/test/mock_structs.d.ts +83 -4
  106. package/dest/test/mock_structs.d.ts.map +1 -1
  107. package/dest/test/mock_structs.js +157 -11
  108. package/dest/test/noop_l1_archiver.d.ts +26 -0
  109. package/dest/test/noop_l1_archiver.d.ts.map +1 -0
  110. package/dest/test/noop_l1_archiver.js +74 -0
  111. package/package.json +20 -20
  112. package/src/archiver.ts +566 -0
  113. package/src/{archiver/config.ts → config.ts} +51 -14
  114. package/src/errors.ts +213 -0
  115. package/src/factory.ts +155 -17
  116. package/src/index.ts +12 -3
  117. package/src/interfaces.ts +9 -0
  118. package/src/l1/README.md +55 -0
  119. package/src/l1/bin/retrieve-calldata.ts +194 -0
  120. package/src/l1/calldata_retriever.ts +523 -0
  121. package/src/{archiver → l1}/data_retrieval.ts +155 -247
  122. package/src/l1/debug_tx.ts +99 -0
  123. package/src/l1/spire_proposer.ts +152 -0
  124. package/src/l1/trace_tx.ts +128 -0
  125. package/src/l1/types.ts +13 -0
  126. package/src/l1/validate_historical_logs.ts +140 -0
  127. package/src/l1/validate_trace.ts +229 -0
  128. package/src/modules/data_source_base.ts +364 -0
  129. package/src/modules/data_store_updater.ts +465 -0
  130. package/src/modules/instrumentation.ts +204 -0
  131. package/src/modules/l1_synchronizer.ts +1126 -0
  132. package/src/{archiver → modules}/validation.ts +21 -15
  133. package/src/store/block_store.ts +1361 -0
  134. package/src/store/contract_class_store.ts +82 -0
  135. package/src/{archiver/kv_archiver_store → store}/contract_instance_store.ts +10 -7
  136. package/src/store/kv_archiver_store.ts +765 -0
  137. package/src/store/l2_tips_cache.ts +134 -0
  138. package/src/store/log_store.ts +733 -0
  139. package/src/{archiver/kv_archiver_store → store}/message_store.ts +48 -28
  140. package/src/{archiver/structs → structs}/inbox_message.ts +7 -7
  141. package/src/{archiver/structs → structs}/published.ts +0 -1
  142. package/src/test/fake_l1_state.ts +770 -0
  143. package/src/test/fixtures/debug_traceTransaction-multicall3.json +88 -0
  144. package/src/test/fixtures/debug_traceTransaction-multiplePropose.json +153 -0
  145. package/src/test/fixtures/debug_traceTransaction-proxied.json +122 -0
  146. package/src/test/fixtures/trace_transaction-multicall3.json +65 -0
  147. package/src/test/fixtures/trace_transaction-multiplePropose.json +319 -0
  148. package/src/test/fixtures/trace_transaction-proxied.json +128 -0
  149. package/src/test/fixtures/trace_transaction-randomRevert.json +216 -0
  150. package/src/test/index.ts +4 -0
  151. package/src/test/mock_archiver.ts +23 -16
  152. package/src/test/mock_l1_to_l2_message_source.ts +19 -11
  153. package/src/test/mock_l2_block_source.ts +367 -93
  154. package/src/test/mock_structs.ts +289 -13
  155. package/src/test/noop_l1_archiver.ts +117 -0
  156. package/dest/archiver/archiver.d.ts +0 -287
  157. package/dest/archiver/archiver.d.ts.map +0 -1
  158. package/dest/archiver/archiver.js +0 -1408
  159. package/dest/archiver/archiver_store.d.ts +0 -255
  160. package/dest/archiver/archiver_store.d.ts.map +0 -1
  161. package/dest/archiver/archiver_store.js +0 -4
  162. package/dest/archiver/archiver_store_test_suite.d.ts +0 -8
  163. package/dest/archiver/archiver_store_test_suite.d.ts.map +0 -1
  164. package/dest/archiver/archiver_store_test_suite.js +0 -1289
  165. package/dest/archiver/config.d.ts +0 -21
  166. package/dest/archiver/config.d.ts.map +0 -1
  167. package/dest/archiver/config.js +0 -55
  168. package/dest/archiver/data_retrieval.d.ts +0 -79
  169. package/dest/archiver/data_retrieval.d.ts.map +0 -1
  170. package/dest/archiver/errors.d.ts +0 -12
  171. package/dest/archiver/errors.d.ts.map +0 -1
  172. package/dest/archiver/errors.js +0 -17
  173. package/dest/archiver/index.d.ts +0 -7
  174. package/dest/archiver/index.d.ts.map +0 -1
  175. package/dest/archiver/index.js +0 -4
  176. package/dest/archiver/instrumentation.d.ts +0 -35
  177. package/dest/archiver/instrumentation.d.ts.map +0 -1
  178. package/dest/archiver/instrumentation.js +0 -140
  179. package/dest/archiver/kv_archiver_store/block_store.d.ts +0 -124
  180. package/dest/archiver/kv_archiver_store/block_store.d.ts.map +0 -1
  181. package/dest/archiver/kv_archiver_store/block_store.js +0 -370
  182. package/dest/archiver/kv_archiver_store/contract_class_store.d.ts +0 -18
  183. package/dest/archiver/kv_archiver_store/contract_class_store.d.ts.map +0 -1
  184. package/dest/archiver/kv_archiver_store/contract_class_store.js +0 -120
  185. package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts +0 -24
  186. package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts.map +0 -1
  187. package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts +0 -168
  188. package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts.map +0 -1
  189. package/dest/archiver/kv_archiver_store/kv_archiver_store.js +0 -296
  190. package/dest/archiver/kv_archiver_store/log_store.d.ts +0 -49
  191. package/dest/archiver/kv_archiver_store/log_store.d.ts.map +0 -1
  192. package/dest/archiver/kv_archiver_store/log_store.js +0 -336
  193. package/dest/archiver/kv_archiver_store/message_store.d.ts +0 -39
  194. package/dest/archiver/kv_archiver_store/message_store.d.ts.map +0 -1
  195. package/dest/archiver/structs/data_retrieval.d.ts.map +0 -1
  196. package/dest/archiver/structs/inbox_message.d.ts +0 -15
  197. package/dest/archiver/structs/inbox_message.d.ts.map +0 -1
  198. package/dest/archiver/structs/published.d.ts +0 -3
  199. package/dest/archiver/structs/published.d.ts.map +0 -1
  200. package/dest/archiver/validation.d.ts +0 -17
  201. package/dest/archiver/validation.d.ts.map +0 -1
  202. package/dest/rpc/index.d.ts +0 -9
  203. package/dest/rpc/index.d.ts.map +0 -1
  204. package/dest/rpc/index.js +0 -15
  205. package/src/archiver/archiver.ts +0 -1858
  206. package/src/archiver/archiver_store.ts +0 -305
  207. package/src/archiver/archiver_store_test_suite.ts +0 -1264
  208. package/src/archiver/errors.ts +0 -26
  209. package/src/archiver/index.ts +0 -6
  210. package/src/archiver/instrumentation.ts +0 -187
  211. package/src/archiver/kv_archiver_store/block_store.ts +0 -481
  212. package/src/archiver/kv_archiver_store/contract_class_store.ts +0 -176
  213. package/src/archiver/kv_archiver_store/kv_archiver_store.ts +0 -422
  214. package/src/archiver/kv_archiver_store/log_store.ts +0 -406
  215. package/src/rpc/index.ts +0 -16
  216. /package/dest/{archiver/structs → structs}/data_retrieval.js +0 -0
  217. /package/dest/{archiver/structs → structs}/published.js +0 -0
  218. /package/src/{archiver/structs → structs}/data_retrieval.ts +0 -0
@@ -1,23 +1,38 @@
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 {
20
+ Checkpoint,
21
+ type CheckpointData,
22
+ L1PublishedData,
23
+ type ProposedCheckpointData,
24
+ PublishedCheckpoint,
25
+ } from '@aztec/stdlib/checkpoint';
18
26
  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';
27
+ import {
28
+ EmptyL1RollupConstants,
29
+ type L1RollupConstants,
30
+ getEpochAtSlot,
31
+ getSlotRangeForEpoch,
32
+ } from '@aztec/stdlib/epoch-helpers';
33
+ import { computeCheckpointOutHash } from '@aztec/stdlib/messaging';
34
+ import { CheckpointHeader } from '@aztec/stdlib/rollup';
35
+ import { type BlockHeader, TxExecutionResult, TxHash, TxReceipt, TxStatus } from '@aztec/stdlib/tx';
21
36
  import type { UInt64 } from '@aztec/stdlib/types';
22
37
 
23
38
  /**
@@ -25,29 +40,65 @@ import type { UInt64 } from '@aztec/stdlib/types';
25
40
  */
26
41
  export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
27
42
  protected l2Blocks: L2Block[] = [];
43
+ protected checkpointList: Checkpoint[] = [];
28
44
 
29
45
  private provenBlockNumber: number = 0;
30
46
  private finalizedBlockNumber: number = 0;
47
+ private checkpointedBlockNumber: number = 0;
48
+ private proposedCheckpointBlockNumber: number = 0;
31
49
 
32
50
  private log = createLogger('archiver:mock_l2_block_source');
33
51
 
52
+ /** Creates blocks grouped into single-block checkpoints. */
34
53
  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);
54
+ await this.createCheckpoints(numBlocks, 1);
55
+ }
56
+
57
+ public getCheckpointNumber(): Promise<CheckpointNumber> {
58
+ return Promise.resolve(
59
+ this.checkpointList.length === 0 ? CheckpointNumber.ZERO : CheckpointNumber(this.checkpointList.length),
60
+ );
61
+ }
62
+
63
+ /** Creates checkpoints, each containing `blocksPerCheckpoint` blocks. */
64
+ public async createCheckpoints(numCheckpoints: number, blocksPerCheckpoint: number = 1) {
65
+ for (let c = 0; c < numCheckpoints; c++) {
66
+ const checkpointNum = CheckpointNumber(this.checkpointList.length + 1);
67
+ const startBlockNum = this.l2Blocks.length + 1;
68
+ const slotNumber = SlotNumber(Number(checkpointNum));
69
+ const checkpoint = await Checkpoint.random(checkpointNum, {
70
+ numBlocks: blocksPerCheckpoint,
71
+ startBlockNumber: startBlockNum,
72
+ slotNumber,
73
+ checkpointNumber: checkpointNum,
74
+ });
75
+ this.checkpointList.push(checkpoint);
76
+ this.l2Blocks.push(...checkpoint.blocks);
39
77
  }
40
78
 
41
- this.log.verbose(`Created ${numBlocks} blocks in the mock L2 block source`);
79
+ this.log.verbose(
80
+ `Created ${numCheckpoints} checkpoints with ${blocksPerCheckpoint} blocks each in the mock L2 block source`,
81
+ );
42
82
  }
43
83
 
44
- public addBlocks(blocks: L2Block[]) {
84
+ public addProposedBlocks(blocks: L2Block[]) {
45
85
  this.l2Blocks.push(...blocks);
46
- this.log.verbose(`Added ${blocks.length} blocks to the mock L2 block source`);
86
+ this.log.verbose(`Added ${blocks.length} proposed blocks to the mock L2 block source`);
47
87
  }
48
88
 
49
89
  public removeBlocks(numBlocks: number) {
50
90
  this.l2Blocks = this.l2Blocks.slice(0, -numBlocks);
91
+ const maxBlockNum = this.l2Blocks.length;
92
+ // Remove any checkpoint whose last block is beyond the remaining blocks.
93
+ this.checkpointList = this.checkpointList.filter(c => {
94
+ const lastBlockNum = c.blocks[0].number + c.blocks.length - 1;
95
+ return lastBlockNum <= maxBlockNum;
96
+ });
97
+ // Keep tip numbers consistent with remaining blocks.
98
+ this.checkpointedBlockNumber = Math.min(this.checkpointedBlockNumber, maxBlockNum);
99
+ this.proposedCheckpointBlockNumber = Math.min(this.proposedCheckpointBlockNumber, maxBlockNum);
100
+ this.provenBlockNumber = Math.min(this.provenBlockNumber, maxBlockNum);
101
+ this.finalizedBlockNumber = Math.min(this.finalizedBlockNumber, maxBlockNum);
51
102
  this.log.verbose(`Removed ${numBlocks} blocks from the mock L2 block source`);
52
103
  }
53
104
 
@@ -62,6 +113,44 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
62
113
  this.finalizedBlockNumber = finalizedBlockNumber;
63
114
  }
64
115
 
116
+ public setProposedCheckpointBlockNumber(blockNumber: number) {
117
+ this.proposedCheckpointBlockNumber = blockNumber;
118
+ }
119
+
120
+ public setCheckpointedBlockNumber(checkpointedBlockNumber: number) {
121
+ const prevCheckpointed = this.checkpointedBlockNumber;
122
+ this.checkpointedBlockNumber = checkpointedBlockNumber;
123
+ // Proposed checkpoint is always at least as advanced as checkpointed
124
+ if (this.proposedCheckpointBlockNumber < checkpointedBlockNumber) {
125
+ this.proposedCheckpointBlockNumber = checkpointedBlockNumber;
126
+ }
127
+ // Auto-create single-block checkpoints for newly checkpointed blocks that don't have one yet.
128
+ // This handles blocks added via addProposedBlocks that are now being marked as checkpointed.
129
+ const newCheckpoints: Checkpoint[] = [];
130
+ for (let blockNum = prevCheckpointed + 1; blockNum <= checkpointedBlockNumber; blockNum++) {
131
+ const block = this.l2Blocks[blockNum - 1];
132
+ if (!block) {
133
+ continue;
134
+ }
135
+ if (this.checkpointList.some(c => c.blocks.some(b => b.number === block.number))) {
136
+ continue;
137
+ }
138
+ const checkpointNum = CheckpointNumber(this.checkpointList.length + newCheckpoints.length + 1);
139
+ const checkpoint = new Checkpoint(
140
+ block.archive,
141
+ CheckpointHeader.random({ slotNumber: block.header.globalVariables.slotNumber }),
142
+ [block],
143
+ checkpointNum,
144
+ );
145
+ newCheckpoints.push(checkpoint);
146
+ }
147
+ // Insert new checkpoints in order by number.
148
+ if (newCheckpoints.length > 0) {
149
+ this.checkpointList.push(...newCheckpoints);
150
+ this.checkpointList.sort((a, b) => a.number - b.number);
151
+ }
152
+ }
153
+
65
154
  /**
66
155
  * Method to fetch the rollup contract address at the base-layer.
67
156
  * @returns The rollup address.
@@ -83,11 +172,49 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
83
172
  * @returns In this mock instance, returns the number of L2 blocks that we've mocked.
84
173
  */
85
174
  public getBlockNumber() {
86
- return Promise.resolve(this.l2Blocks.length);
175
+ return Promise.resolve(BlockNumber(this.l2Blocks.length));
176
+ }
177
+
178
+ public getProvenBlockNumber() {
179
+ return Promise.resolve(BlockNumber(this.provenBlockNumber));
180
+ }
181
+
182
+ public getCheckpointedL2BlockNumber() {
183
+ return Promise.resolve(BlockNumber(this.checkpointedBlockNumber));
184
+ }
185
+
186
+ public getFinalizedL2BlockNumber() {
187
+ return Promise.resolve(BlockNumber(this.finalizedBlockNumber));
188
+ }
189
+
190
+ public getProposedCheckpointL2BlockNumber() {
191
+ return Promise.resolve(BlockNumber(this.proposedCheckpointBlockNumber));
192
+ }
193
+
194
+ public getCheckpointedBlock(number: BlockNumber): Promise<CheckpointedL2Block | undefined> {
195
+ if (number > this.checkpointedBlockNumber) {
196
+ return Promise.resolve(undefined);
197
+ }
198
+ const block = this.l2Blocks[number - 1];
199
+ if (!block) {
200
+ return Promise.resolve(undefined);
201
+ }
202
+ return Promise.resolve(this.toCheckpointedBlock(block));
87
203
  }
88
204
 
89
- public getProvenBlockNumber(): Promise<number> {
90
- return Promise.resolve(this.provenBlockNumber);
205
+ public async getCheckpointedBlocks(from: BlockNumber, limit: number): Promise<CheckpointedL2Block[]> {
206
+ const result: CheckpointedL2Block[] = [];
207
+ for (let i = 0; i < limit; i++) {
208
+ const blockNum = from + i;
209
+ if (blockNum > this.checkpointedBlockNumber) {
210
+ break;
211
+ }
212
+ const block = await this.getCheckpointedBlock(BlockNumber(blockNum));
213
+ if (block) {
214
+ result.push(block);
215
+ }
216
+ }
217
+ return result;
91
218
  }
92
219
 
93
220
  /**
@@ -95,8 +222,19 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
95
222
  * @param number - The block number to return (inclusive).
96
223
  * @returns The requested L2 block.
97
224
  */
98
- public getBlock(number: number) {
99
- return Promise.resolve(this.l2Blocks[number - 1]);
225
+ public getBlock(number: number): Promise<L2Block | undefined> {
226
+ const block = this.l2Blocks[number - 1];
227
+ return Promise.resolve(block);
228
+ }
229
+
230
+ /**
231
+ * Gets an L2 block (new format).
232
+ * @param number - The block number to return.
233
+ * @returns The requested L2 block.
234
+ */
235
+ public getL2Block(number: BlockNumber): Promise<L2Block | undefined> {
236
+ const block = this.l2Blocks[number - 1];
237
+ return Promise.resolve(block);
100
238
  }
101
239
 
102
240
  /**
@@ -105,70 +243,60 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
105
243
  * @param limit - The maximum number of blocks to return.
106
244
  * @returns The requested mocked L2 blocks.
107
245
  */
108
- public getBlocks(from: number, limit: number, proven?: boolean) {
246
+ public getBlocks(from: number, limit: number): Promise<L2Block[]> {
247
+ return Promise.resolve(this.l2Blocks.slice(from - 1, from - 1 + limit));
248
+ }
249
+
250
+ public getCheckpoints(from: CheckpointNumber, limit: number) {
251
+ const checkpoints = this.checkpointList.slice(from - 1, from - 1 + limit);
109
252
  return Promise.resolve(
110
- this.l2Blocks
111
- .slice(from - 1, from - 1 + limit)
112
- .filter(b => !proven || this.provenBlockNumber === undefined || b.number <= this.provenBlockNumber),
253
+ checkpoints.map(checkpoint => new PublishedCheckpoint(checkpoint, this.mockL1DataForCheckpoint(checkpoint), [])),
113
254
  );
114
255
  }
115
256
 
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
- );
257
+ public getCheckpointByArchive(archive: Fr): Promise<Checkpoint | undefined> {
258
+ const checkpoint = this.checkpointList.find(c => c.archive.root.equals(archive));
259
+ return Promise.resolve(checkpoint);
129
260
  }
130
261
 
131
- public async getPublishedBlockByHash(blockHash: Fr): Promise<PublishedL2Block | undefined> {
262
+ public async getCheckpointedBlockByHash(blockHash: BlockHash): Promise<CheckpointedL2Block | undefined> {
132
263
  for (const block of this.l2Blocks) {
133
264
  const hash = await block.hash();
134
265
  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
- });
266
+ return this.toCheckpointedBlock(block);
144
267
  }
145
268
  }
146
269
  return undefined;
147
270
  }
148
271
 
149
- public getPublishedBlockByArchive(archive: Fr): Promise<PublishedL2Block | undefined> {
272
+ public getCheckpointedBlockByArchive(archive: Fr): Promise<CheckpointedL2Block | undefined> {
150
273
  const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
151
274
  if (!block) {
152
275
  return Promise.resolve(undefined);
153
276
  }
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
- );
277
+ return Promise.resolve(this.toCheckpointedBlock(block));
165
278
  }
166
279
 
167
- public async getBlockHeaderByHash(blockHash: Fr): Promise<BlockHeader | undefined> {
280
+ public async getL2BlockByHash(blockHash: BlockHash): Promise<L2Block | undefined> {
168
281
  for (const block of this.l2Blocks) {
169
282
  const hash = await block.hash();
170
283
  if (hash.equals(blockHash)) {
171
- return block.getBlockHeader();
284
+ return block;
285
+ }
286
+ }
287
+ return undefined;
288
+ }
289
+
290
+ public getL2BlockByArchive(archive: Fr): Promise<L2Block | undefined> {
291
+ const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
292
+ return Promise.resolve(block);
293
+ }
294
+
295
+ public async getBlockHeaderByHash(blockHash: BlockHash): Promise<BlockHeader | undefined> {
296
+ for (const block of this.l2Blocks) {
297
+ const hash = await block.hash();
298
+ if (hash.equals(blockHash)) {
299
+ return block.header;
172
300
  }
173
301
  }
174
302
  return undefined;
@@ -176,26 +304,101 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
176
304
 
177
305
  public getBlockHeaderByArchive(archive: Fr): Promise<BlockHeader | undefined> {
178
306
  const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
179
- return Promise.resolve(block?.getBlockHeader());
307
+ return Promise.resolve(block?.header);
308
+ }
309
+
310
+ public async getBlockData(number: BlockNumber): Promise<BlockData | undefined> {
311
+ const block = this.l2Blocks[number - 1];
312
+ if (!block) {
313
+ return undefined;
314
+ }
315
+ return {
316
+ header: block.header,
317
+ archive: block.archive,
318
+ blockHash: await block.hash(),
319
+ checkpointNumber: block.checkpointNumber,
320
+ indexWithinCheckpoint: block.indexWithinCheckpoint,
321
+ };
322
+ }
323
+
324
+ public getCheckpointData(_n: CheckpointNumber): Promise<CheckpointData | undefined> {
325
+ return Promise.resolve(undefined);
326
+ }
327
+
328
+ public getCheckpointDataRange(_from: CheckpointNumber, _limit: number): Promise<CheckpointData[]> {
329
+ return Promise.resolve([]);
330
+ }
331
+
332
+ public getCheckpointNumberBySlot(_slot: SlotNumber): Promise<CheckpointNumber | undefined> {
333
+ return Promise.resolve(undefined);
334
+ }
335
+
336
+ public async getBlockDataWithCheckpointContext(number: BlockNumber) {
337
+ const data = await this.getBlockData(number);
338
+ if (!data) {
339
+ return undefined;
340
+ }
341
+ return { data, checkpoint: undefined, l1: undefined, attestations: [] };
342
+ }
343
+
344
+ public async getBlockDataByArchive(archive: Fr): Promise<BlockData | undefined> {
345
+ const block = this.l2Blocks.find(b => b.archive.root.equals(archive));
346
+ if (!block) {
347
+ return undefined;
348
+ }
349
+ return {
350
+ header: block.header,
351
+ archive: block.archive,
352
+ blockHash: await block.hash(),
353
+ checkpointNumber: block.checkpointNumber,
354
+ indexWithinCheckpoint: block.indexWithinCheckpoint,
355
+ };
180
356
  }
181
357
 
182
358
  getBlockHeader(number: number | 'latest'): Promise<BlockHeader | undefined> {
183
- return Promise.resolve(this.l2Blocks.at(typeof number === 'number' ? number - 1 : -1)?.getBlockHeader());
359
+ return Promise.resolve(this.l2Blocks.at(typeof number === 'number' ? number - 1 : -1)?.header);
184
360
  }
185
361
 
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
- });
362
+ getCheckpointsForEpoch(epochNumber: EpochNumber): Promise<Checkpoint[]> {
363
+ return Promise.resolve(this.getCheckpointsInEpoch(epochNumber));
364
+ }
365
+
366
+ getCheckpointsDataForEpoch(epochNumber: EpochNumber): Promise<CheckpointData[]> {
367
+ const checkpoints = this.getCheckpointsInEpoch(epochNumber);
368
+ return Promise.resolve(
369
+ checkpoints.map(
370
+ (checkpoint): CheckpointData => ({
371
+ checkpointNumber: checkpoint.number,
372
+ header: checkpoint.header,
373
+ archive: checkpoint.archive,
374
+ checkpointOutHash: computeCheckpointOutHash(
375
+ checkpoint.blocks.map(b => b.body.txEffects.map(tx => tx.l2ToL1Msgs)),
376
+ ),
377
+ startBlock: checkpoint.blocks[0].number,
378
+ blockCount: checkpoint.blocks.length,
379
+ feeAssetPriceModifier: checkpoint.feeAssetPriceModifier,
380
+ attestations: [],
381
+ l1: this.mockL1DataForCheckpoint(checkpoint),
382
+ }),
383
+ ),
384
+ );
385
+ }
386
+
387
+ getCheckpointedBlocksForEpoch(epochNumber: EpochNumber): Promise<CheckpointedL2Block[]> {
388
+ const checkpoints = this.getCheckpointsInEpoch(epochNumber);
389
+ return Promise.resolve(
390
+ checkpoints.flatMap(checkpoint => checkpoint.blocks.map(block => this.toCheckpointedBlock(block))),
391
+ );
392
+ }
393
+
394
+ getBlocksForSlot(slotNumber: SlotNumber): Promise<L2Block[]> {
395
+ const blocks = this.l2Blocks.filter(b => b.header.globalVariables.slotNumber === slotNumber);
193
396
  return Promise.resolve(blocks);
194
397
  }
195
398
 
196
- async getBlockHeadersForEpoch(epochNumber: EpochNumber): Promise<BlockHeader[]> {
197
- const blocks = await this.getBlocksForEpoch(epochNumber);
198
- return blocks.map(b => b.getBlockHeader());
399
+ async getCheckpointedBlockHeadersForEpoch(epochNumber: EpochNumber): Promise<BlockHeader[]> {
400
+ const checkpointedBlocks = await this.getCheckpointedBlocksForEpoch(epochNumber);
401
+ return checkpointedBlocks.map(b => b.block.header);
199
402
  }
200
403
 
201
404
  /**
@@ -214,7 +417,7 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
214
417
  return {
215
418
  data: txEffect,
216
419
  l2BlockNumber: block.number,
217
- l2BlockHash: L2BlockHash.fromField(await block.hash()),
420
+ l2BlockHash: await block.hash(),
218
421
  txIndexInBlock: block.body.txEffects.indexOf(txEffect),
219
422
  };
220
423
  }
@@ -228,13 +431,16 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
228
431
  for (const block of this.l2Blocks) {
229
432
  for (const txEffect of block.body.txEffects) {
230
433
  if (txEffect.txHash.equals(txHash)) {
434
+ // In mock, assume all txs are checkpointed with successful execution
231
435
  return new TxReceipt(
232
436
  txHash,
233
- TxStatus.SUCCESS,
234
- '',
437
+ TxStatus.CHECKPOINTED,
438
+ TxExecutionResult.SUCCESS,
439
+ undefined,
235
440
  txEffect.transactionFee.toBigInt(),
236
- L2BlockHash.fromField(await block.hash()),
441
+ await block.hash(),
237
442
  block.number,
443
+ getEpochAtSlot(block.slot, EmptyL1RollupConstants),
238
444
  );
239
445
  }
240
446
  }
@@ -243,37 +449,63 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
243
449
  }
244
450
 
245
451
  async getL2Tips(): Promise<L2Tips> {
246
- const [latest, proven, finalized] = [
452
+ const [latest, proven, finalized, checkpointed, proposedCheckpoint] = [
247
453
  await this.getBlockNumber(),
248
454
  await this.getProvenBlockNumber(),
249
455
  this.finalizedBlockNumber,
456
+ this.checkpointedBlockNumber,
457
+ await this.getProposedCheckpointL2BlockNumber(),
250
458
  ] as const;
251
459
 
252
460
  const latestBlock = this.l2Blocks[latest - 1];
253
461
  const provenBlock = this.l2Blocks[proven - 1];
254
462
  const finalizedBlock = this.l2Blocks[finalized - 1];
463
+ const checkpointedBlock = this.l2Blocks[checkpointed - 1];
464
+ const proposedCheckpointBlock = this.l2Blocks[proposedCheckpoint - 1];
255
465
 
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(),
466
+ const latestBlockId = {
467
+ number: BlockNumber(latest),
468
+ hash: (await latestBlock?.hash())?.toString(),
469
+ };
470
+ const provenBlockId = {
471
+ number: BlockNumber(proven),
472
+ hash: (await provenBlock?.hash())?.toString(),
473
+ };
474
+ const finalizedBlockId = {
475
+ number: BlockNumber(finalized),
476
+ hash: (await finalizedBlock?.hash())?.toString(),
477
+ };
478
+ const checkpointedBlockId = {
479
+ number: BlockNumber(checkpointed),
480
+ hash: (await checkpointedBlock?.hash())?.toString(),
481
+ };
482
+ const proposedCheckpointBlockId = {
483
+ number: BlockNumber(proposedCheckpoint),
484
+ hash: (await proposedCheckpointBlock?.hash())?.toString(),
485
+ };
486
+
487
+ const makeTipId = (blockId: typeof latestBlockId) => ({
488
+ block: blockId,
489
+ checkpoint: {
490
+ number: this.findCheckpointNumberForBlock(blockId.number) ?? CheckpointNumber(0),
491
+ hash: blockId.hash,
268
492
  },
493
+ });
494
+
495
+ return {
496
+ proposed: latestBlockId,
497
+ checkpointed: makeTipId(checkpointedBlockId),
498
+ proven: makeTipId(provenBlockId),
499
+ finalized: makeTipId(finalizedBlockId),
500
+ proposedCheckpoint: makeTipId(proposedCheckpointBlockId),
269
501
  };
270
502
  }
271
503
 
272
- getL2EpochNumber(): Promise<EpochNumber> {
504
+ getSyncedL2EpochNumber(): Promise<EpochNumber> {
273
505
  throw new Error('Method not implemented.');
274
506
  }
275
507
 
276
- getL2SlotNumber(): Promise<SlotNumber> {
508
+ getSyncedL2SlotNumber(): Promise<SlotNumber> {
277
509
  throw new Error('Method not implemented.');
278
510
  }
279
511
 
@@ -343,7 +575,49 @@ export class MockL2BlockSource implements L2BlockSource, ContractDataSource {
343
575
  return Promise.resolve(false);
344
576
  }
345
577
 
346
- getPendingChainValidationStatus(): Promise<ValidateBlockResult> {
578
+ getPendingChainValidationStatus(): Promise<ValidateCheckpointResult> {
347
579
  return Promise.resolve({ valid: true });
348
580
  }
581
+
582
+ getLastCheckpoint(): Promise<ProposedCheckpointData | undefined> {
583
+ return Promise.resolve(undefined);
584
+ }
585
+
586
+ getLastProposedCheckpoint(): Promise<ProposedCheckpointData | undefined> {
587
+ return Promise.resolve(undefined);
588
+ }
589
+
590
+ /** Returns checkpoints whose slot falls within the given epoch. */
591
+ private getCheckpointsInEpoch(epochNumber: EpochNumber): Checkpoint[] {
592
+ const epochDuration = DefaultL1ContractsConfig.aztecEpochDuration;
593
+ const [start, end] = getSlotRangeForEpoch(epochNumber, { epochDuration });
594
+ return this.checkpointList.filter(c => c.header.slotNumber >= start && c.header.slotNumber <= end);
595
+ }
596
+
597
+ /** Creates a mock L1PublishedData for a checkpoint. */
598
+ private mockL1DataForCheckpoint(checkpoint: Checkpoint): L1PublishedData {
599
+ return new L1PublishedData(BigInt(checkpoint.number), BigInt(checkpoint.number), Buffer32.random().toString());
600
+ }
601
+
602
+ /** Creates a CheckpointedL2Block from a block using stored checkpoint info. */
603
+ private toCheckpointedBlock(block: L2Block): CheckpointedL2Block {
604
+ const checkpoint = this.checkpointList.find(c => c.blocks.some(b => b.number === block.number));
605
+ const checkpointNumber = checkpoint?.number ?? block.checkpointNumber;
606
+ return new CheckpointedL2Block(
607
+ checkpointNumber,
608
+ block,
609
+ new L1PublishedData(
610
+ BigInt(block.number),
611
+ BigInt(block.number),
612
+ `0x${block.number.toString(16).padStart(64, '0')}`,
613
+ ),
614
+ [],
615
+ );
616
+ }
617
+
618
+ /** Finds the checkpoint number for a block, or undefined if the block is not in any checkpoint. */
619
+ private findCheckpointNumberForBlock(blockNumber: BlockNumber): CheckpointNumber | undefined {
620
+ const checkpoint = this.checkpointList.find(c => c.blocks.some(b => b.number === blockNumber));
621
+ return checkpoint?.number;
622
+ }
349
623
  }