@aztec/pxe 0.0.1-commit.7d4e6cd → 0.0.1-commit.808bf7f90

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 (261) 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 +11 -5
  6. package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
  7. package/dest/block_synchronizer/block_synchronizer.js +72 -21
  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 -35
  16. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
  17. package/dest/contract_function_simulator/contract_function_simulator.js +198 -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 +1 -1
  25. package/dest/contract_function_simulator/noir-structs/event_validation_request.js +2 -2
  26. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +3 -3
  27. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
  28. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +2 -2
  29. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts +4 -10
  30. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts.map +1 -1
  31. package/dest/contract_function_simulator/noir-structs/utility_context.js +7 -18
  32. package/dest/contract_function_simulator/oracle/interfaces.d.ts +17 -13
  33. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
  34. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts +3 -1
  35. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts.map +1 -1
  36. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts +6 -6
  37. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts.map +1 -1
  38. package/dest/contract_function_simulator/oracle/note_packing_utils.js +8 -8
  39. package/dest/contract_function_simulator/oracle/oracle.d.ts +12 -10
  40. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
  41. package/dest/contract_function_simulator/oracle/oracle.js +67 -44
  42. package/dest/contract_function_simulator/oracle/private_execution.d.ts +2 -26
  43. package/dest/contract_function_simulator/oracle/private_execution.d.ts.map +1 -1
  44. package/dest/contract_function_simulator/oracle/private_execution.js +0 -35
  45. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +44 -35
  46. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
  47. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +82 -25
  48. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +66 -33
  49. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
  50. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +130 -111
  51. package/dest/contract_logging.d.ts +22 -0
  52. package/dest/contract_logging.d.ts.map +1 -0
  53. package/dest/contract_logging.js +23 -0
  54. package/dest/contract_sync/contract_sync_service.d.ts +43 -0
  55. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -0
  56. package/dest/contract_sync/contract_sync_service.js +97 -0
  57. package/dest/contract_sync/helpers.d.ts +29 -0
  58. package/dest/contract_sync/helpers.d.ts.map +1 -0
  59. package/dest/contract_sync/helpers.js +55 -0
  60. package/dest/debug/pxe_debug_utils.d.ts +24 -10
  61. package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
  62. package/dest/debug/pxe_debug_utils.js +28 -17
  63. package/dest/entrypoints/client/bundle/index.d.ts +4 -1
  64. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  65. package/dest/entrypoints/client/bundle/index.js +3 -0
  66. package/dest/entrypoints/client/bundle/utils.d.ts +1 -1
  67. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  68. package/dest/entrypoints/client/bundle/utils.js +21 -7
  69. package/dest/entrypoints/client/lazy/index.d.ts +4 -1
  70. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  71. package/dest/entrypoints/client/lazy/index.js +3 -0
  72. package/dest/entrypoints/client/lazy/utils.d.ts +2 -2
  73. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  74. package/dest/entrypoints/client/lazy/utils.js +22 -8
  75. package/dest/entrypoints/pxe_creation_options.d.ts +3 -2
  76. package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
  77. package/dest/entrypoints/server/index.d.ts +5 -1
  78. package/dest/entrypoints/server/index.d.ts.map +1 -1
  79. package/dest/entrypoints/server/index.js +4 -0
  80. package/dest/entrypoints/server/utils.d.ts +1 -1
  81. package/dest/entrypoints/server/utils.d.ts.map +1 -1
  82. package/dest/entrypoints/server/utils.js +28 -9
  83. package/dest/events/event_service.d.ts +6 -6
  84. package/dest/events/event_service.d.ts.map +1 -1
  85. package/dest/events/event_service.js +19 -22
  86. package/dest/events/private_event_filter_validator.d.ts +5 -5
  87. package/dest/events/private_event_filter_validator.d.ts.map +1 -1
  88. package/dest/events/private_event_filter_validator.js +5 -6
  89. package/dest/job_coordinator/job_coordinator.d.ts +3 -2
  90. package/dest/job_coordinator/job_coordinator.d.ts.map +1 -1
  91. package/dest/job_coordinator/job_coordinator.js +3 -2
  92. package/dest/logs/log_service.d.ts +8 -5
  93. package/dest/logs/log_service.d.ts.map +1 -1
  94. package/dest/logs/log_service.js +28 -30
  95. package/dest/notes/note_service.d.ts +10 -9
  96. package/dest/notes/note_service.d.ts.map +1 -1
  97. package/dest/notes/note_service.js +34 -38
  98. package/dest/notes_filter.d.ts +25 -0
  99. package/dest/notes_filter.d.ts.map +1 -0
  100. package/dest/notes_filter.js +4 -0
  101. package/dest/oracle_version.d.ts +3 -3
  102. package/dest/oracle_version.d.ts.map +1 -1
  103. package/dest/oracle_version.js +4 -3
  104. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
  105. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
  106. package/dest/private_kernel/hints/{compute_tx_include_by_timestamp.js → compute_tx_expiration_timestamp.js} +12 -12
  107. package/dest/private_kernel/hints/index.d.ts +3 -3
  108. package/dest/private_kernel/hints/index.d.ts.map +1 -1
  109. package/dest/private_kernel/hints/index.js +2 -2
  110. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +28 -0
  111. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -0
  112. package/dest/private_kernel/hints/{build_private_kernel_reset_private_inputs.js → private_kernel_reset_private_inputs_builder.js} +15 -9
  113. package/dest/private_kernel/private_kernel_execution_prover.d.ts +3 -2
  114. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
  115. package/dest/private_kernel/private_kernel_execution_prover.js +9 -9
  116. package/dest/private_kernel/private_kernel_oracle.d.ts +23 -24
  117. package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
  118. package/dest/private_kernel/private_kernel_oracle.js +94 -2
  119. package/dest/pxe.d.ts +75 -58
  120. package/dest/pxe.d.ts.map +1 -1
  121. package/dest/pxe.js +124 -132
  122. package/dest/storage/address_store/address_store.d.ts +1 -1
  123. package/dest/storage/address_store/address_store.d.ts.map +1 -1
  124. package/dest/storage/address_store/address_store.js +12 -11
  125. package/dest/storage/anchor_block_store/anchor_block_store.d.ts +9 -1
  126. package/dest/storage/anchor_block_store/anchor_block_store.d.ts.map +1 -1
  127. package/dest/storage/anchor_block_store/anchor_block_store.js +8 -1
  128. package/dest/storage/capsule_store/capsule_store.d.ts +24 -9
  129. package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -1
  130. package/dest/storage/capsule_store/capsule_store.js +130 -23
  131. package/dest/storage/contract_store/contract_store.d.ts +42 -16
  132. package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
  133. package/dest/storage/contract_store/contract_store.js +157 -84
  134. package/dest/storage/metadata.d.ts +1 -1
  135. package/dest/storage/metadata.js +1 -1
  136. package/dest/storage/note_store/note_store.d.ts +50 -51
  137. package/dest/storage/note_store/note_store.d.ts.map +1 -1
  138. package/dest/storage/note_store/note_store.js +284 -263
  139. package/dest/storage/note_store/stored_note.d.ts +16 -0
  140. package/dest/storage/note_store/stored_note.d.ts.map +1 -0
  141. package/dest/storage/note_store/stored_note.js +43 -0
  142. package/dest/storage/private_event_store/private_event_store.d.ts +43 -8
  143. package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -1
  144. package/dest/storage/private_event_store/private_event_store.js +226 -111
  145. package/dest/storage/private_event_store/stored_private_event.d.ts +23 -0
  146. package/dest/storage/private_event_store/stored_private_event.d.ts.map +1 -0
  147. package/dest/storage/private_event_store/stored_private_event.js +56 -0
  148. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +15 -8
  149. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
  150. package/dest/storage/tagging_store/recipient_tagging_store.js +88 -19
  151. package/dest/storage/tagging_store/sender_address_book_store.d.ts +1 -1
  152. package/dest/storage/tagging_store/sender_address_book_store.d.ts.map +1 -1
  153. package/dest/storage/tagging_store/sender_address_book_store.js +20 -14
  154. package/dest/storage/tagging_store/sender_tagging_store.d.ts +19 -9
  155. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
  156. package/dest/storage/tagging_store/sender_tagging_store.js +252 -100
  157. package/dest/tagging/get_all_logs_by_tags.d.ts +24 -0
  158. package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -0
  159. package/dest/tagging/get_all_logs_by_tags.js +60 -0
  160. package/dest/tagging/index.d.ts +2 -1
  161. package/dest/tagging/index.d.ts.map +1 -1
  162. package/dest/tagging/index.js +1 -0
  163. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +3 -2
  164. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +1 -1
  165. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +10 -10
  166. package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +2 -2
  167. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +3 -2
  168. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +1 -1
  169. package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +5 -2
  170. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +3 -2
  171. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
  172. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +7 -7
  173. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +1 -1
  174. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -1
  175. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +5 -8
  176. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +5 -2
  177. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -1
  178. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +10 -5
  179. package/package.json +27 -18
  180. package/src/access_scopes.ts +9 -0
  181. package/src/bin/check_oracle_version.ts +1 -0
  182. package/src/block_synchronizer/block_synchronizer.ts +91 -33
  183. package/src/config/index.ts +14 -0
  184. package/src/config/package_info.ts +1 -1
  185. package/src/contract_function_simulator/benchmarked_node.ts +103 -0
  186. package/src/contract_function_simulator/contract_function_simulator.ts +356 -148
  187. package/src/contract_function_simulator/execution_note_cache.ts +44 -25
  188. package/src/contract_function_simulator/index.ts +1 -1
  189. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +2 -2
  190. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +2 -2
  191. package/src/contract_function_simulator/noir-structs/utility_context.ts +6 -25
  192. package/src/contract_function_simulator/oracle/interfaces.ts +22 -12
  193. package/src/contract_function_simulator/oracle/note_packing_utils.ts +10 -10
  194. package/src/contract_function_simulator/oracle/oracle.ts +79 -47
  195. package/src/contract_function_simulator/oracle/private_execution.ts +1 -67
  196. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +118 -104
  197. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +197 -116
  198. package/src/contract_logging.ts +39 -0
  199. package/src/contract_sync/contract_sync_service.ts +152 -0
  200. package/src/contract_sync/helpers.ts +98 -0
  201. package/src/debug/pxe_debug_utils.ts +63 -18
  202. package/src/entrypoints/client/bundle/index.ts +3 -0
  203. package/src/entrypoints/client/bundle/utils.ts +16 -15
  204. package/src/entrypoints/client/lazy/index.ts +3 -0
  205. package/src/entrypoints/client/lazy/utils.ts +17 -15
  206. package/src/entrypoints/pxe_creation_options.ts +2 -1
  207. package/src/entrypoints/server/index.ts +4 -0
  208. package/src/entrypoints/server/utils.ts +22 -26
  209. package/src/events/event_service.ts +17 -25
  210. package/src/events/private_event_filter_validator.ts +3 -5
  211. package/src/job_coordinator/job_coordinator.ts +4 -3
  212. package/src/logs/log_service.ts +40 -34
  213. package/src/notes/note_service.ts +41 -45
  214. package/src/notes_filter.ts +26 -0
  215. package/src/oracle_version.ts +4 -3
  216. package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
  217. package/src/private_kernel/hints/index.ts +2 -2
  218. package/src/private_kernel/hints/{build_private_kernel_reset_private_inputs.ts → private_kernel_reset_private_inputs_builder.ts} +38 -26
  219. package/src/private_kernel/private_kernel_execution_prover.ts +13 -10
  220. package/src/private_kernel/private_kernel_oracle.ts +116 -37
  221. package/src/pxe.ts +235 -209
  222. package/src/storage/address_store/address_store.ts +15 -15
  223. package/src/storage/anchor_block_store/anchor_block_store.ts +8 -0
  224. package/src/storage/capsule_store/capsule_store.ts +159 -23
  225. package/src/storage/contract_store/contract_store.ts +186 -96
  226. package/src/storage/metadata.ts +1 -1
  227. package/src/storage/note_store/note_store.ts +326 -320
  228. package/src/storage/note_store/stored_note.ts +48 -0
  229. package/src/storage/private_event_store/private_event_store.ts +292 -124
  230. package/src/storage/private_event_store/stored_private_event.ts +73 -0
  231. package/src/storage/tagging_store/recipient_tagging_store.ts +106 -20
  232. package/src/storage/tagging_store/sender_address_book_store.ts +20 -14
  233. package/src/storage/tagging_store/sender_tagging_store.ts +293 -108
  234. package/src/tagging/get_all_logs_by_tags.ts +92 -0
  235. package/src/tagging/index.ts +1 -0
  236. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +20 -9
  237. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +2 -2
  238. package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +7 -1
  239. package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +9 -6
  240. package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +5 -17
  241. package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +16 -4
  242. package/dest/contract_function_simulator/proxied_node.d.ts +0 -9
  243. package/dest/contract_function_simulator/proxied_node.d.ts.map +0 -1
  244. package/dest/contract_function_simulator/proxied_node.js +0 -27
  245. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts +0 -28
  246. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts.map +0 -1
  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/dest/private_kernel/private_kernel_oracle_impl.d.ts +0 -46
  250. package/dest/private_kernel/private_kernel_oracle_impl.d.ts.map +0 -1
  251. package/dest/private_kernel/private_kernel_oracle_impl.js +0 -85
  252. package/dest/public_storage/public_storage_service.d.ts +0 -24
  253. package/dest/public_storage/public_storage_service.d.ts.map +0 -1
  254. package/dest/public_storage/public_storage_service.js +0 -26
  255. package/dest/tree_membership/tree_membership_service.d.ts +0 -52
  256. package/dest/tree_membership/tree_membership_service.d.ts.map +0 -1
  257. package/dest/tree_membership/tree_membership_service.js +0 -84
  258. package/src/contract_function_simulator/proxied_node.ts +0 -33
  259. package/src/private_kernel/private_kernel_oracle_impl.ts +0 -127
  260. package/src/public_storage/public_storage_service.ts +0 -33
  261. 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,70 +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
