@aztec/pxe 0.0.1-commit.96bb3f7 → 0.0.1-commit.993d240

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 (379) hide show
  1. package/dest/bin/check_oracle_version.d.ts +12 -2
  2. package/dest/bin/check_oracle_version.d.ts.map +1 -1
  3. package/dest/bin/check_oracle_version.js +32 -26
  4. package/dest/bin/index.d.ts +2 -0
  5. package/dest/bin/index.d.ts.map +1 -0
  6. package/dest/bin/index.js +1 -0
  7. package/dest/block_synchronizer/block_stream_source.d.ts +10 -0
  8. package/dest/block_synchronizer/block_stream_source.d.ts.map +1 -0
  9. package/dest/block_synchronizer/block_stream_source.js +62 -0
  10. package/dest/block_synchronizer/block_synchronizer.d.ts +16 -6
  11. package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
  12. package/dest/block_synchronizer/block_synchronizer.js +94 -23
  13. package/dest/config/index.d.ts +10 -2
  14. package/dest/config/index.d.ts.map +1 -1
  15. package/dest/config/index.js +17 -2
  16. package/dest/config/package_info.js +1 -1
  17. package/dest/contract_function_simulator/benchmarked_node.d.ts +9 -0
  18. package/dest/contract_function_simulator/benchmarked_node.d.ts.map +1 -0
  19. package/dest/contract_function_simulator/benchmarked_node.js +77 -0
  20. package/dest/contract_function_simulator/contract_function_simulator.d.ts +69 -36
  21. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
  22. package/dest/contract_function_simulator/contract_function_simulator.js +240 -91
  23. package/dest/contract_function_simulator/ephemeral_array_service.d.ts +28 -0
  24. package/dest/contract_function_simulator/ephemeral_array_service.d.ts.map +1 -0
  25. package/dest/contract_function_simulator/ephemeral_array_service.js +78 -0
  26. package/dest/contract_function_simulator/execution_note_cache.d.ts +18 -9
  27. package/dest/contract_function_simulator/execution_note_cache.d.ts.map +1 -1
  28. package/dest/contract_function_simulator/execution_note_cache.js +45 -28
  29. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +7 -11
  30. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -1
  31. package/dest/contract_function_simulator/execution_tagging_index_cache.js +19 -15
  32. package/dest/contract_function_simulator/index.d.ts +5 -2
  33. package/dest/contract_function_simulator/index.d.ts.map +1 -1
  34. package/dest/contract_function_simulator/index.js +4 -1
  35. package/dest/contract_function_simulator/noir-structs/bounded_vec.d.ts +48 -0
  36. package/dest/contract_function_simulator/noir-structs/bounded_vec.d.ts.map +1 -0
  37. package/dest/contract_function_simulator/noir-structs/bounded_vec.js +45 -0
  38. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +5 -7
  39. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts.map +1 -1
  40. package/dest/contract_function_simulator/noir-structs/event_validation_request.js +9 -10
  41. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts +13 -3
  42. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts.map +1 -1
  43. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.js +35 -4
  44. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts +2 -2
  45. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts.map +1 -1
  46. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.js +2 -4
  47. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +5 -8
  48. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
  49. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +7 -11
  50. package/dest/contract_function_simulator/noir-structs/option.d.ts +61 -0
  51. package/dest/contract_function_simulator/noir-structs/option.d.ts.map +1 -0
  52. package/dest/contract_function_simulator/noir-structs/option.js +62 -0
  53. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts +4 -10
  54. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts.map +1 -1
  55. package/dest/contract_function_simulator/noir-structs/utility_context.js +7 -18
  56. package/dest/contract_function_simulator/oracle/interfaces.d.ts +70 -50
  57. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
  58. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts +3 -1
  59. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts.map +1 -1
  60. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts +7 -7
  61. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts.map +1 -1
  62. package/dest/contract_function_simulator/oracle/note_packing_utils.js +10 -10
  63. package/dest/contract_function_simulator/oracle/oracle.d.ts +74 -43
  64. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
  65. package/dest/contract_function_simulator/oracle/oracle.js +471 -264
  66. package/dest/contract_function_simulator/oracle/oracle_registry.d.ts +147 -0
  67. package/dest/contract_function_simulator/oracle/oracle_registry.d.ts.map +1 -0
  68. package/dest/contract_function_simulator/oracle/oracle_registry.js +1199 -0
  69. package/dest/contract_function_simulator/oracle/private_execution.d.ts +2 -26
  70. package/dest/contract_function_simulator/oracle/private_execution.d.ts.map +1 -1
  71. package/dest/contract_function_simulator/oracle/private_execution.js +5 -38
  72. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +74 -91
  73. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
  74. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +164 -110
  75. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +156 -78
  76. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
  77. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +459 -186
  78. package/dest/contract_function_simulator/pick_notes.d.ts +1 -1
  79. package/dest/contract_function_simulator/pick_notes.d.ts.map +1 -1
  80. package/dest/contract_function_simulator/pick_notes.js +20 -3
  81. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts +1 -1
  82. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts.map +1 -1
  83. package/dest/contract_function_simulator/proxied_contract_data_source.js +35 -64
  84. package/dest/contract_logging.d.ts +27 -0
  85. package/dest/contract_logging.d.ts.map +1 -0
  86. package/dest/contract_logging.js +38 -0
  87. package/dest/contract_sync/contract_sync_service.d.ts +42 -0
  88. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -0
  89. package/dest/contract_sync/contract_sync_service.js +135 -0
  90. package/dest/contract_sync/helpers.d.ts +27 -0
  91. package/dest/contract_sync/helpers.d.ts.map +1 -0
  92. package/dest/contract_sync/helpers.js +53 -0
  93. package/dest/debug/pxe_debug_utils.d.ts +19 -10
  94. package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
  95. package/dest/debug/pxe_debug_utils.js +22 -17
  96. package/dest/entrypoints/client/bundle/index.d.ts +3 -1
  97. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  98. package/dest/entrypoints/client/bundle/index.js +2 -0
  99. package/dest/entrypoints/client/bundle/utils.d.ts +2 -2
  100. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  101. package/dest/entrypoints/client/bundle/utils.js +33 -11
  102. package/dest/entrypoints/client/lazy/index.d.ts +3 -1
  103. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  104. package/dest/entrypoints/client/lazy/index.js +2 -0
  105. package/dest/entrypoints/client/lazy/utils.d.ts +3 -3
  106. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  107. package/dest/entrypoints/client/lazy/utils.js +34 -12
  108. package/dest/entrypoints/pxe_creation_options.d.ts +11 -2
  109. package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
  110. package/dest/entrypoints/pxe_creation_options.js +3 -1
  111. package/dest/entrypoints/server/index.d.ts +6 -2
  112. package/dest/entrypoints/server/index.d.ts.map +1 -1
  113. package/dest/entrypoints/server/index.js +5 -1
  114. package/dest/entrypoints/server/utils.d.ts +4 -3
  115. package/dest/entrypoints/server/utils.d.ts.map +1 -1
  116. package/dest/entrypoints/server/utils.js +40 -13
  117. package/dest/events/event_service.d.ts +17 -8
  118. package/dest/events/event_service.d.ts.map +1 -1
  119. package/dest/events/event_service.js +58 -28
  120. package/dest/events/private_event_filter_validator.d.ts +6 -5
  121. package/dest/events/private_event_filter_validator.d.ts.map +1 -1
  122. package/dest/events/private_event_filter_validator.js +20 -6
  123. package/dest/hooks/authorize_utility_call.d.ts +41 -0
  124. package/dest/hooks/authorize_utility_call.d.ts.map +1 -0
  125. package/dest/hooks/authorize_utility_call.js +4 -0
  126. package/dest/hooks/execution_hooks.d.ts +42 -0
  127. package/dest/hooks/execution_hooks.d.ts.map +1 -0
  128. package/dest/hooks/execution_hooks.js +9 -0
  129. package/dest/hooks/index.d.ts +4 -0
  130. package/dest/hooks/index.d.ts.map +1 -0
  131. package/dest/hooks/index.js +1 -0
  132. package/dest/job_coordinator/job_coordinator.d.ts +3 -2
  133. package/dest/job_coordinator/job_coordinator.d.ts.map +1 -1
  134. package/dest/job_coordinator/job_coordinator.js +3 -2
  135. package/dest/logs/log_service.d.ts +13 -10
  136. package/dest/logs/log_service.d.ts.map +1 -1
  137. package/dest/logs/log_service.js +132 -84
  138. package/dest/messages/message_context_service.d.ts +17 -0
  139. package/dest/messages/message_context_service.d.ts.map +1 -0
  140. package/dest/messages/message_context_service.js +38 -0
  141. package/dest/notes/note_service.d.ts +31 -9
  142. package/dest/notes/note_service.d.ts.map +1 -1
  143. package/dest/notes/note_service.js +97 -77
  144. package/dest/notes_filter.d.ts +24 -0
  145. package/dest/notes_filter.d.ts.map +1 -0
  146. package/dest/notes_filter.js +4 -0
  147. package/dest/oracle_version.d.ts +4 -3
  148. package/dest/oracle_version.d.ts.map +1 -1
  149. package/dest/oracle_version.js +20 -9
  150. package/dest/private_kernel/batch_planner.d.ts +47 -0
  151. package/dest/private_kernel/batch_planner.d.ts.map +1 -0
  152. package/dest/private_kernel/batch_planner.js +104 -0
  153. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
  154. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
  155. package/dest/private_kernel/hints/{compute_tx_include_by_timestamp.js → compute_tx_expiration_timestamp.js} +12 -12
  156. package/dest/private_kernel/hints/index.d.ts +3 -3
  157. package/dest/private_kernel/hints/index.d.ts.map +1 -1
  158. package/dest/private_kernel/hints/index.js +2 -2
  159. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +29 -0
  160. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -0
  161. package/dest/private_kernel/hints/{build_private_kernel_reset_private_inputs.js → private_kernel_reset_private_inputs_builder.js} +141 -74
  162. package/dest/private_kernel/hints/test_utils.d.ts +122 -0
  163. package/dest/private_kernel/hints/test_utils.d.ts.map +1 -0
  164. package/dest/private_kernel/hints/test_utils.js +202 -0
  165. package/dest/private_kernel/private_kernel_execution_prover.d.ts +7 -2
  166. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
  167. package/dest/private_kernel/private_kernel_execution_prover.js +168 -67
  168. package/dest/private_kernel/private_kernel_oracle.d.ts +28 -29
  169. package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
  170. package/dest/private_kernel/private_kernel_oracle.js +96 -2
  171. package/dest/pxe.d.ts +126 -59
  172. package/dest/pxe.d.ts.map +1 -1
  173. package/dest/pxe.js +257 -200
  174. package/dest/storage/address_store/address_store.d.ts +1 -1
  175. package/dest/storage/address_store/address_store.d.ts.map +1 -1
  176. package/dest/storage/address_store/address_store.js +12 -11
  177. package/dest/storage/anchor_block_store/anchor_block_store.d.ts +9 -1
  178. package/dest/storage/anchor_block_store/anchor_block_store.d.ts.map +1 -1
  179. package/dest/storage/anchor_block_store/anchor_block_store.js +9 -2
  180. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.d.ts +42 -0
  181. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.d.ts.map +1 -0
  182. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.js +93 -0
  183. package/dest/storage/backwards_compatibility_tests/schema_tests.d.ts +15 -0
  184. package/dest/storage/backwards_compatibility_tests/schema_tests.d.ts.map +1 -0
  185. package/dest/storage/backwards_compatibility_tests/schema_tests.js +591 -0
  186. package/dest/storage/backwards_compatibility_tests/store_spy.d.ts +19 -0
  187. package/dest/storage/backwards_compatibility_tests/store_spy.d.ts.map +1 -0
  188. package/dest/storage/backwards_compatibility_tests/store_spy.js +63 -0
  189. package/dest/storage/capsule_store/capsule_service.d.ts +21 -0
  190. package/dest/storage/capsule_store/capsule_service.d.ts.map +1 -0
  191. package/dest/storage/capsule_store/capsule_service.js +50 -0
  192. package/dest/storage/capsule_store/capsule_store.d.ts +25 -10
  193. package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -1
  194. package/dest/storage/capsule_store/capsule_store.js +143 -28
  195. package/dest/storage/capsule_store/index.d.ts +2 -1
  196. package/dest/storage/capsule_store/index.d.ts.map +1 -1
  197. package/dest/storage/capsule_store/index.js +1 -0
  198. package/dest/storage/contract_store/contract_store.d.ts +42 -16
  199. package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
  200. package/dest/storage/contract_store/contract_store.js +158 -102
  201. package/dest/storage/metadata.d.ts +1 -1
  202. package/dest/storage/metadata.js +1 -1
  203. package/dest/storage/note_store/note_store.d.ts +50 -51
  204. package/dest/storage/note_store/note_store.d.ts.map +1 -1
  205. package/dest/storage/note_store/note_store.js +284 -263
  206. package/dest/storage/note_store/stored_note.d.ts +16 -0
  207. package/dest/storage/note_store/stored_note.d.ts.map +1 -0
  208. package/dest/storage/note_store/stored_note.js +43 -0
  209. package/dest/storage/open_pxe_stores.d.ts +33 -0
  210. package/dest/storage/open_pxe_stores.d.ts.map +1 -0
  211. package/dest/storage/open_pxe_stores.js +27 -0
  212. package/dest/storage/private_event_store/private_event_store.d.ts +43 -8
  213. package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -1
  214. package/dest/storage/private_event_store/private_event_store.js +229 -111
  215. package/dest/storage/private_event_store/stored_private_event.d.ts +23 -0
  216. package/dest/storage/private_event_store/stored_private_event.d.ts.map +1 -0
  217. package/dest/storage/private_event_store/stored_private_event.js +56 -0
  218. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +16 -9
  219. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
  220. package/dest/storage/tagging_store/recipient_tagging_store.js +88 -19
  221. package/dest/storage/tagging_store/sender_address_book_store.d.ts +1 -1
  222. package/dest/storage/tagging_store/sender_address_book_store.d.ts.map +1 -1
  223. package/dest/storage/tagging_store/sender_address_book_store.js +20 -14
  224. package/dest/storage/tagging_store/sender_tagging_store.d.ts +43 -32
  225. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
  226. package/dest/storage/tagging_store/sender_tagging_store.js +300 -122
  227. package/dest/tagging/get_all_logs_by_tags.d.ts +48 -0
  228. package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -0
  229. package/dest/tagging/get_all_logs_by_tags.js +59 -0
  230. package/dest/tagging/index.d.ts +7 -5
  231. package/dest/tagging/index.d.ts.map +1 -1
  232. package/dest/tagging/index.js +5 -3
  233. package/dest/tagging/persist_sender_tagging_index_ranges.d.ts +29 -0
  234. package/dest/tagging/persist_sender_tagging_index_ranges.d.ts.map +1 -0
  235. package/dest/tagging/persist_sender_tagging_index_ranges.js +42 -0
  236. package/dest/tagging/recipient_sync/sync_tagged_private_logs.d.ts +56 -0
  237. package/dest/tagging/recipient_sync/sync_tagged_private_logs.d.ts.map +1 -0
  238. package/dest/tagging/recipient_sync/sync_tagged_private_logs.js +163 -0
  239. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts +3 -3
  240. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts.map +1 -1
  241. package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +2 -2
  242. package/dest/tagging/reconcile_tagging_index_ranges.d.ts +36 -0
  243. package/dest/tagging/reconcile_tagging_index_ranges.d.ts.map +1 -0
  244. package/dest/tagging/reconcile_tagging_index_ranges.js +74 -0
  245. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +5 -9
  246. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
  247. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +34 -18
  248. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +13 -7
  249. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -1
  250. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +44 -16
  251. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +8 -7
  252. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -1
  253. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +44 -27
  254. package/package.json +31 -19
  255. package/src/bin/check_oracle_version.ts +42 -31
  256. package/src/bin/index.ts +1 -0
  257. package/src/block_synchronizer/block_stream_source.ts +81 -0
  258. package/src/block_synchronizer/block_synchronizer.ts +116 -36
  259. package/src/config/index.ts +21 -1
  260. package/src/config/package_info.ts +1 -1
  261. package/src/contract_function_simulator/benchmarked_node.ts +103 -0
  262. package/src/contract_function_simulator/contract_function_simulator.ts +417 -156
  263. package/src/contract_function_simulator/ephemeral_array_service.ts +110 -0
  264. package/src/contract_function_simulator/execution_note_cache.ts +44 -25
  265. package/src/contract_function_simulator/execution_tagging_index_cache.ts +19 -18
  266. package/src/contract_function_simulator/index.ts +4 -1
  267. package/src/contract_function_simulator/noir-structs/bounded_vec.ts +55 -0
  268. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +11 -10
  269. package/src/contract_function_simulator/noir-structs/log_retrieval_request.ts +36 -3
  270. package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +2 -5
  271. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +6 -11
  272. package/src/contract_function_simulator/noir-structs/option.ts +69 -0
  273. package/src/contract_function_simulator/noir-structs/utility_context.ts +6 -25
  274. package/src/contract_function_simulator/oracle/interfaces.ts +93 -70
  275. package/src/contract_function_simulator/oracle/note_packing_utils.ts +13 -13
  276. package/src/contract_function_simulator/oracle/oracle.ts +567 -461
  277. package/src/contract_function_simulator/oracle/oracle_registry.ts +904 -0
  278. package/src/contract_function_simulator/oracle/private_execution.ts +5 -71
  279. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +213 -209
  280. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +657 -254
  281. package/src/contract_function_simulator/pick_notes.ts +22 -3
  282. package/src/contract_function_simulator/proxied_contract_data_source.ts +41 -64
  283. package/src/contract_logging.ts +52 -0
  284. package/src/contract_sync/contract_sync_service.ts +189 -0
  285. package/src/contract_sync/helpers.ts +86 -0
  286. package/src/debug/pxe_debug_utils.ts +55 -18
  287. package/src/entrypoints/client/bundle/index.ts +2 -0
  288. package/src/entrypoints/client/bundle/utils.ts +26 -20
  289. package/src/entrypoints/client/lazy/index.ts +2 -0
  290. package/src/entrypoints/client/lazy/utils.ts +28 -21
  291. package/src/entrypoints/pxe_creation_options.ts +16 -1
  292. package/src/entrypoints/server/index.ts +5 -1
  293. package/src/entrypoints/server/utils.ts +37 -32
  294. package/src/events/event_service.ts +79 -39
  295. package/src/events/private_event_filter_validator.ts +23 -5
  296. package/src/hooks/authorize_utility_call.ts +44 -0
  297. package/src/hooks/execution_hooks.ts +48 -0
  298. package/src/hooks/index.ts +7 -0
  299. package/src/job_coordinator/job_coordinator.ts +4 -3
  300. package/src/logs/log_service.ts +171 -141
  301. package/src/messages/message_context_service.ts +45 -0
  302. package/src/notes/note_service.ts +137 -107
  303. package/src/notes_filter.ts +24 -0
  304. package/src/oracle_version.ts +20 -9
  305. package/src/private_kernel/batch_planner.ts +169 -0
  306. package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
  307. package/src/private_kernel/hints/index.ts +2 -2
  308. package/src/private_kernel/hints/{build_private_kernel_reset_private_inputs.ts → private_kernel_reset_private_inputs_builder.ts} +196 -137
  309. package/src/private_kernel/hints/test_utils.ts +318 -0
  310. package/src/private_kernel/private_kernel_execution_prover.ts +261 -93
  311. package/src/private_kernel/private_kernel_oracle.ts +129 -40
  312. package/src/pxe.ts +467 -273
  313. package/src/storage/address_store/address_store.ts +15 -15
  314. package/src/storage/anchor_block_store/anchor_block_store.ts +9 -1
  315. package/src/storage/backwards_compatibility_tests/__snapshots__/AddressStore.json +22 -0
  316. package/src/storage/backwards_compatibility_tests/__snapshots__/AnchorBlockStore.json +3 -0
  317. package/src/storage/backwards_compatibility_tests/__snapshots__/CapsuleStore.json +16 -0
  318. package/src/storage/backwards_compatibility_tests/__snapshots__/ContractStore.json +28 -0
  319. package/src/storage/backwards_compatibility_tests/__snapshots__/KeyStore.json +52 -0
  320. package/src/storage/backwards_compatibility_tests/__snapshots__/L2TipsKVStore.json +46 -0
  321. package/src/storage/backwards_compatibility_tests/__snapshots__/NoteStore.json +36 -0
  322. package/src/storage/backwards_compatibility_tests/__snapshots__/PrivateEventStore.json +44 -0
  323. package/src/storage/backwards_compatibility_tests/__snapshots__/RecipientTaggingStore.json +18 -0
  324. package/src/storage/backwards_compatibility_tests/__snapshots__/SenderAddressBookStore.json +16 -0
  325. package/src/storage/backwards_compatibility_tests/__snapshots__/SenderTaggingStore.json +22 -0
  326. package/src/storage/backwards_compatibility_tests/__snapshots__/opened_stores.json +97 -0
  327. package/src/storage/backwards_compatibility_tests/kv_store_snapshot.ts +122 -0
  328. package/src/storage/backwards_compatibility_tests/schema_tests.ts +712 -0
  329. package/src/storage/backwards_compatibility_tests/store_spy.ts +73 -0
  330. package/src/storage/capsule_store/capsule_service.ts +90 -0
  331. package/src/storage/capsule_store/capsule_store.ts +183 -29
  332. package/src/storage/capsule_store/index.ts +1 -0
  333. package/src/storage/contract_store/contract_store.ts +194 -125
  334. package/src/storage/metadata.ts +1 -1
  335. package/src/storage/note_store/note_store.ts +323 -320
  336. package/src/storage/note_store/stored_note.ts +48 -0
  337. package/src/storage/open_pxe_stores.ts +49 -0
  338. package/src/storage/private_event_store/private_event_store.ts +296 -124
  339. package/src/storage/private_event_store/stored_private_event.ts +73 -0
  340. package/src/storage/tagging_store/recipient_tagging_store.ts +107 -21
  341. package/src/storage/tagging_store/sender_address_book_store.ts +20 -14
  342. package/src/storage/tagging_store/sender_tagging_store.ts +366 -134
  343. package/src/tagging/get_all_logs_by_tags.ts +120 -0
  344. package/src/tagging/index.ts +6 -4
  345. package/src/tagging/persist_sender_tagging_index_ranges.ts +57 -0
  346. package/src/tagging/recipient_sync/sync_tagged_private_logs.ts +240 -0
  347. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +4 -4
  348. package/src/tagging/reconcile_tagging_index_ranges.ts +102 -0
  349. package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +59 -21
  350. package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +47 -29
  351. package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +41 -29
  352. package/dest/contract_function_simulator/proxied_node.d.ts +0 -9
  353. package/dest/contract_function_simulator/proxied_node.d.ts.map +0 -1
  354. package/dest/contract_function_simulator/proxied_node.js +0 -27
  355. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts +0 -28
  356. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts.map +0 -1
  357. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts +0 -4
  358. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts.map +0 -1
  359. package/dest/private_kernel/private_kernel_oracle_impl.d.ts +0 -46
  360. package/dest/private_kernel/private_kernel_oracle_impl.d.ts.map +0 -1
  361. package/dest/private_kernel/private_kernel_oracle_impl.js +0 -85
  362. package/dest/public_storage/public_storage_service.d.ts +0 -24
  363. package/dest/public_storage/public_storage_service.d.ts.map +0 -1
  364. package/dest/public_storage/public_storage_service.js +0 -26
  365. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +0 -14
  366. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +0 -1
  367. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +0 -99
  368. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +0 -14
  369. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +0 -1
  370. package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +0 -29
  371. package/dest/tree_membership/tree_membership_service.d.ts +0 -52
  372. package/dest/tree_membership/tree_membership_service.d.ts.map +0 -1
  373. package/dest/tree_membership/tree_membership_service.js +0 -84
  374. package/src/contract_function_simulator/proxied_node.ts +0 -33
  375. package/src/private_kernel/private_kernel_oracle_impl.ts +0 -127
  376. package/src/public_storage/public_storage_service.ts +0 -33
  377. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +0 -132
  378. package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +0 -43
  379. package/src/tree_membership/tree_membership_service.ts +0 -112
