@aztec/simulator 0.0.0-test.0 → 0.0.1-commit.03f7ef2
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 +6 -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 -15
- 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 +12 -6
- package/dest/private/acvm/acvm.d.ts.map +1 -1
- package/dest/private/acvm/acvm.js +10 -16
- 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 +39 -0
- package/dest/private/acvm_native.d.ts.map +1 -0
- package/dest/private/{providers/acvm_native.js → acvm_native.js} +26 -20
- package/dest/private/acvm_wasm.d.ts +15 -0
- package/dest/private/acvm_wasm.d.ts.map +1 -0
- package/dest/private/{providers/acvm_wasm.js → acvm_wasm.js} +22 -19
- 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 +108 -0
- package/dest/private/circuit_recording/circuit_recorder.d.ts.map +1 -0
- package/dest/private/circuit_recording/circuit_recorder.js +209 -0
- package/dest/private/circuit_recording/file_circuit_recorder.d.ts +31 -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 +5 -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} +2 -2
- package/dest/public/avm/avm_context.d.ts +7 -7
- package/dest/public/avm/avm_context.d.ts.map +1 -1
- package/dest/public/avm/avm_contract_call_result.d.ts +6 -4
- package/dest/public/avm/avm_contract_call_result.d.ts.map +1 -1
- package/dest/public/avm/avm_contract_call_result.js +11 -7
- package/dest/public/avm/avm_execution_environment.d.ts +5 -3
- 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 +4 -2
- package/dest/public/avm/avm_machine_state.d.ts.map +1 -1
- package/dest/public/avm/avm_machine_state.js +2 -0
- 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 +18 -7
- package/dest/public/avm/avm_simulator.d.ts +7 -7
- package/dest/public/avm/avm_simulator.d.ts.map +1 -1
- package/dest/public/avm/avm_simulator.js +28 -39
- 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/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 +23 -16
- 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 +44 -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 +3 -3
- package/dest/public/avm/opcodes/accrued_substate.d.ts.map +1 -1
- package/dest/public/avm/opcodes/accrued_substate.js +28 -25
- 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 +19 -7
- 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 +10 -18
- package/dest/public/avm/opcodes/bitwise.d.ts.map +1 -1
- package/dest/public/avm/opcodes/bitwise.js +19 -26
- package/dest/public/avm/opcodes/comparators.d.ts +4 -4
- 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 +2 -3
- package/dest/public/avm/opcodes/contract.d.ts.map +1 -1
- package/dest/public/avm/opcodes/contract.js +9 -10
- package/dest/public/avm/opcodes/control_flow.d.ts +1 -1
- package/dest/public/avm/opcodes/control_flow.d.ts.map +1 -1
- package/dest/public/avm/opcodes/control_flow.js +10 -8
- package/dest/public/avm/opcodes/conversion.d.ts +2 -1
- package/dest/public/avm/opcodes/conversion.d.ts.map +1 -1
- package/dest/public/avm/opcodes/conversion.js +267 -3
- package/dest/public/avm/opcodes/ec_add.d.ts +2 -2
- package/dest/public/avm/opcodes/ec_add.d.ts.map +1 -1
- package/dest/public/avm/opcodes/ec_add.js +8 -8
- package/dest/public/avm/opcodes/environment_getters.d.ts +3 -3
- package/dest/public/avm/opcodes/environment_getters.d.ts.map +1 -1
- package/dest/public/avm/opcodes/environment_getters.js +17 -19
- package/dest/public/avm/opcodes/external_calls.d.ts +9 -8
- package/dest/public/avm/opcodes/external_calls.d.ts.map +1 -1
- package/dest/public/avm/opcodes/external_calls.js +39 -34
- package/dest/public/avm/opcodes/hashing.d.ts +2 -2
- package/dest/public/avm/opcodes/hashing.d.ts.map +1 -1
- package/dest/public/avm/opcodes/hashing.js +15 -10
- 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 +1 -1
- package/dest/public/avm/opcodes/instruction_impl.d.ts.map +1 -1
- package/dest/public/avm/opcodes/memory.d.ts +6 -6
- package/dest/public/avm/opcodes/memory.d.ts.map +1 -1
- package/dest/public/avm/opcodes/memory.js +37 -33
- package/dest/public/avm/opcodes/misc.d.ts +3 -2
- package/dest/public/avm/opcodes/misc.d.ts.map +1 -1
- package/dest/public/avm/opcodes/misc.js +41 -16
- package/dest/public/avm/opcodes/storage.d.ts +3 -3
- package/dest/public/avm/opcodes/storage.d.ts.map +1 -1
- package/dest/public/avm/opcodes/storage.js +7 -5
- 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 +35 -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 +37 -6
- 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 +278 -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 +123 -0
- package/dest/public/fixtures/opcode_spammer.d.ts.map +1 -0
- package/dest/public/fixtures/opcode_spammer.js +1681 -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 +46 -0
- package/dest/public/fuzzing/avm_fuzzer_simulator.d.ts.map +1 -0
- package/dest/public/fuzzing/avm_fuzzer_simulator.js +139 -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 +100 -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 +353 -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 +52 -102
- package/dest/public/public_db_sources.d.ts.map +1 -1
- package/dest/public/public_db_sources.js +220 -193
- 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 +111 -0
- package/dest/public/public_processor/public_processor.d.ts +26 -38
- package/dest/public/public_processor/public_processor.d.ts.map +1 -1
- package/dest/public/public_processor/public_processor.js +177 -121
- package/dest/public/public_processor/public_processor_metrics.d.ts +3 -3
- package/dest/public/public_processor/public_processor_metrics.d.ts.map +1 -1
- package/dest/public/public_processor/public_processor_metrics.js +1 -1
- 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 +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 +131 -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 +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 +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 +24 -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 +72 -92
- package/dest/public/public_tx_simulator/public_tx_simulator.d.ts +36 -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 +213 -205
- 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 +39 -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 +22 -68
- package/dest/public/side_effect_trace.d.ts.map +1 -1
- package/dest/public/side_effect_trace.js +72 -122
- 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 +164 -0
- package/dest/public/state_manager/state_manager.d.ts.map +1 -0
- package/dest/public/state_manager/state_manager.js +395 -0
- package/dest/public/test_executor_metrics.d.ts +55 -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 +17 -32
- 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} +47 -24
- package/src/private/acvm_wasm.ts +72 -0
- package/src/private/acvm_wasm_with_blobs.ts +54 -0
- package/src/private/circuit_recording/circuit_recorder.ts +260 -0
- package/src/private/circuit_recording/file_circuit_recorder.ts +158 -0
- package/src/private/circuit_recording/memory_circuit_recorder.ts +11 -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} +6 -6
- package/src/public/avm/avm_context.ts +5 -5
- package/src/public/avm/avm_contract_call_result.ts +18 -6
- package/src/public/avm/avm_execution_environment.ts +9 -2
- package/src/public/avm/avm_gas.ts +26 -38
- package/src/public/avm/avm_machine_state.ts +6 -1
- package/src/public/avm/avm_memory_types.ts +20 -7
- package/src/public/avm/avm_simulator.ts +50 -58
- package/src/public/avm/avm_simulator_interface.ts +8 -0
- package/src/public/avm/errors.ts +20 -75
- package/src/public/avm/fixtures/avm_simulation_tester.ts +33 -22
- package/src/public/avm/fixtures/base_avm_simulation_tester.ts +46 -13
- package/src/public/avm/fixtures/initializers.ts +102 -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 +64 -29
- 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 -7
- package/src/public/avm/opcodes/control_flow.ts +19 -10
- package/src/public/avm/opcodes/conversion.ts +27 -3
- package/src/public/avm/opcodes/ec_add.ts +11 -8
- package/src/public/avm/opcodes/environment_getters.ts +27 -22
- package/src/public/avm/opcodes/external_calls.ts +61 -29
- package/src/public/avm/opcodes/hashing.ts +38 -12
- package/src/public/avm/opcodes/instruction.ts +31 -21
- package/src/public/avm/opcodes/memory.ts +71 -32
- package/src/public/avm/opcodes/misc.ts +60 -18
- package/src/public/avm/opcodes/storage.ts +22 -6
- 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 +50 -0
- package/src/public/executor_metrics.ts +56 -6
- 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 +219 -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 +1638 -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 +240 -0
- package/src/public/fuzzing/avm_simulator_bin.ts +140 -0
- package/src/public/hinting_db_sources.ts +607 -0
- package/src/public/index.ts +11 -8
- package/src/public/public_db_sources.ts +279 -259
- 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 +242 -178
- package/src/public/public_processor/public_processor_metrics.ts +2 -2
- package/src/public/public_tx_simulator/contract_provider_for_cpp.ts +121 -0
- package/src/public/public_tx_simulator/cpp_public_tx_simulator.ts +200 -0
- 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 +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 +168 -195
- package/src/public/public_tx_simulator/public_tx_simulator.ts +302 -260
- 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 +95 -321
- 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 +560 -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_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
|
@@ -6,20 +6,25 @@ function _ts_decorate(decorators, target, key, desc) {
|
|
|
6
6
|
}
|
|
7
7
|
import { MAX_NOTE_HASHES_PER_TX, MAX_NULLIFIERS_PER_TX, NULLIFIER_SUBTREE_HEIGHT } from '@aztec/constants';
|
|
8
8
|
import { padArrayEnd } from '@aztec/foundation/collection';
|
|
9
|
-
import { Fr } from '@aztec/foundation/
|
|
9
|
+
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
10
10
|
import { createLogger } from '@aztec/foundation/log';
|
|
11
|
-
import {
|
|
11
|
+
import { sleep } from '@aztec/foundation/sleep';
|
|
12
|
+
import { DateProvider, Timer, elapsed, executeTimeout } from '@aztec/foundation/timer';
|
|
12
13
|
import { ProtocolContractAddress } from '@aztec/protocol-contracts';
|
|
13
|
-
import {
|
|
14
|
+
import { ContractClassPublishedEvent } from '@aztec/protocol-contracts/class-registry';
|
|
14
15
|
import { computeFeePayerBalanceLeafSlot, computeFeePayerBalanceStorageSlot } from '@aztec/protocol-contracts/fee-juice';
|
|
15
|
-
import { PublicDataWrite } from '@aztec/stdlib/avm';
|
|
16
|
+
import { AvmCircuitInputs, AvmExecutionHints, PublicDataWrite } from '@aztec/stdlib/avm';
|
|
17
|
+
import { computeTransactionFee } from '@aztec/stdlib/fees';
|
|
16
18
|
import { Gas } from '@aztec/stdlib/gas';
|
|
19
|
+
import { ProvingRequestType } from '@aztec/stdlib/proofs';
|
|
17
20
|
import { MerkleTreeId } from '@aztec/stdlib/trees';
|
|
18
|
-
import { NestedProcessReturnValues,
|
|
21
|
+
import { NestedProcessReturnValues, makeProcessedTxFromPrivateOnlyTx, makeProcessedTxFromTxWithPublicCalls } from '@aztec/stdlib/tx';
|
|
19
22
|
import { Attributes, getTelemetryClient, trackSpan } from '@aztec/telemetry-client';
|
|
20
23
|
import { ForkCheckpoint } from '@aztec/world-state/native';
|
|
21
|
-
import {
|
|
22
|
-
import {
|
|
24
|
+
import { AssertionError } from 'assert';
|
|
25
|
+
import { PublicContractsDB, PublicTreesDB } from '../public_db_sources.js';
|
|
26
|
+
import { TelemetryCppPublicTxSimulator } from '../public_tx_simulator/index.js';
|
|
27
|
+
import { GuardedMerkleTreeOperations } from './guarded_merkle_tree.js';
|
|
23
28
|
import { PublicProcessorMetrics } from './public_processor_metrics.js';
|
|
24
29
|
/**
|
|
25
30
|
* Creates new instances of PublicProcessor given the provided merkle tree db and contract data source.
|
|
@@ -27,24 +32,24 @@ import { PublicProcessorMetrics } from './public_processor_metrics.js';
|
|
|
27
32
|
contractDataSource;
|
|
28
33
|
dateProvider;
|
|
29
34
|
telemetryClient;
|
|
30
|
-
constructor(contractDataSource, dateProvider, telemetryClient = getTelemetryClient()){
|
|
35
|
+
constructor(contractDataSource, dateProvider = new DateProvider(), telemetryClient = getTelemetryClient()){
|
|
31
36
|
this.contractDataSource = contractDataSource;
|
|
32
37
|
this.dateProvider = dateProvider;
|
|
33
38
|
this.telemetryClient = telemetryClient;
|
|
34
39
|
}
|
|
35
40
|
/**
|
|
36
41
|
* Creates a new instance of a PublicProcessor.
|
|
37
|
-
* @param historicalHeader - The header of a block previous to the one in which the tx is included.
|
|
38
42
|
* @param globalVariables - The global variables for the block being processed.
|
|
39
43
|
* @param skipFeeEnforcement - Allows disabling balance checks for fee estimations.
|
|
40
44
|
* @returns A new instance of a PublicProcessor.
|
|
41
|
-
*/ create(merkleTree, globalVariables,
|
|
42
|
-
const
|
|
43
|
-
const
|
|
44
|
-
|
|
45
|
+
*/ create(merkleTree, globalVariables, config) {
|
|
46
|
+
const contractsDB = new PublicContractsDB(this.contractDataSource);
|
|
47
|
+
const guardedFork = new GuardedMerkleTreeOperations(merkleTree);
|
|
48
|
+
const publicTxSimulator = this.createPublicTxSimulator(guardedFork, contractsDB, globalVariables, config);
|
|
49
|
+
return new PublicProcessor(globalVariables, guardedFork, contractsDB, publicTxSimulator, this.dateProvider, this.telemetryClient);
|
|
45
50
|
}
|
|
46
|
-
createPublicTxSimulator(
|
|
47
|
-
return new
|
|
51
|
+
createPublicTxSimulator(merkleTree, contractsDB, globalVariables, config) {
|
|
52
|
+
return new TelemetryCppPublicTxSimulator(merkleTree, contractsDB, globalVariables, this.telemetryClient, config);
|
|
48
53
|
}
|
|
49
54
|
}
|
|
50
55
|
class PublicProcessorTimeoutError extends Error {
|
|
@@ -57,20 +62,22 @@ class PublicProcessorTimeoutError extends Error {
|
|
|
57
62
|
* Converts Txs lifted from the P2P module into ProcessedTx objects by executing
|
|
58
63
|
* any public function calls in them. Txs with private calls only are unaffected.
|
|
59
64
|
*/ export class PublicProcessor {
|
|
60
|
-
db;
|
|
61
65
|
globalVariables;
|
|
62
|
-
|
|
66
|
+
guardedMerkleTree;
|
|
67
|
+
contractsDB;
|
|
63
68
|
publicTxSimulator;
|
|
64
69
|
dateProvider;
|
|
65
70
|
log;
|
|
71
|
+
opts;
|
|
66
72
|
metrics;
|
|
67
|
-
constructor(
|
|
68
|
-
this.db = db;
|
|
73
|
+
constructor(globalVariables, guardedMerkleTree, contractsDB, publicTxSimulator, dateProvider, telemetryClient = getTelemetryClient(), log = createLogger('simulator:public-processor'), opts = {}){
|
|
69
74
|
this.globalVariables = globalVariables;
|
|
70
|
-
this.
|
|
75
|
+
this.guardedMerkleTree = guardedMerkleTree;
|
|
76
|
+
this.contractsDB = contractsDB;
|
|
71
77
|
this.publicTxSimulator = publicTxSimulator;
|
|
72
78
|
this.dateProvider = dateProvider;
|
|
73
79
|
this.log = log;
|
|
80
|
+
this.opts = opts;
|
|
74
81
|
this.metrics = new PublicProcessorMetrics(telemetryClient, 'PublicProcessor');
|
|
75
82
|
}
|
|
76
83
|
get tracer() {
|
|
@@ -79,19 +86,22 @@ class PublicProcessorTimeoutError extends Error {
|
|
|
79
86
|
/**
|
|
80
87
|
* Run each tx through the public circuit and the public kernel circuit if needed.
|
|
81
88
|
* @param txs - Txs to process.
|
|
82
|
-
* @param
|
|
89
|
+
* @param limits - Limits for processing the txs.
|
|
90
|
+
* @param validator - Pre-process validator and nullifier cache to use for processing the txs.
|
|
83
91
|
* @returns The list of processed txs with their circuit simulation outputs.
|
|
84
|
-
*/ async process(txs, limits = {},
|
|
85
|
-
const { maxTransactions, maxBlockSize, deadline, maxBlockGas } = limits;
|
|
86
|
-
const { preprocessValidator,
|
|
92
|
+
*/ async process(txs, limits = {}, validator = {}) {
|
|
93
|
+
const { maxTransactions, maxBlockSize, deadline, maxBlockGas, maxBlobFields } = limits;
|
|
94
|
+
const { preprocessValidator, nullifierCache } = validator;
|
|
87
95
|
const result = [];
|
|
96
|
+
const usedTxs = [];
|
|
88
97
|
const failed = [];
|
|
89
98
|
const timer = new Timer();
|
|
90
99
|
let totalSizeInBytes = 0;
|
|
91
100
|
let returns = [];
|
|
92
101
|
let totalPublicGas = new Gas(0, 0);
|
|
93
102
|
let totalBlockGas = new Gas(0, 0);
|
|
94
|
-
|
|
103
|
+
let totalBlobFields = 0;
|
|
104
|
+
for await (const tx of txs){
|
|
95
105
|
// Only process up to the max tx limit
|
|
96
106
|
if (maxTransactions !== undefined && result.length >= maxTransactions) {
|
|
97
107
|
this.log.debug(`Stopping tx processing due to reaching the max tx limit.`);
|
|
@@ -103,8 +113,8 @@ class PublicProcessorTimeoutError extends Error {
|
|
|
103
113
|
break;
|
|
104
114
|
}
|
|
105
115
|
// Skip this tx if it'd exceed max block size
|
|
106
|
-
const txHash =
|
|
107
|
-
const preTxSizeInBytes =
|
|
116
|
+
const txHash = tx.getTxHash().toString();
|
|
117
|
+
const preTxSizeInBytes = tx.getEstimatedPrivateTxEffectsSize();
|
|
108
118
|
if (maxBlockSize !== undefined && totalSizeInBytes + preTxSizeInBytes > maxBlockSize) {
|
|
109
119
|
this.log.warn(`Skipping processing of tx ${txHash} sized ${preTxSizeInBytes} bytes due to block size limit`, {
|
|
110
120
|
txHash,
|
|
@@ -115,7 +125,7 @@ class PublicProcessorTimeoutError extends Error {
|
|
|
115
125
|
continue;
|
|
116
126
|
}
|
|
117
127
|
// Skip this tx if its gas limit would exceed the block gas limit
|
|
118
|
-
const txGasLimit =
|
|
128
|
+
const txGasLimit = tx.data.constants.txContext.gasSettings.gasLimits;
|
|
119
129
|
if (maxBlockGas !== undefined && totalBlockGas.add(txGasLimit).gtAny(maxBlockGas)) {
|
|
120
130
|
this.log.warn(`Skipping processing of tx ${txHash} due to block gas limit`, {
|
|
121
131
|
txHash,
|
|
@@ -125,15 +135,13 @@ class PublicProcessorTimeoutError extends Error {
|
|
|
125
135
|
});
|
|
126
136
|
continue;
|
|
127
137
|
}
|
|
128
|
-
// The processor modifies the tx objects in place, so we need to clone them.
|
|
129
|
-
const tx = Tx.clone(origTx);
|
|
130
138
|
// We validate the tx before processing it, to avoid unnecessary work.
|
|
131
139
|
if (preprocessValidator) {
|
|
132
140
|
const result = await preprocessValidator.validateTx(tx);
|
|
133
|
-
const txHash =
|
|
141
|
+
const txHash = tx.getTxHash();
|
|
134
142
|
if (result.result === 'invalid') {
|
|
135
143
|
const reason = result.reason.join(', ');
|
|
136
|
-
this.log.
|
|
144
|
+
this.log.debug(`Rejecting tx ${txHash.toString()} due to pre-process validation fail: ${reason}`);
|
|
137
145
|
failed.push({
|
|
138
146
|
tx,
|
|
139
147
|
error: new Error(`Tx failed preprocess validation: ${reason}`)
|
|
@@ -142,7 +150,7 @@ class PublicProcessorTimeoutError extends Error {
|
|
|
142
150
|
continue;
|
|
143
151
|
} else if (result.result === 'skipped') {
|
|
144
152
|
const reason = result.reason.join(', ');
|
|
145
|
-
this.log.
|
|
153
|
+
this.log.debug(`Skipping tx ${txHash.toString()} due to pre-process validation: ${reason}`);
|
|
146
154
|
returns.push(new NestedProcessReturnValues([]));
|
|
147
155
|
continue;
|
|
148
156
|
} else {
|
|
@@ -152,13 +160,23 @@ class PublicProcessorTimeoutError extends Error {
|
|
|
152
160
|
// We checkpoint the transaction here, then within the try/catch we
|
|
153
161
|
// 1. Revert the checkpoint if the tx fails or needs to be discarded for any reason
|
|
154
162
|
// 2. Commit the transaction in the finally block. Note that by using the ForkCheckpoint lifecycle only the first commit/revert takes effect
|
|
155
|
-
|
|
163
|
+
// By doing this, every transaction starts on a fresh checkpoint and it's state updates only make it to the fork if this checkpoint is committed.
|
|
164
|
+
// Note: We use the underlying fork here not the guarded one, this ensures that it's not impacted by stopping the guarded version
|
|
165
|
+
const checkpoint = await ForkCheckpoint.new(this.guardedMerkleTree.getUnderlyingFork());
|
|
166
|
+
const startStateReference = await this.guardedMerkleTree.getUnderlyingFork().getStateReference();
|
|
167
|
+
this.contractsDB.createCheckpoint();
|
|
156
168
|
try {
|
|
157
169
|
const [processedTx, returnValues] = await this.processTx(tx, deadline);
|
|
170
|
+
// Inject a fake processing failure after N txs if requested
|
|
171
|
+
const fakeThrowAfter = this.opts.fakeThrowAfterProcessingTxCount;
|
|
172
|
+
if (fakeThrowAfter !== undefined && result.length + failed.length + 1 >= fakeThrowAfter) {
|
|
173
|
+
throw new Error(`Fake error after processing ${fakeThrowAfter} txs`);
|
|
174
|
+
}
|
|
175
|
+
const txBlobFields = processedTx.txEffect.getNumBlobFields();
|
|
158
176
|
// If the actual size of this tx would exceed block size, skip it
|
|
159
|
-
const txSize =
|
|
177
|
+
const txSize = txBlobFields * Fr.SIZE_IN_BYTES;
|
|
160
178
|
if (maxBlockSize !== undefined && totalSizeInBytes + txSize > maxBlockSize) {
|
|
161
|
-
this.log.
|
|
179
|
+
this.log.debug(`Skipping processed tx ${txHash} sized ${txSize} due to max block size.`, {
|
|
162
180
|
txHash,
|
|
163
181
|
sizeInBytes: txSize,
|
|
164
182
|
totalSizeInBytes,
|
|
@@ -166,64 +184,78 @@ class PublicProcessorTimeoutError extends Error {
|
|
|
166
184
|
});
|
|
167
185
|
// Need to revert the checkpoint here and don't go any further
|
|
168
186
|
await checkpoint.revert();
|
|
187
|
+
this.contractsDB.revertCheckpoint();
|
|
169
188
|
continue;
|
|
170
189
|
}
|
|
171
|
-
//
|
|
172
|
-
if (
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
tx,
|
|
184
|
-
error: new Error(`Tx failed post-process validation: ${reason}`)
|
|
185
|
-
});
|
|
186
|
-
// Need to revert the checkpoint here and don't go any further
|
|
187
|
-
await checkpoint.revert();
|
|
188
|
-
continue;
|
|
189
|
-
} else {
|
|
190
|
-
this.log.trace(`Tx ${txHash.toString()} is valid post processing.`);
|
|
191
|
-
}
|
|
192
|
-
}
|
|
193
|
-
if (!tx.hasPublicCalls()) {
|
|
194
|
-
// If there are no public calls, perform all tree insertions for side effects from private
|
|
195
|
-
// When there are public calls, the PublicTxSimulator & AVM handle tree insertions.
|
|
196
|
-
await this.doTreeInsertionsForPrivateOnlyTx(processedTx);
|
|
197
|
-
// Add any contracts registered/deployed in this private-only tx to the block-level cache
|
|
198
|
-
// (add to tx-level cache and then commit to block-level cache)
|
|
199
|
-
await this.worldStateDB.addNewContracts(tx);
|
|
200
|
-
this.worldStateDB.commitContractsForTx();
|
|
190
|
+
// If the actual blob fields of this tx would exceed the limit, skip it
|
|
191
|
+
if (maxBlobFields !== undefined && totalBlobFields + txBlobFields > maxBlobFields) {
|
|
192
|
+
this.log.debug(`Skipping processed tx ${txHash} with ${txBlobFields} blob fields due to max blob fields limit.`, {
|
|
193
|
+
txHash,
|
|
194
|
+
txBlobFields,
|
|
195
|
+
totalBlobFields,
|
|
196
|
+
maxBlobFields
|
|
197
|
+
});
|
|
198
|
+
// Need to revert the checkpoint here and don't go any further
|
|
199
|
+
await checkpoint.revert();
|
|
200
|
+
this.contractsDB.revertCheckpoint();
|
|
201
|
+
continue;
|
|
201
202
|
}
|
|
203
|
+
// FIXME(fcarreiro): it's ugly to have to notify the validator of nullifiers.
|
|
204
|
+
// I'd rather pass the validators the processedTx as well and let them deal with it.
|
|
202
205
|
nullifierCache?.addNullifiers(processedTx.txEffect.nullifiers.map((n)=>n.toBuffer()));
|
|
203
206
|
result.push(processedTx);
|
|
207
|
+
usedTxs.push(tx);
|
|
204
208
|
returns = returns.concat(returnValues);
|
|
205
209
|
totalPublicGas = totalPublicGas.add(processedTx.gasUsed.publicGas);
|
|
206
210
|
totalBlockGas = totalBlockGas.add(processedTx.gasUsed.totalGas);
|
|
207
211
|
totalSizeInBytes += txSize;
|
|
212
|
+
totalBlobFields += txBlobFields;
|
|
208
213
|
} catch (err) {
|
|
209
|
-
// Roll back state to start of TX before proceeding to next TX
|
|
210
|
-
await checkpoint.revert();
|
|
211
214
|
if (err?.name === 'PublicProcessorTimeoutError') {
|
|
212
215
|
this.log.warn(`Stopping tx processing due to timeout.`);
|
|
216
|
+
// We hit the transaction execution deadline.
|
|
217
|
+
// There may still be a transaction executing on a worker thread (C++ via NAPI).
|
|
218
|
+
// Signal cancellation AND WAIT for the simulation to actually stop.
|
|
219
|
+
// This is critical because C++ might be in the middle of a slow operation (e.g., pad_trees)
|
|
220
|
+
// and won't check the cancellation flag until that operation completes.
|
|
221
|
+
// Without waiting, we'd proceed to revert checkpoints while C++ is still writing to state.
|
|
222
|
+
// Wait for C++ to stop gracefully.
|
|
223
|
+
await this.publicTxSimulator.cancel?.();
|
|
224
|
+
// Now stop the guarded fork to prevent any further TS-side access to the world state.
|
|
225
|
+
await this.guardedMerkleTree.stop();
|
|
226
|
+
// We now know there can't be any further access to world state. The fork is in a state where there is:
|
|
227
|
+
// 1. At least one outstanding checkpoint that has not been committed (the one created before we processed the tx).
|
|
228
|
+
// 2. Possible state updates on that checkpoint or any others created during execution.
|
|
229
|
+
// First we revert a checkpoint as managed by the ForkCheckpoint. This will revert whatever is the current checkpoint
|
|
230
|
+
// which may not be the one originally created by this object. But that is ok, we do this to fulfil the ForkCheckpoint
|
|
231
|
+
// lifecycle expectations and ensure it doesn't attempt to commit later on.
|
|
232
|
+
await checkpoint.revert();
|
|
233
|
+
// Now we want to revert any/all remaining checkpoints, destroying any outstanding state updates.
|
|
234
|
+
// This needs to be done directly on the underlying fork as the guarded fork has been stopped.
|
|
235
|
+
await this.guardedMerkleTree.getUnderlyingFork().revertAllCheckpoints();
|
|
236
|
+
// Revert any contracts added to the DB for the tx.
|
|
237
|
+
this.contractsDB.revertCheckpoint();
|
|
238
|
+
// Ensure we're at the same state as when we started processing this tx.
|
|
239
|
+
await this.checkWorldStateUnchanged(startStateReference, txHash, err);
|
|
213
240
|
break;
|
|
214
241
|
}
|
|
215
|
-
|
|
242
|
+
// Roll back state to start of TX before proceeding to next TX
|
|
243
|
+
await checkpoint.revert();
|
|
244
|
+
await this.guardedMerkleTree.getUnderlyingFork().revertAllCheckpoints();
|
|
245
|
+
this.contractsDB.revertCheckpoint();
|
|
246
|
+
const errorMessage = err instanceof Error || err instanceof AssertionError ? err.message : 'Unknown error';
|
|
216
247
|
this.log.warn(`Failed to process tx ${txHash.toString()}: ${errorMessage} ${err?.stack}`);
|
|
217
248
|
failed.push({
|
|
218
249
|
tx,
|
|
219
250
|
error: err instanceof Error ? err : new Error(errorMessage)
|
|
220
251
|
});
|
|
221
252
|
returns.push(new NestedProcessReturnValues([]));
|
|
253
|
+
// Ensure we're at the same state as when we started processing this tx.
|
|
254
|
+
await this.checkWorldStateUnchanged(startStateReference, txHash, err);
|
|
222
255
|
} finally{
|
|
223
|
-
// Base case is we always commit the checkpoint. Using the ForkCheckpoint means this has no effect if the tx was reverted
|
|
256
|
+
// Base case is we always commit the checkpoint. Using the ForkCheckpoint means this has no effect if the tx was previously reverted
|
|
224
257
|
await checkpoint.commit();
|
|
225
|
-
|
|
226
|
-
this.worldStateDB.clearContractsForTx();
|
|
258
|
+
this.contractsDB.commitCheckpointOkIfNone();
|
|
227
259
|
}
|
|
228
260
|
}
|
|
229
261
|
const duration = timer.s();
|
|
@@ -239,12 +271,26 @@ class PublicProcessorTimeoutError extends Error {
|
|
|
239
271
|
return [
|
|
240
272
|
result,
|
|
241
273
|
failed,
|
|
274
|
+
usedTxs,
|
|
242
275
|
returns
|
|
243
276
|
];
|
|
244
277
|
}
|
|
278
|
+
async checkWorldStateUnchanged(startStateReference, txHash, cause) {
|
|
279
|
+
const endStateReference = await this.guardedMerkleTree.getUnderlyingFork().getStateReference();
|
|
280
|
+
if (!startStateReference.equals(endStateReference)) {
|
|
281
|
+
this.log.warn(`Fork state reference changed by tx ${txHash} after error in public processor`, {
|
|
282
|
+
expected: startStateReference.toInspect(),
|
|
283
|
+
actual: endStateReference.toInspect(),
|
|
284
|
+
cause
|
|
285
|
+
});
|
|
286
|
+
throw new Error(`Fork state reference changed by tx ${txHash} after error in public processor`, {
|
|
287
|
+
cause
|
|
288
|
+
});
|
|
289
|
+
}
|
|
290
|
+
}
|
|
245
291
|
async processTx(tx, deadline) {
|
|
246
292
|
const [time, [processedTx, returnValues]] = await elapsed(()=>this.processTxWithinDeadline(tx, deadline));
|
|
247
|
-
this.log.verbose(!tx.hasPublicCalls() ? `Processed tx ${processedTx.hash} with no public calls in ${time}ms` : `Processed tx ${processedTx.hash} with ${tx.
|
|
293
|
+
this.log.verbose(!tx.hasPublicCalls() ? `Processed tx ${processedTx.hash} with no public calls in ${time}ms` : `Processed tx ${processedTx.hash} with ${tx.numberOfPublicCalls()} public calls in ${time}ms`, {
|
|
248
294
|
txHash: processedTx.hash,
|
|
249
295
|
txFee: processedTx.txEffect.transactionFee.toBigInt(),
|
|
250
296
|
revertCode: processedTx.txEffect.revertCode.getCode(),
|
|
@@ -264,7 +310,7 @@ class PublicProcessorTimeoutError extends Error {
|
|
|
264
310
|
returnValues ?? []
|
|
265
311
|
];
|
|
266
312
|
}
|
|
267
|
-
async doTreeInsertionsForPrivateOnlyTx(processedTx
|
|
313
|
+
async doTreeInsertionsForPrivateOnlyTx(processedTx) {
|
|
268
314
|
const treeInsertionStart = process.hrtime.bigint();
|
|
269
315
|
// Update the state so that the next tx in the loop has the correct .startState
|
|
270
316
|
// NB: before this change, all .startStates were actually incorrect, but the issue was never caught because we either:
|
|
@@ -272,29 +318,31 @@ class PublicProcessorTimeoutError extends Error {
|
|
|
272
318
|
// b) always had a txHandler with the same db passed to it as this.db, which updated the db in buildBaseRollupHints in this loop
|
|
273
319
|
// To see how this ^ happens, move back to one shared db in test_context and run orchestrator_multi_public_functions.test.ts
|
|
274
320
|
// The below is taken from buildBaseRollupHints:
|
|
275
|
-
await this.
|
|
321
|
+
await this.guardedMerkleTree.appendLeaves(MerkleTreeId.NOTE_HASH_TREE, padArrayEnd(processedTx.txEffect.noteHashes, Fr.ZERO, MAX_NOTE_HASHES_PER_TX));
|
|
276
322
|
try {
|
|
277
|
-
await this.
|
|
278
|
-
} catch (
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
} else {
|
|
283
|
-
// We have no validator and assume this call should blindly process txs with duplicates being caught later
|
|
284
|
-
this.log.warn(`Detected duplicate nullifier after public processing for: ${processedTx.hash}.`);
|
|
285
|
-
}
|
|
323
|
+
await this.guardedMerkleTree.batchInsert(MerkleTreeId.NULLIFIER_TREE, padArrayEnd(processedTx.txEffect.nullifiers, Fr.ZERO, MAX_NULLIFIERS_PER_TX).map((n)=>n.toBuffer()), NULLIFIER_SUBTREE_HEIGHT);
|
|
324
|
+
} catch (cause) {
|
|
325
|
+
throw new Error(`Transaction ${processedTx.hash} failed with duplicate nullifiers`, {
|
|
326
|
+
cause
|
|
327
|
+
});
|
|
286
328
|
}
|
|
287
|
-
// The only public data write should be for fee payment
|
|
288
|
-
await this.db.sequentialInsert(MerkleTreeId.PUBLIC_DATA_TREE, processedTx.txEffect.publicDataWrites.map((x)=>x.toBuffer()));
|
|
289
329
|
const treeInsertionEnd = process.hrtime.bigint();
|
|
290
330
|
this.metrics.recordTreeInsertions(Number(treeInsertionEnd - treeInsertionStart) / 1_000);
|
|
291
331
|
}
|
|
292
332
|
/** Processes the given tx within deadline. Returns timeout if deadline is hit. */ async processTxWithinDeadline(tx, deadline) {
|
|
293
|
-
const
|
|
333
|
+
const innerProcessFn = tx.hasPublicCalls() ? ()=>this.processTxWithPublicCalls(tx) : ()=>this.processPrivateOnlyTx(tx);
|
|
334
|
+
// Fake a delay per tx if instructed (used for tests)
|
|
335
|
+
const fakeDelayPerTxMs = this.opts.fakeProcessingDelayPerTxMs;
|
|
336
|
+
const processFn = fakeDelayPerTxMs && fakeDelayPerTxMs > 0 ? async ()=>{
|
|
337
|
+
const result = await innerProcessFn();
|
|
338
|
+
this.log.warn(`Sleeping ${fakeDelayPerTxMs}ms after processing tx ${tx.getTxHash().toString()}`);
|
|
339
|
+
await sleep(fakeDelayPerTxMs);
|
|
340
|
+
return result;
|
|
341
|
+
} : innerProcessFn;
|
|
294
342
|
if (!deadline) {
|
|
295
343
|
return await processFn();
|
|
296
344
|
}
|
|
297
|
-
const txHash =
|
|
345
|
+
const txHash = tx.getTxHash();
|
|
298
346
|
const timeout = +deadline - this.dateProvider.now();
|
|
299
347
|
if (timeout <= 0) {
|
|
300
348
|
throw new PublicProcessorTimeoutError();
|
|
@@ -310,26 +358,30 @@ class PublicProcessorTimeoutError extends Error {
|
|
|
310
358
|
* Creates the public data write for paying the tx fee.
|
|
311
359
|
* This is used in private only txs, since for txs with public calls
|
|
312
360
|
* the avm handles the fee payment itself.
|
|
313
|
-
*/ async
|
|
361
|
+
*/ async performFeePaymentPublicDataWrite(txFee, feePayer) {
|
|
314
362
|
const feeJuiceAddress = ProtocolContractAddress.FeeJuice;
|
|
315
363
|
const balanceSlot = await computeFeePayerBalanceStorageSlot(feePayer);
|
|
316
364
|
const leafSlot = await computeFeePayerBalanceLeafSlot(feePayer);
|
|
365
|
+
// This high-level db is used as a convenient helper. It could be done with the merkleTree directly.
|
|
366
|
+
const treesDB = new PublicTreesDB(this.guardedMerkleTree);
|
|
317
367
|
this.log.debug(`Deducting ${txFee.toBigInt()} balance in Fee Juice for ${feePayer}`);
|
|
318
|
-
const balance = await
|
|
368
|
+
const balance = await treesDB.storageRead(feeJuiceAddress, balanceSlot);
|
|
319
369
|
if (balance.lt(txFee)) {
|
|
320
370
|
throw new Error(`Not enough balance for fee payer to pay for transaction (got ${balance.toBigInt()} needs ${txFee.toBigInt()})`);
|
|
321
371
|
}
|
|
322
372
|
const updatedBalance = balance.sub(txFee);
|
|
323
|
-
await
|
|
373
|
+
await treesDB.storageWrite(feeJuiceAddress, balanceSlot, updatedBalance);
|
|
324
374
|
return new PublicDataWrite(leafSlot, updatedBalance);
|
|
325
375
|
}
|
|
326
376
|
async processPrivateOnlyTx(tx) {
|
|
327
377
|
const gasFees = this.globalVariables.gasFees;
|
|
328
|
-
const transactionFee = tx.data.gasUsed
|
|
329
|
-
const feePaymentPublicDataWrite = await this.
|
|
330
|
-
const processedTx =
|
|
331
|
-
|
|
332
|
-
|
|
378
|
+
const transactionFee = computeTransactionFee(gasFees, tx.data.constants.txContext.gasSettings, tx.data.gasUsed);
|
|
379
|
+
const feePaymentPublicDataWrite = await this.performFeePaymentPublicDataWrite(transactionFee, tx.data.feePayer);
|
|
380
|
+
const processedTx = makeProcessedTxFromPrivateOnlyTx(tx, transactionFee, feePaymentPublicDataWrite, this.globalVariables);
|
|
381
|
+
this.metrics.recordClassPublication(...tx.getContractClassLogs().filter((log)=>ContractClassPublishedEvent.isContractClassPublishedEvent(log)).map((log)=>ContractClassPublishedEvent.fromLog(log)));
|
|
382
|
+
// Fee payment insertion has already been done. Do the rest.
|
|
383
|
+
await this.doTreeInsertionsForPrivateOnlyTx(processedTx);
|
|
384
|
+
await this.contractsDB.addNewContracts(tx);
|
|
333
385
|
return [
|
|
334
386
|
processedTx,
|
|
335
387
|
undefined
|
|
@@ -337,43 +389,47 @@ class PublicProcessorTimeoutError extends Error {
|
|
|
337
389
|
}
|
|
338
390
|
async processTxWithPublicCalls(tx) {
|
|
339
391
|
const timer = new Timer();
|
|
340
|
-
const
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
if (phase.reverted) {
|
|
347
|
-
this.metrics.recordRevertedPhase(phase.phase);
|
|
348
|
-
} else {
|
|
349
|
-
this.metrics.recordPhaseDuration(phase.phase, phase.durationMs);
|
|
350
|
-
}
|
|
351
|
-
});
|
|
352
|
-
const siloedContractClassLogs = await tx.filterContractClassLogs(tx.data.getNonEmptyContractClassLogsHashes(), true);
|
|
353
|
-
this.metrics.recordClassRegistration(...siloedContractClassLogs.filter((log)=>ContractClassRegisteredEvent.isContractClassRegisteredEvent(log)).map((log)=>ContractClassRegisteredEvent.fromLog(log)));
|
|
354
|
-
const phaseCount = processedPhases.length;
|
|
392
|
+
const result = await this.publicTxSimulator.simulate(tx);
|
|
393
|
+
// TODO: use the callStackMetadata here to extract more data about public execution
|
|
394
|
+
const { hints, publicInputs, publicTxEffect, gasUsed, revertCode/*callStackMetadata*/ } = result;
|
|
395
|
+
const contractClassLogs = revertCode.isOK() ? tx.getContractClassLogs() : tx.getSplitContractClassLogs(false);
|
|
396
|
+
this.metrics.recordClassPublication(...contractClassLogs.filter((log)=>ContractClassPublishedEvent.isContractClassPublishedEvent(log)).map((log)=>ContractClassPublishedEvent.fromLog(log)));
|
|
397
|
+
// TODO(fcarreiro): remove phase count metric.
|
|
355
398
|
const durationMs = timer.ms();
|
|
356
|
-
this.metrics.recordTx(phaseCount, durationMs, gasUsed.publicGas);
|
|
357
|
-
|
|
358
|
-
const
|
|
399
|
+
this.metrics.recordTx(/*phaseCount=*/ 1, durationMs, gasUsed.publicGas);
|
|
400
|
+
// Extract the return values from the call stack metadata.
|
|
401
|
+
const appLogicReturnValues = result.getAppLogicReturnValues();
|
|
402
|
+
// Extract the revert reason from the call stack metadata.
|
|
403
|
+
const revertReason = result.findRevertReason();
|
|
404
|
+
// Create proving request if we have hints and public inputs.
|
|
405
|
+
const avmProvingRequest = hints && publicInputs ? PublicProcessor.generateProvingRequest(publicInputs, hints) : undefined;
|
|
406
|
+
const processedTx = makeProcessedTxFromTxWithPublicCalls(tx, this.globalVariables, avmProvingRequest, publicTxEffect, gasUsed, revertCode, revertReason);
|
|
359
407
|
return [
|
|
360
408
|
processedTx,
|
|
361
|
-
|
|
409
|
+
appLogicReturnValues
|
|
362
410
|
];
|
|
363
411
|
}
|
|
412
|
+
/**
|
|
413
|
+
* Generate the proving request for the AVM circuit.
|
|
414
|
+
*/ static generateProvingRequest(publicInputs, hints = AvmExecutionHints.empty()) {
|
|
415
|
+
return {
|
|
416
|
+
type: ProvingRequestType.PUBLIC_VM,
|
|
417
|
+
inputs: new AvmCircuitInputs(hints, publicInputs)
|
|
418
|
+
};
|
|
419
|
+
}
|
|
364
420
|
}
|
|
365
421
|
_ts_decorate([
|
|
366
|
-
trackSpan('PublicProcessor.processTx',
|
|
367
|
-
[Attributes.TX_HASH]:
|
|
422
|
+
trackSpan('PublicProcessor.processTx', (tx)=>({
|
|
423
|
+
[Attributes.TX_HASH]: tx.getTxHash().toString()
|
|
368
424
|
}))
|
|
369
425
|
], PublicProcessor.prototype, "processTx", null);
|
|
370
426
|
_ts_decorate([
|
|
371
|
-
trackSpan('PublicProcessor.processPrivateOnlyTx',
|
|
372
|
-
[Attributes.TX_HASH]:
|
|
427
|
+
trackSpan('PublicProcessor.processPrivateOnlyTx', (tx)=>({
|
|
428
|
+
[Attributes.TX_HASH]: tx.getTxHash().toString()
|
|
373
429
|
}))
|
|
374
430
|
], PublicProcessor.prototype, "processPrivateOnlyTx", null);
|
|
375
431
|
_ts_decorate([
|
|
376
|
-
trackSpan('PublicProcessor.processTxWithPublicCalls',
|
|
377
|
-
[Attributes.TX_HASH]:
|
|
432
|
+
trackSpan('PublicProcessor.processTxWithPublicCalls', (tx)=>({
|
|
433
|
+
[Attributes.TX_HASH]: tx.getTxHash().toString()
|
|
378
434
|
}))
|
|
379
435
|
], PublicProcessor.prototype, "processTxWithPublicCalls", null);
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { ContractClassPublishedEvent } from '@aztec/protocol-contracts/class-registry';
|
|
2
2
|
import type { Gas } from '@aztec/stdlib/gas';
|
|
3
3
|
import type { TxExecutionPhase } from '@aztec/stdlib/tx';
|
|
4
4
|
import { type TelemetryClient, type Tracer } from '@aztec/telemetry-client';
|
|
@@ -21,7 +21,7 @@ export declare class PublicProcessorMetrics {
|
|
|
21
21
|
recordAllTxs(totalGas: Gas, gasRate: number): void;
|
|
22
22
|
recordFailedTx(): void;
|
|
23
23
|
recordRevertedPhase(phaseName: TxExecutionPhase): void;
|
|
24
|
-
|
|
24
|
+
recordClassPublication(...events: ContractClassPublishedEvent[]): void;
|
|
25
25
|
recordTreeInsertions(durationUs: number): void;
|
|
26
26
|
}
|
|
27
|
-
//# sourceMappingURL=
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX3Byb2Nlc3Nvcl9tZXRyaWNzLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcHVibGljL3B1YmxpY19wcm9jZXNzb3IvcHVibGljX3Byb2Nlc3Nvcl9tZXRyaWNzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDNUYsT0FBTyxLQUFLLEVBQUUsR0FBRyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDN0MsT0FBTyxLQUFLLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUN6RCxPQUFPLEVBS0wsS0FBSyxlQUFlLEVBQ3BCLEtBQUssTUFBTSxFQUdaLE1BQU0seUJBQXlCLENBQUM7QUFFakMscUJBQWEsc0JBQXNCO0lBQ2pDLFNBQWdCLE1BQU0sRUFBRSxNQUFNLENBQUM7SUFFL0IsT0FBTyxDQUFDLFVBQVUsQ0FBWTtJQUM5QixPQUFPLENBQUMsT0FBTyxDQUFnQjtJQUMvQixPQUFPLENBQUMsWUFBWSxDQUFnQjtJQUVwQyxPQUFPLENBQUMsYUFBYSxDQUFZO0lBQ2pDLE9BQU8sQ0FBQyxVQUFVLENBQWdCO0lBRWxDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBWTtJQUNwQyxPQUFPLENBQUMsUUFBUSxDQUFRO0lBQ3hCLE9BQU8sQ0FBQyxpQkFBaUIsQ0FBWTtJQUNyQyxPQUFPLENBQUMsT0FBTyxDQUFZO0lBQzNCLE9BQU8sQ0FBQyxLQUFLLENBQVk7SUFFekIsT0FBTyxDQUFDLHFCQUFxQixDQUFZO0lBRXpDLFlBQVksTUFBTSxFQUFFLGVBQWUsRUFBRSxJQUFJLFNBQW9CLEVBMEQ1RDtJQUVELG1CQUFtQixDQUFDLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRSxVQUFVLEVBQUUsTUFBTSxRQUdsRTtJQUVELFFBQVEsQ0FBQyxVQUFVLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsT0FBTyxFQUFFLEdBQUcsUUFZNUQ7SUFFRCxZQUFZLENBQUMsUUFBUSxFQUFFLEdBQUcsRUFBRSxPQUFPLEVBQUUsTUFBTSxRQWdCMUM7SUFFRCxjQUFjLFNBSWI7SUFFRCxtQkFBbUIsQ0FBQyxTQUFTLEVBQUUsZ0JBQWdCLFFBRTlDO0lBRUQsc0JBQXNCLENBQUMsR0FBRyxNQUFNLEVBQUUsMkJBQTJCLEVBQUUsUUFTOUQ7SUFFRCxvQkFBb0IsQ0FBQyxVQUFVLEVBQUUsTUFBTSxRQUV0QztDQUNGIn0=
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"public_processor_metrics.d.ts","sourceRoot":"","sources":["../../../src/public/public_processor/public_processor_metrics.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"public_processor_metrics.d.ts","sourceRoot":"","sources":["../../../src/public/public_processor/public_processor_metrics.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,0CAA0C,CAAC;AAC5F,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,mBAAmB,CAAC;AAC7C,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AACzD,OAAO,EAKL,KAAK,eAAe,EACpB,KAAK,MAAM,EAGZ,MAAM,yBAAyB,CAAC;AAEjC,qBAAa,sBAAsB;IACjC,SAAgB,MAAM,EAAE,MAAM,CAAC;IAE/B,OAAO,CAAC,UAAU,CAAY;IAC9B,OAAO,CAAC,OAAO,CAAgB;IAC/B,OAAO,CAAC,YAAY,CAAgB;IAEpC,OAAO,CAAC,aAAa,CAAY;IACjC,OAAO,CAAC,UAAU,CAAgB;IAElC,OAAO,CAAC,gBAAgB,CAAY;IACpC,OAAO,CAAC,QAAQ,CAAQ;IACxB,OAAO,CAAC,iBAAiB,CAAY;IACrC,OAAO,CAAC,OAAO,CAAY;IAC3B,OAAO,CAAC,KAAK,CAAY;IAEzB,OAAO,CAAC,qBAAqB,CAAY;IAEzC,YAAY,MAAM,EAAE,eAAe,EAAE,IAAI,SAAoB,EA0D5D;IAED,mBAAmB,CAAC,SAAS,EAAE,gBAAgB,EAAE,UAAU,EAAE,MAAM,QAGlE;IAED,QAAQ,CAAC,UAAU,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,QAY5D;IAED,YAAY,CAAC,QAAQ,EAAE,GAAG,EAAE,OAAO,EAAE,MAAM,QAgB1C;IAED,cAAc,SAIb;IAED,mBAAmB,CAAC,SAAS,EAAE,gBAAgB,QAE9C;IAED,sBAAsB,CAAC,GAAG,MAAM,EAAE,2BAA2B,EAAE,QAS9D;IAED,oBAAoB,CAAC,UAAU,EAAE,MAAM,QAEtC;CACF"}
|
|
@@ -110,7 +110,7 @@ export class PublicProcessorMetrics {
|
|
|
110
110
|
[Attributes.OK]: false
|
|
111
111
|
});
|
|
112
112
|
}
|
|
113
|
-
|
|
113
|
+
recordClassPublication(...events) {
|
|
114
114
|
let totalBytecode = 0;
|
|
115
115
|
for (const event of events){
|
|
116
116
|
totalBytecode += event.packedPublicBytecode.length;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { ContractProvider } from '@aztec/native';
|
|
2
|
+
import type { GlobalVariables } from '@aztec/stdlib/tx';
|
|
3
|
+
import type { PublicContractsDB } from '../public_db_sources.js';
|
|
4
|
+
export declare class ContractProviderForCpp implements ContractProvider {
|
|
5
|
+
private contractsDB;
|
|
6
|
+
private globalVariables;
|
|
7
|
+
private log;
|
|
8
|
+
constructor(contractsDB: PublicContractsDB, globalVariables: GlobalVariables);
|
|
9
|
+
getContractInstance: (address: string) => Promise<Buffer<ArrayBufferLike> | undefined>;
|
|
10
|
+
getContractClass: (classId: string) => Promise<Buffer<ArrayBufferLike> | undefined>;
|
|
11
|
+
addContracts: (contractDeploymentDataBuffer: Buffer<ArrayBufferLike>) => Promise<void>;
|
|
12
|
+
getBytecodeCommitment: (classId: string) => Promise<Buffer<ArrayBufferLike> | undefined>;
|
|
13
|
+
getDebugFunctionName: (address: string, selector: string) => Promise<string | undefined>;
|
|
14
|
+
createCheckpoint: () => Promise<void>;
|
|
15
|
+
commitCheckpoint: () => Promise<void>;
|
|
16
|
+
revertCheckpoint: () => Promise<void>;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udHJhY3RfcHJvdmlkZXJfZm9yX2NwcC5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3B1YmxpYy9wdWJsaWNfdHhfc2ltdWxhdG9yL2NvbnRyYWN0X3Byb3ZpZGVyX2Zvcl9jcHAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxLQUFLLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFLdEQsT0FBTyxLQUFLLEVBQUUsZUFBZSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFeEQsT0FBTyxLQUFLLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUVqRSxxQkFBYSxzQkFBdUIsWUFBVyxnQkFBZ0I7SUFJM0QsT0FBTyxDQUFDLFdBQVc7SUFDbkIsT0FBTyxDQUFDLGVBQWU7SUFKekIsT0FBTyxDQUFDLEdBQUcsQ0FBK0Q7SUFFMUUsWUFDVSxXQUFXLEVBQUUsaUJBQWlCLEVBQzlCLGVBQWUsRUFBRSxlQUFlLEVBQ3RDO0lBRUcsbUJBQW1CLG9FQWF4QjtJQUVLLGdCQUFnQixvRUFlckI7SUFFSyxZQUFZLDJFQVdqQjtJQUVLLHFCQUFxQixvRUFnQjFCO0lBRUssb0JBQW9CLHFFQXNCekI7SUFFSyxnQkFBZ0Isc0JBR3JCO0lBRUssZ0JBQWdCLHNCQUdyQjtJQUVLLGdCQUFnQixzQkFHckI7Q0FDSCJ9
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contract_provider_for_cpp.d.ts","sourceRoot":"","sources":["../../../src/public/public_tx_simulator/contract_provider_for_cpp.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAKtD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAExD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAEjE,qBAAa,sBAAuB,YAAW,gBAAgB;IAI3D,OAAO,CAAC,WAAW;IACnB,OAAO,CAAC,eAAe;IAJzB,OAAO,CAAC,GAAG,CAA+D;IAE1E,YACU,WAAW,EAAE,iBAAiB,EAC9B,eAAe,EAAE,eAAe,EACtC;IAEG,mBAAmB,oEAaxB;IAEK,gBAAgB,oEAerB;IAEK,YAAY,2EAWjB;IAEK,qBAAqB,oEAgB1B;IAEK,oBAAoB,qEAsBzB;IAEK,gBAAgB,sBAGrB;IAEK,gBAAgB,sBAGrB;IAEK,gBAAgB,sBAGrB;CACH"}
|