@aztec/pxe 0.0.1-commit.0c875d939 → 0.0.1-commit.0ec55a70b

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 (249) 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/config/package_info.js +1 -1
  12. package/dest/contract_function_simulator/contract_function_simulator.d.ts +13 -5
  13. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
  14. package/dest/contract_function_simulator/contract_function_simulator.js +46 -20
  15. package/dest/contract_function_simulator/ephemeral_array_service.d.ts +28 -0
  16. package/dest/contract_function_simulator/ephemeral_array_service.d.ts.map +1 -0
  17. package/dest/contract_function_simulator/ephemeral_array_service.js +78 -0
  18. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +7 -7
  19. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -1
  20. package/dest/contract_function_simulator/execution_tagging_index_cache.js +19 -11
  21. package/dest/contract_function_simulator/index.d.ts +2 -1
  22. package/dest/contract_function_simulator/index.d.ts.map +1 -1
  23. package/dest/contract_function_simulator/index.js +1 -0
  24. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +4 -6
  25. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts.map +1 -1
  26. package/dest/contract_function_simulator/noir-structs/event_validation_request.js +8 -10
  27. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts +1 -1
  28. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.js +1 -1
  29. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts +2 -2
  30. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts.map +1 -1
  31. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.js +2 -4
  32. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +4 -7
  33. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
  34. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +6 -11
  35. package/dest/contract_function_simulator/oracle/interfaces.d.ts +63 -45
  36. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
  37. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts +9 -0
  38. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts.map +1 -0
  39. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.js +47 -0
  40. package/dest/contract_function_simulator/oracle/oracle.d.ts +76 -44
  41. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
  42. package/dest/contract_function_simulator/oracle/oracle.js +288 -96
  43. package/dest/contract_function_simulator/oracle/private_execution.js +5 -3
  44. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +32 -59
  45. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
  46. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +69 -96
  47. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +100 -60
  48. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
  49. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +327 -115
  50. package/dest/contract_function_simulator/pick_notes.d.ts +1 -1
  51. package/dest/contract_function_simulator/pick_notes.d.ts.map +1 -1
  52. package/dest/contract_function_simulator/pick_notes.js +20 -3
  53. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts +1 -1
  54. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts.map +1 -1
  55. package/dest/contract_function_simulator/proxied_contract_data_source.js +3 -0
  56. package/dest/contract_logging.d.ts +27 -0
  57. package/dest/contract_logging.d.ts.map +1 -0
  58. package/dest/contract_logging.js +38 -0
  59. package/dest/contract_sync/contract_sync_service.d.ts +6 -5
  60. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -1
  61. package/dest/contract_sync/contract_sync_service.js +62 -43
  62. package/dest/contract_sync/helpers.d.ts +2 -3
  63. package/dest/contract_sync/helpers.d.ts.map +1 -1
  64. package/dest/contract_sync/helpers.js +7 -2
  65. package/dest/debug/pxe_debug_utils.d.ts +3 -3
  66. package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
  67. package/dest/debug/pxe_debug_utils.js +4 -4
  68. package/dest/entrypoints/client/bundle/index.d.ts +2 -2
  69. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  70. package/dest/entrypoints/client/bundle/index.js +1 -1
  71. package/dest/entrypoints/client/bundle/utils.d.ts +2 -2
  72. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  73. package/dest/entrypoints/client/bundle/utils.js +2 -2
  74. package/dest/entrypoints/client/lazy/index.d.ts +2 -2
  75. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  76. package/dest/entrypoints/client/lazy/index.js +1 -1
  77. package/dest/entrypoints/client/lazy/utils.d.ts +2 -2
  78. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  79. package/dest/entrypoints/client/lazy/utils.js +2 -2
  80. package/dest/entrypoints/pxe_creation_options.d.ts +3 -1
  81. package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
  82. package/dest/entrypoints/pxe_creation_options.js +3 -1
  83. package/dest/entrypoints/server/index.d.ts +2 -3
  84. package/dest/entrypoints/server/index.d.ts.map +1 -1
  85. package/dest/entrypoints/server/index.js +1 -2
  86. package/dest/entrypoints/server/utils.d.ts +2 -2
  87. package/dest/entrypoints/server/utils.d.ts.map +1 -1
  88. package/dest/entrypoints/server/utils.js +2 -2
  89. package/dest/events/event_service.d.ts +3 -2
  90. package/dest/events/event_service.d.ts.map +1 -1
  91. package/dest/events/event_service.js +26 -5
  92. package/dest/events/private_event_filter_validator.d.ts +3 -2
  93. package/dest/events/private_event_filter_validator.d.ts.map +1 -1
  94. package/dest/events/private_event_filter_validator.js +15 -0
  95. package/dest/logs/log_service.d.ts +7 -8
  96. package/dest/logs/log_service.d.ts.map +1 -1
  97. package/dest/logs/log_service.js +29 -39
  98. package/dest/messages/message_context_service.d.ts +17 -0
  99. package/dest/messages/message_context_service.d.ts.map +1 -0
  100. package/dest/messages/message_context_service.js +36 -0
  101. package/dest/notes/note_service.d.ts +4 -5
  102. package/dest/notes/note_service.d.ts.map +1 -1
  103. package/dest/notes/note_service.js +14 -5
  104. package/dest/notes_filter.d.ts +2 -3
  105. package/dest/notes_filter.d.ts.map +1 -1
  106. package/dest/oracle_version.d.ts +4 -3
  107. package/dest/oracle_version.d.ts.map +1 -1
  108. package/dest/oracle_version.js +20 -10
  109. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
  110. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
  111. package/dest/private_kernel/hints/{compute_tx_include_by_timestamp.js → compute_tx_expiration_timestamp.js} +12 -12
  112. package/dest/private_kernel/hints/index.d.ts +1 -1
  113. package/dest/private_kernel/hints/index.js +1 -1
  114. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +4 -3
  115. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -1
  116. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.js +129 -68
  117. package/dest/private_kernel/hints/test_utils.d.ts +122 -0
  118. package/dest/private_kernel/hints/test_utils.d.ts.map +1 -0
  119. package/dest/private_kernel/hints/test_utils.js +203 -0
  120. package/dest/private_kernel/private_kernel_execution_prover.d.ts +1 -1
  121. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
  122. package/dest/private_kernel/private_kernel_execution_prover.js +18 -13
  123. package/dest/private_kernel/private_kernel_oracle.d.ts +10 -6
  124. package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
  125. package/dest/private_kernel/private_kernel_oracle.js +19 -18
  126. package/dest/pxe.d.ts +30 -15
  127. package/dest/pxe.d.ts.map +1 -1
  128. package/dest/pxe.js +116 -63
  129. package/dest/storage/anchor_block_store/anchor_block_store.js +1 -1
  130. package/dest/storage/capsule_store/capsule_service.d.ts +21 -0
  131. package/dest/storage/capsule_store/capsule_service.d.ts.map +1 -0
  132. package/dest/storage/capsule_store/capsule_service.js +50 -0
  133. package/dest/storage/capsule_store/capsule_store.d.ts +9 -9
  134. package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -1
  135. package/dest/storage/capsule_store/capsule_store.js +36 -28
  136. package/dest/storage/capsule_store/index.d.ts +2 -1
  137. package/dest/storage/capsule_store/index.d.ts.map +1 -1
  138. package/dest/storage/capsule_store/index.js +1 -0
  139. package/dest/storage/contract_store/contract_store.d.ts +42 -15
  140. package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
  141. package/dest/storage/contract_store/contract_store.js +143 -65
  142. package/dest/storage/metadata.d.ts +1 -1
  143. package/dest/storage/metadata.js +1 -1
  144. package/dest/storage/note_store/note_store.d.ts +1 -1
  145. package/dest/storage/note_store/note_store.d.ts.map +1 -1
  146. package/dest/storage/note_store/note_store.js +2 -2
  147. package/dest/storage/private_event_store/private_event_store.d.ts +1 -1
  148. package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -1
  149. package/dest/storage/private_event_store/private_event_store.js +3 -0
  150. package/dest/storage/private_event_store/stored_private_event.js +1 -1
  151. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +6 -6
  152. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
  153. package/dest/storage/tagging_store/sender_tagging_store.d.ts +29 -28
  154. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
  155. package/dest/storage/tagging_store/sender_tagging_store.js +141 -115
  156. package/dest/tagging/get_all_logs_by_tags.d.ts +1 -1
  157. package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -1
  158. package/dest/tagging/get_all_logs_by_tags.js +17 -3
  159. package/dest/tagging/index.d.ts +3 -3
  160. package/dest/tagging/index.d.ts.map +1 -1
  161. package/dest/tagging/index.js +1 -1
  162. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +4 -5
  163. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +1 -1
  164. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +8 -22
  165. package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +2 -2
  166. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +6 -7
  167. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +1 -1
  168. package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +12 -11
  169. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +4 -8
  170. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
  171. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +13 -7
  172. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +4 -3
  173. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -1
  174. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +20 -10
  175. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +5 -7
  176. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -1
  177. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +36 -24
  178. package/package.json +16 -16
  179. package/src/bin/check_oracle_version.ts +4 -4
  180. package/src/block_synchronizer/block_stream_source.ts +52 -0
  181. package/src/block_synchronizer/block_synchronizer.ts +33 -11
  182. package/src/config/index.ts +3 -9
  183. package/src/config/package_info.ts +1 -1
  184. package/src/contract_function_simulator/contract_function_simulator.ts +67 -33
  185. package/src/contract_function_simulator/ephemeral_array_service.ts +110 -0
  186. package/src/contract_function_simulator/execution_tagging_index_cache.ts +19 -14
  187. package/src/contract_function_simulator/index.ts +1 -0
  188. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +9 -9
  189. package/src/contract_function_simulator/noir-structs/log_retrieval_request.ts +1 -1
  190. package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +2 -5
  191. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +4 -10
  192. package/src/contract_function_simulator/oracle/interfaces.ts +91 -53
  193. package/src/contract_function_simulator/oracle/legacy_oracle_mappings.ts +104 -0
  194. package/src/contract_function_simulator/oracle/oracle.ts +377 -139
  195. package/src/contract_function_simulator/oracle/private_execution.ts +4 -4
  196. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +89 -120
  197. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +536 -153
  198. package/src/contract_function_simulator/pick_notes.ts +22 -3
  199. package/src/contract_function_simulator/proxied_contract_data_source.ts +8 -1
  200. package/src/contract_logging.ts +52 -0
  201. package/src/contract_sync/contract_sync_service.ts +99 -75
  202. package/src/contract_sync/helpers.ts +4 -4
  203. package/src/debug/pxe_debug_utils.ts +7 -7
  204. package/src/entrypoints/client/bundle/index.ts +1 -1
  205. package/src/entrypoints/client/bundle/utils.ts +2 -3
  206. package/src/entrypoints/client/lazy/index.ts +1 -1
  207. package/src/entrypoints/client/lazy/utils.ts +2 -3
  208. package/src/entrypoints/pxe_creation_options.ts +7 -0
  209. package/src/entrypoints/server/index.ts +1 -2
  210. package/src/entrypoints/server/utils.ts +2 -3
  211. package/src/events/event_service.ts +30 -5
  212. package/src/events/private_event_filter_validator.ts +21 -1
  213. package/src/logs/log_service.ts +59 -75
  214. package/src/messages/message_context_service.ts +44 -0
  215. package/src/notes/note_service.ts +18 -8
  216. package/src/notes_filter.ts +1 -3
  217. package/src/oracle_version.ts +20 -10
  218. package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
  219. package/src/private_kernel/hints/index.ts +1 -1
  220. package/src/private_kernel/hints/private_kernel_reset_private_inputs_builder.ts +164 -117
  221. package/src/private_kernel/hints/test_utils.ts +325 -0
  222. package/src/private_kernel/private_kernel_execution_prover.ts +18 -16
  223. package/src/private_kernel/private_kernel_oracle.ts +21 -21
  224. package/src/pxe.ts +184 -81
  225. package/src/storage/anchor_block_store/anchor_block_store.ts +1 -1
  226. package/src/storage/capsule_store/capsule_service.ts +90 -0
  227. package/src/storage/capsule_store/capsule_store.ts +44 -26
  228. package/src/storage/capsule_store/index.ts +1 -0
  229. package/src/storage/contract_store/contract_store.ts +177 -76
  230. package/src/storage/metadata.ts +1 -1
  231. package/src/storage/note_store/note_store.ts +2 -5
  232. package/src/storage/private_event_store/private_event_store.ts +4 -0
  233. package/src/storage/private_event_store/stored_private_event.ts +1 -1
  234. package/src/storage/tagging_store/recipient_tagging_store.ts +9 -5
  235. package/src/storage/tagging_store/sender_tagging_store.ts +185 -138
  236. package/src/tagging/get_all_logs_by_tags.ts +28 -4
  237. package/src/tagging/index.ts +2 -2
  238. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +12 -25
  239. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +2 -2
  240. package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +10 -15
  241. package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +23 -10
  242. package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +26 -11
  243. package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +27 -26
  244. package/dest/access_scopes.d.ts +0 -9
  245. package/dest/access_scopes.d.ts.map +0 -1
  246. package/dest/access_scopes.js +0 -6
  247. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts +0 -4
  248. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts.map +0 -1
  249. package/src/access_scopes.ts +0 -9
