@aztec/pxe 0.0.1-commit.96bb3f7 → 0.0.1-commit.993d240
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.d.ts +12 -2
- package/dest/bin/check_oracle_version.d.ts.map +1 -1
- package/dest/bin/check_oracle_version.js +32 -26
- 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/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 +16 -6
- package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
- package/dest/block_synchronizer/block_synchronizer.js +94 -23
- package/dest/config/index.d.ts +10 -2
- package/dest/config/index.d.ts.map +1 -1
- package/dest/config/index.js +17 -2
- package/dest/config/package_info.js +1 -1
- package/dest/contract_function_simulator/benchmarked_node.d.ts +9 -0
- package/dest/contract_function_simulator/benchmarked_node.d.ts.map +1 -0
- package/dest/contract_function_simulator/benchmarked_node.js +77 -0
- package/dest/contract_function_simulator/contract_function_simulator.d.ts +69 -36
- package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
- package/dest/contract_function_simulator/contract_function_simulator.js +240 -91
- 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 +18 -9
- package/dest/contract_function_simulator/execution_note_cache.d.ts.map +1 -1
- package/dest/contract_function_simulator/execution_note_cache.js +45 -28
- 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 +5 -2
- package/dest/contract_function_simulator/index.d.ts.map +1 -1
- package/dest/contract_function_simulator/index.js +4 -1
- 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/event_validation_request.d.ts +5 -7
- 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 +9 -10
- 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_validation_request.d.ts +5 -8
- 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 +7 -11
- 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/utility_context.d.ts +4 -10
- package/dest/contract_function_simulator/noir-structs/utility_context.d.ts.map +1 -1
- package/dest/contract_function_simulator/noir-structs/utility_context.js +7 -18
- package/dest/contract_function_simulator/oracle/interfaces.d.ts +70 -50
- package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts +3 -1
- package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts +7 -7
- package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/note_packing_utils.js +10 -10
- package/dest/contract_function_simulator/oracle/oracle.d.ts +74 -43
- package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/oracle.js +471 -264
- package/dest/contract_function_simulator/oracle/oracle_registry.d.ts +147 -0
- package/dest/contract_function_simulator/oracle/oracle_registry.d.ts.map +1 -0
- package/dest/contract_function_simulator/oracle/oracle_registry.js +1199 -0
- package/dest/contract_function_simulator/oracle/private_execution.d.ts +2 -26
- package/dest/contract_function_simulator/oracle/private_execution.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/private_execution.js +5 -38
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +74 -91
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/private_execution_oracle.js +164 -110
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +156 -78
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +459 -186
- 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/helpers.js +53 -0
- package/dest/debug/pxe_debug_utils.d.ts +19 -10
- package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
- package/dest/debug/pxe_debug_utils.js +22 -17
- 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 +33 -11
- 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 +3 -3
- package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
- package/dest/entrypoints/client/lazy/utils.js +34 -12
- package/dest/entrypoints/pxe_creation_options.d.ts +11 -2
- 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 +6 -2
- package/dest/entrypoints/server/index.d.ts.map +1 -1
- package/dest/entrypoints/server/index.js +5 -1
- 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 +40 -13
- package/dest/events/event_service.d.ts +17 -8
- package/dest/events/event_service.d.ts.map +1 -1
- package/dest/events/event_service.js +58 -28
- package/dest/events/private_event_filter_validator.d.ts +6 -5
- package/dest/events/private_event_filter_validator.d.ts.map +1 -1
- package/dest/events/private_event_filter_validator.js +20 -6
- 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/job_coordinator/job_coordinator.d.ts +3 -2
- package/dest/job_coordinator/job_coordinator.d.ts.map +1 -1
- package/dest/job_coordinator/job_coordinator.js +3 -2
- package/dest/logs/log_service.d.ts +13 -10
- package/dest/logs/log_service.d.ts.map +1 -1
- package/dest/logs/log_service.js +132 -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 +38 -0
- package/dest/notes/note_service.d.ts +31 -9
- package/dest/notes/note_service.d.ts.map +1 -1
- package/dest/notes/note_service.js +97 -77
- 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 -9
- 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 +3 -3
- package/dest/private_kernel/hints/index.d.ts.map +1 -1
- package/dest/private_kernel/hints/index.js +2 -2
- package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +29 -0
- package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -0
- package/dest/private_kernel/hints/{build_private_kernel_reset_private_inputs.js → private_kernel_reset_private_inputs_builder.js} +141 -74
- 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 +7 -2
- package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
- package/dest/private_kernel/private_kernel_execution_prover.js +168 -67
- package/dest/private_kernel/private_kernel_oracle.d.ts +28 -29
- package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
- package/dest/private_kernel/private_kernel_oracle.js +96 -2
- package/dest/pxe.d.ts +126 -59
- package/dest/pxe.d.ts.map +1 -1
- package/dest/pxe.js +257 -200
- package/dest/storage/address_store/address_store.d.ts +1 -1
- package/dest/storage/address_store/address_store.d.ts.map +1 -1
- package/dest/storage/address_store/address_store.js +12 -11
- package/dest/storage/anchor_block_store/anchor_block_store.d.ts +9 -1
- package/dest/storage/anchor_block_store/anchor_block_store.d.ts.map +1 -1
- package/dest/storage/anchor_block_store/anchor_block_store.js +9 -2
- 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 +25 -10
- package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -1
- package/dest/storage/capsule_store/capsule_store.js +143 -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 -16
- package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
- package/dest/storage/contract_store/contract_store.js +158 -102
- package/dest/storage/metadata.d.ts +1 -1
- package/dest/storage/metadata.js +1 -1
- package/dest/storage/note_store/note_store.d.ts +50 -51
- package/dest/storage/note_store/note_store.d.ts.map +1 -1
- package/dest/storage/note_store/note_store.js +284 -263
- package/dest/storage/note_store/stored_note.d.ts +16 -0
- package/dest/storage/note_store/stored_note.d.ts.map +1 -0
- package/dest/storage/note_store/stored_note.js +43 -0
- 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 +43 -8
- package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -1
- package/dest/storage/private_event_store/private_event_store.js +229 -111
- package/dest/storage/private_event_store/stored_private_event.d.ts +23 -0
- package/dest/storage/private_event_store/stored_private_event.d.ts.map +1 -0
- package/dest/storage/private_event_store/stored_private_event.js +56 -0
- package/dest/storage/tagging_store/recipient_tagging_store.d.ts +16 -9
- package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
- package/dest/storage/tagging_store/recipient_tagging_store.js +88 -19
- package/dest/storage/tagging_store/sender_address_book_store.d.ts +1 -1
- package/dest/storage/tagging_store/sender_address_book_store.d.ts.map +1 -1
- package/dest/storage/tagging_store/sender_address_book_store.js +20 -14
- package/dest/storage/tagging_store/sender_tagging_store.d.ts +43 -32
- package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
- package/dest/storage/tagging_store/sender_tagging_store.js +300 -122
- package/dest/tagging/get_all_logs_by_tags.d.ts +48 -0
- package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -0
- package/dest/tagging/get_all_logs_by_tags.js +59 -0
- package/dest/tagging/index.d.ts +7 -5
- package/dest/tagging/index.d.ts.map +1 -1
- package/dest/tagging/index.js +5 -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 +5 -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 +34 -18
- 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 +44 -16
- package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +8 -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 +44 -27
- package/package.json +31 -19
- package/src/bin/check_oracle_version.ts +42 -31
- package/src/bin/index.ts +1 -0
- package/src/block_synchronizer/block_stream_source.ts +81 -0
- package/src/block_synchronizer/block_synchronizer.ts +116 -36
- package/src/config/index.ts +21 -1
- package/src/config/package_info.ts +1 -1
- package/src/contract_function_simulator/benchmarked_node.ts +103 -0
- package/src/contract_function_simulator/contract_function_simulator.ts +417 -156
- package/src/contract_function_simulator/ephemeral_array_service.ts +110 -0
- package/src/contract_function_simulator/execution_note_cache.ts +44 -25
- package/src/contract_function_simulator/execution_tagging_index_cache.ts +19 -18
- package/src/contract_function_simulator/index.ts +4 -1
- package/src/contract_function_simulator/noir-structs/bounded_vec.ts +55 -0
- package/src/contract_function_simulator/noir-structs/event_validation_request.ts +11 -10
- 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_validation_request.ts +6 -11
- package/src/contract_function_simulator/noir-structs/option.ts +69 -0
- package/src/contract_function_simulator/noir-structs/utility_context.ts +6 -25
- package/src/contract_function_simulator/oracle/interfaces.ts +93 -70
- package/src/contract_function_simulator/oracle/note_packing_utils.ts +13 -13
- package/src/contract_function_simulator/oracle/oracle.ts +567 -461
- package/src/contract_function_simulator/oracle/oracle_registry.ts +904 -0
- package/src/contract_function_simulator/oracle/private_execution.ts +5 -71
- package/src/contract_function_simulator/oracle/private_execution_oracle.ts +213 -209
- package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +657 -254
- 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/helpers.ts +86 -0
- package/src/debug/pxe_debug_utils.ts +55 -18
- package/src/entrypoints/client/bundle/index.ts +2 -0
- package/src/entrypoints/client/bundle/utils.ts +26 -20
- package/src/entrypoints/client/lazy/index.ts +2 -0
- package/src/entrypoints/client/lazy/utils.ts +28 -21
- package/src/entrypoints/pxe_creation_options.ts +16 -1
- package/src/entrypoints/server/index.ts +5 -1
- package/src/entrypoints/server/utils.ts +37 -32
- package/src/events/event_service.ts +79 -39
- package/src/events/private_event_filter_validator.ts +23 -5
- 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/job_coordinator/job_coordinator.ts +4 -3
- package/src/logs/log_service.ts +171 -141
- package/src/messages/message_context_service.ts +45 -0
- package/src/notes/note_service.ts +137 -107
- package/src/notes_filter.ts +24 -0
- package/src/oracle_version.ts +20 -9
- 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 +2 -2
- package/src/private_kernel/hints/{build_private_kernel_reset_private_inputs.ts → private_kernel_reset_private_inputs_builder.ts} +196 -137
- package/src/private_kernel/hints/test_utils.ts +318 -0
- package/src/private_kernel/private_kernel_execution_prover.ts +261 -93
- package/src/private_kernel/private_kernel_oracle.ts +129 -40
- package/src/pxe.ts +467 -273
- package/src/storage/address_store/address_store.ts +15 -15
- package/src/storage/anchor_block_store/anchor_block_store.ts +9 -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 +183 -29
- package/src/storage/capsule_store/index.ts +1 -0
- package/src/storage/contract_store/contract_store.ts +194 -125
- package/src/storage/metadata.ts +1 -1
- package/src/storage/note_store/note_store.ts +323 -320
- package/src/storage/note_store/stored_note.ts +48 -0
- package/src/storage/open_pxe_stores.ts +49 -0
- package/src/storage/private_event_store/private_event_store.ts +296 -124
- package/src/storage/private_event_store/stored_private_event.ts +73 -0
- package/src/storage/tagging_store/recipient_tagging_store.ts +107 -21
- package/src/storage/tagging_store/sender_address_book_store.ts +20 -14
- package/src/storage/tagging_store/sender_tagging_store.ts +366 -134
- package/src/tagging/get_all_logs_by_tags.ts +120 -0
- package/src/tagging/index.ts +6 -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 +59 -21
- package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +47 -29
- package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +41 -29
- package/dest/contract_function_simulator/proxied_node.d.ts +0 -9
- package/dest/contract_function_simulator/proxied_node.d.ts.map +0 -1
- package/dest/contract_function_simulator/proxied_node.js +0 -27
- package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts +0 -28
- package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.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/private_kernel/private_kernel_oracle_impl.d.ts +0 -46
- package/dest/private_kernel/private_kernel_oracle_impl.d.ts.map +0 -1
- package/dest/private_kernel/private_kernel_oracle_impl.js +0 -85
- package/dest/public_storage/public_storage_service.d.ts +0 -24
- package/dest/public_storage/public_storage_service.d.ts.map +0 -1
- package/dest/public_storage/public_storage_service.js +0 -26
- package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +0 -14
- 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 -14
- 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 -29
- package/dest/tree_membership/tree_membership_service.d.ts +0 -52
- package/dest/tree_membership/tree_membership_service.d.ts.map +0 -1
- package/dest/tree_membership/tree_membership_service.js +0 -84
- package/src/contract_function_simulator/proxied_node.ts +0 -33
- package/src/private_kernel/private_kernel_oracle_impl.ts +0 -127
- package/src/public_storage/public_storage_service.ts +0 -33
- package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +0 -132
- package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +0 -43
- package/src/tree_membership/tree_membership_service.ts +0 -112
|
@@ -1,13 +1,12 @@
|
|
|
1
1
|
import type { FUNCTION_TREE_HEIGHT } from '@aztec/constants';
|
|
2
|
-
import
|
|
2
|
+
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
3
3
|
import { toArray } from '@aztec/foundation/iterable';
|
|
4
|
+
import { BufferReader, numToUInt8, serializeToBuffer } from '@aztec/foundation/serialize';
|
|
4
5
|
import type { MembershipWitness } from '@aztec/foundation/trees';
|
|
5
6
|
import type { AztecAsyncKVStore, AztecAsyncMap } from '@aztec/kv-store';
|
|
6
|
-
import { isProtocolContract } from '@aztec/protocol-contracts';
|
|
7
7
|
import {
|
|
8
8
|
type ContractArtifact,
|
|
9
9
|
type FunctionAbi,
|
|
10
|
-
type FunctionArtifact,
|
|
11
10
|
type FunctionArtifactWithContractName,
|
|
12
11
|
FunctionCall,
|
|
13
12
|
type FunctionDebugMetadata,
|
|
@@ -16,11 +15,14 @@ import {
|
|
|
16
15
|
contractArtifactFromBuffer,
|
|
17
16
|
contractArtifactToBuffer,
|
|
18
17
|
encodeArguments,
|
|
18
|
+
findFunctionAbiBySelector,
|
|
19
|
+
findFunctionArtifactBySelector,
|
|
19
20
|
getFunctionDebugMetadata,
|
|
20
21
|
} from '@aztec/stdlib/abi';
|
|
21
22
|
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
22
23
|
import {
|
|
23
|
-
type
|
|
24
|
+
type ContractClassIdPreimage,
|
|
25
|
+
type ContractClassWithId,
|
|
24
26
|
type ContractInstanceWithAddress,
|
|
25
27
|
SerializableContractInstance,
|
|
26
28
|
getContractClassFromArtifact,
|
|
@@ -28,6 +30,68 @@ import {
|
|
|
28
30
|
|
|
29
31
|
import { PrivateFunctionsTree } from './private_functions_tree.js';
|
|
30
32
|
|
|
33
|
+
const VERSION = 1 as const;
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* All contract class data except the large packedBytecode.
|
|
37
|
+
* The expensive data from the ContractClass is precomputed and stored in this format to avoid redundant hashing.
|
|
38
|
+
* Since we have to store the artifacts anyway, the final ContractClass is reconstructed by combining this data
|
|
39
|
+
* with the packedBytecode obtained from the former. That way we can have quick class lookups without wasted storage.
|
|
40
|
+
*/
|
|
41
|
+
export class SerializableContractClassData {
|
|
42
|
+
public readonly version = VERSION;
|
|
43
|
+
public readonly id: Fr;
|
|
44
|
+
public readonly artifactHash: Fr;
|
|
45
|
+
public readonly privateFunctionsRoot: Fr;
|
|
46
|
+
public readonly publicBytecodeCommitment: Fr;
|
|
47
|
+
public readonly privateFunctions: { selector: FunctionSelector; vkHash: Fr }[];
|
|
48
|
+
|
|
49
|
+
constructor(
|
|
50
|
+
data: ContractClassIdPreimage & {
|
|
51
|
+
id: Fr;
|
|
52
|
+
privateFunctions: { selector: FunctionSelector; vkHash: Fr }[];
|
|
53
|
+
},
|
|
54
|
+
) {
|
|
55
|
+
this.id = data.id;
|
|
56
|
+
this.artifactHash = data.artifactHash;
|
|
57
|
+
this.privateFunctionsRoot = data.privateFunctionsRoot;
|
|
58
|
+
this.publicBytecodeCommitment = data.publicBytecodeCommitment;
|
|
59
|
+
this.privateFunctions = data.privateFunctions;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
toBuffer(): Buffer {
|
|
63
|
+
return serializeToBuffer(
|
|
64
|
+
numToUInt8(this.version),
|
|
65
|
+
this.id,
|
|
66
|
+
this.artifactHash,
|
|
67
|
+
this.privateFunctionsRoot,
|
|
68
|
+
this.publicBytecodeCommitment,
|
|
69
|
+
this.privateFunctions.length,
|
|
70
|
+
...this.privateFunctions.map(fn => serializeToBuffer(fn.selector, fn.vkHash)),
|
|
71
|
+
);
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
static fromBuffer(bufferOrReader: Buffer | BufferReader): SerializableContractClassData {
|
|
75
|
+
const reader = BufferReader.asReader(bufferOrReader);
|
|
76
|
+
const version = reader.readUInt8();
|
|
77
|
+
if (version !== VERSION) {
|
|
78
|
+
throw new Error(`Unexpected contract class data version ${version}`);
|
|
79
|
+
}
|
|
80
|
+
return new SerializableContractClassData({
|
|
81
|
+
id: reader.readObject(Fr),
|
|
82
|
+
artifactHash: reader.readObject(Fr),
|
|
83
|
+
privateFunctionsRoot: reader.readObject(Fr),
|
|
84
|
+
publicBytecodeCommitment: reader.readObject(Fr),
|
|
85
|
+
privateFunctions: reader.readVector({
|
|
86
|
+
fromBuffer: (r: BufferReader) => ({
|
|
87
|
+
selector: r.readObject(FunctionSelector),
|
|
88
|
+
vkHash: r.readObject(Fr),
|
|
89
|
+
}),
|
|
90
|
+
}),
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
|
|
31
95
|
/**
|
|
32
96
|
* ContractStore serves as a data manager and retriever for Aztec.nr contracts.
|
|
33
97
|
* It provides methods to obtain contract addresses, function ABI, bytecode, and membership witnesses
|
|
@@ -40,71 +104,95 @@ export class ContractStore {
|
|
|
40
104
|
// TODO: Update it to be LRU cache so that it doesn't keep all the data all the time.
|
|
41
105
|
#privateFunctionTrees: Map<string, PrivateFunctionsTree> = new Map();
|
|
42
106
|
|
|
43
|
-
/**
|
|
107
|
+
/**
|
|
108
|
+
* In-memory cache of deserialized ContractArtifact objects, keyed by class id string.
|
|
109
|
+
* Avoids repeated LMDB reads + JSON.parse + Zod validation on every oracle call.
|
|
110
|
+
* Artifacts are large but immutable after registration — safe to cache for the lifetime of the store.
|
|
111
|
+
*/
|
|
112
|
+
// TODO: Update it to be LRU cache so that it doesn't keep all the data all the time.
|
|
113
|
+
#contractArtifactCache: Map<string, ContractArtifact> = new Map();
|
|
114
|
+
|
|
115
|
+
/** Map from contract address to contract class id (avoids KV round-trip on hot path). */
|
|
44
116
|
#contractClassIdMap: Map<string, Fr> = new Map();
|
|
45
117
|
|
|
118
|
+
#store: AztecAsyncKVStore;
|
|
46
119
|
#contractArtifacts: AztecAsyncMap<string, Buffer>;
|
|
120
|
+
#contractClassData: AztecAsyncMap<string, Buffer>;
|
|
47
121
|
#contractInstances: AztecAsyncMap<string, Buffer>;
|
|
48
122
|
|
|
49
123
|
constructor(store: AztecAsyncKVStore) {
|
|
124
|
+
this.#store = store;
|
|
50
125
|
this.#contractArtifacts = store.openMap('contract_artifacts');
|
|
126
|
+
this.#contractClassData = store.openMap('contract_classes');
|
|
51
127
|
this.#contractInstances = store.openMap('contracts_instances');
|
|
52
128
|
}
|
|
53
129
|
|
|
54
130
|
// Setters
|
|
55
131
|
|
|
56
|
-
|
|
132
|
+
/**
|
|
133
|
+
* Registers a new contract artifact and its corresponding class data.
|
|
134
|
+
* IMPORTANT: This method does not verify that the provided artifact matches the class data or that the class id matches the artifact.
|
|
135
|
+
* It is the caller's responsibility to ensure the consistency and correctness of the provided data.
|
|
136
|
+
* This is done to avoid redundant, expensive contract class computations
|
|
137
|
+
*/
|
|
138
|
+
public async addContractArtifact(
|
|
139
|
+
contract: ContractArtifact,
|
|
140
|
+
contractClassWithIdAndPreimage?: ContractClassWithId & ContractClassIdPreimage,
|
|
141
|
+
): Promise<Fr> {
|
|
142
|
+
const contractClass = contractClassWithIdAndPreimage ?? (await getContractClassFromArtifact(contract));
|
|
143
|
+
const key = contractClass.id.toString();
|
|
144
|
+
|
|
145
|
+
if (this.#contractArtifactCache.has(key)) {
|
|
146
|
+
return contractClass.id;
|
|
147
|
+
}
|
|
148
|
+
|
|
57
149
|
const privateFunctions = contract.functions.filter(
|
|
58
150
|
functionArtifact => functionArtifact.functionType === FunctionType.PRIVATE,
|
|
59
151
|
);
|
|
60
|
-
|
|
61
152
|
const privateSelectors = await Promise.all(
|
|
62
|
-
privateFunctions.map(async
|
|
63
|
-
(
|
|
64
|
-
await FunctionSelector.fromNameAndParameters(privateFunctionArtifact.name, privateFunctionArtifact.parameters)
|
|
65
|
-
).toString(),
|
|
153
|
+
privateFunctions.map(async fn =>
|
|
154
|
+
(await FunctionSelector.fromNameAndParameters(fn.name, fn.parameters)).toString(),
|
|
66
155
|
),
|
|
67
156
|
);
|
|
68
|
-
|
|
69
157
|
if (privateSelectors.length !== new Set(privateSelectors).size) {
|
|
70
158
|
throw new Error('Repeated function selectors of private functions');
|
|
71
159
|
}
|
|
72
160
|
|
|
73
|
-
|
|
161
|
+
this.#contractArtifactCache.set(key, contract);
|
|
162
|
+
|
|
163
|
+
await this.#store.transactionAsync(async () => {
|
|
164
|
+
await this.#contractArtifacts.set(key, contractArtifactToBuffer(contract));
|
|
165
|
+
await this.#contractClassData.set(key, new SerializableContractClassData(contractClass).toBuffer());
|
|
166
|
+
});
|
|
167
|
+
|
|
168
|
+
return contractClass.id;
|
|
74
169
|
}
|
|
75
170
|
|
|
76
171
|
async addContractInstance(contract: ContractInstanceWithAddress): Promise<void> {
|
|
77
|
-
this.#
|
|
172
|
+
await this.#store.transactionAsync(async () => {
|
|
173
|
+
await this.#contractInstances.set(
|
|
174
|
+
contract.address.toString(),
|
|
175
|
+
new SerializableContractInstance(contract).toBuffer(),
|
|
176
|
+
);
|
|
177
|
+
});
|
|
78
178
|
|
|
79
|
-
|
|
80
|
-
contract.address.toString(),
|
|
81
|
-
new SerializableContractInstance(contract).toBuffer(),
|
|
82
|
-
);
|
|
179
|
+
this.#contractClassIdMap.set(contract.address.toString(), contract.currentContractClassId);
|
|
83
180
|
}
|
|
84
181
|
|
|
85
182
|
// Private getters
|
|
86
183
|
|
|
87
184
|
async #getContractClassId(contractAddress: AztecAddress): Promise<Fr | undefined> {
|
|
88
|
-
|
|
185
|
+
const key = contractAddress.toString();
|
|
186
|
+
if (!this.#contractClassIdMap.has(key)) {
|
|
89
187
|
const instance = await this.getContractInstance(contractAddress);
|
|
90
188
|
if (!instance) {
|
|
91
189
|
return;
|
|
92
190
|
}
|
|
93
|
-
this.#contractClassIdMap.set(
|
|
191
|
+
this.#contractClassIdMap.set(key, instance.currentContractClassId);
|
|
94
192
|
}
|
|
95
|
-
return this.#contractClassIdMap.get(
|
|
193
|
+
return this.#contractClassIdMap.get(key);
|
|
96
194
|
}
|
|
97
195
|
|
|
98
|
-
/**
|
|
99
|
-
* Retrieve or create a ContractTree instance based on the provided class id.
|
|
100
|
-
* If an existing tree with the same class id is found in the cache, it will be returned.
|
|
101
|
-
* Otherwise, a new ContractTree instance will be created using the contract data from the database
|
|
102
|
-
* and added to the cache before returning.
|
|
103
|
-
*
|
|
104
|
-
* @param classId - The class id of the contract for which the ContractTree is required.
|
|
105
|
-
* @returns A ContractTree instance associated with the specified contract address.
|
|
106
|
-
* @throws An Error if the contract is not found in the ContractDatabase.
|
|
107
|
-
*/
|
|
108
196
|
async #getPrivateFunctionTreeForClassId(classId: Fr): Promise<PrivateFunctionsTree | undefined> {
|
|
109
197
|
if (!this.#privateFunctionTrees.has(classId.toString())) {
|
|
110
198
|
const artifact = await this.getContractArtifact(classId);
|
|
@@ -117,34 +205,61 @@ export class ContractStore {
|
|
|
117
205
|
return this.#privateFunctionTrees.get(classId.toString())!;
|
|
118
206
|
}
|
|
119
207
|
|
|
120
|
-
async #
|
|
121
|
-
const
|
|
122
|
-
return
|
|
208
|
+
async #getArtifactByAddress(contractAddress: AztecAddress): Promise<ContractArtifact | undefined> {
|
|
209
|
+
const classId = await this.#getContractClassId(contractAddress);
|
|
210
|
+
return classId && this.getContractArtifact(classId);
|
|
123
211
|
}
|
|
124
212
|
|
|
125
213
|
// Public getters
|
|
126
214
|
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
215
|
+
getContractsAddresses(): Promise<AztecAddress[]> {
|
|
216
|
+
return this.#store.transactionAsync(async () => {
|
|
217
|
+
const keys = await toArray(this.#contractInstances.keysAsync());
|
|
218
|
+
return keys.map(AztecAddress.fromString);
|
|
219
|
+
});
|
|
130
220
|
}
|
|
131
221
|
|
|
132
|
-
/** Returns a contract instance for a given address.
|
|
133
|
-
public
|
|
134
|
-
|
|
135
|
-
|
|
222
|
+
/** Returns a contract instance for a given address. */
|
|
223
|
+
public getContractInstance(contractAddress: AztecAddress): Promise<ContractInstanceWithAddress | undefined> {
|
|
224
|
+
return this.#store.transactionAsync(async () => {
|
|
225
|
+
const contract = await this.#contractInstances.getAsync(contractAddress.toString());
|
|
226
|
+
return contract && SerializableContractInstance.fromBuffer(contract).withAddress(contractAddress);
|
|
227
|
+
});
|
|
136
228
|
}
|
|
137
229
|
|
|
230
|
+
/** Returns the raw contract artifact for a given class id. */
|
|
138
231
|
public async getContractArtifact(contractClassId: Fr): Promise<ContractArtifact | undefined> {
|
|
139
|
-
const
|
|
140
|
-
|
|
141
|
-
|
|
232
|
+
const key = contractClassId.toString();
|
|
233
|
+
const cached = this.#contractArtifactCache.get(key);
|
|
234
|
+
if (cached) {
|
|
235
|
+
return cached;
|
|
236
|
+
}
|
|
237
|
+
const artifact = await this.#store.transactionAsync(async () => {
|
|
238
|
+
const buf = await this.#contractArtifacts.getAsync(key);
|
|
239
|
+
return buf && contractArtifactFromBuffer(buf);
|
|
240
|
+
});
|
|
241
|
+
if (artifact) {
|
|
242
|
+
this.#contractArtifactCache.set(key, artifact);
|
|
243
|
+
}
|
|
244
|
+
return artifact;
|
|
142
245
|
}
|
|
143
246
|
|
|
144
|
-
/** Returns a contract class for a given class id.
|
|
145
|
-
public async
|
|
247
|
+
/** Returns a contract class for a given class id. */
|
|
248
|
+
public async getContractClassWithPreimage(
|
|
249
|
+
contractClassId: Fr,
|
|
250
|
+
): Promise<(ContractClassWithId & ContractClassIdPreimage) | undefined> {
|
|
251
|
+
const key = contractClassId.toString();
|
|
252
|
+
const buf = await this.#store.transactionAsync(() => this.#contractClassData.getAsync(key));
|
|
253
|
+
if (!buf) {
|
|
254
|
+
return undefined;
|
|
255
|
+
}
|
|
256
|
+
const classData = SerializableContractClassData.fromBuffer(buf);
|
|
146
257
|
const artifact = await this.getContractArtifact(contractClassId);
|
|
147
|
-
|
|
258
|
+
if (!artifact) {
|
|
259
|
+
return undefined;
|
|
260
|
+
}
|
|
261
|
+
const packedBytecode = artifact.functions.find(f => f.name === 'public_dispatch')?.bytecode ?? Buffer.alloc(0);
|
|
262
|
+
return { ...classData, packedBytecode };
|
|
148
263
|
}
|
|
149
264
|
|
|
150
265
|
public async getContract(
|
|
@@ -163,8 +278,6 @@ export class ContractStore {
|
|
|
163
278
|
|
|
164
279
|
/**
|
|
165
280
|
* Retrieves the artifact of a specified function within a given contract.
|
|
166
|
-
* The function is identified by its selector, which is a unique code generated from the function's signature.
|
|
167
|
-
* Throws an error if the contract address or function selector are invalid or not found.
|
|
168
281
|
*
|
|
169
282
|
* @param contractAddress - The AztecAddress representing the contract containing the function.
|
|
170
283
|
* @param selector - The function selector.
|
|
@@ -174,9 +287,12 @@ export class ContractStore {
|
|
|
174
287
|
contractAddress: AztecAddress,
|
|
175
288
|
selector: FunctionSelector,
|
|
176
289
|
): Promise<FunctionArtifactWithContractName | undefined> {
|
|
177
|
-
const artifact = await this.#
|
|
178
|
-
|
|
179
|
-
|
|
290
|
+
const artifact = await this.#getArtifactByAddress(contractAddress);
|
|
291
|
+
if (!artifact) {
|
|
292
|
+
return undefined;
|
|
293
|
+
}
|
|
294
|
+
const fn = await findFunctionArtifactBySelector(artifact, selector);
|
|
295
|
+
return fn && { ...fn, contractName: artifact.name };
|
|
180
296
|
}
|
|
181
297
|
|
|
182
298
|
public async getFunctionArtifactWithDebugMetadata(
|
|
@@ -197,50 +313,48 @@ export class ContractStore {
|
|
|
197
313
|
public async getPublicFunctionArtifact(
|
|
198
314
|
contractAddress: AztecAddress,
|
|
199
315
|
): Promise<FunctionArtifactWithContractName | undefined> {
|
|
200
|
-
const artifact = await this.#
|
|
201
|
-
const
|
|
202
|
-
return
|
|
316
|
+
const artifact = await this.#getArtifactByAddress(contractAddress);
|
|
317
|
+
const fn = artifact && artifact.functions.find(f => f.functionType === FunctionType.PUBLIC);
|
|
318
|
+
return fn && { ...fn, contractName: artifact.name };
|
|
203
319
|
}
|
|
204
320
|
|
|
205
321
|
public async getFunctionAbi(
|
|
206
322
|
contractAddress: AztecAddress,
|
|
207
323
|
selector: FunctionSelector,
|
|
208
324
|
): Promise<FunctionAbi | undefined> {
|
|
209
|
-
const artifact = await this.#
|
|
210
|
-
return artifact && (await
|
|
325
|
+
const artifact = await this.#getArtifactByAddress(contractAddress);
|
|
326
|
+
return artifact && (await findFunctionAbiBySelector(artifact, selector));
|
|
211
327
|
}
|
|
212
328
|
|
|
213
329
|
/**
|
|
214
330
|
* Retrieves the debug metadata of a specified function within a given contract.
|
|
215
|
-
* The function is identified by its selector, which is a unique code generated from the function's signature.
|
|
216
|
-
* Returns undefined if the debug metadata for the given function is not found.
|
|
217
|
-
* Throws if the contract has not been added to the database.
|
|
218
331
|
*
|
|
219
332
|
* @param contractAddress - The AztecAddress representing the contract containing the function.
|
|
220
333
|
* @param selector - The function selector.
|
|
221
|
-
* @returns The corresponding function's
|
|
334
|
+
* @returns The corresponding function's debug metadata, or undefined.
|
|
222
335
|
*/
|
|
223
336
|
public async getFunctionDebugMetadata(
|
|
224
337
|
contractAddress: AztecAddress,
|
|
225
338
|
selector: FunctionSelector,
|
|
226
339
|
): Promise<FunctionDebugMetadata | undefined> {
|
|
227
|
-
const artifact = await this.#
|
|
228
|
-
|
|
229
|
-
|
|
340
|
+
const artifact = await this.#getArtifactByAddress(contractAddress);
|
|
341
|
+
if (!artifact) {
|
|
342
|
+
return undefined;
|
|
343
|
+
}
|
|
344
|
+
const fn = await findFunctionArtifactBySelector(artifact, selector);
|
|
345
|
+
return fn && getFunctionDebugMetadata(artifact, fn);
|
|
230
346
|
}
|
|
231
347
|
|
|
232
348
|
public async getPublicFunctionDebugMetadata(
|
|
233
349
|
contractAddress: AztecAddress,
|
|
234
350
|
): Promise<FunctionDebugMetadata | undefined> {
|
|
235
|
-
const artifact = await this.#
|
|
236
|
-
const
|
|
237
|
-
return
|
|
351
|
+
const artifact = await this.#getArtifactByAddress(contractAddress);
|
|
352
|
+
const fn = artifact && artifact.functions.find(f => f.functionType === FunctionType.PUBLIC);
|
|
353
|
+
return fn && getFunctionDebugMetadata(artifact, fn);
|
|
238
354
|
}
|
|
239
355
|
|
|
240
356
|
/**
|
|
241
357
|
* Retrieve the function membership witness for the given contract class and function selector.
|
|
242
|
-
* The function membership witness represents a proof that the function belongs to the specified contract.
|
|
243
|
-
* Throws an error if the contract address or function selector is unknown.
|
|
244
358
|
*
|
|
245
359
|
* @param contractClassId - The id of the class.
|
|
246
360
|
* @param selector - The function selector.
|
|
@@ -255,42 +369,14 @@ export class ContractStore {
|
|
|
255
369
|
}
|
|
256
370
|
|
|
257
371
|
public async getDebugContractName(contractAddress: AztecAddress) {
|
|
258
|
-
const artifact = await this.#
|
|
372
|
+
const artifact = await this.#getArtifactByAddress(contractAddress);
|
|
259
373
|
return artifact?.name;
|
|
260
374
|
}
|
|
261
375
|
|
|
262
376
|
public async getDebugFunctionName(contractAddress: AztecAddress, selector: FunctionSelector) {
|
|
263
|
-
const artifact = await this.#
|
|
264
|
-
const
|
|
265
|
-
return `${artifact?.name ?? contractAddress}:${
|
|
266
|
-
}
|
|
267
|
-
|
|
268
|
-
async #findFunctionArtifactBySelector(
|
|
269
|
-
artifact: ContractArtifact,
|
|
270
|
-
selector: FunctionSelector,
|
|
271
|
-
): Promise<FunctionArtifact | undefined> {
|
|
272
|
-
const functions = artifact.functions;
|
|
273
|
-
for (let i = 0; i < functions.length; i++) {
|
|
274
|
-
const fn = functions[i];
|
|
275
|
-
const fnSelector = await FunctionSelector.fromNameAndParameters(fn.name, fn.parameters);
|
|
276
|
-
if (fnSelector.equals(selector)) {
|
|
277
|
-
return fn;
|
|
278
|
-
}
|
|
279
|
-
}
|
|
280
|
-
}
|
|
281
|
-
|
|
282
|
-
async #findFunctionAbiBySelector(
|
|
283
|
-
artifact: ContractArtifact,
|
|
284
|
-
selector: FunctionSelector,
|
|
285
|
-
): Promise<FunctionAbi | undefined> {
|
|
286
|
-
const functions = [...artifact.functions, ...(artifact.nonDispatchPublicFunctions ?? [])];
|
|
287
|
-
for (let i = 0; i < functions.length; i++) {
|
|
288
|
-
const fn = functions[i];
|
|
289
|
-
const fnSelector = await FunctionSelector.fromNameAndParameters(fn.name, fn.parameters);
|
|
290
|
-
if (fnSelector.equals(selector)) {
|
|
291
|
-
return fn;
|
|
292
|
-
}
|
|
293
|
-
}
|
|
377
|
+
const artifact = await this.#getArtifactByAddress(contractAddress);
|
|
378
|
+
const fn = artifact && (await findFunctionAbiBySelector(artifact, selector));
|
|
379
|
+
return `${artifact?.name ?? contractAddress}:${fn?.name ?? selector}`;
|
|
294
380
|
}
|
|
295
381
|
|
|
296
382
|
public async getFunctionCall(functionName: string, args: any[], to: AztecAddress): Promise<FunctionCall> {
|
|
@@ -306,34 +392,17 @@ export class ContractStore {
|
|
|
306
392
|
throw new Error(`Unknown function ${functionName} in contract ${contract.name}.`);
|
|
307
393
|
}
|
|
308
394
|
|
|
309
|
-
|
|
395
|
+
const selector = await FunctionSelector.fromNameAndParameters(functionDao.name, functionDao.parameters);
|
|
396
|
+
|
|
397
|
+
return FunctionCall.from({
|
|
310
398
|
name: functionDao.name,
|
|
311
|
-
args: encodeArguments(functionDao, args),
|
|
312
|
-
selector: await FunctionSelector.fromNameAndParameters(functionDao.name, functionDao.parameters),
|
|
313
|
-
type: functionDao.functionType,
|
|
314
399
|
to,
|
|
400
|
+
selector,
|
|
401
|
+
type: functionDao.functionType,
|
|
315
402
|
hideMsgSender: false,
|
|
316
403
|
isStatic: functionDao.isStatic,
|
|
404
|
+
args: encodeArguments(functionDao, args),
|
|
317
405
|
returnTypes: functionDao.returnTypes,
|
|
318
|
-
};
|
|
319
|
-
}
|
|
320
|
-
|
|
321
|
-
// Synchronize target contract data
|
|
322
|
-
public async syncPrivateState(
|
|
323
|
-
contractAddress: AztecAddress,
|
|
324
|
-
functionToInvokeAfterSync: FunctionSelector | null,
|
|
325
|
-
utilityExecutor: (privateSyncCall: FunctionCall) => Promise<any>,
|
|
326
|
-
) {
|
|
327
|
-
// Protocol contracts don't have private state to sync
|
|
328
|
-
if (!isProtocolContract(contractAddress)) {
|
|
329
|
-
const syncPrivateStateFunctionCall = await this.getFunctionCall('sync_private_state', [], contractAddress);
|
|
330
|
-
if (functionToInvokeAfterSync && functionToInvokeAfterSync.equals(syncPrivateStateFunctionCall.selector)) {
|
|
331
|
-
throw new Error(
|
|
332
|
-
'Forbidden `sync_private_state` invocation. `sync_private_state` can only be invoked by PXE, manual execution can lead to inconsistencies.',
|
|
333
|
-
);
|
|
334
|
-
}
|
|
335
|
-
|
|
336
|
-
return utilityExecutor(syncPrivateStateFunctionCall);
|
|
337
|
-
}
|
|
406
|
+
});
|
|
338
407
|
}
|
|
339
408
|
}
|
package/src/storage/metadata.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export const PXE_DATA_SCHEMA_VERSION =
|
|
1
|
+
export const PXE_DATA_SCHEMA_VERSION = 6;
|