@@ -1,6 +1,8 @@
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
- import { createLogger } from '@aztec/foundation/log';
5
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
4
6
  import { pushTestData } from '@aztec/foundation/testing';
5
7
  import { Timer } from '@aztec/foundation/timer';
6
8
  import { getVKTreeRoot } from '@aztec/noir-protocol-circuits-types/vk-tree';
@@ -16,24 +18,32 @@ 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
 
36
- import { PrivateKernelResetPrivateInputsBuilder } from './hints/build_private_kernel_reset_private_inputs.js';
44
+ import { BatchPlanner } from './batch_planner.js';
45
+ import { computeTxExpirationTimestamp } from './hints/compute_tx_expiration_timestamp.js';
46
+ import { PrivateKernelResetPrivateInputsBuilder } from './hints/private_kernel_reset_private_inputs_builder.js';
37
47
  import type { PrivateKernelOracle } from './private_kernel_oracle.js';
38
48
 
39
49
  const NULL_SIMULATE_OUTPUT: PrivateKernelSimulateOutput<PrivateKernelCircuitPublicInputs> = {
@@ -56,13 +66,17 @@ export interface PrivateKernelExecutionProverConfig {
56
66
  * inform state tree updates.
57
67
  */
58
68
  export class PrivateKernelExecutionProver {
59
- private log = createLogger('pxe:private-kernel-execution-prover');
69
+ private log: Logger;
60
70
 
61
71
  constructor(
62
72
  private oracle: PrivateKernelOracle,
63
73
  private proofCreator: PrivateKernelProver,
64
74
  private fakeProofs = false,
65
- ) {}
75
+ bindings?: LoggerBindings,
76
+ private maxBatchSize: number = MAX_APPS_PER_KERNEL,
77
+ ) {
78
+ this.log = createLogger('pxe:private-kernel-execution-prover', bindings);
79
+ }
66
80
 
67
81
  /**
68
82
  * Generate a proof for a given transaction request and execution result.
@@ -104,6 +118,13 @@ export class PrivateKernelExecutionProver {
104
118
  const minRevertibleSideEffectCounter = getFinalMinRevertibleSideEffectCounter(executionResult);
105
119
  const splitCounter = isPrivateOnlyTx ? 0 : minRevertibleSideEffectCounter;
106
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
+
107
128
  while (executionStack.length) {
108
129
  if (!firstIteration) {
109
130
  let resetBuilder = new PrivateKernelResetPrivateInputsBuilder(
@@ -113,6 +134,7 @@ export class PrivateKernelExecutionProver {
113
134
  splitCounter,
114
135
  );
115
136
  while (resetBuilder.needsReset()) {
137
+ // Inner reset: without siloing.
116
138
  const witgenTimer = new Timer();
117
139
  const privateInputs = await resetBuilder.build(this.oracle);
118
140
  output = generateWitnesses
@@ -136,93 +158,45 @@ export class PrivateKernelExecutionProver {
136
158
  }
137
159
  }
138
160
 
139
- const currentExecution = executionStack.pop()!;
140
-
141
- executionStack.push(...[...currentExecution.nestedExecutionResults].reverse());
142
-
143
- const functionName = await this.oracle.getDebugFunctionName(
144
- currentExecution.publicInputs.callContext.contractAddress,
145
- currentExecution.publicInputs.callContext.functionSelector,
146
- );
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
+ }
147
166
 
148
- executionSteps.push({
149
- functionName: functionName!,
150
- bytecode: currentExecution.acir,
151
- witness: currentExecution.partialWitness,
152
- vk: currentExecution.vk,
153
- timings: {
154
- witgen: currentExecution.profileResult?.timings.witgen ?? 0,
155
- oracles: currentExecution.profileResult?.timings.oracles,
156
- },
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,
157
177
  });
158
178
 
159
- const privateCallData = await this.createPrivateCallData(currentExecution);
160
-
161
- if (firstIteration) {
162
- const witgenTimer = new Timer();
163
-
164
- const proofInput = new PrivateKernelInitCircuitPrivateInputs(
165
- txRequest,
166
- getVKTreeRoot(),
167
- ProtocolContractsList,
168
- privateCallData,
169
- isPrivateOnlyTx,
170
- executionResult.firstNullifier,
171
- minRevertibleSideEffectCounter,
172
- );
173
- this.log.debug(
174
- `Calling private kernel init with isPrivateOnly ${isPrivateOnlyTx} and firstNullifierHint ${proofInput.firstNullifierHint}`,
175
- );
176
-
177
- pushTestData('private-kernel-inputs-init', proofInput);
178
-
179
- output = generateWitnesses
180
- ? await this.proofCreator.generateInitOutput(proofInput)
181
- : await this.proofCreator.simulateInit(proofInput);
182
-
183
- executionSteps.push({
184
- functionName: 'private_kernel_init',
185
- bytecode: output.bytecode,
186
- witness: output.outputWitness,
187
- vk: output.verificationKey.keyAsBytes,
188
- timings: {
189
- witgen: witgenTimer.ms(),
190
- },
191
- });
192
- } else {
193
- const witgenTimer = new Timer();
194
- const vkData = await this.getVkData(output.verificationKey);
195
- const previousKernelData = new PrivateKernelData(output.publicInputs, vkData);
196
- const proofInput = new PrivateKernelInnerCircuitPrivateInputs(previousKernelData, privateCallData);
197
-
198
- pushTestData('private-kernel-inputs-inner', proofInput);
199
- output = generateWitnesses
200
- ? await this.proofCreator.generateInnerOutput(proofInput)
201
- : await this.proofCreator.simulateInner(proofInput);
202
-
203
- executionSteps.push({
204
- functionName: 'private_kernel_inner',
205
- bytecode: output.bytecode,
206
- witness: output.outputWitness,
207
- vk: output.verificationKey.keyAsBytes,
208
- timings: {
209
- witgen: witgenTimer.ms(),
210
- },
211
- });
212
- }
213
179
  firstIteration = false;
214
180
  }
215
181
 
216
- // Reset.
217
- let resetBuilder = new PrivateKernelResetPrivateInputsBuilder(
182
+ // Final reset: include siloing of note hashes, nullifiers and private logs.
183
+ const finalResetBuilder = new PrivateKernelResetPrivateInputsBuilder(
218
184
  output,
219
185
  [],
220
186
  noteHashNullifierCounterMap,
221
187
  splitCounter,
222
188
  );
223
- while (resetBuilder.needsReset()) {
189
+ if (!finalResetBuilder.needsReset()) {
190
+ // The final reset must be performed exactly once, because each tx has at least one nullifier that requires
191
+ // siloing, and siloing cannot be done multiple times.
192
+ // While, in theory, it might be possible to silo note hashes first and then run another reset to silo nullifiers
193
+ // and/or private logs, we currently don't have standalone dimensions for the arrays that require siloing. As a
194
+ // result, all necessary siloing must be done together in a single reset.
195
+ // Refer to the possible combinations of dimensions in private_kernel_reset_config.json.
196
+ throw new Error('Nothing to reset for the final reset.');
197
+ } else {
224
198
  const witgenTimer = new Timer();
225
- const privateInputs = await resetBuilder.build(this.oracle);
199
+ const privateInputs = await finalResetBuilder.build(this.oracle);
226
200
  output = generateWitnesses
227
201
  ? await this.proofCreator.generateResetOutput(privateInputs)
228
202
  : await this.proofCreator.simulateReset(privateInputs);
@@ -236,8 +210,6 @@ export class PrivateKernelExecutionProver {
236
210
  witgen: witgenTimer.ms(),
237
211
  },
238
212
  });
239
-
240
- resetBuilder = new PrivateKernelResetPrivateInputsBuilder(output, [], noteHashNullifierCounterMap, splitCounter);
241
213
  }
242
214
 
243
215
  if (output.publicInputs.feePayer.isZero() && skipFeeEnforcement) {
@@ -257,20 +229,14 @@ export class PrivateKernelExecutionProver {
257
229
  // TODO: Enable padding once we better understand the final amounts to pad to.
258
230
  const paddedSideEffectAmounts = PaddedSideEffectAmounts.empty();
259
231
 
260
- // Use the aggregated includeByTimestamp set throughout the tx execution.
261
- // TODO: Call `computeTxIncludeByTimestamp` to round the value down and reduce precision, improving privacy.
262
- const includeByTimestampUpperBound = previousKernelData.publicInputs.includeByTimestamp;
263
- const anchorBlockTimestamp = previousKernelData.publicInputs.constants.anchorBlockHeader.globalVariables.timestamp;
264
- if (includeByTimestampUpperBound <= anchorBlockTimestamp) {
265
- throw new Error(
266
- `Include-by timestamp must be greater than the anchor block timestamp. Anchor block timestamp: ${anchorBlockTimestamp}. Include-by timestamp: ${includeByTimestampUpperBound}.`,
267
- );
268
- }
232
+ // Round the aggregated expirationTimestamp down to reduce precision and avoid leaking which private
233
+ // functions were called via their exact expiration offsets.
234
+ const expirationTimestampUpperBound = computeTxExpirationTimestamp(previousKernelData.publicInputs);
269
235
 
270
236
  const privateInputs = new PrivateKernelTailCircuitPrivateInputs(
271
237
  previousKernelData,
272
238
  paddedSideEffectAmounts,
273
- includeByTimestampUpperBound,
239
+ expirationTimestampUpperBound,
274
240
  );
275
241
 
276
242
  const witgenTimer = new Timer();
@@ -396,7 +362,60 @@ export class PrivateKernelExecutionProver {
396
362
  );
397
363
  }
398
364
 
399
- 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
+ ) {
400
419
  const { contractAddress, functionSelector } = publicInputs.callContext;
401
420
 
402
421
  const vkAsFields = await vkAsFieldsMegaHonk(vkAsBuffer);
@@ -412,7 +431,7 @@ export class PrivateKernelExecutionProver {
412
431
  const { artifactHash: contractClassArtifactHash, publicBytecodeCommitment: contractClassPublicBytecodeCommitment } =
413
432
  await this.oracle.getContractClassIdPreimage(currentContractClassId);
414
433
 
415
- const updatedClassIdHints = await this.oracle.getUpdatedClassIdHints(contractAddress);
434
+ const updatedClassIdHints = updatedClassIdHintsMap.get(contractAddress.toString())!;
416
435
 
417
436
  return PrivateCallData.from({
418
437
  publicInputs,
@@ -427,4 +446,153 @@ export class PrivateKernelExecutionProver {
427
446
  }),
428
447
  });
429
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
+ }
430
598
  }
@@ -1,73 +1,162 @@
1
- import { FUNCTION_TREE_HEIGHT, NOTE_HASH_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';
11
+ import type { KeyStore } from '@aztec/key-store';
12
+ import { getVKIndex, getVKSiblingPath } from '@aztec/noir-protocol-circuits-types/vk-tree';
13
+ import { ProtocolContractAddress } from '@aztec/protocol-contracts';
5
14
  import type { FunctionSelector } from '@aztec/stdlib/abi';
6
15
  import type { AztecAddress } from '@aztec/stdlib/aztec-address';
16
+ import { type ContractInstanceWithAddress, computeSaltedInitializationHash } from '@aztec/stdlib/contract';
17
+ import { DelayedPublicMutableValues, DelayedPublicMutableValuesWithHash } from '@aztec/stdlib/delayed-public-mutable';
18
+ import { computePublicDataTreeLeafSlot } from '@aztec/stdlib/hash';
19
+ import type { AztecNode } from '@aztec/stdlib/interfaces/client';
7
20
  import { UpdatedClassIdHints } from '@aztec/stdlib/kernel';
8
- import type { PublicKeys } from '@aztec/stdlib/keys';
9
21
  import type { NullifierMembershipWitness } from '@aztec/stdlib/trees';
22
+ import type { BlockHeader } from '@aztec/stdlib/tx';
10
23
  import type { VerificationKeyAsFields } from '@aztec/stdlib/vks';
11
24
 
25
+ import type { ContractStore } from '../storage/contract_store/contract_store.js';
26
+
12
27
  /**
13
28
  * Provides functionality needed by the private kernel for interacting with our state trees.
14
- * This is either PrivateKernelOracleImpl, or a mocked test implementation.
15
29
  */
16
- export interface PrivateKernelOracle {
30
+ export class PrivateKernelOracle {
31
+ constructor(
32
+ private contractStore: ContractStore,
33
+ private keyStore: KeyStore,
34
+ private node: AztecNode,
35
+ private blockHeader: BlockHeader,
36
+ ) {}
37
+
17
38
  /** Retrieves the preimage of a contract address from the registered contract instances db. */
18
- getContractAddressPreimage(address: AztecAddress): Promise<{
19
- saltedInitializationHash: Fr;
20
- publicKeys: PublicKeys;
21
- currentContractClassId: Fr;
22
- originalContractClassId: Fr;
23
- }>;
39
+ public async getContractAddressPreimage(
40
+ address: AztecAddress,
41
+ ): Promise<ContractInstanceWithAddress & { saltedInitializationHash: Fr }> {
42
+ const instance = await this.contractStore.getContractInstance(address);
43
+ if (!instance) {
44
+ throw new Error(`Contract instance not found when getting address preimage. Contract address: ${address}.`);
45
+ }
46
+ return {
47
+ saltedInitializationHash: await computeSaltedInitializationHash(instance),
48
+ ...instance,
49
+ };
50
+ }
24
51
 
25
52
  /** Retrieves the preimage of a contract class id from the contract classes db. */
26
- getContractClassIdPreimage(
27
- contractClassId: Fr,
28
- ): Promise<{ artifactHash: Fr; publicBytecodeCommitment: Fr; privateFunctionsRoot: Fr }>;
53
+ public async getContractClassIdPreimage(contractClassId: Fr) {
54
+ const contractClass = await this.contractStore.getContractClassWithPreimage(contractClassId);
55
+ if (!contractClass) {
56
+ throw new Error(`Contract class not found when getting class id preimage. Class id: ${contractClassId}.`);
57
+ }
58
+ return {
59
+ artifactHash: contractClass.artifactHash,
60
+ privateFunctionsRoot: contractClass.privateFunctionsRoot,
61
+ publicBytecodeCommitment: contractClass.publicBytecodeCommitment,
62
+ };
63
+ }
29
64
 
30
- /**
31
- * Returns a membership witness with the sibling path and leaf index in our private functions tree.
32
- */
33
- getFunctionMembershipWitness(
65
+ /** Returns a membership witness with the sibling path and leaf index in our private functions tree. */
66
+ public async getFunctionMembershipWitness(
34
67
  contractClassId: Fr,
35
68
  selector: FunctionSelector,
36
- ): Promise<MembershipWitness<typeof FUNCTION_TREE_HEIGHT>>;
69
+ ): Promise<MembershipWitness<typeof FUNCTION_TREE_HEIGHT>> {
70
+ const membershipWitness = await this.contractStore.getFunctionMembershipWitness(contractClassId, selector);
71
+ if (!membershipWitness) {
72
+ throw new Error(
73
+ `Membership witness not found for contract class id ${contractClassId} and selector ${selector}.`,
74
+ );
75
+ }
76
+ return membershipWitness;
77
+ }
37
78
 
38
79
  /**
39
80
  * Returns a membership witness with the sibling path and leaf index in our protocol VK indexed merkle tree.
40
81
  * Used to validate the previous kernel's verification key.
41
82
  */
42
- getVkMembershipWitness(vk: VerificationKeyAsFields): Promise<MembershipWitness<typeof VK_TREE_HEIGHT>>;
83
+ public getVkMembershipWitness(vk: VerificationKeyAsFields): Promise<MembershipWitness<typeof VK_TREE_HEIGHT>> {
84
+ const leafIndex = getVKIndex(vk);
85
+ return Promise.resolve(new MembershipWitness(VK_TREE_HEIGHT, BigInt(leafIndex), getVKSiblingPath(leafIndex)));
86
+ }
43
87
 
44
- /**
45
- * Returns a membership witness with the sibling path and leaf index in our private function indexed merkle tree.
46
- */
47
- getNoteHashMembershipWitness(noteHash: Fr): Promise<MembershipWitness<typeof NOTE_HASH_TREE_HEIGHT> | undefined>;
88
+ /** Returns a membership witness with the sibling path and leaf index in our note hash tree. */
89
+ async getNoteHashMembershipWitness(
90
+ noteHash: Fr,
91
+ ): Promise<MembershipWitness<typeof NOTE_HASH_TREE_HEIGHT> | undefined> {
92
+ return this.node.getNoteHashMembershipWitness(await this.blockHeader.hash(), noteHash);
93
+ }
48
94
 
49
- /**
50
- * Returns a membership witness with the sibling path and leaf index in our nullifier indexed merkle tree.
51
- */
52
- getNullifierMembershipWitness(nullifier: Fr): Promise<NullifierMembershipWitness | undefined>;
53
- /**
54
- * Returns the root of our note hash merkle tree.
55
- */
56
- getNoteHashTreeRoot(): Promise<Fr>;
95
+ /** Returns a membership witness with the sibling path and leaf index in our nullifier indexed merkle tree. */
96
+ async getNullifierMembershipWitness(nullifier: Fr): Promise<NullifierMembershipWitness | undefined> {
97
+ return this.node.getNullifierMembershipWitness(await this.blockHeader.hash(), nullifier);
98
+ }
99
+
100
+ /** Returns the root of our note hash merkle tree. */
101
+ getNoteHashTreeRoot(): Fr {
102
+ return this.blockHeader.state.partial.noteHashTree.root;
103
+ }
57
104
 
58
105
  /**
59
- * Retrieves the sk_m corresponding to the pk_m.
60
- * @throws If the provided public key is not associated with any of the registered accounts.
61
- * @param pkM - 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.
62
109
  * @returns A Promise that resolves to sk_m.
63
110
  * @dev Used when feeding the sk_m to the kernel circuit for keys verification.
64
111
  */
65
- getMasterSecretKey(masterPublicKey: Point): Promise<GrumpkinScalar>;
112
+ public getMasterSecretKey(masterPublicKeyHash: Fr): Promise<GrumpkinScalar> {
113
+ return this.keyStore.getMasterSecretKey(masterPublicKeyHash);
114
+ }
66
115
 
67
116
  /** Use debug data to get the function name corresponding to a selector. */
68
- getDebugFunctionName(contractAddress: AztecAddress, selector: FunctionSelector): Promise<string | undefined>;
117
+ public getDebugFunctionName(contractAddress: AztecAddress, selector: FunctionSelector): Promise<string | undefined> {
118
+ return this.contractStore.getDebugFunctionName(contractAddress, selector);
119
+ }
120
+
121
+ /**
122
+ * Returns a membership witness and leaf index to our public data indexed merkle tree,
123
+ * along with an associated DelayedPublicMutable containing the class ID to update.
124
+ */
125
+ public async getUpdatedClassIdHints(contractAddress: AztecAddress): Promise<UpdatedClassIdHints> {
126
+ const { delayedPublicMutableSlot, delayedPublicMutableHashSlot } =
127
+ await DelayedPublicMutableValuesWithHash.getContractUpdateSlots(contractAddress);
128
+
129
+ const hashLeafSlot = await computePublicDataTreeLeafSlot(
130
+ ProtocolContractAddress.ContractInstanceRegistry,
131
+ delayedPublicMutableHashSlot,
132
+ );
133
+ const blockHash = await this.blockHeader.hash();
134
+
135
+ const updatedClassIdWitness = await this.node.getPublicDataWitness(blockHash, hashLeafSlot);
136
+
137
+ if (!updatedClassIdWitness) {
138
+ throw new Error(`No public data tree witness found for ${hashLeafSlot}`);
139
+ }
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.
145
+ const readStorage = (storageSlot: Fr) =>
146
+ this.node.getPublicStorageAt(blockHash, ProtocolContractAddress.ContractInstanceRegistry, storageSlot);
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);
69
151
 
70
- /** Returns a membership witness and leaf index to our public data indexed merkle tree,
71
- * along with an associated DelayedPublicMutable containing the class ID to update. */
72
- getUpdatedClassIdHints(contractAddress: AztecAddress): Promise<UpdatedClassIdHints>;
152
+ return new UpdatedClassIdHints(
153
+ new MembershipWitness(
154
+ PUBLIC_DATA_TREE_HEIGHT,
155
+ updatedClassIdWitness.index,
156
+ updatedClassIdWitness.siblingPath.toTuple(),
157
+ ),
158
+ updatedClassIdWitness.leafPreimage,
159
+ delayedPublicMutableValues,
160
+ );
161
+ }
73
162
  }