@aztec/simulator 0.0.1-commit.24de95ac → 0.0.1-commit.2ed92850
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/README.md +2 -0
- package/dest/client.d.ts +1 -1
- package/dest/common/errors.d.ts +2 -2
- package/dest/common/errors.d.ts.map +1 -1
- package/dest/common/index.d.ts +1 -1
- package/dest/common/stats/index.d.ts +1 -1
- package/dest/common/stats/stats.d.ts +1 -1
- package/dest/private/acvm/acvm.d.ts +1 -1
- package/dest/private/acvm/acvm_types.d.ts +1 -1
- package/dest/private/acvm/deserialize.d.ts +2 -2
- package/dest/private/acvm/deserialize.d.ts.map +1 -1
- package/dest/private/acvm/deserialize.js +1 -1
- package/dest/private/acvm/index.d.ts +1 -1
- package/dest/private/acvm/serialize.d.ts +2 -2
- package/dest/private/acvm/serialize.d.ts.map +1 -1
- package/dest/private/acvm/serialize.js +1 -1
- package/dest/private/acvm_native.d.ts +1 -1
- package/dest/private/acvm_native.d.ts.map +1 -1
- package/dest/private/acvm_wasm.d.ts +1 -1
- package/dest/private/acvm_wasm.d.ts.map +1 -1
- package/dest/private/acvm_wasm_with_blobs.d.ts +1 -1
- package/dest/private/acvm_wasm_with_blobs.d.ts.map +1 -1
- package/dest/private/circuit_recording/circuit_recorder.d.ts +1 -1
- package/dest/private/circuit_recording/circuit_recorder.d.ts.map +1 -1
- package/dest/private/circuit_recording/circuit_recorder.js +16 -15
- package/dest/private/circuit_recording/file_circuit_recorder.d.ts +1 -1
- package/dest/private/circuit_recording/file_circuit_recorder.d.ts.map +1 -1
- package/dest/private/circuit_recording/memory_circuit_recorder.d.ts +1 -1
- package/dest/private/circuit_recording/memory_circuit_recorder.d.ts.map +1 -1
- package/dest/private/circuit_recording/simulator_recorder_wrapper.d.ts +1 -1
- package/dest/private/circuit_recording/simulator_recorder_wrapper.d.ts.map +1 -1
- package/dest/private/circuit_simulator.d.ts +1 -1
- package/dest/private/factory.d.ts +1 -1
- package/dest/public/avm/avm_context.d.ts +3 -3
- package/dest/public/avm/avm_context.d.ts.map +1 -1
- package/dest/public/avm/avm_contract_call_result.d.ts +6 -6
- package/dest/public/avm/avm_contract_call_result.d.ts.map +1 -1
- package/dest/public/avm/avm_contract_call_result.js +3 -3
- package/dest/public/avm/avm_execution_environment.d.ts +9 -8
- package/dest/public/avm/avm_execution_environment.d.ts.map +1 -1
- package/dest/public/avm/avm_execution_environment.js +5 -8
- package/dest/public/avm/avm_gas.d.ts +2 -2
- package/dest/public/avm/avm_gas.d.ts.map +1 -1
- package/dest/public/avm/avm_machine_state.d.ts +7 -6
- package/dest/public/avm/avm_machine_state.d.ts.map +1 -1
- package/dest/public/avm/avm_machine_state.js +3 -2
- package/dest/public/avm/avm_memory_types.d.ts +14 -14
- package/dest/public/avm/avm_memory_types.d.ts.map +1 -1
- package/dest/public/avm/avm_memory_types.js +4 -1
- package/dest/public/avm/avm_simulator.d.ts +5 -3
- package/dest/public/avm/avm_simulator.d.ts.map +1 -1
- package/dest/public/avm/avm_simulator.js +13 -11
- package/dest/public/avm/avm_simulator_interface.d.ts +1 -1
- package/dest/public/avm/calldata.d.ts +51 -0
- package/dest/public/avm/calldata.d.ts.map +1 -0
- package/dest/public/avm/calldata.js +63 -0
- package/dest/public/avm/errors.d.ts +8 -2
- package/dest/public/avm/errors.d.ts.map +1 -1
- package/dest/public/avm/errors.js +14 -2
- package/dest/public/avm/fixtures/avm_simulation_tester.d.ts +1 -1
- package/dest/public/avm/fixtures/avm_simulation_tester.d.ts.map +1 -1
- package/dest/public/avm/fixtures/avm_simulation_tester.js +15 -5
- package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts +2 -2
- package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts.map +1 -1
- package/dest/public/avm/fixtures/base_avm_simulation_tester.js +1 -1
- package/dest/public/avm/fixtures/initializers.d.ts +2 -3
- package/dest/public/avm/fixtures/initializers.d.ts.map +1 -1
- package/dest/public/avm/fixtures/initializers.js +8 -5
- package/dest/public/avm/fixtures/utils.d.ts +4 -3
- package/dest/public/avm/fixtures/utils.d.ts.map +1 -1
- package/dest/public/avm/fixtures/utils.js +3 -2
- package/dest/public/avm/index.d.ts +1 -1
- package/dest/public/avm/opcodes/accrued_substate.d.ts +15 -15
- package/dest/public/avm/opcodes/accrued_substate.d.ts.map +1 -1
- package/dest/public/avm/opcodes/accrued_substate.js +33 -29
- package/dest/public/avm/opcodes/addressing_mode.d.ts +1 -1
- package/dest/public/avm/opcodes/addressing_mode.d.ts.map +1 -1
- package/dest/public/avm/opcodes/addressing_mode.js +2 -2
- package/dest/public/avm/opcodes/arithmetic.d.ts +3 -1
- package/dest/public/avm/opcodes/arithmetic.d.ts.map +1 -1
- package/dest/public/avm/opcodes/arithmetic.js +12 -2
- package/dest/public/avm/opcodes/bitwise.d.ts +3 -3
- package/dest/public/avm/opcodes/bitwise.d.ts.map +1 -1
- package/dest/public/avm/opcodes/bitwise.js +5 -5
- package/dest/public/avm/opcodes/comparators.d.ts +1 -1
- package/dest/public/avm/opcodes/comparators.d.ts.map +1 -1
- package/dest/public/avm/opcodes/comparators.js +1 -1
- package/dest/public/avm/opcodes/contract.d.ts +3 -3
- package/dest/public/avm/opcodes/contract.d.ts.map +1 -1
- package/dest/public/avm/opcodes/contract.js +8 -8
- package/dest/public/avm/opcodes/control_flow.d.ts +3 -3
- package/dest/public/avm/opcodes/control_flow.d.ts.map +1 -1
- package/dest/public/avm/opcodes/control_flow.js +4 -4
- package/dest/public/avm/opcodes/conversion.d.ts +3 -3
- package/dest/public/avm/opcodes/conversion.d.ts.map +1 -1
- package/dest/public/avm/opcodes/conversion.js +4 -4
- package/dest/public/avm/opcodes/ec_add.d.ts +3 -3
- package/dest/public/avm/opcodes/ec_add.d.ts.map +1 -1
- package/dest/public/avm/opcodes/ec_add.js +17 -8
- package/dest/public/avm/opcodes/environment_getters.d.ts +5 -5
- package/dest/public/avm/opcodes/environment_getters.d.ts.map +1 -1
- package/dest/public/avm/opcodes/environment_getters.js +6 -6
- package/dest/public/avm/opcodes/external_calls.d.ts +9 -9
- package/dest/public/avm/opcodes/external_calls.d.ts.map +1 -1
- package/dest/public/avm/opcodes/external_calls.js +23 -22
- package/dest/public/avm/opcodes/hashing.d.ts +7 -7
- package/dest/public/avm/opcodes/hashing.d.ts.map +1 -1
- package/dest/public/avm/opcodes/hashing.js +21 -16
- package/dest/public/avm/opcodes/index.d.ts +1 -1
- package/dest/public/avm/opcodes/instruction.d.ts +2 -2
- package/dest/public/avm/opcodes/instruction.d.ts.map +1 -1
- package/dest/public/avm/opcodes/instruction_impl.d.ts +4 -4
- package/dest/public/avm/opcodes/instruction_impl.d.ts.map +1 -1
- package/dest/public/avm/opcodes/instruction_impl.js +4 -4
- package/dest/public/avm/opcodes/memory.d.ts +13 -13
- package/dest/public/avm/opcodes/memory.d.ts.map +1 -1
- package/dest/public/avm/opcodes/memory.js +26 -26
- package/dest/public/avm/opcodes/misc.d.ts +3 -3
- package/dest/public/avm/opcodes/misc.d.ts.map +1 -1
- package/dest/public/avm/opcodes/misc.js +8 -8
- package/dest/public/avm/opcodes/storage.d.ts +14 -13
- package/dest/public/avm/opcodes/storage.d.ts.map +1 -1
- package/dest/public/avm/opcodes/storage.js +34 -24
- package/dest/public/avm/revert_reason.d.ts +2 -2
- package/dest/public/avm/revert_reason.d.ts.map +1 -1
- package/dest/public/avm/revert_reason.js +3 -2
- package/dest/public/avm/serialization/buffer_cursor.d.ts +1 -1
- package/dest/public/avm/serialization/buffer_cursor.d.ts.map +1 -1
- package/dest/public/avm/serialization/bytecode_serialization.d.ts +1 -1
- package/dest/public/avm/serialization/bytecode_serialization.d.ts.map +1 -1
- package/dest/public/avm/serialization/bytecode_serialization.js +9 -6
- package/dest/public/avm/serialization/instruction_serialization.d.ts +1 -1
- package/dest/public/avm/serialization/instruction_serialization.js +1 -1
- package/dest/public/avm/test_utils.d.ts +2 -2
- package/dest/public/avm/test_utils.d.ts.map +1 -1
- package/dest/public/avm/test_utils.js +1 -1
- package/dest/public/contracts_db_checkpoint.d.ts +16 -0
- package/dest/public/contracts_db_checkpoint.d.ts.map +1 -0
- package/dest/public/contracts_db_checkpoint.js +30 -0
- package/dest/public/db_interfaces.d.ts +14 -2
- package/dest/public/db_interfaces.d.ts.map +1 -1
- package/dest/public/debug_fn_name.d.ts +16 -3
- package/dest/public/debug_fn_name.d.ts.map +1 -1
- package/dest/public/debug_fn_name.js +31 -3
- package/dest/public/executor_metrics.d.ts +3 -2
- package/dest/public/executor_metrics.d.ts.map +1 -1
- package/dest/public/executor_metrics.js +9 -35
- package/dest/public/executor_metrics_interface.d.ts +3 -2
- package/dest/public/executor_metrics_interface.d.ts.map +1 -1
- package/dest/public/fixtures/amm_test.d.ts +1 -1
- package/dest/public/fixtures/amm_test.js +2 -2
- package/dest/public/fixtures/bulk_test.d.ts +3 -3
- package/dest/public/fixtures/bulk_test.d.ts.map +1 -1
- package/dest/public/fixtures/bulk_test.js +5 -69
- package/dest/public/fixtures/custom_bytecode_tester.d.ts +29 -7
- package/dest/public/fixtures/custom_bytecode_tester.d.ts.map +1 -1
- package/dest/public/fixtures/custom_bytecode_tester.js +36 -12
- package/dest/public/fixtures/custom_bytecode_tests.d.ts +11 -8
- package/dest/public/fixtures/custom_bytecode_tests.d.ts.map +1 -1
- package/dest/public/fixtures/custom_bytecode_tests.js +83 -18
- package/dest/public/fixtures/index.d.ts +4 -2
- package/dest/public/fixtures/index.d.ts.map +1 -1
- package/dest/public/fixtures/index.js +3 -1
- package/dest/public/fixtures/minimal_public_tx.d.ts +2 -8
- package/dest/public/fixtures/minimal_public_tx.d.ts.map +1 -1
- package/dest/public/fixtures/minimal_public_tx.js +6 -16
- package/dest/public/fixtures/opcode_spammer.d.ts +123 -0
- package/dest/public/fixtures/opcode_spammer.d.ts.map +1 -0
- package/dest/public/fixtures/opcode_spammer.js +1693 -0
- package/dest/public/fixtures/public_tx_simulation_tester.d.ts +24 -6
- package/dest/public/fixtures/public_tx_simulation_tester.d.ts.map +1 -1
- package/dest/public/fixtures/public_tx_simulation_tester.js +62 -21
- package/dest/public/fixtures/simple_contract_data_source.d.ts +5 -4
- package/dest/public/fixtures/simple_contract_data_source.d.ts.map +1 -1
- package/dest/public/fixtures/simple_contract_data_source.js +4 -4
- package/dest/public/fixtures/token_test.d.ts +6 -2
- package/dest/public/fixtures/token_test.d.ts.map +1 -1
- package/dest/public/fixtures/token_test.js +13 -12
- package/dest/public/fixtures/utils.d.ts +2 -2
- package/dest/public/fixtures/utils.d.ts.map +1 -1
- package/dest/public/fixtures/utils.js +4 -3
- package/dest/public/fuzzing/avm_fuzzer_simulator.d.ts +60 -0
- package/dest/public/fuzzing/avm_fuzzer_simulator.d.ts.map +1 -0
- package/dest/public/fuzzing/avm_fuzzer_simulator.js +171 -0
- package/dest/public/fuzzing/avm_simulator_bin.d.ts +2 -0
- package/dest/public/fuzzing/avm_simulator_bin.d.ts.map +1 -0
- package/dest/public/fuzzing/avm_simulator_bin.js +118 -0
- package/dest/public/hinting_db_sources.d.ts +14 -4
- package/dest/public/hinting_db_sources.d.ts.map +1 -1
- package/dest/public/hinting_db_sources.js +71 -13
- package/dest/public/index.d.ts +3 -2
- package/dest/public/index.d.ts.map +1 -1
- package/dest/public/index.js +1 -1
- package/dest/public/public_db_sources.d.ts +22 -63
- package/dest/public/public_db_sources.d.ts.map +1 -1
- package/dest/public/public_db_sources.js +74 -131
- package/dest/public/public_errors.d.ts +1 -1
- package/dest/public/public_errors.d.ts.map +1 -1
- package/dest/public/public_processor/guarded_merkle_tree.d.ts +6 -4
- package/dest/public/public_processor/guarded_merkle_tree.d.ts.map +1 -1
- package/dest/public/public_processor/guarded_merkle_tree.js +5 -0
- package/dest/public/public_processor/public_processor.d.ts +12 -19
- package/dest/public/public_processor/public_processor.d.ts.map +1 -1
- package/dest/public/public_processor/public_processor.js +456 -64
- package/dest/public/public_processor/public_processor_metrics.d.ts +1 -1
- package/dest/public/public_processor/public_processor_metrics.d.ts.map +1 -1
- package/dest/public/public_processor/public_processor_metrics.js +12 -45
- package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts +18 -0
- package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/contract_provider_for_cpp.js +98 -0
- package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts +34 -22
- package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/cpp_public_tx_simulator.js +93 -50
- package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.d.ts +42 -0
- package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.js +86 -0
- package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.d.ts +30 -0
- package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.js +171 -0
- package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.d.ts +22 -0
- package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.js +52 -0
- package/dest/public/public_tx_simulator/factories.d.ts +13 -0
- package/dest/public/public_tx_simulator/factories.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/factories.js +28 -0
- package/dest/public/public_tx_simulator/index.d.ts +5 -1
- package/dest/public/public_tx_simulator/index.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/index.js +3 -0
- package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts +14 -7
- package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/measured_public_tx_simulator.js +5 -5
- package/dest/public/public_tx_simulator/public_tx_context.d.ts +6 -3
- package/dest/public/public_tx_simulator/public_tx_context.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/public_tx_context.js +13 -5
- package/dest/public/public_tx_simulator/public_tx_simulator.d.ts +13 -32
- package/dest/public/public_tx_simulator/public_tx_simulator.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/public_tx_simulator.js +115 -129
- package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts +25 -2
- package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts +4 -4
- package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.js +395 -19
- package/dest/public/side_effect_errors.d.ts +1 -1
- package/dest/public/side_effect_errors.d.ts.map +1 -1
- package/dest/public/side_effect_trace.d.ts +2 -2
- package/dest/public/side_effect_trace.d.ts.map +1 -1
- package/dest/public/side_effect_trace.js +1 -1
- package/dest/public/side_effect_trace_interface.d.ts +3 -4
- package/dest/public/side_effect_trace_interface.d.ts.map +1 -1
- package/dest/public/state_manager/index.d.ts +1 -1
- package/dest/public/state_manager/nullifiers.d.ts +2 -2
- package/dest/public/state_manager/nullifiers.d.ts.map +1 -1
- package/dest/public/state_manager/public_storage.d.ts +2 -2
- package/dest/public/state_manager/public_storage.d.ts.map +1 -1
- package/dest/public/state_manager/public_storage.js +1 -1
- package/dest/public/state_manager/state_manager.d.ts +9 -11
- package/dest/public/state_manager/state_manager.d.ts.map +1 -1
- package/dest/public/state_manager/state_manager.js +12 -8
- package/dest/public/test_executor_metrics.d.ts +4 -3
- package/dest/public/test_executor_metrics.d.ts.map +1 -1
- package/dest/public/test_executor_metrics.js +5 -4
- package/dest/public/unique_class_ids.d.ts +1 -1
- package/dest/public/unique_class_ids.d.ts.map +1 -1
- package/dest/public/utils.d.ts +1 -1
- package/dest/server.d.ts +1 -1
- package/dest/testing.d.ts +1 -1
- package/package.json +21 -20
- package/src/common/errors.ts +1 -1
- package/src/private/acvm/deserialize.ts +1 -1
- package/src/private/acvm/serialize.ts +1 -1
- package/src/private/circuit_recording/circuit_recorder.ts +17 -16
- package/src/public/avm/avm_context.ts +2 -2
- package/src/public/avm/avm_contract_call_result.ts +8 -6
- package/src/public/avm/avm_execution_environment.ts +13 -10
- package/src/public/avm/avm_gas.ts +3 -3
- package/src/public/avm/avm_machine_state.ts +7 -6
- package/src/public/avm/avm_memory_types.ts +5 -1
- package/src/public/avm/avm_simulator.ts +19 -14
- package/src/public/avm/calldata.ts +100 -0
- package/src/public/avm/errors.ts +17 -3
- package/src/public/avm/fixtures/avm_simulation_tester.ts +18 -4
- package/src/public/avm/fixtures/base_avm_simulation_tester.ts +1 -1
- package/src/public/avm/fixtures/initializers.ts +10 -11
- package/src/public/avm/fixtures/utils.ts +3 -2
- package/src/public/avm/opcodes/accrued_substate.ts +21 -15
- package/src/public/avm/opcodes/addressing_mode.ts +2 -2
- package/src/public/avm/opcodes/arithmetic.ts +14 -2
- package/src/public/avm/opcodes/bitwise.ts +3 -3
- package/src/public/avm/opcodes/comparators.ts +1 -1
- package/src/public/avm/opcodes/contract.ts +4 -7
- package/src/public/avm/opcodes/control_flow.ts +2 -2
- package/src/public/avm/opcodes/conversion.ts +3 -3
- package/src/public/avm/opcodes/ec_add.ts +15 -6
- package/src/public/avm/opcodes/environment_getters.ts +7 -7
- package/src/public/avm/opcodes/external_calls.ts +17 -15
- package/src/public/avm/opcodes/hashing.ts +16 -10
- package/src/public/avm/opcodes/instruction_impl.ts +2 -2
- package/src/public/avm/opcodes/memory.ts +20 -20
- package/src/public/avm/opcodes/misc.ts +6 -6
- package/src/public/avm/opcodes/storage.ts +30 -22
- package/src/public/avm/revert_reason.ts +6 -3
- package/src/public/avm/serialization/bytecode_serialization.ts +17 -6
- package/src/public/avm/serialization/instruction_serialization.ts +1 -1
- package/src/public/avm/test_utils.ts +1 -1
- package/src/public/contracts_db_checkpoint.ts +41 -0
- package/src/public/db_interfaces.ts +16 -1
- package/src/public/debug_fn_name.ts +39 -5
- package/src/public/executor_metrics.ts +9 -35
- package/src/public/executor_metrics_interface.ts +2 -1
- package/src/public/fixtures/amm_test.ts +2 -2
- package/src/public/fixtures/bulk_test.ts +9 -9
- package/src/public/fixtures/custom_bytecode_tester.ts +54 -20
- package/src/public/fixtures/custom_bytecode_tests.ts +111 -18
- package/src/public/fixtures/index.ts +7 -1
- package/src/public/fixtures/minimal_public_tx.ts +7 -17
- package/src/public/fixtures/opcode_spammer.ts +1754 -0
- package/src/public/fixtures/public_tx_simulation_tester.ts +85 -21
- package/src/public/fixtures/simple_contract_data_source.ts +8 -9
- package/src/public/fixtures/token_test.ts +18 -10
- package/src/public/fixtures/utils.ts +2 -3
- package/src/public/fuzzing/avm_fuzzer_simulator.ts +288 -0
- package/src/public/fuzzing/avm_simulator_bin.ts +175 -0
- package/src/public/hinting_db_sources.ts +112 -10
- package/src/public/index.ts +6 -4
- package/src/public/public_db_sources.ts +93 -172
- package/src/public/public_processor/guarded_merkle_tree.ts +8 -3
- package/src/public/public_processor/public_processor.ts +86 -59
- package/src/public/public_processor/public_processor_metrics.ts +11 -45
- package/src/public/public_tx_simulator/contract_provider_for_cpp.ts +121 -0
- package/src/public/public_tx_simulator/cpp_public_tx_simulator.ts +137 -57
- package/src/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.ts +132 -0
- package/src/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.ts +237 -0
- package/src/public/public_tx_simulator/dumping_cpp_public_tx_simulator.ts +81 -0
- package/src/public/public_tx_simulator/factories.ts +41 -0
- package/src/public/public_tx_simulator/index.ts +4 -0
- package/src/public/public_tx_simulator/measured_public_tx_simulator.ts +10 -14
- package/src/public/public_tx_simulator/public_tx_context.ts +9 -3
- package/src/public/public_tx_simulator/public_tx_simulator.ts +171 -196
- package/src/public/public_tx_simulator/public_tx_simulator_interface.ts +24 -2
- package/src/public/public_tx_simulator/telemetry_public_tx_simulator.ts +3 -3
- package/src/public/side_effect_trace.ts +1 -1
- package/src/public/side_effect_trace_interface.ts +1 -1
- package/src/public/state_manager/nullifiers.ts +1 -1
- package/src/public/state_manager/public_storage.ts +1 -1
- package/src/public/state_manager/state_manager.ts +16 -30
- package/src/public/test_executor_metrics.ts +7 -5
- package/dest/public/tx_contract_cache.d.ts +0 -41
- package/dest/public/tx_contract_cache.d.ts.map +0 -1
- package/dest/public/tx_contract_cache.js +0 -49
- package/src/public/tx_contract_cache.ts +0 -69
|
@@ -1,24 +1,16 @@
|
|
|
1
|
-
import { AVM_MAX_PROCESSABLE_L2_GAS
|
|
2
|
-
import { Fr } from '@aztec/foundation/
|
|
1
|
+
import { AVM_MAX_PROCESSABLE_L2_GAS } from '@aztec/constants';
|
|
2
|
+
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
3
3
|
import { type Logger, createLogger } from '@aztec/foundation/log';
|
|
4
4
|
import { ProtocolContractAddress, ProtocolContractsList } from '@aztec/protocol-contracts';
|
|
5
5
|
import { computeFeePayerBalanceStorageSlot } from '@aztec/protocol-contracts/fee-juice';
|
|
6
|
-
import {
|
|
7
|
-
AvmCircuitInputs,
|
|
8
|
-
AvmCircuitPublicInputs,
|
|
9
|
-
AvmExecutionHints,
|
|
10
|
-
type AvmProvingRequest,
|
|
11
|
-
AvmTxHint,
|
|
12
|
-
type RevertCode,
|
|
13
|
-
} from '@aztec/stdlib/avm';
|
|
6
|
+
import { AvmExecutionHints, AvmTxHint, PublicSimulatorConfig, PublicTxEffect, PublicTxResult } from '@aztec/stdlib/avm';
|
|
14
7
|
import { SimulationError } from '@aztec/stdlib/errors';
|
|
15
|
-
import
|
|
16
|
-
import type { DebugLog } from '@aztec/stdlib/logs';
|
|
17
|
-
import { ProvingRequestType } from '@aztec/stdlib/proofs';
|
|
8
|
+
import { Gas } from '@aztec/stdlib/gas';
|
|
18
9
|
import type { MerkleTreeWriteOperations } from '@aztec/stdlib/trees';
|
|
19
10
|
import {
|
|
20
11
|
type GlobalVariables,
|
|
21
12
|
NestedProcessReturnValues,
|
|
13
|
+
ProtocolContracts,
|
|
22
14
|
PublicCallRequestWithCalldata,
|
|
23
15
|
Tx,
|
|
24
16
|
TxExecutionPhase,
|
|
@@ -27,6 +19,7 @@ import {
|
|
|
27
19
|
import { strict as assert } from 'assert';
|
|
28
20
|
|
|
29
21
|
import type { AvmFinalizedCallResult } from '../avm/avm_contract_call_result.js';
|
|
22
|
+
import { CallDataArray } from '../avm/calldata.js';
|
|
30
23
|
import { AvmSimulator } from '../avm/index.js';
|
|
31
24
|
import { getPublicFunctionDebugName } from '../debug_fn_name.js';
|
|
32
25
|
import { HintingMerkleWriteOperations, HintingPublicContractsDB } from '../hinting_db_sources.js';
|
|
@@ -41,33 +34,6 @@ import type { PublicPersistableStateManager } from '../state_manager/state_manag
|
|
|
41
34
|
import { PublicTxContext } from './public_tx_context.js';
|
|
42
35
|
import type { PublicTxSimulatorInterface } from './public_tx_simulator_interface.js';
|
|
43
36
|
|
|
44
|
-
export type ProcessedPhase = {
|
|
45
|
-
phase: TxExecutionPhase;
|
|
46
|
-
durationMs?: number;
|
|
47
|
-
returnValues: NestedProcessReturnValues[];
|
|
48
|
-
reverted: boolean;
|
|
49
|
-
revertReason?: SimulationError;
|
|
50
|
-
};
|
|
51
|
-
|
|
52
|
-
export type PublicTxResult = {
|
|
53
|
-
avmProvingRequest: AvmProvingRequest;
|
|
54
|
-
/** Gas used during the execution of this tx */
|
|
55
|
-
gasUsed: GasUsed;
|
|
56
|
-
revertCode: RevertCode;
|
|
57
|
-
/** Revert reason, if any */
|
|
58
|
-
revertReason?: SimulationError;
|
|
59
|
-
processedPhases: ProcessedPhase[];
|
|
60
|
-
logs: DebugLog[];
|
|
61
|
-
};
|
|
62
|
-
|
|
63
|
-
export type PublicTxSimulatorConfig = {
|
|
64
|
-
proverId: Fr;
|
|
65
|
-
doMerkleOperations: boolean;
|
|
66
|
-
skipFeeEnforcement: boolean;
|
|
67
|
-
clientInitiatedSimulation: boolean;
|
|
68
|
-
maxDebugLogMemoryReads: number;
|
|
69
|
-
};
|
|
70
|
-
|
|
71
37
|
// The errors below are only thrown here in the public tx simulator,
|
|
72
38
|
// and only during revertible phases (revertible insertions, app logic and teardown).
|
|
73
39
|
// These are strictly "checked" errors (not exported and never propagated).
|
|
@@ -103,23 +69,27 @@ class TxSimTeardownRevert extends Error {
|
|
|
103
69
|
}
|
|
104
70
|
}
|
|
105
71
|
|
|
72
|
+
/** Only used internally. */
|
|
73
|
+
type ProcessedPhase = {
|
|
74
|
+
phase: TxExecutionPhase;
|
|
75
|
+
durationMs?: number;
|
|
76
|
+
returnValues: NestedProcessReturnValues[];
|
|
77
|
+
reverted: boolean;
|
|
78
|
+
revertReason?: SimulationError;
|
|
79
|
+
};
|
|
80
|
+
|
|
106
81
|
export class PublicTxSimulator implements PublicTxSimulatorInterface {
|
|
107
82
|
protected log: Logger;
|
|
108
|
-
|
|
83
|
+
protected readonly config: PublicSimulatorConfig;
|
|
109
84
|
|
|
110
85
|
constructor(
|
|
111
86
|
protected merkleTree: MerkleTreeWriteOperations,
|
|
112
87
|
protected contractsDB: PublicContractsDB,
|
|
113
88
|
protected globalVariables: GlobalVariables,
|
|
114
|
-
config?: Partial<
|
|
89
|
+
config?: Partial<PublicSimulatorConfig>,
|
|
90
|
+
protected protocolContracts: ProtocolContracts = ProtocolContractsList,
|
|
115
91
|
) {
|
|
116
|
-
this.config = {
|
|
117
|
-
proverId: config?.proverId ?? Fr.ZERO,
|
|
118
|
-
doMerkleOperations: config?.doMerkleOperations ?? false,
|
|
119
|
-
skipFeeEnforcement: config?.skipFeeEnforcement ?? false,
|
|
120
|
-
clientInitiatedSimulation: config?.clientInitiatedSimulation ?? false,
|
|
121
|
-
maxDebugLogMemoryReads: config?.maxDebugLogMemoryReads ?? DEFAULT_MAX_DEBUG_LOG_MEMORY_READS,
|
|
122
|
-
};
|
|
92
|
+
this.config = PublicSimulatorConfig.from(config ?? {});
|
|
123
93
|
this.log = createLogger(`simulator:public_tx_simulator`);
|
|
124
94
|
}
|
|
125
95
|
|
|
@@ -129,136 +99,143 @@ export class PublicTxSimulator implements PublicTxSimulatorInterface {
|
|
|
129
99
|
* @returns The result of the transaction's public execution.
|
|
130
100
|
*/
|
|
131
101
|
public async simulate(tx: Tx): Promise<PublicTxResult> {
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
this.log.debug(`Simulating ${tx.publicFunctionCalldata.length} public calls for tx ${txHash}`, { txHash });
|
|
135
|
-
|
|
136
|
-
// Create hinting DBs.
|
|
137
|
-
const hints = new AvmExecutionHints(
|
|
138
|
-
this.globalVariables,
|
|
139
|
-
AvmTxHint.fromTx(tx, this.globalVariables.gasFees),
|
|
140
|
-
ProtocolContractsList, // imported from file
|
|
141
|
-
);
|
|
142
|
-
const hintingMerkleTree = await HintingMerkleWriteOperations.create(this.merkleTree, hints);
|
|
143
|
-
const hintingTreesDB = new PublicTreesDB(hintingMerkleTree);
|
|
144
|
-
const hintingContractsDB = new HintingPublicContractsDB(this.contractsDB, hints);
|
|
145
|
-
|
|
146
|
-
const context = await PublicTxContext.create(
|
|
147
|
-
hintingTreesDB,
|
|
148
|
-
hintingContractsDB,
|
|
149
|
-
tx,
|
|
150
|
-
this.globalVariables,
|
|
151
|
-
ProtocolContractsList, // imported from file
|
|
152
|
-
this.config.doMerkleOperations,
|
|
153
|
-
this.config.proverId,
|
|
154
|
-
);
|
|
102
|
+
const txHash = this.computeTxHash(tx);
|
|
103
|
+
this.log.debug(`Simulating ${tx.publicFunctionCalldata.length} public calls for tx ${txHash}`, { txHash });
|
|
155
104
|
|
|
156
|
-
|
|
105
|
+
// Create hinting DBs.
|
|
106
|
+
const hints = new AvmExecutionHints(
|
|
107
|
+
this.globalVariables,
|
|
108
|
+
AvmTxHint.fromTx(tx, this.globalVariables.gasFees),
|
|
109
|
+
this.protocolContracts,
|
|
110
|
+
);
|
|
111
|
+
const hintingMerkleTree = await HintingMerkleWriteOperations.create(this.merkleTree, hints);
|
|
112
|
+
const hintingTreesDB = new PublicTreesDB(hintingMerkleTree);
|
|
113
|
+
const hintingContractsDB = new HintingPublicContractsDB(this.contractsDB, hints);
|
|
114
|
+
|
|
115
|
+
const context = await PublicTxContext.create(
|
|
116
|
+
hintingTreesDB,
|
|
117
|
+
hintingContractsDB,
|
|
118
|
+
tx,
|
|
119
|
+
this.globalVariables,
|
|
120
|
+
this.protocolContracts,
|
|
121
|
+
this.config.proverId,
|
|
122
|
+
);
|
|
123
|
+
|
|
124
|
+
// This will throw if there is a nullifier collision.
|
|
125
|
+
// In that case the transaction will be thrown out.
|
|
126
|
+
await this.insertNonRevertiblesFromPrivate(context);
|
|
127
|
+
|
|
128
|
+
const processedPhases: ProcessedPhase[] = [];
|
|
129
|
+
if (context.hasPhase(TxExecutionPhase.SETUP)) {
|
|
130
|
+
// This will throw if the setup phase reverts.
|
|
157
131
|
// In that case the transaction will be thrown out.
|
|
158
|
-
await this.
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
// In that case the transaction will be thrown out.
|
|
164
|
-
const setupResult = await this.simulatePhase(TxExecutionPhase.SETUP, context);
|
|
165
|
-
if (setupResult.reverted) {
|
|
166
|
-
throw new Error(
|
|
167
|
-
`Setup phase reverted! The transaction will be thrown out. ${setupResult.revertReason?.message}`,
|
|
168
|
-
);
|
|
169
|
-
}
|
|
170
|
-
processedPhases.push(setupResult);
|
|
132
|
+
const setupResult = await this.simulatePhase(TxExecutionPhase.SETUP, context);
|
|
133
|
+
if (setupResult.reverted) {
|
|
134
|
+
throw new Error(
|
|
135
|
+
`[SETUP] UNRECOVERABLE ERROR! The transaction will be thrown out. ${setupResult.revertReason?.message}`,
|
|
136
|
+
);
|
|
171
137
|
}
|
|
138
|
+
processedPhases.push(setupResult);
|
|
139
|
+
}
|
|
172
140
|
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
try {
|
|
177
|
-
// This will throw if there is a nullifier collision or other insertion error (limit reached).
|
|
178
|
-
await this.insertRevertiblesFromPrivate(context, tx);
|
|
141
|
+
// The checkpoint we should go back to if anything from now on reverts.
|
|
142
|
+
await context.state.fork();
|
|
143
|
+
hintingContractsDB.createCheckpoint();
|
|
179
144
|
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
// We revert to the post-setup state.
|
|
191
|
-
await context.state.discardForkedState();
|
|
192
|
-
// But we also create a new fork so that the teardown phase can transparently
|
|
193
|
-
// commit or rollback at the end of teardown.
|
|
194
|
-
await context.state.fork();
|
|
195
|
-
} else {
|
|
196
|
-
// Unchecked/unknown error - re-throw as-is
|
|
197
|
-
throw e;
|
|
145
|
+
try {
|
|
146
|
+
// This will throw if there is a nullifier collision or other insertion error (limit reached).
|
|
147
|
+
await this.insertRevertiblesFromPrivate(context);
|
|
148
|
+
|
|
149
|
+
// Only proceed with app logic if there was no revert during revertible insertion.
|
|
150
|
+
if (context.hasPhase(TxExecutionPhase.APP_LOGIC)) {
|
|
151
|
+
const appLogicResult = await this.simulatePhase(TxExecutionPhase.APP_LOGIC, context);
|
|
152
|
+
processedPhases.push(appLogicResult);
|
|
153
|
+
if (appLogicResult.reverted) {
|
|
154
|
+
throw new TxSimAppLogicRevert();
|
|
198
155
|
}
|
|
199
156
|
}
|
|
157
|
+
} catch (e: any) {
|
|
158
|
+
if (e instanceof TxSimRevertibleInsertionsRevert || e instanceof TxSimAppLogicRevert) {
|
|
159
|
+
// We revert to the post-setup state.
|
|
160
|
+
await context.state.discardForkedState();
|
|
161
|
+
hintingContractsDB.revertCheckpoint();
|
|
162
|
+
// But we also create a new fork so that the teardown phase can transparently
|
|
163
|
+
// commit or rollback at the end of teardown.
|
|
164
|
+
await context.state.fork();
|
|
165
|
+
hintingContractsDB.createCheckpoint();
|
|
166
|
+
} else {
|
|
167
|
+
// Unchecked/unknown error - re-throw as-is
|
|
168
|
+
throw e;
|
|
169
|
+
}
|
|
170
|
+
}
|
|
200
171
|
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
}
|
|
208
|
-
}
|
|
209
|
-
// We commit the forked state and we are done.
|
|
210
|
-
await context.state.mergeForkedState();
|
|
211
|
-
} catch (e: any) {
|
|
212
|
-
if (e instanceof TxSimTeardownRevert) {
|
|
213
|
-
// We revert to the post-setup state and we are done.
|
|
214
|
-
await context.state.discardForkedState();
|
|
215
|
-
} else {
|
|
216
|
-
// Unchecked/unknown error - re-throw as-is
|
|
217
|
-
throw e;
|
|
172
|
+
try {
|
|
173
|
+
if (context.hasPhase(TxExecutionPhase.TEARDOWN)) {
|
|
174
|
+
const teardownResult = await this.simulatePhase(TxExecutionPhase.TEARDOWN, context);
|
|
175
|
+
processedPhases.push(teardownResult);
|
|
176
|
+
if (teardownResult.reverted) {
|
|
177
|
+
throw new TxSimTeardownRevert();
|
|
218
178
|
}
|
|
219
179
|
}
|
|
180
|
+
// We commit the forked state and we are done.
|
|
181
|
+
await context.state.mergeForkedState();
|
|
182
|
+
hintingContractsDB.commitCheckpoint();
|
|
183
|
+
} catch (e: any) {
|
|
184
|
+
if (e instanceof TxSimTeardownRevert) {
|
|
185
|
+
// We revert to the post-setup state and we are done.
|
|
186
|
+
await context.state.discardForkedState();
|
|
187
|
+
hintingContractsDB.revertCheckpoint();
|
|
188
|
+
} else {
|
|
189
|
+
// Unchecked/unknown error - re-throw as-is
|
|
190
|
+
throw e;
|
|
191
|
+
}
|
|
192
|
+
}
|
|
220
193
|
|
|
221
|
-
|
|
194
|
+
context.halt();
|
|
222
195
|
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
this.contractsDB.commitContractsForTx(/*onlyNonRevertibles=*/ !revertCode.isOK());
|
|
241
|
-
|
|
242
|
-
return {
|
|
243
|
-
avmProvingRequest,
|
|
244
|
-
gasUsed: {
|
|
245
|
-
totalGas: context.getActualGasUsed(),
|
|
246
|
-
teardownGas: context.teardownGasUsed,
|
|
247
|
-
publicGas: context.getActualPublicGasUsed(),
|
|
248
|
-
billedGas: context.getTotalGasUsed(),
|
|
249
|
-
},
|
|
250
|
-
revertCode,
|
|
251
|
-
revertReason: context.revertReason,
|
|
252
|
-
processedPhases: processedPhases,
|
|
253
|
-
logs: context.state.getActiveStateManager().getLogs(),
|
|
254
|
-
};
|
|
255
|
-
} finally {
|
|
256
|
-
// Make sure there are no new contracts in the tx-level cache.
|
|
257
|
-
// They should either be committed to block-level cache or cleared.
|
|
258
|
-
// FIXME(fcarreiro): this should conceptually use the hinted contracts db.
|
|
259
|
-
// However things should work as they are now because the hinted db would still pick up the new contracts.
|
|
260
|
-
this.contractsDB.clearContractsForTx();
|
|
196
|
+
// Such transactions should be filtered by GasTxValidator.
|
|
197
|
+
assert(
|
|
198
|
+
context.getActualGasUsed().l2Gas <= AVM_MAX_PROCESSABLE_L2_GAS,
|
|
199
|
+
`Transaction consumes ${context.getActualGasUsed().l2Gas} L2 gas, which exceeds the AVM maximum processable gas of ${AVM_MAX_PROCESSABLE_L2_GAS}`,
|
|
200
|
+
);
|
|
201
|
+
await this.payFee(context);
|
|
202
|
+
|
|
203
|
+
const publicInputs = await context.generateAvmCircuitPublicInputs();
|
|
204
|
+
const revertCode = context.getFinalRevertCode();
|
|
205
|
+
|
|
206
|
+
// We only return the app logic phase information, and only 1 per phase.
|
|
207
|
+
const appLogicReturnValues: NestedProcessReturnValues[] =
|
|
208
|
+
processedPhases.find(({ phase }) => phase === TxExecutionPhase.APP_LOGIC)?.returnValues ?? [];
|
|
209
|
+
|
|
210
|
+
// TODO(fcarreiro): This is a temporary backwards compatibility layer until we migrate to the C++ simulator.
|
|
211
|
+
if (context.revertReason !== undefined) {
|
|
212
|
+
(appLogicReturnValues as any).revertReason = context.revertReason;
|
|
261
213
|
}
|
|
214
|
+
|
|
215
|
+
// Create PublicTxEffect from PublicInputs.
|
|
216
|
+
const publicTxEffect = new PublicTxEffect(
|
|
217
|
+
publicInputs.transactionFee,
|
|
218
|
+
publicInputs.accumulatedData.noteHashes.filter(h => !h.isEmpty()),
|
|
219
|
+
publicInputs.accumulatedData.nullifiers.filter(n => !n.isEmpty()),
|
|
220
|
+
publicInputs.accumulatedData.l2ToL1Msgs.filter(m => !m.isEmpty()),
|
|
221
|
+
publicInputs.accumulatedData.publicLogs.toLogs(),
|
|
222
|
+
publicInputs.accumulatedData.publicDataWrites.filter(w => !w.isEmpty()),
|
|
223
|
+
);
|
|
224
|
+
|
|
225
|
+
return new PublicTxResult(
|
|
226
|
+
/*gasUsed=*/ {
|
|
227
|
+
totalGas: context.getActualGasUsed(),
|
|
228
|
+
teardownGas: context.teardownGasUsed,
|
|
229
|
+
publicGas: context.getActualPublicGasUsed(),
|
|
230
|
+
billedGas: context.getTotalGasUsed(),
|
|
231
|
+
},
|
|
232
|
+
/*revertCode=*/ revertCode,
|
|
233
|
+
/*publicTxEffect=*/ publicTxEffect,
|
|
234
|
+
/*callStackMetadata=*/ appLogicReturnValues,
|
|
235
|
+
/*logs=*/ context.state.getActiveStateManager().getLogs(),
|
|
236
|
+
/*hints=*/ hints,
|
|
237
|
+
/*publicInputs=*/ publicInputs,
|
|
238
|
+
);
|
|
262
239
|
}
|
|
263
240
|
|
|
264
241
|
protected computeTxHash(tx: Tx) {
|
|
@@ -291,7 +268,7 @@ export class PublicTxSimulator implements PublicTxSimulatorInterface {
|
|
|
291
268
|
|
|
292
269
|
const enqueuedCallResult = await this.simulateEnqueuedCall(phase, context, callRequest);
|
|
293
270
|
|
|
294
|
-
returnValues.push(new NestedProcessReturnValues(enqueuedCallResult.output));
|
|
271
|
+
returnValues.push(new NestedProcessReturnValues(enqueuedCallResult.output.bestEffortReadAll()));
|
|
295
272
|
|
|
296
273
|
if (enqueuedCallResult.reverted) {
|
|
297
274
|
reverted = true;
|
|
@@ -321,7 +298,11 @@ export class PublicTxSimulator implements PublicTxSimulatorInterface {
|
|
|
321
298
|
): Promise<AvmFinalizedCallResult> {
|
|
322
299
|
const stateManager = context.state.getActiveStateManager();
|
|
323
300
|
const contractAddress = callRequest.request.contractAddress;
|
|
324
|
-
const fnName = await getPublicFunctionDebugName(
|
|
301
|
+
const fnName = await getPublicFunctionDebugName(
|
|
302
|
+
this.contractsDB,
|
|
303
|
+
contractAddress,
|
|
304
|
+
new CallDataArray(callRequest.calldata),
|
|
305
|
+
);
|
|
325
306
|
|
|
326
307
|
const allocatedGas = context.getGasLeftAtPhase(phase);
|
|
327
308
|
|
|
@@ -340,7 +321,7 @@ export class PublicTxSimulator implements PublicTxSimulatorInterface {
|
|
|
340
321
|
);
|
|
341
322
|
|
|
342
323
|
if (result.reverted) {
|
|
343
|
-
const culprit = `${contractAddress}:${
|
|
324
|
+
const culprit = `${contractAddress}:${fnName}`;
|
|
344
325
|
context.revert(phase, result.revertReason, culprit);
|
|
345
326
|
}
|
|
346
327
|
|
|
@@ -381,10 +362,9 @@ export class PublicTxSimulator implements PublicTxSimulatorInterface {
|
|
|
381
362
|
transactionFee,
|
|
382
363
|
this.globalVariables,
|
|
383
364
|
request.isStaticCall,
|
|
384
|
-
calldata,
|
|
365
|
+
new CallDataArray(calldata),
|
|
385
366
|
allocatedGas,
|
|
386
|
-
this.config
|
|
387
|
-
this.config.maxDebugLogMemoryReads,
|
|
367
|
+
this.config,
|
|
388
368
|
);
|
|
389
369
|
const avmCallResult = await simulator.execute();
|
|
390
370
|
return avmCallResult.finalize();
|
|
@@ -393,7 +373,7 @@ export class PublicTxSimulator implements PublicTxSimulatorInterface {
|
|
|
393
373
|
/**
|
|
394
374
|
* Insert the non-revertible accumulated data from private into the public state.
|
|
395
375
|
*/
|
|
396
|
-
protected async insertNonRevertiblesFromPrivate(context: PublicTxContext
|
|
376
|
+
protected async insertNonRevertiblesFromPrivate(context: PublicTxContext) {
|
|
397
377
|
const stateManager = context.state.getActiveStateManager();
|
|
398
378
|
|
|
399
379
|
for (const siloedNullifier of context.nonRevertibleAccumulatedDataFromPrivate.nullifiers.filter(
|
|
@@ -412,11 +392,12 @@ export class PublicTxSimulator implements PublicTxSimulatorInterface {
|
|
|
412
392
|
}
|
|
413
393
|
}
|
|
414
394
|
|
|
415
|
-
// add new contracts to the contracts db so that their
|
|
416
|
-
//
|
|
417
|
-
//
|
|
418
|
-
//
|
|
419
|
-
|
|
395
|
+
// add new contracts to the contracts db so that their code may be found and called
|
|
396
|
+
// FIXME(fcarreiro): this should conceptually use the hinting contracts db.
|
|
397
|
+
// However, things work as expected because later calls to getters on the hintingContractsDB
|
|
398
|
+
// will pick up the new contracts and will generate the necessary hints.
|
|
399
|
+
// So, a consumer of the hints will always see the new contracts.
|
|
400
|
+
await this.contractsDB.addContracts(context.nonRevertibleContractDeploymentData);
|
|
420
401
|
}
|
|
421
402
|
|
|
422
403
|
/**
|
|
@@ -428,7 +409,7 @@ export class PublicTxSimulator implements PublicTxSimulatorInterface {
|
|
|
428
409
|
* - NoteHashLimitReachedError
|
|
429
410
|
* - L2ToL1MessageLimitReachedError
|
|
430
411
|
*/
|
|
431
|
-
protected async insertRevertiblesFromPrivate(context: PublicTxContext
|
|
412
|
+
protected async insertRevertiblesFromPrivate(context: PublicTxContext) {
|
|
432
413
|
const stateManager = context.state.getActiveStateManager();
|
|
433
414
|
|
|
434
415
|
try {
|
|
@@ -497,16 +478,21 @@ export class PublicTxSimulator implements PublicTxSimulatorInterface {
|
|
|
497
478
|
}
|
|
498
479
|
|
|
499
480
|
// add new contracts to the contracts db so that their functions may be found and called
|
|
500
|
-
// FIXME(fcarreiro): this should conceptually use the
|
|
501
|
-
// However things
|
|
502
|
-
|
|
481
|
+
// FIXME(fcarreiro): this should conceptually use the hinting contracts db.
|
|
482
|
+
// However, things work as expected because later calls to getters on the hintingContractsDB
|
|
483
|
+
// will pick up the new contracts and will generate the necessary hints.
|
|
484
|
+
// So, a consumer of the hints will always see the new contracts.
|
|
485
|
+
await this.contractsDB.addContracts(context.revertibleContractDeploymentData);
|
|
503
486
|
}
|
|
504
487
|
|
|
505
488
|
private async payFee(context: PublicTxContext) {
|
|
506
489
|
const txFee = context.getTransactionFee(TxExecutionPhase.TEARDOWN);
|
|
507
490
|
|
|
508
491
|
if (context.feePayer.isZero()) {
|
|
509
|
-
|
|
492
|
+
// Real transactions are enforced by private kernel to have nonzero fee payer.
|
|
493
|
+
// Real transactions cannot skip fee enforcement (skipping fee enforcement makes them unprovable).
|
|
494
|
+
assert(this.config.skipFeeEnforcement, 'Fee payer cannot be 0 unless skipping fee enforcement for simulation');
|
|
495
|
+
this.log.debug(`Fee payer is 0. Skipping fee enforcement. No one is paying the fee of ${txFee.toBigInt()}`);
|
|
510
496
|
return;
|
|
511
497
|
}
|
|
512
498
|
|
|
@@ -526,23 +512,12 @@ export class PublicTxSimulator implements PublicTxSimulatorInterface {
|
|
|
526
512
|
this.config.skipFeeEnforcement,
|
|
527
513
|
`Not enough balance for fee payer to pay for transaction (got ${currentBalance.toBigInt()} needs ${txFee.toBigInt()})`,
|
|
528
514
|
);
|
|
515
|
+
this.log.debug(`Fee payer balance insufficient, but we're skipping fee enforcement`);
|
|
516
|
+
// We still proceed and perform the storage write to minimize deviation from normal execution.
|
|
529
517
|
currentBalance = txFee;
|
|
530
518
|
}
|
|
531
519
|
|
|
532
520
|
const updatedBalance = currentBalance.sub(txFee);
|
|
533
521
|
await stateManager.writeStorage(feeJuiceAddress, balanceSlot, updatedBalance, true);
|
|
534
522
|
}
|
|
535
|
-
|
|
536
|
-
/**
|
|
537
|
-
* Generate the proving request for the AVM circuit.
|
|
538
|
-
*/
|
|
539
|
-
private static generateProvingRequest(
|
|
540
|
-
publicInputs: AvmCircuitPublicInputs,
|
|
541
|
-
hints: AvmExecutionHints,
|
|
542
|
-
): AvmProvingRequest {
|
|
543
|
-
return {
|
|
544
|
-
type: ProvingRequestType.PUBLIC_VM,
|
|
545
|
-
inputs: new AvmCircuitInputs(hints, publicInputs),
|
|
546
|
-
};
|
|
547
|
-
}
|
|
548
523
|
}
|
|
@@ -1,11 +1,33 @@
|
|
|
1
|
+
import type { PublicTxResult } from '@aztec/stdlib/avm';
|
|
1
2
|
import type { Tx } from '@aztec/stdlib/tx';
|
|
2
3
|
|
|
3
|
-
import type { PublicTxResult } from './public_tx_simulator.js';
|
|
4
|
-
|
|
5
4
|
export interface PublicTxSimulatorInterface {
|
|
6
5
|
simulate(tx: Tx): Promise<PublicTxResult>;
|
|
6
|
+
/**
|
|
7
|
+
* Cancel the current simulation if one is in progress.
|
|
8
|
+
* This signals the underlying simulator (e.g., C++) to stop at the next safe point.
|
|
9
|
+
* Safe to call even if no simulation is in progress.
|
|
10
|
+
* Optional - not all implementations support cancellation.
|
|
11
|
+
*
|
|
12
|
+
* @param waitTimeoutMs - If provided, wait up to this many ms for the simulation to actually stop.
|
|
13
|
+
* This is important because signaling cancellation doesn't immediately stop C++ -
|
|
14
|
+
* it only sets a flag that C++ checks at certain points. If C++ is in the middle
|
|
15
|
+
* of a slow operation (e.g., pad_trees), it won't stop until that completes.
|
|
16
|
+
* @returns Promise that resolves when cancellation is signaled (and optionally when simulation stops)
|
|
17
|
+
*/
|
|
18
|
+
cancel?(waitTimeoutMs?: number): Promise<void>;
|
|
7
19
|
}
|
|
8
20
|
|
|
9
21
|
export interface MeasuredPublicTxSimulatorInterface {
|
|
10
22
|
simulate(tx: Tx, txLabel: string): Promise<PublicTxResult>;
|
|
23
|
+
/**
|
|
24
|
+
* Cancel the current simulation if one is in progress.
|
|
25
|
+
* This signals the underlying simulator (e.g., C++) to stop at the next safe point.
|
|
26
|
+
* Safe to call even if no simulation is in progress.
|
|
27
|
+
* Optional - not all implementations support cancellation.
|
|
28
|
+
*
|
|
29
|
+
* @param waitTimeoutMs - If provided, wait up to this many ms for the simulation to actually stop.
|
|
30
|
+
* @returns Promise that resolves when cancellation is signaled (and optionally when simulation stops)
|
|
31
|
+
*/
|
|
32
|
+
cancel?(waitTimeoutMs?: number): Promise<void>;
|
|
11
33
|
}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import type { Fr } from '@aztec/foundation/
|
|
1
|
+
import type { Fr } from '@aztec/foundation/curves/bn254';
|
|
2
|
+
import type { PublicSimulatorConfig } from '@aztec/stdlib/avm';
|
|
2
3
|
import type { Gas } from '@aztec/stdlib/gas';
|
|
3
4
|
import type { MerkleTreeWriteOperations } from '@aztec/stdlib/trees';
|
|
4
5
|
import { type GlobalVariables, PublicCallRequestWithCalldata, TxExecutionPhase } from '@aztec/stdlib/tx';
|
|
@@ -10,7 +11,6 @@ import type { PublicContractsDB } from '../public_db_sources.js';
|
|
|
10
11
|
import type { PublicPersistableStateManager } from '../state_manager/state_manager.js';
|
|
11
12
|
import { MeasuredPublicTxSimulator } from './measured_public_tx_simulator.js';
|
|
12
13
|
import { PublicTxContext } from './public_tx_context.js';
|
|
13
|
-
import type { PublicTxSimulatorConfig } from './public_tx_simulator.js';
|
|
14
14
|
|
|
15
15
|
/**
|
|
16
16
|
* A public tx simulator that tracks runtime/production metrics with telemetry.
|
|
@@ -24,7 +24,7 @@ export class TelemetryPublicTxSimulator extends MeasuredPublicTxSimulator {
|
|
|
24
24
|
contractsDB: PublicContractsDB,
|
|
25
25
|
globalVariables: GlobalVariables,
|
|
26
26
|
telemetryClient: TelemetryClient = getTelemetryClient(),
|
|
27
|
-
config?: Partial<
|
|
27
|
+
config?: Partial<PublicSimulatorConfig>,
|
|
28
28
|
) {
|
|
29
29
|
const metrics = new ExecutorMetrics(telemetryClient, 'PublicTxSimulator');
|
|
30
30
|
super(merkleTree, contractsDB, globalVariables, metrics, config);
|
|
@@ -7,8 +7,8 @@ import {
|
|
|
7
7
|
MAX_PUBLIC_DATA_UPDATE_REQUESTS_PER_TX,
|
|
8
8
|
PROTOCOL_PUBLIC_DATA_UPDATE_REQUESTS_PER_TX,
|
|
9
9
|
} from '@aztec/constants';
|
|
10
|
+
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
10
11
|
import { EthAddress } from '@aztec/foundation/eth-address';
|
|
11
|
-
import { Fr } from '@aztec/foundation/fields';
|
|
12
12
|
import { type LogLevel, createLogger } from '@aztec/foundation/log';
|
|
13
13
|
import { PublicDataUpdateRequest } from '@aztec/stdlib/avm';
|
|
14
14
|
import type { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { Fr } from '@aztec/foundation/
|
|
1
|
+
import type { Fr } from '@aztec/foundation/curves/bn254';
|
|
2
2
|
import type { LogLevel } from '@aztec/foundation/log';
|
|
3
3
|
import type { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
4
4
|
import type { DebugLog } from '@aztec/stdlib/logs';
|