@@ -6,7 +6,7 @@ import { toACVMWitness } from '@aztec/simulator/client';
6
6
  import { FunctionSelector, countArgumentsSize } from '@aztec/stdlib/abi';
7
7
  import { siloNullifier } from '@aztec/stdlib/hash';
8
8
  import { PrivateContextInputs } from '@aztec/stdlib/kernel';
9
- import { DirectionalAppTaggingSecret } from '@aztec/stdlib/logs';
9
+ import { ExtendedDirectionalAppTaggingSecret } from '@aztec/stdlib/logs';
10
10
  import { Tag } from '@aztec/stdlib/logs';
11
11
  import { Note } from '@aztec/stdlib/note';
12
12
  import { CallContext, CountedContractClassLog, NoteAndSlot } from '@aztec/stdlib/tx';
@@ -29,7 +29,6 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
29
29
  */ newNotes = [];
30
30
  noteHashNullifierCounterMap = new Map();
31
31
  contractClassLogs = [];
32
- offchainEffects = [];
33
32
  nestedExecutionResults = [];
34
33
  argsHash;
35
34
  txContext;
@@ -39,11 +38,10 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
39
38
  noteCache;
40
39
  taggingIndexCache;
41
40
  senderTaggingStore;
42
- contractSyncService;
43
41
  totalPublicCalldataCount;
