@aztec/pxe 0.0.1-commit.4ad48494d → 0.0.1-commit.4d3c002

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 (196) hide show
  1. package/dest/block_synchronizer/block_synchronizer.d.ts +1 -1
  2. package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
  3. package/dest/block_synchronizer/block_synchronizer.js +6 -0
  4. package/dest/config/index.d.ts +2 -2
  5. package/dest/config/index.d.ts.map +1 -1
  6. package/dest/config/index.js +1 -1
  7. package/dest/config/package_info.js +1 -1
  8. package/dest/contract_function_simulator/contract_function_simulator.d.ts +11 -5
  9. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
  10. package/dest/contract_function_simulator/contract_function_simulator.js +38 -15
  11. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +7 -7
  12. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -1
  13. package/dest/contract_function_simulator/execution_tagging_index_cache.js +19 -11
  14. package/dest/contract_function_simulator/index.d.ts +2 -1
  15. package/dest/contract_function_simulator/index.d.ts.map +1 -1
  16. package/dest/contract_function_simulator/index.js +1 -0
  17. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +3 -5
  18. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts.map +1 -1
  19. package/dest/contract_function_simulator/noir-structs/event_validation_request.js +7 -9
  20. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts +1 -1
  21. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts.map +1 -1
  22. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.js +1 -3
  23. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +3 -6
  24. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
  25. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +5 -10
  26. package/dest/contract_function_simulator/oracle/interfaces.d.ts +50 -45
  27. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
  28. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts +9 -0
  29. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts.map +1 -0
  30. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.js +38 -0
  31. package/dest/contract_function_simulator/oracle/oracle.d.ts +64 -44
  32. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
  33. package/dest/contract_function_simulator/oracle/oracle.js +187 -97
  34. package/dest/contract_function_simulator/oracle/private_execution.js +5 -3
  35. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +23 -48
  36. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
  37. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +50 -81
  38. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +66 -46
  39. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
  40. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +190 -99
  41. package/dest/contract_logging.d.ts +27 -0
  42. package/dest/contract_logging.d.ts.map +1 -0
  43. package/dest/contract_logging.js +38 -0
  44. package/dest/contract_sync/contract_sync_service.d.ts +7 -5
  45. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -1
  46. package/dest/contract_sync/contract_sync_service.js +45 -38
  47. package/dest/contract_sync/helpers.d.ts +2 -2
  48. package/dest/contract_sync/helpers.d.ts.map +1 -1
  49. package/dest/contract_sync/helpers.js +9 -4
  50. package/dest/debug/pxe_debug_utils.d.ts +4 -3
  51. package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
  52. package/dest/debug/pxe_debug_utils.js +4 -4
  53. package/dest/entrypoints/client/bundle/index.d.ts +3 -1
  54. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  55. package/dest/entrypoints/client/bundle/index.js +2 -0
  56. package/dest/entrypoints/client/lazy/index.d.ts +3 -1
  57. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  58. package/dest/entrypoints/client/lazy/index.js +2 -0
  59. package/dest/entrypoints/server/index.d.ts +2 -1
  60. package/dest/entrypoints/server/index.d.ts.map +1 -1
  61. package/dest/entrypoints/server/index.js +1 -0
  62. package/dest/events/event_service.d.ts +3 -2
  63. package/dest/events/event_service.d.ts.map +1 -1
  64. package/dest/events/event_service.js +16 -4
  65. package/dest/logs/log_service.d.ts +6 -6
  66. package/dest/logs/log_service.d.ts.map +1 -1
  67. package/dest/logs/log_service.js +34 -32
  68. package/dest/messages/message_context_service.d.ts +17 -0
  69. package/dest/messages/message_context_service.d.ts.map +1 -0
  70. package/dest/messages/message_context_service.js +36 -0
  71. package/dest/notes/note_service.d.ts +4 -4
  72. package/dest/notes/note_service.d.ts.map +1 -1
  73. package/dest/notes/note_service.js +17 -7
  74. package/dest/notes_filter.d.ts +24 -0
  75. package/dest/notes_filter.d.ts.map +1 -0
  76. package/dest/notes_filter.js +4 -0
  77. package/dest/oracle_version.d.ts +2 -2
  78. package/dest/oracle_version.js +3 -3
  79. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
  80. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
  81. package/dest/private_kernel/hints/{compute_tx_include_by_timestamp.js → compute_tx_expiration_timestamp.js} +12 -12
  82. package/dest/private_kernel/hints/index.d.ts +1 -1
  83. package/dest/private_kernel/hints/index.js +1 -1
  84. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +4 -3
  85. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -1
  86. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.js +129 -68
  87. package/dest/private_kernel/hints/test_utils.d.ts +122 -0
  88. package/dest/private_kernel/hints/test_utils.d.ts.map +1 -0
  89. package/dest/private_kernel/hints/test_utils.js +203 -0
  90. package/dest/private_kernel/private_kernel_execution_prover.d.ts +1 -1
  91. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
  92. package/dest/private_kernel/private_kernel_execution_prover.js +19 -11
  93. package/dest/private_kernel/private_kernel_oracle.d.ts +6 -2
  94. package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
  95. package/dest/private_kernel/private_kernel_oracle.js +7 -3
  96. package/dest/pxe.d.ts +18 -14
  97. package/dest/pxe.d.ts.map +1 -1
  98. package/dest/pxe.js +73 -47
  99. package/dest/storage/capsule_store/capsule_service.d.ts +21 -0
  100. package/dest/storage/capsule_store/capsule_service.d.ts.map +1 -0
  101. package/dest/storage/capsule_store/capsule_service.js +50 -0
  102. package/dest/storage/capsule_store/capsule_store.d.ts +9 -9
  103. package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -1
  104. package/dest/storage/capsule_store/capsule_store.js +33 -28
  105. package/dest/storage/capsule_store/index.d.ts +2 -1
  106. package/dest/storage/capsule_store/index.d.ts.map +1 -1
  107. package/dest/storage/capsule_store/index.js +1 -0
  108. package/dest/storage/contract_store/contract_store.d.ts +42 -15
  109. package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
  110. package/dest/storage/contract_store/contract_store.js +140 -64
  111. package/dest/storage/metadata.d.ts +1 -1
  112. package/dest/storage/metadata.js +1 -1
  113. package/dest/storage/note_store/note_store.d.ts +3 -2
  114. package/dest/storage/note_store/note_store.d.ts.map +1 -1
  115. package/dest/storage/note_store/note_store.js +2 -2
  116. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +6 -6
  117. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
  118. package/dest/storage/tagging_store/sender_tagging_store.d.ts +29 -28
  119. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
  120. package/dest/storage/tagging_store/sender_tagging_store.js +141 -115
  121. package/dest/tagging/get_all_logs_by_tags.d.ts +1 -1
  122. package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -1
  123. package/dest/tagging/get_all_logs_by_tags.js +17 -3
  124. package/dest/tagging/index.d.ts +3 -3
  125. package/dest/tagging/index.d.ts.map +1 -1
  126. package/dest/tagging/index.js +1 -1
  127. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +4 -5
  128. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +1 -1
  129. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +7 -7
  130. package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +2 -2
  131. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +6 -7
  132. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +1 -1
  133. package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +12 -11
  134. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +4 -8
  135. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
  136. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +13 -7
  137. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +4 -3
  138. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -1
  139. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +20 -10
  140. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +5 -7
  141. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -1
  142. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +36 -24
  143. package/package.json +16 -16
  144. package/src/block_synchronizer/block_synchronizer.ts +6 -0
  145. package/src/config/index.ts +1 -1
  146. package/src/config/package_info.ts +1 -1
  147. package/src/contract_function_simulator/contract_function_simulator.ts +60 -29
  148. package/src/contract_function_simulator/execution_tagging_index_cache.ts +19 -14
  149. package/src/contract_function_simulator/index.ts +1 -0
  150. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +8 -8
  151. package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +1 -4
  152. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +3 -9
  153. package/src/contract_function_simulator/oracle/interfaces.ts +63 -54
  154. package/src/contract_function_simulator/oracle/legacy_oracle_mappings.ts +98 -0
  155. package/src/contract_function_simulator/oracle/oracle.ts +223 -139
  156. package/src/contract_function_simulator/oracle/private_execution.ts +4 -4
  157. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +58 -102
  158. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +320 -122
  159. package/src/contract_logging.ts +52 -0
  160. package/src/contract_sync/contract_sync_service.ts +79 -54
  161. package/src/contract_sync/helpers.ts +8 -3
  162. package/src/debug/pxe_debug_utils.ts +8 -7
  163. package/src/entrypoints/client/bundle/index.ts +2 -0
  164. package/src/entrypoints/client/lazy/index.ts +2 -0
  165. package/src/entrypoints/server/index.ts +1 -0
  166. package/src/events/event_service.ts +17 -4
  167. package/src/logs/log_service.ts +68 -51
  168. package/src/messages/message_context_service.ts +44 -0
  169. package/src/notes/note_service.ts +19 -8
  170. package/src/notes_filter.ts +24 -0
  171. package/src/oracle_version.ts +3 -3
  172. package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
  173. package/src/private_kernel/hints/index.ts +1 -1
  174. package/src/private_kernel/hints/private_kernel_reset_private_inputs_builder.ts +164 -117
  175. package/src/private_kernel/hints/test_utils.ts +325 -0
  176. package/src/private_kernel/private_kernel_execution_prover.ts +19 -12
  177. package/src/private_kernel/private_kernel_oracle.ts +7 -7
  178. package/src/pxe.ts +103 -61
  179. package/src/storage/capsule_store/capsule_service.ts +90 -0
  180. package/src/storage/capsule_store/capsule_store.ts +34 -26
  181. package/src/storage/capsule_store/index.ts +1 -0
  182. package/src/storage/contract_store/contract_store.ts +170 -71
  183. package/src/storage/metadata.ts +1 -1
  184. package/src/storage/note_store/note_store.ts +4 -3
  185. package/src/storage/tagging_store/recipient_tagging_store.ts +9 -5
  186. package/src/storage/tagging_store/sender_tagging_store.ts +185 -138
  187. package/src/tagging/get_all_logs_by_tags.ts +28 -4
  188. package/src/tagging/index.ts +2 -2
  189. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +7 -10
  190. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +2 -2
  191. package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +10 -15
  192. package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +23 -10
  193. package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +26 -11
  194. package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +27 -26
  195. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts +0 -4
  196. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts.map +0 -1
