@aztec/pxe 0.0.1-commit.1bea0213 → 0.0.1-commit.21ecf947b

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 (159) hide show
  1. package/dest/access_scopes.d.ts +9 -0
  2. package/dest/access_scopes.d.ts.map +1 -0
  3. package/dest/access_scopes.js +6 -0
  4. package/dest/block_synchronizer/block_synchronizer.d.ts +5 -3
  5. package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
  6. package/dest/block_synchronizer/block_synchronizer.js +9 -3
  7. package/dest/contract_function_simulator/contract_function_simulator.d.ts +54 -30
  8. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
  9. package/dest/contract_function_simulator/contract_function_simulator.js +170 -66
  10. package/dest/contract_function_simulator/oracle/interfaces.d.ts +9 -9
  11. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
  12. package/dest/contract_function_simulator/oracle/oracle.d.ts +5 -5
  13. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
  14. package/dest/contract_function_simulator/oracle/oracle.js +32 -20
  15. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +36 -36
  16. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
  17. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +74 -21
  18. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +48 -24
  19. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
  20. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +85 -61
  21. package/dest/contract_sync/contract_sync_service.d.ts +43 -0
  22. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -0
  23. package/dest/contract_sync/contract_sync_service.js +97 -0
  24. package/dest/contract_sync/helpers.d.ts +29 -0
  25. package/dest/contract_sync/helpers.d.ts.map +1 -0
  26. package/dest/contract_sync/{index.js → helpers.js} +13 -12
  27. package/dest/debug/pxe_debug_utils.d.ts +24 -10
  28. package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
  29. package/dest/debug/pxe_debug_utils.js +28 -18
  30. package/dest/entrypoints/client/bundle/index.d.ts +3 -1
  31. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  32. package/dest/entrypoints/client/bundle/index.js +2 -0
  33. package/dest/entrypoints/client/bundle/utils.d.ts +1 -1
  34. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  35. package/dest/entrypoints/client/bundle/utils.js +21 -7
  36. package/dest/entrypoints/client/lazy/index.d.ts +3 -1
  37. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  38. package/dest/entrypoints/client/lazy/index.js +2 -0
  39. package/dest/entrypoints/client/lazy/utils.d.ts +2 -2
  40. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  41. package/dest/entrypoints/client/lazy/utils.js +22 -8
  42. package/dest/entrypoints/pxe_creation_options.d.ts +3 -2
  43. package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
  44. package/dest/entrypoints/server/index.d.ts +4 -2
  45. package/dest/entrypoints/server/index.d.ts.map +1 -1
  46. package/dest/entrypoints/server/index.js +3 -1
  47. package/dest/entrypoints/server/utils.d.ts +1 -1
  48. package/dest/entrypoints/server/utils.d.ts.map +1 -1
  49. package/dest/entrypoints/server/utils.js +28 -9
  50. package/dest/events/event_service.d.ts +4 -5
  51. package/dest/events/event_service.d.ts.map +1 -1
  52. package/dest/events/event_service.js +5 -6
  53. package/dest/job_coordinator/job_coordinator.d.ts +3 -2
  54. package/dest/job_coordinator/job_coordinator.d.ts.map +1 -1
  55. package/dest/job_coordinator/job_coordinator.js +3 -2
  56. package/dest/logs/log_service.d.ts +7 -5
  57. package/dest/logs/log_service.d.ts.map +1 -1
  58. package/dest/logs/log_service.js +15 -25
  59. package/dest/notes/note_service.d.ts +7 -7
  60. package/dest/notes/note_service.d.ts.map +1 -1
  61. package/dest/notes/note_service.js +9 -9
  62. package/dest/notes_filter.d.ts +25 -0
  63. package/dest/notes_filter.d.ts.map +1 -0
  64. package/dest/notes_filter.js +4 -0
  65. package/dest/oracle_version.d.ts +3 -3
  66. package/dest/oracle_version.d.ts.map +1 -1
  67. package/dest/oracle_version.js +2 -2
  68. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
  69. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
  70. package/dest/private_kernel/hints/{compute_tx_include_by_timestamp.js → compute_tx_expiration_timestamp.js} +12 -12
  71. package/dest/private_kernel/hints/index.d.ts +1 -1
  72. package/dest/private_kernel/hints/index.js +1 -1
  73. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.js +4 -4
  74. package/dest/private_kernel/private_kernel_execution_prover.d.ts +3 -2
  75. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
  76. package/dest/private_kernel/private_kernel_execution_prover.js +8 -8
  77. package/dest/pxe.d.ts +69 -23
  78. package/dest/pxe.d.ts.map +1 -1
  79. package/dest/pxe.js +76 -46
  80. package/dest/storage/address_store/address_store.d.ts +1 -1
  81. package/dest/storage/address_store/address_store.d.ts.map +1 -1
  82. package/dest/storage/address_store/address_store.js +12 -11
  83. package/dest/storage/anchor_block_store/anchor_block_store.d.ts +9 -1
  84. package/dest/storage/anchor_block_store/anchor_block_store.d.ts.map +1 -1
  85. package/dest/storage/anchor_block_store/anchor_block_store.js +8 -1
  86. package/dest/storage/capsule_store/capsule_store.js +6 -8
  87. package/dest/storage/contract_store/contract_store.d.ts +1 -1
  88. package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
  89. package/dest/storage/contract_store/contract_store.js +27 -18
  90. package/dest/storage/metadata.d.ts +1 -1
  91. package/dest/storage/metadata.js +1 -1
  92. package/dest/storage/note_store/note_store.d.ts +13 -3
  93. package/dest/storage/note_store/note_store.d.ts.map +1 -1
  94. package/dest/storage/note_store/note_store.js +147 -107
  95. package/dest/storage/private_event_store/private_event_store.d.ts +1 -1
  96. package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -1
  97. package/dest/storage/private_event_store/private_event_store.js +84 -61
  98. package/dest/storage/private_event_store/stored_private_event.js +1 -1
  99. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +1 -1
  100. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
  101. package/dest/storage/tagging_store/recipient_tagging_store.js +31 -19
  102. package/dest/storage/tagging_store/sender_address_book_store.d.ts +1 -1
  103. package/dest/storage/tagging_store/sender_address_book_store.d.ts.map +1 -1
  104. package/dest/storage/tagging_store/sender_address_book_store.js +20 -14
  105. package/dest/storage/tagging_store/sender_tagging_store.d.ts +1 -1
  106. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
  107. package/dest/storage/tagging_store/sender_tagging_store.js +183 -113
  108. package/dest/tagging/get_all_logs_by_tags.d.ts +1 -1
  109. package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -1
  110. package/dest/tagging/get_all_logs_by_tags.js +17 -3
  111. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +4 -4
  112. package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +2 -2
  113. package/package.json +25 -16
  114. package/src/access_scopes.ts +9 -0
  115. package/src/block_synchronizer/block_synchronizer.ts +21 -12
  116. package/src/contract_function_simulator/contract_function_simulator.ts +318 -121
  117. package/src/contract_function_simulator/oracle/interfaces.ts +10 -10
  118. package/src/contract_function_simulator/oracle/oracle.ts +35 -18
  119. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +97 -101
  120. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +131 -63
  121. package/src/contract_sync/contract_sync_service.ts +152 -0
  122. package/src/contract_sync/{index.ts → helpers.ts} +21 -21
  123. package/src/debug/pxe_debug_utils.ts +63 -19
  124. package/src/entrypoints/client/bundle/index.ts +2 -0
  125. package/src/entrypoints/client/bundle/utils.ts +16 -15
  126. package/src/entrypoints/client/lazy/index.ts +2 -0
  127. package/src/entrypoints/client/lazy/utils.ts +17 -15
  128. package/src/entrypoints/pxe_creation_options.ts +2 -1
  129. package/src/entrypoints/server/index.ts +3 -1
  130. package/src/entrypoints/server/utils.ts +22 -26
  131. package/src/events/event_service.ts +4 -6
  132. package/src/job_coordinator/job_coordinator.ts +4 -3
  133. package/src/logs/log_service.ts +20 -32
  134. package/src/notes/note_service.ts +9 -10
  135. package/src/notes_filter.ts +26 -0
  136. package/src/oracle_version.ts +2 -2
  137. package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
  138. package/src/private_kernel/hints/index.ts +1 -1
  139. package/src/private_kernel/hints/private_kernel_reset_private_inputs_builder.ts +7 -7
  140. package/src/private_kernel/private_kernel_execution_prover.ts +12 -9
  141. package/src/pxe.ts +164 -92
  142. package/src/storage/address_store/address_store.ts +15 -15
  143. package/src/storage/anchor_block_store/anchor_block_store.ts +8 -0
  144. package/src/storage/capsule_store/capsule_store.ts +8 -8
  145. package/src/storage/contract_store/contract_store.ts +26 -15
  146. package/src/storage/metadata.ts +1 -1
  147. package/src/storage/note_store/note_store.ts +169 -132
  148. package/src/storage/private_event_store/private_event_store.ts +102 -81
  149. package/src/storage/private_event_store/stored_private_event.ts +1 -1
  150. package/src/storage/tagging_store/recipient_tagging_store.ts +31 -21
  151. package/src/storage/tagging_store/sender_address_book_store.ts +20 -14
  152. package/src/storage/tagging_store/sender_tagging_store.ts +210 -126
  153. package/src/tagging/get_all_logs_by_tags.ts +28 -4
  154. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +4 -4
  155. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +2 -2
  156. package/dest/contract_sync/index.d.ts +0 -23
  157. package/dest/contract_sync/index.d.ts.map +0 -1
  158. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts +0 -4
  159. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts.map +0 -1
