@aztec/archiver 0.0.0-test.1 → 0.0.1-commit.1142ef1

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 (151) hide show
  1. package/README.md +27 -6
  2. package/dest/archiver/archiver.d.ts +204 -94
  3. package/dest/archiver/archiver.d.ts.map +1 -1
  4. package/dest/archiver/archiver.js +1616 -414
  5. package/dest/archiver/archiver_store.d.ts +178 -83
  6. package/dest/archiver/archiver_store.d.ts.map +1 -1
  7. package/dest/archiver/archiver_store_test_suite.d.ts +1 -1
  8. package/dest/archiver/archiver_store_test_suite.d.ts.map +1 -1
  9. package/dest/archiver/archiver_store_test_suite.js +2373 -397
  10. package/dest/archiver/config.d.ts +7 -22
  11. package/dest/archiver/config.d.ts.map +1 -1
  12. package/dest/archiver/config.js +30 -14
  13. package/dest/archiver/errors.d.ts +33 -1
  14. package/dest/archiver/errors.d.ts.map +1 -1
  15. package/dest/archiver/errors.js +49 -0
  16. package/dest/archiver/index.d.ts +3 -4
  17. package/dest/archiver/index.d.ts.map +1 -1
  18. package/dest/archiver/index.js +1 -2
  19. package/dest/archiver/instrumentation.d.ts +14 -6
  20. package/dest/archiver/instrumentation.d.ts.map +1 -1
  21. package/dest/archiver/instrumentation.js +45 -41
  22. package/dest/archiver/kv_archiver_store/block_store.d.ts +98 -21
  23. package/dest/archiver/kv_archiver_store/block_store.d.ts.map +1 -1
  24. package/dest/archiver/kv_archiver_store/block_store.js +495 -86
  25. package/dest/archiver/kv_archiver_store/contract_class_store.d.ts +4 -4
  26. package/dest/archiver/kv_archiver_store/contract_class_store.d.ts.map +1 -1
  27. package/dest/archiver/kv_archiver_store/contract_class_store.js +13 -19
  28. package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts +12 -9
  29. package/dest/archiver/kv_archiver_store/contract_instance_store.d.ts.map +1 -1
  30. package/dest/archiver/kv_archiver_store/contract_instance_store.js +30 -16
  31. package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts +81 -75
  32. package/dest/archiver/kv_archiver_store/kv_archiver_store.d.ts.map +1 -1
  33. package/dest/archiver/kv_archiver_store/kv_archiver_store.js +145 -83
  34. package/dest/archiver/kv_archiver_store/log_store.d.ts +12 -16
  35. package/dest/archiver/kv_archiver_store/log_store.d.ts.map +1 -1
  36. package/dest/archiver/kv_archiver_store/log_store.js +151 -114
  37. package/dest/archiver/kv_archiver_store/message_store.d.ts +25 -18
  38. package/dest/archiver/kv_archiver_store/message_store.d.ts.map +1 -1
  39. package/dest/archiver/kv_archiver_store/message_store.js +152 -49
  40. package/dest/archiver/l1/bin/retrieve-calldata.d.ts +3 -0
  41. package/dest/archiver/l1/bin/retrieve-calldata.d.ts.map +1 -0
  42. package/dest/archiver/l1/bin/retrieve-calldata.js +149 -0
  43. package/dest/archiver/l1/calldata_retriever.d.ts +112 -0
  44. package/dest/archiver/l1/calldata_retriever.d.ts.map +1 -0
  45. package/dest/archiver/l1/calldata_retriever.js +471 -0
  46. package/dest/archiver/l1/data_retrieval.d.ts +90 -0
  47. package/dest/archiver/l1/data_retrieval.d.ts.map +1 -0
  48. package/dest/archiver/l1/data_retrieval.js +331 -0
  49. package/dest/archiver/l1/debug_tx.d.ts +19 -0
  50. package/dest/archiver/l1/debug_tx.d.ts.map +1 -0
  51. package/dest/archiver/l1/debug_tx.js +73 -0
  52. package/dest/archiver/l1/spire_proposer.d.ts +70 -0
  53. package/dest/archiver/l1/spire_proposer.d.ts.map +1 -0
  54. package/dest/archiver/l1/spire_proposer.js +157 -0
  55. package/dest/archiver/l1/trace_tx.d.ts +97 -0
  56. package/dest/archiver/l1/trace_tx.d.ts.map +1 -0
  57. package/dest/archiver/l1/trace_tx.js +91 -0
  58. package/dest/archiver/l1/types.d.ts +12 -0
  59. package/dest/archiver/l1/types.d.ts.map +1 -0
  60. package/dest/archiver/l1/types.js +3 -0
  61. package/dest/archiver/l1/validate_trace.d.ts +29 -0
  62. package/dest/archiver/l1/validate_trace.d.ts.map +1 -0
  63. package/dest/archiver/l1/validate_trace.js +150 -0
  64. package/dest/archiver/structs/data_retrieval.d.ts +1 -1
  65. package/dest/archiver/structs/inbox_message.d.ts +15 -0
  66. package/dest/archiver/structs/inbox_message.d.ts.map +1 -0
  67. package/dest/archiver/structs/inbox_message.js +39 -0
  68. package/dest/archiver/structs/published.d.ts +2 -11
  69. package/dest/archiver/structs/published.d.ts.map +1 -1
  70. package/dest/archiver/structs/published.js +1 -1
  71. package/dest/archiver/validation.d.ts +17 -0
  72. package/dest/archiver/validation.d.ts.map +1 -0
  73. package/dest/archiver/validation.js +98 -0
  74. package/dest/factory.d.ts +9 -14
  75. package/dest/factory.d.ts.map +1 -1
  76. package/dest/factory.js +22 -52
  77. package/dest/index.d.ts +2 -2
  78. package/dest/index.d.ts.map +1 -1
  79. package/dest/index.js +1 -1
  80. package/dest/rpc/index.d.ts +2 -3
  81. package/dest/rpc/index.d.ts.map +1 -1
  82. package/dest/rpc/index.js +1 -4
  83. package/dest/test/index.d.ts +1 -1
  84. package/dest/test/mock_archiver.d.ts +16 -8
  85. package/dest/test/mock_archiver.d.ts.map +1 -1
  86. package/dest/test/mock_archiver.js +19 -14
  87. package/dest/test/mock_l1_to_l2_message_source.d.ts +9 -6
  88. package/dest/test/mock_l1_to_l2_message_source.d.ts.map +1 -1
  89. package/dest/test/mock_l1_to_l2_message_source.js +30 -7
  90. package/dest/test/mock_l2_block_source.d.ts +56 -13
  91. package/dest/test/mock_l2_block_source.d.ts.map +1 -1
  92. package/dest/test/mock_l2_block_source.js +196 -25
  93. package/dest/test/mock_structs.d.ts +10 -0
  94. package/dest/test/mock_structs.d.ts.map +1 -0
  95. package/dest/test/mock_structs.js +38 -0
  96. package/package.json +29 -30
  97. package/src/archiver/archiver.ts +1596 -512
  98. package/src/archiver/archiver_store.ts +205 -88
  99. package/src/archiver/archiver_store_test_suite.ts +2386 -354
  100. package/src/archiver/config.ts +38 -46
  101. package/src/archiver/errors.ts +85 -0
  102. package/src/archiver/index.ts +2 -3
  103. package/src/archiver/instrumentation.ts +65 -45
  104. package/src/archiver/kv_archiver_store/block_store.ts +668 -101
  105. package/src/archiver/kv_archiver_store/contract_class_store.ts +14 -24
  106. package/src/archiver/kv_archiver_store/contract_instance_store.ts +36 -28
  107. package/src/archiver/kv_archiver_store/kv_archiver_store.ts +197 -113
  108. package/src/archiver/kv_archiver_store/log_store.ts +204 -132
  109. package/src/archiver/kv_archiver_store/message_store.ts +213 -54
  110. package/src/archiver/l1/README.md +98 -0
  111. package/src/archiver/l1/bin/retrieve-calldata.ts +182 -0
  112. package/src/archiver/l1/calldata_retriever.ts +641 -0
  113. package/src/archiver/l1/data_retrieval.ts +512 -0
  114. package/src/archiver/l1/debug_tx.ts +99 -0
  115. package/src/archiver/l1/spire_proposer.ts +160 -0
  116. package/src/archiver/l1/trace_tx.ts +128 -0
  117. package/src/archiver/l1/types.ts +13 -0
  118. package/src/archiver/l1/validate_trace.ts +211 -0
  119. package/src/archiver/structs/inbox_message.ts +41 -0
  120. package/src/archiver/structs/published.ts +1 -11
  121. package/src/archiver/validation.ts +124 -0
  122. package/src/factory.ts +28 -69
  123. package/src/index.ts +1 -1
  124. package/src/rpc/index.ts +1 -5
  125. package/src/test/fixtures/debug_traceTransaction-multicall3.json +88 -0
  126. package/src/test/fixtures/debug_traceTransaction-multiplePropose.json +153 -0
  127. package/src/test/fixtures/debug_traceTransaction-proxied.json +122 -0
  128. package/src/test/fixtures/trace_transaction-multicall3.json +65 -0
  129. package/src/test/fixtures/trace_transaction-multiplePropose.json +319 -0
  130. package/src/test/fixtures/trace_transaction-proxied.json +128 -0
  131. package/src/test/fixtures/trace_transaction-randomRevert.json +216 -0
  132. package/src/test/mock_archiver.ts +22 -16
  133. package/src/test/mock_l1_to_l2_message_source.ts +26 -8
  134. package/src/test/mock_l2_block_source.ts +254 -31
  135. package/src/test/mock_structs.ts +50 -0
  136. package/dest/archiver/data_retrieval.d.ts +0 -74
  137. package/dest/archiver/data_retrieval.d.ts.map +0 -1
  138. package/dest/archiver/data_retrieval.js +0 -283
  139. package/dest/archiver/kv_archiver_store/nullifier_store.d.ts +0 -12
  140. package/dest/archiver/kv_archiver_store/nullifier_store.d.ts.map +0 -1
  141. package/dest/archiver/kv_archiver_store/nullifier_store.js +0 -73
  142. package/dest/archiver/memory_archiver_store/l1_to_l2_message_store.d.ts +0 -23
  143. package/dest/archiver/memory_archiver_store/l1_to_l2_message_store.d.ts.map +0 -1
  144. package/dest/archiver/memory_archiver_store/l1_to_l2_message_store.js +0 -49
  145. package/dest/archiver/memory_archiver_store/memory_archiver_store.d.ts +0 -175
  146. package/dest/archiver/memory_archiver_store/memory_archiver_store.d.ts.map +0 -1
  147. package/dest/archiver/memory_archiver_store/memory_archiver_store.js +0 -636
  148. package/src/archiver/data_retrieval.ts +0 -422
  149. package/src/archiver/kv_archiver_store/nullifier_store.ts +0 -97
  150. package/src/archiver/memory_archiver_store/l1_to_l2_message_store.ts +0 -61
  151. package/src/archiver/memory_archiver_store/memory_archiver_store.ts +0 -801
