@aztec/pxe 0.0.1-commit.6d3c34e → 0.0.1-commit.7cf39cb55

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