@@ -77,6 +77,8 @@ export class BlockSynchronizer implements L2BlockStreamEventHandler {
77
77
  const blockHeader = await this.node.getBlockHeader(BlockNumber(event.block.number));
78
78
  if (blockHeader) {
79
79
  await this.updateAnchorBlockHeader(blockHeader);
80
+ } else {
81
+ this.log.warn(`Block header not found for proven block ${event.block.number}, skipping anchor update`);
80
82
  }
81
83
  }
82
84
  break;
@@ -86,6 +88,8 @@ export class BlockSynchronizer implements L2BlockStreamEventHandler {
86
88
  const blockHeader = await this.node.getBlockHeader(BlockNumber(event.block.number));
87
89
  if (blockHeader) {
88
90
  await this.updateAnchorBlockHeader(blockHeader);
91
+ } else {
92
+ this.log.warn(`Block header not found for finalized block ${event.block.number}, skipping anchor update`);
89
93
  }
90
94
  }
91
95
  break;
@@ -152,6 +156,8 @@ export class BlockSynchronizer implements L2BlockStreamEventHandler {
152
156
  }
153
157
 
154
158
  this.log.debug(`Syncing PXE with the node`);
159
+ // Capture the promise locally so we always await the exact promise we created, even if this.isSyncing is modified
160
+ // between assignment and await (e.g. due to future refactors introducing a yield point).
155
161
  const isSyncing = this.doSync();
156
162
  this.isSyncing = isSyncing;
