@aztec/pxe 0.0.1-commit.001888fc → 0.0.1-commit.017a351
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 +6 -2
- package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
- package/dest/block_synchronizer/block_synchronizer.js +30 -10
- package/dest/config/index.d.ts +7 -1
- package/dest/config/index.d.ts.map +1 -1
- package/dest/config/index.js +12 -14
- package/dest/config/package_info.js +1 -1
- package/dest/contract_function_simulator/contract_function_simulator.d.ts +9 -4
- package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
- package/dest/contract_function_simulator/contract_function_simulator.js +35 -14
- 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 +5 -9
- package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -1
- package/dest/contract_function_simulator/execution_tagging_index_cache.js +3 -7
- package/dest/contract_function_simulator/index.d.ts +13 -2
- package/dest/contract_function_simulator/index.d.ts.map +1 -1
- package/dest/contract_function_simulator/index.js +10 -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 +5 -5
- 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 +6 -8
- 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 +1 -1
- package/dest/contract_function_simulator/noir-structs/log_retrieval_response.js +1 -1
- 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 +5 -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 -8
- 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 -102
- 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 +74 -45
- package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/oracle.js +405 -270
- 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 +1 -1
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +33 -39
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/private_execution_oracle.js +70 -54
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +104 -60
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +374 -160
- 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 +9 -4
- package/dest/contract_logging.d.ts.map +1 -1
- package/dest/contract_logging.js +21 -6
- package/dest/contract_sync/contract_sync_service.d.ts +7 -8
- package/dest/contract_sync/contract_sync_service.d.ts.map +1 -1
- package/dest/contract_sync/contract_sync_service.js +87 -49
- package/dest/contract_sync/helpers.d.ts +2 -4
- package/dest/contract_sync/helpers.d.ts.map +1 -1
- package/dest/contract_sync/helpers.js +12 -14
- package/dest/debug/pxe_debug_utils.d.ts +3 -8
- package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
- package/dest/debug/pxe_debug_utils.js +0 -6
- package/dest/entrypoints/client/bundle/index.d.ts +1 -2
- package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
- package/dest/entrypoints/client/bundle/index.js +0 -1
- 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 +13 -5
- package/dest/entrypoints/client/lazy/index.d.ts +1 -2
- package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
- package/dest/entrypoints/client/lazy/index.js +0 -1
- 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 +13 -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 +3 -3
- package/dest/entrypoints/server/index.d.ts.map +1 -1
- package/dest/entrypoints/server/index.js +2 -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 +13 -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 -9
- package/dest/logs/log_service.d.ts.map +1 -1
- package/dest/logs/log_service.js +126 -72
- package/dest/messages/message_context_service.d.ts +3 -3
- package/dest/messages/message_context_service.d.ts.map +1 -1
- package/dest/messages/message_context_service.js +30 -11
- package/dest/notes/note_service.d.ts +27 -6
- package/dest/notes/note_service.d.ts.map +1 -1
- package/dest/notes/note_service.js +80 -56
- package/dest/notes_filter.d.ts +2 -3
- package/dest/notes_filter.d.ts.map +1 -1
- 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/private_kernel_reset_private_inputs_builder.js +1 -1
- package/dest/private_kernel/hints/test_utils.d.ts +1 -1
- package/dest/private_kernel/hints/test_utils.d.ts.map +1 -1
- package/dest/private_kernel/hints/test_utils.js +2 -3
- 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 +152 -59
- package/dest/private_kernel/private_kernel_oracle.d.ts +10 -10
- package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
- package/dest/private_kernel/private_kernel_oracle.js +24 -22
- package/dest/pxe.d.ts +56 -10
- package/dest/pxe.d.ts.map +1 -1
- package/dest/pxe.js +139 -88
- 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 +1 -1
- package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
- package/dest/storage/contract_store/contract_store.js +9 -26
- package/dest/storage/metadata.d.ts +1 -1
- package/dest/storage/metadata.js +1 -1
- package/dest/storage/note_store/note_store.d.ts +1 -1
- package/dest/storage/note_store/note_store.d.ts.map +1 -1
- package/dest/storage/note_store/note_store.js +2 -2
- 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 +5 -5
- package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
- package/dest/storage/tagging_store/sender_tagging_store.js +3 -3
- 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 +36 -37
- package/dest/tagging/index.d.ts +5 -4
- 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/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 -5
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +26 -14
- package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +11 -6
- 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 +21 -0
- package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +4 -4
- 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 +2 -2
- package/package.json +20 -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 +33 -11
- package/src/config/index.ts +14 -8
- package/src/config/package_info.ts +1 -1
- package/src/contract_function_simulator/contract_function_simulator.ts +55 -17
- 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 +5 -9
- package/src/contract_function_simulator/index.ts +50 -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 +4 -6
- package/src/contract_function_simulator/noir-structs/log_retrieval_request.ts +36 -3
- package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +1 -1
- package/src/contract_function_simulator/noir-structs/note_data.ts +27 -0
- package/src/contract_function_simulator/noir-structs/note_validation_request.ts +4 -6
- 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 -175
- package/src/contract_function_simulator/oracle/note_packing_utils.ts +3 -3
- package/src/contract_function_simulator/oracle/oracle.ts +498 -442
- 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 +1 -1
- package/src/contract_function_simulator/oracle/private_execution_oracle.ts +93 -75
- package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +547 -265
- 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 +18 -5
- package/src/contract_sync/contract_sync_service.ts +120 -83
- package/src/contract_sync/helpers.ts +13 -25
- package/src/debug/pxe_debug_utils.ts +3 -11
- package/src/entrypoints/client/bundle/index.ts +0 -1
- package/src/entrypoints/client/bundle/utils.ts +10 -5
- package/src/entrypoints/client/lazy/index.ts +0 -1
- package/src/entrypoints/client/lazy/utils.ts +10 -5
- package/src/entrypoints/pxe_creation_options.ts +14 -0
- package/src/entrypoints/server/index.ts +2 -2
- package/src/entrypoints/server/utils.ts +15 -6
- 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 +158 -134
- package/src/messages/message_context_service.ts +43 -26
- package/src/notes/note_service.ts +119 -85
- package/src/notes_filter.ts +1 -3
- package/src/oracle_version.ts +20 -10
- package/src/private_kernel/batch_planner.ts +169 -0
- package/src/private_kernel/hints/private_kernel_reset_private_inputs_builder.ts +1 -1
- package/src/private_kernel/hints/test_utils.ts +2 -9
- package/src/private_kernel/private_kernel_execution_prover.ts +240 -82
- package/src/private_kernel/private_kernel_oracle.ts +35 -25
- package/src/pxe.ts +227 -92
- 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 +14 -35
- package/src/storage/metadata.ts +1 -1
- package/src/storage/note_store/note_store.ts +2 -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 -9
- package/src/storage/tagging_store/sender_tagging_store.ts +6 -6
- package/src/tagging/get_all_logs_by_tags.ts +78 -50
- package/src/tagging/index.ts +4 -3
- 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 +2 -2
- package/src/tagging/reconcile_tagging_index_ranges.ts +102 -0
- package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +41 -19
- package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +23 -8
- package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +4 -5
- package/dest/access_scopes.d.ts +0 -9
- package/dest/access_scopes.d.ts.map +0 -1
- package/dest/access_scopes.js +0 -6
- package/dest/contract_function_simulator/noir-structs/message_tx_context.d.ts +0 -16
- package/dest/contract_function_simulator/noir-structs/message_tx_context.d.ts.map +0 -1
- package/dest/contract_function_simulator/noir-structs/message_tx_context.js +0 -57
- package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts +0 -9
- package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts.map +0 -1
- package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.js +0 -43
- 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 -33
- package/src/access_scopes.ts +0 -9
- package/src/contract_function_simulator/noir-structs/message_tx_context.ts +0 -55
- package/src/contract_function_simulator/oracle/legacy_oracle_mappings.ts +0 -142
- package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +0 -140
- package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +0 -44
|
@@ -2,11 +2,10 @@ import { MAX_FR_CALLDATA_TO_ALL_ENQUEUED_CALLS, PRIVATE_CONTEXT_INPUTS_LENGTH }
|
|
|
2
2
|
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
3
3
|
import { createLogger } from '@aztec/foundation/log';
|
|
4
4
|
import { Timer } from '@aztec/foundation/timer';
|
|
5
|
-
import {
|
|
5
|
+
import { toACVMWitness } from '@aztec/simulator/client';
|
|
6
6
|
import {
|
|
7
7
|
type FunctionAbi,
|
|
8
8
|
type FunctionArtifact,
|
|
9
|
-
type FunctionCall,
|
|
10
9
|
FunctionSelector,
|
|
11
10
|
type NoteSelector,
|
|
12
11
|
countArgumentsSize,
|
|
@@ -14,8 +13,12 @@ import {
|
|
|
14
13
|
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
15
14
|
import { siloNullifier } from '@aztec/stdlib/hash';
|
|
16
15
|
import { PrivateContextInputs } from '@aztec/stdlib/kernel';
|
|
17
|
-
import {
|
|
18
|
-
|
|
16
|
+
import {
|
|
17
|
+
AppTaggingSecret,
|
|
18
|
+
AppTaggingSecretKind,
|
|
19
|
+
type ContractClassLog,
|
|
20
|
+
type TaggingIndexRange,
|
|
21
|
+
} from '@aztec/stdlib/logs';
|
|
19
22
|
import { Note, type NoteStatus } from '@aztec/stdlib/note';
|
|
20
23
|
import {
|
|
21
24
|
CallContext,
|
|
@@ -25,16 +28,17 @@ import {
|
|
|
25
28
|
type TxContext,
|
|
26
29
|
} from '@aztec/stdlib/tx';
|
|
27
30
|
|
|
28
|
-
import type { AccessScopes } from '../../access_scopes.js';
|
|
29
|
-
import type { ContractSyncService } from '../../contract_sync/contract_sync_service.js';
|
|
30
31
|
import { NoteService } from '../../notes/note_service.js';
|
|
31
32
|
import type { SenderTaggingStore } from '../../storage/tagging_store/sender_tagging_store.js';
|
|
32
33
|
import { syncSenderTaggingIndexes } from '../../tagging/index.js';
|
|
33
34
|
import type { ExecutionNoteCache } from '../execution_note_cache.js';
|
|
34
35
|
import { ExecutionTaggingIndexCache } from '../execution_tagging_index_cache.js';
|
|
35
36
|
import type { HashedValuesCache } from '../hashed_values_cache.js';
|
|
37
|
+
import { BoundedVec } from '../noir-structs/bounded_vec.js';
|
|
38
|
+
import type { NoteData } from '../noir-structs/note_data.js';
|
|
39
|
+
import { Option } from '../noir-structs/option.js';
|
|
36
40
|
import { pickNotes } from '../pick_notes.js';
|
|
37
|
-
import type { IPrivateExecutionOracle
|
|
41
|
+
import type { IPrivateExecutionOracle } from './interfaces.js';
|
|
38
42
|
import { executePrivateFunction } from './private_execution.js';
|
|
39
43
|
import { UtilityExecutionOracle, type UtilityExecutionOracleArgs } from './utility_execution_oracle.js';
|
|
40
44
|
|
|
@@ -43,17 +47,13 @@ export type PrivateExecutionOracleArgs = Omit<UtilityExecutionOracleArgs, 'contr
|
|
|
43
47
|
argsHash: Fr;
|
|
44
48
|
txContext: TxContext;
|
|
45
49
|
callContext: CallContext;
|
|
46
|
-
/** Needed to trigger contract synchronization before nested calls */
|
|
47
|
-
utilityExecutor: (call: FunctionCall, scopes: AccessScopes) => Promise<void>;
|
|
48
50
|
executionCache: HashedValuesCache;
|
|
49
51
|
noteCache: ExecutionNoteCache;
|
|
50
52
|
taggingIndexCache: ExecutionTaggingIndexCache;
|
|
51
53
|
senderTaggingStore: SenderTaggingStore;
|
|
52
|
-
contractSyncService: ContractSyncService;
|
|
53
54
|
totalPublicCalldataCount?: number;
|
|
54
55
|
sideEffectCounter?: number;
|
|
55
56
|
senderForTags?: AztecAddress;
|
|
56
|
-
simulator?: CircuitSimulator;
|
|
57
57
|
};
|
|
58
58
|
|
|
59
59
|
/**
|
|
@@ -78,16 +78,14 @@ export class PrivateExecutionOracle extends UtilityExecutionOracle implements IP
|
|
|
78
78
|
private readonly argsHash: Fr;
|
|
79
79
|
private readonly txContext: TxContext;
|
|
80
80
|
private readonly callContext: CallContext;
|
|
81
|
-
private readonly utilityExecutor: (call: FunctionCall, scopes: AccessScopes) => Promise<void>;
|
|
82
81
|
private readonly executionCache: HashedValuesCache;
|
|
83
82
|
private readonly noteCache: ExecutionNoteCache;
|
|
84
83
|
private readonly taggingIndexCache: ExecutionTaggingIndexCache;
|
|
85
84
|
private readonly senderTaggingStore: SenderTaggingStore;
|
|
86
|
-
private readonly contractSyncService: ContractSyncService;
|
|
87
85
|
private totalPublicCalldataCount: number;
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
private readonly
|
|
86
|
+
private readonly initialSideEffectCounter: number;
|
|
87
|
+
/** Sender for tags passed in at oracle construction time. Returned by `getSenderForTags`. */
|
|
88
|
+
private readonly defaultSenderForTags: AztecAddress | undefined;
|
|
91
89
|
|
|
92
90
|
constructor(args: PrivateExecutionOracleArgs) {
|
|
93
91
|
super({
|
|
@@ -98,20 +96,22 @@ export class PrivateExecutionOracle extends UtilityExecutionOracle implements IP
|
|
|
98
96
|
this.argsHash = args.argsHash;
|
|
99
97
|
this.txContext = args.txContext;
|
|
100
98
|
this.callContext = args.callContext;
|
|
101
|
-
this.utilityExecutor = args.utilityExecutor;
|
|
102
99
|
this.executionCache = args.executionCache;
|
|
103
100
|
this.noteCache = args.noteCache;
|
|
104
101
|
this.taggingIndexCache = args.taggingIndexCache;
|
|
105
102
|
this.senderTaggingStore = args.senderTaggingStore;
|
|
106
|
-
this.contractSyncService = args.contractSyncService;
|
|
107
103
|
this.totalPublicCalldataCount = args.totalPublicCalldataCount ?? 0;
|
|
108
|
-
this.
|
|
109
|
-
this.
|
|
110
|
-
this.simulator = args.simulator;
|
|
104
|
+
this.initialSideEffectCounter = args.sideEffectCounter ?? 0;
|
|
105
|
+
this.defaultSenderForTags = args.senderForTags;
|
|
111
106
|
}
|
|
112
107
|
|
|
113
108
|
public getPrivateContextInputs(): PrivateContextInputs {
|
|
114
|
-
return new PrivateContextInputs(
|
|
109
|
+
return new PrivateContextInputs(
|
|
110
|
+
this.callContext,
|
|
111
|
+
this.anchorBlockHeader,
|
|
112
|
+
this.txContext,
|
|
113
|
+
this.initialSideEffectCounter,
|
|
114
|
+
);
|
|
115
115
|
}
|
|
116
116
|
|
|
117
117
|
// We still need this function until we can get user-defined ordering of structs for fn arguments
|
|
@@ -178,59 +178,62 @@ export class PrivateExecutionOracle extends UtilityExecutionOracle implements IP
|
|
|
178
178
|
* for a tag in order to emit a log. Constrained tagging should not use this as there is no
|
|
179
179
|
* guarantee that the recipient knows about the sender, and hence about the shared secret.
|
|
180
180
|
*
|
|
181
|
-
*
|
|
182
|
-
* 'senderForTags' value (unless it is replaced).
|
|
181
|
+
* Returns the wallet-supplied default sender for tags, or `None` if no default was provided.
|
|
183
182
|
*/
|
|
184
|
-
public getSenderForTags(): Promise<AztecAddress
|
|
185
|
-
return Promise.resolve(
|
|
183
|
+
public getSenderForTags(): Promise<Option<AztecAddress>> {
|
|
184
|
+
return Promise.resolve(
|
|
185
|
+
this.defaultSenderForTags ? Option.some(this.defaultSenderForTags) : Option.none(AztecAddress.ZERO),
|
|
186
|
+
);
|
|
186
187
|
}
|
|
187
188
|
|
|
188
189
|
/**
|
|
189
|
-
*
|
|
190
|
+
* Returns the sender-side app tagging secret for a `(sender, recipient)` pair.
|
|
190
191
|
*
|
|
191
|
-
*
|
|
192
|
-
*
|
|
193
|
-
* guarantee that the recipient knows about the sender, and hence about the shared secret.
|
|
192
|
+
* The caller obtains an index via {@link getNextTaggingIndex} and computes the final tag itself.
|
|
193
|
+
* The only expected `None` case is an invalid recipient address; missing sender data fails while deriving.
|
|
194
194
|
*
|
|
195
|
-
*
|
|
196
|
-
*
|
|
197
|
-
*
|
|
195
|
+
* @param sender - The address sending the log
|
|
196
|
+
* @param recipient - The address receiving the log
|
|
197
|
+
* @returns The app tagging secret, or `None` if the recipient is invalid.
|
|
198
198
|
*/
|
|
199
|
-
public
|
|
200
|
-
this.
|
|
201
|
-
|
|
199
|
+
public async getAppTaggingSecret(sender: AztecAddress, recipient: AztecAddress): Promise<Option<Fr>> {
|
|
200
|
+
const extendedSecret = await this.#calculateAppTaggingSecret(this.contractAddress, sender, recipient);
|
|
201
|
+
|
|
202
|
+
if (!extendedSecret) {
|
|
203
|
+
this.logger.warn(`Computing a tagging secret for invalid recipient ${recipient} - returning no secret`, {
|
|
204
|
+
contractAddress: this.contractAddress,
|
|
205
|
+
});
|
|
206
|
+
return Option.none(Fr.ZERO);
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
return Option.some(extendedSecret.secret);
|
|
202
210
|
}
|
|
203
211
|
|
|
204
212
|
/**
|
|
205
|
-
* Returns the next
|
|
206
|
-
*
|
|
207
|
-
* @param
|
|
208
|
-
* @
|
|
213
|
+
* Returns the next sender-side tagging index for a given secret and delivery mode.
|
|
214
|
+
*
|
|
215
|
+
* @param secret - The tagging secret to allocate an index for.
|
|
216
|
+
* @param kind - The sender-side index namespace.
|
|
217
|
+
* @returns The next index to use for this secret.
|
|
209
218
|
*/
|
|
210
|
-
public async
|
|
211
|
-
const
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
const index = await this.#getIndexToUseForSecret(extendedSecret);
|
|
218
|
-
this.logger.debug(
|
|
219
|
-
`Incrementing tagging index for sender: ${sender}, recipient: ${recipient}, contract: ${this.contractAddress} to ${index}`,
|
|
220
|
-
);
|
|
221
|
-
this.taggingIndexCache.setLastUsedIndex(extendedSecret, index);
|
|
219
|
+
public async getNextTaggingIndex(secret: Fr, kind: AppTaggingSecretKind): Promise<number> {
|
|
220
|
+
const appTaggingSecret = new AppTaggingSecret(secret, this.contractAddress, kind);
|
|
221
|
+
const index = await this.#reserveNextIndexForSecret(appTaggingSecret);
|
|
222
|
+
this.logger.debug(`Incrementing ${kind} tagging index for secret in contract ${this.contractAddress} to ${index}`);
|
|
223
|
+
return index;
|
|
224
|
+
}
|
|
222
225
|
|
|
223
|
-
|
|
226
|
+
/** Resolves the next index for a given tagging secret, syncing from chain if it is missing from the in-tx cache. */
|
|
227
|
+
async #reserveNextIndexForSecret(secret: AppTaggingSecret): Promise<number> {
|
|
228
|
+
const index = await this.#getIndexToUseForSecret(secret);
|
|
229
|
+
this.taggingIndexCache.setLastUsedIndex(secret, index);
|
|
230
|
+
return index;
|
|
224
231
|
}
|
|
225
232
|
|
|
226
|
-
async #
|
|
227
|
-
contractAddress: AztecAddress,
|
|
228
|
-
sender: AztecAddress,
|
|
229
|
-
recipient: AztecAddress,
|
|
230
|
-
) {
|
|
233
|
+
async #calculateAppTaggingSecret(contractAddress: AztecAddress, sender: AztecAddress, recipient: AztecAddress) {
|
|
231
234
|
const senderCompleteAddress = await this.getCompleteAddressOrFail(sender);
|
|
232
235
|
const senderIvsk = await this.keyStore.getMasterIncomingViewingSecretKey(sender);
|
|
233
|
-
return
|
|
236
|
+
return AppTaggingSecret.computeUnconstrained(
|
|
234
237
|
senderCompleteAddress,
|
|
235
238
|
senderIvsk,
|
|
236
239
|
recipient,
|
|
@@ -239,7 +242,7 @@ export class PrivateExecutionOracle extends UtilityExecutionOracle implements IP
|
|
|
239
242
|
);
|
|
240
243
|
}
|
|
241
244
|
|
|
242
|
-
async #getIndexToUseForSecret(secret:
|
|
245
|
+
async #getIndexToUseForSecret(secret: AppTaggingSecret): Promise<number> {
|
|
243
246
|
// If we have the tagging index in the cache, we use it. If not we obtain it from the execution data provider.
|
|
244
247
|
const lastUsedIndexInTx = this.taggingIndexCache.getLastUsedIndex(secret);
|
|
245
248
|
|
|
@@ -269,7 +272,7 @@ export class PrivateExecutionOracle extends UtilityExecutionOracle implements IP
|
|
|
269
272
|
* @param values - Values to store.
|
|
270
273
|
* @returns The hash of the values.
|
|
271
274
|
*/
|
|
272
|
-
public
|
|
275
|
+
public setHashPreimage(values: Fr[], hash: Fr) {
|
|
273
276
|
return this.executionCache.store(values, hash);
|
|
274
277
|
}
|
|
275
278
|
|
|
@@ -278,7 +281,7 @@ export class PrivateExecutionOracle extends UtilityExecutionOracle implements IP
|
|
|
278
281
|
* @param hash - Hash of the values.
|
|
279
282
|
* @returns The values.
|
|
280
283
|
*/
|
|
281
|
-
public
|
|
284
|
+
public getHashPreimage(hash: Fr): Promise<Fr[]> {
|
|
282
285
|
const preimage = this.executionCache.getPreimage(hash);
|
|
283
286
|
if (!preimage) {
|
|
284
287
|
throw new Error(`Preimage for hash ${hash.toString()} not found in cache`);
|
|
@@ -286,7 +289,7 @@ export class PrivateExecutionOracle extends UtilityExecutionOracle implements IP
|
|
|
286
289
|
return Promise.resolve(preimage);
|
|
287
290
|
}
|
|
288
291
|
|
|
289
|
-
override async
|
|
292
|
+
override async doesNullifierExist(innerNullifier: Fr): Promise<boolean> {
|
|
290
293
|
// This oracle must be overridden because while utility execution can only meaningfully check if a nullifier exists
|
|
291
294
|
// in the synched block, during private execution there's also the possibility of it being pending, i.e. created
|
|
292
295
|
// in the current transaction.
|
|
@@ -299,7 +302,7 @@ export class PrivateExecutionOracle extends UtilityExecutionOracle implements IP
|
|
|
299
302
|
|
|
300
303
|
return (
|
|
301
304
|
this.noteCache.getNullifiers(this.contractAddress).has(nullifier) ||
|
|
302
|
-
(await super.
|
|
305
|
+
(await super.doesNullifierExist(innerNullifier))
|
|
303
306
|
);
|
|
304
307
|
}
|
|
305
308
|
|
|
@@ -325,7 +328,7 @@ export class PrivateExecutionOracle extends UtilityExecutionOracle implements IP
|
|
|
325
328
|
* @returns Array of note data.
|
|
326
329
|
*/
|
|
327
330
|
public override async getNotes(
|
|
328
|
-
owner: AztecAddress
|
|
331
|
+
owner: Option<AztecAddress>,
|
|
329
332
|
storageSlot: Fr,
|
|
330
333
|
numSelects: number,
|
|
331
334
|
selectByIndexes: number[],
|
|
@@ -340,16 +343,18 @@ export class PrivateExecutionOracle extends UtilityExecutionOracle implements IP
|
|
|
340
343
|
limit: number,
|
|
341
344
|
offset: number,
|
|
342
345
|
status: NoteStatus,
|
|
343
|
-
|
|
346
|
+
maxNotes: number,
|
|
347
|
+
packedHintedNoteLength: number,
|
|
348
|
+
): Promise<BoundedVec<NoteData>> {
|
|
344
349
|
// Nullified pending notes are already removed from the list.
|
|
345
|
-
const pendingNotes = this.noteCache.getNotes(this.callContext.contractAddress, owner, storageSlot);
|
|
350
|
+
const pendingNotes = this.noteCache.getNotes(this.callContext.contractAddress, owner.value, storageSlot);
|
|
346
351
|
|
|
347
352
|
const pendingNullifiers = this.noteCache.getNullifiers(this.callContext.contractAddress);
|
|
348
353
|
|
|
349
354
|
const noteService = new NoteService(this.noteStore, this.aztecNode, this.anchorBlockHeader, this.jobId);
|
|
350
355
|
const dbNotes = await noteService.getNotes(
|
|
351
356
|
this.callContext.contractAddress,
|
|
352
|
-
owner,
|
|
357
|
+
owner.value,
|
|
353
358
|
storageSlot,
|
|
354
359
|
status,
|
|
355
360
|
this.scopes,
|
|
@@ -376,7 +381,7 @@ export class PrivateExecutionOracle extends UtilityExecutionOracle implements IP
|
|
|
376
381
|
.join(', ')}`,
|
|
377
382
|
);
|
|
378
383
|
|
|
379
|
-
return notes;
|
|
384
|
+
return BoundedVec.from({ data: notes, maxLength: maxNotes, elementSize: packedHintedNoteLength });
|
|
380
385
|
}
|
|
381
386
|
|
|
382
387
|
/**
|
|
@@ -559,7 +564,7 @@ export class PrivateExecutionOracle extends UtilityExecutionOracle implements IP
|
|
|
559
564
|
senderTaggingStore: this.senderTaggingStore,
|
|
560
565
|
recipientTaggingStore: this.recipientTaggingStore,
|
|
561
566
|
senderAddressBookStore: this.senderAddressBookStore,
|
|
562
|
-
|
|
567
|
+
capsuleService: this.capsuleService,
|
|
563
568
|
privateEventStore: this.privateEventStore,
|
|
564
569
|
messageContextService: this.messageContextService,
|
|
565
570
|
contractSyncService: this.contractSyncService,
|
|
@@ -568,20 +573,25 @@ export class PrivateExecutionOracle extends UtilityExecutionOracle implements IP
|
|
|
568
573
|
sideEffectCounter,
|
|
569
574
|
log: this.logger,
|
|
570
575
|
scopes: this.scopes,
|
|
571
|
-
senderForTags: this.
|
|
572
|
-
simulator: this.simulator
|
|
576
|
+
senderForTags: this.defaultSenderForTags,
|
|
577
|
+
simulator: this.simulator,
|
|
578
|
+
hooks: this.hooks,
|
|
579
|
+
l2TipsStore: this.l2TipsStore,
|
|
573
580
|
});
|
|
574
581
|
|
|
575
582
|
const setupTime = simulatorSetupTimer.ms();
|
|
576
583
|
|
|
577
584
|
const childExecutionResult = await executePrivateFunction(
|
|
578
|
-
this.simulator
|
|
585
|
+
this.simulator,
|
|
579
586
|
privateExecutionOracle,
|
|
580
587
|
targetArtifact,
|
|
581
588
|
targetContractAddress,
|
|
582
589
|
functionSelector,
|
|
583
590
|
);
|
|
584
591
|
|
|
592
|
+
// Propagate the nested call's calldata count so the parent sees its increments on subsequent enqueues.
|
|
593
|
+
this.totalPublicCalldataCount = privateExecutionOracle.getTotalPublicCalldataCount();
|
|
594
|
+
|
|
585
595
|
if (isStaticCall) {
|
|
586
596
|
this.#checkValidStaticCall(childExecutionResult);
|
|
587
597
|
}
|
|
@@ -602,7 +612,7 @@ export class PrivateExecutionOracle extends UtilityExecutionOracle implements IP
|
|
|
602
612
|
}
|
|
603
613
|
|
|
604
614
|
/** Validates the calldata preimage exists in the cache and checks cumulative calldata size is within limits. */
|
|
605
|
-
public
|
|
615
|
+
public assertValidPublicCalldata(calldataHash: Fr) {
|
|
606
616
|
const calldata = this.executionCache.getPreimage(calldataHash);
|
|
607
617
|
if (!calldata) {
|
|
608
618
|
throw new Error('Calldata for public call not found in cache');
|
|
@@ -615,11 +625,15 @@ export class PrivateExecutionOracle extends UtilityExecutionOracle implements IP
|
|
|
615
625
|
return Promise.resolve();
|
|
616
626
|
}
|
|
617
627
|
|
|
628
|
+
public getTotalPublicCalldataCount(): number {
|
|
629
|
+
return this.totalPublicCalldataCount;
|
|
630
|
+
}
|
|
631
|
+
|
|
618
632
|
public notifyRevertiblePhaseStart(minRevertibleSideEffectCounter: number): Promise<void> {
|
|
619
633
|
return this.noteCache.setMinRevertibleSideEffectCounter(minRevertibleSideEffectCounter);
|
|
620
634
|
}
|
|
621
635
|
|
|
622
|
-
public
|
|
636
|
+
public isExecutionInRevertiblePhase(sideEffectCounter: number): Promise<boolean> {
|
|
623
637
|
return Promise.resolve(this.noteCache.isSideEffectCounterRevertible(sideEffectCounter));
|
|
624
638
|
}
|
|
625
639
|
|
|
@@ -646,4 +660,8 @@ export class PrivateExecutionOracle extends UtilityExecutionOracle implements IP
|
|
|
646
660
|
public getDebugFunctionName() {
|
|
647
661
|
return this.contractStore.getDebugFunctionName(this.contractAddress, this.callContext.functionSelector);
|
|
648
662
|
}
|
|
663
|
+
|
|
664
|
+
protected override get callerContext() {
|
|
665
|
+
return this.callContext.isStaticCall ? 'private view' : 'private';
|
|
666
|
+
}
|
|
649
667
|
}
|