@aztec/pxe 0.0.1-commit.fcb71a6 → 0.0.1-commit.ff7989d6c

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