@aztec/pxe 0.0.0-test.1 → 0.0.1-commit.1142ef1

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 (445) hide show
  1. package/README.md +5 -5
  2. package/dest/bin/check_oracle_version.d.ts +2 -0
  3. package/dest/bin/check_oracle_version.d.ts.map +1 -0
  4. package/dest/bin/check_oracle_version.js +129 -0
  5. package/dest/block_synchronizer/block_synchronizer.d.ts +39 -0
  6. package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -0
  7. package/dest/{synchronizer/synchronizer.js → block_synchronizer/block_synchronizer.js} +34 -35
  8. package/dest/block_synchronizer/index.d.ts +2 -0
  9. package/dest/block_synchronizer/index.d.ts.map +1 -0
  10. package/dest/block_synchronizer/index.js +1 -0
  11. package/dest/config/index.d.ts +11 -24
  12. package/dest/config/index.d.ts.map +1 -1
  13. package/dest/config/index.js +18 -33
  14. package/dest/config/package_info.d.ts +1 -1
  15. package/dest/config/package_info.js +1 -1
  16. package/dest/contract_function_simulator/contract_function_simulator.d.ts +86 -0
  17. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -0
  18. package/dest/contract_function_simulator/contract_function_simulator.js +331 -0
  19. package/dest/contract_function_simulator/execution_note_cache.d.ts +95 -0
  20. package/dest/contract_function_simulator/execution_note_cache.d.ts.map +1 -0
  21. package/dest/contract_function_simulator/execution_note_cache.js +191 -0
  22. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +16 -0
  23. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -0
  24. package/dest/contract_function_simulator/execution_tagging_index_cache.js +26 -0
  25. package/dest/contract_function_simulator/hashed_values_cache.d.ts +28 -0
  26. package/dest/contract_function_simulator/hashed_values_cache.d.ts.map +1 -0
  27. package/dest/contract_function_simulator/hashed_values_cache.js +36 -0
  28. package/dest/contract_function_simulator/index.d.ts +14 -0
  29. package/dest/contract_function_simulator/index.d.ts.map +1 -0
  30. package/dest/contract_function_simulator/index.js +12 -0
  31. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +21 -0
  32. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts.map +1 -0
  33. package/dest/contract_function_simulator/noir-structs/event_validation_request.js +40 -0
  34. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts +16 -0
  35. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts.map +1 -0
  36. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.js +26 -0
  37. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts +17 -0
  38. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts.map +1 -0
  39. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.js +65 -0
  40. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +24 -0
  41. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -0
  42. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +51 -0
  43. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts +22 -0
  44. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts.map +1 -0
  45. package/dest/contract_function_simulator/noir-structs/utility_context.js +33 -0
  46. package/dest/contract_function_simulator/oracle/index.d.ts +14 -0
  47. package/dest/contract_function_simulator/oracle/index.d.ts.map +1 -0
  48. package/dest/contract_function_simulator/oracle/index.js +2 -0
  49. package/dest/contract_function_simulator/oracle/interfaces.d.ts +103 -0
  50. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -0
  51. package/dest/contract_function_simulator/oracle/interfaces.js +4 -0
  52. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts +17 -0
  53. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts.map +1 -0
  54. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.js +24 -0
  55. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts +28 -0
  56. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts.map +1 -0
  57. package/dest/contract_function_simulator/oracle/note_packing_utils.js +54 -0
  58. package/dest/contract_function_simulator/oracle/oracle.d.ts +58 -0
  59. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -0
  60. package/dest/contract_function_simulator/oracle/oracle.js +345 -0
  61. package/dest/contract_function_simulator/oracle/private_execution.d.ts +47 -0
  62. package/dest/contract_function_simulator/oracle/private_execution.d.ts.map +1 -0
  63. package/dest/contract_function_simulator/oracle/private_execution.js +122 -0
  64. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +231 -0
  65. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -0
  66. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +414 -0
  67. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +196 -0
  68. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -0
  69. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +374 -0
  70. package/dest/contract_function_simulator/pick_notes.d.ts +85 -0
  71. package/dest/contract_function_simulator/pick_notes.d.ts.map +1 -0
  72. package/dest/contract_function_simulator/pick_notes.js +51 -0
  73. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts +6 -0
  74. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts.map +1 -0
  75. package/dest/contract_function_simulator/proxied_contract_data_source.js +80 -0
  76. package/dest/contract_function_simulator/proxied_node.d.ts +9 -0
  77. package/dest/contract_function_simulator/proxied_node.d.ts.map +1 -0
  78. package/dest/contract_function_simulator/proxied_node.js +27 -0
  79. package/dest/debug/pxe_debug_utils.d.ts +31 -0
  80. package/dest/debug/pxe_debug_utils.d.ts.map +1 -0
  81. package/dest/debug/pxe_debug_utils.js +37 -0
  82. package/dest/entrypoints/client/bundle/index.d.ts +4 -3
  83. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  84. package/dest/entrypoints/client/bundle/index.js +2 -2
  85. package/dest/entrypoints/client/bundle/utils.d.ts +10 -10
  86. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  87. package/dest/entrypoints/client/bundle/utils.js +27 -12
  88. package/dest/entrypoints/client/lazy/index.d.ts +4 -3
  89. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  90. package/dest/entrypoints/client/lazy/index.js +2 -2
  91. package/dest/entrypoints/client/lazy/utils.d.ts +9 -9
  92. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  93. package/dest/entrypoints/client/lazy/utils.js +26 -11
  94. package/dest/entrypoints/pxe_creation_options.d.ts +17 -0
  95. package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -0
  96. package/dest/entrypoints/server/index.d.ts +6 -4
  97. package/dest/entrypoints/server/index.d.ts.map +1 -1
  98. package/dest/entrypoints/server/index.js +4 -3
  99. package/dest/entrypoints/server/utils.d.ts +8 -16
  100. package/dest/entrypoints/server/utils.d.ts.map +1 -1
  101. package/dest/entrypoints/server/utils.js +35 -36
  102. package/dest/error_enriching.d.ts +11 -0
  103. package/dest/error_enriching.d.ts.map +1 -0
  104. package/dest/{pxe_service/error_enriching.js → error_enriching.js} +30 -22
  105. package/dest/events/event_service.d.ts +15 -0
  106. package/dest/events/event_service.d.ts.map +1 -0
  107. package/dest/events/event_service.js +47 -0
  108. package/dest/events/index.d.ts +2 -0
  109. package/dest/events/index.d.ts.map +1 -0
  110. package/dest/events/index.js +1 -0
  111. package/dest/events/private_event_filter_validator.d.ts +9 -0
  112. package/dest/events/private_event_filter_validator.d.ts.map +1 -0
  113. package/dest/events/private_event_filter_validator.js +39 -0
  114. package/dest/job_coordinator/job_coordinator.d.ts +74 -0
  115. package/dest/job_coordinator/job_coordinator.d.ts.map +1 -0
  116. package/dest/job_coordinator/job_coordinator.js +93 -0
  117. package/dest/logs/log_service.d.ts +26 -0
  118. package/dest/logs/log_service.d.ts.map +1 -0
  119. package/dest/logs/log_service.js +120 -0
  120. package/dest/notes/index.d.ts +2 -0
  121. package/dest/notes/index.d.ts.map +1 -0
  122. package/dest/notes/index.js +1 -0
  123. package/dest/notes/note_service.d.ts +48 -0
  124. package/dest/notes/note_service.d.ts.map +1 -0
  125. package/dest/notes/note_service.js +152 -0
  126. package/dest/oracle_version.d.ts +3 -0
  127. package/dest/oracle_version.d.ts.map +1 -0
  128. package/dest/oracle_version.js +10 -0
  129. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts +28 -0
  130. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts.map +1 -0
  131. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.js +271 -0
  132. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts +4 -0
  133. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts.map +1 -0
  134. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.js +41 -0
  135. package/dest/private_kernel/hints/index.d.ts +3 -0
  136. package/dest/private_kernel/hints/index.d.ts.map +1 -0
  137. package/dest/{kernel_prover → private_kernel}/hints/index.js +1 -0
  138. package/dest/private_kernel/index.d.ts +3 -0
  139. package/dest/private_kernel/index.d.ts.map +1 -0
  140. package/dest/private_kernel/index.js +2 -0
  141. package/dest/private_kernel/private_kernel_execution_prover.d.ts +44 -0
  142. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -0
  143. package/dest/private_kernel/private_kernel_execution_prover.js +285 -0
  144. package/dest/private_kernel/private_kernel_oracle.d.ts +64 -0
  145. package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -0
  146. package/dest/private_kernel/private_kernel_oracle.js +4 -0
  147. package/dest/private_kernel/private_kernel_oracle_impl.d.ts +46 -0
  148. package/dest/private_kernel/private_kernel_oracle_impl.d.ts.map +1 -0
  149. package/dest/{kernel_oracle/index.js → private_kernel/private_kernel_oracle_impl.js} +27 -18
  150. package/dest/public_storage/public_storage_service.d.ts +24 -0
  151. package/dest/public_storage/public_storage_service.d.ts.map +1 -0
  152. package/dest/public_storage/public_storage_service.js +26 -0
  153. package/dest/pxe.d.ts +233 -0
  154. package/dest/pxe.d.ts.map +1 -0
  155. package/dest/pxe.js +782 -0
  156. package/dest/storage/address_store/address_store.d.ts +11 -0
  157. package/dest/storage/address_store/address_store.d.ts.map +1 -0
  158. package/dest/storage/{address_data_provider/address_data_provider.js → address_store/address_store.js} +1 -4
  159. package/dest/storage/address_store/index.d.ts +2 -0
  160. package/dest/storage/address_store/index.d.ts.map +1 -0
  161. package/dest/storage/address_store/index.js +1 -0
  162. package/dest/storage/anchor_block_store/anchor_block_store.d.ts +9 -0
  163. package/dest/storage/anchor_block_store/anchor_block_store.d.ts.map +1 -0
  164. package/dest/storage/{sync_data_provider/sync_data_provider.js → anchor_block_store/anchor_block_store.js} +2 -12
  165. package/dest/storage/anchor_block_store/index.d.ts +2 -0
  166. package/dest/storage/anchor_block_store/index.d.ts.map +1 -0
  167. package/dest/storage/anchor_block_store/index.js +1 -0
  168. package/dest/storage/capsule_store/capsule_store.d.ts +57 -0
  169. package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -0
  170. package/dest/storage/capsule_store/capsule_store.js +146 -0
  171. package/dest/storage/capsule_store/index.d.ts +2 -0
  172. package/dest/storage/capsule_store/index.d.ts.map +1 -0
  173. package/dest/storage/capsule_store/index.js +1 -0
  174. package/dest/storage/contract_store/contract_store.d.ts +67 -0
  175. package/dest/storage/contract_store/contract_store.d.ts.map +1 -0
  176. package/dest/storage/contract_store/contract_store.js +236 -0
  177. package/dest/storage/contract_store/index.d.ts +2 -0
  178. package/dest/storage/contract_store/index.d.ts.map +1 -0
  179. package/dest/storage/contract_store/index.js +1 -0
  180. package/dest/storage/contract_store/private_functions_tree.d.ts +27 -0
  181. package/dest/storage/contract_store/private_functions_tree.d.ts.map +1 -0
  182. package/dest/storage/contract_store/private_functions_tree.js +47 -0
  183. package/dest/storage/index.d.ts +9 -10
  184. package/dest/storage/index.d.ts.map +1 -1
  185. package/dest/storage/index.js +8 -9
  186. package/dest/storage/metadata.d.ts +2 -0
  187. package/dest/storage/metadata.d.ts.map +1 -0
  188. package/dest/storage/metadata.js +1 -0
  189. package/dest/storage/note_store/index.d.ts +3 -0
  190. package/dest/storage/note_store/index.d.ts.map +1 -0
  191. package/dest/storage/note_store/index.js +2 -0
  192. package/dest/storage/note_store/note_store.d.ts +84 -0
  193. package/dest/storage/note_store/note_store.d.ts.map +1 -0
  194. package/dest/storage/note_store/note_store.js +322 -0
  195. package/dest/storage/private_event_store/private_event_store.d.ts +56 -0
  196. package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -0
  197. package/dest/storage/private_event_store/private_event_store.js +158 -0
  198. package/dest/storage/tagging_store/index.d.ts +4 -0
  199. package/dest/storage/tagging_store/index.d.ts.map +1 -0
  200. package/dest/storage/tagging_store/index.js +3 -0
  201. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +21 -0
  202. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -0
  203. package/dest/storage/tagging_store/recipient_tagging_store.js +42 -0
  204. package/dest/storage/tagging_store/sender_address_book_store.d.ts +14 -0
  205. package/dest/storage/tagging_store/sender_address_book_store.d.ts.map +1 -0
  206. package/dest/storage/tagging_store/sender_address_book_store.js +30 -0
  207. package/dest/storage/tagging_store/sender_tagging_store.d.ts +67 -0
  208. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -0
  209. package/dest/storage/tagging_store/sender_tagging_store.js +196 -0
  210. package/dest/tagging/constants.d.ts +2 -0
  211. package/dest/tagging/constants.d.ts.map +1 -0
  212. package/dest/tagging/constants.js +10 -0
  213. package/dest/tagging/index.d.ts +16 -0
  214. package/dest/tagging/index.d.ts.map +1 -0
  215. package/dest/tagging/index.js +14 -0
  216. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +14 -0
  217. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +1 -0
  218. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +99 -0
  219. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts +12 -0
  220. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts.map +1 -0
  221. package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +20 -0
  222. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +14 -0
  223. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +1 -0
  224. package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +29 -0
  225. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +20 -0
  226. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -0
  227. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +74 -0
  228. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +11 -0
  229. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -0
  230. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +32 -0
  231. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +18 -0
  232. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -0
  233. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +55 -0
  234. package/dest/tree_membership/tree_membership_service.d.ts +52 -0
  235. package/dest/tree_membership/tree_membership_service.d.ts.map +1 -0
  236. package/dest/tree_membership/tree_membership_service.js +84 -0
  237. package/package.json +37 -34
  238. package/src/bin/check_oracle_version.ts +160 -0
  239. package/src/{synchronizer/synchronizer.ts → block_synchronizer/block_synchronizer.ts} +37 -38
  240. package/src/block_synchronizer/index.ts +1 -0
  241. package/src/config/index.ts +27 -55
  242. package/src/config/package_info.ts +1 -1
  243. package/src/contract_function_simulator/contract_function_simulator.ts +627 -0
  244. package/src/contract_function_simulator/execution_note_cache.ts +233 -0
  245. package/src/contract_function_simulator/execution_tagging_index_cache.ts +32 -0
  246. package/src/contract_function_simulator/hashed_values_cache.ts +47 -0
  247. package/src/contract_function_simulator/index.ts +13 -0
  248. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +51 -0
  249. package/src/contract_function_simulator/noir-structs/log_retrieval_request.ts +28 -0
  250. package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +69 -0
  251. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +64 -0
  252. package/src/contract_function_simulator/noir-structs/utility_context.ts +42 -0
  253. package/src/contract_function_simulator/oracle/index.ts +16 -0
  254. package/src/contract_function_simulator/oracle/interfaces.ts +175 -0
  255. package/src/contract_function_simulator/oracle/message_load_oracle_inputs.ts +23 -0
  256. package/src/contract_function_simulator/oracle/note_packing_utils.ts +68 -0
  257. package/src/contract_function_simulator/oracle/oracle.ts +605 -0
  258. package/src/contract_function_simulator/oracle/private_execution.ts +207 -0
  259. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +676 -0
  260. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +536 -0
  261. package/src/contract_function_simulator/pick_notes.ts +141 -0
  262. package/src/contract_function_simulator/proxied_contract_data_source.ts +83 -0
  263. package/src/contract_function_simulator/proxied_node.ts +33 -0
  264. package/src/debug/pxe_debug_utils.ts +48 -0
  265. package/src/entrypoints/client/bundle/index.ts +3 -2
  266. package/src/entrypoints/client/bundle/utils.ts +42 -36
  267. package/src/entrypoints/client/lazy/index.ts +3 -2
  268. package/src/entrypoints/client/lazy/utils.ts +41 -31
  269. package/src/entrypoints/pxe_creation_options.ts +13 -0
  270. package/src/entrypoints/server/index.ts +5 -3
  271. package/src/entrypoints/server/utils.ts +55 -51
  272. package/src/{pxe_service/error_enriching.ts → error_enriching.ts} +40 -39
  273. package/src/events/event_service.ts +79 -0
  274. package/src/events/index.ts +1 -0
  275. package/src/events/private_event_filter_validator.ts +48 -0
  276. package/src/job_coordinator/job_coordinator.ts +149 -0
  277. package/src/logs/log_service.ts +202 -0
  278. package/src/notes/index.ts +1 -0
  279. package/src/notes/note_service.ts +200 -0
  280. package/src/oracle_version.ts +11 -0
  281. package/src/{kernel_prover → private_kernel}/hints/build_private_kernel_reset_private_inputs.ts +159 -148
  282. package/src/private_kernel/hints/compute_tx_include_by_timestamp.ts +58 -0
  283. package/src/{kernel_prover → private_kernel}/hints/index.ts +1 -0
  284. package/src/private_kernel/index.ts +2 -0
  285. package/src/private_kernel/private_kernel_execution_prover.ts +430 -0
  286. package/src/{kernel_prover/proving_data_oracle.ts → private_kernel/private_kernel_oracle.ts} +19 -29
  287. package/src/{kernel_oracle/index.ts → private_kernel/private_kernel_oracle_impl.ts} +40 -30
  288. package/src/public_storage/public_storage_service.ts +33 -0
  289. package/src/pxe.ts +1111 -0
  290. package/src/storage/{address_data_provider/address_data_provider.ts → address_store/address_store.ts} +1 -7
  291. package/src/storage/address_store/index.ts +1 -0
  292. package/src/storage/{sync_data_provider/sync_data_provider.ts → anchor_block_store/anchor_block_store.ts} +2 -17
  293. package/src/storage/anchor_block_store/index.ts +1 -0
  294. package/src/storage/capsule_store/capsule_store.ts +179 -0
  295. package/src/storage/capsule_store/index.ts +1 -0
  296. package/src/storage/contract_store/contract_store.ts +339 -0
  297. package/src/storage/contract_store/index.ts +1 -0
  298. package/src/storage/contract_store/private_functions_tree.ts +67 -0
  299. package/src/storage/index.ts +8 -10
  300. package/src/storage/metadata.ts +1 -0
  301. package/src/storage/note_store/index.ts +2 -0
  302. package/src/storage/{note_data_provider/note_data_provider.ts → note_store/note_store.ts} +190 -123
  303. package/src/storage/private_event_store/private_event_store.ts +216 -0
  304. package/src/storage/tagging_store/index.ts +3 -0
  305. package/src/storage/tagging_store/recipient_tagging_store.ts +53 -0
  306. package/src/storage/tagging_store/sender_address_book_store.ts +42 -0
  307. package/src/storage/tagging_store/sender_tagging_store.ts +244 -0
  308. package/src/tagging/constants.ts +10 -0
  309. package/src/tagging/index.ts +18 -0
  310. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +132 -0
  311. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +34 -0
  312. package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +43 -0
  313. package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +96 -0
  314. package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +48 -0
  315. package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +72 -0
  316. package/src/tree_membership/tree_membership_service.ts +112 -0
  317. package/dest/bin/index.d.ts +0 -3
  318. package/dest/bin/index.d.ts.map +0 -1
  319. package/dest/bin/index.js +0 -28
  320. package/dest/entrypoints/client/pxe_creation_options.d.ts +0 -11
  321. package/dest/entrypoints/client/pxe_creation_options.d.ts.map +0 -1
  322. package/dest/kernel_oracle/index.d.ts +0 -45
  323. package/dest/kernel_oracle/index.d.ts.map +0 -1
  324. package/dest/kernel_prover/hints/build_private_kernel_reset_private_inputs.d.ts +0 -28
  325. package/dest/kernel_prover/hints/build_private_kernel_reset_private_inputs.d.ts.map +0 -1
  326. package/dest/kernel_prover/hints/build_private_kernel_reset_private_inputs.js +0 -270
  327. package/dest/kernel_prover/hints/index.d.ts +0 -2
  328. package/dest/kernel_prover/hints/index.d.ts.map +0 -1
  329. package/dest/kernel_prover/index.d.ts +0 -3
  330. package/dest/kernel_prover/index.d.ts.map +0 -1
  331. package/dest/kernel_prover/index.js +0 -2
  332. package/dest/kernel_prover/kernel_prover.d.ts +0 -38
  333. package/dest/kernel_prover/kernel_prover.d.ts.map +0 -1
  334. package/dest/kernel_prover/kernel_prover.js +0 -217
  335. package/dest/kernel_prover/proving_data_oracle.d.ts +0 -73
  336. package/dest/kernel_prover/proving_data_oracle.d.ts.map +0 -1
  337. package/dest/kernel_prover/proving_data_oracle.js +0 -4
  338. package/dest/note_decryption_utils/add_public_values_to_payload.d.ts +0 -11
  339. package/dest/note_decryption_utils/add_public_values_to_payload.d.ts.map +0 -1
  340. package/dest/note_decryption_utils/add_public_values_to_payload.js +0 -47
  341. package/dest/pxe_http/index.d.ts +0 -2
  342. package/dest/pxe_http/index.d.ts.map +0 -1
  343. package/dest/pxe_http/index.js +0 -1
  344. package/dest/pxe_http/pxe_http_server.d.ts +0 -16
  345. package/dest/pxe_http/pxe_http_server.d.ts.map +0 -1
  346. package/dest/pxe_http/pxe_http_server.js +0 -27
  347. package/dest/pxe_oracle_interface/index.d.ts +0 -159
  348. package/dest/pxe_oracle_interface/index.d.ts.map +0 -1
  349. package/dest/pxe_oracle_interface/index.js +0 -692
  350. package/dest/pxe_oracle_interface/tagging_utils.d.ts +0 -17
  351. package/dest/pxe_oracle_interface/tagging_utils.d.ts.map +0 -1
  352. package/dest/pxe_oracle_interface/tagging_utils.js +0 -23
  353. package/dest/pxe_service/error_enriching.d.ts +0 -11
  354. package/dest/pxe_service/error_enriching.d.ts.map +0 -1
  355. package/dest/pxe_service/index.d.ts +0 -3
  356. package/dest/pxe_service/index.d.ts.map +0 -1
  357. package/dest/pxe_service/index.js +0 -2
  358. package/dest/pxe_service/pxe_service.d.ts +0 -111
  359. package/dest/pxe_service/pxe_service.d.ts.map +0 -1
  360. package/dest/pxe_service/pxe_service.js +0 -664
  361. package/dest/storage/address_data_provider/address_data_provider.d.ts +0 -13
  362. package/dest/storage/address_data_provider/address_data_provider.d.ts.map +0 -1
  363. package/dest/storage/address_data_provider/index.d.ts +0 -2
  364. package/dest/storage/address_data_provider/index.d.ts.map +0 -1
  365. package/dest/storage/address_data_provider/index.js +0 -1
  366. package/dest/storage/auth_witness_data_provider/auth_witness_data_provider.d.ts +0 -11
  367. package/dest/storage/auth_witness_data_provider/auth_witness_data_provider.d.ts.map +0 -1
  368. package/dest/storage/auth_witness_data_provider/auth_witness_data_provider.js +0 -20
  369. package/dest/storage/auth_witness_data_provider/index.d.ts +0 -2
  370. package/dest/storage/auth_witness_data_provider/index.d.ts.map +0 -1
  371. package/dest/storage/auth_witness_data_provider/index.js +0 -1
  372. package/dest/storage/capsule_data_provider/capsule_data_provider.d.ts +0 -16
  373. package/dest/storage/capsule_data_provider/capsule_data_provider.d.ts.map +0 -1
  374. package/dest/storage/capsule_data_provider/capsule_data_provider.js +0 -57
  375. package/dest/storage/capsule_data_provider/index.d.ts +0 -2
  376. package/dest/storage/capsule_data_provider/index.d.ts.map +0 -1
  377. package/dest/storage/capsule_data_provider/index.js +0 -1
  378. package/dest/storage/contract_data_provider/contract_data_provider.d.ts +0 -109
  379. package/dest/storage/contract_data_provider/contract_data_provider.d.ts.map +0 -1
  380. package/dest/storage/contract_data_provider/contract_data_provider.js +0 -183
  381. package/dest/storage/contract_data_provider/index.d.ts +0 -3
  382. package/dest/storage/contract_data_provider/index.d.ts.map +0 -1
  383. package/dest/storage/contract_data_provider/index.js +0 -2
  384. package/dest/storage/contract_data_provider/private_functions_tree.d.ts +0 -66
  385. package/dest/storage/contract_data_provider/private_functions_tree.d.ts.map +0 -1
  386. package/dest/storage/contract_data_provider/private_functions_tree.js +0 -99
  387. package/dest/storage/data_provider.d.ts +0 -4
  388. package/dest/storage/data_provider.d.ts.map +0 -1
  389. package/dest/storage/data_provider.js +0 -1
  390. package/dest/storage/note_data_provider/index.d.ts +0 -3
  391. package/dest/storage/note_data_provider/index.d.ts.map +0 -1
  392. package/dest/storage/note_data_provider/index.js +0 -2
  393. package/dest/storage/note_data_provider/note_dao.d.ts +0 -106
  394. package/dest/storage/note_data_provider/note_dao.d.ts.map +0 -1
  395. package/dest/storage/note_data_provider/note_dao.js +0 -106
  396. package/dest/storage/note_data_provider/note_data_provider.d.ts +0 -20
  397. package/dest/storage/note_data_provider/note_data_provider.d.ts.map +0 -1
  398. package/dest/storage/note_data_provider/note_data_provider.js +0 -249
  399. package/dest/storage/sync_data_provider/index.d.ts +0 -2
  400. package/dest/storage/sync_data_provider/index.d.ts.map +0 -1
  401. package/dest/storage/sync_data_provider/index.js +0 -1
  402. package/dest/storage/sync_data_provider/sync_data_provider.d.ts +0 -12
  403. package/dest/storage/sync_data_provider/sync_data_provider.d.ts.map +0 -1
  404. package/dest/storage/tagging_data_provider/index.d.ts +0 -2
  405. package/dest/storage/tagging_data_provider/index.d.ts.map +0 -1
  406. package/dest/storage/tagging_data_provider/index.js +0 -1
  407. package/dest/storage/tagging_data_provider/tagging_data_provider.d.ts +0 -18
  408. package/dest/storage/tagging_data_provider/tagging_data_provider.d.ts.map +0 -1
  409. package/dest/storage/tagging_data_provider/tagging_data_provider.js +0 -65
  410. package/dest/synchronizer/index.d.ts +0 -2
  411. package/dest/synchronizer/index.d.ts.map +0 -1
  412. package/dest/synchronizer/index.js +0 -1
  413. package/dest/synchronizer/synchronizer.d.ts +0 -37
  414. package/dest/synchronizer/synchronizer.d.ts.map +0 -1
  415. package/dest/test/pxe_test_suite.d.ts +0 -3
  416. package/dest/test/pxe_test_suite.d.ts.map +0 -1
  417. package/dest/test/pxe_test_suite.js +0 -97
  418. package/src/bin/index.ts +0 -38
  419. package/src/entrypoints/client/pxe_creation_options.ts +0 -7
  420. package/src/kernel_prover/index.ts +0 -2
  421. package/src/kernel_prover/kernel_prover.ts +0 -351
  422. package/src/note_decryption_utils/add_public_values_to_payload.ts +0 -64
  423. package/src/pxe_http/index.ts +0 -1
  424. package/src/pxe_http/pxe_http_server.ts +0 -29
  425. package/src/pxe_oracle_interface/index.ts +0 -925
  426. package/src/pxe_oracle_interface/tagging_utils.ts +0 -32
  427. package/src/pxe_service/index.ts +0 -2
  428. package/src/pxe_service/pxe_service.ts +0 -949
  429. package/src/storage/address_data_provider/index.ts +0 -1
  430. package/src/storage/auth_witness_data_provider/auth_witness_data_provider.ts +0 -34
  431. package/src/storage/auth_witness_data_provider/index.ts +0 -1
  432. package/src/storage/capsule_data_provider/capsule_data_provider.ts +0 -80
  433. package/src/storage/capsule_data_provider/index.ts +0 -1
  434. package/src/storage/contract_data_provider/contract_data_provider.ts +0 -261
  435. package/src/storage/contract_data_provider/index.ts +0 -2
  436. package/src/storage/contract_data_provider/private_functions_tree.ts +0 -131
  437. package/src/storage/data_provider.ts +0 -3
  438. package/src/storage/note_data_provider/index.ts +0 -2
  439. package/src/storage/note_data_provider/note_dao.ts +0 -162
  440. package/src/storage/sync_data_provider/index.ts +0 -1
  441. package/src/storage/tagging_data_provider/index.ts +0 -1
  442. package/src/storage/tagging_data_provider/tagging_data_provider.ts +0 -92
  443. package/src/synchronizer/index.ts +0 -1
  444. package/src/test/pxe_test_suite.ts +0 -111
  445. /package/dest/entrypoints/{client/pxe_creation_options.js → pxe_creation_options.js} +0 -0
