@aztec/pxe 0.0.1-commit.2448fdb → 0.0.1-commit.2606882

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 (279) hide show
  1. package/dest/bin/check_oracle_version.js +40 -96
  2. package/dest/bin/index.d.ts +2 -0
  3. package/dest/bin/index.d.ts.map +1 -0
  4. package/dest/bin/index.js +1 -0
  5. package/dest/bin/oracle_version_helpers.d.ts +26 -0
  6. package/dest/bin/oracle_version_helpers.d.ts.map +1 -0
  7. package/dest/bin/oracle_version_helpers.js +93 -0
  8. package/dest/block_synchronizer/block_stream_source.d.ts +10 -0
  9. package/dest/block_synchronizer/block_stream_source.d.ts.map +1 -0
  10. package/dest/block_synchronizer/block_stream_source.js +62 -0
  11. package/dest/block_synchronizer/block_synchronizer.d.ts +5 -3
  12. package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
  13. package/dest/block_synchronizer/block_synchronizer.js +21 -11
  14. package/dest/config/index.d.ts +8 -2
  15. package/dest/config/index.d.ts.map +1 -1
  16. package/dest/config/index.js +13 -15
  17. package/dest/config/package_info.js +1 -1
  18. package/dest/contract_function_simulator/contract_function_simulator.d.ts +4 -1
  19. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
  20. package/dest/contract_function_simulator/contract_function_simulator.js +20 -12
  21. package/dest/contract_function_simulator/execution_note_cache.d.ts +2 -2
  22. package/dest/contract_function_simulator/execution_note_cache.d.ts.map +1 -1
  23. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +5 -9
  24. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -1
  25. package/dest/contract_function_simulator/execution_tagging_index_cache.js +3 -7
  26. package/dest/contract_function_simulator/index.d.ts +13 -2
  27. package/dest/contract_function_simulator/index.d.ts.map +1 -1
  28. package/dest/contract_function_simulator/index.js +10 -0
  29. package/dest/contract_function_simulator/noir-structs/bounded_vec.d.ts +48 -0
  30. package/dest/contract_function_simulator/noir-structs/bounded_vec.d.ts.map +1 -0
  31. package/dest/contract_function_simulator/noir-structs/bounded_vec.js +45 -0
  32. package/dest/contract_function_simulator/noir-structs/ephemeral_array.d.ts +37 -0
  33. package/dest/contract_function_simulator/noir-structs/ephemeral_array.d.ts.map +1 -0
  34. package/dest/contract_function_simulator/noir-structs/ephemeral_array.js +59 -0
  35. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +3 -2
  36. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts.map +1 -1
  37. package/dest/contract_function_simulator/noir-structs/event_validation_request.js +3 -2
  38. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts +12 -2
  39. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts.map +1 -1
  40. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.js +34 -3
  41. package/dest/contract_function_simulator/noir-structs/note_data.d.ts +27 -0
  42. package/dest/contract_function_simulator/noir-structs/note_data.d.ts.map +1 -0
  43. package/dest/contract_function_simulator/noir-structs/note_data.js +3 -0
  44. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +3 -2
  45. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
  46. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +3 -2
  47. package/dest/contract_function_simulator/noir-structs/option.d.ts +61 -0
  48. package/dest/contract_function_simulator/noir-structs/option.d.ts.map +1 -0
  49. package/dest/contract_function_simulator/noir-structs/option.js +62 -0
  50. package/dest/contract_function_simulator/noir-structs/provided_secret.d.ts +11 -0
  51. package/dest/contract_function_simulator/noir-structs/provided_secret.d.ts.map +1 -0
  52. package/dest/contract_function_simulator/noir-structs/provided_secret.js +24 -0
  53. package/dest/contract_function_simulator/oracle/interfaces.d.ts +16 -114
  54. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
  55. package/dest/contract_function_simulator/oracle/interfaces.js +2 -2
  56. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts +2 -2
  57. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts.map +1 -1
  58. package/dest/contract_function_simulator/oracle/note_packing_utils.js +2 -2
  59. package/dest/contract_function_simulator/oracle/oracle.d.ts +55 -57
  60. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
  61. package/dest/contract_function_simulator/oracle/oracle.js +343 -344
  62. package/dest/contract_function_simulator/oracle/oracle_registry.d.ts +127 -0
  63. package/dest/contract_function_simulator/oracle/oracle_registry.d.ts.map +1 -0
  64. package/dest/contract_function_simulator/oracle/oracle_registry.js +786 -0
  65. package/dest/contract_function_simulator/oracle/oracle_type_mappings.d.ts +139 -0
  66. package/dest/contract_function_simulator/oracle/oracle_type_mappings.d.ts.map +1 -0
  67. package/dest/contract_function_simulator/oracle/oracle_type_mappings.js +560 -0
  68. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +27 -29
  69. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
  70. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +55 -47
  71. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +59 -39
  72. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
  73. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +244 -149
  74. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts +1 -1
  75. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts.map +1 -1
  76. package/dest/contract_function_simulator/proxied_contract_data_source.js +35 -67
  77. package/dest/contract_sync/contract_sync_service.d.ts +4 -6
  78. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -1
  79. package/dest/contract_sync/contract_sync_service.js +43 -24
  80. package/dest/contract_sync/helpers.d.ts +2 -3
  81. package/dest/contract_sync/helpers.d.ts.map +1 -1
  82. package/dest/contract_sync/helpers.js +12 -19
  83. package/dest/debug/pxe_debug_utils.d.ts +1 -6
  84. package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
  85. package/dest/debug/pxe_debug_utils.js +0 -6
  86. package/dest/entrypoints/client/bundle/utils.d.ts +1 -1
  87. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  88. package/dest/entrypoints/client/bundle/utils.js +11 -3
  89. package/dest/entrypoints/client/lazy/utils.d.ts +1 -1
  90. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  91. package/dest/entrypoints/client/lazy/utils.js +11 -3
  92. package/dest/entrypoints/pxe_creation_options.d.ts +7 -1
  93. package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
  94. package/dest/entrypoints/server/index.d.ts +2 -1
  95. package/dest/entrypoints/server/index.d.ts.map +1 -1
  96. package/dest/entrypoints/server/index.js +1 -0
  97. package/dest/entrypoints/server/utils.d.ts +3 -2
  98. package/dest/entrypoints/server/utils.d.ts.map +1 -1
  99. package/dest/entrypoints/server/utils.js +11 -3
  100. package/dest/events/event_service.d.ts +13 -5
  101. package/dest/events/event_service.d.ts.map +1 -1
  102. package/dest/events/event_service.js +30 -9
  103. package/dest/hooks/authorize_utility_call.d.ts +41 -0
  104. package/dest/hooks/authorize_utility_call.d.ts.map +1 -0
  105. package/dest/hooks/authorize_utility_call.js +4 -0
  106. package/dest/hooks/execution_hooks.d.ts +42 -0
  107. package/dest/hooks/execution_hooks.d.ts.map +1 -0
  108. package/dest/hooks/execution_hooks.js +9 -0
  109. package/dest/hooks/index.d.ts +4 -0
  110. package/dest/hooks/index.d.ts.map +1 -0
  111. package/dest/hooks/index.js +1 -0
  112. package/dest/logs/log_service.d.ts +6 -5
  113. package/dest/logs/log_service.d.ts.map +1 -1
  114. package/dest/logs/log_service.js +112 -48
  115. package/dest/messages/message_context_service.d.ts +1 -1
  116. package/dest/messages/message_context_service.d.ts.map +1 -1
  117. package/dest/messages/message_context_service.js +28 -9
  118. package/dest/notes/note_service.d.ts +25 -3
  119. package/dest/notes/note_service.d.ts.map +1 -1
  120. package/dest/notes/note_service.js +80 -65
  121. package/dest/oracle_version.d.ts +3 -3
  122. package/dest/oracle_version.js +4 -4
  123. package/dest/private_kernel/batch_planner.d.ts +47 -0
  124. package/dest/private_kernel/batch_planner.d.ts.map +1 -0
  125. package/dest/private_kernel/batch_planner.js +104 -0
  126. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.js +1 -1
  127. package/dest/private_kernel/hints/test_utils.d.ts +1 -1
  128. package/dest/private_kernel/hints/test_utils.d.ts.map +1 -1
  129. package/dest/private_kernel/hints/test_utils.js +2 -3
  130. package/dest/private_kernel/private_kernel_execution_prover.d.ts +6 -2
  131. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
  132. package/dest/private_kernel/private_kernel_execution_prover.js +148 -52
  133. package/dest/private_kernel/private_kernel_oracle.d.ts +6 -6
  134. package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
  135. package/dest/private_kernel/private_kernel_oracle.js +12 -7
  136. package/dest/pxe.d.ts +54 -7
  137. package/dest/pxe.d.ts.map +1 -1
  138. package/dest/pxe.js +126 -84
  139. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.d.ts +42 -0
  140. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.d.ts.map +1 -0
  141. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.js +93 -0
  142. package/dest/storage/backwards_compatibility_tests/schema_tests.d.ts +15 -0
  143. package/dest/storage/backwards_compatibility_tests/schema_tests.d.ts.map +1 -0
  144. package/dest/storage/backwards_compatibility_tests/schema_tests.js +591 -0
  145. package/dest/storage/backwards_compatibility_tests/store_spy.d.ts +19 -0
  146. package/dest/storage/backwards_compatibility_tests/store_spy.d.ts.map +1 -0
  147. package/dest/storage/backwards_compatibility_tests/store_spy.js +63 -0
  148. package/dest/storage/contract_store/contract_store.d.ts +1 -1
  149. package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
  150. package/dest/storage/contract_store/contract_store.js +5 -24
  151. package/dest/storage/metadata.d.ts +1 -1
  152. package/dest/storage/metadata.js +1 -1
  153. package/dest/storage/open_pxe_stores.d.ts +33 -0
  154. package/dest/storage/open_pxe_stores.d.ts.map +1 -0
  155. package/dest/storage/open_pxe_stores.js +27 -0
  156. package/dest/storage/private_event_store/stored_private_event.js +1 -1
  157. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +6 -6
  158. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
  159. package/dest/storage/tagging_store/sender_tagging_store.d.ts +5 -5
  160. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
  161. package/dest/storage/tagging_store/sender_tagging_store.js +3 -3
  162. package/dest/tagging/get_all_logs_by_tags.d.ts +34 -10
  163. package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -1
  164. package/dest/tagging/get_all_logs_by_tags.js +36 -37
  165. package/dest/tagging/index.d.ts +5 -4
  166. package/dest/tagging/index.d.ts.map +1 -1
  167. package/dest/tagging/index.js +4 -3
  168. package/dest/tagging/persist_sender_tagging_index_ranges.d.ts +29 -0
  169. package/dest/tagging/persist_sender_tagging_index_ranges.d.ts.map +1 -0
  170. package/dest/tagging/persist_sender_tagging_index_ranges.js +42 -0
  171. package/dest/tagging/recipient_sync/sync_tagged_private_logs.d.ts +56 -0
  172. package/dest/tagging/recipient_sync/sync_tagged_private_logs.d.ts.map +1 -0
  173. package/dest/tagging/recipient_sync/sync_tagged_private_logs.js +163 -0
  174. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts +3 -3
  175. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts.map +1 -1
  176. package/dest/tagging/reconcile_tagging_index_ranges.d.ts +36 -0
  177. package/dest/tagging/reconcile_tagging_index_ranges.d.ts.map +1 -0
  178. package/dest/tagging/reconcile_tagging_index_ranges.js +74 -0
  179. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +4 -5
  180. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
  181. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +26 -14
  182. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +11 -6
  183. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -1
  184. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +21 -0
  185. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +4 -4
  186. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -1
  187. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +2 -2
  188. package/package.json +20 -17
  189. package/src/bin/check_oracle_version.ts +46 -119
  190. package/src/bin/index.ts +1 -0
  191. package/src/bin/oracle_version_helpers.ts +121 -0
  192. package/src/block_synchronizer/block_stream_source.ts +81 -0
  193. package/src/block_synchronizer/block_synchronizer.ts +22 -12
  194. package/src/config/index.ts +15 -9
  195. package/src/config/package_info.ts +1 -1
  196. package/src/contract_function_simulator/contract_function_simulator.ts +34 -11
  197. package/src/contract_function_simulator/execution_note_cache.ts +1 -1
  198. package/src/contract_function_simulator/execution_tagging_index_cache.ts +5 -9
  199. package/src/contract_function_simulator/index.ts +50 -1
  200. package/src/contract_function_simulator/noir-structs/bounded_vec.ts +55 -0
  201. package/src/contract_function_simulator/noir-structs/ephemeral_array.ts +66 -0
  202. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +3 -2
  203. package/src/contract_function_simulator/noir-structs/log_retrieval_request.ts +35 -2
  204. package/src/contract_function_simulator/noir-structs/note_data.ts +27 -0
  205. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +3 -2
  206. package/src/contract_function_simulator/noir-structs/option.ts +69 -0
  207. package/src/contract_function_simulator/noir-structs/provided_secret.ts +27 -0
  208. package/src/contract_function_simulator/oracle/interfaces.ts +12 -204
  209. package/src/contract_function_simulator/oracle/note_packing_utils.ts +3 -3
  210. package/src/contract_function_simulator/oracle/oracle.ts +406 -556
  211. package/src/contract_function_simulator/oracle/oracle_registry.ts +585 -0
  212. package/src/contract_function_simulator/oracle/oracle_type_mappings.ts +553 -0
  213. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +74 -67
  214. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +350 -304
  215. package/src/contract_function_simulator/proxied_contract_data_source.ts +40 -70
  216. package/src/contract_sync/contract_sync_service.ts +56 -43
  217. package/src/contract_sync/helpers.ts +11 -23
  218. package/src/debug/pxe_debug_utils.ts +0 -8
  219. package/src/entrypoints/client/bundle/utils.ts +8 -2
  220. package/src/entrypoints/client/lazy/utils.ts +8 -2
  221. package/src/entrypoints/pxe_creation_options.ts +7 -0
  222. package/src/entrypoints/server/index.ts +1 -0
  223. package/src/entrypoints/server/utils.ts +13 -3
  224. package/src/events/event_service.ts +54 -19
  225. package/src/hooks/authorize_utility_call.ts +44 -0
  226. package/src/hooks/execution_hooks.ts +48 -0
  227. package/src/hooks/index.ts +7 -0
  228. package/src/logs/log_service.ts +137 -92
  229. package/src/messages/message_context_service.ts +42 -24
  230. package/src/notes/note_service.ts +115 -91
  231. package/src/oracle_version.ts +4 -4
  232. package/src/private_kernel/batch_planner.ts +169 -0
  233. package/src/private_kernel/hints/private_kernel_reset_private_inputs_builder.ts +1 -1
  234. package/src/private_kernel/hints/test_utils.ts +2 -9
  235. package/src/private_kernel/private_kernel_execution_prover.ts +236 -73
  236. package/src/private_kernel/private_kernel_oracle.ts +21 -11
  237. package/src/pxe.ts +208 -85
  238. package/src/storage/backwards_compatibility_tests/__snapshots__/AddressStore.json +22 -0
  239. package/src/storage/backwards_compatibility_tests/__snapshots__/AnchorBlockStore.json +3 -0
  240. package/src/storage/backwards_compatibility_tests/__snapshots__/CapsuleStore.json +16 -0
  241. package/src/storage/backwards_compatibility_tests/__snapshots__/ContractStore.json +28 -0
  242. package/src/storage/backwards_compatibility_tests/__snapshots__/KeyStore.json +52 -0
  243. package/src/storage/backwards_compatibility_tests/__snapshots__/L2TipsKVStore.json +46 -0
  244. package/src/storage/backwards_compatibility_tests/__snapshots__/NoteStore.json +36 -0
  245. package/src/storage/backwards_compatibility_tests/__snapshots__/PrivateEventStore.json +44 -0
  246. package/src/storage/backwards_compatibility_tests/__snapshots__/RecipientTaggingStore.json +18 -0
  247. package/src/storage/backwards_compatibility_tests/__snapshots__/SenderAddressBookStore.json +16 -0
  248. package/src/storage/backwards_compatibility_tests/__snapshots__/SenderTaggingStore.json +22 -0
  249. package/src/storage/backwards_compatibility_tests/__snapshots__/opened_stores.json +97 -0
  250. package/src/storage/backwards_compatibility_tests/kv_store_snapshot.ts +122 -0
  251. package/src/storage/backwards_compatibility_tests/schema_tests.ts +712 -0
  252. package/src/storage/backwards_compatibility_tests/store_spy.ts +73 -0
  253. package/src/storage/contract_store/contract_store.ts +6 -29
  254. package/src/storage/metadata.ts +1 -1
  255. package/src/storage/open_pxe_stores.ts +49 -0
  256. package/src/storage/private_event_store/stored_private_event.ts +1 -1
  257. package/src/storage/tagging_store/recipient_tagging_store.ts +5 -9
  258. package/src/storage/tagging_store/sender_tagging_store.ts +6 -6
  259. package/src/tagging/get_all_logs_by_tags.ts +78 -50
  260. package/src/tagging/index.ts +4 -3
  261. package/src/tagging/persist_sender_tagging_index_ranges.ts +57 -0
  262. package/src/tagging/recipient_sync/sync_tagged_private_logs.ts +240 -0
  263. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +2 -2
  264. package/src/tagging/reconcile_tagging_index_ranges.ts +102 -0
  265. package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +41 -19
  266. package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +23 -8
  267. package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +4 -5
  268. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts +0 -9
  269. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts.map +0 -1
  270. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.js +0 -47
  271. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +0 -14
  272. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +0 -1
  273. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +0 -85
  274. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +0 -14
  275. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +0 -1
  276. package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +0 -33
  277. package/src/contract_function_simulator/oracle/legacy_oracle_mappings.ts +0 -104
  278. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +0 -130
  279. package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +0 -44
