@aztec/pxe 0.0.1-commit.e3c1de76 → 0.0.1-commit.e57c76e

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 (347) hide show
  1. package/dest/bin/check_oracle_version.js +43 -99
  2. package/dest/bin/index.d.ts +2 -0
  3. package/dest/bin/index.d.ts.map +1 -0
  4. package/dest/bin/index.js +1 -0
  5. package/dest/bin/oracle_version_helpers.d.ts +26 -0
  6. package/dest/bin/oracle_version_helpers.d.ts.map +1 -0
  7. package/dest/bin/oracle_version_helpers.js +93 -0
  8. package/dest/block_synchronizer/block_stream_source.d.ts +10 -0
  9. package/dest/block_synchronizer/block_stream_source.d.ts.map +1 -0
  10. package/dest/block_synchronizer/block_stream_source.js +62 -0
  11. package/dest/block_synchronizer/block_synchronizer.d.ts +9 -3
  12. package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
  13. package/dest/block_synchronizer/block_synchronizer.js +37 -11
  14. package/dest/config/index.d.ts +8 -2
  15. package/dest/config/index.d.ts.map +1 -1
  16. package/dest/config/index.js +13 -15
  17. package/dest/config/package_info.js +1 -1
  18. package/dest/contract_function_simulator/contract_function_simulator.d.ts +66 -29
  19. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
  20. package/dest/contract_function_simulator/contract_function_simulator.js +216 -75
  21. package/dest/contract_function_simulator/ephemeral_array_service.d.ts +28 -0
  22. package/dest/contract_function_simulator/ephemeral_array_service.d.ts.map +1 -0
  23. package/dest/contract_function_simulator/ephemeral_array_service.js +78 -0
  24. package/dest/contract_function_simulator/execution_note_cache.d.ts +2 -2
  25. package/dest/contract_function_simulator/execution_note_cache.d.ts.map +1 -1
  26. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +7 -11
  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 -15
  29. package/dest/contract_function_simulator/index.d.ts +14 -2
  30. package/dest/contract_function_simulator/index.d.ts.map +1 -1
  31. package/dest/contract_function_simulator/index.js +11 -0
  32. package/dest/contract_function_simulator/noir-structs/bounded_vec.d.ts +48 -0
  33. package/dest/contract_function_simulator/noir-structs/bounded_vec.d.ts.map +1 -0
  34. package/dest/contract_function_simulator/noir-structs/bounded_vec.js +45 -0
  35. package/dest/contract_function_simulator/noir-structs/ephemeral_array.d.ts +37 -0
  36. package/dest/contract_function_simulator/noir-structs/ephemeral_array.d.ts.map +1 -0
  37. package/dest/contract_function_simulator/noir-structs/ephemeral_array.js +59 -0
  38. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +3 -4
  39. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts.map +1 -1
  40. package/dest/contract_function_simulator/noir-structs/event_validation_request.js +8 -9
  41. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts +13 -3
  42. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts.map +1 -1
  43. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.js +35 -4
  44. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts +2 -2
  45. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts.map +1 -1
  46. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.js +2 -4
  47. package/dest/contract_function_simulator/noir-structs/note_data.d.ts +27 -0
  48. package/dest/contract_function_simulator/noir-structs/note_data.d.ts.map +1 -0
  49. package/dest/contract_function_simulator/noir-structs/note_data.js +3 -0
  50. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +3 -5
  51. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
  52. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +6 -10
  53. package/dest/contract_function_simulator/noir-structs/option.d.ts +61 -0
  54. package/dest/contract_function_simulator/noir-structs/option.d.ts.map +1 -0
  55. package/dest/contract_function_simulator/noir-structs/option.js +62 -0
  56. package/dest/contract_function_simulator/noir-structs/provided_secret.d.ts +11 -0
  57. package/dest/contract_function_simulator/noir-structs/provided_secret.d.ts.map +1 -0
  58. package/dest/contract_function_simulator/noir-structs/provided_secret.js +24 -0
  59. package/dest/contract_function_simulator/oracle/interfaces.d.ts +16 -98
  60. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
  61. package/dest/contract_function_simulator/oracle/interfaces.js +2 -2
  62. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts +2 -2
  63. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts.map +1 -1
  64. package/dest/contract_function_simulator/oracle/note_packing_utils.js +2 -2
  65. package/dest/contract_function_simulator/oracle/oracle.d.ts +75 -46
  66. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
  67. package/dest/contract_function_simulator/oracle/oracle.js +471 -275
  68. package/dest/contract_function_simulator/oracle/oracle_registry.d.ts +127 -0
  69. package/dest/contract_function_simulator/oracle/oracle_registry.d.ts.map +1 -0
  70. package/dest/contract_function_simulator/oracle/oracle_registry.js +786 -0
  71. package/dest/contract_function_simulator/oracle/oracle_type_mappings.d.ts +139 -0
  72. package/dest/contract_function_simulator/oracle/oracle_type_mappings.d.ts.map +1 -0
  73. package/dest/contract_function_simulator/oracle/oracle_type_mappings.js +560 -0
  74. package/dest/contract_function_simulator/oracle/private_execution.js +5 -3
  75. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +68 -95
  76. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
  77. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +141 -110
  78. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +156 -76
  79. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
  80. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +450 -166
  81. package/dest/contract_function_simulator/pick_notes.d.ts +1 -1
  82. package/dest/contract_function_simulator/pick_notes.d.ts.map +1 -1
  83. package/dest/contract_function_simulator/pick_notes.js +20 -3
  84. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts +1 -1
  85. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts.map +1 -1
  86. package/dest/contract_function_simulator/proxied_contract_data_source.js +35 -64
  87. package/dest/contract_logging.d.ts +27 -0
  88. package/dest/contract_logging.d.ts.map +1 -0
  89. package/dest/contract_logging.js +38 -0
  90. package/dest/contract_sync/contract_sync_service.d.ts +42 -0
  91. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -0
  92. package/dest/contract_sync/contract_sync_service.js +135 -0
  93. package/dest/contract_sync/helpers.d.ts +27 -0
  94. package/dest/contract_sync/helpers.d.ts.map +1 -0
  95. package/dest/contract_sync/{index.js → helpers.js} +16 -17
  96. package/dest/debug/pxe_debug_utils.d.ts +14 -15
  97. package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
  98. package/dest/debug/pxe_debug_utils.js +16 -21
  99. package/dest/entrypoints/client/bundle/index.d.ts +3 -1
  100. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  101. package/dest/entrypoints/client/bundle/index.js +2 -0
  102. package/dest/entrypoints/client/bundle/utils.d.ts +2 -2
  103. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  104. package/dest/entrypoints/client/bundle/utils.js +21 -5
  105. package/dest/entrypoints/client/lazy/index.d.ts +3 -1
  106. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  107. package/dest/entrypoints/client/lazy/index.js +2 -0
  108. package/dest/entrypoints/client/lazy/utils.d.ts +2 -2
  109. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  110. package/dest/entrypoints/client/lazy/utils.js +21 -5
  111. package/dest/entrypoints/pxe_creation_options.d.ts +9 -1
  112. package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
  113. package/dest/entrypoints/pxe_creation_options.js +3 -1
  114. package/dest/entrypoints/server/index.d.ts +5 -3
  115. package/dest/entrypoints/server/index.d.ts.map +1 -1
  116. package/dest/entrypoints/server/index.js +4 -2
  117. package/dest/entrypoints/server/utils.d.ts +4 -3
  118. package/dest/entrypoints/server/utils.d.ts.map +1 -1
  119. package/dest/entrypoints/server/utils.js +21 -5
  120. package/dest/events/event_service.d.ts +15 -6
  121. package/dest/events/event_service.d.ts.map +1 -1
  122. package/dest/events/event_service.js +44 -11
  123. package/dest/events/private_event_filter_validator.d.ts +3 -2
  124. package/dest/events/private_event_filter_validator.d.ts.map +1 -1
  125. package/dest/events/private_event_filter_validator.js +15 -0
  126. package/dest/hooks/authorize_utility_call.d.ts +41 -0
  127. package/dest/hooks/authorize_utility_call.d.ts.map +1 -0
  128. package/dest/hooks/authorize_utility_call.js +4 -0
  129. package/dest/hooks/execution_hooks.d.ts +42 -0
  130. package/dest/hooks/execution_hooks.d.ts.map +1 -0
  131. package/dest/hooks/execution_hooks.js +9 -0
  132. package/dest/hooks/index.d.ts +4 -0
  133. package/dest/hooks/index.d.ts.map +1 -0
  134. package/dest/hooks/index.js +1 -0
  135. package/dest/logs/log_service.d.ts +9 -8
  136. package/dest/logs/log_service.d.ts.map +1 -1
  137. package/dest/logs/log_service.js +131 -84
  138. package/dest/messages/message_context_service.d.ts +17 -0
  139. package/dest/messages/message_context_service.d.ts.map +1 -0
  140. package/dest/messages/message_context_service.js +55 -0
  141. package/dest/notes/note_service.d.ts +27 -5
  142. package/dest/notes/note_service.d.ts.map +1 -1
  143. package/dest/notes/note_service.js +83 -58
  144. package/dest/notes_filter.d.ts +24 -0
  145. package/dest/notes_filter.d.ts.map +1 -0
  146. package/dest/notes_filter.js +4 -0
  147. package/dest/oracle_version.d.ts +4 -3
  148. package/dest/oracle_version.d.ts.map +1 -1
  149. package/dest/oracle_version.js +20 -10
  150. package/dest/private_kernel/batch_planner.d.ts +47 -0
  151. package/dest/private_kernel/batch_planner.d.ts.map +1 -0
  152. package/dest/private_kernel/batch_planner.js +104 -0
  153. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
  154. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
  155. package/dest/private_kernel/hints/{compute_tx_include_by_timestamp.js → compute_tx_expiration_timestamp.js} +12 -12
  156. package/dest/private_kernel/hints/index.d.ts +1 -1
  157. package/dest/private_kernel/hints/index.js +1 -1
  158. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +4 -3
  159. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -1
  160. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.js +130 -69
  161. package/dest/private_kernel/hints/test_utils.d.ts +122 -0
  162. package/dest/private_kernel/hints/test_utils.d.ts.map +1 -0
  163. package/dest/private_kernel/hints/test_utils.js +202 -0
  164. package/dest/private_kernel/private_kernel_execution_prover.d.ts +6 -2
  165. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
  166. package/dest/private_kernel/private_kernel_execution_prover.js +166 -65
  167. package/dest/private_kernel/private_kernel_oracle.d.ts +15 -11
  168. package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
  169. package/dest/private_kernel/private_kernel_oracle.js +31 -25
  170. package/dest/pxe.d.ts +120 -24
  171. package/dest/pxe.d.ts.map +1 -1
  172. package/dest/pxe.js +231 -134
  173. package/dest/storage/anchor_block_store/anchor_block_store.js +1 -1
  174. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.d.ts +42 -0
  175. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.d.ts.map +1 -0
  176. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.js +93 -0
  177. package/dest/storage/backwards_compatibility_tests/schema_tests.d.ts +15 -0
  178. package/dest/storage/backwards_compatibility_tests/schema_tests.d.ts.map +1 -0
  179. package/dest/storage/backwards_compatibility_tests/schema_tests.js +591 -0
  180. package/dest/storage/backwards_compatibility_tests/store_spy.d.ts +19 -0
  181. package/dest/storage/backwards_compatibility_tests/store_spy.d.ts.map +1 -0
  182. package/dest/storage/backwards_compatibility_tests/store_spy.js +63 -0
  183. package/dest/storage/capsule_store/capsule_service.d.ts +21 -0
  184. package/dest/storage/capsule_store/capsule_service.d.ts.map +1 -0
  185. package/dest/storage/capsule_store/capsule_service.js +50 -0
  186. package/dest/storage/capsule_store/capsule_store.d.ts +9 -9
  187. package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -1
  188. package/dest/storage/capsule_store/capsule_store.js +36 -28
  189. package/dest/storage/capsule_store/index.d.ts +2 -1
  190. package/dest/storage/capsule_store/index.d.ts.map +1 -1
  191. package/dest/storage/capsule_store/index.js +1 -0
  192. package/dest/storage/contract_store/contract_store.d.ts +42 -15
  193. package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
  194. package/dest/storage/contract_store/contract_store.js +146 -87
  195. package/dest/storage/metadata.d.ts +1 -1
  196. package/dest/storage/metadata.js +1 -1
  197. package/dest/storage/note_store/note_store.d.ts +3 -3
  198. package/dest/storage/note_store/note_store.d.ts.map +1 -1
  199. package/dest/storage/note_store/note_store.js +6 -4
  200. package/dest/storage/open_pxe_stores.d.ts +33 -0
  201. package/dest/storage/open_pxe_stores.d.ts.map +1 -0
  202. package/dest/storage/open_pxe_stores.js +27 -0
  203. package/dest/storage/private_event_store/private_event_store.d.ts +1 -1
  204. package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -1
  205. package/dest/storage/private_event_store/private_event_store.js +3 -0
  206. package/dest/storage/private_event_store/stored_private_event.js +1 -1
  207. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +6 -6
  208. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
  209. package/dest/storage/tagging_store/sender_tagging_store.d.ts +29 -28
  210. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
  211. package/dest/storage/tagging_store/sender_tagging_store.js +141 -115
  212. package/dest/tagging/get_all_logs_by_tags.d.ts +34 -10
  213. package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -1
  214. package/dest/tagging/get_all_logs_by_tags.js +45 -32
  215. package/dest/tagging/index.d.ts +6 -5
  216. package/dest/tagging/index.d.ts.map +1 -1
  217. package/dest/tagging/index.js +4 -3
  218. package/dest/tagging/persist_sender_tagging_index_ranges.d.ts +29 -0
  219. package/dest/tagging/persist_sender_tagging_index_ranges.d.ts.map +1 -0
  220. package/dest/tagging/persist_sender_tagging_index_ranges.js +42 -0
  221. package/dest/tagging/recipient_sync/sync_tagged_private_logs.d.ts +56 -0
  222. package/dest/tagging/recipient_sync/sync_tagged_private_logs.d.ts.map +1 -0
  223. package/dest/tagging/recipient_sync/sync_tagged_private_logs.js +163 -0
  224. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts +3 -3
  225. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts.map +1 -1
  226. package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +2 -2
  227. package/dest/tagging/reconcile_tagging_index_ranges.d.ts +36 -0
  228. package/dest/tagging/reconcile_tagging_index_ranges.d.ts.map +1 -0
  229. package/dest/tagging/reconcile_tagging_index_ranges.js +74 -0
  230. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +4 -9
  231. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
  232. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +32 -14
  233. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +13 -7
  234. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -1
  235. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +41 -10
  236. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +5 -7
  237. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -1
  238. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +37 -25
  239. package/package.json +29 -17
  240. package/src/bin/check_oracle_version.ts +49 -122
  241. package/src/bin/index.ts +1 -0
  242. package/src/bin/oracle_version_helpers.ts +121 -0
  243. package/src/block_synchronizer/block_stream_source.ts +81 -0
  244. package/src/block_synchronizer/block_synchronizer.ts +39 -11
  245. package/src/config/index.ts +15 -9
  246. package/src/config/package_info.ts +1 -1
  247. package/src/contract_function_simulator/contract_function_simulator.ts +391 -136
  248. package/src/contract_function_simulator/ephemeral_array_service.ts +110 -0
  249. package/src/contract_function_simulator/execution_note_cache.ts +1 -1
  250. package/src/contract_function_simulator/execution_tagging_index_cache.ts +19 -18
  251. package/src/contract_function_simulator/index.ts +51 -1
  252. package/src/contract_function_simulator/noir-structs/bounded_vec.ts +55 -0
  253. package/src/contract_function_simulator/noir-structs/ephemeral_array.ts +66 -0
  254. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +9 -8
  255. package/src/contract_function_simulator/noir-structs/log_retrieval_request.ts +36 -3
  256. package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +2 -5
  257. package/src/contract_function_simulator/noir-structs/note_data.ts +27 -0
  258. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +4 -9
  259. package/src/contract_function_simulator/noir-structs/option.ts +69 -0
  260. package/src/contract_function_simulator/noir-structs/provided_secret.ts +27 -0
  261. package/src/contract_function_simulator/oracle/interfaces.ts +12 -176
  262. package/src/contract_function_simulator/oracle/note_packing_utils.ts +3 -3
  263. package/src/contract_function_simulator/oracle/oracle.ts +564 -473
  264. package/src/contract_function_simulator/oracle/oracle_registry.ts +585 -0
  265. package/src/contract_function_simulator/oracle/oracle_type_mappings.ts +553 -0
  266. package/src/contract_function_simulator/oracle/private_execution.ts +4 -4
  267. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +173 -205
  268. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +664 -245
  269. package/src/contract_function_simulator/pick_notes.ts +22 -3
  270. package/src/contract_function_simulator/proxied_contract_data_source.ts +41 -64
  271. package/src/contract_logging.ts +52 -0
  272. package/src/contract_sync/contract_sync_service.ts +189 -0
  273. package/src/contract_sync/{index.ts → helpers.ts} +17 -29
  274. package/src/debug/pxe_debug_utils.ts +47 -25
  275. package/src/entrypoints/client/bundle/index.ts +2 -0
  276. package/src/entrypoints/client/bundle/utils.ts +19 -6
  277. package/src/entrypoints/client/lazy/index.ts +2 -0
  278. package/src/entrypoints/client/lazy/utils.ts +19 -6
  279. package/src/entrypoints/pxe_creation_options.ts +14 -0
  280. package/src/entrypoints/server/index.ts +4 -2
  281. package/src/entrypoints/server/utils.ts +22 -13
  282. package/src/events/event_service.ts +69 -21
  283. package/src/events/private_event_filter_validator.ts +21 -1
  284. package/src/hooks/authorize_utility_call.ts +44 -0
  285. package/src/hooks/execution_hooks.ts +48 -0
  286. package/src/hooks/index.ts +7 -0
  287. package/src/logs/log_service.ts +162 -145
  288. package/src/messages/message_context_service.ts +62 -0
  289. package/src/notes/note_service.ts +120 -85
  290. package/src/notes_filter.ts +24 -0
  291. package/src/oracle_version.ts +20 -10
  292. package/src/private_kernel/batch_planner.ts +169 -0
  293. package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
  294. package/src/private_kernel/hints/index.ts +1 -1
  295. package/src/private_kernel/hints/private_kernel_reset_private_inputs_builder.ts +165 -118
  296. package/src/private_kernel/hints/test_utils.ts +318 -0
  297. package/src/private_kernel/private_kernel_execution_prover.ts +254 -89
  298. package/src/private_kernel/private_kernel_oracle.ts +42 -32
  299. package/src/pxe.ts +416 -181
  300. package/src/storage/anchor_block_store/anchor_block_store.ts +1 -1
  301. package/src/storage/backwards_compatibility_tests/__snapshots__/AddressStore.json +22 -0
  302. package/src/storage/backwards_compatibility_tests/__snapshots__/AnchorBlockStore.json +3 -0
  303. package/src/storage/backwards_compatibility_tests/__snapshots__/CapsuleStore.json +16 -0
  304. package/src/storage/backwards_compatibility_tests/__snapshots__/ContractStore.json +28 -0
  305. package/src/storage/backwards_compatibility_tests/__snapshots__/KeyStore.json +52 -0
  306. package/src/storage/backwards_compatibility_tests/__snapshots__/L2TipsKVStore.json +46 -0
  307. package/src/storage/backwards_compatibility_tests/__snapshots__/NoteStore.json +36 -0
  308. package/src/storage/backwards_compatibility_tests/__snapshots__/PrivateEventStore.json +44 -0
  309. package/src/storage/backwards_compatibility_tests/__snapshots__/RecipientTaggingStore.json +18 -0
  310. package/src/storage/backwards_compatibility_tests/__snapshots__/SenderAddressBookStore.json +16 -0
  311. package/src/storage/backwards_compatibility_tests/__snapshots__/SenderTaggingStore.json +22 -0
  312. package/src/storage/backwards_compatibility_tests/__snapshots__/opened_stores.json +97 -0
  313. package/src/storage/backwards_compatibility_tests/kv_store_snapshot.ts +122 -0
  314. package/src/storage/backwards_compatibility_tests/schema_tests.ts +712 -0
  315. package/src/storage/backwards_compatibility_tests/store_spy.ts +73 -0
  316. package/src/storage/capsule_store/capsule_service.ts +90 -0
  317. package/src/storage/capsule_store/capsule_store.ts +44 -26
  318. package/src/storage/capsule_store/index.ts +1 -0
  319. package/src/storage/contract_store/contract_store.ts +182 -104
  320. package/src/storage/metadata.ts +1 -1
  321. package/src/storage/note_store/note_store.ts +9 -5
  322. package/src/storage/open_pxe_stores.ts +49 -0
  323. package/src/storage/private_event_store/private_event_store.ts +4 -0
  324. package/src/storage/private_event_store/stored_private_event.ts +1 -1
  325. package/src/storage/tagging_store/recipient_tagging_store.ts +5 -5
  326. package/src/storage/tagging_store/sender_tagging_store.ts +185 -138
  327. package/src/tagging/get_all_logs_by_tags.ts +87 -35
  328. package/src/tagging/index.ts +5 -4
  329. package/src/tagging/persist_sender_tagging_index_ranges.ts +57 -0
  330. package/src/tagging/recipient_sync/sync_tagged_private_logs.ts +240 -0
  331. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +4 -4
  332. package/src/tagging/reconcile_tagging_index_ranges.ts +102 -0
  333. package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +52 -17
  334. package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +44 -14
  335. package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +27 -27
  336. package/dest/contract_sync/index.d.ts +0 -23
  337. package/dest/contract_sync/index.d.ts.map +0 -1
  338. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts +0 -4
  339. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts.map +0 -1
  340. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +0 -15
  341. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +0 -1
  342. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +0 -99
  343. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +0 -15
  344. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +0 -1
  345. package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +0 -32
  346. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +0 -143
  347. package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +0 -49
