@aztec/simulator 0.0.0-test.1 → 0.0.1-commit.5daedc8
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 +5 -14
- 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 +18 -19
- package/dest/private/acvm/deserialize.d.ts.map +1 -1
- package/dest/private/acvm/deserialize.js +31 -23
- 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 +20 -3
- package/dest/private/acvm/serialize.d.ts.map +1 -1
- package/dest/private/acvm/serialize.js +53 -0
- 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 +6 -6
- package/dest/public/avm/avm_context.d.ts.map +1 -1
- package/dest/public/avm/avm_contract_call_result.d.ts +5 -3
- 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 +4 -2
- package/dest/public/avm/avm_execution_environment.d.ts.map +1 -1
- package/dest/public/avm/avm_execution_environment.js +4 -2
- 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 +3 -1
- 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 +99 -88
- package/dest/public/avm/avm_memory_types.d.ts.map +1 -1
- package/dest/public/avm/avm_memory_types.js +17 -6
- package/dest/public/avm/avm_simulator.d.ts +6 -6
- package/dest/public/avm/avm_simulator.d.ts.map +1 -1
- package/dest/public/avm/avm_simulator.js +23 -35
- 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 +7 -31
- package/dest/public/avm/errors.d.ts.map +1 -1
- package/dest/public/avm/errors.js +7 -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 +22 -15
- package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts +7 -5
- package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts.map +1 -1
- package/dest/public/avm/fixtures/base_avm_simulation_tester.js +37 -14
- 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 +38 -0
- package/dest/public/avm/fixtures/utils.d.ts.map +1 -0
- package/dest/public/avm/fixtures/utils.js +95 -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 +17 -7
- package/dest/public/avm/opcodes/arithmetic.d.ts.map +1 -1
- package/dest/public/avm/opcodes/arithmetic.js +16 -2
- 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 +6 -6
- 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 +6 -6
- 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 +38 -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 +70 -69
- 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 +11 -14
- package/dest/public/avm/test_utils.d.ts.map +1 -1
- package/dest/public/avm/test_utils.js +16 -24
- 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 +5 -0
- package/dest/public/debug_fn_name.d.ts.map +1 -0
- package/dest/public/debug_fn_name.js +9 -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 +326 -0
- package/dest/public/fixtures/custom_bytecode_tester.d.ts +12 -0
- package/dest/public/fixtures/custom_bytecode_tester.d.ts.map +1 -0
- package/dest/public/fixtures/custom_bytecode_tester.js +29 -0
- package/dest/public/fixtures/custom_bytecode_tests.d.ts +9 -0
- package/dest/public/fixtures/custom_bytecode_tests.d.ts.map +1 -0
- package/dest/public/fixtures/custom_bytecode_tests.js +109 -0
- package/dest/public/fixtures/index.d.ts +8 -1
- package/dest/public/fixtures/index.d.ts.map +1 -1
- package/dest/public/fixtures/index.js +7 -0
- package/dest/public/fixtures/minimal_public_tx.d.ts +9 -0
- package/dest/public/fixtures/minimal_public_tx.d.ts.map +1 -0
- package/dest/public/fixtures/minimal_public_tx.js +29 -0
- package/dest/public/fixtures/public_tx_simulation_tester.d.ts +35 -14
- package/dest/public/fixtures/public_tx_simulation_tester.d.ts.map +1 -1
- package/dest/public/fixtures/public_tx_simulation_tester.js +100 -71
- package/dest/public/fixtures/simple_contract_data_source.d.ts +35 -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 +8 -0
- package/dest/public/fixtures/token_test.d.ts.map +1 -0
- package/dest/public/fixtures/token_test.js +94 -0
- package/dest/public/fixtures/utils.d.ts +17 -4
- package/dest/public/fixtures/utils.d.ts.map +1 -1
- package/dest/public/fixtures/utils.js +100 -58
- package/dest/public/hinting_db_sources.d.ts +78 -0
- package/dest/public/hinting_db_sources.d.ts.map +1 -0
- package/dest/public/hinting_db_sources.js +350 -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 +51 -101
- package/dest/public/public_db_sources.d.ts.map +1 -1
- package/dest/public/public_db_sources.js +219 -192
- 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 +49 -0
- package/dest/public/public_processor/guarded_merkle_tree.d.ts.map +1 -0
- package/dest/public/public_processor/guarded_merkle_tree.js +108 -0
- package/dest/public/public_processor/public_processor.d.ts +25 -37
- package/dest/public/public_processor/public_processor.d.ts.map +1 -1
- package/dest/public/public_processor/public_processor.js +154 -111
- 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 +30 -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 +133 -0
- package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts +66 -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 +210 -0
- package/dest/public/public_tx_simulator/index.d.ts +5 -0
- package/dest/public/public_tx_simulator/index.d.ts.map +1 -0
- package/dest/public/public_tx_simulator/index.js +2 -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 +23 -30
- package/dest/public/public_tx_simulator/public_tx_context.d.ts.map +1 -1
- package/dest/public/public_tx_simulator/public_tx_context.js +71 -91
- 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 +208 -206
- package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts +9 -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 +21 -67
- package/dest/public/side_effect_trace.d.ts.map +1 -1
- package/dest/public/side_effect_trace.js +71 -121
- package/dest/public/side_effect_trace_interface.d.ts +12 -24
- 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 +3 -6
- 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 +3 -3
- package/dest/public/state_manager/public_storage.d.ts.map +1 -0
- package/dest/public/state_manager/state_manager.d.ts +159 -0
- package/dest/public/state_manager/state_manager.d.ts.map +1 -0
- package/dest/public/state_manager/state_manager.js +392 -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 +79 -44
- 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 +35 -29
- package/src/private/acvm/index.ts +0 -1
- package/src/private/acvm/serialize.ts +63 -0
- 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 +4 -4
- package/src/public/avm/avm_contract_call_result.ts +17 -5
- package/src/public/avm/avm_execution_environment.ts +8 -1
- package/src/public/avm/avm_gas.ts +23 -35
- package/src/public/avm/avm_machine_state.ts +5 -0
- package/src/public/avm/avm_memory_types.ts +19 -6
- package/src/public/avm/avm_simulator.ts +43 -54
- package/src/public/avm/avm_simulator_interface.ts +8 -0
- package/src/public/avm/errors.ts +8 -77
- package/src/public/avm/fixtures/avm_simulation_tester.ts +32 -21
- package/src/public/avm/fixtures/base_avm_simulation_tester.ts +45 -12
- package/src/public/avm/fixtures/initializers.ts +102 -0
- package/src/public/avm/fixtures/utils.ts +150 -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 +24 -2
- 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 +9 -6
- 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 +28 -8
- 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 +55 -0
- package/src/public/avm/serialization/buffer_cursor.ts +4 -1
- package/src/public/avm/serialization/bytecode_serialization.ts +72 -74
- package/src/public/avm/serialization/instruction_serialization.ts +75 -34
- package/src/public/avm/test_utils.ts +24 -41
- package/src/public/contracts_db_checkpoint.ts +41 -0
- package/src/public/db_interfaces.ts +76 -0
- package/src/{common → public}/debug_fn_name.ts +7 -7
- 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 +49 -0
- package/src/public/fixtures/custom_bytecode_tests.ts +135 -0
- package/src/public/fixtures/index.ts +7 -0
- package/src/public/fixtures/minimal_public_tx.ts +35 -0
- package/src/public/fixtures/public_tx_simulation_tester.ts +166 -113
- package/src/public/{avm/fixtures → fixtures}/simple_contract_data_source.ts +36 -18
- package/src/public/fixtures/token_test.ts +139 -0
- package/src/public/fixtures/utils.ts +141 -68
- package/src/public/hinting_db_sources.ts +602 -0
- package/src/public/index.ts +5 -8
- package/src/public/public_db_sources.ts +278 -258
- package/src/public/public_errors.ts +14 -0
- package/src/public/public_processor/guarded_merkle_tree.ts +153 -0
- package/src/public/public_processor/public_processor.ts +212 -164
- package/src/public/public_processor/public_processor_metrics.ts +2 -2
- package/src/public/public_tx_simulator/contract_provider_for_cpp.ts +162 -0
- package/src/public/public_tx_simulator/cpp_public_tx_simulator.ts +306 -0
- package/src/public/public_tx_simulator/index.ts +4 -0
- package/src/public/public_tx_simulator/measured_public_tx_simulator.ts +105 -0
- package/src/public/public_tx_simulator/public_tx_context.ts +167 -194
- package/src/public/public_tx_simulator/public_tx_simulator.ts +292 -265
- package/src/public/public_tx_simulator/public_tx_simulator_interface.ts +10 -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 +94 -320
- package/src/public/side_effect_trace_interface.ts +10 -58
- package/src/public/state_manager/index.ts +1 -0
- package/src/public/{avm/journal → state_manager}/nullifiers.ts +5 -11
- package/src/public/{avm/journal → state_manager}/public_storage.ts +2 -2
- package/src/public/state_manager/state_manager.ts +553 -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/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
- /package/dest/public/{avm/journal → state_manager}/public_storage.js +0 -0
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import type { Fr } from '@aztec/foundation/fields';
|
|
2
2
|
|
|
3
|
-
import type {
|
|
3
|
+
import type { PublicTreesDB } from '../public_db_sources.js';
|
|
4
|
+
import { NullifierCollisionError } from '../side_effect_errors.js';
|
|
4
5
|
|
|
5
6
|
/**
|
|
6
7
|
* A class to manage new nullifier staging and existence checks during a contract call's AVM simulation.
|
|
@@ -10,7 +11,7 @@ import type { WorldStateDB } from '../../public_db_sources.js';
|
|
|
10
11
|
export class NullifierManager {
|
|
11
12
|
constructor(
|
|
12
13
|
/** Reference to node storage. Checked on parent cache-miss. */
|
|
13
|
-
private readonly hostNullifiers:
|
|
14
|
+
private readonly hostNullifiers: PublicTreesDB,
|
|
14
15
|
/** Cache of siloed nullifiers. */
|
|
15
16
|
private cache: Set<bigint> = new Set(),
|
|
16
17
|
/** Parent nullifier manager to fall back on */
|
|
@@ -64,8 +65,8 @@ export class NullifierManager {
|
|
|
64
65
|
// `${MerkleTreeId[MerkleTreeId.NULLIFIER_TREE]} low leaf index should always be found (even if target leaf does not exist)`,
|
|
65
66
|
//);
|
|
66
67
|
//existsInTree = leafOrLowLeafIndex.alreadyPresent;
|
|
67
|
-
const
|
|
68
|
-
existsInTree =
|
|
68
|
+
const exists = await this.hostNullifiers.checkNullifierExists(siloedNullifier);
|
|
69
|
+
existsInTree = exists;
|
|
69
70
|
}
|
|
70
71
|
const exists = cacheHit || existsInTree;
|
|
71
72
|
return Promise.resolve({ exists, cacheHit });
|
|
@@ -100,10 +101,3 @@ export class NullifierManager {
|
|
|
100
101
|
this.cache = new Set([...this.cache, ...incomingNullifiers.cache]);
|
|
101
102
|
}
|
|
102
103
|
}
|
|
103
|
-
|
|
104
|
-
export class NullifierCollisionError extends Error {
|
|
105
|
-
constructor(message: string, ...rest: any[]) {
|
|
106
|
-
super(message, ...rest);
|
|
107
|
-
this.name = 'NullifierCollisionError';
|
|
108
|
-
}
|
|
109
|
-
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Fr } from '@aztec/foundation/fields';
|
|
2
2
|
import type { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
3
3
|
|
|
4
|
-
import type {
|
|
4
|
+
import type { PublicStateDBInterface } from '../db_interfaces.js';
|
|
5
5
|
|
|
6
6
|
type PublicStorageReadResult = {
|
|
7
7
|
value: Fr;
|
|
@@ -19,7 +19,7 @@ export class PublicStorage {
|
|
|
19
19
|
|
|
20
20
|
constructor(
|
|
21
21
|
/** Reference to node storage. Checked on parent cache-miss. */
|
|
22
|
-
private readonly hostPublicStorage:
|
|
22
|
+
private readonly hostPublicStorage: PublicStateDBInterface,
|
|
23
23
|
/** Parent's storage. Checked on this' cache-miss. */
|
|
24
24
|
private readonly parent?: PublicStorage,
|
|
25
25
|
) {
|
|
@@ -0,0 +1,553 @@
|
|
|
1
|
+
import {
|
|
2
|
+
CANONICAL_AUTH_REGISTRY_ADDRESS,
|
|
3
|
+
CONTRACT_CLASS_REGISTRY_CONTRACT_ADDRESS,
|
|
4
|
+
CONTRACT_INSTANCE_REGISTRY_CONTRACT_ADDRESS,
|
|
5
|
+
FEE_JUICE_ADDRESS,
|
|
6
|
+
MULTI_CALL_ENTRYPOINT_ADDRESS,
|
|
7
|
+
ROUTER_ADDRESS,
|
|
8
|
+
} from '@aztec/constants';
|
|
9
|
+
import { poseidon2Hash } from '@aztec/foundation/crypto';
|
|
10
|
+
import { Fr } from '@aztec/foundation/fields';
|
|
11
|
+
import { jsonStringify } from '@aztec/foundation/json-rpc';
|
|
12
|
+
import { type LogLevel, createLogger } from '@aztec/foundation/log';
|
|
13
|
+
import { ProtocolContractAddress } from '@aztec/protocol-contracts';
|
|
14
|
+
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
15
|
+
import type { ContractClassPublicWithCommitment, ContractInstanceWithAddress } from '@aztec/stdlib/contract';
|
|
16
|
+
import { SerializableContractInstance } from '@aztec/stdlib/contract';
|
|
17
|
+
import { DelayedPublicMutableValues, DelayedPublicMutableValuesWithHash } from '@aztec/stdlib/delayed-public-mutable';
|
|
18
|
+
import { computeNoteHashNonce, computeUniqueNoteHash, siloNoteHash, siloNullifier } from '@aztec/stdlib/hash';
|
|
19
|
+
import type { DebugLog } from '@aztec/stdlib/logs';
|
|
20
|
+
import { ScopedL2ToL1Message } from '@aztec/stdlib/messaging';
|
|
21
|
+
import { MerkleTreeId } from '@aztec/stdlib/trees';
|
|
22
|
+
import type { TreeSnapshots } from '@aztec/stdlib/tx';
|
|
23
|
+
import type { UInt64 } from '@aztec/stdlib/types';
|
|
24
|
+
|
|
25
|
+
import { strict as assert } from 'assert';
|
|
26
|
+
|
|
27
|
+
import type { AvmExecutionEnvironment } from '../avm/avm_execution_environment.js';
|
|
28
|
+
import type { PublicContractsDBInterface } from '../db_interfaces.js';
|
|
29
|
+
import { getPublicFunctionDebugName } from '../debug_fn_name.js';
|
|
30
|
+
import type { PublicTreesDB } from '../public_db_sources.js';
|
|
31
|
+
import {
|
|
32
|
+
L1ToL2MessageIndexOutOfRangeError,
|
|
33
|
+
MaxCallsToUniqueContractClassIdsError,
|
|
34
|
+
NoteHashIndexOutOfRangeError,
|
|
35
|
+
NullifierCollisionError,
|
|
36
|
+
} from '../side_effect_errors.js';
|
|
37
|
+
import type { PublicSideEffectTraceInterface } from '../side_effect_trace_interface.js';
|
|
38
|
+
import { NullifierManager } from './nullifiers.js';
|
|
39
|
+
import { PublicStorage } from './public_storage.js';
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* A class to manage persistable AVM state for contract calls.
|
|
43
|
+
* Maintains a cache of the current world state,
|
|
44
|
+
* a trace of all side effects.
|
|
45
|
+
*
|
|
46
|
+
* The simulator should make any world state / tree queries through this object.
|
|
47
|
+
*
|
|
48
|
+
* Manages merging of successful/reverted child state into current state.
|
|
49
|
+
*/
|
|
50
|
+
export class PublicPersistableStateManager {
|
|
51
|
+
private readonly log = createLogger('simulator:state_manager');
|
|
52
|
+
|
|
53
|
+
/** Make sure a forked state is never merged twice. */
|
|
54
|
+
private alreadyMergedIntoParent = false;
|
|
55
|
+
|
|
56
|
+
constructor(
|
|
57
|
+
private readonly treesDB: PublicTreesDB,
|
|
58
|
+
private readonly contractsDB: PublicContractsDBInterface,
|
|
59
|
+
private readonly trace: PublicSideEffectTraceInterface,
|
|
60
|
+
private readonly firstNullifier: Fr, // Needed for note hashes.
|
|
61
|
+
private readonly timestamp: UInt64, // Needed for contract updates.
|
|
62
|
+
private readonly doMerkleOperations: boolean = true,
|
|
63
|
+
private readonly publicStorage: PublicStorage = new PublicStorage(treesDB),
|
|
64
|
+
private readonly nullifiers: NullifierManager = new NullifierManager(treesDB),
|
|
65
|
+
) {}
|
|
66
|
+
|
|
67
|
+
/**
|
|
68
|
+
* Create a new state manager
|
|
69
|
+
*/
|
|
70
|
+
public static create(
|
|
71
|
+
treesDB: PublicTreesDB,
|
|
72
|
+
contractsDB: PublicContractsDBInterface,
|
|
73
|
+
trace: PublicSideEffectTraceInterface,
|
|
74
|
+
firstNullifier: Fr,
|
|
75
|
+
timestamp: UInt64,
|
|
76
|
+
): PublicPersistableStateManager {
|
|
77
|
+
return new PublicPersistableStateManager(treesDB, contractsDB, trace, firstNullifier, timestamp);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
/**
|
|
81
|
+
* Create a new state manager forked from this one
|
|
82
|
+
*/
|
|
83
|
+
public async fork() {
|
|
84
|
+
await this.treesDB.createCheckpoint();
|
|
85
|
+
return new PublicPersistableStateManager(
|
|
86
|
+
this.treesDB,
|
|
87
|
+
this.contractsDB,
|
|
88
|
+
this.trace.fork(),
|
|
89
|
+
this.firstNullifier,
|
|
90
|
+
this.timestamp,
|
|
91
|
+
this.doMerkleOperations,
|
|
92
|
+
this.publicStorage.fork(),
|
|
93
|
+
this.nullifiers.fork(),
|
|
94
|
+
);
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
/**
|
|
98
|
+
* Accept forked world state modifications & traced side effects / hints
|
|
99
|
+
*/
|
|
100
|
+
public async merge(forkedState: PublicPersistableStateManager) {
|
|
101
|
+
await this._merge(forkedState, /*reverted=*/ false);
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
/**
|
|
105
|
+
* Reject forked world state modifications & traced side effects, keep traced hints
|
|
106
|
+
*/
|
|
107
|
+
public async reject(forkedState: PublicPersistableStateManager) {
|
|
108
|
+
await this._merge(forkedState, /*reverted=*/ true);
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
private async _merge(forkedState: PublicPersistableStateManager, reverted: boolean) {
|
|
112
|
+
// sanity check to avoid merging the same forked trace twice
|
|
113
|
+
assert(
|
|
114
|
+
!forkedState.alreadyMergedIntoParent,
|
|
115
|
+
'Cannot merge forked state that has already been merged into its parent!',
|
|
116
|
+
);
|
|
117
|
+
forkedState.alreadyMergedIntoParent = true;
|
|
118
|
+
this.publicStorage.acceptAndMerge(forkedState.publicStorage);
|
|
119
|
+
this.nullifiers.acceptAndMerge(forkedState.nullifiers);
|
|
120
|
+
this.trace.merge(forkedState.trace, reverted);
|
|
121
|
+
if (reverted) {
|
|
122
|
+
this.log.trace('Reverting forked state...');
|
|
123
|
+
await this.treesDB.revertCheckpoint();
|
|
124
|
+
} else {
|
|
125
|
+
this.log.trace('Merging forked state into parent...');
|
|
126
|
+
await this.treesDB.commitCheckpoint();
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
/**
|
|
131
|
+
* Write to public storage, journal/trace the write.
|
|
132
|
+
*
|
|
133
|
+
* @param contractAddress - the address of the contract whose storage is being written to
|
|
134
|
+
* @param slot - the slot in the contract's storage being written to
|
|
135
|
+
* @param value - the value being written to the slot
|
|
136
|
+
*/
|
|
137
|
+
public async writeStorage(contractAddress: AztecAddress, slot: Fr, value: Fr, protocolWrite = false): Promise<void> {
|
|
138
|
+
this.log.trace(`Storage write (address=${contractAddress}, slot=${slot}): value=${value}`);
|
|
139
|
+
|
|
140
|
+
await this.trace.tracePublicStorageWrite(contractAddress, slot, value, protocolWrite);
|
|
141
|
+
|
|
142
|
+
if (this.doMerkleOperations) {
|
|
143
|
+
// write to native merkle trees
|
|
144
|
+
await this.treesDB.storageWrite(contractAddress, slot, value);
|
|
145
|
+
} else {
|
|
146
|
+
// Cache storage writes for later reference/reads
|
|
147
|
+
this.publicStorage.write(contractAddress, slot, value);
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
public isStorageCold(contractAddress: AztecAddress, slot: Fr): boolean {
|
|
152
|
+
return this.trace.isStorageCold(contractAddress, slot);
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
/**
|
|
156
|
+
* Read from public storage.
|
|
157
|
+
*
|
|
158
|
+
* @param contractAddress - the address of the contract whose storage is being read from
|
|
159
|
+
* @param slot - the slot in the contract's storage being read from
|
|
160
|
+
* @returns the latest value written to slot, or 0 if never written to before
|
|
161
|
+
*/
|
|
162
|
+
public async readStorage(contractAddress: AztecAddress, slot: Fr): Promise<Fr> {
|
|
163
|
+
if (this.doMerkleOperations) {
|
|
164
|
+
return await this.treesDB.storageRead(contractAddress, slot);
|
|
165
|
+
} else {
|
|
166
|
+
const read = await this.publicStorage.read(contractAddress, slot);
|
|
167
|
+
this.log.trace(
|
|
168
|
+
`Storage read results (address=${contractAddress}, slot=${slot}): value=${read.value}, cached=${read.cached}`,
|
|
169
|
+
);
|
|
170
|
+
return read.value;
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
// TODO(4886): We currently don't silo note hashes.
|
|
175
|
+
/**
|
|
176
|
+
* Check if a note hash exists at the given leaf index, trace the check.
|
|
177
|
+
*
|
|
178
|
+
* @param contractAddress - the address of the contract whose storage is being read from
|
|
179
|
+
* @param noteHash - the unsiloed note hash being checked
|
|
180
|
+
* @param leafIndex - the leaf index being checked
|
|
181
|
+
* @returns true if the note hash exists at the given leaf index, false otherwise
|
|
182
|
+
*/
|
|
183
|
+
public async checkNoteHashExists(contractAddress: AztecAddress, noteHash: Fr, leafIndex: bigint): Promise<boolean> {
|
|
184
|
+
try {
|
|
185
|
+
const gotLeafValue = await this.treesDB.getNoteHash(leafIndex);
|
|
186
|
+
const exists = gotLeafValue.equals(noteHash);
|
|
187
|
+
this.log.trace(
|
|
188
|
+
`noteHashes(${contractAddress})@${noteHash} ?? leafIndex: ${leafIndex} | gotLeafValue: ${gotLeafValue}, exists: ${exists}.`,
|
|
189
|
+
);
|
|
190
|
+
return Promise.resolve(exists);
|
|
191
|
+
} catch (error) {
|
|
192
|
+
// If the index is out of range, note_hash_leaf_in_range = 0 and the circuit returns false:
|
|
193
|
+
if (error instanceof NoteHashIndexOutOfRangeError) {
|
|
194
|
+
return Promise.resolve(false);
|
|
195
|
+
}
|
|
196
|
+
// Otherwise, unknown error. This is a bug.
|
|
197
|
+
throw error;
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
/**
|
|
202
|
+
* Write a raw note hash, silo it and make it unique, then trace the write.
|
|
203
|
+
* @param noteHash - the unsiloed note hash to write
|
|
204
|
+
*/
|
|
205
|
+
public async writeNoteHash(contractAddress: AztecAddress, noteHash: Fr): Promise<void> {
|
|
206
|
+
this.log.trace(`noteHashes(${contractAddress}) += ${noteHash}.`);
|
|
207
|
+
const siloedNoteHash = await siloNoteHash(contractAddress, noteHash);
|
|
208
|
+
await this.writeSiloedNoteHash(siloedNoteHash);
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
/**
|
|
212
|
+
* Write a note hash, make it unique, trace the write.
|
|
213
|
+
* @param siloedNoteHash - the non unique note hash to write
|
|
214
|
+
*/
|
|
215
|
+
public async writeSiloedNoteHash(siloedNoteHash: Fr): Promise<void> {
|
|
216
|
+
const noteNonce = await computeNoteHashNonce(this.firstNullifier, this.trace.getNoteHashCount());
|
|
217
|
+
const uniqueNoteHash = await computeUniqueNoteHash(noteNonce, siloedNoteHash);
|
|
218
|
+
await this.writeUniqueNoteHash(uniqueNoteHash);
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
/**
|
|
222
|
+
* Write a note hash, trace the write.
|
|
223
|
+
* @param uniqueNoteHash - the siloed unique hash to write
|
|
224
|
+
*/
|
|
225
|
+
public async writeUniqueNoteHash(uniqueNoteHash: Fr): Promise<void> {
|
|
226
|
+
this.log.trace(`noteHashes += @${uniqueNoteHash}.`);
|
|
227
|
+
this.trace.traceNewNoteHash(uniqueNoteHash);
|
|
228
|
+
if (this.doMerkleOperations) {
|
|
229
|
+
await this.treesDB.writeNoteHash(uniqueNoteHash);
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
|
|
233
|
+
/**
|
|
234
|
+
* Check if a nullifier exists, trace the check.
|
|
235
|
+
* @param contractAddress - address of the contract that the nullifier is associated with
|
|
236
|
+
* @param nullifier - the unsiloed nullifier to check
|
|
237
|
+
* @returns exists - whether the nullifier exists in the nullifier set
|
|
238
|
+
*/
|
|
239
|
+
public async checkNullifierExists(contractAddress: AztecAddress, nullifier: Fr): Promise<boolean> {
|
|
240
|
+
this.log.trace(`Checking existence of nullifier (address=${contractAddress}, nullifier=${nullifier})`);
|
|
241
|
+
const siloedNullifier = await siloNullifier(contractAddress, nullifier);
|
|
242
|
+
|
|
243
|
+
if (this.doMerkleOperations) {
|
|
244
|
+
const exists = await this.treesDB.checkNullifierExists(siloedNullifier);
|
|
245
|
+
this.log.trace(`Checked siloed nullifier ${siloedNullifier} (exists=${exists})`);
|
|
246
|
+
return Promise.resolve(exists);
|
|
247
|
+
} else {
|
|
248
|
+
const { exists, cacheHit } = await this.nullifiers.checkExists(siloedNullifier);
|
|
249
|
+
this.log.trace(`Checked siloed nullifier ${siloedNullifier} (exists=${exists}), cacheHit=${cacheHit}`);
|
|
250
|
+
return Promise.resolve(exists);
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
|
|
254
|
+
/**
|
|
255
|
+
* Write a nullifier to the nullifier set, trace the write.
|
|
256
|
+
* @param contractAddress - address of the contract that the nullifier is associated with
|
|
257
|
+
* @param nullifier - the unsiloed nullifier to write
|
|
258
|
+
*/
|
|
259
|
+
public async writeNullifier(contractAddress: AztecAddress, nullifier: Fr) {
|
|
260
|
+
this.log.trace(`Inserting new nullifier (address=${nullifier}, nullifier=${contractAddress})`);
|
|
261
|
+
const siloedNullifier = await siloNullifier(contractAddress, nullifier);
|
|
262
|
+
await this.writeSiloedNullifier(siloedNullifier);
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
/**
|
|
266
|
+
* Write a nullifier to the nullifier set, trace the write.
|
|
267
|
+
* @param siloedNullifier - the siloed nullifier to write
|
|
268
|
+
*/
|
|
269
|
+
public async writeSiloedNullifier(siloedNullifier: Fr) {
|
|
270
|
+
this.log.trace(`Inserting siloed nullifier=${siloedNullifier}`);
|
|
271
|
+
|
|
272
|
+
this.trace.traceNewNullifier(siloedNullifier);
|
|
273
|
+
|
|
274
|
+
if (this.doMerkleOperations) {
|
|
275
|
+
const exists = await this.treesDB.checkNullifierExists(siloedNullifier);
|
|
276
|
+
|
|
277
|
+
if (exists) {
|
|
278
|
+
this.log.verbose(`Siloed nullifier ${siloedNullifier} already present in tree!`);
|
|
279
|
+
throw new NullifierCollisionError(
|
|
280
|
+
`Siloed nullifier ${siloedNullifier} already exists in parent cache or host.`,
|
|
281
|
+
);
|
|
282
|
+
} else {
|
|
283
|
+
await this.treesDB.writeNullifier(siloedNullifier);
|
|
284
|
+
}
|
|
285
|
+
} else {
|
|
286
|
+
// Cache pending nullifiers for later access
|
|
287
|
+
await this.nullifiers.append(siloedNullifier);
|
|
288
|
+
}
|
|
289
|
+
}
|
|
290
|
+
|
|
291
|
+
/**
|
|
292
|
+
* Check if an L1 to L2 message exists, trace the check.
|
|
293
|
+
* @param msgHash - the message hash to check existence of
|
|
294
|
+
* @param msgLeafIndex - the message leaf index to use in the check
|
|
295
|
+
* @returns exists - whether the message exists in the L1 to L2 Messages tree
|
|
296
|
+
*/
|
|
297
|
+
public async checkL1ToL2MessageExists(msgHash: Fr, msgLeafIndex: Fr): Promise<boolean> {
|
|
298
|
+
try {
|
|
299
|
+
const valueAtIndex = await this.treesDB.getL1ToL2LeafValue(msgLeafIndex.toBigInt());
|
|
300
|
+
const exists = valueAtIndex.equals(msgHash);
|
|
301
|
+
this.log.trace(
|
|
302
|
+
`l1ToL2Messages(@${msgLeafIndex}) ?? exists: ${exists}, expected: ${msgHash}, found: ${valueAtIndex}.`,
|
|
303
|
+
);
|
|
304
|
+
return Promise.resolve(exists);
|
|
305
|
+
} catch (error) {
|
|
306
|
+
// If the index is out of range, l1_to_l2_msg_leaf_in_range = 0 and the circuit returns false:
|
|
307
|
+
if (error instanceof L1ToL2MessageIndexOutOfRangeError) {
|
|
308
|
+
return Promise.resolve(false);
|
|
309
|
+
}
|
|
310
|
+
// Otherwise, unknown error. This is a bug.
|
|
311
|
+
throw error;
|
|
312
|
+
}
|
|
313
|
+
}
|
|
314
|
+
|
|
315
|
+
/**
|
|
316
|
+
* Write an L2 to L1 message.
|
|
317
|
+
* @param contractAddress - L2 contract address that created this message
|
|
318
|
+
* @param recipient - L1 contract address to send the message to.
|
|
319
|
+
* @param content - Message content.
|
|
320
|
+
*/
|
|
321
|
+
public writeL2ToL1Message(contractAddress: AztecAddress, recipient: Fr, content: Fr) {
|
|
322
|
+
this.log.trace(`L2ToL1Messages(${contractAddress}) += (recipient: ${recipient}, content: ${content}).`);
|
|
323
|
+
this.trace.traceNewL2ToL1Message(contractAddress, recipient, content);
|
|
324
|
+
}
|
|
325
|
+
|
|
326
|
+
/**
|
|
327
|
+
* Write a scoped L2 to L1 message.
|
|
328
|
+
* @param l2ToL1Message - The L2 to L1 message to write.
|
|
329
|
+
*/
|
|
330
|
+
public writeScopedL2ToL1Message(l2ToL1Message: ScopedL2ToL1Message) {
|
|
331
|
+
this.writeL2ToL1Message(
|
|
332
|
+
l2ToL1Message.contractAddress,
|
|
333
|
+
l2ToL1Message.message.recipient.toField(),
|
|
334
|
+
l2ToL1Message.message.content,
|
|
335
|
+
);
|
|
336
|
+
}
|
|
337
|
+
|
|
338
|
+
public writeDebugLog(contractAddress: AztecAddress, level: LogLevel, message: string, fields: Fr[]) {
|
|
339
|
+
this.trace.traceDebugLog(contractAddress, level, message, fields);
|
|
340
|
+
}
|
|
341
|
+
|
|
342
|
+
public writeDebugLogMemoryReads(memoryReads: number) {
|
|
343
|
+
this.trace.traceDebugLogMemoryReads(memoryReads);
|
|
344
|
+
}
|
|
345
|
+
|
|
346
|
+
public getDebugLogMemoryReads() {
|
|
347
|
+
return this.trace.getDebugLogMemoryReads();
|
|
348
|
+
}
|
|
349
|
+
|
|
350
|
+
public getLogs(): DebugLog[] {
|
|
351
|
+
return this.trace.getDebugLogs();
|
|
352
|
+
}
|
|
353
|
+
|
|
354
|
+
/**
|
|
355
|
+
* Write a public log
|
|
356
|
+
* @param contractAddress - address of the contract that emitted the log
|
|
357
|
+
* @param log - log contents
|
|
358
|
+
*/
|
|
359
|
+
public writePublicLog(contractAddress: AztecAddress, log: Fr[]) {
|
|
360
|
+
this.log.trace(`PublicLog(${contractAddress}) += event with ${log.length} fields.`);
|
|
361
|
+
this.trace.tracePublicLog(contractAddress, log);
|
|
362
|
+
}
|
|
363
|
+
|
|
364
|
+
/**
|
|
365
|
+
* Get a contract instance.
|
|
366
|
+
* @param contractAddress - address of the contract instance to retrieve.
|
|
367
|
+
* @returns the contract instance or undefined if it does not exist.
|
|
368
|
+
*/
|
|
369
|
+
public async getContractInstance(contractAddress: AztecAddress): Promise<SerializableContractInstance | undefined> {
|
|
370
|
+
this.log.trace(`Getting contract instance for address ${contractAddress}`);
|
|
371
|
+
const instanceWithAddress = await this.contractsDB.getContractInstance(contractAddress, this.timestamp);
|
|
372
|
+
const exists = instanceWithAddress !== undefined;
|
|
373
|
+
|
|
374
|
+
const instance = exists ? new SerializableContractInstance(instanceWithAddress) : undefined;
|
|
375
|
+
|
|
376
|
+
if (contractAddressIsCanonical(contractAddress)) {
|
|
377
|
+
this.log.trace(
|
|
378
|
+
`Got canonical contract instance (address=${contractAddress}): instance=${jsonStringify(instance!)}`,
|
|
379
|
+
);
|
|
380
|
+
return instance;
|
|
381
|
+
}
|
|
382
|
+
|
|
383
|
+
// Nullifier check! We do this regardless of whether or not the instance exists,
|
|
384
|
+
// as even for non-existence, we need to generate nullifier check hints.
|
|
385
|
+
|
|
386
|
+
// This will internally decide whether to check the nullifier tree or not depending on doMerkleOperations.
|
|
387
|
+
const nullifierExistsInTree = await this.checkNullifierExists(
|
|
388
|
+
AztecAddress.fromNumber(CONTRACT_INSTANCE_REGISTRY_CONTRACT_ADDRESS),
|
|
389
|
+
contractAddress.toField(),
|
|
390
|
+
);
|
|
391
|
+
assert(
|
|
392
|
+
exists == nullifierExistsInTree,
|
|
393
|
+
`Contract instance for address ${contractAddress} in DB: ${exists} != nullifier tree: ${nullifierExistsInTree}. This is a bug!`,
|
|
394
|
+
);
|
|
395
|
+
|
|
396
|
+
if (!exists) {
|
|
397
|
+
this.log.debug(`Contract instance NOT FOUND (address=${contractAddress})`);
|
|
398
|
+
return undefined;
|
|
399
|
+
}
|
|
400
|
+
|
|
401
|
+
this.log.trace(`Got contract instance (address=${contractAddress}): instance=${jsonStringify(instance!)}`);
|
|
402
|
+
|
|
403
|
+
// All that is left is to check that the contract updatability information is correct.
|
|
404
|
+
// That is, that the current and original contract class ids are correct.
|
|
405
|
+
await this.checkContractUpdateInformation(instanceWithAddress);
|
|
406
|
+
|
|
407
|
+
return instance;
|
|
408
|
+
}
|
|
409
|
+
|
|
410
|
+
private async checkContractUpdateInformation(instance: ContractInstanceWithAddress): Promise<void> {
|
|
411
|
+
// If "merkle operations" are not requested, we trust the DB.
|
|
412
|
+
// Otherwise we check that the contract updatability information is correct.
|
|
413
|
+
// That is, that the current and original contract class ids are correct.
|
|
414
|
+
// All failures are fatal and the simulation is not expected to be provable.
|
|
415
|
+
if (this.doMerkleOperations) {
|
|
416
|
+
// Conceptually, we want to do the following:
|
|
417
|
+
// * Read a DelayedPublicMutable at the contract update slot.
|
|
418
|
+
// * Obtain the expected current class id from the DelayedPublicMutable, at the current block.
|
|
419
|
+
// * if expectedId == 0 then currentClassId should be original contract class id
|
|
420
|
+
// * if expectedId != 0 then currentClassId should be expectedId
|
|
421
|
+
//
|
|
422
|
+
// However, we will also be checking the hash of the delayed public mutable values.
|
|
423
|
+
// This is a bit of a leak of information, since the circuit will use it to prove
|
|
424
|
+
// one public read instead of N of the delayed public mutable values.
|
|
425
|
+
const { delayedPublicMutableSlot, delayedPublicMutableHashSlot } =
|
|
426
|
+
await DelayedPublicMutableValuesWithHash.getContractUpdateSlots(instance.address);
|
|
427
|
+
const readDeployerStorage = async (storageSlot: Fr) =>
|
|
428
|
+
await this.readStorage(ProtocolContractAddress.ContractInstanceRegistry, storageSlot);
|
|
429
|
+
|
|
430
|
+
const hash = await readDeployerStorage(delayedPublicMutableHashSlot);
|
|
431
|
+
// NOTE: The below reads are either not performed (if hash.isZero()) or only performed in unconstrained in c++ simulation.
|
|
432
|
+
// See UpdateCheck::check_current_class_id documentation - this means if we generate hints from the merkle db, they are unused:
|
|
433
|
+
const delayedPublicMutableValues = await DelayedPublicMutableValues.readFromTree(
|
|
434
|
+
delayedPublicMutableSlot,
|
|
435
|
+
readDeployerStorage,
|
|
436
|
+
);
|
|
437
|
+
const preImage = delayedPublicMutableValues.toFields();
|
|
438
|
+
|
|
439
|
+
// 1) update never scheduled: hash == 0 and preimage should be empty (but poseidon2hash(preimage) will not be 0s)
|
|
440
|
+
if (hash.isZero()) {
|
|
441
|
+
assert(
|
|
442
|
+
preImage.every(f => f.isZero()),
|
|
443
|
+
`Found updatability hash 0 but preimage is not empty for contract instance ${instance.address}.`,
|
|
444
|
+
);
|
|
445
|
+
assert(
|
|
446
|
+
instance.currentContractClassId.equals(instance.originalContractClassId),
|
|
447
|
+
`Found updatability hash 0 for contract instance ${instance.address} but original class id ${instance.originalContractClassId} != current class id ${instance.currentContractClassId}.`,
|
|
448
|
+
);
|
|
449
|
+
return;
|
|
450
|
+
}
|
|
451
|
+
|
|
452
|
+
// 2) At this point we know that the hash is not zero and this means that an update has at some point been scheduled.
|
|
453
|
+
const computedHash = await poseidon2Hash(preImage);
|
|
454
|
+
assert(
|
|
455
|
+
hash.equals(computedHash),
|
|
456
|
+
`Delayed public mutable values hash mismatch for contract instance ${instance.address}. Expected: ${hash}, computed: ${computedHash}`,
|
|
457
|
+
);
|
|
458
|
+
|
|
459
|
+
// We now check that, depending on the current block, the current class id is correct.
|
|
460
|
+
const expectedClassIdRaw = delayedPublicMutableValues.svc.getCurrentAt(this.timestamp).at(0)!;
|
|
461
|
+
const expectedClassId = expectedClassIdRaw.isZero() ? instance.originalContractClassId : expectedClassIdRaw;
|
|
462
|
+
assert(
|
|
463
|
+
instance.currentContractClassId.equals(expectedClassId),
|
|
464
|
+
`Current class id mismatch
|
|
465
|
+
for contract instance ${instance.address}. Expected: ${expectedClassId}, current: ${instance.currentContractClassId}`,
|
|
466
|
+
);
|
|
467
|
+
}
|
|
468
|
+
}
|
|
469
|
+
|
|
470
|
+
/**
|
|
471
|
+
* Get a contract class.
|
|
472
|
+
* @param classId - class id to retrieve.
|
|
473
|
+
* @returns the contract class or undefined if it does not exist.
|
|
474
|
+
*/
|
|
475
|
+
private async getContractClass(classId: Fr): Promise<ContractClassPublicWithCommitment | undefined> {
|
|
476
|
+
this.log.trace(`Getting contract class for id ${classId}`);
|
|
477
|
+
const contractClass = await this.contractsDB.getContractClass(classId);
|
|
478
|
+
const exists = contractClass !== undefined;
|
|
479
|
+
let extendedClass: ContractClassPublicWithCommitment | undefined = undefined;
|
|
480
|
+
|
|
481
|
+
// Note: We currently do not generate info to check the nullifier tree, because
|
|
482
|
+
// this is not needed for our use cases.
|
|
483
|
+
if (exists) {
|
|
484
|
+
this.log.trace(`Got contract class (id=${classId})`);
|
|
485
|
+
// Extend class information with public bytecode commitment.
|
|
486
|
+
const bytecodeCommitment = await this.contractsDB.getBytecodeCommitment(classId);
|
|
487
|
+
assert(
|
|
488
|
+
bytecodeCommitment,
|
|
489
|
+
`Bytecode commitment was not found in DB for contract class (${classId}). This should not happen!`,
|
|
490
|
+
);
|
|
491
|
+
extendedClass = {
|
|
492
|
+
...contractClass,
|
|
493
|
+
publicBytecodeCommitment: bytecodeCommitment,
|
|
494
|
+
};
|
|
495
|
+
} else {
|
|
496
|
+
this.log.debug(`Contract class NOT FOUND (id=${classId})`);
|
|
497
|
+
}
|
|
498
|
+
|
|
499
|
+
// TODO(dbanks12): does this need to be moved to before the DB accesses as was done with writeNullifier?
|
|
500
|
+
this.trace.traceGetContractClass(classId, exists);
|
|
501
|
+
return extendedClass;
|
|
502
|
+
}
|
|
503
|
+
|
|
504
|
+
/**
|
|
505
|
+
* Get a contract's bytecode from the contracts DB, also trace the contract class and instance indirectly.
|
|
506
|
+
*/
|
|
507
|
+
public async getBytecode(contractAddress: AztecAddress): Promise<Buffer | undefined> {
|
|
508
|
+
this.log.debug(`Getting bytecode for contract address ${contractAddress}`);
|
|
509
|
+
const contractInstance = await this.getContractInstance(contractAddress);
|
|
510
|
+
|
|
511
|
+
if (!contractInstance) {
|
|
512
|
+
return undefined;
|
|
513
|
+
}
|
|
514
|
+
|
|
515
|
+
try {
|
|
516
|
+
const contractClass = await this.getContractClass(contractInstance.currentContractClassId);
|
|
517
|
+
assert(
|
|
518
|
+
contractClass,
|
|
519
|
+
`Contract class not found in DB, but a contract instance was found with this class ID (${contractInstance.currentContractClassId}). This should not happen!`,
|
|
520
|
+
);
|
|
521
|
+
return contractClass.packedBytecode;
|
|
522
|
+
} catch (error) {
|
|
523
|
+
if (error instanceof MaxCallsToUniqueContractClassIdsError) {
|
|
524
|
+
return undefined;
|
|
525
|
+
}
|
|
526
|
+
// Otherwise, unknown error. This is a bug.
|
|
527
|
+
throw error;
|
|
528
|
+
}
|
|
529
|
+
}
|
|
530
|
+
|
|
531
|
+
public async getPublicFunctionDebugName(avmEnvironment: AvmExecutionEnvironment): Promise<string> {
|
|
532
|
+
return await getPublicFunctionDebugName(this.contractsDB, avmEnvironment.address, avmEnvironment.calldata);
|
|
533
|
+
}
|
|
534
|
+
|
|
535
|
+
public async padTree(treeId: MerkleTreeId, leavesToInsert: number): Promise<void> {
|
|
536
|
+
await this.treesDB.padTree(treeId, leavesToInsert);
|
|
537
|
+
}
|
|
538
|
+
|
|
539
|
+
public async getTreeSnapshots(): Promise<TreeSnapshots> {
|
|
540
|
+
return await this.treesDB.getTreeSnapshots();
|
|
541
|
+
}
|
|
542
|
+
}
|
|
543
|
+
|
|
544
|
+
function contractAddressIsCanonical(contractAddress: AztecAddress): boolean {
|
|
545
|
+
return (
|
|
546
|
+
contractAddress.equals(AztecAddress.fromNumber(CANONICAL_AUTH_REGISTRY_ADDRESS)) ||
|
|
547
|
+
contractAddress.equals(AztecAddress.fromNumber(CONTRACT_INSTANCE_REGISTRY_CONTRACT_ADDRESS)) ||
|
|
548
|
+
contractAddress.equals(AztecAddress.fromNumber(CONTRACT_CLASS_REGISTRY_CONTRACT_ADDRESS)) ||
|
|
549
|
+
contractAddress.equals(AztecAddress.fromNumber(MULTI_CALL_ENTRYPOINT_ADDRESS)) ||
|
|
550
|
+
contractAddress.equals(AztecAddress.fromNumber(FEE_JUICE_ADDRESS)) ||
|
|
551
|
+
contractAddress.equals(AztecAddress.fromNumber(ROUTER_ADDRESS))
|
|
552
|
+
);
|
|
553
|
+
}
|