@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
package/src/logs/log_service.ts
CHANGED
|
@@ -1,38 +1,38 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { BlockNumber } from '@aztec/foundation/branded-types';
|
|
2
2
|
import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
|
|
3
3
|
import type { KeyStore } from '@aztec/key-store';
|
|
4
4
|
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
5
|
+
import type { BlockHash, L2TipsProvider } from '@aztec/stdlib/block';
|
|
5
6
|
import type { AztecNode } from '@aztec/stdlib/interfaces/server';
|
|
6
|
-
import {
|
|
7
|
-
ExtendedDirectionalAppTaggingSecret,
|
|
8
|
-
PendingTaggedLog,
|
|
9
|
-
SiloedTag,
|
|
10
|
-
Tag,
|
|
11
|
-
TxScopedL2Log,
|
|
12
|
-
} from '@aztec/stdlib/logs';
|
|
7
|
+
import { AppTaggingSecret, type LogResult, PendingTaggedLog, SiloedTag } from '@aztec/stdlib/logs';
|
|
13
8
|
import type { BlockHeader } from '@aztec/stdlib/tx';
|
|
14
9
|
|
|
15
|
-
import
|
|
16
|
-
|
|
10
|
+
import {
|
|
11
|
+
type LogRetrievalRequest,
|
|
12
|
+
LogSource,
|
|
13
|
+
} from '../contract_function_simulator/noir-structs/log_retrieval_request.js';
|
|
17
14
|
import { LogRetrievalResponse } from '../contract_function_simulator/noir-structs/log_retrieval_response.js';
|
|
18
15
|
import { AddressStore } from '../storage/address_store/address_store.js';
|
|
19
|
-
import { CapsuleStore } from '../storage/capsule_store/capsule_store.js';
|
|
20
16
|
import type { RecipientTaggingStore } from '../storage/tagging_store/recipient_tagging_store.js';
|
|
21
17
|
import type { SenderAddressBookStore } from '../storage/tagging_store/sender_address_book_store.js';
|
|
22
18
|
import {
|
|
23
19
|
getAllPrivateLogsByTags,
|
|
24
20
|
getAllPublicLogsByTagsFromContract,
|
|
25
|
-
|
|
21
|
+
syncTaggedPrivateLogs,
|
|
26
22
|
} from '../tagging/index.js';
|
|
27
23
|
|
|
24
|
+
/** Key used to group requests by their (fromBlock, toBlock) range so each group becomes a single node call. */
|
|
25
|
+
type RangeKey = string;
|
|
26
|
+
const rangeKey = (fromBlock?: BlockNumber, toBlock?: BlockNumber): RangeKey => `${fromBlock ?? ''}-${toBlock ?? ''}`;
|
|
27
|
+
|
|
28
28
|
export class LogService {
|
|
29
29
|
private log: Logger;
|
|
30
30
|
|
|
31
31
|
constructor(
|
|
32
32
|
private readonly aztecNode: AztecNode,
|
|
33
33
|
private readonly anchorBlockHeader: BlockHeader,
|
|
34
|
+
private readonly l2TipsStore: L2TipsProvider,
|
|
34
35
|
private readonly keyStore: KeyStore,
|
|
35
|
-
private readonly capsuleStore: CapsuleStore,
|
|
36
36
|
private readonly recipientTaggingStore: RecipientTaggingStore,
|
|
37
37
|
private readonly senderAddressBookStore: SenderAddressBookStore,
|
|
38
38
|
private readonly addressStore: AddressStore,
|
|
@@ -42,132 +42,170 @@ export class LogService {
|
|
|
42
42
|
this.log = createLogger('pxe:log_service', bindings);
|
|
43
43
|
}
|
|
44
44
|
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
`Found both a public and private log when searching for tag ${request.tag} from contract ${request.contractAddress}`,
|
|
56
|
-
);
|
|
57
|
-
}
|
|
45
|
+
/** Fetches all logs matching each request's tag, returning an array of log arrays (one per request). */
|
|
46
|
+
public async fetchLogsByTag(
|
|
47
|
+
contractAddress: AztecAddress,
|
|
48
|
+
logRetrievalRequests: LogRetrievalRequest[],
|
|
49
|
+
): Promise<LogRetrievalResponse[][]> {
|
|
50
|
+
for (const request of logRetrievalRequests) {
|
|
51
|
+
if (!contractAddress.equals(request.contractAddress)) {
|
|
52
|
+
throw new Error(`Got a log retrieval request from ${request.contractAddress}, expected ${contractAddress}`);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
58
55
|
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
}
|
|
56
|
+
if (logRetrievalRequests.length === 0) {
|
|
57
|
+
return [];
|
|
58
|
+
}
|
|
63
59
|
|
|
64
|
-
async #getPublicLogByTag(tag: Tag, contractAddress: AztecAddress): Promise<LogRetrievalResponse | null> {
|
|
65
60
|
const anchorBlockHash = await this.anchorBlockHeader.hash();
|
|
66
|
-
const allLogsPerTag = await getAllPublicLogsByTagsFromContract(
|
|
67
|
-
this.aztecNode,
|
|
68
|
-
contractAddress,
|
|
69
|
-
[tag],
|
|
70
|
-
anchorBlockHash,
|
|
71
|
-
);
|
|
72
|
-
const logsForTag = allLogsPerTag[0];
|
|
73
|
-
|
|
74
|
-
if (logsForTag.length === 0) {
|
|
75
|
-
return null;
|
|
76
|
-
} else if (logsForTag.length > 1) {
|
|
77
|
-
// TODO(#11627): handle this case
|
|
78
|
-
throw new Error(
|
|
79
|
-
`Got ${logsForTag.length} logs for tag ${tag} and contract ${contractAddress.toString()}. getPublicLogByTag currently only supports a single log per tag`,
|
|
80
|
-
);
|
|
81
|
-
}
|
|
82
61
|
|
|
83
|
-
const
|
|
62
|
+
const [publicLogsPerRequest, privateLogsPerRequest] = await Promise.all([
|
|
63
|
+
this.#fetchPublicLogs(contractAddress, logRetrievalRequests, anchorBlockHash),
|
|
64
|
+
this.#fetchPrivateLogs(logRetrievalRequests, anchorBlockHash),
|
|
65
|
+
]);
|
|
84
66
|
|
|
85
|
-
return
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
scopedLog.firstNullifier,
|
|
90
|
-
);
|
|
67
|
+
return logRetrievalRequests.map((_request, i) => [
|
|
68
|
+
...publicLogsPerRequest[i].map(LogService.#toLogRetrievalResponse),
|
|
69
|
+
...privateLogsPerRequest[i].map(LogService.#toLogRetrievalResponse),
|
|
70
|
+
]);
|
|
91
71
|
}
|
|
92
72
|
|
|
93
|
-
async #
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
// TODO(#11627): handle this case
|
|
102
|
-
throw new Error(
|
|
103
|
-
`Got ${logsForTag.length} logs for tag ${siloedTag}. getPrivateLogByTag currently only supports a single log per tag`,
|
|
104
|
-
);
|
|
73
|
+
async #fetchPublicLogs(
|
|
74
|
+
contractAddress: AztecAddress,
|
|
75
|
+
requests: LogRetrievalRequest[],
|
|
76
|
+
anchorBlockHash: BlockHash,
|
|
77
|
+
): Promise<LogResult[][]> {
|
|
78
|
+
const indices = requests.flatMap((r, i) => (r.source !== LogSource.PRIVATE ? [i] : []));
|
|
79
|
+
if (indices.length === 0) {
|
|
80
|
+
return requests.map(() => []);
|
|
105
81
|
}
|
|
106
82
|
|
|
107
|
-
const
|
|
83
|
+
const resultsPerRequest: LogResult[][] = requests.map(() => []);
|
|
84
|
+
const groups = LogService.#groupByRange(indices.map(i => ({ index: i, request: requests[i] })));
|
|
108
85
|
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
86
|
+
await Promise.all(
|
|
87
|
+
Array.from(groups.values()).map(async group => {
|
|
88
|
+
const tags = group.entries.map(e => e.request.tag);
|
|
89
|
+
const results = await getAllPublicLogsByTagsFromContract(
|
|
90
|
+
this.aztecNode,
|
|
91
|
+
contractAddress,
|
|
92
|
+
tags,
|
|
93
|
+
anchorBlockHash,
|
|
94
|
+
{ fromBlock: group.fromBlock, toBlock: group.toBlock, includeEffects: true },
|
|
95
|
+
);
|
|
96
|
+
group.entries.forEach((entry, i) => {
|
|
97
|
+
resultsPerRequest[entry.index] = results[i];
|
|
98
|
+
});
|
|
99
|
+
}),
|
|
114
100
|
);
|
|
115
|
-
}
|
|
116
101
|
|
|
117
|
-
|
|
118
|
-
|
|
102
|
+
return resultsPerRequest;
|
|
103
|
+
}
|
|
119
104
|
|
|
120
|
-
|
|
121
|
-
const
|
|
122
|
-
|
|
105
|
+
async #fetchPrivateLogs(requests: LogRetrievalRequest[], anchorBlockHash: BlockHash): Promise<LogResult[][]> {
|
|
106
|
+
const indices = requests.flatMap((r, i) => (r.source !== LogSource.PUBLIC ? [i] : []));
|
|
107
|
+
if (indices.length === 0) {
|
|
108
|
+
return requests.map(() => []);
|
|
109
|
+
}
|
|
123
110
|
|
|
124
|
-
|
|
125
|
-
const
|
|
111
|
+
const resultsPerRequest: LogResult[][] = requests.map(() => []);
|
|
112
|
+
const groups = LogService.#groupByRange(indices.map(i => ({ index: i, request: requests[i] })));
|
|
126
113
|
|
|
127
|
-
// For each recipient, fetch secrets, load logs, and store them.
|
|
128
|
-
// We run these per-recipient tasks in parallel so that logs are loaded for all recipients concurrently.
|
|
129
114
|
await Promise.all(
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
// Load logs for all sender-recipient pairs in parallel
|
|
135
|
-
const logArrays = await Promise.all(
|
|
136
|
-
secrets.map(secret =>
|
|
137
|
-
loadPrivateLogsForSenderRecipientPair(
|
|
138
|
-
secret,
|
|
139
|
-
this.aztecNode,
|
|
140
|
-
this.recipientTaggingStore,
|
|
141
|
-
anchorBlockNumber,
|
|
142
|
-
anchorBlockHash,
|
|
143
|
-
this.jobId,
|
|
144
|
-
),
|
|
145
|
-
),
|
|
115
|
+
Array.from(groups.values()).map(async group => {
|
|
116
|
+
const siloedTags = await Promise.all(
|
|
117
|
+
group.entries.map(e => SiloedTag.computeFromTagAndApp(e.request.tag, e.request.contractAddress)),
|
|
146
118
|
);
|
|
119
|
+
const results = await getAllPrivateLogsByTags(this.aztecNode, siloedTags, anchorBlockHash, {
|
|
120
|
+
fromBlock: group.fromBlock,
|
|
121
|
+
toBlock: group.toBlock,
|
|
122
|
+
includeEffects: true,
|
|
123
|
+
});
|
|
124
|
+
group.entries.forEach((entry, i) => {
|
|
125
|
+
resultsPerRequest[entry.index] = results[i];
|
|
126
|
+
});
|
|
127
|
+
}),
|
|
128
|
+
);
|
|
147
129
|
|
|
148
|
-
|
|
149
|
-
|
|
130
|
+
return resultsPerRequest;
|
|
131
|
+
}
|
|
150
132
|
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
133
|
+
/**
|
|
134
|
+
* Groups requests by their (fromBlock, toBlock) range so each distinct range becomes a single node call with
|
|
135
|
+
* the range pushed down into the query (no in-memory filter).
|
|
136
|
+
*/
|
|
137
|
+
static #groupByRange(
|
|
138
|
+
entries: Array<{ index: number; request: LogRetrievalRequest }>,
|
|
139
|
+
): Map<RangeKey, { fromBlock?: BlockNumber; toBlock?: BlockNumber; entries: typeof entries }> {
|
|
140
|
+
const groups = new Map<RangeKey, { fromBlock?: BlockNumber; toBlock?: BlockNumber; entries: typeof entries }>();
|
|
141
|
+
for (const entry of entries) {
|
|
142
|
+
const key = rangeKey(entry.request.fromBlock, entry.request.toBlock);
|
|
143
|
+
const existing = groups.get(key);
|
|
144
|
+
if (existing) {
|
|
145
|
+
existing.entries.push(entry);
|
|
146
|
+
} else {
|
|
147
|
+
groups.set(key, { fromBlock: entry.request.fromBlock, toBlock: entry.request.toBlock, entries: [entry] });
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
return groups;
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
static #toLogRetrievalResponse(log: LogResult): LogRetrievalResponse {
|
|
154
|
+
// includeEffects: true was used, so noteHashes and nullifiers are populated. Every tx has at least one nullifier
|
|
155
|
+
// (the first nullifier derived from the tx hash); empty here would indicate a buggy node.
|
|
156
|
+
const noteHashes = log.noteHashes!;
|
|
157
|
+
const nullifiers = log.nullifiers!;
|
|
158
|
+
if (nullifiers.length === 0) {
|
|
159
|
+
throw new Error(`Log for tx ${log.txHash} returned no nullifiers from the node`);
|
|
160
|
+
}
|
|
161
|
+
return new LogRetrievalResponse(
|
|
162
|
+
log.logData.slice(1), // Skip the tag
|
|
163
|
+
log.txHash,
|
|
164
|
+
noteHashes,
|
|
165
|
+
nullifiers[0],
|
|
156
166
|
);
|
|
157
167
|
}
|
|
158
168
|
|
|
159
|
-
async
|
|
169
|
+
public async fetchTaggedLogs(
|
|
160
170
|
contractAddress: AztecAddress,
|
|
161
171
|
recipient: AztecAddress,
|
|
162
|
-
|
|
172
|
+
providedSecrets: AppTaggingSecret[],
|
|
173
|
+
): Promise<PendingTaggedLog[]> {
|
|
174
|
+
this.log.verbose(`Fetching tagged logs for ${contractAddress.toString()}`);
|
|
175
|
+
|
|
176
|
+
const l2Tips = await this.l2TipsStore.getL2Tips();
|
|
177
|
+
// The secrets PXE derives or stores internally, plus any the app supplies explicitly for secrets PXE cannot
|
|
178
|
+
// enumerate itself (e.g. handshake-derived ones).
|
|
179
|
+
const secrets = [...(await this.#getSecretsForSenders(contractAddress, recipient)), ...providedSecrets];
|
|
180
|
+
|
|
181
|
+
const logs = await syncTaggedPrivateLogs(
|
|
182
|
+
secrets,
|
|
183
|
+
this.aztecNode,
|
|
184
|
+
this.recipientTaggingStore,
|
|
185
|
+
this.anchorBlockHeader,
|
|
186
|
+
l2Tips.finalized.block.number,
|
|
187
|
+
this.jobId,
|
|
188
|
+
);
|
|
189
|
+
|
|
190
|
+
return logs.map(log => {
|
|
191
|
+
const noteHashes = log.noteHashes!;
|
|
192
|
+
const nullifiers = log.nullifiers!;
|
|
193
|
+
if (nullifiers.length === 0) {
|
|
194
|
+
throw new Error(`Log for tx ${log.txHash} returned no nullifiers from the node`);
|
|
195
|
+
}
|
|
196
|
+
return new PendingTaggedLog(log.logData, log.txHash, noteHashes, nullifiers[0]);
|
|
197
|
+
});
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
async #getSecretsForSenders(contractAddress: AztecAddress, recipient: AztecAddress): Promise<AppTaggingSecret[]> {
|
|
163
201
|
const recipientCompleteAddress = await this.addressStore.getCompleteAddress(recipient);
|
|
164
202
|
if (!recipientCompleteAddress) {
|
|
165
203
|
return [];
|
|
166
204
|
}
|
|
167
205
|
const recipientIvsk = await this.keyStore.getMasterIncomingViewingSecretKey(recipient);
|
|
168
206
|
|
|
169
|
-
// We implicitly add all PXE accounts as senders, this helps us
|
|
170
|
-
// (recipient = us, sender = us)
|
|
207
|
+
// We implicitly add all PXE accounts as senders, this helps us find tagged logs with messages that are sent to a
|
|
208
|
+
// local account (recipient = us, sender = us)
|
|
171
209
|
const allSenders = [...(await this.senderAddressBookStore.getSenders()), ...(await this.keyStore.getAccounts())];
|
|
172
210
|
|
|
173
211
|
// We deduplicate the senders by adding them to a set and then converting the set back to an array
|
|
@@ -176,38 +214,24 @@ export class LogService {
|
|
|
176
214
|
);
|
|
177
215
|
|
|
178
216
|
return Promise.all(
|
|
179
|
-
deduplicatedSenders.map(sender => {
|
|
180
|
-
|
|
217
|
+
deduplicatedSenders.map(async sender => {
|
|
218
|
+
const secret = await AppTaggingSecret.computeUnconstrained(
|
|
181
219
|
recipientCompleteAddress,
|
|
182
220
|
recipientIvsk,
|
|
183
221
|
sender,
|
|
184
222
|
contractAddress,
|
|
185
223
|
recipient,
|
|
186
224
|
);
|
|
187
|
-
}),
|
|
188
|
-
);
|
|
189
|
-
}
|
|
190
225
|
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
// Build all pending tagged logs from the scoped logs
|
|
198
|
-
const pendingTaggedLogs = privateLogs.map(scopedLog => {
|
|
199
|
-
const pendingTaggedLog = new PendingTaggedLog(
|
|
200
|
-
scopedLog.logData,
|
|
201
|
-
scopedLog.txHash,
|
|
202
|
-
scopedLog.noteHashes,
|
|
203
|
-
scopedLog.firstNullifier,
|
|
204
|
-
recipient,
|
|
205
|
-
);
|
|
206
|
-
|
|
207
|
-
return pendingTaggedLog.toFields();
|
|
208
|
-
});
|
|
226
|
+
if (!secret) {
|
|
227
|
+
// Note that all senders originate from either the SenderAddressBookStore or the KeyStore.
|
|
228
|
+
throw new Error(
|
|
229
|
+
`Failed to compute a tagging secret for sender ${sender} - this implies this is an invalid address, which should not happen as they have been previously registered in PXE.`,
|
|
230
|
+
);
|
|
231
|
+
}
|
|
209
232
|
|
|
210
|
-
|
|
211
|
-
|
|
233
|
+
return secret;
|
|
234
|
+
}),
|
|
235
|
+
);
|
|
212
236
|
}
|
|
213
237
|
}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
+
import { uniqueBy } from '@aztec/foundation/collection';
|
|
1
2
|
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
2
3
|
import type { AztecNode } from '@aztec/stdlib/interfaces/server';
|
|
3
|
-
import {
|
|
4
|
-
|
|
5
|
-
import { MessageTxContext } from '../contract_function_simulator/noir-structs/message_tx_context.js';
|
|
4
|
+
import { MessageContext } from '@aztec/stdlib/logs';
|
|
5
|
+
import { type IndexedTxEffect, TxHash } from '@aztec/stdlib/tx';
|
|
6
6
|
|
|
7
7
|
/** Resolves transaction hashes into the context needed to process messages. */
|
|
8
8
|
export class MessageContextService {
|
|
@@ -15,31 +15,48 @@ export class MessageContextService {
|
|
|
15
15
|
* process messages that originated from that transaction. Returns `null` for tx hashes that are zero, not yet
|
|
16
16
|
* available, or in blocks beyond the anchor block.
|
|
17
17
|
*/
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
18
|
+
async getMessageContextsByTxHash(txHashes: Fr[], anchorBlockNumber: number): Promise<(MessageContext | null)[]> {
|
|
19
|
+
const nonZeroTxHashes = txHashes.filter(h => !h.isZero()).map(h => TxHash.fromField(h));
|
|
20
|
+
const uniqueTxHashes = uniqueBy(nonZeroTxHashes, h => h.toString());
|
|
21
|
+
const fetched = await Promise.all(
|
|
22
|
+
uniqueTxHashes.map(h => this.aztecNode.getTxReceipt(h, { includeTxEffect: true })),
|
|
23
|
+
);
|
|
24
|
+
const txEffects = new Map(
|
|
25
|
+
uniqueTxHashes
|
|
26
|
+
.map((h, i): [string, IndexedTxEffect | undefined] => {
|
|
27
|
+
const receipt = fetched[i];
|
|
28
|
+
if (!receipt.isMined() || !receipt.txEffect) {
|
|
29
|
+
return [h.toString(), undefined];
|
|
30
|
+
}
|
|
31
|
+
return [
|
|
32
|
+
h.toString(),
|
|
33
|
+
{
|
|
34
|
+
data: receipt.txEffect,
|
|
35
|
+
l2BlockNumber: receipt.blockNumber,
|
|
36
|
+
l2BlockHash: receipt.blockHash,
|
|
37
|
+
txIndexInBlock: receipt.txIndexInBlock,
|
|
38
|
+
slotNumber: receipt.slotNumber,
|
|
39
|
+
},
|
|
40
|
+
];
|
|
41
|
+
})
|
|
42
|
+
.filter((entry): entry is [string, IndexedTxEffect] => entry[1] !== undefined),
|
|
43
|
+
);
|
|
27
44
|
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
45
|
+
return txHashes.map(txHashField => {
|
|
46
|
+
const txHash = TxHash.fromField(txHashField);
|
|
47
|
+
const txEffect = txEffects.get(txHash.toString());
|
|
48
|
+
if (!txEffect || txEffect.l2BlockNumber > anchorBlockNumber) {
|
|
49
|
+
return null;
|
|
50
|
+
}
|
|
33
51
|
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
52
|
+
// Every tx has at least one nullifier (the first nullifier derived from the tx hash). Hitting this condition
|
|
53
|
+
// would mean a buggy node, but since we need to access data.nullifiers[0], the defensive check does no harm.
|
|
54
|
+
const data = txEffect.data;
|
|
55
|
+
if (data.nullifiers.length === 0) {
|
|
56
|
+
throw new Error(`Tx effect for ${txHash} has no nullifiers`);
|
|
57
|
+
}
|
|
40
58
|
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
);
|
|
59
|
+
return new MessageContext(data.txHash, data.noteHashes, data.nullifiers[0]);
|
|
60
|
+
});
|
|
44
61
|
}
|
|
45
62
|
}
|