@aztec/simulator 0.0.0-test.1 → 0.0.1-commit.0208eb9
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 +8 -0
- package/dest/client.d.ts +6 -4
- package/dest/client.d.ts.map +1 -1
- package/dest/client.js +4 -2
- package/dest/common/errors.d.ts +6 -9
- package/dest/common/errors.d.ts.map +1 -1
- package/dest/common/errors.js +51 -32
- package/dest/common/index.d.ts +1 -2
- package/dest/common/index.d.ts.map +1 -1
- package/dest/common/index.js +0 -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 +15 -7
- package/dest/private/acvm/acvm.d.ts.map +1 -1
- package/dest/private/acvm/acvm.js +14 -19
- package/dest/private/acvm/acvm_types.d.ts +2 -2
- package/dest/private/acvm/acvm_types.d.ts.map +1 -1
- package/dest/private/acvm/deserialize.d.ts +19 -20
- package/dest/private/acvm/deserialize.d.ts.map +1 -1
- package/dest/private/acvm/deserialize.js +32 -24
- package/dest/private/acvm/index.d.ts +1 -2
- package/dest/private/acvm/index.d.ts.map +1 -1
- package/dest/private/acvm/index.js +0 -1
- package/dest/private/acvm/serialize.d.ts +21 -4
- package/dest/private/acvm/serialize.d.ts.map +1 -1
- package/dest/private/acvm/serialize.js +54 -1
- package/dest/private/acvm_native.d.ts +41 -0
- package/dest/private/acvm_native.d.ts.map +1 -0
- package/dest/private/{providers/acvm_native.js → acvm_native.js} +34 -26
- package/dest/private/acvm_wasm.d.ts +16 -0
- package/dest/private/acvm_wasm.d.ts.map +1 -0
- package/dest/private/acvm_wasm.js +65 -0
- package/dest/private/acvm_wasm_with_blobs.d.ts +20 -0
- package/dest/private/acvm_wasm_with_blobs.d.ts.map +1 -0
- package/dest/private/acvm_wasm_with_blobs.js +35 -0
- package/dest/private/circuit_recording/circuit_recorder.d.ts +109 -0
- package/dest/private/circuit_recording/circuit_recorder.d.ts.map +1 -0
- package/dest/private/circuit_recording/circuit_recorder.js +212 -0
- package/dest/private/circuit_recording/file_circuit_recorder.d.ts +32 -0
- package/dest/private/circuit_recording/file_circuit_recorder.d.ts.map +1 -0
- package/dest/private/circuit_recording/file_circuit_recorder.js +135 -0
- package/dest/private/circuit_recording/memory_circuit_recorder.d.ts +10 -0
- package/dest/private/circuit_recording/memory_circuit_recorder.d.ts.map +1 -0
- package/dest/private/circuit_recording/memory_circuit_recorder.js +9 -0
- package/dest/private/circuit_recording/simulator_recorder_wrapper.d.ts +21 -0
- package/dest/private/circuit_recording/simulator_recorder_wrapper.d.ts.map +1 -0
- package/dest/private/circuit_recording/simulator_recorder_wrapper.js +44 -0
- package/dest/private/circuit_simulator.d.ts +35 -0
- package/dest/private/circuit_simulator.d.ts.map +1 -0
- package/dest/private/circuit_simulator.js +43 -0
- package/dest/private/factory.d.ts +12 -0
- package/dest/private/factory.d.ts.map +1 -0
- package/dest/private/{providers/factory.js → factory.js} +8 -5
- package/dest/public/avm/avm_context.d.ts +8 -8
- package/dest/public/avm/avm_context.d.ts.map +1 -1
- package/dest/public/avm/avm_contract_call_result.d.ts +8 -6
- package/dest/public/avm/avm_contract_call_result.d.ts.map +1 -1
- package/dest/public/avm/avm_contract_call_result.js +12 -8
- package/dest/public/avm/avm_execution_environment.d.ts +9 -6
- package/dest/public/avm/avm_execution_environment.d.ts.map +1 -1
- package/dest/public/avm/avm_execution_environment.js +5 -3
- package/dest/public/avm/avm_gas.d.ts +5 -21
- package/dest/public/avm/avm_gas.d.ts.map +1 -1
- package/dest/public/avm/avm_gas.js +27 -35
- package/dest/public/avm/avm_machine_state.d.ts +9 -6
- package/dest/public/avm/avm_machine_state.d.ts.map +1 -1
- package/dest/public/avm/avm_machine_state.js +5 -2
- package/dest/public/avm/avm_memory_types.d.ts +100 -89
- package/dest/public/avm/avm_memory_types.d.ts.map +1 -1
- package/dest/public/avm/avm_memory_types.js +21 -7
- package/dest/public/avm/avm_simulator.d.ts +8 -7
- package/dest/public/avm/avm_simulator.d.ts.map +1 -1
- package/dest/public/avm/avm_simulator.js +32 -42
- package/dest/public/avm/avm_simulator_interface.d.ts +9 -0
- package/dest/public/avm/avm_simulator_interface.d.ts.map +1 -0
- package/dest/public/avm/avm_simulator_interface.js +3 -0
- 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 +11 -29
- package/dest/public/avm/errors.d.ts.map +1 -1
- package/dest/public/avm/errors.js +19 -57
- package/dest/public/avm/fixtures/avm_simulation_tester.d.ts +6 -5
- package/dest/public/avm/fixtures/avm_simulation_tester.d.ts.map +1 -1
- package/dest/public/avm/fixtures/avm_simulation_tester.js +26 -18
- package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts +8 -6
- package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts.map +1 -1
- package/dest/public/avm/fixtures/base_avm_simulation_tester.js +38 -15
- package/dest/public/avm/fixtures/initializers.d.ts +42 -0
- package/dest/public/avm/fixtures/initializers.d.ts.map +1 -0
- package/dest/public/avm/fixtures/initializers.js +45 -0
- package/dest/public/avm/fixtures/utils.d.ts +39 -0
- package/dest/public/avm/fixtures/utils.d.ts.map +1 -0
- package/dest/public/avm/fixtures/utils.js +96 -0
- package/dest/public/avm/index.d.ts +1 -3
- package/dest/public/avm/index.d.ts.map +1 -1
- package/dest/public/avm/index.js +0 -2
- package/dest/public/avm/opcodes/accrued_substate.d.ts +17 -18
- package/dest/public/avm/opcodes/accrued_substate.d.ts.map +1 -1
- package/dest/public/avm/opcodes/accrued_substate.js +58 -55
- package/dest/public/avm/opcodes/addressing_mode.d.ts +12 -8
- package/dest/public/avm/opcodes/addressing_mode.d.ts.map +1 -1
- package/dest/public/avm/opcodes/addressing_mode.js +46 -26
- package/dest/public/avm/opcodes/arithmetic.d.ts +14 -2
- package/dest/public/avm/opcodes/arithmetic.d.ts.map +1 -1
- package/dest/public/avm/opcodes/arithmetic.js +27 -3
- package/dest/public/avm/opcodes/bitwise.d.ts +8 -16
- package/dest/public/avm/opcodes/bitwise.d.ts.map +1 -1
- package/dest/public/avm/opcodes/bitwise.js +22 -29
- 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 +3 -3
- package/dest/public/avm/opcodes/contract.d.ts +3 -4
- package/dest/public/avm/opcodes/contract.d.ts.map +1 -1
- package/dest/public/avm/opcodes/contract.js +11 -12
- 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 +13 -11
- package/dest/public/avm/opcodes/conversion.d.ts +4 -3
- package/dest/public/avm/opcodes/conversion.d.ts.map +1 -1
- package/dest/public/avm/opcodes/conversion.js +270 -6
- 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 +21 -12
- 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 +20 -22
- package/dest/public/avm/opcodes/external_calls.d.ts +14 -13
- package/dest/public/avm/opcodes/external_calls.d.ts.map +1 -1
- package/dest/public/avm/opcodes/external_calls.js +52 -46
- 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 +24 -19
- package/dest/public/avm/opcodes/index.d.ts +1 -1
- package/dest/public/avm/opcodes/instruction.d.ts +15 -11
- package/dest/public/avm/opcodes/instruction.d.ts.map +1 -1
- package/dest/public/avm/opcodes/instruction.js +23 -19
- 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 +15 -15
- package/dest/public/avm/opcodes/memory.d.ts.map +1 -1
- package/dest/public/avm/opcodes/memory.js +52 -48
- package/dest/public/avm/opcodes/misc.d.ts +4 -3
- package/dest/public/avm/opcodes/misc.d.ts.map +1 -1
- package/dest/public/avm/opcodes/misc.js +42 -17
- 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 +39 -27
- package/dest/public/avm/revert_reason.d.ts +18 -0
- package/dest/public/avm/revert_reason.d.ts.map +1 -0
- package/dest/public/avm/revert_reason.js +39 -0
- package/dest/public/avm/serialization/buffer_cursor.d.ts +1 -3
- package/dest/public/avm/serialization/buffer_cursor.d.ts.map +1 -1
- package/dest/public/avm/serialization/bytecode_serialization.d.ts +3 -7
- package/dest/public/avm/serialization/bytecode_serialization.d.ts.map +1 -1
- package/dest/public/avm/serialization/bytecode_serialization.js +79 -75
- package/dest/public/avm/serialization/instruction_serialization.d.ts +14 -5
- package/dest/public/avm/serialization/instruction_serialization.d.ts.map +1 -1
- package/dest/public/avm/serialization/instruction_serialization.js +70 -35
- package/dest/public/avm/test_utils.d.ts +12 -15
- package/dest/public/avm/test_utils.d.ts.map +1 -1
- package/dest/public/avm/test_utils.js +17 -25
- 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 +68 -0
- package/dest/public/db_interfaces.d.ts.map +1 -0
- package/dest/public/db_interfaces.js +3 -0
- package/dest/public/debug_fn_name.d.ts +18 -0
- package/dest/public/debug_fn_name.d.ts.map +1 -0
- package/dest/public/debug_fn_name.js +37 -0
- package/dest/public/executor_metrics.d.ts +12 -4
- package/dest/public/executor_metrics.d.ts.map +1 -1
- package/dest/public/executor_metrics.js +33 -23
- package/dest/public/executor_metrics_interface.d.ts +10 -0
- package/dest/public/executor_metrics_interface.d.ts.map +1 -0
- package/dest/public/executor_metrics_interface.js +1 -0
- package/dest/public/fixtures/amm_test.d.ts +10 -0
- package/dest/public/fixtures/amm_test.d.ts.map +1 -0
- package/dest/public/fixtures/amm_test.js +213 -0
- package/dest/public/fixtures/bulk_test.d.ts +6 -0
- package/dest/public/fixtures/bulk_test.d.ts.map +1 -0
- package/dest/public/fixtures/bulk_test.js +262 -0
- package/dest/public/fixtures/custom_bytecode_tester.d.ts +34 -0
- package/dest/public/fixtures/custom_bytecode_tester.d.ts.map +1 -0
- package/dest/public/fixtures/custom_bytecode_tester.js +53 -0
- package/dest/public/fixtures/custom_bytecode_tests.d.ts +12 -0
- package/dest/public/fixtures/custom_bytecode_tests.d.ts.map +1 -0
- package/dest/public/fixtures/custom_bytecode_tests.js +174 -0
- package/dest/public/fixtures/index.d.ts +10 -1
- package/dest/public/fixtures/index.d.ts.map +1 -1
- package/dest/public/fixtures/index.js +9 -0
- package/dest/public/fixtures/minimal_public_tx.d.ts +4 -0
- package/dest/public/fixtures/minimal_public_tx.d.ts.map +1 -0
- package/dest/public/fixtures/minimal_public_tx.js +19 -0
- package/dest/public/fixtures/opcode_spammer.d.ts +122 -0
- package/dest/public/fixtures/opcode_spammer.d.ts.map +1 -0
- package/dest/public/fixtures/opcode_spammer.js +1653 -0
- package/dest/public/fixtures/public_tx_simulation_tester.d.ts +55 -15
- package/dest/public/fixtures/public_tx_simulation_tester.d.ts.map +1 -1
- package/dest/public/fixtures/public_tx_simulation_tester.js +138 -72
- package/dest/public/fixtures/simple_contract_data_source.d.ts +36 -0
- package/dest/public/fixtures/simple_contract_data_source.d.ts.map +1 -0
- package/dest/public/{avm/fixtures → fixtures}/simple_contract_data_source.js +31 -10
- package/dest/public/fixtures/token_test.d.ts +12 -0
- package/dest/public/fixtures/token_test.d.ts.map +1 -0
- package/dest/public/fixtures/token_test.js +96 -0
- package/dest/public/fixtures/utils.d.ts +18 -5
- package/dest/public/fixtures/utils.d.ts.map +1 -1
- package/dest/public/fixtures/utils.js +102 -59
- 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 +80 -0
- package/dest/public/hinting_db_sources.d.ts.map +1 -0
- package/dest/public/hinting_db_sources.js +355 -0
- package/dest/public/index.d.ts +6 -9
- package/dest/public/index.d.ts.map +1 -1
- package/dest/public/index.js +4 -7
- package/dest/public/public_db_sources.d.ts +54 -103
- package/dest/public/public_db_sources.d.ts.map +1 -1
- package/dest/public/public_db_sources.js +222 -195
- package/dest/public/public_errors.d.ts +12 -0
- package/dest/public/public_errors.d.ts.map +1 -0
- package/dest/public/public_errors.js +13 -0
- package/dest/public/public_processor/guarded_merkle_tree.d.ts +51 -0
- package/dest/public/public_processor/guarded_merkle_tree.d.ts.map +1 -0
- package/dest/public/public_processor/guarded_merkle_tree.js +113 -0
- package/dest/public/public_processor/public_processor.d.ts +28 -38
- package/dest/public/public_processor/public_processor.d.ts.map +1 -1
- package/dest/public/public_processor/public_processor.js +576 -136
- package/dest/public/public_processor/public_processor_metrics.d.ts +4 -4
- package/dest/public/public_processor/public_processor_metrics.d.ts.map +1 -1
- package/dest/public/public_processor/public_processor_metrics.js +29 -46
- package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts +19 -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 +53 -0
- package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/cpp_public_tx_simulator.js +132 -0
- 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 +23 -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 +14 -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 +8 -0
- package/dest/public/public_tx_simulator/index.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/index.js +5 -0
- package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts +31 -0
- package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/measured_public_tx_simulator.js +51 -0
- package/dest/public/public_tx_simulator/public_tx_context.d.ts +25 -31
- package/dest/public/public_tx_simulator/public_tx_context.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/public_tx_context.js +75 -95
- package/dest/public/public_tx_simulator/public_tx_simulator.d.ts +38 -58
- package/dest/public/public_tx_simulator/public_tx_simulator.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/public_tx_simulator.js +220 -207
- package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts +32 -0
- package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/public_tx_simulator_interface.js +1 -0
- package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts +21 -0
- package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.js +415 -0
- package/dest/public/side_effect_errors.d.ts +42 -2
- package/dest/public/side_effect_errors.d.ts.map +1 -1
- package/dest/public/side_effect_errors.js +70 -1
- package/dest/public/side_effect_trace.d.ts +24 -69
- package/dest/public/side_effect_trace.d.ts.map +1 -1
- package/dest/public/side_effect_trace.js +74 -124
- package/dest/public/side_effect_trace_interface.d.ts +13 -25
- package/dest/public/side_effect_trace_interface.d.ts.map +1 -1
- package/dest/public/state_manager/index.d.ts +2 -0
- package/dest/public/state_manager/index.d.ts.map +1 -0
- package/dest/public/state_manager/index.js +1 -0
- package/dest/public/{avm/journal → state_manager}/nullifiers.d.ts +4 -7
- package/dest/public/state_manager/nullifiers.d.ts.map +1 -0
- package/dest/public/{avm/journal → state_manager}/nullifiers.js +3 -8
- package/dest/public/{avm/journal → state_manager}/public_storage.d.ts +4 -4
- package/dest/public/state_manager/public_storage.d.ts.map +1 -0
- package/dest/public/{avm/journal → state_manager}/public_storage.js +1 -1
- package/dest/public/state_manager/state_manager.d.ts +170 -0
- package/dest/public/state_manager/state_manager.d.ts.map +1 -0
- package/dest/public/state_manager/state_manager.js +402 -0
- package/dest/public/test_executor_metrics.d.ts +56 -0
- package/dest/public/test_executor_metrics.d.ts.map +1 -0
- package/dest/public/test_executor_metrics.js +307 -0
- 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 +3 -5
- package/dest/public/utils.d.ts.map +1 -1
- package/dest/public/utils.js +4 -21
- package/dest/server.d.ts +7 -4
- package/dest/server.d.ts.map +1 -1
- package/dest/server.js +5 -2
- package/dest/testing.d.ts +2 -0
- package/dest/testing.d.ts.map +1 -0
- package/dest/testing.js +1 -0
- package/package.json +39 -33
- package/src/client.ts +5 -3
- package/src/common/errors.ts +80 -45
- package/src/common/index.ts +0 -1
- package/src/private/acvm/acvm.ts +21 -35
- package/src/private/acvm/acvm_types.ts +1 -1
- package/src/private/acvm/deserialize.ts +36 -30
- package/src/private/acvm/index.ts +0 -1
- package/src/private/acvm/serialize.ts +64 -1
- package/src/private/{providers/acvm_native.ts → acvm_native.ts} +57 -28
- package/src/private/acvm_wasm.ts +76 -0
- package/src/private/acvm_wasm_with_blobs.ts +54 -0
- package/src/private/circuit_recording/circuit_recorder.ts +263 -0
- package/src/private/circuit_recording/file_circuit_recorder.ts +163 -0
- package/src/private/circuit_recording/memory_circuit_recorder.ts +13 -0
- package/src/private/circuit_recording/simulator_recorder_wrapper.ts +91 -0
- package/src/private/circuit_simulator.ts +90 -0
- package/src/private/{providers/factory.ts → factory.ts} +13 -10
- package/src/public/avm/avm_context.ts +6 -6
- package/src/public/avm/avm_contract_call_result.ts +23 -9
- package/src/public/avm/avm_execution_environment.ts +17 -5
- package/src/public/avm/avm_gas.ts +26 -38
- package/src/public/avm/avm_machine_state.ts +12 -6
- package/src/public/avm/avm_memory_types.ts +24 -7
- package/src/public/avm/avm_simulator.ts +57 -62
- package/src/public/avm/avm_simulator_interface.ts +8 -0
- package/src/public/avm/calldata.ts +100 -0
- package/src/public/avm/errors.ts +20 -75
- package/src/public/avm/fixtures/avm_simulation_tester.ts +41 -24
- package/src/public/avm/fixtures/base_avm_simulation_tester.ts +46 -13
- package/src/public/avm/fixtures/initializers.ts +103 -0
- package/src/public/avm/fixtures/utils.ts +151 -0
- package/src/public/avm/index.ts +0 -2
- package/src/public/avm/opcodes/accrued_substate.ts +81 -48
- package/src/public/avm/opcodes/addressing_mode.ts +56 -32
- package/src/public/avm/opcodes/arithmetic.ts +37 -3
- package/src/public/avm/opcodes/bitwise.ts +33 -29
- package/src/public/avm/opcodes/comparators.ts +6 -3
- package/src/public/avm/opcodes/contract.ts +10 -10
- package/src/public/avm/opcodes/control_flow.ts +19 -10
- package/src/public/avm/opcodes/conversion.ts +29 -5
- package/src/public/avm/opcodes/ec_add.ts +22 -10
- package/src/public/avm/opcodes/environment_getters.ts +28 -23
- package/src/public/avm/opcodes/external_calls.ts +70 -36
- package/src/public/avm/opcodes/hashing.ts +39 -13
- package/src/public/avm/opcodes/instruction.ts +31 -21
- package/src/public/avm/opcodes/instruction_impl.ts +2 -2
- package/src/public/avm/opcodes/memory.ts +81 -42
- package/src/public/avm/opcodes/misc.ts +61 -19
- package/src/public/avm/opcodes/storage.ts +47 -23
- package/src/public/avm/revert_reason.ts +58 -0
- package/src/public/avm/serialization/buffer_cursor.ts +4 -1
- package/src/public/avm/serialization/bytecode_serialization.ts +89 -80
- package/src/public/avm/serialization/instruction_serialization.ts +75 -34
- package/src/public/avm/test_utils.ts +25 -42
- package/src/public/contracts_db_checkpoint.ts +41 -0
- package/src/public/db_interfaces.ts +76 -0
- package/src/public/debug_fn_name.ts +52 -0
- package/src/public/executor_metrics.ts +49 -23
- package/src/public/executor_metrics_interface.ts +15 -0
- package/src/public/fixtures/amm_test.ts +331 -0
- package/src/public/fixtures/bulk_test.ts +169 -0
- package/src/public/fixtures/custom_bytecode_tester.ts +83 -0
- package/src/public/fixtures/custom_bytecode_tests.ts +228 -0
- package/src/public/fixtures/index.ts +13 -0
- package/src/public/fixtures/minimal_public_tx.ts +26 -0
- package/src/public/fixtures/opcode_spammer.ts +1721 -0
- package/src/public/fixtures/public_tx_simulation_tester.ts +223 -114
- package/src/public/{avm/fixtures → fixtures}/simple_contract_data_source.ts +37 -20
- package/src/public/fixtures/token_test.ts +148 -0
- package/src/public/fixtures/utils.ts +141 -69
- 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 +607 -0
- package/src/public/index.ts +11 -8
- package/src/public/public_db_sources.ts +290 -260
- package/src/public/public_errors.ts +14 -0
- package/src/public/public_processor/guarded_merkle_tree.ts +158 -0
- package/src/public/public_processor/public_processor.ts +257 -179
- package/src/public/public_processor/public_processor_metrics.ts +18 -46
- package/src/public/public_tx_simulator/contract_provider_for_cpp.ts +124 -0
- package/src/public/public_tx_simulator/cpp_public_tx_simulator.ts +211 -0
- package/src/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.ts +134 -0
- package/src/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.ts +239 -0
- package/src/public/public_tx_simulator/dumping_cpp_public_tx_simulator.ts +83 -0
- package/src/public/public_tx_simulator/factories.ts +43 -0
- package/src/public/public_tx_simulator/index.ts +7 -0
- package/src/public/public_tx_simulator/measured_public_tx_simulator.ts +105 -0
- package/src/public/public_tx_simulator/public_tx_context.ts +179 -199
- package/src/public/public_tx_simulator/public_tx_simulator.ts +316 -263
- package/src/public/public_tx_simulator/public_tx_simulator_interface.ts +33 -0
- package/src/public/public_tx_simulator/telemetry_public_tx_simulator.ts +63 -0
- package/src/public/side_effect_errors.ts +91 -1
- package/src/public/side_effect_trace.ts +99 -322
- package/src/public/side_effect_trace_interface.ts +11 -59
- package/src/public/state_manager/index.ts +1 -0
- package/src/public/{avm/journal → state_manager}/nullifiers.ts +6 -12
- package/src/public/{avm/journal → state_manager}/public_storage.ts +3 -3
- package/src/public/state_manager/state_manager.ts +569 -0
- package/src/public/test_executor_metrics.ts +397 -0
- package/src/public/utils.ts +5 -21
- package/src/server.ts +6 -3
- package/src/testing.ts +1 -0
- package/dest/common/db_interfaces.d.ts +0 -80
- package/dest/common/db_interfaces.d.ts.map +0 -1
- package/dest/common/db_interfaces.js +0 -1
- package/dest/common/debug_fn_name.d.ts +0 -5
- package/dest/common/debug_fn_name.d.ts.map +0 -1
- package/dest/common/debug_fn_name.js +0 -6
- package/dest/common/message_load_oracle_inputs.d.ts +0 -15
- package/dest/common/message_load_oracle_inputs.d.ts.map +0 -1
- package/dest/common/message_load_oracle_inputs.js +0 -15
- package/dest/private/acvm/oracle/index.d.ts +0 -14
- package/dest/private/acvm/oracle/index.d.ts.map +0 -1
- package/dest/private/acvm/oracle/index.js +0 -2
- package/dest/private/acvm/oracle/oracle.d.ts +0 -49
- package/dest/private/acvm/oracle/oracle.d.ts.map +0 -1
- package/dest/private/acvm/oracle/oracle.js +0 -263
- package/dest/private/acvm/oracle/typed_oracle.d.ts +0 -83
- package/dest/private/acvm/oracle/typed_oracle.d.ts.map +0 -1
- package/dest/private/acvm/oracle/typed_oracle.js +0 -132
- package/dest/private/execution_data_provider.d.ts +0 -261
- package/dest/private/execution_data_provider.d.ts.map +0 -1
- package/dest/private/execution_data_provider.js +0 -14
- package/dest/private/execution_note_cache.d.ts +0 -93
- package/dest/private/execution_note_cache.d.ts.map +0 -1
- package/dest/private/execution_note_cache.js +0 -180
- package/dest/private/hashed_values_cache.d.ts +0 -28
- package/dest/private/hashed_values_cache.d.ts.map +0 -1
- package/dest/private/hashed_values_cache.js +0 -46
- package/dest/private/index.d.ts +0 -13
- package/dest/private/index.d.ts.map +0 -1
- package/dest/private/index.js +0 -12
- package/dest/private/pick_notes.d.ts +0 -85
- package/dest/private/pick_notes.d.ts.map +0 -1
- package/dest/private/pick_notes.js +0 -51
- package/dest/private/private_execution.d.ts +0 -25
- package/dest/private/private_execution.d.ts.map +0 -1
- package/dest/private/private_execution.js +0 -92
- package/dest/private/private_execution_oracle.d.ts +0 -215
- package/dest/private/private_execution_oracle.d.ts.map +0 -1
- package/dest/private/private_execution_oracle.js +0 -382
- package/dest/private/providers/acvm_native.d.ts +0 -40
- package/dest/private/providers/acvm_native.d.ts.map +0 -1
- package/dest/private/providers/acvm_wasm.d.ts +0 -15
- package/dest/private/providers/acvm_wasm.d.ts.map +0 -1
- package/dest/private/providers/acvm_wasm.js +0 -62
- package/dest/private/providers/acvm_wasm_with_blobs.d.ts +0 -19
- package/dest/private/providers/acvm_wasm_with_blobs.d.ts.map +0 -1
- package/dest/private/providers/acvm_wasm_with_blobs.js +0 -32
- package/dest/private/providers/factory.d.ts +0 -12
- package/dest/private/providers/factory.d.ts.map +0 -1
- package/dest/private/providers/simulation_provider.d.ts +0 -19
- package/dest/private/providers/simulation_provider.d.ts.map +0 -1
- package/dest/private/providers/simulation_provider.js +0 -24
- package/dest/private/simulator.d.ts +0 -34
- package/dest/private/simulator.d.ts.map +0 -1
- package/dest/private/simulator.js +0 -76
- package/dest/private/unconstrained_execution.d.ts +0 -10
- package/dest/private/unconstrained_execution.d.ts.map +0 -1
- package/dest/private/unconstrained_execution.js +0 -27
- package/dest/private/unconstrained_execution_oracle.d.ts +0 -161
- package/dest/private/unconstrained_execution_oracle.d.ts.map +0 -1
- package/dest/private/unconstrained_execution_oracle.js +0 -258
- package/dest/public/avm/bytecode_utils.d.ts +0 -5
- package/dest/public/avm/bytecode_utils.d.ts.map +0 -1
- package/dest/public/avm/bytecode_utils.js +0 -17
- package/dest/public/avm/fixtures/index.d.ts +0 -84
- package/dest/public/avm/fixtures/index.d.ts.map +0 -1
- package/dest/public/avm/fixtures/index.js +0 -175
- package/dest/public/avm/fixtures/simple_contract_data_source.d.ts +0 -35
- package/dest/public/avm/fixtures/simple_contract_data_source.d.ts.map +0 -1
- package/dest/public/avm/journal/index.d.ts +0 -2
- package/dest/public/avm/journal/index.d.ts.map +0 -1
- package/dest/public/avm/journal/index.js +0 -1
- package/dest/public/avm/journal/journal.d.ts +0 -209
- package/dest/public/avm/journal/journal.d.ts.map +0 -1
- package/dest/public/avm/journal/journal.js +0 -486
- package/dest/public/avm/journal/nullifiers.d.ts.map +0 -1
- package/dest/public/avm/journal/public_storage.d.ts.map +0 -1
- package/dest/public/bytecode_errors.d.ts +0 -4
- package/dest/public/bytecode_errors.d.ts.map +0 -1
- package/dest/public/bytecode_errors.js +0 -6
- package/dest/public/execution.d.ts +0 -108
- package/dest/public/execution.d.ts.map +0 -1
- package/dest/public/execution.js +0 -9
- 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/dest/test/utils.d.ts +0 -13
- package/dest/test/utils.d.ts.map +0 -1
- package/dest/test/utils.js +0 -22
- package/src/common/db_interfaces.ts +0 -94
- package/src/common/debug_fn_name.ts +0 -18
- package/src/common/message_load_oracle_inputs.ts +0 -15
- package/src/private/acvm/oracle/index.ts +0 -16
- package/src/private/acvm/oracle/oracle.ts +0 -455
- package/src/private/acvm/oracle/typed_oracle.ts +0 -259
- package/src/private/execution_data_provider.ts +0 -323
- package/src/private/execution_note_cache.ts +0 -217
- package/src/private/hashed_values_cache.ts +0 -55
- package/src/private/index.ts +0 -16
- package/src/private/pick_notes.ts +0 -141
- package/src/private/private_execution.ts +0 -151
- package/src/private/private_execution_oracle.ts +0 -614
- package/src/private/providers/acvm_wasm.ts +0 -63
- package/src/private/providers/acvm_wasm_with_blobs.ts +0 -50
- package/src/private/providers/simulation_provider.ts +0 -45
- package/src/private/simulator.ts +0 -147
- package/src/private/unconstrained_execution.ts +0 -50
- package/src/private/unconstrained_execution_oracle.ts +0 -373
- package/src/public/avm/bytecode_utils.ts +0 -17
- package/src/public/avm/fixtures/index.ts +0 -296
- package/src/public/avm/journal/index.ts +0 -1
- package/src/public/avm/journal/journal.ts +0 -742
- package/src/public/avm/opcodes/.eslintrc.cjs +0 -8
- package/src/public/bytecode_errors.ts +0 -6
- package/src/public/execution.ts +0 -140
- package/src/public/tx_contract_cache.ts +0 -69
- package/src/test/utils.ts +0 -36
|
@@ -1,255 +1,278 @@
|
|
|
1
|
-
import
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import { ProtocolContractAddress } from '@aztec/protocol-contracts';
|
|
1
|
+
import { AVM_MAX_PROCESSABLE_L2_GAS } from '@aztec/constants';
|
|
2
|
+
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
3
|
+
import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
|
|
4
|
+
import { ProtocolContractAddress, ProtocolContractsList } from '@aztec/protocol-contracts';
|
|
5
5
|
import { computeFeePayerBalanceStorageSlot } from '@aztec/protocol-contracts/fee-juice';
|
|
6
|
-
import
|
|
6
|
+
import { AvmExecutionHints, AvmTxHint, PublicSimulatorConfig, PublicTxEffect, PublicTxResult } from '@aztec/stdlib/avm';
|
|
7
7
|
import { SimulationError } from '@aztec/stdlib/errors';
|
|
8
|
-
import
|
|
9
|
-
import type {
|
|
10
|
-
import type { PublicCallRequest } from '@aztec/stdlib/kernel';
|
|
11
|
-
import type { AvmSimulationStats } from '@aztec/stdlib/stats';
|
|
8
|
+
import { Gas } from '@aztec/stdlib/gas';
|
|
9
|
+
import type { MerkleTreeWriteOperations } from '@aztec/stdlib/trees';
|
|
12
10
|
import {
|
|
13
11
|
type GlobalVariables,
|
|
14
12
|
NestedProcessReturnValues,
|
|
15
|
-
|
|
13
|
+
ProtocolContracts,
|
|
14
|
+
PublicCallRequestWithCalldata,
|
|
16
15
|
Tx,
|
|
17
16
|
TxExecutionPhase,
|
|
18
17
|
} from '@aztec/stdlib/tx';
|
|
19
|
-
import { Attributes, type TelemetryClient, type Tracer, getTelemetryClient, trackSpan } from '@aztec/telemetry-client';
|
|
20
18
|
|
|
21
19
|
import { strict as assert } from 'assert';
|
|
22
20
|
|
|
23
|
-
import { getPublicFunctionDebugName } from '../../common/debug_fn_name.js';
|
|
24
21
|
import type { AvmFinalizedCallResult } from '../avm/avm_contract_call_result.js';
|
|
25
|
-
import {
|
|
26
|
-
import {
|
|
27
|
-
import {
|
|
28
|
-
import
|
|
22
|
+
import { CallDataArray } from '../avm/calldata.js';
|
|
23
|
+
import { AvmSimulator } from '../avm/index.js';
|
|
24
|
+
import { getPublicFunctionDebugName } from '../debug_fn_name.js';
|
|
25
|
+
import { HintingMerkleWriteOperations, HintingPublicContractsDB } from '../hinting_db_sources.js';
|
|
26
|
+
import { type PublicContractsDB, PublicTreesDB } from '../public_db_sources.js';
|
|
27
|
+
import {
|
|
28
|
+
L2ToL1MessageLimitReachedError,
|
|
29
|
+
NoteHashLimitReachedError,
|
|
30
|
+
NullifierCollisionError,
|
|
31
|
+
NullifierLimitReachedError,
|
|
32
|
+
} from '../side_effect_errors.js';
|
|
33
|
+
import type { PublicPersistableStateManager } from '../state_manager/state_manager.js';
|
|
29
34
|
import { PublicTxContext } from './public_tx_context.js';
|
|
35
|
+
import type { PublicTxSimulatorInterface } from './public_tx_simulator_interface.js';
|
|
36
|
+
|
|
37
|
+
// The errors below are only thrown here in the public tx simulator,
|
|
38
|
+
// and only during revertible phases (revertible insertions, app logic and teardown).
|
|
39
|
+
// These are strictly "checked" errors (not exported and never propagated).
|
|
40
|
+
// They are used internally for control flow to trigger rollbacks to the post-setup state.
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
* Error thrown when public tx simulation reverts in a known/checked way during revertible insertions.
|
|
44
|
+
*/
|
|
45
|
+
class TxSimRevertibleInsertionsRevert extends Error {
|
|
46
|
+
constructor() {
|
|
47
|
+
super('Public Tx Simulation reverted during Revertible Insertions');
|
|
48
|
+
this.name = 'TxSimRevertibleInsertionsRevert';
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
/**
|
|
53
|
+
* Error thrown when public tx simulation reverts during app logic.
|
|
54
|
+
*/
|
|
55
|
+
class TxSimAppLogicRevert extends Error {
|
|
56
|
+
constructor() {
|
|
57
|
+
super('Public Tx Simulation reverted during App Logic');
|
|
58
|
+
this.name = 'TxSimAppLogicRevert';
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
/**
|
|
63
|
+
* Error thrown when public tx simulation reverts during teardown.
|
|
64
|
+
*/
|
|
65
|
+
class TxSimTeardownRevert extends Error {
|
|
66
|
+
constructor() {
|
|
67
|
+
super('Public Tx Simulation reverted during Teardown');
|
|
68
|
+
this.name = 'TxSimTeardownRevert';
|
|
69
|
+
}
|
|
70
|
+
}
|
|
30
71
|
|
|
31
|
-
|
|
72
|
+
/** Only used internally. */
|
|
73
|
+
type ProcessedPhase = {
|
|
32
74
|
phase: TxExecutionPhase;
|
|
33
|
-
durationMs
|
|
75
|
+
durationMs?: number;
|
|
34
76
|
returnValues: NestedProcessReturnValues[];
|
|
35
77
|
reverted: boolean;
|
|
36
78
|
revertReason?: SimulationError;
|
|
37
79
|
};
|
|
38
80
|
|
|
39
|
-
export
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
revertCode: RevertCode;
|
|
44
|
-
/** Revert reason, if any */
|
|
45
|
-
revertReason?: SimulationError;
|
|
46
|
-
processedPhases: ProcessedPhase[];
|
|
47
|
-
};
|
|
48
|
-
|
|
49
|
-
export class PublicTxSimulator {
|
|
50
|
-
metrics: ExecutorMetrics;
|
|
51
|
-
|
|
52
|
-
private log: Logger;
|
|
81
|
+
export class PublicTxSimulator implements PublicTxSimulatorInterface {
|
|
82
|
+
protected log: Logger;
|
|
83
|
+
protected readonly config: PublicSimulatorConfig;
|
|
84
|
+
protected readonly bindings?: LoggerBindings;
|
|
53
85
|
|
|
54
86
|
constructor(
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
87
|
+
protected merkleTree: MerkleTreeWriteOperations,
|
|
88
|
+
protected contractsDB: PublicContractsDB,
|
|
89
|
+
protected globalVariables: GlobalVariables,
|
|
90
|
+
config?: Partial<PublicSimulatorConfig>,
|
|
91
|
+
protected protocolContracts: ProtocolContracts = ProtocolContractsList,
|
|
92
|
+
bindings?: LoggerBindings,
|
|
61
93
|
) {
|
|
62
|
-
this.
|
|
63
|
-
this.
|
|
94
|
+
this.config = PublicSimulatorConfig.from(config ?? {});
|
|
95
|
+
this.bindings = bindings;
|
|
96
|
+
this.log = createLogger(`simulator:public_tx_simulator`, bindings);
|
|
64
97
|
}
|
|
65
98
|
|
|
66
|
-
get tracer(): Tracer {
|
|
67
|
-
return this.metrics.tracer;
|
|
68
|
-
}
|
|
69
99
|
/**
|
|
70
100
|
* Simulate a transaction's public portion including all of its phases.
|
|
71
101
|
* @param tx - The transaction to simulate.
|
|
72
102
|
* @returns The result of the transaction's public execution.
|
|
73
103
|
*/
|
|
74
104
|
public async simulate(tx: Tx): Promise<PublicTxResult> {
|
|
75
|
-
|
|
76
|
-
|
|
105
|
+
const txHash = this.computeTxHash(tx);
|
|
106
|
+
this.log.debug(`Simulating ${tx.publicFunctionCalldata.length} public calls for tx ${txHash}`, { txHash });
|
|
77
107
|
|
|
78
|
-
|
|
79
|
-
|
|
108
|
+
// Create hinting DBs.
|
|
109
|
+
const hints = new AvmExecutionHints(
|
|
110
|
+
this.globalVariables,
|
|
111
|
+
AvmTxHint.fromTx(tx, this.globalVariables.gasFees),
|
|
112
|
+
this.protocolContracts,
|
|
113
|
+
);
|
|
114
|
+
const hintingMerkleTree = await HintingMerkleWriteOperations.create(this.merkleTree, hints);
|
|
115
|
+
const hintingTreesDB = new PublicTreesDB(hintingMerkleTree);
|
|
116
|
+
const hintingContractsDB = new HintingPublicContractsDB(this.contractsDB, hints);
|
|
117
|
+
|
|
118
|
+
const context = await PublicTxContext.create(
|
|
119
|
+
hintingTreesDB,
|
|
120
|
+
hintingContractsDB,
|
|
121
|
+
tx,
|
|
122
|
+
this.globalVariables,
|
|
123
|
+
this.protocolContracts,
|
|
124
|
+
this.config.proverId,
|
|
125
|
+
this.bindings,
|
|
126
|
+
);
|
|
80
127
|
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
tx,
|
|
85
|
-
this.globalVariables,
|
|
86
|
-
this.doMerkleOperations,
|
|
87
|
-
);
|
|
128
|
+
// This will throw if there is a nullifier collision.
|
|
129
|
+
// In that case the transaction will be thrown out.
|
|
130
|
+
await this.insertNonRevertiblesFromPrivate(context);
|
|
88
131
|
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
//
|
|
92
|
-
//
|
|
93
|
-
await this.
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
if (context.hasPhase(TxExecutionPhase.SETUP)) {
|
|
99
|
-
const setupResult: ProcessedPhase = await this.simulateSetupPhase(context);
|
|
100
|
-
processedPhases.push(setupResult);
|
|
132
|
+
const processedPhases: ProcessedPhase[] = [];
|
|
133
|
+
if (context.hasPhase(TxExecutionPhase.SETUP)) {
|
|
134
|
+
// This will throw if the setup phase reverts.
|
|
135
|
+
// In that case the transaction will be thrown out.
|
|
136
|
+
const setupResult = await this.simulatePhase(TxExecutionPhase.SETUP, context);
|
|
137
|
+
if (setupResult.reverted) {
|
|
138
|
+
throw new Error(
|
|
139
|
+
`[SETUP] UNRECOVERABLE ERROR! The transaction will be thrown out. ${setupResult.revertReason?.message}`,
|
|
140
|
+
);
|
|
101
141
|
}
|
|
142
|
+
processedPhases.push(setupResult);
|
|
143
|
+
}
|
|
102
144
|
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
145
|
+
// The checkpoint we should go back to if anything from now on reverts.
|
|
146
|
+
await context.state.fork();
|
|
147
|
+
hintingContractsDB.createCheckpoint();
|
|
148
|
+
|
|
149
|
+
try {
|
|
150
|
+
// This will throw if there is a nullifier collision or other insertion error (limit reached).
|
|
151
|
+
await this.insertRevertiblesFromPrivate(context);
|
|
152
|
+
|
|
153
|
+
// Only proceed with app logic if there was no revert during revertible insertion.
|
|
154
|
+
if (context.hasPhase(TxExecutionPhase.APP_LOGIC)) {
|
|
155
|
+
const appLogicResult = await this.simulatePhase(TxExecutionPhase.APP_LOGIC, context);
|
|
156
|
+
processedPhases.push(appLogicResult);
|
|
157
|
+
if (appLogicResult.reverted) {
|
|
158
|
+
throw new TxSimAppLogicRevert();
|
|
115
159
|
}
|
|
160
|
+
}
|
|
161
|
+
} catch (e: any) {
|
|
162
|
+
if (e instanceof TxSimRevertibleInsertionsRevert || e instanceof TxSimAppLogicRevert) {
|
|
163
|
+
// We revert to the post-setup state.
|
|
164
|
+
await context.state.discardForkedState();
|
|
165
|
+
hintingContractsDB.revertCheckpoint();
|
|
166
|
+
// But we also create a new fork so that the teardown phase can transparently
|
|
167
|
+
// commit or rollback at the end of teardown.
|
|
168
|
+
await context.state.fork();
|
|
169
|
+
hintingContractsDB.createCheckpoint();
|
|
116
170
|
} else {
|
|
117
|
-
|
|
171
|
+
// Unchecked/unknown error - re-throw as-is
|
|
172
|
+
throw e;
|
|
118
173
|
}
|
|
174
|
+
}
|
|
119
175
|
|
|
176
|
+
try {
|
|
120
177
|
if (context.hasPhase(TxExecutionPhase.TEARDOWN)) {
|
|
121
|
-
const teardownResult
|
|
178
|
+
const teardownResult = await this.simulatePhase(TxExecutionPhase.TEARDOWN, context);
|
|
122
179
|
processedPhases.push(teardownResult);
|
|
180
|
+
if (teardownResult.reverted) {
|
|
181
|
+
throw new TxSimTeardownRevert();
|
|
182
|
+
}
|
|
123
183
|
}
|
|
124
|
-
|
|
125
|
-
await context.
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
await tx.filterRevertedLogs();
|
|
184
|
+
// We commit the forked state and we are done.
|
|
185
|
+
await context.state.mergeForkedState();
|
|
186
|
+
hintingContractsDB.commitCheckpoint();
|
|
187
|
+
} catch (e: any) {
|
|
188
|
+
if (e instanceof TxSimTeardownRevert) {
|
|
189
|
+
// We revert to the post-setup state and we are done.
|
|
190
|
+
await context.state.discardForkedState();
|
|
191
|
+
hintingContractsDB.revertCheckpoint();
|
|
192
|
+
} else {
|
|
193
|
+
// Unchecked/unknown error - re-throw as-is
|
|
194
|
+
throw e;
|
|
136
195
|
}
|
|
137
|
-
// Commit contracts from this TX to the block-level cache and clear tx cache
|
|
138
|
-
// If the tx reverted, only commit non-revertible contracts
|
|
139
|
-
// NOTE: You can't create contracts in public, so this is only relevant for private-created contracts
|
|
140
|
-
this.worldStateDB.commitContractsForTx(/*onlyNonRevertibles=*/ !revertCode.isOK());
|
|
141
|
-
|
|
142
|
-
const endTime = process.hrtime.bigint();
|
|
143
|
-
this.log.debug(`Public TX simulator took ${Number(endTime - startTime) / 1_000_000} ms\n`);
|
|
144
|
-
|
|
145
|
-
return {
|
|
146
|
-
avmProvingRequest,
|
|
147
|
-
gasUsed: {
|
|
148
|
-
totalGas: context.getActualGasUsed(),
|
|
149
|
-
teardownGas: context.teardownGasUsed,
|
|
150
|
-
publicGas: context.getActualPublicGasUsed(),
|
|
151
|
-
billedGas: context.getTotalGasUsed(),
|
|
152
|
-
},
|
|
153
|
-
revertCode,
|
|
154
|
-
revertReason: context.revertReason,
|
|
155
|
-
processedPhases: processedPhases,
|
|
156
|
-
};
|
|
157
|
-
} finally {
|
|
158
|
-
// Make sure there are no new contracts in the tx-level cache.
|
|
159
|
-
// They should either be committed to block-level cache or cleared.
|
|
160
|
-
this.worldStateDB.clearContractsForTx();
|
|
161
196
|
}
|
|
162
|
-
}
|
|
163
|
-
|
|
164
|
-
/**
|
|
165
|
-
* Simulate the setup phase of a transaction's public execution.
|
|
166
|
-
* @param context - WILL BE MUTATED. The context of the currently executing public transaction portion
|
|
167
|
-
* @returns The phase result.
|
|
168
|
-
*/
|
|
169
|
-
private async simulateSetupPhase(context: PublicTxContext): Promise<ProcessedPhase> {
|
|
170
|
-
return await this.simulatePhase(TxExecutionPhase.SETUP, context);
|
|
171
|
-
}
|
|
172
197
|
|
|
173
|
-
|
|
174
|
-
* Simulate the app logic phase of a transaction's public execution.
|
|
175
|
-
* @param context - WILL BE MUTATED. The context of the currently executing public transaction portion
|
|
176
|
-
* @returns The phase result.
|
|
177
|
-
*/
|
|
178
|
-
private async simulateAppLogicPhase(context: PublicTxContext): Promise<ProcessedPhase> {
|
|
179
|
-
assert(context.state.isForked(), 'App logic phase should operate with forked state.');
|
|
198
|
+
context.halt();
|
|
180
199
|
|
|
181
|
-
|
|
200
|
+
// Such transactions should be filtered by GasTxValidator.
|
|
201
|
+
assert(
|
|
202
|
+
context.getActualGasUsed().l2Gas <= AVM_MAX_PROCESSABLE_L2_GAS,
|
|
203
|
+
`Transaction consumes ${context.getActualGasUsed().l2Gas} L2 gas, which exceeds the AVM maximum processable gas of ${AVM_MAX_PROCESSABLE_L2_GAS}`,
|
|
204
|
+
);
|
|
205
|
+
await this.payFee(context);
|
|
182
206
|
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
await context.state.discardForkedState();
|
|
186
|
-
} else {
|
|
187
|
-
if (!context.hasPhase(TxExecutionPhase.TEARDOWN)) {
|
|
188
|
-
// Nothing to do after this (no teardown), so merge state updates now instead of letting teardown handle it.
|
|
189
|
-
await context.state.mergeForkedState();
|
|
190
|
-
}
|
|
191
|
-
}
|
|
207
|
+
const publicInputs = await context.generateAvmCircuitPublicInputs();
|
|
208
|
+
const revertCode = context.getFinalRevertCode();
|
|
192
209
|
|
|
193
|
-
return
|
|
194
|
-
|
|
210
|
+
// We only return the app logic phase information, and only 1 per phase.
|
|
211
|
+
const appLogicReturnValues: NestedProcessReturnValues[] =
|
|
212
|
+
processedPhases.find(({ phase }) => phase === TxExecutionPhase.APP_LOGIC)?.returnValues ?? [];
|
|
195
213
|
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
* @returns The phase result.
|
|
200
|
-
*/
|
|
201
|
-
private async simulateTeardownPhase(context: PublicTxContext): Promise<ProcessedPhase> {
|
|
202
|
-
if (!context.state.isForked()) {
|
|
203
|
-
// If state isn't forked (app logic reverted), fork now
|
|
204
|
-
// so we can rollback to the end of setup if teardown reverts.
|
|
205
|
-
await context.state.fork();
|
|
214
|
+
// TODO(fcarreiro): This is a temporary backwards compatibility layer until we migrate to the C++ simulator.
|
|
215
|
+
if (context.revertReason !== undefined) {
|
|
216
|
+
(appLogicReturnValues as any).revertReason = context.revertReason;
|
|
206
217
|
}
|
|
207
218
|
|
|
208
|
-
|
|
219
|
+
// Create PublicTxEffect from PublicInputs.
|
|
220
|
+
const publicTxEffect = new PublicTxEffect(
|
|
221
|
+
publicInputs.transactionFee,
|
|
222
|
+
publicInputs.accumulatedData.noteHashes.filter(h => !h.isEmpty()),
|
|
223
|
+
publicInputs.accumulatedData.nullifiers.filter(n => !n.isEmpty()),
|
|
224
|
+
publicInputs.accumulatedData.l2ToL1Msgs.filter(m => !m.isEmpty()),
|
|
225
|
+
publicInputs.accumulatedData.publicLogs.toLogs(),
|
|
226
|
+
publicInputs.accumulatedData.publicDataWrites.filter(w => !w.isEmpty()),
|
|
227
|
+
);
|
|
209
228
|
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
229
|
+
return new PublicTxResult(
|
|
230
|
+
/*gasUsed=*/ {
|
|
231
|
+
totalGas: context.getActualGasUsed(),
|
|
232
|
+
teardownGas: context.teardownGasUsed,
|
|
233
|
+
publicGas: context.getActualPublicGasUsed(),
|
|
234
|
+
billedGas: context.getTotalGasUsed(),
|
|
235
|
+
},
|
|
236
|
+
/*revertCode=*/ revertCode,
|
|
237
|
+
/*publicTxEffect=*/ publicTxEffect,
|
|
238
|
+
/*callStackMetadata=*/ appLogicReturnValues,
|
|
239
|
+
/*logs=*/ context.state.getActiveStateManager().getLogs(),
|
|
240
|
+
/*hints=*/ hints,
|
|
241
|
+
/*publicInputs=*/ publicInputs,
|
|
242
|
+
);
|
|
243
|
+
}
|
|
217
244
|
|
|
218
|
-
|
|
245
|
+
protected computeTxHash(tx: Tx) {
|
|
246
|
+
return tx.getTxHash();
|
|
219
247
|
}
|
|
220
248
|
|
|
221
249
|
/**
|
|
222
|
-
* Simulate
|
|
223
|
-
* @param phase - The current phase
|
|
250
|
+
* Simulate the setup phase of a transaction's public execution.
|
|
224
251
|
* @param context - WILL BE MUTATED. The context of the currently executing public transaction portion
|
|
225
252
|
* @returns The phase result.
|
|
226
253
|
*/
|
|
227
|
-
|
|
254
|
+
protected async simulatePhase(phase: TxExecutionPhase, context: PublicTxContext): Promise<ProcessedPhase> {
|
|
228
255
|
const callRequests = context.getCallRequestsForPhase(phase);
|
|
229
|
-
const executionRequests = context.getExecutionRequestsForPhase(phase);
|
|
230
256
|
|
|
231
257
|
this.log.debug(`Processing phase ${TxExecutionPhase[phase]} for tx ${context.txHash}`, {
|
|
232
258
|
txHash: context.txHash.toString(),
|
|
233
259
|
phase: TxExecutionPhase[phase],
|
|
234
260
|
callRequests: callRequests.length,
|
|
235
|
-
executionRequests: executionRequests.length,
|
|
236
261
|
});
|
|
237
262
|
|
|
238
263
|
const returnValues: NestedProcessReturnValues[] = [];
|
|
239
264
|
let reverted = false;
|
|
240
265
|
let revertReason: SimulationError | undefined;
|
|
241
|
-
|
|
242
|
-
for (let i = callRequests.length - 1; i >= 0; i--) {
|
|
266
|
+
for (let i = 0; i < callRequests.length; i++) {
|
|
243
267
|
if (reverted) {
|
|
244
268
|
break;
|
|
245
269
|
}
|
|
246
270
|
|
|
247
271
|
const callRequest = callRequests[i];
|
|
248
|
-
const executionRequest = executionRequests[i];
|
|
249
272
|
|
|
250
|
-
const enqueuedCallResult = await this.simulateEnqueuedCall(phase, context, callRequest
|
|
273
|
+
const enqueuedCallResult = await this.simulateEnqueuedCall(phase, context, callRequest);
|
|
251
274
|
|
|
252
|
-
returnValues.push(new NestedProcessReturnValues(enqueuedCallResult.output));
|
|
275
|
+
returnValues.push(new NestedProcessReturnValues(enqueuedCallResult.output.bestEffortReadAll()));
|
|
253
276
|
|
|
254
277
|
if (enqueuedCallResult.reverted) {
|
|
255
278
|
reverted = true;
|
|
@@ -259,7 +282,6 @@ export class PublicTxSimulator {
|
|
|
259
282
|
|
|
260
283
|
return {
|
|
261
284
|
phase,
|
|
262
|
-
durationMs: phaseTimer.ms(),
|
|
263
285
|
returnValues,
|
|
264
286
|
reverted,
|
|
265
287
|
revertReason,
|
|
@@ -270,31 +292,27 @@ export class PublicTxSimulator {
|
|
|
270
292
|
* Simulate an enqueued public call.
|
|
271
293
|
* @param phase - The current phase of public execution
|
|
272
294
|
* @param context - WILL BE MUTATED. The context of the currently executing public transaction portion
|
|
273
|
-
* @param callRequest - The
|
|
274
|
-
* @param executionRequest - The execution request (includes args)
|
|
295
|
+
* @param callRequest - The public function call request, including the calldata.
|
|
275
296
|
* @returns The result of execution.
|
|
276
297
|
*/
|
|
277
|
-
|
|
278
|
-
[Attributes.TX_HASH]: context.txHash.toString(),
|
|
279
|
-
[Attributes.TARGET_ADDRESS]: executionRequest.callContext.contractAddress.toString(),
|
|
280
|
-
[Attributes.SENDER_ADDRESS]: executionRequest.callContext.msgSender.toString(),
|
|
281
|
-
[Attributes.SIMULATOR_PHASE]: TxExecutionPhase[phase].toString(),
|
|
282
|
-
}))
|
|
283
|
-
private async simulateEnqueuedCall(
|
|
298
|
+
protected async simulateEnqueuedCall(
|
|
284
299
|
phase: TxExecutionPhase,
|
|
285
300
|
context: PublicTxContext,
|
|
286
|
-
callRequest:
|
|
287
|
-
executionRequest: PublicExecutionRequest,
|
|
301
|
+
callRequest: PublicCallRequestWithCalldata,
|
|
288
302
|
): Promise<AvmFinalizedCallResult> {
|
|
289
303
|
const stateManager = context.state.getActiveStateManager();
|
|
290
|
-
const
|
|
291
|
-
const fnName = await getPublicFunctionDebugName(
|
|
304
|
+
const contractAddress = callRequest.request.contractAddress;
|
|
305
|
+
const fnName = await getPublicFunctionDebugName(
|
|
306
|
+
this.contractsDB,
|
|
307
|
+
contractAddress,
|
|
308
|
+
new CallDataArray(callRequest.calldata),
|
|
309
|
+
);
|
|
292
310
|
|
|
293
311
|
const allocatedGas = context.getGasLeftAtPhase(phase);
|
|
294
312
|
|
|
295
313
|
const result = await this.simulateEnqueuedCallInternal(
|
|
296
|
-
|
|
297
|
-
|
|
314
|
+
stateManager,
|
|
315
|
+
callRequest,
|
|
298
316
|
allocatedGas,
|
|
299
317
|
/*transactionFee=*/ context.getTransactionFee(phase),
|
|
300
318
|
fnName,
|
|
@@ -306,11 +324,9 @@ export class PublicTxSimulator {
|
|
|
306
324
|
`Simulated enqueued public call (${fnName}) consumed ${gasUsed.l2Gas} L2 gas ending with ${result.gasLeft.l2Gas} L2 gas left.`,
|
|
307
325
|
);
|
|
308
326
|
|
|
309
|
-
stateManager.traceEnqueuedCall(callRequest, executionRequest.args, result.reverted);
|
|
310
|
-
|
|
311
327
|
if (result.reverted) {
|
|
312
|
-
const culprit = `${
|
|
313
|
-
context.revert(phase, result.revertReason, culprit);
|
|
328
|
+
const culprit = `${contractAddress}:${fnName}`;
|
|
329
|
+
context.revert(phase, result.revertReason, culprit);
|
|
314
330
|
}
|
|
315
331
|
|
|
316
332
|
return result;
|
|
@@ -324,32 +340,24 @@ export class PublicTxSimulator {
|
|
|
324
340
|
* while still simulating phases and generating a proving request.
|
|
325
341
|
*
|
|
326
342
|
* @param stateManager - The state manager for AvmSimulation
|
|
327
|
-
* @param
|
|
328
|
-
* @param executionRequest - The execution request (includes args)
|
|
343
|
+
* @param callRequest - The public function call request, including the calldata.
|
|
329
344
|
* @param allocatedGas - The gas allocated to the enqueued call
|
|
330
345
|
* @param fnName - The name of the function
|
|
331
346
|
* @returns The result of execution.
|
|
332
347
|
*/
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
[Attributes.APP_CIRCUIT_NAME]: fnName,
|
|
337
|
-
}),
|
|
338
|
-
)
|
|
339
|
-
private async simulateEnqueuedCallInternal(
|
|
340
|
-
stateManager: AvmPersistableStateManager,
|
|
341
|
-
executionRequest: PublicExecutionRequest,
|
|
348
|
+
protected async simulateEnqueuedCallInternal(
|
|
349
|
+
stateManager: PublicPersistableStateManager,
|
|
350
|
+
{ request, calldata }: PublicCallRequestWithCalldata,
|
|
342
351
|
allocatedGas: Gas,
|
|
343
352
|
transactionFee: Fr,
|
|
344
353
|
fnName: string,
|
|
345
354
|
): Promise<AvmFinalizedCallResult> {
|
|
346
|
-
const address =
|
|
347
|
-
const sender =
|
|
355
|
+
const address = request.contractAddress;
|
|
356
|
+
const sender = request.msgSender;
|
|
348
357
|
|
|
349
358
|
this.log.debug(
|
|
350
359
|
`Executing enqueued public call to external function ${fnName}@${address} with ${allocatedGas.l2Gas} allocated L2 gas.`,
|
|
351
360
|
);
|
|
352
|
-
const timer = new Timer();
|
|
353
361
|
|
|
354
362
|
const simulator = await AvmSimulator.create(
|
|
355
363
|
stateManager,
|
|
@@ -357,94 +365,138 @@ export class PublicTxSimulator {
|
|
|
357
365
|
sender,
|
|
358
366
|
transactionFee,
|
|
359
367
|
this.globalVariables,
|
|
360
|
-
|
|
361
|
-
|
|
368
|
+
request.isStaticCall,
|
|
369
|
+
new CallDataArray(calldata),
|
|
362
370
|
allocatedGas,
|
|
371
|
+
this.config,
|
|
363
372
|
);
|
|
364
373
|
const avmCallResult = await simulator.execute();
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
this.log.verbose(
|
|
368
|
-
result.reverted
|
|
369
|
-
? `Simulation of enqueued public call ${fnName} reverted with reason ${result.revertReason}.`
|
|
370
|
-
: `Simulation of enqueued public call ${fnName} completed successfully.`,
|
|
371
|
-
{
|
|
372
|
-
eventName: 'avm-simulation',
|
|
373
|
-
appCircuitName: fnName,
|
|
374
|
-
duration: timer.ms(),
|
|
375
|
-
} satisfies AvmSimulationStats,
|
|
376
|
-
);
|
|
377
|
-
|
|
378
|
-
if (result.reverted) {
|
|
379
|
-
this.metrics.recordFunctionSimulationFailure();
|
|
380
|
-
} else {
|
|
381
|
-
this.metrics.recordFunctionSimulation(timer.ms(), allocatedGas.sub(result.gasLeft).l2Gas, fnName);
|
|
382
|
-
}
|
|
383
|
-
|
|
384
|
-
return result;
|
|
374
|
+
return avmCallResult.finalize();
|
|
385
375
|
}
|
|
386
376
|
|
|
387
377
|
/**
|
|
388
378
|
* Insert the non-revertible accumulated data from private into the public state.
|
|
389
379
|
*/
|
|
390
|
-
|
|
380
|
+
protected async insertNonRevertiblesFromPrivate(context: PublicTxContext) {
|
|
391
381
|
const stateManager = context.state.getActiveStateManager();
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
`Nullifier collision encountered when inserting non-revertible nullifiers from private.\nDetails: ${e.message}\nStack:${e.stack}`,
|
|
398
|
-
);
|
|
399
|
-
}
|
|
382
|
+
|
|
383
|
+
for (const siloedNullifier of context.nonRevertibleAccumulatedDataFromPrivate.nullifiers.filter(
|
|
384
|
+
n => !n.isEmpty(),
|
|
385
|
+
)) {
|
|
386
|
+
await stateManager.writeSiloedNullifier(siloedNullifier);
|
|
400
387
|
}
|
|
401
388
|
for (const noteHash of context.nonRevertibleAccumulatedDataFromPrivate.noteHashes) {
|
|
402
389
|
if (!noteHash.isEmpty()) {
|
|
403
390
|
await stateManager.writeUniqueNoteHash(noteHash);
|
|
404
391
|
}
|
|
405
392
|
}
|
|
393
|
+
for (const l2ToL1Message of context.nonRevertibleAccumulatedDataFromPrivate.l2ToL1Msgs) {
|
|
394
|
+
if (!l2ToL1Message.isEmpty()) {
|
|
395
|
+
stateManager.writeScopedL2ToL1Message(l2ToL1Message);
|
|
396
|
+
}
|
|
397
|
+
}
|
|
398
|
+
|
|
399
|
+
// add new contracts to the contracts db so that their code may be found and called
|
|
400
|
+
// FIXME(fcarreiro): this should conceptually use the hinting contracts db.
|
|
401
|
+
// However, things work as expected because later calls to getters on the hintingContractsDB
|
|
402
|
+
// will pick up the new contracts and will generate the necessary hints.
|
|
403
|
+
// So, a consumer of the hints will always see the new contracts.
|
|
404
|
+
await this.contractsDB.addContracts(context.nonRevertibleContractDeploymentData);
|
|
406
405
|
}
|
|
407
406
|
|
|
408
407
|
/**
|
|
409
408
|
* Insert the revertible accumulated data from private into the public state.
|
|
410
|
-
*
|
|
409
|
+
* Throws TxSimRevertibleInsertionsRevert if there is some checked error during revertible insertions.
|
|
410
|
+
* This function checks for the following errors:
|
|
411
|
+
* - NullifierLimitReachedError
|
|
412
|
+
* - NullifierCollisionError
|
|
413
|
+
* - NoteHashLimitReachedError
|
|
414
|
+
* - L2ToL1MessageLimitReachedError
|
|
411
415
|
*/
|
|
412
|
-
|
|
413
|
-
// Fork the state manager so we can rollback to end of setup if app logic reverts.
|
|
414
|
-
await context.state.fork();
|
|
416
|
+
protected async insertRevertiblesFromPrivate(context: PublicTxContext) {
|
|
415
417
|
const stateManager = context.state.getActiveStateManager();
|
|
418
|
+
|
|
416
419
|
try {
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
420
|
+
for (const siloedNullifier of context.revertibleAccumulatedDataFromPrivate.nullifiers.filter(n => !n.isEmpty())) {
|
|
421
|
+
await stateManager.writeSiloedNullifier(siloedNullifier);
|
|
422
|
+
}
|
|
423
|
+
} catch (e: any) {
|
|
424
|
+
if (e instanceof NullifierLimitReachedError || e instanceof NullifierCollisionError) {
|
|
421
425
|
context.revert(
|
|
422
426
|
TxExecutionPhase.APP_LOGIC,
|
|
423
427
|
new SimulationError(
|
|
424
|
-
`
|
|
428
|
+
`Error encountered when inserting revertible nullifiers from private.\nDetails: ${e.message}`,
|
|
425
429
|
[],
|
|
426
430
|
),
|
|
427
|
-
/*culprit=*/ 'insertRevertiblesFromPrivate',
|
|
428
431
|
);
|
|
429
|
-
|
|
432
|
+
throw new TxSimRevertibleInsertionsRevert();
|
|
430
433
|
} else {
|
|
434
|
+
// Unchecked/unknown error - re-throw as-is
|
|
431
435
|
throw e;
|
|
432
436
|
}
|
|
433
437
|
}
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
+
|
|
439
|
+
try {
|
|
440
|
+
for (const noteHash of context.revertibleAccumulatedDataFromPrivate.noteHashes) {
|
|
441
|
+
if (!noteHash.isEmpty()) {
|
|
442
|
+
// Revertible note hashes from private are not hashed with nonce, since private can't know their final position, only we can.
|
|
443
|
+
await stateManager.writeSiloedNoteHash(noteHash);
|
|
444
|
+
}
|
|
445
|
+
}
|
|
446
|
+
} catch (e: any) {
|
|
447
|
+
if (e instanceof NoteHashLimitReachedError) {
|
|
448
|
+
context.revert(
|
|
449
|
+
TxExecutionPhase.APP_LOGIC,
|
|
450
|
+
new SimulationError(
|
|
451
|
+
`Error encountered when inserting revertible note hashes from private.\nDetails: ${e.message}`,
|
|
452
|
+
[],
|
|
453
|
+
),
|
|
454
|
+
);
|
|
455
|
+
throw new TxSimRevertibleInsertionsRevert();
|
|
456
|
+
} else {
|
|
457
|
+
// Unchecked/unknown error - re-throw as-is
|
|
458
|
+
throw e;
|
|
459
|
+
}
|
|
460
|
+
}
|
|
461
|
+
|
|
462
|
+
try {
|
|
463
|
+
for (const l2ToL1Message of context.revertibleAccumulatedDataFromPrivate.l2ToL1Msgs) {
|
|
464
|
+
if (!l2ToL1Message.isEmpty()) {
|
|
465
|
+
stateManager.writeScopedL2ToL1Message(l2ToL1Message);
|
|
466
|
+
}
|
|
467
|
+
}
|
|
468
|
+
} catch (e: any) {
|
|
469
|
+
if (e instanceof L2ToL1MessageLimitReachedError) {
|
|
470
|
+
context.revert(
|
|
471
|
+
TxExecutionPhase.APP_LOGIC,
|
|
472
|
+
new SimulationError(
|
|
473
|
+
`Error encountered when inserting revertible L2-to-L1 messages from private.\nDetails: ${e.message}`,
|
|
474
|
+
[],
|
|
475
|
+
),
|
|
476
|
+
);
|
|
477
|
+
throw new TxSimRevertibleInsertionsRevert();
|
|
478
|
+
} else {
|
|
479
|
+
// Unchecked/unknown error - re-throw as-is
|
|
480
|
+
throw e;
|
|
438
481
|
}
|
|
439
482
|
}
|
|
440
|
-
|
|
483
|
+
|
|
484
|
+
// add new contracts to the contracts db so that their functions may be found and called
|
|
485
|
+
// FIXME(fcarreiro): this should conceptually use the hinting contracts db.
|
|
486
|
+
// However, things work as expected because later calls to getters on the hintingContractsDB
|
|
487
|
+
// will pick up the new contracts and will generate the necessary hints.
|
|
488
|
+
// So, a consumer of the hints will always see the new contracts.
|
|
489
|
+
await this.contractsDB.addContracts(context.revertibleContractDeploymentData);
|
|
441
490
|
}
|
|
442
491
|
|
|
443
492
|
private async payFee(context: PublicTxContext) {
|
|
444
493
|
const txFee = context.getTransactionFee(TxExecutionPhase.TEARDOWN);
|
|
445
494
|
|
|
446
495
|
if (context.feePayer.isZero()) {
|
|
447
|
-
|
|
496
|
+
// Real transactions are enforced by private kernel to have nonzero fee payer.
|
|
497
|
+
// Real transactions cannot skip fee enforcement (skipping fee enforcement makes them unprovable).
|
|
498
|
+
assert(this.config.skipFeeEnforcement, 'Fee payer cannot be 0 unless skipping fee enforcement for simulation');
|
|
499
|
+
this.log.debug(`Fee payer is 0. Skipping fee enforcement. No one is paying the fee of ${txFee.toBigInt()}`);
|
|
448
500
|
return;
|
|
449
501
|
}
|
|
450
502
|
|
|
@@ -459,13 +511,14 @@ export class PublicTxSimulator {
|
|
|
459
511
|
// When mocking the balance of the fee payer, the circuit should not be able to prove the simulation
|
|
460
512
|
|
|
461
513
|
if (currentBalance.lt(txFee)) {
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
)
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
514
|
+
// Without "skipFeeEnforcement", such transactions should be filtered by GasTxValidator.
|
|
515
|
+
assert(
|
|
516
|
+
this.config.skipFeeEnforcement,
|
|
517
|
+
`Not enough balance for fee payer to pay for transaction (got ${currentBalance.toBigInt()} needs ${txFee.toBigInt()})`,
|
|
518
|
+
);
|
|
519
|
+
this.log.debug(`Fee payer balance insufficient, but we're skipping fee enforcement`);
|
|
520
|
+
// We still proceed and perform the storage write to minimize deviation from normal execution.
|
|
521
|
+
currentBalance = txFee;
|
|
469
522
|
}
|
|
470
523
|
|
|
471
524
|
const updatedBalance = currentBalance.sub(txFee);
|