@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.
- package/dest/bin/check_oracle_version.js +43 -99
- package/dest/bin/index.d.ts +2 -0
- package/dest/bin/index.d.ts.map +1 -0
- package/dest/bin/index.js +1 -0
- package/dest/bin/oracle_version_helpers.d.ts +26 -0
- package/dest/bin/oracle_version_helpers.d.ts.map +1 -0
- package/dest/bin/oracle_version_helpers.js +93 -0
- package/dest/block_synchronizer/block_stream_source.d.ts +10 -0
- package/dest/block_synchronizer/block_stream_source.d.ts.map +1 -0
- package/dest/block_synchronizer/block_stream_source.js +62 -0
- package/dest/block_synchronizer/block_synchronizer.d.ts +9 -3
- package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
- package/dest/block_synchronizer/block_synchronizer.js +37 -11
- package/dest/config/index.d.ts +8 -2
- package/dest/config/index.d.ts.map +1 -1
- package/dest/config/index.js +13 -15
- package/dest/config/package_info.js +1 -1
- package/dest/contract_function_simulator/contract_function_simulator.d.ts +66 -29
- package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
- package/dest/contract_function_simulator/contract_function_simulator.js +216 -75
- package/dest/contract_function_simulator/ephemeral_array_service.d.ts +28 -0
- package/dest/contract_function_simulator/ephemeral_array_service.d.ts.map +1 -0
- package/dest/contract_function_simulator/ephemeral_array_service.js +78 -0
- package/dest/contract_function_simulator/execution_note_cache.d.ts +2 -2
- package/dest/contract_function_simulator/execution_note_cache.d.ts.map +1 -1
- package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +7 -11
- package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -1
- package/dest/contract_function_simulator/execution_tagging_index_cache.js +19 -15
- package/dest/contract_function_simulator/index.d.ts +14 -2
- package/dest/contract_function_simulator/index.d.ts.map +1 -1
- package/dest/contract_function_simulator/index.js +11 -0
- package/dest/contract_function_simulator/noir-structs/bounded_vec.d.ts +48 -0
- package/dest/contract_function_simulator/noir-structs/bounded_vec.d.ts.map +1 -0
- package/dest/contract_function_simulator/noir-structs/bounded_vec.js +45 -0
- package/dest/contract_function_simulator/noir-structs/ephemeral_array.d.ts +37 -0
- package/dest/contract_function_simulator/noir-structs/ephemeral_array.d.ts.map +1 -0
- package/dest/contract_function_simulator/noir-structs/ephemeral_array.js +59 -0
- package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +3 -4
- package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts.map +1 -1
- package/dest/contract_function_simulator/noir-structs/event_validation_request.js +8 -9
- package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts +13 -3
- package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts.map +1 -1
- package/dest/contract_function_simulator/noir-structs/log_retrieval_request.js +35 -4
- package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts +2 -2
- package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts.map +1 -1
- package/dest/contract_function_simulator/noir-structs/log_retrieval_response.js +2 -4
- package/dest/contract_function_simulator/noir-structs/note_data.d.ts +27 -0
- package/dest/contract_function_simulator/noir-structs/note_data.d.ts.map +1 -0
- package/dest/contract_function_simulator/noir-structs/note_data.js +3 -0
- package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +3 -5
- package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
- package/dest/contract_function_simulator/noir-structs/note_validation_request.js +6 -10
- package/dest/contract_function_simulator/noir-structs/option.d.ts +61 -0
- package/dest/contract_function_simulator/noir-structs/option.d.ts.map +1 -0
- package/dest/contract_function_simulator/noir-structs/option.js +62 -0
- package/dest/contract_function_simulator/noir-structs/provided_secret.d.ts +11 -0
- package/dest/contract_function_simulator/noir-structs/provided_secret.d.ts.map +1 -0
- package/dest/contract_function_simulator/noir-structs/provided_secret.js +24 -0
- package/dest/contract_function_simulator/oracle/interfaces.d.ts +16 -98
- package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/interfaces.js +2 -2
- package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts +2 -2
- package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/note_packing_utils.js +2 -2
- package/dest/contract_function_simulator/oracle/oracle.d.ts +75 -46
- package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/oracle.js +471 -275
- package/dest/contract_function_simulator/oracle/oracle_registry.d.ts +127 -0
- package/dest/contract_function_simulator/oracle/oracle_registry.d.ts.map +1 -0
- package/dest/contract_function_simulator/oracle/oracle_registry.js +786 -0
- package/dest/contract_function_simulator/oracle/oracle_type_mappings.d.ts +139 -0
- package/dest/contract_function_simulator/oracle/oracle_type_mappings.d.ts.map +1 -0
- package/dest/contract_function_simulator/oracle/oracle_type_mappings.js +560 -0
- package/dest/contract_function_simulator/oracle/private_execution.js +5 -3
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +68 -95
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/private_execution_oracle.js +141 -110
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +156 -76
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +450 -166
- package/dest/contract_function_simulator/pick_notes.d.ts +1 -1
- package/dest/contract_function_simulator/pick_notes.d.ts.map +1 -1
- package/dest/contract_function_simulator/pick_notes.js +20 -3
- package/dest/contract_function_simulator/proxied_contract_data_source.d.ts +1 -1
- package/dest/contract_function_simulator/proxied_contract_data_source.d.ts.map +1 -1
- package/dest/contract_function_simulator/proxied_contract_data_source.js +35 -64
- package/dest/contract_logging.d.ts +27 -0
- package/dest/contract_logging.d.ts.map +1 -0
- package/dest/contract_logging.js +38 -0
- package/dest/contract_sync/contract_sync_service.d.ts +42 -0
- package/dest/contract_sync/contract_sync_service.d.ts.map +1 -0
- package/dest/contract_sync/contract_sync_service.js +135 -0
- package/dest/contract_sync/helpers.d.ts +27 -0
- package/dest/contract_sync/helpers.d.ts.map +1 -0
- package/dest/contract_sync/{index.js → helpers.js} +16 -17
- package/dest/debug/pxe_debug_utils.d.ts +14 -15
- package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
- package/dest/debug/pxe_debug_utils.js +16 -21
- package/dest/entrypoints/client/bundle/index.d.ts +3 -1
- package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
- package/dest/entrypoints/client/bundle/index.js +2 -0
- package/dest/entrypoints/client/bundle/utils.d.ts +2 -2
- package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
- package/dest/entrypoints/client/bundle/utils.js +21 -5
- package/dest/entrypoints/client/lazy/index.d.ts +3 -1
- package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
- package/dest/entrypoints/client/lazy/index.js +2 -0
- package/dest/entrypoints/client/lazy/utils.d.ts +2 -2
- package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
- package/dest/entrypoints/client/lazy/utils.js +21 -5
- package/dest/entrypoints/pxe_creation_options.d.ts +9 -1
- package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
- package/dest/entrypoints/pxe_creation_options.js +3 -1
- package/dest/entrypoints/server/index.d.ts +5 -3
- package/dest/entrypoints/server/index.d.ts.map +1 -1
- package/dest/entrypoints/server/index.js +4 -2
- package/dest/entrypoints/server/utils.d.ts +4 -3
- package/dest/entrypoints/server/utils.d.ts.map +1 -1
- package/dest/entrypoints/server/utils.js +21 -5
- package/dest/events/event_service.d.ts +15 -6
- package/dest/events/event_service.d.ts.map +1 -1
- package/dest/events/event_service.js +44 -11
- package/dest/events/private_event_filter_validator.d.ts +3 -2
- package/dest/events/private_event_filter_validator.d.ts.map +1 -1
- package/dest/events/private_event_filter_validator.js +15 -0
- package/dest/hooks/authorize_utility_call.d.ts +41 -0
- package/dest/hooks/authorize_utility_call.d.ts.map +1 -0
- package/dest/hooks/authorize_utility_call.js +4 -0
- package/dest/hooks/execution_hooks.d.ts +42 -0
- package/dest/hooks/execution_hooks.d.ts.map +1 -0
- package/dest/hooks/execution_hooks.js +9 -0
- package/dest/hooks/index.d.ts +4 -0
- package/dest/hooks/index.d.ts.map +1 -0
- package/dest/hooks/index.js +1 -0
- package/dest/logs/log_service.d.ts +9 -8
- package/dest/logs/log_service.d.ts.map +1 -1
- package/dest/logs/log_service.js +131 -84
- package/dest/messages/message_context_service.d.ts +17 -0
- package/dest/messages/message_context_service.d.ts.map +1 -0
- package/dest/messages/message_context_service.js +55 -0
- package/dest/notes/note_service.d.ts +27 -5
- package/dest/notes/note_service.d.ts.map +1 -1
- package/dest/notes/note_service.js +83 -58
- package/dest/notes_filter.d.ts +24 -0
- package/dest/notes_filter.d.ts.map +1 -0
- package/dest/notes_filter.js +4 -0
- package/dest/oracle_version.d.ts +4 -3
- package/dest/oracle_version.d.ts.map +1 -1
- package/dest/oracle_version.js +20 -10
- package/dest/private_kernel/batch_planner.d.ts +47 -0
- package/dest/private_kernel/batch_planner.d.ts.map +1 -0
- package/dest/private_kernel/batch_planner.js +104 -0
- package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
- package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
- package/dest/private_kernel/hints/{compute_tx_include_by_timestamp.js → compute_tx_expiration_timestamp.js} +12 -12
- package/dest/private_kernel/hints/index.d.ts +1 -1
- package/dest/private_kernel/hints/index.js +1 -1
- package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +4 -3
- package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -1
- package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.js +130 -69
- package/dest/private_kernel/hints/test_utils.d.ts +122 -0
- package/dest/private_kernel/hints/test_utils.d.ts.map +1 -0
- package/dest/private_kernel/hints/test_utils.js +202 -0
- package/dest/private_kernel/private_kernel_execution_prover.d.ts +6 -2
- package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
- package/dest/private_kernel/private_kernel_execution_prover.js +166 -65
- package/dest/private_kernel/private_kernel_oracle.d.ts +15 -11
- package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
- package/dest/private_kernel/private_kernel_oracle.js +31 -25
- package/dest/pxe.d.ts +120 -24
- package/dest/pxe.d.ts.map +1 -1
- package/dest/pxe.js +231 -134
- package/dest/storage/anchor_block_store/anchor_block_store.js +1 -1
- package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.d.ts +42 -0
- package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.d.ts.map +1 -0
- package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.js +93 -0
- package/dest/storage/backwards_compatibility_tests/schema_tests.d.ts +15 -0
- package/dest/storage/backwards_compatibility_tests/schema_tests.d.ts.map +1 -0
- package/dest/storage/backwards_compatibility_tests/schema_tests.js +591 -0
- package/dest/storage/backwards_compatibility_tests/store_spy.d.ts +19 -0
- package/dest/storage/backwards_compatibility_tests/store_spy.d.ts.map +1 -0
- package/dest/storage/backwards_compatibility_tests/store_spy.js +63 -0
- package/dest/storage/capsule_store/capsule_service.d.ts +21 -0
- package/dest/storage/capsule_store/capsule_service.d.ts.map +1 -0
- package/dest/storage/capsule_store/capsule_service.js +50 -0
- package/dest/storage/capsule_store/capsule_store.d.ts +9 -9
- package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -1
- package/dest/storage/capsule_store/capsule_store.js +36 -28
- package/dest/storage/capsule_store/index.d.ts +2 -1
- package/dest/storage/capsule_store/index.d.ts.map +1 -1
- package/dest/storage/capsule_store/index.js +1 -0
- package/dest/storage/contract_store/contract_store.d.ts +42 -15
- package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
- package/dest/storage/contract_store/contract_store.js +146 -87
- package/dest/storage/metadata.d.ts +1 -1
- package/dest/storage/metadata.js +1 -1
- package/dest/storage/note_store/note_store.d.ts +3 -3
- package/dest/storage/note_store/note_store.d.ts.map +1 -1
- package/dest/storage/note_store/note_store.js +6 -4
- package/dest/storage/open_pxe_stores.d.ts +33 -0
- package/dest/storage/open_pxe_stores.d.ts.map +1 -0
- package/dest/storage/open_pxe_stores.js +27 -0
- package/dest/storage/private_event_store/private_event_store.d.ts +1 -1
- package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -1
- package/dest/storage/private_event_store/private_event_store.js +3 -0
- package/dest/storage/private_event_store/stored_private_event.js +1 -1
- package/dest/storage/tagging_store/recipient_tagging_store.d.ts +6 -6
- package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
- package/dest/storage/tagging_store/sender_tagging_store.d.ts +29 -28
- package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
- package/dest/storage/tagging_store/sender_tagging_store.js +141 -115
- package/dest/tagging/get_all_logs_by_tags.d.ts +34 -10
- package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -1
- package/dest/tagging/get_all_logs_by_tags.js +45 -32
- package/dest/tagging/index.d.ts +6 -5
- package/dest/tagging/index.d.ts.map +1 -1
- package/dest/tagging/index.js +4 -3
- package/dest/tagging/persist_sender_tagging_index_ranges.d.ts +29 -0
- package/dest/tagging/persist_sender_tagging_index_ranges.d.ts.map +1 -0
- package/dest/tagging/persist_sender_tagging_index_ranges.js +42 -0
- package/dest/tagging/recipient_sync/sync_tagged_private_logs.d.ts +56 -0
- package/dest/tagging/recipient_sync/sync_tagged_private_logs.d.ts.map +1 -0
- package/dest/tagging/recipient_sync/sync_tagged_private_logs.js +163 -0
- package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts +3 -3
- package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts.map +1 -1
- package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +2 -2
- package/dest/tagging/reconcile_tagging_index_ranges.d.ts +36 -0
- package/dest/tagging/reconcile_tagging_index_ranges.d.ts.map +1 -0
- package/dest/tagging/reconcile_tagging_index_ranges.js +74 -0
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +4 -9
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +32 -14
- package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +13 -7
- package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -1
- package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +41 -10
- package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +5 -7
- package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -1
- package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +37 -25
- package/package.json +29 -17
- package/src/bin/check_oracle_version.ts +49 -122
- package/src/bin/index.ts +1 -0
- package/src/bin/oracle_version_helpers.ts +121 -0
- package/src/block_synchronizer/block_stream_source.ts +81 -0
- package/src/block_synchronizer/block_synchronizer.ts +39 -11
- package/src/config/index.ts +15 -9
- package/src/config/package_info.ts +1 -1
- package/src/contract_function_simulator/contract_function_simulator.ts +391 -136
- package/src/contract_function_simulator/ephemeral_array_service.ts +110 -0
- package/src/contract_function_simulator/execution_note_cache.ts +1 -1
- package/src/contract_function_simulator/execution_tagging_index_cache.ts +19 -18
- package/src/contract_function_simulator/index.ts +51 -1
- package/src/contract_function_simulator/noir-structs/bounded_vec.ts +55 -0
- package/src/contract_function_simulator/noir-structs/ephemeral_array.ts +66 -0
- package/src/contract_function_simulator/noir-structs/event_validation_request.ts +9 -8
- package/src/contract_function_simulator/noir-structs/log_retrieval_request.ts +36 -3
- package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +2 -5
- package/src/contract_function_simulator/noir-structs/note_data.ts +27 -0
- package/src/contract_function_simulator/noir-structs/note_validation_request.ts +4 -9
- package/src/contract_function_simulator/noir-structs/option.ts +69 -0
- package/src/contract_function_simulator/noir-structs/provided_secret.ts +27 -0
- package/src/contract_function_simulator/oracle/interfaces.ts +12 -176
- package/src/contract_function_simulator/oracle/note_packing_utils.ts +3 -3
- package/src/contract_function_simulator/oracle/oracle.ts +564 -473
- package/src/contract_function_simulator/oracle/oracle_registry.ts +585 -0
- package/src/contract_function_simulator/oracle/oracle_type_mappings.ts +553 -0
- package/src/contract_function_simulator/oracle/private_execution.ts +4 -4
- package/src/contract_function_simulator/oracle/private_execution_oracle.ts +173 -205
- package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +664 -245
- package/src/contract_function_simulator/pick_notes.ts +22 -3
- package/src/contract_function_simulator/proxied_contract_data_source.ts +41 -64
- package/src/contract_logging.ts +52 -0
- package/src/contract_sync/contract_sync_service.ts +189 -0
- package/src/contract_sync/{index.ts → helpers.ts} +17 -29
- package/src/debug/pxe_debug_utils.ts +47 -25
- package/src/entrypoints/client/bundle/index.ts +2 -0
- package/src/entrypoints/client/bundle/utils.ts +19 -6
- package/src/entrypoints/client/lazy/index.ts +2 -0
- package/src/entrypoints/client/lazy/utils.ts +19 -6
- package/src/entrypoints/pxe_creation_options.ts +14 -0
- package/src/entrypoints/server/index.ts +4 -2
- package/src/entrypoints/server/utils.ts +22 -13
- package/src/events/event_service.ts +69 -21
- package/src/events/private_event_filter_validator.ts +21 -1
- package/src/hooks/authorize_utility_call.ts +44 -0
- package/src/hooks/execution_hooks.ts +48 -0
- package/src/hooks/index.ts +7 -0
- package/src/logs/log_service.ts +162 -145
- package/src/messages/message_context_service.ts +62 -0
- package/src/notes/note_service.ts +120 -85
- package/src/notes_filter.ts +24 -0
- package/src/oracle_version.ts +20 -10
- package/src/private_kernel/batch_planner.ts +169 -0
- package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
- package/src/private_kernel/hints/index.ts +1 -1
- package/src/private_kernel/hints/private_kernel_reset_private_inputs_builder.ts +165 -118
- package/src/private_kernel/hints/test_utils.ts +318 -0
- package/src/private_kernel/private_kernel_execution_prover.ts +254 -89
- package/src/private_kernel/private_kernel_oracle.ts +42 -32
- package/src/pxe.ts +416 -181
- package/src/storage/anchor_block_store/anchor_block_store.ts +1 -1
- package/src/storage/backwards_compatibility_tests/__snapshots__/AddressStore.json +22 -0
- package/src/storage/backwards_compatibility_tests/__snapshots__/AnchorBlockStore.json +3 -0
- package/src/storage/backwards_compatibility_tests/__snapshots__/CapsuleStore.json +16 -0
- package/src/storage/backwards_compatibility_tests/__snapshots__/ContractStore.json +28 -0
- package/src/storage/backwards_compatibility_tests/__snapshots__/KeyStore.json +52 -0
- package/src/storage/backwards_compatibility_tests/__snapshots__/L2TipsKVStore.json +46 -0
- package/src/storage/backwards_compatibility_tests/__snapshots__/NoteStore.json +36 -0
- package/src/storage/backwards_compatibility_tests/__snapshots__/PrivateEventStore.json +44 -0
- package/src/storage/backwards_compatibility_tests/__snapshots__/RecipientTaggingStore.json +18 -0
- package/src/storage/backwards_compatibility_tests/__snapshots__/SenderAddressBookStore.json +16 -0
- package/src/storage/backwards_compatibility_tests/__snapshots__/SenderTaggingStore.json +22 -0
- package/src/storage/backwards_compatibility_tests/__snapshots__/opened_stores.json +97 -0
- package/src/storage/backwards_compatibility_tests/kv_store_snapshot.ts +122 -0
- package/src/storage/backwards_compatibility_tests/schema_tests.ts +712 -0
- package/src/storage/backwards_compatibility_tests/store_spy.ts +73 -0
- package/src/storage/capsule_store/capsule_service.ts +90 -0
- package/src/storage/capsule_store/capsule_store.ts +44 -26
- package/src/storage/capsule_store/index.ts +1 -0
- package/src/storage/contract_store/contract_store.ts +182 -104
- package/src/storage/metadata.ts +1 -1
- package/src/storage/note_store/note_store.ts +9 -5
- package/src/storage/open_pxe_stores.ts +49 -0
- package/src/storage/private_event_store/private_event_store.ts +4 -0
- package/src/storage/private_event_store/stored_private_event.ts +1 -1
- package/src/storage/tagging_store/recipient_tagging_store.ts +5 -5
- package/src/storage/tagging_store/sender_tagging_store.ts +185 -138
- package/src/tagging/get_all_logs_by_tags.ts +87 -35
- package/src/tagging/index.ts +5 -4
- package/src/tagging/persist_sender_tagging_index_ranges.ts +57 -0
- package/src/tagging/recipient_sync/sync_tagged_private_logs.ts +240 -0
- package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +4 -4
- package/src/tagging/reconcile_tagging_index_ranges.ts +102 -0
- package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +52 -17
- package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +44 -14
- package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +27 -27
- package/dest/contract_sync/index.d.ts +0 -23
- package/dest/contract_sync/index.d.ts.map +0 -1
- package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts +0 -4
- package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts.map +0 -1
- package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +0 -15
- package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +0 -1
- package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +0 -99
- package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +0 -15
- package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +0 -1
- package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +0 -32
- package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +0 -143
- 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
|
+
}
|