157
163
  try {
@@ -5,8 +5,8 @@ import {
5
5
  numberConfigHelper,
6
6
  parseBooleanEnv,
7
7
  } from '@aztec/foundation/config';
8
- import { type DataStoreConfig, dataConfigMappings } from '@aztec/kv-store/config';
9
8
  import { type ChainConfig, chainConfigMappings } from '@aztec/stdlib/config';
9
+ import { type DataStoreConfig, dataConfigMappings } from '@aztec/stdlib/kv-store';
10
10
 
11
11
  export { getPackageInfo } from './package_info.js';
12
12
 
@@ -1,3 +1,3 @@
1
1
  export function getPackageInfo() {
2
- return { version: '4.0.0', name: '@aztec/pxe' };
2
+ return { version: '5.0.0', name: '@aztec/pxe' };
3
3
  }
@@ -2,11 +2,8 @@ import {
2
2
  AVM_EMITNOTEHASH_BASE_L2_GAS,
3
3
  AVM_EMITNULLIFIER_BASE_L2_GAS,
4
4
  AVM_SENDL2TOL1MSG_BASE_L2_GAS,
5
- DA_BYTES_PER_FIELD,
6
- DA_GAS_PER_BYTE,
5
+ DA_GAS_PER_FIELD,
7
6
  FIXED_AVM_STARTUP_L2_GAS,
8
- FIXED_DA_GAS,
9
- FIXED_L2_GAS,
10
7
  L2_GAS_PER_CONTRACT_CLASS_LOG,
11
8
  L2_GAS_PER_L2_TO_L1_MSG,
12
9
  L2_GAS_PER_NOTE_HASH,
@@ -20,6 +17,10 @@ import {
20
17
  MAX_NULLIFIERS_PER_TX,
21
18
  MAX_NULLIFIER_READ_REQUESTS_PER_TX,
22
19
  MAX_PRIVATE_LOGS_PER_TX,
20
+ MAX_TX_LIFETIME,
21
+ PRIVATE_TX_L2_GAS_OVERHEAD,
22
+ PUBLIC_TX_L2_GAS_OVERHEAD,
23
+ TX_DA_GAS_OVERHEAD,
23
24
  } from '@aztec/constants';
24
25
  import { arrayNonEmptyLength, padArrayEnd } from '@aztec/foundation/collection';
25
26
  import { Fr } from '@aztec/foundation/curves/bn254';
@@ -79,6 +80,7 @@ import {
79
80
  BlockHeader,
80
81
  CallContext,
81
82
  HashedValues,
83
+ type OffchainEffect,
82
84
  PrivateExecutionResult,
83
85
  TxConstantData,
84
86
  TxExecutionRequest,
@@ -88,7 +90,9 @@ import {
88
90
  } from '@aztec/stdlib/tx';
89
91
 
90
92
  import type { ContractSyncService } from '../contract_sync/contract_sync_service.js';
93
+ import type { MessageContextService } from '../messages/message_context_service.js';
91
94
  import type { AddressStore } from '../storage/address_store/address_store.js';
95
+ import { CapsuleService } from '../storage/capsule_store/capsule_service.js';
92
96
  import type { CapsuleStore } from '../storage/capsule_store/capsule_store.js';
93
97
  import type { ContractStore } from '../storage/contract_store/contract_store.js';
94
98
  import type { NoteStore } from '../storage/note_store/note_store.js';
@@ -117,8 +121,8 @@ export type ContractSimulatorRunOpts = {
117
121
  anchorBlockHeader: BlockHeader;
118
122
  /** The address used as a tagging sender when emitting private logs. */
119
123
  senderForTags?: AztecAddress;
120
- /** The accounts whose notes we can access in this call. Defaults to all. */
121
- scopes?: AztecAddress[];
124
+ /** The accounts whose notes we can access in this call. */
125
+ scopes: AztecAddress[];
122
126
  /** The job ID for staged writes. */
123
127
  jobId: string;
124
128
  };
@@ -137,6 +141,7 @@ export type ContractFunctionSimulatorArgs = {
137
141
  privateEventStore: PrivateEventStore;
138
142
  simulator: CircuitSimulator;
139
143
  contractSyncService: ContractSyncService;
144
+ messageContextService: MessageContextService;
140
145
  };
141
146
 
142
147
  /**
@@ -156,6 +161,7 @@ export class ContractFunctionSimulator {
156
161
  private readonly privateEventStore: PrivateEventStore;
157
162
  private readonly simulator: CircuitSimulator;
158
163
  private readonly contractSyncService: ContractSyncService;
164
+ private readonly messageContextService: MessageContextService;
159
165
 
160
166
  constructor(args: ContractFunctionSimulatorArgs) {
161
167
  this.contractStore = args.contractStore;
@@ -170,6 +176,7 @@ export class ContractFunctionSimulator {
170
176
  this.privateEventStore = args.privateEventStore;
171
177
  this.simulator = args.simulator;
172
178
  this.contractSyncService = args.contractSyncService;
179
+ this.messageContextService = args.messageContextService;
173
180
  this.log = createLogger('simulator');
174
181
  }
175
182
 
@@ -238,8 +245,9 @@ export class ContractFunctionSimulator {
238
245
  senderTaggingStore: this.senderTaggingStore,
239
246
  recipientTaggingStore: this.recipientTaggingStore,
240
247
  senderAddressBookStore: this.senderAddressBookStore,
241
- capsuleStore: this.capsuleStore,
248
+ capsuleService: new CapsuleService(this.capsuleStore, scopes),
242
249
  privateEventStore: this.privateEventStore,
250
+ messageContextService: this.messageContextService,
243
251
  contractSyncService: this.contractSyncService,
244
252
  jobId,
245
253
  totalPublicCalldataCount: 0,
@@ -276,7 +284,7 @@ export class ContractFunctionSimulator {
276
284
  );
277
285
  const publicFunctionsCalldata = await Promise.all(
278
286
  publicCallRequests.map(async r => {
279
- const calldata = await privateExecutionOracle.privateLoadFromExecutionCache(r.calldataHash);
287
+ const calldata = await privateExecutionOracle.getHashPreimage(r.calldataHash);
280
288
  return new HashedValues(calldata, r.calldataHash);
281
289
  }),
282
290
  );
@@ -311,9 +319,9 @@ export class ContractFunctionSimulator {
311
319
  call: FunctionCall,
312
320
  authwits: AuthWitness[],
313
321
  anchorBlockHeader: BlockHeader,
314
- scopes: AztecAddress[] | undefined,
322
+ scopes: AztecAddress[],
315
323
  jobId: string,
316
- ): Promise<Fr[]> {
324
+ ): Promise<{ result: Fr[]; offchainEffects: OffchainEffect[] }> {
317
325
  const entryPointArtifact = await this.contractStore.getFunctionArtifactWithDebugMetadata(call.to, call.selector);
318
326
 
319
327
  if (entryPointArtifact.functionType !== FunctionType.UTILITY) {
@@ -332,8 +340,10 @@ export class ContractFunctionSimulator {
332
340
  aztecNode: this.aztecNode,
333
341
  recipientTaggingStore: this.recipientTaggingStore,
334
342
  senderAddressBookStore: this.senderAddressBookStore,
335
- capsuleStore: this.capsuleStore,
343
+ capsuleService: new CapsuleService(this.capsuleStore, scopes),
336
344
  privateEventStore: this.privateEventStore,
345
+ messageContextService: this.messageContextService,
346
+ contractSyncService: this.contractSyncService,
337
347
  jobId,
338
348
  scopes,
339
349
  });
@@ -360,8 +370,11 @@ export class ContractFunctionSimulator {
360
370
  );
361
371
  });
362
372
 
363
- this.log.verbose(`Utility simulation for ${call.to}.${call.selector} completed`);
364
- return witnessMapToFields(acirExecutionResult.returnWitness);
373
+ this.log.verbose(`Utility execution for ${call.to}.${call.selector} completed`);
374
+ return {
375
+ result: witnessMapToFields(acirExecutionResult.returnWitness),
376
+ offchainEffects: oracle.getOffchainEffects(),
377
+ };
365
378
  } catch (err) {
366
379
  throw createSimulationError(err instanceof Error ? err : new Error('Unknown error during private execution'));
367
380
  }
@@ -431,14 +444,34 @@ export async function generateSimulatedProvingResult(
431
444
 
432
445
  let publicTeardownCallRequest;
433
446
 
447
+ // We set expiration timestamp to anchor_block_timestamp + MAX_TX_LIFETIME (24h) just like kernels do
448
+ let expirationTimestamp =
449
+ privateExecutionResult.entrypoint.publicInputs.anchorBlockHeader.globalVariables.timestamp +
450
+ BigInt(MAX_TX_LIFETIME);
451
+
452
+ let feePayer = AztecAddress.zero();
453
+
434
454
  const executions = [privateExecutionResult.entrypoint];
435
455
 
436
456
  while (executions.length !== 0) {
437
457
  const execution = executions.shift()!;
438
458
  executions.unshift(...execution!.nestedExecutionResults);
439
459
 
460
+ // Just like kernels we overwrite the default value if the call sets it.
461
+ const callExpirationTimestamp = execution.publicInputs.expirationTimestamp;
462
+ if (callExpirationTimestamp !== 0n && callExpirationTimestamp < expirationTimestamp) {
463
+ expirationTimestamp = callExpirationTimestamp;
464
+ }
465
+
440
466
  const { contractAddress } = execution.publicInputs.callContext;
441
467
 
468
+ if (execution.publicInputs.isFeePayer) {
469
+ if (!feePayer.isZero()) {
470
+ throw new Error('Multiple fee payers found in private execution result');
471
+ }
472
+ feePayer = contractAddress;
473
+ }
474
+
442
475
  scopedNoteHashes.push(
443
476
  ...execution.publicInputs.noteHashes
444
477
  .getActiveItems()
@@ -653,9 +686,14 @@ export async function generateSimulatedProvingResult(
653
686
 
654
687
  const publicInputs = new PrivateKernelTailCircuitPublicInputs(
655
688
  constantData,
656
- /*gasUsed=*/ gasUsed.add(Gas.from({ l2Gas: FIXED_L2_GAS, daGas: FIXED_DA_GAS })),
657
- /*feePayer=*/ AztecAddress.zero(),
658
- /*includeByTimestamp=*/ 0n,
689
+ /*gasUsed=*/ gasUsed.add(
690
+ Gas.from({
691
+ l2Gas: isPrivateOnlyTx ? PRIVATE_TX_L2_GAS_OVERHEAD : PUBLIC_TX_L2_GAS_OVERHEAD,
692
+ daGas: TX_DA_GAS_OVERHEAD,
693
+ }),
694
+ ),
695
+ /*feePayer=*/ feePayer,
696
+ /*expirationTimestamp=*/ expirationTimestamp,
659
697
  hasPublicCalls ? inputsForPublic : undefined,
660
698
  !hasPublicCalls ? inputsForRollup : undefined,
661
699
  );
@@ -683,6 +721,7 @@ function squashTransientSideEffects(
683
721
  scopedNullifiersCLA,
684
722
  /*futureNoteHashReads=*/ [],
685
723
  /*futureNullifierReads=*/ [],
724
+ /*futureLogs=*/ [],
686
725
  noteHashNullifierCounterMap,
687
726
  minRevertibleSideEffectCounter,
688
727
  );
@@ -725,16 +764,8 @@ async function verifyReadRequests(
725
764
  nullifierReadRequests.length,
726
765
  );
727
766
 
728
- const noteHashResetActions = getNoteHashReadRequestResetActions(
729
- noteHashReadRequestsCLA,
730
- scopedNoteHashesCLA,
731
- /*futureNoteHashes=*/ [],
732
- );
733
- const nullifierResetActions = getNullifierReadRequestResetActions(
734
- nullifierReadRequestsCLA,
735
- scopedNullifiersCLA,
736
- /*futureNullifiers=*/ [],
737
- );
767
+ const noteHashResetActions = getNoteHashReadRequestResetActions(noteHashReadRequestsCLA, scopedNoteHashesCLA);
768
+ const nullifierResetActions = getNullifierReadRequestResetActions(nullifierReadRequestsCLA, scopedNullifiersCLA);
738
769
 
739
770
  const settledNoteHashReads: { index: number; value: Fr }[] = [];
740
771
  for (let i = 0; i < noteHashResetActions.actions.length; i++) {
@@ -810,14 +841,14 @@ function meterGasUsed(data: PrivateToRollupAccumulatedData | PrivateToPublicAccu
810
841
  meteredL2Gas += numPrivatelogs * L2_GAS_PER_PRIVATE_LOG;
811
842
 
812
843
  const numContractClassLogs = arrayNonEmptyLength(data.contractClassLogsHashes, log => log.isEmpty());
813
- // Every contract class log emits its length and contract address as additional fields
844
+ // Every contract class log emits its contract address as an additional field
814
845
  meteredDAFields += data.contractClassLogsHashes.reduce(
815
- (acc, log) => (!log.isEmpty() ? acc + log.logHash.length + 2 : acc),
846
+ (acc, log) => (!log.isEmpty() ? acc + log.logHash.length + 1 : acc),
816
847
  0,
817
848
  );
818
849
  meteredL2Gas += numContractClassLogs * L2_GAS_PER_CONTRACT_CLASS_LOG;
819
850
 
820
- const meteredDAGas = meteredDAFields * DA_BYTES_PER_FIELD * DA_GAS_PER_BYTE;
851
+ const meteredDAGas = meteredDAFields * DA_GAS_PER_FIELD;
821
852
 
822
853
  if ((data as PrivateToPublicAccumulatedData).publicCallRequests) {
823
854
  const dataForPublic = data as PrivateToPublicAccumulatedData;
@@ -1,32 +1,37 @@
1
- import { DirectionalAppTaggingSecret, type PreTag } from '@aztec/stdlib/logs';
1
+ import { ExtendedDirectionalAppTaggingSecret, type TaggingIndexRange } from '@aztec/stdlib/logs';
2
2
 
3
3
  /**
4
- * A map that stores the tagging index for a given directional app tagging secret.
4
+ * A map that stores the tagging index range for a given extended directional app tagging secret.
5
5
  * Note: The directional app tagging secret is unique for a (sender, recipient, contract) tuple while the direction
6
6
  * of sender -> recipient matters.
7
7
  */
8
8
  export class ExecutionTaggingIndexCache {
9
- private taggingIndexMap: Map<string, number> = new Map();
9
+ private taggingIndexMap: Map<string, { lowestIndex: number; highestIndex: number }> = new Map();
10
10
 
11
- public getLastUsedIndex(secret: DirectionalAppTaggingSecret): number | undefined {
12
- return this.taggingIndexMap.get(secret.toString());
11
+ public getLastUsedIndex(secret: ExtendedDirectionalAppTaggingSecret): number | undefined {
12
+ return this.taggingIndexMap.get(secret.toString())?.highestIndex;
13
13
  }
14
14
 
15
- public setLastUsedIndex(secret: DirectionalAppTaggingSecret, index: number) {
15
+ public setLastUsedIndex(secret: ExtendedDirectionalAppTaggingSecret, index: number) {
16
16
  const currentValue = this.taggingIndexMap.get(secret.toString());
17
- if (currentValue !== undefined && currentValue !== index - 1) {
18
- throw new Error(`Invalid tagging index update. Current value: ${currentValue}, new value: ${index}`);
17
+ if (currentValue !== undefined && currentValue.highestIndex !== index - 1) {
18
+ throw new Error(`Invalid tagging index update. Current value: ${currentValue.highestIndex}, new value: ${index}`);
19
+ }
20
+ if (currentValue !== undefined) {
21
+ currentValue.highestIndex = index;
22
+ } else {
23
+ this.taggingIndexMap.set(secret.toString(), { lowestIndex: index, highestIndex: index });
19
24
  }
20
- this.taggingIndexMap.set(secret.toString(), index);
21
25
  }
22
26
 
23
27
  /**
24
- * Returns the pre-tags that were used in this execution (and that need to be stored in the db).
28
+ * Returns the tagging index ranges that were used in this execution (and that need to be stored in the db).
25
29
  */
26
- public getUsedPreTags(): PreTag[] {
27
- return Array.from(this.taggingIndexMap.entries()).map(([secret, index]) => ({
28
- secret: DirectionalAppTaggingSecret.fromString(secret),
29
- index,
30
+ public getUsedTaggingIndexRanges(): TaggingIndexRange[] {
31
+ return Array.from(this.taggingIndexMap.entries()).map(([secret, { lowestIndex, highestIndex }]) => ({
32
+ extendedSecret: ExtendedDirectionalAppTaggingSecret.fromString(secret),
33
+ lowestIndex,
34
+ highestIndex,
30
35
  }));
31
36
  }
32
37
  }
@@ -4,6 +4,7 @@ export { HashedValuesCache } from './hashed_values_cache.js';
4
4
  export { pickNotes } from './pick_notes.js';
5
5
  export type { NoteData, IMiscOracle, IUtilityExecutionOracle, IPrivateExecutionOracle } from './oracle/interfaces.js';
6
6
  export { MessageLoadOracleInputs } from './oracle/message_load_oracle_inputs.js';
7
+ export { MessageContextService } from '../messages/message_context_service.js';
7
8
  export { UtilityExecutionOracle } from './oracle/utility_execution_oracle.js';
8
9
  export { PrivateExecutionOracle } from './oracle/private_execution_oracle.js';
9
10
  export { Oracle } from './oracle/oracle.js';
@@ -4,9 +4,6 @@ import { EventSelector } from '@aztec/stdlib/abi';
4
4
  import { AztecAddress } from '@aztec/stdlib/aztec-address';
5
5
  import { TxHash } from '@aztec/stdlib/tx';
6
6
 
7
- // TODO(#14617): should we compute this from constants? This value is aztec-nr specific.
8
- const MAX_EVENT_SERIALIZED_LEN = 12;
9
-
10
7
  /**
11
8
  * Intermediate struct used to perform batch event validation by PXE. The `utilityValidateAndStoreEnqueuedNotesAndEvents` oracle
12
9
  * expects for values of this type to be stored in a `CapsuleArray`.
@@ -19,10 +16,9 @@ export class EventValidationRequest {
19
16
  public serializedEvent: Fr[],
20
17
  public eventCommitment: Fr,
21
18
  public txHash: TxHash,
22
- public recipient: AztecAddress,
23
19
  ) {}
24
20
 
25
- static fromFields(fields: Fr[] | FieldReader): EventValidationRequest {
21
+ static fromFields(fields: Fr[], maxEventSerializedLen: number): EventValidationRequest {
26
22
  const reader = FieldReader.asReader(fields);
27
23
 
28
24
  const contractAddress = AztecAddress.fromField(reader.readField());
@@ -30,13 +26,18 @@ export class EventValidationRequest {
30
26
 
31
27
  const randomness = reader.readField();
32
28
 
33
- const eventStorage = reader.readFieldArray(MAX_EVENT_SERIALIZED_LEN);
29
+ const eventStorage = reader.readFieldArray(maxEventSerializedLen);
34
30
  const eventLen = reader.readField().toNumber();
35
31
  const serializedEvent = eventStorage.slice(0, eventLen);
36
32
 
37
33
  const eventCommitment = reader.readField();
38
34
  const txHash = TxHash.fromField(reader.readField());
39
- const recipient = AztecAddress.fromField(reader.readField());
35
+
36
+ if (reader.remainingFields() !== 0) {
37
+ throw new Error(
38
+ `Error converting array of fields to EventValidationRequest: expected ${reader.cursor} fields but received ${fields.length} (maxEventSerializedLen=${maxEventSerializedLen}).`,
39
+ );
40
+ }
40
41
 
41
42
  return new EventValidationRequest(
42
43
  contractAddress,
@@ -45,7 +46,6 @@ export class EventValidationRequest {
45
46
  serializedEvent,
46
47
  eventCommitment,
47
48
  txHash,
48
- recipient,
49
49
  );
50
50
  }
51
51
  }
@@ -3,10 +3,7 @@ import { range } from '@aztec/foundation/array';
3
3
  import { Fr } from '@aztec/foundation/curves/bn254';
4
4
  import type { TxHash } from '@aztec/stdlib/tx';
5
5
 
6
- import { MAX_NOTE_PACKED_LEN } from './note_validation_request.js';
7
-
8
- const MAX_PUBLIC_LOG_LEN_FOR_NOTE_COMPLETION = MAX_NOTE_PACKED_LEN;
9
- const MAX_LOG_CONTENT_LEN = Math.max(MAX_PUBLIC_LOG_LEN_FOR_NOTE_COMPLETION, PRIVATE_LOG_CIPHERTEXT_LEN);
6
+ const MAX_LOG_CONTENT_LEN = PRIVATE_LOG_CIPHERTEXT_LEN;
10
7
 
11
8
  /**
12
9
  * Intermediate struct used to perform batch log retrieval by PXE. The `utilityBulkRetrieveLogs` oracle stores values of this
@@ -3,9 +3,6 @@ import { FieldReader } from '@aztec/foundation/serialize';
3
3
  import { AztecAddress } from '@aztec/stdlib/aztec-address';
4
4
  import { TxHash } from '@aztec/stdlib/tx';
5
5
 
6
- // TODO(#14617): should we compute this from constants? This value is aztec-nr specific.
7
- export const MAX_NOTE_PACKED_LEN = 10;
8
-
9
6
  /**
10
7
  * Intermediate struct used to perform batch note validation by PXE. The `utilityValidateAndStoreEnqueuedNotesAndEvents` oracle
11
8
  * expects for values of this type to be stored in a `CapsuleArray`.
@@ -21,10 +18,9 @@ export class NoteValidationRequest {
21
18
  public noteHash: Fr,
22
19
  public nullifier: Fr,
23
20
  public txHash: TxHash,
24
- public recipient: AztecAddress,
25
21
  ) {}
26
22
 
27
- static fromFields(fields: Fr[] | FieldReader): NoteValidationRequest {
23
+ static fromFields(fields: Fr[], maxNotePackedLen: number): NoteValidationRequest {
28
24
  const reader = FieldReader.asReader(fields);
29
25
 
30
26
  const contractAddress = AztecAddress.fromField(reader.readField());
@@ -33,18 +29,17 @@ export class NoteValidationRequest {
33
29
  const randomness = reader.readField();
34
30
  const noteNonce = reader.readField();
35
31
 
36
- const contentStorage = reader.readFieldArray(MAX_NOTE_PACKED_LEN);
32
+ const contentStorage = reader.readFieldArray(maxNotePackedLen);
37
33
  const contentLen = reader.readField().toNumber();
38
34
  const content = contentStorage.slice(0, contentLen);
39
35
 
40
36
  const noteHash = reader.readField();
41
37
  const nullifier = reader.readField();
42
38
  const txHash = TxHash.fromField(reader.readField());
43
- const recipient = AztecAddress.fromField(reader.readField());
44
39
 
45
40
  if (reader.remainingFields() !== 0) {
46
41
  throw new Error(
47
- `Error converting array of fields to NoteValidationRequest. Hint: check that MAX_NOTE_PACKED_LEN is consistent with private_notes::MAX_NOTE_PACKED_LEN in Aztec-nr.`,
42
+ `Error converting array of fields to NoteValidationRequest: expected ${reader.cursor} fields but received ${fields.length} (maxNotePackedLen=${maxNotePackedLen}).`,
48
43
  );
49
44
  }
50
45
 
@@ -58,7 +53,6 @@ export class NoteValidationRequest {
58
53
  noteHash,
59
54
  nullifier,
60
55
  txHash,
61
- recipient,
62
56
  );
63
57
  }
64
58
  }
@@ -6,8 +6,9 @@ import { MembershipWitness } from '@aztec/foundation/trees';
6
6
  import type { FunctionSelector, NoteSelector } from '@aztec/stdlib/abi';
7
7
  import type { AztecAddress } from '@aztec/stdlib/aztec-address';
8
8
  import { BlockHash } from '@aztec/stdlib/block';
9
- import type { CompleteAddress, ContractInstance } from '@aztec/stdlib/contract';
9
+ import type { ContractInstance, PartialAddress } from '@aztec/stdlib/contract';
10
10
  import type { KeyValidationRequest } from '@aztec/stdlib/kernel';
11
+ import type { PublicKeys } from '@aztec/stdlib/keys';
11
12
  import type { ContractClassLog, Tag } from '@aztec/stdlib/logs';
12
13
  import type { Note, NoteStatus } from '@aztec/stdlib/note';
13
14
  import { type NullifierMembershipWitness, PublicDataWitness } from '@aztec/stdlib/trees';
@@ -52,9 +53,9 @@ export interface NoteData {
52
53
  export interface IMiscOracle {
53
54
  isMisc: true;
54
55
 
55
- utilityGetRandomField(): Fr;
56
- utilityAssertCompatibleOracleVersion(version: number): void;
57
- utilityLog(level: number, message: string, fields: Fr[]): Promise<void>;
56
+ getRandomField(): Fr;
57
+ assertCompatibleOracleVersion(version: number): void;
58
+ log(level: number, message: string, fields: Fr[]): Promise<void>;
58
59
  }
59
60
 
60
61
  /**
@@ -64,30 +65,32 @@ export interface IMiscOracle {
64
65
  export interface IUtilityExecutionOracle {
65
66
  isUtility: true;
66
67
 
67
- utilityGetUtilityContext(): UtilityContext;
68
- utilityGetKeyValidationRequest(pkMHash: Fr): Promise<KeyValidationRequest>;
69
- utilityGetContractInstance(address: AztecAddress): Promise<ContractInstance>;
70
- utilityGetNoteHashMembershipWitness(
68
+ getUtilityContext(): UtilityContext;
69
+ getKeyValidationRequest(pkMHash: Fr): Promise<KeyValidationRequest>;
70
+ getContractInstance(address: AztecAddress): Promise<ContractInstance>;
71
+ getNoteHashMembershipWitness(
71
72
  anchorBlockHash: BlockHash,
72
73
  noteHash: Fr,
73
74
  ): Promise<MembershipWitness<typeof NOTE_HASH_TREE_HEIGHT> | undefined>;
74
- utilityGetBlockHashMembershipWitness(
75
+ getBlockHashMembershipWitness(
75
76
  anchorBlockHash: BlockHash,
76
77
  blockHash: BlockHash,
77
78
  ): Promise<MembershipWitness<typeof ARCHIVE_HEIGHT> | undefined>;
78
- utilityGetNullifierMembershipWitness(
79
+ getNullifierMembershipWitness(
79
80
  anchorBlockHash: BlockHash,
80
81
  nullifier: Fr,
81
82
  ): Promise<NullifierMembershipWitness | undefined>;
82
- utilityGetPublicDataWitness(anchorBlockHash: BlockHash, leafSlot: Fr): Promise<PublicDataWitness | undefined>;
83
- utilityGetLowNullifierMembershipWitness(
83
+ getPublicDataWitness(anchorBlockHash: BlockHash, leafSlot: Fr): Promise<PublicDataWitness | undefined>;
84
+ getLowNullifierMembershipWitness(
84
85
  anchorBlockHash: BlockHash,
85
86
  nullifier: Fr,
86
87
  ): Promise<NullifierMembershipWitness | undefined>;
87
- utilityGetBlockHeader(blockNumber: BlockNumber): Promise<BlockHeader | undefined>;
88
- utilityTryGetPublicKeysAndPartialAddress(account: AztecAddress): Promise<CompleteAddress | undefined>;
89
- utilityGetAuthWitness(messageHash: Fr): Promise<Fr[] | undefined>;
90
- utilityGetNotes(
88
+ getBlockHeader(blockNumber: BlockNumber): Promise<BlockHeader | undefined>;
89
+ getPublicKeysAndPartialAddress(
90
+ account: AztecAddress,
91
+ ): Promise<{ publicKeys: PublicKeys; partialAddress: PartialAddress } | undefined>;
92
+ getAuthWitness(messageHash: Fr): Promise<Fr[] | undefined>;
93
+ getNotes(
91
94
  owner: AztecAddress | undefined,
92
95
  storageSlot: Fr,
93
96
  numSelects: number,
@@ -104,35 +107,53 @@ export interface IUtilityExecutionOracle {
104
107
  offset: number,
105
108
  status: NoteStatus,
106
109
  ): Promise<NoteData[]>;
107
- utilityCheckNullifierExists(innerNullifier: Fr): Promise<boolean>;
108
- utilityGetL1ToL2MembershipWitness(
110
+ doesNullifierExist(innerNullifier: Fr): Promise<boolean>;
111
+ getL1ToL2MembershipWitness(
109
112
  contractAddress: AztecAddress,
110
113
  messageHash: Fr,
111
114
  secret: Fr,
112
115
  ): Promise<MessageLoadOracleInputs<typeof L1_TO_L2_MSG_TREE_HEIGHT>>;
113
- utilityStorageRead(
116
+ getFromPublicStorage(
114
117
  anchorBlockHash: BlockHash,
115
118
  contractAddress: AztecAddress,
116
119
  startStorageSlot: Fr,
117
120
  numberOfElements: number,
118
121
  ): Promise<Fr[]>;
119
- utilityFetchTaggedLogs(pendingTaggedLogArrayBaseSlot: Fr): Promise<void>;
120
- utilityValidateAndStoreEnqueuedNotesAndEvents(
122
+ getPendingTaggedLogs(pendingTaggedLogArrayBaseSlot: Fr, scope: AztecAddress): Promise<void>;
123
+ validateAndStoreEnqueuedNotesAndEvents(
121
124
  contractAddress: AztecAddress,
122
125
  noteValidationRequestsArrayBaseSlot: Fr,
123
126
  eventValidationRequestsArrayBaseSlot: Fr,
127
+ maxNotePackedLen: number,
128
+ maxEventSerializedLen: number,
129
+ scope: AztecAddress,
124
130
  ): Promise<void>;
125
- utilityBulkRetrieveLogs(
131
+ getLogsByTag(
126
132
  contractAddress: AztecAddress,
127
133
  logRetrievalRequestsArrayBaseSlot: Fr,
128
134
  logRetrievalResponsesArrayBaseSlot: Fr,
135
+ scope: AztecAddress,
129
136
  ): Promise<void>;
130
- utilityStoreCapsule(contractAddress: AztecAddress, key: Fr, capsule: Fr[]): Promise<void>;
131
- utilityLoadCapsule(contractAddress: AztecAddress, key: Fr): Promise<Fr[] | null>;
132
- utilityDeleteCapsule(contractAddress: AztecAddress, key: Fr): Promise<void>;
133
- utilityCopyCapsule(contractAddress: AztecAddress, srcKey: Fr, dstKey: Fr, numEntries: number): Promise<void>;
134
- utilityAes128Decrypt(ciphertext: Buffer, iv: Buffer, symKey: Buffer): Promise<Buffer>;
135
- utilityGetSharedSecret(address: AztecAddress, ephPk: Point): Promise<Point>;
137
+ getMessageContextsByTxHash(
138
+ contractAddress: AztecAddress,
139
+ messageContextRequestsArrayBaseSlot: Fr,
140
+ messageContextResponsesArrayBaseSlot: Fr,
141
+ scope: AztecAddress,
142
+ ): Promise<void>;
143
+ setCapsule(contractAddress: AztecAddress, key: Fr, capsule: Fr[], scope: AztecAddress): void;
144
+ getCapsule(contractAddress: AztecAddress, key: Fr, scope: AztecAddress): Promise<Fr[] | null>;
145
+ deleteCapsule(contractAddress: AztecAddress, key: Fr, scope: AztecAddress): void;
146
+ copyCapsule(
147
+ contractAddress: AztecAddress,
148
+ srcKey: Fr,
149
+ dstKey: Fr,
150
+ numEntries: number,
151
+ scope: AztecAddress,
152
+ ): Promise<void>;
153
+ decryptAes128(ciphertext: Buffer, iv: Buffer, symKey: Buffer): Promise<Buffer>;
154
+ getSharedSecret(address: AztecAddress, ephPk: Point, contractAddress: AztecAddress): Promise<Fr>;
155
+ setContractSyncCacheInvalid(contractAddress: AztecAddress, scopes: AztecAddress[]): void;
156
+ emitOffchainEffect(data: Fr[]): Promise<void>;
136
157
  }
137
158
 
138
159
  /**
@@ -142,9 +163,9 @@ export interface IUtilityExecutionOracle {
142
163
  export interface IPrivateExecutionOracle {
143
164
  isPrivate: true;
144
165
 
145
- privateStoreInExecutionCache(values: Fr[], hash: Fr): void;
146
- privateLoadFromExecutionCache(hash: Fr): Promise<Fr[]>;
147
- privateNotifyCreatedNote(
166
+ setHashPreimage(values: Fr[], hash: Fr): void;
167
+ getHashPreimage(hash: Fr): Promise<Fr[]>;
168
+ notifyCreatedNote(
148
169
  owner: AztecAddress,
149
170
  storageSlot: Fr,
150
171
  randomness: Fr,
@@ -153,33 +174,21 @@ export interface IPrivateExecutionOracle {
153
174
  noteHash: Fr,
154
175
  counter: number,
155
176
  ): void;
156
- privateNotifyNullifiedNote(innerNullifier: Fr, noteHash: Fr, counter: number): Promise<void>;
157
- privateNotifyCreatedNullifier(innerNullifier: Fr): Promise<void>;
158
- privateIsNullifierPending(innerNullifier: Fr, contractAddress: AztecAddress): Promise<boolean>;
159
- privateNotifyCreatedContractClassLog(log: ContractClassLog, counter: number): void;
160
- privateCallPrivateFunction(
177
+ notifyNullifiedNote(innerNullifier: Fr, noteHash: Fr, counter: number): Promise<void>;
178
+ notifyCreatedNullifier(innerNullifier: Fr): Promise<void>;
179
+ isNullifierPending(innerNullifier: Fr, contractAddress: AztecAddress): Promise<boolean>;
180
+ notifyCreatedContractClassLog(log: ContractClassLog, counter: number): void;
181
+ callPrivateFunction(
161
182
  targetContractAddress: AztecAddress,
162
183
  functionSelector: FunctionSelector,
163
184
  argsHash: Fr,
164
185
  sideEffectCounter: number,
165
186
  isStaticCall: boolean,
166
187
  ): Promise<{ endSideEffectCounter: Fr; returnsHash: Fr }>;
167
- privateNotifyEnqueuedPublicFunctionCall(
168
- targetContractAddress: AztecAddress,
169
- calldataHash: Fr,
170
- sideEffectCounter: number,
171
- isStaticCall: boolean,
172
- ): Promise<void>;
173
- privateNotifySetPublicTeardownFunctionCall(
174
- targetContractAddress: AztecAddress,
175
- calldataHash: Fr,
176
- sideEffectCounter: number,
177
- isStaticCall: boolean,
178
- ): Promise<void>;
179
- privateNotifySetMinRevertibleSideEffectCounter(minRevertibleSideEffectCounter: number): Promise<void>;
180
- privateIsSideEffectCounterRevertible(sideEffectCounter: number): Promise<boolean>;
181
- privateGetSenderForTags(): Promise<AztecAddress | undefined>;
182
- privateSetSenderForTags(senderForTags: AztecAddress): Promise<void>;
183
- privateGetNextAppTagAsSender(sender: AztecAddress, recipient: AztecAddress): Promise<Tag>;
184
- utilityEmitOffchainEffect(data: Fr[]): Promise<void>;
188
+ assertValidPublicCalldata(calldataHash: Fr): Promise<void>;
189
+ notifyRevertiblePhaseStart(minRevertibleSideEffectCounter: number): Promise<void>;
190
+ isExecutionInRevertiblePhase(sideEffectCounter: number): Promise<boolean>;
191
+ getSenderForTags(): Promise<AztecAddress | undefined>;
192
+ setSenderForTags(senderForTags: AztecAddress): Promise<void>;
193
+ getNextAppTagAsSender(sender: AztecAddress, recipient: AztecAddress): Promise<Tag>;
185
194
  }