@@ -0,0 +1,430 @@
1
+ import { vkAsFieldsMegaHonk } from '@aztec/foundation/crypto/keys';
2
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
+ import { createLogger } from '@aztec/foundation/log';
4
+ import { pushTestData } from '@aztec/foundation/testing';
5
+ import { Timer } from '@aztec/foundation/timer';
6
+ import { getVKTreeRoot } from '@aztec/noir-protocol-circuits-types/vk-tree';
7
+ import { ProtocolContractsList } from '@aztec/protocol-contracts';
8
+ import { AztecAddress } from '@aztec/stdlib/aztec-address';
9
+ import type { PrivateKernelProver } from '@aztec/stdlib/interfaces/client';
10
+ import {
11
+ HidingKernelToPublicPrivateInputs,
12
+ HidingKernelToRollupPrivateInputs,
13
+ PaddedSideEffectAmounts,
14
+ PrivateCallData,
15
+ type PrivateExecutionStep,
16
+ PrivateKernelCircuitPublicInputs,
17
+ PrivateKernelData,
18
+ type PrivateKernelExecutionProofOutput,
19
+ PrivateKernelInitCircuitPrivateInputs,
20
+ PrivateKernelInnerCircuitPrivateInputs,
21
+ type PrivateKernelSimulateOutput,
22
+ PrivateKernelTailCircuitPrivateInputs,
23
+ type PrivateKernelTailCircuitPublicInputs,
24
+ PrivateVerificationKeyHints,
25
+ } from '@aztec/stdlib/kernel';
26
+ import { ChonkProof, ChonkProofWithPublicInputs } from '@aztec/stdlib/proofs';
27
+ import {
28
+ type PrivateCallExecutionResult,
29
+ type PrivateExecutionResult,
30
+ TxRequest,
31
+ collectNoteHashNullifierCounterMap,
32
+ getFinalMinRevertibleSideEffectCounter,
33
+ } from '@aztec/stdlib/tx';
34
+ import { VerificationKeyAsFields, VerificationKeyData, VkData } from '@aztec/stdlib/vks';
35
+
36
+ import { PrivateKernelResetPrivateInputsBuilder } from './hints/build_private_kernel_reset_private_inputs.js';
37
+ import type { PrivateKernelOracle } from './private_kernel_oracle.js';
38
+
39
+ const NULL_SIMULATE_OUTPUT: PrivateKernelSimulateOutput<PrivateKernelCircuitPublicInputs> = {
40
+ publicInputs: PrivateKernelCircuitPublicInputs.empty(),
41
+ verificationKey: VerificationKeyData.empty(),
42
+ outputWitness: new Map(),
43
+ bytecode: Buffer.from([]),
44
+ };
45
+
46
+ export interface PrivateKernelExecutionProverConfig {
47
+ simulate: boolean;
48
+ skipFeeEnforcement: boolean;
49
+ profileMode: 'gates' | 'execution-steps' | 'full' | 'none';
50
+ }
51
+
52
+ /**
53
+ * The PrivateKernelExecutionProver class is responsible for taking a transaction request and sequencing the
54
+ * the execution of the private functions within, sequenced with private kernel "glue" to check protocol rules.
55
+ * The result can be a chonk proof of the private transaction portion, or just a simulation that can e.g.
56
+ * inform state tree updates.
57
+ */
58
+ export class PrivateKernelExecutionProver {
59
+ private log = createLogger('pxe:private-kernel-execution-prover');
60
+
61
+ constructor(
62
+ private oracle: PrivateKernelOracle,
63
+ private proofCreator: PrivateKernelProver,
64
+ private fakeProofs = false,
65
+ ) {}
66
+
67
+ /**
68
+ * Generate a proof for a given transaction request and execution result.
69
+ * The function iterates through the nested executions in the execution result, creates private call data,
70
+ * and generates a proof using the provided ProofCreator instance. It also maintains an index of new notes
71
+ * created during the execution and returns them as a part of the KernelProverOutput.
72
+ *
73
+ * @param txRequest - The authenticated transaction request object.
74
+ * @param executionResult - The execution result object containing nested executions and preimages.
75
+ * @param profile - Set true to profile the gate count for each circuit
76
+ * @returns A Promise that resolves to a KernelProverOutput object containing proof, public inputs, and output notes.
77
+ */
78
+ async proveWithKernels(
79
+ txRequest: TxRequest,
80
+ executionResult: PrivateExecutionResult,
81
+ { simulate, skipFeeEnforcement, profileMode }: PrivateKernelExecutionProverConfig = {
82
+ simulate: false,
83
+ skipFeeEnforcement: false,
84
+ profileMode: 'none',
85
+ },
86
+ ): Promise<PrivateKernelExecutionProofOutput<PrivateKernelTailCircuitPublicInputs>> {
87
+ const skipProofGeneration = this.fakeProofs || simulate;
88
+ const generateWitnesses = !skipProofGeneration || profileMode !== 'none';
89
+
90
+ const timer = new Timer();
91
+
92
+ const isPrivateOnlyTx = executionResult.publicFunctionCalldata.length === 0;
93
+
94
+ // Initialize an executionStack, beginning with the PrivateCallExecutionResult
95
+ // of the entrypoint function of the tx.
96
+ const executionStack = [executionResult.entrypoint];
97
+ let firstIteration = true;
98
+
99
+ let output = NULL_SIMULATE_OUTPUT;
100
+
101
+ const executionSteps: PrivateExecutionStep[] = [];
102
+
103
+ const noteHashNullifierCounterMap = collectNoteHashNullifierCounterMap(executionResult);
104
+ const minRevertibleSideEffectCounter = getFinalMinRevertibleSideEffectCounter(executionResult);
105
+ const splitCounter = isPrivateOnlyTx ? 0 : minRevertibleSideEffectCounter;
106
+
107
+ while (executionStack.length) {
108
+ if (!firstIteration) {
109
+ let resetBuilder = new PrivateKernelResetPrivateInputsBuilder(
110
+ output,
111
+ executionStack,
112
+ noteHashNullifierCounterMap,
113
+ splitCounter,
114
+ );
115
+ while (resetBuilder.needsReset()) {
116
+ const witgenTimer = new Timer();
117
+ const privateInputs = await resetBuilder.build(this.oracle);
118
+ output = generateWitnesses
119
+ ? await this.proofCreator.generateResetOutput(privateInputs)
120
+ : await this.proofCreator.simulateReset(privateInputs);
121
+ executionSteps.push({
122
+ functionName: 'private_kernel_reset',
123
+ bytecode: output.bytecode,
124
+ witness: output.outputWitness,
125
+ vk: output.verificationKey.keyAsBytes,
126
+ timings: {
127
+ witgen: witgenTimer.ms(),
128
+ },
129
+ });
130
+ resetBuilder = new PrivateKernelResetPrivateInputsBuilder(
131
+ output,
132
+ executionStack,
133
+ noteHashNullifierCounterMap,
134
+ splitCounter,
135
+ );
136
+ }
137
+ }
138
+
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
+ );
147
+
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
+ },
157
+ });
158
+
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
+ firstIteration = false;
214
+ }
215
+
216
+ // Reset.
217
+ let resetBuilder = new PrivateKernelResetPrivateInputsBuilder(
218
+ output,
219
+ [],
220
+ noteHashNullifierCounterMap,
221
+ splitCounter,
222
+ );
223
+ while (resetBuilder.needsReset()) {
224
+ const witgenTimer = new Timer();
225
+ const privateInputs = await resetBuilder.build(this.oracle);
226
+ output = generateWitnesses
227
+ ? await this.proofCreator.generateResetOutput(privateInputs)
228
+ : await this.proofCreator.simulateReset(privateInputs);
229
+
230
+ executionSteps.push({
231
+ functionName: 'private_kernel_reset',
232
+ bytecode: output.bytecode,
233
+ witness: output.outputWitness,
234
+ vk: output.verificationKey.keyAsBytes,
235
+ timings: {
236
+ witgen: witgenTimer.ms(),
237
+ },
238
+ });
239
+
240
+ resetBuilder = new PrivateKernelResetPrivateInputsBuilder(output, [], noteHashNullifierCounterMap, splitCounter);
241
+ }
242
+
243
+ if (output.publicInputs.feePayer.isZero() && skipFeeEnforcement) {
244
+ if (!skipProofGeneration) {
245
+ throw new Error('Fee payment must be enforced when creating real proof.');
246
+ }
247
+ output.publicInputs.feePayer = new AztecAddress(Fr.MAX_FIELD_VALUE);
248
+ }
249
+ // Private tail.
250
+ const vkData = await this.getVkData(output.verificationKey);
251
+ const previousKernelData = new PrivateKernelData(output.publicInputs, vkData);
252
+
253
+ this.log.debug(
254
+ `Calling private kernel tail with hwm ${previousKernelData.publicInputs.minRevertibleSideEffectCounter}`,
255
+ );
256
+
257
+ // TODO: Enable padding once we better understand the final amounts to pad to.
258
+ const paddedSideEffectAmounts = PaddedSideEffectAmounts.empty();
259
+
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
+ }
269
+
270
+ const privateInputs = new PrivateKernelTailCircuitPrivateInputs(
271
+ previousKernelData,
272
+ paddedSideEffectAmounts,
273
+ includeByTimestampUpperBound,
274
+ );
275
+
276
+ const witgenTimer = new Timer();
277
+ const tailOutput = generateWitnesses
278
+ ? await this.proofCreator.generateTailOutput(privateInputs)
279
+ : await this.proofCreator.simulateTail(privateInputs);
280
+
281
+ executionSteps.push({
282
+ functionName: 'private_kernel_tail',
283
+ bytecode: tailOutput.bytecode,
284
+ witness: tailOutput.outputWitness,
285
+ vk: tailOutput.verificationKey.keyAsBytes,
286
+ timings: {
287
+ witgen: witgenTimer.ms(),
288
+ },
289
+ });
290
+
291
+ // Hiding kernel is only executed if we are generating witnesses.
292
+ // For simulation, we can end with the tail, since the Hiding kernel will simply return the same tail output.
293
+ if (generateWitnesses) {
294
+ const previousKernelVkData = await this.getVkData(tailOutput.verificationKey);
295
+
296
+ const witgenTimer = new Timer();
297
+ let hidingOutput: PrivateKernelSimulateOutput<PrivateKernelTailCircuitPublicInputs>;
298
+ if (tailOutput.publicInputs.forPublic) {
299
+ const privateInputs = new HidingKernelToPublicPrivateInputs(
300
+ tailOutput.publicInputs.toPrivateToPublicKernelCircuitPublicInputs(),
301
+ previousKernelVkData,
302
+ );
303
+ hidingOutput = await this.proofCreator.generateHidingToPublicOutput(privateInputs);
304
+ } else {
305
+ const privateInputs = new HidingKernelToRollupPrivateInputs(
306
+ tailOutput.publicInputs.toPrivateToRollupKernelCircuitPublicInputs(),
307
+ previousKernelVkData,
308
+ );
309
+ hidingOutput = await this.proofCreator.generateHidingToRollupOutput(privateInputs);
310
+ }
311
+
312
+ executionSteps.push({
313
+ functionName: 'hiding_kernel',
314
+ bytecode: hidingOutput.bytecode,
315
+ witness: hidingOutput.outputWitness,
316
+ vk: hidingOutput.verificationKey.keyAsBytes,
317
+ timings: {
318
+ witgen: witgenTimer.ms(),
319
+ },
320
+ });
321
+ }
322
+
323
+ if (profileMode == 'gates' || profileMode == 'full') {
324
+ for (const entry of executionSteps) {
325
+ const gateCountTimer = new Timer();
326
+ const gateCount = await this.proofCreator.computeGateCountForCircuit(entry.bytecode, entry.functionName);
327
+ entry.gateCount = gateCount;
328
+ entry.timings.gateCount = gateCountTimer.ms();
329
+ }
330
+ }
331
+ if (profileMode === 'gates') {
332
+ for (const entry of executionSteps) {
333
+ // These buffers are often a few megabytes in size - prevent accidentally serializing them if not requested.
334
+ entry.bytecode = Buffer.from([]);
335
+ entry.witness = new Map();
336
+ }
337
+ }
338
+
339
+ if (generateWitnesses) {
340
+ this.log.info(`Private kernel witness generation took ${timer.ms()}ms`);
341
+ }
342
+
343
+ let chonkProof: ChonkProof;
344
+ // TODO(#7368) how do we 'bincode' encode these inputs?
345
+ let provingTime;
346
+ if (!skipProofGeneration) {
347
+ const provingTimer = new Timer();
348
+ const proofWithPublicInputs = await this.proofCreator.createChonkProof(executionSteps);
349
+ provingTime = provingTimer.ms();
350
+ this.ensurePublicInputsMatch(proofWithPublicInputs, tailOutput.publicInputs);
351
+ chonkProof = proofWithPublicInputs.removePublicInputs();
352
+ } else {
353
+ chonkProof = ChonkProof.random();
354
+ }
355
+
356
+ return {
357
+ publicInputs: tailOutput.publicInputs,
358
+ executionSteps,
359
+ chonkProof,
360
+ timings: provingTime ? { proving: provingTime } : undefined,
361
+ };
362
+ }
363
+
364
+ /**
365
+ * Checks that the public inputs of the chonk proof match the public inputs of the tail circuit.
366
+ * This can only mismatch if there is a circuit / noir / bb bug.
367
+ * @param chonkProof - The chonk proof with public inputs.
368
+ * @param tailPublicInputs - The public inputs resulting from witness generation of the tail circuit.
369
+ */
370
+ private ensurePublicInputsMatch(
371
+ chonkProof: ChonkProofWithPublicInputs,
372
+ tailPublicInputs: PrivateKernelTailCircuitPublicInputs,
373
+ ) {
374
+ const serializedChonkProofPublicInputs = chonkProof.getPublicInputs();
375
+ const serializedTailPublicInputs = tailPublicInputs.publicInputs().toFields();
376
+ if (serializedChonkProofPublicInputs.length !== serializedTailPublicInputs.length) {
377
+ throw new Error(
378
+ `Public inputs length mismatch: ${serializedChonkProofPublicInputs.length} !== ${serializedTailPublicInputs.length}`,
379
+ );
380
+ }
381
+ if (
382
+ !serializedChonkProofPublicInputs.every((input: Fr, index: number) =>
383
+ input.equals(serializedTailPublicInputs[index]),
384
+ )
385
+ ) {
386
+ throw new Error(`Public inputs mismatch between kernel and chonk proof`);
387
+ }
388
+ }
389
+
390
+ private async getVkData(verificationKey: VerificationKeyData) {
391
+ const previousVkMembershipWitness = await this.oracle.getVkMembershipWitness(verificationKey.keyAsFields);
392
+ return new VkData(
393
+ verificationKey,
394
+ Number(previousVkMembershipWitness.leafIndex),
395
+ previousVkMembershipWitness.siblingPath,
396
+ );
397
+ }
398
+
399
+ private async createPrivateCallData({ publicInputs, vk: vkAsBuffer }: PrivateCallExecutionResult) {
400
+ const { contractAddress, functionSelector } = publicInputs.callContext;
401
+
402
+ const vkAsFields = await vkAsFieldsMegaHonk(vkAsBuffer);
403
+ const vk = await VerificationKeyAsFields.fromKey(vkAsFields);
404
+
405
+ const { currentContractClassId, publicKeys, saltedInitializationHash } =
406
+ await this.oracle.getContractAddressPreimage(contractAddress);
407
+ const functionLeafMembershipWitness = await this.oracle.getFunctionMembershipWitness(
408
+ currentContractClassId,
409
+ functionSelector,
410
+ );
411
+
412
+ const { artifactHash: contractClassArtifactHash, publicBytecodeCommitment: contractClassPublicBytecodeCommitment } =
413
+ await this.oracle.getContractClassIdPreimage(currentContractClassId);
414
+
415
+ const updatedClassIdHints = await this.oracle.getUpdatedClassIdHints(contractAddress);
416
+
417
+ return PrivateCallData.from({
418
+ publicInputs,
419
+ vk,
420
+ verificationKeyHints: PrivateVerificationKeyHints.from({
421
+ publicKeys,
422
+ contractClassArtifactHash,
423
+ contractClassPublicBytecodeCommitment,
424
+ saltedInitializationHash,
425
+ functionLeafMembershipWitness,
426
+ updatedClassIdHints,
427
+ }),
428
+ });
429
+ }
430
+ }
@@ -1,6 +1,7 @@
1
- import type { FUNCTION_TREE_HEIGHT, NOTE_HASH_TREE_HEIGHT, VK_TREE_HEIGHT } from '@aztec/constants';
2
- import type { Fr, GrumpkinScalar, Point } from '@aztec/foundation/fields';
3
- import type { MembershipWitness } from '@aztec/foundation/trees';
1
+ import { FUNCTION_TREE_HEIGHT, NOTE_HASH_TREE_HEIGHT, VK_TREE_HEIGHT } from '@aztec/constants';
2
+ import type { Fr } from '@aztec/foundation/curves/bn254';
3
+ import type { GrumpkinScalar, Point } from '@aztec/foundation/curves/grumpkin';
4
+ import { MembershipWitness } from '@aztec/foundation/trees';
4
5
  import type { FunctionSelector } from '@aztec/stdlib/abi';
