@aztec/pxe 0.0.1-commit.b655e406 → 0.0.1-commit.b6e433891

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 (434) 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.d.ts +1 -1
  5. package/dest/bin/check_oracle_version.js +105 -15
  6. package/dest/block_synchronizer/block_synchronizer.d.ts +45 -0
  7. package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -0
  8. package/dest/block_synchronizer/block_synchronizer.js +153 -0
  9. package/dest/block_synchronizer/index.d.ts +2 -0
  10. package/dest/block_synchronizer/index.d.ts.map +1 -0
  11. package/dest/block_synchronizer/index.js +1 -0
  12. package/dest/config/index.d.ts +7 -13
  13. package/dest/config/index.d.ts.map +1 -1
  14. package/dest/config/index.js +25 -14
  15. package/dest/config/package_info.d.ts +1 -1
  16. package/dest/config/package_info.js +1 -1
  17. package/dest/contract_function_simulator/benchmarked_node.d.ts +9 -0
  18. package/dest/contract_function_simulator/benchmarked_node.d.ts.map +1 -0
  19. package/dest/contract_function_simulator/benchmarked_node.js +77 -0
  20. package/dest/contract_function_simulator/contract_function_simulator.d.ts +84 -26
  21. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
  22. package/dest/contract_function_simulator/contract_function_simulator.js +251 -85
  23. package/dest/contract_function_simulator/execution_note_cache.d.ts +25 -14
  24. package/dest/contract_function_simulator/execution_note_cache.d.ts.map +1 -1
  25. package/dest/contract_function_simulator/execution_note_cache.js +59 -34
  26. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +7 -7
  27. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -1
  28. package/dest/contract_function_simulator/execution_tagging_index_cache.js +19 -11
  29. package/dest/contract_function_simulator/hashed_values_cache.d.ts +2 -2
  30. package/dest/contract_function_simulator/hashed_values_cache.d.ts.map +1 -1
  31. package/dest/contract_function_simulator/index.d.ts +3 -2
  32. package/dest/contract_function_simulator/index.d.ts.map +1 -1
  33. package/dest/contract_function_simulator/index.js +2 -1
  34. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +6 -6
  35. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts.map +1 -1
  36. package/dest/contract_function_simulator/noir-structs/event_validation_request.js +11 -7
  37. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts +5 -4
  38. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts.map +1 -1
  39. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.js +7 -6
  40. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts +3 -3
  41. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts.map +1 -1
  42. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.js +2 -4
  43. package/dest/contract_function_simulator/noir-structs/message_tx_context.d.ts +16 -0
  44. package/dest/contract_function_simulator/noir-structs/message_tx_context.d.ts.map +1 -0
  45. package/dest/contract_function_simulator/noir-structs/message_tx_context.js +57 -0
  46. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +7 -7
  47. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
  48. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +14 -7
  49. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts +4 -10
  50. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts.map +1 -1
  51. package/dest/contract_function_simulator/noir-structs/utility_context.js +7 -18
  52. package/dest/contract_function_simulator/oracle/index.d.ts +1 -1
  53. package/dest/contract_function_simulator/oracle/interfaces.d.ts +64 -49
  54. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
  55. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts +9 -0
  56. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts.map +1 -0
  57. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.js +42 -0
  58. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts +2 -2
  59. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts.map +1 -1
  60. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.js +1 -1
  61. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts +14 -8
  62. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts.map +1 -1
  63. package/dest/contract_function_simulator/oracle/note_packing_utils.js +16 -11
  64. package/dest/contract_function_simulator/oracle/oracle.d.ts +45 -41
  65. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
  66. package/dest/contract_function_simulator/oracle/oracle.js +226 -117
  67. package/dest/contract_function_simulator/oracle/private_execution.d.ts +2 -27
  68. package/dest/contract_function_simulator/oracle/private_execution.d.ts.map +1 -1
  69. package/dest/contract_function_simulator/oracle/private_execution.js +6 -40
  70. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +67 -88
  71. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
  72. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +140 -118
  73. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +149 -56
  74. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
  75. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +290 -104
  76. package/dest/contract_function_simulator/pick_notes.d.ts +2 -2
  77. package/dest/contract_function_simulator/pick_notes.d.ts.map +1 -1
  78. package/dest/contract_function_simulator/pick_notes.js +1 -1
  79. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts +4 -4
  80. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts.map +1 -1
  81. package/dest/contract_function_simulator/proxied_contract_data_source.js +23 -5
  82. package/dest/contract_logging.d.ts +22 -0
  83. package/dest/contract_logging.d.ts.map +1 -0
  84. package/dest/contract_logging.js +23 -0
  85. package/dest/contract_sync/contract_sync_service.d.ts +45 -0
  86. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -0
  87. package/dest/contract_sync/contract_sync_service.js +114 -0
  88. package/dest/contract_sync/helpers.d.ts +29 -0
  89. package/dest/contract_sync/helpers.d.ts.map +1 -0
  90. package/dest/contract_sync/helpers.js +55 -0
  91. package/dest/debug/pxe_debug_utils.d.ts +45 -0
  92. package/dest/debug/pxe_debug_utils.d.ts.map +1 -0
  93. package/dest/debug/pxe_debug_utils.js +48 -0
  94. package/dest/entrypoints/client/bundle/index.d.ts +4 -2
  95. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  96. package/dest/entrypoints/client/bundle/index.js +3 -1
  97. package/dest/entrypoints/client/bundle/utils.d.ts +1 -1
  98. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  99. package/dest/entrypoints/client/bundle/utils.js +33 -10
  100. package/dest/entrypoints/client/lazy/index.d.ts +4 -2
  101. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  102. package/dest/entrypoints/client/lazy/index.js +3 -1
  103. package/dest/entrypoints/client/lazy/utils.d.ts +2 -2
  104. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  105. package/dest/entrypoints/client/lazy/utils.js +34 -11
  106. package/dest/entrypoints/pxe_creation_options.d.ts +7 -3
  107. package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
  108. package/dest/entrypoints/server/index.d.ts +6 -2
  109. package/dest/entrypoints/server/index.d.ts.map +1 -1
  110. package/dest/entrypoints/server/index.js +5 -1
  111. package/dest/entrypoints/server/utils.d.ts +1 -1
  112. package/dest/entrypoints/server/utils.d.ts.map +1 -1
  113. package/dest/entrypoints/server/utils.js +40 -28
  114. package/dest/error_enriching.d.ts +4 -4
  115. package/dest/error_enriching.d.ts.map +1 -1
  116. package/dest/error_enriching.js +6 -6
  117. package/dest/events/event_service.d.ts +15 -0
  118. package/dest/events/event_service.d.ts.map +1 -0
  119. package/dest/events/event_service.js +44 -0
  120. package/dest/events/index.d.ts +2 -0
  121. package/dest/events/index.d.ts.map +1 -0
  122. package/dest/events/index.js +1 -0
  123. package/dest/events/private_event_filter_validator.d.ts +9 -0
  124. package/dest/events/private_event_filter_validator.d.ts.map +1 -0
  125. package/dest/events/private_event_filter_validator.js +38 -0
  126. package/dest/job_coordinator/job_coordinator.d.ts +75 -0
  127. package/dest/job_coordinator/job_coordinator.d.ts.map +1 -0
  128. package/dest/job_coordinator/job_coordinator.js +94 -0
  129. package/dest/logs/log_service.d.ts +29 -0
  130. package/dest/logs/log_service.d.ts.map +1 -0
  131. package/dest/logs/log_service.js +118 -0
  132. package/dest/messages/message_context_service.d.ts +17 -0
  133. package/dest/messages/message_context_service.d.ts.map +1 -0
  134. package/dest/messages/message_context_service.js +36 -0
  135. package/dest/notes/index.d.ts +2 -0
  136. package/dest/notes/index.d.ts.map +1 -0
  137. package/dest/notes/index.js +1 -0
  138. package/dest/notes/note_service.d.ts +49 -0
  139. package/dest/notes/note_service.d.ts.map +1 -0
  140. package/dest/notes/note_service.js +148 -0
  141. package/dest/notes_filter.d.ts +25 -0
  142. package/dest/notes_filter.d.ts.map +1 -0
  143. package/dest/notes_filter.js +4 -0
  144. package/dest/oracle_version.d.ts +3 -3
  145. package/dest/oracle_version.d.ts.map +1 -1
  146. package/dest/oracle_version.js +5 -4
  147. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
  148. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
  149. package/dest/private_kernel/hints/{compute_tx_include_by_timestamp.js → compute_tx_expiration_timestamp.js} +12 -12
  150. package/dest/private_kernel/hints/index.d.ts +3 -3
  151. package/dest/private_kernel/hints/index.d.ts.map +1 -1
  152. package/dest/private_kernel/hints/index.js +2 -2
  153. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +29 -0
  154. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -0
  155. package/dest/private_kernel/hints/{build_private_kernel_reset_private_inputs.js → private_kernel_reset_private_inputs_builder.js} +144 -77
  156. package/dest/private_kernel/hints/test_utils.d.ts +122 -0
  157. package/dest/private_kernel/hints/test_utils.d.ts.map +1 -0
  158. package/dest/private_kernel/hints/test_utils.js +203 -0
  159. package/dest/private_kernel/index.d.ts +1 -1
  160. package/dest/private_kernel/private_kernel_execution_prover.d.ts +3 -2
  161. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
  162. package/dest/private_kernel/private_kernel_execution_prover.js +33 -25
  163. package/dest/private_kernel/private_kernel_oracle.d.ts +26 -25
  164. package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
  165. package/dest/private_kernel/private_kernel_oracle.js +94 -2
  166. package/dest/pxe.d.ts +124 -103
  167. package/dest/pxe.d.ts.map +1 -1
  168. package/dest/pxe.js +288 -285
  169. package/dest/storage/address_store/address_store.d.ts +11 -0
  170. package/dest/storage/address_store/address_store.d.ts.map +1 -0
  171. package/dest/storage/{address_data_provider/address_data_provider.js → address_store/address_store.js} +13 -12
  172. package/dest/storage/address_store/index.d.ts +2 -0
  173. package/dest/storage/address_store/index.d.ts.map +1 -0
  174. package/dest/storage/address_store/index.js +1 -0
  175. package/dest/storage/anchor_block_store/anchor_block_store.d.ts +17 -0
  176. package/dest/storage/anchor_block_store/anchor_block_store.d.ts.map +1 -0
  177. package/dest/storage/{sync_data_provider/sync_data_provider.js → anchor_block_store/anchor_block_store.js} +10 -10
  178. package/dest/storage/anchor_block_store/index.d.ts +2 -0
  179. package/dest/storage/anchor_block_store/index.d.ts.map +1 -0
  180. package/dest/storage/anchor_block_store/index.js +1 -0
  181. package/dest/storage/capsule_store/capsule_store.d.ts +72 -0
  182. package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -0
  183. package/dest/storage/capsule_store/capsule_store.js +253 -0
  184. package/dest/storage/capsule_store/index.d.ts +2 -0
  185. package/dest/storage/capsule_store/index.d.ts.map +1 -0
  186. package/dest/storage/capsule_store/index.js +1 -0
  187. package/dest/storage/contract_store/contract_store.d.ts +93 -0
  188. package/dest/storage/contract_store/contract_store.d.ts.map +1 -0
  189. package/dest/storage/contract_store/contract_store.js +309 -0
  190. package/dest/storage/contract_store/index.d.ts +2 -0
  191. package/dest/storage/contract_store/index.d.ts.map +1 -0
  192. package/dest/storage/contract_store/index.js +1 -0
  193. package/dest/storage/{contract_data_provider → contract_store}/private_functions_tree.d.ts +1 -1
  194. package/dest/storage/contract_store/private_functions_tree.d.ts.map +1 -0
  195. package/dest/storage/{contract_data_provider → contract_store}/private_functions_tree.js +1 -1
  196. package/dest/storage/index.d.ts +8 -8
  197. package/dest/storage/index.d.ts.map +1 -1
  198. package/dest/storage/index.js +7 -7
  199. package/dest/storage/metadata.d.ts +2 -2
  200. package/dest/storage/metadata.js +1 -1
  201. package/dest/storage/note_store/index.d.ts +3 -0
  202. package/dest/storage/note_store/index.d.ts.map +1 -0
  203. package/dest/storage/note_store/index.js +2 -0
  204. package/dest/storage/note_store/note_store.d.ts +83 -0
  205. package/dest/storage/note_store/note_store.d.ts.map +1 -0
  206. package/dest/storage/note_store/note_store.js +343 -0
  207. package/dest/storage/note_store/stored_note.d.ts +16 -0
  208. package/dest/storage/note_store/stored_note.d.ts.map +1 -0
  209. package/dest/storage/note_store/stored_note.js +43 -0
  210. package/dest/storage/private_event_store/private_event_store.d.ts +91 -0
  211. package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -0
  212. package/dest/storage/private_event_store/private_event_store.js +273 -0
  213. package/dest/storage/private_event_store/stored_private_event.d.ts +23 -0
  214. package/dest/storage/private_event_store/stored_private_event.d.ts.map +1 -0
  215. package/dest/storage/private_event_store/stored_private_event.js +56 -0
  216. package/dest/storage/tagging_store/index.d.ts +4 -0
  217. package/dest/storage/tagging_store/index.d.ts.map +1 -0
  218. package/dest/storage/tagging_store/index.js +3 -0
  219. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +28 -0
  220. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -0
  221. package/dest/storage/tagging_store/recipient_tagging_store.js +111 -0
  222. package/dest/storage/tagging_store/sender_address_book_store.d.ts +14 -0
  223. package/dest/storage/tagging_store/sender_address_book_store.d.ts.map +1 -0
  224. package/dest/storage/tagging_store/sender_address_book_store.js +36 -0
  225. package/dest/storage/tagging_store/sender_tagging_store.d.ts +78 -0
  226. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -0
  227. package/dest/storage/tagging_store/sender_tagging_store.js +374 -0
  228. package/dest/tagging/constants.d.ts +2 -2
  229. package/dest/tagging/constants.d.ts.map +1 -1
  230. package/dest/tagging/constants.js +10 -2
  231. package/dest/tagging/get_all_logs_by_tags.d.ts +24 -0
  232. package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -0
  233. package/dest/tagging/get_all_logs_by_tags.js +60 -0
  234. package/dest/tagging/index.d.ts +17 -7
  235. package/dest/tagging/index.d.ts.map +1 -1
  236. package/dest/tagging/index.js +15 -5
  237. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +14 -0
  238. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +1 -0
  239. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +99 -0
  240. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts +12 -0
  241. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts.map +1 -0
  242. package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +20 -0
  243. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +14 -0
  244. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +1 -0
  245. package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +33 -0
  246. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +17 -0
  247. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -0
  248. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +80 -0
  249. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +12 -0
  250. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -0
  251. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +39 -0
  252. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +19 -0
  253. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -0
  254. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +72 -0
  255. package/package.json +29 -19
  256. package/src/access_scopes.ts +9 -0
  257. package/src/bin/check_oracle_version.ts +131 -20
  258. package/src/block_synchronizer/block_synchronizer.ts +178 -0
  259. package/src/block_synchronizer/index.ts +1 -0
  260. package/src/config/index.ts +25 -26
  261. package/src/config/package_info.ts +1 -1
  262. package/src/contract_function_simulator/benchmarked_node.ts +103 -0
  263. package/src/contract_function_simulator/contract_function_simulator.ts +431 -119
  264. package/src/contract_function_simulator/execution_note_cache.ts +58 -28
  265. package/src/contract_function_simulator/execution_tagging_index_cache.ts +19 -14
  266. package/src/contract_function_simulator/hashed_values_cache.ts +1 -1
  267. package/src/contract_function_simulator/index.ts +2 -1
  268. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +14 -7
  269. package/src/contract_function_simulator/noir-structs/log_retrieval_request.ts +6 -5
  270. package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +3 -6
  271. package/src/contract_function_simulator/noir-structs/message_tx_context.ts +55 -0
  272. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +16 -7
  273. package/src/contract_function_simulator/noir-structs/utility_context.ts +6 -25
  274. package/src/contract_function_simulator/oracle/interfaces.ts +86 -61
  275. package/src/contract_function_simulator/oracle/legacy_oracle_mappings.ts +135 -0
  276. package/src/contract_function_simulator/oracle/message_load_oracle_inputs.ts +1 -1
  277. package/src/contract_function_simulator/oracle/note_packing_utils.ts +30 -14
  278. package/src/contract_function_simulator/oracle/oracle.ts +258 -158
  279. package/src/contract_function_simulator/oracle/private_execution.ts +6 -72
  280. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +187 -167
  281. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +457 -115
  282. package/src/contract_function_simulator/pick_notes.ts +1 -1
  283. package/src/contract_function_simulator/proxied_contract_data_source.ts +24 -7
  284. package/src/contract_logging.ts +39 -0
  285. package/src/contract_sync/contract_sync_service.ts +181 -0
  286. package/src/contract_sync/helpers.ts +98 -0
  287. package/src/debug/pxe_debug_utils.ts +93 -0
  288. package/src/entrypoints/client/bundle/index.ts +3 -1
  289. package/src/entrypoints/client/bundle/utils.ts +25 -18
  290. package/src/entrypoints/client/lazy/index.ts +3 -1
  291. package/src/entrypoints/client/lazy/utils.ts +26 -19
  292. package/src/entrypoints/pxe_creation_options.ts +6 -2
  293. package/src/entrypoints/server/index.ts +5 -1
  294. package/src/entrypoints/server/utils.ts +34 -56
  295. package/src/error_enriching.ts +7 -15
  296. package/src/events/event_service.ts +71 -0
  297. package/src/events/index.ts +1 -0
  298. package/src/events/private_event_filter_validator.ts +46 -0
  299. package/src/job_coordinator/job_coordinator.ts +150 -0
  300. package/src/logs/log_service.ts +213 -0
  301. package/src/messages/message_context_service.ts +45 -0
  302. package/src/notes/index.ts +1 -0
  303. package/src/notes/note_service.ts +196 -0
  304. package/src/notes_filter.ts +26 -0
  305. package/src/oracle_version.ts +5 -4
  306. package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
  307. package/src/private_kernel/hints/index.ts +2 -2
  308. package/src/private_kernel/hints/{build_private_kernel_reset_private_inputs.ts → private_kernel_reset_private_inputs_builder.ts} +199 -145
  309. package/src/private_kernel/hints/test_utils.ts +325 -0
  310. package/src/private_kernel/private_kernel_execution_prover.ts +38 -34
  311. package/src/private_kernel/private_kernel_oracle.ts +118 -37
  312. package/src/pxe.ts +450 -389
  313. package/src/storage/{address_data_provider/address_data_provider.ts → address_store/address_store.ts} +16 -16
  314. package/src/storage/address_store/index.ts +1 -0
  315. package/src/storage/{sync_data_provider/sync_data_provider.ts → anchor_block_store/anchor_block_store.ts} +10 -11
  316. package/src/storage/anchor_block_store/index.ts +1 -0
  317. package/src/storage/capsule_store/capsule_store.ts +315 -0
  318. package/src/storage/capsule_store/index.ts +1 -0
  319. package/src/storage/contract_store/contract_store.ts +429 -0
  320. package/src/storage/contract_store/index.ts +1 -0
  321. package/src/storage/{contract_data_provider → contract_store}/private_functions_tree.ts +1 -1
  322. package/src/storage/index.ts +7 -7
  323. package/src/storage/metadata.ts +1 -1
  324. package/src/storage/note_store/index.ts +2 -0
  325. package/src/storage/note_store/note_store.ts +418 -0
  326. package/src/storage/note_store/stored_note.ts +48 -0
  327. package/src/storage/private_event_store/private_event_store.ts +384 -0
  328. package/src/storage/private_event_store/stored_private_event.ts +73 -0
  329. package/src/storage/tagging_store/index.ts +3 -0
  330. package/src/storage/tagging_store/recipient_tagging_store.ts +143 -0
  331. package/src/storage/tagging_store/sender_address_book_store.ts +48 -0
  332. package/src/storage/tagging_store/sender_tagging_store.ts +476 -0
  333. package/src/tagging/constants.ts +10 -2
  334. package/src/tagging/get_all_logs_by_tags.ts +92 -0
  335. package/src/tagging/index.ts +19 -6
  336. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +140 -0
  337. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +34 -0
  338. package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +44 -0
  339. package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +112 -0
  340. package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +51 -0
  341. package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +85 -0
  342. package/dest/contract_function_simulator/execution_data_provider.d.ts +0 -274
  343. package/dest/contract_function_simulator/execution_data_provider.d.ts.map +0 -1
  344. package/dest/contract_function_simulator/execution_data_provider.js +0 -14
  345. package/dest/contract_function_simulator/proxied_node.d.ts +0 -9
  346. package/dest/contract_function_simulator/proxied_node.d.ts.map +0 -1
  347. package/dest/contract_function_simulator/proxied_node.js +0 -27
  348. package/dest/contract_function_simulator/pxe_oracle_interface.d.ts +0 -122
  349. package/dest/contract_function_simulator/pxe_oracle_interface.d.ts.map +0 -1
  350. package/dest/contract_function_simulator/pxe_oracle_interface.js +0 -701
  351. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts +0 -28
  352. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts.map +0 -1
  353. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts +0 -4
  354. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts.map +0 -1
  355. package/dest/private_kernel/private_kernel_oracle_impl.d.ts +0 -45
  356. package/dest/private_kernel/private_kernel_oracle_impl.d.ts.map +0 -1
  357. package/dest/private_kernel/private_kernel_oracle_impl.js +0 -86
  358. package/dest/storage/address_data_provider/address_data_provider.d.ts +0 -11
  359. package/dest/storage/address_data_provider/address_data_provider.d.ts.map +0 -1
  360. package/dest/storage/address_data_provider/index.d.ts +0 -2
  361. package/dest/storage/address_data_provider/index.d.ts.map +0 -1
  362. package/dest/storage/address_data_provider/index.js +0 -1
  363. package/dest/storage/capsule_data_provider/capsule_data_provider.d.ts +0 -25
  364. package/dest/storage/capsule_data_provider/capsule_data_provider.d.ts.map +0 -1
  365. package/dest/storage/capsule_data_provider/capsule_data_provider.js +0 -118
  366. package/dest/storage/capsule_data_provider/index.d.ts +0 -2
  367. package/dest/storage/capsule_data_provider/index.d.ts.map +0 -1
  368. package/dest/storage/capsule_data_provider/index.js +0 -1
  369. package/dest/storage/contract_data_provider/contract_data_provider.d.ts +0 -74
  370. package/dest/storage/contract_data_provider/contract_data_provider.d.ts.map +0 -1
  371. package/dest/storage/contract_data_provider/contract_data_provider.js +0 -205
  372. package/dest/storage/contract_data_provider/index.d.ts +0 -2
  373. package/dest/storage/contract_data_provider/index.d.ts.map +0 -1
  374. package/dest/storage/contract_data_provider/index.js +0 -1
  375. package/dest/storage/contract_data_provider/private_functions_tree.d.ts.map +0 -1
  376. package/dest/storage/note_data_provider/index.d.ts +0 -3
  377. package/dest/storage/note_data_provider/index.d.ts.map +0 -1
  378. package/dest/storage/note_data_provider/index.js +0 -2
  379. package/dest/storage/note_data_provider/note_dao.d.ts +0 -100
  380. package/dest/storage/note_data_provider/note_dao.d.ts.map +0 -1
  381. package/dest/storage/note_data_provider/note_dao.js +0 -102
  382. package/dest/storage/note_data_provider/note_data_provider.d.ts +0 -83
  383. package/dest/storage/note_data_provider/note_data_provider.d.ts.map +0 -1
  384. package/dest/storage/note_data_provider/note_data_provider.js +0 -308
  385. package/dest/storage/private_event_data_provider/private_event_data_provider.d.ts +0 -43
  386. package/dest/storage/private_event_data_provider/private_event_data_provider.d.ts.map +0 -1
  387. package/dest/storage/private_event_data_provider/private_event_data_provider.js +0 -104
  388. package/dest/storage/sync_data_provider/index.d.ts +0 -2
  389. package/dest/storage/sync_data_provider/index.d.ts.map +0 -1
  390. package/dest/storage/sync_data_provider/index.js +0 -1
  391. package/dest/storage/sync_data_provider/sync_data_provider.d.ts +0 -10
  392. package/dest/storage/sync_data_provider/sync_data_provider.d.ts.map +0 -1
  393. package/dest/storage/tagging_data_provider/index.d.ts +0 -2
  394. package/dest/storage/tagging_data_provider/index.d.ts.map +0 -1
  395. package/dest/storage/tagging_data_provider/index.js +0 -1
  396. package/dest/storage/tagging_data_provider/tagging_data_provider.d.ts +0 -40
  397. package/dest/storage/tagging_data_provider/tagging_data_provider.d.ts.map +0 -1
  398. package/dest/storage/tagging_data_provider/tagging_data_provider.js +0 -89
  399. package/dest/synchronizer/index.d.ts +0 -2
  400. package/dest/synchronizer/index.d.ts.map +0 -1
  401. package/dest/synchronizer/index.js +0 -1
  402. package/dest/synchronizer/synchronizer.d.ts +0 -35
  403. package/dest/synchronizer/synchronizer.d.ts.map +0 -1
  404. package/dest/synchronizer/synchronizer.js +0 -101
  405. package/dest/tagging/siloed_tag.d.ts +0 -14
  406. package/dest/tagging/siloed_tag.d.ts.map +0 -1
  407. package/dest/tagging/siloed_tag.js +0 -20
  408. package/dest/tagging/tag.d.ts +0 -12
  409. package/dest/tagging/tag.d.ts.map +0 -1
  410. package/dest/tagging/tag.js +0 -17
  411. package/dest/tagging/utils.d.ts +0 -18
  412. package/dest/tagging/utils.d.ts.map +0 -1
  413. package/dest/tagging/utils.js +0 -24
  414. package/src/contract_function_simulator/execution_data_provider.ts +0 -343
  415. package/src/contract_function_simulator/proxied_node.ts +0 -33
  416. package/src/contract_function_simulator/pxe_oracle_interface.ts +0 -1019
  417. package/src/private_kernel/private_kernel_oracle_impl.ts +0 -132
  418. package/src/storage/address_data_provider/index.ts +0 -1
  419. package/src/storage/capsule_data_provider/capsule_data_provider.ts +0 -147
  420. package/src/storage/capsule_data_provider/index.ts +0 -1
  421. package/src/storage/contract_data_provider/contract_data_provider.ts +0 -294
  422. package/src/storage/contract_data_provider/index.ts +0 -1
  423. package/src/storage/note_data_provider/index.ts +0 -2
  424. package/src/storage/note_data_provider/note_dao.ts +0 -154
  425. package/src/storage/note_data_provider/note_data_provider.ts +0 -393
  426. package/src/storage/private_event_data_provider/private_event_data_provider.ts +0 -148
  427. package/src/storage/sync_data_provider/index.ts +0 -1
  428. package/src/storage/tagging_data_provider/index.ts +0 -1
  429. package/src/storage/tagging_data_provider/tagging_data_provider.ts +0 -120
  430. package/src/synchronizer/index.ts +0 -1
  431. package/src/synchronizer/synchronizer.ts +0 -120
  432. package/src/tagging/siloed_tag.ts +0 -22
  433. package/src/tagging/tag.ts +0 -16
  434. package/src/tagging/utils.ts +0 -31
