@aztec/pxe 0.0.1-commit.d1f2d6c → 0.0.1-commit.d20b825a7

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