5
6
  import type { AztecAddress } from '@aztec/stdlib/aztec-address';
6
7
  import { UpdatedClassIdHints } from '@aztec/stdlib/kernel';
@@ -9,10 +10,10 @@ import type { NullifierMembershipWitness } from '@aztec/stdlib/trees';
9
10
  import type { VerificationKeyAsFields } from '@aztec/stdlib/vks';
10
11
 
11
12
  /**
12
- * Provides functionality to fetch membership witnesses for verification keys,
13
- * contract addresses, and function selectors in their respective merkle trees.
13
+ * Provides functionality needed by the private kernel for interacting with our state trees.
14
+ * This is either PrivateKernelOracleImpl, or a mocked test implementation.
14
15
  */
15
- export interface ProvingDataOracle {
16
+ export interface PrivateKernelOracle {
16
17
  /** Retrieves the preimage of a contract address from the registered contract instances db. */
17
18
  getContractAddressPreimage(address: AztecAddress): Promise<{
18
19
  saltedInitializationHash: Fr;
@@ -27,13 +28,7 @@ export interface ProvingDataOracle {
27
28
  ): Promise<{ artifactHash: Fr; publicBytecodeCommitment: Fr; privateFunctionsRoot: Fr }>;
28
29
 
29
30
  /**
30
- * Retrieve the function membership witness for the given contract class and function selector.
31
- * The function membership witness represents a proof that the function belongs to the specified contract.
32
- * Throws an error if the contract address or function selector is unknown.
33
- *
34
- * @param contractClassId - The id of the class.
35
- * @param selector - The function selector.
36
- * @returns A promise that resolves with the MembershipWitness instance for the specified contract's function.
31
+ * Returns a membership witness with the sibling path and leaf index in our private functions tree.
37
32
  */
38
33
  getFunctionMembershipWitness(
39
34
  contractClassId: Fr,
@@ -41,30 +36,22 @@ export interface ProvingDataOracle {
41
36
  ): Promise<MembershipWitness<typeof FUNCTION_TREE_HEIGHT>>;
42
37
 
43
38
  /**
44
- * Retrieve the membership witness corresponding to a verification key.
45
- * This function currently returns a random membership witness of the specified height,
46
- * which is a placeholder implementation until a concrete membership witness calculation
47
- * is implemented.
48
- *
49
- * @param vk - The VerificationKey for which the membership witness is needed.
50
- * @returns A Promise that resolves to the MembershipWitness instance.
39
+ * Returns a membership witness with the sibling path and leaf index in our protocol VK indexed merkle tree.
40
+ * Used to validate the previous kernel's verification key.
51
41
  */
52
42
  getVkMembershipWitness(vk: VerificationKeyAsFields): Promise<MembershipWitness<typeof VK_TREE_HEIGHT>>;
53
43
 
54
44
  /**
55
- * Get the note membership witness for a note in the note hash tree at the given leaf index.
56
- *
57
- * @param leafIndex - The leaf index of the note in the note hash tree.
58
- * @returns the MembershipWitness for the note.
45
+ * Returns a membership witness with the sibling path and leaf index in our private function indexed merkle tree.
59
46
  */
60
- getNoteHashMembershipWitness(leafIndex: bigint): Promise<MembershipWitness<typeof NOTE_HASH_TREE_HEIGHT>>;
47
+ getNoteHashMembershipWitness(noteHash: Fr): Promise<MembershipWitness<typeof NOTE_HASH_TREE_HEIGHT> | undefined>;
61
48
 
49
+ /**
50
+ * Returns a membership witness with the sibling path and leaf index in our nullifier indexed merkle tree.
51
+ */
62
52
  getNullifierMembershipWitness(nullifier: Fr): Promise<NullifierMembershipWitness | undefined>;
63
-
64
53
  /**
65
- * Get the root of the note hash tree.
66
- *
67
- * @returns the root of the note hash tree.
54
+ * Returns the root of our note hash merkle tree.
68
55
  */
69
56
  getNoteHashTreeRoot(): Promise<Fr>;
70
57
 
@@ -77,7 +64,10 @@ export interface ProvingDataOracle {
77
64
  */
78
65
  getMasterSecretKey(masterPublicKey: Point): Promise<GrumpkinScalar>;
79
66
 
67
+ /** Use debug data to get the function name corresponding to a selector. */
80
68
  getDebugFunctionName(contractAddress: AztecAddress, selector: FunctionSelector): Promise<string | undefined>;
81
69
 
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. */
82
72
  getUpdatedClassIdHints(contractAddress: AztecAddress): Promise<UpdatedClassIdHints>;
83
73
  }
@@ -1,41 +1,45 @@
1
- import { type NOTE_HASH_TREE_HEIGHT, PUBLIC_DATA_TREE_HEIGHT, VK_TREE_HEIGHT } from '@aztec/constants';
2
- import type { Fr, GrumpkinScalar, Point } from '@aztec/foundation/fields';
1
+ import { NOTE_HASH_TREE_HEIGHT, PUBLIC_DATA_TREE_HEIGHT, VK_TREE_HEIGHT } from '@aztec/constants';
2
+ import type { Fr } from '@aztec/foundation/curves/bn254';
3
+ import type { GrumpkinScalar, Point } from '@aztec/foundation/curves/grumpkin';
3
4
  import { createLogger } from '@aztec/foundation/log';
4
- import type { Tuple } from '@aztec/foundation/serialize';
5
5
  import { MembershipWitness } from '@aztec/foundation/trees';
6
6
  import type { KeyStore } from '@aztec/key-store';
7
7
  import { getVKIndex, getVKSiblingPath } from '@aztec/noir-protocol-circuits-types/vk-tree';
8
8
  import { ProtocolContractAddress } from '@aztec/protocol-contracts';
9
9
  import type { FunctionSelector } from '@aztec/stdlib/abi';
10
10
  import type { AztecAddress } from '@aztec/stdlib/aztec-address';
11
- import type { L2BlockNumber } from '@aztec/stdlib/block';
11
+ import type { BlockParameter } from '@aztec/stdlib/block';
12
12
  import { computeContractClassIdPreimage, computeSaltedInitializationHash } from '@aztec/stdlib/contract';
13
+ import { DelayedPublicMutableValues, DelayedPublicMutableValuesWithHash } from '@aztec/stdlib/delayed-public-mutable';
13
14
  import { computePublicDataTreeLeafSlot } from '@aztec/stdlib/hash';
14
15
  import type { AztecNode } from '@aztec/stdlib/interfaces/client';
15
16
  import { UpdatedClassIdHints } from '@aztec/stdlib/kernel';
16
- import { SharedMutableValues, SharedMutableValuesWithHash } from '@aztec/stdlib/shared-mutable';
17
17
  import type { NullifierMembershipWitness } from '@aztec/stdlib/trees';
18
18
  import type { VerificationKeyAsFields } from '@aztec/stdlib/vks';
19
19
 
20
- import type { ContractDataProvider } from '../storage/contract_data_provider/contract_data_provider.js';
21
- import type { ProvingDataOracle } from './../kernel_prover/proving_data_oracle.js';
20
+ import type { ContractStore } from '../storage/contract_store/contract_store.js';
21
+ import type { PrivateKernelOracle } from './private_kernel_oracle.js';
22
22
 
23
23
  // TODO: Block number should not be "latest".
24
24
  // It should be fixed at the time the proof is being simulated. I.e., it should be the same as the value defined in the constant data.
25
+
25
26
  /**
26
27
  * A data oracle that provides information needed for simulating a transaction.
27
28
  */
28
- export class KernelOracle implements ProvingDataOracle {
29
+ export class PrivateKernelOracleImpl implements PrivateKernelOracle {
29
30
  constructor(
30
- private contractDataProvider: ContractDataProvider,
31
+ private contractStore: ContractStore,
31
32
  private keyStore: KeyStore,
32
33
  private node: AztecNode,
33
- private blockNumber: L2BlockNumber = 'latest',
34
+ private blockNumber: BlockParameter = 'latest',
34
35
  private log = createLogger('pxe:kernel_oracle'),
35
36
  ) {}
36
37
 
37
38
  public async getContractAddressPreimage(address: AztecAddress) {
38
- const instance = await this.contractDataProvider.getContractInstance(address);
39
+ const instance = await this.contractStore.getContractInstance(address);
40
+ if (!instance) {
41
+ throw new Error(`Contract instance not found when getting address preimage. Contract address: ${address}.`);
42
+ }
39
43
  return {
40
44
  saltedInitializationHash: await computeSaltedInitializationHash(instance),
41
45
  ...instance,
@@ -43,12 +47,21 @@ export class KernelOracle implements ProvingDataOracle {
43
47
  }
44
48
 
45
49
  public async getContractClassIdPreimage(contractClassId: Fr) {
46
- const contractClass = await this.contractDataProvider.getContractClass(contractClassId);
50
+ const contractClass = await this.contractStore.getContractClass(contractClassId);
51
+ if (!contractClass) {
52
+ throw new Error(`Contract class not found when getting class id preimage. Class id: ${contractClassId}.`);
53
+ }
47
54
  return computeContractClassIdPreimage(contractClass);
48
55
  }
49
56
 
50
57
  public async getFunctionMembershipWitness(contractClassId: Fr, selector: FunctionSelector) {
51
- return await this.contractDataProvider.getFunctionMembershipWitness(contractClassId, selector);
58
+ const membershipWitness = await this.contractStore.getFunctionMembershipWitness(contractClassId, selector);
59
+ if (!membershipWitness) {
60
+ throw new Error(
61
+ `Membership witness not found for contract class id ${contractClassId} and selector ${selector}.`,
62
+ );
63
+ }
64
+ return membershipWitness;
52
65
  }
53
66
 
54
67
  public getVkMembershipWitness(vk: VerificationKeyAsFields) {
@@ -56,13 +69,8 @@ export class KernelOracle implements ProvingDataOracle {
56
69
  return Promise.resolve(new MembershipWitness(VK_TREE_HEIGHT, BigInt(leafIndex), getVKSiblingPath(leafIndex)));
57
70
  }
58
71
 
59
- async getNoteHashMembershipWitness(leafIndex: bigint): Promise<MembershipWitness<typeof NOTE_HASH_TREE_HEIGHT>> {
60
- const path = await this.node.getNoteHashSiblingPath(this.blockNumber, leafIndex);
61
- return new MembershipWitness<typeof NOTE_HASH_TREE_HEIGHT>(
62
- path.pathSize,
63
- leafIndex,
64
- path.toFields() as Tuple<Fr, typeof NOTE_HASH_TREE_HEIGHT>,
65
- );
72
+ getNoteHashMembershipWitness(noteHash: Fr): Promise<MembershipWitness<typeof NOTE_HASH_TREE_HEIGHT> | undefined> {
73
+ return this.node.getNoteHashMembershipWitness(this.blockNumber, noteHash);
66
74
  }
67
75
 
68
76
  getNullifierMembershipWitness(nullifier: Fr): Promise<NullifierMembershipWitness | undefined> {
@@ -82,27 +90,29 @@ export class KernelOracle implements ProvingDataOracle {
82
90
  }
83
91
 
84
92
  public getDebugFunctionName(contractAddress: AztecAddress, selector: FunctionSelector): Promise<string> {
85
- return this.contractDataProvider.getDebugFunctionName(contractAddress, selector);
93
+ return this.contractStore.getDebugFunctionName(contractAddress, selector);
86
94
  }
87
95
 
88
96
  public async getUpdatedClassIdHints(contractAddress: AztecAddress): Promise<UpdatedClassIdHints> {
89
- const { sharedMutableSlot, sharedMutableHashSlot } = await SharedMutableValuesWithHash.getContractUpdateSlots(
90
- contractAddress,
91
- );
97
+ const { delayedPublicMutableSlot, delayedPublicMutableHashSlot } =
98
+ await DelayedPublicMutableValuesWithHash.getContractUpdateSlots(contractAddress);
92
99
 
93
100
  const hashLeafSlot = await computePublicDataTreeLeafSlot(
94
- ProtocolContractAddress.ContractInstanceDeployer,
95
- sharedMutableHashSlot,
101
+ ProtocolContractAddress.ContractInstanceRegistry,
102
+ delayedPublicMutableHashSlot,
96
103
  );
97
- const updatedClassIdWitness = await this.node.getPublicDataTreeWitness(this.blockNumber, hashLeafSlot);
104
+ const updatedClassIdWitness = await this.node.getPublicDataWitness(this.blockNumber, hashLeafSlot);
98
105
 
99
106
  if (!updatedClassIdWitness) {
100
107
  throw new Error(`No public data tree witness found for ${hashLeafSlot}`);
101
108
  }
102
109
 
103
110
  const readStorage = (storageSlot: Fr) =>
104
- this.node.getPublicStorageAt(this.blockNumber, ProtocolContractAddress.ContractInstanceDeployer, storageSlot);
105
- const sharedMutableValues = await SharedMutableValues.readFromTree(sharedMutableSlot, readStorage);
111
+ this.node.getPublicStorageAt(this.blockNumber, ProtocolContractAddress.ContractInstanceRegistry, storageSlot);
112
+ const delayedPublicMutableValues = await DelayedPublicMutableValues.readFromTree(
113
+ delayedPublicMutableSlot,
114
+ readStorage,
115
+ );
106
116
 
107
117
  return new UpdatedClassIdHints(
108
118
  new MembershipWitness(
@@ -111,7 +121,7 @@ export class KernelOracle implements ProvingDataOracle {
111
121
  updatedClassIdWitness.siblingPath.toTuple(),
112
122
  ),
113
123
  updatedClassIdWitness.leafPreimage,
114
- sharedMutableValues,
124
+ delayedPublicMutableValues,
115
125
  );
116
126
  }
117
127
  }