44
- sideEffectCounter;
45
- senderForTags;
46
- simulator;
42
+ initialSideEffectCounter;
43
+ /** Sender for tags passed in at oracle construction time. Returned by `getSenderForTags` unless overridden. */ defaultSenderForTags;
44
+ /** Per-call sender-for-tags override, set by `setSenderForTags`. Takes precedence over `defaultSenderForTags`. */ currentSenderForTags;
47
45
  constructor(args){
48
46
  super({
49
47
  ...args,
@@ -58,14 +56,12 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
58
56
  this.noteCache = args.noteCache;
59
57
  this.taggingIndexCache = args.taggingIndexCache;
60
58
  this.senderTaggingStore = args.senderTaggingStore;
61
- this.contractSyncService = args.contractSyncService;
62
59
  this.totalPublicCalldataCount = args.totalPublicCalldataCount ?? 0;
63
- this.sideEffectCounter = args.sideEffectCounter ?? 0;
64
- this.senderForTags = args.senderForTags;
65
- this.simulator = args.simulator;
60
+ this.initialSideEffectCounter = args.sideEffectCounter ?? 0;
61
+ this.defaultSenderForTags = args.senderForTags;
66
62
  }
67
63
  getPrivateContextInputs() {
68
- return new PrivateContextInputs(this.callContext, this.anchorBlockHeader, this.txContext, this.sideEffectCounter);
64
+ return new PrivateContextInputs(this.callContext, this.anchorBlockHeader, this.txContext, this.initialSideEffectCounter);
69
65
  }
70
66
  // We still need this function until we can get user-defined ordering of structs for fn arguments
71
67
  // TODO When that is sorted out on noir side, we can use instead the utilities in serialize.ts
@@ -103,14 +99,9 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
103
99
  return this.contractClassLogs;
104
100
  }
105
101
  /**
106
- * Return the offchain effects emitted during this execution.
107
- */ getOffchainEffects() {
108
- return this.offchainEffects;
109
- }
110
- /**
111
- * Returns the pre-tags that were used in this execution (and that need to be stored in the db).
112
- */ getUsedPreTags() {
113
- return this.taggingIndexCache.getUsedPreTags();
102
+ * Returns the tagging index ranges that were used in this execution (and that need to be stored in the db).
103
+ */ getUsedTaggingIndexRanges() {
104
+ return this.taggingIndexCache.getUsedTaggingIndexRanges();
114
105
  }
115
106
  /**
116
107
  * Return the nested execution results during this execution.
@@ -124,10 +115,9 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
124
115
  * for a tag in order to emit a log. Constrained tagging should not use this as there is no
125
116
  * guarantee that the recipient knows about the sender, and hence about the shared secret.
126
117
  *
127
- * The value persists through nested calls, meaning all calls down the stack will use the same
128
- * 'senderForTags' value (unless it is replaced).
129
- */ privateGetSenderForTags() {
130
- return Promise.resolve(this.senderForTags);
118
+ * Returns `currentSenderForTags` if set (via `setSenderForTags`), otherwise `defaultSenderForTags`.
119
+ */ getSenderForTags() {
120
+ return Promise.resolve(this.currentSenderForTags ?? this.defaultSenderForTags);
131
121
  }
132
122
  /**
133
123
  * Set the sender for tags.
@@ -136,11 +126,11 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
136
126
  * for a tag in order to emit a log. Constrained tagging should not use this as there is no
137
127
  * guarantee that the recipient knows about the sender, and hence about the shared secret.
138
128
  *
139
- * Account contracts typically set this value before calling other contracts. The value persists
140
- * through nested calls, meaning all calls down the stack will use the same 'senderForTags'
141
- * value (unless it is replaced by another call to this setter).
142
- */ privateSetSenderForTags(senderForTags) {
143
- this.senderForTags = senderForTags;
129
+ * Overrides `defaultSenderForTags` for the remainder of this call. Each oracle instance is
130
+ * independent, so this has no effect on any other call in the execution.
131
+ */ setSenderForTags(senderForTags) {
132
+ this.logger.debug(`Sender for tags switched to ${senderForTags} by contract ${this.contractAddress} (default was ${this.defaultSenderForTags})`);
133
+ this.currentSenderForTags = senderForTags;
144
134
  return Promise.resolve();
145
135
  }
146
136
  /**
@@ -148,20 +138,29 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
148
138
  * @param sender - The address sending the log
149
139
  * @param recipient - The address receiving the log
150
140
  * @returns An app tag to be used in a log.
151
- */ async privateGetNextAppTagAsSender(sender, recipient) {
152
- const secret = await this.#calculateDirectionalAppTaggingSecret(this.contractAddress, sender, recipient);
153
- const index = await this.#getIndexToUseForSecret(secret);
154
- this.log.debug(`Incrementing tagging index for sender: ${sender}, recipient: ${recipient}, contract: ${this.contractAddress} to ${index}`);
155
- this.taggingIndexCache.setLastUsedIndex(secret, index);
141
+ */ async getNextAppTagAsSender(sender, recipient) {
142
+ const extendedSecret = await this.#calculateExtendedDirectionalAppTaggingSecret(this.contractAddress, sender, recipient);
143
+ if (!extendedSecret) {
144
+ // We'd only fail to compute an extended secret if the recipient is an invalid address. To prevent
145
+ // king-of-the-hill attacks, instead of failing we use a random tag. By including a correct-looking tag in the
146
+ // log, the transaction shape is preserved and no privacy is leaked, even if the tag is bogus.
147
+ this.logger.warn(`Computing a tag for invalid recipient ${recipient} - returning a random tag instead`, {
148
+ contractAddress: this.contractAddress
149
+ });
150
+ return Tag.random();
151
+ }
152
+ const index = await this.#getIndexToUseForSecret(extendedSecret);
153
+ this.logger.debug(`Incrementing tagging index for sender: ${sender}, recipient: ${recipient}, contract: ${this.contractAddress} to ${index}`);
154
+ this.taggingIndexCache.setLastUsedIndex(extendedSecret, index);
156
155
  return Tag.compute({
157
- secret,
156
+ extendedSecret,
158
157
  index
159
158
  });
160
159
  }
161
- async #calculateDirectionalAppTaggingSecret(contractAddress, sender, recipient) {
160
+ async #calculateExtendedDirectionalAppTaggingSecret(contractAddress, sender, recipient) {
162
161
  const senderCompleteAddress = await this.getCompleteAddressOrFail(sender);
163
162
  const senderIvsk = await this.keyStore.getMasterIncomingViewingSecretKey(sender);
164
- return DirectionalAppTaggingSecret.compute(senderCompleteAddress, senderIvsk, recipient, contractAddress, recipient);
163
+ return ExtendedDirectionalAppTaggingSecret.compute(senderCompleteAddress, senderIvsk, recipient, contractAddress, recipient);
165
164
  }
166
165
  async #getIndexToUseForSecret(secret) {
167
166
  // If we have the tagging index in the cache, we use it. If not we obtain it from the execution data provider.
@@ -172,7 +171,7 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
172
171
  // This is a tagging secret we've not yet used in this tx, so first sync our store to make sure its indices
173
172
  // are up to date. We do this here because this store is not synced as part of the global sync because
174
173
  // that'd be wasteful as most tagging secrets are not used in each tx.
175
- await syncSenderTaggingIndexes(secret, this.contractAddress, this.aztecNode, this.senderTaggingStore, await this.anchorBlockHeader.hash(), this.jobId);
174
+ await syncSenderTaggingIndexes(secret, this.aztecNode, this.senderTaggingStore, await this.anchorBlockHeader.hash(), this.jobId);
176
175
  const lastUsedIndex = await this.senderTaggingStore.getLastUsedIndex(secret, this.jobId);
177
176
  // If lastUsedIndex is undefined, we've never used this secret, so start from 0
178
177
  // Otherwise, the next index to use is one past the last used index
@@ -183,29 +182,29 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
183
182
  * Store values in the execution cache.
184
183
  * @param values - Values to store.
185
184
  * @returns The hash of the values.
186
- */ privateStoreInExecutionCache(values, hash) {
185
+ */ setHashPreimage(values, hash) {
187
186
  return this.executionCache.store(values, hash);
188
187
  }
189
188
  /**
190
189
  * Gets values from the execution cache.
191
190
  * @param hash - Hash of the values.
192
191
  * @returns The values.
193
- */ privateLoadFromExecutionCache(hash) {
192
+ */ getHashPreimage(hash) {
194
193
  const preimage = this.executionCache.getPreimage(hash);
195
194
  if (!preimage) {
196
195
  throw new Error(`Preimage for hash ${hash.toString()} not found in cache`);
197
196
  }
198
197
  return Promise.resolve(preimage);
199
198
  }
200
- async utilityCheckNullifierExists(innerNullifier) {
199
+ async doesNullifierExist(innerNullifier) {
201
200
  // This oracle must be overridden because while utility execution can only meaningfully check if a nullifier exists
202
201
  // in the synched block, during private execution there's also the possibility of it being pending, i.e. created
203
202
  // in the current transaction.
204
- this.log.debug(`Checking existence of inner nullifier ${innerNullifier}`, {
203
+ this.logger.debug(`Checking existence of inner nullifier ${innerNullifier}`, {
205
204
  contractAddress: this.contractAddress
206
205
  });
207
206
  const nullifier = (await siloNullifier(this.contractAddress, innerNullifier)).toBigInt();
208
- return this.noteCache.getNullifiers(this.contractAddress).has(nullifier) || await super.utilityCheckNullifierExists(innerNullifier);
207
+ return this.noteCache.getNullifiers(this.contractAddress).has(nullifier) || await super.doesNullifierExist(innerNullifier);
209
208
  }
210
209
  /**
211
210
  * Gets some notes for a storage slot.
@@ -227,7 +226,7 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
227
226
  * @param offset - The starting index for pagination.
228
227
  * @param status - The status of notes to fetch.
229
228
  * @returns Array of note data.
230
- */ async utilityGetNotes(owner, storageSlot, numSelects, selectByIndexes, selectByOffsets, selectByLengths, selectValues, selectComparators, sortByIndexes, sortByOffsets, sortByLengths, sortOrder, limit, offset, status) {
229
+ */ async getNotes(owner, storageSlot, numSelects, selectByIndexes, selectByOffsets, selectByLengths, selectValues, selectComparators, sortByIndexes, sortByOffsets, sortByLengths, sortOrder, limit, offset, status) {
231
230
  // Nullified pending notes are already removed from the list.
232
231
  const pendingNotes = this.noteCache.getNotes(this.callContext.contractAddress, owner, storageSlot);
233
232
  const pendingNullifiers = this.noteCache.getNullifiers(this.callContext.contractAddress);
@@ -258,7 +257,7 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
258
257
  limit,
259
258
  offset
260
259
  });
261
- this.log.debug(`Returning ${notes.length} notes for ${this.callContext.contractAddress} at ${storageSlot}: ${notes.map((n)=>`${n.noteNonce.toString()}:[${n.note.items.map((i)=>i.toString()).join(',')}]`).join(', ')}`);
260
+ this.logger.debug(`Returning ${notes.length} notes for ${this.callContext.contractAddress} at ${storageSlot}: ${notes.map((n)=>`${n.noteNonce.toString()}:[${n.note.items.map((i)=>i.toString()).join(',')}]`).join(', ')}`);
262
261
  return notes;
263
262
  }
264
263
  /**
@@ -271,8 +270,8 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
271
270
  * @param noteItems - The items to be included in a Note.
272
271
  * @param noteHash - A hash of the new note.
273
272
  * @returns
274
- */ privateNotifyCreatedNote(owner, storageSlot, randomness, noteTypeId, noteItems, noteHash, counter) {
275
- this.log.debug(`Notified of new note with inner hash ${noteHash}`, {
273
+ */ notifyCreatedNote(owner, storageSlot, randomness, noteTypeId, noteItems, noteHash, counter) {
274
+ this.logger.debug(`Notified of new note with inner hash ${noteHash}`, {
276
275
  contractAddress: this.callContext.contractAddress,
277
276
  storageSlot,
278
277
  randomness,
@@ -303,7 +302,7 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
303
302
  * within the current transaction/execution.
304
303
  * @param innerNullifier - The pending nullifier to add in the list (not yet siloed by contract address).
305
304
  * @param noteHash - A hash of the new note.
306
- */ async privateNotifyNullifiedNote(innerNullifier, noteHash, counter) {
305
+ */ async notifyNullifiedNote(innerNullifier, noteHash, counter) {
307
306
  const nullifiedNoteHashCounter = await this.noteCache.nullifyNote(this.callContext.contractAddress, innerNullifier, noteHash);
308
307
  if (nullifiedNoteHashCounter !== undefined) {
309
308
  this.noteHashNullifierCounterMap.set(nullifiedNoteHashCounter, counter);
@@ -314,19 +313,19 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
314
313
  * within the current transaction/execution.
315
314
  * @param innerNullifier - The pending nullifier to add in the list (not yet siloed by contract address).
316
315
  * @param noteHash - A hash of the new note.
317
- */ privateNotifyCreatedNullifier(innerNullifier) {
318
- this.log.debug(`Notified of new inner nullifier ${innerNullifier}`, {
316
+ */ notifyCreatedNullifier(innerNullifier) {
317
+ this.logger.debug(`Notified of new inner nullifier ${innerNullifier}`, {
319
318
  contractAddress: this.contractAddress
320
319
  });
321
320
  return this.noteCache.nullifierCreated(this.callContext.contractAddress, innerNullifier);
322
321
  }
323
322
  /**
324
- * Check if a nullifier has been emitted in the same transaction, i.e. if privateNotifyCreatedNullifier has been
323
+ * Check if a nullifier has been emitted in the same transaction, i.e. if notifyCreatedNullifier has been
325
324
  * called for this inner nullifier from the contract with the specified address.
326
325
  * @param innerNullifier - The inner nullifier to check.
327
326
  * @param contractAddress - Address of the contract that emitted the nullifier.
328
327
  * @returns A boolean indicating whether the nullifier is pending or not.
329
- */ async privateIsNullifierPending(innerNullifier, contractAddress) {
328
+ */ async isNullifierPending(innerNullifier, contractAddress) {
330
329
  const siloedNullifier = await siloNullifier(contractAddress, innerNullifier);
331
330
  const isNullifierPending = this.noteCache.getNullifiers(contractAddress).has(siloedNullifier.toBigInt());
332
331
  return Promise.resolve(isNullifierPending);
@@ -337,10 +336,10 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
337
336
  * keep the preimage in ts for later.
338
337
  * @param log - The contract class log to be emitted.
339
338
  * @param counter - The contract class log's counter.
340
- */ privateNotifyCreatedContractClassLog(log, counter) {
339
+ */ notifyCreatedContractClassLog(log, counter) {
341
340
  this.contractClassLogs.push(new CountedContractClassLog(log, counter));
342
341
  const text = log.toBuffer().toString('hex');
343
- this.log.verbose(`Emitted log from ContractClassRegistry: "${text.length > 100 ? text.slice(0, 100) + '...' : text}"`);
342
+ this.logger.verbose(`Emitted log from ContractClassRegistry: "${text.length > 100 ? text.slice(0, 100) + '...' : text}"`);
344
343
  }
345
344
  #checkValidStaticCall(childExecutionResult) {
346
345
  if (childExecutionResult.publicInputs.noteHashes.claimedLength > 0 || childExecutionResult.publicInputs.nullifiers.claimedLength > 0 || childExecutionResult.publicInputs.l2ToL1Msgs.claimedLength > 0 || childExecutionResult.publicInputs.privateLogs.claimedLength > 0 || childExecutionResult.publicInputs.contractClassLogsHashes.claimedLength > 0) {
@@ -355,24 +354,16 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
355
354
  * @param sideEffectCounter - The side effect counter at the start of the call.
356
355
  * @param isStaticCall - Whether the call is a static call.
357
356
  * @returns The execution result.
358
- */ async privateCallPrivateFunction(targetContractAddress, functionSelector, argsHash, sideEffectCounter, isStaticCall) {
357
+ */ async callPrivateFunction(targetContractAddress, functionSelector, argsHash, sideEffectCounter, isStaticCall) {
359
358
  if (!this.simulator) {
360
359
  // In practice it is only when creating inline private contexts in a Noir test using TXE that we create an
361
360
  // instance of this class without a simulator.
362
361
  throw new Error('No simulator provided, cannot perform a nested private call');
363
362
  }
364
363
  const simulatorSetupTimer = new Timer();
365
- this.log.debug(`Calling private function ${targetContractAddress}:${functionSelector} from ${this.callContext.contractAddress}`);
364
+ this.logger.debug(`Calling private function ${targetContractAddress}:${functionSelector} from ${this.callContext.contractAddress}`);
366
365
  isStaticCall = isStaticCall || this.callContext.isStaticCall;
367
- // When scopes are set and the target contract is a registered account (has keys in the keyStore),
368
- // expand scopes to include it so nested private calls can sync and read the contract's own notes.
369
- // We only expand for registered accounts because the log service needs the recipient's keys to derive
370
- // tagging secrets, which are only available for registered accounts.
371
- const expandedScopes = this.scopes !== 'ALL_SCOPES' && await this.keyStore.hasAccount(targetContractAddress) ? [
372
- ...this.scopes,
373
- targetContractAddress
374
- ] : this.scopes;
375
- await this.contractSyncService.ensureContractSynced(targetContractAddress, functionSelector, this.utilityExecutor, this.anchorBlockHeader, this.jobId, expandedScopes);
366
+ await this.contractSyncService.ensureContractSynced(targetContractAddress, functionSelector, this.utilityExecutor, this.anchorBlockHeader, this.jobId, this.scopes);
376
367
  const targetArtifact = await this.contractStore.getFunctionArtifactWithDebugMetadata(targetContractAddress, functionSelector);
377
368
  const derivedTxContext = this.txContext.clone();
378
369
  const derivedCallContext = await this.deriveCallContext(targetContractAddress, targetArtifact, isStaticCall);
@@ -395,19 +386,23 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
395
386
  senderTaggingStore: this.senderTaggingStore,
396
387
  recipientTaggingStore: this.recipientTaggingStore,
397
388
  senderAddressBookStore: this.senderAddressBookStore,
398
- capsuleStore: this.capsuleStore,
389
+ capsuleService: this.capsuleService,
399
390
  privateEventStore: this.privateEventStore,
391
+ messageContextService: this.messageContextService,
400
392
  contractSyncService: this.contractSyncService,
401
393
  jobId: this.jobId,
402
394
  totalPublicCalldataCount: this.totalPublicCalldataCount,
403
395
  sideEffectCounter,
404
- log: this.log,
405
- scopes: expandedScopes,
406
- senderForTags: this.senderForTags,
407
- simulator: this.simulator
396
+ log: this.logger,
397
+ scopes: this.scopes,
398
+ senderForTags: this.defaultSenderForTags,
399
+ simulator: this.simulator,
400
+ l2TipsStore: this.l2TipsStore
408
401
  });
409
402
  const setupTime = simulatorSetupTimer.ms();
410
403
  const childExecutionResult = await executePrivateFunction(this.simulator, privateExecutionOracle, targetArtifact, targetContractAddress, functionSelector);
404
+ // Propagate the nested call's calldata count so the parent sees its increments on subsequent enqueues.
405
+ this.totalPublicCalldataCount = privateExecutionOracle.getTotalPublicCalldataCount();
411
406
  if (isStaticCall) {
412
407
  this.#checkValidStaticCall(childExecutionResult);
413
408
  }
@@ -422,7 +417,7 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
422
417
  returnsHash: publicInputs.returnsHash
423
418
  };
424
419
  }
425
- #onNewPublicFunctionCall(calldataHash) {
420
+ /** Validates the calldata preimage exists in the cache and checks cumulative calldata size is within limits. */ assertValidPublicCalldata(calldataHash) {
426
421
  const calldata = this.executionCache.getPreimage(calldataHash);
427
422
  if (!calldata) {
428
423
  throw new Error('Calldata for public call not found in cache');
@@ -431,31 +426,15 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
431
426
  if (this.totalPublicCalldataCount > MAX_FR_CALLDATA_TO_ALL_ENQUEUED_CALLS) {
432
427
  throw new Error(`Too many total args to all enqueued public calls! (> ${MAX_FR_CALLDATA_TO_ALL_ENQUEUED_CALLS})`);
433
428
  }
434
- }
435
- /**
436
- * Verify relevant information when a public function is enqueued.
437
- * @param targetContractAddress - The address of the contract to call.
438
- * @param calldataHash - The hash of the function selector and arguments.
439
- * @param sideEffectCounter - The side effect counter at the start of the call.
440
- * @param isStaticCall - Whether the call is a static call.
441
- */ privateNotifyEnqueuedPublicFunctionCall(_targetContractAddress, calldataHash, _sideEffectCounter, _isStaticCall) {
442
- this.#onNewPublicFunctionCall(calldataHash);
443
429
  return Promise.resolve();
444
430
  }
445
- /**
446
- * Verify relevant information when a public teardown function is set.
447
- * @param targetContractAddress - The address of the contract to call.
448
- * @param argsHash - The arguments hash to pass to the function.
449
- * @param sideEffectCounter - The side effect counter at the start of the call.
450
- * @param isStaticCall - Whether the call is a static call.
451
- */ privateNotifySetPublicTeardownFunctionCall(_targetContractAddress, calldataHash, _sideEffectCounter, _isStaticCall) {
452
- this.#onNewPublicFunctionCall(calldataHash);
453
- return Promise.resolve();
431
+ getTotalPublicCalldataCount() {
432
+ return this.totalPublicCalldataCount;
454
433
  }
455
- privateNotifySetMinRevertibleSideEffectCounter(minRevertibleSideEffectCounter) {
434
+ notifyRevertiblePhaseStart(minRevertibleSideEffectCounter) {
456
435
  return this.noteCache.setMinRevertibleSideEffectCounter(minRevertibleSideEffectCounter);
457
436
  }
458
- privateIsSideEffectCounterRevertible(sideEffectCounter) {
437
+ isExecutionInRevertiblePhase(sideEffectCounter) {
459
438
  return Promise.resolve(this.noteCache.isSideEffectCounterRevertible(sideEffectCounter));
460
439
  }
461
440
  /**
@@ -470,10 +449,4 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
470
449
  getDebugFunctionName() {
471
450
  return this.contractStore.getDebugFunctionName(this.contractAddress, this.callContext.functionSelector);
472
451
  }
473
- utilityEmitOffchainEffect(data) {
474
- this.offchainEffects.push({
475
- data
476
- });
477
- return Promise.resolve();
478
- }
479
452
  }