@aztec/pxe 0.0.1-commit.6230efd → 0.0.1-commit.643667a5cb

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 (266) hide show
  1. package/dest/access_scopes.d.ts +9 -0
  2. package/dest/access_scopes.d.ts.map +1 -0
  3. package/dest/access_scopes.js +6 -0
  4. package/dest/bin/check_oracle_version.js +1 -1
  5. package/dest/block_synchronizer/block_synchronizer.d.ts +13 -5
  6. package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
  7. package/dest/block_synchronizer/block_synchronizer.js +74 -20
  8. package/dest/config/index.d.ts +3 -1
  9. package/dest/config/index.d.ts.map +1 -1
  10. package/dest/config/index.js +17 -0
  11. package/dest/config/package_info.js +1 -1
  12. package/dest/contract_function_simulator/benchmarked_node.d.ts +9 -0
  13. package/dest/contract_function_simulator/benchmarked_node.d.ts.map +1 -0
  14. package/dest/contract_function_simulator/benchmarked_node.js +77 -0
  15. package/dest/contract_function_simulator/contract_function_simulator.d.ts +57 -34
  16. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
  17. package/dest/contract_function_simulator/contract_function_simulator.js +199 -84
  18. package/dest/contract_function_simulator/execution_note_cache.d.ts +18 -9
  19. package/dest/contract_function_simulator/execution_note_cache.d.ts.map +1 -1
  20. package/dest/contract_function_simulator/execution_note_cache.js +45 -28
  21. package/dest/contract_function_simulator/index.d.ts +2 -2
  22. package/dest/contract_function_simulator/index.d.ts.map +1 -1
  23. package/dest/contract_function_simulator/index.js +1 -1
  24. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +4 -3
  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 +7 -4
  27. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +3 -3
  28. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
  29. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +2 -2
  30. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts +4 -10
  31. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts.map +1 -1
  32. package/dest/contract_function_simulator/noir-structs/utility_context.js +7 -18
  33. package/dest/contract_function_simulator/oracle/interfaces.d.ts +17 -13
  34. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
  35. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts +3 -1
  36. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts.map +1 -1
  37. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts +6 -6
  38. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts.map +1 -1
  39. package/dest/contract_function_simulator/oracle/note_packing_utils.js +8 -8
  40. package/dest/contract_function_simulator/oracle/oracle.d.ts +12 -10
  41. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
  42. package/dest/contract_function_simulator/oracle/oracle.js +67 -44
  43. package/dest/contract_function_simulator/oracle/private_execution.d.ts +2 -26
  44. package/dest/contract_function_simulator/oracle/private_execution.d.ts.map +1 -1
  45. package/dest/contract_function_simulator/oracle/private_execution.js +1 -37
  46. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +44 -50
  47. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
  48. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +83 -54
  49. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +67 -33
  50. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
  51. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +131 -110
  52. package/dest/contract_logging.d.ts +22 -0
  53. package/dest/contract_logging.d.ts.map +1 -0
  54. package/dest/contract_logging.js +23 -0
  55. package/dest/contract_sync/contract_sync_service.d.ts +43 -0
  56. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -0
  57. package/dest/contract_sync/contract_sync_service.js +97 -0
  58. package/dest/contract_sync/helpers.d.ts +29 -0
  59. package/dest/contract_sync/helpers.d.ts.map +1 -0
  60. package/dest/contract_sync/helpers.js +55 -0
  61. package/dest/debug/pxe_debug_utils.d.ts +24 -10
  62. package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
  63. package/dest/debug/pxe_debug_utils.js +28 -17
  64. package/dest/entrypoints/client/bundle/index.d.ts +4 -1
  65. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  66. package/dest/entrypoints/client/bundle/index.js +3 -0
  67. package/dest/entrypoints/client/bundle/utils.d.ts +1 -1
  68. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  69. package/dest/entrypoints/client/bundle/utils.js +31 -8
  70. package/dest/entrypoints/client/lazy/index.d.ts +4 -1
  71. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  72. package/dest/entrypoints/client/lazy/index.js +3 -0
  73. package/dest/entrypoints/client/lazy/utils.d.ts +2 -2
  74. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  75. package/dest/entrypoints/client/lazy/utils.js +32 -9
  76. package/dest/entrypoints/pxe_creation_options.d.ts +5 -3
  77. package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
  78. package/dest/entrypoints/server/index.d.ts +5 -1
  79. package/dest/entrypoints/server/index.d.ts.map +1 -1
  80. package/dest/entrypoints/server/index.js +4 -0
  81. package/dest/entrypoints/server/utils.d.ts +1 -1
  82. package/dest/entrypoints/server/utils.d.ts.map +1 -1
  83. package/dest/entrypoints/server/utils.js +39 -16
  84. package/dest/events/event_service.d.ts +6 -6
  85. package/dest/events/event_service.d.ts.map +1 -1
  86. package/dest/events/event_service.js +19 -22
  87. package/dest/events/private_event_filter_validator.d.ts +5 -5
  88. package/dest/events/private_event_filter_validator.d.ts.map +1 -1
  89. package/dest/events/private_event_filter_validator.js +5 -6
  90. package/dest/job_coordinator/job_coordinator.d.ts +75 -0
  91. package/dest/job_coordinator/job_coordinator.d.ts.map +1 -0
  92. package/dest/job_coordinator/job_coordinator.js +94 -0
  93. package/dest/logs/log_service.d.ts +8 -5
  94. package/dest/logs/log_service.d.ts.map +1 -1
  95. package/dest/logs/log_service.js +28 -30
  96. package/dest/notes/note_service.d.ts +10 -9
  97. package/dest/notes/note_service.d.ts.map +1 -1
  98. package/dest/notes/note_service.js +34 -38
  99. package/dest/notes_filter.d.ts +25 -0
  100. package/dest/notes_filter.d.ts.map +1 -0
  101. package/dest/notes_filter.js +4 -0
  102. package/dest/oracle_version.d.ts +3 -3
  103. package/dest/oracle_version.d.ts.map +1 -1
  104. package/dest/oracle_version.js +4 -3
  105. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
  106. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
  107. package/dest/private_kernel/hints/{compute_tx_include_by_timestamp.js → compute_tx_expiration_timestamp.js} +12 -12
  108. package/dest/private_kernel/hints/index.d.ts +3 -3
  109. package/dest/private_kernel/hints/index.d.ts.map +1 -1
  110. package/dest/private_kernel/hints/index.js +2 -2
  111. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +28 -0
  112. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -0
  113. package/dest/private_kernel/hints/{build_private_kernel_reset_private_inputs.js → private_kernel_reset_private_inputs_builder.js} +16 -10
  114. package/dest/private_kernel/private_kernel_execution_prover.d.ts +3 -2
  115. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
  116. package/dest/private_kernel/private_kernel_execution_prover.js +12 -13
  117. package/dest/private_kernel/private_kernel_oracle.d.ts +24 -24
  118. package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
  119. package/dest/private_kernel/private_kernel_oracle.js +94 -2
  120. package/dest/pxe.d.ts +76 -58
  121. package/dest/pxe.d.ts.map +1 -1
  122. package/dest/pxe.js +149 -138
  123. package/dest/storage/address_store/address_store.d.ts +1 -1
  124. package/dest/storage/address_store/address_store.d.ts.map +1 -1
  125. package/dest/storage/address_store/address_store.js +12 -11
  126. package/dest/storage/anchor_block_store/anchor_block_store.d.ts +9 -1
  127. package/dest/storage/anchor_block_store/anchor_block_store.d.ts.map +1 -1
  128. package/dest/storage/anchor_block_store/anchor_block_store.js +8 -1
  129. package/dest/storage/capsule_store/capsule_store.d.ts +24 -9
  130. package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -1
  131. package/dest/storage/capsule_store/capsule_store.js +130 -23
  132. package/dest/storage/contract_store/contract_store.d.ts +42 -16
  133. package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
  134. package/dest/storage/contract_store/contract_store.js +157 -84
  135. package/dest/storage/metadata.d.ts +1 -1
  136. package/dest/storage/metadata.js +1 -1
  137. package/dest/storage/note_store/note_store.d.ts +50 -51
  138. package/dest/storage/note_store/note_store.d.ts.map +1 -1
  139. package/dest/storage/note_store/note_store.js +284 -263
  140. package/dest/storage/note_store/stored_note.d.ts +16 -0
  141. package/dest/storage/note_store/stored_note.d.ts.map +1 -0
  142. package/dest/storage/note_store/stored_note.js +43 -0
  143. package/dest/storage/private_event_store/private_event_store.d.ts +47 -7
  144. package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -1
  145. package/dest/storage/private_event_store/private_event_store.js +231 -73
  146. package/dest/storage/private_event_store/stored_private_event.d.ts +23 -0
  147. package/dest/storage/private_event_store/stored_private_event.d.ts.map +1 -0
  148. package/dest/storage/private_event_store/stored_private_event.js +56 -0
  149. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +15 -8
  150. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
  151. package/dest/storage/tagging_store/recipient_tagging_store.js +88 -19
  152. package/dest/storage/tagging_store/sender_address_book_store.d.ts +1 -1
  153. package/dest/storage/tagging_store/sender_address_book_store.d.ts.map +1 -1
  154. package/dest/storage/tagging_store/sender_address_book_store.js +20 -14
  155. package/dest/storage/tagging_store/sender_tagging_store.d.ts +19 -9
  156. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
  157. package/dest/storage/tagging_store/sender_tagging_store.js +253 -101
  158. package/dest/tagging/constants.d.ts +2 -0
  159. package/dest/tagging/constants.d.ts.map +1 -0
  160. package/dest/tagging/constants.js +10 -0
  161. package/dest/tagging/get_all_logs_by_tags.d.ts +24 -0
  162. package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -0
  163. package/dest/tagging/get_all_logs_by_tags.js +60 -0
  164. package/dest/tagging/index.d.ts +3 -2
  165. package/dest/tagging/index.d.ts.map +1 -1
  166. package/dest/tagging/index.js +2 -10
  167. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +3 -2
  168. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +1 -1
  169. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +12 -12
  170. package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +2 -2
  171. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +3 -2
  172. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +1 -1
  173. package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +5 -2
  174. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +3 -2
  175. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
  176. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +8 -8
  177. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +1 -1
  178. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -1
  179. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +5 -8
  180. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +5 -2
  181. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -1
  182. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +10 -5
  183. package/package.json +27 -18
  184. package/src/access_scopes.ts +9 -0
  185. package/src/bin/check_oracle_version.ts +1 -0
  186. package/src/block_synchronizer/block_synchronizer.ts +93 -32
  187. package/src/config/index.ts +14 -0
  188. package/src/config/package_info.ts +1 -1
  189. package/src/contract_function_simulator/benchmarked_node.ts +103 -0
  190. package/src/contract_function_simulator/contract_function_simulator.ts +359 -146
  191. package/src/contract_function_simulator/execution_note_cache.ts +44 -25
  192. package/src/contract_function_simulator/index.ts +1 -1
  193. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +6 -2
  194. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +2 -2
  195. package/src/contract_function_simulator/noir-structs/utility_context.ts +6 -25
  196. package/src/contract_function_simulator/oracle/interfaces.ts +22 -12
  197. package/src/contract_function_simulator/oracle/note_packing_utils.ts +10 -10
  198. package/src/contract_function_simulator/oracle/oracle.ts +79 -47
  199. package/src/contract_function_simulator/oracle/private_execution.ts +1 -69
  200. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +119 -137
  201. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +198 -115
  202. package/src/contract_logging.ts +39 -0
  203. package/src/contract_sync/contract_sync_service.ts +152 -0
  204. package/src/contract_sync/helpers.ts +98 -0
  205. package/src/debug/pxe_debug_utils.ts +63 -18
  206. package/src/entrypoints/client/bundle/index.ts +3 -0
  207. package/src/entrypoints/client/bundle/utils.ts +23 -16
  208. package/src/entrypoints/client/lazy/index.ts +3 -0
  209. package/src/entrypoints/client/lazy/utils.ts +24 -17
  210. package/src/entrypoints/pxe_creation_options.ts +4 -2
  211. package/src/entrypoints/server/index.ts +4 -0
  212. package/src/entrypoints/server/utils.ts +33 -41
  213. package/src/events/event_service.ts +19 -25
  214. package/src/events/private_event_filter_validator.ts +3 -5
  215. package/src/job_coordinator/job_coordinator.ts +150 -0
  216. package/src/logs/log_service.ts +40 -34
  217. package/src/notes/note_service.ts +41 -45
  218. package/src/notes_filter.ts +26 -0
  219. package/src/oracle_version.ts +4 -3
  220. package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
  221. package/src/private_kernel/hints/index.ts +2 -2
  222. package/src/private_kernel/hints/{build_private_kernel_reset_private_inputs.ts → private_kernel_reset_private_inputs_builder.ts} +39 -28
  223. package/src/private_kernel/private_kernel_execution_prover.ts +15 -14
  224. package/src/private_kernel/private_kernel_oracle.ts +116 -36
  225. package/src/pxe.ts +280 -209
  226. package/src/storage/address_store/address_store.ts +15 -15
  227. package/src/storage/anchor_block_store/anchor_block_store.ts +8 -0
  228. package/src/storage/capsule_store/capsule_store.ts +159 -23
  229. package/src/storage/contract_store/contract_store.ts +186 -96
  230. package/src/storage/metadata.ts +1 -1
  231. package/src/storage/note_store/note_store.ts +326 -320
  232. package/src/storage/note_store/stored_note.ts +48 -0
  233. package/src/storage/private_event_store/private_event_store.ts +301 -79
  234. package/src/storage/private_event_store/stored_private_event.ts +73 -0
  235. package/src/storage/tagging_store/recipient_tagging_store.ts +106 -20
  236. package/src/storage/tagging_store/sender_address_book_store.ts +20 -14
  237. package/src/storage/tagging_store/sender_tagging_store.ts +294 -109
  238. package/src/tagging/constants.ts +10 -0
  239. package/src/tagging/get_all_logs_by_tags.ts +92 -0
  240. package/src/tagging/index.ts +2 -11
  241. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +25 -11
  242. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +2 -2
  243. package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +7 -1
  244. package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +10 -7
  245. package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +5 -13
  246. package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +16 -4
  247. package/dest/contract_function_simulator/proxied_node.d.ts +0 -9
  248. package/dest/contract_function_simulator/proxied_node.d.ts.map +0 -1
  249. package/dest/contract_function_simulator/proxied_node.js +0 -27
  250. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts +0 -28
  251. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts.map +0 -1
  252. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts +0 -4
  253. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts.map +0 -1
  254. package/dest/private_kernel/private_kernel_oracle_impl.d.ts +0 -46
  255. package/dest/private_kernel/private_kernel_oracle_impl.d.ts.map +0 -1
  256. package/dest/private_kernel/private_kernel_oracle_impl.js +0 -86
  257. package/dest/public_storage/public_storage_service.d.ts +0 -24
  258. package/dest/public_storage/public_storage_service.d.ts.map +0 -1
  259. package/dest/public_storage/public_storage_service.js +0 -26
  260. package/dest/tree_membership/tree_membership_service.d.ts +0 -52
  261. package/dest/tree_membership/tree_membership_service.d.ts.map +0 -1
  262. package/dest/tree_membership/tree_membership_service.js +0 -84
  263. package/src/contract_function_simulator/proxied_node.ts +0 -33
  264. package/src/private_kernel/private_kernel_oracle_impl.ts +0 -133
  265. package/src/public_storage/public_storage_service.ts +0 -33
  266. package/src/tree_membership/tree_membership_service.ts +0 -112