@@ -1,3 +1,5 @@
1
+ import { MAX_APPS_PER_KERNEL } from '@aztec/constants';
2
+ import { uniqueBy } from '@aztec/foundation/collection';
1
3
  import { vkAsFieldsMegaHonk } from '@aztec/foundation/crypto/keys';
2
4
  import { Fr } from '@aztec/foundation/curves/bn254';
3
5
  import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
@@ -16,23 +18,30 @@ import {
16
18
  PrivateKernelCircuitPublicInputs,
17
19
  PrivateKernelData,
18
20
  type PrivateKernelExecutionProofOutput,
21
+ PrivateKernelInit2CircuitPrivateInputs,
22
+ PrivateKernelInit3CircuitPrivateInputs,
19
23
  PrivateKernelInitCircuitPrivateInputs,
24
+ PrivateKernelInner2CircuitPrivateInputs,
25
+ PrivateKernelInner3CircuitPrivateInputs,
20
26
  PrivateKernelInnerCircuitPrivateInputs,
21
27
  type PrivateKernelSimulateOutput,
22
28
  PrivateKernelTailCircuitPrivateInputs,
23
29
  type PrivateKernelTailCircuitPublicInputs,
24
30
  PrivateVerificationKeyHints,
31
+ type UpdatedClassIdHints,
25
32
  } from '@aztec/stdlib/kernel';
