@aztec/pxe 0.0.1-commit.9593d84 → 0.0.1-commit.967fc6998

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 (413) hide show
  1. package/dest/access_scopes.d.ts +9 -0
  2. package/dest/access_scopes.d.ts.map +1 -0
  3. package/dest/access_scopes.js +6 -0
  4. package/dest/bin/check_oracle_version.js +105 -15
  5. package/dest/block_synchronizer/block_synchronizer.d.ts +45 -0
  6. package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -0
  7. package/dest/block_synchronizer/block_synchronizer.js +153 -0
  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 +6 -4
  12. package/dest/config/index.d.ts.map +1 -1
  13. package/dest/config/index.js +17 -0
  14. package/dest/config/package_info.js +1 -1
  15. package/dest/contract_function_simulator/benchmarked_node.d.ts +9 -0
  16. package/dest/contract_function_simulator/benchmarked_node.d.ts.map +1 -0
  17. package/dest/contract_function_simulator/benchmarked_node.js +77 -0
  18. package/dest/contract_function_simulator/contract_function_simulator.d.ts +76 -24
  19. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
  20. package/dest/contract_function_simulator/contract_function_simulator.js +220 -75
  21. package/dest/contract_function_simulator/execution_note_cache.d.ts +21 -11
  22. package/dest/contract_function_simulator/execution_note_cache.d.ts.map +1 -1
  23. package/dest/contract_function_simulator/execution_note_cache.js +49 -31
  24. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +6 -6
  25. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -1
  26. package/dest/contract_function_simulator/execution_tagging_index_cache.js +4 -4
  27. package/dest/contract_function_simulator/hashed_values_cache.d.ts +2 -2
  28. package/dest/contract_function_simulator/hashed_values_cache.d.ts.map +1 -1
  29. package/dest/contract_function_simulator/index.d.ts +2 -2
  30. package/dest/contract_function_simulator/index.d.ts.map +1 -1
  31. package/dest/contract_function_simulator/index.js +1 -1
  32. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +5 -4
  33. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts.map +1 -1
  34. package/dest/contract_function_simulator/noir-structs/event_validation_request.js +7 -4
  35. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts +5 -4
  36. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts.map +1 -1
  37. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.js +7 -6
  38. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts +2 -2
  39. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts.map +1 -1
  40. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.js +1 -1
  41. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +6 -5
  42. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
  43. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +7 -4
  44. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts +4 -10
  45. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts.map +1 -1
  46. package/dest/contract_function_simulator/noir-structs/utility_context.js +7 -18
  47. package/dest/contract_function_simulator/oracle/interfaces.d.ts +27 -20
  48. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
  49. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts +4 -2
  50. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts.map +1 -1
  51. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.js +1 -1
  52. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts +11 -7
  53. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts.map +1 -1
  54. package/dest/contract_function_simulator/oracle/note_packing_utils.js +14 -10
  55. package/dest/contract_function_simulator/oracle/oracle.d.ts +13 -11
  56. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
  57. package/dest/contract_function_simulator/oracle/oracle.js +86 -51
  58. package/dest/contract_function_simulator/oracle/private_execution.d.ts +2 -27
  59. package/dest/contract_function_simulator/oracle/private_execution.d.ts.map +1 -1
  60. package/dest/contract_function_simulator/oracle/private_execution.js +2 -38
  61. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +54 -45
  62. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
  63. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +108 -65
  64. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +114 -38
  65. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
  66. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +214 -86
  67. package/dest/contract_function_simulator/pick_notes.d.ts +2 -2
  68. package/dest/contract_function_simulator/pick_notes.d.ts.map +1 -1
  69. package/dest/contract_function_simulator/pick_notes.js +1 -1
  70. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts +4 -4
  71. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts.map +1 -1
  72. package/dest/contract_function_simulator/proxied_contract_data_source.js +23 -5
  73. package/dest/contract_logging.d.ts +22 -0
  74. package/dest/contract_logging.d.ts.map +1 -0
  75. package/dest/contract_logging.js +23 -0
  76. package/dest/contract_sync/contract_sync_service.d.ts +43 -0
  77. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -0
  78. package/dest/contract_sync/contract_sync_service.js +97 -0
  79. package/dest/contract_sync/helpers.d.ts +29 -0
  80. package/dest/contract_sync/helpers.d.ts.map +1 -0
  81. package/dest/contract_sync/helpers.js +55 -0
  82. package/dest/debug/pxe_debug_utils.d.ts +45 -0
  83. package/dest/debug/pxe_debug_utils.d.ts.map +1 -0
  84. package/dest/debug/pxe_debug_utils.js +48 -0
  85. package/dest/entrypoints/client/bundle/index.d.ts +4 -2
  86. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  87. package/dest/entrypoints/client/bundle/index.js +3 -1
  88. package/dest/entrypoints/client/bundle/utils.d.ts +1 -1
  89. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  90. package/dest/entrypoints/client/bundle/utils.js +32 -9
  91. package/dest/entrypoints/client/lazy/index.d.ts +4 -2
  92. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  93. package/dest/entrypoints/client/lazy/index.js +3 -1
  94. package/dest/entrypoints/client/lazy/utils.d.ts +2 -2
  95. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  96. package/dest/entrypoints/client/lazy/utils.js +33 -10
  97. package/dest/entrypoints/pxe_creation_options.d.ts +7 -3
  98. package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
  99. package/dest/entrypoints/server/index.d.ts +6 -2
  100. package/dest/entrypoints/server/index.d.ts.map +1 -1
  101. package/dest/entrypoints/server/index.js +5 -1
  102. package/dest/entrypoints/server/utils.d.ts +1 -1
  103. package/dest/entrypoints/server/utils.d.ts.map +1 -1
  104. package/dest/entrypoints/server/utils.js +39 -16
  105. package/dest/error_enriching.d.ts +4 -4
  106. package/dest/error_enriching.d.ts.map +1 -1
  107. package/dest/error_enriching.js +6 -6
  108. package/dest/events/event_service.d.ts +15 -0
  109. package/dest/events/event_service.d.ts.map +1 -0
  110. package/dest/events/event_service.js +44 -0
  111. package/dest/events/index.d.ts +2 -0
  112. package/dest/events/index.d.ts.map +1 -0
  113. package/dest/events/index.js +1 -0
  114. package/dest/events/private_event_filter_validator.d.ts +9 -0
  115. package/dest/events/private_event_filter_validator.d.ts.map +1 -0
  116. package/dest/events/private_event_filter_validator.js +38 -0
  117. package/dest/job_coordinator/job_coordinator.d.ts +75 -0
  118. package/dest/job_coordinator/job_coordinator.d.ts.map +1 -0
  119. package/dest/job_coordinator/job_coordinator.js +94 -0
  120. package/dest/logs/log_service.d.ts +29 -0
  121. package/dest/logs/log_service.d.ts.map +1 -0
  122. package/dest/logs/log_service.js +118 -0
  123. package/dest/notes/index.d.ts +2 -0
  124. package/dest/notes/index.d.ts.map +1 -0
  125. package/dest/notes/index.js +1 -0
  126. package/dest/notes/note_service.d.ts +49 -0
  127. package/dest/notes/note_service.d.ts.map +1 -0
  128. package/dest/notes/note_service.js +148 -0
  129. package/dest/notes_filter.d.ts +25 -0
  130. package/dest/notes_filter.d.ts.map +1 -0
  131. package/dest/notes_filter.js +4 -0
  132. package/dest/oracle_version.d.ts +3 -3
  133. package/dest/oracle_version.d.ts.map +1 -1
  134. package/dest/oracle_version.js +4 -3
  135. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
  136. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
  137. package/dest/private_kernel/hints/{compute_tx_include_by_timestamp.js → compute_tx_expiration_timestamp.js} +12 -12
  138. package/dest/private_kernel/hints/index.d.ts +3 -3
  139. package/dest/private_kernel/hints/index.d.ts.map +1 -1
  140. package/dest/private_kernel/hints/index.js +2 -2
  141. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +29 -0
  142. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -0
  143. package/dest/private_kernel/hints/{build_private_kernel_reset_private_inputs.js → private_kernel_reset_private_inputs_builder.js} +141 -74
  144. package/dest/private_kernel/hints/test_utils.d.ts +122 -0
  145. package/dest/private_kernel/hints/test_utils.d.ts.map +1 -0
  146. package/dest/private_kernel/hints/test_utils.js +203 -0
  147. package/dest/private_kernel/private_kernel_execution_prover.d.ts +3 -2
  148. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
  149. package/dest/private_kernel/private_kernel_execution_prover.js +28 -21
  150. package/dest/private_kernel/private_kernel_oracle.d.ts +26 -25
  151. package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
  152. package/dest/private_kernel/private_kernel_oracle.js +94 -2
  153. package/dest/pxe.d.ts +114 -103
  154. package/dest/pxe.d.ts.map +1 -1
  155. package/dest/pxe.js +263 -256
  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} +13 -12
  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 +17 -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} +10 -10
  165. package/dest/storage/{sync_data_provider → anchor_block_store}/index.d.ts +2 -2
  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 +72 -0
  169. package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -0
  170. package/dest/storage/capsule_store/capsule_store.js +253 -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 +93 -0
  175. package/dest/storage/contract_store/contract_store.d.ts.map +1 -0
  176. package/dest/storage/contract_store/contract_store.js +309 -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_data_provider → contract_store}/private_functions_tree.d.ts +1 -1
  181. package/dest/storage/contract_store/private_functions_tree.d.ts.map +1 -0
  182. package/dest/storage/{contract_data_provider → contract_store}/private_functions_tree.js +1 -1
  183. package/dest/storage/index.d.ts +8 -8
  184. package/dest/storage/index.d.ts.map +1 -1
  185. package/dest/storage/index.js +7 -7
  186. package/dest/storage/metadata.d.ts +1 -1
  187. package/dest/storage/metadata.js +1 -1
  188. package/dest/storage/note_store/index.d.ts +3 -0
  189. package/dest/storage/note_store/index.d.ts.map +1 -0
  190. package/dest/storage/note_store/index.js +2 -0
  191. package/dest/storage/note_store/note_store.d.ts +83 -0
  192. package/dest/storage/note_store/note_store.d.ts.map +1 -0
  193. package/dest/storage/note_store/note_store.js +343 -0
  194. package/dest/storage/note_store/stored_note.d.ts +16 -0
  195. package/dest/storage/note_store/stored_note.d.ts.map +1 -0
  196. package/dest/storage/note_store/stored_note.js +43 -0
  197. package/dest/storage/private_event_store/private_event_store.d.ts +91 -0
  198. package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -0
  199. package/dest/storage/private_event_store/private_event_store.js +273 -0
  200. package/dest/storage/private_event_store/stored_private_event.d.ts +23 -0
  201. package/dest/storage/private_event_store/stored_private_event.d.ts.map +1 -0
  202. package/dest/storage/private_event_store/stored_private_event.js +56 -0
  203. package/dest/storage/tagging_store/index.d.ts +4 -0
  204. package/dest/storage/tagging_store/index.d.ts.map +1 -0
  205. package/dest/storage/tagging_store/index.js +3 -0
  206. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +28 -0
  207. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -0
  208. package/dest/storage/tagging_store/recipient_tagging_store.js +111 -0
  209. package/dest/storage/tagging_store/sender_address_book_store.d.ts +14 -0
  210. package/dest/storage/tagging_store/sender_address_book_store.d.ts.map +1 -0
  211. package/dest/storage/tagging_store/sender_address_book_store.js +36 -0
  212. package/dest/storage/tagging_store/sender_tagging_store.d.ts +77 -0
  213. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -0
  214. package/dest/storage/tagging_store/sender_tagging_store.js +348 -0
  215. package/dest/tagging/constants.d.ts +2 -2
  216. package/dest/tagging/constants.d.ts.map +1 -1
  217. package/dest/tagging/constants.js +10 -2
  218. package/dest/tagging/get_all_logs_by_tags.d.ts +24 -0
  219. package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -0
  220. package/dest/tagging/get_all_logs_by_tags.js +60 -0
  221. package/dest/tagging/index.d.ts +16 -6
  222. package/dest/tagging/index.d.ts.map +1 -1
  223. package/dest/tagging/index.js +15 -5
  224. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +14 -0
  225. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +1 -0
  226. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +99 -0
  227. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts +12 -0
  228. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts.map +1 -0
  229. package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +20 -0
  230. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +14 -0
  231. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +1 -0
  232. package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +33 -0
  233. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +17 -0
  234. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -0
  235. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +71 -0
  236. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +11 -0
  237. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -0
  238. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +29 -0
  239. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +18 -0
  240. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -0
  241. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +59 -0
  242. package/package.json +28 -19
  243. package/src/access_scopes.ts +9 -0
  244. package/src/bin/check_oracle_version.ts +131 -20
  245. package/src/block_synchronizer/block_synchronizer.ts +178 -0
  246. package/src/block_synchronizer/index.ts +1 -0
  247. package/src/config/index.ts +17 -3
  248. package/src/config/package_info.ts +1 -1
  249. package/src/contract_function_simulator/benchmarked_node.ts +103 -0
  250. package/src/contract_function_simulator/contract_function_simulator.ts +382 -107
  251. package/src/contract_function_simulator/execution_note_cache.ts +51 -28
  252. package/src/contract_function_simulator/execution_tagging_index_cache.ts +6 -6
  253. package/src/contract_function_simulator/hashed_values_cache.ts +1 -1
  254. package/src/contract_function_simulator/index.ts +1 -1
  255. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +7 -3
  256. package/src/contract_function_simulator/noir-structs/log_retrieval_request.ts +6 -5
  257. package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +1 -1
  258. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +6 -3
  259. package/src/contract_function_simulator/noir-structs/utility_context.ts +6 -25
  260. package/src/contract_function_simulator/oracle/interfaces.ts +32 -17
  261. package/src/contract_function_simulator/oracle/message_load_oracle_inputs.ts +1 -1
  262. package/src/contract_function_simulator/oracle/note_packing_utils.ts +27 -13
  263. package/src/contract_function_simulator/oracle/oracle.ts +101 -47
  264. package/src/contract_function_simulator/oracle/private_execution.ts +2 -68
  265. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +157 -97
  266. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +350 -91
  267. package/src/contract_function_simulator/pick_notes.ts +1 -1
  268. package/src/contract_function_simulator/proxied_contract_data_source.ts +24 -7
  269. package/src/contract_logging.ts +39 -0
  270. package/src/contract_sync/contract_sync_service.ts +152 -0
  271. package/src/contract_sync/helpers.ts +98 -0
  272. package/src/debug/pxe_debug_utils.ts +93 -0
  273. package/src/entrypoints/client/bundle/index.ts +3 -1
  274. package/src/entrypoints/client/bundle/utils.ts +24 -17
  275. package/src/entrypoints/client/lazy/index.ts +3 -1
  276. package/src/entrypoints/client/lazy/utils.ts +25 -18
  277. package/src/entrypoints/pxe_creation_options.ts +6 -2
  278. package/src/entrypoints/server/index.ts +5 -1
  279. package/src/entrypoints/server/utils.ts +33 -41
  280. package/src/error_enriching.ts +7 -15
  281. package/src/events/event_service.ts +71 -0
  282. package/src/events/index.ts +1 -0
  283. package/src/events/private_event_filter_validator.ts +46 -0
  284. package/src/job_coordinator/job_coordinator.ts +150 -0
  285. package/src/logs/log_service.ts +213 -0
  286. package/src/notes/index.ts +1 -0
  287. package/src/notes/note_service.ts +196 -0
  288. package/src/notes_filter.ts +26 -0
  289. package/src/oracle_version.ts +4 -3
  290. package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
  291. package/src/private_kernel/hints/index.ts +2 -2
  292. package/src/private_kernel/hints/{build_private_kernel_reset_private_inputs.ts → private_kernel_reset_private_inputs_builder.ts} +197 -139
  293. package/src/private_kernel/hints/test_utils.ts +325 -0
  294. package/src/private_kernel/private_kernel_execution_prover.ts +32 -23
  295. package/src/private_kernel/private_kernel_oracle.ts +118 -37
  296. package/src/pxe.ts +403 -347
  297. package/src/storage/{address_data_provider/address_data_provider.ts → address_store/address_store.ts} +16 -16
  298. package/src/storage/address_store/index.ts +1 -0
  299. package/src/storage/{sync_data_provider/sync_data_provider.ts → anchor_block_store/anchor_block_store.ts} +10 -11
  300. package/src/storage/anchor_block_store/index.ts +1 -0
  301. package/src/storage/capsule_store/capsule_store.ts +315 -0
  302. package/src/storage/capsule_store/index.ts +1 -0
  303. package/src/storage/contract_store/contract_store.ts +429 -0
  304. package/src/storage/contract_store/index.ts +1 -0
  305. package/src/storage/{contract_data_provider → contract_store}/private_functions_tree.ts +1 -1
  306. package/src/storage/index.ts +7 -7
  307. package/src/storage/metadata.ts +1 -1
  308. package/src/storage/note_store/index.ts +2 -0
  309. package/src/storage/note_store/note_store.ts +418 -0
  310. package/src/storage/note_store/stored_note.ts +48 -0
  311. package/src/storage/private_event_store/private_event_store.ts +384 -0
  312. package/src/storage/private_event_store/stored_private_event.ts +73 -0
  313. package/src/storage/tagging_store/index.ts +3 -0
  314. package/src/storage/tagging_store/recipient_tagging_store.ts +143 -0
  315. package/src/storage/tagging_store/sender_address_book_store.ts +48 -0
  316. package/src/storage/tagging_store/sender_tagging_store.ts +429 -0
  317. package/src/tagging/constants.ts +10 -2
  318. package/src/tagging/get_all_logs_by_tags.ts +92 -0
  319. package/src/tagging/index.ts +18 -5
  320. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +140 -0
  321. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +34 -0
  322. package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +44 -0
  323. package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +94 -0
  324. package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +36 -0
  325. package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +75 -0
  326. package/dest/contract_function_simulator/execution_data_provider.d.ts +0 -265
  327. package/dest/contract_function_simulator/execution_data_provider.d.ts.map +0 -1
  328. package/dest/contract_function_simulator/execution_data_provider.js +0 -14
  329. package/dest/contract_function_simulator/proxied_node.d.ts +0 -9
  330. package/dest/contract_function_simulator/proxied_node.d.ts.map +0 -1
  331. package/dest/contract_function_simulator/proxied_node.js +0 -27
  332. package/dest/contract_function_simulator/pxe_oracle_interface.d.ts +0 -122
  333. package/dest/contract_function_simulator/pxe_oracle_interface.d.ts.map +0 -1
  334. package/dest/contract_function_simulator/pxe_oracle_interface.js +0 -694
  335. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts +0 -28
  336. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts.map +0 -1
  337. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts +0 -4
  338. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts.map +0 -1
  339. package/dest/private_kernel/private_kernel_oracle_impl.d.ts +0 -45
  340. package/dest/private_kernel/private_kernel_oracle_impl.d.ts.map +0 -1
  341. package/dest/private_kernel/private_kernel_oracle_impl.js +0 -86
  342. package/dest/storage/address_data_provider/address_data_provider.d.ts +0 -11
  343. package/dest/storage/address_data_provider/address_data_provider.d.ts.map +0 -1
  344. package/dest/storage/address_data_provider/index.d.ts +0 -2
  345. package/dest/storage/address_data_provider/index.d.ts.map +0 -1
  346. package/dest/storage/address_data_provider/index.js +0 -1
  347. package/dest/storage/capsule_data_provider/capsule_data_provider.d.ts +0 -25
  348. package/dest/storage/capsule_data_provider/capsule_data_provider.d.ts.map +0 -1
  349. package/dest/storage/capsule_data_provider/capsule_data_provider.js +0 -118
  350. package/dest/storage/capsule_data_provider/index.d.ts +0 -2
  351. package/dest/storage/capsule_data_provider/index.d.ts.map +0 -1
  352. package/dest/storage/capsule_data_provider/index.js +0 -1
  353. package/dest/storage/contract_data_provider/contract_data_provider.d.ts +0 -64
  354. package/dest/storage/contract_data_provider/contract_data_provider.d.ts.map +0 -1
  355. package/dest/storage/contract_data_provider/contract_data_provider.js +0 -193
  356. package/dest/storage/contract_data_provider/index.d.ts +0 -2
  357. package/dest/storage/contract_data_provider/index.d.ts.map +0 -1
  358. package/dest/storage/contract_data_provider/index.js +0 -1
  359. package/dest/storage/contract_data_provider/private_functions_tree.d.ts.map +0 -1
  360. package/dest/storage/note_data_provider/index.d.ts +0 -3
  361. package/dest/storage/note_data_provider/index.d.ts.map +0 -1
  362. package/dest/storage/note_data_provider/index.js +0 -2
  363. package/dest/storage/note_data_provider/note_data_provider.d.ts +0 -83
  364. package/dest/storage/note_data_provider/note_data_provider.d.ts.map +0 -1
  365. package/dest/storage/note_data_provider/note_data_provider.js +0 -311
  366. package/dest/storage/private_event_data_provider/private_event_data_provider.d.ts +0 -37
  367. package/dest/storage/private_event_data_provider/private_event_data_provider.d.ts.map +0 -1
  368. package/dest/storage/private_event_data_provider/private_event_data_provider.js +0 -105
  369. package/dest/storage/sync_data_provider/index.d.ts.map +0 -1
  370. package/dest/storage/sync_data_provider/index.js +0 -1
  371. package/dest/storage/sync_data_provider/sync_data_provider.d.ts +0 -10
  372. package/dest/storage/sync_data_provider/sync_data_provider.d.ts.map +0 -1
  373. package/dest/storage/tagging_data_provider/index.d.ts +0 -2
  374. package/dest/storage/tagging_data_provider/index.d.ts.map +0 -1
  375. package/dest/storage/tagging_data_provider/index.js +0 -1
  376. package/dest/storage/tagging_data_provider/tagging_data_provider.d.ts +0 -40
  377. package/dest/storage/tagging_data_provider/tagging_data_provider.d.ts.map +0 -1
  378. package/dest/storage/tagging_data_provider/tagging_data_provider.js +0 -89
  379. package/dest/synchronizer/index.d.ts +0 -2
  380. package/dest/synchronizer/index.d.ts.map +0 -1
  381. package/dest/synchronizer/index.js +0 -1
  382. package/dest/synchronizer/synchronizer.d.ts +0 -35
  383. package/dest/synchronizer/synchronizer.d.ts.map +0 -1
  384. package/dest/synchronizer/synchronizer.js +0 -101
  385. package/dest/tagging/siloed_tag.d.ts +0 -14
  386. package/dest/tagging/siloed_tag.d.ts.map +0 -1
  387. package/dest/tagging/siloed_tag.js +0 -20
  388. package/dest/tagging/tag.d.ts +0 -12
  389. package/dest/tagging/tag.d.ts.map +0 -1
  390. package/dest/tagging/tag.js +0 -17
  391. package/dest/tagging/utils.d.ts +0 -18
  392. package/dest/tagging/utils.d.ts.map +0 -1
  393. package/dest/tagging/utils.js +0 -24
  394. package/src/contract_function_simulator/execution_data_provider.ts +0 -333
  395. package/src/contract_function_simulator/proxied_node.ts +0 -33
  396. package/src/contract_function_simulator/pxe_oracle_interface.ts +0 -1008
  397. package/src/private_kernel/private_kernel_oracle_impl.ts +0 -132
  398. package/src/storage/address_data_provider/index.ts +0 -1
  399. package/src/storage/capsule_data_provider/capsule_data_provider.ts +0 -147
  400. package/src/storage/capsule_data_provider/index.ts +0 -1
  401. package/src/storage/contract_data_provider/contract_data_provider.ts +0 -277
  402. package/src/storage/contract_data_provider/index.ts +0 -1
  403. package/src/storage/note_data_provider/index.ts +0 -2
  404. package/src/storage/note_data_provider/note_data_provider.ts +0 -399
  405. package/src/storage/private_event_data_provider/private_event_data_provider.ts +0 -143
  406. package/src/storage/sync_data_provider/index.ts +0 -1
  407. package/src/storage/tagging_data_provider/index.ts +0 -1
  408. package/src/storage/tagging_data_provider/tagging_data_provider.ts +0 -120
  409. package/src/synchronizer/index.ts +0 -1
  410. package/src/synchronizer/synchronizer.ts +0 -120
  411. package/src/tagging/siloed_tag.ts +0 -22
  412. package/src/tagging/tag.ts +0 -16
  413. package/src/tagging/utils.ts +0 -31