@@ -2,22 +2,26 @@ 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,
8
+ L2_GAS_PER_L2_TO_L1_MSG,
9
+ L2_GAS_PER_NOTE_HASH,
10
+ L2_GAS_PER_NULLIFIER,
11
11
  L2_GAS_PER_PRIVATE_LOG,
12
12
  MAX_CONTRACT_CLASS_LOGS_PER_TX,
13
13
  MAX_ENQUEUED_CALLS_PER_TX,
14
14
  MAX_L2_TO_L1_MSGS_PER_TX,
15
15
  MAX_NOTE_HASHES_PER_TX,
16
+ MAX_NOTE_HASH_READ_REQUESTS_PER_TX,
16
17
  MAX_NULLIFIERS_PER_TX,
18
+ MAX_NULLIFIER_READ_REQUESTS_PER_TX,
17
19
  MAX_PRIVATE_LOGS_PER_TX,
20
+ PRIVATE_TX_L2_GAS_OVERHEAD,
21
+ PUBLIC_TX_L2_GAS_OVERHEAD,
22
+ TX_DA_GAS_OVERHEAD,
18
23
  } from '@aztec/constants';
19
24
  import { arrayNonEmptyLength, padArrayEnd } from '@aztec/foundation/collection';
20
- import { poseidon2Hash } from '@aztec/foundation/crypto/poseidon';
21
25
  import { Fr } from '@aztec/foundation/curves/bn254';
