@aztec/pxe 0.0.1-commit.934299a21 → 0.0.1-commit.949a33fd8

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 (223) hide show
  1. package/dest/bin/check_oracle_version.js +4 -4
  2. package/dest/block_synchronizer/block_stream_source.d.ts +10 -0
  3. package/dest/block_synchronizer/block_stream_source.d.ts.map +1 -0
  4. package/dest/block_synchronizer/block_stream_source.js +37 -0
  5. package/dest/block_synchronizer/block_synchronizer.d.ts +6 -2
  6. package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
  7. package/dest/block_synchronizer/block_synchronizer.js +30 -10
  8. package/dest/config/index.d.ts +2 -2
  9. package/dest/config/index.d.ts.map +1 -1
  10. package/dest/config/index.js +8 -15
  11. package/dest/contract_function_simulator/contract_function_simulator.d.ts +13 -5
  12. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
  13. package/dest/contract_function_simulator/contract_function_simulator.js +39 -13
  14. package/dest/contract_function_simulator/ephemeral_array_service.d.ts +28 -0
  15. package/dest/contract_function_simulator/ephemeral_array_service.d.ts.map +1 -0
  16. package/dest/contract_function_simulator/ephemeral_array_service.js +78 -0
  17. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +7 -7
  18. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -1
  19. package/dest/contract_function_simulator/execution_tagging_index_cache.js +19 -11
  20. package/dest/contract_function_simulator/index.d.ts +2 -1
  21. package/dest/contract_function_simulator/index.d.ts.map +1 -1
  22. package/dest/contract_function_simulator/index.js +1 -0
  23. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +4 -6
  24. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts.map +1 -1
  25. package/dest/contract_function_simulator/noir-structs/event_validation_request.js +8 -10
  26. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts +1 -1
  27. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.js +1 -1
  28. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts +2 -2
  29. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts.map +1 -1
  30. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.js +2 -4
  31. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +4 -7
  32. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
  33. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +6 -11
  34. package/dest/contract_function_simulator/oracle/interfaces.d.ts +63 -45
  35. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
  36. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts +9 -0
  37. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts.map +1 -0
  38. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.js +47 -0
  39. package/dest/contract_function_simulator/oracle/oracle.d.ts +76 -44
  40. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
  41. package/dest/contract_function_simulator/oracle/oracle.js +288 -96
  42. package/dest/contract_function_simulator/oracle/private_execution.js +5 -3
  43. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +32 -59
  44. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
  45. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +67 -86
  46. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +100 -60
  47. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
  48. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +326 -111
  49. package/dest/contract_function_simulator/pick_notes.d.ts +1 -1
  50. package/dest/contract_function_simulator/pick_notes.d.ts.map +1 -1
  51. package/dest/contract_function_simulator/pick_notes.js +20 -3
  52. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts +1 -1
  53. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts.map +1 -1
  54. package/dest/contract_function_simulator/proxied_contract_data_source.js +3 -0
  55. package/dest/contract_logging.d.ts +9 -4
  56. package/dest/contract_logging.d.ts.map +1 -1
  57. package/dest/contract_logging.js +21 -6
  58. package/dest/contract_sync/contract_sync_service.d.ts +6 -5
  59. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -1
  60. package/dest/contract_sync/contract_sync_service.js +62 -43
  61. package/dest/contract_sync/helpers.d.ts +2 -3
  62. package/dest/contract_sync/helpers.d.ts.map +1 -1
  63. package/dest/contract_sync/helpers.js +7 -2
  64. package/dest/debug/pxe_debug_utils.d.ts +3 -3
  65. package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
  66. package/dest/entrypoints/client/bundle/index.d.ts +1 -2
  67. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  68. package/dest/entrypoints/client/bundle/index.js +0 -1
  69. package/dest/entrypoints/client/bundle/utils.d.ts +2 -2
  70. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  71. package/dest/entrypoints/client/bundle/utils.js +2 -2
  72. package/dest/entrypoints/client/lazy/index.d.ts +1 -2
  73. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  74. package/dest/entrypoints/client/lazy/index.js +0 -1
  75. package/dest/entrypoints/client/lazy/utils.d.ts +2 -2
  76. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  77. package/dest/entrypoints/client/lazy/utils.js +2 -2
  78. package/dest/entrypoints/pxe_creation_options.d.ts +3 -1
  79. package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
  80. package/dest/entrypoints/pxe_creation_options.js +3 -1
  81. package/dest/entrypoints/server/index.d.ts +2 -3
  82. package/dest/entrypoints/server/index.d.ts.map +1 -1
  83. package/dest/entrypoints/server/index.js +1 -2
  84. package/dest/entrypoints/server/utils.d.ts +2 -2
  85. package/dest/entrypoints/server/utils.d.ts.map +1 -1
  86. package/dest/entrypoints/server/utils.js +2 -2
  87. package/dest/events/event_service.d.ts +3 -2
  88. package/dest/events/event_service.d.ts.map +1 -1
  89. package/dest/events/event_service.js +26 -5
  90. package/dest/events/private_event_filter_validator.d.ts +3 -2
  91. package/dest/events/private_event_filter_validator.d.ts.map +1 -1
  92. package/dest/events/private_event_filter_validator.js +15 -0
  93. package/dest/logs/log_service.d.ts +7 -8
  94. package/dest/logs/log_service.d.ts.map +1 -1
  95. package/dest/logs/log_service.js +29 -39
  96. package/dest/messages/message_context_service.d.ts +17 -0
  97. package/dest/messages/message_context_service.d.ts.map +1 -0
  98. package/dest/messages/message_context_service.js +36 -0
  99. package/dest/notes/note_service.d.ts +4 -5
  100. package/dest/notes/note_service.d.ts.map +1 -1
  101. package/dest/notes/note_service.js +14 -5
  102. package/dest/notes_filter.d.ts +2 -3
  103. package/dest/notes_filter.d.ts.map +1 -1
  104. package/dest/oracle_version.d.ts +4 -3
  105. package/dest/oracle_version.d.ts.map +1 -1
  106. package/dest/oracle_version.js +20 -10
  107. package/dest/private_kernel/private_kernel_execution_prover.d.ts +1 -1
  108. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
  109. package/dest/private_kernel/private_kernel_execution_prover.js +4 -7
  110. package/dest/private_kernel/private_kernel_oracle.d.ts +5 -5
  111. package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
  112. package/dest/private_kernel/private_kernel_oracle.js +12 -15
  113. package/dest/pxe.d.ts +25 -10
  114. package/dest/pxe.d.ts.map +1 -1
  115. package/dest/pxe.js +91 -42
  116. package/dest/storage/anchor_block_store/anchor_block_store.js +1 -1
  117. package/dest/storage/capsule_store/capsule_service.d.ts +21 -0
  118. package/dest/storage/capsule_store/capsule_service.d.ts.map +1 -0
  119. package/dest/storage/capsule_store/capsule_service.js +50 -0
  120. package/dest/storage/capsule_store/capsule_store.d.ts +9 -9
  121. package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -1
  122. package/dest/storage/capsule_store/capsule_store.js +36 -28
  123. package/dest/storage/capsule_store/index.d.ts +2 -1
  124. package/dest/storage/capsule_store/index.d.ts.map +1 -1
  125. package/dest/storage/capsule_store/index.js +1 -0
  126. package/dest/storage/contract_store/contract_store.d.ts +1 -1
  127. package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
  128. package/dest/storage/contract_store/contract_store.js +4 -2
  129. package/dest/storage/metadata.d.ts +1 -1
  130. package/dest/storage/metadata.js +1 -1
  131. package/dest/storage/note_store/note_store.d.ts +1 -1
  132. package/dest/storage/note_store/note_store.d.ts.map +1 -1
  133. package/dest/storage/note_store/note_store.js +2 -2
  134. package/dest/storage/private_event_store/private_event_store.d.ts +1 -1
  135. package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -1
  136. package/dest/storage/private_event_store/private_event_store.js +3 -0
  137. package/dest/storage/private_event_store/stored_private_event.js +1 -1
  138. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +6 -6
  139. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
  140. package/dest/storage/tagging_store/sender_tagging_store.d.ts +29 -28
  141. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
  142. package/dest/storage/tagging_store/sender_tagging_store.js +141 -115
  143. package/dest/tagging/index.d.ts +3 -3
  144. package/dest/tagging/index.d.ts.map +1 -1
  145. package/dest/tagging/index.js +1 -1
  146. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +4 -5
  147. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +1 -1
  148. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +4 -18
  149. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +6 -7
  150. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +1 -1
  151. package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +12 -11
  152. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +4 -8
  153. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
  154. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +13 -7
  155. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +4 -3
  156. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -1
  157. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +20 -10
  158. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +5 -7
  159. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -1
  160. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +36 -24
  161. package/package.json +16 -16
  162. package/src/bin/check_oracle_version.ts +4 -4
  163. package/src/block_synchronizer/block_stream_source.ts +52 -0
  164. package/src/block_synchronizer/block_synchronizer.ts +33 -11
  165. package/src/config/index.ts +3 -9
  166. package/src/contract_function_simulator/contract_function_simulator.ts +52 -16
  167. package/src/contract_function_simulator/ephemeral_array_service.ts +110 -0
  168. package/src/contract_function_simulator/execution_tagging_index_cache.ts +19 -14
  169. package/src/contract_function_simulator/index.ts +1 -0
  170. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +9 -9
  171. package/src/contract_function_simulator/noir-structs/log_retrieval_request.ts +1 -1
  172. package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +2 -5
  173. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +4 -10
  174. package/src/contract_function_simulator/oracle/interfaces.ts +91 -53
  175. package/src/contract_function_simulator/oracle/legacy_oracle_mappings.ts +104 -0
  176. package/src/contract_function_simulator/oracle/oracle.ts +377 -139
  177. package/src/contract_function_simulator/oracle/private_execution.ts +4 -4
  178. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +87 -109
  179. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +530 -148
  180. package/src/contract_function_simulator/pick_notes.ts +22 -3
  181. package/src/contract_function_simulator/proxied_contract_data_source.ts +8 -1
  182. package/src/contract_logging.ts +18 -5
  183. package/src/contract_sync/contract_sync_service.ts +99 -75
  184. package/src/contract_sync/helpers.ts +4 -4
  185. package/src/debug/pxe_debug_utils.ts +3 -3
  186. package/src/entrypoints/client/bundle/index.ts +0 -1
  187. package/src/entrypoints/client/bundle/utils.ts +2 -3
  188. package/src/entrypoints/client/lazy/index.ts +0 -1
  189. package/src/entrypoints/client/lazy/utils.ts +2 -3
  190. package/src/entrypoints/pxe_creation_options.ts +7 -0
  191. package/src/entrypoints/server/index.ts +1 -2
  192. package/src/entrypoints/server/utils.ts +2 -3
  193. package/src/events/event_service.ts +30 -5
  194. package/src/events/private_event_filter_validator.ts +21 -1
  195. package/src/logs/log_service.ts +59 -75
  196. package/src/messages/message_context_service.ts +44 -0
  197. package/src/notes/note_service.ts +18 -8
  198. package/src/notes_filter.ts +1 -3
  199. package/src/oracle_version.ts +20 -10
  200. package/src/private_kernel/private_kernel_execution_prover.ts +4 -9
  201. package/src/private_kernel/private_kernel_oracle.ts +14 -14
  202. package/src/pxe.ts +153 -53
  203. package/src/storage/anchor_block_store/anchor_block_store.ts +1 -1
  204. package/src/storage/capsule_store/capsule_service.ts +90 -0
  205. package/src/storage/capsule_store/capsule_store.ts +44 -26
  206. package/src/storage/capsule_store/index.ts +1 -0
  207. package/src/storage/contract_store/contract_store.ts +8 -6
  208. package/src/storage/metadata.ts +1 -1
  209. package/src/storage/note_store/note_store.ts +2 -5
  210. package/src/storage/private_event_store/private_event_store.ts +4 -0
  211. package/src/storage/private_event_store/stored_private_event.ts +1 -1
  212. package/src/storage/tagging_store/recipient_tagging_store.ts +9 -5
  213. package/src/storage/tagging_store/sender_tagging_store.ts +185 -138
  214. package/src/tagging/index.ts +2 -2
  215. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +8 -21
  216. package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +10 -15
  217. package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +23 -10
  218. package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +26 -11
  219. package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +27 -26
  220. package/dest/access_scopes.d.ts +0 -9
  221. package/dest/access_scopes.d.ts.map +0 -1
  222. package/dest/access_scopes.js +0 -6
  223. package/src/access_scopes.ts +0 -9