@@ -0,0 +1,325 @@
1
+ import {
2
+ MAX_KEY_VALIDATION_REQUESTS_PER_CALL,
3
+ MAX_KEY_VALIDATION_REQUESTS_PER_TX,
4
+ MAX_NOTE_HASHES_PER_CALL,
5
+ MAX_NOTE_HASHES_PER_TX,
6
+ MAX_NOTE_HASH_READ_REQUESTS_PER_CALL,
7
+ MAX_NOTE_HASH_READ_REQUESTS_PER_TX,
8
+ MAX_NULLIFIERS_PER_CALL,
9
+ MAX_NULLIFIERS_PER_TX,
10
+ MAX_NULLIFIER_READ_REQUESTS_PER_CALL,
11
+ MAX_NULLIFIER_READ_REQUESTS_PER_TX,
12
+ MAX_PRIVATE_LOGS_PER_CALL,
13
+ MAX_PRIVATE_LOGS_PER_TX,
14
+ } from '@aztec/constants';
15
+ import { makeTuple } from '@aztec/foundation/array';
16
+ import { Fr } from '@aztec/foundation/curves/bn254';
17
+ import { Point } from '@aztec/foundation/curves/grumpkin';
18
+ import type { Serializable } from '@aztec/foundation/serialize';
19
+ import { AztecAddress } from '@aztec/stdlib/aztec-address';
20
+ import {
21
+ ClaimedLengthArray,
22
+ KeyValidationRequest,
23
+ KeyValidationRequestAndSeparator,
24
+ NoteHash,
25
+ Nullifier,
26
+ PrivateCircuitPublicInputs,
27
+ PrivateKernelCircuitPublicInputs,
28
+ type PrivateKernelSimulateOutput,
29
+ ReadRequest,
30
+ ScopedKeyValidationRequestAndSeparator,
31
+ ScopedNoteHash,
32
+ ScopedNullifier,
33
+ ScopedReadRequest,
34
+ } from '@aztec/stdlib/kernel';
35
+ import { PrivateLogData, ScopedPrivateLogData } from '@aztec/stdlib/kernel';
36
+ import { PrivateLog } from '@aztec/stdlib/logs';
37
+ import { PrivateCallExecutionResult } from '@aztec/stdlib/tx';
38
+ import { VerificationKeyData } from '@aztec/stdlib/vks';
39
+
40
+ const DEFAULT_CONTRACT_ADDRESS = AztecAddress.fromBigInt(987654n);
41
+
42
+ /**
43
+ * Builds a ClaimedLengthArray from a list of items, padding to the required size.
44
+ */
45
+ function makeClaimed<T extends Serializable, N extends number>(items: T[], emptyFactory: { empty(): T }, maxSize: N) {
46
+ const padded = makeTuple(maxSize, i => items[i] ?? emptyFactory.empty());
47
+ return new ClaimedLengthArray<T, typeof maxSize>(padded, items.length);
48
+ }
49
+
50
+ /** Builder for PrivateKernelCircuitPublicInputs with fluent API for adding side effects. */
51
+ export class PrivateKernelCircuitPublicInputsBuilder {
52
+ private noteHashes: ScopedNoteHash[] = [];
53
+ private nullifiers: ScopedNullifier[] = [];
54
+ private noteHashReadRequests: ScopedReadRequest[] = [];
55
+ private nullifierReadRequests: ScopedReadRequest[] = [];
56
+ private keyValidationRequests: ScopedKeyValidationRequestAndSeparator[] = [];
57
+ private privateLogs: ScopedPrivateLogData[] = [];
58
+ private nextCounter: number;
59
+
60
+ constructor(
61
+ private contractAddress: AztecAddress = DEFAULT_CONTRACT_ADDRESS,
62
+ startCounter = 1,
63
+ ) {
64
+ this.nextCounter = startCounter;
65
+ }
66
+
67
+ private getCounter(sideEffectCounter?: number): number {
68
+ if (sideEffectCounter !== undefined) {
69
+ this.nextCounter = sideEffectCounter + 1;
70
+ return sideEffectCounter;
71
+ }
72
+ return this.nextCounter++;
73
+ }
74
+
75
+ /** Adds a note hash to the accumulated data. Defaults are generated randomly. */
76
+ addNoteHash(opts?: { value?: Fr; counter?: number; contractAddress?: AztecAddress }): this {
77
+ const value = opts?.value ?? Fr.random();
78
+ const counter = this.getCounter(opts?.counter);
79
+ const addr = opts?.contractAddress ?? this.contractAddress;
80
+ this.noteHashes.push(new NoteHash(value, counter).scope(addr));
81
+ return this;
82
+ }
83
+
84
+ /** Adds a nullifier to the accumulated data. Defaults are generated randomly. */
85
+ addNullifier(opts?: { value?: Fr; noteHash?: Fr; counter?: number; contractAddress?: AztecAddress }): this {
86
+ const value = opts?.value ?? Fr.random();
87
+ const noteHash = opts?.noteHash ?? Fr.ZERO;
88
+ const counter = this.getCounter(opts?.counter);
89
+ const addr = opts?.contractAddress ?? this.contractAddress;
90
+ this.nullifiers.push(new Nullifier(value, noteHash, counter).scope(addr));
91
+ return this;
92
+ }
93
+
94
+ /** Adds a pending note hash read request (non-empty contract address, can match a pending note hash). */
95
+ addPendingNoteHashReadRequest(opts?: { value?: Fr; counter?: number; contractAddress?: AztecAddress }): this {
96
+ const value = opts?.value ?? Fr.random();
97
+ const counter = this.getCounter(opts?.counter);
98
+ const addr = opts?.contractAddress ?? this.contractAddress;
99
+ this.noteHashReadRequests.push(new ScopedReadRequest(new ReadRequest(value, counter), addr));
100
+ return this;
101
+ }
102
+
103
+ /** Adds a settled note hash read request (empty contract address, resolved against the note hash tree). */
104
+ addSettledNoteHashReadRequest(opts?: { value?: Fr; counter?: number }): this {
105
+ const value = opts?.value ?? Fr.random();
106
+ const counter = this.getCounter(opts?.counter);
107
+ this.noteHashReadRequests.push(new ScopedReadRequest(new ReadRequest(value, counter), AztecAddress.ZERO));
108
+ return this;
109
+ }
110
+
111
+ /** Adds a pending nullifier read request (non-empty contract address, can match a pending nullifier). */
112
+ addPendingNullifierReadRequest(opts?: { value?: Fr; counter?: number; contractAddress?: AztecAddress }): this {
113
+ const value = opts?.value ?? Fr.random();
114
+ const counter = this.getCounter(opts?.counter);
115
+ const addr = opts?.contractAddress ?? this.contractAddress;
116
+ this.nullifierReadRequests.push(new ScopedReadRequest(new ReadRequest(value, counter), addr));
117
+ return this;
118
+ }
119
+
120
+ /** Adds a settled nullifier read request (empty contract address, resolved against the nullifier tree). */
121
+ addSettledNullifierReadRequest(opts?: { value?: Fr; counter?: number }): this {
122
+ const value = opts?.value ?? Fr.random();
123
+ const counter = this.getCounter(opts?.counter);
124
+ this.nullifierReadRequests.push(new ScopedReadRequest(new ReadRequest(value, counter), AztecAddress.ZERO));
125
+ return this;
126
+ }
127
+
128
+ /** Adds a key validation request to validation requests. */
129
+ addKeyValidationRequest(opts?: { contractAddress?: AztecAddress }): this {
130
+ const addr = opts?.contractAddress ?? this.contractAddress;
131
+ this.keyValidationRequests.push(
132
+ new ScopedKeyValidationRequestAndSeparator(
133
+ new KeyValidationRequestAndSeparator(
134
+ new KeyValidationRequest(new Point(Fr.random(), Fr.random(), false), Fr.random()),
135
+ Fr.random(),
136
+ ),
137
+ addr,
138
+ ),
139
+ );
140
+ return this;
141
+ }
142
+
143
+ /** Adds a private log to the accumulated data. Defaults are generated randomly. */
144
+ addPrivateLog(opts?: { noteHashCounter?: number; counter?: number; contractAddress?: AztecAddress }): this {
145
+ const noteHashCounter = opts?.noteHashCounter ?? 0;
146
+ const counter = this.getCounter(opts?.counter);
147
+ const addr = opts?.contractAddress ?? this.contractAddress;
148
+ this.privateLogs.push(
149
+ new ScopedPrivateLogData(new PrivateLogData(PrivateLog.empty(), noteHashCounter, counter), addr),
150
+ );
151
+ return this;
152
+ }
153
+
154
+ /** Builds the PrivateKernelCircuitPublicInputs with all added side effects. */
155
+ build(): PrivateKernelCircuitPublicInputs {
156
+ const publicInputs = PrivateKernelCircuitPublicInputs.empty();
157
+ publicInputs.end.noteHashes = makeClaimed(this.noteHashes, ScopedNoteHash, MAX_NOTE_HASHES_PER_TX);
158
+ publicInputs.end.nullifiers = makeClaimed(this.nullifiers, ScopedNullifier, MAX_NULLIFIERS_PER_TX);
159
+ publicInputs.end.privateLogs = makeClaimed(this.privateLogs, ScopedPrivateLogData, MAX_PRIVATE_LOGS_PER_TX);
160
+ publicInputs.validationRequests.noteHashReadRequests = makeClaimed(
161
+ this.noteHashReadRequests,
162
+ ScopedReadRequest,
163
+ MAX_NOTE_HASH_READ_REQUESTS_PER_TX,
164
+ );
165
+ publicInputs.validationRequests.nullifierReadRequests = makeClaimed(
166
+ this.nullifierReadRequests,
167
+ ScopedReadRequest,
168
+ MAX_NULLIFIER_READ_REQUESTS_PER_TX,
169
+ );
170
+ publicInputs.validationRequests.scopedKeyValidationRequestsAndSeparators = makeClaimed(
171
+ this.keyValidationRequests,
172
+ ScopedKeyValidationRequestAndSeparator,
173
+ MAX_KEY_VALIDATION_REQUESTS_PER_TX,
174
+ );
175
+ return publicInputs;
176
+ }
177
+ }
178
+
179
+ /** Builder for PrivateCircuitPublicInputs (call-level) with fluent API for adding side effects. */
180
+ export class PrivateCircuitPublicInputsBuilder {
181
+ private noteHashes: NoteHash[] = [];
182
+ private nullifiers: Nullifier[] = [];
183
+ private noteHashReadRequests: ScopedReadRequest[] = [];
184
+ private nullifierReadRequests: ScopedReadRequest[] = [];
185
+ private keyValidationRequests: KeyValidationRequestAndSeparator[] = [];
186
+ private privateLogs: PrivateLogData[] = [];
187
+ private nextCounter: number;
188
+
189
+ constructor(
190
+ private contractAddress: AztecAddress = DEFAULT_CONTRACT_ADDRESS,
191
+ startCounter = 1,
192
+ ) {
193
+ this.nextCounter = startCounter;
194
+ }
195
+
196
+ private getCounter(sideEffectCounter?: number): number {
197
+ if (sideEffectCounter !== undefined) {
198
+ this.nextCounter = sideEffectCounter + 1;
199
+ return sideEffectCounter;
200
+ }
201
+ return this.nextCounter++;
202
+ }
203
+
204
+ /** Adds a note hash. Defaults are generated randomly. */
205
+ addNoteHash(opts?: { value?: Fr; counter?: number }): this {
206
+ const value = opts?.value ?? Fr.random();
207
+ const counter = this.getCounter(opts?.counter);
208
+ this.noteHashes.push(new NoteHash(value, counter));
209
+ return this;
210
+ }
211
+
212
+ /** Adds a nullifier. Defaults are generated randomly. */
213
+ addNullifier(opts?: { value?: Fr; noteHash?: Fr; counter?: number }): this {
214
+ const value = opts?.value ?? Fr.random();
215
+ const noteHash = opts?.noteHash ?? Fr.ZERO;
216
+ const counter = this.getCounter(opts?.counter);
217
+ this.nullifiers.push(new Nullifier(value, noteHash, counter));
218
+ return this;
219
+ }
220
+
221
+ /** Adds a pending note hash read request (non-empty contract address, can match a pending note hash). */
222
+ addPendingNoteHashReadRequest(opts?: { value?: Fr; counter?: number }): this {
223
+ const value = opts?.value ?? Fr.random();
224
+ const counter = this.getCounter(opts?.counter);
225
+ this.noteHashReadRequests.push(new ScopedReadRequest(new ReadRequest(value, counter), this.contractAddress));
226
+ return this;
227
+ }
228
+
229
+ /** Adds a settled note hash read request (empty contract address, resolved against the note hash tree). */
230
+ addSettledNoteHashReadRequest(opts?: { value?: Fr; counter?: number }): this {
231
+ const value = opts?.value ?? Fr.random();
232
+ const counter = this.getCounter(opts?.counter);
233
+ this.noteHashReadRequests.push(new ScopedReadRequest(new ReadRequest(value, counter), AztecAddress.ZERO));
234
+ return this;
235
+ }
236
+
237
+ /** Adds a pending nullifier read request (non-empty contract address, can match a pending nullifier). */
238
+ addPendingNullifierReadRequest(opts?: { value?: Fr; counter?: number }): this {
239
+ const value = opts?.value ?? Fr.random();
240
+ const counter = this.getCounter(opts?.counter);
241
+ this.nullifierReadRequests.push(new ScopedReadRequest(new ReadRequest(value, counter), this.contractAddress));
242
+ return this;
243
+ }
244
+
245
+ /** Adds a settled nullifier read request (empty contract address, resolved against the nullifier tree). */
246
+ addSettledNullifierReadRequest(opts?: { value?: Fr; counter?: number }): this {
247
+ const value = opts?.value ?? Fr.random();
248
+ const counter = this.getCounter(opts?.counter);
249
+ this.nullifierReadRequests.push(new ScopedReadRequest(new ReadRequest(value, counter), AztecAddress.ZERO));
250
+ return this;
251
+ }
252
+
253
+ /** Adds a key validation request. */
254
+ addKeyValidationRequest(): this {
255
+ this.keyValidationRequests.push(
256
+ new KeyValidationRequestAndSeparator(
257
+ new KeyValidationRequest(new Point(Fr.random(), Fr.random(), false), Fr.random()),
258
+ Fr.random(),
259
+ ),
260
+ );
261
+ return this;
262
+ }
263
+
264
+ /** Adds a private log. Defaults are generated randomly. */
265
+ addPrivateLog(opts?: { noteHashCounter?: number; counter?: number }): this {
266
+ const noteHashCounter = opts?.noteHashCounter ?? 0;
267
+ const counter = this.getCounter(opts?.counter);
268
+ this.privateLogs.push(new PrivateLogData(PrivateLog.empty(), noteHashCounter, counter));
269
+ return this;
270
+ }
271
+
272
+ /** Builds the PrivateCircuitPublicInputs with all added side effects. */
273
+ build(): PrivateCircuitPublicInputs {
274
+ const publicInputs = PrivateCircuitPublicInputs.empty();
275
+ publicInputs.callContext.contractAddress = this.contractAddress;
276
+ publicInputs.noteHashes = makeClaimed(this.noteHashes, NoteHash, MAX_NOTE_HASHES_PER_CALL);
277
+ publicInputs.nullifiers = makeClaimed(this.nullifiers, Nullifier, MAX_NULLIFIERS_PER_CALL);
278
+ publicInputs.privateLogs = makeClaimed(this.privateLogs, PrivateLogData, MAX_PRIVATE_LOGS_PER_CALL);
279
+ publicInputs.noteHashReadRequests = makeClaimed(
280
+ this.noteHashReadRequests,
281
+ ScopedReadRequest,
282
+ MAX_NOTE_HASH_READ_REQUESTS_PER_CALL,
283
+ );
284
+ publicInputs.nullifierReadRequests = makeClaimed(
285
+ this.nullifierReadRequests,
286
+ ScopedReadRequest,
287
+ MAX_NULLIFIER_READ_REQUESTS_PER_CALL,
288
+ );
289
+ publicInputs.keyValidationRequestsAndSeparators = makeClaimed(
290
+ this.keyValidationRequests,
291
+ KeyValidationRequestAndSeparator,
292
+ MAX_KEY_VALIDATION_REQUESTS_PER_CALL,
293
+ );
294
+ return publicInputs;
295
+ }
296
+ }
297
+
298
+ /** Wraps a PrivateKernelCircuitPublicInputs in a PrivateKernelSimulateOutput. */
299
+ export function makeKernelOutput(
300
+ publicInputs?: PrivateKernelCircuitPublicInputs,
301
+ ): PrivateKernelSimulateOutput<PrivateKernelCircuitPublicInputs> {
302
+ return {
303
+ publicInputs: publicInputs ?? PrivateKernelCircuitPublicInputs.empty(),
304
+ verificationKey: VerificationKeyData.empty(),
305
+ outputWitness: new Map(),
306
+ bytecode: Buffer.from([]),
307
+ };
308
+ }
309
+
310
+ /** Wraps a PrivateCircuitPublicInputs in a PrivateCallExecutionResult. */
311
+ export function makeExecutionResult(publicInputs?: PrivateCircuitPublicInputs): PrivateCallExecutionResult {
312
+ return new PrivateCallExecutionResult(
313
+ Buffer.alloc(0),
314
+ Buffer.alloc(0),
315
+ new Map(),
316
+ publicInputs ?? PrivateCircuitPublicInputs.empty(),
317
+ [],
318
+ new Map(),
319
+ [],
320
+ [],
321
+ [],
322
+ [],
323
+ [],
324
+ );
325
+ }
@@ -1,6 +1,6 @@
1
- import { vkAsFieldsMegaHonk } from '@aztec/foundation/crypto';
2
- import { Fr } from '@aztec/foundation/fields';
3
- import { createLogger } from '@aztec/foundation/log';
1
+ import { vkAsFieldsMegaHonk } from '@aztec/foundation/crypto/keys';
2
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
4
4
  import { pushTestData } from '@aztec/foundation/testing';
