@aztec/pxe 0.0.1-commit.9b94fc1 → 0.0.1-commit.9ee6fcc6

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 (425) 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 +7 -5
  12. package/dest/config/index.d.ts.map +1 -1
  13. package/dest/config/index.js +18 -1
  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 +82 -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 +246 -79
  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 +7 -7
  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 +19 -11
  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 +3 -2
  30. package/dest/contract_function_simulator/index.d.ts.map +1 -1
  31. package/dest/contract_function_simulator/index.js +2 -1
  32. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +6 -6
  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 +11 -7
  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 +2 -4
  41. package/dest/contract_function_simulator/noir-structs/message_tx_context.d.ts +16 -0
  42. package/dest/contract_function_simulator/noir-structs/message_tx_context.d.ts.map +1 -0
  43. package/dest/contract_function_simulator/noir-structs/message_tx_context.js +57 -0
  44. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +6 -7
  45. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
  46. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +9 -8
  47. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts +4 -10
  48. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts.map +1 -1
  49. package/dest/contract_function_simulator/noir-structs/utility_context.js +7 -18
  50. package/dest/contract_function_simulator/oracle/interfaces.d.ts +62 -50
  51. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
  52. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts +9 -0
  53. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts.map +1 -0
  54. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.js +42 -0
  55. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts +4 -2
  56. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts.map +1 -1
  57. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.js +1 -1
  58. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts +11 -7
  59. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts.map +1 -1
  60. package/dest/contract_function_simulator/oracle/note_packing_utils.js +14 -10
  61. package/dest/contract_function_simulator/oracle/oracle.d.ts +45 -42
  62. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
  63. package/dest/contract_function_simulator/oracle/oracle.js +222 -118
  64. package/dest/contract_function_simulator/oracle/private_execution.d.ts +2 -27
  65. package/dest/contract_function_simulator/oracle/private_execution.d.ts.map +1 -1
  66. package/dest/contract_function_simulator/oracle/private_execution.js +6 -40
  67. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +66 -82
  68. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
  69. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +129 -118
  70. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +149 -55
  71. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
  72. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +290 -104
  73. package/dest/contract_function_simulator/pick_notes.d.ts +2 -2
  74. package/dest/contract_function_simulator/pick_notes.d.ts.map +1 -1
  75. package/dest/contract_function_simulator/pick_notes.js +1 -1
  76. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts +4 -4
  77. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts.map +1 -1
  78. package/dest/contract_function_simulator/proxied_contract_data_source.js +23 -5
  79. package/dest/contract_logging.d.ts +22 -0
  80. package/dest/contract_logging.d.ts.map +1 -0
  81. package/dest/contract_logging.js +23 -0
  82. package/dest/contract_sync/contract_sync_service.d.ts +45 -0
  83. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -0
  84. package/dest/contract_sync/contract_sync_service.js +114 -0
  85. package/dest/contract_sync/helpers.d.ts +29 -0
  86. package/dest/contract_sync/helpers.d.ts.map +1 -0
  87. package/dest/contract_sync/helpers.js +55 -0
  88. package/dest/debug/pxe_debug_utils.d.ts +45 -0
  89. package/dest/debug/pxe_debug_utils.d.ts.map +1 -0
  90. package/dest/debug/pxe_debug_utils.js +48 -0
  91. package/dest/entrypoints/client/bundle/index.d.ts +4 -2
  92. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  93. package/dest/entrypoints/client/bundle/index.js +3 -1
  94. package/dest/entrypoints/client/bundle/utils.d.ts +1 -1
  95. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  96. package/dest/entrypoints/client/bundle/utils.js +32 -9
  97. package/dest/entrypoints/client/lazy/index.d.ts +4 -2
  98. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  99. package/dest/entrypoints/client/lazy/index.js +3 -1
  100. package/dest/entrypoints/client/lazy/utils.d.ts +2 -2
  101. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  102. package/dest/entrypoints/client/lazy/utils.js +33 -10
  103. package/dest/entrypoints/pxe_creation_options.d.ts +7 -3
  104. package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
  105. package/dest/entrypoints/server/index.d.ts +6 -2
  106. package/dest/entrypoints/server/index.d.ts.map +1 -1
  107. package/dest/entrypoints/server/index.js +5 -1
  108. package/dest/entrypoints/server/utils.d.ts +1 -1
  109. package/dest/entrypoints/server/utils.d.ts.map +1 -1
  110. package/dest/entrypoints/server/utils.js +39 -16
  111. package/dest/error_enriching.d.ts +4 -4
  112. package/dest/error_enriching.d.ts.map +1 -1
  113. package/dest/error_enriching.js +6 -6
  114. package/dest/events/event_service.d.ts +15 -0
  115. package/dest/events/event_service.d.ts.map +1 -0
  116. package/dest/events/event_service.js +44 -0
  117. package/dest/events/index.d.ts +2 -0
  118. package/dest/events/index.d.ts.map +1 -0
  119. package/dest/events/index.js +1 -0
  120. package/dest/events/private_event_filter_validator.d.ts +9 -0
  121. package/dest/events/private_event_filter_validator.d.ts.map +1 -0
  122. package/dest/events/private_event_filter_validator.js +38 -0
  123. package/dest/job_coordinator/job_coordinator.d.ts +75 -0
  124. package/dest/job_coordinator/job_coordinator.d.ts.map +1 -0
  125. package/dest/job_coordinator/job_coordinator.js +94 -0
  126. package/dest/logs/log_service.d.ts +29 -0
  127. package/dest/logs/log_service.d.ts.map +1 -0
  128. package/dest/logs/log_service.js +118 -0
  129. package/dest/messages/message_context_service.d.ts +17 -0
  130. package/dest/messages/message_context_service.d.ts.map +1 -0
  131. package/dest/messages/message_context_service.js +36 -0
  132. package/dest/notes/index.d.ts +2 -0
  133. package/dest/notes/index.d.ts.map +1 -0
  134. package/dest/notes/index.js +1 -0
  135. package/dest/notes/note_service.d.ts +49 -0
  136. package/dest/notes/note_service.d.ts.map +1 -0
  137. package/dest/notes/note_service.js +148 -0
  138. package/dest/notes_filter.d.ts +25 -0
  139. package/dest/notes_filter.d.ts.map +1 -0
  140. package/dest/notes_filter.js +4 -0
  141. package/dest/oracle_version.d.ts +3 -3
  142. package/dest/oracle_version.d.ts.map +1 -1
  143. package/dest/oracle_version.js +5 -4
  144. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
  145. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
  146. package/dest/private_kernel/hints/{compute_tx_include_by_timestamp.js → compute_tx_expiration_timestamp.js} +12 -12
  147. package/dest/private_kernel/hints/index.d.ts +3 -3
  148. package/dest/private_kernel/hints/index.d.ts.map +1 -1
  149. package/dest/private_kernel/hints/index.js +2 -2
  150. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +29 -0
  151. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -0
  152. package/dest/private_kernel/hints/{build_private_kernel_reset_private_inputs.js → private_kernel_reset_private_inputs_builder.js} +141 -74
  153. package/dest/private_kernel/hints/test_utils.d.ts +122 -0
  154. package/dest/private_kernel/hints/test_utils.d.ts.map +1 -0
  155. package/dest/private_kernel/hints/test_utils.js +203 -0
  156. package/dest/private_kernel/private_kernel_execution_prover.d.ts +3 -2
  157. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
  158. package/dest/private_kernel/private_kernel_execution_prover.js +28 -21
  159. package/dest/private_kernel/private_kernel_oracle.d.ts +26 -25
  160. package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
  161. package/dest/private_kernel/private_kernel_oracle.js +94 -2
  162. package/dest/pxe.d.ts +117 -103
  163. package/dest/pxe.d.ts.map +1 -1
  164. package/dest/pxe.js +283 -262
  165. package/dest/storage/address_store/address_store.d.ts +11 -0
  166. package/dest/storage/address_store/address_store.d.ts.map +1 -0
  167. package/dest/storage/{address_data_provider/address_data_provider.js → address_store/address_store.js} +13 -12
  168. package/dest/storage/address_store/index.d.ts +2 -0
  169. package/dest/storage/address_store/index.d.ts.map +1 -0
  170. package/dest/storage/address_store/index.js +1 -0
  171. package/dest/storage/anchor_block_store/anchor_block_store.d.ts +17 -0
  172. package/dest/storage/anchor_block_store/anchor_block_store.d.ts.map +1 -0
  173. package/dest/storage/{sync_data_provider/sync_data_provider.js → anchor_block_store/anchor_block_store.js} +10 -10
  174. package/dest/storage/{sync_data_provider → anchor_block_store}/index.d.ts +2 -2
  175. package/dest/storage/anchor_block_store/index.d.ts.map +1 -0
  176. package/dest/storage/anchor_block_store/index.js +1 -0
  177. package/dest/storage/capsule_store/capsule_store.d.ts +72 -0
  178. package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -0
  179. package/dest/storage/capsule_store/capsule_store.js +253 -0
  180. package/dest/storage/capsule_store/index.d.ts +2 -0
  181. package/dest/storage/capsule_store/index.d.ts.map +1 -0
  182. package/dest/storage/capsule_store/index.js +1 -0
  183. package/dest/storage/contract_store/contract_store.d.ts +93 -0
  184. package/dest/storage/contract_store/contract_store.d.ts.map +1 -0
  185. package/dest/storage/contract_store/contract_store.js +309 -0
  186. package/dest/storage/contract_store/index.d.ts +2 -0
  187. package/dest/storage/contract_store/index.d.ts.map +1 -0
  188. package/dest/storage/contract_store/index.js +1 -0
  189. package/dest/storage/{contract_data_provider → contract_store}/private_functions_tree.d.ts +1 -1
  190. package/dest/storage/contract_store/private_functions_tree.d.ts.map +1 -0
  191. package/dest/storage/{contract_data_provider → contract_store}/private_functions_tree.js +1 -1
  192. package/dest/storage/index.d.ts +8 -8
  193. package/dest/storage/index.d.ts.map +1 -1
  194. package/dest/storage/index.js +7 -7
  195. package/dest/storage/metadata.d.ts +1 -1
  196. package/dest/storage/metadata.js +1 -1
  197. package/dest/storage/note_store/index.d.ts +3 -0
  198. package/dest/storage/note_store/index.d.ts.map +1 -0
  199. package/dest/storage/note_store/index.js +2 -0
  200. package/dest/storage/note_store/note_store.d.ts +83 -0
  201. package/dest/storage/note_store/note_store.d.ts.map +1 -0
  202. package/dest/storage/note_store/note_store.js +343 -0
  203. package/dest/storage/note_store/stored_note.d.ts +16 -0
  204. package/dest/storage/note_store/stored_note.d.ts.map +1 -0
  205. package/dest/storage/note_store/stored_note.js +43 -0
  206. package/dest/storage/private_event_store/private_event_store.d.ts +91 -0
  207. package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -0
  208. package/dest/storage/private_event_store/private_event_store.js +273 -0
  209. package/dest/storage/private_event_store/stored_private_event.d.ts +23 -0
  210. package/dest/storage/private_event_store/stored_private_event.d.ts.map +1 -0
  211. package/dest/storage/private_event_store/stored_private_event.js +56 -0
  212. package/dest/storage/tagging_store/index.d.ts +4 -0
  213. package/dest/storage/tagging_store/index.d.ts.map +1 -0
  214. package/dest/storage/tagging_store/index.js +3 -0
  215. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +28 -0
  216. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -0
  217. package/dest/storage/tagging_store/recipient_tagging_store.js +111 -0
  218. package/dest/storage/tagging_store/sender_address_book_store.d.ts +14 -0
  219. package/dest/storage/tagging_store/sender_address_book_store.d.ts.map +1 -0
  220. package/dest/storage/tagging_store/sender_address_book_store.js +36 -0
  221. package/dest/storage/tagging_store/sender_tagging_store.d.ts +78 -0
  222. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -0
  223. package/dest/storage/tagging_store/sender_tagging_store.js +374 -0
  224. package/dest/tagging/constants.d.ts +2 -2
  225. package/dest/tagging/constants.d.ts.map +1 -1
  226. package/dest/tagging/constants.js +10 -2
  227. package/dest/tagging/get_all_logs_by_tags.d.ts +24 -0
  228. package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -0
  229. package/dest/tagging/get_all_logs_by_tags.js +60 -0
  230. package/dest/tagging/index.d.ts +17 -7
  231. package/dest/tagging/index.d.ts.map +1 -1
  232. package/dest/tagging/index.js +15 -5
  233. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +14 -0
  234. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +1 -0
  235. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +99 -0
  236. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts +12 -0
  237. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts.map +1 -0
  238. package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +20 -0
  239. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +14 -0
  240. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +1 -0
  241. package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +33 -0
  242. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +17 -0
  243. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -0
  244. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +80 -0
  245. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +12 -0
  246. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -0
  247. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +39 -0
  248. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +19 -0
  249. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -0
  250. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +72 -0
  251. package/package.json +28 -19
  252. package/src/access_scopes.ts +9 -0
  253. package/src/bin/check_oracle_version.ts +131 -20
  254. package/src/block_synchronizer/block_synchronizer.ts +178 -0
  255. package/src/block_synchronizer/index.ts +1 -0
  256. package/src/config/index.ts +18 -4
  257. package/src/config/package_info.ts +1 -1
  258. package/src/contract_function_simulator/benchmarked_node.ts +103 -0
  259. package/src/contract_function_simulator/contract_function_simulator.ts +418 -111
  260. package/src/contract_function_simulator/execution_note_cache.ts +51 -28
  261. package/src/contract_function_simulator/execution_tagging_index_cache.ts +19 -14
  262. package/src/contract_function_simulator/hashed_values_cache.ts +1 -1
  263. package/src/contract_function_simulator/index.ts +2 -1
  264. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +14 -7
  265. package/src/contract_function_simulator/noir-structs/log_retrieval_request.ts +6 -5
  266. package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +2 -5
  267. package/src/contract_function_simulator/noir-structs/message_tx_context.ts +55 -0
  268. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +8 -8
  269. package/src/contract_function_simulator/noir-structs/utility_context.ts +6 -25
  270. package/src/contract_function_simulator/oracle/interfaces.ts +77 -62
  271. package/src/contract_function_simulator/oracle/legacy_oracle_mappings.ts +135 -0
  272. package/src/contract_function_simulator/oracle/message_load_oracle_inputs.ts +1 -1
  273. package/src/contract_function_simulator/oracle/note_packing_utils.ts +27 -13
  274. package/src/contract_function_simulator/oracle/oracle.ts +254 -162
  275. package/src/contract_function_simulator/oracle/private_execution.ts +6 -72
  276. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +180 -168
  277. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +457 -115
  278. package/src/contract_function_simulator/pick_notes.ts +1 -1
  279. package/src/contract_function_simulator/proxied_contract_data_source.ts +24 -7
  280. package/src/contract_logging.ts +39 -0
  281. package/src/contract_sync/contract_sync_service.ts +181 -0
  282. package/src/contract_sync/helpers.ts +98 -0
  283. package/src/debug/pxe_debug_utils.ts +93 -0
  284. package/src/entrypoints/client/bundle/index.ts +3 -1
  285. package/src/entrypoints/client/bundle/utils.ts +24 -17
  286. package/src/entrypoints/client/lazy/index.ts +3 -1
  287. package/src/entrypoints/client/lazy/utils.ts +25 -18
  288. package/src/entrypoints/pxe_creation_options.ts +6 -2
  289. package/src/entrypoints/server/index.ts +5 -1
  290. package/src/entrypoints/server/utils.ts +33 -41
  291. package/src/error_enriching.ts +7 -15
  292. package/src/events/event_service.ts +71 -0
  293. package/src/events/index.ts +1 -0
  294. package/src/events/private_event_filter_validator.ts +46 -0
  295. package/src/job_coordinator/job_coordinator.ts +150 -0
  296. package/src/logs/log_service.ts +213 -0
  297. package/src/messages/message_context_service.ts +45 -0
  298. package/src/notes/index.ts +1 -0
  299. package/src/notes/note_service.ts +196 -0
  300. package/src/notes_filter.ts +26 -0
  301. package/src/oracle_version.ts +5 -4
  302. package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
  303. package/src/private_kernel/hints/index.ts +2 -2
  304. package/src/private_kernel/hints/{build_private_kernel_reset_private_inputs.ts → private_kernel_reset_private_inputs_builder.ts} +197 -139
  305. package/src/private_kernel/hints/test_utils.ts +325 -0
  306. package/src/private_kernel/private_kernel_execution_prover.ts +32 -23
  307. package/src/private_kernel/private_kernel_oracle.ts +118 -37
  308. package/src/pxe.ts +443 -354
  309. package/src/storage/{address_data_provider/address_data_provider.ts → address_store/address_store.ts} +16 -16
  310. package/src/storage/address_store/index.ts +1 -0
  311. package/src/storage/{sync_data_provider/sync_data_provider.ts → anchor_block_store/anchor_block_store.ts} +10 -11
  312. package/src/storage/anchor_block_store/index.ts +1 -0
  313. package/src/storage/capsule_store/capsule_store.ts +315 -0
  314. package/src/storage/capsule_store/index.ts +1 -0
  315. package/src/storage/contract_store/contract_store.ts +429 -0
  316. package/src/storage/contract_store/index.ts +1 -0
  317. package/src/storage/{contract_data_provider → contract_store}/private_functions_tree.ts +1 -1
  318. package/src/storage/index.ts +7 -7
  319. package/src/storage/metadata.ts +1 -1
  320. package/src/storage/note_store/index.ts +2 -0
  321. package/src/storage/note_store/note_store.ts +418 -0
  322. package/src/storage/note_store/stored_note.ts +48 -0
  323. package/src/storage/private_event_store/private_event_store.ts +384 -0
  324. package/src/storage/private_event_store/stored_private_event.ts +73 -0
  325. package/src/storage/tagging_store/index.ts +3 -0
  326. package/src/storage/tagging_store/recipient_tagging_store.ts +143 -0
  327. package/src/storage/tagging_store/sender_address_book_store.ts +48 -0
  328. package/src/storage/tagging_store/sender_tagging_store.ts +476 -0
  329. package/src/tagging/constants.ts +10 -2
  330. package/src/tagging/get_all_logs_by_tags.ts +92 -0
  331. package/src/tagging/index.ts +19 -6
  332. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +140 -0
  333. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +34 -0
  334. package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +44 -0
  335. package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +112 -0
  336. package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +51 -0
  337. package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +85 -0
  338. package/dest/contract_function_simulator/execution_data_provider.d.ts +0 -265
  339. package/dest/contract_function_simulator/execution_data_provider.d.ts.map +0 -1
  340. package/dest/contract_function_simulator/execution_data_provider.js +0 -14
  341. package/dest/contract_function_simulator/proxied_node.d.ts +0 -9
  342. package/dest/contract_function_simulator/proxied_node.d.ts.map +0 -1
  343. package/dest/contract_function_simulator/proxied_node.js +0 -27
  344. package/dest/contract_function_simulator/pxe_oracle_interface.d.ts +0 -122
  345. package/dest/contract_function_simulator/pxe_oracle_interface.d.ts.map +0 -1
  346. package/dest/contract_function_simulator/pxe_oracle_interface.js +0 -694
  347. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts +0 -28
  348. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts.map +0 -1
  349. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts +0 -4
  350. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts.map +0 -1
  351. package/dest/private_kernel/private_kernel_oracle_impl.d.ts +0 -45
  352. package/dest/private_kernel/private_kernel_oracle_impl.d.ts.map +0 -1
  353. package/dest/private_kernel/private_kernel_oracle_impl.js +0 -86
  354. package/dest/storage/address_data_provider/address_data_provider.d.ts +0 -11
  355. package/dest/storage/address_data_provider/address_data_provider.d.ts.map +0 -1
  356. package/dest/storage/address_data_provider/index.d.ts +0 -2
  357. package/dest/storage/address_data_provider/index.d.ts.map +0 -1
  358. package/dest/storage/address_data_provider/index.js +0 -1
  359. package/dest/storage/capsule_data_provider/capsule_data_provider.d.ts +0 -25
  360. package/dest/storage/capsule_data_provider/capsule_data_provider.d.ts.map +0 -1
  361. package/dest/storage/capsule_data_provider/capsule_data_provider.js +0 -118
  362. package/dest/storage/capsule_data_provider/index.d.ts +0 -2
  363. package/dest/storage/capsule_data_provider/index.d.ts.map +0 -1
  364. package/dest/storage/capsule_data_provider/index.js +0 -1
  365. package/dest/storage/contract_data_provider/contract_data_provider.d.ts +0 -64
  366. package/dest/storage/contract_data_provider/contract_data_provider.d.ts.map +0 -1
  367. package/dest/storage/contract_data_provider/contract_data_provider.js +0 -193
  368. package/dest/storage/contract_data_provider/index.d.ts +0 -2
  369. package/dest/storage/contract_data_provider/index.d.ts.map +0 -1
  370. package/dest/storage/contract_data_provider/index.js +0 -1
  371. package/dest/storage/contract_data_provider/private_functions_tree.d.ts.map +0 -1
  372. package/dest/storage/note_data_provider/index.d.ts +0 -3
  373. package/dest/storage/note_data_provider/index.d.ts.map +0 -1
  374. package/dest/storage/note_data_provider/index.js +0 -2
  375. package/dest/storage/note_data_provider/note_data_provider.d.ts +0 -83
  376. package/dest/storage/note_data_provider/note_data_provider.d.ts.map +0 -1
  377. package/dest/storage/note_data_provider/note_data_provider.js +0 -311
  378. package/dest/storage/private_event_data_provider/private_event_data_provider.d.ts +0 -37
  379. package/dest/storage/private_event_data_provider/private_event_data_provider.d.ts.map +0 -1
  380. package/dest/storage/private_event_data_provider/private_event_data_provider.js +0 -105
  381. package/dest/storage/sync_data_provider/index.d.ts.map +0 -1
  382. package/dest/storage/sync_data_provider/index.js +0 -1
  383. package/dest/storage/sync_data_provider/sync_data_provider.d.ts +0 -10
  384. package/dest/storage/sync_data_provider/sync_data_provider.d.ts.map +0 -1
  385. package/dest/storage/tagging_data_provider/index.d.ts +0 -2
  386. package/dest/storage/tagging_data_provider/index.d.ts.map +0 -1
  387. package/dest/storage/tagging_data_provider/index.js +0 -1
  388. package/dest/storage/tagging_data_provider/tagging_data_provider.d.ts +0 -40
  389. package/dest/storage/tagging_data_provider/tagging_data_provider.d.ts.map +0 -1
  390. package/dest/storage/tagging_data_provider/tagging_data_provider.js +0 -89
  391. package/dest/synchronizer/index.d.ts +0 -2
  392. package/dest/synchronizer/index.d.ts.map +0 -1
  393. package/dest/synchronizer/index.js +0 -1
  394. package/dest/synchronizer/synchronizer.d.ts +0 -35
  395. package/dest/synchronizer/synchronizer.d.ts.map +0 -1
  396. package/dest/synchronizer/synchronizer.js +0 -101
  397. package/dest/tagging/siloed_tag.d.ts +0 -14
  398. package/dest/tagging/siloed_tag.d.ts.map +0 -1
  399. package/dest/tagging/siloed_tag.js +0 -20
  400. package/dest/tagging/tag.d.ts +0 -12
  401. package/dest/tagging/tag.d.ts.map +0 -1
  402. package/dest/tagging/tag.js +0 -17
  403. package/dest/tagging/utils.d.ts +0 -18
  404. package/dest/tagging/utils.d.ts.map +0 -1
  405. package/dest/tagging/utils.js +0 -24
  406. package/src/contract_function_simulator/execution_data_provider.ts +0 -333
  407. package/src/contract_function_simulator/proxied_node.ts +0 -33
  408. package/src/contract_function_simulator/pxe_oracle_interface.ts +0 -1008
  409. package/src/private_kernel/private_kernel_oracle_impl.ts +0 -132
  410. package/src/storage/address_data_provider/index.ts +0 -1
  411. package/src/storage/capsule_data_provider/capsule_data_provider.ts +0 -147
  412. package/src/storage/capsule_data_provider/index.ts +0 -1
  413. package/src/storage/contract_data_provider/contract_data_provider.ts +0 -277
  414. package/src/storage/contract_data_provider/index.ts +0 -1
  415. package/src/storage/note_data_provider/index.ts +0 -2
  416. package/src/storage/note_data_provider/note_data_provider.ts +0 -399
  417. package/src/storage/private_event_data_provider/private_event_data_provider.ts +0 -143
  418. package/src/storage/sync_data_provider/index.ts +0 -1
  419. package/src/storage/tagging_data_provider/index.ts +0 -1
  420. package/src/storage/tagging_data_provider/tagging_data_provider.ts +0 -120
  421. package/src/synchronizer/index.ts +0 -1
  422. package/src/synchronizer/synchronizer.ts +0 -120
  423. package/src/tagging/siloed_tag.ts +0 -22
  424. package/src/tagging/tag.ts +0 -16
  425. 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,34 +250,21 @@ 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.