22
26
  import { type Logger, createLogger } from '@aztec/foundation/log';
23
27
  import { Timer } from '@aztec/foundation/timer';
@@ -37,25 +41,36 @@ import type { FunctionCall } from '@aztec/stdlib/abi';
37
41
  import { FunctionSelector, FunctionType } from '@aztec/stdlib/abi';
38
42
  import type { AuthWitness } from '@aztec/stdlib/auth-witness';
39
43
  import { AztecAddress } from '@aztec/stdlib/aztec-address';
44
+ import type { BlockParameter } from '@aztec/stdlib/block';
40
45
  import { Gas } from '@aztec/stdlib/gas';
41
46
  import {
42
47
  computeNoteHashNonce,
43
48
  computeProtocolNullifier,
49
+ computeSiloedPrivateLogFirstField,
44
50
  computeUniqueNoteHash,
45
51
  siloNoteHash,
46
52
  siloNullifier,
47
53
  } from '@aztec/stdlib/hash';
48
54
  import type { AztecNode } from '@aztec/stdlib/interfaces/server';
49
55
  import {
56
+ ClaimedLengthArray,
50
57
  PartialPrivateTailPublicInputsForPublic,
51
58
  PartialPrivateTailPublicInputsForRollup,
52
59
  type PrivateExecutionStep,
53
60
  type PrivateKernelExecutionProofOutput,
54
61
  PrivateKernelTailCircuitPublicInputs,
62
+ PrivateLogData,
55
63
  PrivateToPublicAccumulatedData,
56
64
  PrivateToRollupAccumulatedData,
57
65
  PublicCallRequest,
66
+ ReadRequestActionEnum,
58
67
  ScopedLogHash,
68
+ ScopedNoteHash,
69
+ ScopedNullifier,
70
+ ScopedReadRequest,
71
+ buildTransientDataHints,
72
+ getNoteHashReadRequestResetActions,
73
+ getNullifierReadRequestResetActions,
59
74
  } from '@aztec/stdlib/kernel';
60
75
  import { PrivateLog } from '@aztec/stdlib/logs';
61
76
  import { ScopedL2ToL1Message } from '@aztec/stdlib/messaging';
@@ -68,11 +83,13 @@ import {
68
83
  TxConstantData,
69
84
  TxExecutionRequest,
70
85
  collectNested,
86
+ collectNoteHashNullifierCounterMap,
71
87
  getFinalMinRevertibleSideEffectCounter,
72
88
  } from '@aztec/stdlib/tx';
73
89
 
90
+ import type { AccessScopes } from '../access_scopes.js';
91
+ import type { ContractSyncService } from '../contract_sync/contract_sync_service.js';
74
92
  import type { AddressStore } from '../storage/address_store/address_store.js';
75
- import type { AnchorBlockStore } from '../storage/anchor_block_store/anchor_block_store.js';
76
93
  import type { CapsuleStore } from '../storage/capsule_store/capsule_store.js';
77
94
  import type { ContractStore } from '../storage/contract_store/contract_store.js';
78
95
  import type { NoteStore } from '../storage/note_store/note_store.js';
@@ -80,68 +97,101 @@ import type { PrivateEventStore } from '../storage/private_event_store/private_e
80
97
  import type { RecipientTaggingStore } from '../storage/tagging_store/recipient_tagging_store.js';
81
98
  import type { SenderAddressBookStore } from '../storage/tagging_store/sender_address_book_store.js';
82
99
  import type { SenderTaggingStore } from '../storage/tagging_store/sender_tagging_store.js';
100
+ import type { BenchmarkedNode } from './benchmarked_node.js';
83
101
  import { ExecutionNoteCache } from './execution_note_cache.js';
84
102
  import { ExecutionTaggingIndexCache } from './execution_tagging_index_cache.js';
85
103
  import { HashedValuesCache } from './hashed_values_cache.js';
86
104
  import { Oracle } from './oracle/oracle.js';
87
- import { executePrivateFunction, verifyCurrentClassId } from './oracle/private_execution.js';
105
+ import { executePrivateFunction } from './oracle/private_execution.js';
88
106
  import { PrivateExecutionOracle } from './oracle/private_execution_oracle.js';
89
107
  import { UtilityExecutionOracle } from './oracle/utility_execution_oracle.js';
90
- import type { ProxiedNode } from './proxied_node.js';
108
+
109
+ /** Options for ContractFunctionSimulator.run. */
110
+ export type ContractSimulatorRunOpts = {
111
+ /** The address of the contract (should match request.origin). */
112
+ contractAddress: AztecAddress;
113
+ /** The function selector of the entry point. */
114
+ selector: FunctionSelector;
115
+ /** The address calling the function. Can be replaced to simulate a call from another contract or account. */
116
+ msgSender?: AztecAddress;
117
+ /** The block header to use as base state for this run. */
118
+ anchorBlockHeader: BlockHeader;
119
+ /** The address used as a tagging sender when emitting private logs. */
120
+ senderForTags?: AztecAddress;
121
+ /** The accounts whose notes we can access in this call. */
122
+ scopes: AccessScopes;
123
+ /** The job ID for staged writes. */
124
+ jobId: string;
125
+ };
126
+
127
+ /** Args for ContractFunctionSimulator constructor. */
128
+ export type ContractFunctionSimulatorArgs = {
129
+ contractStore: ContractStore;
130
+ noteStore: NoteStore;
131
+ keyStore: KeyStore;
132
+ addressStore: AddressStore;
133
+ aztecNode: AztecNode;
134
+ senderTaggingStore: SenderTaggingStore;
135
+ recipientTaggingStore: RecipientTaggingStore;
136
+ senderAddressBookStore: SenderAddressBookStore;
137
+ capsuleStore: CapsuleStore;
138
+ privateEventStore: PrivateEventStore;
139
+ simulator: CircuitSimulator;
140
+ contractSyncService: ContractSyncService;
141
+ };
91
142
 
