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