@@ -1,20 +1,23 @@
1
1
  import { toArray } from '@aztec/foundation/iterable';
2
2
  import { createLogger } from '@aztec/foundation/log';
3
3
  import { FunctionSelector } from '@aztec/stdlib/abi';
4
+ import { L2BlockHash } from '@aztec/stdlib/block';
5
+ import { join } from 'path';
4
6
  import { BlockStore } from './block_store.js';
5
7
  import { ContractClassStore } from './contract_class_store.js';
6
8
  import { ContractInstanceStore } from './contract_instance_store.js';
7
9
  import { LogStore } from './log_store.js';
8
10
  import { MessageStore } from './message_store.js';
9
- import { NullifierStore } from './nullifier_store.js';
11
+ export const ARCHIVER_DB_VERSION = 5;
12
+ export const MAX_FUNCTION_SIGNATURES = 1000;
13
+ export const MAX_FUNCTION_NAME_LEN = 256;
10
14
  /**
11
15
  * LMDB implementation of the ArchiverDataStore interface.
12
16
  */ export class KVArchiverDataStore {
13
17
  db;
14
- static SCHEMA_VERSION = 1;
18
+ static SCHEMA_VERSION = ARCHIVER_DB_VERSION;
15
19
  #blockStore;
16
20
  #logStore;
17
- #nullifierStore;
18
21
  #messageStore;
19
22
  #contractClassStore;
20
23
  #contractInstanceStore;
@@ -29,19 +32,36 @@ import { NullifierStore } from './nullifier_store.js';
29
32
  this.#messageStore = new MessageStore(db);
30
33
  this.#contractClassStore = new ContractClassStore(db);
31
34
  this.#contractInstanceStore = new ContractInstanceStore(db);
32
- this.#nullifierStore = new NullifierStore(db);
33
35
  }
