@aztec/stdlib 0.0.0-test.1 → 0.0.1-commit.0208eb9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dest/abi/abi.d.ts +988 -412
- package/dest/abi/abi.d.ts.map +1 -1
- package/dest/abi/abi.js +79 -45
- package/dest/abi/authorization_selector.d.ts +52 -0
- package/dest/abi/authorization_selector.d.ts.map +1 -0
- package/dest/abi/authorization_selector.js +71 -0
- package/dest/abi/buffer.d.ts +2 -4
- package/dest/abi/buffer.d.ts.map +1 -1
- package/dest/abi/buffer.js +1 -1
- package/dest/abi/contract_artifact.d.ts +18 -5
- package/dest/abi/contract_artifact.d.ts.map +1 -1
- package/dest/abi/contract_artifact.js +79 -56
- package/dest/abi/decoder.d.ts +3 -3
- package/dest/abi/decoder.d.ts.map +1 -1
- package/dest/abi/decoder.js +8 -10
- package/dest/abi/encoder.d.ts +2 -2
- package/dest/abi/encoder.d.ts.map +1 -1
- package/dest/abi/encoder.js +69 -3
- package/dest/abi/event_metadata_definition.d.ts +8 -0
- package/dest/abi/event_metadata_definition.d.ts.map +1 -0
- package/dest/abi/event_selector.d.ts +2 -4
- package/dest/abi/event_selector.d.ts.map +1 -1
- package/dest/abi/event_selector.js +2 -1
- package/dest/abi/function_call.d.ts +9 -4
- package/dest/abi/function_call.d.ts.map +1 -1
- package/dest/abi/function_call.js +6 -2
- package/dest/abi/function_selector.d.ts +3 -4
- package/dest/abi/function_selector.d.ts.map +1 -1
- package/dest/abi/function_selector.js +9 -1
- package/dest/abi/index.d.ts +3 -1
- package/dest/abi/index.d.ts.map +1 -1
- package/dest/abi/index.js +2 -0
- package/dest/abi/mocked_keys.d.ts +1 -1
- package/dest/abi/note_selector.d.ts +2 -4
- package/dest/abi/note_selector.d.ts.map +1 -1
- package/dest/abi/note_selector.js +2 -2
- package/dest/abi/selector.d.ts +2 -5
- package/dest/abi/selector.d.ts.map +1 -1
- package/dest/abi/selector.js +4 -2
- package/dest/abi/utils.d.ts +13 -3
- package/dest/abi/utils.d.ts.map +1 -1
- package/dest/abi/utils.js +14 -0
- package/dest/auth_witness/auth_witness.d.ts +24 -5
- package/dest/auth_witness/auth_witness.d.ts.map +1 -1
- package/dest/auth_witness/auth_witness.js +30 -1
- package/dest/auth_witness/index.d.ts +1 -1
- package/dest/avm/avm.d.ts +11630 -2931
- package/dest/avm/avm.d.ts.map +1 -1
- package/dest/avm/avm.js +947 -132
- package/dest/avm/avm_accumulated_data.d.ts +103 -29
- package/dest/avm/avm_accumulated_data.d.ts.map +1 -1
- package/dest/avm/avm_accumulated_data.js +114 -13
- package/dest/avm/avm_circuit_public_inputs.d.ts +273 -201
- package/dest/avm/avm_circuit_public_inputs.d.ts.map +1 -1
- package/dest/avm/avm_circuit_public_inputs.js +73 -11
- package/dest/avm/avm_proving_request.d.ts +4597 -1115
- package/dest/avm/avm_proving_request.d.ts.map +1 -1
- package/dest/avm/contract_storage_read.d.ts +3 -5
- package/dest/avm/contract_storage_read.d.ts.map +1 -1
- package/dest/avm/contract_storage_read.js +1 -1
- package/dest/avm/contract_storage_update_request.d.ts +3 -5
- package/dest/avm/contract_storage_update_request.d.ts.map +1 -1
- package/dest/avm/contract_storage_update_request.js +1 -1
- package/dest/avm/index.d.ts +2 -2
- package/dest/avm/index.d.ts.map +1 -1
- package/dest/avm/index.js +1 -1
- package/dest/avm/message_pack.d.ts +2 -3
- package/dest/avm/message_pack.d.ts.map +1 -1
- package/dest/avm/message_pack.js +41 -7
- package/dest/avm/public_call_stack_item_compressed.d.ts +3 -5
- package/dest/avm/public_call_stack_item_compressed.d.ts.map +1 -1
- package/dest/avm/public_call_stack_item_compressed.js +1 -1
- package/dest/avm/public_data_read.d.ts +3 -5
- package/dest/avm/public_data_read.d.ts.map +1 -1
- package/dest/avm/public_data_read.js +1 -1
- package/dest/avm/public_data_update_request.d.ts +3 -6
- package/dest/avm/public_data_update_request.d.ts.map +1 -1
- package/dest/avm/public_data_update_request.js +4 -2
- package/dest/avm/public_data_write.d.ts +18 -8
- package/dest/avm/public_data_write.d.ts.map +1 -1
- package/dest/avm/public_data_write.js +32 -2
- package/dest/avm/public_inner_call_request.d.ts +3 -6
- package/dest/avm/public_inner_call_request.d.ts.map +1 -1
- package/dest/avm/public_inner_call_request.js +4 -2
- package/dest/avm/revert_code.d.ts +14 -8
- package/dest/avm/revert_code.d.ts.map +1 -1
- package/dest/avm/revert_code.js +28 -10
- package/dest/aztec-address/index.d.ts +13 -6
- package/dest/aztec-address/index.d.ts.map +1 -1
- package/dest/aztec-address/index.js +29 -4
- package/dest/block/attestation_info.d.ts +32 -0
- package/dest/block/attestation_info.d.ts.map +1 -0
- package/dest/block/attestation_info.js +42 -0
- package/dest/block/block_hash.d.ts +19 -13
- package/dest/block/block_hash.d.ts.map +1 -1
- package/dest/block/block_hash.js +26 -13
- package/dest/block/block_parameter.d.ts +6 -0
- package/dest/block/block_parameter.d.ts.map +1 -0
- package/dest/block/block_parameter.js +8 -0
- package/dest/block/body.d.ts +10 -9
- package/dest/block/body.d.ts.map +1 -1
- package/dest/block/body.js +18 -32
- package/dest/block/checkpointed_l2_block.d.ts +150 -0
- package/dest/block/checkpointed_l2_block.d.ts.map +1 -0
- package/dest/block/checkpointed_l2_block.js +46 -0
- package/dest/block/in_block.d.ts +36 -24
- package/dest/block/in_block.d.ts.map +1 -1
- package/dest/block/in_block.js +21 -12
- package/dest/block/index.d.ts +8 -4
- package/dest/block/index.d.ts.map +1 -1
- package/dest/block/index.js +7 -3
- package/dest/block/l2_block.d.ts +56 -47
- package/dest/block/l2_block.d.ts.map +1 -1
- package/dest/block/l2_block.js +92 -77
- package/dest/block/l2_block_info.d.ts +46 -0
- package/dest/block/l2_block_info.d.ts.map +1 -0
- package/dest/block/l2_block_info.js +41 -0
- package/dest/block/l2_block_source.d.ts +424 -134
- package/dest/block/l2_block_source.d.ts.map +1 -1
- package/dest/block/l2_block_source.js +39 -15
- package/dest/block/l2_block_stream/index.d.ts +5 -0
- package/dest/block/l2_block_stream/index.d.ts.map +1 -0
- package/dest/block/l2_block_stream/index.js +4 -0
- package/dest/block/l2_block_stream/interfaces.d.ts +36 -0
- package/dest/block/l2_block_stream/interfaces.d.ts.map +1 -0
- package/dest/block/l2_block_stream/interfaces.js +1 -0
- package/dest/block/l2_block_stream/l2_block_stream.d.ts +40 -0
- package/dest/block/l2_block_stream/l2_block_stream.d.ts.map +1 -0
- package/dest/block/l2_block_stream/l2_block_stream.js +272 -0
- package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts +27 -0
- package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts.map +1 -0
- package/dest/block/l2_block_stream/l2_tips_memory_store.js +66 -0
- package/dest/block/l2_block_stream/l2_tips_store_base.d.ts +49 -0
- package/dest/block/l2_block_stream/l2_tips_store_base.d.ts.map +1 -0
- package/dest/block/l2_block_stream/l2_tips_store_base.js +179 -0
- package/dest/block/proposal/attestations_and_signers.d.ts +59 -0
- package/dest/block/proposal/attestations_and_signers.d.ts.map +1 -0
- package/dest/block/proposal/attestations_and_signers.js +113 -0
- package/dest/block/proposal/committee_attestation.d.ts +36 -0
- package/dest/block/proposal/committee_attestation.d.ts.map +1 -0
- package/dest/block/proposal/committee_attestation.js +101 -0
- package/dest/block/proposal/index.d.ts +3 -0
- package/dest/block/proposal/index.d.ts.map +1 -0
- package/dest/block/proposal/index.js +2 -0
- package/dest/block/test/index.d.ts +2 -0
- package/dest/block/test/index.d.ts.map +1 -0
- package/dest/block/test/index.js +1 -0
- package/dest/block/test/l2_tips_store_test_suite.d.ts +3 -0
- package/dest/block/test/l2_tips_store_test_suite.d.ts.map +1 -0
- package/dest/block/test/l2_tips_store_test_suite.js +545 -0
- package/dest/block/validate_block_result.d.ts +50 -0
- package/dest/block/validate_block_result.d.ts.map +1 -0
- package/dest/block/validate_block_result.js +85 -0
- package/dest/checkpoint/checkpoint.d.ts +163 -0
- package/dest/checkpoint/checkpoint.d.ts.map +1 -0
- package/dest/checkpoint/checkpoint.js +113 -0
- package/dest/checkpoint/checkpoint_info.d.ts +38 -0
- package/dest/checkpoint/checkpoint_info.d.ts.map +1 -0
- package/dest/checkpoint/checkpoint_info.js +34 -0
- package/dest/checkpoint/index.d.ts +4 -0
- package/dest/checkpoint/index.d.ts.map +1 -0
- package/dest/checkpoint/index.js +3 -0
- package/dest/checkpoint/published_checkpoint.d.ts +240 -0
- package/dest/checkpoint/published_checkpoint.d.ts.map +1 -0
- package/dest/checkpoint/published_checkpoint.js +82 -0
- package/dest/config/chain-config.d.ts +19 -0
- package/dest/config/chain-config.d.ts.map +1 -0
- package/dest/config/{config.js → chain-config.js} +4 -5
- package/dest/config/index.d.ts +3 -2
- package/dest/config/index.d.ts.map +1 -1
- package/dest/config/index.js +2 -1
- package/dest/config/node-rpc-config.d.ts +13 -0
- package/dest/config/node-rpc-config.d.ts.map +1 -0
- package/dest/config/node-rpc-config.js +24 -0
- package/dest/contract/artifact_hash.d.ts +8 -10
- package/dest/contract/artifact_hash.d.ts.map +1 -1
- package/dest/contract/artifact_hash.js +13 -12
- package/dest/contract/complete_address.d.ts +2 -4
- package/dest/contract/complete_address.d.ts.map +1 -1
- package/dest/contract/complete_address.js +1 -1
- package/dest/contract/contract_address.d.ts +3 -3
- package/dest/contract/contract_address.d.ts.map +1 -1
- package/dest/contract/contract_address.js +4 -4
- package/dest/contract/contract_class.d.ts +2 -2
- package/dest/contract/contract_class.d.ts.map +1 -1
- package/dest/contract/contract_class.js +4 -20
- package/dest/contract/contract_class_id.d.ts +3 -5
- package/dest/contract/contract_class_id.d.ts.map +1 -1
- package/dest/contract/contract_class_id.js +9 -7
- package/dest/contract/contract_deployment_data.d.ts +119 -0
- package/dest/contract/contract_deployment_data.d.ts.map +1 -0
- package/dest/contract/contract_deployment_data.js +99 -0
- package/dest/contract/contract_function_dao.d.ts +1 -1
- package/dest/contract/contract_instance.d.ts +15 -16
- package/dest/contract/contract_instance.d.ts.map +1 -1
- package/dest/contract/contract_instance.js +8 -8
- package/dest/contract/contract_instance_update.d.ts +5 -6
- package/dest/contract/contract_instance_update.d.ts.map +1 -1
- package/dest/contract/contract_instance_update.js +7 -7
- package/dest/contract/deployment_info.d.ts +2 -2
- package/dest/contract/deployment_info.d.ts.map +1 -1
- package/dest/contract/index.d.ts +3 -2
- package/dest/contract/index.d.ts.map +1 -1
- package/dest/contract/index.js +2 -1
- package/dest/contract/interfaces/contract_class.d.ts +81 -297
- package/dest/contract/interfaces/contract_class.d.ts.map +1 -1
- package/dest/contract/interfaces/contract_class.js +36 -24
- package/dest/contract/interfaces/contract_data_source.d.ts +14 -21
- package/dest/contract/interfaces/contract_data_source.d.ts.map +1 -1
- package/dest/contract/interfaces/contract_instance.d.ts +50 -41
- package/dest/contract/interfaces/contract_instance.d.ts.map +1 -1
- package/dest/contract/interfaces/contract_instance.js +30 -5
- package/dest/contract/interfaces/contract_instance_update.d.ts +16 -16
- package/dest/contract/interfaces/contract_instance_update.d.ts.map +1 -1
- package/dest/contract/interfaces/contract_instance_update.js +6 -6
- package/dest/contract/interfaces/index.d.ts +1 -1
- package/dest/contract/interfaces/node-info.d.ts +3 -3
- package/dest/contract/interfaces/node-info.d.ts.map +1 -1
- package/dest/contract/interfaces/node-info.js +1 -1
- package/dest/contract/interfaces/protocol_contract_addresses.d.ts +10 -10
- package/dest/contract/interfaces/protocol_contract_addresses.d.ts.map +1 -1
- package/dest/contract/interfaces/protocol_contract_addresses.js +4 -4
- package/dest/contract/partial_address.d.ts +2 -2
- package/dest/contract/partial_address.d.ts.map +1 -1
- package/dest/contract/private_function.d.ts +2 -4
- package/dest/contract/private_function.d.ts.map +1 -1
- package/dest/contract/private_function.js +4 -4
- package/dest/contract/private_function_membership_proof.d.ts +5 -5
- package/dest/contract/private_function_membership_proof.js +11 -11
- package/dest/contract/utility_function_membership_proof.d.ts +27 -0
- package/dest/contract/utility_function_membership_proof.d.ts.map +1 -0
- package/dest/contract/{unconstrained_function_membership_proof.js → utility_function_membership_proof.js} +14 -14
- package/dest/database-version/database_version.d.ts +58 -0
- package/dest/database-version/database_version.d.ts.map +1 -0
- package/dest/database-version/database_version.js +69 -0
- package/dest/database-version/version_manager.d.ts +20 -49
- package/dest/database-version/version_manager.d.ts.map +1 -1
- package/dest/database-version/version_manager.js +33 -75
- package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts +20 -0
- package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts.map +1 -0
- package/dest/{shared_mutable/shared_mutable_values.js → delayed_public_mutable/delayed_public_mutable_values.js} +20 -23
- package/dest/delayed_public_mutable/delayed_public_mutable_values_with_hash.d.ts +15 -0
- package/dest/delayed_public_mutable/delayed_public_mutable_values_with_hash.d.ts.map +1 -0
- package/dest/delayed_public_mutable/delayed_public_mutable_values_with_hash.js +30 -0
- package/dest/delayed_public_mutable/index.d.ts +5 -0
- package/dest/delayed_public_mutable/index.d.ts.map +1 -0
- package/dest/delayed_public_mutable/index.js +4 -0
- package/dest/delayed_public_mutable/scheduled_delay_change.d.ts +10 -0
- package/dest/delayed_public_mutable/scheduled_delay_change.d.ts.map +1 -0
- package/dest/{shared_mutable → delayed_public_mutable}/scheduled_delay_change.js +5 -5
- package/dest/delayed_public_mutable/scheduled_value_change.d.ts +12 -0
- package/dest/delayed_public_mutable/scheduled_value_change.d.ts.map +1 -0
- package/dest/{shared_mutable → delayed_public_mutable}/scheduled_value_change.js +8 -8
- package/dest/deserialization/index.d.ts +11 -0
- package/dest/deserialization/index.d.ts.map +1 -0
- package/dest/deserialization/index.js +10 -0
- package/dest/epoch-helpers/index.d.ts +31 -6
- package/dest/epoch-helpers/index.d.ts.map +1 -1
- package/dest/epoch-helpers/index.js +46 -11
- package/dest/errors/index.d.ts +1 -1
- package/dest/errors/proving_error.d.ts +1 -1
- package/dest/errors/proving_error.d.ts.map +1 -1
- package/dest/errors/simulation_error.d.ts +2 -2
- package/dest/errors/simulation_error.d.ts.map +1 -1
- package/dest/errors/simulation_error.js +2 -2
- package/dest/fees/index.d.ts +1 -1
- package/dest/fees/transaction_fee.d.ts +7 -2
- package/dest/fees/transaction_fee.d.ts.map +1 -1
- package/dest/fees/transaction_fee.js +15 -5
- package/dest/file-store/factory.d.ts +7 -0
- package/dest/file-store/factory.d.ts.map +1 -0
- package/dest/file-store/factory.js +64 -0
- package/dest/file-store/gcs.d.ts +20 -0
- package/dest/file-store/gcs.d.ts.map +1 -0
- package/dest/file-store/gcs.js +115 -0
- package/dest/file-store/http.d.ts +14 -0
- package/dest/file-store/http.d.ts.map +1 -0
- package/dest/file-store/http.js +74 -0
- package/dest/file-store/index.d.ts +3 -0
- package/dest/file-store/index.d.ts.map +1 -0
- package/dest/file-store/index.js +2 -0
- package/dest/file-store/interface.d.ts +28 -0
- package/dest/file-store/interface.d.ts.map +1 -0
- package/dest/file-store/interface.js +1 -0
- package/dest/file-store/local.d.ts +14 -0
- package/dest/file-store/local.d.ts.map +1 -0
- package/dest/file-store/local.js +40 -0
- package/dest/file-store/s3.d.ts +26 -0
- package/dest/file-store/s3.d.ts.map +1 -0
- package/dest/file-store/s3.js +248 -0
- package/dest/gas/gas.d.ts +12 -6
- package/dest/gas/gas.d.ts.map +1 -1
- package/dest/gas/gas.js +20 -3
- package/dest/gas/gas_fees.d.ts +26 -20
- package/dest/gas/gas_fees.d.ts.map +1 -1
- package/dest/gas/gas_fees.js +32 -19
- package/dest/gas/gas_settings.d.ts +35 -29
- package/dest/gas/gas_settings.d.ts.map +1 -1
- package/dest/gas/gas_settings.js +19 -7
- package/dest/gas/gas_used.d.ts +13 -2
- package/dest/gas/gas_used.d.ts.map +1 -1
- package/dest/gas/gas_used.js +19 -1
- package/dest/gas/index.d.ts +1 -1
- package/dest/hash/hash.d.ts +30 -10
- package/dest/hash/hash.d.ts.map +1 -1
- package/dest/hash/hash.js +39 -28
- package/dest/hash/index.d.ts +1 -1
- package/dest/hash/map_slot.d.ts +2 -2
- package/dest/hash/map_slot.d.ts.map +1 -1
- package/dest/hash/map_slot.js +4 -3
- package/dest/interfaces/allowed_element.d.ts +52 -0
- package/dest/interfaces/allowed_element.d.ts.map +1 -0
- package/dest/interfaces/allowed_element.js +18 -0
- package/dest/interfaces/api_limit.d.ts +6 -0
- package/dest/interfaces/api_limit.d.ts.map +1 -0
- package/dest/interfaces/api_limit.js +5 -0
- package/dest/interfaces/archiver.d.ts +55 -3
- package/dest/interfaces/archiver.d.ts.map +1 -1
- package/dest/interfaces/archiver.js +59 -25
- package/dest/interfaces/aztec-node-admin.d.ts +357 -0
- package/dest/interfaces/aztec-node-admin.d.ts.map +1 -0
- package/dest/interfaces/aztec-node-admin.js +39 -0
- package/dest/interfaces/aztec-node.d.ts +153 -143
- package/dest/interfaces/aztec-node.d.ts.map +1 -1
- package/dest/interfaces/aztec-node.js +54 -44
- package/dest/interfaces/block-builder.d.ts +53 -7
- package/dest/interfaces/block-builder.d.ts.map +1 -1
- package/dest/interfaces/block-builder.js +16 -1
- package/dest/interfaces/client.d.ts +3 -2
- package/dest/interfaces/client.d.ts.map +1 -1
- package/dest/interfaces/client.js +2 -1
- package/dest/interfaces/configs.d.ts +124 -60
- package/dest/interfaces/configs.d.ts.map +1 -1
- package/dest/interfaces/configs.js +24 -23
- package/dest/interfaces/epoch-prover.d.ts +36 -17
- package/dest/interfaces/epoch-prover.d.ts.map +1 -1
- package/dest/interfaces/get_logs_response.d.ts +23 -6
- package/dest/interfaces/get_logs_response.d.ts.map +1 -1
- package/dest/interfaces/get_logs_response.js +5 -4
- package/dest/interfaces/l2_logs_source.d.ts +21 -14
- package/dest/interfaces/l2_logs_source.d.ts.map +1 -1
- package/dest/interfaces/merkle_tree_operations.d.ts +31 -14
- package/dest/interfaces/merkle_tree_operations.d.ts.map +1 -1
- package/dest/interfaces/p2p-bootstrap.d.ts +1 -1
- package/dest/interfaces/p2p.d.ts +19 -8
- package/dest/interfaces/p2p.d.ts.map +1 -1
- package/dest/interfaces/p2p.js +6 -3
- package/dest/interfaces/private_kernel_prover.d.ts +6 -7
- package/dest/interfaces/private_kernel_prover.d.ts.map +1 -1
- package/dest/interfaces/processed-tx-handler.d.ts +1 -1
- package/dest/interfaces/prover-agent.d.ts +32 -7
- package/dest/interfaces/prover-agent.d.ts.map +1 -1
- package/dest/interfaces/prover-agent.js +15 -6
- package/dest/interfaces/prover-broker.d.ts +16 -1
- package/dest/interfaces/prover-broker.d.ts.map +1 -1
- package/dest/interfaces/prover-broker.js +4 -1
- package/dest/interfaces/prover-client.d.ts +26 -10
- package/dest/interfaces/prover-client.d.ts.map +1 -1
- package/dest/interfaces/prover-client.js +24 -10
- package/dest/interfaces/prover-coordination.d.ts +5 -10
- package/dest/interfaces/prover-coordination.d.ts.map +1 -1
- package/dest/interfaces/prover-coordination.js +1 -7
- package/dest/interfaces/prover-node.d.ts +6 -3
- package/dest/interfaces/prover-node.d.ts.map +1 -1
- package/dest/interfaces/prover-node.js +8 -3
- package/dest/interfaces/proving-job-source.d.ts +1 -1
- package/dest/interfaces/proving-job.d.ts +4875 -1278
- package/dest/interfaces/proving-job.d.ts.map +1 -1
- package/dest/interfaces/proving-job.js +139 -113
- package/dest/interfaces/public_state_source.d.ts +8 -0
- package/dest/interfaces/public_state_source.d.ts.map +1 -0
- package/dest/interfaces/public_state_source.js +1 -0
- package/dest/interfaces/server.d.ts +12 -6
- package/dest/interfaces/server.d.ts.map +1 -1
- package/dest/interfaces/server.js +11 -5
- package/dest/interfaces/server_circuit_prover.d.ts +48 -36
- package/dest/interfaces/server_circuit_prover.d.ts.map +1 -1
- package/dest/interfaces/service.d.ts +4 -3
- package/dest/interfaces/service.d.ts.map +1 -1
- package/dest/interfaces/slasher.d.ts +86 -0
- package/dest/interfaces/slasher.d.ts.map +1 -0
- package/dest/interfaces/slasher.js +23 -0
- package/dest/interfaces/tx_provider.d.ts +24 -0
- package/dest/interfaces/tx_provider.d.ts.map +1 -0
- package/dest/interfaces/tx_provider.js +1 -0
- package/dest/interfaces/validator.d.ts +292 -0
- package/dest/interfaces/validator.d.ts.map +1 -0
- package/dest/interfaces/validator.js +21 -0
- package/dest/interfaces/world_state.d.ts +38 -44
- package/dest/interfaces/world_state.d.ts.map +1 -1
- package/dest/interfaces/world_state.js +4 -3
- package/dest/kernel/claimed_length_array.d.ts +34 -0
- package/dest/kernel/claimed_length_array.d.ts.map +1 -0
- package/dest/kernel/claimed_length_array.js +60 -0
- package/dest/kernel/hiding_kernel_private_inputs.d.ts +19 -0
- package/dest/kernel/hiding_kernel_private_inputs.d.ts.map +1 -0
- package/dest/kernel/hiding_kernel_private_inputs.js +34 -0
- package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts +10 -9
- package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts.map +1 -1
- package/dest/kernel/hints/build_note_hash_read_request_hints.js +34 -27
- package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts +12 -14
- package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts.map +1 -1
- package/dest/kernel/hints/build_nullifier_read_request_hints.js +30 -37
- package/dest/kernel/hints/build_transient_data_hints.d.ts +5 -4
- package/dest/kernel/hints/build_transient_data_hints.d.ts.map +1 -1
- package/dest/kernel/hints/build_transient_data_hints.js +10 -11
- package/dest/kernel/hints/find_private_kernel_reset_dimensions.d.ts +1 -1
- package/dest/kernel/hints/find_private_kernel_reset_dimensions.d.ts.map +1 -1
- package/dest/kernel/hints/find_private_kernel_reset_dimensions.js +2 -4
- package/dest/kernel/hints/index.d.ts +2 -3
- package/dest/kernel/hints/index.d.ts.map +1 -1
- package/dest/kernel/hints/index.js +1 -2
- package/dest/kernel/hints/key_validation_hint.d.ts +5 -11
- package/dest/kernel/hints/key_validation_hint.d.ts.map +1 -1
- package/dest/kernel/hints/key_validation_hint.js +6 -8
- package/dest/kernel/hints/key_validation_request.d.ts +5 -6
- package/dest/kernel/hints/key_validation_request.d.ts.map +1 -1
- package/dest/kernel/hints/key_validation_request.js +2 -1
- package/dest/kernel/hints/key_validation_request_and_generator.d.ts +3 -5
- package/dest/kernel/hints/key_validation_request_and_generator.d.ts.map +1 -1
- package/dest/kernel/hints/key_validation_request_and_generator.js +1 -1
- package/dest/kernel/hints/note_hash_read_request_hints.d.ts +2 -4
- package/dest/kernel/hints/note_hash_read_request_hints.d.ts.map +1 -1
- package/dest/kernel/hints/note_hash_read_request_hints.js +5 -5
- package/dest/kernel/hints/nullifier_read_request_hints.d.ts +5 -6
- package/dest/kernel/hints/nullifier_read_request_hints.d.ts.map +1 -1
- package/dest/kernel/hints/nullifier_read_request_hints.js +4 -4
- package/dest/kernel/hints/private_kernel_reset_hints.d.ts +10 -22
- package/dest/kernel/hints/private_kernel_reset_hints.d.ts.map +1 -1
- package/dest/kernel/hints/private_kernel_reset_hints.js +13 -14
- package/dest/kernel/hints/read_request.d.ts +2 -4
- package/dest/kernel/hints/read_request.d.ts.map +1 -1
- package/dest/kernel/hints/read_request.js +1 -1
- package/dest/kernel/hints/read_request_hints.d.ts +30 -32
- package/dest/kernel/hints/read_request_hints.d.ts.map +1 -1
- package/dest/kernel/hints/read_request_hints.js +28 -28
- package/dest/kernel/hints/scoped_key_validation_request_and_generator.d.ts +3 -5
- package/dest/kernel/hints/scoped_key_validation_request_and_generator.d.ts.map +1 -1
- package/dest/kernel/hints/scoped_value_cache.d.ts +2 -2
- package/dest/kernel/hints/scoped_value_cache.d.ts.map +1 -1
- package/dest/kernel/hints/transient_data_squashing_hint.d.ts +17 -0
- package/dest/kernel/hints/transient_data_squashing_hint.d.ts.map +1 -0
- package/dest/kernel/hints/{transient_data_index_hint.js → transient_data_squashing_hint.js} +9 -7
- package/dest/kernel/hints/tree_leaf_read_request.d.ts +2 -4
- package/dest/kernel/hints/tree_leaf_read_request.d.ts.map +1 -1
- package/dest/kernel/hints/tree_leaf_read_request.js +1 -1
- package/dest/kernel/index.d.ts +5 -3
- package/dest/kernel/index.d.ts.map +1 -1
- package/dest/kernel/index.js +4 -2
- package/dest/kernel/log_hash.d.ts +29 -11
- package/dest/kernel/log_hash.d.ts.map +1 -1
- package/dest/kernel/log_hash.js +76 -15
- package/dest/kernel/note_hash.d.ts +2 -4
- package/dest/kernel/note_hash.d.ts.map +1 -1
- package/dest/kernel/note_hash.js +1 -1
- package/dest/kernel/nullifier.d.ts +4 -6
- package/dest/kernel/nullifier.d.ts.map +1 -1
- package/dest/kernel/nullifier.js +12 -12
- package/dest/kernel/padded_side_effects.d.ts +26 -0
- package/dest/kernel/padded_side_effects.d.ts.map +1 -0
- package/dest/kernel/padded_side_effects.js +51 -0
- package/dest/kernel/private_accumulated_data.d.ts +20 -21
- package/dest/kernel/private_accumulated_data.d.ts.map +1 -1
- package/dest/kernel/private_accumulated_data.js +5 -5
- package/dest/kernel/private_call_data.d.ts +10 -32
- package/dest/kernel/private_call_data.d.ts.map +1 -1
- package/dest/kernel/private_call_data.js +7 -19
- package/dest/kernel/private_call_request.d.ts +3 -5
- package/dest/kernel/private_call_request.d.ts.map +1 -1
- package/dest/kernel/private_call_request.js +2 -2
- package/dest/kernel/private_circuit_public_inputs.d.ts +98 -83
- package/dest/kernel/private_circuit_public_inputs.d.ts.map +1 -1
- package/dest/kernel/private_circuit_public_inputs.js +90 -60
- package/dest/kernel/private_context_inputs.d.ts +4 -4
- package/dest/kernel/private_context_inputs.d.ts.map +1 -1
- package/dest/kernel/private_context_inputs.js +4 -4
- package/dest/kernel/private_kernel_circuit_public_inputs.d.ts +25 -10
- package/dest/kernel/private_kernel_circuit_public_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_circuit_public_inputs.js +15 -7
- package/dest/kernel/private_kernel_data.d.ts +8 -29
- package/dest/kernel/private_kernel_data.d.ts.map +1 -1
- package/dest/kernel/private_kernel_data.js +8 -21
- package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts +17 -10
- package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_init_circuit_private_inputs.js +13 -8
- package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts +2 -4
- package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_prover_output.d.ts +79 -0
- package/dest/kernel/private_kernel_prover_output.d.ts.map +1 -0
- package/dest/kernel/private_kernel_prover_output.js +28 -0
- package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts +10 -9
- package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_reset_circuit_private_inputs.js +10 -6
- package/dest/kernel/private_kernel_reset_dimensions.d.ts +12 -14
- package/dest/kernel/private_kernel_reset_dimensions.d.ts.map +1 -1
- package/dest/kernel/private_kernel_reset_dimensions.js +29 -29
- package/dest/kernel/private_kernel_simulated_output.d.ts +7 -13
- package/dest/kernel/private_kernel_simulated_output.d.ts.map +1 -1
- package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts +21 -5
- package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_tail_circuit_private_inputs.js +14 -6
- package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts +22 -14
- package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_tail_circuit_public_inputs.js +29 -22
- package/dest/kernel/private_log_data.d.ts +3 -6
- package/dest/kernel/private_log_data.d.ts.map +1 -1
- package/dest/kernel/private_log_data.js +9 -4
- package/dest/kernel/private_to_avm_accumulated_data.d.ts +24 -17
- package/dest/kernel/private_to_avm_accumulated_data.d.ts.map +1 -1
- package/dest/kernel/private_to_avm_accumulated_data.js +35 -3
- package/dest/kernel/private_to_public_accumulated_data.d.ts +4 -7
- package/dest/kernel/private_to_public_accumulated_data.d.ts.map +1 -1
- package/dest/kernel/private_to_public_accumulated_data.js +4 -2
- package/dest/kernel/private_to_public_accumulated_data_builder.d.ts +2 -2
- package/dest/kernel/private_to_public_accumulated_data_builder.d.ts.map +1 -1
- package/dest/kernel/private_to_public_accumulated_data_builder.js +1 -1
- package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts +9 -9
- package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts.map +1 -1
- package/dest/kernel/private_to_public_kernel_circuit_public_inputs.js +17 -11
- package/dest/kernel/private_to_rollup_accumulated_data.d.ts +5 -8
- package/dest/kernel/private_to_rollup_accumulated_data.d.ts.map +1 -1
- package/dest/kernel/private_to_rollup_accumulated_data.js +4 -2
- package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts +15 -17
- package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts.map +1 -1
- package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.js +12 -13
- package/dest/kernel/private_validation_requests.d.ts +10 -38
- package/dest/kernel/private_validation_requests.d.ts.map +1 -1
- package/dest/kernel/private_validation_requests.js +13 -31
- package/dest/kernel/public_call_request.d.ts +93 -31
- package/dest/kernel/public_call_request.d.ts.map +1 -1
- package/dest/kernel/public_call_request.js +100 -22
- package/dest/kernel/utils/index.d.ts +1 -1
- package/dest/kernel/utils/interfaces.d.ts +1 -1
- package/dest/kernel/utils/optional_number.d.ts +3 -5
- package/dest/kernel/utils/optional_number.d.ts.map +1 -1
- package/dest/kernel/utils/order_and_comparison.d.ts +1 -4
- package/dest/kernel/utils/order_and_comparison.d.ts.map +1 -1
- package/dest/kernel/utils/order_and_comparison.js +0 -19
- package/dest/keys/derivation.d.ts +7 -8
- package/dest/keys/derivation.d.ts.map +1 -1
- package/dest/keys/derivation.js +15 -25
- package/dest/keys/index.d.ts +1 -1
- package/dest/keys/key_types.d.ts +2 -2
- package/dest/keys/public_key.d.ts +2 -2
- package/dest/keys/public_key.d.ts.map +1 -1
- package/dest/keys/public_keys.d.ts +11 -4
- package/dest/keys/public_keys.d.ts.map +1 -1
- package/dest/keys/public_keys.js +15 -3
- package/dest/keys/utils.d.ts +1 -1
- package/dest/keys/utils.d.ts.map +1 -1
- package/dest/keys/utils.js +7 -3
- package/dest/l1-contracts/index.d.ts +2 -0
- package/dest/l1-contracts/index.d.ts.map +1 -0
- package/dest/l1-contracts/index.js +1 -0
- package/dest/l1-contracts/slash_factory.d.ts +45 -0
- package/dest/l1-contracts/slash_factory.d.ts.map +1 -0
- package/dest/l1-contracts/slash_factory.js +158 -0
- package/dest/logs/contract_class_log.d.ts +72 -18
- package/dest/logs/contract_class_log.d.ts.map +1 -1
- package/dest/logs/contract_class_log.js +139 -82
- package/dest/logs/debug_log.d.ts +21 -0
- package/dest/logs/debug_log.d.ts.map +1 -0
- package/dest/logs/debug_log.js +39 -0
- package/dest/logs/directional_app_tagging_secret.d.ts +40 -0
- package/dest/logs/directional_app_tagging_secret.d.ts.map +1 -0
- package/dest/logs/directional_app_tagging_secret.js +64 -0
- package/dest/logs/extended_contract_class_log.d.ts +1 -3
- package/dest/logs/extended_contract_class_log.d.ts.map +1 -1
- package/dest/logs/extended_public_log.d.ts +11 -5
- package/dest/logs/extended_public_log.d.ts.map +1 -1
- package/dest/logs/index.d.ts +9 -4
- package/dest/logs/index.d.ts.map +1 -1
- package/dest/logs/index.js +8 -3
- package/dest/logs/log_filter.d.ts +1 -1
- package/dest/logs/log_id.d.ts +17 -7
- package/dest/logs/log_id.d.ts.map +1 -1
- package/dest/logs/log_id.js +20 -11
- package/dest/logs/message_context.d.ts +29 -0
- package/dest/logs/message_context.d.ts.map +1 -0
- package/dest/logs/message_context.js +56 -0
- package/dest/logs/pending_tagged_log.d.ts +14 -0
- package/dest/logs/pending_tagged_log.d.ts.map +1 -0
- package/dest/logs/pending_tagged_log.js +34 -0
- package/dest/logs/pre_tag.d.ts +34 -0
- package/dest/logs/pre_tag.d.ts.map +1 -0
- package/dest/logs/pre_tag.js +7 -0
- package/dest/logs/private_log.d.ts +26 -10
- package/dest/logs/private_log.d.ts.map +1 -1
- package/dest/logs/private_log.js +65 -25
- package/dest/logs/public_log.d.ts +37 -14
- package/dest/logs/public_log.d.ts.map +1 -1
- package/dest/logs/public_log.js +144 -36
- package/dest/logs/shared_secret_derivation.d.ts +17 -0
- package/dest/logs/shared_secret_derivation.d.ts.map +1 -0
- package/dest/logs/{l1_payload/shared_secret_derivation.js → shared_secret_derivation.js} +6 -10
- package/dest/logs/siloed_tag.d.ts +23 -0
- package/dest/logs/siloed_tag.d.ts.map +1 -0
- package/dest/logs/siloed_tag.js +31 -0
- package/dest/logs/tag.d.ts +21 -0
- package/dest/logs/tag.d.ts.map +1 -0
- package/dest/logs/tag.js +30 -0
- package/dest/logs/tx_scoped_l2_log.d.ts +34 -45
- package/dest/logs/tx_scoped_l2_log.d.ts.map +1 -1
- package/dest/logs/tx_scoped_l2_log.js +38 -26
- package/dest/messaging/in_hash.d.ts +6 -0
- package/dest/messaging/in_hash.d.ts.map +1 -0
- package/dest/messaging/in_hash.js +10 -0
- package/dest/messaging/inbox_leaf.d.ts +11 -5
- package/dest/messaging/inbox_leaf.d.ts.map +1 -1
- package/dest/messaging/inbox_leaf.js +19 -4
- package/dest/messaging/index.d.ts +4 -1
- package/dest/messaging/index.d.ts.map +1 -1
- package/dest/messaging/index.js +3 -0
- package/dest/messaging/l1_actor.d.ts +2 -4
- package/dest/messaging/l1_actor.d.ts.map +1 -1
- package/dest/messaging/l1_actor.js +2 -2
- package/dest/messaging/l1_to_l2_message.d.ts +2 -4
- package/dest/messaging/l1_to_l2_message.d.ts.map +1 -1
- package/dest/messaging/l1_to_l2_message.js +2 -2
- package/dest/messaging/l1_to_l2_message_source.d.ts +9 -8
- package/dest/messaging/l1_to_l2_message_source.d.ts.map +1 -1
- package/dest/messaging/l2_actor.d.ts +2 -4
- package/dest/messaging/l2_actor.d.ts.map +1 -1
- package/dest/messaging/l2_actor.js +2 -2
- package/dest/messaging/l2_to_l1_membership.d.ts +97 -0
- package/dest/messaging/l2_to_l1_membership.d.ts.map +1 -0
- package/dest/messaging/l2_to_l1_membership.js +181 -0
- package/dest/messaging/l2_to_l1_message.d.ts +128 -19
- package/dest/messaging/l2_to_l1_message.d.ts.map +1 -1
- package/dest/messaging/l2_to_l1_message.js +102 -35
- package/dest/messaging/out_hash.d.ts +43 -0
- package/dest/messaging/out_hash.d.ts.map +1 -0
- package/dest/messaging/out_hash.js +63 -0
- package/dest/noir/index.d.ts +25 -8
- package/dest/noir/index.d.ts.map +1 -1
- package/dest/noir/index.js +6 -5
- package/dest/note/comparator.d.ts +1 -1
- package/dest/note/index.d.ts +2 -2
- package/dest/note/index.d.ts.map +1 -1
- package/dest/note/index.js +1 -1
- package/dest/note/note.d.ts +39 -21
- package/dest/note/note.d.ts.map +1 -1
- package/dest/note/note.js +55 -5
- package/dest/note/note_dao.d.ts +110 -0
- package/dest/note/note_dao.d.ts.map +1 -0
- package/dest/note/note_dao.js +115 -0
- package/dest/note/note_status.d.ts +1 -1
- package/dest/note/notes_filter.d.ts +9 -9
- package/dest/note/notes_filter.d.ts.map +1 -1
- package/dest/note/notes_filter.js +2 -4
- package/dest/p2p/attestation_utils.d.ts +10 -0
- package/dest/p2p/attestation_utils.d.ts.map +1 -0
- package/dest/p2p/attestation_utils.js +21 -0
- package/dest/p2p/block_proposal.d.ts +117 -25
- package/dest/p2p/block_proposal.d.ts.map +1 -1
- package/dest/p2p/block_proposal.js +160 -31
- package/dest/p2p/checkpoint_attestation.d.ts +81 -0
- package/dest/p2p/checkpoint_attestation.d.ts.map +1 -0
- package/dest/p2p/checkpoint_attestation.js +104 -0
- package/dest/p2p/checkpoint_proposal.d.ts +167 -0
- package/dest/p2p/checkpoint_proposal.d.ts.map +1 -0
- package/dest/p2p/checkpoint_proposal.js +229 -0
- package/dest/p2p/client_type.d.ts +1 -1
- package/dest/p2p/consensus_payload.d.ts +42 -24
- package/dest/p2p/consensus_payload.d.ts.map +1 -1
- package/dest/p2p/consensus_payload.js +43 -30
- package/dest/p2p/constants.d.ts +3 -0
- package/dest/p2p/constants.d.ts.map +1 -0
- package/dest/p2p/constants.js +2 -0
- package/dest/p2p/gossipable.d.ts +21 -18
- package/dest/p2p/gossipable.d.ts.map +1 -1
- package/dest/p2p/gossipable.js +52 -4
- package/dest/p2p/index.d.ts +6 -2
- package/dest/p2p/index.d.ts.map +1 -1
- package/dest/p2p/index.js +5 -1
- package/dest/p2p/interface.d.ts +1 -14
- package/dest/p2p/interface.d.ts.map +1 -1
- package/dest/p2p/interface.js +1 -19
- package/dest/p2p/message_validator.d.ts +18 -3
- package/dest/p2p/message_validator.d.ts.map +1 -1
- package/dest/p2p/message_validator.js +2 -1
- package/dest/p2p/peer_error.d.ts +1 -1
- package/dest/p2p/signature_utils.d.ts +8 -7
- package/dest/p2p/signature_utils.d.ts.map +1 -1
- package/dest/p2p/signature_utils.js +10 -6
- package/dest/p2p/signed_txs.d.ts +42 -0
- package/dest/p2p/signed_txs.d.ts.map +1 -0
- package/dest/p2p/signed_txs.js +75 -0
- package/dest/p2p/topic_type.d.ts +9 -11
- package/dest/p2p/topic_type.d.ts.map +1 -1
- package/dest/p2p/topic_type.js +44 -17
- package/dest/parity/index.d.ts +3 -4
- package/dest/parity/index.d.ts.map +1 -1
- package/dest/parity/index.js +2 -3
- package/dest/parity/parity_base_private_inputs.d.ts +35 -0
- package/dest/parity/parity_base_private_inputs.d.ts.map +1 -0
- package/dest/parity/{base_parity_inputs.js → parity_base_private_inputs.js} +11 -7
- package/dest/parity/parity_public_inputs.d.ts +4 -6
- package/dest/parity/parity_public_inputs.d.ts.map +1 -1
- package/dest/parity/parity_public_inputs.js +1 -1
- package/dest/parity/parity_root_private_inputs.d.ts +39 -0
- package/dest/parity/parity_root_private_inputs.d.ts.map +1 -0
- package/dest/parity/{root_parity_inputs.js → parity_root_private_inputs.js} +12 -13
- package/dest/proofs/chonk_proof.d.ts +28 -0
- package/dest/proofs/chonk_proof.d.ts.map +1 -0
- package/dest/proofs/chonk_proof.js +106 -0
- package/dest/proofs/index.d.ts +3 -2
- package/dest/proofs/index.d.ts.map +1 -1
- package/dest/proofs/index.js +2 -1
- package/dest/proofs/proof.d.ts +7 -8
- package/dest/proofs/proof.d.ts.map +1 -1
- package/dest/proofs/proof.js +29 -21
- package/dest/proofs/proof_data.d.ts +33 -0
- package/dest/proofs/proof_data.d.ts.map +1 -0
- package/dest/proofs/proof_data.js +39 -0
- package/dest/proofs/proving_request_type.d.ts +18 -13
- package/dest/proofs/proving_request_type.d.ts.map +1 -1
- package/dest/proofs/proving_request_type.js +17 -11
- package/dest/proofs/recursive_proof.d.ts +5 -22
- package/dest/proofs/recursive_proof.d.ts.map +1 -1
- package/dest/proofs/recursive_proof.js +1 -1
- package/dest/rollup/avm_proof_data.d.ts +4 -16
- package/dest/rollup/avm_proof_data.d.ts.map +1 -1
- package/dest/rollup/avm_proof_data.js +1 -25
- package/dest/rollup/base_rollup_hints.d.ts +36 -37
- package/dest/rollup/base_rollup_hints.d.ts.map +1 -1
- package/dest/rollup/base_rollup_hints.js +41 -40
- package/dest/rollup/block_constant_data.d.ts +51 -0
- package/dest/rollup/block_constant_data.d.ts.map +1 -0
- package/dest/rollup/block_constant_data.js +50 -0
- package/dest/rollup/block_headers_hash.d.ts +4 -0
- package/dest/rollup/block_headers_hash.d.ts.map +1 -0
- package/dest/rollup/block_headers_hash.js +9 -0
- package/dest/rollup/block_merge_rollup_private_inputs.d.ts +50 -0
- package/dest/rollup/block_merge_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/{block_merge_rollup.js → block_merge_rollup_private_inputs.js} +14 -13
- package/dest/rollup/block_rollup_public_inputs.d.ts +128 -0
- package/dest/rollup/block_rollup_public_inputs.d.ts.map +1 -0
- package/dest/rollup/block_rollup_public_inputs.js +87 -0
- package/dest/rollup/block_root_rollup_private_inputs.d.ts +225 -0
- package/dest/rollup/block_root_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/block_root_rollup_private_inputs.js +249 -0
- package/dest/rollup/checkpoint_constant_data.d.ts +77 -0
- package/dest/rollup/checkpoint_constant_data.d.ts.map +1 -0
- package/dest/rollup/checkpoint_constant_data.js +82 -0
- package/dest/rollup/checkpoint_header.d.ts +119 -0
- package/dest/rollup/checkpoint_header.d.ts.map +1 -0
- package/dest/rollup/checkpoint_header.js +214 -0
- package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts +30 -0
- package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/checkpoint_merge_rollup_private_inputs.js +37 -0
- package/dest/rollup/checkpoint_rollup_public_inputs.d.ts +122 -0
- package/dest/rollup/checkpoint_rollup_public_inputs.d.ts.map +1 -0
- package/dest/rollup/checkpoint_rollup_public_inputs.js +116 -0
- package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts +141 -0
- package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/checkpoint_root_rollup_private_inputs.js +190 -0
- package/dest/rollup/epoch_constant_data.d.ts +56 -0
- package/dest/rollup/epoch_constant_data.d.ts.map +1 -0
- package/dest/rollup/epoch_constant_data.js +53 -0
- package/dest/rollup/index.d.ts +21 -17
- package/dest/rollup/index.d.ts.map +1 -1
- package/dest/rollup/index.js +20 -16
- package/dest/rollup/private_tx_base_rollup_private_inputs.d.ts +21 -0
- package/dest/rollup/private_tx_base_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/private_tx_base_rollup_private_inputs.js +42 -0
- package/dest/rollup/public_chonk_verifier_private_inputs.d.ts +21 -0
- package/dest/rollup/public_chonk_verifier_private_inputs.d.ts.map +1 -0
- package/dest/rollup/public_chonk_verifier_private_inputs.js +43 -0
- package/dest/rollup/public_chonk_verifier_public_inputs.d.ts +20 -0
- package/dest/rollup/public_chonk_verifier_public_inputs.d.ts.map +1 -0
- package/dest/rollup/public_chonk_verifier_public_inputs.js +42 -0
- package/dest/rollup/public_tx_base_rollup_private_inputs.d.ts +23 -0
- package/dest/rollup/public_tx_base_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/public_tx_base_rollup_private_inputs.js +46 -0
- package/dest/rollup/root_rollup_private_inputs.d.ts +67 -0
- package/dest/rollup/root_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/root_rollup_private_inputs.js +69 -0
- package/dest/rollup/root_rollup_public_inputs.d.ts +59 -0
- package/dest/rollup/root_rollup_public_inputs.d.ts.map +1 -0
- package/dest/rollup/root_rollup_public_inputs.js +77 -0
- package/dest/rollup/tree_snapshot_diff_hints.d.ts +87 -0
- package/dest/rollup/tree_snapshot_diff_hints.d.ts.map +1 -0
- package/dest/rollup/tree_snapshot_diff_hints.js +75 -0
- package/dest/rollup/tx_merge_rollup_private_inputs.d.ts +44 -0
- package/dest/rollup/tx_merge_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/{merge_rollup.js → tx_merge_rollup_private_inputs.js} +14 -13
- package/dest/rollup/tx_rollup_public_inputs.d.ts +115 -0
- package/dest/rollup/tx_rollup_public_inputs.d.ts.map +1 -0
- package/dest/rollup/{base_or_merge_rollup_public_inputs.js → tx_rollup_public_inputs.js} +17 -22
- package/dest/schemas/index.d.ts +1 -1
- package/dest/schemas/schemas.d.ts +93 -19
- package/dest/schemas/schemas.d.ts.map +1 -1
- package/dest/schemas/schemas.js +15 -2
- package/dest/slashing/empire.d.ts +31 -0
- package/dest/slashing/empire.d.ts.map +1 -0
- package/dest/slashing/empire.js +85 -0
- package/dest/slashing/helpers.d.ts +36 -0
- package/dest/slashing/helpers.d.ts.map +1 -0
- package/dest/slashing/helpers.js +91 -0
- package/dest/slashing/index.d.ts +7 -0
- package/dest/slashing/index.d.ts.map +1 -0
- package/dest/slashing/index.js +6 -0
- package/dest/slashing/interfaces.d.ts +12 -0
- package/dest/slashing/interfaces.d.ts.map +1 -0
- package/dest/slashing/interfaces.js +1 -0
- package/dest/slashing/serialization.d.ts +8 -0
- package/dest/slashing/serialization.d.ts.map +1 -0
- package/dest/slashing/serialization.js +78 -0
- package/dest/slashing/tally.d.ts +23 -0
- package/dest/slashing/tally.d.ts.map +1 -0
- package/dest/slashing/tally.js +60 -0
- package/dest/slashing/types.d.ts +161 -0
- package/dest/slashing/types.d.ts.map +1 -0
- package/dest/slashing/types.js +88 -0
- package/dest/snapshots/download.d.ts +9 -0
- package/dest/snapshots/download.d.ts.map +1 -0
- package/dest/snapshots/download.js +93 -0
- package/dest/snapshots/index.d.ts +4 -0
- package/dest/snapshots/index.d.ts.map +1 -0
- package/dest/snapshots/index.js +3 -0
- package/dest/snapshots/types.d.ts +120 -0
- package/dest/snapshots/types.d.ts.map +1 -0
- package/dest/snapshots/types.js +35 -0
- package/dest/snapshots/upload.d.ts +8 -0
- package/dest/snapshots/upload.d.ts.map +1 -0
- package/dest/snapshots/upload.js +42 -0
- package/dest/stats/index.d.ts +1 -1
- package/dest/stats/stats.d.ts +19 -17
- package/dest/stats/stats.d.ts.map +1 -1
- package/dest/tests/factories.d.ts +143 -131
- package/dest/tests/factories.d.ts.map +1 -1
- package/dest/tests/factories.js +451 -376
- package/dest/tests/fixtures.d.ts +1 -1
- package/dest/tests/index.d.ts +1 -1
- package/dest/tests/jest.d.ts +1 -1
- package/dest/tests/jest.js +1 -1
- package/dest/tests/mocks.d.ts +142 -23
- package/dest/tests/mocks.d.ts.map +1 -1
- package/dest/tests/mocks.js +352 -93
- package/dest/trees/append_only_tree_snapshot.d.ts +14 -8
- package/dest/trees/append_only_tree_snapshot.d.ts.map +1 -1
- package/dest/trees/append_only_tree_snapshot.js +21 -4
- package/dest/trees/database_public_state_source.d.ts +11 -0
- package/dest/trees/database_public_state_source.d.ts.map +1 -0
- package/dest/trees/database_public_state_source.js +18 -0
- package/dest/trees/index.d.ts +2 -2
- package/dest/trees/index.d.ts.map +1 -1
- package/dest/trees/index.js +1 -1
- package/dest/trees/merkle_tree_id.d.ts +17 -9
- package/dest/trees/merkle_tree_id.d.ts.map +1 -1
- package/dest/trees/merkle_tree_id.js +10 -0
- package/dest/trees/nullifier_leaf.d.ts +67 -19
- package/dest/trees/nullifier_leaf.d.ts.map +1 -1
- package/dest/trees/nullifier_leaf.js +70 -23
- package/dest/trees/nullifier_membership_witness.d.ts +40 -45
- package/dest/trees/nullifier_membership_witness.d.ts.map +1 -1
- package/dest/trees/nullifier_membership_witness.js +15 -2
- package/dest/trees/public_data_leaf.d.ts +80 -32
- package/dest/trees/public_data_leaf.d.ts.map +1 -1
- package/dest/trees/public_data_leaf.js +66 -31
- package/dest/trees/public_data_witness.d.ts +47 -54
- package/dest/trees/public_data_witness.d.ts.map +1 -1
- package/dest/trees/public_data_witness.js +21 -5
- package/dest/tx/block_header.d.ts +32 -28
- package/dest/tx/block_header.d.ts.map +1 -1
- package/dest/tx/block_header.js +47 -24
- package/dest/tx/call_context.d.ts +8 -11
- package/dest/tx/call_context.d.ts.map +1 -1
- package/dest/tx/call_context.js +3 -1
- package/dest/tx/capsule.d.ts +5 -5
- package/dest/tx/capsule.d.ts.map +1 -1
- package/dest/tx/capsule.js +3 -1
- package/dest/tx/execution_payload.d.ts +45 -0
- package/dest/tx/execution_payload.d.ts.map +1 -0
- package/dest/tx/execution_payload.js +40 -0
- package/dest/tx/function_data.d.ts +4 -6
- package/dest/tx/function_data.d.ts.map +1 -1
- package/dest/tx/function_data.js +1 -1
- package/dest/tx/global_variable_builder.d.ts +8 -5
- package/dest/tx/global_variable_builder.d.ts.map +1 -1
- package/dest/tx/global_variables.d.ts +76 -44
- package/dest/tx/global_variables.d.ts.map +1 -1
- package/dest/tx/global_variables.js +72 -22
- package/dest/tx/hashed_values.d.ts +19 -9
- package/dest/tx/hashed_values.d.ts.map +1 -1
- package/dest/tx/hashed_values.js +27 -10
- package/dest/tx/in_tx.d.ts +26 -0
- package/dest/tx/in_tx.d.ts.map +1 -0
- package/dest/tx/in_tx.js +14 -0
- package/dest/tx/index.d.ts +11 -4
- package/dest/tx/index.d.ts.map +1 -1
- package/dest/tx/index.js +10 -3
- package/dest/tx/indexed_tx_effect.d.ts +31 -0
- package/dest/tx/indexed_tx_effect.d.ts.map +1 -0
- package/dest/tx/indexed_tx_effect.js +36 -0
- package/dest/tx/offchain_effect.d.ts +14 -0
- package/dest/tx/offchain_effect.d.ts.map +1 -0
- package/dest/tx/offchain_effect.js +4 -0
- package/dest/tx/partial_state_reference.d.ts +12 -5
- package/dest/tx/partial_state_reference.d.ts.map +1 -1
- package/dest/tx/partial_state_reference.js +22 -2
- package/dest/tx/private_execution_result.d.ts +71 -69
- package/dest/tx/private_execution_result.d.ts.map +1 -1
- package/dest/tx/private_execution_result.js +74 -100
- package/dest/tx/private_tx_constant_data.d.ts +60 -0
- package/dest/tx/private_tx_constant_data.d.ts.map +1 -0
- package/dest/tx/private_tx_constant_data.js +69 -0
- package/dest/tx/processed_tx.d.ts +10 -11
- package/dest/tx/processed_tx.d.ts.map +1 -1
- package/dest/tx/processed_tx.js +28 -25
- package/dest/tx/profiling.d.ts +483 -0
- package/dest/tx/profiling.d.ts.map +1 -0
- package/dest/tx/profiling.js +167 -0
- package/dest/tx/protocol_contracts.d.ts +37 -0
- package/dest/tx/protocol_contracts.d.ts.map +1 -0
- package/dest/tx/protocol_contracts.js +58 -0
- package/dest/tx/proven_tx.d.ts +129 -0
- package/dest/tx/proven_tx.d.ts.map +1 -0
- package/dest/tx/proven_tx.js +45 -0
- package/dest/tx/public_call_request_with_calldata.d.ts +46 -0
- package/dest/tx/public_call_request_with_calldata.d.ts.map +1 -0
- package/dest/tx/public_call_request_with_calldata.js +71 -0
- package/dest/tx/public_simulation_output.d.ts +7 -5
- package/dest/tx/public_simulation_output.d.ts.map +1 -1
- package/dest/tx/public_simulation_output.js +16 -9
- package/dest/tx/simulated_tx.d.ts +1194 -46
- package/dest/tx/simulated_tx.d.ts.map +1 -1
- package/dest/tx/simulated_tx.js +52 -47
- package/dest/tx/state_reference.d.ts +18 -12
- package/dest/tx/state_reference.d.ts.map +1 -1
- package/dest/tx/state_reference.js +41 -6
- package/dest/tx/tree_snapshots.d.ts +15 -10
- package/dest/tx/tree_snapshots.d.ts.map +1 -1
- package/dest/tx/tree_snapshots.js +15 -4
- package/dest/tx/tx.d.ts +80 -90
- package/dest/tx/tx.d.ts.map +1 -1
- package/dest/tx/tx.js +165 -152
- package/dest/tx/tx_constant_data.d.ts +9 -43
- package/dest/tx/tx_constant_data.d.ts.map +1 -1
- package/dest/tx/tx_constant_data.js +12 -21
- package/dest/tx/tx_context.d.ts +35 -37
- package/dest/tx/tx_context.d.ts.map +1 -1
- package/dest/tx/tx_context.js +1 -1
- package/dest/tx/tx_effect.d.ts +22 -54
- package/dest/tx/tx_effect.d.ts.map +1 -1
- package/dest/tx/tx_effect.js +85 -275
- package/dest/tx/tx_execution_request.d.ts +15 -8
- package/dest/tx/tx_execution_request.d.ts.map +1 -1
- package/dest/tx/tx_execution_request.js +23 -12
- package/dest/tx/tx_hash.d.ts +13 -6
- package/dest/tx/tx_hash.d.ts.map +1 -1
- package/dest/tx/tx_hash.js +25 -6
- package/dest/tx/tx_receipt.d.ts +45 -45
- package/dest/tx/tx_receipt.d.ts.map +1 -1
- package/dest/tx/tx_receipt.js +50 -28
- package/dest/tx/tx_request.d.ts +13 -11
- package/dest/tx/tx_request.d.ts.map +1 -1
- package/dest/tx/tx_request.js +13 -10
- package/dest/tx/validator/empty_validator.d.ts +1 -1
- package/dest/tx/validator/empty_validator.d.ts.map +1 -1
- package/dest/tx/validator/error_texts.d.ts +25 -0
- package/dest/tx/validator/error_texts.d.ts.map +1 -0
- package/dest/tx/validator/error_texts.js +33 -0
- package/dest/tx/validator/tx_validator.d.ts +3 -4
- package/dest/tx/validator/tx_validator.d.ts.map +1 -1
- package/dest/tx/validator/tx_validator.js +7 -4
- package/dest/types/index.d.ts +1 -1
- package/dest/types/shared.d.ts +10 -12
- package/dest/types/shared.d.ts.map +1 -1
- package/dest/types/shared.js +0 -8
- package/dest/update-checker/index.d.ts +2 -0
- package/dest/update-checker/index.d.ts.map +1 -0
- package/dest/update-checker/index.js +1 -0
- package/dest/update-checker/update-checker.d.ts +49 -0
- package/dest/update-checker/update-checker.d.ts.map +1 -0
- package/dest/update-checker/update-checker.js +130 -0
- package/dest/validators/errors.d.ts +33 -0
- package/dest/validators/errors.d.ts.map +1 -0
- package/dest/validators/errors.js +45 -0
- package/dest/validators/index.d.ts +4 -0
- package/dest/validators/index.d.ts.map +1 -0
- package/dest/validators/index.js +2 -0
- package/dest/validators/schemas.d.ts +650 -0
- package/dest/validators/schemas.d.ts.map +1 -0
- package/dest/validators/schemas.js +52 -0
- package/dest/validators/types.d.ts +53 -0
- package/dest/validators/types.d.ts.map +1 -0
- package/dest/validators/types.js +1 -0
- package/dest/versioning/index.d.ts +1 -1
- package/dest/versioning/versioning.d.ts +6 -6
- package/dest/versioning/versioning.d.ts.map +1 -1
- package/dest/versioning/versioning.js +23 -18
- package/dest/vks/index.d.ts +2 -2
- package/dest/vks/index.d.ts.map +1 -1
- package/dest/vks/index.js +1 -1
- package/dest/vks/verification_key.d.ts +19 -14
- package/dest/vks/verification_key.d.ts.map +1 -1
- package/dest/vks/verification_key.js +30 -12
- package/dest/vks/vk_data.d.ts +30 -0
- package/dest/vks/vk_data.d.ts.map +1 -0
- package/dest/vks/{vk_witness_data.js → vk_data.js} +11 -11
- package/dest/world-state/index.d.ts +2 -0
- package/dest/world-state/index.d.ts.map +1 -0
- package/dest/world-state/index.js +1 -0
- package/dest/world-state/world_state_revision.d.ts +54 -0
- package/dest/world-state/world_state_revision.d.ts.map +1 -0
- package/dest/world-state/world_state_revision.js +44 -0
- package/dest/zkpassport/index.d.ts +34 -0
- package/dest/zkpassport/index.d.ts.map +1 -0
- package/dest/zkpassport/index.js +82 -0
- package/package.json +51 -25
- package/src/abi/abi.ts +138 -102
- package/src/abi/authorization_selector.ts +96 -0
- package/src/abi/buffer.ts +1 -1
- package/src/abi/contract_artifact.ts +101 -70
- package/src/abi/decoder.ts +19 -14
- package/src/abi/encoder.ts +89 -4
- package/src/abi/event_metadata_definition.ts +8 -0
- package/src/abi/event_selector.ts +3 -2
- package/src/abi/function_call.ts +6 -2
- package/src/abi/function_selector.ts +11 -2
- package/src/abi/index.ts +2 -0
- package/src/abi/note_selector.ts +2 -2
- package/src/abi/selector.ts +1 -1
- package/src/abi/utils.ts +32 -0
- package/src/auth_witness/auth_witness.ts +30 -1
- package/src/avm/avm.ts +1330 -127
- package/src/avm/avm_accumulated_data.ts +170 -13
- package/src/avm/avm_circuit_public_inputs.ts +121 -4
- package/src/avm/contract_storage_read.ts +1 -1
- package/src/avm/contract_storage_update_request.ts +1 -1
- package/src/avm/index.ts +1 -1
- package/src/avm/message_pack.ts +38 -3
- package/src/avm/public_call_stack_item_compressed.ts +1 -1
- package/src/avm/public_data_read.ts +1 -1
- package/src/avm/public_data_update_request.ts +1 -1
- package/src/avm/public_data_write.ts +37 -2
- package/src/avm/public_inner_call_request.ts +2 -2
- package/src/avm/revert_code.ts +35 -15
- package/src/aztec-address/index.ts +28 -3
- package/src/block/attestation_info.ts +72 -0
- package/src/block/block_hash.ts +31 -16
- package/src/block/block_parameter.ts +10 -0
- package/src/block/body.ts +24 -39
- package/src/block/checkpointed_l2_block.ts +70 -0
- package/src/block/in_block.ts +28 -15
- package/src/block/index.ts +7 -3
- package/src/block/l2_block.ts +131 -112
- package/src/block/l2_block_info.ts +64 -0
- package/src/block/l2_block_source.ts +267 -54
- package/src/block/l2_block_stream/index.ts +4 -0
- package/src/block/l2_block_stream/interfaces.ts +44 -0
- package/src/block/l2_block_stream/l2_block_stream.ts +307 -0
- package/src/block/l2_block_stream/l2_tips_memory_store.ts +84 -0
- package/src/block/l2_block_stream/l2_tips_store_base.ts +226 -0
- package/src/block/proposal/attestations_and_signers.ts +140 -0
- package/src/block/proposal/committee_attestation.ts +120 -0
- package/src/block/proposal/index.ts +2 -0
- package/src/block/test/index.ts +1 -0
- package/src/block/test/l2_tips_store_test_suite.ts +537 -0
- package/src/block/validate_block_result.ts +129 -0
- package/src/checkpoint/checkpoint.ts +158 -0
- package/src/checkpoint/checkpoint_info.ts +52 -0
- package/src/checkpoint/index.ts +3 -0
- package/src/checkpoint/published_checkpoint.ts +106 -0
- package/src/config/{config.ts → chain-config.ts} +8 -7
- package/src/config/index.ts +2 -1
- package/src/config/node-rpc-config.ts +37 -0
- package/src/contract/artifact_hash.ts +16 -14
- package/src/contract/complete_address.ts +1 -1
- package/src/contract/contract_address.ts +4 -4
- package/src/contract/contract_class.ts +9 -26
- package/src/contract/contract_class_id.ts +13 -7
- package/src/contract/contract_deployment_data.ts +125 -0
- package/src/contract/contract_instance.ts +27 -18
- package/src/contract/contract_instance_update.ts +8 -7
- package/src/contract/deployment_info.ts +1 -1
- package/src/contract/index.ts +2 -1
- package/src/contract/interfaces/contract_class.ts +98 -79
- package/src/contract/interfaces/contract_data_source.ts +14 -22
- package/src/contract/interfaces/contract_instance.ts +48 -16
- package/src/contract/interfaces/contract_instance_update.ts +15 -12
- package/src/contract/interfaces/node-info.ts +3 -3
- package/src/contract/interfaces/protocol_contract_addresses.ts +5 -10
- package/src/contract/partial_address.ts +1 -1
- package/src/contract/private_function.ts +7 -5
- package/src/contract/private_function_membership_proof.ts +11 -11
- package/src/contract/{unconstrained_function_membership_proof.ts → utility_function_membership_proof.ts} +19 -19
- package/src/database-version/database_version.ts +87 -0
- package/src/database-version/version_manager.ts +60 -83
- package/src/{shared_mutable/shared_mutable_values.ts → delayed_public_mutable/delayed_public_mutable_values.ts} +29 -27
- package/src/delayed_public_mutable/delayed_public_mutable_values_with_hash.ts +38 -0
- package/src/delayed_public_mutable/index.ts +4 -0
- package/src/delayed_public_mutable/scheduled_delay_change.ts +17 -0
- package/src/{shared_mutable → delayed_public_mutable}/scheduled_value_change.ts +12 -6
- package/src/deserialization/index.ts +21 -0
- package/src/epoch-helpers/index.ts +97 -20
- package/src/errors/proving_error.ts +5 -1
- package/src/errors/simulation_error.ts +3 -3
- package/src/fees/transaction_fee.ts +29 -9
- package/src/file-store/factory.ts +76 -0
- package/src/file-store/gcs.ts +121 -0
- package/src/file-store/http.ts +70 -0
- package/src/file-store/index.ts +2 -0
- package/src/file-store/interface.ts +25 -0
- package/src/file-store/local.ts +46 -0
- package/src/file-store/s3.ts +250 -0
- package/src/gas/gas.ts +24 -3
- package/src/gas/gas_fees.ts +42 -24
- package/src/gas/gas_settings.ts +31 -10
- package/src/gas/gas_used.ts +22 -1
- package/src/hash/hash.ts +51 -32
- package/src/hash/map_slot.ts +4 -3
- package/src/interfaces/allowed_element.ts +23 -0
- package/src/interfaces/api_limit.ts +5 -0
- package/src/interfaces/archiver.ts +104 -37
- package/src/interfaces/aztec-node-admin.ts +103 -0
- package/src/interfaces/aztec-node.ts +285 -240
- package/src/interfaces/block-builder.ts +83 -10
- package/src/interfaces/client.ts +2 -1
- package/src/interfaces/configs.ts +90 -39
- package/src/interfaces/epoch-prover.ts +46 -17
- package/src/interfaces/get_logs_response.ts +13 -9
- package/src/interfaces/l2_logs_source.ts +24 -13
- package/src/interfaces/merkle_tree_operations.ts +37 -11
- package/src/interfaces/p2p.ts +34 -11
- package/src/interfaces/private_kernel_prover.ts +13 -4
- package/src/interfaces/prover-agent.ts +9 -10
- package/src/interfaces/prover-broker.ts +22 -0
- package/src/interfaces/prover-client.ts +50 -20
- package/src/interfaces/prover-coordination.ts +6 -16
- package/src/interfaces/prover-node.ts +10 -2
- package/src/interfaces/proving-job.ts +244 -139
- package/src/interfaces/public_state_source.ts +9 -0
- package/src/interfaces/server.ts +11 -5
- package/src/interfaces/server_circuit_prover.ts +111 -59
- package/src/interfaces/service.ts +4 -2
- package/src/interfaces/slasher.ts +52 -0
- package/src/interfaces/tx_provider.ts +17 -0
- package/src/interfaces/validator.ts +150 -0
- package/src/interfaces/world_state.ts +45 -29
- package/src/kernel/claimed_length_array.ts +104 -0
- package/src/kernel/hiding_kernel_private_inputs.ts +37 -0
- package/src/kernel/hints/build_note_hash_read_request_hints.ts +47 -41
- package/src/kernel/hints/build_nullifier_read_request_hints.ts +49 -76
- package/src/kernel/hints/build_transient_data_hints.ts +14 -16
- package/src/kernel/hints/find_private_kernel_reset_dimensions.ts +5 -7
- package/src/kernel/hints/index.ts +1 -2
- package/src/kernel/hints/key_validation_hint.ts +5 -7
- package/src/kernel/hints/key_validation_request.ts +2 -1
- package/src/kernel/hints/key_validation_request_and_generator.ts +1 -1
- package/src/kernel/hints/note_hash_read_request_hints.ts +9 -18
- package/src/kernel/hints/nullifier_read_request_hints.ts +11 -20
- package/src/kernel/hints/private_kernel_reset_hints.ts +37 -54
- package/src/kernel/hints/read_request.ts +5 -2
- package/src/kernel/hints/read_request_hints.ts +59 -38
- package/src/kernel/hints/scoped_key_validation_request_and_generator.ts +1 -1
- package/src/kernel/hints/scoped_value_cache.ts +1 -1
- package/src/kernel/hints/{transient_data_index_hint.ts → transient_data_squashing_hint.ts} +10 -7
- package/src/kernel/hints/tree_leaf_read_request.ts +5 -2
- package/src/kernel/index.ts +4 -2
- package/src/kernel/log_hash.ts +87 -15
- package/src/kernel/note_hash.ts +9 -3
- package/src/kernel/nullifier.ts +17 -10
- package/src/kernel/padded_side_effects.ts +73 -0
- package/src/kernel/private_accumulated_data.ts +25 -25
- package/src/kernel/private_call_data.ts +6 -25
- package/src/kernel/private_call_request.ts +2 -2
- package/src/kernel/private_circuit_public_inputs.ts +161 -117
- package/src/kernel/private_context_inputs.ts +3 -3
- package/src/kernel/private_kernel_circuit_public_inputs.ts +21 -6
- package/src/kernel/private_kernel_data.ts +7 -31
- package/src/kernel/private_kernel_init_circuit_private_inputs.ts +12 -5
- package/src/kernel/private_kernel_prover_output.ts +70 -0
- package/src/kernel/private_kernel_reset_circuit_private_inputs.ts +16 -13
- package/src/kernel/private_kernel_reset_dimensions.ts +27 -27
- package/src/kernel/private_kernel_simulated_output.ts +7 -16
- package/src/kernel/private_kernel_tail_circuit_private_inputs.ts +22 -5
- package/src/kernel/private_kernel_tail_circuit_public_inputs.ts +42 -25
- package/src/kernel/private_log_data.ts +14 -5
- package/src/kernel/private_to_avm_accumulated_data.ts +54 -2
- package/src/kernel/private_to_public_accumulated_data.ts +1 -1
- package/src/kernel/private_to_public_accumulated_data_builder.ts +1 -1
- package/src/kernel/private_to_public_kernel_circuit_public_inputs.ts +18 -9
- package/src/kernel/private_to_rollup_accumulated_data.ts +1 -1
- package/src/kernel/private_to_rollup_kernel_circuit_public_inputs.ts +18 -12
- package/src/kernel/private_validation_requests.ts +19 -62
- package/src/kernel/public_call_request.ts +120 -29
- package/src/kernel/utils/optional_number.ts +1 -1
- package/src/kernel/utils/order_and_comparison.ts +0 -25
- package/src/keys/derivation.ts +15 -32
- package/src/keys/key_types.ts +1 -1
- package/src/keys/public_key.ts +1 -1
- package/src/keys/public_keys.ts +23 -3
- package/src/keys/utils.ts +7 -3
- package/src/l1-contracts/index.ts +1 -0
- package/src/l1-contracts/slash_factory.ts +180 -0
- package/src/logs/contract_class_log.ts +168 -66
- package/src/logs/debug_log.ts +51 -0
- package/src/logs/directional_app_tagging_secret.ts +79 -0
- package/src/logs/index.ts +8 -3
- package/src/logs/log_id.ts +23 -11
- package/src/logs/message_context.ts +62 -0
- package/src/logs/pending_tagged_log.ts +41 -0
- package/src/logs/pre_tag.ts +25 -0
- package/src/logs/private_log.ts +79 -26
- package/src/logs/public_log.ts +158 -37
- package/src/logs/shared_secret_derivation.ts +26 -0
- package/src/logs/siloed_tag.ts +45 -0
- package/src/logs/tag.ts +42 -0
- package/src/logs/tx_scoped_l2_log.ts +48 -33
- package/src/messaging/in_hash.ts +12 -0
- package/src/messaging/inbox_leaf.ts +20 -4
- package/src/messaging/index.ts +3 -0
- package/src/messaging/l1_actor.ts +2 -2
- package/src/messaging/l1_to_l2_message.ts +3 -2
- package/src/messaging/l1_to_l2_message_source.ts +9 -7
- package/src/messaging/l2_actor.ts +2 -2
- package/src/messaging/l2_to_l1_membership.ts +225 -0
- package/src/messaging/l2_to_l1_message.ts +131 -37
- package/src/messaging/out_hash.ts +77 -0
- package/src/noir/index.ts +24 -7
- package/src/note/index.ts +1 -1
- package/src/note/note.ts +65 -6
- package/src/note/note_dao.ts +187 -0
- package/src/note/notes_filter.ts +10 -11
- package/src/p2p/attestation_utils.ts +35 -0
- package/src/p2p/block_proposal.ts +249 -36
- package/src/p2p/checkpoint_attestation.ts +143 -0
- package/src/p2p/checkpoint_proposal.ts +355 -0
- package/src/p2p/consensus_payload.ts +53 -32
- package/src/p2p/constants.ts +3 -0
- package/src/p2p/gossipable.ts +60 -15
- package/src/p2p/index.ts +5 -1
- package/src/p2p/interface.ts +0 -24
- package/src/p2p/message_validator.ts +14 -2
- package/src/p2p/signature_utils.ts +12 -11
- package/src/p2p/signed_txs.ts +88 -0
- package/src/p2p/topic_type.ts +35 -15
- package/src/parity/index.ts +2 -3
- package/src/parity/{base_parity_inputs.ts → parity_base_private_inputs.ts} +14 -12
- package/src/parity/parity_public_inputs.ts +1 -1
- package/src/parity/{root_parity_inputs.ts → parity_root_private_inputs.ts} +16 -18
- package/src/proofs/chonk_proof.ts +122 -0
- package/src/proofs/index.ts +2 -1
- package/src/proofs/proof.ts +30 -22
- package/src/proofs/proof_data.ts +60 -0
- package/src/proofs/proving_request_type.ts +14 -9
- package/src/proofs/recursive_proof.ts +1 -1
- package/src/rollup/avm_proof_data.ts +3 -32
- package/src/rollup/base_rollup_hints.ts +42 -41
- package/src/rollup/block_constant_data.ts +73 -0
- package/src/rollup/block_headers_hash.ts +12 -0
- package/src/rollup/{block_merge_rollup.ts → block_merge_rollup_private_inputs.ts} +15 -11
- package/src/rollup/block_rollup_public_inputs.ts +125 -0
- package/src/rollup/block_root_rollup_private_inputs.ts +303 -0
- package/src/rollup/checkpoint_constant_data.ts +124 -0
- package/src/rollup/checkpoint_header.ts +297 -0
- package/src/rollup/checkpoint_merge_rollup_private_inputs.ts +49 -0
- package/src/rollup/checkpoint_rollup_public_inputs.ts +151 -0
- package/src/rollup/checkpoint_root_rollup_private_inputs.ts +232 -0
- package/src/rollup/epoch_constant_data.ts +62 -0
- package/src/rollup/index.ts +20 -16
- package/src/rollup/private_tx_base_rollup_private_inputs.ts +53 -0
- package/src/rollup/public_chonk_verifier_private_inputs.ts +54 -0
- package/src/rollup/public_chonk_verifier_public_inputs.ts +53 -0
- package/src/rollup/public_tx_base_rollup_private_inputs.ts +57 -0
- package/src/rollup/root_rollup_private_inputs.ts +90 -0
- package/src/rollup/root_rollup_public_inputs.ts +108 -0
- package/src/rollup/{state_diff_hints.ts → tree_snapshot_diff_hints.ts} +27 -42
- package/src/rollup/{merge_rollup.ts → tx_merge_rollup_private_inputs.ts} +13 -9
- package/src/rollup/{base_or_merge_rollup_public_inputs.ts → tx_rollup_public_inputs.ts} +18 -26
- package/src/schemas/schemas.ts +27 -1
- package/src/slashing/empire.ts +102 -0
- package/src/slashing/helpers.ts +141 -0
- package/src/slashing/index.ts +6 -0
- package/src/slashing/interfaces.ts +13 -0
- package/src/slashing/serialization.ts +103 -0
- package/src/slashing/tally.ts +87 -0
- package/src/slashing/types.ts +156 -0
- package/src/snapshots/download.ts +123 -0
- package/src/snapshots/index.ts +3 -0
- package/src/snapshots/types.ts +74 -0
- package/src/snapshots/upload.ts +64 -0
- package/src/stats/stats.ts +38 -26
- package/src/tests/factories.ts +852 -657
- package/src/tests/jest.ts +1 -1
- package/src/tests/mocks.ts +578 -151
- package/src/trees/append_only_tree_snapshot.ts +18 -3
- package/src/trees/database_public_state_source.ts +30 -0
- package/src/trees/index.ts +1 -1
- package/src/trees/merkle_tree_id.ts +12 -0
- package/src/trees/nullifier_leaf.ts +81 -22
- package/src/trees/nullifier_membership_witness.ts +18 -2
- package/src/trees/public_data_leaf.ts +73 -30
- package/src/trees/public_data_witness.ts +24 -5
- package/src/tx/block_header.ts +61 -32
- package/src/tx/call_context.ts +1 -1
- package/src/tx/capsule.ts +3 -1
- package/src/tx/execution_payload.ts +60 -0
- package/src/tx/function_data.ts +1 -1
- package/src/tx/global_variable_builder.ts +13 -5
- package/src/tx/global_variables.ts +107 -32
- package/src/tx/hashed_values.ts +30 -10
- package/src/tx/in_tx.ts +24 -0
- package/src/tx/index.ts +10 -3
- package/src/tx/indexed_tx_effect.ts +41 -0
- package/src/tx/offchain_effect.ts +20 -0
- package/src/tx/partial_state_reference.ts +30 -5
- package/src/tx/private_execution_result.ts +76 -107
- package/src/tx/private_tx_constant_data.ts +94 -0
- package/src/tx/processed_tx.ts +58 -49
- package/src/tx/profiling.ts +201 -0
- package/src/tx/protocol_contracts.ts +86 -0
- package/src/tx/proven_tx.ts +62 -0
- package/src/tx/public_call_request_with_calldata.ts +89 -0
- package/src/tx/public_simulation_output.ts +24 -7
- package/src/tx/simulated_tx.ts +66 -76
- package/src/tx/state_reference.ts +49 -6
- package/src/tx/tree_snapshots.ts +30 -14
- package/src/tx/tx.ts +178 -200
- package/src/tx/tx_constant_data.ts +9 -22
- package/src/tx/tx_context.ts +1 -1
- package/src/tx/tx_effect.ts +138 -316
- package/src/tx/tx_execution_request.ts +17 -4
- package/src/tx/tx_hash.ts +27 -6
- package/src/tx/tx_receipt.ts +79 -57
- package/src/tx/tx_request.ts +18 -8
- package/src/tx/validator/error_texts.ts +41 -0
- package/src/tx/validator/tx_validator.ts +13 -6
- package/src/types/shared.ts +10 -9
- package/src/update-checker/index.ts +1 -0
- package/src/update-checker/update-checker.ts +166 -0
- package/src/validators/errors.ts +58 -0
- package/src/validators/index.ts +3 -0
- package/src/validators/schemas.ts +81 -0
- package/src/validators/types.ts +47 -0
- package/src/versioning/versioning.ts +29 -33
- package/src/vks/index.ts +1 -1
- package/src/vks/verification_key.ts +44 -19
- package/src/vks/{vk_witness_data.ts → vk_data.ts} +7 -7
- package/src/world-state/index.ts +1 -0
- package/src/world-state/world_state_revision.ts +63 -0
- package/src/zkpassport/index.ts +118 -0
- package/dest/avm/public_data_hint.d.ts +0 -18
- package/dest/avm/public_data_hint.d.ts.map +0 -1
- package/dest/avm/public_data_hint.js +0 -27
- package/dest/block/l2_block_code_to_purge.d.ts +0 -24
- package/dest/block/l2_block_code_to_purge.d.ts.map +0 -1
- package/dest/block/l2_block_code_to_purge.js +0 -51
- package/dest/block/l2_block_downloader/index.d.ts +0 -3
- package/dest/block/l2_block_downloader/index.d.ts.map +0 -1
- package/dest/block/l2_block_downloader/index.js +0 -2
- package/dest/block/l2_block_downloader/l2_block_downloader.d.ts +0 -58
- package/dest/block/l2_block_downloader/l2_block_downloader.d.ts.map +0 -1
- package/dest/block/l2_block_downloader/l2_block_downloader.js +0 -124
- package/dest/block/l2_block_downloader/l2_block_stream.d.ts +0 -57
- package/dest/block/l2_block_downloader/l2_block_stream.d.ts.map +0 -1
- package/dest/block/l2_block_downloader/l2_block_stream.js +0 -137
- package/dest/block/l2_block_number.d.ts +0 -5
- package/dest/block/l2_block_number.d.ts.map +0 -1
- package/dest/block/l2_block_number.js +0 -6
- package/dest/block/nullifier_with_block_source.d.ts +0 -6
- package/dest/block/nullifier_with_block_source.d.ts.map +0 -1
- package/dest/config/config.d.ts +0 -18
- package/dest/config/config.d.ts.map +0 -1
- package/dest/contract/unconstrained_function_membership_proof.d.ts +0 -27
- package/dest/contract/unconstrained_function_membership_proof.d.ts.map +0 -1
- package/dest/database-version/index.d.ts +0 -2
- package/dest/database-version/index.d.ts.map +0 -1
- package/dest/database-version/index.js +0 -1
- package/dest/event/event.d.ts +0 -24
- package/dest/event/event.d.ts.map +0 -1
- package/dest/event/event.js +0 -13
- package/dest/event/event_metadata.d.ts +0 -38
- package/dest/event/event_metadata.d.ts.map +0 -1
- package/dest/event/event_metadata.js +0 -45
- package/dest/event/index.d.ts +0 -4
- package/dest/event/index.d.ts.map +0 -1
- package/dest/event/index.js +0 -3
- package/dest/event/l1_event_payload.d.ts +0 -52
- package/dest/event/l1_event_payload.d.ts.map +0 -1
- package/dest/event/l1_event_payload.js +0 -64
- package/dest/interfaces/pxe.d.ts +0 -347
- package/dest/interfaces/pxe.d.ts.map +0 -1
- package/dest/interfaces/pxe.js +0 -104
- package/dest/kernel/combined_constant_data.d.ts +0 -73
- package/dest/kernel/combined_constant_data.d.ts.map +0 -1
- package/dest/kernel/combined_constant_data.js +0 -73
- package/dest/kernel/hints/rollup_validation_requests.d.ts +0 -40
- package/dest/kernel/hints/rollup_validation_requests.d.ts.map +0 -1
- package/dest/kernel/hints/rollup_validation_requests.js +0 -57
- package/dest/kernel/hints/transient_data_index_hint.d.ts +0 -20
- package/dest/kernel/hints/transient_data_index_hint.d.ts.map +0 -1
- package/dest/kernel/private_kernel_prover_profile_result.d.ts +0 -25
- package/dest/kernel/private_kernel_prover_profile_result.d.ts.map +0 -1
- package/dest/kernel/private_kernel_prover_profile_result.js +0 -7
- package/dest/logs/indexed_tagging_secret.d.ts +0 -28
- package/dest/logs/indexed_tagging_secret.d.ts.map +0 -1
- package/dest/logs/indexed_tagging_secret.js +0 -50
- package/dest/logs/l1_payload/encrypted_log_payload.d.ts +0 -50
- package/dest/logs/l1_payload/encrypted_log_payload.d.ts.map +0 -1
- package/dest/logs/l1_payload/encrypted_log_payload.js +0 -140
- package/dest/logs/l1_payload/encryption_util.d.ts +0 -24
- package/dest/logs/l1_payload/encryption_util.d.ts.map +0 -1
- package/dest/logs/l1_payload/encryption_util.js +0 -46
- package/dest/logs/l1_payload/index.d.ts +0 -3
- package/dest/logs/l1_payload/index.d.ts.map +0 -1
- package/dest/logs/l1_payload/index.js +0 -2
- package/dest/logs/l1_payload/l1_note_payload.d.ts +0 -82
- package/dest/logs/l1_payload/l1_note_payload.d.ts.map +0 -1
- package/dest/logs/l1_payload/l1_note_payload.js +0 -129
- package/dest/logs/l1_payload/payload.d.ts +0 -60
- package/dest/logs/l1_payload/payload.d.ts.map +0 -1
- package/dest/logs/l1_payload/payload.js +0 -61
- package/dest/logs/l1_payload/shared_secret_derivation.d.ts +0 -16
- package/dest/logs/l1_payload/shared_secret_derivation.d.ts.map +0 -1
- package/dest/logs/log_with_tx_data.d.ts +0 -11
- package/dest/logs/log_with_tx_data.d.ts.map +0 -1
- package/dest/logs/log_with_tx_data.js +0 -36
- package/dest/network/index.d.ts +0 -32
- package/dest/network/index.d.ts.map +0 -1
- package/dest/network/index.js +0 -30
- package/dest/note/extended_note.d.ts +0 -124
- package/dest/note/extended_note.d.ts.map +0 -1
- package/dest/note/extended_note.js +0 -115
- package/dest/p2p/block_attestation.d.ts +0 -49
- package/dest/p2p/block_attestation.d.ts.map +0 -1
- package/dest/p2p/block_attestation.js +0 -78
- package/dest/parity/base_parity_inputs.d.ts +0 -37
- package/dest/parity/base_parity_inputs.d.ts.map +0 -1
- package/dest/parity/root_parity_input.d.ts +0 -54
- package/dest/parity/root_parity_input.d.ts.map +0 -1
- package/dest/parity/root_parity_input.js +0 -50
- package/dest/parity/root_parity_inputs.d.ts +0 -39
- package/dest/parity/root_parity_inputs.d.ts.map +0 -1
- package/dest/proofs/client_ivc_proof.d.ts +0 -21
- package/dest/proofs/client_ivc_proof.d.ts.map +0 -1
- package/dest/proofs/client_ivc_proof.js +0 -44
- package/dest/rollup/base_or_merge_rollup_public_inputs.d.ts +0 -126
- package/dest/rollup/base_or_merge_rollup_public_inputs.d.ts.map +0 -1
- package/dest/rollup/block_merge_rollup.d.ts +0 -45
- package/dest/rollup/block_merge_rollup.d.ts.map +0 -1
- package/dest/rollup/block_root_or_block_merge_public_inputs.d.ts +0 -159
- package/dest/rollup/block_root_or_block_merge_public_inputs.d.ts.map +0 -1
- package/dest/rollup/block_root_or_block_merge_public_inputs.js +0 -136
- package/dest/rollup/block_root_rollup.d.ts +0 -262
- package/dest/rollup/block_root_rollup.d.ts.map +0 -1
- package/dest/rollup/block_root_rollup.js +0 -293
- package/dest/rollup/constant_rollup_data.d.ts +0 -47
- package/dest/rollup/constant_rollup_data.d.ts.map +0 -1
- package/dest/rollup/constant_rollup_data.js +0 -45
- package/dest/rollup/empty_block_root_rollup_inputs.d.ts +0 -54
- package/dest/rollup/empty_block_root_rollup_inputs.d.ts.map +0 -1
- package/dest/rollup/empty_block_root_rollup_inputs.js +0 -68
- package/dest/rollup/merge_rollup.d.ts +0 -45
- package/dest/rollup/merge_rollup.d.ts.map +0 -1
- package/dest/rollup/previous_rollup_block_data.d.ts +0 -58
- package/dest/rollup/previous_rollup_block_data.d.ts.map +0 -1
- package/dest/rollup/previous_rollup_block_data.js +0 -42
- package/dest/rollup/previous_rollup_data.d.ts +0 -58
- package/dest/rollup/previous_rollup_data.d.ts.map +0 -1
- package/dest/rollup/previous_rollup_data.js +0 -42
- package/dest/rollup/private_base_rollup_inputs.d.ts +0 -23
- package/dest/rollup/private_base_rollup_inputs.d.ts.map +0 -1
- package/dest/rollup/private_base_rollup_inputs.js +0 -44
- package/dest/rollup/private_tube_data.d.ts +0 -17
- package/dest/rollup/private_tube_data.d.ts.map +0 -1
- package/dest/rollup/private_tube_data.js +0 -25
- package/dest/rollup/public_base_rollup_inputs.d.ts +0 -25
- package/dest/rollup/public_base_rollup_inputs.d.ts.map +0 -1
- package/dest/rollup/public_base_rollup_inputs.js +0 -48
- package/dest/rollup/public_tube_data.d.ts +0 -17
- package/dest/rollup/public_tube_data.d.ts.map +0 -1
- package/dest/rollup/public_tube_data.js +0 -25
- package/dest/rollup/root_rollup.d.ts +0 -112
- package/dest/rollup/root_rollup.d.ts.map +0 -1
- package/dest/rollup/root_rollup.js +0 -158
- package/dest/rollup/state_diff_hints.d.ts +0 -105
- package/dest/rollup/state_diff_hints.d.ts.map +0 -1
- package/dest/rollup/state_diff_hints.js +0 -85
- package/dest/rollup/tube_inputs.d.ts +0 -40
- package/dest/rollup/tube_inputs.d.ts.map +0 -1
- package/dest/rollup/tube_inputs.js +0 -57
- package/dest/shared_mutable/index.d.ts +0 -5
- package/dest/shared_mutable/index.d.ts.map +0 -1
- package/dest/shared_mutable/index.js +0 -4
- package/dest/shared_mutable/scheduled_delay_change.d.ts +0 -10
- package/dest/shared_mutable/scheduled_delay_change.d.ts.map +0 -1
- package/dest/shared_mutable/scheduled_value_change.d.ts +0 -11
- package/dest/shared_mutable/scheduled_value_change.d.ts.map +0 -1
- package/dest/shared_mutable/shared_mutable_values.d.ts +0 -22
- package/dest/shared_mutable/shared_mutable_values.d.ts.map +0 -1
- package/dest/shared_mutable/shared_mutable_values_with_hash.d.ts +0 -15
- package/dest/shared_mutable/shared_mutable_values_with_hash.d.ts.map +0 -1
- package/dest/shared_mutable/shared_mutable_values_with_hash.js +0 -30
- package/dest/trees/protocol_contract_leaf.d.ts +0 -87
- package/dest/trees/protocol_contract_leaf.d.ts.map +0 -1
- package/dest/trees/protocol_contract_leaf.js +0 -103
- package/dest/tx/content_commitment.d.ts +0 -105
- package/dest/tx/content_commitment.d.ts.map +0 -1
- package/dest/tx/content_commitment.js +0 -96
- package/dest/tx/max_block_number.d.ts +0 -55
- package/dest/tx/max_block_number.d.ts.map +0 -1
- package/dest/tx/max_block_number.js +0 -65
- package/dest/tx/public_execution_request.d.ts +0 -45
- package/dest/tx/public_execution_request.d.ts.map +0 -1
- package/dest/tx/public_execution_request.js +0 -72
- package/dest/vks/vk_witness_data.d.ts +0 -32
- package/dest/vks/vk_witness_data.d.ts.map +0 -1
- package/src/avm/public_data_hint.ts +0 -38
- package/src/block/l2_block_code_to_purge.ts +0 -103
- package/src/block/l2_block_downloader/index.ts +0 -2
- package/src/block/l2_block_downloader/l2_block_downloader.ts +0 -149
- package/src/block/l2_block_downloader/l2_block_stream.ts +0 -179
- package/src/block/l2_block_number.ts +0 -8
- package/src/block/nullifier_with_block_source.ts +0 -7
- package/src/database-version/index.ts +0 -1
- package/src/event/event.ts +0 -16
- package/src/event/event_metadata.ts +0 -56
- package/src/event/index.ts +0 -3
- package/src/event/l1_event_payload.ts +0 -87
- package/src/interfaces/pxe.ts +0 -536
- package/src/kernel/combined_constant_data.ts +0 -128
- package/src/kernel/hints/rollup_validation_requests.ts +0 -73
- package/src/kernel/private_kernel_prover_profile_result.ts +0 -7
- package/src/logs/indexed_tagging_secret.ts +0 -45
- package/src/logs/l1_payload/encrypted_log_payload.ts +0 -202
- package/src/logs/l1_payload/encryption_util.ts +0 -54
- package/src/logs/l1_payload/index.ts +0 -2
- package/src/logs/l1_payload/l1_note_payload.ts +0 -182
- package/src/logs/l1_payload/payload.ts +0 -73
- package/src/logs/l1_payload/shared_secret_derivation.ts +0 -35
- package/src/logs/log_with_tx_data.ts +0 -36
- package/src/network/index.ts +0 -32
- package/src/note/extended_note.ts +0 -168
- package/src/p2p/block_attestation.ts +0 -107
- package/src/parity/root_parity_input.ts +0 -71
- package/src/proofs/client_ivc_proof.ts +0 -61
- package/src/rollup/block_root_or_block_merge_public_inputs.ts +0 -175
- package/src/rollup/block_root_rollup.ts +0 -362
- package/src/rollup/constant_rollup_data.ts +0 -54
- package/src/rollup/empty_block_root_rollup_inputs.ts +0 -85
- package/src/rollup/previous_rollup_block_data.ts +0 -54
- package/src/rollup/previous_rollup_data.ts +0 -54
- package/src/rollup/private_base_rollup_inputs.ts +0 -50
- package/src/rollup/private_tube_data.ts +0 -35
- package/src/rollup/public_base_rollup_inputs.ts +0 -59
- package/src/rollup/public_tube_data.ts +0 -35
- package/src/rollup/root_rollup.ts +0 -206
- package/src/rollup/tube_inputs.ts +0 -70
- package/src/shared_mutable/index.ts +0 -4
- package/src/shared_mutable/scheduled_delay_change.ts +0 -13
- package/src/shared_mutable/shared_mutable_values_with_hash.ts +0 -38
- package/src/trees/protocol_contract_leaf.ts +0 -132
- package/src/tx/content_commitment.ts +0 -133
- package/src/tx/max_block_number.ts +0 -79
- package/src/tx/public_execution_request.ts +0 -97
- /package/dest/{block/nullifier_with_block_source.js → abi/event_metadata_definition.js} +0 -0
package/dest/avm/avm.js
CHANGED
|
@@ -1,240 +1,732 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { DEFAULT_MAX_DEBUG_LOG_MEMORY_READS } from '@aztec/constants';
|
|
2
|
+
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
2
3
|
import { jsonParseWithSchema, jsonStringify } from '@aztec/foundation/json-rpc';
|
|
3
|
-
import { schemas } from '@aztec/foundation/schemas';
|
|
4
4
|
import { z } from 'zod';
|
|
5
|
+
import { FunctionSelector } from '../abi/index.js';
|
|
5
6
|
import { AztecAddress } from '../aztec-address/index.js';
|
|
7
|
+
import { AllContractDeploymentData, ContractDeploymentData } from '../contract/index.js';
|
|
8
|
+
import { SimulationError } from '../errors/simulation_error.js';
|
|
9
|
+
import { computeEffectiveGasFees } from '../fees/transaction_fee.js';
|
|
10
|
+
import { Gas } from '../gas/gas.js';
|
|
11
|
+
import { GasFees } from '../gas/gas_fees.js';
|
|
12
|
+
import { GasSettings } from '../gas/gas_settings.js';
|
|
13
|
+
import { GasUsed } from '../gas/gas_used.js';
|
|
6
14
|
import { PublicKeys } from '../keys/public_keys.js';
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
15
|
+
import { DebugLog } from '../logs/debug_log.js';
|
|
16
|
+
import { PublicLog } from '../logs/public_log.js';
|
|
17
|
+
import { ScopedL2ToL1Message } from '../messaging/l2_to_l1_message.js';
|
|
18
|
+
import { NullishToUndefined, schemas } from '../schemas/schemas.js';
|
|
19
|
+
import { AppendOnlyTreeSnapshot } from '../trees/append_only_tree_snapshot.js';
|
|
20
|
+
import { MerkleTreeId } from '../trees/merkle_tree_id.js';
|
|
21
|
+
import { NullifierLeaf, NullifierLeafPreimage } from '../trees/nullifier_leaf.js';
|
|
22
|
+
import { PublicDataTreeLeaf, PublicDataTreeLeafPreimage } from '../trees/public_data_leaf.js';
|
|
23
|
+
import { GlobalVariables, NestedProcessReturnValues, ProtocolContracts, PublicCallRequestWithCalldata, TreeSnapshots } from '../tx/index.js';
|
|
24
|
+
import { TxExecutionPhase } from '../tx/processed_tx.js';
|
|
25
|
+
import { WorldStateRevision } from '../world-state/world_state_revision.js';
|
|
9
26
|
import { AvmCircuitPublicInputs } from './avm_circuit_public_inputs.js';
|
|
10
27
|
import { serializeWithMessagePack } from './message_pack.js';
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
this.calldata = calldata;
|
|
17
|
-
}
|
|
18
|
-
static get schema() {
|
|
19
|
-
return z.object({
|
|
20
|
-
contractAddress: AztecAddress.schema,
|
|
21
|
-
calldata: schemas.Fr.array()
|
|
22
|
-
}).transform(({ contractAddress, calldata })=>new AvmEnqueuedCallHint(contractAddress, calldata));
|
|
23
|
-
}
|
|
24
|
-
}
|
|
28
|
+
import { PublicDataWrite } from './public_data_write.js';
|
|
29
|
+
import { RevertCode } from './revert_code.js';
|
|
30
|
+
////////////////////////////////////////////////////////////////////////////
|
|
31
|
+
// Hints (contracts)
|
|
32
|
+
////////////////////////////////////////////////////////////////////////////
|
|
25
33
|
export class AvmContractClassHint {
|
|
34
|
+
hintKey;
|
|
26
35
|
classId;
|
|
27
|
-
exists;
|
|
28
36
|
artifactHash;
|
|
29
37
|
privateFunctionsRoot;
|
|
30
|
-
publicBytecodeCommitment;
|
|
31
38
|
packedBytecode;
|
|
32
|
-
constructor(
|
|
39
|
+
constructor(hintKey, classId, artifactHash, privateFunctionsRoot, packedBytecode){
|
|
40
|
+
this.hintKey = hintKey;
|
|
33
41
|
this.classId = classId;
|
|
34
|
-
this.exists = exists;
|
|
35
42
|
this.artifactHash = artifactHash;
|
|
36
43
|
this.privateFunctionsRoot = privateFunctionsRoot;
|
|
37
|
-
this.publicBytecodeCommitment = publicBytecodeCommitment;
|
|
38
44
|
this.packedBytecode = packedBytecode;
|
|
39
45
|
}
|
|
40
46
|
static get schema() {
|
|
41
47
|
return z.object({
|
|
48
|
+
hintKey: z.number().int().nonnegative(),
|
|
42
49
|
classId: schemas.Fr,
|
|
43
|
-
exists: z.boolean(),
|
|
44
50
|
artifactHash: schemas.Fr,
|
|
45
51
|
privateFunctionsRoot: schemas.Fr,
|
|
46
|
-
publicBytecodeCommitment: schemas.Fr,
|
|
47
52
|
packedBytecode: schemas.Buffer
|
|
48
|
-
}).transform(({
|
|
53
|
+
}).transform(({ hintKey, classId, artifactHash, privateFunctionsRoot, packedBytecode })=>new AvmContractClassHint(hintKey, classId, artifactHash, privateFunctionsRoot, packedBytecode));
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Creates an AvmContractClassHint from a plain object without Zod validation.
|
|
57
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
58
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
59
|
+
* @param obj - Plain object containing AvmContractClassHint fields
|
|
60
|
+
* @returns An AvmContractClassHint instance
|
|
61
|
+
*/ static fromPlainObject(obj) {
|
|
62
|
+
if (obj instanceof AvmContractClassHint) {
|
|
63
|
+
return obj;
|
|
64
|
+
}
|
|
65
|
+
return new AvmContractClassHint(obj.hintKey, Fr.fromPlainObject(obj.classId), Fr.fromPlainObject(obj.artifactHash), Fr.fromPlainObject(obj.privateFunctionsRoot), obj.packedBytecode instanceof Buffer ? obj.packedBytecode : Buffer.from(obj.packedBytecode));
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
export class AvmBytecodeCommitmentHint {
|
|
69
|
+
hintKey;
|
|
70
|
+
classId;
|
|
71
|
+
commitment;
|
|
72
|
+
constructor(hintKey, classId, commitment){
|
|
73
|
+
this.hintKey = hintKey;
|
|
74
|
+
this.classId = classId;
|
|
75
|
+
this.commitment = commitment;
|
|
76
|
+
}
|
|
77
|
+
static get schema() {
|
|
78
|
+
return z.object({
|
|
79
|
+
hintKey: z.number().int().nonnegative(),
|
|
80
|
+
classId: schemas.Fr,
|
|
81
|
+
commitment: schemas.Fr
|
|
82
|
+
}).transform(({ hintKey, classId, commitment })=>new AvmBytecodeCommitmentHint(hintKey, classId, commitment));
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Creates an AvmBytecodeCommitmentHint from a plain object without Zod validation.
|
|
86
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
87
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
88
|
+
* @param obj - Plain object containing AvmBytecodeCommitmentHint fields
|
|
89
|
+
* @returns An AvmBytecodeCommitmentHint instance
|
|
90
|
+
*/ static fromPlainObject(obj) {
|
|
91
|
+
if (obj instanceof AvmBytecodeCommitmentHint) {
|
|
92
|
+
return obj;
|
|
93
|
+
}
|
|
94
|
+
return new AvmBytecodeCommitmentHint(obj.hintKey, Fr.fromPlainObject(obj.classId), Fr.fromPlainObject(obj.commitment));
|
|
49
95
|
}
|
|
50
96
|
}
|
|
51
97
|
export class AvmContractInstanceHint {
|
|
98
|
+
hintKey;
|
|
52
99
|
address;
|
|
53
|
-
exists;
|
|
54
100
|
salt;
|
|
55
101
|
deployer;
|
|
56
102
|
currentContractClassId;
|
|
57
103
|
originalContractClassId;
|
|
58
104
|
initializationHash;
|
|
59
105
|
publicKeys;
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
constructor(address, exists, salt, deployer, currentContractClassId, originalContractClassId, initializationHash, publicKeys, // public readonly updateMembershipHint: AvmPublicDataReadTreeHint = AvmPublicDataReadTreeHint.empty(),
|
|
63
|
-
updateMembershipHint, updatePreimage = []){
|
|
106
|
+
constructor(hintKey, address, salt, deployer, currentContractClassId, originalContractClassId, initializationHash, publicKeys){
|
|
107
|
+
this.hintKey = hintKey;
|
|
64
108
|
this.address = address;
|
|
65
|
-
this.exists = exists;
|
|
66
109
|
this.salt = salt;
|
|
67
110
|
this.deployer = deployer;
|
|
68
111
|
this.currentContractClassId = currentContractClassId;
|
|
69
112
|
this.originalContractClassId = originalContractClassId;
|
|
70
113
|
this.initializationHash = initializationHash;
|
|
71
114
|
this.publicKeys = publicKeys;
|
|
72
|
-
this.updateMembershipHint = updateMembershipHint;
|
|
73
|
-
this.updatePreimage = updatePreimage;
|
|
74
115
|
}
|
|
75
116
|
static get schema() {
|
|
76
117
|
return z.object({
|
|
118
|
+
hintKey: z.number().int().nonnegative(),
|
|
77
119
|
address: AztecAddress.schema,
|
|
78
|
-
exists: z.boolean(),
|
|
79
120
|
salt: schemas.Fr,
|
|
80
121
|
deployer: AztecAddress.schema,
|
|
81
122
|
currentContractClassId: schemas.Fr,
|
|
82
123
|
originalContractClassId: schemas.Fr,
|
|
83
124
|
initializationHash: schemas.Fr,
|
|
84
|
-
publicKeys: PublicKeys.schema
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
125
|
+
publicKeys: PublicKeys.schema
|
|
126
|
+
}).transform(({ hintKey, address, salt, deployer, currentContractClassId, originalContractClassId, initializationHash, publicKeys })=>new AvmContractInstanceHint(hintKey, address, salt, deployer, currentContractClassId, originalContractClassId, initializationHash, publicKeys));
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* Creates an AvmContractInstanceHint from a plain object without Zod validation.
|
|
130
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
131
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
132
|
+
* @param obj - Plain object containing AvmContractInstanceHint fields
|
|
133
|
+
* @returns An AvmContractInstanceHint instance
|
|
134
|
+
*/ static fromPlainObject(obj) {
|
|
135
|
+
if (obj instanceof AvmContractInstanceHint) {
|
|
136
|
+
return obj;
|
|
137
|
+
}
|
|
138
|
+
return new AvmContractInstanceHint(obj.hintKey, AztecAddress.fromPlainObject(obj.address), Fr.fromPlainObject(obj.salt), AztecAddress.fromPlainObject(obj.deployer), Fr.fromPlainObject(obj.currentContractClassId), Fr.fromPlainObject(obj.originalContractClassId), Fr.fromPlainObject(obj.initializationHash), PublicKeys.fromPlainObject(obj.publicKeys));
|
|
88
139
|
}
|
|
89
140
|
}
|
|
90
|
-
export class
|
|
91
|
-
|
|
141
|
+
export class AvmDebugFunctionNameHint {
|
|
142
|
+
address;
|
|
143
|
+
selector;
|
|
144
|
+
name;
|
|
145
|
+
constructor(address, selector, name){
|
|
146
|
+
this.address = address;
|
|
147
|
+
this.selector = selector;
|
|
148
|
+
this.name = name;
|
|
149
|
+
}
|
|
150
|
+
static get schema() {
|
|
151
|
+
return z.object({
|
|
152
|
+
address: AztecAddress.schema,
|
|
153
|
+
selector: schemas.Fr,
|
|
154
|
+
name: z.string()
|
|
155
|
+
}).transform(({ address, selector, name })=>new AvmDebugFunctionNameHint(address, selector, name));
|
|
156
|
+
}
|
|
157
|
+
/**
|
|
158
|
+
* Creates an AvmDebugFunctionNameHint from a plain object without Zod validation.
|
|
159
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
160
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
161
|
+
* @param obj - Plain object containing AvmDebugFunctionNameHint fields
|
|
162
|
+
* @returns An AvmDebugFunctionNameHint instance
|
|
163
|
+
*/ static fromPlainObject(obj) {
|
|
164
|
+
if (obj instanceof AvmDebugFunctionNameHint) {
|
|
165
|
+
return obj;
|
|
166
|
+
}
|
|
167
|
+
return new AvmDebugFunctionNameHint(AztecAddress.fromPlainObject(obj.address), Fr.fromPlainObject(obj.selector), obj.name);
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
////////////////////////////////////////////////////////////////////////////
|
|
171
|
+
// Hints (merkle db)
|
|
172
|
+
////////////////////////////////////////////////////////////////////////////
|
|
173
|
+
// Hint for MerkleTreeDB.getSiblingPath.
|
|
174
|
+
export class AvmGetSiblingPathHint {
|
|
175
|
+
hintKey;
|
|
176
|
+
treeId;
|
|
177
|
+
index;
|
|
178
|
+
path;
|
|
179
|
+
constructor(hintKey, // params
|
|
180
|
+
treeId, index, // return
|
|
181
|
+
path){
|
|
182
|
+
this.hintKey = hintKey;
|
|
183
|
+
this.treeId = treeId;
|
|
184
|
+
this.index = index;
|
|
185
|
+
this.path = path;
|
|
186
|
+
}
|
|
187
|
+
static get schema() {
|
|
188
|
+
return z.object({
|
|
189
|
+
hintKey: AppendOnlyTreeSnapshot.schema,
|
|
190
|
+
treeId: z.number().int().nonnegative(),
|
|
191
|
+
index: schemas.BigInt,
|
|
192
|
+
path: schemas.Fr.array()
|
|
193
|
+
}).transform(({ hintKey, treeId, index, path })=>new AvmGetSiblingPathHint(hintKey, treeId, index, path));
|
|
194
|
+
}
|
|
195
|
+
/**
|
|
196
|
+
* Creates an AvmGetSiblingPathHint from a plain object without Zod validation.
|
|
197
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
198
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
199
|
+
* @param obj - Plain object containing AvmGetSiblingPathHint fields
|
|
200
|
+
* @returns An AvmGetSiblingPathHint instance
|
|
201
|
+
*/ static fromPlainObject(obj) {
|
|
202
|
+
if (obj instanceof AvmGetSiblingPathHint) {
|
|
203
|
+
return obj;
|
|
204
|
+
}
|
|
205
|
+
return new AvmGetSiblingPathHint(AppendOnlyTreeSnapshot.fromPlainObject(obj.hintKey), obj.treeId, typeof obj.index === 'bigint' ? obj.index : BigInt(obj.index), obj.path.map((p)=>Fr.fromPlainObject(p)));
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
// Hint for MerkleTreeDB.getPreviousValueIndex.
|
|
209
|
+
export class AvmGetPreviousValueIndexHint {
|
|
210
|
+
hintKey;
|
|
211
|
+
treeId;
|
|
92
212
|
value;
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
213
|
+
index;
|
|
214
|
+
alreadyPresent;
|
|
215
|
+
constructor(hintKey, // params
|
|
216
|
+
treeId, value, // return
|
|
217
|
+
index, alreadyPresent){
|
|
218
|
+
this.hintKey = hintKey;
|
|
219
|
+
this.treeId = treeId;
|
|
96
220
|
this.value = value;
|
|
97
|
-
this.
|
|
221
|
+
this.index = index;
|
|
222
|
+
this.alreadyPresent = alreadyPresent;
|
|
98
223
|
}
|
|
99
224
|
static get schema() {
|
|
100
225
|
return z.object({
|
|
101
|
-
|
|
226
|
+
hintKey: AppendOnlyTreeSnapshot.schema,
|
|
227
|
+
treeId: z.number().int().nonnegative(),
|
|
102
228
|
value: schemas.Fr,
|
|
103
|
-
|
|
104
|
-
|
|
229
|
+
index: schemas.BigInt,
|
|
230
|
+
alreadyPresent: z.boolean()
|
|
231
|
+
}).transform(({ hintKey, treeId, value, index, alreadyPresent })=>new AvmGetPreviousValueIndexHint(hintKey, treeId, value, index, alreadyPresent));
|
|
232
|
+
}
|
|
233
|
+
/**
|
|
234
|
+
* Creates an AvmGetPreviousValueIndexHint from a plain object without Zod validation.
|
|
235
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
236
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
237
|
+
* @param obj - Plain object containing AvmGetPreviousValueIndexHint fields
|
|
238
|
+
* @returns An AvmGetPreviousValueIndexHint instance
|
|
239
|
+
*/ static fromPlainObject(obj) {
|
|
240
|
+
if (obj instanceof AvmGetPreviousValueIndexHint) {
|
|
241
|
+
return obj;
|
|
242
|
+
}
|
|
243
|
+
return new AvmGetPreviousValueIndexHint(AppendOnlyTreeSnapshot.fromPlainObject(obj.hintKey), obj.treeId, Fr.fromPlainObject(obj.value), typeof obj.index === 'bigint' ? obj.index : BigInt(obj.index), obj.alreadyPresent);
|
|
105
244
|
}
|
|
106
245
|
}
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
246
|
+
// Hint for MerkleTreeDB.getLeafPreimage.
|
|
247
|
+
// NOTE: I need this factory because in order to get hold of the schema, I need an actual instance of the class,
|
|
248
|
+
// having the type doesn't suffice since TS does type erasure in the end.
|
|
249
|
+
function AvmGetLeafPreimageHintFactory(klass) {
|
|
250
|
+
return class {
|
|
251
|
+
hintKey;
|
|
252
|
+
index;
|
|
253
|
+
leafPreimage;
|
|
254
|
+
constructor(hintKey, // params (tree id will be implicit)
|
|
255
|
+
index, // return
|
|
256
|
+
leafPreimage){
|
|
257
|
+
this.hintKey = hintKey;
|
|
258
|
+
this.index = index;
|
|
259
|
+
this.leafPreimage = leafPreimage;
|
|
260
|
+
}
|
|
261
|
+
static get schema() {
|
|
262
|
+
return z.object({
|
|
263
|
+
hintKey: AppendOnlyTreeSnapshot.schema,
|
|
264
|
+
index: schemas.BigInt,
|
|
265
|
+
leafPreimage: klass.schema
|
|
266
|
+
}).transform(({ hintKey, index, leafPreimage })=>new this(hintKey, index, leafPreimage));
|
|
267
|
+
}
|
|
268
|
+
/**
|
|
269
|
+
* Creates an instance from a plain object without Zod validation.
|
|
270
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
271
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
272
|
+
* @param obj - Plain object containing hint fields
|
|
273
|
+
* @returns An instance
|
|
274
|
+
*/ static fromPlainObject(obj) {
|
|
275
|
+
if (obj instanceof this) {
|
|
276
|
+
return obj;
|
|
277
|
+
}
|
|
278
|
+
return new this(AppendOnlyTreeSnapshot.fromPlainObject(obj.hintKey), typeof obj.index === 'bigint' ? obj.index : BigInt(obj.index), klass.fromPlainObject(obj.leafPreimage));
|
|
279
|
+
}
|
|
280
|
+
};
|
|
281
|
+
}
|
|
282
|
+
// Note: only supported for PUBLIC_DATA_TREE and NULLIFIER_TREE.
|
|
283
|
+
export class AvmGetLeafPreimageHintPublicDataTree extends AvmGetLeafPreimageHintFactory(PublicDataTreeLeafPreimage) {
|
|
284
|
+
}
|
|
285
|
+
export class AvmGetLeafPreimageHintNullifierTree extends AvmGetLeafPreimageHintFactory(NullifierLeafPreimage) {
|
|
286
|
+
}
|
|
287
|
+
// Hint for MerkleTreeDB.getLeafValue.
|
|
288
|
+
// Note: only supported for NOTE_HASH_TREE and L1_TO_L2_MESSAGE_TREE.
|
|
289
|
+
export class AvmGetLeafValueHint {
|
|
290
|
+
hintKey;
|
|
291
|
+
treeId;
|
|
292
|
+
index;
|
|
293
|
+
value;
|
|
294
|
+
constructor(hintKey, // params
|
|
295
|
+
treeId, index, // return
|
|
296
|
+
value){
|
|
297
|
+
this.hintKey = hintKey;
|
|
298
|
+
this.treeId = treeId;
|
|
299
|
+
this.index = index;
|
|
300
|
+
this.value = value;
|
|
113
301
|
}
|
|
114
302
|
static get schema() {
|
|
115
303
|
return z.object({
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
304
|
+
hintKey: AppendOnlyTreeSnapshot.schema,
|
|
305
|
+
treeId: z.number().int().nonnegative(),
|
|
306
|
+
index: schemas.BigInt,
|
|
307
|
+
value: schemas.Fr
|
|
308
|
+
}).transform(({ hintKey, treeId, index, value })=>new AvmGetLeafValueHint(hintKey, treeId, index, value));
|
|
119
309
|
}
|
|
310
|
+
/**
|
|
311
|
+
* Creates an AvmGetLeafValueHint from a plain object without Zod validation.
|
|
312
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
313
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
314
|
+
* @param obj - Plain object containing AvmGetLeafValueHint fields
|
|
315
|
+
* @returns An AvmGetLeafValueHint instance
|
|
316
|
+
*/ static fromPlainObject(obj) {
|
|
317
|
+
if (obj instanceof AvmGetLeafValueHint) {
|
|
318
|
+
return obj;
|
|
319
|
+
}
|
|
320
|
+
return new AvmGetLeafValueHint(AppendOnlyTreeSnapshot.fromPlainObject(obj.hintKey), obj.treeId, typeof obj.index === 'bigint' ? obj.index : BigInt(obj.index), Fr.fromPlainObject(obj.value));
|
|
321
|
+
}
|
|
322
|
+
}
|
|
323
|
+
// Hint for MerkleTreeDB.sequentialInsert.
|
|
324
|
+
// NOTE: I need this factory because in order to get hold of the schema, I need an actual instance of the class,
|
|
325
|
+
// having the type doesn't suffice since TS does type erasure in the end.
|
|
326
|
+
function AvmSequentialInsertHintFactory(klass) {
|
|
327
|
+
return class {
|
|
328
|
+
hintKey;
|
|
329
|
+
stateAfter;
|
|
330
|
+
treeId;
|
|
331
|
+
leaf;
|
|
332
|
+
lowLeavesWitnessData;
|
|
333
|
+
insertionWitnessData;
|
|
334
|
+
constructor(hintKey, stateAfter, // params
|
|
335
|
+
treeId, leaf, // return
|
|
336
|
+
lowLeavesWitnessData, insertionWitnessData){
|
|
337
|
+
this.hintKey = hintKey;
|
|
338
|
+
this.stateAfter = stateAfter;
|
|
339
|
+
this.treeId = treeId;
|
|
340
|
+
this.leaf = leaf;
|
|
341
|
+
this.lowLeavesWitnessData = lowLeavesWitnessData;
|
|
342
|
+
this.insertionWitnessData = insertionWitnessData;
|
|
343
|
+
}
|
|
344
|
+
static get schema() {
|
|
345
|
+
return z.object({
|
|
346
|
+
hintKey: AppendOnlyTreeSnapshot.schema,
|
|
347
|
+
stateAfter: AppendOnlyTreeSnapshot.schema,
|
|
348
|
+
treeId: z.number().int().nonnegative(),
|
|
349
|
+
leaf: klass.leafSchema,
|
|
350
|
+
lowLeavesWitnessData: z.object({
|
|
351
|
+
leaf: klass.schema,
|
|
352
|
+
index: schemas.BigInt,
|
|
353
|
+
path: schemas.Fr.array()
|
|
354
|
+
}),
|
|
355
|
+
insertionWitnessData: z.object({
|
|
356
|
+
leaf: klass.schema,
|
|
357
|
+
index: schemas.BigInt,
|
|
358
|
+
path: schemas.Fr.array()
|
|
359
|
+
})
|
|
360
|
+
}).transform(({ hintKey, stateAfter, treeId, leaf, lowLeavesWitnessData, insertionWitnessData })=>new this(hintKey, stateAfter, treeId, leaf, lowLeavesWitnessData, insertionWitnessData));
|
|
361
|
+
}
|
|
362
|
+
/**
|
|
363
|
+
* Creates an instance from a plain object without Zod validation.
|
|
364
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
365
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
366
|
+
* @param obj - Plain object containing hint fields
|
|
367
|
+
* @returns An instance
|
|
368
|
+
*/ static fromPlainObject(obj) {
|
|
369
|
+
if (obj instanceof this) {
|
|
370
|
+
return obj;
|
|
371
|
+
}
|
|
372
|
+
// Determine the leaf class based on the klass parameter
|
|
373
|
+
const LeafClass = klass === PublicDataTreeLeafPreimage ? PublicDataTreeLeaf : NullifierLeaf;
|
|
374
|
+
return new this(AppendOnlyTreeSnapshot.fromPlainObject(obj.hintKey), AppendOnlyTreeSnapshot.fromPlainObject(obj.stateAfter), obj.treeId, LeafClass.fromPlainObject(obj.leaf), {
|
|
375
|
+
leaf: klass.fromPlainObject(obj.lowLeavesWitnessData.leaf),
|
|
376
|
+
index: typeof obj.lowLeavesWitnessData.index === 'bigint' ? obj.lowLeavesWitnessData.index : BigInt(obj.lowLeavesWitnessData.index),
|
|
377
|
+
path: obj.lowLeavesWitnessData.path.map((p)=>Fr.fromPlainObject(p))
|
|
378
|
+
}, {
|
|
379
|
+
leaf: klass.fromPlainObject(obj.insertionWitnessData.leaf),
|
|
380
|
+
index: typeof obj.insertionWitnessData.index === 'bigint' ? obj.insertionWitnessData.index : BigInt(obj.insertionWitnessData.index),
|
|
381
|
+
path: obj.insertionWitnessData.path.map((p)=>Fr.fromPlainObject(p))
|
|
382
|
+
});
|
|
383
|
+
}
|
|
384
|
+
};
|
|
120
385
|
}
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
386
|
+
// Note: only supported for PUBLIC_DATA_TREE and NULLIFIER_TREE.
|
|
387
|
+
export class AvmSequentialInsertHintPublicDataTree extends AvmSequentialInsertHintFactory(PublicDataTreeLeafPreimage) {
|
|
388
|
+
}
|
|
389
|
+
export class AvmSequentialInsertHintNullifierTree extends AvmSequentialInsertHintFactory(NullifierLeafPreimage) {
|
|
390
|
+
}
|
|
391
|
+
// Hint for MerkleTreeDB.appendLeaves.
|
|
392
|
+
// Note: only supported for NOTE_HASH_TREE and L1_TO_L2_MESSAGE_TREE.
|
|
393
|
+
export class AvmAppendLeavesHint {
|
|
394
|
+
hintKey;
|
|
395
|
+
stateAfter;
|
|
396
|
+
treeId;
|
|
397
|
+
leaves;
|
|
398
|
+
constructor(hintKey, stateAfter, // params
|
|
399
|
+
treeId, leaves){
|
|
400
|
+
this.hintKey = hintKey;
|
|
401
|
+
this.stateAfter = stateAfter;
|
|
402
|
+
this.treeId = treeId;
|
|
403
|
+
this.leaves = leaves;
|
|
129
404
|
}
|
|
130
405
|
static get schema() {
|
|
131
406
|
return z.object({
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
407
|
+
hintKey: AppendOnlyTreeSnapshot.schema,
|
|
408
|
+
stateAfter: AppendOnlyTreeSnapshot.schema,
|
|
409
|
+
treeId: z.number().int().nonnegative(),
|
|
410
|
+
leaves: schemas.Fr.array()
|
|
411
|
+
}).transform(({ hintKey, stateAfter, treeId, leaves })=>new AvmAppendLeavesHint(hintKey, stateAfter, treeId, leaves));
|
|
412
|
+
}
|
|
413
|
+
/**
|
|
414
|
+
* Creates an AvmAppendLeavesHint from a plain object without Zod validation.
|
|
415
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
416
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
417
|
+
* @param obj - Plain object containing AvmAppendLeavesHint fields
|
|
418
|
+
* @returns An AvmAppendLeavesHint instance
|
|
419
|
+
*/ static fromPlainObject(obj) {
|
|
420
|
+
if (obj instanceof AvmAppendLeavesHint) {
|
|
421
|
+
return obj;
|
|
422
|
+
}
|
|
423
|
+
return new AvmAppendLeavesHint(AppendOnlyTreeSnapshot.fromPlainObject(obj.hintKey), AppendOnlyTreeSnapshot.fromPlainObject(obj.stateAfter), obj.treeId, obj.leaves.map((l)=>Fr.fromPlainObject(l)));
|
|
136
424
|
}
|
|
137
425
|
}
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
426
|
+
// Hint for checkpoint actions that don't change the state.
|
|
427
|
+
class AvmCheckpointActionNoStateChangeHint {
|
|
428
|
+
actionCounter;
|
|
429
|
+
oldCheckpointId;
|
|
430
|
+
newCheckpointId;
|
|
431
|
+
constructor(// key
|
|
432
|
+
actionCounter, // current checkpoint evolution
|
|
433
|
+
oldCheckpointId, newCheckpointId){
|
|
434
|
+
this.actionCounter = actionCounter;
|
|
435
|
+
this.oldCheckpointId = oldCheckpointId;
|
|
436
|
+
this.newCheckpointId = newCheckpointId;
|
|
146
437
|
}
|
|
147
|
-
static
|
|
148
|
-
return
|
|
438
|
+
static get schema() {
|
|
439
|
+
return z.object({
|
|
440
|
+
actionCounter: z.number().int().nonnegative(),
|
|
441
|
+
oldCheckpointId: z.number().int().nonnegative(),
|
|
442
|
+
newCheckpointId: z.number().int().nonnegative()
|
|
443
|
+
}).transform(({ actionCounter, oldCheckpointId, newCheckpointId })=>new this(actionCounter, oldCheckpointId, newCheckpointId));
|
|
444
|
+
}
|
|
445
|
+
/**
|
|
446
|
+
* Creates an instance from a plain object without Zod validation.
|
|
447
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
448
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
449
|
+
* @param obj - Plain object containing hint fields
|
|
450
|
+
* @returns An instance
|
|
451
|
+
*/ static fromPlainObject(obj) {
|
|
452
|
+
if (obj instanceof this) {
|
|
453
|
+
return obj;
|
|
454
|
+
}
|
|
455
|
+
return new this(obj.actionCounter, obj.oldCheckpointId, obj.newCheckpointId);
|
|
456
|
+
}
|
|
457
|
+
}
|
|
458
|
+
// Hint for MerkleTreeDB.createCheckpoint.
|
|
459
|
+
export class AvmCreateCheckpointHint extends AvmCheckpointActionNoStateChangeHint {
|
|
460
|
+
}
|
|
461
|
+
// Hint for MerkleTreeDB.commitCheckpoint.
|
|
462
|
+
export class AvmCommitCheckpointHint extends AvmCheckpointActionNoStateChangeHint {
|
|
463
|
+
}
|
|
464
|
+
// Hint for MerkleTreeDB.revertCheckpoint.
|
|
465
|
+
export class AvmRevertCheckpointHint {
|
|
466
|
+
actionCounter;
|
|
467
|
+
oldCheckpointId;
|
|
468
|
+
newCheckpointId;
|
|
469
|
+
stateBefore;
|
|
470
|
+
stateAfter;
|
|
471
|
+
// We use explicit fields for MessagePack.
|
|
472
|
+
constructor(// key
|
|
473
|
+
actionCounter, // current checkpoint evolution
|
|
474
|
+
oldCheckpointId, newCheckpointId, // state evolution
|
|
475
|
+
stateBefore, stateAfter){
|
|
476
|
+
this.actionCounter = actionCounter;
|
|
477
|
+
this.oldCheckpointId = oldCheckpointId;
|
|
478
|
+
this.newCheckpointId = newCheckpointId;
|
|
479
|
+
this.stateBefore = stateBefore;
|
|
480
|
+
this.stateAfter = stateAfter;
|
|
481
|
+
}
|
|
482
|
+
static create(actionCounter, oldCheckpointId, newCheckpointId, stateBefore, stateAfter) {
|
|
483
|
+
return new AvmRevertCheckpointHint(actionCounter, oldCheckpointId, newCheckpointId, new TreeSnapshots(stateBefore[MerkleTreeId.L1_TO_L2_MESSAGE_TREE], stateBefore[MerkleTreeId.NOTE_HASH_TREE], stateBefore[MerkleTreeId.NULLIFIER_TREE], stateBefore[MerkleTreeId.PUBLIC_DATA_TREE]), new TreeSnapshots(stateAfter[MerkleTreeId.L1_TO_L2_MESSAGE_TREE], stateAfter[MerkleTreeId.NOTE_HASH_TREE], stateAfter[MerkleTreeId.NULLIFIER_TREE], stateAfter[MerkleTreeId.PUBLIC_DATA_TREE]));
|
|
149
484
|
}
|
|
150
485
|
static get schema() {
|
|
151
486
|
return z.object({
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
487
|
+
actionCounter: z.number().int().nonnegative(),
|
|
488
|
+
oldCheckpointId: z.number().int().nonnegative(),
|
|
489
|
+
newCheckpointId: z.number().int().nonnegative(),
|
|
490
|
+
stateBefore: TreeSnapshots.schema,
|
|
491
|
+
stateAfter: TreeSnapshots.schema
|
|
492
|
+
}).transform(({ actionCounter, oldCheckpointId, newCheckpointId, stateBefore, stateAfter })=>new AvmRevertCheckpointHint(actionCounter, oldCheckpointId, newCheckpointId, stateBefore, stateAfter));
|
|
156
493
|
}
|
|
494
|
+
/**
|
|
495
|
+
* Creates an AvmRevertCheckpointHint from a plain object without Zod validation.
|
|
496
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
497
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
498
|
+
* @param obj - Plain object containing AvmRevertCheckpointHint fields
|
|
499
|
+
* @returns An AvmRevertCheckpointHint instance
|
|
500
|
+
*/ static fromPlainObject(obj) {
|
|
501
|
+
if (obj instanceof AvmRevertCheckpointHint) {
|
|
502
|
+
return obj;
|
|
503
|
+
}
|
|
504
|
+
return new AvmRevertCheckpointHint(obj.actionCounter, obj.oldCheckpointId, obj.newCheckpointId, TreeSnapshots.fromPlainObject(obj.stateBefore), TreeSnapshots.fromPlainObject(obj.stateAfter));
|
|
505
|
+
}
|
|
506
|
+
}
|
|
507
|
+
export class AvmContractDbCreateCheckpointHint extends AvmCheckpointActionNoStateChangeHint {
|
|
508
|
+
}
|
|
509
|
+
export class AvmContractDbCommitCheckpointHint extends AvmCheckpointActionNoStateChangeHint {
|
|
510
|
+
}
|
|
511
|
+
export class AvmContractDbRevertCheckpointHint extends AvmCheckpointActionNoStateChangeHint {
|
|
157
512
|
}
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
513
|
+
////////////////////////////////////////////////////////////////////////////
|
|
514
|
+
// Hints (other)
|
|
515
|
+
////////////////////////////////////////////////////////////////////////////
|
|
516
|
+
export class AvmTxHint {
|
|
517
|
+
hash;
|
|
518
|
+
gasSettings;
|
|
519
|
+
effectiveGasFees;
|
|
520
|
+
nonRevertibleContractDeploymentData;
|
|
521
|
+
revertibleContractDeploymentData;
|
|
522
|
+
nonRevertibleAccumulatedData;
|
|
523
|
+
revertibleAccumulatedData;
|
|
524
|
+
setupEnqueuedCalls;
|
|
525
|
+
appLogicEnqueuedCalls;
|
|
526
|
+
teardownEnqueuedCall;
|
|
527
|
+
gasUsedByPrivate;
|
|
528
|
+
feePayer;
|
|
529
|
+
constructor(hash, gasSettings, effectiveGasFees, nonRevertibleContractDeploymentData, revertibleContractDeploymentData, nonRevertibleAccumulatedData, revertibleAccumulatedData, setupEnqueuedCalls, appLogicEnqueuedCalls, // We need this to be null and not undefined because that's what
|
|
530
|
+
// MessagePack expects for an std::optional.
|
|
531
|
+
teardownEnqueuedCall, gasUsedByPrivate, feePayer){
|
|
532
|
+
this.hash = hash;
|
|
533
|
+
this.gasSettings = gasSettings;
|
|
534
|
+
this.effectiveGasFees = effectiveGasFees;
|
|
535
|
+
this.nonRevertibleContractDeploymentData = nonRevertibleContractDeploymentData;
|
|
536
|
+
this.revertibleContractDeploymentData = revertibleContractDeploymentData;
|
|
537
|
+
this.nonRevertibleAccumulatedData = nonRevertibleAccumulatedData;
|
|
538
|
+
this.revertibleAccumulatedData = revertibleAccumulatedData;
|
|
539
|
+
this.setupEnqueuedCalls = setupEnqueuedCalls;
|
|
540
|
+
this.appLogicEnqueuedCalls = appLogicEnqueuedCalls;
|
|
541
|
+
this.teardownEnqueuedCall = teardownEnqueuedCall;
|
|
542
|
+
this.gasUsedByPrivate = gasUsedByPrivate;
|
|
543
|
+
this.feePayer = feePayer;
|
|
544
|
+
}
|
|
545
|
+
static fromTx(tx, gasFees) {
|
|
546
|
+
const setupCallRequests = tx.getNonRevertiblePublicCallRequestsWithCalldata();
|
|
547
|
+
const appLogicCallRequests = tx.getRevertiblePublicCallRequestsWithCalldata();
|
|
548
|
+
const teardownCallRequest = tx.getTeardownPublicCallRequestWithCalldata();
|
|
549
|
+
const gasSettings = tx.data.constants.txContext.gasSettings;
|
|
550
|
+
const effectiveGasFees = computeEffectiveGasFees(gasFees, gasSettings);
|
|
551
|
+
const allContractDeploymentData = AllContractDeploymentData.fromTx(tx);
|
|
552
|
+
// For informational purposes. Assumed quick because it should be cached.
|
|
553
|
+
const txHash = tx.getTxHash();
|
|
554
|
+
return new AvmTxHint(txHash.hash.toString(), gasSettings, effectiveGasFees, allContractDeploymentData.getNonRevertibleContractDeploymentData(), allContractDeploymentData.getRevertibleContractDeploymentData(), {
|
|
555
|
+
noteHashes: tx.data.forPublic.nonRevertibleAccumulatedData.noteHashes.filter((x)=>!x.isZero()),
|
|
556
|
+
nullifiers: tx.data.forPublic.nonRevertibleAccumulatedData.nullifiers.filter((x)=>!x.isZero()),
|
|
557
|
+
l2ToL1Messages: tx.data.forPublic.nonRevertibleAccumulatedData.l2ToL1Msgs.filter((x)=>!x.isEmpty())
|
|
558
|
+
}, {
|
|
559
|
+
noteHashes: tx.data.forPublic.revertibleAccumulatedData.noteHashes.filter((x)=>!x.isZero()),
|
|
560
|
+
nullifiers: tx.data.forPublic.revertibleAccumulatedData.nullifiers.filter((x)=>!x.isZero()),
|
|
561
|
+
l2ToL1Messages: tx.data.forPublic.revertibleAccumulatedData.l2ToL1Msgs.filter((x)=>!x.isEmpty())
|
|
562
|
+
}, setupCallRequests, appLogicCallRequests, teardownCallRequest ?? null, tx.data.gasUsed, tx.data.feePayer);
|
|
563
|
+
}
|
|
564
|
+
static empty() {
|
|
565
|
+
return new AvmTxHint('', GasSettings.empty(), GasFees.empty(), ContractDeploymentData.empty(), ContractDeploymentData.empty(), {
|
|
566
|
+
noteHashes: [],
|
|
567
|
+
nullifiers: [],
|
|
568
|
+
l2ToL1Messages: []
|
|
569
|
+
}, {
|
|
570
|
+
noteHashes: [],
|
|
571
|
+
nullifiers: [],
|
|
572
|
+
l2ToL1Messages: []
|
|
573
|
+
}, [], [], null, Gas.empty(), AztecAddress.zero());
|
|
574
|
+
}
|
|
575
|
+
/**
|
|
576
|
+
* Creates an AvmTxHint from a plain object without Zod validation.
|
|
577
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
578
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
579
|
+
* @param obj - Plain object containing AvmTxHint fields
|
|
580
|
+
* @returns An AvmTxHint instance
|
|
581
|
+
*/ static fromPlainObject(obj) {
|
|
582
|
+
if (obj instanceof AvmTxHint) {
|
|
583
|
+
return obj;
|
|
584
|
+
}
|
|
585
|
+
return new AvmTxHint(obj.hash, GasSettings.fromPlainObject(obj.gasSettings), GasFees.fromPlainObject(obj.effectiveGasFees), ContractDeploymentData.fromPlainObject(obj.nonRevertibleContractDeploymentData), ContractDeploymentData.fromPlainObject(obj.revertibleContractDeploymentData), {
|
|
586
|
+
noteHashes: obj.nonRevertibleAccumulatedData.noteHashes.map((h)=>Fr.fromPlainObject(h)),
|
|
587
|
+
nullifiers: obj.nonRevertibleAccumulatedData.nullifiers.map((n)=>Fr.fromPlainObject(n)),
|
|
588
|
+
l2ToL1Messages: obj.nonRevertibleAccumulatedData.l2ToL1Messages.map((m)=>ScopedL2ToL1Message.fromPlainObject(m))
|
|
589
|
+
}, {
|
|
590
|
+
noteHashes: obj.revertibleAccumulatedData.noteHashes.map((h)=>Fr.fromPlainObject(h)),
|
|
591
|
+
nullifiers: obj.revertibleAccumulatedData.nullifiers.map((n)=>Fr.fromPlainObject(n)),
|
|
592
|
+
l2ToL1Messages: obj.revertibleAccumulatedData.l2ToL1Messages.map((m)=>ScopedL2ToL1Message.fromPlainObject(m))
|
|
593
|
+
}, obj.setupEnqueuedCalls.map((c)=>PublicCallRequestWithCalldata.fromPlainObject(c)), obj.appLogicEnqueuedCalls.map((c)=>PublicCallRequestWithCalldata.fromPlainObject(c)), obj.teardownEnqueuedCall ? PublicCallRequestWithCalldata.fromPlainObject(obj.teardownEnqueuedCall) : null, Gas.fromPlainObject(obj.gasUsedByPrivate), AztecAddress.fromPlainObject(obj.feePayer));
|
|
167
594
|
}
|
|
168
595
|
static get schema() {
|
|
169
596
|
return z.object({
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
597
|
+
hash: z.string(),
|
|
598
|
+
gasSettings: GasSettings.schema,
|
|
599
|
+
effectiveGasFees: GasFees.schema,
|
|
600
|
+
nonRevertibleContractDeploymentData: ContractDeploymentData.schema,
|
|
601
|
+
revertibleContractDeploymentData: ContractDeploymentData.schema,
|
|
602
|
+
nonRevertibleAccumulatedData: z.object({
|
|
603
|
+
noteHashes: schemas.Fr.array(),
|
|
604
|
+
nullifiers: schemas.Fr.array(),
|
|
605
|
+
l2ToL1Messages: ScopedL2ToL1Message.schema.array()
|
|
606
|
+
}),
|
|
607
|
+
revertibleAccumulatedData: z.object({
|
|
608
|
+
noteHashes: schemas.Fr.array(),
|
|
609
|
+
nullifiers: schemas.Fr.array(),
|
|
610
|
+
l2ToL1Messages: ScopedL2ToL1Message.schema.array()
|
|
611
|
+
}),
|
|
612
|
+
setupEnqueuedCalls: PublicCallRequestWithCalldata.schema.array(),
|
|
613
|
+
appLogicEnqueuedCalls: PublicCallRequestWithCalldata.schema.array(),
|
|
614
|
+
teardownEnqueuedCall: PublicCallRequestWithCalldata.schema.nullable(),
|
|
615
|
+
gasUsedByPrivate: Gas.schema,
|
|
616
|
+
feePayer: AztecAddress.schema
|
|
617
|
+
}).transform(({ hash, gasSettings, effectiveGasFees, nonRevertibleContractDeploymentData, revertibleContractDeploymentData, nonRevertibleAccumulatedData, revertibleAccumulatedData, setupEnqueuedCalls, appLogicEnqueuedCalls, teardownEnqueuedCall, gasUsedByPrivate, feePayer })=>new AvmTxHint(hash, gasSettings, effectiveGasFees, nonRevertibleContractDeploymentData, revertibleContractDeploymentData, nonRevertibleAccumulatedData, revertibleAccumulatedData, setupEnqueuedCalls, appLogicEnqueuedCalls, teardownEnqueuedCall, gasUsedByPrivate, feePayer));
|
|
174
618
|
}
|
|
175
619
|
}
|
|
176
620
|
export class AvmExecutionHints {
|
|
177
|
-
|
|
621
|
+
globalVariables;
|
|
622
|
+
tx;
|
|
623
|
+
protocolContracts;
|
|
178
624
|
contractInstances;
|
|
179
625
|
contractClasses;
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
626
|
+
bytecodeCommitments;
|
|
627
|
+
debugFunctionNames;
|
|
628
|
+
contractDbCreateCheckpointHints;
|
|
629
|
+
contractDbCommitCheckpointHints;
|
|
630
|
+
contractDbRevertCheckpointHints;
|
|
631
|
+
startingTreeRoots;
|
|
632
|
+
getSiblingPathHints;
|
|
633
|
+
getPreviousValueIndexHints;
|
|
634
|
+
getLeafPreimageHintsPublicDataTree;
|
|
635
|
+
getLeafPreimageHintsNullifierTree;
|
|
636
|
+
getLeafValueHints;
|
|
637
|
+
sequentialInsertHintsPublicDataTree;
|
|
638
|
+
sequentialInsertHintsNullifierTree;
|
|
639
|
+
appendLeavesHints;
|
|
640
|
+
createCheckpointHints;
|
|
641
|
+
commitCheckpointHints;
|
|
642
|
+
revertCheckpointHints;
|
|
643
|
+
constructor(globalVariables, tx, // Protocol contracts.
|
|
644
|
+
protocolContracts, // Contract hints.
|
|
645
|
+
contractInstances = [], contractClasses = [], bytecodeCommitments = [], debugFunctionNames = [], contractDbCreateCheckpointHints = [], contractDbCommitCheckpointHints = [], contractDbRevertCheckpointHints = [], // Merkle DB hints.
|
|
646
|
+
startingTreeRoots = TreeSnapshots.empty(), getSiblingPathHints = [], getPreviousValueIndexHints = [], getLeafPreimageHintsPublicDataTree = [], getLeafPreimageHintsNullifierTree = [], getLeafValueHints = [], sequentialInsertHintsPublicDataTree = [], sequentialInsertHintsNullifierTree = [], appendLeavesHints = [], createCheckpointHints = [], commitCheckpointHints = [], revertCheckpointHints = []){
|
|
647
|
+
this.globalVariables = globalVariables;
|
|
648
|
+
this.tx = tx;
|
|
649
|
+
this.protocolContracts = protocolContracts;
|
|
189
650
|
this.contractInstances = contractInstances;
|
|
190
651
|
this.contractClasses = contractClasses;
|
|
191
|
-
this.
|
|
192
|
-
this.
|
|
193
|
-
this.
|
|
194
|
-
this.
|
|
195
|
-
this.
|
|
196
|
-
this.
|
|
197
|
-
this.
|
|
652
|
+
this.bytecodeCommitments = bytecodeCommitments;
|
|
653
|
+
this.debugFunctionNames = debugFunctionNames;
|
|
654
|
+
this.contractDbCreateCheckpointHints = contractDbCreateCheckpointHints;
|
|
655
|
+
this.contractDbCommitCheckpointHints = contractDbCommitCheckpointHints;
|
|
656
|
+
this.contractDbRevertCheckpointHints = contractDbRevertCheckpointHints;
|
|
657
|
+
this.startingTreeRoots = startingTreeRoots;
|
|
658
|
+
this.getSiblingPathHints = getSiblingPathHints;
|
|
659
|
+
this.getPreviousValueIndexHints = getPreviousValueIndexHints;
|
|
660
|
+
this.getLeafPreimageHintsPublicDataTree = getLeafPreimageHintsPublicDataTree;
|
|
661
|
+
this.getLeafPreimageHintsNullifierTree = getLeafPreimageHintsNullifierTree;
|
|
662
|
+
this.getLeafValueHints = getLeafValueHints;
|
|
663
|
+
this.sequentialInsertHintsPublicDataTree = sequentialInsertHintsPublicDataTree;
|
|
664
|
+
this.sequentialInsertHintsNullifierTree = sequentialInsertHintsNullifierTree;
|
|
665
|
+
this.appendLeavesHints = appendLeavesHints;
|
|
666
|
+
this.createCheckpointHints = createCheckpointHints;
|
|
667
|
+
this.commitCheckpointHints = commitCheckpointHints;
|
|
668
|
+
this.revertCheckpointHints = revertCheckpointHints;
|
|
669
|
+
}
|
|
670
|
+
/**
|
|
671
|
+
* Creates an AvmExecutionHints from a plain object without Zod validation.
|
|
672
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
673
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
674
|
+
* @param obj - Plain object containing AvmExecutionHints fields
|
|
675
|
+
* @returns An AvmExecutionHints instance
|
|
676
|
+
*/ static fromPlainObject(obj) {
|
|
677
|
+
if (obj instanceof AvmExecutionHints) {
|
|
678
|
+
return obj;
|
|
679
|
+
}
|
|
680
|
+
return new AvmExecutionHints(GlobalVariables.fromPlainObject(obj.globalVariables), AvmTxHint.fromPlainObject(obj.tx), ProtocolContracts.fromPlainObject(obj.protocolContracts), obj.contractInstances?.map((i)=>AvmContractInstanceHint.fromPlainObject(i)) || [], obj.contractClasses?.map((c)=>AvmContractClassHint.fromPlainObject(c)) || [], obj.bytecodeCommitments?.map((b)=>AvmBytecodeCommitmentHint.fromPlainObject(b)) || [], obj.debugFunctionNames?.map((d)=>AvmDebugFunctionNameHint.fromPlainObject(d)) || [], obj.contractDbCreateCheckpointHints?.map((h)=>AvmContractDbCreateCheckpointHint.fromPlainObject(h)) || [], obj.contractDbCommitCheckpointHints?.map((h)=>AvmContractDbCommitCheckpointHint.fromPlainObject(h)) || [], obj.contractDbRevertCheckpointHints?.map((h)=>AvmContractDbRevertCheckpointHint.fromPlainObject(h)) || [], obj.startingTreeRoots ? TreeSnapshots.fromPlainObject(obj.startingTreeRoots) : TreeSnapshots.empty(), obj.getSiblingPathHints?.map((h)=>AvmGetSiblingPathHint.fromPlainObject(h)) || [], obj.getPreviousValueIndexHints?.map((h)=>AvmGetPreviousValueIndexHint.fromPlainObject(h)) || [], obj.getLeafPreimageHintsPublicDataTree?.map((h)=>AvmGetLeafPreimageHintPublicDataTree.fromPlainObject(h)) || [], obj.getLeafPreimageHintsNullifierTree?.map((h)=>AvmGetLeafPreimageHintNullifierTree.fromPlainObject(h)) || [], obj.getLeafValueHints?.map((h)=>AvmGetLeafValueHint.fromPlainObject(h)) || [], obj.sequentialInsertHintsPublicDataTree?.map((h)=>AvmSequentialInsertHintPublicDataTree.fromPlainObject(h)) || [], obj.sequentialInsertHintsNullifierTree?.map((h)=>AvmSequentialInsertHintNullifierTree.fromPlainObject(h)) || [], obj.appendLeavesHints?.map((h)=>AvmAppendLeavesHint.fromPlainObject(h)) || [], obj.createCheckpointHints?.map((h)=>AvmCreateCheckpointHint.fromPlainObject(h)) || [], obj.commitCheckpointHints?.map((h)=>AvmCommitCheckpointHint.fromPlainObject(h)) || [], obj.revertCheckpointHints?.map((h)=>AvmRevertCheckpointHint.fromPlainObject(h)) || []);
|
|
198
681
|
}
|
|
199
682
|
static empty() {
|
|
200
|
-
return new AvmExecutionHints(
|
|
683
|
+
return new AvmExecutionHints(GlobalVariables.empty(), AvmTxHint.empty(), ProtocolContracts.empty());
|
|
201
684
|
}
|
|
202
685
|
static get schema() {
|
|
203
686
|
return z.object({
|
|
204
|
-
|
|
687
|
+
globalVariables: GlobalVariables.schema,
|
|
688
|
+
tx: AvmTxHint.schema,
|
|
689
|
+
protocolContracts: ProtocolContracts.schema,
|
|
205
690
|
contractInstances: AvmContractInstanceHint.schema.array(),
|
|
206
691
|
contractClasses: AvmContractClassHint.schema.array(),
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
692
|
+
bytecodeCommitments: AvmBytecodeCommitmentHint.schema.array(),
|
|
693
|
+
debugFunctionNames: AvmDebugFunctionNameHint.schema.array(),
|
|
694
|
+
contractDbCreateCheckpointHints: AvmContractDbCreateCheckpointHint.schema.array(),
|
|
695
|
+
contractDbCommitCheckpointHints: AvmContractDbCommitCheckpointHint.schema.array(),
|
|
696
|
+
contractDbRevertCheckpointHints: AvmContractDbRevertCheckpointHint.schema.array(),
|
|
697
|
+
startingTreeRoots: TreeSnapshots.schema,
|
|
698
|
+
getSiblingPathHints: AvmGetSiblingPathHint.schema.array(),
|
|
699
|
+
getPreviousValueIndexHints: AvmGetPreviousValueIndexHint.schema.array(),
|
|
700
|
+
getLeafPreimageHintsPublicDataTree: AvmGetLeafPreimageHintPublicDataTree.schema.array(),
|
|
701
|
+
getLeafPreimageHintsNullifierTree: AvmGetLeafPreimageHintNullifierTree.schema.array(),
|
|
702
|
+
getLeafValueHints: AvmGetLeafValueHint.schema.array(),
|
|
703
|
+
sequentialInsertHintsPublicDataTree: AvmSequentialInsertHintPublicDataTree.schema.array(),
|
|
704
|
+
sequentialInsertHintsNullifierTree: AvmSequentialInsertHintNullifierTree.schema.array(),
|
|
705
|
+
appendLeavesHints: AvmAppendLeavesHint.schema.array(),
|
|
706
|
+
createCheckpointHints: AvmCreateCheckpointHint.schema.array(),
|
|
707
|
+
commitCheckpointHints: AvmCommitCheckpointHint.schema.array(),
|
|
708
|
+
revertCheckpointHints: AvmRevertCheckpointHint.schema.array()
|
|
709
|
+
}).transform(({ globalVariables, tx, protocolContracts, contractInstances, contractClasses, bytecodeCommitments, debugFunctionNames, contractDbCreateCheckpointHints, contractDbCommitCheckpointHints, contractDbRevertCheckpointHints, startingTreeRoots, getSiblingPathHints, getPreviousValueIndexHints, getLeafPreimageHintsPublicDataTree, getLeafPreimageHintsNullifierTree, getLeafValueHints, sequentialInsertHintsPublicDataTree, sequentialInsertHintsNullifierTree, appendLeavesHints, createCheckpointHints, commitCheckpointHints, revertCheckpointHints })=>new AvmExecutionHints(globalVariables, tx, protocolContracts, contractInstances, contractClasses, bytecodeCommitments, debugFunctionNames, contractDbCreateCheckpointHints, contractDbCommitCheckpointHints, contractDbRevertCheckpointHints, startingTreeRoots, getSiblingPathHints, getPreviousValueIndexHints, getLeafPreimageHintsPublicDataTree, getLeafPreimageHintsNullifierTree, getLeafValueHints, sequentialInsertHintsPublicDataTree, sequentialInsertHintsNullifierTree, appendLeavesHints, createCheckpointHints, commitCheckpointHints, revertCheckpointHints));
|
|
215
710
|
}
|
|
216
711
|
}
|
|
217
712
|
export class AvmCircuitInputs {
|
|
218
|
-
functionName;
|
|
219
|
-
calldata;
|
|
220
713
|
hints;
|
|
221
714
|
publicInputs;
|
|
222
|
-
constructor(
|
|
223
|
-
this.functionName = functionName;
|
|
224
|
-
this.calldata = calldata;
|
|
715
|
+
constructor(hints, publicInputs){
|
|
225
716
|
this.hints = hints;
|
|
226
717
|
this.publicInputs = publicInputs;
|
|
227
718
|
}
|
|
228
719
|
static empty() {
|
|
229
|
-
return new AvmCircuitInputs(
|
|
720
|
+
return new AvmCircuitInputs(AvmExecutionHints.empty(), AvmCircuitPublicInputs.empty());
|
|
721
|
+
}
|
|
722
|
+
static fromPlainObject(obj) {
|
|
723
|
+
return new AvmCircuitInputs(AvmExecutionHints.fromPlainObject(obj.hints), AvmCircuitPublicInputs.fromPlainObject(obj.publicInputs));
|
|
230
724
|
}
|
|
231
725
|
static get schema() {
|
|
232
726
|
return z.object({
|
|
233
|
-
functionName: z.string(),
|
|
234
|
-
calldata: schemas.Fr.array(),
|
|
235
727
|
hints: AvmExecutionHints.schema,
|
|
236
728
|
publicInputs: AvmCircuitPublicInputs.schema
|
|
237
|
-
}).transform(({
|
|
729
|
+
}).transform(({ hints, publicInputs })=>new AvmCircuitInputs(hints, publicInputs));
|
|
238
730
|
}
|
|
239
731
|
serializeWithMessagePack() {
|
|
240
732
|
return serializeWithMessagePack(this);
|
|
@@ -247,3 +739,326 @@ export class AvmCircuitInputs {
|
|
|
247
739
|
return jsonParseWithSchema(buf.toString(), this.schema);
|
|
248
740
|
}
|
|
249
741
|
}
|
|
742
|
+
// Metadata about a given (enqueued or external) call.
|
|
743
|
+
export class CallStackMetadata {
|
|
744
|
+
phase;
|
|
745
|
+
contractAddress;
|
|
746
|
+
callerPc;
|
|
747
|
+
calldata;
|
|
748
|
+
isStaticCall;
|
|
749
|
+
gasLimit;
|
|
750
|
+
output;
|
|
751
|
+
internalCallStackAtExit;
|
|
752
|
+
haltingMessage;
|
|
753
|
+
reverted;
|
|
754
|
+
nested;
|
|
755
|
+
numNestedCalls;
|
|
756
|
+
constructor(phase, contractAddress, callerPc, calldata, isStaticCall, gasLimit, output, internalCallStackAtExit, haltingMessage, reverted, nested, numNestedCalls){
|
|
757
|
+
this.phase = phase;
|
|
758
|
+
this.contractAddress = contractAddress;
|
|
759
|
+
this.callerPc = callerPc;
|
|
760
|
+
this.calldata = calldata;
|
|
761
|
+
this.isStaticCall = isStaticCall;
|
|
762
|
+
this.gasLimit = gasLimit;
|
|
763
|
+
this.output = output;
|
|
764
|
+
this.internalCallStackAtExit = internalCallStackAtExit;
|
|
765
|
+
this.haltingMessage = haltingMessage;
|
|
766
|
+
this.reverted = reverted;
|
|
767
|
+
this.nested = nested;
|
|
768
|
+
this.numNestedCalls = numNestedCalls;
|
|
769
|
+
}
|
|
770
|
+
static get schema() {
|
|
771
|
+
return z.object({
|
|
772
|
+
phase: z.nativeEnum(TxExecutionPhase),
|
|
773
|
+
contractAddress: Fr.schema,
|
|
774
|
+
callerPc: z.number(),
|
|
775
|
+
calldata: Fr.schema.array(),
|
|
776
|
+
isStaticCall: z.boolean(),
|
|
777
|
+
gasLimit: Gas.schema,
|
|
778
|
+
output: Fr.schema.array(),
|
|
779
|
+
internalCallStackAtExit: z.number().array(),
|
|
780
|
+
haltingMessage: NullishToUndefined(z.string()),
|
|
781
|
+
reverted: z.boolean(),
|
|
782
|
+
nested: CallStackMetadata.schema.array(),
|
|
783
|
+
numNestedCalls: z.number()
|
|
784
|
+
}).transform(({ phase, contractAddress, callerPc, calldata, isStaticCall, gasLimit, output, internalCallStackAtExit, haltingMessage, reverted, nested, numNestedCalls })=>new CallStackMetadata(phase, contractAddress, callerPc, calldata, isStaticCall, gasLimit, output, internalCallStackAtExit, haltingMessage, reverted, nested, numNestedCalls));
|
|
785
|
+
}
|
|
786
|
+
/**
|
|
787
|
+
* Creates a CallStackMetadata from a plain object without Zod validation.
|
|
788
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
789
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
790
|
+
* @param obj - Plain object containing CallStackMetadata fields
|
|
791
|
+
* @returns A CallStackMetadata instance
|
|
792
|
+
*/ static fromPlainObject(obj) {
|
|
793
|
+
if (obj instanceof CallStackMetadata) {
|
|
794
|
+
return obj;
|
|
795
|
+
}
|
|
796
|
+
return new CallStackMetadata(obj.phase, Fr.fromPlainObject(obj.contractAddress), obj.callerPc, obj.calldata.map((f)=>Fr.fromPlainObject(f)), obj.isStaticCall, Gas.fromPlainObject(obj.gasLimit), obj.output.map((f)=>Fr.fromPlainObject(f)), obj.internalCallStackAtExit.map((p)=>Number(p)), obj.haltingMessage, obj.reverted, obj.nested.map((n)=>CallStackMetadata.fromPlainObject(n)), obj.numNestedCalls);
|
|
797
|
+
}
|
|
798
|
+
getRevertReason() {
|
|
799
|
+
const failingCall = this.findDeepestRevert([
|
|
800
|
+
this
|
|
801
|
+
]);
|
|
802
|
+
if (!failingCall) {
|
|
803
|
+
return undefined;
|
|
804
|
+
}
|
|
805
|
+
const { stack, leaf } = failingCall;
|
|
806
|
+
const aztecCallStack = stack.map((call)=>({
|
|
807
|
+
contractAddress: AztecAddress.fromField(call.contractAddress),
|
|
808
|
+
functionSelector: call.calldata.length > 0 ? FunctionSelector.fromFieldOrUndefined(call.calldata[0]) : undefined
|
|
809
|
+
}));
|
|
810
|
+
// The Noir call stack is the internal call stack at exit of the failing call
|
|
811
|
+
const noirCallStack = leaf.internalCallStackAtExit.map((pc)=>`0.${pc}`);
|
|
812
|
+
return new SimulationError(leaf.haltingMessage ?? 'Transaction reverted', aztecCallStack, leaf.output, noirCallStack);
|
|
813
|
+
}
|
|
814
|
+
/**
|
|
815
|
+
* Finds the "rightmost deepest" revert in the call tree.
|
|
816
|
+
*
|
|
817
|
+
* At each level, we select the LAST (rightmost) reverted call, then recurse into its
|
|
818
|
+
* nested calls to find the deepest reverted leaf along that path. The chain stops
|
|
819
|
+
* when we encounter a non-reverted call (since you can choose not to rethrow).
|
|
820
|
+
*
|
|
821
|
+
* Examples (X = reverted, O = passed):
|
|
822
|
+
*
|
|
823
|
+
* 1. [X, X, X] at depth 1 -> returns the last X (rightmost)
|
|
824
|
+
*
|
|
825
|
+
* 2. [X(depth2), X, X] where first X has a nested revert -> returns the last X at depth 1,
|
|
826
|
+
* NOT the deeper revert in the first X (rightmost takes priority over depth)
|
|
827
|
+
*
|
|
828
|
+
* 3. X -> X -> X -> O -> O -> X (nested chain)
|
|
829
|
+
* Returns the 3rd X, because the O's break the reverted chain (they didn't rethrow)
|
|
830
|
+
*
|
|
831
|
+
* @param calls - Array of call metadata at the current level
|
|
832
|
+
* @param parentStack - Accumulated stack of parent calls (for building the result)
|
|
833
|
+
* @returns The deepest reverted call along the rightmost reverted path, or undefined if none
|
|
834
|
+
*/ findDeepestRevert(calls, parentStack = []) {
|
|
835
|
+
const lastReverted = calls.findLast((call)=>call.reverted);
|
|
836
|
+
if (!lastReverted) {
|
|
837
|
+
return undefined;
|
|
838
|
+
}
|
|
839
|
+
const currentStack = [
|
|
840
|
+
...parentStack,
|
|
841
|
+
lastReverted
|
|
842
|
+
];
|
|
843
|
+
return this.findDeepestRevert(lastReverted.nested, currentStack) || {
|
|
844
|
+
stack: currentStack,
|
|
845
|
+
leaf: lastReverted
|
|
846
|
+
};
|
|
847
|
+
}
|
|
848
|
+
}
|
|
849
|
+
export class PublicTxEffect {
|
|
850
|
+
transactionFee;
|
|
851
|
+
noteHashes;
|
|
852
|
+
nullifiers;
|
|
853
|
+
l2ToL1Msgs;
|
|
854
|
+
publicLogs;
|
|
855
|
+
publicDataWrites;
|
|
856
|
+
constructor(transactionFee, noteHashes, nullifiers, l2ToL1Msgs, publicLogs, publicDataWrites){
|
|
857
|
+
this.transactionFee = transactionFee;
|
|
858
|
+
this.noteHashes = noteHashes;
|
|
859
|
+
this.nullifiers = nullifiers;
|
|
860
|
+
this.l2ToL1Msgs = l2ToL1Msgs;
|
|
861
|
+
this.publicLogs = publicLogs;
|
|
862
|
+
this.publicDataWrites = publicDataWrites;
|
|
863
|
+
}
|
|
864
|
+
static empty() {
|
|
865
|
+
return new PublicTxEffect(Fr.ZERO, [], [], [], [], []);
|
|
866
|
+
}
|
|
867
|
+
static get schema() {
|
|
868
|
+
return z.object({
|
|
869
|
+
transactionFee: Fr.schema,
|
|
870
|
+
noteHashes: Fr.schema.array(),
|
|
871
|
+
nullifiers: Fr.schema.array(),
|
|
872
|
+
l2ToL1Msgs: ScopedL2ToL1Message.schema.array(),
|
|
873
|
+
publicLogs: PublicLog.schema.array(),
|
|
874
|
+
publicDataWrites: PublicDataWrite.schema.array()
|
|
875
|
+
}).transform(PublicTxEffect.from);
|
|
876
|
+
}
|
|
877
|
+
static from(obj) {
|
|
878
|
+
return new PublicTxEffect(obj.transactionFee, obj.noteHashes, obj.nullifiers, obj.l2ToL1Msgs, obj.publicLogs, obj.publicDataWrites);
|
|
879
|
+
}
|
|
880
|
+
static fromPlainObject(obj) {
|
|
881
|
+
return new PublicTxEffect(Fr.fromPlainObject(obj.transactionFee), obj.noteHashes.map((h)=>Fr.fromPlainObject(h)), obj.nullifiers.map((n)=>Fr.fromPlainObject(n)), obj.l2ToL1Msgs.map((m)=>ScopedL2ToL1Message.fromPlainObject(m)), obj.publicLogs.map((l)=>PublicLog.fromPlainObject(l)), obj.publicDataWrites.map((w)=>PublicDataWrite.fromPlainObject(w)));
|
|
882
|
+
}
|
|
883
|
+
equals(other) {
|
|
884
|
+
return this.transactionFee.equals(other.transactionFee) && this.noteHashes.length === other.noteHashes.length && this.noteHashes.every((h, i)=>h.equals(other.noteHashes[i])) && this.nullifiers.length === other.nullifiers.length && this.nullifiers.every((h, i)=>h.equals(other.nullifiers[i])) && this.l2ToL1Msgs.length === other.l2ToL1Msgs.length && this.l2ToL1Msgs.every((m, i)=>m.equals(other.l2ToL1Msgs[i])) && this.publicLogs.length === other.publicLogs.length && this.publicLogs.every((l, i)=>l.equals(other.publicLogs[i])) && this.publicDataWrites.length === other.publicDataWrites.length && this.publicDataWrites.every((w, i)=>w.equals(other.publicDataWrites[i]));
|
|
885
|
+
}
|
|
886
|
+
}
|
|
887
|
+
export class PublicTxResult {
|
|
888
|
+
gasUsed;
|
|
889
|
+
revertCode;
|
|
890
|
+
publicTxEffect;
|
|
891
|
+
callStackMetadata;
|
|
892
|
+
logs;
|
|
893
|
+
hints;
|
|
894
|
+
publicInputs;
|
|
895
|
+
constructor(// Simulation result.
|
|
896
|
+
gasUsed, revertCode, publicTxEffect, // These are only guaranteed to be present if the simulator is configured to collect them.
|
|
897
|
+
// TODO(fcarreiro): Remove NestedProcessReturnValues[] once we migrate to the C++ simulator.
|
|
898
|
+
callStackMetadata, logs, // For the proving request.
|
|
899
|
+
hints, publicInputs){
|
|
900
|
+
this.gasUsed = gasUsed;
|
|
901
|
+
this.revertCode = revertCode;
|
|
902
|
+
this.publicTxEffect = publicTxEffect;
|
|
903
|
+
this.callStackMetadata = callStackMetadata;
|
|
904
|
+
this.logs = logs;
|
|
905
|
+
this.hints = hints;
|
|
906
|
+
this.publicInputs = publicInputs;
|
|
907
|
+
}
|
|
908
|
+
static empty() {
|
|
909
|
+
return new PublicTxResult({
|
|
910
|
+
totalGas: Gas.empty(),
|
|
911
|
+
teardownGas: Gas.empty(),
|
|
912
|
+
publicGas: Gas.empty(),
|
|
913
|
+
billedGas: Gas.empty()
|
|
914
|
+
}, RevertCode.OK, PublicTxEffect.empty(), /*callStackMetadata=*/ [], /*logs=*/ [], /*hints=*/ AvmExecutionHints.empty(), /*publicInputs=*/ AvmCircuitPublicInputs.empty());
|
|
915
|
+
}
|
|
916
|
+
static get schema() {
|
|
917
|
+
return z.object({
|
|
918
|
+
gasUsed: schemas.GasUsed,
|
|
919
|
+
revertCode: RevertCode.schema,
|
|
920
|
+
revertReason: NullishToUndefined(SimulationError.schema),
|
|
921
|
+
publicTxEffect: PublicTxEffect.schema,
|
|
922
|
+
callStackMetadata: z.union([
|
|
923
|
+
CallStackMetadata.schema.array(),
|
|
924
|
+
NestedProcessReturnValues.schema.array()
|
|
925
|
+
]),
|
|
926
|
+
logs: NullishToUndefined(DebugLog.schema.array()),
|
|
927
|
+
// For the proving request.
|
|
928
|
+
publicInputs: NullishToUndefined(AvmCircuitPublicInputs.schema),
|
|
929
|
+
hints: NullishToUndefined(AvmExecutionHints.schema)
|
|
930
|
+
}).transform(({ gasUsed, revertCode, publicTxEffect, callStackMetadata, logs, hints, publicInputs })=>new PublicTxResult(gasUsed, revertCode, publicTxEffect, callStackMetadata, logs, hints, publicInputs));
|
|
931
|
+
}
|
|
932
|
+
/**
|
|
933
|
+
* Creates a PublicTxResult from a plain object without Zod validation.
|
|
934
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
935
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
936
|
+
* @param obj - Plain object containing PublicTxResult fields
|
|
937
|
+
* @returns A PublicTxResult instance
|
|
938
|
+
*/ static fromPlainObject(obj) {
|
|
939
|
+
return new PublicTxResult(GasUsed.fromPlainObject(obj.gasUsed), RevertCode.fromPlainObject(obj.revertCode), PublicTxEffect.fromPlainObject(obj.publicTxEffect), obj.callStackMetadata.map(CallStackMetadata.fromPlainObject), obj.logs?.map(DebugLog.fromPlainObject), obj.hints ? AvmExecutionHints.fromPlainObject(obj.hints) : undefined, obj.publicInputs ? AvmCircuitPublicInputs.fromPlainObject(obj.publicInputs) : undefined);
|
|
940
|
+
}
|
|
941
|
+
/** Returns one level of return values for the app logic phase, one per enqueued call. */ getAppLogicReturnValues() {
|
|
942
|
+
if (this.callStackMetadata.every((metadata)=>metadata instanceof CallStackMetadata)) {
|
|
943
|
+
return this.callStackMetadata.filter((metadata)=>metadata.phase === TxExecutionPhase.APP_LOGIC).map((metadata)=>new NestedProcessReturnValues(metadata.output));
|
|
944
|
+
} else {
|
|
945
|
+
return this.callStackMetadata.map((metadata)=>new NestedProcessReturnValues(metadata.values, metadata.nested));
|
|
946
|
+
}
|
|
947
|
+
}
|
|
948
|
+
findRevertReason() {
|
|
949
|
+
if (this.revertCode.isOK()) {
|
|
950
|
+
return undefined;
|
|
951
|
+
}
|
|
952
|
+
const callStackMetadata = this.callStackMetadata;
|
|
953
|
+
// TODO(fcarreiro): Remove this after migration to the C++ simulator.
|
|
954
|
+
// If the "stack" comes from TS, it will have this field.
|
|
955
|
+
if (callStackMetadata.revertReason !== undefined) {
|
|
956
|
+
return callStackMetadata.revertReason;
|
|
957
|
+
}
|
|
958
|
+
// Handle CallStackMetadata[].
|
|
959
|
+
let revertReason = undefined;
|
|
960
|
+
for (const call of callStackMetadata){
|
|
961
|
+
revertReason = call.getRevertReason();
|
|
962
|
+
if (revertReason) {
|
|
963
|
+
break;
|
|
964
|
+
}
|
|
965
|
+
}
|
|
966
|
+
return revertReason;
|
|
967
|
+
}
|
|
968
|
+
}
|
|
969
|
+
export class CollectionLimitsConfig {
|
|
970
|
+
maxDebugLogMemoryReads;
|
|
971
|
+
maxCalldataSizeInFields;
|
|
972
|
+
maxReturndataSizeInFields;
|
|
973
|
+
maxCallStackDepth;
|
|
974
|
+
maxCallStackItems;
|
|
975
|
+
constructor(maxDebugLogMemoryReads, maxCalldataSizeInFields, maxReturndataSizeInFields, maxCallStackDepth, maxCallStackItems){
|
|
976
|
+
this.maxDebugLogMemoryReads = maxDebugLogMemoryReads;
|
|
977
|
+
this.maxCalldataSizeInFields = maxCalldataSizeInFields;
|
|
978
|
+
this.maxReturndataSizeInFields = maxReturndataSizeInFields;
|
|
979
|
+
this.maxCallStackDepth = maxCallStackDepth;
|
|
980
|
+
this.maxCallStackItems = maxCallStackItems;
|
|
981
|
+
}
|
|
982
|
+
static from(obj) {
|
|
983
|
+
return new CollectionLimitsConfig(obj.maxDebugLogMemoryReads ?? DEFAULT_MAX_DEBUG_LOG_MEMORY_READS, obj.maxCalldataSizeInFields ?? 300, obj.maxReturndataSizeInFields ?? 300, obj.maxCallStackDepth ?? 5, obj.maxCallStackItems ?? 100);
|
|
984
|
+
}
|
|
985
|
+
static empty() {
|
|
986
|
+
return CollectionLimitsConfig.from({});
|
|
987
|
+
}
|
|
988
|
+
static get schema() {
|
|
989
|
+
return z.object({
|
|
990
|
+
maxDebugLogMemoryReads: z.number(),
|
|
991
|
+
maxCalldataSizeInFields: z.number(),
|
|
992
|
+
maxReturndataSizeInFields: z.number(),
|
|
993
|
+
maxCallStackDepth: z.number(),
|
|
994
|
+
maxCallStackItems: z.number()
|
|
995
|
+
}).transform(({ maxDebugLogMemoryReads, maxCalldataSizeInFields, maxReturndataSizeInFields, maxCallStackDepth, maxCallStackItems })=>new CollectionLimitsConfig(maxDebugLogMemoryReads, maxCalldataSizeInFields, maxReturndataSizeInFields, maxCallStackDepth, maxCallStackItems));
|
|
996
|
+
}
|
|
997
|
+
}
|
|
998
|
+
export class PublicSimulatorConfig {
|
|
999
|
+
proverId;
|
|
1000
|
+
skipFeeEnforcement;
|
|
1001
|
+
collectCallMetadata;
|
|
1002
|
+
collectHints;
|
|
1003
|
+
collectPublicInputs;
|
|
1004
|
+
collectDebugLogs;
|
|
1005
|
+
collectStatistics;
|
|
1006
|
+
collectionLimits;
|
|
1007
|
+
constructor(proverId, skipFeeEnforcement, collectCallMetadata, collectHints, collectPublicInputs, collectDebugLogs, collectStatistics, collectionLimits){
|
|
1008
|
+
this.proverId = proverId;
|
|
1009
|
+
this.skipFeeEnforcement = skipFeeEnforcement;
|
|
1010
|
+
this.collectCallMetadata = collectCallMetadata;
|
|
1011
|
+
this.collectHints = collectHints;
|
|
1012
|
+
this.collectPublicInputs = collectPublicInputs;
|
|
1013
|
+
this.collectDebugLogs = collectDebugLogs;
|
|
1014
|
+
this.collectStatistics = collectStatistics;
|
|
1015
|
+
this.collectionLimits = collectionLimits;
|
|
1016
|
+
}
|
|
1017
|
+
static from(obj) {
|
|
1018
|
+
return new PublicSimulatorConfig(obj.proverId ?? Fr.ZERO, obj.skipFeeEnforcement ?? false, obj.collectCallMetadata ?? false, obj.collectHints ?? false, obj.collectPublicInputs ?? false, obj.collectDebugLogs ?? false, obj.collectStatistics ?? false, obj.collectionLimits ?? CollectionLimitsConfig.empty());
|
|
1019
|
+
}
|
|
1020
|
+
static empty() {
|
|
1021
|
+
return PublicSimulatorConfig.from({});
|
|
1022
|
+
}
|
|
1023
|
+
static get schema() {
|
|
1024
|
+
return z.object({
|
|
1025
|
+
proverId: Fr.schema,
|
|
1026
|
+
skipFeeEnforcement: z.boolean(),
|
|
1027
|
+
collectCallMetadata: z.boolean(),
|
|
1028
|
+
collectHints: z.boolean(),
|
|
1029
|
+
collectPublicInputs: z.boolean(),
|
|
1030
|
+
collectDebugLogs: z.boolean(),
|
|
1031
|
+
collectStatistics: z.boolean(),
|
|
1032
|
+
collectionLimits: CollectionLimitsConfig.schema
|
|
1033
|
+
}).transform(PublicSimulatorConfig.from);
|
|
1034
|
+
}
|
|
1035
|
+
}
|
|
1036
|
+
export class AvmFastSimulationInputs {
|
|
1037
|
+
wsRevision;
|
|
1038
|
+
config;
|
|
1039
|
+
tx;
|
|
1040
|
+
globalVariables;
|
|
1041
|
+
protocolContracts;
|
|
1042
|
+
constructor(wsRevision, config, tx, globalVariables, protocolContracts){
|
|
1043
|
+
this.wsRevision = wsRevision;
|
|
1044
|
+
this.config = config;
|
|
1045
|
+
this.tx = tx;
|
|
1046
|
+
this.globalVariables = globalVariables;
|
|
1047
|
+
this.protocolContracts = protocolContracts;
|
|
1048
|
+
}
|
|
1049
|
+
static empty() {
|
|
1050
|
+
return new AvmFastSimulationInputs(WorldStateRevision.empty(), PublicSimulatorConfig.empty(), AvmTxHint.empty(), GlobalVariables.empty(), ProtocolContracts.empty());
|
|
1051
|
+
}
|
|
1052
|
+
static get schema() {
|
|
1053
|
+
return z.object({
|
|
1054
|
+
wsRevision: WorldStateRevision.schema,
|
|
1055
|
+
config: PublicSimulatorConfig.schema,
|
|
1056
|
+
tx: AvmTxHint.schema,
|
|
1057
|
+
globalVariables: GlobalVariables.schema,
|
|
1058
|
+
protocolContracts: ProtocolContracts.schema
|
|
1059
|
+
}).transform(({ wsRevision, config, tx, globalVariables, protocolContracts })=>new AvmFastSimulationInputs(wsRevision, config, tx, globalVariables, protocolContracts));
|
|
1060
|
+
}
|
|
1061
|
+
serializeWithMessagePack() {
|
|
1062
|
+
return serializeWithMessagePack(this);
|
|
1063
|
+
}
|
|
1064
|
+
}
|