268
261
  * @param randomness - The randomness injected into the note.
269
262
  * @param noteTypeId - The type ID of the note.
270
263
  * @param noteItems - The items to be included in a Note.
271
264
  * @param noteHash - A hash of the new note.
272
265
  * @returns
273
- */ privateNotifyCreatedNote(storageSlot, randomness, noteTypeId, noteItems, noteHash, counter) {
274
- 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}`, {
275
268
  contractAddress: this.callContext.contractAddress,
276
269
  storageSlot,
277
270
  randomness,
@@ -281,12 +274,14 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
281
274
  const note = new Note(noteItems);
282
275
  this.noteCache.addNewNote({
283
276
  contractAddress: this.callContext.contractAddress,
277
+ owner,
284
278
  storageSlot,
285
279
  randomness,
286
280
  noteNonce: Fr.ZERO,
287
281
  note,
288
282
  siloedNullifier: undefined,
289
- noteHash
283
+ noteHash,
284
+ isPending: true
290
285
  }, counter);
291
286
  this.newNotes.push(NoteAndSlot.from({
292
287
  note,
@@ -300,7 +295,7 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
300
295
  * within the current transaction/execution.
301
296
  * @param innerNullifier - The pending nullifier to add in the list (not yet siloed by contract address).
302
297
  * @param noteHash - A hash of the new note.
303
- */ async privateNotifyNullifiedNote(innerNullifier, noteHash, counter) {
298
+ */ async notifyNullifiedNote(innerNullifier, noteHash, counter) {
304
299
  const nullifiedNoteHashCounter = await this.noteCache.nullifyNote(this.callContext.contractAddress, innerNullifier, noteHash);
305
300
  if (nullifiedNoteHashCounter !== undefined) {
306
301
  this.noteHashNullifierCounterMap.set(nullifiedNoteHashCounter, counter);
@@ -311,22 +306,33 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
311
306
  * within the current transaction/execution.
312
307
  * @param innerNullifier - The pending nullifier to add in the list (not yet siloed by contract address).
313
308
  * @param noteHash - A hash of the new note.
314
- */ privateNotifyCreatedNullifier(innerNullifier) {
315
- this.log.debug(`Notified of new inner nullifier ${innerNullifier}`, {
309
+ */ notifyCreatedNullifier(innerNullifier) {
310
+ this.logger.debug(`Notified of new inner nullifier ${innerNullifier}`, {
316
311
  contractAddress: this.contractAddress
317
312
  });
318
313
  return this.noteCache.nullifierCreated(this.callContext.contractAddress, innerNullifier);
319
314
  }
320
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
+ /**
321
327
  * Emit a contract class log.
322
328
  * This fn exists because we only carry a poseidon hash through the kernels, and need to
323
329
  * keep the preimage in ts for later.
324
330
  * @param log - The contract class log to be emitted.
325
331
  * @param counter - The contract class log's counter.
326
- */ privateNotifyCreatedContractClassLog(log, counter) {
332
+ */ notifyCreatedContractClassLog(log, counter) {
327
333
  this.contractClassLogs.push(new CountedContractClassLog(log, counter));
328
334
  const text = log.toBuffer().toString('hex');
329
- 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}"`);
330
336
  }