92
143
  /**
93
144
  * The contract function simulator.
94
145
  */
95
146
  export class ContractFunctionSimulator {
96
- private log: Logger;
97
-
98
- constructor(
99
- private contractStore: ContractStore,
100
- private noteStore: NoteStore,
101
- private keyStore: KeyStore,
102
- private addressStore: AddressStore,
103
- private aztecNode: AztecNode,
104
- private anchorBlockStore: AnchorBlockStore,
105
- private senderTaggingStore: SenderTaggingStore,
106
- private recipientTaggingStore: RecipientTaggingStore,
107
- private senderAddressBookStore: SenderAddressBookStore,
108
- private capsuleStore: CapsuleStore,
109
- private privateEventStore: PrivateEventStore,
110
- private simulator: CircuitSimulator,
111
- ) {
147
+ private readonly log: Logger;
148
+ private readonly contractStore: ContractStore;
149
+ private readonly noteStore: NoteStore;
150
+ private readonly keyStore: KeyStore;
151
+ private readonly addressStore: AddressStore;
152
+ private readonly aztecNode: AztecNode;
153
+ private readonly senderTaggingStore: SenderTaggingStore;
154
+ private readonly recipientTaggingStore: RecipientTaggingStore;
155
+ private readonly senderAddressBookStore: SenderAddressBookStore;
156
+ private readonly capsuleStore: CapsuleStore;
157
+ private readonly privateEventStore: PrivateEventStore;
158
+ private readonly simulator: CircuitSimulator;
159
+ private readonly contractSyncService: ContractSyncService;
160
+
161
+ constructor(args: ContractFunctionSimulatorArgs) {
162
+ this.contractStore = args.contractStore;
163
+ this.noteStore = args.noteStore;
164
+ this.keyStore = args.keyStore;
165
+ this.addressStore = args.addressStore;
166
+ this.aztecNode = args.aztecNode;
167
+ this.senderTaggingStore = args.senderTaggingStore;
168
+ this.recipientTaggingStore = args.recipientTaggingStore;
169
+ this.senderAddressBookStore = args.senderAddressBookStore;
170
+ this.capsuleStore = args.capsuleStore;
171
+ this.privateEventStore = args.privateEventStore;
172
+ this.simulator = args.simulator;
173
+ this.contractSyncService = args.contractSyncService;
112
174
  this.log = createLogger('simulator');
113
175
  }
114
176
 
115
177
  /**
116
178
  * Runs a private function.
117
179
  * @param request - The transaction request.
118
- * @param entryPointArtifact - The artifact of the entry point function.
119
- * @param contractAddress - The address of the contract (should match request.origin)
120
- * @param msgSender - The address calling the function. This can be replaced to simulate a call from another contract
121
- * or a specific account.
122
- * @param anchorBlockHeader - The block header to use as base state for this run.
123
- * @param senderForTags - The address that is used as a tagging sender when emitting private logs. Returned from
124
- * the `privateGetSenderForTags` oracle.
125
- * @param scopes - The accounts whose notes we can access in this call. Currently optional and will default to all.
126
- * @returns The result of the execution.
127
180
  */
128
181
  public async run(
129
182
  request: TxExecutionRequest,
130
- contractAddress: AztecAddress,
131
- selector: FunctionSelector,
132
- msgSender = AztecAddress.fromField(Fr.MAX_FIELD_VALUE),
133
- anchorBlockHeader: BlockHeader,
134
- senderForTags?: AztecAddress,
135
- scopes?: AztecAddress[],
183
+ {
184
+ contractAddress,
185
+ selector,
186
+ msgSender = AztecAddress.fromField(Fr.MAX_FIELD_VALUE),
187
+ anchorBlockHeader,
188
+ senderForTags,
189
+ scopes,
190
+ jobId,
191
+ }: ContractSimulatorRunOpts,
136
192
  ): Promise<PrivateExecutionResult> {
137
193
  const simulatorSetupTimer = new Timer();
138
194
 
139
- await this.contractStore.syncPrivateState(contractAddress, selector, privateSyncCall =>
140
- this.runUtility(privateSyncCall, [], anchorBlockHeader, scopes),
141
- );
142
-
143
- await verifyCurrentClassId(contractAddress, this.aztecNode, this.contractStore, anchorBlockHeader);
144
-
145
195
  const entryPointArtifact = await this.contractStore.getFunctionArtifactWithDebugMetadata(contractAddress, selector);
146
196
 
147
197
  if (entryPointArtifact.functionType !== FunctionType.PRIVATE) {
@@ -168,37 +218,37 @@ export class ContractFunctionSimulator {
168
218
  const noteCache = new ExecutionNoteCache(protocolNullifier);
169
219
  const taggingIndexCache = new ExecutionTaggingIndexCache();
170
220
 
171
- const privateExecutionOracle = new PrivateExecutionOracle(
172
- request.firstCallArgsHash,
173
- request.txContext,
221
+ const privateExecutionOracle = new PrivateExecutionOracle({
222
+ argsHash: request.firstCallArgsHash,
223
+ txContext: request.txContext,
174
224
  callContext,
175
225
  anchorBlockHeader,
176
- async call => {
177
- await this.runUtility(call, [], anchorBlockHeader, scopes);
226
+ utilityExecutor: async (call, execScopes) => {
227
+ await this.runUtility(call, [], anchorBlockHeader, execScopes, jobId);
178
228
  },
179
- request.authWitnesses,
180
- request.capsules,
181
- HashedValuesCache.create(request.argsOfCalls),
229
+ authWitnesses: request.authWitnesses,
230
+ capsules: request.capsules,
231
+ executionCache: HashedValuesCache.create(request.argsOfCalls),
182
232
  noteCache,
183
233
  taggingIndexCache,
184
- this.contractStore,
185
- this.noteStore,
186
- this.keyStore,
187
- this.addressStore,
188
- this.aztecNode,
189
- this.anchorBlockStore,
190
- this.senderTaggingStore,
191
- this.recipientTaggingStore,
192
- this.senderAddressBookStore,
193
- this.capsuleStore,
194
- this.privateEventStore,
195
- 0, // totalPublicArgsCount
196
- startSideEffectCounter,
197
- undefined, // log
234
+ contractStore: this.contractStore,
235
+ noteStore: this.noteStore,
236
+ keyStore: this.keyStore,
237
+ addressStore: this.addressStore,
238
+ aztecNode: this.aztecNode,
239
+ senderTaggingStore: this.senderTaggingStore,
240
+ recipientTaggingStore: this.recipientTaggingStore,
241
+ senderAddressBookStore: this.senderAddressBookStore,
242
+ capsuleStore: this.capsuleStore,
243
+ privateEventStore: this.privateEventStore,
244
+ contractSyncService: this.contractSyncService,
245
+ jobId,
246
+ totalPublicCalldataCount: 0,
247
+ sideEffectCounter: startSideEffectCounter,
198
248
  scopes,
199
249
  senderForTags,
200
- this.simulator,
201
- );
250
+ simulator: this.simulator,
251
+ });
202
252
 
203
253
  const setupTime = simulatorSetupTimer.ms();
204
254
 
@@ -215,8 +265,9 @@ export class ContractFunctionSimulator {
215
265
  request.functionSelector,
216
266
  );
217
267
  const simulatorTeardownTimer = new Timer();
218
- const { usedProtocolNullifierForNonces } = noteCache.finish();
219
- const firstNullifierHint = usedProtocolNullifierForNonces ? Fr.ZERO : noteCache.getAllNullifiers()[0];
268
+
269
+ noteCache.finish();
270
+ const firstNullifierHint = noteCache.getNonceGenerator();
220
271
 
221
272
  const publicCallRequests = collectNested([executionResult], r =>
222
273
  r.publicInputs.publicCallRequests
@@ -261,34 +312,32 @@ export class ContractFunctionSimulator {
261
312
  call: FunctionCall,
262
313
  authwits: AuthWitness[],
263
314
  anchorBlockHeader: BlockHeader,
264
- scopes?: AztecAddress[],
315
+ scopes: AccessScopes,
316
+ jobId: string,
265
317
  ): Promise<Fr[]> {
266
- await verifyCurrentClassId(call.to, this.aztecNode, this.contractStore, anchorBlockHeader);
267
-
268
318
  const entryPointArtifact = await this.contractStore.getFunctionArtifactWithDebugMetadata(call.to, call.selector);
269
319
 
270
320
  if (entryPointArtifact.functionType !== FunctionType.UTILITY) {
271
321
  throw new Error(`Cannot run ${entryPointArtifact.functionType} function as utility`);
272
322
  }
273
323
 
274
- const oracle = new UtilityExecutionOracle(
275
- call.to,
276
- authwits,
277
- [],
324
+ const oracle = new UtilityExecutionOracle({
325
+ contractAddress: call.to,
326
+ authWitnesses: authwits,
327
+ capsules: [],
278
328
  anchorBlockHeader,
279
- this.contractStore,
280
- this.noteStore,
281
- this.keyStore,
282
- this.addressStore,
283
- this.aztecNode,
284
- this.anchorBlockStore,
285
- this.recipientTaggingStore,
286
- this.senderAddressBookStore,
287
- this.capsuleStore,
288
- this.privateEventStore,
289
- undefined,
329
+ contractStore: this.contractStore,
330
+ noteStore: this.noteStore,
331
+ keyStore: this.keyStore,
332
+ addressStore: this.addressStore,
333
+ aztecNode: this.aztecNode,
334
+ recipientTaggingStore: this.recipientTaggingStore,
335
+ senderAddressBookStore: this.senderAddressBookStore,
336
+ capsuleStore: this.capsuleStore,
337
+ privateEventStore: this.privateEventStore,
338
+ jobId,
290
339
  scopes,
291
- );
340
+ });
292
341
 
293
342
  try {
294
343
  this.log.verbose(`Executing utility function ${entryPointArtifact.name}`, {
@@ -312,7 +361,7 @@ export class ContractFunctionSimulator {
312
361
  );
313
362
  });
314
363
 
315
- this.log.verbose(`Utility simulation for ${call.to}.${call.selector} completed`);
364
+ this.log.verbose(`Utility execution for ${call.to}.${call.selector} completed`);
316
365
  return witnessMapToFields(acirExecutionResult.returnWitness);
317
366
  } catch (err) {
318
367
  throw createSimulationError(err instanceof Error ? err : new Error('Unknown error during private execution'));
@@ -326,7 +375,12 @@ export class ContractFunctionSimulator {
326
375
  */
327
376
  getStats() {
328
377
  const nodeRPCCalls =
329
- typeof (this.aztecNode as ProxiedNode).getStats === 'function' ? (this.aztecNode as ProxiedNode).getStats() : {};
378
+ typeof (this.aztecNode as BenchmarkedNode).getStats === 'function'
379
+ ? (this.aztecNode as BenchmarkedNode).getStats()
380
+ : {
381
+ perMethod: {},
382
+ roundTrips: { roundTrips: 0, totalBlockingTime: 0, roundTripDurations: [], roundTripMethods: [] },
383
+ };
330
384
 
331
385
  return { nodeRPCCalls };
332
386
  }
@@ -349,24 +403,33 @@ class OrderedSideEffect<T> {
349
403
  * (allowing state overrides) and is much faster, while still generating a valid
350
404
  * output that can be sent to the node for public simulation
351
405
  * @param privateExecutionResult - The result of the private execution.
352
- * @param nonceGenerator - A nonce generator for note hashes. According to the protocol rules,
353
- * it can either be the first nullifier in the tx or the hash of the initial tx request if there are none.
354
- * @param contractStore - A provider for contract data in order to get function names and debug info.
406
+ * @param debugFunctionNameGetter - A provider for contract data in order to get function names and debug info.
407
+ * @param node - AztecNode for verifying settled read requests against the note hash and nullifier trees.
408
+ * @param minRevertibleSideEffectCounterOverride - Optional override for the min revertible side effect counter.
409
+ * Used by TXE to simulate account contract behavior (setting the counter before app execution).
355
410
  * @returns The simulated proving result.
356
411
  */
357
412
  export async function generateSimulatedProvingResult(
358
413
  privateExecutionResult: PrivateExecutionResult,
359
- nonceGenerator: Fr,
360
- contractStore: ContractStore,
414
+ debugFunctionNameGetter: (contractAddress: AztecAddress, functionSelector: FunctionSelector) => Promise<string>,
415
+ node: AztecNode,
416
+ minRevertibleSideEffectCounterOverride?: number,
361
417
  ): Promise<PrivateKernelExecutionProofOutput<PrivateKernelTailCircuitPublicInputs>> {
362
- const siloedNoteHashes: OrderedSideEffect<Fr>[] = [];
363
- const nullifiers: OrderedSideEffect<Fr>[] = [];
364
- const taggedPrivateLogs: OrderedSideEffect<PrivateLog>[] = [];
418
+ const taggedPrivateLogs: OrderedSideEffect<PrivateLogData>[] = [];
365
419
  const l2ToL1Messages: OrderedSideEffect<ScopedL2ToL1Message>[] = [];
366
420
  const contractClassLogsHashes: OrderedSideEffect<ScopedLogHash>[] = [];
367
421
  const publicCallRequests: OrderedSideEffect<PublicCallRequest>[] = [];
368
422
  const executionSteps: PrivateExecutionStep[] = [];
369
423
 
424
+ // Unsiloed scoped arrays — used for squashing, read request verification,
425
+ // and siloed at the end only for the surviving items
426
+ const scopedNoteHashes: ScopedNoteHash[] = [];
427
+ const scopedNullifiers: ScopedNullifier[] = [];
428
+
429
+ // Read requests for verification
430
+ const noteHashReadRequests: ScopedReadRequest[] = [];
431
+ const nullifierReadRequests: ScopedReadRequest[] = [];
432
+
370
433
  let publicTeardownCallRequest;
371
434
 
372
435
  const executions = [privateExecutionResult.entrypoint];
@@ -377,35 +440,25 @@ export async function generateSimulatedProvingResult(
377
440
 
378
441
  const { contractAddress } = execution.publicInputs.callContext;
379
442
 
380
- const noteHashesFromExecution = await Promise.all(
381
- execution.publicInputs.noteHashes
382
- .getActiveItems()
383
- .filter(noteHash => !noteHash.isEmpty())
384
- .map(
385
- async noteHash =>
386
- new OrderedSideEffect(await siloNoteHash(contractAddress, noteHash.value), noteHash.counter),
387
- ),
388
- );
389
-
390
- const nullifiersFromExecution = await Promise.all(
391
- execution.publicInputs.nullifiers
443
+ scopedNoteHashes.push(
444
+ ...execution.publicInputs.noteHashes
392
445
  .getActiveItems()
393
- .map(
394
- async nullifier =>
395
- new OrderedSideEffect(await siloNullifier(contractAddress, nullifier.value), nullifier.counter),
396
- ),
446
+ .filter(nh => !nh.isEmpty())
447
+ .map(nh => nh.scope(contractAddress)),
397
448
  );
449
+ scopedNullifiers.push(...execution.publicInputs.nullifiers.getActiveItems().map(n => n.scope(contractAddress)));
398
450
 
399
- const privateLogsFromExecution = await Promise.all(
400
- execution.publicInputs.privateLogs.getActiveItems().map(async metadata => {
401
- metadata.log.fields[0] = await poseidon2Hash([contractAddress, metadata.log.fields[0]]);
402
- return new OrderedSideEffect(metadata.log, metadata.counter);
403
- }),
451
+ taggedPrivateLogs.push(
452
+ ...(await Promise.all(
453
+ execution.publicInputs.privateLogs.getActiveItems().map(async metadata => {
454
+ metadata.log.fields[0] = await computeSiloedPrivateLogFirstField(contractAddress, metadata.log.fields[0]);
455
+ return new OrderedSideEffect(metadata, metadata.counter);
456
+ }),
457
+ )),
404
458
  );
405
459
 
406
- siloedNoteHashes.push(...noteHashesFromExecution);
407
- taggedPrivateLogs.push(...privateLogsFromExecution);
408
- nullifiers.push(...nullifiersFromExecution);
460
+ noteHashReadRequests.push(...execution.publicInputs.noteHashReadRequests.getActiveItems());
461
+ nullifierReadRequests.push(...execution.publicInputs.nullifierReadRequests.getActiveItems());
409
462
  l2ToL1Messages.push(
410
463
  ...execution.publicInputs.l2ToL1Msgs
411
464
  .getActiveItems()
@@ -434,7 +487,7 @@ export async function generateSimulatedProvingResult(
434
487
  : execution.publicInputs.publicTeardownCallRequest;
435
488
 
436
489
  executionSteps.push({
437
- functionName: await contractStore.getDebugFunctionName(
490
+ functionName: await debugFunctionNameGetter(
438
491
  execution.publicInputs.callContext.contractAddress,
439
492
  execution.publicInputs.callContext.functionSelector,
440
493
  ),
@@ -445,6 +498,47 @@ export async function generateSimulatedProvingResult(
445
498
  });
446
499
  }
447
500
 
501
+ const noteHashNullifierCounterMap = collectNoteHashNullifierCounterMap(privateExecutionResult);
502
+ const minRevertibleSideEffectCounter =
503
+ minRevertibleSideEffectCounterOverride ?? getFinalMinRevertibleSideEffectCounter(privateExecutionResult);
504
+
505
+ const scopedNoteHashesCLA = new ClaimedLengthArray<ScopedNoteHash, typeof MAX_NOTE_HASHES_PER_TX>(
506
+ padArrayEnd(scopedNoteHashes, ScopedNoteHash.empty(), MAX_NOTE_HASHES_PER_TX),
507
+ scopedNoteHashes.length,
508
+ );
509
+ const scopedNullifiersCLA = new ClaimedLengthArray<ScopedNullifier, typeof MAX_NULLIFIERS_PER_TX>(
510
+ padArrayEnd(scopedNullifiers, ScopedNullifier.empty(), MAX_NULLIFIERS_PER_TX),
511
+ scopedNullifiers.length,
512
+ );
513
+
514
+ const { filteredNoteHashes, filteredNullifiers, filteredPrivateLogs } = squashTransientSideEffects(
515
+ taggedPrivateLogs,
516
+ scopedNoteHashesCLA,
517
+ scopedNullifiersCLA,
518
+ noteHashNullifierCounterMap,
519
+ minRevertibleSideEffectCounter,
520
+ );
521
+
522
+ await verifyReadRequests(
523
+ node,
524
+ await privateExecutionResult.entrypoint.publicInputs.anchorBlockHeader.hash(),
525
+ noteHashReadRequests,
526
+ nullifierReadRequests,
527
+ scopedNoteHashesCLA,
528
+ scopedNullifiersCLA,
529
+ );
530
+
531
+ const siloedNoteHashes = await Promise.all(
532
+ filteredNoteHashes
533
+ .sort((a, b) => a.counter - b.counter)
534
+ .map(async nh => new OrderedSideEffect(await siloNoteHash(nh.contractAddress, nh.value), nh.counter)),
535
+ );
536
+ const siloedNullifiers = await Promise.all(
537
+ filteredNullifiers
538
+ .sort((a, b) => a.counter - b.counter)
539
+ .map(async n => new OrderedSideEffect(await siloNullifier(n.contractAddress, n.value), n.counter)),
540
+ );
541
+
448
542
  const constantData = new TxConstantData(
449
543
  privateExecutionResult.entrypoint.publicInputs.anchorBlockHeader,
450
544
  privateExecutionResult.entrypoint.publicInputs.txContext,
@@ -461,23 +555,23 @@ export async function generateSimulatedProvingResult(
461
555
  const getEffect = <T>(orderedSideEffect: OrderedSideEffect<T>) => orderedSideEffect.sideEffect;
462
556
 
463
557
  const isPrivateOnlyTx = privateExecutionResult.publicFunctionCalldata.length === 0;
464
- const minRevertibleSideEffectCounter = getFinalMinRevertibleSideEffectCounter(privateExecutionResult);
465
558
 
466
559
  const [nonRevertibleNullifiers, revertibleNullifiers] = splitOrderedSideEffects(
467
- nullifiers.sort(sortByCounter),
560
+ siloedNullifiers,
468
561
  minRevertibleSideEffectCounter,
469
562
  );
470
- if (nonRevertibleNullifiers.length > 0 && !nonRevertibleNullifiers[0].equals(nonceGenerator)) {
563
+ const nonceGenerator = privateExecutionResult.firstNullifier;
564
+ if (nonRevertibleNullifiers.length === 0) {
565
+ nonRevertibleNullifiers.push(nonceGenerator);
566
+ } else if (!nonRevertibleNullifiers[0].equals(nonceGenerator)) {
471
567
  throw new Error('The first non revertible nullifier should be equal to the nonce generator. This is a bug!');
472
- } else {
473
- nonRevertibleNullifiers.unshift(nonceGenerator);
474
568
  }
475
569
 
476
570
  if (isPrivateOnlyTx) {
477
571
  // We must make the note hashes unique by using the
478
572
  // nonce generator and their index in the tx.
479
573
  const uniqueNoteHashes = await Promise.all(
480
- siloedNoteHashes.sort(sortByCounter).map(async (orderedSideEffect, i) => {
574
+ siloedNoteHashes.map(async (orderedSideEffect, i) => {
481
575
  const siloedNoteHash = orderedSideEffect.sideEffect;
482
576
  const nonce = await computeNoteHashNonce(nonceGenerator, i);
483
577
  const uniqueNoteHash = await computeUniqueNoteHash(nonce, siloedNoteHash);
@@ -492,26 +586,32 @@ export async function generateSimulatedProvingResult(
492
586
  ScopedL2ToL1Message.empty(),
493
587
  MAX_L2_TO_L1_MSGS_PER_TX,
494
588
  ),
495
- padArrayEnd(taggedPrivateLogs.sort(sortByCounter).map(getEffect), PrivateLog.empty(), MAX_PRIVATE_LOGS_PER_TX),
589
+ padArrayEnd(filteredPrivateLogs.sort(sortByCounter).map(getEffect), PrivateLog.empty(), MAX_PRIVATE_LOGS_PER_TX),
496
590
  padArrayEnd(
497
591
  contractClassLogsHashes.sort(sortByCounter).map(getEffect),
498
592
  ScopedLogHash.empty(),
499
593
  MAX_CONTRACT_CLASS_LOGS_PER_TX,
500
594
  ),
501
595
  );
502
- gasUsed = meterGasUsed(accumulatedDataForRollup);
596
+ gasUsed = meterGasUsed(accumulatedDataForRollup, isPrivateOnlyTx);
503
597
  inputsForRollup = new PartialPrivateTailPublicInputsForRollup(accumulatedDataForRollup);
504
598
  } else {
505
599
  const [nonRevertibleNoteHashes, revertibleNoteHashes] = splitOrderedSideEffects(
506
- siloedNoteHashes.sort(sortByCounter),
600
+ siloedNoteHashes,
507
601
  minRevertibleSideEffectCounter,
508
602
  );
603
+ const nonRevertibleUniqueNoteHashes = await Promise.all(
604
+ nonRevertibleNoteHashes.map(async (noteHash, i) => {
605
+ const nonce = await computeNoteHashNonce(nonceGenerator, i);
606
+ return await computeUniqueNoteHash(nonce, noteHash);
607
+ }),
608
+ );
509
609
  const [nonRevertibleL2ToL1Messages, revertibleL2ToL1Messages] = splitOrderedSideEffects(
510
610
  l2ToL1Messages.sort(sortByCounter),
511
611
  minRevertibleSideEffectCounter,
512
612
  );
513
613
  const [nonRevertibleTaggedPrivateLogs, revertibleTaggedPrivateLogs] = splitOrderedSideEffects(
514
- taggedPrivateLogs,
614
+ filteredPrivateLogs,
515
615
  minRevertibleSideEffectCounter,
516
616
  );
517
617
  const [nonRevertibleContractClassLogHashes, revertibleContractClassLogHashes] = splitOrderedSideEffects(
@@ -524,7 +624,7 @@ export async function generateSimulatedProvingResult(
524
624
  );
525
625
 
526
626
  const nonRevertibleData = new PrivateToPublicAccumulatedData(
527
- padArrayEnd(nonRevertibleNoteHashes, Fr.ZERO, MAX_NOTE_HASHES_PER_TX),
627
+ padArrayEnd(nonRevertibleUniqueNoteHashes, Fr.ZERO, MAX_NOTE_HASHES_PER_TX),
528
628
  padArrayEnd(nonRevertibleNullifiers, Fr.ZERO, MAX_NULLIFIERS_PER_TX),
529
629
  padArrayEnd(nonRevertibleL2ToL1Messages, ScopedL2ToL1Message.empty(), MAX_L2_TO_L1_MSGS_PER_TX),
530
630
  padArrayEnd(nonRevertibleTaggedPrivateLogs, PrivateLog.empty(), MAX_PRIVATE_LOGS_PER_TX),
@@ -540,9 +640,9 @@ export async function generateSimulatedProvingResult(
540
640
  padArrayEnd(revertibleContractClassLogHashes, ScopedLogHash.empty(), MAX_CONTRACT_CLASS_LOGS_PER_TX),
541
641
  padArrayEnd(revertiblePublicCallRequests, PublicCallRequest.empty(), MAX_ENQUEUED_CALLS_PER_TX),
542
642
  );
543
- gasUsed = meterGasUsed(revertibleData).add(meterGasUsed(nonRevertibleData));
643
+ gasUsed = meterGasUsed(revertibleData, isPrivateOnlyTx).add(meterGasUsed(nonRevertibleData, isPrivateOnlyTx));
544
644
  if (publicTeardownCallRequest) {
545
- gasUsed.add(privateExecutionResult.entrypoint.publicInputs.txContext.gasSettings.teardownGasLimits);
645
+ gasUsed = gasUsed.add(privateExecutionResult.entrypoint.publicInputs.txContext.gasSettings.teardownGasLimits);
546
646
  }
547
647
 
548
648
  inputsForPublic = new PartialPrivateTailPublicInputsForPublic(
@@ -554,9 +654,14 @@ export async function generateSimulatedProvingResult(
554
654
 
555
655
  const publicInputs = new PrivateKernelTailCircuitPublicInputs(
556
656
  constantData,
557
- /*gasUsed=*/ gasUsed.add(Gas.from({ l2Gas: FIXED_L2_GAS, daGas: FIXED_DA_GAS })),
657
+ /*gasUsed=*/ gasUsed.add(
658
+ Gas.from({
659
+ l2Gas: isPrivateOnlyTx ? PRIVATE_TX_L2_GAS_OVERHEAD : PUBLIC_TX_L2_GAS_OVERHEAD,
660
+ daGas: TX_DA_GAS_OVERHEAD,
661
+ }),
662
+ ),
558
663
  /*feePayer=*/ AztecAddress.zero(),
559
- /*includeByTimestamp=*/ 0n,
664
+ /*expirationTimestamp=*/ 0n,
560
665
  hasPublicCalls ? inputsForPublic : undefined,
561
666
  !hasPublicCalls ? inputsForRollup : undefined,
562
667
  );
@@ -568,11 +673,116 @@ export async function generateSimulatedProvingResult(
568
673
  };
569
674
  }
570
675
 
676
+ /**
677
+ * Squashes transient note hashes and nullifiers, mimicking the behavior
678
+ * of the reset kernels. Returns the filtered (surviving) scoped items and private logs.
679
+ */
680
+ function squashTransientSideEffects(
681
+ taggedPrivateLogs: OrderedSideEffect<PrivateLogData>[],
682
+ scopedNoteHashesCLA: ClaimedLengthArray<ScopedNoteHash, typeof MAX_NOTE_HASHES_PER_TX>,
683
+ scopedNullifiersCLA: ClaimedLengthArray<ScopedNullifier, typeof MAX_NULLIFIERS_PER_TX>,
684
+ noteHashNullifierCounterMap: Map<number, number>,
685
+ minRevertibleSideEffectCounter: number,
686
+ ) {
687
+ const { numTransientData, hints: transientDataHints } = buildTransientDataHints(
688
+ scopedNoteHashesCLA,
689
+ scopedNullifiersCLA,
690
+ /*futureNoteHashReads=*/ [],
691
+ /*futureNullifierReads=*/ [],
692
+ noteHashNullifierCounterMap,
693
+ minRevertibleSideEffectCounter,
694
+ );
695
+
696
+ const squashedNoteHashCounters = new Set<number>();
697
+ const squashedNullifierCounters = new Set<number>();
698
+ for (let i = 0; i < numTransientData; i++) {
699
+ const hint = transientDataHints[i];
700
+ squashedNoteHashCounters.add(scopedNoteHashesCLA.array[hint.noteHashIndex].counter);
701
+ squashedNullifierCounters.add(scopedNullifiersCLA.array[hint.nullifierIndex].counter);
702
+ }
703
+
704
+ return {
705
+ filteredNoteHashes: scopedNoteHashesCLA.getActiveItems().filter(nh => !squashedNoteHashCounters.has(nh.counter)),
706
+ filteredNullifiers: scopedNullifiersCLA.getActiveItems().filter(n => !squashedNullifierCounters.has(n.counter)),
707
+ filteredPrivateLogs: taggedPrivateLogs
708
+ .filter(item => !squashedNoteHashCounters.has(item.sideEffect.noteHashCounter))
709
+ .map(item => new OrderedSideEffect(item.sideEffect.log, item.counter)),
710
+ };
711
+ }
712
+
713
+ /**
714
+ * Verifies settled read requests by checking membership in the note hash and nullifier trees
715
+ * at the tx's anchor block, mimicking the behavior of the kernels
716
+ */
717
+ async function verifyReadRequests(
718
+ node: Pick<AztecNode, 'getNoteHashMembershipWitness' | 'getNullifierMembershipWitness'>,
719
+ anchorBlockHash: BlockParameter,
720
+ noteHashReadRequests: ScopedReadRequest[],
721
+ nullifierReadRequests: ScopedReadRequest[],
722
+ scopedNoteHashesCLA: ClaimedLengthArray<ScopedNoteHash, typeof MAX_NOTE_HASHES_PER_TX>,
723
+ scopedNullifiersCLA: ClaimedLengthArray<ScopedNullifier, typeof MAX_NULLIFIERS_PER_TX>,
724
+ ) {
725
+ const noteHashReadRequestsCLA = new ClaimedLengthArray<ScopedReadRequest, typeof MAX_NOTE_HASH_READ_REQUESTS_PER_TX>(
726
+ padArrayEnd(noteHashReadRequests, ScopedReadRequest.empty(), MAX_NOTE_HASH_READ_REQUESTS_PER_TX),
727
+ noteHashReadRequests.length,
728
+ );
729
+ const nullifierReadRequestsCLA = new ClaimedLengthArray<ScopedReadRequest, typeof MAX_NULLIFIER_READ_REQUESTS_PER_TX>(
730
+ padArrayEnd(nullifierReadRequests, ScopedReadRequest.empty(), MAX_NULLIFIER_READ_REQUESTS_PER_TX),
731
+ nullifierReadRequests.length,
732
+ );
733
+
734
+ const noteHashResetActions = getNoteHashReadRequestResetActions(
735
+ noteHashReadRequestsCLA,
736
+ scopedNoteHashesCLA,
737
+ /*futureNoteHashes=*/ [],
738
+ );
739
+ const nullifierResetActions = getNullifierReadRequestResetActions(
740
+ nullifierReadRequestsCLA,
741
+ scopedNullifiersCLA,
742
+ /*futureNullifiers=*/ [],
743
+ );
744
+
745
+ const settledNoteHashReads: { index: number; value: Fr }[] = [];
746
+ for (let i = 0; i < noteHashResetActions.actions.length; i++) {
747
+ if (noteHashResetActions.actions[i] === ReadRequestActionEnum.READ_AS_SETTLED) {
748
+ settledNoteHashReads.push({ index: i, value: noteHashReadRequests[i].value });
749
+ }
750
+ }
751
+
752
+ const settledNullifierReads: { index: number; value: Fr }[] = [];
753
+ for (let i = 0; i < nullifierResetActions.actions.length; i++) {
754
+ if (nullifierResetActions.actions[i] === ReadRequestActionEnum.READ_AS_SETTLED) {
755
+ settledNullifierReads.push({ index: i, value: nullifierReadRequests[i].value });
756
+ }
757
+ }
758
+
759
+ const [noteHashWitnesses, nullifierWitnesses] = await Promise.all([
760
+ Promise.all(settledNoteHashReads.map(({ value }) => node.getNoteHashMembershipWitness(anchorBlockHash, value))),
761
+ Promise.all(settledNullifierReads.map(({ value }) => node.getNullifierMembershipWitness(anchorBlockHash, value))),
762
+ ]);
763
+
764
+ for (let i = 0; i < settledNoteHashReads.length; i++) {
765
+ if (!noteHashWitnesses[i]) {
766
+ throw new Error(
767
+ `Note hash read request at index ${settledNoteHashReads[i].index} is reading an unknown note hash: ${settledNoteHashReads[i].value}`,
768
+ );
769
+ }
770
+ }
771
+
772
+ for (let i = 0; i < settledNullifierReads.length; i++) {
773
+ if (!nullifierWitnesses[i]) {
774
+ throw new Error(
775
+ `Nullifier read request at index ${settledNullifierReads[i].index} is reading an unknown nullifier: ${settledNullifierReads[i].value}`,
776
+ );
777
+ }
778
+ }
779
+ }
780
+
571
781
  function splitOrderedSideEffects<T>(effects: OrderedSideEffect<T>[], minRevertibleSideEffectCounter: number) {
572
782
  const revertibleSideEffects: T[] = [];
573
783
  const nonRevertibleSideEffects: T[] = [];
574
784
  effects.forEach(effect => {
575
- if (effect.counter < minRevertibleSideEffectCounter) {
785
+ if (minRevertibleSideEffectCounter === 0 || effect.counter < minRevertibleSideEffectCounter) {
576
786
  nonRevertibleSideEffects.push(effect.sideEffect);
577
787
  } else {
578
788
  revertibleSideEffects.push(effect.sideEffect);
@@ -581,21 +791,24 @@ function splitOrderedSideEffects<T>(effects: OrderedSideEffect<T>[], minRevertib
581
791
  return [nonRevertibleSideEffects, revertibleSideEffects];
582
792
  }
583
793
 
584
- function meterGasUsed(data: PrivateToRollupAccumulatedData | PrivateToPublicAccumulatedData) {
794
+ function meterGasUsed(data: PrivateToRollupAccumulatedData | PrivateToPublicAccumulatedData, isPrivateOnlyTx: boolean) {
585
795
  let meteredDAFields = 0;
586
796
  let meteredL2Gas = 0;
587
797
 
588
798
  const numNoteHashes = arrayNonEmptyLength(data.noteHashes, hash => hash.isEmpty());
589
799
  meteredDAFields += numNoteHashes;
590
- meteredL2Gas += numNoteHashes * AVM_EMITNOTEHASH_BASE_L2_GAS;
800
+ const noteHashBaseGas = isPrivateOnlyTx ? L2_GAS_PER_NOTE_HASH : AVM_EMITNOTEHASH_BASE_L2_GAS;
801
+ meteredL2Gas += numNoteHashes * noteHashBaseGas;
591
802
 
592
803
  const numNullifiers = arrayNonEmptyLength(data.nullifiers, nullifier => nullifier.isEmpty());
593
804
  meteredDAFields += numNullifiers;
594
- meteredL2Gas += numNullifiers * AVM_EMITNULLIFIER_BASE_L2_GAS;
805
+ const nullifierBaseGas = isPrivateOnlyTx ? L2_GAS_PER_NULLIFIER : AVM_EMITNULLIFIER_BASE_L2_GAS;
806
+ meteredL2Gas += numNullifiers * nullifierBaseGas;
595
807
 
596
808
  const numL2toL1Messages = arrayNonEmptyLength(data.l2ToL1Msgs, msg => msg.isEmpty());
597
809
  meteredDAFields += numL2toL1Messages;
598
- meteredL2Gas += numL2toL1Messages * AVM_SENDL2TOL1MSG_BASE_L2_GAS;
810
+ const l2ToL1MessageBaseGas = isPrivateOnlyTx ? L2_GAS_PER_L2_TO_L1_MSG : AVM_SENDL2TOL1MSG_BASE_L2_GAS;
811
+ meteredL2Gas += numL2toL1Messages * l2ToL1MessageBaseGas;
599
812
 
600
813
  const numPrivatelogs = arrayNonEmptyLength(data.privateLogs, log => log.isEmpty());
601
814
  // Every private log emits its length as an additional field
@@ -610,7 +823,7 @@ function meterGasUsed(data: PrivateToRollupAccumulatedData | PrivateToPublicAccu
610
823
  );
611
824
  meteredL2Gas += numContractClassLogs * L2_GAS_PER_CONTRACT_CLASS_LOG;
612
825
 
613
- const meteredDAGas = meteredDAFields * DA_BYTES_PER_FIELD * DA_GAS_PER_BYTE;
826
+ const meteredDAGas = meteredDAFields * DA_GAS_PER_FIELD;
614
827
 
615
828
  if ((data as PrivateToPublicAccumulatedData).publicCallRequests) {
616
829
  const dataForPublic = data as PrivateToPublicAccumulatedData;