5
5
  import { Timer } from '@aztec/foundation/timer';
6
6
  import { getVKTreeRoot } from '@aztec/noir-protocol-circuits-types/vk-tree';
@@ -28,13 +28,12 @@ import {
28
28
  type PrivateCallExecutionResult,
29
29
  type PrivateExecutionResult,
30
30
  TxRequest,
31
- collectNoteHashLeafIndexMap,
32
31
  collectNoteHashNullifierCounterMap,
33
32
  getFinalMinRevertibleSideEffectCounter,
34
33
  } from '@aztec/stdlib/tx';
35
34
  import { VerificationKeyAsFields, VerificationKeyData, VkData } from '@aztec/stdlib/vks';
36
35
 
37
- import { PrivateKernelResetPrivateInputsBuilder } from './hints/build_private_kernel_reset_private_inputs.js';
36
+ import { PrivateKernelResetPrivateInputsBuilder } from './hints/private_kernel_reset_private_inputs_builder.js';
38
37
  import type { PrivateKernelOracle } from './private_kernel_oracle.js';
39
38
 
40
39
  const NULL_SIMULATE_OUTPUT: PrivateKernelSimulateOutput<PrivateKernelCircuitPublicInputs> = {
@@ -57,13 +56,16 @@ export interface PrivateKernelExecutionProverConfig {
57
56
  * inform state tree updates.
58
57
  */
59
58
  export class PrivateKernelExecutionProver {
60
- private log = createLogger('pxe:private-kernel-execution-prover');
59
+ private log: Logger;
61
60
 
62
61
  constructor(
63
62
  private oracle: PrivateKernelOracle,
64
63
  private proofCreator: PrivateKernelProver,
65
64
  private fakeProofs = false,
66
- ) {}
65
+ bindings?: LoggerBindings,
66
+ ) {
67
+ this.log = createLogger('pxe:private-kernel-execution-prover', bindings);
68
+ }
67
69
 
68
70
  /**
69
71
  * Generate a proof for a given transaction request and execution result.
@@ -101,7 +103,6 @@ export class PrivateKernelExecutionProver {
101
103
 
102
104
  const executionSteps: PrivateExecutionStep[] = [];
103
105
 
104
- const noteHashLeafIndexMap = collectNoteHashLeafIndexMap(executionResult);
105
106
  const noteHashNullifierCounterMap = collectNoteHashNullifierCounterMap(executionResult);
106
107
  const minRevertibleSideEffectCounter = getFinalMinRevertibleSideEffectCounter(executionResult);
107
108
  const splitCounter = isPrivateOnlyTx ? 0 : minRevertibleSideEffectCounter;
@@ -115,8 +116,9 @@ export class PrivateKernelExecutionProver {
115
116
  splitCounter,
116
117
  );
117
118
  while (resetBuilder.needsReset()) {
119
+ // Inner reset: without siloing.
118
120
  const witgenTimer = new Timer();
119
- const privateInputs = await resetBuilder.build(this.oracle, noteHashLeafIndexMap);
121
+ const privateInputs = await resetBuilder.build(this.oracle);
120
122
  output = generateWitnesses
121
123
  ? await this.proofCreator.generateResetOutput(privateInputs)
122
124
  : await this.proofCreator.simulateReset(privateInputs);
@@ -215,16 +217,24 @@ export class PrivateKernelExecutionProver {
215
217
  firstIteration = false;
216
218
  }
217
219
 
218
- // Reset.
219
- let resetBuilder = new PrivateKernelResetPrivateInputsBuilder(
220
+ // Final reset: include siloing of note hashes, nullifiers and private logs.
221
+ const finalResetBuilder = new PrivateKernelResetPrivateInputsBuilder(
220
222
  output,
221
223
  [],
222
224
  noteHashNullifierCounterMap,
223
225
  splitCounter,
224
226
  );
225
- while (resetBuilder.needsReset()) {
227
+ if (!finalResetBuilder.needsReset()) {
228
+ // The final reset must be performed exactly once, because each tx has at least one nullifier that requires
229
+ // siloing, and siloing cannot be done multiple times.
230
+ // While, in theory, it might be possible to silo note hashes first and then run another reset to silo nullifiers
231
+ // and/or private logs, we currently don't have standalone dimensions for the arrays that require siloing. As a
232
+ // result, all necessary siloing must be done together in a single reset.
233
+ // Refer to the possible combinations of dimensions in private_kernel_reset_config.json.
234
+ throw new Error('Nothing to reset for the final reset.');
235
+ } else {
226
236
  const witgenTimer = new Timer();
227
- const privateInputs = await resetBuilder.build(this.oracle, noteHashLeafIndexMap);
237
+ const privateInputs = await finalResetBuilder.build(this.oracle);
228
238
  output = generateWitnesses
229
239
  ? await this.proofCreator.generateResetOutput(privateInputs)
230
240
  : await this.proofCreator.simulateReset(privateInputs);
@@ -238,8 +248,6 @@ export class PrivateKernelExecutionProver {
238
248
  witgen: witgenTimer.ms(),
239
249
  },
240
250
  });
241
-
242
- resetBuilder = new PrivateKernelResetPrivateInputsBuilder(output, [], noteHashNullifierCounterMap, splitCounter);
243
251
  }
244
252
 
245
253
  if (output.publicInputs.feePayer.isZero() && skipFeeEnforcement) {
@@ -259,20 +267,20 @@ export class PrivateKernelExecutionProver {
259
267
  // TODO: Enable padding once we better understand the final amounts to pad to.
260
268
  const paddedSideEffectAmounts = PaddedSideEffectAmounts.empty();
261
269
 
262
- // Use the aggregated includeByTimestamp set throughout the tx execution.
263
- // TODO: Call `computeTxIncludeByTimestamp` to round the value down and reduce precision, improving privacy.
264
- const includeByTimestampUpperBound = previousKernelData.publicInputs.includeByTimestamp;
270
+ // Use the aggregated expirationTimestamp set throughout the tx execution.
271
+ // TODO: Call `computeTxExpirationTimestamp` to round the value down and reduce precision, improving privacy.
272
+ const expirationTimestampUpperBound = previousKernelData.publicInputs.expirationTimestamp;
265
273
  const anchorBlockTimestamp = previousKernelData.publicInputs.constants.anchorBlockHeader.globalVariables.timestamp;
266
- if (includeByTimestampUpperBound <= anchorBlockTimestamp) {
274
+ if (expirationTimestampUpperBound <= anchorBlockTimestamp) {
267
275
  throw new Error(
268
- `Include-by timestamp must be greater than the anchor block timestamp. Anchor block timestamp: ${anchorBlockTimestamp}. Include-by timestamp: ${includeByTimestampUpperBound}.`,
276
+ `Include-by timestamp must be greater than the anchor block timestamp. Anchor block timestamp: ${anchorBlockTimestamp}. Include-by timestamp: ${expirationTimestampUpperBound}.`,
269
277
  );
270
278
  }
271
279
 
272
280
  const privateInputs = new PrivateKernelTailCircuitPrivateInputs(
273
281
  previousKernelData,
274
282
  paddedSideEffectAmounts,
275
- includeByTimestampUpperBound,
283
+ expirationTimestampUpperBound,
276
284
  );
277
285
 
278
286
  const witgenTimer = new Timer();
@@ -290,8 +298,8 @@ export class PrivateKernelExecutionProver {
290
298
  },
291
299
  });
292
300
 
293
- // Hiding circuit is only executed if we are generating witnesses.
294
- // For simulation, we can end with the tail, since the hiding circuit will simply return the same tail output.
301
+ // Hiding kernel is only executed if we are generating witnesses.
302
+ // For simulation, we can end with the tail, since the Hiding kernel will simply return the same tail output.
295
303
  if (generateWitnesses) {
296
304
  const previousKernelVkData = await this.getVkData(tailOutput.verificationKey);
297
305
 
@@ -415,6 +423,7 @@ export class PrivateKernelExecutionProver {
415
423
  await this.oracle.getContractClassIdPreimage(currentContractClassId);
416
424
 
417
425
  const updatedClassIdHints = await this.oracle.getUpdatedClassIdHints(contractAddress);
426
+
418
427
  return PrivateCallData.from({
419
428
  publicInputs,
420
429
  vk,
@@ -1,71 +1,152 @@
1
- import { FUNCTION_TREE_HEIGHT, NOTE_HASH_TREE_HEIGHT, VK_TREE_HEIGHT } from '@aztec/constants';
2
- import type { Fr, GrumpkinScalar, Point } from '@aztec/foundation/fields';
1
+ import { FUNCTION_TREE_HEIGHT, 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 { MembershipWitness } from '@aztec/foundation/trees';
5
+ import type { KeyStore } from '@aztec/key-store';
6
+ import { getVKIndex, getVKSiblingPath } from '@aztec/noir-protocol-circuits-types/vk-tree';
7
+ import { ProtocolContractAddress } from '@aztec/protocol-contracts';
4
8
  import type { FunctionSelector } from '@aztec/stdlib/abi';
5
9
  import type { AztecAddress } from '@aztec/stdlib/aztec-address';
10
+ import { BlockHash } from '@aztec/stdlib/block';
11
+ import { type ContractInstanceWithAddress, computeSaltedInitializationHash } from '@aztec/stdlib/contract';
12
+ import { DelayedPublicMutableValues, DelayedPublicMutableValuesWithHash } from '@aztec/stdlib/delayed-public-mutable';
13
+ import { computePublicDataTreeLeafSlot } from '@aztec/stdlib/hash';
14
+ import type { AztecNode } from '@aztec/stdlib/interfaces/client';
6
15
  import { UpdatedClassIdHints } from '@aztec/stdlib/kernel';
7
- import type { PublicKeys } from '@aztec/stdlib/keys';
8
16
  import type { NullifierMembershipWitness } from '@aztec/stdlib/trees';
9
17
  import type { VerificationKeyAsFields } from '@aztec/stdlib/vks';
10
18
 
19
+ import type { ContractStore } from '../storage/contract_store/contract_store.js';
20
+
11
21
  /**
12
22
  * Provides functionality needed by the private kernel for interacting with our state trees.
13
- * This is either PrivateKernelOracleImpl, or a mocked test implementation.
14
23
  */
15
- export interface PrivateKernelOracle {
24
+ export class PrivateKernelOracle {
25
+ constructor(
26
+ private contractStore: ContractStore,
27
+ private keyStore: KeyStore,
28
+ private node: AztecNode,
29
+ private blockHash: BlockHash,
30
+ ) {}
31
+
16
32
  /** Retrieves the preimage of a contract address from the registered contract instances db. */
17
- getContractAddressPreimage(address: AztecAddress): Promise<{
18
- saltedInitializationHash: Fr;
19
- publicKeys: PublicKeys;
20
- currentContractClassId: Fr;
21
- originalContractClassId: Fr;
22
- }>;
33
+ public async getContractAddressPreimage(
34
+ address: AztecAddress,
35
+ ): Promise<ContractInstanceWithAddress & { saltedInitializationHash: Fr }> {
36
+ const instance = await this.contractStore.getContractInstance(address);
37
+ if (!instance) {
38
+ throw new Error(`Contract instance not found when getting address preimage. Contract address: ${address}.`);
39
+ }
40
+ return {
41
+ saltedInitializationHash: await computeSaltedInitializationHash(instance),
42
+ ...instance,
43
+ };
44
+ }
23
45
 
24
46
  /** Retrieves the preimage of a contract class id from the contract classes db. */
25
- getContractClassIdPreimage(
26
- contractClassId: Fr,
27
- ): Promise<{ artifactHash: Fr; publicBytecodeCommitment: Fr; privateFunctionsRoot: Fr }>;
47
+ public async getContractClassIdPreimage(contractClassId: Fr) {
48
+ const contractClass = await this.contractStore.getContractClassWithPreimage(contractClassId);
49
+ if (!contractClass) {
50
+ throw new Error(`Contract class not found when getting class id preimage. Class id: ${contractClassId}.`);
51
+ }
52
+ return {
53
+ artifactHash: contractClass.artifactHash,
54
+ privateFunctionsRoot: contractClass.privateFunctionsRoot,
55
+ publicBytecodeCommitment: contractClass.publicBytecodeCommitment,
56
+ };
57
+ }
28
58
 
29
- /**
30
- * Returns a membership witness with the sibling path and leaf index in our private functions tree.
31
- */
32
- getFunctionMembershipWitness(
59
+ /** Returns a membership witness with the sibling path and leaf index in our private functions tree. */
60
+ public async getFunctionMembershipWitness(
33
61
  contractClassId: Fr,
34
62
  selector: FunctionSelector,
35
- ): Promise<MembershipWitness<typeof FUNCTION_TREE_HEIGHT>>;
63
+ ): Promise<MembershipWitness<typeof FUNCTION_TREE_HEIGHT>> {
64
+ const membershipWitness = await this.contractStore.getFunctionMembershipWitness(contractClassId, selector);
65
+ if (!membershipWitness) {
66
+ throw new Error(
67
+ `Membership witness not found for contract class id ${contractClassId} and selector ${selector}.`,
68
+ );
69
+ }
70
+ return membershipWitness;
71
+ }
36
72
 
37
73
  /**
38
74
  * Returns a membership witness with the sibling path and leaf index in our protocol VK indexed merkle tree.
39
75
  * Used to validate the previous kernel's verification key.
40
76
  */
41
- getVkMembershipWitness(vk: VerificationKeyAsFields): Promise<MembershipWitness<typeof VK_TREE_HEIGHT>>;
77
+ public getVkMembershipWitness(vk: VerificationKeyAsFields): Promise<MembershipWitness<typeof VK_TREE_HEIGHT>> {
78
+ const leafIndex = getVKIndex(vk);
79
+ return Promise.resolve(new MembershipWitness(VK_TREE_HEIGHT, BigInt(leafIndex), getVKSiblingPath(leafIndex)));
80
+ }
42
81
 
43
- /**
44
- * Returns a membership witness with the sibling path and leaf index in our private function indexed merkle tree.
45
- */ getNoteHashMembershipWitness(leafIndex: bigint): Promise<MembershipWitness<typeof NOTE_HASH_TREE_HEIGHT>>;
82
+ /** Returns a membership witness with the sibling path and leaf index in our note hash tree. */
83
+ getNoteHashMembershipWitness(noteHash: Fr): Promise<MembershipWitness<typeof NOTE_HASH_TREE_HEIGHT> | undefined> {
84
+ return this.node.getNoteHashMembershipWitness(this.blockHash, noteHash);
85
+ }
46
86
 
47
- /**
48
- * Returns a membership witness with the sibling path and leaf index in our nullifier indexed merkle tree.
49
- */
50
- getNullifierMembershipWitness(nullifier: Fr): Promise<NullifierMembershipWitness | undefined>;
51
- /**
52
- * Returns the root of our note hash merkle tree.
53
- */
54
- getNoteHashTreeRoot(): Promise<Fr>;
87
+ /** Returns a membership witness with the sibling path and leaf index in our nullifier indexed merkle tree. */
88
+ getNullifierMembershipWitness(nullifier: Fr): Promise<NullifierMembershipWitness | undefined> {
89
+ return this.node.getNullifierMembershipWitness(this.blockHash, nullifier);
90
+ }
91
+
92
+ /** Returns the root of our note hash merkle tree. */
93
+ async getNoteHashTreeRoot(): Promise<Fr> {
94
+ const header = await this.node.getBlockHeader(this.blockHash);
95
+ if (!header) {
96
+ throw new Error(`No block header found for block hash ${this.blockHash}`);
97
+ }
98
+ return header.state.partial.noteHashTree.root;
99
+ }
55
100
 
56
101
  /**
57
102
  * Retrieves the sk_m corresponding to the pk_m.
58
103
  * @throws If the provided public key is not associated with any of the registered accounts.
59
- * @param pkM - The master public key to get secret key for.
104
+ * @param masterPublicKey - The master public key to get secret key for.
60
105
  * @returns A Promise that resolves to sk_m.
61
106
  * @dev Used when feeding the sk_m to the kernel circuit for keys verification.
62
107
  */
63
- getMasterSecretKey(masterPublicKey: Point): Promise<GrumpkinScalar>;
108
+ public getMasterSecretKey(masterPublicKey: Point): Promise<GrumpkinScalar> {
109
+ return this.keyStore.getMasterSecretKey(masterPublicKey);
110
+ }
64
111
 
65
112
  /** Use debug data to get the function name corresponding to a selector. */
66
- getDebugFunctionName(contractAddress: AztecAddress, selector: FunctionSelector): Promise<string | undefined>;
113
+ public getDebugFunctionName(contractAddress: AztecAddress, selector: FunctionSelector): Promise<string | undefined> {
114
+ return this.contractStore.getDebugFunctionName(contractAddress, selector);
115
+ }
116
+
117
+ /**
118
+ * Returns a membership witness and leaf index to our public data indexed merkle tree,
119
+ * along with an associated DelayedPublicMutable containing the class ID to update.
120
+ */
121
+ public async getUpdatedClassIdHints(contractAddress: AztecAddress): Promise<UpdatedClassIdHints> {
122
+ const { delayedPublicMutableSlot, delayedPublicMutableHashSlot } =
123
+ await DelayedPublicMutableValuesWithHash.getContractUpdateSlots(contractAddress);
124
+
125
+ const hashLeafSlot = await computePublicDataTreeLeafSlot(
126
+ ProtocolContractAddress.ContractInstanceRegistry,
127
+ delayedPublicMutableHashSlot,
128
+ );
129
+ const updatedClassIdWitness = await this.node.getPublicDataWitness(this.blockHash, hashLeafSlot);
130
+
131
+ if (!updatedClassIdWitness) {
132
+ throw new Error(`No public data tree witness found for ${hashLeafSlot}`);
133
+ }
134
+
135
+ const readStorage = (storageSlot: Fr) =>
136
+ this.node.getPublicStorageAt(this.blockHash, ProtocolContractAddress.ContractInstanceRegistry, storageSlot);
137
+ const delayedPublicMutableValues = await DelayedPublicMutableValues.readFromTree(
138
+ delayedPublicMutableSlot,
139
+ readStorage,
140
+ );
67
141
 
68
- /** Returns a membership witness and leaf index to our public data indexed merkle tree,
69
- * along with an associated DelayedPublicMutable containing the class ID to update. */
70
- getUpdatedClassIdHints(contractAddress: AztecAddress): Promise<UpdatedClassIdHints>;
142
+ return new UpdatedClassIdHints(
143
+ new MembershipWitness(
144
+ PUBLIC_DATA_TREE_HEIGHT,
145
+ updatedClassIdWitness.index,
146
+ updatedClassIdWitness.siblingPath.toTuple(),
147
+ ),
148
+ updatedClassIdWitness.leafPreimage,
149
+ delayedPublicMutableValues,
150
+ );
151
+ }
71
152
  }