331
337
  #checkValidStaticCall(childExecutionResult) {
332
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) {
@@ -341,20 +347,50 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
341
347
  * @param sideEffectCounter - The side effect counter at the start of the call.
342
348
  * @param isStaticCall - Whether the call is a static call.
343
349
  * @returns The execution result.
344
- */ async privateCallPrivateFunction(targetContractAddress, functionSelector, argsHash, sideEffectCounter, isStaticCall) {
350
+ */ async callPrivateFunction(targetContractAddress, functionSelector, argsHash, sideEffectCounter, isStaticCall) {
345
351
  if (!this.simulator) {
346
352
  // In practice it is only when creating inline private contexts in a Noir test using TXE that we create an
347
353
  // instance of this class without a simulator.
348
354
  throw new Error('No simulator provided, cannot perform a nested private call');
349
355
  }
350
356
  const simulatorSetupTimer = new Timer();
351
- 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}`);
352
358
  isStaticCall = isStaticCall || this.callContext.isStaticCall;
353
- await verifyCurrentClassId(targetContractAddress, this.executionDataProvider, this.anchorBlockHeader);
354
- 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);
355
361
  const derivedTxContext = this.txContext.clone();
356
362
  const derivedCallContext = await this.deriveCallContext(targetContractAddress, targetArtifact, isStaticCall);
357
- 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
+ });
358
394
  const setupTime = simulatorSetupTimer.ms();
359
395
  const childExecutionResult = await executePrivateFunction(this.simulator, privateExecutionOracle, targetArtifact, targetContractAddress, functionSelector);
360
396
  if (isStaticCall) {
@@ -371,7 +407,7 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
371
407
  returnsHash: publicInputs.returnsHash
372
408
  };
373
409
  }
374
- #onNewPublicFunctionCall(calldataHash) {
410
+ /** Validates the calldata preimage exists in the cache and checks cumulative calldata size is within limits. */ validatePublicCalldata(calldataHash) {
375
411
  const calldata = this.executionCache.getPreimage(calldataHash);
376
412
  if (!calldata) {
377
413
  throw new Error('Calldata for public call not found in cache');
@@ -380,31 +416,12 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
380
416
  if (this.totalPublicCalldataCount > MAX_FR_CALLDATA_TO_ALL_ENQUEUED_CALLS) {
381
417
  throw new Error(`Too many total args to all enqueued public calls! (> ${MAX_FR_CALLDATA_TO_ALL_ENQUEUED_CALLS})`);
382
418
  }
383
- }
384
- /**
385
- * Verify relevant information when a public function is enqueued.
386
- * @param targetContractAddress - The address of the contract to call.
387
- * @param calldataHash - The hash of the function selector and arguments.
388
- * @param sideEffectCounter - The side effect counter at the start of the call.
389
- * @param isStaticCall - Whether the call is a static call.
390
- */ privateNotifyEnqueuedPublicFunctionCall(_targetContractAddress, calldataHash, _sideEffectCounter, _isStaticCall) {
391
- this.#onNewPublicFunctionCall(calldataHash);
392
419
  return Promise.resolve();
393
420
  }
394
- /**
395
- * Verify relevant information when a public teardown function is set.
396
- * @param targetContractAddress - The address of the contract to call.
397
- * @param argsHash - The arguments hash to pass to the function.
398
- * @param sideEffectCounter - The side effect counter at the start of the call.
399
- * @param isStaticCall - Whether the call is a static call.
400
- */ privateNotifySetPublicTeardownFunctionCall(_targetContractAddress, calldataHash, _sideEffectCounter, _isStaticCall) {
401
- this.#onNewPublicFunctionCall(calldataHash);
402
- return Promise.resolve();
403
- }
404
- privateNotifySetMinRevertibleSideEffectCounter(minRevertibleSideEffectCounter) {
421
+ notifyRevertiblePhaseStart(minRevertibleSideEffectCounter) {
405
422
  return this.noteCache.setMinRevertibleSideEffectCounter(minRevertibleSideEffectCounter);
406
423
  }
407
- privateIsSideEffectCounterRevertible(sideEffectCounter) {
424
+ inRevertiblePhase(sideEffectCounter) {
408
425
  return Promise.resolve(this.noteCache.isSideEffectCounterRevertible(sideEffectCounter));
409
426
  }
410
427
  /**
@@ -417,12 +434,6 @@ import { UtilityExecutionOracle } from './utility_execution_oracle.js';
417
434
  return new CallContext(this.contractAddress, targetContractAddress, await FunctionSelector.fromNameAndParameters(targetArtifact.name, targetArtifact.parameters), isStaticCall);
418
435
  }
419
436
  getDebugFunctionName() {
420
- return this.executionDataProvider.getDebugFunctionName(this.contractAddress, this.callContext.functionSelector);
421
- }
422
- utilityEmitOffchainEffect(data) {
423
- this.offchainEffects.push({
424
- data
425
- });
426
- return Promise.resolve();
437
+ return this.contractStore.getDebugFunctionName(this.contractAddress, this.callContext.functionSelector);
427
438
  }
428
439
  }