@aztec/pxe 0.0.1-commit.e558bd1c → 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 +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 +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 +65 -30
- package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
- package/dest/contract_function_simulator/contract_function_simulator.js +215 -76
- 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 -287
- 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 -97
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/private_execution_oracle.js +140 -109
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +146 -72
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +433 -157
- 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 +8 -7
- package/dest/contract_sync/contract_sync_service.d.ts.map +1 -1
- package/dest/contract_sync/contract_sync_service.js +93 -40
- package/dest/contract_sync/helpers.d.ts +2 -3
- 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 +5 -11
- package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
- package/dest/debug/pxe_debug_utils.js +4 -13
- 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 +4 -2
- package/dest/entrypoints/server/index.d.ts.map +1 -1
- package/dest/entrypoints/server/index.js +3 -1
- package/dest/entrypoints/server/utils.d.ts +4 -3
- package/dest/entrypoints/server/utils.d.ts.map +1 -1
- package/dest/entrypoints/server/utils.js +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 +130 -81
- 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 +119 -24
- package/dest/pxe.d.ts.map +1 -1
- package/dest/pxe.js +223 -137
- 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 +3 -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 +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 +15 -9
- package/src/config/package_info.ts +1 -1
- package/src/contract_function_simulator/contract_function_simulator.ts +390 -138
- 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 +559 -485
- 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 +170 -203
- package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +646 -236
- 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 +125 -65
- package/src/contract_sync/helpers.ts +13 -20
- package/src/debug/pxe_debug_utils.ts +11 -22
- 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 +3 -1
- 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 +160 -143
- 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 +393 -178
- 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 +5 -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/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
package/src/logs/log_service.ts
CHANGED
|
@@ -1,32 +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 {
|
|
5
|
+
import type { BlockHash, L2TipsProvider } from '@aztec/stdlib/block';
|
|
6
6
|
import type { AztecNode } from '@aztec/stdlib/interfaces/server';
|
|
7
|
-
import {
|
|
7
|
+
import { AppTaggingSecret, type LogResult, PendingTaggedLog, SiloedTag } from '@aztec/stdlib/logs';
|
|
8
8
|
import type { BlockHeader } from '@aztec/stdlib/tx';
|
|
9
9
|
|
|
10
|
-
import
|
|
10
|
+
import {
|
|
11
|
+
type LogRetrievalRequest,
|
|
12
|
+
LogSource,
|
|
13
|
+
} from '../contract_function_simulator/noir-structs/log_retrieval_request.js';
|
|
11
14
|
import { LogRetrievalResponse } from '../contract_function_simulator/noir-structs/log_retrieval_response.js';
|
|
12
15
|
import { AddressStore } from '../storage/address_store/address_store.js';
|
|
13
|
-
import { CapsuleStore } from '../storage/capsule_store/capsule_store.js';
|
|
14
16
|
import type { RecipientTaggingStore } from '../storage/tagging_store/recipient_tagging_store.js';
|
|
15
17
|
import type { SenderAddressBookStore } from '../storage/tagging_store/sender_address_book_store.js';
|
|
16
18
|
import {
|
|
17
19
|
getAllPrivateLogsByTags,
|
|
18
20
|
getAllPublicLogsByTagsFromContract,
|
|
19
|
-
|
|
21
|
+
syncTaggedPrivateLogs,
|
|
20
22
|
} from '../tagging/index.js';
|
|
21
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
|
+
|
|
22
28
|
export class LogService {
|
|
23
29
|
private log: Logger;
|
|
24
30
|
|
|
25
31
|
constructor(
|
|
26
32
|
private readonly aztecNode: AztecNode,
|
|
27
33
|
private readonly anchorBlockHeader: BlockHeader,
|
|
34
|
+
private readonly l2TipsStore: L2TipsProvider,
|
|
28
35
|
private readonly keyStore: KeyStore,
|
|
29
|
-
private readonly capsuleStore: CapsuleStore,
|
|
30
36
|
private readonly recipientTaggingStore: RecipientTaggingStore,
|
|
31
37
|
private readonly senderAddressBookStore: SenderAddressBookStore,
|
|
32
38
|
private readonly addressStore: AddressStore,
|
|
@@ -36,134 +42,170 @@ export class LogService {
|
|
|
36
42
|
this.log = createLogger('pxe:log_service', bindings);
|
|
37
43
|
}
|
|
38
44
|
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
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
|
+
}
|
|
46
55
|
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
56
|
+
if (logRetrievalRequests.length === 0) {
|
|
57
|
+
return [];
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
const anchorBlockHash = await this.anchorBlockHeader.hash();
|
|
61
|
+
|
|
62
|
+
const [publicLogsPerRequest, privateLogsPerRequest] = await Promise.all([
|
|
63
|
+
this.#fetchPublicLogs(contractAddress, logRetrievalRequests, anchorBlockHash),
|
|
64
|
+
this.#fetchPrivateLogs(logRetrievalRequests, anchorBlockHash),
|
|
65
|
+
]);
|
|
66
|
+
|
|
67
|
+
return logRetrievalRequests.map((_request, i) => [
|
|
68
|
+
...publicLogsPerRequest[i].map(LogService.#toLogRetrievalResponse),
|
|
69
|
+
...privateLogsPerRequest[i].map(LogService.#toLogRetrievalResponse),
|
|
70
|
+
]);
|
|
71
|
+
}
|
|
72
|
+
|
|
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(() => []);
|
|
81
|
+
}
|
|
52
82
|
|
|
53
|
-
|
|
83
|
+
const resultsPerRequest: LogResult[][] = requests.map(() => []);
|
|
84
|
+
const groups = LogService.#groupByRange(indices.map(i => ({ index: i, request: requests[i] })));
|
|
85
|
+
|
|
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
|
+
});
|
|
54
99
|
}),
|
|
55
100
|
);
|
|
101
|
+
|
|
102
|
+
return resultsPerRequest;
|
|
56
103
|
}
|
|
57
104
|
|
|
58
|
-
async #
|
|
59
|
-
const
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
contractAddress,
|
|
63
|
-
[tag],
|
|
64
|
-
anchorBlockHash,
|
|
65
|
-
);
|
|
66
|
-
const logsForTag = allLogsPerTag[0];
|
|
67
|
-
|
|
68
|
-
if (logsForTag.length === 0) {
|
|
69
|
-
return null;
|
|
70
|
-
} else if (logsForTag.length > 1) {
|
|
71
|
-
// TODO(#11627): handle this case
|
|
72
|
-
throw new Error(
|
|
73
|
-
`Got ${logsForTag.length} logs for tag ${tag} and contract ${contractAddress.toString()}. getPublicLogByTag currently only supports a single log per tag`,
|
|
74
|
-
);
|
|
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(() => []);
|
|
75
109
|
}
|
|
76
110
|
|
|
77
|
-
const
|
|
111
|
+
const resultsPerRequest: LogResult[][] = requests.map(() => []);
|
|
112
|
+
const groups = LogService.#groupByRange(indices.map(i => ({ index: i, request: requests[i] })));
|
|
78
113
|
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
114
|
+
await Promise.all(
|
|
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)),
|
|
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
|
+
}),
|
|
84
128
|
);
|
|
129
|
+
|
|
130
|
+
return resultsPerRequest;
|
|
85
131
|
}
|
|
86
132
|
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
)
|
|
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
|
+
}
|
|
99
149
|
}
|
|
150
|
+
return groups;
|
|
151
|
+
}
|
|
100
152
|
|
|
101
|
-
|
|
102
|
-
|
|
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
|
+
}
|
|
103
161
|
return new LogRetrievalResponse(
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
162
|
+
log.logData.slice(1), // Skip the tag
|
|
163
|
+
log.txHash,
|
|
164
|
+
noteHashes,
|
|
165
|
+
nullifiers[0],
|
|
108
166
|
);
|
|
109
167
|
}
|
|
110
168
|
|
|
111
169
|
public async fetchTaggedLogs(
|
|
112
170
|
contractAddress: AztecAddress,
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
) {
|
|
171
|
+
recipient: AztecAddress,
|
|
172
|
+
providedSecrets: AppTaggingSecret[],
|
|
173
|
+
): Promise<PendingTaggedLog[]> {
|
|
116
174
|
this.log.verbose(`Fetching tagged logs for ${contractAddress.toString()}`);
|
|
117
175
|
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
// Determine recipients: use scopes if provided, otherwise get all accounts
|
|
123
|
-
const recipients = scopes && scopes.length > 0 ? scopes : await this.keyStore.getAccounts();
|
|
124
|
-
|
|
125
|
-
// For each recipient, fetch secrets, load logs, and store them.
|
|
126
|
-
// We run these per-recipient tasks in parallel so that logs are loaded for all recipients concurrently.
|
|
127
|
-
await Promise.all(
|
|
128
|
-
recipients.map(async recipient => {
|
|
129
|
-
// Get all secrets for this recipient (one per sender)
|
|
130
|
-
const secrets = await this.#getSecretsForSenders(contractAddress, recipient);
|
|
131
|
-
|
|
132
|
-
// Load logs for all sender-recipient pairs in parallel
|
|
133
|
-
const logArrays = await Promise.all(
|
|
134
|
-
secrets.map(secret =>
|
|
135
|
-
loadPrivateLogsForSenderRecipientPair(
|
|
136
|
-
secret,
|
|
137
|
-
contractAddress,
|
|
138
|
-
this.aztecNode,
|
|
139
|
-
this.recipientTaggingStore,
|
|
140
|
-
anchorBlockNumber,
|
|
141
|
-
anchorBlockHash,
|
|
142
|
-
this.jobId,
|
|
143
|
-
),
|
|
144
|
-
),
|
|
145
|
-
);
|
|
146
|
-
|
|
147
|
-
// Flatten all logs from all secrets
|
|
148
|
-
const allLogs = logArrays.flat();
|
|
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];
|
|
149
180
|
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
181
|
+
const logs = await syncTaggedPrivateLogs(
|
|
182
|
+
secrets,
|
|
183
|
+
this.aztecNode,
|
|
184
|
+
this.recipientTaggingStore,
|
|
185
|
+
this.anchorBlockHeader,
|
|
186
|
+
l2Tips.finalized.block.number,
|
|
187
|
+
this.jobId,
|
|
155
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
|
+
});
|
|
156
198
|
}
|
|
157
199
|
|
|
158
|
-
async #getSecretsForSenders(
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
200
|
+
async #getSecretsForSenders(contractAddress: AztecAddress, recipient: AztecAddress): Promise<AppTaggingSecret[]> {
|
|
201
|
+
const recipientCompleteAddress = await this.addressStore.getCompleteAddress(recipient);
|
|
202
|
+
if (!recipientCompleteAddress) {
|
|
203
|
+
return [];
|
|
204
|
+
}
|
|
163
205
|
const recipientIvsk = await this.keyStore.getMasterIncomingViewingSecretKey(recipient);
|
|
164
206
|
|
|
165
|
-
// We implicitly add all PXE accounts as senders, this helps us
|
|
166
|
-
// (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)
|
|
167
209
|
const allSenders = [...(await this.senderAddressBookStore.getSenders()), ...(await this.keyStore.getAccounts())];
|
|
168
210
|
|
|
169
211
|
// We deduplicate the senders by adding them to a set and then converting the set back to an array
|
|
@@ -172,49 +214,24 @@ export class LogService {
|
|
|
172
214
|
);
|
|
173
215
|
|
|
174
216
|
return Promise.all(
|
|
175
|
-
deduplicatedSenders.map(sender => {
|
|
176
|
-
|
|
217
|
+
deduplicatedSenders.map(async sender => {
|
|
218
|
+
const secret = await AppTaggingSecret.computeUnconstrained(
|
|
177
219
|
recipientCompleteAddress,
|
|
178
220
|
recipientIvsk,
|
|
179
221
|
sender,
|
|
180
222
|
contractAddress,
|
|
181
223
|
recipient,
|
|
182
224
|
);
|
|
183
|
-
}),
|
|
184
|
-
);
|
|
185
|
-
}
|
|
186
|
-
|
|
187
|
-
#storePendingTaggedLogs(
|
|
188
|
-
contractAddress: AztecAddress,
|
|
189
|
-
capsuleArrayBaseSlot: Fr,
|
|
190
|
-
recipient: AztecAddress,
|
|
191
|
-
privateLogs: TxScopedL2Log[],
|
|
192
|
-
) {
|
|
193
|
-
// Build all pending tagged logs from the scoped logs
|
|
194
|
-
const pendingTaggedLogs = privateLogs.map(scopedLog => {
|
|
195
|
-
const pendingTaggedLog = new PendingTaggedLog(
|
|
196
|
-
scopedLog.logData,
|
|
197
|
-
scopedLog.txHash,
|
|
198
|
-
scopedLog.noteHashes,
|
|
199
|
-
scopedLog.firstNullifier,
|
|
200
|
-
recipient,
|
|
201
|
-
);
|
|
202
|
-
|
|
203
|
-
return pendingTaggedLog.toFields();
|
|
204
|
-
});
|
|
205
225
|
|
|
206
|
-
|
|
207
|
-
|
|
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
|
-
|
|
212
|
-
|
|
213
|
-
throw new Error(
|
|
214
|
-
`No public key registered for address ${account}.
|
|
215
|
-
Register it by calling pxe.addAccount(...).\nSee docs for context: https://docs.aztec.network/developers/resources/debugging/aztecnr-errors#simulation-error-no-public-key-registered-for-address-0x0-register-it-by-calling-pxeregisterrecipient-or-pxeregisteraccount`,
|
|
216
|
-
);
|
|
217
|
-
}
|
|
218
|
-
return completeAddress;
|
|
233
|
+
return secret;
|
|
234
|
+
}),
|
|
235
|
+
);
|
|
219
236
|
}
|
|
220
237
|
}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { uniqueBy } from '@aztec/foundation/collection';
|
|
2
|
+
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
3
|
+
import type { AztecNode } from '@aztec/stdlib/interfaces/server';
|
|
4
|
+
import { MessageContext } from '@aztec/stdlib/logs';
|
|
5
|
+
import { type IndexedTxEffect, TxHash } from '@aztec/stdlib/tx';
|
|
6
|
+
|
|
7
|
+
/** Resolves transaction hashes into the context needed to process messages. */
|
|
8
|
+
export class MessageContextService {
|
|
9
|
+
constructor(private readonly aztecNode: AztecNode) {}
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* Resolves a list of tx hashes into their message contexts.
|
|
13
|
+
*
|
|
14
|
+
* For each tx hash, looks up the corresponding tx effect and extracts the note hashes and first nullifier needed to
|
|
15
|
+
* process messages that originated from that transaction. Returns `null` for tx hashes that are zero, not yet
|
|
16
|
+
* available, or in blocks beyond the anchor block.
|
|
17
|
+
*/
|
|
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
|
+
);
|
|
44
|
+
|
|
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
|
+
}
|
|
51
|
+
|
|
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
|
+
}
|
|
58
|
+
|
|
59
|
+
return new MessageContext(data.txHash, data.noteHashes, data.nullifiers[0]);
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
}
|