@@ -20,6 +20,9 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
20
20
  /**
21
21
  * The oracle for an execution of utility contract functions.
22
22
  */ export class UtilityExecutionOracle {
23
+ isMisc = true;
24
+ isUtility = true;
25
+ contractLogger;
23
26
  contractAddress;
24
27
  authWitnesses;
25
28
  capsules;
@@ -29,7 +32,6 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
29
32
  keyStore;
30
33
  addressStore;
31
34
  aztecNode;
32
- anchorBlockStore;
33
35
  recipientTaggingStore;
34
36
  senderAddressBookStore;
35
37
  capsuleStore;
@@ -37,30 +39,23 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
37
39
  jobId;
38
40
  log;
39
41
  scopes;
40
- isMisc;
41
- isUtility;
42
- aztecNrDebugLog;
43
- constructor(contractAddress, /** List of transient auth witnesses to be used during this simulation */ authWitnesses, capsules, anchorBlockHeader, contractStore, noteStore, keyStore, addressStore, aztecNode, anchorBlockStore, recipientTaggingStore, senderAddressBookStore, capsuleStore, privateEventStore, jobId, log = createLogger('simulator:client_view_context'), scopes){
44
- this.contractAddress = contractAddress;
45
- this.authWitnesses = authWitnesses;
46
- this.capsules = capsules;
47
- this.anchorBlockHeader = anchorBlockHeader;
48
- this.contractStore = contractStore;
49
- this.noteStore = noteStore;
50
- this.keyStore = keyStore;
51
- this.addressStore = addressStore;
52
- this.aztecNode = aztecNode;
53
- this.anchorBlockStore = anchorBlockStore;
54
- this.recipientTaggingStore = recipientTaggingStore;
55
- this.senderAddressBookStore = senderAddressBookStore;
56
- this.capsuleStore = capsuleStore;
57
- this.privateEventStore = privateEventStore;
58
- this.jobId = jobId;
59
- this.log = log;
60
- this.scopes = scopes;
61
- this.isMisc = true;
62
- this.isUtility = true;
63
- this.aztecNrDebugLog = createLogger('aztec-nr:debug_log');
42
+ constructor(args){
43
+ this.contractAddress = args.contractAddress;
44
+ this.authWitnesses = args.authWitnesses;
45
+ this.capsules = args.capsules;
46
+ this.anchorBlockHeader = args.anchorBlockHeader;
47
+ this.contractStore = args.contractStore;
48
+ this.noteStore = args.noteStore;
49
+ this.keyStore = args.keyStore;
50
+ this.addressStore = args.addressStore;
51
+ this.aztecNode = args.aztecNode;
52
+ this.recipientTaggingStore = args.recipientTaggingStore;
53
+ this.senderAddressBookStore = args.senderAddressBookStore;
54
+ this.capsuleStore = args.capsuleStore;
55
+ this.privateEventStore = args.privateEventStore;
56
+ this.jobId = args.jobId;
57
+ this.log = args.log ?? createLogger('simulator:client_view_context');
58
+ this.scopes = args.scopes;
64
59
  }
65
60
  utilityAssertCompatibleOracleVersion(version) {
66
61
  if (version !== ORACLE_VERSION) {
@@ -78,24 +73,43 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
78
73
  * @param pkMHash - The master public key hash.
79
74
  * @returns A Promise that resolves to nullifier keys.
80
75
  * @throws If the keys are not registered in the key store.
81
- */ utilityGetKeyValidationRequest(pkMHash) {
76
+ * @throws If scopes are defined and the account is not in the scopes.
77
+ */ async utilityGetKeyValidationRequest(pkMHash) {
78
+ // If scopes are defined, check that the key belongs to an account in the scopes.
79
+ if (this.scopes !== 'ALL_SCOPES' && this.scopes.length > 0) {
80
+ let hasAccess = false;
81
+ for(let i = 0; i < this.scopes.length && !hasAccess; i++){
82
+ if (await this.keyStore.accountHasKey(this.scopes[i], pkMHash)) {
83
+ hasAccess = true;
84
+ }
85
+ }
86
+ if (!hasAccess) {
87
+ throw new Error(`Key validation request denied: no scoped account has a key with hash ${pkMHash.toString()}.`);
88
+ }
89
+ }
82
90
  return this.keyStore.getKeyValidationRequest(pkMHash, this.contractAddress);
83
91
  }
84
92
  /**
85
93
  * Fetches the index and sibling path of a leaf at a given block from the note hash tree.
86
- * @param blockHash - The block hash at which to get the membership witness.
87
- * @param leafValue - The leaf value
94
+ * @param anchorBlockHash - The hash of a block that contains the note hash tree root in which to find the membership
95
+ * witness.
96
+ * @param noteHash - The note hash to find in the note hash tree.
88
97
  * @returns The membership witness containing the leaf index and sibling path
89
- */ utilityGetNoteHashMembershipWitness(blockHash, leafValue) {
90
- return this.aztecNode.getNoteHashMembershipWitness(blockHash, leafValue);
98
+ */ utilityGetNoteHashMembershipWitness(anchorBlockHash, noteHash) {
99
+ return this.aztecNode.getNoteHashMembershipWitness(anchorBlockHash, noteHash);
91
100
  }
92
101
  /**
93
- * Fetches the index and sibling path of a leaf at a given block from the archive tree.
94
- * @param blockHash - The block hash at which to get the membership witness.
95
- * @param leafValue - The leaf value
102
+ * Fetches the index and sibling path of a block hash in the archive tree.
103
+ *
104
+ * Block hashes are the leaves of the archive tree. Each time a new block is added to the chain,
105
+ * its block hash is appended as a new leaf to the archive tree.
106
+ *
107
+ * @param anchorBlockHash - The hash of a block that contains the archive tree root in which to find the membership
108
+ * witness.
109
+ * @param blockHash - The block hash to find in the archive tree.
96
110
  * @returns The membership witness containing the leaf index and sibling path
97
- */ utilityGetArchiveMembershipWitness(blockHash, leafValue) {
98
- return this.aztecNode.getArchiveMembershipWitness(blockHash, leafValue);
111
+ */ utilityGetBlockHashMembershipWitness(anchorBlockHash, blockHash) {
112
+ return this.aztecNode.getBlockHashMembershipWitness(anchorBlockHash, blockHash);
99
113
  }
100
114
  /**
101
115
  * Returns a nullifier membership witness for a given nullifier at a given block.
@@ -129,7 +143,7 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
129
143
  * @param blockNumber - The number of a block of which to get the block header.
130
144
  * @returns Block extracted from a block with block number `blockNumber`.
131
145
  */ async utilityGetBlockHeader(blockNumber) {
132
- const anchorBlockNumber = (await this.anchorBlockStore.getBlockHeader()).getBlockNumber();
146
+ const anchorBlockNumber = this.anchorBlockHeader.getBlockNumber();
133
147
  if (blockNumber > anchorBlockNumber) {
134
148
  throw new Error(`Block number ${blockNumber} is higher than current block ${anchorBlockNumber}`);
135
149
  }
@@ -139,12 +153,11 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
139
153
  /**
140
154
  * Retrieve the complete address associated to a given address.
141
155
  * @param account - The account address.
142
- * @returns A complete address associated with the input address.
143
- * @throws An error if the account is not registered in the database.
144
- */ utilityGetPublicKeysAndPartialAddress(account) {
145
- return this.getCompleteAddress(account);
156
+ * @returns A complete address associated with the input address, or `undefined` if not registered.
157
+ */ utilityTryGetPublicKeysAndPartialAddress(account) {
158
+ return this.addressStore.getCompleteAddress(account);
146
159
  }
147
- async getCompleteAddress(account) {
160
+ async getCompleteAddressOrFail(account) {
148
161
  const completeAddress = await this.addressStore.getCompleteAddress(account);
149
162
  if (!completeAddress) {
150
163
  throw new Error(`No public key registered for address ${account}.
@@ -196,7 +209,7 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
196
209
  * @param status - The status of notes to fetch.
197
210
  * @returns Array of note data.
198
211
  */ async utilityGetNotes(owner, storageSlot, numSelects, selectByIndexes, selectByOffsets, selectByLengths, selectValues, selectComparators, sortByIndexes, sortByOffsets, sortByLengths, sortOrder, limit, offset, status) {
199
- const noteService = new NoteService(this.noteStore, this.aztecNode, this.anchorBlockStore, this.jobId);
212
+ const noteService = new NoteService(this.noteStore, this.aztecNode, this.anchorBlockHeader, this.jobId);
200
213
  const dbNotes = await noteService.getNotes(this.contractAddress, owner, storageSlot, status, this.scopes);
201
214
  return pickNotes(dbNotes, {
202
215
  selects: selectByIndexes.slice(0, numSelects).map((index, i)=>({
@@ -225,8 +238,11 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
225
238
  * @param innerNullifier - The inner nullifier.
226
239
  * @returns A boolean indicating whether the nullifier exists in the tree or not.
227
240
  */ async utilityCheckNullifierExists(innerNullifier) {
228
- const nullifier = await siloNullifier(this.contractAddress, innerNullifier);
229
- const [leafIndex] = await this.aztecNode.findLeavesIndexes('latest', MerkleTreeId.NULLIFIER_TREE, [
241
+ const [nullifier, anchorBlockHash] = await Promise.all([
242
+ siloNullifier(this.contractAddress, innerNullifier),
243
+ this.anchorBlockHeader.hash()
244
+ ]);
245
+ const [leafIndex] = await this.aztecNode.findLeavesIndexes(anchorBlockHash, MerkleTreeId.NULLIFIER_TREE, [
230
246
  nullifier
231
247
  ]);
232
248
  return leafIndex?.data !== undefined;
@@ -254,24 +270,32 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
254
270
  this.log.debug(`Oracle storage read: slots=[${slots.map((slot)=>slot.toString()).join(', ')}] address=${contractAddress.toString()} values=[${values.join(', ')}]`);
255
271
  return values;
256
272
  }
257
- utilityDebugLog(level, message, fields) {
273
+ /**
274
+ * Returns a per-contract logger whose output is prefixed with `contract_log::<name>(<addrAbbrev>)`.
275
+ */ async #getContractLogger() {
276
+ if (!this.contractLogger) {
277
+ const addrAbbrev = this.contractAddress.toString().slice(0, 10);
278
+ const name = await this.contractStore.getDebugContractName(this.contractAddress);
279
+ const module = name ? `contract_log::${name}(${addrAbbrev})` : `contract_log::${addrAbbrev}`;
280
+ // Purpose of instanceId is to distinguish logs from different instances of the same component. It makes sense
281
+ // to re-use jobId as instanceId here as executions of different PXE jobs are isolated.
282
+ this.contractLogger = createLogger(module, {
283
+ instanceId: this.jobId
284
+ });
285
+ }
286
+ return this.contractLogger;
287
+ }
288
+ async utilityLog(level, message, fields) {
258
289
  if (!LogLevels[level]) {
259
- throw new Error(`Invalid debug log level: ${level}`);
290
+ throw new Error(`Invalid log level: ${level}`);
260
291
  }
261
292
  const levelName = LogLevels[level];
262
- this.aztecNrDebugLog[levelName](`${applyStringFormatting(message, fields)}`);
293
+ const logger = await this.#getContractLogger();
294
+ logger[levelName](`${applyStringFormatting(message, fields)}`);
263
295
  }
264
296
  async utilityFetchTaggedLogs(pendingTaggedLogArrayBaseSlot) {
265
- const logService = new LogService(this.aztecNode, this.anchorBlockStore, this.keyStore, this.capsuleStore, this.recipientTaggingStore, this.senderAddressBookStore, this.addressStore, this.jobId);
266
- const noteService = new NoteService(this.noteStore, this.aztecNode, this.anchorBlockStore, this.jobId);
267
- // It is acceptable to run the following operations in parallel for several reasons:
268
- // 1. syncTaggedLogs does not write to the note store — it only stores the pending tagged logs in a capsule array,
269
- // which is then processed in Noir after this handler returns.
270
- // 2. Even if syncTaggedLogs did write to the note store, it would not cause inconsistent state.
271
- await Promise.all([
272
- logService.syncTaggedLogs(this.contractAddress, pendingTaggedLogArrayBaseSlot, this.scopes),
273
- noteService.syncNoteNullifiers(this.contractAddress)
274
- ]);
297
+ const logService = new LogService(this.aztecNode, this.anchorBlockHeader, this.keyStore, this.capsuleStore, this.recipientTaggingStore, this.senderAddressBookStore, this.addressStore, this.jobId, this.log.getBindings());
298
+ await logService.fetchTaggedLogs(this.contractAddress, pendingTaggedLogArrayBaseSlot, this.scopes);
275
299
  }
276
300
  /**
277
301
  * Validates all note and event validation requests enqueued via `enqueue_note_for_validation` and
@@ -291,9 +315,9 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
291
315
  // faster as we don't need to wait for the network round-trip.
292
316
  const noteValidationRequests = (await this.capsuleStore.readCapsuleArray(contractAddress, noteValidationRequestsArrayBaseSlot, this.jobId)).map(NoteValidationRequest.fromFields);
293
317
  const eventValidationRequests = (await this.capsuleStore.readCapsuleArray(contractAddress, eventValidationRequestsArrayBaseSlot, this.jobId)).map(EventValidationRequest.fromFields);
294
- const noteService = new NoteService(this.noteStore, this.aztecNode, this.anchorBlockStore, this.jobId);
318
+ const noteService = new NoteService(this.noteStore, this.aztecNode, this.anchorBlockHeader, this.jobId);
295
319
  const noteStorePromises = noteValidationRequests.map((request)=>noteService.validateAndStoreNote(request.contractAddress, request.owner, request.storageSlot, request.randomness, request.noteNonce, request.content, request.noteHash, request.nullifier, request.txHash, request.recipient));
296
- const eventService = new EventService(this.anchorBlockStore, this.aztecNode, this.privateEventStore, this.jobId);
320
+ const eventService = new EventService(this.anchorBlockHeader, this.aztecNode, this.privateEventStore, this.jobId);
297
321
  const eventStorePromises = eventValidationRequests.map((request)=>eventService.validateAndStoreEvent(request.contractAddress, request.eventTypeId, request.randomness, request.serializedEvent, request.eventCommitment, request.txHash, request.recipient));
298
322
  await Promise.all([
299
323
  ...noteStorePromises,
@@ -311,7 +335,7 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
311
335
  // We read all log retrieval requests and process them all concurrently. This makes the process much faster as we
312
336
  // don't need to wait for the network round-trip.
313
337
  const logRetrievalRequests = (await this.capsuleStore.readCapsuleArray(contractAddress, logRetrievalRequestsArrayBaseSlot, this.jobId)).map(LogRetrievalRequest.fromFields);
314
- const logService = new LogService(this.aztecNode, this.anchorBlockStore, this.keyStore, this.capsuleStore, this.recipientTaggingStore, this.senderAddressBookStore, this.addressStore, this.jobId);
338
+ const logService = new LogService(this.aztecNode, this.anchorBlockHeader, this.keyStore, this.capsuleStore, this.recipientTaggingStore, this.senderAddressBookStore, this.addressStore, this.jobId, this.log.getBindings());
315
339
  const maybeLogRetrievalResponses = await logService.bulkRetrieveLogs(logRetrievalRequests);
316
340
  // Requests are cleared once we're done.
317
341
  await this.capsuleStore.setCapsuleArray(contractAddress, logRetrievalRequestsArrayBaseSlot, [], this.jobId);
@@ -364,7 +388,7 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
364
388
  }
365
389
  async getSharedSecret(address, ephPk) {
366
390
  // TODO(#12656): return an app-siloed secret
367
- const recipientCompleteAddress = await this.getCompleteAddress(address);
391
+ const recipientCompleteAddress = await this.getCompleteAddressOrFail(address);
368
392
  const ivskM = await this.keyStore.getMasterSecretKey(recipientCompleteAddress.publicKeys.masterIncomingViewingPublicKey);
369
393
  const addressSecret = await computeAddressSecret(await recipientCompleteAddress.getPreaddress(), ivskM);
370
394
  return deriveEcdhSharedSecret(addressSecret, ephPk);
@@ -0,0 +1,43 @@
1
+ import type { Logger } from '@aztec/foundation/log';
2
+ import type { FunctionCall, FunctionSelector } from '@aztec/stdlib/abi';
3
+ import type { AztecAddress } from '@aztec/stdlib/aztec-address';
4
+ import type { AztecNode } from '@aztec/stdlib/interfaces/client';
5
+ import type { BlockHeader } from '@aztec/stdlib/tx';
6
+ import type { AccessScopes } from '../access_scopes.js';
7
+ import type { StagedStore } from '../job_coordinator/job_coordinator.js';
8
+ import type { ContractStore } from '../storage/contract_store/contract_store.js';
9
+ import type { NoteStore } from '../storage/note_store/note_store.js';
10
+ /**
11
+ * Service for syncing the private state of contracts and verifying that the PXE holds the current class artifact.
12
+ * It uses a cache to avoid redundant sync operations - the cache is wiped when the anchor block changes.
13
+ *
14
+ * TODO: The StagedStore naming is broken here. Figure out a better name.
15
+ */
16
+ export declare class ContractSyncService implements StagedStore {
17
+ #private;
18
+ private aztecNode;
19
+ private contractStore;
20
+ private noteStore;
21
+ private log;
22
+ readonly storeName = "contract_sync";
23
+ private syncedContracts;
24
+ private overriddenContracts;
25
+ constructor(aztecNode: AztecNode, contractStore: ContractStore, noteStore: NoteStore, log: Logger);
26
+ /** Sets contracts that should be skipped during sync for a specific job. */
27
+ setOverriddenContracts(jobId: string, addresses: Set<string>): void;
28
+ /**
29
+ * Ensures a contract's private state is synchronized and that the PXE holds the current class artifact.
30
+ * Uses a cache to avoid redundant sync operations - the cache is wiped when the anchor block changes.
31
+ * @param contractAddress - The address of the contract to sync.
32
+ * @param functionToInvokeAfterSync - The function selector that will be called after sync (used to validate it's
33
+ * not sync_state itself).
34
+ * @param utilityExecutor - Executor function for running the sync_state utility function.
35
+ * @param scopes - Access scopes to pass through to the utility executor (affects whose account's private state is discovered).
36
+ */
37
+ ensureContractSynced(contractAddress: AztecAddress, functionToInvokeAfterSync: FunctionSelector | null, utilityExecutor: (call: FunctionCall, scopes: AccessScopes) => Promise<any>, anchorBlockHeader: BlockHeader, jobId: string, scopes: AccessScopes): Promise<void>;
38
+ /** Clears sync cache. Called by BlockSynchronizer when anchor block changes. */
39
+ wipe(): void;
40
+ commit(jobId: string): Promise<void>;
41
+ discardStaged(jobId: string): Promise<void>;
42
+ }
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udHJhY3Rfc3luY19zZXJ2aWNlLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY29udHJhY3Rfc3luYy9jb250cmFjdF9zeW5jX3NlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDcEQsT0FBTyxLQUFLLEVBQUUsWUFBWSxFQUFFLGdCQUFnQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDeEUsT0FBTyxLQUFLLEVBQUUsWUFBWSxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDaEUsT0FBTyxLQUFLLEVBQUUsU0FBUyxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDakUsT0FBTyxLQUFLLEVBQUUsV0FBVyxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFcEQsT0FBTyxLQUFLLEVBQUUsWUFBWSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDeEQsT0FBTyxLQUFLLEVBQUUsV0FBVyxFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDekUsT0FBTyxLQUFLLEVBQUUsYUFBYSxFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFDakYsT0FBTyxLQUFLLEVBQUUsU0FBUyxFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFHckU7Ozs7O0dBS0c7QUFDSCxxQkFBYSxtQkFBb0IsWUFBVyxXQUFXOztJQVluRCxPQUFPLENBQUMsU0FBUztJQUNqQixPQUFPLENBQUMsYUFBYTtJQUNyQixPQUFPLENBQUMsU0FBUztJQUNqQixPQUFPLENBQUMsR0FBRztJQWRiLFFBQVEsQ0FBQyxTQUFTLG1CQUFtQjtJQUtyQyxPQUFPLENBQUMsZUFBZSxDQUF5QztJQUdoRSxPQUFPLENBQUMsbUJBQW1CLENBQXVDO0lBRWxFLFlBQ1UsU0FBUyxFQUFFLFNBQVMsRUFDcEIsYUFBYSxFQUFFLGFBQWEsRUFDNUIsU0FBUyxFQUFFLFNBQVMsRUFDcEIsR0FBRyxFQUFFLE1BQU0sRUFDakI7SUFFSiw0RUFBNEU7SUFDNUUsc0JBQXNCLENBQUMsS0FBSyxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsR0FBRyxDQUFDLE1BQU0sQ0FBQyxHQUFHLElBQUksQ0FFbEU7SUFFRDs7Ozs7Ozs7T0FRRztJQUNHLG9CQUFvQixDQUN4QixlQUFlLEVBQUUsWUFBWSxFQUM3Qix5QkFBeUIsRUFBRSxnQkFBZ0IsR0FBRyxJQUFJLEVBQ2xELGVBQWUsRUFBRSxDQUFDLElBQUksRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLFlBQVksS0FBSyxPQUFPLENBQUMsR0FBRyxDQUFDLEVBQzNFLGlCQUFpQixFQUFFLFdBQVcsRUFDOUIsS0FBSyxFQUFFLE1BQU0sRUFDYixNQUFNLEVBQUUsWUFBWSxHQUNuQixPQUFPLENBQUMsSUFBSSxDQUFDLENBdUNmO0lBNEJELGdGQUFnRjtJQUNoRixJQUFJLElBQUksSUFBSSxDQUdYO0lBRUQsTUFBTSxDQUFDLEtBQUssRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUluQztJQUVELGFBQWEsQ0FBQyxLQUFLLEVBQUUsTUFBTSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FNMUM7Q0FDRiJ9
@@ -0,0 +1 @@
1
+ {"version":3,"file":"contract_sync_service.d.ts","sourceRoot":"","sources":["../../src/contract_sync/contract_sync_service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,KAAK,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AACxE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAChE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAEpD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,uCAAuC,CAAC;AACzE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,6CAA6C,CAAC;AACjF,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qCAAqC,CAAC;AAGrE;;;;;GAKG;AACH,qBAAa,mBAAoB,YAAW,WAAW;;IAYnD,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,aAAa;IACrB,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,GAAG;IAdb,QAAQ,CAAC,SAAS,mBAAmB;IAKrC,OAAO,CAAC,eAAe,CAAyC;IAGhE,OAAO,CAAC,mBAAmB,CAAuC;IAElE,YACU,SAAS,EAAE,SAAS,EACpB,aAAa,EAAE,aAAa,EAC5B,SAAS,EAAE,SAAS,EACpB,GAAG,EAAE,MAAM,EACjB;IAEJ,4EAA4E;IAC5E,sBAAsB,CAAC,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,GAAG,CAAC,MAAM,CAAC,GAAG,IAAI,CAElE;IAED;;;;;;;;OAQG;IACG,oBAAoB,CACxB,eAAe,EAAE,YAAY,EAC7B,yBAAyB,EAAE,gBAAgB,GAAG,IAAI,EAClD,eAAe,EAAE,CAAC,IAAI,EAAE,YAAY,EAAE,MAAM,EAAE,YAAY,KAAK,OAAO,CAAC,GAAG,CAAC,EAC3E,iBAAiB,EAAE,WAAW,EAC9B,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,YAAY,GACnB,OAAO,CAAC,IAAI,CAAC,CAuCf;IA4BD,gFAAgF;IAChF,IAAI,IAAI,IAAI,CAGX;IAED,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAInC;IAED,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAM1C;CACF"}
@@ -0,0 +1,97 @@
1
+ import { syncState, verifyCurrentClassId } from './helpers.js';
2
+ /**
3
+ * Service for syncing the private state of contracts and verifying that the PXE holds the current class artifact.
4
+ * It uses a cache to avoid redundant sync operations - the cache is wiped when the anchor block changes.
5
+ *
6
+ * TODO: The StagedStore naming is broken here. Figure out a better name.
7
+ */ export class ContractSyncService {
8
+ aztecNode;
9
+ contractStore;
10
+ noteStore;
11
+ log;
12
+ storeName;
13
+ // Tracks contracts synced since last wipe. The cache is keyed per individual scope address
14
+ // (`contractAddress:scopeAddress`), or `contractAddress:*` for undefined scopes (all accounts).
15
+ // The value is a promise that resolves when the contract is synced.
16
+ syncedContracts;
17
+ // Per-job overridden contract addresses - these contracts should not be synced.
18
+ overriddenContracts;
19
+ constructor(aztecNode, contractStore, noteStore, log){
20
+ this.aztecNode = aztecNode;
21
+ this.contractStore = contractStore;
22
+ this.noteStore = noteStore;
23
+ this.log = log;
24
+ this.storeName = 'contract_sync';
25
+ this.syncedContracts = new Map();
26
+ this.overriddenContracts = new Map();
27
+ }
28
+ /** Sets contracts that should be skipped during sync for a specific job. */ setOverriddenContracts(jobId, addresses) {
29
+ this.overriddenContracts.set(jobId, addresses);
30
+ }
31
+ /**
32
+ * Ensures a contract's private state is synchronized and that the PXE holds the current class artifact.
33
+ * Uses a cache to avoid redundant sync operations - the cache is wiped when the anchor block changes.
34
+ * @param contractAddress - The address of the contract to sync.
35
+ * @param functionToInvokeAfterSync - The function selector that will be called after sync (used to validate it's
36
+ * not sync_state itself).
37
+ * @param utilityExecutor - Executor function for running the sync_state utility function.
38
+ * @param scopes - Access scopes to pass through to the utility executor (affects whose account's private state is discovered).
39
+ */ async ensureContractSynced(contractAddress, functionToInvokeAfterSync, utilityExecutor, anchorBlockHeader, jobId, scopes) {
40
+ // Skip sync if this contract has an override for this job (overrides are keyed by contract address only)
41
+ const overrides = this.overriddenContracts.get(jobId);
42
+ if (overrides?.has(contractAddress.toString())) {
43
+ return;
44
+ }
45
+ // Skip sync if we already synced for "all scopes", or if we have an empty list of scopes
46
+ const allScopesKey = toKey(contractAddress, 'ALL_SCOPES');
47
+ const allScopesExisting = this.syncedContracts.get(allScopesKey);
48
+ if (allScopesExisting || scopes !== 'ALL_SCOPES' && scopes.length == 0) {
49
+ return;
50
+ }
51
+ const unsyncedScopes = scopes === 'ALL_SCOPES' ? scopes : scopes.filter((scope)=>!this.syncedContracts.has(toKey(contractAddress, scope)));
52
+ const unsyncedScopesKeys = toKeys(contractAddress, unsyncedScopes);
53
+ if (unsyncedScopesKeys.length > 0) {
54
+ // Start sync and store the promise for all unsynced scopes
55
+ const promise = this.#doSync(contractAddress, functionToInvokeAfterSync, utilityExecutor, anchorBlockHeader, jobId, unsyncedScopes).catch((err)=>{
56
+ // There was an error syncing the contract, so we remove it from the cache so that it can be retried.
57
+ unsyncedScopesKeys.forEach((key)=>this.syncedContracts.delete(key));
58
+ throw err;
59
+ });
60
+ unsyncedScopesKeys.forEach((key)=>this.syncedContracts.set(key, promise));
61
+ }
62
+ const promises = toKeys(contractAddress, scopes).map((key)=>this.syncedContracts.get(key));
63
+ await Promise.all(promises);
64
+ }
65
+ async #doSync(contractAddress, functionToInvokeAfterSync, utilityExecutor, anchorBlockHeader, jobId, scopes) {
66
+ this.log.debug(`Syncing contract ${contractAddress}`);
67
+ await Promise.all([
68
+ syncState(contractAddress, this.contractStore, functionToInvokeAfterSync, utilityExecutor, this.noteStore, this.aztecNode, anchorBlockHeader, jobId, scopes),
69
+ verifyCurrentClassId(contractAddress, this.aztecNode, this.contractStore, anchorBlockHeader)
70
+ ]);
71
+ this.log.debug(`Contract ${contractAddress} synced`);
72
+ }
73
+ /** Clears sync cache. Called by BlockSynchronizer when anchor block changes. */ wipe() {
74
+ this.log.debug(`Wiping contract sync cache (${this.syncedContracts.size} entries)`);
75
+ this.syncedContracts.clear();
76
+ }
77
+ commit(jobId) {
78
+ // Clear overridden contracts for this job
79
+ this.overriddenContracts.delete(jobId);
80
+ return Promise.resolve();
81
+ }
82
+ discardStaged(jobId) {
83
+ // We clear the synced contracts cache here because, when the job is discarded, any associated database writes from
84
+ // the sync are also undone.
85
+ this.syncedContracts.clear();
86
+ this.overriddenContracts.delete(jobId);
87
+ return Promise.resolve();
88
+ }
89
+ }
90
+ function toKeys(contract, scopes) {
91
+ return scopes === 'ALL_SCOPES' ? [
92
+ toKey(contract, scopes)
93
+ ] : scopes.map((scope)=>toKey(contract, scope));
94
+ }
95
+ function toKey(contract, scope) {
96
+ return scope === 'ALL_SCOPES' ? `${contract.toString()}:*` : `${contract.toString()}:${scope.toString()}`;
97
+ }
@@ -0,0 +1,29 @@
1
+ import type { FunctionCall, FunctionSelector } from '@aztec/stdlib/abi';
2
+ import type { AztecAddress } from '@aztec/stdlib/aztec-address';
3
+ import type { ContractInstance } from '@aztec/stdlib/contract';
4
+ import type { AztecNode } from '@aztec/stdlib/interfaces/client';
5
+ import type { BlockHeader } from '@aztec/stdlib/tx';
6
+ import type { AccessScopes } from '../access_scopes.js';
7
+ import type { ContractStore } from '../storage/contract_store/contract_store.js';
8
+ import type { NoteStore } from '../storage/note_store/note_store.js';
9
+ /**
10
+ * Read the current class id of a contract from the execution data provider or AztecNode. If not found, class id
11
+ * from the instance is used.
12
+ * @param contractAddress - The address of the contract to read the class id for.
13
+ * @param instance - The instance of the contract.
14
+ * @param aztecNode - The Aztec node to query for storage.
15
+ * @param header - The header of the block at which to load the DelayedPublicMutable storing the class id.
16
+ * @returns The current class id.
17
+ */
18
+ export declare function readCurrentClassId(contractAddress: AztecAddress, instance: ContractInstance, aztecNode: AztecNode, header: BlockHeader): Promise<import("@aztec/foundation/schemas").Fr>;
19
+ export declare function syncState(contractAddress: AztecAddress, contractStore: ContractStore, functionToInvokeAfterSync: FunctionSelector | null, utilityExecutor: (privateSyncCall: FunctionCall, scopes: AccessScopes) => Promise<any>, noteStore: NoteStore, aztecNode: AztecNode, anchorBlockHeader: BlockHeader, jobId: string, scopes: AccessScopes): Promise<void>;
20
+ /**
21
+ * Verify that the current class id of a contract obtained from AztecNode is the same as the one in contract data
22
+ * provider (i.e. PXE's own storage).
23
+ * @param contractAddress - The address of the contract to verify.
24
+ * @param aztecNode - The Aztec node to query for storage.
25
+ * @param contractStore - The contract store to fetch the local instance from.
26
+ * @param header - The header of the block at which to verify the current class id.
27
+ */
28
+ export declare function verifyCurrentClassId(contractAddress: AztecAddress, aztecNode: AztecNode, contractStore: ContractStore, header: BlockHeader): Promise<void>;
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscGVycy5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbnRyYWN0X3N5bmMvaGVscGVycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEtBQUssRUFBRSxZQUFZLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUN4RSxPQUFPLEtBQUssRUFBRSxZQUFZLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUNoRSxPQUFPLEtBQUssRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRS9ELE9BQU8sS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ2pFLE9BQU8sS0FBSyxFQUFFLFdBQVcsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBRXBELE9BQU8sS0FBSyxFQUFFLFlBQVksRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRXhELE9BQU8sS0FBSyxFQUFFLGFBQWEsRUFBRSxNQUFNLDZDQUE2QyxDQUFDO0FBQ2pGLE9BQU8sS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBRXJFOzs7Ozs7OztHQVFHO0FBQ0gsd0JBQXNCLGtCQUFrQixDQUN0QyxlQUFlLEVBQUUsWUFBWSxFQUM3QixRQUFRLEVBQUUsZ0JBQWdCLEVBQzFCLFNBQVMsRUFBRSxTQUFTLEVBQ3BCLE1BQU0sRUFBRSxXQUFXLG1EQWFwQjtBQUVELHdCQUFzQixTQUFTLENBQzdCLGVBQWUsRUFBRSxZQUFZLEVBQzdCLGFBQWEsRUFBRSxhQUFhLEVBQzVCLHlCQUF5QixFQUFFLGdCQUFnQixHQUFHLElBQUksRUFDbEQsZUFBZSxFQUFFLENBQUMsZUFBZSxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsWUFBWSxLQUFLLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFDdEYsU0FBUyxFQUFFLFNBQVMsRUFDcEIsU0FBUyxFQUFFLFNBQVMsRUFDcEIsaUJBQWlCLEVBQUUsV0FBVyxFQUM5QixLQUFLLEVBQUUsTUFBTSxFQUNiLE1BQU0sRUFBRSxZQUFZLGlCQW9CckI7QUFFRDs7Ozs7OztHQU9HO0FBQ0gsd0JBQXNCLG9CQUFvQixDQUN4QyxlQUFlLEVBQUUsWUFBWSxFQUM3QixTQUFTLEVBQUUsU0FBUyxFQUNwQixhQUFhLEVBQUUsYUFBYSxFQUM1QixNQUFNLEVBQUUsV0FBVyxpQkFhcEIifQ==
@@ -0,0 +1 @@
1
+ {"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../../src/contract_sync/helpers.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AACxE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAChE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAE/D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAEpD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAExD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,6CAA6C,CAAC;AACjF,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qCAAqC,CAAC;AAErE;;;;;;;;GAQG;AACH,wBAAsB,kBAAkB,CACtC,eAAe,EAAE,YAAY,EAC7B,QAAQ,EAAE,gBAAgB,EAC1B,SAAS,EAAE,SAAS,EACpB,MAAM,EAAE,WAAW,mDAapB;AAED,wBAAsB,SAAS,CAC7B,eAAe,EAAE,YAAY,EAC7B,aAAa,EAAE,aAAa,EAC5B,yBAAyB,EAAE,gBAAgB,GAAG,IAAI,EAClD,eAAe,EAAE,CAAC,eAAe,EAAE,YAAY,EAAE,MAAM,EAAE,YAAY,KAAK,OAAO,CAAC,GAAG,CAAC,EACtF,SAAS,EAAE,SAAS,EACpB,SAAS,EAAE,SAAS,EACpB,iBAAiB,EAAE,WAAW,EAC9B,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,YAAY,iBAoBrB;AAED;;;;;;;GAOG;AACH,wBAAsB,oBAAoB,CACxC,eAAe,EAAE,YAAY,EAC7B,SAAS,EAAE,SAAS,EACpB,aAAa,EAAE,aAAa,EAC5B,MAAM,EAAE,WAAW,iBAapB"}
@@ -1,5 +1,6 @@
1
1
  import { ProtocolContractAddress, isProtocolContract } from '@aztec/protocol-contracts';
2
2
  import { DelayedPublicMutableValues, DelayedPublicMutableValuesWithHash } from '@aztec/stdlib/delayed-public-mutable';
3
+ import { NoteService } from '../notes/note_service.js';
3
4
  /**
4
5
  * Read the current class id of a contract from the execution data provider or AztecNode. If not found, class id
5
6
  * from the instance is used.
@@ -19,21 +20,30 @@ import { DelayedPublicMutableValues, DelayedPublicMutableValuesWithHash } from '
19
20
  }
20
21
  return currentClassId;
21
22
  }
22
- export async function syncState(contractAddress, contractStore, functionToInvokeAfterSync, utilityExecutor) {
23
+ export async function syncState(contractAddress, contractStore, functionToInvokeAfterSync, utilityExecutor, noteStore, aztecNode, anchorBlockHeader, jobId, scopes) {
23
24
  // Protocol contracts don't have private state to sync
24
25
  if (!isProtocolContract(contractAddress)) {
25
26
  const syncStateFunctionCall = await contractStore.getFunctionCall('sync_state', [], contractAddress);
26
27
  if (functionToInvokeAfterSync && functionToInvokeAfterSync.equals(syncStateFunctionCall.selector)) {
27
28
  throw new Error('Forbidden `sync_state` invocation. `sync_state` can only be invoked by PXE, manual execution can lead to inconsistencies.');
28
29
  }
29
- return utilityExecutor(syncStateFunctionCall);
30
+ const noteService = new NoteService(noteStore, aztecNode, anchorBlockHeader, jobId);
31
+ // Both sync_state and syncNoteNullifiers interact with the note store, but running them in parallel is safe
32
+ // because note store is designed to handle concurrent operations.
33
+ await Promise.all([
34
+ utilityExecutor(syncStateFunctionCall, scopes),
35
+ noteService.syncNoteNullifiers(contractAddress, scopes)
36
+ ]);
30
37
  }
31
38
  }
32
39
  /**
33
40
  * Verify that the current class id of a contract obtained from AztecNode is the same as the one in contract data
34
41
  * provider (i.e. PXE's own storage).
42
+ * @param contractAddress - The address of the contract to verify.
43
+ * @param aztecNode - The Aztec node to query for storage.
44
+ * @param contractStore - The contract store to fetch the local instance from.
35
45
  * @param header - The header of the block at which to verify the current class id.
36
- */ async function verifyCurrentClassId(contractAddress, aztecNode, contractStore, header) {
46
+ */ export async function verifyCurrentClassId(contractAddress, aztecNode, contractStore, header) {
37
47
  const instance = await contractStore.getContractInstance(contractAddress);
38
48
  if (!instance) {
39
49
  throw new Error(`No contract instance found for address ${contractAddress.toString()}`);
@@ -43,12 +53,3 @@ export async function syncState(contractAddress, contractStore, functionToInvoke
43
53
  throw new Error(`Contract ${contractAddress} is outdated, current class id is ${currentClassId}, local class id is ${instance.currentContractClassId}`);
44
54
  }
45
55
  }
46
- /**
47
- * Ensures the contract's private state is synchronized and that the PXE holds the current class artifact for
48
- * the contract.
49
- */ export async function ensureContractSynced(contractAddress, functionToInvokeAfterSync, utilityExecutor, aztecNode, contractStore, header) {
50
- await Promise.all([
51
- syncState(contractAddress, contractStore, functionToInvokeAfterSync, utilityExecutor),
52
- verifyCurrentClassId(contractAddress, aztecNode, contractStore, header)
53
- ]);
54
- }
@@ -1,6 +1,13 @@
1
- import type { NoteDao, NotesFilter } from '@aztec/stdlib/note';
2
- import type { PXE } from '../pxe.js';
3
- import type { ContractStore } from '../storage/contract_store/contract_store.js';
1
+ import type { FunctionCall } from '@aztec/stdlib/abi';
2
+ import type { AuthWitness } from '@aztec/stdlib/auth-witness';
3
+ import type { NoteDao } from '@aztec/stdlib/note';
4
+ import type { ContractOverrides } from '@aztec/stdlib/tx';
5
+ import type { AccessScopes } from '../access_scopes.js';
6
+ import type { BlockSynchronizer } from '../block_synchronizer/block_synchronizer.js';
7
+ import type { ContractFunctionSimulator } from '../contract_function_simulator/contract_function_simulator.js';
8
+ import type { ContractSyncService } from '../contract_sync/contract_sync_service.js';
9
+ import type { NotesFilter } from '../notes_filter.js';
10
+ import type { AnchorBlockStore } from '../storage/index.js';
4
11
  import type { NoteStore } from '../storage/note_store/note_store.js';
5
12
  /**
6
13
  * Methods provided by this class might help debugging but must not be used in production.
@@ -8,13 +15,15 @@ import type { NoteStore } from '../storage/note_store/note_store.js';
8
15
  */
9
16
  export declare class PXEDebugUtils {
10
17
  #private;
11
- private contractStore;
18
+ private contractSyncService;
12
19
  private noteStore;
13
- constructor(contractStore: ContractStore, noteStore: NoteStore);
14
- /**
15
- * Not injected through constructor since they're are co-dependant.
16
- */
17
- setPXE(pxe: PXE): void;
20
+ private blockStateSynchronizer;
21
+ private anchorBlockStore;
22
+ constructor(contractSyncService: ContractSyncService, noteStore: NoteStore, blockStateSynchronizer: BlockSynchronizer, anchorBlockStore: AnchorBlockStore);
23
+ /** Not injected through constructor since they're are co-dependant */
24
+ setPXEHelpers(putJobInQueue: <T>(job: (jobId: string) => Promise<T>) => Promise<T>, getSimulatorForTx: (overrides?: {
25
+ contracts?: ContractOverrides;
26
+ }) => ContractFunctionSimulator, simulateUtility: (contractFunctionSimulator: ContractFunctionSimulator, call: FunctionCall, authWitnesses: AuthWitness[] | undefined, scopes: AccessScopes, jobId: string) => Promise<any>): void;
18
27
  /**
19
28
  * A debugging utility to get notes based on the provided filter.
20
29
  *
@@ -27,5 +36,10 @@ export declare class PXEDebugUtils {
27
36
  * @returns The requested notes.
28
37
  */
29
38
  getNotes(filter: NotesFilter): Promise<NoteDao[]>;
39
+ /**
40
+ * Triggers a sync of the PXE with the node.
41
+ * Blocks until the sync is complete.
42
+ */
43
+ sync(): Promise<void>;
30
44
  }
31
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHhlX2RlYnVnX3V0aWxzLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZGVidWcvcHhlX2RlYnVnX3V0aWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sS0FBSyxFQUFFLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUUvRCxPQUFPLEtBQUssRUFBRSxHQUFHLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDckMsT0FBTyxLQUFLLEVBQUUsYUFBYSxFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFDakYsT0FBTyxLQUFLLEVBQUUsU0FBUyxFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFFckU7OztHQUdHO0FBQ0gscUJBQWEsYUFBYTs7SUFJdEIsT0FBTyxDQUFDLGFBQWE7SUFDckIsT0FBTyxDQUFDLFNBQVM7SUFGbkIsWUFDVSxhQUFhLEVBQUUsYUFBYSxFQUM1QixTQUFTLEVBQUUsU0FBUyxFQUMxQjtJQUVKOztPQUVHO0lBQ0ksTUFBTSxDQUFDLEdBQUcsRUFBRSxHQUFHLFFBRXJCO0lBRUQ7Ozs7Ozs7Ozs7T0FVRztJQUNVLFFBQVEsQ0FBQyxNQUFNLEVBQUUsV0FBVyxHQUFHLE9BQU8sQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQVU3RDtDQUNGIn0=
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHhlX2RlYnVnX3V0aWxzLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZGVidWcvcHhlX2RlYnVnX3V0aWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxFQUFFLFlBQVksRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3RELE9BQU8sS0FBSyxFQUFFLFdBQVcsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzlELE9BQU8sS0FBSyxFQUFFLE9BQU8sRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ2xELE9BQU8sS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFMUQsT0FBTyxLQUFLLEVBQUUsWUFBWSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDeEQsT0FBTyxLQUFLLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQztBQUNyRixPQUFPLEtBQUssRUFBRSx5QkFBeUIsRUFBRSxNQUFNLCtEQUErRCxDQUFDO0FBQy9HLE9BQU8sS0FBSyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDckYsT0FBTyxLQUFLLEVBQUUsV0FBVyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDdEQsT0FBTyxLQUFLLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUM1RCxPQUFPLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUVyRTs7O0dBR0c7QUFDSCxxQkFBYSxhQUFhOztJQVl0QixPQUFPLENBQUMsbUJBQW1CO0lBQzNCLE9BQU8sQ0FBQyxTQUFTO0lBQ2pCLE9BQU8sQ0FBQyxzQkFBc0I7SUFDOUIsT0FBTyxDQUFDLGdCQUFnQjtJQUoxQixZQUNVLG1CQUFtQixFQUFFLG1CQUFtQixFQUN4QyxTQUFTLEVBQUUsU0FBUyxFQUNwQixzQkFBc0IsRUFBRSxpQkFBaUIsRUFDekMsZ0JBQWdCLEVBQUUsZ0JBQWdCLEVBQ3hDO0lBRUosc0VBQXNFO0lBQy9ELGFBQWEsQ0FDbEIsYUFBYSxFQUFFLENBQUMsQ0FBQyxFQUFFLEdBQUcsRUFBRSxDQUFDLEtBQUssRUFBRSxNQUFNLEtBQUssT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFDcEUsaUJBQWlCLEVBQUUsQ0FBQyxTQUFTLENBQUMsRUFBRTtRQUFFLFNBQVMsQ0FBQyxFQUFFLGlCQUFpQixDQUFBO0tBQUUsS0FBSyx5QkFBeUIsRUFDL0YsZUFBZSxFQUFFLENBQ2YseUJBQXlCLEVBQUUseUJBQXlCLEVBQ3BELElBQUksRUFBRSxZQUFZLEVBQ2xCLGFBQWEsRUFBRSxXQUFXLEVBQUUsR0FBRyxTQUFTLEVBQ3hDLE1BQU0sRUFBRSxZQUFZLEVBQ3BCLEtBQUssRUFBRSxNQUFNLEtBQ1YsT0FBTyxDQUFDLEdBQUcsQ0FBQyxRQUtsQjtJQUVEOzs7Ozs7Ozs7O09BVUc7SUFDSSxRQUFRLENBQUMsTUFBTSxFQUFFLFdBQVcsR0FBRyxPQUFPLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FvQnZEO0lBRUQ7OztPQUdHO0lBQ0ksSUFBSSxJQUFJLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FFM0I7Q0FDRiJ9
@@ -1 +1 @@
1
- {"version":3,"file":"pxe_debug_utils.d.ts","sourceRoot":"","sources":["../../src/debug/pxe_debug_utils.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAE/D,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,WAAW,CAAC;AACrC,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,6CAA6C,CAAC;AACjF,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qCAAqC,CAAC;AAErE;;;GAGG;AACH,qBAAa,aAAa;;IAItB,OAAO,CAAC,aAAa;IACrB,OAAO,CAAC,SAAS;IAFnB,YACU,aAAa,EAAE,aAAa,EAC5B,SAAS,EAAE,SAAS,EAC1B;IAEJ;;OAEG;IACI,MAAM,CAAC,GAAG,EAAE,GAAG,QAErB;IAED;;;;;;;;;;OAUG;IACU,QAAQ,CAAC,MAAM,EAAE,WAAW,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC,CAU7D;CACF"}
1
+ {"version":3,"file":"pxe_debug_utils.d.ts","sourceRoot":"","sources":["../../src/debug/pxe_debug_utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AAC9D,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAE1D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,6CAA6C,CAAC;AACrF,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,+DAA+D,CAAC;AAC/G,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,2CAA2C,CAAC;AACrF,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAC5D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qCAAqC,CAAC;AAErE;;;GAGG;AACH,qBAAa,aAAa;;IAYtB,OAAO,CAAC,mBAAmB;IAC3B,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,sBAAsB;IAC9B,OAAO,CAAC,gBAAgB;IAJ1B,YACU,mBAAmB,EAAE,mBAAmB,EACxC,SAAS,EAAE,SAAS,EACpB,sBAAsB,EAAE,iBAAiB,EACzC,gBAAgB,EAAE,gBAAgB,EACxC;IAEJ,sEAAsE;IAC/D,aAAa,CAClB,aAAa,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,OAAO,CAAC,CAAC,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,EACpE,iBAAiB,EAAE,CAAC,SAAS,CAAC,EAAE;QAAE,SAAS,CAAC,EAAE,iBAAiB,CAAA;KAAE,KAAK,yBAAyB,EAC/F,eAAe,EAAE,CACf,yBAAyB,EAAE,yBAAyB,EACpD,IAAI,EAAE,YAAY,EAClB,aAAa,EAAE,WAAW,EAAE,GAAG,SAAS,EACxC,MAAM,EAAE,YAAY,EACpB,KAAK,EAAE,MAAM,KACV,OAAO,CAAC,GAAG,CAAC,QAKlB;IAED;;;;;;;;;;OAUG;IACI,QAAQ,CAAC,MAAM,EAAE,WAAW,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC,CAoBvD;IAED;;;OAGG;IACI,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,CAE3B;CACF"}
@@ -1,20 +1,24 @@
1
- import { randomBytes } from '@aztec/foundation/crypto/random';
2
1
  /**
3
2
  * Methods provided by this class might help debugging but must not be used in production.
4
3
  * No backwards compatibility or API stability should be expected. Use at your own risk.
5
4
  */ export class PXEDebugUtils {
6
- contractStore;
5
+ contractSyncService;
7
6
  noteStore;
8
- #pxe;
9
- constructor(contractStore, noteStore){
10
- this.contractStore = contractStore;
7
+ blockStateSynchronizer;
8
+ anchorBlockStore;
9
+ #putJobInQueue;
10
+ #getSimulatorForTx;
11
+ #simulateUtility;
12
+ constructor(contractSyncService, noteStore, blockStateSynchronizer, anchorBlockStore){
13
+ this.contractSyncService = contractSyncService;
11
14
  this.noteStore = noteStore;
12
- this.#pxe = undefined;
15
+ this.blockStateSynchronizer = blockStateSynchronizer;
16
+ this.anchorBlockStore = anchorBlockStore;
13
17
  }
14
- /**
15
- * Not injected through constructor since they're are co-dependant.
16
- */ setPXE(pxe) {
17
- this.#pxe = pxe;
18
+ /** Not injected through constructor since they're are co-dependant */ setPXEHelpers(putJobInQueue, getSimulatorForTx, simulateUtility) {
19
+ this.#putJobInQueue = putJobInQueue;
20
+ this.#getSimulatorForTx = getSimulatorForTx;
21
+ this.#simulateUtility = simulateUtility;
18
22
  }
19
23
  /**
20
24
  * A debugging utility to get notes based on the provided filter.
@@ -26,13 +30,19 @@ import { randomBytes } from '@aztec/foundation/crypto/random';
26
30
  *
27
31
  * @param filter - The filter to apply to the notes.
28
32
  * @returns The requested notes.
29
- */ async getNotes(filter) {
30
- if (!this.#pxe) {
31
- throw new Error('Cannot getNotes because no PXE is set');
32
- }
33
- // We need to manually trigger private state sync to have a guarantee that all the notes are available.
34
- const call = await this.contractStore.getFunctionCall('sync_state', [], filter.contractAddress);
35
- await this.#pxe.simulateUtility(call);
36
- return this.noteStore.getNotes(filter, randomBytes(8).toString('hex'));
33
+ */ getNotes(filter) {
34
+ return this.#putJobInQueue(async (jobId)=>{
35
+ await this.blockStateSynchronizer.sync();
36
+ const anchorBlockHeader = await this.anchorBlockStore.getBlockHeader();
37
+ const contractFunctionSimulator = this.#getSimulatorForTx();
38
+ await this.contractSyncService.ensureContractSynced(filter.contractAddress, null, async (privateSyncCall, execScopes)=>await this.#simulateUtility(contractFunctionSimulator, privateSyncCall, [], execScopes, jobId), anchorBlockHeader, jobId, filter.scopes);
39
+ return this.noteStore.getNotes(filter, jobId);
40
+ });
41
+ }
42
+ /**
43
+ * Triggers a sync of the PXE with the node.
44
+ * Blocks until the sync is complete.
45
+ */ sync() {
46
+ return this.#putJobInQueue(()=>this.blockStateSynchronizer.sync());
37
47
  }
38
48
  }
@@ -1,7 +1,9 @@
1
+ export * from '../../../access_scopes.js';
2
+ export * from '../../../notes_filter.js';
1
3
  export * from '../../../pxe.js';
2
4
  export * from '../../../config/index.js';
3
5
  export * from '../../../error_enriching.js';
4
6
  export * from '../../../storage/index.js';
5
7
  export * from './utils.js';
6
8
  export type { PXECreationOptions } from '../../pxe_creation_options.js';
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9lbnRyeXBvaW50cy9jbGllbnQvYnVuZGxlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyxZQUFZLENBQUM7QUFDM0IsWUFBWSxFQUFFLGtCQUFrQixFQUFFLE1BQU0sK0JBQStCLENBQUMifQ==
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9lbnRyeXBvaW50cy9jbGllbnQvYnVuZGxlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsWUFBWSxDQUFDO0FBQzNCLFlBQVksRUFBRSxrQkFBa0IsRUFBRSxNQUFNLCtCQUErQixDQUFDIn0=