@aztec/pxe 0.0.1-commit.c7c42ec → 0.0.1-commit.cf93bcc56

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