@aztec/pxe 0.0.1-commit.e3c1de76 → 0.0.1-commit.e588bc7e5

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