@@ -1,55 +1,65 @@
1
1
  import { MAX_FR_CALLDATA_TO_ALL_ENQUEUED_CALLS, PRIVATE_CONTEXT_INPUTS_LENGTH } from '@aztec/constants';
2
- import { Fr } from '@aztec/foundation/fields';
2
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
3
  import { createLogger } from '@aztec/foundation/log';
4
4
  import { Timer } from '@aztec/foundation/timer';
5
5
  import { toACVMWitness } from '@aztec/simulator/client';
6
6
  import { FunctionSelector, countArgumentsSize } from '@aztec/stdlib/abi';
7
- import { computeUniqueNoteHash, siloNoteHash, siloNullifier } from '@aztec/stdlib/hash';
7
+ import { siloNullifier } from '@aztec/stdlib/hash';
8
8
  import { PrivateContextInputs } from '@aztec/stdlib/kernel';
9
+ import { ExtendedDirectionalAppTaggingSecret } from '@aztec/stdlib/logs';
10
+ import { Tag } from '@aztec/stdlib/logs';
9
11
  import { Note } from '@aztec/stdlib/note';
10
12
  import { CallContext, CountedContractClassLog, NoteAndSlot } from '@aztec/stdlib/tx';
11
- import { Tag } from '../../tagging/tag.js';
13
+ import { NoteService } from '../../notes/note_service.js';
14
+ import { syncSenderTaggingIndexes } from '../../tagging/index.js';
12
15
  import { pickNotes } from '../pick_notes.js';
