@aztec/pxe 0.0.1-commit.03f7ef2 → 0.0.1-commit.04d373f
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dest/bin/check_oracle_version.d.ts +12 -2
- package/dest/bin/check_oracle_version.d.ts.map +1 -1
- package/dest/bin/check_oracle_version.js +32 -26
- package/dest/bin/index.d.ts +2 -0
- package/dest/bin/index.d.ts.map +1 -0
- package/dest/bin/index.js +1 -0
- package/dest/block_synchronizer/block_stream_source.d.ts +10 -0
- package/dest/block_synchronizer/block_stream_source.d.ts.map +1 -0
- package/dest/block_synchronizer/block_stream_source.js +62 -0
- package/dest/block_synchronizer/block_synchronizer.d.ts +22 -12
- package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
- package/dest/block_synchronizer/block_synchronizer.js +101 -35
- package/dest/config/index.d.ts +10 -2
- package/dest/config/index.d.ts.map +1 -1
- package/dest/config/index.js +17 -2
- package/dest/config/package_info.js +1 -1
- package/dest/contract_function_simulator/benchmarked_node.d.ts +9 -0
- package/dest/contract_function_simulator/benchmarked_node.d.ts.map +1 -0
- package/dest/contract_function_simulator/benchmarked_node.js +77 -0
- package/dest/contract_function_simulator/contract_function_simulator.d.ts +77 -41
- package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
- package/dest/contract_function_simulator/contract_function_simulator.js +251 -96
- package/dest/contract_function_simulator/ephemeral_array_service.d.ts +28 -0
- package/dest/contract_function_simulator/ephemeral_array_service.d.ts.map +1 -0
- package/dest/contract_function_simulator/ephemeral_array_service.js +78 -0
- package/dest/contract_function_simulator/execution_note_cache.d.ts +18 -9
- package/dest/contract_function_simulator/execution_note_cache.d.ts.map +1 -1
- package/dest/contract_function_simulator/execution_note_cache.js +45 -28
- package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +7 -11
- package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -1
- package/dest/contract_function_simulator/execution_tagging_index_cache.js +19 -15
- package/dest/contract_function_simulator/index.d.ts +5 -2
- package/dest/contract_function_simulator/index.d.ts.map +1 -1
- package/dest/contract_function_simulator/index.js +4 -1
- package/dest/contract_function_simulator/noir-structs/bounded_vec.d.ts +48 -0
- package/dest/contract_function_simulator/noir-structs/bounded_vec.d.ts.map +1 -0
- package/dest/contract_function_simulator/noir-structs/bounded_vec.js +45 -0
- package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +6 -7
- package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts.map +1 -1
- package/dest/contract_function_simulator/noir-structs/event_validation_request.js +12 -10
- package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts +13 -3
- package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts.map +1 -1
- package/dest/contract_function_simulator/noir-structs/log_retrieval_request.js +35 -4
- package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts +2 -2
- package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts.map +1 -1
- package/dest/contract_function_simulator/noir-structs/log_retrieval_response.js +2 -4
- package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +5 -8
- package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
- package/dest/contract_function_simulator/noir-structs/note_validation_request.js +7 -11
- package/dest/contract_function_simulator/noir-structs/option.d.ts +61 -0
- package/dest/contract_function_simulator/noir-structs/option.d.ts.map +1 -0
- package/dest/contract_function_simulator/noir-structs/option.js +62 -0
- package/dest/contract_function_simulator/noir-structs/utility_context.d.ts +4 -10
- package/dest/contract_function_simulator/noir-structs/utility_context.d.ts.map +1 -1
- package/dest/contract_function_simulator/noir-structs/utility_context.js +7 -18
- package/dest/contract_function_simulator/oracle/interfaces.d.ts +70 -50
- package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts +3 -1
- package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts +7 -7
- package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/note_packing_utils.js +10 -10
- package/dest/contract_function_simulator/oracle/oracle.d.ts +74 -43
- package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/oracle.js +471 -264
- package/dest/contract_function_simulator/oracle/oracle_registry.d.ts +147 -0
- package/dest/contract_function_simulator/oracle/oracle_registry.d.ts.map +1 -0
- package/dest/contract_function_simulator/oracle/oracle_registry.js +1199 -0
- package/dest/contract_function_simulator/oracle/private_execution.d.ts +2 -26
- package/dest/contract_function_simulator/oracle/private_execution.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/private_execution.js +5 -39
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +74 -100
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/private_execution_oracle.js +168 -139
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +169 -90
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +468 -193
- 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 +4 -4
- package/dest/contract_function_simulator/proxied_contract_data_source.d.ts.map +1 -1
- package/dest/contract_function_simulator/proxied_contract_data_source.js +39 -68
- package/dest/contract_logging.d.ts +27 -0
- package/dest/contract_logging.d.ts.map +1 -0
- package/dest/contract_logging.js +38 -0
- package/dest/contract_sync/contract_sync_service.d.ts +42 -0
- package/dest/contract_sync/contract_sync_service.d.ts.map +1 -0
- package/dest/contract_sync/contract_sync_service.js +135 -0
- package/dest/contract_sync/helpers.d.ts +27 -0
- package/dest/contract_sync/helpers.d.ts.map +1 -0
- package/dest/contract_sync/helpers.js +53 -0
- package/dest/debug/pxe_debug_utils.d.ts +21 -12
- package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
- package/dest/debug/pxe_debug_utils.js +24 -19
- 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 +41 -10
- package/dest/entrypoints/client/lazy/index.d.ts +3 -1
- package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
- package/dest/entrypoints/client/lazy/index.js +2 -0
- package/dest/entrypoints/client/lazy/utils.d.ts +3 -3
- package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
- package/dest/entrypoints/client/lazy/utils.js +42 -11
- package/dest/entrypoints/pxe_creation_options.d.ts +13 -3
- package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
- package/dest/entrypoints/pxe_creation_options.js +3 -1
- package/dest/entrypoints/server/index.d.ts +6 -2
- package/dest/entrypoints/server/index.d.ts.map +1 -1
- package/dest/entrypoints/server/index.js +5 -1
- package/dest/entrypoints/server/utils.d.ts +4 -3
- package/dest/entrypoints/server/utils.d.ts.map +1 -1
- package/dest/entrypoints/server/utils.js +49 -18
- package/dest/error_enriching.d.ts +4 -4
- package/dest/error_enriching.d.ts.map +1 -1
- package/dest/error_enriching.js +6 -6
- package/dest/events/event_service.d.ts +19 -10
- package/dest/events/event_service.d.ts.map +1 -1
- package/dest/events/event_service.js +60 -30
- package/dest/events/private_event_filter_validator.d.ts +7 -6
- package/dest/events/private_event_filter_validator.d.ts.map +1 -1
- package/dest/events/private_event_filter_validator.js +20 -6
- package/dest/hooks/authorize_utility_call.d.ts +41 -0
- package/dest/hooks/authorize_utility_call.d.ts.map +1 -0
- package/dest/hooks/authorize_utility_call.js +4 -0
- package/dest/hooks/execution_hooks.d.ts +42 -0
- package/dest/hooks/execution_hooks.d.ts.map +1 -0
- package/dest/hooks/execution_hooks.js +9 -0
- package/dest/hooks/index.d.ts +4 -0
- package/dest/hooks/index.d.ts.map +1 -0
- package/dest/hooks/index.js +1 -0
- package/dest/job_coordinator/job_coordinator.d.ts +75 -0
- package/dest/job_coordinator/job_coordinator.d.ts.map +1 -0
- package/dest/job_coordinator/job_coordinator.js +94 -0
- package/dest/logs/log_service.d.ts +21 -35
- package/dest/logs/log_service.d.ts.map +1 -1
- package/dest/logs/log_service.js +144 -215
- package/dest/messages/message_context_service.d.ts +17 -0
- package/dest/messages/message_context_service.d.ts.map +1 -0
- package/dest/messages/message_context_service.js +38 -0
- package/dest/notes/note_service.d.ts +34 -12
- package/dest/notes/note_service.d.ts.map +1 -1
- package/dest/notes/note_service.js +102 -82
- package/dest/notes_filter.d.ts +24 -0
- package/dest/notes_filter.d.ts.map +1 -0
- package/dest/notes_filter.js +4 -0
- package/dest/oracle_version.d.ts +4 -3
- package/dest/oracle_version.d.ts.map +1 -1
- package/dest/oracle_version.js +20 -9
- package/dest/private_kernel/batch_planner.d.ts +47 -0
- package/dest/private_kernel/batch_planner.d.ts.map +1 -0
- package/dest/private_kernel/batch_planner.js +104 -0
- package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
- package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
- package/dest/private_kernel/hints/{compute_tx_include_by_timestamp.js → compute_tx_expiration_timestamp.js} +12 -12
- package/dest/private_kernel/hints/index.d.ts +3 -3
- package/dest/private_kernel/hints/index.d.ts.map +1 -1
- package/dest/private_kernel/hints/index.js +2 -2
- package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +29 -0
- package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -0
- package/dest/private_kernel/hints/{build_private_kernel_reset_private_inputs.js → private_kernel_reset_private_inputs_builder.js} +142 -75
- package/dest/private_kernel/hints/test_utils.d.ts +122 -0
- package/dest/private_kernel/hints/test_utils.d.ts.map +1 -0
- package/dest/private_kernel/hints/test_utils.js +202 -0
- package/dest/private_kernel/private_kernel_execution_prover.d.ts +7 -2
- package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
- package/dest/private_kernel/private_kernel_execution_prover.js +169 -69
- package/dest/private_kernel/private_kernel_oracle.d.ts +29 -29
- package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
- package/dest/private_kernel/private_kernel_oracle.js +96 -2
- package/dest/pxe.d.ts +136 -67
- package/dest/pxe.d.ts.map +1 -1
- package/dest/pxe.js +314 -231
- package/dest/storage/address_store/address_store.d.ts +11 -0
- package/dest/storage/address_store/address_store.d.ts.map +1 -0
- package/dest/storage/{address_data_provider/address_data_provider.js → address_store/address_store.js} +13 -12
- package/dest/storage/address_store/index.d.ts +2 -0
- package/dest/storage/address_store/index.d.ts.map +1 -0
- package/dest/storage/address_store/index.js +1 -0
- package/dest/storage/anchor_block_store/anchor_block_store.d.ts +17 -0
- package/dest/storage/anchor_block_store/anchor_block_store.d.ts.map +1 -0
- package/dest/storage/anchor_block_store/anchor_block_store.js +26 -0
- package/dest/storage/anchor_block_store/index.d.ts +2 -0
- package/dest/storage/anchor_block_store/index.d.ts.map +1 -0
- package/dest/storage/anchor_block_store/index.js +1 -0
- 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 +72 -0
- package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -0
- package/dest/storage/capsule_store/capsule_store.js +261 -0
- package/dest/storage/capsule_store/index.d.ts +3 -0
- package/dest/storage/capsule_store/index.d.ts.map +1 -0
- package/dest/storage/capsule_store/index.js +2 -0
- package/dest/storage/contract_store/contract_store.d.ts +93 -0
- package/dest/storage/contract_store/contract_store.d.ts.map +1 -0
- package/dest/storage/contract_store/contract_store.js +292 -0
- package/dest/storage/contract_store/index.d.ts +2 -0
- package/dest/storage/contract_store/index.d.ts.map +1 -0
- package/dest/storage/contract_store/index.js +1 -0
- package/dest/storage/{contract_data_provider → contract_store}/private_functions_tree.d.ts +1 -1
- package/dest/storage/contract_store/private_functions_tree.d.ts.map +1 -0
- package/dest/storage/index.d.ts +8 -8
- package/dest/storage/index.d.ts.map +1 -1
- package/dest/storage/index.js +7 -7
- package/dest/storage/metadata.d.ts +1 -1
- package/dest/storage/metadata.js +1 -1
- package/dest/storage/note_store/index.d.ts +3 -0
- package/dest/storage/note_store/index.d.ts.map +1 -0
- package/dest/storage/note_store/index.js +2 -0
- package/dest/storage/note_store/note_store.d.ts +83 -0
- package/dest/storage/note_store/note_store.d.ts.map +1 -0
- package/dest/storage/note_store/note_store.js +343 -0
- package/dest/storage/note_store/stored_note.d.ts +16 -0
- package/dest/storage/note_store/stored_note.d.ts.map +1 -0
- package/dest/storage/note_store/stored_note.js +43 -0
- package/dest/storage/open_pxe_stores.d.ts +33 -0
- package/dest/storage/open_pxe_stores.d.ts.map +1 -0
- package/dest/storage/open_pxe_stores.js +27 -0
- package/dest/storage/private_event_store/private_event_store.d.ts +91 -0
- package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -0
- package/dest/storage/private_event_store/private_event_store.js +276 -0
- package/dest/storage/private_event_store/stored_private_event.d.ts +23 -0
- package/dest/storage/private_event_store/stored_private_event.d.ts.map +1 -0
- package/dest/storage/private_event_store/stored_private_event.js +56 -0
- package/dest/storage/tagging_store/index.d.ts +4 -0
- package/dest/storage/tagging_store/index.d.ts.map +1 -0
- package/dest/storage/tagging_store/index.js +3 -0
- package/dest/storage/tagging_store/recipient_tagging_store.d.ts +28 -0
- package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -0
- package/dest/storage/tagging_store/recipient_tagging_store.js +111 -0
- package/dest/storage/tagging_store/sender_address_book_store.d.ts +14 -0
- package/dest/storage/tagging_store/sender_address_book_store.d.ts.map +1 -0
- package/dest/storage/tagging_store/sender_address_book_store.js +36 -0
- package/dest/storage/tagging_store/sender_tagging_store.d.ts +78 -0
- package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -0
- package/dest/storage/tagging_store/sender_tagging_store.js +374 -0
- package/dest/tagging/constants.d.ts +2 -2
- package/dest/tagging/constants.d.ts.map +1 -1
- package/dest/tagging/constants.js +10 -3
- package/dest/tagging/get_all_logs_by_tags.d.ts +48 -0
- package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -0
- package/dest/tagging/get_all_logs_by_tags.js +59 -0
- package/dest/tagging/index.d.ts +18 -5
- package/dest/tagging/index.d.ts.map +1 -1
- package/dest/tagging/index.js +16 -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 +16 -0
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -0
- package/dest/tagging/{sync → sender_sync}/sync_sender_tagging_indexes.js +35 -34
- package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +17 -0
- package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -0
- package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +60 -0
- package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +19 -0
- package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -0
- package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +72 -0
- package/package.json +31 -19
- package/src/bin/check_oracle_version.ts +42 -31
- package/src/bin/index.ts +1 -0
- package/src/block_synchronizer/block_stream_source.ts +81 -0
- package/src/block_synchronizer/block_synchronizer.ts +123 -48
- package/src/config/index.ts +21 -1
- package/src/config/package_info.ts +1 -1
- package/src/contract_function_simulator/benchmarked_node.ts +103 -0
- package/src/contract_function_simulator/contract_function_simulator.ts +431 -161
- package/src/contract_function_simulator/ephemeral_array_service.ts +110 -0
- package/src/contract_function_simulator/execution_note_cache.ts +44 -25
- package/src/contract_function_simulator/execution_tagging_index_cache.ts +19 -18
- package/src/contract_function_simulator/index.ts +4 -1
- package/src/contract_function_simulator/noir-structs/bounded_vec.ts +55 -0
- package/src/contract_function_simulator/noir-structs/event_validation_request.ts +15 -10
- package/src/contract_function_simulator/noir-structs/log_retrieval_request.ts +36 -3
- package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +2 -5
- package/src/contract_function_simulator/noir-structs/note_validation_request.ts +6 -11
- package/src/contract_function_simulator/noir-structs/option.ts +69 -0
- package/src/contract_function_simulator/noir-structs/utility_context.ts +6 -25
- package/src/contract_function_simulator/oracle/interfaces.ts +93 -70
- package/src/contract_function_simulator/oracle/note_packing_utils.ts +13 -13
- package/src/contract_function_simulator/oracle/oracle.ts +567 -461
- package/src/contract_function_simulator/oracle/oracle_registry.ts +904 -0
- package/src/contract_function_simulator/oracle/private_execution.ts +5 -73
- package/src/contract_function_simulator/oracle/private_execution_oracle.ts +215 -239
- package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +668 -261
- package/src/contract_function_simulator/pick_notes.ts +22 -3
- package/src/contract_function_simulator/proxied_contract_data_source.ts +47 -70
- package/src/contract_logging.ts +52 -0
- package/src/contract_sync/contract_sync_service.ts +189 -0
- package/src/contract_sync/helpers.ts +86 -0
- package/src/debug/pxe_debug_utils.ts +57 -20
- package/src/entrypoints/client/bundle/index.ts +2 -0
- package/src/entrypoints/client/bundle/utils.ts +31 -19
- package/src/entrypoints/client/lazy/index.ts +2 -0
- package/src/entrypoints/client/lazy/utils.ts +33 -21
- package/src/entrypoints/pxe_creation_options.ts +18 -2
- package/src/entrypoints/server/index.ts +5 -1
- package/src/entrypoints/server/utils.ts +46 -45
- package/src/error_enriching.ts +7 -15
- package/src/events/event_service.ts +83 -41
- package/src/events/private_event_filter_validator.ts +24 -6
- package/src/hooks/authorize_utility_call.ts +44 -0
- package/src/hooks/execution_hooks.ts +48 -0
- package/src/hooks/index.ts +7 -0
- package/src/job_coordinator/job_coordinator.ts +150 -0
- package/src/logs/log_service.ts +181 -313
- package/src/messages/message_context_service.ts +45 -0
- package/src/notes/note_service.ts +140 -110
- package/src/notes_filter.ts +24 -0
- package/src/oracle_version.ts +20 -9
- package/src/private_kernel/batch_planner.ts +169 -0
- package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
- package/src/private_kernel/hints/index.ts +2 -2
- package/src/private_kernel/hints/{build_private_kernel_reset_private_inputs.ts → private_kernel_reset_private_inputs_builder.ts} +197 -139
- package/src/private_kernel/hints/test_utils.ts +318 -0
- package/src/private_kernel/private_kernel_execution_prover.ts +262 -96
- package/src/private_kernel/private_kernel_oracle.ts +129 -39
- package/src/pxe.ts +552 -310
- package/src/storage/{address_data_provider/address_data_provider.ts → address_store/address_store.ts} +16 -16
- package/src/storage/address_store/index.ts +1 -0
- package/src/storage/{anchor_block_data_provider/anchor_block_data_provider.ts → anchor_block_store/anchor_block_store.ts} +10 -2
- package/src/storage/anchor_block_store/index.ts +1 -0
- 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 +333 -0
- package/src/storage/capsule_store/index.ts +2 -0
- package/src/storage/contract_store/contract_store.ts +408 -0
- package/src/storage/contract_store/index.ts +1 -0
- package/src/storage/index.ts +7 -7
- package/src/storage/metadata.ts +1 -1
- package/src/storage/note_store/index.ts +2 -0
- package/src/storage/note_store/note_store.ts +415 -0
- package/src/storage/note_store/stored_note.ts +48 -0
- package/src/storage/open_pxe_stores.ts +49 -0
- package/src/storage/private_event_store/private_event_store.ts +388 -0
- package/src/storage/private_event_store/stored_private_event.ts +73 -0
- package/src/storage/tagging_store/index.ts +3 -0
- package/src/storage/tagging_store/recipient_tagging_store.ts +139 -0
- package/src/storage/tagging_store/sender_address_book_store.ts +48 -0
- package/src/storage/tagging_store/sender_tagging_store.ts +476 -0
- package/src/tagging/constants.ts +10 -3
- package/src/tagging/get_all_logs_by_tags.ts +120 -0
- package/src/tagging/index.ts +20 -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 +134 -0
- package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +66 -0
- package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +84 -0
- package/dest/contract_function_simulator/proxied_node.d.ts +0 -9
- package/dest/contract_function_simulator/proxied_node.d.ts.map +0 -1
- package/dest/contract_function_simulator/proxied_node.js +0 -27
- package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts +0 -28
- package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts.map +0 -1
- package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts +0 -4
- package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts.map +0 -1
- package/dest/private_kernel/private_kernel_oracle_impl.d.ts +0 -46
- package/dest/private_kernel/private_kernel_oracle_impl.d.ts.map +0 -1
- package/dest/private_kernel/private_kernel_oracle_impl.js +0 -86
- package/dest/public_storage/public_storage_service.d.ts +0 -24
- package/dest/public_storage/public_storage_service.d.ts.map +0 -1
- package/dest/public_storage/public_storage_service.js +0 -26
- package/dest/storage/address_data_provider/address_data_provider.d.ts +0 -11
- package/dest/storage/address_data_provider/address_data_provider.d.ts.map +0 -1
- package/dest/storage/address_data_provider/index.d.ts +0 -2
- package/dest/storage/address_data_provider/index.d.ts.map +0 -1
- package/dest/storage/address_data_provider/index.js +0 -1
- package/dest/storage/anchor_block_data_provider/anchor_block_data_provider.d.ts +0 -9
- package/dest/storage/anchor_block_data_provider/anchor_block_data_provider.d.ts.map +0 -1
- package/dest/storage/anchor_block_data_provider/anchor_block_data_provider.js +0 -19
- package/dest/storage/anchor_block_data_provider/index.d.ts +0 -2
- package/dest/storage/anchor_block_data_provider/index.d.ts.map +0 -1
- package/dest/storage/anchor_block_data_provider/index.js +0 -1
- package/dest/storage/capsule_data_provider/capsule_data_provider.d.ts +0 -57
- package/dest/storage/capsule_data_provider/capsule_data_provider.d.ts.map +0 -1
- package/dest/storage/capsule_data_provider/capsule_data_provider.js +0 -146
- package/dest/storage/capsule_data_provider/index.d.ts +0 -2
- package/dest/storage/capsule_data_provider/index.d.ts.map +0 -1
- package/dest/storage/capsule_data_provider/index.js +0 -1
- package/dest/storage/contract_data_provider/contract_data_provider.d.ts +0 -66
- package/dest/storage/contract_data_provider/contract_data_provider.d.ts.map +0 -1
- package/dest/storage/contract_data_provider/contract_data_provider.js +0 -224
- package/dest/storage/contract_data_provider/index.d.ts +0 -2
- package/dest/storage/contract_data_provider/index.d.ts.map +0 -1
- package/dest/storage/contract_data_provider/index.js +0 -1
- package/dest/storage/contract_data_provider/private_functions_tree.d.ts.map +0 -1
- package/dest/storage/note_data_provider/index.d.ts +0 -3
- package/dest/storage/note_data_provider/index.d.ts.map +0 -1
- package/dest/storage/note_data_provider/index.js +0 -2
- package/dest/storage/note_data_provider/note_data_provider.d.ts +0 -84
- package/dest/storage/note_data_provider/note_data_provider.d.ts.map +0 -1
- package/dest/storage/note_data_provider/note_data_provider.js +0 -322
- package/dest/storage/private_event_data_provider/private_event_data_provider.d.ts +0 -51
- package/dest/storage/private_event_data_provider/private_event_data_provider.d.ts.map +0 -1
- package/dest/storage/private_event_data_provider/private_event_data_provider.js +0 -115
- package/dest/storage/tagging_data_provider/index.d.ts +0 -3
- package/dest/storage/tagging_data_provider/index.d.ts.map +0 -1
- package/dest/storage/tagging_data_provider/index.js +0 -2
- package/dest/storage/tagging_data_provider/recipient_tagging_data_provider.d.ts +0 -31
- package/dest/storage/tagging_data_provider/recipient_tagging_data_provider.d.ts.map +0 -1
- package/dest/storage/tagging_data_provider/recipient_tagging_data_provider.js +0 -65
- package/dest/storage/tagging_data_provider/sender_tagging_data_provider.d.ts +0 -67
- package/dest/storage/tagging_data_provider/sender_tagging_data_provider.d.ts.map +0 -1
- package/dest/storage/tagging_data_provider/sender_tagging_data_provider.js +0 -196
- 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/new_recipient_tagging_data_provider.d.ts +0 -21
- package/dest/tagging/recipient_sync/new_recipient_tagging_data_provider.d.ts.map +0 -1
- package/dest/tagging/recipient_sync/new_recipient_tagging_data_provider.js +0 -42
- package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +0 -14
- package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +0 -1
- package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +0 -29
- package/dest/tagging/sync/sync_sender_tagging_indexes.d.ts +0 -21
- package/dest/tagging/sync/sync_sender_tagging_indexes.d.ts.map +0 -1
- package/dest/tagging/sync/utils/get_status_change_of_pending.d.ts +0 -11
- package/dest/tagging/sync/utils/get_status_change_of_pending.d.ts.map +0 -1
- package/dest/tagging/sync/utils/get_status_change_of_pending.js +0 -32
- package/dest/tagging/sync/utils/load_and_store_new_tagging_indexes.d.ts +0 -18
- package/dest/tagging/sync/utils/load_and_store_new_tagging_indexes.d.ts.map +0 -1
- package/dest/tagging/sync/utils/load_and_store_new_tagging_indexes.js +0 -55
- package/dest/tagging/utils.d.ts +0 -18
- package/dest/tagging/utils.d.ts.map +0 -1
- package/dest/tagging/utils.js +0 -25
- package/dest/tree_membership/tree_membership_service.d.ts +0 -52
- package/dest/tree_membership/tree_membership_service.d.ts.map +0 -1
- package/dest/tree_membership/tree_membership_service.js +0 -84
- package/src/contract_function_simulator/proxied_node.ts +0 -33
- package/src/private_kernel/private_kernel_oracle_impl.ts +0 -133
- package/src/public_storage/public_storage_service.ts +0 -33
- package/src/storage/address_data_provider/index.ts +0 -1
- package/src/storage/anchor_block_data_provider/index.ts +0 -1
- package/src/storage/capsule_data_provider/capsule_data_provider.ts +0 -179
- package/src/storage/capsule_data_provider/index.ts +0 -1
- package/src/storage/contract_data_provider/contract_data_provider.ts +0 -319
- package/src/storage/contract_data_provider/index.ts +0 -1
- package/src/storage/note_data_provider/index.ts +0 -2
- package/src/storage/note_data_provider/note_data_provider.ts +0 -412
- package/src/storage/private_event_data_provider/private_event_data_provider.ts +0 -162
- package/src/storage/tagging_data_provider/index.ts +0 -2
- package/src/storage/tagging_data_provider/recipient_tagging_data_provider.ts +0 -86
- package/src/storage/tagging_data_provider/sender_tagging_data_provider.ts +0 -244
- package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +0 -129
- package/src/tagging/recipient_sync/new_recipient_tagging_data_provider.ts +0 -53
- package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +0 -43
- package/src/tagging/sync/sync_sender_tagging_indexes.ts +0 -112
- package/src/tagging/sync/utils/get_status_change_of_pending.ts +0 -44
- package/src/tagging/sync/utils/load_and_store_new_tagging_indexes.ts +0 -72
- package/src/tagging/utils.ts +0 -32
- package/src/tree_membership/tree_membership_service.ts +0 -112
- /package/dest/storage/{contract_data_provider → contract_store}/private_functions_tree.js +0 -0
- /package/src/storage/{contract_data_provider → contract_store}/private_functions_tree.ts +0 -0
|
@@ -2,22 +2,27 @@ import {
|
|
|
2
2
|
AVM_EMITNOTEHASH_BASE_L2_GAS,
|
|
3
3
|
AVM_EMITNULLIFIER_BASE_L2_GAS,
|
|
4
4
|
AVM_SENDL2TOL1MSG_BASE_L2_GAS,
|
|
5
|
-
|
|
6
|
-
DA_GAS_PER_BYTE,
|
|
5
|
+
DA_GAS_PER_FIELD,
|
|
7
6
|
FIXED_AVM_STARTUP_L2_GAS,
|
|
8
|
-
FIXED_DA_GAS,
|
|
9
|
-
FIXED_L2_GAS,
|
|
10
7
|
L2_GAS_PER_CONTRACT_CLASS_LOG,
|
|
8
|
+
L2_GAS_PER_L2_TO_L1_MSG,
|
|
9
|
+
L2_GAS_PER_NOTE_HASH,
|
|
10
|
+
L2_GAS_PER_NULLIFIER,
|
|
11
11
|
L2_GAS_PER_PRIVATE_LOG,
|
|
12
12
|
MAX_CONTRACT_CLASS_LOGS_PER_TX,
|
|
13
13
|
MAX_ENQUEUED_CALLS_PER_TX,
|
|
14
14
|
MAX_L2_TO_L1_MSGS_PER_TX,
|
|
15
15
|
MAX_NOTE_HASHES_PER_TX,
|
|
16
|
+
MAX_NOTE_HASH_READ_REQUESTS_PER_TX,
|
|
16
17
|
MAX_NULLIFIERS_PER_TX,
|
|
18
|
+
MAX_NULLIFIER_READ_REQUESTS_PER_TX,
|
|
17
19
|
MAX_PRIVATE_LOGS_PER_TX,
|
|
20
|
+
MAX_TX_LIFETIME,
|
|
21
|
+
PRIVATE_TX_L2_GAS_OVERHEAD,
|
|
22
|
+
PUBLIC_TX_L2_GAS_OVERHEAD,
|
|
23
|
+
TX_DA_GAS_OVERHEAD,
|
|
18
24
|
} from '@aztec/constants';
|
|
19
25
|
import { arrayNonEmptyLength, padArrayEnd } from '@aztec/foundation/collection';
|
|
20
|
-
import { poseidon2Hash } from '@aztec/foundation/crypto/poseidon';
|
|
21
26
|
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
22
27
|
import { type Logger, createLogger } from '@aztec/foundation/log';
|
|
23
28
|
import { Timer } from '@aztec/foundation/timer';
|
|
@@ -37,116 +42,178 @@ import type { FunctionCall } from '@aztec/stdlib/abi';
|
|
|
37
42
|
import { FunctionSelector, FunctionType } from '@aztec/stdlib/abi';
|
|
38
43
|
import type { AuthWitness } from '@aztec/stdlib/auth-witness';
|
|
39
44
|
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
45
|
+
import type { BlockParameter, L2TipsProvider } from '@aztec/stdlib/block';
|
|
40
46
|
import { Gas } from '@aztec/stdlib/gas';
|
|
41
47
|
import {
|
|
42
48
|
computeNoteHashNonce,
|
|
43
49
|
computeProtocolNullifier,
|
|
50
|
+
computeSiloedPrivateLogFirstField,
|
|
44
51
|
computeUniqueNoteHash,
|
|
45
52
|
siloNoteHash,
|
|
46
53
|
siloNullifier,
|
|
47
54
|
} from '@aztec/stdlib/hash';
|
|
48
55
|
import type { AztecNode } from '@aztec/stdlib/interfaces/server';
|
|
49
56
|
import {
|
|
57
|
+
ClaimedLengthArray,
|
|
50
58
|
PartialPrivateTailPublicInputsForPublic,
|
|
51
59
|
PartialPrivateTailPublicInputsForRollup,
|
|
52
60
|
type PrivateExecutionStep,
|
|
53
61
|
type PrivateKernelExecutionProofOutput,
|
|
54
62
|
PrivateKernelTailCircuitPublicInputs,
|
|
63
|
+
PrivateLogData,
|
|
55
64
|
PrivateToPublicAccumulatedData,
|
|
56
65
|
PrivateToRollupAccumulatedData,
|
|
57
66
|
PublicCallRequest,
|
|
67
|
+
ReadRequestActionEnum,
|
|
58
68
|
ScopedLogHash,
|
|
69
|
+
ScopedNoteHash,
|
|
70
|
+
ScopedNullifier,
|
|
71
|
+
ScopedReadRequest,
|
|
72
|
+
buildTransientDataHints,
|
|
73
|
+
getNoteHashReadRequestResetActions,
|
|
74
|
+
getNullifierReadRequestResetActions,
|
|
59
75
|
} from '@aztec/stdlib/kernel';
|
|
60
76
|
import { PrivateLog } from '@aztec/stdlib/logs';
|
|
61
77
|
import { ScopedL2ToL1Message } from '@aztec/stdlib/messaging';
|
|
62
78
|
import { ChonkProof } from '@aztec/stdlib/proofs';
|
|
79
|
+
import { MerkleTreeId } from '@aztec/stdlib/trees';
|
|
63
80
|
import {
|
|
64
81
|
BlockHeader,
|
|
65
82
|
CallContext,
|
|
66
83
|
HashedValues,
|
|
84
|
+
type OffchainEffect,
|
|
67
85
|
PrivateExecutionResult,
|
|
68
86
|
TxConstantData,
|
|
69
87
|
TxExecutionRequest,
|
|
70
88
|
collectNested,
|
|
89
|
+
collectNoteHashNullifierCounterMap,
|
|
71
90
|
getFinalMinRevertibleSideEffectCounter,
|
|
72
91
|
} from '@aztec/stdlib/tx';
|
|
73
92
|
|
|
74
|
-
import type {
|
|
75
|
-
import type {
|
|
76
|
-
import type {
|
|
77
|
-
import type {
|
|
78
|
-
import
|
|
79
|
-
import type {
|
|
80
|
-
import type {
|
|
81
|
-
import type {
|
|
93
|
+
import type { ContractSyncService } from '../contract_sync/contract_sync_service.js';
|
|
94
|
+
import type { ExecutionHooks } from '../hooks/index.js';
|
|
95
|
+
import type { MessageContextService } from '../messages/message_context_service.js';
|
|
96
|
+
import type { AddressStore } from '../storage/address_store/address_store.js';
|
|
97
|
+
import { CapsuleService } from '../storage/capsule_store/capsule_service.js';
|
|
98
|
+
import type { CapsuleStore } from '../storage/capsule_store/capsule_store.js';
|
|
99
|
+
import type { ContractStore } from '../storage/contract_store/contract_store.js';
|
|
100
|
+
import type { NoteStore } from '../storage/note_store/note_store.js';
|
|
101
|
+
import type { PrivateEventStore } from '../storage/private_event_store/private_event_store.js';
|
|
102
|
+
import type { RecipientTaggingStore } from '../storage/tagging_store/recipient_tagging_store.js';
|
|
103
|
+
import type { SenderAddressBookStore } from '../storage/tagging_store/sender_address_book_store.js';
|
|
104
|
+
import type { SenderTaggingStore } from '../storage/tagging_store/sender_tagging_store.js';
|
|
105
|
+
import type { BenchmarkedNode } from './benchmarked_node.js';
|
|
82
106
|
import { ExecutionNoteCache } from './execution_note_cache.js';
|
|
83
107
|
import { ExecutionTaggingIndexCache } from './execution_tagging_index_cache.js';
|
|
84
108
|
import { HashedValuesCache } from './hashed_values_cache.js';
|
|
85
109
|
import { Oracle } from './oracle/oracle.js';
|
|
86
|
-
import { executePrivateFunction
|
|
110
|
+
import { executePrivateFunction } from './oracle/private_execution.js';
|
|
87
111
|
import { PrivateExecutionOracle } from './oracle/private_execution_oracle.js';
|
|
88
112
|
import { UtilityExecutionOracle } from './oracle/utility_execution_oracle.js';
|
|
89
|
-
|
|
113
|
+
|
|
114
|
+
/** Options for ContractFunctionSimulator.run. */
|
|
115
|
+
export type ContractSimulatorRunOpts = {
|
|
116
|
+
/** The address of the contract (should match request.origin). */
|
|
117
|
+
contractAddress: AztecAddress;
|
|
118
|
+
/** The function selector of the entry point. */
|
|
119
|
+
selector: FunctionSelector;
|
|
120
|
+
/** The address calling the function. Can be replaced to simulate a call from another contract or account. */
|
|
121
|
+
msgSender?: AztecAddress;
|
|
122
|
+
/** The block header to use as base state for this run. */
|
|
123
|
+
anchorBlockHeader: BlockHeader;
|
|
124
|
+
/** The address used as a tagging sender when emitting private logs. */
|
|
125
|
+
senderForTags?: AztecAddress;
|
|
126
|
+
/** The accounts whose notes we can access in this call. */
|
|
127
|
+
scopes: AztecAddress[];
|
|
128
|
+
/** The job ID for staged writes. */
|
|
129
|
+
jobId: string;
|
|
130
|
+
};
|
|
131
|
+
|
|
132
|
+
/** Args for ContractFunctionSimulator constructor. */
|
|
133
|
+
export type ContractFunctionSimulatorArgs = {
|
|
134
|
+
contractStore: ContractStore;
|
|
135
|
+
noteStore: NoteStore;
|
|
136
|
+
keyStore: KeyStore;
|
|
137
|
+
addressStore: AddressStore;
|
|
138
|
+
aztecNode: AztecNode;
|
|
139
|
+
l2TipsStore: L2TipsProvider;
|
|
140
|
+
senderTaggingStore: SenderTaggingStore;
|
|
141
|
+
recipientTaggingStore: RecipientTaggingStore;
|
|
142
|
+
senderAddressBookStore: SenderAddressBookStore;
|
|
143
|
+
capsuleStore: CapsuleStore;
|
|
144
|
+
privateEventStore: PrivateEventStore;
|
|
145
|
+
simulator: CircuitSimulator;
|
|
146
|
+
contractSyncService: ContractSyncService;
|
|
147
|
+
messageContextService: MessageContextService;
|
|
148
|
+
hooks?: ExecutionHooks;
|
|
149
|
+
};
|
|
90
150
|
|
|
91
151
|
/**
|
|
92
152
|
* The contract function simulator.
|
|
93
153
|
*/
|
|
94
154
|
export class ContractFunctionSimulator {
|
|
95
|
-
private log: Logger;
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
155
|
+
private readonly log: Logger;
|
|
156
|
+
private readonly contractStore: ContractStore;
|
|
157
|
+
private readonly noteStore: NoteStore;
|
|
158
|
+
private readonly keyStore: KeyStore;
|
|
159
|
+
private readonly addressStore: AddressStore;
|
|
160
|
+
private readonly aztecNode: AztecNode;
|
|
161
|
+
private readonly l2TipsStore: L2TipsProvider;
|
|
162
|
+
private readonly senderTaggingStore: SenderTaggingStore;
|
|
163
|
+
private readonly recipientTaggingStore: RecipientTaggingStore;
|
|
164
|
+
private readonly senderAddressBookStore: SenderAddressBookStore;
|
|
165
|
+
private readonly capsuleStore: CapsuleStore;
|
|
166
|
+
private readonly privateEventStore: PrivateEventStore;
|
|
167
|
+
private readonly simulator: CircuitSimulator;
|
|
168
|
+
private readonly contractSyncService: ContractSyncService;
|
|
169
|
+
private readonly messageContextService: MessageContextService;
|
|
170
|
+
private readonly hooks: ExecutionHooks | undefined;
|
|
171
|
+
|
|
172
|
+
constructor(args: ContractFunctionSimulatorArgs) {
|
|
173
|
+
this.contractStore = args.contractStore;
|
|
174
|
+
this.noteStore = args.noteStore;
|
|
175
|
+
this.keyStore = args.keyStore;
|
|
176
|
+
this.addressStore = args.addressStore;
|
|
177
|
+
this.aztecNode = args.aztecNode;
|
|
178
|
+
this.l2TipsStore = args.l2TipsStore;
|
|
179
|
+
this.senderTaggingStore = args.senderTaggingStore;
|
|
180
|
+
this.recipientTaggingStore = args.recipientTaggingStore;
|
|
181
|
+
this.senderAddressBookStore = args.senderAddressBookStore;
|
|
182
|
+
this.capsuleStore = args.capsuleStore;
|
|
183
|
+
this.privateEventStore = args.privateEventStore;
|
|
184
|
+
this.simulator = args.simulator;
|
|
185
|
+
this.contractSyncService = args.contractSyncService;
|
|
186
|
+
this.messageContextService = args.messageContextService;
|
|
187
|
+
this.hooks = args.hooks;
|
|
110
188
|
this.log = createLogger('simulator');
|
|
111
189
|
}
|
|
112
190
|
|
|
113
191
|
/**
|
|
114
192
|
* Runs a private function.
|
|
115
193
|
* @param request - The transaction request.
|
|
116
|
-
* @param entryPointArtifact - The artifact of the entry point function.
|
|
117
|
-
* @param contractAddress - The address of the contract (should match request.origin)
|
|
118
|
-
* @param msgSender - The address calling the function. This can be replaced to simulate a call from another contract
|
|
119
|
-
* or a specific account.
|
|
120
|
-
* @param anchorBlockHeader - The block header to use as base state for this run.
|
|
121
|
-
* @param senderForTags - The address that is used as a tagging sender when emitting private logs. Returned from
|
|
122
|
-
* the `privateGetSenderForTags` oracle.
|
|
123
|
-
* @param scopes - The accounts whose notes we can access in this call. Currently optional and will default to all.
|
|
124
|
-
* @returns The result of the execution.
|
|
125
194
|
*/
|
|
126
195
|
public async run(
|
|
127
196
|
request: TxExecutionRequest,
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
197
|
+
{
|
|
198
|
+
contractAddress,
|
|
199
|
+
selector,
|
|
200
|
+
msgSender = AztecAddress.fromField(Fr.MAX_FIELD_VALUE),
|
|
201
|
+
anchorBlockHeader,
|
|
202
|
+
senderForTags,
|
|
203
|
+
scopes,
|
|
204
|
+
jobId,
|
|
205
|
+
}: ContractSimulatorRunOpts,
|
|
134
206
|
): Promise<PrivateExecutionResult> {
|
|
135
207
|
const simulatorSetupTimer = new Timer();
|
|
136
208
|
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
const entryPointArtifact = await this.contractDataProvider.getFunctionArtifactWithDebugMetadata(
|
|
140
|
-
contractAddress,
|
|
141
|
-
selector,
|
|
142
|
-
);
|
|
209
|
+
const entryPointArtifact = await this.contractStore.getFunctionArtifactWithDebugMetadata(contractAddress, selector);
|
|
143
210
|
|
|
144
211
|
if (entryPointArtifact.functionType !== FunctionType.PRIVATE) {
|
|
145
212
|
throw new Error(`Cannot run ${entryPointArtifact.functionType} function as private`);
|
|
146
213
|
}
|
|
147
214
|
|
|
148
215
|
if (request.origin !== contractAddress) {
|
|
149
|
-
|
|
216
|
+
throw new Error(
|
|
150
217
|
`Request origin does not match contract address in simulation. Request origin: ${request.origin}, contract address: ${contractAddress}`,
|
|
151
218
|
);
|
|
152
219
|
}
|
|
@@ -165,33 +232,40 @@ export class ContractFunctionSimulator {
|
|
|
165
232
|
const noteCache = new ExecutionNoteCache(protocolNullifier);
|
|
166
233
|
const taggingIndexCache = new ExecutionTaggingIndexCache();
|
|
167
234
|
|
|
168
|
-
const privateExecutionOracle = new PrivateExecutionOracle(
|
|
169
|
-
request.firstCallArgsHash,
|
|
170
|
-
request.txContext,
|
|
235
|
+
const privateExecutionOracle = new PrivateExecutionOracle({
|
|
236
|
+
argsHash: request.firstCallArgsHash,
|
|
237
|
+
txContext: request.txContext,
|
|
171
238
|
callContext,
|
|
172
239
|
anchorBlockHeader,
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
240
|
+
utilityExecutor: async (call, execScopes) => {
|
|
241
|
+
await this.runUtility(call, [], anchorBlockHeader, execScopes, jobId);
|
|
242
|
+
},
|
|
243
|
+
authWitnesses: request.authWitnesses,
|
|
244
|
+
capsules: request.capsules,
|
|
245
|
+
executionCache: HashedValuesCache.create(request.argsOfCalls),
|
|
176
246
|
noteCache,
|
|
177
247
|
taggingIndexCache,
|
|
178
|
-
this.
|
|
179
|
-
this.
|
|
180
|
-
this.keyStore,
|
|
181
|
-
this.
|
|
182
|
-
this.aztecNode,
|
|
183
|
-
this.
|
|
184
|
-
this.
|
|
185
|
-
this.
|
|
186
|
-
this.
|
|
187
|
-
this.
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
248
|
+
contractStore: this.contractStore,
|
|
249
|
+
noteStore: this.noteStore,
|
|
250
|
+
keyStore: this.keyStore,
|
|
251
|
+
addressStore: this.addressStore,
|
|
252
|
+
aztecNode: this.aztecNode,
|
|
253
|
+
senderTaggingStore: this.senderTaggingStore,
|
|
254
|
+
recipientTaggingStore: this.recipientTaggingStore,
|
|
255
|
+
senderAddressBookStore: this.senderAddressBookStore,
|
|
256
|
+
capsuleService: new CapsuleService(this.capsuleStore, scopes),
|
|
257
|
+
privateEventStore: this.privateEventStore,
|
|
258
|
+
messageContextService: this.messageContextService,
|
|
259
|
+
contractSyncService: this.contractSyncService,
|
|
260
|
+
jobId,
|
|
261
|
+
totalPublicCalldataCount: 0,
|
|
262
|
+
sideEffectCounter: startSideEffectCounter,
|
|
191
263
|
scopes,
|
|
192
264
|
senderForTags,
|
|
193
|
-
this.simulator,
|
|
194
|
-
|
|
265
|
+
simulator: this.simulator,
|
|
266
|
+
l2TipsStore: this.l2TipsStore,
|
|
267
|
+
hooks: this.hooks,
|
|
268
|
+
});
|
|
195
269
|
|
|
196
270
|
const setupTime = simulatorSetupTimer.ms();
|
|
197
271
|
|
|
@@ -208,8 +282,9 @@ export class ContractFunctionSimulator {
|
|
|
208
282
|
request.functionSelector,
|
|
209
283
|
);
|
|
210
284
|
const simulatorTeardownTimer = new Timer();
|
|
211
|
-
|
|
212
|
-
|
|
285
|
+
|
|
286
|
+
noteCache.finish();
|
|
287
|
+
const firstNullifierHint = noteCache.getNonceGenerator();
|
|
213
288
|
|
|
214
289
|
const publicCallRequests = collectNested([executionResult], r =>
|
|
215
290
|
r.publicInputs.publicCallRequests
|
|
@@ -219,7 +294,7 @@ export class ContractFunctionSimulator {
|
|
|
219
294
|
);
|
|
220
295
|
const publicFunctionsCalldata = await Promise.all(
|
|
221
296
|
publicCallRequests.map(async r => {
|
|
222
|
-
const calldata = await privateExecutionOracle.
|
|
297
|
+
const calldata = await privateExecutionOracle.getHashPreimage(r.calldataHash);
|
|
223
298
|
return new HashedValues(calldata, r.calldataHash);
|
|
224
299
|
}),
|
|
225
300
|
);
|
|
@@ -240,7 +315,6 @@ export class ContractFunctionSimulator {
|
|
|
240
315
|
}
|
|
241
316
|
}
|
|
242
317
|
|
|
243
|
-
// docs:start:execute_utility_function
|
|
244
318
|
/**
|
|
245
319
|
* Runs a utility function.
|
|
246
320
|
* @param call - The function call to execute.
|
|
@@ -254,37 +328,42 @@ export class ContractFunctionSimulator {
|
|
|
254
328
|
call: FunctionCall,
|
|
255
329
|
authwits: AuthWitness[],
|
|
256
330
|
anchorBlockHeader: BlockHeader,
|
|
257
|
-
scopes
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
const entryPointArtifact = await this.contractDataProvider.getFunctionArtifactWithDebugMetadata(
|
|
262
|
-
call.to,
|
|
263
|
-
call.selector,
|
|
264
|
-
);
|
|
331
|
+
scopes: AztecAddress[],
|
|
332
|
+
jobId: string,
|
|
333
|
+
): Promise<{ result: Fr[]; offchainEffects: OffchainEffect[] }> {
|
|
334
|
+
const entryPointArtifact = await this.contractStore.getFunctionArtifactWithDebugMetadata(call.to, call.selector);
|
|
265
335
|
|
|
266
336
|
if (entryPointArtifact.functionType !== FunctionType.UTILITY) {
|
|
267
337
|
throw new Error(`Cannot run ${entryPointArtifact.functionType} function as utility`);
|
|
268
338
|
}
|
|
269
339
|
|
|
270
|
-
const
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
340
|
+
const utilityExecutor = async (syncCall: FunctionCall, execScopes: AztecAddress[]) => {
|
|
341
|
+
await this.runUtility(syncCall, [], anchorBlockHeader, execScopes, jobId);
|
|
342
|
+
};
|
|
343
|
+
|
|
344
|
+
const oracle = new UtilityExecutionOracle({
|
|
345
|
+
contractAddress: call.to,
|
|
346
|
+
authWitnesses: authwits,
|
|
347
|
+
capsules: [],
|
|
274
348
|
anchorBlockHeader,
|
|
275
|
-
this.
|
|
276
|
-
this.
|
|
277
|
-
this.keyStore,
|
|
278
|
-
this.
|
|
279
|
-
this.aztecNode,
|
|
280
|
-
this.
|
|
281
|
-
this.
|
|
282
|
-
this.
|
|
283
|
-
this.
|
|
284
|
-
this.
|
|
285
|
-
|
|
349
|
+
contractStore: this.contractStore,
|
|
350
|
+
noteStore: this.noteStore,
|
|
351
|
+
keyStore: this.keyStore,
|
|
352
|
+
addressStore: this.addressStore,
|
|
353
|
+
aztecNode: this.aztecNode,
|
|
354
|
+
recipientTaggingStore: this.recipientTaggingStore,
|
|
355
|
+
senderAddressBookStore: this.senderAddressBookStore,
|
|
356
|
+
capsuleService: new CapsuleService(this.capsuleStore, scopes),
|
|
357
|
+
privateEventStore: this.privateEventStore,
|
|
358
|
+
messageContextService: this.messageContextService,
|
|
359
|
+
contractSyncService: this.contractSyncService,
|
|
360
|
+
l2TipsStore: this.l2TipsStore,
|
|
361
|
+
jobId,
|
|
286
362
|
scopes,
|
|
287
|
-
|
|
363
|
+
simulator: this.simulator,
|
|
364
|
+
hooks: this.hooks,
|
|
365
|
+
utilityExecutor,
|
|
366
|
+
});
|
|
288
367
|
|
|
289
368
|
try {
|
|
290
369
|
this.log.verbose(`Executing utility function ${entryPointArtifact.name}`, {
|
|
@@ -308,13 +387,15 @@ export class ContractFunctionSimulator {
|
|
|
308
387
|
);
|
|
309
388
|
});
|
|
310
389
|
|
|
311
|
-
this.log.verbose(`Utility
|
|
312
|
-
return
|
|
390
|
+
this.log.verbose(`Utility execution for ${call.to}.${call.selector} completed`);
|
|
391
|
+
return {
|
|
392
|
+
result: witnessMapToFields(acirExecutionResult.returnWitness),
|
|
393
|
+
offchainEffects: oracle.getOffchainEffects(),
|
|
394
|
+
};
|
|
313
395
|
} catch (err) {
|
|
314
396
|
throw createSimulationError(err instanceof Error ? err : new Error('Unknown error during private execution'));
|
|
315
397
|
}
|
|
316
398
|
}
|
|
317
|
-
// docs:end:execute_utility_function
|
|
318
399
|
|
|
319
400
|
/**
|
|
320
401
|
* Returns the execution statistics collected during the simulator run.
|
|
@@ -322,7 +403,12 @@ export class ContractFunctionSimulator {
|
|
|
322
403
|
*/
|
|
323
404
|
getStats() {
|
|
324
405
|
const nodeRPCCalls =
|
|
325
|
-
typeof (this.aztecNode as
|
|
406
|
+
typeof (this.aztecNode as BenchmarkedNode).getStats === 'function'
|
|
407
|
+
? (this.aztecNode as BenchmarkedNode).getStats()
|
|
408
|
+
: {
|
|
409
|
+
perMethod: {},
|
|
410
|
+
roundTrips: { roundTrips: 0, totalBlockingTime: 0, roundTripDurations: [], roundTripMethods: [] },
|
|
411
|
+
};
|
|
326
412
|
|
|
327
413
|
return { nodeRPCCalls };
|
|
328
414
|
}
|
|
@@ -345,63 +431,82 @@ class OrderedSideEffect<T> {
|
|
|
345
431
|
* (allowing state overrides) and is much faster, while still generating a valid
|
|
346
432
|
* output that can be sent to the node for public simulation
|
|
347
433
|
* @param privateExecutionResult - The result of the private execution.
|
|
348
|
-
* @param
|
|
349
|
-
*
|
|
350
|
-
* @param
|
|
434
|
+
* @param debugFunctionNameGetter - A provider for contract data in order to get function names and debug info.
|
|
435
|
+
* @param node - AztecNode for verifying settled read requests against the note hash and nullifier trees.
|
|
436
|
+
* @param minRevertibleSideEffectCounterOverride - Optional override for the min revertible side effect counter.
|
|
437
|
+
* Used by TXE to simulate account contract behavior (setting the counter before app execution).
|
|
351
438
|
* @returns The simulated proving result.
|
|
352
439
|
*/
|
|
353
440
|
export async function generateSimulatedProvingResult(
|
|
354
441
|
privateExecutionResult: PrivateExecutionResult,
|
|
355
|
-
|
|
356
|
-
|
|
442
|
+
debugFunctionNameGetter: (contractAddress: AztecAddress, functionSelector: FunctionSelector) => Promise<string>,
|
|
443
|
+
node: AztecNode,
|
|
444
|
+
minRevertibleSideEffectCounterOverride?: number,
|
|
357
445
|
): Promise<PrivateKernelExecutionProofOutput<PrivateKernelTailCircuitPublicInputs>> {
|
|
358
|
-
const
|
|
359
|
-
const nullifiers: OrderedSideEffect<Fr>[] = [];
|
|
360
|
-
const taggedPrivateLogs: OrderedSideEffect<PrivateLog>[] = [];
|
|
446
|
+
const taggedPrivateLogs: OrderedSideEffect<PrivateLogData>[] = [];
|
|
361
447
|
const l2ToL1Messages: OrderedSideEffect<ScopedL2ToL1Message>[] = [];
|
|
362
448
|
const contractClassLogsHashes: OrderedSideEffect<ScopedLogHash>[] = [];
|
|
363
449
|
const publicCallRequests: OrderedSideEffect<PublicCallRequest>[] = [];
|
|
364
450
|
const executionSteps: PrivateExecutionStep[] = [];
|
|
365
451
|
|
|
452
|
+
// Unsiloed scoped arrays — used for squashing, read request verification,
|
|
453
|
+
// and siloed at the end only for the surviving items
|
|
454
|
+
const scopedNoteHashes: ScopedNoteHash[] = [];
|
|
455
|
+
const scopedNullifiers: ScopedNullifier[] = [];
|
|
456
|
+
|
|
457
|
+
// Read requests for verification
|
|
458
|
+
const noteHashReadRequests: ScopedReadRequest[] = [];
|
|
459
|
+
const nullifierReadRequests: ScopedReadRequest[] = [];
|
|
460
|
+
|
|
366
461
|
let publicTeardownCallRequest;
|
|
367
462
|
|
|
463
|
+
// We set expiration timestamp to anchor_block_timestamp + MAX_TX_LIFETIME (24h) just like kernels do
|
|
464
|
+
let expirationTimestamp =
|
|
465
|
+
privateExecutionResult.entrypoint.publicInputs.anchorBlockHeader.globalVariables.timestamp +
|
|
466
|
+
BigInt(MAX_TX_LIFETIME);
|
|
467
|
+
|
|
468
|
+
let feePayer = AztecAddress.zero();
|
|
469
|
+
|
|
368
470
|
const executions = [privateExecutionResult.entrypoint];
|
|
369
471
|
|
|
370
472
|
while (executions.length !== 0) {
|
|
371
473
|
const execution = executions.shift()!;
|
|
372
474
|
executions.unshift(...execution!.nestedExecutionResults);
|
|
373
475
|
|
|
476
|
+
// Just like kernels we overwrite the default value if the call sets it.
|
|
477
|
+
const callExpirationTimestamp = execution.publicInputs.expirationTimestamp;
|
|
478
|
+
if (callExpirationTimestamp !== 0n && callExpirationTimestamp < expirationTimestamp) {
|
|
479
|
+
expirationTimestamp = callExpirationTimestamp;
|
|
480
|
+
}
|
|
481
|
+
|
|
374
482
|
const { contractAddress } = execution.publicInputs.callContext;
|
|
375
483
|
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
new OrderedSideEffect(await siloNoteHash(contractAddress, noteHash.value), noteHash.counter),
|
|
383
|
-
),
|
|
384
|
-
);
|
|
484
|
+
if (execution.publicInputs.isFeePayer) {
|
|
485
|
+
if (!feePayer.isZero()) {
|
|
486
|
+
throw new Error('Multiple fee payers found in private execution result');
|
|
487
|
+
}
|
|
488
|
+
feePayer = contractAddress;
|
|
489
|
+
}
|
|
385
490
|
|
|
386
|
-
|
|
387
|
-
execution.publicInputs.
|
|
491
|
+
scopedNoteHashes.push(
|
|
492
|
+
...execution.publicInputs.noteHashes
|
|
388
493
|
.getActiveItems()
|
|
389
|
-
.
|
|
390
|
-
|
|
391
|
-
new OrderedSideEffect(await siloNullifier(contractAddress, nullifier.value), nullifier.counter),
|
|
392
|
-
),
|
|
494
|
+
.filter(nh => !nh.isEmpty())
|
|
495
|
+
.map(nh => nh.scope(contractAddress)),
|
|
393
496
|
);
|
|
497
|
+
scopedNullifiers.push(...execution.publicInputs.nullifiers.getActiveItems().map(n => n.scope(contractAddress)));
|
|
394
498
|
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
499
|
+
taggedPrivateLogs.push(
|
|
500
|
+
...(await Promise.all(
|
|
501
|
+
execution.publicInputs.privateLogs.getActiveItems().map(async metadata => {
|
|
502
|
+
metadata.log.fields[0] = await computeSiloedPrivateLogFirstField(contractAddress, metadata.log.fields[0]);
|
|
503
|
+
return new OrderedSideEffect(metadata, metadata.counter);
|
|
504
|
+
}),
|
|
505
|
+
)),
|
|
400
506
|
);
|
|
401
507
|
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
nullifiers.push(...nullifiersFromExecution);
|
|
508
|
+
noteHashReadRequests.push(...execution.publicInputs.noteHashReadRequests.getActiveItems());
|
|
509
|
+
nullifierReadRequests.push(...execution.publicInputs.nullifierReadRequests.getActiveItems());
|
|
405
510
|
l2ToL1Messages.push(
|
|
406
511
|
...execution.publicInputs.l2ToL1Msgs
|
|
407
512
|
.getActiveItems()
|
|
@@ -430,7 +535,7 @@ export async function generateSimulatedProvingResult(
|
|
|
430
535
|
: execution.publicInputs.publicTeardownCallRequest;
|
|
431
536
|
|
|
432
537
|
executionSteps.push({
|
|
433
|
-
functionName: await
|
|
538
|
+
functionName: await debugFunctionNameGetter(
|
|
434
539
|
execution.publicInputs.callContext.contractAddress,
|
|
435
540
|
execution.publicInputs.callContext.functionSelector,
|
|
436
541
|
),
|
|
@@ -441,6 +546,47 @@ export async function generateSimulatedProvingResult(
|
|
|
441
546
|
});
|
|
442
547
|
}
|
|
443
548
|
|
|
549
|
+
const noteHashNullifierCounterMap = collectNoteHashNullifierCounterMap(privateExecutionResult);
|
|
550
|
+
const minRevertibleSideEffectCounter =
|
|
551
|
+
minRevertibleSideEffectCounterOverride ?? getFinalMinRevertibleSideEffectCounter(privateExecutionResult);
|
|
552
|
+
|
|
553
|
+
const scopedNoteHashesCLA = new ClaimedLengthArray<ScopedNoteHash, typeof MAX_NOTE_HASHES_PER_TX>(
|
|
554
|
+
padArrayEnd(scopedNoteHashes, ScopedNoteHash.empty(), MAX_NOTE_HASHES_PER_TX),
|
|
555
|
+
scopedNoteHashes.length,
|
|
556
|
+
);
|
|
557
|
+
const scopedNullifiersCLA = new ClaimedLengthArray<ScopedNullifier, typeof MAX_NULLIFIERS_PER_TX>(
|
|
558
|
+
padArrayEnd(scopedNullifiers, ScopedNullifier.empty(), MAX_NULLIFIERS_PER_TX),
|
|
559
|
+
scopedNullifiers.length,
|
|
560
|
+
);
|
|
561
|
+
|
|
562
|
+
const { filteredNoteHashes, filteredNullifiers, filteredPrivateLogs } = squashTransientSideEffects(
|
|
563
|
+
taggedPrivateLogs,
|
|
564
|
+
scopedNoteHashesCLA,
|
|
565
|
+
scopedNullifiersCLA,
|
|
566
|
+
noteHashNullifierCounterMap,
|
|
567
|
+
minRevertibleSideEffectCounter,
|
|
568
|
+
);
|
|
569
|
+
|
|
570
|
+
await verifyReadRequests(
|
|
571
|
+
node,
|
|
572
|
+
await privateExecutionResult.entrypoint.publicInputs.anchorBlockHeader.hash(),
|
|
573
|
+
noteHashReadRequests,
|
|
574
|
+
nullifierReadRequests,
|
|
575
|
+
scopedNoteHashesCLA,
|
|
576
|
+
scopedNullifiersCLA,
|
|
577
|
+
);
|
|
578
|
+
|
|
579
|
+
const siloedNoteHashes = await Promise.all(
|
|
580
|
+
filteredNoteHashes
|
|
581
|
+
.sort((a, b) => a.counter - b.counter)
|
|
582
|
+
.map(async nh => new OrderedSideEffect(await siloNoteHash(nh.contractAddress, nh.value), nh.counter)),
|
|
583
|
+
);
|
|
584
|
+
const siloedNullifiers = await Promise.all(
|
|
585
|
+
filteredNullifiers
|
|
586
|
+
.sort((a, b) => a.counter - b.counter)
|
|
587
|
+
.map(async n => new OrderedSideEffect(await siloNullifier(n.contractAddress, n.value), n.counter)),
|
|
588
|
+
);
|
|
589
|
+
|
|
444
590
|
const constantData = new TxConstantData(
|
|
445
591
|
privateExecutionResult.entrypoint.publicInputs.anchorBlockHeader,
|
|
446
592
|
privateExecutionResult.entrypoint.publicInputs.txContext,
|
|
@@ -457,23 +603,23 @@ export async function generateSimulatedProvingResult(
|
|
|
457
603
|
const getEffect = <T>(orderedSideEffect: OrderedSideEffect<T>) => orderedSideEffect.sideEffect;
|
|
458
604
|
|
|
459
605
|
const isPrivateOnlyTx = privateExecutionResult.publicFunctionCalldata.length === 0;
|
|
460
|
-
const minRevertibleSideEffectCounter = getFinalMinRevertibleSideEffectCounter(privateExecutionResult);
|
|
461
606
|
|
|
462
607
|
const [nonRevertibleNullifiers, revertibleNullifiers] = splitOrderedSideEffects(
|
|
463
|
-
|
|
608
|
+
siloedNullifiers,
|
|
464
609
|
minRevertibleSideEffectCounter,
|
|
465
610
|
);
|
|
466
|
-
|
|
611
|
+
const nonceGenerator = privateExecutionResult.firstNullifier;
|
|
612
|
+
if (nonRevertibleNullifiers.length === 0) {
|
|
613
|
+
nonRevertibleNullifiers.push(nonceGenerator);
|
|
614
|
+
} else if (!nonRevertibleNullifiers[0].equals(nonceGenerator)) {
|
|
467
615
|
throw new Error('The first non revertible nullifier should be equal to the nonce generator. This is a bug!');
|
|
468
|
-
} else {
|
|
469
|
-
nonRevertibleNullifiers.unshift(nonceGenerator);
|
|
470
616
|
}
|
|
471
617
|
|
|
472
618
|
if (isPrivateOnlyTx) {
|
|
473
619
|
// We must make the note hashes unique by using the
|
|
474
620
|
// nonce generator and their index in the tx.
|
|
475
621
|
const uniqueNoteHashes = await Promise.all(
|
|
476
|
-
siloedNoteHashes.
|
|
622
|
+
siloedNoteHashes.map(async (orderedSideEffect, i) => {
|
|
477
623
|
const siloedNoteHash = orderedSideEffect.sideEffect;
|
|
478
624
|
const nonce = await computeNoteHashNonce(nonceGenerator, i);
|
|
479
625
|
const uniqueNoteHash = await computeUniqueNoteHash(nonce, siloedNoteHash);
|
|
@@ -488,26 +634,32 @@ export async function generateSimulatedProvingResult(
|
|
|
488
634
|
ScopedL2ToL1Message.empty(),
|
|
489
635
|
MAX_L2_TO_L1_MSGS_PER_TX,
|
|
490
636
|
),
|
|
491
|
-
padArrayEnd(
|
|
637
|
+
padArrayEnd(filteredPrivateLogs.sort(sortByCounter).map(getEffect), PrivateLog.empty(), MAX_PRIVATE_LOGS_PER_TX),
|
|
492
638
|
padArrayEnd(
|
|
493
639
|
contractClassLogsHashes.sort(sortByCounter).map(getEffect),
|
|
494
640
|
ScopedLogHash.empty(),
|
|
495
641
|
MAX_CONTRACT_CLASS_LOGS_PER_TX,
|
|
496
642
|
),
|
|
497
643
|
);
|
|
498
|
-
gasUsed = meterGasUsed(accumulatedDataForRollup);
|
|
644
|
+
gasUsed = meterGasUsed(accumulatedDataForRollup, isPrivateOnlyTx);
|
|
499
645
|
inputsForRollup = new PartialPrivateTailPublicInputsForRollup(accumulatedDataForRollup);
|
|
500
646
|
} else {
|
|
501
647
|
const [nonRevertibleNoteHashes, revertibleNoteHashes] = splitOrderedSideEffects(
|
|
502
|
-
siloedNoteHashes
|
|
648
|
+
siloedNoteHashes,
|
|
503
649
|
minRevertibleSideEffectCounter,
|
|
504
650
|
);
|
|
651
|
+
const nonRevertibleUniqueNoteHashes = await Promise.all(
|
|
652
|
+
nonRevertibleNoteHashes.map(async (noteHash, i) => {
|
|
653
|
+
const nonce = await computeNoteHashNonce(nonceGenerator, i);
|
|
654
|
+
return await computeUniqueNoteHash(nonce, noteHash);
|
|
655
|
+
}),
|
|
656
|
+
);
|
|
505
657
|
const [nonRevertibleL2ToL1Messages, revertibleL2ToL1Messages] = splitOrderedSideEffects(
|
|
506
658
|
l2ToL1Messages.sort(sortByCounter),
|
|
507
659
|
minRevertibleSideEffectCounter,
|
|
508
660
|
);
|
|
509
661
|
const [nonRevertibleTaggedPrivateLogs, revertibleTaggedPrivateLogs] = splitOrderedSideEffects(
|
|
510
|
-
|
|
662
|
+
filteredPrivateLogs,
|
|
511
663
|
minRevertibleSideEffectCounter,
|
|
512
664
|
);
|
|
513
665
|
const [nonRevertibleContractClassLogHashes, revertibleContractClassLogHashes] = splitOrderedSideEffects(
|
|
@@ -520,7 +672,7 @@ export async function generateSimulatedProvingResult(
|
|
|
520
672
|
);
|
|
521
673
|
|
|
522
674
|
const nonRevertibleData = new PrivateToPublicAccumulatedData(
|
|
523
|
-
padArrayEnd(
|
|
675
|
+
padArrayEnd(nonRevertibleUniqueNoteHashes, Fr.ZERO, MAX_NOTE_HASHES_PER_TX),
|
|
524
676
|
padArrayEnd(nonRevertibleNullifiers, Fr.ZERO, MAX_NULLIFIERS_PER_TX),
|
|
525
677
|
padArrayEnd(nonRevertibleL2ToL1Messages, ScopedL2ToL1Message.empty(), MAX_L2_TO_L1_MSGS_PER_TX),
|
|
526
678
|
padArrayEnd(nonRevertibleTaggedPrivateLogs, PrivateLog.empty(), MAX_PRIVATE_LOGS_PER_TX),
|
|
@@ -536,9 +688,9 @@ export async function generateSimulatedProvingResult(
|
|
|
536
688
|
padArrayEnd(revertibleContractClassLogHashes, ScopedLogHash.empty(), MAX_CONTRACT_CLASS_LOGS_PER_TX),
|
|
537
689
|
padArrayEnd(revertiblePublicCallRequests, PublicCallRequest.empty(), MAX_ENQUEUED_CALLS_PER_TX),
|
|
538
690
|
);
|
|
539
|
-
gasUsed = meterGasUsed(revertibleData).add(meterGasUsed(nonRevertibleData));
|
|
691
|
+
gasUsed = meterGasUsed(revertibleData, isPrivateOnlyTx).add(meterGasUsed(nonRevertibleData, isPrivateOnlyTx));
|
|
540
692
|
if (publicTeardownCallRequest) {
|
|
541
|
-
gasUsed.add(privateExecutionResult.entrypoint.publicInputs.txContext.gasSettings.teardownGasLimits);
|
|
693
|
+
gasUsed = gasUsed.add(privateExecutionResult.entrypoint.publicInputs.txContext.gasSettings.teardownGasLimits);
|
|
542
694
|
}
|
|
543
695
|
|
|
544
696
|
inputsForPublic = new PartialPrivateTailPublicInputsForPublic(
|
|
@@ -550,9 +702,14 @@ export async function generateSimulatedProvingResult(
|
|
|
550
702
|
|
|
551
703
|
const publicInputs = new PrivateKernelTailCircuitPublicInputs(
|
|
552
704
|
constantData,
|
|
553
|
-
/*gasUsed=*/ gasUsed.add(
|
|
554
|
-
|
|
555
|
-
|
|
705
|
+
/*gasUsed=*/ gasUsed.add(
|
|
706
|
+
Gas.from({
|
|
707
|
+
l2Gas: isPrivateOnlyTx ? PRIVATE_TX_L2_GAS_OVERHEAD : PUBLIC_TX_L2_GAS_OVERHEAD,
|
|
708
|
+
daGas: TX_DA_GAS_OVERHEAD,
|
|
709
|
+
}),
|
|
710
|
+
),
|
|
711
|
+
/*feePayer=*/ feePayer,
|
|
712
|
+
/*expirationTimestamp=*/ expirationTimestamp,
|
|
556
713
|
hasPublicCalls ? inputsForPublic : undefined,
|
|
557
714
|
!hasPublicCalls ? inputsForRollup : undefined,
|
|
558
715
|
);
|
|
@@ -564,11 +721,121 @@ export async function generateSimulatedProvingResult(
|
|
|
564
721
|
};
|
|
565
722
|
}
|
|
566
723
|
|
|
724
|
+
/**
|
|
725
|
+
* Squashes transient note hashes and nullifiers, mimicking the behavior
|
|
726
|
+
* of the reset kernels. Returns the filtered (surviving) scoped items and private logs.
|
|
727
|
+
*/
|
|
728
|
+
function squashTransientSideEffects(
|
|
729
|
+
taggedPrivateLogs: OrderedSideEffect<PrivateLogData>[],
|
|
730
|
+
scopedNoteHashesCLA: ClaimedLengthArray<ScopedNoteHash, typeof MAX_NOTE_HASHES_PER_TX>,
|
|
731
|
+
scopedNullifiersCLA: ClaimedLengthArray<ScopedNullifier, typeof MAX_NULLIFIERS_PER_TX>,
|
|
732
|
+
noteHashNullifierCounterMap: Map<number, number>,
|
|
733
|
+
minRevertibleSideEffectCounter: number,
|
|
734
|
+
) {
|
|
735
|
+
const { numTransientData, hints: transientDataHints } = buildTransientDataHints(
|
|
736
|
+
scopedNoteHashesCLA,
|
|
737
|
+
scopedNullifiersCLA,
|
|
738
|
+
/*futureNoteHashReads=*/ [],
|
|
739
|
+
/*futureNullifierReads=*/ [],
|
|
740
|
+
/*futureLogs=*/ [],
|
|
741
|
+
noteHashNullifierCounterMap,
|
|
742
|
+
minRevertibleSideEffectCounter,
|
|
743
|
+
);
|
|
744
|
+
|
|
745
|
+
const squashedNoteHashCounters = new Set<number>();
|
|
746
|
+
const squashedNullifierCounters = new Set<number>();
|
|
747
|
+
for (let i = 0; i < numTransientData; i++) {
|
|
748
|
+
const hint = transientDataHints[i];
|
|
749
|
+
squashedNoteHashCounters.add(scopedNoteHashesCLA.array[hint.noteHashIndex].counter);
|
|
750
|
+
squashedNullifierCounters.add(scopedNullifiersCLA.array[hint.nullifierIndex].counter);
|
|
751
|
+
}
|
|
752
|
+
|
|
753
|
+
return {
|
|
754
|
+
filteredNoteHashes: scopedNoteHashesCLA.getActiveItems().filter(nh => !squashedNoteHashCounters.has(nh.counter)),
|
|
755
|
+
filteredNullifiers: scopedNullifiersCLA.getActiveItems().filter(n => !squashedNullifierCounters.has(n.counter)),
|
|
756
|
+
filteredPrivateLogs: taggedPrivateLogs
|
|
757
|
+
.filter(item => !squashedNoteHashCounters.has(item.sideEffect.noteHashCounter))
|
|
758
|
+
.map(item => new OrderedSideEffect(item.sideEffect.log, item.counter)),
|
|
759
|
+
};
|
|
760
|
+
}
|
|
761
|
+
|
|
762
|
+
/**
|
|
763
|
+
* Verifies settled read requests by checking membership in the note hash and nullifier trees
|
|
764
|
+
* at the tx's anchor block, mimicking the behavior of the kernels
|
|
765
|
+
*/
|
|
766
|
+
async function verifyReadRequests(
|
|
767
|
+
node: Pick<AztecNode, 'findLeavesIndexes'>,
|
|
768
|
+
anchorBlockHash: BlockParameter,
|
|
769
|
+
noteHashReadRequests: ScopedReadRequest[],
|
|
770
|
+
nullifierReadRequests: ScopedReadRequest[],
|
|
771
|
+
scopedNoteHashesCLA: ClaimedLengthArray<ScopedNoteHash, typeof MAX_NOTE_HASHES_PER_TX>,
|
|
772
|
+
scopedNullifiersCLA: ClaimedLengthArray<ScopedNullifier, typeof MAX_NULLIFIERS_PER_TX>,
|
|
773
|
+
) {
|
|
774
|
+
const noteHashReadRequestsCLA = new ClaimedLengthArray<ScopedReadRequest, typeof MAX_NOTE_HASH_READ_REQUESTS_PER_TX>(
|
|
775
|
+
padArrayEnd(noteHashReadRequests, ScopedReadRequest.empty(), MAX_NOTE_HASH_READ_REQUESTS_PER_TX),
|
|
776
|
+
noteHashReadRequests.length,
|
|
777
|
+
);
|
|
778
|
+
const nullifierReadRequestsCLA = new ClaimedLengthArray<ScopedReadRequest, typeof MAX_NULLIFIER_READ_REQUESTS_PER_TX>(
|
|
779
|
+
padArrayEnd(nullifierReadRequests, ScopedReadRequest.empty(), MAX_NULLIFIER_READ_REQUESTS_PER_TX),
|
|
780
|
+
nullifierReadRequests.length,
|
|
781
|
+
);
|
|
782
|
+
|
|
783
|
+
const noteHashResetActions = getNoteHashReadRequestResetActions(noteHashReadRequestsCLA, scopedNoteHashesCLA);
|
|
784
|
+
const nullifierResetActions = getNullifierReadRequestResetActions(nullifierReadRequestsCLA, scopedNullifiersCLA);
|
|
785
|
+
|
|
786
|
+
const settledNoteHashReads: { index: number; value: Fr }[] = [];
|
|
787
|
+
for (let i = 0; i < noteHashResetActions.actions.length; i++) {
|
|
788
|
+
if (noteHashResetActions.actions[i] === ReadRequestActionEnum.READ_AS_SETTLED) {
|
|
789
|
+
settledNoteHashReads.push({ index: i, value: noteHashReadRequests[i].value });
|
|
790
|
+
}
|
|
791
|
+
}
|
|
792
|
+
|
|
793
|
+
const settledNullifierReads: { index: number; value: Fr }[] = [];
|
|
794
|
+
for (let i = 0; i < nullifierResetActions.actions.length; i++) {
|
|
795
|
+
if (nullifierResetActions.actions[i] === ReadRequestActionEnum.READ_AS_SETTLED) {
|
|
796
|
+
settledNullifierReads.push({ index: i, value: nullifierReadRequests[i].value });
|
|
797
|
+
}
|
|
798
|
+
}
|
|
799
|
+
|
|
800
|
+
const [noteHashResults, nullifierResults] = await Promise.all([
|
|
801
|
+
settledNoteHashReads.length > 0
|
|
802
|
+
? node.findLeavesIndexes(
|
|
803
|
+
anchorBlockHash,
|
|
804
|
+
MerkleTreeId.NOTE_HASH_TREE,
|
|
805
|
+
settledNoteHashReads.map(({ value }) => value),
|
|
806
|
+
)
|
|
807
|
+
: [],
|
|
808
|
+
settledNullifierReads.length > 0
|
|
809
|
+
? node.findLeavesIndexes(
|
|
810
|
+
anchorBlockHash,
|
|
811
|
+
MerkleTreeId.NULLIFIER_TREE,
|
|
812
|
+
settledNullifierReads.map(({ value }) => value),
|
|
813
|
+
)
|
|
814
|
+
: [],
|
|
815
|
+
]);
|
|
816
|
+
|
|
817
|
+
for (let i = 0; i < settledNoteHashReads.length; i++) {
|
|
818
|
+
if (!noteHashResults[i]) {
|
|
819
|
+
throw new Error(
|
|
820
|
+
`Note hash read request at index ${settledNoteHashReads[i].index} is reading an unknown note hash: ${settledNoteHashReads[i].value}`,
|
|
821
|
+
);
|
|
822
|
+
}
|
|
823
|
+
}
|
|
824
|
+
|
|
825
|
+
for (let i = 0; i < settledNullifierReads.length; i++) {
|
|
826
|
+
if (!nullifierResults[i]) {
|
|
827
|
+
throw new Error(
|
|
828
|
+
`Nullifier read request at index ${settledNullifierReads[i].index} is reading an unknown nullifier: ${settledNullifierReads[i].value}`,
|
|
829
|
+
);
|
|
830
|
+
}
|
|
831
|
+
}
|
|
832
|
+
}
|
|
833
|
+
|
|
567
834
|
function splitOrderedSideEffects<T>(effects: OrderedSideEffect<T>[], minRevertibleSideEffectCounter: number) {
|
|
568
835
|
const revertibleSideEffects: T[] = [];
|
|
569
836
|
const nonRevertibleSideEffects: T[] = [];
|
|
570
837
|
effects.forEach(effect => {
|
|
571
|
-
if (effect.counter < minRevertibleSideEffectCounter) {
|
|
838
|
+
if (minRevertibleSideEffectCounter === 0 || effect.counter < minRevertibleSideEffectCounter) {
|
|
572
839
|
nonRevertibleSideEffects.push(effect.sideEffect);
|
|
573
840
|
} else {
|
|
574
841
|
revertibleSideEffects.push(effect.sideEffect);
|
|
@@ -577,21 +844,24 @@ function splitOrderedSideEffects<T>(effects: OrderedSideEffect<T>[], minRevertib
|
|
|
577
844
|
return [nonRevertibleSideEffects, revertibleSideEffects];
|
|
578
845
|
}
|
|
579
846
|
|
|
580
|
-
function meterGasUsed(data: PrivateToRollupAccumulatedData | PrivateToPublicAccumulatedData) {
|
|
847
|
+
function meterGasUsed(data: PrivateToRollupAccumulatedData | PrivateToPublicAccumulatedData, isPrivateOnlyTx: boolean) {
|
|
581
848
|
let meteredDAFields = 0;
|
|
582
849
|
let meteredL2Gas = 0;
|
|
583
850
|
|
|
584
851
|
const numNoteHashes = arrayNonEmptyLength(data.noteHashes, hash => hash.isEmpty());
|
|
585
852
|
meteredDAFields += numNoteHashes;
|
|
586
|
-
|
|
853
|
+
const noteHashBaseGas = isPrivateOnlyTx ? L2_GAS_PER_NOTE_HASH : AVM_EMITNOTEHASH_BASE_L2_GAS;
|
|
854
|
+
meteredL2Gas += numNoteHashes * noteHashBaseGas;
|
|
587
855
|
|
|
588
856
|
const numNullifiers = arrayNonEmptyLength(data.nullifiers, nullifier => nullifier.isEmpty());
|
|
589
857
|
meteredDAFields += numNullifiers;
|
|
590
|
-
|
|
858
|
+
const nullifierBaseGas = isPrivateOnlyTx ? L2_GAS_PER_NULLIFIER : AVM_EMITNULLIFIER_BASE_L2_GAS;
|
|
859
|
+
meteredL2Gas += numNullifiers * nullifierBaseGas;
|
|
591
860
|
|
|
592
861
|
const numL2toL1Messages = arrayNonEmptyLength(data.l2ToL1Msgs, msg => msg.isEmpty());
|
|
593
862
|
meteredDAFields += numL2toL1Messages;
|
|
594
|
-
|
|
863
|
+
const l2ToL1MessageBaseGas = isPrivateOnlyTx ? L2_GAS_PER_L2_TO_L1_MSG : AVM_SENDL2TOL1MSG_BASE_L2_GAS;
|
|
864
|
+
meteredL2Gas += numL2toL1Messages * l2ToL1MessageBaseGas;
|
|
595
865
|
|
|
596
866
|
const numPrivatelogs = arrayNonEmptyLength(data.privateLogs, log => log.isEmpty());
|
|
597
867
|
// Every private log emits its length as an additional field
|
|
@@ -599,14 +869,14 @@ function meterGasUsed(data: PrivateToRollupAccumulatedData | PrivateToPublicAccu
|
|
|
599
869
|
meteredL2Gas += numPrivatelogs * L2_GAS_PER_PRIVATE_LOG;
|
|
600
870
|
|
|
601
871
|
const numContractClassLogs = arrayNonEmptyLength(data.contractClassLogsHashes, log => log.isEmpty());
|
|
602
|
-
// Every contract class log emits its
|
|
872
|
+
// Every contract class log emits its contract address as an additional field
|
|
603
873
|
meteredDAFields += data.contractClassLogsHashes.reduce(
|
|
604
|
-
(acc, log) => (!log.isEmpty() ? acc + log.logHash.length +
|
|
874
|
+
(acc, log) => (!log.isEmpty() ? acc + log.logHash.length + 1 : acc),
|
|
605
875
|
0,
|
|
606
876
|
);
|
|
607
877
|
meteredL2Gas += numContractClassLogs * L2_GAS_PER_CONTRACT_CLASS_LOG;
|
|
608
878
|
|
|
609
|
-
const meteredDAGas = meteredDAFields *
|
|
879
|
+
const meteredDAGas = meteredDAFields * DA_GAS_PER_FIELD;
|
|
610
880
|
|
|
611
881
|
if ((data as PrivateToPublicAccumulatedData).publicCallRequests) {
|
|
612
882
|
const dataForPublic = data as PrivateToPublicAccumulatedData;
|