26
33
  import { ChonkProof, ChonkProofWithPublicInputs } from '@aztec/stdlib/proofs';
27
34
  import {
28
35
  type PrivateCallExecutionResult,
29
36
  type PrivateExecutionResult,
30
37
  TxRequest,
38
+ collectNested,
31
39
  collectNoteHashNullifierCounterMap,
32
40
  getFinalMinRevertibleSideEffectCounter,
33
41
  } from '@aztec/stdlib/tx';
34
42
  import { VerificationKeyAsFields, VerificationKeyData, VkData } from '@aztec/stdlib/vks';
35
43
 
44
+ import { BatchPlanner } from './batch_planner.js';
36
45
  import { computeTxExpirationTimestamp } from './hints/compute_tx_expiration_timestamp.js';
37
46
  import { PrivateKernelResetPrivateInputsBuilder } from './hints/private_kernel_reset_private_inputs_builder.js';
38
47
  import type { PrivateKernelOracle } from './private_kernel_oracle.js';
@@ -64,6 +73,7 @@ export class PrivateKernelExecutionProver {
64
73
  private proofCreator: PrivateKernelProver,
65
74
  private fakeProofs = false,
66
75
  bindings?: LoggerBindings,
76
+ private maxBatchSize: number = MAX_APPS_PER_KERNEL,
67
77
  ) {
68
78
  this.log = createLogger('pxe:private-kernel-execution-prover', bindings);
69
79
  }