13
- import { executePrivateFunction, verifyCurrentClassId } from './private_execution.js';
16
+ import { executePrivateFunction } from './private_execution.js';
14
17
  import { UtilityExecutionOracle } from './utility_execution_oracle.js';
15
18
  /**
16
19
  * The execution oracle for the private part of a transaction.
17
20
  */ export class PrivateExecutionOracle extends UtilityExecutionOracle {
21
+ isPrivate = true;
22
+ /**
23
+ * New notes created during this execution.
24
+ * It's possible that a note in this list has been nullified (in the same or other executions) and doesn't exist in
25
+ * the ExecutionNoteCache and the final proof data. But we still include those notes in the execution result because
26
+ * their commitments are still in the public inputs of this execution.
27
+ * This information is only for references (currently used for tests), and is not used for any sort of constrains.
28
+ * Users can also use this to get a clearer idea of what's happened during a simulation.
29
+ */ newNotes = [];
30
+ noteHashNullifierCounterMap = new Map();
31
+ contractClassLogs = [];
32
+ nestedExecutionResults = [];
18
33
  argsHash;
19
34
  txContext;
20
35
  callContext;
21
- anchorBlockHeader;
36
+ utilityExecutor;
22
37
  executionCache;
23
38
  noteCache;
24
39
  taggingIndexCache;
40
+ senderTaggingStore;
25
41
  totalPublicCalldataCount;
26
42
  sideEffectCounter;
27
43
  senderForTags;
28
44
  simulator;
29
- isPrivate;
30
- /**
31
- * New notes created during this execution.
32
- * It's possible that a note in this list has been nullified (in the same or other executions) and doesn't exist in
33
- * the ExecutionNoteCache and the final proof data. But we still include those notes in the execution result because
34
- * their commitments are still in the public inputs of this execution.
35
- * This information is only for references (currently used for tests), and is not used for any sort of constrains.
36
- * Users can also use this to get a clearer idea of what's happened during a simulation.
37
- */ newNotes;
38
- /**
39
- * Notes from previous transactions that are returned to the oracle call `getNotes` during this execution.
40
- * The mapping maps from the unique siloed note hash to the index for notes created in private executions.
41
- * It maps from siloed note hash to the index for notes created by public functions.
42
- *
43
- * They are not part of the ExecutionNoteCache and being forwarded to nested contexts via `extend()`
44
- * because these notes are meant to be maintained on a per-call basis
45
- * They should act as references for the read requests output by an app circuit via public inputs.
46
- */ noteHashLeafIndexMap;
47
- noteHashNullifierCounterMap;
48
- contractClassLogs;
49
- offchainEffects;
50
- nestedExecutionResults;
51
- constructor(argsHash, txContext, callContext, /** Header of a block whose state is used during private execution (not the block the transaction is included in). */ anchorBlockHeader, /** List of transient auth witnesses to be used during this simulation */ authWitnesses, capsules, executionCache, noteCache, taggingIndexCache, executionDataProvider, totalPublicCalldataCount = 0, sideEffectCounter = 0, log = createLogger('simulator:client_execution_context'), scopes, senderForTags, simulator){
52
- super(callContext.contractAddress, authWitnesses, capsules, executionDataProvider, log, scopes), this.argsHash = argsHash, this.txContext = txContext, this.callContext = callContext, this.anchorBlockHeader = anchorBlockHeader, this.executionCache = executionCache, this.noteCache = noteCache, this.taggingIndexCache = taggingIndexCache, this.totalPublicCalldataCount = totalPublicCalldataCount, this.sideEffectCounter = sideEffectCounter, this.senderForTags = senderForTags, this.simulator = simulator, this.isPrivate = true, this.newNotes = [], this.noteHashLeafIndexMap = new Map(), this.noteHashNullifierCounterMap = new Map(), this.contractClassLogs = [], this.offchainEffects = [], this.nestedExecutionResults = [];
45
+ constructor(args){
46
+ super({
47
+ ...args,
48
+ contractAddress: args.callContext.contractAddress,
49
+ log: args.log ?? createLogger('simulator:client_execution_context')
50
+ });
51
+ this.argsHash = args.argsHash;
52
+ this.txContext = args.txContext;
53
+ this.callContext = args.callContext;
54
+ this.utilityExecutor = args.utilityExecutor;
55
+ this.executionCache = args.executionCache;
56
+ this.noteCache = args.noteCache;
57
+ this.taggingIndexCache = args.taggingIndexCache;
58
+ this.senderTaggingStore = args.senderTaggingStore;
59
+ this.totalPublicCalldataCount = args.totalPublicCalldataCount ?? 0;
60
+ this.sideEffectCounter = args.sideEffectCounter ?? 0;
61
+ this.senderForTags = args.senderForTags;
62
+ this.simulator = args.simulator;
53
63
  }
54
64
  getPrivateContextInputs() {
55
65
  return new PrivateContextInputs(this.callContext, this.anchorBlockHeader, this.txContext, this.sideEffectCounter);
@@ -77,12 +87,6 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
77
87
  return toACVMWitness(0, fields);
78
88
  }
79
89
  /**
80
- * The KernelProver will use this to fully populate witnesses and provide hints to the kernel circuit
81
- * regarding which note hash each settled read request corresponds to.
82
- */ getNoteHashLeafIndexMap() {
83
- return this.noteHashLeafIndexMap;
84
- }
85
- /**
86
90
  * Get the data for the newly created notes.
87
91
  */ getNewNotes() {
88
92
  return this.newNotes;
@@ -96,14 +100,9 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
96
100
  return this.contractClassLogs;
97
101
  }
98
102
  /**
99
- * Return the offchain effects emitted during this execution.
100
- */ getOffchainEffects() {
101
- return this.offchainEffects;
102
- }
103
- /**
104
- * Returns the pre tags that were used in this execution (and that need to be stored in the db).
105
- */ getUsedPreTags() {
106
- return this.taggingIndexCache.getUsedPreTags();
103
+ * Returns the tagging index ranges that were used in this execution (and that need to be stored in the db).
104
+ */ getUsedTaggingIndexRanges() {
105
+ return this.taggingIndexCache.getUsedTaggingIndexRanges();
107
106
  }
108
107
  /**
109
108
  * Return the nested execution results during this execution.
@@ -119,7 +118,7 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
119
118
  *
120
119
  * The value persists through nested calls, meaning all calls down the stack will use the same
121
120
  * 'senderForTags' value (unless it is replaced).
122
- */ privateGetSenderForTags() {
121
+ */ getSenderForTags() {
123
122
  return Promise.resolve(this.senderForTags);
124
123
  }
125
124
  /**
@@ -132,7 +131,7 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
132
131
  * Account contracts typically set this value before calling other contracts. The value persists
133
132
  * through nested calls, meaning all calls down the stack will use the same 'senderForTags'
134
133
  * value (unless it is replaced by another call to this setter).
135
- */ privateSetSenderForTags(senderForTags) {
134
+ */ setSenderForTags(senderForTags) {
136
135
  this.senderForTags = senderForTags;
137
136
  return Promise.resolve();
138
137
  }
@@ -141,16 +140,21 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
141
140
  * @param sender - The address sending the log
142
141
  * @param recipient - The address receiving the log
143
142
  * @returns An app tag to be used in a log.
144
- */ async privateGetNextAppTagAsSender(sender, recipient) {
145
- const secret = await this.executionDataProvider.calculateDirectionalAppTaggingSecret(this.contractAddress, sender, recipient);
146
- const index = await this.#getIndexToUseForSecret(secret);
147
- this.log.debug(`Incrementing tagging index for sender: ${sender}, recipient: ${recipient}, contract: ${this.contractAddress} to ${index}`);
148
- this.taggingIndexCache.setLastUsedIndex(secret, index);
143
+ */ async getNextAppTagAsSender(sender, recipient) {
144
+ const extendedSecret = await this.#calculateExtendedDirectionalAppTaggingSecret(this.contractAddress, sender, recipient);
145
+ const index = await this.#getIndexToUseForSecret(extendedSecret);
146
+ this.logger.debug(`Incrementing tagging index for sender: ${sender}, recipient: ${recipient}, contract: ${this.contractAddress} to ${index}`);
147
+ this.taggingIndexCache.setLastUsedIndex(extendedSecret, index);
149
148
  return Tag.compute({
150
- secret,
149
+ extendedSecret,
151
150
  index
152
151
  });
153
152
  }
153
+ async #calculateExtendedDirectionalAppTaggingSecret(contractAddress, sender, recipient) {
154
+ const senderCompleteAddress = await this.getCompleteAddressOrFail(sender);
155
+ const senderIvsk = await this.keyStore.getMasterIncomingViewingSecretKey(sender);
156
+ return ExtendedDirectionalAppTaggingSecret.compute(senderCompleteAddress, senderIvsk, recipient, contractAddress, recipient);
157
+ }
154
158
  async #getIndexToUseForSecret(secret) {
155
159
  // If we have the tagging index in the cache, we use it. If not we obtain it from the execution data provider.
156
160
  const lastUsedIndexInTx = this.taggingIndexCache.getLastUsedIndex(secret);
@@ -160,8 +164,8 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
160
164
  // This is a tagging secret we've not yet used in this tx, so first sync our store to make sure its indices
161
165
  // are up to date. We do this here because this store is not synced as part of the global sync because
162
166
  // that'd be wasteful as most tagging secrets are not used in each tx.
163
- await this.executionDataProvider.syncTaggedLogsAsSender(secret, this.contractAddress);
164
- const lastUsedIndex = await this.executionDataProvider.getLastUsedIndexAsSender(secret);
167
+ await syncSenderTaggingIndexes(secret, this.aztecNode, this.senderTaggingStore, await this.anchorBlockHeader.hash(), this.jobId);
168
+ const lastUsedIndex = await this.senderTaggingStore.getLastUsedIndex(secret, this.jobId);
165
169
  // If lastUsedIndex is undefined, we've never used this secret, so start from 0
166
170
  // Otherwise, the next index to use is one past the last used index
167
171
  return lastUsedIndex === undefined ? 0 : lastUsedIndex + 1;
@@ -171,29 +175,29 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
171
175
  * Store values in the execution cache.
172
176
  * @param values - Values to store.
173
177
  * @returns The hash of the values.
174
- */ privateStoreInExecutionCache(values, hash) {
178
+ */ storeInExecutionCache(values, hash) {
175
179
  return this.executionCache.store(values, hash);
176
180
  }
177
181
  /**
178
182
  * Gets values from the execution cache.
179
183
  * @param hash - Hash of the values.
180
184
  * @returns The values.
181
- */ privateLoadFromExecutionCache(hash) {
185
+ */ loadFromExecutionCache(hash) {
182
186
  const preimage = this.executionCache.getPreimage(hash);
183
187
  if (!preimage) {
184
188
  throw new Error(`Preimage for hash ${hash.toString()} not found in cache`);
185
189
  }
186
190
  return Promise.resolve(preimage);
187
191
  }
188
- async utilityCheckNullifierExists(innerNullifier) {
192
+ async checkNullifierExists(innerNullifier) {
189
193
  // This oracle must be overridden because while utility execution can only meaningfully check if a nullifier exists
190
194
  // in the synched block, during private execution there's also the possibility of it being pending, i.e. created
191
195
  // in the current transaction.
192
- this.log.debug(`Checking existence of inner nullifier ${innerNullifier}`, {
196
+ this.logger.debug(`Checking existence of inner nullifier ${innerNullifier}`, {
193
197
  contractAddress: this.contractAddress
194
198
  });
195
199
  const nullifier = (await siloNullifier(this.contractAddress, innerNullifier)).toBigInt();
196
- return this.noteCache.getNullifiers(this.contractAddress).has(nullifier) || await super.utilityCheckNullifierExists(innerNullifier);
200
+ return this.noteCache.getNullifiers(this.contractAddress).has(nullifier) || await super.checkNullifierExists(innerNullifier);
197
201
  }
198
202
  /**
199
203
  * Gets some notes for a storage slot.
@@ -203,6 +207,7 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
203
207
  * Real notes coming from DB will have a leafIndex which
204
208
  * represents their index in the note hash tree.
205
209
  *
210
+ * @param owner - The owner of the notes. If undefined, returns notes for all owners.
206
211
  * @param storageSlot - The storage slot.
207
212
  * @param numSelects - The number of valid selects in selectBy and selectValues.
208
213
  * @param selectBy - An array of indices of the fields to selects.
@@ -214,11 +219,12 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
214
219
  * @param offset - The starting index for pagination.
215
220
  * @param status - The status of notes to fetch.
216
221
  * @returns Array of note data.
217
- */ async utilityGetNotes(storageSlot, numSelects, selectByIndexes, selectByOffsets, selectByLengths, selectValues, selectComparators, sortByIndexes, sortByOffsets, sortByLengths, sortOrder, limit, offset, status) {
222
+ */ async getNotes(owner, storageSlot, numSelects, selectByIndexes, selectByOffsets, selectByLengths, selectValues, selectComparators, sortByIndexes, sortByOffsets, sortByLengths, sortOrder, limit, offset, status) {
218
223
  // Nullified pending notes are already removed from the list.
219
- const pendingNotes = this.noteCache.getNotes(this.callContext.contractAddress, storageSlot);
224
+ const pendingNotes = this.noteCache.getNotes(this.callContext.contractAddress, owner, storageSlot);
220
225
  const pendingNullifiers = this.noteCache.getNullifiers(this.callContext.contractAddress);
221
- const dbNotes = await this.executionDataProvider.getNotes(this.callContext.contractAddress, storageSlot, status, this.scopes);
226
+ const noteService = new NoteService(this.noteStore, this.aztecNode, this.anchorBlockHeader, this.jobId);
227
+ const dbNotes = await noteService.getNotes(this.callContext.contractAddress, owner, storageSlot, status, this.scopes);
222
228
  const dbNotesFiltered = dbNotes.filter((n)=>!pendingNullifiers.has(n.siloedNullifier.value));
223
229
  const notes = pickNotes([
224
230
  ...dbNotesFiltered,
@@ -244,55 +250,52 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
244
250
  limit,
245
251
  offset
246
252
  });
247
- this.log.debug(`Returning ${notes.length} notes for ${this.callContext.contractAddress} at ${storageSlot}: ${notes.map((n)=>`${n.noteNonce.toString()}:[${n.note.items.map((i)=>i.toString()).join(',')}]`).join(', ')}`);
248
- const noteHashesAndIndexes = await Promise.all(notes.map(async (n)=>{
249
- if (n.index !== undefined) {
250
- const siloedNoteHash = await siloNoteHash(n.contractAddress, n.noteHash);
251
- const uniqueNoteHash = await computeUniqueNoteHash(n.noteNonce, siloedNoteHash);
252
- return {
253
- hash: uniqueNoteHash,
254
- index: n.index
255
- };
256
- }
257
- }));
258
- noteHashesAndIndexes.filter((n)=>n !== undefined).forEach((n)=>{
259
- this.noteHashLeafIndexMap.set(n.hash.toBigInt(), n.index);
260
- });
253
+ this.logger.debug(`Returning ${notes.length} notes for ${this.callContext.contractAddress} at ${storageSlot}: ${notes.map((n)=>`${n.noteNonce.toString()}:[${n.note.items.map((i)=>i.toString()).join(',')}]`).join(', ')}`);
261
254
  return notes;
262
255
  }
263
256
  /**
264
257
  * Keep track of the new note created during execution.
265
258
  * It can be used in subsequent calls (or transactions when chaining txs is possible).
266
- * @param contractAddress - The contract address.
259
+ * @param owner - The owner of the note.
267
260
  * @param storageSlot - The storage slot.
261
+ * @param randomness - The randomness injected into the note.
268
262
  * @param noteTypeId - The type ID of the note.
269
263
  * @param noteItems - The items to be included in a Note.
270
264
  * @param noteHash - A hash of the new note.
271
265
  * @returns
272
- */ privateNotifyCreatedNote(storageSlot, noteTypeId, noteItems, noteHash, counter) {
273
- this.log.debug(`Notified of new note with inner hash ${noteHash}`, {
266
+ */ notifyCreatedNote(owner, storageSlot, randomness, noteTypeId, noteItems, noteHash, counter) {
267
+ this.logger.debug(`Notified of new note with inner hash ${noteHash}`, {
274
268
  contractAddress: this.callContext.contractAddress,
275
269
  storageSlot,
270
+ randomness,
276
271
  noteTypeId,
277
272
  counter
278
273
  });
279
274
  const note = new Note(noteItems);
280
275
  this.noteCache.addNewNote({
281
276
  contractAddress: this.callContext.contractAddress,
277
+ owner,
282
278
  storageSlot,
279
+ randomness,
283
280
  noteNonce: Fr.ZERO,
284
281
  note,
285
282
  siloedNullifier: undefined,
286
- noteHash
283
+ noteHash,
284
+ isPending: true
287
285
  }, counter);
288
- this.newNotes.push(new NoteAndSlot(note, storageSlot, noteTypeId));
286
+ this.newNotes.push(NoteAndSlot.from({
287
+ note,
288
+ storageSlot,
289
+ randomness,
290
+ noteTypeId
291
+ }));
289
292
  }
290
293
  /**
291
294
  * Adding a siloed nullifier into the current set of all pending nullifiers created
292
295
  * within the current transaction/execution.
293
296
  * @param innerNullifier - The pending nullifier to add in the list (not yet siloed by contract address).
294
297
  * @param noteHash - A hash of the new note.
295
- */ async privateNotifyNullifiedNote(innerNullifier, noteHash, counter) {
298
+ */ async notifyNullifiedNote(innerNullifier, noteHash, counter) {
296
299
  const nullifiedNoteHashCounter = await this.noteCache.nullifyNote(this.callContext.contractAddress, innerNullifier, noteHash);
297
300
  if (nullifiedNoteHashCounter !== undefined) {
298
301
  this.noteHashNullifierCounterMap.set(nullifiedNoteHashCounter, counter);
@@ -303,22 +306,33 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
303
306
  * within the current transaction/execution.
304
307
  * @param innerNullifier - The pending nullifier to add in the list (not yet siloed by contract address).
305
308
  * @param noteHash - A hash of the new note.
306
- */ privateNotifyCreatedNullifier(innerNullifier) {
307
- this.log.debug(`Notified of new inner nullifier ${innerNullifier}`, {
309
+ */ notifyCreatedNullifier(innerNullifier) {
310
+ this.logger.debug(`Notified of new inner nullifier ${innerNullifier}`, {
308
311
  contractAddress: this.contractAddress
309
312
  });
310
313
  return this.noteCache.nullifierCreated(this.callContext.contractAddress, innerNullifier);
311
314
  }
312
315
  /**
316
+ * Check if a nullifier has been emitted in the same transaction, i.e. if notifyCreatedNullifier has been
317
+ * called for this inner nullifier from the contract with the specified address.
318
+ * @param innerNullifier - The inner nullifier to check.
319
+ * @param contractAddress - Address of the contract that emitted the nullifier.
320
+ * @returns A boolean indicating whether the nullifier is pending or not.
321
+ */ async isNullifierPending(innerNullifier, contractAddress) {
322
+ const siloedNullifier = await siloNullifier(contractAddress, innerNullifier);
323
+ const isNullifierPending = this.noteCache.getNullifiers(contractAddress).has(siloedNullifier.toBigInt());
324
+ return Promise.resolve(isNullifierPending);
325
+ }
326
+ /**
313
327
  * Emit a contract class log.
314
328
  * This fn exists because we only carry a poseidon hash through the kernels, and need to
315
329
  * keep the preimage in ts for later.
316
330
  * @param log - The contract class log to be emitted.
317
331
  * @param counter - The contract class log's counter.
318
- */ privateNotifyCreatedContractClassLog(log, counter) {
332
+ */ notifyCreatedContractClassLog(log, counter) {
319
333
  this.contractClassLogs.push(new CountedContractClassLog(log, counter));
320
334
  const text = log.toBuffer().toString('hex');
321
- this.log.verbose(`Emitted log from ContractClassRegistry: "${text.length > 100 ? text.slice(0, 100) + '...' : text}"`);
335
+ this.logger.verbose(`Emitted log from ContractClassRegistry: "${text.length > 100 ? text.slice(0, 100) + '...' : text}"`);
322
336
  }
323
337
  #checkValidStaticCall(childExecutionResult) {
324
338
  if (childExecutionResult.publicInputs.noteHashes.claimedLength > 0 || childExecutionResult.publicInputs.nullifiers.claimedLength > 0 || childExecutionResult.publicInputs.l2ToL1Msgs.claimedLength > 0 || childExecutionResult.publicInputs.privateLogs.claimedLength > 0 || childExecutionResult.publicInputs.contractClassLogsHashes.claimedLength > 0) {
@@ -333,20 +347,50 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
333
347
  * @param sideEffectCounter - The side effect counter at the start of the call.
334
348
  * @param isStaticCall - Whether the call is a static call.
335
349
  * @returns The execution result.
336
- */ async privateCallPrivateFunction(targetContractAddress, functionSelector, argsHash, sideEffectCounter, isStaticCall) {
350
+ */ async callPrivateFunction(targetContractAddress, functionSelector, argsHash, sideEffectCounter, isStaticCall) {
337
351
  if (!this.simulator) {
338
352
  // In practice it is only when creating inline private contexts in a Noir test using TXE that we create an
339
353
  // instance of this class without a simulator.
340
354
  throw new Error('No simulator provided, cannot perform a nested private call');
341
355
  }
342
356
  const simulatorSetupTimer = new Timer();
343
- this.log.debug(`Calling private function ${targetContractAddress}:${functionSelector} from ${this.callContext.contractAddress}`);
357
+ this.logger.debug(`Calling private function ${targetContractAddress}:${functionSelector} from ${this.callContext.contractAddress}`);
344
358
  isStaticCall = isStaticCall || this.callContext.isStaticCall;
345
- await verifyCurrentClassId(targetContractAddress, this.executionDataProvider, this.anchorBlockHeader);
346
- const targetArtifact = await this.executionDataProvider.getFunctionArtifact(targetContractAddress, functionSelector);
359
+ await this.contractSyncService.ensureContractSynced(targetContractAddress, functionSelector, this.utilityExecutor, this.anchorBlockHeader, this.jobId, this.scopes);
360
+ const targetArtifact = await this.contractStore.getFunctionArtifactWithDebugMetadata(targetContractAddress, functionSelector);
347
361
  const derivedTxContext = this.txContext.clone();
348
362
  const derivedCallContext = await this.deriveCallContext(targetContractAddress, targetArtifact, isStaticCall);
349
- const privateExecutionOracle = new PrivateExecutionOracle(argsHash, derivedTxContext, derivedCallContext, this.anchorBlockHeader, this.authWitnesses, this.capsules, this.executionCache, this.noteCache, this.taggingIndexCache, this.executionDataProvider, this.totalPublicCalldataCount, sideEffectCounter, this.log, this.scopes, this.senderForTags, this.simulator);
363
+ const privateExecutionOracle = new PrivateExecutionOracle({
364
+ argsHash,
365
+ txContext: derivedTxContext,
366
+ callContext: derivedCallContext,
367
+ anchorBlockHeader: this.anchorBlockHeader,
368
+ utilityExecutor: this.utilityExecutor,
369
+ authWitnesses: this.authWitnesses,
370
+ capsules: this.capsules,
371
+ executionCache: this.executionCache,
372
+ noteCache: this.noteCache,
373
+ taggingIndexCache: this.taggingIndexCache,
374
+ contractStore: this.contractStore,
375
+ noteStore: this.noteStore,
376
+ keyStore: this.keyStore,
377
+ addressStore: this.addressStore,
378
+ aztecNode: this.aztecNode,
379
+ senderTaggingStore: this.senderTaggingStore,
380
+ recipientTaggingStore: this.recipientTaggingStore,
381
+ senderAddressBookStore: this.senderAddressBookStore,
382
+ capsuleStore: this.capsuleStore,
383
+ privateEventStore: this.privateEventStore,
384
+ messageContextService: this.messageContextService,
385
+ contractSyncService: this.contractSyncService,
386
+ jobId: this.jobId,
387
+ totalPublicCalldataCount: this.totalPublicCalldataCount,
388
+ sideEffectCounter,
389
+ log: this.logger,
390
+ scopes: this.scopes,
391
+ senderForTags: this.senderForTags,
392
+ simulator: this.simulator
393
+ });
350
394
  const setupTime = simulatorSetupTimer.ms();
351
395
  const childExecutionResult = await executePrivateFunction(this.simulator, privateExecutionOracle, targetArtifact, targetContractAddress, functionSelector);
352
396
  if (isStaticCall) {
@@ -363,7 +407,7 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
363
407
  returnsHash: publicInputs.returnsHash
364
408
  };
365
409
  }
366
- #onNewPublicFunctionCall(calldataHash) {
410
+ /** Validates the calldata preimage exists in the cache and checks cumulative calldata size is within limits. */ validatePublicCalldata(calldataHash) {
367
411
  const calldata = this.executionCache.getPreimage(calldataHash);
368
412
  if (!calldata) {
369
413
  throw new Error('Calldata for public call not found in cache');
@@ -372,30 +416,14 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
372
416
  if (this.totalPublicCalldataCount > MAX_FR_CALLDATA_TO_ALL_ENQUEUED_CALLS) {
373
417
  throw new Error(`Too many total args to all enqueued public calls! (> ${MAX_FR_CALLDATA_TO_ALL_ENQUEUED_CALLS})`);
374
418
  }
375
- }
376
- /**
377
- * Verify relevant information when a public function is enqueued.
378
- * @param targetContractAddress - The address of the contract to call.
379
- * @param calldataHash - The hash of the function selector and arguments.
380
- * @param sideEffectCounter - The side effect counter at the start of the call.
381
- * @param isStaticCall - Whether the call is a static call.
382
- */ privateNotifyEnqueuedPublicFunctionCall(_targetContractAddress, calldataHash, _sideEffectCounter, _isStaticCall) {
383
- this.#onNewPublicFunctionCall(calldataHash);
384
419
  return Promise.resolve();
385
420
  }
386
- /**
387
- * Verify relevant information when a public teardown function is set.
388
- * @param targetContractAddress - The address of the contract to call.
389
- * @param argsHash - The arguments hash to pass to the function.
390
- * @param sideEffectCounter - The side effect counter at the start of the call.
391
- * @param isStaticCall - Whether the call is a static call.
392
- */ privateNotifySetPublicTeardownFunctionCall(_targetContractAddress, calldataHash, _sideEffectCounter, _isStaticCall) {
393
- this.#onNewPublicFunctionCall(calldataHash);
394
- return Promise.resolve();
395
- }
396
- privateNotifySetMinRevertibleSideEffectCounter(minRevertibleSideEffectCounter) {
421
+ notifyRevertiblePhaseStart(minRevertibleSideEffectCounter) {
397
422
  return this.noteCache.setMinRevertibleSideEffectCounter(minRevertibleSideEffectCounter);
398
423
  }
424
+ inRevertiblePhase(sideEffectCounter) {
425
+ return Promise.resolve(this.noteCache.isSideEffectCounterRevertible(sideEffectCounter));
426
+ }
399
427
  /**
400
428
  * Derives the call context for a nested execution.
401
429
  * @param targetContractAddress - The address of the contract being called.
@@ -406,12 +434,6 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
406
434
  return new CallContext(this.contractAddress, targetContractAddress, await FunctionSelector.fromNameAndParameters(targetArtifact.name, targetArtifact.parameters), isStaticCall);
407
435
  }
408
436
  getDebugFunctionName() {
409
- return this.executionDataProvider.getDebugFunctionName(this.contractAddress, this.callContext.functionSelector);
410
- }
411
- utilityEmitOffchainEffect(data) {
412
- this.offchainEffects.push({
413
- data
414
- });
415
- return Promise.resolve();
437
+ return this.contractStore.getDebugFunctionName(this.contractAddress, this.callContext.functionSelector);
416
438
  }
417
439
  }