@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
|
@@ -1,12 +1,5 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import { Point } from '@aztec/foundation/curves/grumpkin';
|
|
4
|
-
import { arrayOfArraysToBoundedVecOfArrays, bufferToBoundedVec, fromUintArray, fromUintBoundedVec, toACVMField } from '@aztec/simulator/client';
|
|
5
|
-
import { FunctionSelector, NoteSelector } from '@aztec/stdlib/abi';
|
|
6
|
-
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
7
|
-
import { BlockHash } from '@aztec/stdlib/block';
|
|
8
|
-
import { ContractClassLog, ContractClassLogFields } from '@aztec/stdlib/logs';
|
|
9
|
-
import { packAsHintedNote } from './note_packing_utils.js';
|
|
1
|
+
import { ORACLE_VERSION_MAJOR, ORACLE_VERSION_MINOR } from '../../oracle_version.js';
|
|
2
|
+
import { callHandler } from './oracle_registry.js';
|
|
10
3
|
export class UnavailableOracleError extends Error {
|
|
11
4
|
constructor(oracleName){
|
|
12
5
|
super(`${oracleName} oracles not available with the current handler`);
|
|
@@ -14,6 +7,25 @@ export class UnavailableOracleError extends Error {
|
|
|
14
7
|
}
|
|
15
8
|
/**
|
|
16
9
|
* A data source that has all the apis required by Aztec.nr.
|
|
10
|
+
*
|
|
11
|
+
* ## Oracle naming conventions
|
|
12
|
+
*
|
|
13
|
+
* We try to keep oracle naming consistent, please see below the conventions we adhere to.
|
|
14
|
+
*
|
|
15
|
+
* Each oracle method name has the form `aztec_{scope}_{verb}{Object}`, where:
|
|
16
|
+
*
|
|
17
|
+
* - **Scope prefix** indicates the execution context required:
|
|
18
|
+
* - `aztec_prv_` — available only during private function execution.
|
|
19
|
+
* - `aztec_utl_` — available during both utility and private execution.
|
|
20
|
+
*
|
|
21
|
+
* - **Verb** signals the operation's semantics (verb-first, then object):
|
|
22
|
+
* - `get` — read / lookup / get data from oracle into contract.
|
|
23
|
+
* - `does`/`is`/`has` — predicate (returns boolean).
|
|
24
|
+
* - `emit`/`notify` — propagate data from contract to oracle.
|
|
25
|
+
* - `set` — contract driven oracle state mutation (capsules, execution cache, tagging, etc).
|
|
26
|
+
* - `call` — trigger nested execution (control flow).
|
|
27
|
+
* - `assert` — validate a condition, throw on failure.
|
|
28
|
+
* - Standalone verbs (`delete`, `copy`, `decrypt`, `log`, etc) are used when no generic verb fits.
|
|
17
29
|
*/ export class Oracle {
|
|
18
30
|
handler;
|
|
19
31
|
constructor(handler){
|
|
@@ -48,11 +60,11 @@ export class UnavailableOracleError extends Error {
|
|
|
48
60
|
];
|
|
49
61
|
// Get all the oracle function names
|
|
50
62
|
const oracleNames = Object.getOwnPropertyNames(Oracle.prototype).filter((name)=>!excludedProps.includes(name));
|
|
51
|
-
// Validate oracle names - these must be prefixed with either "
|
|
63
|
+
// Validate oracle names - these must be prefixed with either "aztec_prv_" or "aztec_utl_" to indicate their scope
|
|
52
64
|
// and must correspond to a function on the Oracle class.
|
|
53
65
|
oracleNames.forEach((name)=>{
|
|
54
|
-
if (!name.startsWith('
|
|
55
|
-
throw new Error(`Oracle function "${name}" must be prefixed with
|
|
66
|
+
if (!name.startsWith('aztec_prv_') && !name.startsWith('aztec_utl_') && !name.startsWith('aztec_misc_')) {
|
|
67
|
+
throw new Error(`Oracle function "${name}" must be prefixed with "aztec_prv_", "aztec_utl_", or "aztec_misc_" to indicate its scope`);
|
|
56
68
|
}
|
|
57
69
|
const method = this[name];
|
|
58
70
|
if (typeof method !== 'function') {
|
|
@@ -60,297 +72,481 @@ export class UnavailableOracleError extends Error {
|
|
|
60
72
|
}
|
|
61
73
|
});
|
|
62
74
|
// Build callback object and return it
|
|
63
|
-
|
|
75
|
+
const callback = oracleNames.reduce((acc, name)=>{
|
|
64
76
|
const method = this[name];
|
|
65
77
|
acc[name] = method.bind(this);
|
|
66
78
|
return acc;
|
|
67
79
|
}, {});
|
|
80
|
+
// Wrap in a Proxy to intercept access to missing oracle names and provide enhanced error messages when the
|
|
81
|
+
// contract's minor version is higher than the PXE's (i.e. the contract expects oracles that were added in a newer
|
|
82
|
+
// minor version).
|
|
83
|
+
const handler = this.handler;
|
|
84
|
+
return new Proxy(callback, {
|
|
85
|
+
get (target, prop) {
|
|
86
|
+
if (prop in target) {
|
|
87
|
+
return target[prop];
|
|
88
|
+
}
|
|
89
|
+
// Return a function that throws with an enhanced error message if applicable
|
|
90
|
+
return ()=>{
|
|
91
|
+
let contractVersion = undefined;
|
|
92
|
+
if ('nonOracleFunctionGetContractOracleVersion' in handler) {
|
|
93
|
+
contractVersion = handler.nonOracleFunctionGetContractOracleVersion();
|
|
94
|
+
}
|
|
95
|
+
if (!contractVersion) {
|
|
96
|
+
throw new Error(`Oracle '${prop}' not found and the contract's oracle version is unknown (the version check oracle ` + `was not called before '${prop}'). This usually means the contract was not compiled with the ` + `#[aztec] macro, which injects the version check as the first oracle call in every private/utility ` + `external function. If you're using a custom entry point, ensure assert_compatible_oracle_version() ` + `is called before any other oracle calls. See https://docs.aztec.network/errors/8`);
|
|
97
|
+
} else if (contractVersion.minor > ORACLE_VERSION_MINOR) {
|
|
98
|
+
throw new Error(`Oracle '${prop}' not found.` + ` This usually means the contract requires a newer private execution environment than you have.` + ` Upgrade your private execution environment to a compatible version. The contract was compiled with` + ` Aztec.nr oracle version ${contractVersion.major}.${contractVersion.minor}, but this private` + ` execution environment only supports up to ${ORACLE_VERSION_MAJOR}.${ORACLE_VERSION_MINOR}.` + ` See https://docs.aztec.network/errors/8`);
|
|
99
|
+
} else {
|
|
100
|
+
throw new Error(`Oracle '${prop}' not found.` + ` The contract's oracle version (${contractVersion.major}.${contractVersion.minor}) is compatible` + ` with this private execution environment (${ORACLE_VERSION_MAJOR}.${ORACLE_VERSION_MINOR}), so all` + ` standard oracles should be available. This could mean the contract was compiled against a modified` + ` version of Aztec.nr, or that it references an oracle that does not exist.` + ` See https://docs.aztec.network/errors/8`);
|
|
101
|
+
}
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
});
|
|
68
105
|
}
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
return
|
|
106
|
+
// eslint-disable-next-line camelcase
|
|
107
|
+
aztec_misc_assertCompatibleOracleVersion(...inputs) {
|
|
108
|
+
return callHandler({
|
|
109
|
+
oracle: 'aztec_misc_assertCompatibleOracleVersion',
|
|
110
|
+
inputs,
|
|
111
|
+
handler: ([major, minor])=>{
|
|
112
|
+
this.handlerAsMisc().assertCompatibleOracleVersion(major, minor);
|
|
113
|
+
}
|
|
114
|
+
});
|
|
72
115
|
}
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
return
|
|
76
|
-
|
|
77
|
-
|
|
116
|
+
// eslint-disable-next-line camelcase
|
|
117
|
+
aztec_misc_getRandomField() {
|
|
118
|
+
return callHandler({
|
|
119
|
+
oracle: 'aztec_misc_getRandomField',
|
|
120
|
+
inputs: [],
|
|
121
|
+
handler: ()=>this.handlerAsMisc().getRandomField()
|
|
122
|
+
});
|
|
78
123
|
}
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
return
|
|
124
|
+
// eslint-disable-next-line camelcase
|
|
125
|
+
aztec_prv_setHashPreimage(...inputs) {
|
|
126
|
+
return callHandler({
|
|
127
|
+
oracle: 'aztec_prv_setHashPreimage',
|
|
128
|
+
inputs,
|
|
129
|
+
handler: ([values, hash])=>{
|
|
130
|
+
this.handlerAsPrivate().setHashPreimage(values, hash);
|
|
131
|
+
}
|
|
132
|
+
});
|
|
82
133
|
}
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
return
|
|
86
|
-
|
|
87
|
-
|
|
134
|
+
// eslint-disable-next-line camelcase
|
|
135
|
+
aztec_prv_getHashPreimage(...inputs) {
|
|
136
|
+
return callHandler({
|
|
137
|
+
oracle: 'aztec_prv_getHashPreimage',
|
|
138
|
+
inputs,
|
|
139
|
+
handler: ([returnsHash])=>this.handlerAsPrivate().getHashPreimage(returnsHash)
|
|
140
|
+
});
|
|
88
141
|
}
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
return
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
}
|
|
97
|
-
async utilityGetContractInstance([address]) {
|
|
98
|
-
const instance = await this.handlerAsUtility().utilityGetContractInstance(AztecAddress.fromField(Fr.fromString(address)));
|
|
99
|
-
return [
|
|
100
|
-
instance.salt,
|
|
101
|
-
instance.deployer,
|
|
102
|
-
instance.currentContractClassId,
|
|
103
|
-
instance.initializationHash,
|
|
104
|
-
...instance.publicKeys.toFields()
|
|
105
|
-
].map(toACVMField);
|
|
106
|
-
}
|
|
107
|
-
async utilityGetNoteHashMembershipWitness([blockHash], [leafValue]) {
|
|
108
|
-
const parsedBlockHash = BlockHash.fromString(blockHash);
|
|
109
|
-
const parsedLeafValue = Fr.fromString(leafValue);
|
|
110
|
-
const witness = await this.handlerAsUtility().utilityGetNoteHashMembershipWitness(parsedBlockHash, parsedLeafValue);
|
|
111
|
-
if (!witness) {
|
|
112
|
-
throw new Error(`Leaf ${leafValue} not found in the note hash tree at block hash ${parsedBlockHash.toString()}.`);
|
|
113
|
-
}
|
|
114
|
-
return witness.toNoirRepresentation();
|
|
115
|
-
}
|
|
116
|
-
async utilityGetArchiveMembershipWitness([blockHash], [leafValue]) {
|
|
117
|
-
const parsedBlockHash = BlockHash.fromString(blockHash);
|
|
118
|
-
const parsedLeafValue = Fr.fromString(leafValue);
|
|
119
|
-
const witness = await this.handlerAsUtility().utilityGetArchiveMembershipWitness(parsedBlockHash, parsedLeafValue);
|
|
120
|
-
if (!witness) {
|
|
121
|
-
throw new Error(`Leaf ${leafValue} not found in the archive tree at block hash ${parsedBlockHash.toString()}.`);
|
|
122
|
-
}
|
|
123
|
-
return witness.toNoirRepresentation();
|
|
124
|
-
}
|
|
125
|
-
async utilityGetNullifierMembershipWitness([blockHash], [nullifier]) {
|
|
126
|
-
const parsedBlockHash = BlockHash.fromString(blockHash);
|
|
127
|
-
const parsedNullifier = Fr.fromString(nullifier);
|
|
128
|
-
const witness = await this.handlerAsUtility().utilityGetNullifierMembershipWitness(parsedBlockHash, parsedNullifier);
|
|
129
|
-
if (!witness) {
|
|
130
|
-
throw new Error(`Nullifier witness not found for nullifier ${parsedNullifier} at block hash ${parsedBlockHash.toString()}.`);
|
|
131
|
-
}
|
|
132
|
-
return witness.toNoirRepresentation();
|
|
133
|
-
}
|
|
134
|
-
async utilityGetLowNullifierMembershipWitness([blockHash], [nullifier]) {
|
|
135
|
-
const parsedBlockHash = BlockHash.fromString(blockHash);
|
|
136
|
-
const parsedNullifier = Fr.fromString(nullifier);
|
|
137
|
-
const witness = await this.handlerAsUtility().utilityGetLowNullifierMembershipWitness(parsedBlockHash, parsedNullifier);
|
|
138
|
-
if (!witness) {
|
|
139
|
-
throw new Error(`Low nullifier witness not found for nullifier ${parsedNullifier} at block hash ${parsedBlockHash.toString()}.`);
|
|
140
|
-
}
|
|
141
|
-
return witness.toNoirRepresentation();
|
|
142
|
-
}
|
|
143
|
-
async utilityGetPublicDataWitness([blockHash], [leafSlot]) {
|
|
144
|
-
const parsedBlockHash = BlockHash.fromString(blockHash);
|
|
145
|
-
const parsedLeafSlot = Fr.fromString(leafSlot);
|
|
146
|
-
const witness = await this.handlerAsUtility().utilityGetPublicDataWitness(parsedBlockHash, parsedLeafSlot);
|
|
147
|
-
if (!witness) {
|
|
148
|
-
throw new Error(`Public data witness not found for slot ${parsedLeafSlot} at block hash ${parsedBlockHash.toString()}.`);
|
|
149
|
-
}
|
|
150
|
-
return witness.toNoirRepresentation();
|
|
142
|
+
// eslint-disable-next-line camelcase
|
|
143
|
+
aztec_utl_getUtilityContext() {
|
|
144
|
+
return callHandler({
|
|
145
|
+
oracle: 'aztec_utl_getUtilityContext',
|
|
146
|
+
inputs: [],
|
|
147
|
+
handler: ()=>this.handlerAsUtility().getUtilityContext()
|
|
148
|
+
});
|
|
151
149
|
}
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
150
|
+
// eslint-disable-next-line camelcase
|
|
151
|
+
aztec_utl_getKeyValidationRequest(...inputs) {
|
|
152
|
+
return callHandler({
|
|
153
|
+
oracle: 'aztec_utl_getKeyValidationRequest',
|
|
154
|
+
inputs,
|
|
155
|
+
handler: ([pkMHash])=>this.handlerAsUtility().getKeyValidationRequest(pkMHash)
|
|
156
|
+
});
|
|
159
157
|
}
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
witness.map(toACVMField)
|
|
168
|
-
];
|
|
158
|
+
// eslint-disable-next-line camelcase
|
|
159
|
+
aztec_utl_getContractInstance(...inputs) {
|
|
160
|
+
return callHandler({
|
|
161
|
+
oracle: 'aztec_utl_getContractInstance',
|
|
162
|
+
inputs,
|
|
163
|
+
handler: ([address])=>this.handlerAsUtility().getContractInstance(address)
|
|
164
|
+
});
|
|
169
165
|
}
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
].map(toACVMField)
|
|
178
|
-
];
|
|
166
|
+
// eslint-disable-next-line camelcase
|
|
167
|
+
aztec_utl_getNoteHashMembershipWitness(...inputs) {
|
|
168
|
+
return callHandler({
|
|
169
|
+
oracle: 'aztec_utl_getNoteHashMembershipWitness',
|
|
170
|
+
inputs,
|
|
171
|
+
handler: ([anchorBlockHash, noteHash])=>this.handlerAsUtility().getNoteHashMembershipWitness(anchorBlockHash, noteHash)
|
|
172
|
+
});
|
|
179
173
|
}
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
randomness: noteData.randomness,
|
|
188
|
-
storageSlot: noteData.storageSlot,
|
|
189
|
-
noteNonce: noteData.noteNonce,
|
|
190
|
-
isPending: noteData.isPending,
|
|
191
|
-
note: noteData.note
|
|
192
|
-
}));
|
|
193
|
-
// Now we convert each sub-array to an array of ACVMField
|
|
194
|
-
const returnDataAsArrayOfACVMFieldArrays = returnDataAsArrayOfPackedHintedNotes.map((subArray)=>subArray.map(toACVMField));
|
|
195
|
-
// At last we convert the array of arrays to a bounded vec of arrays
|
|
196
|
-
return arrayOfArraysToBoundedVecOfArrays(returnDataAsArrayOfACVMFieldArrays, +maxNotes, +packedHintedNoteLength);
|
|
197
|
-
}
|
|
198
|
-
privateNotifyCreatedNote([owner], [storageSlot], [randomness], [noteTypeId], note, [noteHash], [counter]) {
|
|
199
|
-
this.handlerAsPrivate().privateNotifyCreatedNote(AztecAddress.fromString(owner), Fr.fromString(storageSlot), Fr.fromString(randomness), NoteSelector.fromField(Fr.fromString(noteTypeId)), note.map(Fr.fromString), Fr.fromString(noteHash), +counter);
|
|
200
|
-
return Promise.resolve([]);
|
|
201
|
-
}
|
|
202
|
-
async privateNotifyNullifiedNote([innerNullifier], [noteHash], [counter]) {
|
|
203
|
-
await this.handlerAsPrivate().privateNotifyNullifiedNote(Fr.fromString(innerNullifier), Fr.fromString(noteHash), +counter);
|
|
204
|
-
return [];
|
|
205
|
-
}
|
|
206
|
-
async privateNotifyCreatedNullifier([innerNullifier]) {
|
|
207
|
-
await this.handlerAsPrivate().privateNotifyCreatedNullifier(Fr.fromString(innerNullifier));
|
|
208
|
-
return [];
|
|
209
|
-
}
|
|
210
|
-
async privateIsNullifierPending([innerNullifier], [contractAddress]) {
|
|
211
|
-
const isPending = await this.handlerAsPrivate().privateIsNullifierPending(Fr.fromString(innerNullifier), AztecAddress.fromString(contractAddress));
|
|
212
|
-
return [
|
|
213
|
-
toACVMField(isPending)
|
|
214
|
-
];
|
|
174
|
+
// eslint-disable-next-line camelcase
|
|
175
|
+
aztec_utl_getBlockHashMembershipWitness(...inputs) {
|
|
176
|
+
return callHandler({
|
|
177
|
+
oracle: 'aztec_utl_getBlockHashMembershipWitness',
|
|
178
|
+
inputs,
|
|
179
|
+
handler: ([anchorBlockHash, blockHash])=>this.handlerAsUtility().getBlockHashMembershipWitness(anchorBlockHash, blockHash)
|
|
180
|
+
});
|
|
215
181
|
}
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
return
|
|
219
|
-
|
|
220
|
-
|
|
182
|
+
// eslint-disable-next-line camelcase
|
|
183
|
+
aztec_utl_getNullifierMembershipWitness(...inputs) {
|
|
184
|
+
return callHandler({
|
|
185
|
+
oracle: 'aztec_utl_getNullifierMembershipWitness',
|
|
186
|
+
inputs,
|
|
187
|
+
handler: ([blockHash, nullifier])=>this.handlerAsUtility().getNullifierMembershipWitness(blockHash, nullifier)
|
|
188
|
+
});
|
|
221
189
|
}
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
return
|
|
190
|
+
// eslint-disable-next-line camelcase
|
|
191
|
+
aztec_utl_getLowNullifierMembershipWitness(...inputs) {
|
|
192
|
+
return callHandler({
|
|
193
|
+
oracle: 'aztec_utl_getLowNullifierMembershipWitness',
|
|
194
|
+
inputs,
|
|
195
|
+
handler: ([blockHash, nullifier])=>this.handlerAsUtility().getLowNullifierMembershipWitness(blockHash, nullifier)
|
|
196
|
+
});
|
|
225
197
|
}
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
return
|
|
229
|
-
|
|
230
|
-
|
|
198
|
+
// eslint-disable-next-line camelcase
|
|
199
|
+
aztec_utl_getPublicDataWitness(...inputs) {
|
|
200
|
+
return callHandler({
|
|
201
|
+
oracle: 'aztec_utl_getPublicDataWitness',
|
|
202
|
+
inputs,
|
|
203
|
+
handler: ([blockHash, leafSlot])=>this.handlerAsUtility().getPublicDataWitness(blockHash, leafSlot)
|
|
204
|
+
});
|
|
205
|
+
}
|
|
206
|
+
// eslint-disable-next-line camelcase
|
|
207
|
+
aztec_utl_getBlockHeader(...inputs) {
|
|
208
|
+
return callHandler({
|
|
209
|
+
oracle: 'aztec_utl_getBlockHeader',
|
|
210
|
+
inputs,
|
|
211
|
+
handler: ([blockNumber])=>this.handlerAsUtility().getBlockHeader(blockNumber)
|
|
212
|
+
});
|
|
213
|
+
}
|
|
214
|
+
// eslint-disable-next-line camelcase
|
|
215
|
+
aztec_utl_getAuthWitness(...inputs) {
|
|
216
|
+
return callHandler({
|
|
217
|
+
oracle: 'aztec_utl_getAuthWitness',
|
|
218
|
+
inputs,
|
|
219
|
+
handler: ([messageHash])=>this.handlerAsUtility().getAuthWitness(messageHash)
|
|
220
|
+
});
|
|
221
|
+
}
|
|
222
|
+
// eslint-disable-next-line camelcase
|
|
223
|
+
aztec_utl_getPublicKeysAndPartialAddress(...inputs) {
|
|
224
|
+
return callHandler({
|
|
225
|
+
oracle: 'aztec_utl_getPublicKeysAndPartialAddress',
|
|
226
|
+
inputs,
|
|
227
|
+
handler: ([address])=>this.handlerAsUtility().getPublicKeysAndPartialAddress(address)
|
|
228
|
+
});
|
|
229
|
+
}
|
|
230
|
+
// eslint-disable-next-line camelcase
|
|
231
|
+
aztec_utl_getNotes(...inputs) {
|
|
232
|
+
return callHandler({
|
|
233
|
+
oracle: 'aztec_utl_getNotes',
|
|
234
|
+
inputs,
|
|
235
|
+
handler: ([owner, storageSlot, numSelects, selectByIndexes, selectByOffsets, selectByLengths, selectValues, selectComparators, sortByIndexes, sortByOffsets, sortByLengths, sortOrder, limit, offset, status, maxNotes, packedHintedNoteLength])=>this.handlerAsUtility().getNotes(owner, storageSlot, numSelects, selectByIndexes, selectByOffsets, selectByLengths, selectValues, selectComparators, sortByIndexes, sortByOffsets, sortByLengths, sortOrder, limit, offset, status, maxNotes, packedHintedNoteLength)
|
|
236
|
+
});
|
|
237
|
+
}
|
|
238
|
+
// eslint-disable-next-line camelcase
|
|
239
|
+
aztec_prv_notifyCreatedNote(...inputs) {
|
|
240
|
+
return callHandler({
|
|
241
|
+
oracle: 'aztec_prv_notifyCreatedNote',
|
|
242
|
+
inputs,
|
|
243
|
+
handler: ([owner, storageSlot, randomness, noteTypeId, note, noteHash, counter])=>{
|
|
244
|
+
this.handlerAsPrivate().notifyCreatedNote(owner, storageSlot, randomness, noteTypeId, note, noteHash, counter);
|
|
245
|
+
}
|
|
246
|
+
});
|
|
247
|
+
}
|
|
248
|
+
// eslint-disable-next-line camelcase
|
|
249
|
+
aztec_prv_notifyNullifiedNote(...inputs) {
|
|
250
|
+
return callHandler({
|
|
251
|
+
oracle: 'aztec_prv_notifyNullifiedNote',
|
|
252
|
+
inputs,
|
|
253
|
+
handler: ([innerNullifier, noteHash, counter])=>this.handlerAsPrivate().notifyNullifiedNote(innerNullifier, noteHash, counter)
|
|
254
|
+
});
|
|
231
255
|
}
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
256
|
+
// eslint-disable-next-line camelcase
|
|
257
|
+
aztec_prv_notifyCreatedNullifier(...inputs) {
|
|
258
|
+
return callHandler({
|
|
259
|
+
oracle: 'aztec_prv_notifyCreatedNullifier',
|
|
260
|
+
inputs,
|
|
261
|
+
handler: ([innerNullifier])=>this.handlerAsPrivate().notifyCreatedNullifier(innerNullifier)
|
|
262
|
+
});
|
|
263
|
+
}
|
|
264
|
+
// eslint-disable-next-line camelcase
|
|
265
|
+
aztec_prv_isNullifierPending(...inputs) {
|
|
266
|
+
return callHandler({
|
|
267
|
+
oracle: 'aztec_prv_isNullifierPending',
|
|
268
|
+
inputs,
|
|
269
|
+
handler: ([innerNullifier, contractAddress])=>this.handlerAsPrivate().isNullifierPending(innerNullifier, contractAddress)
|
|
270
|
+
});
|
|
271
|
+
}
|
|
272
|
+
// eslint-disable-next-line camelcase
|
|
273
|
+
aztec_utl_doesNullifierExist(...inputs) {
|
|
274
|
+
return callHandler({
|
|
275
|
+
oracle: 'aztec_utl_doesNullifierExist',
|
|
276
|
+
inputs,
|
|
277
|
+
handler: ([innerNullifier])=>this.handlerAsUtility().doesNullifierExist(innerNullifier)
|
|
278
|
+
});
|
|
279
|
+
}
|
|
280
|
+
// eslint-disable-next-line camelcase
|
|
281
|
+
aztec_utl_getL1ToL2MembershipWitness(...inputs) {
|
|
282
|
+
return callHandler({
|
|
283
|
+
oracle: 'aztec_utl_getL1ToL2MembershipWitness',
|
|
284
|
+
inputs,
|
|
285
|
+
handler: ([contractAddress, messageHash, secret])=>this.handlerAsUtility().getL1ToL2MembershipWitness(contractAddress, messageHash, secret)
|
|
286
|
+
});
|
|
287
|
+
}
|
|
288
|
+
// eslint-disable-next-line camelcase
|
|
289
|
+
aztec_utl_getFromPublicStorage(...inputs) {
|
|
290
|
+
return callHandler({
|
|
291
|
+
oracle: 'aztec_utl_getFromPublicStorage',
|
|
292
|
+
inputs,
|
|
293
|
+
handler: ([blockHash, contractAddress, startStorageSlot, numberOfElements])=>this.handlerAsUtility().getFromPublicStorage(blockHash, contractAddress, startStorageSlot, numberOfElements)
|
|
294
|
+
});
|
|
295
|
+
}
|
|
296
|
+
// eslint-disable-next-line camelcase
|
|
297
|
+
aztec_utl_callUtilityFunction(...inputs) {
|
|
298
|
+
return callHandler({
|
|
299
|
+
oracle: 'aztec_utl_callUtilityFunction',
|
|
300
|
+
inputs,
|
|
301
|
+
handler: ([contractAddress, functionSelector, args])=>this.handlerAsUtility().callUtilityFunction(contractAddress, functionSelector, args)
|
|
302
|
+
});
|
|
303
|
+
}
|
|
304
|
+
// eslint-disable-next-line camelcase
|
|
305
|
+
aztec_prv_notifyCreatedContractClassLog(...inputs) {
|
|
306
|
+
return callHandler({
|
|
307
|
+
oracle: 'aztec_prv_notifyCreatedContractClassLog',
|
|
308
|
+
inputs,
|
|
309
|
+
handler: ([log, counter])=>{
|
|
310
|
+
this.handlerAsPrivate().notifyCreatedContractClassLog(log, counter);
|
|
311
|
+
}
|
|
312
|
+
});
|
|
237
313
|
}
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
314
|
+
// eslint-disable-next-line camelcase
|
|
315
|
+
aztec_misc_log(...inputs) {
|
|
316
|
+
return callHandler({
|
|
317
|
+
oracle: 'aztec_misc_log',
|
|
318
|
+
inputs,
|
|
319
|
+
handler: ([level, message, fieldsSize, fields])=>this.handlerAsMisc().log(level, message, fieldsSize, fields)
|
|
320
|
+
});
|
|
244
321
|
}
|
|
245
322
|
// This function's name is directly hardcoded in `circuit_recorder.ts`. Don't forget to update it there if you
|
|
246
323
|
// change the name here.
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
return
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
];
|
|
324
|
+
// eslint-disable-next-line camelcase
|
|
325
|
+
aztec_prv_callPrivateFunction(...inputs) {
|
|
326
|
+
return callHandler({
|
|
327
|
+
oracle: 'aztec_prv_callPrivateFunction',
|
|
328
|
+
inputs,
|
|
329
|
+
handler: ([contractAddress, functionSelector, argsHash, sideEffectCounter, isStaticCall])=>this.handlerAsPrivate().callPrivateFunction(contractAddress, functionSelector, argsHash, sideEffectCounter, isStaticCall)
|
|
330
|
+
});
|
|
255
331
|
}
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
return
|
|
332
|
+
// eslint-disable-next-line camelcase
|
|
333
|
+
aztec_prv_assertValidPublicCalldata(...inputs) {
|
|
334
|
+
return callHandler({
|
|
335
|
+
oracle: 'aztec_prv_assertValidPublicCalldata',
|
|
336
|
+
inputs,
|
|
337
|
+
handler: ([calldataHash])=>this.handlerAsPrivate().assertValidPublicCalldata(calldataHash)
|
|
338
|
+
});
|
|
259
339
|
}
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
return
|
|
340
|
+
// eslint-disable-next-line camelcase
|
|
341
|
+
aztec_prv_notifyRevertiblePhaseStart(...inputs) {
|
|
342
|
+
return callHandler({
|
|
343
|
+
oracle: 'aztec_prv_notifyRevertiblePhaseStart',
|
|
344
|
+
inputs,
|
|
345
|
+
handler: ([minRevertibleSideEffectCounter])=>this.handlerAsPrivate().notifyRevertiblePhaseStart(minRevertibleSideEffectCounter)
|
|
346
|
+
});
|
|
347
|
+
}
|
|
348
|
+
// eslint-disable-next-line camelcase
|
|
349
|
+
aztec_prv_isExecutionInRevertiblePhase(...inputs) {
|
|
350
|
+
return callHandler({
|
|
351
|
+
oracle: 'aztec_prv_isExecutionInRevertiblePhase',
|
|
352
|
+
inputs,
|
|
353
|
+
handler: ([sideEffectCounter])=>this.handlerAsPrivate().isExecutionInRevertiblePhase(sideEffectCounter)
|
|
354
|
+
});
|
|
263
355
|
}
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
return
|
|
356
|
+
// eslint-disable-next-line camelcase
|
|
357
|
+
aztec_prv_getAppTaggingSecret(...inputs) {
|
|
358
|
+
return callHandler({
|
|
359
|
+
oracle: 'aztec_prv_getAppTaggingSecret',
|
|
360
|
+
inputs,
|
|
361
|
+
handler: ([sender, recipient])=>this.handlerAsPrivate().getAppTaggingSecret(sender, recipient)
|
|
362
|
+
});
|
|
267
363
|
}
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
return
|
|
271
|
-
|
|
272
|
-
|
|
364
|
+
// eslint-disable-next-line camelcase
|
|
365
|
+
aztec_prv_getNextTaggingIndex(...inputs) {
|
|
366
|
+
return callHandler({
|
|
367
|
+
oracle: 'aztec_prv_getNextTaggingIndex',
|
|
368
|
+
inputs,
|
|
369
|
+
handler: ([secret, mode])=>this.handlerAsPrivate().getNextTaggingIndex(secret, mode)
|
|
370
|
+
});
|
|
273
371
|
}
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
return
|
|
277
|
-
|
|
278
|
-
|
|
372
|
+
// eslint-disable-next-line camelcase
|
|
373
|
+
aztec_utl_getPendingTaggedLogs(...inputs) {
|
|
374
|
+
return callHandler({
|
|
375
|
+
oracle: 'aztec_utl_getPendingTaggedLogs',
|
|
376
|
+
inputs,
|
|
377
|
+
handler: ([scope, providedSecrets])=>this.handlerAsUtility().getPendingTaggedLogs(scope, providedSecrets)
|
|
378
|
+
});
|
|
279
379
|
}
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
return
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
}
|
|
288
|
-
async utilityBulkRetrieveLogs([contractAddress], [logRetrievalRequestsArrayBaseSlot], [logRetrievalResponsesArrayBaseSlot]) {
|
|
289
|
-
await this.handlerAsUtility().utilityBulkRetrieveLogs(AztecAddress.fromString(contractAddress), Fr.fromString(logRetrievalRequestsArrayBaseSlot), Fr.fromString(logRetrievalResponsesArrayBaseSlot));
|
|
290
|
-
return [];
|
|
291
|
-
}
|
|
292
|
-
async utilityStoreCapsule([contractAddress], [slot], capsule) {
|
|
293
|
-
await this.handlerAsUtility().utilityStoreCapsule(AztecAddress.fromField(Fr.fromString(contractAddress)), Fr.fromString(slot), capsule.map(Fr.fromString));
|
|
294
|
-
return [];
|
|
295
|
-
}
|
|
296
|
-
async utilityLoadCapsule([contractAddress], [slot], [tSize]) {
|
|
297
|
-
const values = await this.handlerAsUtility().utilityLoadCapsule(AztecAddress.fromField(Fr.fromString(contractAddress)), Fr.fromString(slot));
|
|
298
|
-
// We are going to return a Noir Option struct to represent the possibility of null values. Options are a struct
|
|
299
|
-
// with two fields: `some` (a boolean) and `value` (a field array in this case).
|
|
300
|
-
if (values === null) {
|
|
301
|
-
// No data was found so we set `some` to 0 and pad `value` with zeros get the correct return size.
|
|
302
|
-
return [
|
|
303
|
-
toACVMField(0),
|
|
304
|
-
Array(Fr.fromString(tSize).toNumber()).fill(toACVMField(0))
|
|
305
|
-
];
|
|
306
|
-
} else {
|
|
307
|
-
// Data was found so we set `some` to 1 and return it along with `value`.
|
|
308
|
-
return [
|
|
309
|
-
toACVMField(1),
|
|
310
|
-
values.map(toACVMField)
|
|
311
|
-
];
|
|
312
|
-
}
|
|
380
|
+
// eslint-disable-next-line camelcase
|
|
381
|
+
aztec_utl_validateAndStoreEnqueuedNotesAndEvents(...inputs) {
|
|
382
|
+
return callHandler({
|
|
383
|
+
oracle: 'aztec_utl_validateAndStoreEnqueuedNotesAndEvents',
|
|
384
|
+
inputs,
|
|
385
|
+
handler: ([noteValidationRequests, eventValidationRequests, scope])=>this.handlerAsUtility().validateAndStoreEnqueuedNotesAndEvents(noteValidationRequests, eventValidationRequests, scope)
|
|
386
|
+
});
|
|
313
387
|
}
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
return
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
}
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
388
|
+
// eslint-disable-next-line camelcase
|
|
389
|
+
aztec_utl_getLogsByTag(...inputs) {
|
|
390
|
+
return callHandler({
|
|
391
|
+
oracle: 'aztec_utl_getLogsByTag',
|
|
392
|
+
inputs,
|
|
393
|
+
handler: ([requests])=>this.handlerAsUtility().getLogsByTag(requests)
|
|
394
|
+
});
|
|
395
|
+
}
|
|
396
|
+
// eslint-disable-next-line camelcase
|
|
397
|
+
aztec_utl_getMessageContextsByTxHash(...inputs) {
|
|
398
|
+
return callHandler({
|
|
399
|
+
oracle: 'aztec_utl_getMessageContextsByTxHash',
|
|
400
|
+
inputs,
|
|
401
|
+
handler: ([requests])=>this.handlerAsUtility().getMessageContextsByTxHash(requests)
|
|
402
|
+
});
|
|
403
|
+
}
|
|
404
|
+
// eslint-disable-next-line camelcase
|
|
405
|
+
aztec_utl_getTxEffect(...inputs) {
|
|
406
|
+
return callHandler({
|
|
407
|
+
oracle: 'aztec_utl_getTxEffect',
|
|
408
|
+
inputs,
|
|
409
|
+
handler: ([txHash])=>this.handlerAsUtility().getTxEffect(txHash)
|
|
410
|
+
});
|
|
411
|
+
}
|
|
412
|
+
// eslint-disable-next-line camelcase
|
|
413
|
+
aztec_utl_setCapsule(...inputs) {
|
|
414
|
+
return callHandler({
|
|
415
|
+
oracle: 'aztec_utl_setCapsule',
|
|
416
|
+
inputs,
|
|
417
|
+
handler: ([contractAddress, slot, capsule, scope])=>{
|
|
418
|
+
this.handlerAsUtility().setCapsule(contractAddress, slot, capsule, scope);
|
|
419
|
+
}
|
|
420
|
+
});
|
|
421
|
+
}
|
|
422
|
+
// eslint-disable-next-line camelcase
|
|
423
|
+
aztec_utl_getCapsule(...inputs) {
|
|
424
|
+
return callHandler({
|
|
425
|
+
oracle: 'aztec_utl_getCapsule',
|
|
426
|
+
inputs,
|
|
427
|
+
handler: ([contractAddress, slot, tSize, scope])=>this.handlerAsUtility().getCapsule(contractAddress, slot, tSize, scope)
|
|
428
|
+
});
|
|
429
|
+
}
|
|
430
|
+
// eslint-disable-next-line camelcase
|
|
431
|
+
aztec_utl_deleteCapsule(...inputs) {
|
|
432
|
+
return callHandler({
|
|
433
|
+
oracle: 'aztec_utl_deleteCapsule',
|
|
434
|
+
inputs,
|
|
435
|
+
handler: ([contractAddress, slot, scope])=>{
|
|
436
|
+
this.handlerAsUtility().deleteCapsule(contractAddress, slot, scope);
|
|
437
|
+
}
|
|
438
|
+
});
|
|
439
|
+
}
|
|
440
|
+
// eslint-disable-next-line camelcase
|
|
441
|
+
aztec_utl_copyCapsule(...inputs) {
|
|
442
|
+
return callHandler({
|
|
443
|
+
oracle: 'aztec_utl_copyCapsule',
|
|
444
|
+
inputs,
|
|
445
|
+
handler: ([contractAddress, srcSlot, dstSlot, numEntries, scope])=>this.handlerAsUtility().copyCapsule(contractAddress, srcSlot, dstSlot, numEntries, scope)
|
|
446
|
+
});
|
|
447
|
+
}
|
|
448
|
+
// eslint-disable-next-line camelcase
|
|
449
|
+
aztec_utl_pushEphemeral(...inputs) {
|
|
450
|
+
return callHandler({
|
|
451
|
+
oracle: 'aztec_utl_pushEphemeral',
|
|
452
|
+
inputs,
|
|
453
|
+
handler: ([slot, elements])=>this.handlerAsUtility().pushEphemeral(slot, elements)
|
|
454
|
+
});
|
|
455
|
+
}
|
|
456
|
+
// eslint-disable-next-line camelcase
|
|
457
|
+
aztec_utl_popEphemeral(...inputs) {
|
|
458
|
+
return callHandler({
|
|
459
|
+
oracle: 'aztec_utl_popEphemeral',
|
|
460
|
+
inputs,
|
|
461
|
+
handler: ([slot])=>this.handlerAsUtility().popEphemeral(slot)
|
|
462
|
+
});
|
|
463
|
+
}
|
|
464
|
+
// eslint-disable-next-line camelcase
|
|
465
|
+
aztec_utl_getEphemeral(...inputs) {
|
|
466
|
+
return callHandler({
|
|
467
|
+
oracle: 'aztec_utl_getEphemeral',
|
|
468
|
+
inputs,
|
|
469
|
+
handler: ([slot, index])=>this.handlerAsUtility().getEphemeral(slot, index)
|
|
470
|
+
});
|
|
471
|
+
}
|
|
472
|
+
// eslint-disable-next-line camelcase
|
|
473
|
+
aztec_utl_setEphemeral(...inputs) {
|
|
474
|
+
return callHandler({
|
|
475
|
+
oracle: 'aztec_utl_setEphemeral',
|
|
476
|
+
inputs,
|
|
477
|
+
handler: ([slot, index, elements])=>{
|
|
478
|
+
this.handlerAsUtility().setEphemeral(slot, index, elements);
|
|
479
|
+
}
|
|
480
|
+
});
|
|
481
|
+
}
|
|
482
|
+
// eslint-disable-next-line camelcase
|
|
483
|
+
aztec_utl_getEphemeralLen(...inputs) {
|
|
484
|
+
return callHandler({
|
|
485
|
+
oracle: 'aztec_utl_getEphemeralLen',
|
|
486
|
+
inputs,
|
|
487
|
+
handler: ([slot])=>this.handlerAsUtility().getEphemeralLen(slot)
|
|
488
|
+
});
|
|
489
|
+
}
|
|
490
|
+
// eslint-disable-next-line camelcase
|
|
491
|
+
aztec_utl_removeEphemeral(...inputs) {
|
|
492
|
+
return callHandler({
|
|
493
|
+
oracle: 'aztec_utl_removeEphemeral',
|
|
494
|
+
inputs,
|
|
495
|
+
handler: ([slot, index])=>{
|
|
496
|
+
this.handlerAsUtility().removeEphemeral(slot, index);
|
|
497
|
+
}
|
|
498
|
+
});
|
|
499
|
+
}
|
|
500
|
+
// eslint-disable-next-line camelcase
|
|
501
|
+
aztec_utl_clearEphemeral(...inputs) {
|
|
502
|
+
return callHandler({
|
|
503
|
+
oracle: 'aztec_utl_clearEphemeral',
|
|
504
|
+
inputs,
|
|
505
|
+
handler: ([slot])=>{
|
|
506
|
+
this.handlerAsUtility().clearEphemeral(slot);
|
|
507
|
+
}
|
|
508
|
+
});
|
|
509
|
+
}
|
|
510
|
+
// eslint-disable-next-line camelcase
|
|
511
|
+
aztec_utl_decryptAes128(...inputs) {
|
|
512
|
+
return callHandler({
|
|
513
|
+
oracle: 'aztec_utl_decryptAes128',
|
|
514
|
+
inputs,
|
|
515
|
+
handler: ([ciphertext, iv, symKey])=>this.handlerAsUtility().decryptAes128(ciphertext, iv, symKey)
|
|
516
|
+
});
|
|
517
|
+
}
|
|
518
|
+
// eslint-disable-next-line camelcase
|
|
519
|
+
aztec_utl_getSharedSecrets(...inputs) {
|
|
520
|
+
return callHandler({
|
|
521
|
+
oracle: 'aztec_utl_getSharedSecrets',
|
|
522
|
+
inputs,
|
|
523
|
+
handler: ([address, ephPks, contractAddress])=>this.handlerAsUtility().getSharedSecrets(address, ephPks, contractAddress)
|
|
524
|
+
});
|
|
525
|
+
}
|
|
526
|
+
// eslint-disable-next-line camelcase
|
|
527
|
+
aztec_utl_setContractSyncCacheInvalid(...inputs) {
|
|
528
|
+
return callHandler({
|
|
529
|
+
oracle: 'aztec_utl_setContractSyncCacheInvalid',
|
|
530
|
+
inputs,
|
|
531
|
+
handler: ([contractAddress, scopes])=>{
|
|
532
|
+
this.handlerAsUtility().setContractSyncCacheInvalid(contractAddress, scopes);
|
|
533
|
+
}
|
|
534
|
+
});
|
|
351
535
|
}
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
return
|
|
536
|
+
// eslint-disable-next-line camelcase
|
|
537
|
+
aztec_utl_emitOffchainEffect(...inputs) {
|
|
538
|
+
return callHandler({
|
|
539
|
+
oracle: 'aztec_utl_emitOffchainEffect',
|
|
540
|
+
inputs,
|
|
541
|
+
handler: ([data])=>this.handlerAsUtility().emitOffchainEffect(data)
|
|
542
|
+
});
|
|
543
|
+
}
|
|
544
|
+
// eslint-disable-next-line camelcase
|
|
545
|
+
aztec_prv_getSenderForTags() {
|
|
546
|
+
return callHandler({
|
|
547
|
+
oracle: 'aztec_prv_getSenderForTags',
|
|
548
|
+
inputs: [],
|
|
549
|
+
handler: ()=>this.handlerAsPrivate().getSenderForTags()
|
|
550
|
+
});
|
|
355
551
|
}
|
|
356
552
|
}
|