@@ -0,0 +1,591 @@
1
+ /* eslint-disable camelcase */ import { CONTRACT_CLASS_LOG_SIZE_IN_FIELDS, PRIVATE_LOG_SIZE_IN_FIELDS } from '@aztec/constants';
2
+ import { BlockNumber, CheckpointNumber, IndexWithinCheckpoint, SlotNumber } from '@aztec/foundation/branded-types';
3
+ import { Fr } from '@aztec/foundation/curves/bn254';
4
+ import { EthAddress } from '@aztec/foundation/eth-address';
5
+ import { KeyStore } from '@aztec/key-store';
6
+ import { L2TipsKVStore } from '@aztec/kv-store/stores';
7
+ import { EventSelector, FunctionSelector, FunctionType } from '@aztec/stdlib/abi';
8
+ import { PublicDataWrite, RevertCode } from '@aztec/stdlib/avm';
9
+ import { AztecAddress } from '@aztec/stdlib/aztec-address';
10
+ import { BlockHash, Body, GENESIS_BLOCK_HEADER_HASH, L2Block } from '@aztec/stdlib/block';
11
+ import { Checkpoint, L1PublishedData, PublishedCheckpoint } from '@aztec/stdlib/checkpoint';
12
+ import { CompleteAddress, SerializableContractInstance } from '@aztec/stdlib/contract';
13
+ import { GasFees } from '@aztec/stdlib/gas';
14
+ import { PublicKey, PublicKeys } from '@aztec/stdlib/keys';
15
+ import { AppTaggingSecret, ContractClassLog, ContractClassLogFields, PrivateLog, PublicLog } from '@aztec/stdlib/logs';
16
+ import { Note, NoteDao } from '@aztec/stdlib/note';
17
+ import { CheckpointHeader } from '@aztec/stdlib/rollup';
18
+ import { AppendOnlyTreeSnapshot } from '@aztec/stdlib/trees';
19
+ import { BlockHeader, GlobalVariables, PartialStateReference, StateReference, TxEffect, TxHash } from '@aztec/stdlib/tx';
20
+ import { AddressStore } from '../address_store/address_store.js';
21
+ import { AnchorBlockStore } from '../anchor_block_store/anchor_block_store.js';
22
+ import { CapsuleStore } from '../capsule_store/capsule_store.js';
23
+ import { ContractStore } from '../contract_store/contract_store.js';
24
+ import { NoteStore } from '../note_store/note_store.js';
25
+ import { PrivateEventStore } from '../private_event_store/private_event_store.js';
26
+ import { RecipientTaggingStore, SenderAddressBookStore, SenderTaggingStore } from '../tagging_store/index.js';
27
+ import { snapshotArray, snapshotMap, snapshotSingleton } from './kv_store_snapshot.js';
28
+ export const SCHEMA_TESTS = [
29
+ {
30
+ name: 'AddressStore',
31
+ writeToStore: async (kvStore)=>{
32
+ const addressStore = new AddressStore(kvStore);
33
+ const addresses = [
34
+ await CompleteAddress.fromSecretKeyAndPartialAddress(new Fr(2n), new Fr(3n)),
35
+ await CompleteAddress.fromSecretKeyAndPartialAddress(new Fr(5n), new Fr(7n))
36
+ ];
37
+ await addressStore.addCompleteAddress(addresses[0]);
38
+ await addressStore.addCompleteAddress(addresses[1]);
39
+ // Re-adding an already-registered address must be a no-op: duplicate detection should leave both sub-stores
40
+ // unchanged. If this regresses, the snapshot picks up an extra array entry.
41
+ await addressStore.addCompleteAddress(addresses[0]);
42
+ },
43
+ snapshotStore: async (kvStore)=>({
44
+ complete_addresses: await snapshotArray(kvStore.openArray('complete_addresses')),
45
+ complete_address_index: await snapshotMap(kvStore.openMap('complete_address_index'))
46
+ })
47
+ },
48
+ {
49
+ name: 'AnchorBlockStore',
50
+ writeToStore: async (kvStore)=>{
51
+ const anchorBlockStore = new AnchorBlockStore(kvStore);
52
+ // Each primitive field gets a distinct prime so any reorder shows up in the snapshot diff. An all-zero
53
+ // `BlockHeader.empty()` would silently pass through same-width field swaps.
54
+ await anchorBlockStore.setHeader(new BlockHeader(new AppendOnlyTreeSnapshot(new Fr(2n), 3), new StateReference(new AppendOnlyTreeSnapshot(new Fr(5n), 7), new PartialStateReference(new AppendOnlyTreeSnapshot(new Fr(11n), 13), new AppendOnlyTreeSnapshot(new Fr(17n), 19), new AppendOnlyTreeSnapshot(new Fr(23n), 29))), new Fr(31n), new GlobalVariables(new Fr(37n), new Fr(41n), BlockNumber(43), SlotNumber(47), 53n, EthAddress.fromField(new Fr(59n)), AztecAddress.fromBigInt(61n), new GasFees(67n, 71n)), new Fr(73n), new Fr(79n)));
55
+ },
56
+ snapshotStore: async (kvStore)=>({
57
+ header: await snapshotSingleton(kvStore.openSingleton('header'))
58
+ })
59
+ },
60
+ {
61
+ name: 'CapsuleStore',
62
+ writeToStore: async (kvStore)=>{
63
+ const capsuleStore = new CapsuleStore(kvStore);
64
+ const jobId = 'fixture-job';
65
+ const contractAddress = AztecAddress.fromBigInt(2n);
66
+ const scope = AztecAddress.fromBigInt(3n);
67
+ // Three setCapsule calls (2-element, 1-element, 0-element value vector) pin every value-encoding length case.
68
+ capsuleStore.setCapsule(contractAddress, new Fr(5n), [
69
+ new Fr(7n),
70
+ new Fr(11n)
71
+ ], jobId, scope);
72
+ capsuleStore.setCapsule(contractAddress, new Fr(13n), [
73
+ new Fr(17n)
74
+ ], jobId, scope);
75
+ capsuleStore.setCapsule(contractAddress, new Fr(19n), [], jobId, scope);
76
+ await kvStore.transactionAsync(()=>capsuleStore.commit(jobId));
77
+ },
78
+ snapshotStore: async (kvStore)=>({
79
+ capsules: await snapshotMap(kvStore.openMap('capsules'))
80
+ })
81
+ },
82
+ {
83
+ name: 'ContractStore',
84
+ writeToStore: async (kvStore)=>{
85
+ const contractStore = new ContractStore(kvStore);
86
+ // Hand-rolled artifact (see `buildSchemaContractArtifact` below) instead of importing a noir-compiled fixture.
87
+ // The compiled fixture's JSON contains noir-compiler outputs (error-type hashes, debug symbols, struct paths)
88
+ // that drift across compiler versions and produce spurious ContractStore.json diffs that have nothing to do with
89
+ // PXE's on-disk schema. The hand-rolled artifact is small, deterministic across versions, and exercises the
90
+ // `addContractArtifact` write path identically.
91
+ const artifact = buildSchemaContractArtifact();
92
+ // Precomputed class so the `contract_classes` bytes are hardcoded by this test rather than derived from
93
+ // `getContractClassFromArtifact`.
94
+ const populatedClass = {
95
+ version: 1,
96
+ id: new Fr(2n),
97
+ artifactHash: new Fr(3n),
98
+ privateFunctionsRoot: new Fr(5n),
99
+ publicBytecodeCommitment: new Fr(7n),
100
+ privateFunctions: [
101
+ {
102
+ selector: FunctionSelector.fromField(new Fr(11n)),
103
+ vkHash: new Fr(13n)
104
+ },
105
+ {
106
+ selector: FunctionSelector.fromField(new Fr(17n)),
107
+ vkHash: new Fr(19n)
108
+ }
109
+ ],
110
+ packedBytecode: Buffer.alloc(0)
111
+ };
112
+ await contractStore.addContractArtifact(artifact, populatedClass);
113
+ // Same artifact, different class with empty `privateFunctions`. Tests zero-length-vector encoding for the
114
+ // privateFunctions field, which the populated case can't reach.
115
+ await contractStore.addContractArtifact(artifact, {
116
+ version: 1,
117
+ id: new Fr(23n),
118
+ artifactHash: new Fr(29n),
119
+ privateFunctionsRoot: new Fr(31n),
120
+ publicBytecodeCommitment: new Fr(37n),
121
+ privateFunctions: [],
122
+ packedBytecode: Buffer.alloc(0)
123
+ });
124
+ // Re-register the populated class: must hit the `#contractArtifactCache` short-circuit and leave both
125
+ // `contract_artifacts` and `contract_classes` unchanged.
126
+ await contractStore.addContractArtifact(artifact, populatedClass);
127
+ await contractStore.addContractInstance(new SerializableContractInstance({
128
+ version: 2,
129
+ salt: new Fr(73n),
130
+ deployer: AztecAddress.fromBigInt(79n),
131
+ currentContractClassId: new Fr(83n),
132
+ originalContractClassId: new Fr(89n),
133
+ initializationHash: new Fr(97n),
134
+ immutablesHash: new Fr(103n),
135
+ // Only `ivpk_m` is exposed as a curve point; the other master keys
136
+ // are exposed as `hash_public_key` digests. Constructor signature is
137
+ // `(npkMHash, ivpkM, ovpkMHash, tpkMHash, mspkMHash, fbpkMHash)`.
138
+ publicKeys: new PublicKeys(new Fr(41n), new PublicKey(new Fr(47n), new Fr(53n)), new Fr(59n), new Fr(67n), new Fr(71n), new Fr(73n))
139
+ }).withAddress(AztecAddress.fromBigInt(101n)));
140
+ },
141
+ snapshotStore: async (kvStore)=>({
142
+ contract_artifacts: await snapshotMap(kvStore.openMap('contract_artifacts')),
143
+ contract_classes: await snapshotMap(kvStore.openMap('contract_classes')),
144
+ contracts_instances: await snapshotMap(kvStore.openMap('contracts_instances'))
145
+ })
146
+ },
147
+ {
148
+ name: 'KeyStore',
149
+ writeToStore: async (kvStore)=>{
150
+ const keyStore = new KeyStore(kvStore);
151
+ await keyStore.addAccount(new Fr(2n), new Fr(3n));
152
+ },
153
+ snapshotStore: async (kvStore)=>({
154
+ key_store: await snapshotMap(kvStore.openMap('key_store'))
155
+ })
156
+ },
157
+ {
158
+ name: 'L2TipsKVStore',
159
+ writeToStore: async (kvStore)=>{
160
+ const l2TipsStore = new L2TipsKVStore(kvStore, 'pxe', GENESIS_BLOCK_HEADER_HASH);
161
+ const block = buildL2Block();
162
+ const publishedCheckpoint = new PublishedCheckpoint(new Checkpoint(new AppendOnlyTreeSnapshot(new Fr(2n), 3), new CheckpointHeader(new Fr(5n), new Fr(7n), new Fr(11n), new Fr(13n), new Fr(17n), SlotNumber(19), 23n, EthAddress.fromField(new Fr(29n)), AztecAddress.fromBigInt(31n), new GasFees(37n, 41n), new Fr(43n)), [
163
+ block
164
+ ], CheckpointNumber(47), 53n), new L1PublishedData(59n, 61n, new Fr(67n).toString()), []);
165
+ // `'blocks-added'` writes to `pxe_l2_tips` (proposed tag) and `pxe_l2_block_hashes`.
166
+ // `'chain-checkpointed'` writes to all four sub-stores: tips ('checkpointed' and 'proposedCheckpoint' tags),
167
+ // block-to-checkpoint mapping, and the checkpoint store.
168
+ await l2TipsStore.handleBlockStreamEvent({
169
+ type: 'blocks-added',
170
+ blocks: [
171
+ block
172
+ ]
173
+ });
174
+ await l2TipsStore.handleBlockStreamEvent({
175
+ type: 'chain-checkpointed',
176
+ block: {
177
+ number: BlockNumber(71),
178
+ hash: new Fr(73n).toString()
179
+ },
180
+ checkpoint: publishedCheckpoint
181
+ });
182
+ // `'chain-proven'` writes the 'proven' tag. `'finalized'` is omitted because its handler runs delete-before
183
+ // logic that would depend on the order of preceding events.
184
+ await l2TipsStore.handleBlockStreamEvent({
185
+ type: 'chain-proven',
186
+ block: {
187
+ number: BlockNumber(79),
188
+ hash: new Fr(83n).toString()
189
+ }
190
+ });
191
+ },
192
+ snapshotStore: async (kvStore)=>({
193
+ pxe_l2_tips: await snapshotMap(kvStore.openMap('pxe_l2_tips')),
194
+ pxe_l2_block_hashes: await snapshotMap(kvStore.openMap('pxe_l2_block_hashes')),
195
+ pxe_l2_block_number_to_checkpoint_number: await snapshotMap(kvStore.openMap('pxe_l2_block_number_to_checkpoint_number')),
196
+ pxe_l2_checkpoint_store: await snapshotMap(kvStore.openMap('pxe_l2_checkpoint_store'))
197
+ })
198
+ },
199
+ {
200
+ name: 'NoteStore',
201
+ writeToStore: async (kvStore)=>{
202
+ const noteStore = new NoteStore(kvStore);
203
+ const jobId = 'fixture-job';
204
+ // Two contracts so `note_nullifiers_by_contract` exhibits both a multi-value row (contractA → {n1, n2}) and a
205
+ // single-value row (contractB → {n3}).
206
+ const contractA = AztecAddress.fromBigInt(2n);
207
+ const contractB = AztecAddress.fromBigInt(3n);
208
+ const scopeX = AztecAddress.fromBigInt(5n);
209
+ const scopeY = AztecAddress.fromBigInt(7n);
210
+ // note1: active, will be added under two scopes to exercise the multi-element scopes vector encoding in
211
+ // `StoredNote.toBuffer`.
212
+ const note1 = new NoteDao(new Note([
213
+ new Fr(13n),
214
+ new Fr(17n),
215
+ new Fr(19n)
216
+ ]), contractA, AztecAddress.fromBigInt(23n), new Fr(29n), new Fr(31n), new Fr(37n), new Fr(41n), new Fr(43n), TxHash.fromField(new Fr(47n)), BlockNumber(53), new Fr(59n).toString(), 61, 67);
217
+ // note2: same contract as note1 → produces the multi-value row in `note_nullifiers_by_contract`.
218
+ const note2 = new NoteDao(new Note([
219
+ new Fr(71n),
220
+ new Fr(73n),
221
+ new Fr(79n)
222
+ ]), contractA, AztecAddress.fromBigInt(83n), new Fr(89n), new Fr(97n), new Fr(101n), new Fr(103n), new Fr(107n), TxHash.fromField(new Fr(109n)), BlockNumber(113), new Fr(127n).toString(), 131, 137);
223
+ // note3: different contract; will be nullified to populate `note_block_number_to_nullifier` and exercise the
224
+ // populated `_nullifiedAt` trailer of `StoredNote.toBuffer`.
225
+ const note3 = new NoteDao(new Note([
226
+ new Fr(139n),
227
+ new Fr(149n),
228
+ new Fr(151n)
229
+ ]), contractB, AztecAddress.fromBigInt(157n), new Fr(163n), new Fr(167n), new Fr(173n), new Fr(179n), new Fr(181n), TxHash.fromField(new Fr(191n)), BlockNumber(193), new Fr(197n).toString(), 199, 211);
230
+ // Adding note1 twice with different scopes triggers `addScope` on the staged StoredNote, producing a 2-element
231
+ // scope vector in the committed buffer.
232
+ await noteStore.addNotes([
233
+ note1
234
+ ], scopeX, jobId);
235
+ await noteStore.addNotes([
236
+ note1
237
+ ], scopeY, jobId);
238
+ await noteStore.addNotes([
239
+ note2
240
+ ], scopeX, jobId);
241
+ await noteStore.addNotes([
242
+ note3
243
+ ], scopeX, jobId);
244
+ // Nullify note3 within the same job. `applyNullifiers` reads the staged StoredNote, sets `_nullifiedAt`, and
245
+ // writes back to the staged map; `commit` then flushes it to disk with the populated trailer and adds the
246
+ // corresponding `note_block_number_to_nullifier` entry.
247
+ await noteStore.applyNullifiers([
248
+ {
249
+ data: note3.siloedNullifier,
250
+ l2BlockNumber: BlockNumber(223),
251
+ l2BlockHash: BlockHash.ZERO
252
+ }
253
+ ], jobId);
254
+ await kvStore.transactionAsync(()=>noteStore.commit(jobId));
255
+ },
256
+ snapshotStore: async (kvStore)=>({
257
+ notes: await snapshotMap(kvStore.openMap('notes')),
258
+ note_nullifiers_by_contract: await snapshotMap(kvStore.openMultiMap('note_nullifiers_by_contract')),
259
+ note_block_number_to_nullifier: await snapshotMap(kvStore.openMultiMap('note_block_number_to_nullifier'))
260
+ })
261
+ },
262
+ {
263
+ name: 'PrivateEventStore',
264
+ writeToStore: async (kvStore)=>{
265
+ const privateEventStore = new PrivateEventStore(kvStore);
266
+ const jobId = 'fixture-job';
267
+ // Two (contract, selector) pairs and two block numbers so each multimap exhibits both a multi-value row
268
+ // (contractA/selectorA → {e1, e2} and blockN1 → {e1, e2}) and a contrasting single-value row.
269
+ const contractA = AztecAddress.fromBigInt(2n);
270
+ const contractB = AztecAddress.fromBigInt(3n);
271
+ const selectorA = EventSelector.fromField(new Fr(5n));
272
+ const selectorB = EventSelector.fromField(new Fr(7n));
273
+ const scopeX = AztecAddress.fromBigInt(11n);
274
+ const scopeY = AztecAddress.fromBigInt(13n);
275
+ const blockN1 = BlockNumber(17);
276
+ const blockN2 = BlockNumber(19);
277
+ // event1: rich fixture. Re-stored under scopeY below to exercise the `addScope` branch and produce a 2-element
278
+ // scopes vector in the committed buffer.
279
+ const event1Commitment = new Fr(23n);
280
+ await privateEventStore.storePrivateEventLog(selectorA, new Fr(29n), [
281
+ new Fr(31n),
282
+ new Fr(37n),
283
+ new Fr(41n)
284
+ ], event1Commitment, {
285
+ contractAddress: contractA,
286
+ scope: scopeX,
287
+ txHash: TxHash.fromField(new Fr(43n)),
288
+ l2BlockNumber: blockN1,
289
+ l2BlockHash: new BlockHash(new Fr(47n)),
290
+ txIndexInBlock: 53,
291
+ eventIndexInTx: 59
292
+ }, jobId);
293
+ // Same eventId, different scope: takes the `existing.addScope(...)` path in `storePrivateEventLog`.
294
+ await privateEventStore.storePrivateEventLog(selectorA, new Fr(29n), [
295
+ new Fr(31n),
296
+ new Fr(37n),
297
+ new Fr(41n)
298
+ ], event1Commitment, {
299
+ contractAddress: contractA,
300
+ scope: scopeY,
301
+ txHash: TxHash.fromField(new Fr(43n)),
302
+ l2BlockNumber: blockN1,
303
+ l2BlockHash: new BlockHash(new Fr(47n)),
304
+ txIndexInBlock: 53,
305
+ eventIndexInTx: 59
306
+ }, jobId);
307
+ // event2: same (contract, selector) and same block as event1 → multi-value rows in both multimaps.
308
+ await privateEventStore.storePrivateEventLog(selectorA, new Fr(61n), [
309
+ new Fr(67n),
310
+ new Fr(71n),
311
+ new Fr(73n)
312
+ ], new Fr(79n), {
313
+ contractAddress: contractA,
314
+ scope: scopeX,
315
+ txHash: TxHash.fromField(new Fr(83n)),
316
+ l2BlockNumber: blockN1,
317
+ l2BlockHash: new BlockHash(new Fr(89n)),
318
+ txIndexInBlock: 97,
319
+ eventIndexInTx: 101
320
+ }, jobId);
321
+ // event3: distinct (contract, selector) and block → contrasting single-value multimap rows.
322
+ await privateEventStore.storePrivateEventLog(selectorB, new Fr(103n), [
323
+ new Fr(107n),
324
+ new Fr(109n),
325
+ new Fr(113n)
326
+ ], new Fr(127n), {
327
+ contractAddress: contractB,
328
+ scope: scopeX,
329
+ txHash: TxHash.fromField(new Fr(131n)),
330
+ l2BlockNumber: blockN2,
331
+ l2BlockHash: new BlockHash(new Fr(137n)),
332
+ txIndexInBlock: 139,
333
+ eventIndexInTx: 149
334
+ }, jobId);
335
+ await kvStore.transactionAsync(()=>privateEventStore.commit(jobId));
336
+ },
337
+ snapshotStore: async (kvStore)=>({
338
+ private_event_logs: await snapshotMap(kvStore.openMap('private_event_logs')),
339
+ events_by_contract_selector: await snapshotMap(kvStore.openMultiMap('events_by_contract_selector')),
340
+ events_by_block_number: await snapshotMap(kvStore.openMultiMap('events_by_block_number'))
341
+ })
342
+ },
343
+ {
344
+ name: 'RecipientTaggingStore',
345
+ writeToStore: async (kvStore)=>{
346
+ const recipientTaggingStore = new RecipientTaggingStore(kvStore);
347
+ const jobId = 'fixture-job';
348
+ const secretA = new AppTaggingSecret(new Fr(2n), AztecAddress.fromBigInt(3n));
349
+ const secretB = new AppTaggingSecret(new Fr(5n), AztecAddress.fromBigInt(7n));
350
+ await recipientTaggingStore.updateHighestFinalizedIndex(secretA, 11, jobId);
351
+ await recipientTaggingStore.updateHighestAgedIndex(secretA, 13, jobId);
352
+ await recipientTaggingStore.updateHighestFinalizedIndex(secretB, 17, jobId);
353
+ await kvStore.transactionAsync(()=>recipientTaggingStore.commit(jobId));
354
+ },
355
+ snapshotStore: async (kvStore)=>({
356
+ highest_aged_index: await snapshotMap(kvStore.openMap('highest_aged_index')),
357
+ highest_finalized_index: await snapshotMap(kvStore.openMap('highest_finalized_index'))
358
+ })
359
+ },
360
+ {
361
+ name: 'SenderAddressBookStore',
362
+ writeToStore: async (kvStore)=>{
363
+ const senderAddressBookStore = new SenderAddressBookStore(kvStore);
364
+ await senderAddressBookStore.addSender(AztecAddress.fromBigInt(2n));
365
+ await senderAddressBookStore.addSender(AztecAddress.fromBigInt(3n));
366
+ await senderAddressBookStore.addSender(AztecAddress.fromBigInt(5n));
367
+ },
368
+ snapshotStore: async (kvStore)=>({
369
+ address_book: await snapshotMap(kvStore.openMap('address_book'))
370
+ })
371
+ },
372
+ {
373
+ name: 'SenderTaggingStore',
374
+ writeToStore: async (kvStore)=>{
375
+ const senderTaggingStore = new SenderTaggingStore(kvStore);
376
+ const jobId = 'fixture-job';
377
+ const secretA = new AppTaggingSecret(new Fr(2n), AztecAddress.fromBigInt(3n));
378
+ const secretB = new AppTaggingSecret(new Fr(5n), AztecAddress.fromBigInt(7n));
379
+ const secretC = new AppTaggingSecret(new Fr(11n), AztecAddress.fromBigInt(13n));
380
+ const txHashA = TxHash.fromBigInt(17n);
381
+ const txHashB = TxHash.fromBigInt(19n);
382
+ const txHashC = TxHash.fromBigInt(23n);
383
+ const txHashD = TxHash.fromBigInt(29n);
384
+ // secretA receives three pending ranges (one per tx); secretB receives one. After finalizing txHashA below,
385
+ // secretA's array shrinks to two elements (the txHashB and txHashC ranges, both with highestIndex > 3) which
386
+ // pins the multi-element JSON encoding of `pending_indexes`.
387
+ const txHashARanges = [
388
+ {
389
+ extendedSecret: secretA,
390
+ lowestIndex: 1,
391
+ highestIndex: 3
392
+ },
393
+ {
394
+ extendedSecret: secretB,
395
+ lowestIndex: 1,
396
+ highestIndex: 5
397
+ }
398
+ ];
399
+ await senderTaggingStore.storePendingIndexes(txHashARanges, txHashA, jobId);
400
+ await senderTaggingStore.storePendingIndexes([
401
+ {
402
+ extendedSecret: secretA,
403
+ lowestIndex: 4,
404
+ highestIndex: 7
405
+ }
406
+ ], txHashB, jobId);
407
+ // Re-store the exact same (secret, txHash, range). Exercises the "exact duplicate — skip" branch at
408
+ // sender_tagging_store.ts:199. The snapshot must be unchanged by this call; it pins the no-op assumption.
409
+ await senderTaggingStore.storePendingIndexes([
410
+ {
411
+ extendedSecret: secretA,
412
+ lowestIndex: 4,
413
+ highestIndex: 7
414
+ }
415
+ ], txHashB, jobId);
416
+ await senderTaggingStore.storePendingIndexes([
417
+ {
418
+ extendedSecret: secretA,
419
+ lowestIndex: 8,
420
+ highestIndex: 11
421
+ }
422
+ ], txHashC, jobId);
423
+ // secretC's range is never finalized, so it survives commit as a single-element pending array (contrast with
424
+ // secretA's multi-element shape).
425
+ await senderTaggingStore.storePendingIndexes([
426
+ {
427
+ extendedSecret: secretC,
428
+ lowestIndex: 1,
429
+ highestIndex: 9
430
+ }
431
+ ], txHashD, jobId);
432
+ await senderTaggingStore.finalizePendingIndexes([
433
+ txHashA
434
+ ], jobId);
435
+ await kvStore.transactionAsync(()=>senderTaggingStore.commit(jobId));
436
+ },
437
+ snapshotStore: async (kvStore)=>({
438
+ pending_indexes: await snapshotMap(kvStore.openMap('pending_indexes')),
439
+ last_finalized_indexes: await snapshotMap(kvStore.openMap('last_finalized_indexes'))
440
+ })
441
+ }
442
+ ];
443
+ /**
444
+ * Pads an Fr array to `totalLength` with `Fr.ZERO`. Returns plain `Fr[]` rather than `Tuple<Fr, N>` so that callers
445
+ * with very large `totalLength` (e.g. `CONTRACT_CLASS_LOG_SIZE_IN_FIELDS = 3023`) don't trip TypeScript's recursive
446
+ * type instantiation depth limit on `Tuple<T, N>` — which is why we don't simply call `padArrayEnd` from foundation.
447
+ * Used because `ContractClassLogFields` and `PrivateLog` require fixed-length collections; populating only the leading
448
+ * slots is enough to detect reorders, while the trailing zeros pin each field's total width (a shrunk or grown size
449
+ * constant shifts the byte count and shows up in the snapshot diff).
450
+ */ function paddedFrs(leading, totalLength) {
451
+ const out = leading.map((p)=>new Fr(p));
452
+ while(out.length < totalLength){
453
+ out.push(Fr.ZERO);
454
+ }
455
+ return out;
456
+ }
457
+ /**
458
+ * Builds a fully-populated `L2Block` with distinct values for every primitive field that appears in `toBuffer`.
459
+ * We use distinct values to make a snapshot diff sensitive to regressions of specific fields, and same-width reorders.
460
+ */ function buildL2Block() {
461
+ const archive = new AppendOnlyTreeSnapshot(new Fr(101n), 103);
462
+ const header = new BlockHeader(new AppendOnlyTreeSnapshot(new Fr(107n), 109), new StateReference(new AppendOnlyTreeSnapshot(new Fr(113n), 127), new PartialStateReference(new AppendOnlyTreeSnapshot(new Fr(131n), 137), new AppendOnlyTreeSnapshot(new Fr(139n), 149), new AppendOnlyTreeSnapshot(new Fr(151n), 157))), new Fr(163n), new GlobalVariables(new Fr(167n), new Fr(173n), BlockNumber(179), SlotNumber(181), 191n, EthAddress.fromField(new Fr(193n)), AztecAddress.fromBigInt(197n), new GasFees(199n, 211n)), new Fr(223n), new Fr(227n));
463
+ const txEffect = new TxEffect(RevertCode.REVERTED, TxHash.fromBigInt(229n), new Fr(233n), [
464
+ new Fr(239n)
465
+ ], [
466
+ new Fr(241n)
467
+ ], [
468
+ new Fr(251n)
469
+ ], [
470
+ new PublicDataWrite(new Fr(257n), new Fr(263n))
471
+ ], [
472
+ new PrivateLog(paddedFrs([
473
+ 269n,
474
+ 271n,
475
+ 277n
476
+ ], PRIVATE_LOG_SIZE_IN_FIELDS), 3)
477
+ ], [
478
+ new PublicLog(AztecAddress.fromBigInt(281n), [
479
+ new Fr(283n),
480
+ new Fr(293n)
481
+ ])
482
+ ], [
483
+ new ContractClassLog(AztecAddress.fromBigInt(307n), new ContractClassLogFields(paddedFrs([
484
+ 311n,
485
+ 313n,
486
+ 317n
487
+ ], CONTRACT_CLASS_LOG_SIZE_IN_FIELDS)), 3)
488
+ ]);
489
+ return new L2Block(archive, header, new Body([
490
+ txEffect
491
+ ]), CheckpointNumber(331), IndexWithinCheckpoint(337));
492
+ }
493
+ /**
494
+ * Builds a deterministic, hand-rolled `ContractArtifact` for the ContractStore schema test. Every collection field
495
+ * has at least one entry so that JSON serialization branches for non-empty arrays and records are exercised; values
496
+ * are picked to be distinguishable so a reorder or shape change of `ContractArtifact`/`FunctionAbi` is visible in
497
+ * the snapshot diff.
498
+ *
499
+ * Why not import a real noir-compiled artifact? Compiled artifacts embed noir-compiler output (error-type hashes,
500
+ * debug symbols, struct paths) that drifts across compiler versions and produces spurious schema diffs unrelated to
501
+ * PXE's on-disk layout.
502
+ */ function buildSchemaContractArtifact() {
503
+ return {
504
+ name: 'SchemaFixtureContract',
505
+ aztecVersion: 'schema-fixture-version',
506
+ functions: [
507
+ {
508
+ name: 'private_fn',
509
+ functionType: FunctionType.PRIVATE,
510
+ isOnlySelf: false,
511
+ isStatic: false,
512
+ isInitializer: true,
513
+ parameters: [
514
+ {
515
+ name: 'first',
516
+ type: {
517
+ kind: 'field'
518
+ },
519
+ visibility: 'private'
520
+ },
521
+ {
522
+ name: 'second',
523
+ type: {
524
+ kind: 'integer',
525
+ sign: 'unsigned',
526
+ width: 32
527
+ },
528
+ visibility: 'public'
529
+ }
530
+ ],
531
+ returnTypes: [
532
+ {
533
+ kind: 'boolean'
534
+ }
535
+ ],
536
+ errorTypes: {
537
+ // Single entry. Exercises the non-empty `Record<string, AbiErrorType>` branch without depending on
538
+ // noir compiler output.
539
+ schema_test_error: {
540
+ error_kind: 'string',
541
+ string: 'fixed schema-test error'
542
+ }
543
+ },
544
+ bytecode: Buffer.from([
545
+ 2,
546
+ 3,
547
+ 5,
548
+ 7
549
+ ]),
550
+ debugSymbols: 'schema-fixture-debug'
551
+ }
552
+ ],
553
+ nonDispatchPublicFunctions: [
554
+ {
555
+ name: 'public_fn',
556
+ functionType: FunctionType.PUBLIC,
557
+ isOnlySelf: true,
558
+ isStatic: true,
559
+ isInitializer: false,
560
+ parameters: [],
561
+ returnTypes: [],
562
+ errorTypes: {}
563
+ }
564
+ ],
565
+ outputs: {
566
+ structs: {
567
+ my_struct: [
568
+ {
569
+ kind: 'field'
570
+ },
571
+ {
572
+ kind: 'boolean'
573
+ }
574
+ ]
575
+ },
576
+ globals: {}
577
+ },
578
+ storageLayout: {
579
+ my_field: {
580
+ slot: new Fr(11n)
581
+ }
582
+ },
583
+ fileMap: {
584
+ 1: {
585
+ source: 'schema fixture source',
586
+ path: 'src/schema_fixture.nr',
587
+ function_locations: []
588
+ }
589
+ }
590
+ };
591
+ }
@@ -0,0 +1,19 @@
1
+ import type { AztecAsyncKVStore } from '@aztec/kv-store';
2
+ /** The kind of named sub-store opened on an `AztecAsyncKVStore`. */
3
+ export type StoreKind = 'map' | 'multimap' | 'array' | 'singleton' | 'set' | 'counter';
4
+ /** A single recorded `open*()` call against a spied store. */
5
+ export interface OpenedStoreEntry {
6
+ name: string;
7
+ kind: StoreKind;
8
+ }
9
+ /** A spied `AztecAsyncKVStore` together with a function that returns the sorted log of `open*()` calls. */
10
+ export interface StoreSpy {
11
+ store: AztecAsyncKVStore;
12
+ getOpenedStores: () => OpenedStoreEntry[];
13
+ }
14
+ /**
15
+ * Wraps an `AztecAsyncKVStore` so every `openMap`/`openMultiMap`/`openArray`/`openSingleton`/`openSet`/`openCounter`
16
+ * call is recorded before being delegated to the inner store.
17
+ */
18
+ export declare function createStoreSpy(inner: AztecAsyncKVStore): StoreSpy;
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcmVfc3B5LmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc3RvcmFnZS9iYWNrd2FyZHNfY29tcGF0aWJpbGl0eV90ZXN0cy9zdG9yZV9zcHkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLEVBR1YsaUJBQWlCLEVBTWxCLE1BQU0saUJBQWlCLENBQUM7QUFJekIsb0VBQW9FO0FBQ3BFLE1BQU0sTUFBTSxTQUFTLEdBQUcsS0FBSyxHQUFHLFVBQVUsR0FBRyxPQUFPLEdBQUcsV0FBVyxHQUFHLEtBQUssR0FBRyxTQUFTLENBQUM7QUFFdkYsOERBQThEO0FBQzlELE1BQU0sV0FBVyxnQkFBZ0I7SUFDL0IsSUFBSSxFQUFFLE1BQU0sQ0FBQztJQUNiLElBQUksRUFBRSxTQUFTLENBQUM7Q0FDakI7QUFFRCwyR0FBMkc7QUFDM0csTUFBTSxXQUFXLFFBQVE7SUFDdkIsS0FBSyxFQUFFLGlCQUFpQixDQUFDO0lBQ3pCLGVBQWUsRUFBRSxNQUFNLGdCQUFnQixFQUFFLENBQUM7Q0FDM0M7QUFFRDs7O0dBR0c7QUFDSCx3QkFBZ0IsY0FBYyxDQUFDLEtBQUssRUFBRSxpQkFBaUIsR0FBRyxRQUFRLENBd0NqRSJ9
@@ -0,0 +1 @@
1
+ {"version":3,"file":"store_spy.d.ts","sourceRoot":"","sources":["../../../src/storage/backwards_compatibility_tests/store_spy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAGV,iBAAiB,EAMlB,MAAM,iBAAiB,CAAC;AAIzB,oEAAoE;AACpE,MAAM,MAAM,SAAS,GAAG,KAAK,GAAG,UAAU,GAAG,OAAO,GAAG,WAAW,GAAG,KAAK,GAAG,SAAS,CAAC;AAEvF,8DAA8D;AAC9D,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,SAAS,CAAC;CACjB;AAED,2GAA2G;AAC3G,MAAM,WAAW,QAAQ;IACvB,KAAK,EAAE,iBAAiB,CAAC;IACzB,eAAe,EAAE,MAAM,gBAAgB,EAAE,CAAC;CAC3C;AAED;;;GAGG;AACH,wBAAgB,cAAc,CAAC,KAAK,EAAE,iBAAiB,GAAG,QAAQ,CAwCjE"}
@@ -0,0 +1,63 @@
1
+ /**
2
+ * Wraps an `AztecAsyncKVStore` so every `openMap`/`openMultiMap`/`openArray`/`openSingleton`/`openSet`/`openCounter`
3
+ * call is recorded before being delegated to the inner store.
4
+ */ export function createStoreSpy(inner) {
5
+ const entries = [];
6
+ const store = {
7
+ openMap (name) {
8
+ entries.push({
9
+ name,
10
+ kind: 'map'
11
+ });
12
+ return inner.openMap(name);
13
+ },
14
+ openMultiMap (name) {
15
+ entries.push({
16
+ name,
17
+ kind: 'multimap'
18
+ });
19
+ return inner.openMultiMap(name);
20
+ },
21
+ openArray (name) {
22
+ entries.push({
23
+ name,
24
+ kind: 'array'
25
+ });
26
+ return inner.openArray(name);
27
+ },
28
+ openSingleton (name) {
29
+ entries.push({
30
+ name,
31
+ kind: 'singleton'
32
+ });
33
+ return inner.openSingleton(name);
34
+ },
35
+ openSet (name) {
36
+ entries.push({
37
+ name,
38
+ kind: 'set'
39
+ });
40
+ return inner.openSet(name);
41
+ },
42
+ openCounter (name) {
43
+ entries.push({
44
+ name,
45
+ kind: 'counter'
46
+ });
47
+ return inner.openCounter(name);
48
+ },
49
+ transactionAsync: (callback)=>inner.transactionAsync(callback),
50
+ clear: ()=>inner.clear(),
51
+ delete: ()=>inner.delete(),
52
+ estimateSize: ()=>inner.estimateSize(),
53
+ close: ()=>inner.close(),
54
+ backupTo: (dstPath, compact)=>inner.backupTo(dstPath, compact)
55
+ };
56
+ const getOpenedStores = ()=>[
57
+ ...entries
58
+ ].sort((a, b)=>a.name === b.name ? a.kind.localeCompare(b.kind) : a.name.localeCompare(b.name));
59
+ return {
60
+ store,
61
+ getOpenedStores
62
+ };
63
+ }