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