@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,712 @@
1
+ /* eslint-disable camelcase */
2
+ import { CONTRACT_CLASS_LOG_SIZE_IN_FIELDS, PRIVATE_LOG_SIZE_IN_FIELDS } from '@aztec/constants';
3
+ import { BlockNumber, CheckpointNumber, IndexWithinCheckpoint, SlotNumber } from '@aztec/foundation/branded-types';
4
+ import { Fr } from '@aztec/foundation/curves/bn254';
5
+ import { EthAddress } from '@aztec/foundation/eth-address';
6
+ import type { Tuple } from '@aztec/foundation/serialize';
7
+ import { KeyStore } from '@aztec/key-store';
8
+ import type { AztecAsyncKVStore } from '@aztec/kv-store';
9
+ import { L2TipsKVStore } from '@aztec/kv-store/stores';
10
+ import { type ContractArtifact, EventSelector, FunctionSelector, FunctionType } from '@aztec/stdlib/abi';
11
+ import { PublicDataWrite, RevertCode } from '@aztec/stdlib/avm';
12
+ import { AztecAddress } from '@aztec/stdlib/aztec-address';
13
+ import { BlockHash, Body, GENESIS_BLOCK_HEADER_HASH, L2Block } from '@aztec/stdlib/block';
14
+ import { Checkpoint, L1PublishedData, PublishedCheckpoint } from '@aztec/stdlib/checkpoint';
15
+ import { CompleteAddress, SerializableContractInstance } from '@aztec/stdlib/contract';
16
+ import { GasFees } from '@aztec/stdlib/gas';
17
+ import { PublicKey, PublicKeys } from '@aztec/stdlib/keys';
18
+ import {
19
+ AppTaggingSecret,
20
+ ContractClassLog,
21
+ ContractClassLogFields,
22
+ PrivateLog,
23
+ PublicLog,
24
+ type TaggingIndexRange,
25
+ } from '@aztec/stdlib/logs';
26
+ import { Note, NoteDao } from '@aztec/stdlib/note';
27
+ import { CheckpointHeader } from '@aztec/stdlib/rollup';
28
+ import { AppendOnlyTreeSnapshot } from '@aztec/stdlib/trees';
29
+ import {
30
+ BlockHeader,
31
+ GlobalVariables,
32
+ PartialStateReference,
33
+ StateReference,
34
+ TxEffect,
35
+ TxHash,
36
+ } from '@aztec/stdlib/tx';
37
+
38
+ import { AddressStore } from '../address_store/address_store.js';
39
+ import { AnchorBlockStore } from '../anchor_block_store/anchor_block_store.js';
40
+ import { CapsuleStore } from '../capsule_store/capsule_store.js';
41
+ import { ContractStore } from '../contract_store/contract_store.js';
42
+ import { NoteStore } from '../note_store/note_store.js';
43
+ import { PrivateEventStore } from '../private_event_store/private_event_store.js';
44
+ import { RecipientTaggingStore, SenderAddressBookStore, SenderTaggingStore } from '../tagging_store/index.js';
45
+ import { snapshotArray, snapshotMap, snapshotSingleton } from './kv_store_snapshot.js';
46
+
47
+ /**
48
+ * Template of a specific store's backwards compatibility checks.
49
+ *
50
+ * 1. `name` is the store's name (`AddressStore`, `NoteStore`, etc).
51
+ * 2. `writeToStore` drives writes through each store's own production API (`addNote`, `setCapsule`, etc).
52
+ * 3. `snapshotStore` re-opens the underlying kv-stores by name (raw) and renders them as snapshots.
53
+ */
54
+ export type SchemaTest = {
55
+ name: string;
56
+ writeToStore: (kvStore: AztecAsyncKVStore) => Promise<void>;
57
+ snapshotStore: (kvStore: AztecAsyncKVStore) => Promise<Record<string, unknown>>;
58
+ };
59
+
60
+ export const SCHEMA_TESTS: readonly SchemaTest[] = [
61
+ {
62
+ name: 'AddressStore',
63
+ writeToStore: async kvStore => {
64
+ const addressStore = new AddressStore(kvStore);
65
+
66
+ const addresses = [
67
+ await CompleteAddress.fromSecretKeyAndPartialAddress(new Fr(2n), new Fr(3n)),
68
+ await CompleteAddress.fromSecretKeyAndPartialAddress(new Fr(5n), new Fr(7n)),
69
+ ];
70
+
71
+ await addressStore.addCompleteAddress(addresses[0]);
72
+ await addressStore.addCompleteAddress(addresses[1]);
73
+ // Re-adding an already-registered address must be a no-op: duplicate detection should leave both sub-stores
74
+ // unchanged. If this regresses, the snapshot picks up an extra array entry.
75
+ await addressStore.addCompleteAddress(addresses[0]);
76
+ },
77
+ snapshotStore: async kvStore => ({
78
+ complete_addresses: await snapshotArray(kvStore.openArray<Buffer>('complete_addresses')),
79
+ complete_address_index: await snapshotMap(kvStore.openMap<string, number>('complete_address_index')),
80
+ }),
81
+ },
82
+
83
+ {
84
+ name: 'AnchorBlockStore',
85
+ writeToStore: async kvStore => {
86
+ const anchorBlockStore = new AnchorBlockStore(kvStore);
87
+
88
+ // Each primitive field gets a distinct prime so any reorder shows up in the snapshot diff. An all-zero
89
+ // `BlockHeader.empty()` would silently pass through same-width field swaps.
90
+ await anchorBlockStore.setHeader(
91
+ new BlockHeader(
92
+ new AppendOnlyTreeSnapshot(new Fr(2n), 3),
93
+ new StateReference(
94
+ new AppendOnlyTreeSnapshot(new Fr(5n), 7),
95
+ new PartialStateReference(
96
+ new AppendOnlyTreeSnapshot(new Fr(11n), 13),
97
+ new AppendOnlyTreeSnapshot(new Fr(17n), 19),
98
+ new AppendOnlyTreeSnapshot(new Fr(23n), 29),
99
+ ),
100
+ ),
101
+ new Fr(31n),
102
+ new GlobalVariables(
103
+ new Fr(37n),
104
+ new Fr(41n),
105
+ BlockNumber(43),
106
+ SlotNumber(47),
107
+ 53n,
108
+ EthAddress.fromField(new Fr(59n)),
109
+ AztecAddress.fromBigInt(61n),
110
+ new GasFees(67n, 71n),
111
+ ),
112
+ new Fr(73n),
113
+ new Fr(79n),
114
+ ),
115
+ );
116
+ },
117
+ snapshotStore: async kvStore => ({
118
+ header: await snapshotSingleton(kvStore.openSingleton<Buffer>('header')),
119
+ }),
120
+ },
121
+
122
+ {
123
+ name: 'CapsuleStore',
124
+ writeToStore: async kvStore => {
125
+ const capsuleStore = new CapsuleStore(kvStore);
126
+
127
+ const jobId = 'fixture-job';
128
+ const contractAddress = AztecAddress.fromBigInt(2n);
129
+ const scope = AztecAddress.fromBigInt(3n);
130
+
131
+ // Three setCapsule calls (2-element, 1-element, 0-element value vector) pin every value-encoding length case.
132
+ capsuleStore.setCapsule(contractAddress, new Fr(5n), [new Fr(7n), new Fr(11n)], jobId, scope);
133
+ capsuleStore.setCapsule(contractAddress, new Fr(13n), [new Fr(17n)], jobId, scope);
134
+ capsuleStore.setCapsule(contractAddress, new Fr(19n), [], jobId, scope);
135
+ await kvStore.transactionAsync(() => capsuleStore.commit(jobId));
136
+ },
137
+ snapshotStore: async kvStore => ({
138
+ capsules: await snapshotMap(kvStore.openMap<string, Buffer>('capsules')),
139
+ }),
140
+ },
141
+
142
+ {
143
+ name: 'ContractStore',
144
+ writeToStore: async kvStore => {
145
+ const contractStore = new ContractStore(kvStore);
146
+
147
+ // Hand-rolled artifact (see `buildSchemaContractArtifact` below) instead of importing a noir-compiled fixture.
148
+ // The compiled fixture's JSON contains noir-compiler outputs (error-type hashes, debug symbols, struct paths)
149
+ // that drift across compiler versions and produce spurious ContractStore.json diffs that have nothing to do with
150
+ // PXE's on-disk schema. The hand-rolled artifact is small, deterministic across versions, and exercises the
151
+ // `addContractArtifact` write path identically.
152
+ const artifact = buildSchemaContractArtifact();
153
+
154
+ // Precomputed class so the `contract_classes` bytes are hardcoded by this test rather than derived from
155
+ // `getContractClassFromArtifact`.
156
+ const populatedClass = {
157
+ version: 1 as const,
158
+ id: new Fr(2n),
159
+ artifactHash: new Fr(3n),
160
+ privateFunctionsRoot: new Fr(5n),
161
+ publicBytecodeCommitment: new Fr(7n),
162
+ privateFunctions: [
163
+ { selector: FunctionSelector.fromField(new Fr(11n)), vkHash: new Fr(13n) },
164
+ { selector: FunctionSelector.fromField(new Fr(17n)), vkHash: new Fr(19n) },
165
+ ],
166
+ packedBytecode: Buffer.alloc(0),
167
+ };
168
+
169
+ await contractStore.addContractArtifact(artifact, populatedClass);
170
+
171
+ // Same artifact, different class with empty `privateFunctions`. Tests zero-length-vector encoding for the
172
+ // privateFunctions field, which the populated case can't reach.
173
+ await contractStore.addContractArtifact(artifact, {
174
+ version: 1 as const,
175
+ id: new Fr(23n),
176
+ artifactHash: new Fr(29n),
177
+ privateFunctionsRoot: new Fr(31n),
178
+ publicBytecodeCommitment: new Fr(37n),
179
+ privateFunctions: [],
180
+ packedBytecode: Buffer.alloc(0),
181
+ });
182
+
183
+ // Re-register the populated class: must hit the `#contractArtifactCache` short-circuit and leave both
184
+ // `contract_artifacts` and `contract_classes` unchanged.
185
+ await contractStore.addContractArtifact(artifact, populatedClass);
186
+
187
+ await contractStore.addContractInstance(
188
+ new SerializableContractInstance({
189
+ version: 2,
190
+ salt: new Fr(73n),
191
+ deployer: AztecAddress.fromBigInt(79n),
192
+ currentContractClassId: new Fr(83n),
193
+ originalContractClassId: new Fr(89n),
194
+ initializationHash: new Fr(97n),
195
+ immutablesHash: new Fr(103n),
196
+ // Only `ivpk_m` is exposed as a curve point; the other master keys
197
+ // are exposed as `hash_public_key` digests. Constructor signature is
198
+ // `(npkMHash, ivpkM, ovpkMHash, tpkMHash, mspkMHash, fbpkMHash)`.
199
+ publicKeys: new PublicKeys(
200
+ new Fr(41n),
201
+ new PublicKey(new Fr(47n), new Fr(53n)),
202
+ new Fr(59n),
203
+ new Fr(67n),
204
+ new Fr(71n),
205
+ new Fr(73n),
206
+ ),
207
+ }).withAddress(AztecAddress.fromBigInt(101n)),
208
+ );
209
+ },
210
+ snapshotStore: async kvStore => ({
211
+ contract_artifacts: await snapshotMap(kvStore.openMap<string, Buffer>('contract_artifacts')),
212
+ contract_classes: await snapshotMap(kvStore.openMap<string, Buffer>('contract_classes')),
213
+ contracts_instances: await snapshotMap(kvStore.openMap<string, Buffer>('contracts_instances')),
214
+ }),
215
+ },
216
+
217
+ {
218
+ name: 'KeyStore',
219
+ writeToStore: async kvStore => {
220
+ const keyStore = new KeyStore(kvStore);
221
+ await keyStore.addAccount(new Fr(2n), new Fr(3n));
222
+ },
223
+ snapshotStore: async kvStore => ({
224
+ key_store: await snapshotMap(kvStore.openMap<string, Buffer>('key_store')),
225
+ }),
226
+ },
227
+
228
+ {
229
+ name: 'L2TipsKVStore',
230
+ writeToStore: async kvStore => {
231
+ const l2TipsStore = new L2TipsKVStore(kvStore, 'pxe', GENESIS_BLOCK_HEADER_HASH);
232
+
233
+ const block = buildL2Block();
234
+ const publishedCheckpoint = new PublishedCheckpoint(
235
+ new Checkpoint(
236
+ new AppendOnlyTreeSnapshot(new Fr(2n), 3),
237
+ new CheckpointHeader(
238
+ new Fr(5n),
239
+ new Fr(7n),
240
+ new Fr(11n),
241
+ new Fr(13n),
242
+ new Fr(17n),
243
+ SlotNumber(19),
244
+ 23n,
245
+ EthAddress.fromField(new Fr(29n)),
246
+ AztecAddress.fromBigInt(31n),
247
+ new GasFees(37n, 41n),
248
+ new Fr(43n),
249
+ ),
250
+ [block],
251
+ CheckpointNumber(47),
252
+ 53n,
253
+ ),
254
+ new L1PublishedData(59n, 61n, new Fr(67n).toString()),
255
+ [],
256
+ );
257
+
258
+ // `'blocks-added'` writes to `pxe_l2_tips` (proposed tag) and `pxe_l2_block_hashes`.
259
+ // `'chain-checkpointed'` writes to all four sub-stores: tips ('checkpointed' and 'proposedCheckpoint' tags),
260
+ // block-to-checkpoint mapping, and the checkpoint store.
261
+ await l2TipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks: [block] });
262
+ await l2TipsStore.handleBlockStreamEvent({
263
+ type: 'chain-checkpointed',
264
+ block: { number: BlockNumber(71), hash: new Fr(73n).toString() },
265
+ checkpoint: publishedCheckpoint,
266
+ });
267
+ // `'chain-proven'` writes the 'proven' tag. `'finalized'` is omitted because its handler runs delete-before
268
+ // logic that would depend on the order of preceding events.
269
+ await l2TipsStore.handleBlockStreamEvent({
270
+ type: 'chain-proven',
271
+ block: { number: BlockNumber(79), hash: new Fr(83n).toString() },
272
+ });
273
+ },
274
+ snapshotStore: async kvStore => ({
275
+ pxe_l2_tips: await snapshotMap(kvStore.openMap<string, number>('pxe_l2_tips')),
276
+ pxe_l2_block_hashes: await snapshotMap(kvStore.openMap<number, string>('pxe_l2_block_hashes')),
277
+ pxe_l2_block_number_to_checkpoint_number: await snapshotMap(
278
+ kvStore.openMap<number, number>('pxe_l2_block_number_to_checkpoint_number'),
279
+ ),
280
+ pxe_l2_checkpoint_store: await snapshotMap(kvStore.openMap<number, Buffer>('pxe_l2_checkpoint_store')),
281
+ }),
282
+ },
283
+
284
+ {
285
+ name: 'NoteStore',
286
+ writeToStore: async kvStore => {
287
+ const noteStore = new NoteStore(kvStore);
288
+
289
+ const jobId = 'fixture-job';
290
+
291
+ // Two contracts so `note_nullifiers_by_contract` exhibits both a multi-value row (contractA → {n1, n2}) and a
292
+ // single-value row (contractB → {n3}).
293
+ const contractA = AztecAddress.fromBigInt(2n);
294
+ const contractB = AztecAddress.fromBigInt(3n);
295
+ const scopeX = AztecAddress.fromBigInt(5n);
296
+ const scopeY = AztecAddress.fromBigInt(7n);
297
+
298
+ // note1: active, will be added under two scopes to exercise the multi-element scopes vector encoding in
299
+ // `StoredNote.toBuffer`.
300
+ const note1 = new NoteDao(
301
+ new Note([new Fr(13n), new Fr(17n), new Fr(19n)]),
302
+ contractA,
303
+ AztecAddress.fromBigInt(23n),
304
+ new Fr(29n),
305
+ new Fr(31n),
306
+ new Fr(37n),
307
+ new Fr(41n),
308
+ new Fr(43n),
309
+ TxHash.fromField(new Fr(47n)),
310
+ BlockNumber(53),
311
+ new Fr(59n).toString(),
312
+ 61,
313
+ 67,
314
+ );
315
+
316
+ // note2: same contract as note1 → produces the multi-value row in `note_nullifiers_by_contract`.
317
+ const note2 = new NoteDao(
318
+ new Note([new Fr(71n), new Fr(73n), new Fr(79n)]),
319
+ contractA,
320
+ AztecAddress.fromBigInt(83n),
321
+ new Fr(89n),
322
+ new Fr(97n),
323
+ new Fr(101n),
324
+ new Fr(103n),
325
+ new Fr(107n),
326
+ TxHash.fromField(new Fr(109n)),
327
+ BlockNumber(113),
328
+ new Fr(127n).toString(),
329
+ 131,
330
+ 137,
331
+ );
332
+
333
+ // note3: different contract; will be nullified to populate `note_block_number_to_nullifier` and exercise the
334
+ // populated `_nullifiedAt` trailer of `StoredNote.toBuffer`.
335
+ const note3 = new NoteDao(
336
+ new Note([new Fr(139n), new Fr(149n), new Fr(151n)]),
337
+ contractB,
338
+ AztecAddress.fromBigInt(157n),
339
+ new Fr(163n),
340
+ new Fr(167n),
341
+ new Fr(173n),
342
+ new Fr(179n),
343
+ new Fr(181n),
344
+ TxHash.fromField(new Fr(191n)),
345
+ BlockNumber(193),
346
+ new Fr(197n).toString(),
347
+ 199,
348
+ 211,
349
+ );
350
+
351
+ // Adding note1 twice with different scopes triggers `addScope` on the staged StoredNote, producing a 2-element
352
+ // scope vector in the committed buffer.
353
+ await noteStore.addNotes([note1], scopeX, jobId);
354
+ await noteStore.addNotes([note1], scopeY, jobId);
355
+ await noteStore.addNotes([note2], scopeX, jobId);
356
+ await noteStore.addNotes([note3], scopeX, jobId);
357
+
358
+ // Nullify note3 within the same job. `applyNullifiers` reads the staged StoredNote, sets `_nullifiedAt`, and
359
+ // writes back to the staged map; `commit` then flushes it to disk with the populated trailer and adds the
360
+ // corresponding `note_block_number_to_nullifier` entry.
361
+ await noteStore.applyNullifiers(
362
+ [{ data: note3.siloedNullifier, l2BlockNumber: BlockNumber(223), l2BlockHash: BlockHash.ZERO }],
363
+ jobId,
364
+ );
365
+
366
+ await kvStore.transactionAsync(() => noteStore.commit(jobId));
367
+ },
368
+ snapshotStore: async kvStore => ({
369
+ notes: await snapshotMap(kvStore.openMap<string, Buffer>('notes')),
370
+ note_nullifiers_by_contract: await snapshotMap(
371
+ kvStore.openMultiMap<string, string>('note_nullifiers_by_contract'),
372
+ ),
373
+ note_block_number_to_nullifier: await snapshotMap(
374
+ kvStore.openMultiMap<number, string>('note_block_number_to_nullifier'),
375
+ ),
376
+ }),
377
+ },
378
+
379
+ {
380
+ name: 'PrivateEventStore',
381
+ writeToStore: async kvStore => {
382
+ const privateEventStore = new PrivateEventStore(kvStore);
383
+
384
+ const jobId = 'fixture-job';
385
+
386
+ // Two (contract, selector) pairs and two block numbers so each multimap exhibits both a multi-value row
387
+ // (contractA/selectorA → {e1, e2} and blockN1 → {e1, e2}) and a contrasting single-value row.
388
+ const contractA = AztecAddress.fromBigInt(2n);
389
+ const contractB = AztecAddress.fromBigInt(3n);
390
+ const selectorA = EventSelector.fromField(new Fr(5n));
391
+ const selectorB = EventSelector.fromField(new Fr(7n));
392
+ const scopeX = AztecAddress.fromBigInt(11n);
393
+ const scopeY = AztecAddress.fromBigInt(13n);
394
+ const blockN1 = BlockNumber(17);
395
+ const blockN2 = BlockNumber(19);
396
+
397
+ // event1: rich fixture. Re-stored under scopeY below to exercise the `addScope` branch and produce a 2-element
398
+ // scopes vector in the committed buffer.
399
+ const event1Commitment = new Fr(23n);
400
+ await privateEventStore.storePrivateEventLog(
401
+ selectorA,
402
+ new Fr(29n),
403
+ [new Fr(31n), new Fr(37n), new Fr(41n)],
404
+ event1Commitment,
405
+ {
406
+ contractAddress: contractA,
407
+ scope: scopeX,
408
+ txHash: TxHash.fromField(new Fr(43n)),
409
+ l2BlockNumber: blockN1,
410
+ l2BlockHash: new BlockHash(new Fr(47n)),
411
+ txIndexInBlock: 53,
412
+ eventIndexInTx: 59,
413
+ },
414
+ jobId,
415
+ );
416
+
417
+ // Same eventId, different scope: takes the `existing.addScope(...)` path in `storePrivateEventLog`.
418
+ await privateEventStore.storePrivateEventLog(
419
+ selectorA,
420
+ new Fr(29n),
421
+ [new Fr(31n), new Fr(37n), new Fr(41n)],
422
+ event1Commitment,
423
+ {
424
+ contractAddress: contractA,
425
+ scope: scopeY,
426
+ txHash: TxHash.fromField(new Fr(43n)),
427
+ l2BlockNumber: blockN1,
428
+ l2BlockHash: new BlockHash(new Fr(47n)),
429
+ txIndexInBlock: 53,
430
+ eventIndexInTx: 59,
431
+ },
432
+ jobId,
433
+ );
434
+
435
+ // event2: same (contract, selector) and same block as event1 → multi-value rows in both multimaps.
436
+ await privateEventStore.storePrivateEventLog(
437
+ selectorA,
438
+ new Fr(61n),
439
+ [new Fr(67n), new Fr(71n), new Fr(73n)],
440
+ new Fr(79n),
441
+ {
442
+ contractAddress: contractA,
443
+ scope: scopeX,
444
+ txHash: TxHash.fromField(new Fr(83n)),
445
+ l2BlockNumber: blockN1,
446
+ l2BlockHash: new BlockHash(new Fr(89n)),
447
+ txIndexInBlock: 97,
448
+ eventIndexInTx: 101,
449
+ },
450
+ jobId,
451
+ );
452
+
453
+ // event3: distinct (contract, selector) and block → contrasting single-value multimap rows.
454
+ await privateEventStore.storePrivateEventLog(
455
+ selectorB,
456
+ new Fr(103n),
457
+ [new Fr(107n), new Fr(109n), new Fr(113n)],
458
+ new Fr(127n),
459
+ {
460
+ contractAddress: contractB,
461
+ scope: scopeX,
462
+ txHash: TxHash.fromField(new Fr(131n)),
463
+ l2BlockNumber: blockN2,
464
+ l2BlockHash: new BlockHash(new Fr(137n)),
465
+ txIndexInBlock: 139,
466
+ eventIndexInTx: 149,
467
+ },
468
+ jobId,
469
+ );
470
+
471
+ await kvStore.transactionAsync(() => privateEventStore.commit(jobId));
472
+ },
473
+ snapshotStore: async kvStore => ({
474
+ private_event_logs: await snapshotMap(kvStore.openMap<string, Buffer>('private_event_logs')),
475
+ events_by_contract_selector: await snapshotMap(
476
+ kvStore.openMultiMap<string, string>('events_by_contract_selector'),
477
+ ),
478
+ events_by_block_number: await snapshotMap(kvStore.openMultiMap<number, string>('events_by_block_number')),
479
+ }),
480
+ },
481
+
482
+ {
483
+ name: 'RecipientTaggingStore',
484
+ writeToStore: async kvStore => {
485
+ const recipientTaggingStore = new RecipientTaggingStore(kvStore);
486
+
487
+ const jobId = 'fixture-job';
488
+ const secretA = new AppTaggingSecret(new Fr(2n), AztecAddress.fromBigInt(3n));
489
+ const secretB = new AppTaggingSecret(new Fr(5n), AztecAddress.fromBigInt(7n));
490
+
491
+ await recipientTaggingStore.updateHighestFinalizedIndex(secretA, 11, jobId);
492
+ await recipientTaggingStore.updateHighestAgedIndex(secretA, 13, jobId);
493
+ await recipientTaggingStore.updateHighestFinalizedIndex(secretB, 17, jobId);
494
+ await kvStore.transactionAsync(() => recipientTaggingStore.commit(jobId));
495
+ },
496
+ snapshotStore: async kvStore => ({
497
+ highest_aged_index: await snapshotMap(kvStore.openMap<string, number>('highest_aged_index')),
498
+ highest_finalized_index: await snapshotMap(kvStore.openMap<string, number>('highest_finalized_index')),
499
+ }),
500
+ },
501
+
502
+ {
503
+ name: 'SenderAddressBookStore',
504
+ writeToStore: async kvStore => {
505
+ const senderAddressBookStore = new SenderAddressBookStore(kvStore);
506
+
507
+ await senderAddressBookStore.addSender(AztecAddress.fromBigInt(2n));
508
+ await senderAddressBookStore.addSender(AztecAddress.fromBigInt(3n));
509
+ await senderAddressBookStore.addSender(AztecAddress.fromBigInt(5n));
510
+ },
511
+ snapshotStore: async kvStore => ({
512
+ address_book: await snapshotMap(kvStore.openMap<string, true>('address_book')),
513
+ }),
514
+ },
515
+
516
+ {
517
+ name: 'SenderTaggingStore',
518
+ writeToStore: async kvStore => {
519
+ const senderTaggingStore = new SenderTaggingStore(kvStore);
520
+
521
+ const jobId = 'fixture-job';
522
+ const secretA = new AppTaggingSecret(new Fr(2n), AztecAddress.fromBigInt(3n));
523
+ const secretB = new AppTaggingSecret(new Fr(5n), AztecAddress.fromBigInt(7n));
524
+ const secretC = new AppTaggingSecret(new Fr(11n), AztecAddress.fromBigInt(13n));
525
+ const txHashA = TxHash.fromBigInt(17n);
526
+ const txHashB = TxHash.fromBigInt(19n);
527
+ const txHashC = TxHash.fromBigInt(23n);
528
+ const txHashD = TxHash.fromBigInt(29n);
529
+
530
+ // secretA receives three pending ranges (one per tx); secretB receives one. After finalizing txHashA below,
531
+ // secretA's array shrinks to two elements (the txHashB and txHashC ranges, both with highestIndex > 3) which
532
+ // pins the multi-element JSON encoding of `pending_indexes`.
533
+ const txHashARanges: TaggingIndexRange[] = [
534
+ { extendedSecret: secretA, lowestIndex: 1, highestIndex: 3 },
535
+ { extendedSecret: secretB, lowestIndex: 1, highestIndex: 5 },
536
+ ];
537
+ await senderTaggingStore.storePendingIndexes(txHashARanges, txHashA, jobId);
538
+
539
+ await senderTaggingStore.storePendingIndexes(
540
+ [{ extendedSecret: secretA, lowestIndex: 4, highestIndex: 7 }],
541
+ txHashB,
542
+ jobId,
543
+ );
544
+
545
+ // Re-store the exact same (secret, txHash, range). Exercises the "exact duplicate — skip" branch at
546
+ // sender_tagging_store.ts:199. The snapshot must be unchanged by this call; it pins the no-op assumption.
547
+ await senderTaggingStore.storePendingIndexes(
548
+ [{ extendedSecret: secretA, lowestIndex: 4, highestIndex: 7 }],
549
+ txHashB,
550
+ jobId,
551
+ );
552
+
553
+ await senderTaggingStore.storePendingIndexes(
554
+ [{ extendedSecret: secretA, lowestIndex: 8, highestIndex: 11 }],
555
+ txHashC,
556
+ jobId,
557
+ );
558
+
559
+ // secretC's range is never finalized, so it survives commit as a single-element pending array (contrast with
560
+ // secretA's multi-element shape).
561
+ await senderTaggingStore.storePendingIndexes(
562
+ [{ extendedSecret: secretC, lowestIndex: 1, highestIndex: 9 }],
563
+ txHashD,
564
+ jobId,
565
+ );
566
+
567
+ await senderTaggingStore.finalizePendingIndexes([txHashA], jobId);
568
+
569
+ await kvStore.transactionAsync(() => senderTaggingStore.commit(jobId));
570
+ },
571
+ snapshotStore: async kvStore => ({
572
+ pending_indexes: await snapshotMap(kvStore.openMap<string, Buffer>('pending_indexes')),
573
+ last_finalized_indexes: await snapshotMap(kvStore.openMap<string, number>('last_finalized_indexes')),
574
+ }),
575
+ },
576
+ ];
577
+
578
+ /**
579
+ * Pads an Fr array to `totalLength` with `Fr.ZERO`. Returns plain `Fr[]` rather than `Tuple<Fr, N>` so that callers
580
+ * with very large `totalLength` (e.g. `CONTRACT_CLASS_LOG_SIZE_IN_FIELDS = 3023`) don't trip TypeScript's recursive
581
+ * type instantiation depth limit on `Tuple<T, N>` — which is why we don't simply call `padArrayEnd` from foundation.
582
+ * Used because `ContractClassLogFields` and `PrivateLog` require fixed-length collections; populating only the leading
583
+ * slots is enough to detect reorders, while the trailing zeros pin each field's total width (a shrunk or grown size
584
+ * constant shifts the byte count and shows up in the snapshot diff).
585
+ */
586
+ function paddedFrs(leading: bigint[], totalLength: number): Fr[] {
587
+ const out = leading.map(p => new Fr(p));
588
+ while (out.length < totalLength) {
589
+ out.push(Fr.ZERO);
590
+ }
591
+ return out;
592
+ }
593
+
594
+ /**
595
+ * Builds a fully-populated `L2Block` with distinct values for every primitive field that appears in `toBuffer`.
596
+ * We use distinct values to make a snapshot diff sensitive to regressions of specific fields, and same-width reorders.
597
+ */
598
+ function buildL2Block(): L2Block {
599
+ const archive = new AppendOnlyTreeSnapshot(new Fr(101n), 103);
600
+ const header = new BlockHeader(
601
+ new AppendOnlyTreeSnapshot(new Fr(107n), 109),
602
+ new StateReference(
603
+ new AppendOnlyTreeSnapshot(new Fr(113n), 127),
604
+ new PartialStateReference(
605
+ new AppendOnlyTreeSnapshot(new Fr(131n), 137),
606
+ new AppendOnlyTreeSnapshot(new Fr(139n), 149),
607
+ new AppendOnlyTreeSnapshot(new Fr(151n), 157),
608
+ ),
609
+ ),
610
+ new Fr(163n),
611
+ new GlobalVariables(
612
+ new Fr(167n),
613
+ new Fr(173n),
614
+ BlockNumber(179),
615
+ SlotNumber(181),
616
+ 191n,
617
+ EthAddress.fromField(new Fr(193n)),
618
+ AztecAddress.fromBigInt(197n),
619
+ new GasFees(199n, 211n),
620
+ ),
621
+ new Fr(223n),
622
+ new Fr(227n),
623
+ );
624
+
625
+ const txEffect = new TxEffect(
626
+ RevertCode.REVERTED,
627
+ TxHash.fromBigInt(229n),
628
+ new Fr(233n),
629
+ [new Fr(239n)],
630
+ [new Fr(241n)],
631
+ [new Fr(251n)],
632
+ [new PublicDataWrite(new Fr(257n), new Fr(263n))],
633
+ [
634
+ new PrivateLog(
635
+ paddedFrs([269n, 271n, 277n], PRIVATE_LOG_SIZE_IN_FIELDS) as Tuple<Fr, typeof PRIVATE_LOG_SIZE_IN_FIELDS>,
636
+ 3,
637
+ ),
638
+ ],
639
+ [new PublicLog(AztecAddress.fromBigInt(281n), [new Fr(283n), new Fr(293n)])],
640
+ [
641
+ new ContractClassLog(
642
+ AztecAddress.fromBigInt(307n),
643
+ new ContractClassLogFields(paddedFrs([311n, 313n, 317n], CONTRACT_CLASS_LOG_SIZE_IN_FIELDS)),
644
+ 3,
645
+ ),
646
+ ],
647
+ );
648
+
649
+ return new L2Block(archive, header, new Body([txEffect]), CheckpointNumber(331), IndexWithinCheckpoint(337));
650
+ }
651
+
652
+ /**
653
+ * Builds a deterministic, hand-rolled `ContractArtifact` for the ContractStore schema test. Every collection field
654
+ * has at least one entry so that JSON serialization branches for non-empty arrays and records are exercised; values
655
+ * are picked to be distinguishable so a reorder or shape change of `ContractArtifact`/`FunctionAbi` is visible in
656
+ * the snapshot diff.
657
+ *
658
+ * Why not import a real noir-compiled artifact? Compiled artifacts embed noir-compiler output (error-type hashes,
659
+ * debug symbols, struct paths) that drifts across compiler versions and produces spurious schema diffs unrelated to
660
+ * PXE's on-disk layout.
661
+ */
662
+ function buildSchemaContractArtifact(): ContractArtifact {
663
+ return {
664
+ name: 'SchemaFixtureContract',
665
+ aztecVersion: 'schema-fixture-version',
666
+ functions: [
667
+ {
668
+ name: 'private_fn',
669
+ functionType: FunctionType.PRIVATE,
670
+ isOnlySelf: false,
671
+ isStatic: false,
672
+ isInitializer: true,
673
+ parameters: [
674
+ { name: 'first', type: { kind: 'field' }, visibility: 'private' },
675
+ { name: 'second', type: { kind: 'integer', sign: 'unsigned', width: 32 }, visibility: 'public' },
676
+ ],
677
+ returnTypes: [{ kind: 'boolean' }],
678
+ errorTypes: {
679
+ // Single entry. Exercises the non-empty `Record<string, AbiErrorType>` branch without depending on
680
+ // noir compiler output.
681
+ schema_test_error: { error_kind: 'string', string: 'fixed schema-test error' },
682
+ },
683
+ bytecode: Buffer.from([2, 3, 5, 7]),
684
+ debugSymbols: 'schema-fixture-debug',
685
+ },
686
+ ],
687
+ nonDispatchPublicFunctions: [
688
+ {
689
+ name: 'public_fn',
690
+ functionType: FunctionType.PUBLIC,
691
+ isOnlySelf: true,
692
+ isStatic: true,
693
+ isInitializer: false,
694
+ parameters: [],
695
+ returnTypes: [],
696
+ errorTypes: {},
697
+ },
698
+ ],
699
+ outputs: {
700
+ structs: { my_struct: [{ kind: 'field' }, { kind: 'boolean' }] },
701
+ globals: {},
702
+ },
703
+ storageLayout: { my_field: { slot: new Fr(11n) } },
704
+ fileMap: {
705
+ 1: {
706
+ source: 'schema fixture source',
707
+ path: 'src/schema_fixture.nr',
708
+ function_locations: [],
709
+ },
710
+ },
711
+ };
712
+ }