package/dest/pxe.js CHANGED
@@ -20,6 +20,7 @@ import { PXEDebugUtils } from './debug/pxe_debug_utils.js';
20
20
  import { enrichPublicSimulationError, enrichSimulationError } from './error_enriching.js';
21
21
  import { PrivateEventFilterValidator } from './events/private_event_filter_validator.js';
22
22
  import { JobCoordinator } from './job_coordinator/job_coordinator.js';
23
+ import { MessageContextService } from './messages/message_context_service.js';
23
24
  import { PrivateKernelExecutionProver } from './private_kernel/private_kernel_execution_prover.js';
24
25
  import { PrivateKernelOracle } from './private_kernel/private_kernel_oracle.js';
25
26
  import { AddressStore } from './storage/address_store/address_store.js';
@@ -36,6 +37,7 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
36
37
  * manage private state of users.
37
38
  */ export class PXE {
38
39
  node;
40
+ db;
39
41
  blockStateSynchronizer;
40
42
  keyStore;
41
43
  contractStore;
@@ -48,6 +50,8 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
48
50
  addressStore;
49
51
  privateEventStore;
50
52
  contractSyncService;
53
+ messageContextService;
54
+ l2TipsStore;
51
55
  simulator;
52
56
  proverEnabled;
53
57
  proofCreator;
@@ -56,8 +60,9 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
56
60
  jobQueue;
57
61
  jobCoordinator;
58
62
  debug;
59
- constructor(node, blockStateSynchronizer, keyStore, contractStore, noteStore, capsuleStore, anchorBlockStore, senderTaggingStore, senderAddressBookStore, recipientTaggingStore, addressStore, privateEventStore, contractSyncService, simulator, proverEnabled, proofCreator, protocolContractsProvider, log, jobQueue, jobCoordinator, debug){
63
+ constructor(node, db, blockStateSynchronizer, keyStore, contractStore, noteStore, capsuleStore, anchorBlockStore, senderTaggingStore, senderAddressBookStore, recipientTaggingStore, addressStore, privateEventStore, contractSyncService, messageContextService, l2TipsStore, simulator, proverEnabled, proofCreator, protocolContractsProvider, log, jobQueue, jobCoordinator, debug){
60
64
  this.node = node;
65
+ this.db = db;
61
66
  this.blockStateSynchronizer = blockStateSynchronizer;
62
67
  this.keyStore = keyStore;
63
68
  this.contractStore = contractStore;
@@ -70,6 +75,8 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
70
75
  this.addressStore = addressStore;
71
76
  this.privateEventStore = privateEventStore;
72
77
  this.contractSyncService = contractSyncService;
78
+ this.messageContextService = messageContextService;
79
+ this.l2TipsStore = l2TipsStore;
73
80
  this.simulator = simulator;
74
81
  this.proverEnabled = proverEnabled;
75
82
  this.proofCreator = proofCreator;
@@ -103,6 +110,7 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
103
110
  const keyStore = new KeyStore(store);
104
111
  const tipsStore = new L2TipsKVStore(store, 'pxe');
105
112
  const contractSyncService = new ContractSyncService(node, contractStore, noteStore, createLogger('pxe:contract_sync', bindings));
113
+ const messageContextService = new MessageContextService(node);
106
114
  const synchronizer = new BlockSynchronizer(node, store, anchorBlockStore, noteStore, privateEventStore, tipsStore, contractSyncService, config, bindings);
107
115
  const jobCoordinator = new JobCoordinator(store, bindings);
108
116
  jobCoordinator.registerStores([
@@ -115,7 +123,7 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
115
123
  ]);
116
124
  const debugUtils = new PXEDebugUtils(contractSyncService, noteStore, synchronizer, anchorBlockStore);
117
125
  const jobQueue = new SerialQueue();
118
- const pxe = new PXE(node, synchronizer, keyStore, contractStore, noteStore, capsuleStore, anchorBlockStore, senderTaggingStore, senderAddressBookStore, recipientTaggingStore, addressStore, privateEventStore, contractSyncService, simulator, proverEnabled, proofCreator, protocolContractsProvider, log, jobQueue, jobCoordinator, debugUtils);
126
+ const pxe = new PXE(node, store, synchronizer, keyStore, contractStore, noteStore, capsuleStore, anchorBlockStore, senderTaggingStore, senderAddressBookStore, recipientTaggingStore, addressStore, privateEventStore, contractSyncService, messageContextService, tipsStore, simulator, proverEnabled, proofCreator, protocolContractsProvider, log, jobQueue, jobCoordinator, debugUtils);
119
127
  debugUtils.setPXEHelpers(pxe.#putInJobQueue.bind(pxe), pxe.#getSimulatorForTx.bind(pxe), pxe.#executeUtility.bind(pxe));
120
128
  pxe.jobQueue.start();
121
129
  await pxe.#registerProtocolContracts();
@@ -131,13 +139,15 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
131
139
  keyStore: this.keyStore,
132
140
  addressStore: this.addressStore,
133
141
  aztecNode: BenchmarkedNodeFactory.create(this.node),
142
+ l2TipsStore: this.l2TipsStore,
134
143
  senderTaggingStore: this.senderTaggingStore,
135
144
  recipientTaggingStore: this.recipientTaggingStore,
136
145
  senderAddressBookStore: this.senderAddressBookStore,
137
146
  capsuleStore: this.capsuleStore,
138
147
  privateEventStore: this.privateEventStore,
139
148
  simulator: this.simulator,
140
- contractSyncService: this.contractSyncService
149
+ contractSyncService: this.contractSyncService,
150
+ messageContextService: this.messageContextService
141
151
  });
142
152
  }
143
153
  #contextualizeError(err, ...context) {
@@ -190,17 +200,17 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
190
200
  }