- * @param jobId - The job ID for staged writes.
127
- * @returns The result of the execution.
128
180
  */
129
181
  public async run(
130
182
  request: TxExecutionRequest,
131
- contractAddress: AztecAddress,
132
- selector: FunctionSelector,
133
- msgSender = AztecAddress.fromField(Fr.MAX_FIELD_VALUE),
134
- anchorBlockHeader: BlockHeader,
135
- senderForTags: AztecAddress | undefined,
136
- scopes: AztecAddress[] | undefined,
137
- jobId: string,
183
+ {
184
+ contractAddress,
185
+ selector,
186
+ msgSender = AztecAddress.fromField(Fr.MAX_FIELD_VALUE),
187
+ anchorBlockHeader,
188
+ senderForTags,
189
+ scopes,
190
+ jobId,
191
+ }: ContractSimulatorRunOpts,
138
192
  ): Promise<PrivateExecutionResult> {
139
193
  const simulatorSetupTimer = new Timer();
140
194
 
141
- await this.contractStore.syncPrivateState(contractAddress, selector, privateSyncCall =>
142
- this.runUtility(privateSyncCall, [], anchorBlockHeader, scopes, jobId),
143
- );
144
-
145
- await verifyCurrentClassId(contractAddress, this.aztecNode, this.contractStore, anchorBlockHeader);
146
-
147
195
  const entryPointArtifact = await this.contractStore.getFunctionArtifactWithDebugMetadata(contractAddress, selector);
148
196
 
149
197
  if (entryPointArtifact.functionType !== FunctionType.PRIVATE) {
@@ -170,38 +218,37 @@ export class ContractFunctionSimulator {
170
218
  const noteCache = new ExecutionNoteCache(protocolNullifier);
171
219
  const taggingIndexCache = new ExecutionTaggingIndexCache();
172
220
 
173
- const privateExecutionOracle = new PrivateExecutionOracle(
174
- request.firstCallArgsHash,
175
- request.txContext,
221
+ const privateExecutionOracle = new PrivateExecutionOracle({
222
+ argsHash: request.firstCallArgsHash,
223
+ txContext: request.txContext,
176
224
  callContext,
177
225
  anchorBlockHeader,
178
- async call => {
179
- await this.runUtility(call, [], anchorBlockHeader, scopes, jobId);
226
+ utilityExecutor: async (call, execScopes) => {
227
+ await this.runUtility(call, [], anchorBlockHeader, execScopes, jobId);
180
228
  },
181
- request.authWitnesses,
182
- request.capsules,
183
- HashedValuesCache.create(request.argsOfCalls),
229
+ authWitnesses: request.authWitnesses,
230
+ capsules: request.capsules,
231
+ executionCache: HashedValuesCache.create(request.argsOfCalls),
184
232
  noteCache,
185
233
  taggingIndexCache,
186
- this.contractStore,
187
- this.noteStore,
188
- this.keyStore,
189
- this.addressStore,
190
- this.aztecNode,
191
- this.anchorBlockStore,
192
- this.senderTaggingStore,
193
- this.recipientTaggingStore,
194
- this.senderAddressBookStore,
195
- this.capsuleStore,
196
- this.privateEventStore,
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,
197
245
  jobId,
198
- 0, // totalPublicArgsCount
199
- startSideEffectCounter,
200
- undefined, // log
246
+ totalPublicCalldataCount: 0,
247
+ sideEffectCounter: startSideEffectCounter,
201
248
  scopes,
202
249
  senderForTags,
203
- this.simulator,
204
- );
250
+ simulator: this.simulator,
251
+ });
205
252
 
206
253
  const setupTime = simulatorSetupTimer.ms();
207
254
 
@@ -218,8 +265,9 @@ export class ContractFunctionSimulator {
218
265
  request.functionSelector,
219
266
  );
220
267
  const simulatorTeardownTimer = new Timer();
221
- const { usedProtocolNullifierForNonces } = noteCache.finish();
222
- const firstNullifierHint = usedProtocolNullifierForNonces ? Fr.ZERO : noteCache.getAllNullifiers()[0];
268
+
269
+ noteCache.finish();
270
+ const firstNullifierHint = noteCache.getNonceGenerator();
223
271
 
224
272
  const publicCallRequests = collectNested([executionResult], r =>
225
273
  r.publicInputs.publicCallRequests
@@ -264,36 +312,32 @@ export class ContractFunctionSimulator {
264
312
  call: FunctionCall,
265
313
  authwits: AuthWitness[],
266
314
  anchorBlockHeader: BlockHeader,
267
- scopes: AztecAddress[] | undefined,
315
+ scopes: AccessScopes,
268
316
  jobId: string,
269
317
  ): Promise<Fr[]> {
270
- await verifyCurrentClassId(call.to, this.aztecNode, this.contractStore, anchorBlockHeader);
271
-
272
318
  const entryPointArtifact = await this.contractStore.getFunctionArtifactWithDebugMetadata(call.to, call.selector);
273
319
 
274
320
  if (entryPointArtifact.functionType !== FunctionType.UTILITY) {
275
321
  throw new Error(`Cannot run ${entryPointArtifact.functionType} function as utility`);
276
322
  }
277
323
 
278
- const oracle = new UtilityExecutionOracle(
279
- call.to,
280
- authwits,
281
- [],
324
+ const oracle = new UtilityExecutionOracle({
325
+ contractAddress: call.to,
326
+ authWitnesses: authwits,
327
+ capsules: [],
282
328
  anchorBlockHeader,
283
- this.contractStore,
284
- this.noteStore,
285
- this.keyStore,
286
- this.addressStore,
287
- this.aztecNode,
288
- this.anchorBlockStore,
289
- this.recipientTaggingStore,
290
- this.senderAddressBookStore,
291
- this.capsuleStore,
292
- this.privateEventStore,
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,
293
338
  jobId,
294
- undefined,
295
339
  scopes,
296
- );
340
+ });
297
341
 
298
342
  try {
299
343
  this.log.verbose(`Executing utility function ${entryPointArtifact.name}`, {
@@ -317,7 +361,7 @@ export class ContractFunctionSimulator {
317
361
  );
318
362
  });
319
363
 
320
- this.log.verbose(`Utility simulation for ${call.to}.${call.selector} completed`);
364
+ this.log.verbose(`Utility execution for ${call.to}.${call.selector} completed`);
321
365
  return witnessMapToFields(acirExecutionResult.returnWitness);
322
366
  } catch (err) {
323
367
  throw createSimulationError(err instanceof Error ? err : new Error('Unknown error during private execution'));
@@ -331,7 +375,12 @@ export class ContractFunctionSimulator {
331
375
  */
332
376
  getStats() {
333
377
  const nodeRPCCalls =
334
- 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
+ };
335
384
 
336
385
  return { nodeRPCCalls };
337
386
  }
@@ -354,24 +403,33 @@ class OrderedSideEffect<T> {
354
403
  * (allowing state overrides) and is much faster, while still generating a valid
355
404
  * output that can be sent to the node for public simulation
356
405
  * @param privateExecutionResult - The result of the private execution.
357
- * @param nonceGenerator - A nonce generator for note hashes. According to the protocol rules,
358
- * it can either be the first nullifier in the tx or the hash of the initial tx request if there are none.
359
- * @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).
360
410
  * @returns The simulated proving result.
361
411
  */
362
412
  export async function generateSimulatedProvingResult(
363
413
  privateExecutionResult: PrivateExecutionResult,
364
- nonceGenerator: Fr,
365
- contractStore: ContractStore,
414
+ debugFunctionNameGetter: (contractAddress: AztecAddress, functionSelector: FunctionSelector) => Promise<string>,
415
+ node: AztecNode,
416
+ minRevertibleSideEffectCounterOverride?: number,
366
417
  ): Promise<PrivateKernelExecutionProofOutput<PrivateKernelTailCircuitPublicInputs>> {
367
- const siloedNoteHashes: OrderedSideEffect<Fr>[] = [];
368
- const nullifiers: OrderedSideEffect<Fr>[] = [];
369
- const taggedPrivateLogs: OrderedSideEffect<PrivateLog>[] = [];
418
+ const taggedPrivateLogs: OrderedSideEffect<PrivateLogData>[] = [];
370
419
  const l2ToL1Messages: OrderedSideEffect<ScopedL2ToL1Message>[] = [];
371
420
  const contractClassLogsHashes: OrderedSideEffect<ScopedLogHash>[] = [];
372
421
  const publicCallRequests: OrderedSideEffect<PublicCallRequest>[] = [];
373
422
  const executionSteps: PrivateExecutionStep[] = [];
374
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
+
375
433
  let publicTeardownCallRequest;
376
434
 
377
435
  const executions = [privateExecutionResult.entrypoint];
@@ -382,35 +440,25 @@ export async function generateSimulatedProvingResult(
382
440
 
383
441
  const { contractAddress } = execution.publicInputs.callContext;
384
442
 
385
- const noteHashesFromExecution = await Promise.all(
386
- execution.publicInputs.noteHashes
443
+ scopedNoteHashes.push(
444
+ ...execution.publicInputs.noteHashes
387
445
  .getActiveItems()
388
- .filter(noteHash => !noteHash.isEmpty())
389
- .map(
390
- async noteHash =>
391
- new OrderedSideEffect(await siloNoteHash(contractAddress, noteHash.value), noteHash.counter),
392
- ),
393
- );
394
-
395
- const nullifiersFromExecution = await Promise.all(
396
- execution.publicInputs.nullifiers
397
- .getActiveItems()
398
- .map(
399
- async nullifier =>
400
- new OrderedSideEffect(await siloNullifier(contractAddress, nullifier.value), nullifier.counter),
401
- ),
446
+ .filter(nh => !nh.isEmpty())
447
+ .map(nh => nh.scope(contractAddress)),
402
448
  );
449
+ scopedNullifiers.push(...execution.publicInputs.nullifiers.getActiveItems().map(n => n.scope(contractAddress)));
403
450
 
404
- const privateLogsFromExecution = await Promise.all(
405
- execution.publicInputs.privateLogs.getActiveItems().map(async metadata => {
406
- metadata.log.fields[0] = await poseidon2Hash([contractAddress, metadata.log.fields[0]]);
407
- return new OrderedSideEffect(metadata.log, metadata.counter);
408
- }),
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
+ )),
409
458
  );
410
459
 
411
- siloedNoteHashes.push(...noteHashesFromExecution);
412
- taggedPrivateLogs.push(...privateLogsFromExecution);
413
- nullifiers.push(...nullifiersFromExecution);
460
+ noteHashReadRequests.push(...execution.publicInputs.noteHashReadRequests.getActiveItems());
461
+ nullifierReadRequests.push(...execution.publicInputs.nullifierReadRequests.getActiveItems());
414
462
  l2ToL1Messages.push(
415
463
  ...execution.publicInputs.l2ToL1Msgs
416
464
  .getActiveItems()
@@ -439,7 +487,7 @@ export async function generateSimulatedProvingResult(
439
487
  : execution.publicInputs.publicTeardownCallRequest;
440
488
 
441
489
  executionSteps.push({
442
- functionName: await contractStore.getDebugFunctionName(
490
+ functionName: await debugFunctionNameGetter(
443
491
  execution.publicInputs.callContext.contractAddress,
444
492
  execution.publicInputs.callContext.functionSelector,
445
493
  ),
@@ -450,6 +498,47 @@ export async function generateSimulatedProvingResult(
450
498
  });
451
499
  }
452
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
+
453
542
  const constantData = new TxConstantData(
454
543
  privateExecutionResult.entrypoint.publicInputs.anchorBlockHeader,
455
544
  privateExecutionResult.entrypoint.publicInputs.txContext,
@@ -466,23 +555,23 @@ export async function generateSimulatedProvingResult(
466
555
  const getEffect = <T>(orderedSideEffect: OrderedSideEffect<T>) => orderedSideEffect.sideEffect;
467
556
 
468
557
  const isPrivateOnlyTx = privateExecutionResult.publicFunctionCalldata.length === 0;
469
- const minRevertibleSideEffectCounter = getFinalMinRevertibleSideEffectCounter(privateExecutionResult);
470
558
 
471
559
  const [nonRevertibleNullifiers, revertibleNullifiers] = splitOrderedSideEffects(
472
- nullifiers.sort(sortByCounter),
560
+ siloedNullifiers,
473
561
  minRevertibleSideEffectCounter,
474
562
  );
475
- 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)) {
476
567
  throw new Error('The first non revertible nullifier should be equal to the nonce generator. This is a bug!');
477
- } else {
478
- nonRevertibleNullifiers.unshift(nonceGenerator);
479
568
  }
480
569
 
481
570
  if (isPrivateOnlyTx) {
482
571
  // We must make the note hashes unique by using the
483
572
  // nonce generator and their index in the tx.
484
573
  const uniqueNoteHashes = await Promise.all(
485
- siloedNoteHashes.sort(sortByCounter).map(async (orderedSideEffect, i) => {
574
+ siloedNoteHashes.map(async (orderedSideEffect, i) => {
486
575
  const siloedNoteHash = orderedSideEffect.sideEffect;
487
576
  const nonce = await computeNoteHashNonce(nonceGenerator, i);
488
577
  const uniqueNoteHash = await computeUniqueNoteHash(nonce, siloedNoteHash);
@@ -497,26 +586,32 @@ export async function generateSimulatedProvingResult(
497
586
  ScopedL2ToL1Message.empty(),
498
587
  MAX_L2_TO_L1_MSGS_PER_TX,
499
588
  ),
500
- 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),
501
590
  padArrayEnd(
502
591
  contractClassLogsHashes.sort(sortByCounter).map(getEffect),
503
592
  ScopedLogHash.empty(),
504
593
  MAX_CONTRACT_CLASS_LOGS_PER_TX,
505
594
  ),
506
595
  );
507
- gasUsed = meterGasUsed(accumulatedDataForRollup);
596
+ gasUsed = meterGasUsed(accumulatedDataForRollup, isPrivateOnlyTx);
508
597
  inputsForRollup = new PartialPrivateTailPublicInputsForRollup(accumulatedDataForRollup);
509
598
  } else {
510
599
  const [nonRevertibleNoteHashes, revertibleNoteHashes] = splitOrderedSideEffects(
511
- siloedNoteHashes.sort(sortByCounter),
600
+ siloedNoteHashes,
512
601
  minRevertibleSideEffectCounter,
513
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
+ );
514
609
  const [nonRevertibleL2ToL1Messages, revertibleL2ToL1Messages] = splitOrderedSideEffects(
515
610
  l2ToL1Messages.sort(sortByCounter),
516
611
  minRevertibleSideEffectCounter,
517
612
  );
518
613
  const [nonRevertibleTaggedPrivateLogs, revertibleTaggedPrivateLogs] = splitOrderedSideEffects(
519
- taggedPrivateLogs,
614
+ filteredPrivateLogs,
520
615
  minRevertibleSideEffectCounter,
521
616
  );
522
617
  const [nonRevertibleContractClassLogHashes, revertibleContractClassLogHashes] = splitOrderedSideEffects(
@@ -529,7 +624,7 @@ export async function generateSimulatedProvingResult(
529
624
  );
530
625
 
531
626
  const nonRevertibleData = new PrivateToPublicAccumulatedData(
532
- padArrayEnd(nonRevertibleNoteHashes, Fr.ZERO, MAX_NOTE_HASHES_PER_TX),
627
+ padArrayEnd(nonRevertibleUniqueNoteHashes, Fr.ZERO, MAX_NOTE_HASHES_PER_TX),
533
628
  padArrayEnd(nonRevertibleNullifiers, Fr.ZERO, MAX_NULLIFIERS_PER_TX),
534
629
  padArrayEnd(nonRevertibleL2ToL1Messages, ScopedL2ToL1Message.empty(), MAX_L2_TO_L1_MSGS_PER_TX),
535
630
  padArrayEnd(nonRevertibleTaggedPrivateLogs, PrivateLog.empty(), MAX_PRIVATE_LOGS_PER_TX),
@@ -545,9 +640,9 @@ export async function generateSimulatedProvingResult(
545
640
  padArrayEnd(revertibleContractClassLogHashes, ScopedLogHash.empty(), MAX_CONTRACT_CLASS_LOGS_PER_TX),
546
641
  padArrayEnd(revertiblePublicCallRequests, PublicCallRequest.empty(), MAX_ENQUEUED_CALLS_PER_TX),
547
642
  );
548
- gasUsed = meterGasUsed(revertibleData).add(meterGasUsed(nonRevertibleData));
643
+ gasUsed = meterGasUsed(revertibleData, isPrivateOnlyTx).add(meterGasUsed(nonRevertibleData, isPrivateOnlyTx));
549
644
  if (publicTeardownCallRequest) {
550
- gasUsed.add(privateExecutionResult.entrypoint.publicInputs.txContext.gasSettings.teardownGasLimits);
645
+ gasUsed = gasUsed.add(privateExecutionResult.entrypoint.publicInputs.txContext.gasSettings.teardownGasLimits);
551
646
  }
552
647
 
553
648
  inputsForPublic = new PartialPrivateTailPublicInputsForPublic(
@@ -559,9 +654,14 @@ export async function generateSimulatedProvingResult(
559
654
 
560
655
  const publicInputs = new PrivateKernelTailCircuitPublicInputs(
561
656
  constantData,
562
- /*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
+ ),
563
663
  /*feePayer=*/ AztecAddress.zero(),
564
- /*includeByTimestamp=*/ 0n,
664
+ /*expirationTimestamp=*/ 0n,
565
665
  hasPublicCalls ? inputsForPublic : undefined,
566
666
  !hasPublicCalls ? inputsForRollup : undefined,
567
667
  );
@@ -573,11 +673,116 @@ export async function generateSimulatedProvingResult(
573
673
  };
574
674
  }
575
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
+
576
781
  function splitOrderedSideEffects<T>(effects: OrderedSideEffect<T>[], minRevertibleSideEffectCounter: number) {
577
782
  const revertibleSideEffects: T[] = [];
578
783
  const nonRevertibleSideEffects: T[] = [];
579
784
  effects.forEach(effect => {
580
- if (effect.counter < minRevertibleSideEffectCounter) {
785
+ if (minRevertibleSideEffectCounter === 0 || effect.counter < minRevertibleSideEffectCounter) {
581
786
  nonRevertibleSideEffects.push(effect.sideEffect);
582
787
  } else {
583
788
  revertibleSideEffects.push(effect.sideEffect);
@@ -586,21 +791,24 @@ function splitOrderedSideEffects<T>(effects: OrderedSideEffect<T>[], minRevertib
586
791
  return [nonRevertibleSideEffects, revertibleSideEffects];
587
792
  }
588
793
 
589
- function meterGasUsed(data: PrivateToRollupAccumulatedData | PrivateToPublicAccumulatedData) {
794
+ function meterGasUsed(data: PrivateToRollupAccumulatedData | PrivateToPublicAccumulatedData, isPrivateOnlyTx: boolean) {
590
795
  let meteredDAFields = 0;
591
796
  let meteredL2Gas = 0;
592
797
 
593
798
  const numNoteHashes = arrayNonEmptyLength(data.noteHashes, hash => hash.isEmpty());
594
799
  meteredDAFields += numNoteHashes;
595
- 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;
596
802
 
597
803
  const numNullifiers = arrayNonEmptyLength(data.nullifiers, nullifier => nullifier.isEmpty());
598
804
  meteredDAFields += numNullifiers;
599
- meteredL2Gas += numNullifiers * AVM_EMITNULLIFIER_BASE_L2_GAS;
805
+ const nullifierBaseGas = isPrivateOnlyTx ? L2_GAS_PER_NULLIFIER : AVM_EMITNULLIFIER_BASE_L2_GAS;
806
+ meteredL2Gas += numNullifiers * nullifierBaseGas;
600
807
 
601
808
  const numL2toL1Messages = arrayNonEmptyLength(data.l2ToL1Msgs, msg => msg.isEmpty());
602
809
  meteredDAFields += numL2toL1Messages;
603
- 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;
604
812
 
605
813
  const numPrivatelogs = arrayNonEmptyLength(data.privateLogs, log => log.isEmpty());
606
814
  // Every private log emits its length as an additional field
@@ -615,7 +823,7 @@ function meterGasUsed(data: PrivateToRollupAccumulatedData | PrivateToPublicAccu
615
823
  );
616
824
  meteredL2Gas += numContractClassLogs * L2_GAS_PER_CONTRACT_CLASS_LOG;
617
825
 
618
- const meteredDAGas = meteredDAFields * DA_BYTES_PER_FIELD * DA_GAS_PER_BYTE;
826
+ const meteredDAGas = meteredDAFields * DA_GAS_PER_FIELD;
619
827
 
620
828
  if ((data as PrivateToPublicAccumulatedData).publicCallRequests) {
621
829
  const dataForPublic = data as PrivateToPublicAccumulatedData;