@aztec/pxe 0.0.1-commit.9372f48 → 0.0.1-commit.949a33fd8

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