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