@@ -108,6 +118,13 @@ export class PrivateKernelExecutionProver {
108
118
  const minRevertibleSideEffectCounter = getFinalMinRevertibleSideEffectCounter(executionResult);
109
119
  const splitCounter = isPrivateOnlyTx ? 0 : minRevertibleSideEffectCounter;
110
120
 
121
+ // Each kernel iteration absorbs up to `maxBatchSize` apps. The planner walks the upcoming
122
+ // apps and decides where the next reset must fall by using an accumulator and
123
+ // reusing the existing single-app `needsReset()` check.
124
+ const planner = new BatchPlanner(noteHashNullifierCounterMap, splitCounter, this.maxBatchSize);
125
+
126
+ const updatedClassIdHintsMap = await this.prefetchUpdatedClassIdHints(executionResult);
127
+
111
128
  while (executionStack.length) {
112
129
  if (!firstIteration) {
113
130
  let resetBuilder = new PrivateKernelResetPrivateInputsBuilder(
@@ -141,80 +158,24 @@ export class PrivateKernelExecutionProver {
141
158
  }
142
159
  }
143
160
 
144
- const currentExecution = executionStack.pop()!;
145
-
146
- executionStack.push(...[...currentExecution.nestedExecutionResults].reverse());
147
-
148
- const functionName = await this.oracle.getDebugFunctionName(
149
- currentExecution.publicInputs.callContext.contractAddress,
150
- currentExecution.publicInputs.callContext.functionSelector,
151
- );
161
+ const batchSize = planner.decideBatchSize(output.publicInputs, executionStack);
162
+ const apps: PrivateCallData[] = [];
163
+ for (let i = 0; i < batchSize; i++) {
164
+ apps.push(await this.consumeNextApp(executionStack, executionSteps, updatedClassIdHintsMap));
165
+ }
152
166
 
153
- executionSteps.push({
154
- functionName: functionName!,
155
- bytecode: currentExecution.acir,
156
- witness: currentExecution.partialWitness,
157
- vk: currentExecution.vk,
158
- timings: {
159
- witgen: currentExecution.profileResult?.timings.witgen ?? 0,
160
- oracles: currentExecution.profileResult?.timings.oracles,
161
- },
167
+ output = await this.runBatchedKernel({
168
+ apps,
169
+ firstIteration,
170
+ previousOutput: output,
171
+ txRequest,
172
+ isPrivateOnlyTx,
173
+ firstNullifierHint: executionResult.firstNullifier,
174
+ minRevertibleSideEffectCounter,
175
+ executionSteps,
176
+ generateWitnesses,
162
177
  });
163
178
 
164
- const privateCallData = await this.createPrivateCallData(currentExecution);
165
-
166
- if (firstIteration) {
167
- const witgenTimer = new Timer();
168
-
169
- const proofInput = new PrivateKernelInitCircuitPrivateInputs(
170
- txRequest,
171
- getVKTreeRoot(),
172
- ProtocolContractsList,
173
- privateCallData,
174
- isPrivateOnlyTx,
175
- executionResult.firstNullifier,
176
- minRevertibleSideEffectCounter,
177
- );
178
- this.log.debug(
179
- `Calling private kernel init with isPrivateOnly ${isPrivateOnlyTx} and firstNullifierHint ${proofInput.firstNullifierHint}`,
180
- );
181
-
182
- pushTestData('private-kernel-inputs-init', proofInput);
183
-
184
- output = generateWitnesses
185
- ? await this.proofCreator.generateInitOutput(proofInput)
186
- : await this.proofCreator.simulateInit(proofInput);
187
-
188
- executionSteps.push({
189
- functionName: 'private_kernel_init',
190
- bytecode: output.bytecode,
191
- witness: output.outputWitness,
192
- vk: output.verificationKey.keyAsBytes,
193
- timings: {
194
- witgen: witgenTimer.ms(),
195
- },
196
- });
197
- } else {
198
- const witgenTimer = new Timer();
199
- const vkData = await this.getVkData(output.verificationKey);
200
- const previousKernelData = new PrivateKernelData(output.publicInputs, vkData);
201
- const proofInput = new PrivateKernelInnerCircuitPrivateInputs(previousKernelData, privateCallData);
202
-
203
- pushTestData('private-kernel-inputs-inner', proofInput);
204
- output = generateWitnesses
205
- ? await this.proofCreator.generateInnerOutput(proofInput)
206
- : await this.proofCreator.simulateInner(proofInput);
207
-
208
- executionSteps.push({
209
- functionName: 'private_kernel_inner',
210
- bytecode: output.bytecode,
211
- witness: output.outputWitness,
212
- vk: output.verificationKey.keyAsBytes,
213
- timings: {
214
- witgen: witgenTimer.ms(),
215
- },
216
- });
217
- }
218
179
  firstIteration = false;
219
180
  }
220
181
 
@@ -401,7 +362,60 @@ export class PrivateKernelExecutionProver {
401
362
  );
402
363
  }
403
364
 
404
- private async createPrivateCallData({ publicInputs, vk: vkAsBuffer }: PrivateCallExecutionResult) {
365
+ /**
366
+ * Pops the next app off the execution stack, pushes its nested calls back on (preserving DFS
367
+ * order), records the app's execution step, and returns its constructed `PrivateCallData`.
368
+ * Caller is responsible for ensuring the stack is non-empty.
369
+ */
370
+ private async consumeNextApp(
371
+ executionStack: PrivateCallExecutionResult[],
372
+ executionSteps: PrivateExecutionStep[],
373
+ updatedClassIdHintsMap: Map<string, UpdatedClassIdHints>,
374
+ ): Promise<PrivateCallData> {
375
+ const next = executionStack.pop()!;
376
+ executionStack.push(...[...next.nestedExecutionResults].reverse());
377
+
378
+ const functionName = await this.oracle.getDebugFunctionName(
379
+ next.publicInputs.callContext.contractAddress,
380
+ next.publicInputs.callContext.functionSelector,
381
+ );
382
+
383
+ executionSteps.push({
384
+ functionName: functionName!,
385
+ bytecode: next.acir,
386
+ witness: next.partialWitness,
387
+ vk: next.vk,
388
+ timings: {
389
+ witgen: next.profileResult?.timings.witgen ?? 0,
390
+ oracles: next.profileResult?.timings.oracles,
391
+ },
392
+ });
393
+
394
+ return await this.createPrivateCallData(next, updatedClassIdHintsMap);
395
+ }
396
+
397
+ /** Prefetches updated class id hints for all unique contracts in the execution tree in parallel. */
398
+ private async prefetchUpdatedClassIdHints(
399
+ executionResult: PrivateExecutionResult,
400
+ ): Promise<Map<string, UpdatedClassIdHints>> {
401
+ const allAddresses = collectNested([executionResult.entrypoint], exec => [
402
+ exec.publicInputs.callContext.contractAddress,
403
+ ]);
404
+ const uniqueAddresses = uniqueBy(allAddresses, a => a.toString());
405
+ return new Map<string, UpdatedClassIdHints>(
406
+ await Promise.all(
407
+ uniqueAddresses.map(
408
+ async addr =>
409
+ [addr.toString(), await this.oracle.getUpdatedClassIdHints(addr)] as [string, UpdatedClassIdHints],
410
+ ),
411
+ ),
412
+ );
413
+ }
414
+
415
+ private async createPrivateCallData(
416
+ { publicInputs, vk: vkAsBuffer }: PrivateCallExecutionResult,
417
+ updatedClassIdHintsMap: Map<string, UpdatedClassIdHints>,
418
+ ) {
405
419
  const { contractAddress, functionSelector } = publicInputs.callContext;
406
420
 
407
421
  const vkAsFields = await vkAsFieldsMegaHonk(vkAsBuffer);
@@ -417,7 +431,7 @@ export class PrivateKernelExecutionProver {
417
431
  const { artifactHash: contractClassArtifactHash, publicBytecodeCommitment: contractClassPublicBytecodeCommitment } =
418
432
  await this.oracle.getContractClassIdPreimage(currentContractClassId);
419
433
 
420
- const updatedClassIdHints = await this.oracle.getUpdatedClassIdHints(contractAddress);
434
+ const updatedClassIdHints = updatedClassIdHintsMap.get(contractAddress.toString())!;
421
435
 
422
436
  return PrivateCallData.from({
423
437
  publicInputs,
@@ -432,4 +446,153 @@ export class PrivateKernelExecutionProver {
432
446
  }),
433
447
  });
434
448
  }
449
+
450
+ /**
451
+ * Runs one batched kernel iteration. Picks the right circuit variant based on whether this is
452
+ * the first iteration or a later one and the size of the batch.
453
+ */
454
+ private async runBatchedKernel(args: {
455
+ apps: PrivateCallData[];
456
+ firstIteration: boolean;
457
+ previousOutput: PrivateKernelSimulateOutput<PrivateKernelCircuitPublicInputs>;
458
+ txRequest: TxRequest;
459
+ isPrivateOnlyTx: boolean;
460
+ firstNullifierHint: Fr;
461
+ minRevertibleSideEffectCounter: number;
462
+ executionSteps: PrivateExecutionStep[];
463
+ generateWitnesses: boolean;
464
+ }): Promise<PrivateKernelSimulateOutput<PrivateKernelCircuitPublicInputs>> {
465
+ const {
466
+ apps,
467
+ firstIteration,
468
+ previousOutput,
469
+ txRequest,
470
+ isPrivateOnlyTx,
471
+ firstNullifierHint,
472
+ minRevertibleSideEffectCounter,
473
+ executionSteps,
474
+ generateWitnesses,
475
+ } = args;
476
+
477
+ const witgenTimer = new Timer();
478
+ let output: PrivateKernelSimulateOutput<PrivateKernelCircuitPublicInputs>;
479
+ let functionName: string;
480
+
481
+ if (firstIteration) {
482
+ const vkTreeRoot = getVKTreeRoot();
483
+ switch (apps.length) {
484
+ case 1: {
485
+ const proofInput = new PrivateKernelInitCircuitPrivateInputs(
486
+ txRequest,
487
+ vkTreeRoot,
488
+ ProtocolContractsList,
489
+ apps[0],
490
+ isPrivateOnlyTx,
491
+ firstNullifierHint,
492
+ minRevertibleSideEffectCounter,
493
+ );
494
+ this.log.debug(
495
+ `Calling private kernel init with isPrivateOnly ${isPrivateOnlyTx} and firstNullifierHint ${proofInput.firstNullifierHint}`,
496
+ );
497
+ pushTestData('private-kernel-inputs-init', proofInput);
498
+ output = generateWitnesses
499
+ ? await this.proofCreator.generateInitOutput(proofInput)
500
+ : await this.proofCreator.simulateInit(proofInput);
501
+ functionName = 'private_kernel_init';
502
+ break;
503
+ }
504
+ case 2: {
505
+ const proofInput = new PrivateKernelInit2CircuitPrivateInputs(
506
+ txRequest,
507
+ vkTreeRoot,
508
+ ProtocolContractsList,
509
+ apps[0],
510
+ apps[1],
511
+ isPrivateOnlyTx,
512
+ firstNullifierHint,
513
+ minRevertibleSideEffectCounter,
514
+ );
515
+ this.log.debug(
516
+ `Calling private kernel init_2 with isPrivateOnly ${isPrivateOnlyTx} and firstNullifierHint ${proofInput.firstNullifierHint}`,
517
+ );
518
+ pushTestData('private-kernel-inputs-init-2', proofInput);
519
+ output = generateWitnesses
520
+ ? await this.proofCreator.generateInit2Output(proofInput)
521
+ : await this.proofCreator.simulateInit2(proofInput);
522
+ functionName = 'private_kernel_init_2';
523
+ break;
524
+ }
525
+ case 3: {
526
+ const proofInput = new PrivateKernelInit3CircuitPrivateInputs(
527
+ txRequest,
528
+ vkTreeRoot,
529
+ ProtocolContractsList,
530
+ apps[0],
531
+ apps[1],
532
+ apps[2],
533
+ isPrivateOnlyTx,
534
+ firstNullifierHint,
535
+ minRevertibleSideEffectCounter,
536
+ );
537
+ this.log.debug(
538
+ `Calling private kernel init_3 with isPrivateOnly ${isPrivateOnlyTx} and firstNullifierHint ${proofInput.firstNullifierHint}`,
539
+ );
540
+ pushTestData('private-kernel-inputs-init-3', proofInput);
541
+ output = generateWitnesses
542
+ ? await this.proofCreator.generateInit3Output(proofInput)
543
+ : await this.proofCreator.simulateInit3(proofInput);
544
+ functionName = 'private_kernel_init_3';
545
+ break;
546
+ }
547
+ default:
548
+ throw new Error(`Unsupported init kernel batch size: ${apps.length}`);
549
+ }
550
+ } else {
551
+ const vkData = await this.getVkData(previousOutput.verificationKey);
552
+ const previousKernelData = new PrivateKernelData(previousOutput.publicInputs, vkData);
553
+ switch (apps.length) {
554
+ case 1: {
555
+ const proofInput = new PrivateKernelInnerCircuitPrivateInputs(previousKernelData, apps[0]);
556
+ pushTestData('private-kernel-inputs-inner', proofInput);
557
+ output = generateWitnesses
558
+ ? await this.proofCreator.generateInnerOutput(proofInput)
559
+ : await this.proofCreator.simulateInner(proofInput);
560
+ functionName = 'private_kernel_inner';
561
+ break;
562
+ }
563
+ case 2: {
564
+ const proofInput = new PrivateKernelInner2CircuitPrivateInputs(previousKernelData, apps[0], apps[1]);
565
+ pushTestData('private-kernel-inputs-inner-2', proofInput);
566
+ output = generateWitnesses
567
+ ? await this.proofCreator.generateInner2Output(proofInput)
568
+ : await this.proofCreator.simulateInner2(proofInput);
569
+ functionName = 'private_kernel_inner_2';
570
+ break;
571
+ }
572
+ case 3: {
573
+ const proofInput = new PrivateKernelInner3CircuitPrivateInputs(previousKernelData, apps[0], apps[1], apps[2]);
574
+ pushTestData('private-kernel-inputs-inner-3', proofInput);
575
+ output = generateWitnesses
576
+ ? await this.proofCreator.generateInner3Output(proofInput)
577
+ : await this.proofCreator.simulateInner3(proofInput);
578
+ functionName = 'private_kernel_inner_3';
579
+ break;
580
+ }
581
+ default:
582
+ throw new Error(`Unsupported inner kernel batch size: ${apps.length}`);
583
+ }
584
+ }
585
+
586
+ executionSteps.push({
587
+ functionName,
588
+ bytecode: output.bytecode,
589
+ witness: output.outputWitness,
590
+ vk: output.verificationKey.keyAsBytes,
591
+ timings: {
592
+ witgen: witgenTimer.ms(),
593
+ },
594
+ });
595
+
596
+ return output;
597
+ }
435
598
  }
@@ -1,6 +1,12 @@
1
- import { FUNCTION_TREE_HEIGHT, NOTE_HASH_TREE_HEIGHT, PUBLIC_DATA_TREE_HEIGHT, VK_TREE_HEIGHT } from '@aztec/constants';
1
+ import {
2
+ FUNCTION_TREE_HEIGHT,
3
+ NOTE_HASH_TREE_HEIGHT,
4
+ PUBLIC_DATA_TREE_HEIGHT,
5
+ UPDATES_VALUE_SIZE,
6
+ VK_TREE_HEIGHT,
7
+ } from '@aztec/constants';
2
8
  import type { Fr } from '@aztec/foundation/curves/bn254';
3
- import type { GrumpkinScalar, Point } from '@aztec/foundation/curves/grumpkin';
9
+ import type { GrumpkinScalar } from '@aztec/foundation/curves/grumpkin';
4
10
  import { MembershipWitness } from '@aztec/foundation/trees';
5
11
  import type { KeyStore } from '@aztec/key-store';
6
12
  import { getVKIndex, getVKSiblingPath } from '@aztec/noir-protocol-circuits-types/vk-tree';
@@ -97,14 +103,14 @@ export class PrivateKernelOracle {
97
103
  }
98
104
 
99
105
  /**
100
- * Retrieves the sk_m corresponding to the pk_m.
101
- * @throws If the provided public key is not associated with any of the registered accounts.
102
- * @param masterPublicKey - The master public key to get secret key for.
106
+ * Retrieves the sk_m corresponding to the pk_m hash.
107
+ * @throws If the provided hash is not associated with any of the registered accounts.
108
+ * @param masterPublicKeyHash - The master public key hash to get secret key for.
103
109
  * @returns A Promise that resolves to sk_m.
104
110
  * @dev Used when feeding the sk_m to the kernel circuit for keys verification.
105
111
  */
106
- public getMasterSecretKey(masterPublicKey: Point): Promise<GrumpkinScalar> {
107
- return this.keyStore.getMasterSecretKey(masterPublicKey);
112
+ public getMasterSecretKey(masterPublicKeyHash: Fr): Promise<GrumpkinScalar> {
113
+ return this.keyStore.getMasterSecretKey(masterPublicKeyHash);
108
114
  }
109
115
 
110
116
  /** Use debug data to get the function name corresponding to a selector. */
@@ -132,12 +138,16 @@ export class PrivateKernelOracle {
132
138
  throw new Error(`No public data tree witness found for ${hashLeafSlot}`);
133
139
  }
134
140
 
141
+ // In an indexed merkle tree, getPublicDataWitness returns a leaf whose slot matches our query
142
+ // only if the slot has been written to. Otherwise, it returns the "low leaf" predecessor, whose
143
+ // slot will differ. Most contracts are never updated, so we can skip the readFromTree call
144
+ // (which triggers multiple RPC calls) and return empty values directly.
135
145
  const readStorage = (storageSlot: Fr) =>
136
146
  this.node.getPublicStorageAt(blockHash, ProtocolContractAddress.ContractInstanceRegistry, storageSlot);
137
- const delayedPublicMutableValues = await DelayedPublicMutableValues.readFromTree(
138
- delayedPublicMutableSlot,
139
- readStorage,
140
- );
147
+ const slotExists = updatedClassIdWitness.leafPreimage.leaf.slot.equals(hashLeafSlot);
148
+ const delayedPublicMutableValues = slotExists
149
+ ? await DelayedPublicMutableValues.readFromTree(delayedPublicMutableSlot, readStorage)
150
+ : DelayedPublicMutableValues.empty(UPDATES_VALUE_SIZE);
141
151
 
142
152
  return new UpdatedClassIdHints(
143
153
  new MembershipWitness(