@aztec/pxe 0.0.1-commit.ee80a48 → 0.0.1-commit.f103f88

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