34
- // TODO: These function names are in memory only as they are for development/debugging. They require the full contract
35
- // artifact supplied to the node out of band. This should be reviewed and potentially removed as part of
36
- // the node api cleanup process.
37
- getContractFunctionName(_address, selector) {
36
+ transactionAsync(callback) {
37
+ return this.db.transactionAsync(callback);
38
+ }
39
+ getBlockNumber() {
40
+ return this.#blockStore.getLatestL2BlockNumber();
41
+ }
42
+ async getContract(address, maybeTimestamp) {
43
+ const [header] = await this.getBlockHeaders(await this.getBlockNumber(), 1);
44
+ const timestamp = maybeTimestamp ?? header.globalVariables.timestamp;
45
+ return this.getContractInstance(address, timestamp);
46
+ }
47
+ async backupTo(path, compress = true) {
48
+ await this.db.backupTo(path, compress);
49
+ return join(path, 'data.mdb');
50
+ }
51
+ close() {
52
+ return this.db.close();
53
+ }
54
+ getDebugFunctionName(_address, selector) {
38
55
  return Promise.resolve(this.functionNames.get(selector.toString()));
39
56
  }
40
- async registerContractFunctionSignatures(_address, signatures) {
57
+ async registerContractFunctionSignatures(signatures) {
41
58
  for (const sig of signatures){
59
+ if (this.functionNames.size > MAX_FUNCTION_SIGNATURES) {
60
+ return;
61
+ }
42
62
  try {
43
63
  const selector = await FunctionSelector.fromSignature(sig);
44
- this.functionNames.set(selector.toString(), sig.slice(0, sig.indexOf('(')));
64
+ this.functionNames.set(selector.toString(), sig.slice(0, sig.indexOf('(')).slice(0, MAX_FUNCTION_NAME_LEN));
45
65
  } catch {
46
66
  this.#log.warn(`Failed to parse signature: ${sig}. Ignoring`);
47
67
  }
@@ -53,9 +73,11 @@ import { NullifierStore } from './nullifier_store.js';
53
73
  getContractClassIds() {
54
74
  return this.#contractClassStore.getContractClassIds();
55
75
  }
56
- async getContractInstance(address) {
57
- const contract = this.#contractInstanceStore.getContractInstance(address, await this.getSynchedL2BlockNumber());
58
- return contract;
76
+ getContractInstance(address, timestamp) {
77
+ return this.#contractInstanceStore.getContractInstance(address, timestamp);
78
+ }
79
+ getContractInstanceDeploymentBlockNumber(address) {
80
+ return this.#contractInstanceStore.getContractInstanceDeploymentBlockNumber(address);
59
81
  }
60
82
  async addContractClasses(data, bytecodeCommitments, blockNumber) {
61
83
  return (await Promise.all(data.map((c, i)=>this.#contractClassStore.addContractClass(c, bytecodeCommitments[i], blockNumber)))).every(Boolean);
@@ -66,45 +88,69 @@ import { NullifierStore } from './nullifier_store.js';
66
88
  getBytecodeCommitment(contractClassId) {
67
89
  return this.#contractClassStore.getBytecodeCommitment(contractClassId);
68
90
  }
69
- addFunctions(contractClassId, privateFunctions, unconstrainedFunctions) {
70
- return this.#contractClassStore.addFunctions(contractClassId, privateFunctions, unconstrainedFunctions);
91
+ addFunctions(contractClassId, privateFunctions, utilityFunctions) {
92
+ return this.#contractClassStore.addFunctions(contractClassId, privateFunctions, utilityFunctions);
71
93
  }
72
- async addContractInstances(data, _blockNumber) {
73
- return (await Promise.all(data.map((c)=>this.#contractInstanceStore.addContractInstance(c)))).every(Boolean);
94
+ async addContractInstances(data, blockNumber) {
95
+ return (await Promise.all(data.map((c)=>this.#contractInstanceStore.addContractInstance(c, blockNumber)))).every(Boolean);
74
96
  }
75
97
  async deleteContractInstances(data, _blockNumber) {
76
98
  return (await Promise.all(data.map((c)=>this.#contractInstanceStore.deleteContractInstance(c)))).every(Boolean);
77
99
  }
78
- async addContractInstanceUpdates(data, blockNumber) {
79
- return (await Promise.all(data.map((update, logIndex)=>this.#contractInstanceStore.addContractInstanceUpdate(update, blockNumber, logIndex)))).every(Boolean);
100
+ async addContractInstanceUpdates(data, timestamp) {
101
+ return (await Promise.all(data.map((update, logIndex)=>this.#contractInstanceStore.addContractInstanceUpdate(update, timestamp, logIndex)))).every(Boolean);
80
102
  }
81
- async deleteContractInstanceUpdates(data, blockNumber) {
82
- return (await Promise.all(data.map((update, logIndex)=>this.#contractInstanceStore.deleteContractInstanceUpdate(update, blockNumber, logIndex)))).every(Boolean);
103
+ async deleteContractInstanceUpdates(data, timestamp) {
104
+ return (await Promise.all(data.map((update, logIndex)=>this.#contractInstanceStore.deleteContractInstanceUpdate(update, timestamp, logIndex)))).every(Boolean);
83
105
  }
84
106
  /**
85
107
  * Append new blocks to the store's list.
86
108
  * @param blocks - The L2 blocks to be added to the store and the last processed L1 block.
87
109
  * @returns True if the operation is successful.
88
- */ addBlocks(blocks) {
89
- return this.#blockStore.addBlocks(blocks);
110
+ */ addBlocks(blocks, opts = {}) {
111
+ return this.#blockStore.addBlocks(blocks, opts);
112
+ }
113
+ getRangeOfCheckpoints(from, limit) {
114
+ return this.#blockStore.getRangeOfCheckpoints(from, limit);
115
+ }
116
+ getLatestBlockNumber() {
117
+ return this.#blockStore.getLatestBlockNumber();
90
118
  }
91
119
  /**
92
- * Unwinds blocks from the database
120
+ * Unwinds checkpoints from the database
93
121
  * @param from - The tip of the chain, passed for verification purposes,
94
122
  * ensuring that we don't end up deleting something we did not intend
95
- * @param blocksToUnwind - The number of blocks we are to unwind
123
+ * @param checkpointsToUnwind - The number of checkpoints we are to unwind
96
124
  * @returns True if the operation is successful
97
- */ unwindBlocks(from, blocksToUnwind) {
98
- return this.#blockStore.unwindBlocks(from, blocksToUnwind);
125
+ */ unwindCheckpoints(from, checkpointsToUnwind) {
126
+ return this.#blockStore.unwindCheckpoints(from, checkpointsToUnwind);
99
127
  }
100
- /**
101
- * Gets up to `limit` amount of L2 blocks starting from `from`.
102
- *
103
- * @param start - Number of the first block to return (inclusive).
104
- * @param limit - The number of blocks to return.
105
- * @returns The requested L2 blocks
106
- */ getBlocks(start, limit) {
107
- return toArray(this.#blockStore.getBlocks(start, limit));
128
+ addCheckpoints(checkpoints) {
129
+ return this.#blockStore.addCheckpoints(checkpoints);
130
+ }
131
+ getCheckpointedBlock(number) {
132
+ return this.#blockStore.getCheckpointedBlock(number);
133
+ }
134
+ getCheckpointedBlockByHash(blockHash) {
135
+ return this.#blockStore.getCheckpointedBlockByHash(blockHash);
136
+ }
137
+ getCheckpointedBlockByArchive(archive) {
138
+ return this.#blockStore.getCheckpointedBlockByArchive(archive);
139
+ }
140
+ getBlock(number) {
141
+ return this.#blockStore.getBlock(number);
142
+ }
143
+ getBlockByHash(blockHash) {
144
+ return this.#blockStore.getBlockByHash(L2BlockHash.fromField(blockHash));
145
+ }
146
+ getBlockByArchive(archive) {
147
+ return this.#blockStore.getBlockByArchive(archive);
148
+ }
149
+ getBlocks(from, limit) {
150
+ return toArray(this.#blockStore.getBlocks(from, limit));
151
+ }
152
+ getCheckpointedBlocks(from, limit) {
153
+ return toArray(this.#blockStore.getCheckpointedBlocks(from, limit));
108
154
  }
109
155
  /**
110
156
  * Gets up to `limit` amount of L2 blocks headers starting from `from`.
@@ -115,10 +161,16 @@ import { NullifierStore } from './nullifier_store.js';
115
161
  */ getBlockHeaders(start, limit) {
116
162
  return toArray(this.#blockStore.getBlockHeaders(start, limit));
117
163
  }
164
+ getBlockHeaderByHash(blockHash) {
165
+ return this.#blockStore.getBlockHeaderByHash(L2BlockHash.fromField(blockHash));
166
+ }
167
+ getBlockHeaderByArchive(archive) {
168
+ return this.#blockStore.getBlockHeaderByArchive(archive);
169
+ }
118
170
  /**
119
171
  * Gets a tx effect.
120
- * @param txHash - The txHash of the tx corresponding to the tx effect.
121
- * @returns The requested tx effect (or undefined if not found).
172
+ * @param txHash - The hash of the tx corresponding to the tx effect.
173
+ * @returns The requested tx effect with block info (or undefined if not found).
122
174
  */ getTxEffect(txHash) {
123
175
  return this.#blockStore.getTxEffect(txHash);
124
176
  }
@@ -139,26 +191,15 @@ import { NullifierStore } from './nullifier_store.js';
139
191
  deleteLogs(blocks) {
140
192
  return this.#logStore.deleteLogs(blocks);
141
193
  }
142
- /**
143
- * Append new nullifiers to the store's list.
144
- * @param blocks - The blocks for which to add the nullifiers.
145
- * @returns True if the operation is successful.
146
- */ addNullifiers(blocks) {
147
- return this.#nullifierStore.addNullifiers(blocks);
148
- }
149
- deleteNullifiers(blocks) {
150
- return this.#nullifierStore.deleteNullifiers(blocks);
151
- }
152
- findNullifiersIndexesWithBlock(blockNumber, nullifiers) {
153
- return this.#nullifierStore.findNullifiersIndexesWithBlock(blockNumber, nullifiers);
154
- }
155
194
  getTotalL1ToL2MessageCount() {
156
195
  return this.#messageStore.getTotalL1ToL2MessageCount();
157
196
  }
197
+ getLastL1ToL2Message() {
198
+ return this.#messageStore.getLastMessage();
199
+ }
158
200
  /**
159
201
  * Append L1 to L2 messages to the store.
160
- * @param messages - The L1 to L2 messages to be added to the store and the last processed L1 block.
161
- * @returns True if the operation is successful.
202
+ * @param messages - The L1 to L2 messages to be added to the store.
162
203
  */ addL1ToL2Messages(messages) {
163
204
  return this.#messageStore.addL1ToL2Messages(messages);
164
205
  }
@@ -170,28 +211,22 @@ import { NullifierStore } from './nullifier_store.js';
170
211
  return this.#messageStore.getL1ToL2MessageIndex(l1ToL2Message);
171
212
  }
172
213
  /**
173
- * Gets L1 to L2 message (to be) included in a given block.
174
- * @param blockNumber - L2 block number to get messages for.
214
+ * Gets L1 to L2 message (to be) included in a given checkpoint.
215
+ * @param checkpointNumber - Checkpoint number to get messages for.
175
216
  * @returns The L1 to L2 messages/leaves of the messages subtree (throws if not found).
176
- */ getL1ToL2Messages(blockNumber) {
177
- return this.#messageStore.getL1ToL2Messages(blockNumber);
217
+ */ getL1ToL2Messages(checkpointNumber) {
218
+ return this.#messageStore.getL1ToL2Messages(checkpointNumber);
178
219
  }
179
- /**
180
- * Retrieves all private logs from up to `limit` blocks, starting from the block number `from`.
181
- * @param from - The block number from which to begin retrieving logs.
182
- * @param limit - The maximum number of blocks to retrieve logs from.
183
- * @returns An array of private logs from the specified range of blocks.
184
- */ getPrivateLogs(from, limit) {
185
- return this.#logStore.getPrivateLogs(from, limit);
220
+ getPrivateLogsByTags(tags) {
221
+ try {
222
+ return this.#logStore.getPrivateLogsByTags(tags);
223
+ } catch (err) {
224
+ return Promise.reject(err);
225
+ }
186
226
  }
187
- /**
188
- * Gets all logs that match any of the received tags (i.e. logs with their first field equal to a tag).
189
- * @param tags - The tags to filter the logs by.
190
- * @returns For each received tag, an array of matching logs is returned. An empty array implies no logs match
191
- * that tag.
192
- */ getLogsByTags(tags) {
227
+ getPublicLogsByTagsFromContract(contractAddress, tags) {
193
228
  try {
194
- return this.#logStore.getLogsByTags(tags);
229
+ return this.#logStore.getPublicLogsByTagsFromContract(contractAddress, tags);
195
230
  } catch (err) {
196
231
  return Promise.reject(err);
197
232
  }
@@ -218,30 +253,27 @@ import { NullifierStore } from './nullifier_store.js';
218
253
  return Promise.reject(err);
219
254
  }
220
255
  }
221
- /**
222
- * Gets the number of the latest L2 block processed.
223
- * @returns The number of the latest L2 block processed.
224
- */ getSynchedL2BlockNumber() {
225
- return this.#blockStore.getSynchedL2BlockNumber();
226
- }
227
- getProvenL2BlockNumber() {
228
- return this.#blockStore.getProvenL2BlockNumber();
256
+ getProvenCheckpointNumber() {
257
+ return this.#blockStore.getProvenCheckpointNumber();
229
258
  }
230
- async setProvenL2BlockNumber(blockNumber) {
231
- await this.#blockStore.setProvenL2BlockNumber(blockNumber);
259
+ async setProvenCheckpointNumber(checkpointNumber) {
260
+ await this.#blockStore.setProvenCheckpointNumber(checkpointNumber);
232
261
  }
233
262
  async setBlockSynchedL1BlockNumber(l1BlockNumber) {
234
263
  await this.#blockStore.setSynchedL1BlockNumber(l1BlockNumber);
235
264
  }
236
- async setMessageSynchedL1BlockNumber(l1BlockNumber) {
237
- await this.#messageStore.setSynchedL1BlockNumber(l1BlockNumber);
265
+ async setMessageSynchedL1Block(l1Block) {
266
+ await this.#messageStore.setSynchedL1Block(l1Block);
267
+ }
268
+ getProvenBlockNumber() {
269
+ return this.#blockStore.getProvenBlockNumber();
238
270
  }
239
271
  /**
240
272
  * Gets the last L1 block number processed by the archiver
241
273
  */ async getSynchPoint() {
242
274
  const [blocksSynchedTo, messagesSynchedTo] = await Promise.all([
243
275
  this.#blockStore.getSynchedL1BlockNumber(),
244
- this.#messageStore.getSynchedL1BlockNumber()
276
+ this.#messageStore.getSynchedL1Block()
245
277
  ]);
246
278
  return {
247
279
  blocksSynchedTo,
@@ -251,4 +283,34 @@ import { NullifierStore } from './nullifier_store.js';
251
283
  estimateSize() {
252
284
  return this.db.estimateSize();
253
285
  }
286
+ rollbackL1ToL2MessagesToCheckpoint(targetCheckpointNumber) {
287
+ return this.#messageStore.rollbackL1ToL2MessagesToCheckpoint(targetCheckpointNumber);
288
+ }
289
+ iterateL1ToL2Messages(range = {}) {
290
+ return this.#messageStore.iterateL1ToL2Messages(range);
291
+ }
292
+ removeL1ToL2Messages(startIndex) {
293
+ return this.#messageStore.removeL1ToL2Messages(startIndex);
294
+ }
295
+ getPendingChainValidationStatus() {
296
+ return this.#blockStore.getPendingChainValidationStatus();
297
+ }
298
+ setPendingChainValidationStatus(status) {
299
+ return this.#blockStore.setPendingChainValidationStatus(status);
300
+ }
301
+ getCheckpointedL2BlockNumber() {
302
+ return this.#blockStore.getCheckpointedL2BlockNumber();
303
+ }
304
+ getSynchedCheckpointNumber() {
305
+ return this.#blockStore.getLatestCheckpointNumber();
306
+ }
307
+ async setCheckpointSynchedL1BlockNumber(l1BlockNumber) {
308
+ await this.#blockStore.setSynchedL1BlockNumber(l1BlockNumber);
309
+ }
310
+ getBlocksForCheckpoint(checkpointNumber) {
311
+ return this.#blockStore.getBlocksForCheckpoint(checkpointNumber);
312
+ }
313
+ getCheckpointData(checkpointNumber) {
314
+ return this.#blockStore.getCheckpointData(checkpointNumber);
315
+ }
254
316
  }
@@ -1,8 +1,8 @@
1
- import type { Fr } from '@aztec/foundation/fields';
2
1
  import type { AztecAsyncKVStore } from '@aztec/kv-store';
3
- import type { L2Block } from '@aztec/stdlib/block';
2
+ import type { AztecAddress } from '@aztec/stdlib/aztec-address';
3
+ import { L2BlockNew } from '@aztec/stdlib/block';
4
4
  import type { GetContractClassLogsResponse, GetPublicLogsResponse } from '@aztec/stdlib/interfaces/client';
5
- import { type LogFilter, PrivateLog, TxScopedL2Log } from '@aztec/stdlib/logs';
5
+ import { type LogFilter, type SiloedTag, Tag, TxScopedL2Log } from '@aztec/stdlib/logs';
6
6
  import type { BlockStore } from './block_store.js';
7
7
  /**
8
8
  * A store for logs
@@ -17,22 +17,18 @@ export declare class LogStore {
17
17
  * @param blocks - The blocks for which to add the logs.
18
18
  * @returns True if the operation is successful.
19
19
  */
20
- addLogs(blocks: L2Block[]): Promise<boolean>;
21
- deleteLogs(blocks: L2Block[]): Promise<boolean>;
20
+ addLogs(blocks: L2BlockNew[]): Promise<boolean>;
21
+ deleteLogs(blocks: L2BlockNew[]): Promise<boolean>;
22
22
  /**
23
- * Retrieves all private logs from up to `limit` blocks, starting from the block number `start`.
24
- * @param start - The block number from which to begin retrieving logs.
25
- * @param limit - The maximum number of blocks to retrieve logs from.
26
- * @returns An array of private logs from the specified range of blocks.
23
+ * Gets all private logs that match any of the `tags`. For each tag, an array of matching logs is returned. An empty
24
+ * array implies no logs match that tag.
27
25
  */
28
- getPrivateLogs(start: number, limit: number): Promise<PrivateLog[]>;
26
+ getPrivateLogsByTags(tags: SiloedTag[]): Promise<TxScopedL2Log[][]>;
29
27
  /**
30
- * Gets all logs that match any of the received tags (i.e. logs with their first field equal to a tag).
31
- * @param tags - The tags to filter the logs by.
32
- * @returns For each received tag, an array of matching logs is returned. An empty array implies no logs match
33
- * that tag.
28
+ * Gets all public logs that match any of the `tags` from the specified contract. For each tag, an array of matching
29
+ * logs is returned. An empty array implies no logs match that tag.
34
30
  */
35
- getLogsByTags(tags: Fr[]): Promise<TxScopedL2Log[][]>;
31
+ getPublicLogsByTagsFromContract(contractAddress: AztecAddress, tags: Tag[]): Promise<TxScopedL2Log[][]>;
36
32
  /**
37
33
  * Gets public logs based on the provided filter.
38
34
  * @param filter - The filter to apply to the logs.
@@ -46,4 +42,4 @@ export declare class LogStore {
46
42
  */
47
43
  getContractClassLogs(filter: LogFilter): Promise<GetContractClassLogsResponse>;
48
44
  }
49
- //# sourceMappingURL=log_store.d.ts.map
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nX3N0b3JlLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXJjaGl2ZXIva3ZfYXJjaGl2ZXJfc3RvcmUvbG9nX3N0b3JlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUtBLE9BQU8sS0FBSyxFQUFFLGlCQUFpQixFQUFpQixNQUFNLGlCQUFpQixDQUFDO0FBQ3hFLE9BQU8sS0FBSyxFQUFFLFlBQVksRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ2hFLE9BQU8sRUFBZSxVQUFVLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUM5RCxPQUFPLEtBQUssRUFBRSw0QkFBNEIsRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQzNHLE9BQU8sRUFJTCxLQUFLLFNBQVMsRUFHZCxLQUFLLFNBQVMsRUFDZCxHQUFHLEVBQ0gsYUFBYSxFQUNkLE1BQU0sb0JBQW9CLENBQUM7QUFFNUIsT0FBTyxLQUFLLEVBQUUsVUFBVSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFbkQ7O0dBRUc7QUFDSCxxQkFBYSxRQUFROztJQWFqQixPQUFPLENBQUMsRUFBRTtJQUNWLE9BQU8sQ0FBQyxVQUFVO0lBRnBCLFlBQ1UsRUFBRSxFQUFFLGlCQUFpQixFQUNyQixVQUFVLEVBQUUsVUFBVSxFQUM5QixlQUFlLEdBQUUsTUFBYSxFQVUvQjtJQStGRDs7OztPQUlHO0lBQ0gsT0FBTyxDQUFDLE1BQU0sRUFBRSxVQUFVLEVBQUUsR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLENBbUY5QztJQWdCRCxVQUFVLENBQUMsTUFBTSxFQUFFLFVBQVUsRUFBRSxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0EyQmpEO0lBRUQ7OztPQUdHO0lBQ0csb0JBQW9CLENBQUMsSUFBSSxFQUFFLFNBQVMsRUFBRSxHQUFHLE9BQU8sQ0FBQyxhQUFhLEVBQUUsRUFBRSxDQUFDLENBSXhFO0lBRUQ7OztPQUdHO0lBQ0csK0JBQStCLENBQUMsZUFBZSxFQUFFLFlBQVksRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLEdBQUcsT0FBTyxDQUFDLGFBQWEsRUFBRSxFQUFFLENBQUMsQ0FRNUc7SUFFRDs7OztPQUlHO0lBQ0gsYUFBYSxDQUFDLE1BQU0sRUFBRSxTQUFTLEdBQUcsT0FBTyxDQUFDLHFCQUFxQixDQUFDLENBUS9EO0lBNkVEOzs7O09BSUc7SUFDSCxvQkFBb0IsQ0FBQyxNQUFNLEVBQUUsU0FBUyxHQUFHLE9BQU8sQ0FBQyw0QkFBNEIsQ0FBQyxDQVE3RTtDQTZHRiJ9
@@ -1 +1 @@
1
- {"version":3,"file":"log_store.d.ts","sourceRoot":"","sources":["../../../src/archiver/kv_archiver_store/log_store.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAGnD,OAAO,KAAK,EAAE,iBAAiB,EAAiB,MAAM,iBAAiB,CAAC;AACxE,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,KAAK,EAAE,4BAA4B,EAAE,qBAAqB,EAAE,MAAM,iCAAiC,CAAC;AAC3G,OAAO,EAIL,KAAK,SAAS,EAEd,UAAU,EAEV,aAAa,EACd,MAAM,oBAAoB,CAAC;AAE5B,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAEnD;;GAEG;AACH,qBAAa,QAAQ;;IASP,OAAO,CAAC,EAAE;IAAqB,OAAO,CAAC,UAAU;gBAAzC,EAAE,EAAE,iBAAiB,EAAU,UAAU,EAAE,UAAU,EAAE,eAAe,GAAE,MAAa;IAsFzG;;;;OAIG;IACH,OAAO,CAAC,MAAM,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC;IAkE5C,UAAU,CAAC,MAAM,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC;IA0B/C;;;;;OAKG;IACG,cAAc,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;IAWzE;;;;;OAKG;IACG,aAAa,CAAC,IAAI,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,aAAa,EAAE,EAAE,CAAC;IAO3D;;;;OAIG;IACH,aAAa,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,qBAAqB,CAAC;IA+EhE;;;;OAIG;IACH,oBAAoB,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,4BAA4B,CAAC;CA6G/E"}
1
+ {"version":3,"file":"log_store.d.ts","sourceRoot":"","sources":["../../../src/archiver/kv_archiver_store/log_store.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,iBAAiB,EAAiB,MAAM,iBAAiB,CAAC;AACxE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAChE,OAAO,EAAe,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC9D,OAAO,KAAK,EAAE,4BAA4B,EAAE,qBAAqB,EAAE,MAAM,iCAAiC,CAAC;AAC3G,OAAO,EAIL,KAAK,SAAS,EAGd,KAAK,SAAS,EACd,GAAG,EACH,aAAa,EACd,MAAM,oBAAoB,CAAC;AAE5B,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAEnD;;GAEG;AACH,qBAAa,QAAQ;;IAajB,OAAO,CAAC,EAAE;IACV,OAAO,CAAC,UAAU;IAFpB,YACU,EAAE,EAAE,iBAAiB,EACrB,UAAU,EAAE,UAAU,EAC9B,eAAe,GAAE,MAAa,EAU/B;IA+FD;;;;OAIG;IACH,OAAO,CAAC,MAAM,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC,CAmF9C;IAgBD,UAAU,CAAC,MAAM,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC,CA2BjD;IAED;;;OAGG;IACG,oBAAoB,CAAC,IAAI,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,aAAa,EAAE,EAAE,CAAC,CAIxE;IAED;;;OAGG;IACG,+BAA+B,CAAC,eAAe,EAAE,YAAY,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,aAAa,EAAE,EAAE,CAAC,CAQ5G;IAED;;;;OAIG;IACH,aAAa,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,qBAAqB,CAAC,CAQ/D;IA6ED;;;;OAIG;IACH,oBAAoB,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,4BAA4B,CAAC,CAQ7E;CA6GF"}