191
201
  // Executes the entrypoint private function, as well as all nested private
192
202
  // functions that might arise.
193
- async #executePrivate(contractFunctionSimulator, txRequest, scopes, jobId) {
203
+ async #executePrivate({ contractFunctionSimulator, txRequest, anchorBlockHeader, scopes, jobId, senderForTags }) {
194
204
  const { origin: contractAddress, functionSelector } = txRequest;
195
205
  try {
196
- const anchorBlockHeader = await this.anchorBlockStore.getBlockHeader();
197
206
  await this.contractSyncService.ensureContractSynced(contractAddress, functionSelector, (privateSyncCall, execScopes)=>this.#executeUtility(contractFunctionSimulator, privateSyncCall, [], execScopes, jobId), anchorBlockHeader, jobId, scopes);
198
207
  const result = await contractFunctionSimulator.run(txRequest, {
199
208
  contractAddress,
200
209
  selector: functionSelector,
201
210
  anchorBlockHeader,
202
211
  scopes,
203
- jobId
212
+ jobId,
213
+ senderForTags
204
214
  });
205
215
  this.log.debug(`Private simulation completed for ${contractAddress.toString()}:${functionSelector}`);
206
216
  return result;
@@ -223,7 +233,11 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
223
233
  */ async #executeUtility(contractFunctionSimulator, call, authWitnesses, scopes, jobId) {
224
234
  try {
225
235
  const anchorBlockHeader = await this.anchorBlockStore.getBlockHeader();
226
- return contractFunctionSimulator.runUtility(call, authWitnesses ?? [], anchorBlockHeader, scopes, jobId);
236
+ const { result, offchainEffects } = await contractFunctionSimulator.runUtility(call, authWitnesses ?? [], anchorBlockHeader, scopes, jobId);
237
+ return {
238
+ result,
239
+ offchainEffects
240
+ };
227
241
  } catch (err) {
228
242
  if (err instanceof SimulationError) {
229
243
  await enrichSimulationError(err, this.contractStore, this.log);
@@ -266,10 +280,8 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
266
280
  * @param privateExecutionResult - The result of the private execution
267
281
  * @param config - The configuration for the kernel execution prover.
268
282
  * @returns An object that contains the output of the kernel execution, including the ChonkProof if proving is enabled.
269
- */ async #prove(txExecutionRequest, proofCreator, privateExecutionResult, config) {
270
- const anchorBlockHeader = await this.anchorBlockStore.getBlockHeader();
271
- const anchorBlockHash = await anchorBlockHeader.hash();
272
- const kernelOracle = new PrivateKernelOracle(this.contractStore, this.keyStore, this.node, anchorBlockHash);
283
+ */ async #prove(txExecutionRequest, proofCreator, privateExecutionResult, anchorBlockHeader, config) {
284
+ const kernelOracle = new PrivateKernelOracle(this.contractStore, this.keyStore, this.node, anchorBlockHeader);
273
285
  const kernelTraceProver = new PrivateKernelExecutionProver(kernelOracle, proofCreator, !this.proverEnabled, this.log.getBindings());
274
286
  this.log.debug(`Executing kernel trace prover (${JSON.stringify(config)})...`);
275
287
  return await kernelTraceProver.proveWithKernels(txExecutionRequest.toTxRequest(), privateExecutionResult, config);
@@ -279,7 +291,9 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
279
291
  * Returns the block header up to which the PXE has synced.
280
292
  * @returns The synced block header
281
293
  */ getSyncedBlockHeader() {
282
- return this.anchorBlockStore.getBlockHeader();
294
+ return this.#putInJobQueue(()=>{
295
+ return this.anchorBlockStore.getBlockHeader();
296
+ });
283
297
  }
284
298
  /**
285
299
  * Returns the contract instance for a given address, if it's registered in the PXE.
@@ -327,6 +341,9 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
327
341
  * @returns The address of the sender.
328
342
  * TODO: It's strange that we return the address here and I (benesjan) think we should drop the return value.
329
343
  */ async registerSender(sender) {
344
+ if (!await sender.isValid()) {
345
+ throw new Error(`Address ${sender} is not valid: it does not correspond to a point on the Grumpkin curve. Cannot register it as a sender.`);
346
+ }
330
347
  const accounts = await this.keyStore.getAccounts();
331
348
  if (accounts.includes(sender)) {
332
349
  this.log.info(`Sender:\n "${sender.toString()}"\n already registered.`);
@@ -335,6 +352,9 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
335
352
  const wasAdded = await this.senderAddressBookStore.addSender(sender);
336
353
  if (wasAdded) {
337
354
  this.log.info(`Added sender:\n ${sender.toString()}`);
355
+ // Wipe the entire sync cache: the new sender's tagged logs could contain notes/events for any contract, so
356
+ // all contracts must re-sync to discover them. Queued to avoid wiping while a job is in flight.
357
+ await this.#putInJobQueue(()=>Promise.resolve(this.contractSyncService.wipe()));
338
358
  } else {
339
359
  this.log.info(`Sender:\n "${sender.toString()}"\n already registered.`);
340
360
  }
@@ -456,7 +476,7 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
456
476
  * @returns A result containing the proof and public inputs of the tail circuit.
457
477
  * @throws If contract code not found, or public simulation reverts.
458
478
  * Also throws if simulatePublic is true and public simulation reverts.
459
- */ proveTx(txRequest, scopes) {
479
+ */ proveTx(txRequest, { scopes, senderForTags }) {
460
480
  let privateExecutionResult;
461
481
  // We disable proving concurrently mostly out of caution, since it accesses some of our stores. Proving is so
462
482
  // computationally demanding that it'd be rare for someone to try to do it concurrently regardless.
@@ -465,10 +485,18 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
465
485
  try {
466
486
  const syncTimer = new Timer();
467
487
  await this.blockStateSynchronizer.sync();
488
+ const anchorBlockHeader = await this.anchorBlockStore.getBlockHeader();
468
489
  const syncTime = syncTimer.ms();
469
490
  const contractFunctionSimulator = this.#getSimulatorForTx();
470
- privateExecutionResult = await this.#executePrivate(contractFunctionSimulator, txRequest, scopes, jobId);
471
- const { publicInputs, chonkProof, executionSteps, timings: { proving } = {} } = await this.#prove(txRequest, this.proofCreator, privateExecutionResult, {
491
+ privateExecutionResult = await this.#executePrivate({
492
+ contractFunctionSimulator,
493
+ txRequest,
494
+ anchorBlockHeader,
495
+ scopes,
496
+ jobId,
497
+ senderForTags
498
+ });
499
+ const { publicInputs, chonkProof, executionSteps, timings: { proving } = {} } = await this.#prove(txRequest, this.proofCreator, privateExecutionResult, anchorBlockHeader, {
472
500
  simulate: false,
473
501
  skipFeeEnforcement: false,
474
502
  profileMode: 'none'
@@ -498,16 +526,16 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
498
526
  // transaction before this one is included in a block from this PXE, and that transaction contains a log with
499
527
  // a tag derived from the same secret, we would reuse the tag and the transactions would be linked. Hence
500
528
  // storing the tags here prevents linkage of txs sent from the same PXE.
501
- const preTagsUsedInTheTx = privateExecutionResult.entrypoint.preTags;
502
- if (preTagsUsedInTheTx.length > 0) {
529
+ const taggingIndexRangesUsedInTheTx = privateExecutionResult.entrypoint.taggingIndexRanges;
530
+ if (taggingIndexRangesUsedInTheTx.length > 0) {
503
531
  // TODO(benesjan): The following is an expensive operation. Figure out a way to avoid it.
504
532
  const txHash = (await txProvingResult.toTx()).txHash;
505
- await this.senderTaggingStore.storePendingIndexes(preTagsUsedInTheTx, txHash, jobId);
506
- this.log.debug(`Stored used pre-tags as sender for the tx`, {
507
- preTagsUsedInTheTx
533
+ await this.senderTaggingStore.storePendingIndexes(taggingIndexRangesUsedInTheTx, txHash, jobId);
534
+ this.log.debug(`Stored used tagging index ranges as sender for the tx`, {
535
+ taggingIndexRangesUsedInTheTx
508
536
  });
509
537
  } else {
510
- this.log.debug(`No pre-tags used in the tx`);
538
+ this.log.debug(`No tagging index ranges used in the tx`);
511
539
  }
512
540
  return txProvingResult;
513
541
  } catch (err) {
@@ -520,7 +548,7 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
520
548
  * @param txRequest - An authenticated tx request ready for simulation.
521
549
  * @returns A trace of the program execution with gate counts.
522
550
  * @throws If the code for the functions executed in this transaction have not been made available via `addContracts`.
523
- */ profileTx(txRequest, { profileMode, skipProofGeneration = true, scopes }) {
551
+ */ profileTx(txRequest, { profileMode, skipProofGeneration = true, scopes, senderForTags }) {
524
552
  // We disable concurrent profiles for consistency with simulateTx.
525
553
  return this.#putInJobQueue(async (jobId)=>{
526
554
  const totalTimer = new Timer();
@@ -536,10 +564,18 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
536
564
  this.log.info(`Profiling transaction execution request to ${txRequest.functionSelector} at ${txRequest.origin}`, txInfo);
537
565
  const syncTimer = new Timer();
538
566
  await this.blockStateSynchronizer.sync();
567
+ const anchorBlockHeader = await this.anchorBlockStore.getBlockHeader();
539
568
  const syncTime = syncTimer.ms();
540
569
  const contractFunctionSimulator = this.#getSimulatorForTx();
541
- const privateExecutionResult = await this.#executePrivate(contractFunctionSimulator, txRequest, scopes, jobId);
542
- const { executionSteps, timings: { proving } = {} } = await this.#prove(txRequest, this.proofCreator, privateExecutionResult, {
570
+ const privateExecutionResult = await this.#executePrivate({
571
+ contractFunctionSimulator,
572
+ txRequest,
573
+ anchorBlockHeader,
574
+ scopes,
575
+ jobId,
576
+ senderForTags
577
+ });
578
+ const { executionSteps, timings: { proving } = {} } = await this.#prove(txRequest, this.proofCreator, privateExecutionResult, anchorBlockHeader, {
543
579
  simulate: skipProofGeneration,
544
580
  skipFeeEnforcement: false,
545
581
  profileMode
@@ -589,7 +625,7 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
589
625
  * Also throws if simulatePublic is true and public simulation reverts.
590
626
  *
591
627
  * TODO(#7456) Prevent msgSender being defined here for the first call
592
- */ simulateTx(txRequest, { simulatePublic, skipTxValidation = false, skipFeeEnforcement = false, overrides, scopes }) {
628
+ */ simulateTx(txRequest, { simulatePublic, skipTxValidation = false, skipFeeEnforcement = false, skipKernels = true, overrides, scopes, senderForTags }) {
593
629
  // We disable concurrent simulations since those might execute oracles which read and write to the PXE stores (e.g.
594
630
  // to the capsules), and we need to prevent concurrent runs from interfering with one another (e.g. attempting to
595
631
  // delete the same read value, or reading values that another simulation is currently modifying).
@@ -607,27 +643,35 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
607
643
  this.log.info(`Simulating transaction execution request to ${txRequest.functionSelector} at ${txRequest.origin}`, txInfo);
608
644
  const syncTimer = new Timer();
609
645
  await this.blockStateSynchronizer.sync();
646
+ const anchorBlockHeader = await this.anchorBlockStore.getBlockHeader();
610
647
  const syncTime = syncTimer.ms();
611
- const contractFunctionSimulator = this.#getSimulatorForTx(overrides);
612
- // Temporary: in case there are overrides, we have to skip the kernels or validations
613
- // will fail. Consider handing control to the user/wallet on whether they want to run them
614
- // or not.
615
648
  const overriddenContracts = overrides?.contracts ? new Set(Object.keys(overrides.contracts)) : undefined;
616
649
  const hasOverriddenContracts = overriddenContracts !== undefined && overriddenContracts.size > 0;
617
- const skipKernels = hasOverriddenContracts;
618
- // Set overridden contracts on the sync service so it knows to skip syncing them
650
+ if (hasOverriddenContracts && !skipKernels) {
651
+ throw new Error('Simulating with overridden contracts is not compatible with kernel execution. Please set skipKernels to true when simulating with overridden contracts.');
652
+ }
653
+ const contractFunctionSimulator = this.#getSimulatorForTx(overrides);
619
654
  if (hasOverriddenContracts) {
620
- this.contractSyncService.setOverriddenContracts(jobId, overriddenContracts);
655
+ // Overridden contracts don't have a sync function, so calling sync on them would fail.
656
+ // We exclude them so the sync service skips them entirely.
657
+ this.contractSyncService.setExcludedFromSync(jobId, overriddenContracts);
621
658
  }
622
659
  // Execution of private functions only; no proving, and no kernel logic.
623
- const privateExecutionResult = await this.#executePrivate(contractFunctionSimulator, txRequest, scopes, jobId);
660
+ const privateExecutionResult = await this.#executePrivate({
661
+ contractFunctionSimulator,
662
+ txRequest,
663
+ anchorBlockHeader,
664
+ scopes,
665
+ jobId,
666
+ senderForTags
667
+ });
624
668
  let publicInputs;
625
669
  let executionSteps = [];
626
670
  if (skipKernels) {
627
671
  ({ publicInputs, executionSteps } = await generateSimulatedProvingResult(privateExecutionResult, (addr, sel)=>this.contractStore.getDebugFunctionName(addr, sel), this.node));
628
672
  } else {
629
673
  // Kernel logic, plus proving of all private functions and kernels.
630
- ({ publicInputs, executionSteps } = await this.#prove(txRequest, this.proofCreator, privateExecutionResult, {
674
+ ({ publicInputs, executionSteps } = await this.#prove(txRequest, this.proofCreator, privateExecutionResult, anchorBlockHeader, {
631
675
  simulate: true,
632
676
  skipFeeEnforcement,
633
677
  profileMode: 'none'
@@ -654,7 +698,8 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
654
698
  });
655
699
  validationTime = validationTimer.ms();
656
700
  if (validationResult.result === 'invalid') {
657
- throw new Error('The simulated transaction is unable to be added to state and is invalid.');
701
+ const reason = validationResult.reason.length > 0 ? ` Reason: ${validationResult.reason.join(', ')}` : '';
702
+ throw new Error(`The simulated transaction is unable to be added to state and is invalid.${reason}`);
658
703
  }
659
704
  }
660
705
  const txHash = simulatedTx.getTxHash();
@@ -687,7 +732,7 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
687
732
  nodeRPCCalls: simulatorStats.nodeRPCCalls
688
733
  });
689
734
  } catch (err) {
690
- throw this.#contextualizeError(err, inspect(txRequest), `simulatePublic=${simulatePublic}`, `skipTxValidation=${skipTxValidation}`, `scopes=${scopes === 'ALL_SCOPES' ? scopes : scopes.map((s)=>s.toString()).join(', ')}`);
735
+ throw this.#contextualizeError(err, inspect(txRequest), `simulatePublic=${simulatePublic}`, `skipTxValidation=${skipTxValidation}`, `scopes=${scopes.map((s)=>s.toString()).join(', ')}`);
691
736
  }
692
737
  });
693
738
  }
@@ -695,7 +740,7 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
695
740
  * Executes a contract utility function.
696
741
  * @param call - The function call containing the function details, arguments, and target contract address.
697
742
  */ executeUtility(call, { authwits, scopes } = {
698
- scopes: 'ALL_SCOPES'
743
+ scopes: []
699
744
  }) {
700
745
  // We disable concurrent executions since those might execute oracles which read and write to the PXE stores (e.g.
701
746
  // to the capsules), and we need to prevent concurrent runs from interfering with one another (e.g. attempting to
@@ -710,7 +755,7 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
710
755
  const contractFunctionSimulator = this.#getSimulatorForTx();
711
756
  const anchorBlockHeader = await this.anchorBlockStore.getBlockHeader();
712
757
  await this.contractSyncService.ensureContractSynced(call.to, call.selector, (privateSyncCall, execScopes)=>this.#executeUtility(contractFunctionSimulator, privateSyncCall, [], execScopes, jobId), anchorBlockHeader, jobId, scopes);
713
- const executionResult = await this.#executeUtility(contractFunctionSimulator, call, authwits ?? [], scopes, jobId);
758
+ const { result: executionResult, offchainEffects } = await this.#executeUtility(contractFunctionSimulator, call, authwits ?? [], scopes, jobId);
714
759
  const functionTime = functionTimer.ms();
715
760
  const totalTime = totalTimer.ms();
716
761
  const perFunction = [
@@ -728,6 +773,8 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
728
773
  const simulationStats = contractFunctionSimulator.getStats();
729
774
  return {
730
775
  result: executionResult,
776
+ offchainEffects,
777
+ anchorBlockTimestamp: anchorBlockHeader.globalVariables.timestamp,
731
778
  stats: {
732
779
  timings,
733
780
  nodeRPCCalls: simulationStats.nodeRPCCalls
@@ -736,7 +783,7 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
736
783
  } catch (err) {
737
784
  const { to, name, args } = call;
738
785
  const stringifiedArgs = args.map((arg)=>arg.toString()).join(', ');
739
- throw this.#contextualizeError(err, `executeUtility ${to}:${name}(${stringifiedArgs})`, `scopes=${scopes === 'ALL_SCOPES' ? scopes : scopes.map((s)=>s.toString()).join(', ')}`);
786
+ throw this.#contextualizeError(err, `executeUtility ${to}:${name}(${stringifiedArgs})`, `scopes=${scopes.map((s)=>s.toString()).join(', ')}`);
740
787
  }
741
788
  });
742
789
  }
@@ -767,8 +814,10 @@ import { SenderTaggingStore } from './storage/tagging_store/sender_tagging_store
767
814
  return this.privateEventStore.getPrivateEvents(eventSelector, sanitizedFilter);
768
815
  }
769
816
  /**
770
- * Stops the PXE's job queue.
771
- */ stop() {
772
- return this.jobQueue.end();
817
+ * Stops the PXE's job queue and closes the backing store.
818
+ */ async stop() {
819
+ await this.jobQueue.end();
820
+ await this.blockStateSynchronizer.stop();
821
+ await this.db.close();
773
822
  }
774
823
  }
@@ -17,7 +17,7 @@ export class AnchorBlockStore {
17
17
  await this.#synchronizedHeader.set(header.toBuffer());
18
18
  }
19
19
  async getBlockHeader() {
20
- const headerBuffer = await this.#synchronizedHeader.getAsync();
20
+ const headerBuffer = await this.#store.transactionAsync(()=>this.#synchronizedHeader.getAsync());
21
21
  if (!headerBuffer) {
22
22
  throw new Error(`Trying to get block header with a not-yet-synchronized PXE - this should never happen`);
23
23
  }
@@ -0,0 +1,21 @@
1
+ import type { Fr } from '@aztec/foundation/curves/bn254';
2
+ import { AztecAddress } from '@aztec/stdlib/aztec-address';
3
+ import type { Capsule } from '@aztec/stdlib/tx';
4
+ import type { CapsuleStore } from './capsule_store.js';
5
+ /**
6
+ * Wraps a CapsuleStore with scope-based access control. Each operation asserts that the requested scope is in the
7
+ * allowed scopes list before delegating to the underlying store.
8
+ */
9
+ export declare class CapsuleService {
10
+ private readonly capsuleStore;
11
+ private readonly allowedScopes;
12
+ constructor(capsuleStore: CapsuleStore, allowedScopes: AztecAddress[]);
13
+ setCapsule(contractAddress: AztecAddress, slot: Fr, capsule: Fr[], jobId: string, scope: AztecAddress): void;
14
+ getCapsule(contractAddress: AztecAddress, slot: Fr, jobId: string, scope: AztecAddress, transientCapsules?: Capsule[]): Promise<Fr[] | null>;
15
+ deleteCapsule(contractAddress: AztecAddress, slot: Fr, jobId: string, scope: AztecAddress): void;
16
+ copyCapsule(contractAddress: AztecAddress, srcSlot: Fr, dstSlot: Fr, numEntries: number, jobId: string, scope: AztecAddress): Promise<void>;
17
+ appendToCapsuleArray(contractAddress: AztecAddress, baseSlot: Fr, content: Fr[][], jobId: string, scope: AztecAddress): Promise<void>;
18
+ readCapsuleArray(contractAddress: AztecAddress, baseSlot: Fr, jobId: string, scope: AztecAddress): Promise<Fr[][]>;
19
+ setCapsuleArray(contractAddress: AztecAddress, baseSlot: Fr, content: Fr[][], jobId: string, scope: AztecAddress): Promise<void>;
20
+ }
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2Fwc3VsZV9zZXJ2aWNlLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc3RvcmFnZS9jYXBzdWxlX3N0b3JlL2NhcHN1bGVfc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssRUFBRSxFQUFFLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN6RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDM0QsT0FBTyxLQUFLLEVBQUUsT0FBTyxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFaEQsT0FBTyxLQUFLLEVBQUUsWUFBWSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFdkQ7OztHQUdHO0FBQ0gscUJBQWEsY0FBYztJQUV2QixPQUFPLENBQUMsUUFBUSxDQUFDLFlBQVk7SUFDN0IsT0FBTyxDQUFDLFFBQVEsQ0FBQyxhQUFhO0lBRmhDLFlBQ21CLFlBQVksRUFBRSxZQUFZLEVBQzFCLGFBQWEsRUFBRSxZQUFZLEVBQUUsRUFDNUM7SUFFSixVQUFVLENBQUMsZUFBZSxFQUFFLFlBQVksRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFLE9BQU8sRUFBRSxFQUFFLEVBQUUsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxZQUFZLFFBR3BHO0lBRUssVUFBVSxDQUNkLGVBQWUsRUFBRSxZQUFZLEVBQzdCLElBQUksRUFBRSxFQUFFLEVBQ1IsS0FBSyxFQUFFLE1BQU0sRUFDYixLQUFLLEVBQUUsWUFBWSxFQUNuQixpQkFBaUIsQ0FBQyxFQUFFLE9BQU8sRUFBRSxHQUM1QixPQUFPLENBQUMsRUFBRSxFQUFFLEdBQUcsSUFBSSxDQUFDLENBWXRCO0lBRUQsYUFBYSxDQUFDLGVBQWUsRUFBRSxZQUFZLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxZQUFZLFFBR3hGO0lBRUQsV0FBVyxDQUNULGVBQWUsRUFBRSxZQUFZLEVBQzdCLE9BQU8sRUFBRSxFQUFFLEVBQ1gsT0FBTyxFQUFFLEVBQUUsRUFDWCxVQUFVLEVBQUUsTUFBTSxFQUNsQixLQUFLLEVBQUUsTUFBTSxFQUNiLEtBQUssRUFBRSxZQUFZLEdBQ2xCLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FHZjtJQUVELG9CQUFvQixDQUNsQixlQUFlLEVBQUUsWUFBWSxFQUM3QixRQUFRLEVBQUUsRUFBRSxFQUNaLE9BQU8sRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUNmLEtBQUssRUFBRSxNQUFNLEVBQ2IsS0FBSyxFQUFFLFlBQVksR0FDbEIsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUdmO0lBRUQsZ0JBQWdCLENBQUMsZUFBZSxFQUFFLFlBQVksRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLFlBQVksR0FBRyxPQUFPLENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUdqSDtJQUVELGVBQWUsQ0FBQyxlQUFlLEVBQUUsWUFBWSxFQUFFLFFBQVEsRUFBRSxFQUFFLEVBQUUsT0FBTyxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsWUFBWSxpQkFHL0c7Q0FDRiJ9
@@ -0,0 +1 @@
1
+ {"version":3,"file":"capsule_service.d.ts","sourceRoot":"","sources":["../../../src/storage/capsule_store/capsule_service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAC3D,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAEhD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAEvD;;;GAGG;AACH,qBAAa,cAAc;IAEvB,OAAO,CAAC,QAAQ,CAAC,YAAY;IAC7B,OAAO,CAAC,QAAQ,CAAC,aAAa;IAFhC,YACmB,YAAY,EAAE,YAAY,EAC1B,aAAa,EAAE,YAAY,EAAE,EAC5C;IAEJ,UAAU,CAAC,eAAe,EAAE,YAAY,EAAE,IAAI,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,YAAY,QAGpG;IAEK,UAAU,CACd,eAAe,EAAE,YAAY,EAC7B,IAAI,EAAE,EAAE,EACR,KAAK,EAAE,MAAM,EACb,KAAK,EAAE,YAAY,EACnB,iBAAiB,CAAC,EAAE,OAAO,EAAE,GAC5B,OAAO,CAAC,EAAE,EAAE,GAAG,IAAI,CAAC,CAYtB;IAED,aAAa,CAAC,eAAe,EAAE,YAAY,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,YAAY,QAGxF;IAED,WAAW,CACT,eAAe,EAAE,YAAY,EAC7B,OAAO,EAAE,EAAE,EACX,OAAO,EAAE,EAAE,EACX,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,MAAM,EACb,KAAK,EAAE,YAAY,GAClB,OAAO,CAAC,IAAI,CAAC,CAGf;IAED,oBAAoB,CAClB,eAAe,EAAE,YAAY,EAC7B,QAAQ,EAAE,EAAE,EACZ,OAAO,EAAE,EAAE,EAAE,EAAE,EACf,KAAK,EAAE,MAAM,EACb,KAAK,EAAE,YAAY,GAClB,OAAO,CAAC,IAAI,CAAC,CAGf;IAED,gBAAgB,CAAC,eAAe,EAAE,YAAY,EAAE,QAAQ,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,YAAY,GAAG,OAAO,CAAC,EAAE,EAAE,EAAE,CAAC,CAGjH;IAED,eAAe,CAAC,eAAe,EAAE,YAAY,EAAE,QAAQ,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,YAAY,iBAG/G;CACF"}
@@ -0,0 +1,50 @@
1
+ import { AztecAddress } from '@aztec/stdlib/aztec-address';
2
+ /**
3
+ * Wraps a CapsuleStore with scope-based access control. Each operation asserts that the requested scope is in the
4
+ * allowed scopes list before delegating to the underlying store.
5
+ */ export class CapsuleService {
6
+ capsuleStore;
7
+ allowedScopes;
8
+ constructor(capsuleStore, allowedScopes){
9
+ this.capsuleStore = capsuleStore;
10
+ this.allowedScopes = allowedScopes;
11
+ }
12
+ setCapsule(contractAddress, slot, capsule, jobId, scope) {
13
+ assertAllowedScope(scope, this.allowedScopes);
14
+ this.capsuleStore.setCapsule(contractAddress, slot, capsule, jobId, scope);
15
+ }
16
+ async getCapsule(contractAddress, slot, jobId, scope, transientCapsules) {
17
+ assertAllowedScope(scope, this.allowedScopes);
18
+ // TODO(#12425): On the following line, the pertinent capsule gets overshadowed by the transient one. Tackle this.
19
+ const maybeTransientCapsule = transientCapsules?.find((c)=>c.contractAddress.equals(contractAddress) && c.storageSlot.equals(slot) && (c.scope ?? AztecAddress.ZERO).equals(scope))?.data;
20
+ return maybeTransientCapsule ?? await this.capsuleStore.getCapsule(contractAddress, slot, jobId, scope);
21
+ }
22
+ deleteCapsule(contractAddress, slot, jobId, scope) {
23
+ assertAllowedScope(scope, this.allowedScopes);
24
+ this.capsuleStore.deleteCapsule(contractAddress, slot, jobId, scope);
25
+ }
26
+ copyCapsule(contractAddress, srcSlot, dstSlot, numEntries, jobId, scope) {
27
+ assertAllowedScope(scope, this.allowedScopes);
28
+ return this.capsuleStore.copyCapsule(contractAddress, srcSlot, dstSlot, numEntries, jobId, scope);
29
+ }
30
+ appendToCapsuleArray(contractAddress, baseSlot, content, jobId, scope) {
31
+ assertAllowedScope(scope, this.allowedScopes);
32
+ return this.capsuleStore.appendToCapsuleArray(contractAddress, baseSlot, content, jobId, scope);
33
+ }
34
+ readCapsuleArray(contractAddress, baseSlot, jobId, scope) {
35
+ assertAllowedScope(scope, this.allowedScopes);
36
+ return this.capsuleStore.readCapsuleArray(contractAddress, baseSlot, jobId, scope);
37
+ }
38
+ setCapsuleArray(contractAddress, baseSlot, content, jobId, scope) {
39
+ assertAllowedScope(scope, this.allowedScopes);
40
+ return this.capsuleStore.setCapsuleArray(contractAddress, baseSlot, content, jobId, scope);
41
+ }
42
+ }
43
+ function assertAllowedScope(scope, allowedScopes) {
44
+ if (scope.equals(AztecAddress.ZERO)) {
45
+ return;
46
+ }
47
+ if (!allowedScopes.some((allowed)=>allowed.equals(scope))) {
48
+ throw new Error(`Scope ${scope.toString()} is not in the allowed scopes list: [${allowedScopes.map((s)=>s.toString()).join(', ')}]. See https://docs.aztec.network/errors/10`);
49
+ }
50
+ }
@@ -1,7 +1,7 @@
1
1
  import { Fr } from '@aztec/foundation/curves/bn254';
2
2
  import { type Logger } from '@aztec/foundation/log';
3
3
  import type { AztecAsyncKVStore } from '@aztec/kv-store';
4
- import type { AztecAddress } from '@aztec/stdlib/aztec-address';
4
+ import { AztecAddress } from '@aztec/stdlib/aztec-address';
5
5
  import type { StagedStore } from '../../job_coordinator/job_coordinator.js';
6
6
  export declare class CapsuleStore implements StagedStore {
7
7
  #private;
@@ -31,20 +31,20 @@ export declare class CapsuleStore implements StagedStore {
31
31
  * to public contract storage in that it's indexed by the contract address and storage slot but instead of the global
32
32
  * network state it's backed by local PXE db.
33
33
  */
34
- storeCapsule(contractAddress: AztecAddress, slot: Fr, capsule: Fr[], jobId: string): void;
34
+ setCapsule(contractAddress: AztecAddress, slot: Fr, capsule: Fr[], jobId: string, scope: AztecAddress): void;
35
35
  /**
36
36
  * Returns data previously stored via `storeCapsule` in the per-contract non-volatile database.
37
37
  * @param contractAddress - The contract address under which the data is scoped.
38
38
  * @param slot - The slot in the database to read.
39
39
  * @returns The stored data or `null` if no data is stored under the slot.
40
40
  */
41
- loadCapsule(contractAddress: AztecAddress, slot: Fr, jobId: string): Promise<Fr[] | null>;
41
+ getCapsule(contractAddress: AztecAddress, slot: Fr, jobId: string, scope: AztecAddress): Promise<Fr[] | null>;
42
42
  /**
43
43
  * Deletes data in the per-contract non-volatile database. Does nothing if no data was present.
44
44
  * @param contractAddress - The contract address under which the data is scoped.
45
45
  * @param slot - The slot in the database to delete.
46
46
  */
47
- deleteCapsule(contractAddress: AztecAddress, slot: Fr, jobId: string): void;
47
+ deleteCapsule(contractAddress: AztecAddress, slot: Fr, jobId: string, scope: AztecAddress): void;
48
48
  /**
49
49
  * Copies a number of contiguous entries in the per-contract non-volatile database. This allows for efficient data
50
50
  * structures by avoiding repeated calls to `loadCapsule` and `storeCapsule`.
@@ -56,7 +56,7 @@ export declare class CapsuleStore implements StagedStore {
56
56
  * @param dstSlot - The first slot to copy to.
57
57
  * @param numEntries - The number of entries to copy.
58
58
  */
59
- copyCapsule(contractAddress: AztecAddress, srcSlot: Fr, dstSlot: Fr, numEntries: number, jobId: string): Promise<void>;
59
+ copyCapsule(contractAddress: AztecAddress, srcSlot: Fr, dstSlot: Fr, numEntries: number, jobId: string, scope: AztecAddress): Promise<void>;
60
60
  /**
61
61
  * Appends multiple capsules to a capsule array stored at the base slot.
62
62
  * The array length is stored at the base slot, and elements are stored in consecutive slots after it.
@@ -65,8 +65,8 @@ export declare class CapsuleStore implements StagedStore {
65
65
  * @param baseSlot - The slot where the array length is stored
66
66
  * @param content - Array of capsule data to append
67
67
  */
68
- appendToCapsuleArray(contractAddress: AztecAddress, baseSlot: Fr, content: Fr[][], jobId: string): Promise<void>;
69
- readCapsuleArray(contractAddress: AztecAddress, baseSlot: Fr, jobId: string): Promise<Fr[][]>;
70
- setCapsuleArray(contractAddress: AztecAddress, baseSlot: Fr, content: Fr[][], jobId: string): Promise<void>;
68
+ appendToCapsuleArray(contractAddress: AztecAddress, baseSlot: Fr, content: Fr[][], jobId: string, scope: AztecAddress): Promise<void>;
69
+ readCapsuleArray(contractAddress: AztecAddress, baseSlot: Fr, jobId: string, scope: AztecAddress): Promise<Fr[][]>;
70
+ setCapsuleArray(contractAddress: AztecAddress, baseSlot: Fr, content: Fr[][], jobId: string, scope: AztecAddress): Promise<void>;
71
71
  }
72
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2Fwc3VsZV9zdG9yZS5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3N0b3JhZ2UvY2Fwc3VsZV9zdG9yZS9jYXBzdWxlX3N0b3JlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNwRCxPQUFPLEVBQUUsS0FBSyxNQUFNLEVBQWdCLE1BQU0sdUJBQXVCLENBQUM7QUFDbEUsT0FBTyxLQUFLLEVBQUUsaUJBQWlCLEVBQWlCLE1BQU0saUJBQWlCLENBQUM7QUFDeEUsT0FBTyxLQUFLLEVBQUUsWUFBWSxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFFaEUsT0FBTyxLQUFLLEVBQUUsV0FBVyxFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFFNUUscUJBQWEsWUFBYSxZQUFXLFdBQVc7O0lBQzlDLFFBQVEsQ0FBQyxTQUFTLGFBQWE7SUFZL0IsTUFBTSxFQUFFLE1BQU0sQ0FBQztJQUVmLFlBQVksS0FBSyxFQUFFLGlCQUFpQixFQVFuQztJQStERDs7Ozs7O09BTUc7SUFDRyxNQUFNLENBQUMsS0FBSyxFQUFFLE1BQU0sR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLENBZXpDO0lBRUQ7O09BRUc7SUFDSCxhQUFhLENBQUMsS0FBSyxFQUFFLE1BQU0sR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLENBRzFDO0lBRUQ7Ozs7Ozs7Ozs7T0FVRztJQUNILFlBQVksQ0FBQyxlQUFlLEVBQUUsWUFBWSxFQUFFLElBQUksRUFBRSxFQUFFLEVBQUUsT0FBTyxFQUFFLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxNQUFNLFFBS2pGO0lBRUQ7Ozs7O09BS0c7SUFDRyxXQUFXLENBQUMsZUFBZSxFQUFFLFlBQVksRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLEVBQUUsRUFBRSxHQUFHLElBQUksQ0FBQyxDQVc5RjtJQUVEOzs7O09BSUc7SUFDSCxhQUFhLENBQUMsZUFBZSxFQUFFLFlBQVksRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxNQUFNLFFBR25FO0lBRUQ7Ozs7Ozs7Ozs7T0FVRztJQUNILFdBQVcsQ0FDVCxlQUFlLEVBQUUsWUFBWSxFQUM3QixPQUFPLEVBQUUsRUFBRSxFQUNYLE9BQU8sRUFBRSxFQUFFLEVBQ1gsVUFBVSxFQUFFLE1BQU0sRUFDbEIsS0FBSyxFQUFFLE1BQU0sR0FDWixPQUFPLENBQUMsSUFBSSxDQUFDLENBMkJmO0lBRUQ7Ozs7Ozs7T0FPRztJQUNILG9CQUFvQixDQUFDLGVBQWUsRUFBRSxZQUFZLEVBQUUsUUFBUSxFQUFFLEVBQUUsRUFBRSxPQUFPLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxLQUFLLEVBQUUsTUFBTSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FxQi9HO0lBRUQsZ0JBQWdCLENBQUMsZUFBZSxFQUFFLFlBQVksRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0EyQjVGO0lBRUQsZUFBZSxDQUFDLGVBQWUsRUFBRSxZQUFZLEVBQUUsUUFBUSxFQUFFLEVBQUUsRUFBRSxPQUFPLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxLQUFLLEVBQUUsTUFBTSxpQkEyQjFGO0NBQ0YifQ==
72
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2Fwc3VsZV9zdG9yZS5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3N0b3JhZ2UvY2Fwc3VsZV9zdG9yZS9jYXBzdWxlX3N0b3JlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNwRCxPQUFPLEVBQUUsS0FBSyxNQUFNLEVBQWdCLE1BQU0sdUJBQXVCLENBQUM7QUFDbEUsT0FBTyxLQUFLLEVBQUUsaUJBQWlCLEVBQWlCLE1BQU0saUJBQWlCLENBQUM7QUFDeEUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBRTNELE9BQU8sS0FBSyxFQUFFLFdBQVcsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBRTVFLHFCQUFhLFlBQWEsWUFBVyxXQUFXOztJQUM5QyxRQUFRLENBQUMsU0FBUyxhQUFhO0lBYS9CLE1BQU0sRUFBRSxNQUFNLENBQUM7SUFFZixZQUFZLEtBQUssRUFBRSxpQkFBaUIsRUFRbkM7SUErREQ7Ozs7OztPQU1HO0lBQ0csTUFBTSxDQUFDLEtBQUssRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQWV6QztJQUVEOztPQUVHO0lBQ0gsYUFBYSxDQUFDLEtBQUssRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUcxQztJQUVEOzs7Ozs7Ozs7O09BVUc7SUFDSCxVQUFVLENBQUMsZUFBZSxFQUFFLFlBQVksRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFLE9BQU8sRUFBRSxFQUFFLEVBQUUsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxZQUFZLFFBS3BHO0lBRUQ7Ozs7O09BS0c7SUFDSCxVQUFVLENBQUMsZUFBZSxFQUFFLFlBQVksRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLFlBQVksR0FBRyxPQUFPLENBQUMsRUFBRSxFQUFFLEdBQUcsSUFBSSxDQUFDLENBRTVHO0lBcUJEOzs7O09BSUc7SUFDSCxhQUFhLENBQUMsZUFBZSxFQUFFLFlBQVksRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLFlBQVksUUFHeEY7SUFFRDs7Ozs7Ozs7OztPQVVHO0lBQ0gsV0FBVyxDQUNULGVBQWUsRUFBRSxZQUFZLEVBQzdCLE9BQU8sRUFBRSxFQUFFLEVBQ1gsT0FBTyxFQUFFLEVBQUUsRUFDWCxVQUFVLEVBQUUsTUFBTSxFQUNsQixLQUFLLEVBQUUsTUFBTSxFQUNiLEtBQUssRUFBRSxZQUFZLEdBQ2xCLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0EyQmY7SUFFRDs7Ozs7OztPQU9HO0lBQ0gsb0JBQW9CLENBQ2xCLGVBQWUsRUFBRSxZQUFZLEVBQzdCLFFBQVEsRUFBRSxFQUFFLEVBQ1osT0FBTyxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQ2YsS0FBSyxFQUFFLE1BQU0sRUFDYixLQUFLLEVBQUUsWUFBWSxHQUNsQixPQUFPLENBQUMsSUFBSSxDQUFDLENBcUJmO0lBRUQsZ0JBQWdCLENBQUMsZUFBZSxFQUFFLFlBQVksRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLFlBQVksR0FBRyxPQUFPLENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQTJCakg7SUFFRCxlQUFlLENBQUMsZUFBZSxFQUFFLFlBQVksRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFLE9BQU8sRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLFlBQVksaUJBMkIvRztDQUNGIn0=
@@ -1 +1 @@
1
- {"version":3,"file":"capsule_store.d.ts","sourceRoot":"","sources":["../../../src/storage/capsule_store/capsule_store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AACpD,OAAO,EAAE,KAAK,MAAM,EAAgB,MAAM,uBAAuB,CAAC;AAClE,OAAO,KAAK,EAAE,iBAAiB,EAAiB,MAAM,iBAAiB,CAAC;AACxE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAEhE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,0CAA0C,CAAC;AAE5E,qBAAa,YAAa,YAAW,WAAW;;IAC9C,QAAQ,CAAC,SAAS,aAAa;IAY/B,MAAM,EAAE,MAAM,CAAC;IAEf,YAAY,KAAK,EAAE,iBAAiB,EAQnC;IA+DD;;;;;;OAMG;IACG,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAezC;IAED;;OAEG;IACH,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAG1C;IAED;;;;;;;;;;OAUG;IACH,YAAY,CAAC,eAAe,EAAE,YAAY,EAAE,IAAI,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,QAKjF;IAED;;;;;OAKG;IACG,WAAW,CAAC,eAAe,EAAE,YAAY,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,EAAE,EAAE,GAAG,IAAI,CAAC,CAW9F;IAED;;;;OAIG;IACH,aAAa,CAAC,eAAe,EAAE,YAAY,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,QAGnE;IAED;;;;;;;;;;OAUG;IACH,WAAW,CACT,eAAe,EAAE,YAAY,EAC7B,OAAO,EAAE,EAAE,EACX,OAAO,EAAE,EAAE,EACX,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,MAAM,GACZ,OAAO,CAAC,IAAI,CAAC,CA2Bf;IAED;;;;;;;OAOG;IACH,oBAAoB,CAAC,eAAe,EAAE,YAAY,EAAE,QAAQ,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAqB/G;IAED,gBAAgB,CAAC,eAAe,EAAE,YAAY,EAAE,QAAQ,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,EAAE,EAAE,EAAE,CAAC,CA2B5F;IAED,eAAe,CAAC,eAAe,EAAE,YAAY,EAAE,QAAQ,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,iBA2B1F;CACF"}
1
+ {"version":3,"file":"capsule_store.d.ts","sourceRoot":"","sources":["../../../src/storage/capsule_store/capsule_store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AACpD,OAAO,EAAE,KAAK,MAAM,EAAgB,MAAM,uBAAuB,CAAC;AAClE,OAAO,KAAK,EAAE,iBAAiB,EAAiB,MAAM,iBAAiB,CAAC;AACxE,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAE3D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,0CAA0C,CAAC;AAE5E,qBAAa,YAAa,YAAW,WAAW;;IAC9C,QAAQ,CAAC,SAAS,aAAa;IAa/B,MAAM,EAAE,MAAM,CAAC;IAEf,YAAY,KAAK,EAAE,iBAAiB,EAQnC;IA+DD;;;;;;OAMG;IACG,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAezC;IAED;;OAEG;IACH,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAG1C;IAED;;;;;;;;;;OAUG;IACH,UAAU,CAAC,eAAe,EAAE,YAAY,EAAE,IAAI,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,YAAY,QAKpG;IAED;;;;;OAKG;IACH,UAAU,CAAC,eAAe,EAAE,YAAY,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,YAAY,GAAG,OAAO,CAAC,EAAE,EAAE,GAAG,IAAI,CAAC,CAE5G;IAqBD;;;;OAIG;IACH,aAAa,CAAC,eAAe,EAAE,YAAY,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,YAAY,QAGxF;IAED;;;;;;;;;;OAUG;IACH,WAAW,CACT,eAAe,EAAE,YAAY,EAC7B,OAAO,EAAE,EAAE,EACX,OAAO,EAAE,EAAE,EACX,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,MAAM,EACb,KAAK,EAAE,YAAY,GAClB,OAAO,CAAC,IAAI,CAAC,CA2Bf;IAED;;;;;;;OAOG;IACH,oBAAoB,CAClB,eAAe,EAAE,YAAY,EAC7B,QAAQ,EAAE,EAAE,EACZ,OAAO,EAAE,EAAE,EAAE,EAAE,EACf,KAAK,EAAE,MAAM,EACb,KAAK,EAAE,YAAY,GAClB,OAAO,CAAC,IAAI,CAAC,CAqBf;IAED,gBAAgB,CAAC,eAAe,EAAE,YAAY,EAAE,QAAQ,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,YAAY,GAAG,OAAO,CAAC,EAAE,EAAE,EAAE,CAAC,CA2BjH;IAED,eAAe,CAAC,eAAe,EAAE,YAAY,EAAE,QAAQ,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,YAAY,iBA2B/G;CACF"}