@aztec/pxe 0.0.1-commit.aada20e3 → 0.0.1-commit.b2a5d0dd1

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