@aztec/stdlib 0.0.0-test.1 → 0.0.1-commit.1142ef1
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 +8 -11
- 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 +7 -3
- package/dest/abi/utils.d.ts.map +1 -1
- package/dest/abi/utils.js +7 -0
- package/dest/auth_witness/auth_witness.d.ts +24 -6
- 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 +89 -42
- 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 +265 -193
- 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 +4671 -1189
- package/dest/avm/avm_proving_request.d.ts.map +1 -1
- package/dest/avm/contract_storage_read.d.ts +3 -17
- 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 -17
- 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 -7
- 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 -14
- 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 -15
- 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 -14
- 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 -9
- 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 +17 -11
- 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 +7 -5
- package/dest/block/block_hash.d.ts.map +1 -1
- package/dest/block/block_hash.js +12 -1
- package/dest/block/block_parameter.d.ts +5 -0
- package/dest/block/block_parameter.d.ts.map +1 -0
- package/dest/block/block_parameter.js +6 -0
- package/dest/block/body.d.ts +10 -9
- package/dest/block/body.d.ts.map +1 -1
- package/dest/block/body.js +16 -31
- package/dest/block/checkpointed_l2_block.d.ts +267 -0
- package/dest/block/checkpointed_l2_block.d.ts.map +1 -0
- package/dest/block/checkpointed_l2_block.js +84 -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 +10 -4
- package/dest/block/index.d.ts.map +1 -1
- package/dest/block/index.js +9 -3
- package/dest/block/l2_block.d.ts +43 -31
- package/dest/block/l2_block.d.ts.map +1 -1
- package/dest/block/l2_block.js +110 -49
- package/dest/block/l2_block_code_to_purge.d.ts +4 -17
- package/dest/block/l2_block_code_to_purge.d.ts.map +1 -1
- package/dest/block/l2_block_code_to_purge.js +25 -21
- package/dest/block/l2_block_header.d.ts +94 -0
- package/dest/block/l2_block_header.d.ts.map +1 -0
- package/dest/block/l2_block_header.js +160 -0
- 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_new.d.ts +134 -0
- package/dest/block/l2_block_new.d.ts.map +1 -0
- package/dest/block/l2_block_new.js +155 -0
- package/dest/block/l2_block_source.d.ts +399 -135
- package/dest/block/l2_block_source.d.ts.map +1 -1
- package/dest/block/l2_block_source.js +37 -14
- 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 +33 -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 +37 -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 +269 -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 +550 -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 +84 -0
- package/dest/checkpoint/checkpoint.d.ts +153 -0
- package/dest/checkpoint/checkpoint.d.ts.map +1 -0
- package/dest/checkpoint/checkpoint.js +101 -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 +238 -0
- package/dest/checkpoint/published_checkpoint.d.ts.map +1 -0
- package/dest/checkpoint/published_checkpoint.js +81 -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 -7
- 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 +3 -3
- 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 +2 -4
- package/dest/contract/contract_class_id.d.ts.map +1 -1
- package/dest/contract/contract_class_id.js +8 -6
- package/dest/contract/contract_class_metadata.d.ts +8 -0
- package/dest/contract/contract_class_metadata.d.ts.map +1 -0
- package/dest/contract/contract_class_metadata.js +1 -0
- 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/contract_metadata.d.ts +7 -0
- package/dest/contract/contract_metadata.d.ts.map +1 -0
- package/dest/contract/contract_metadata.js +1 -0
- 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 +5 -2
- package/dest/contract/index.d.ts.map +1 -1
- package/dest/contract/index.js +4 -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 +3 -2
- package/dest/contract/private_function_membership_proof.d.ts +4 -4
- package/dest/contract/private_function_membership_proof.js +10 -10
- 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/index.d.ts +1 -1
- package/dest/database-version/version_manager.d.ts +31 -14
- package/dest/database-version/version_manager.d.ts.map +1 -1
- package/dest/database-version/version_manager.js +44 -21
- 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} +18 -18
- 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/epoch-helpers/index.d.ts +29 -6
- package/dest/epoch-helpers/index.d.ts.map +1 -1
- package/dest/epoch-helpers/index.js +42 -11
- package/dest/errors/index.d.ts +1 -1
- package/dest/errors/proving_error.d.ts +2 -2
- 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 +37 -26
- 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 +1 -1
- 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 +5 -0
- package/dest/interfaces/api_limit.d.ts.map +1 -0
- package/dest/interfaces/api_limit.js +4 -0
- package/dest/interfaces/archiver.d.ts +55 -3
- package/dest/interfaces/archiver.d.ts.map +1 -1
- package/dest/interfaces/archiver.js +56 -25
- package/dest/interfaces/aztec-node-admin.d.ts +321 -0
- package/dest/interfaces/aztec-node-admin.d.ts.map +1 -0
- package/dest/interfaces/aztec-node-admin.js +37 -0
- package/dest/interfaces/aztec-node.d.ts +124 -111
- package/dest/interfaces/aztec-node.d.ts.map +1 -1
- package/dest/interfaces/aztec-node.js +59 -43
- package/dest/interfaces/block-builder.d.ts +44 -6
- package/dest/interfaces/block-builder.d.ts.map +1 -1
- package/dest/interfaces/block-builder.js +9 -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 +12 -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 +1 -1
- package/dest/interfaces/prover-client.d.ts +12 -10
- package/dest/interfaces/prover-client.d.ts.map +1 -1
- package/dest/interfaces/prover-client.js +13 -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 +4866 -1269
- 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 +204 -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 +21 -24
- 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 +17 -32
- 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 -12
- 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 -7
- 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 -10
- 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 -34
- 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 -10
- 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 -38
- 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 -43
- 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 -56
- 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 -20
- 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 +68 -126
- 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 +19 -34
- 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 +7 -34
- 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 +13 -27
- 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 -10
- 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 -12
- 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 +15 -8
- 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 +19 -33
- 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 +22 -15
- 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 -24
- 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 +12 -29
- 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 -47
- 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 +81 -40
- 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 -11
- 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 +4 -5
- package/dest/keys/derivation.d.ts.map +1 -1
- package/dest/keys/derivation.js +7 -17
- package/dest/keys/index.d.ts +1 -1
- package/dest/keys/key_types.d.ts +1 -1
- 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 -8
- 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/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 +157 -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 -5
- package/dest/logs/extended_contract_class_log.d.ts.map +1 -1
- package/dest/logs/extended_public_log.d.ts +12 -8
- 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 +16 -10
- package/dest/logs/log_id.d.ts.map +1 -1
- package/dest/logs/log_id.js +19 -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 +30 -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 -7
- 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 -10
- 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 -9
- 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 -10
- 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 +179 -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 +6 -0
- package/dest/messaging/out_hash.d.ts.map +1 -0
- package/dest/messaging/out_hash.js +37 -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 +79 -0
- package/dest/note/note_dao.d.ts.map +1 -0
- package/dest/note/note_dao.js +112 -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 +102 -25
- package/dest/p2p/block_proposal.d.ts.map +1 -1
- package/dest/p2p/block_proposal.js +141 -30
- package/dest/p2p/checkpoint_attestation.d.ts +77 -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 +154 -0
- package/dest/p2p/checkpoint_proposal.d.ts.map +1 -0
- package/dest/p2p/checkpoint_proposal.js +217 -0
- package/dest/p2p/client_type.d.ts +1 -1
- package/dest/p2p/consensus_payload.d.ts +41 -24
- package/dest/p2p/consensus_payload.d.ts.map +1 -1
- package/dest/p2p/consensus_payload.js +46 -30
- 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 +5 -2
- package/dest/p2p/index.d.ts.map +1 -1
- package/dest/p2p/index.js +4 -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 +1 -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 +40 -0
- package/dest/p2p/signed_txs.d.ts.map +1 -0
- package/dest/p2p/signed_txs.js +70 -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 +43 -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 +33 -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 -9
- 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 +38 -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 +101 -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 -11
- 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 -31
- 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 +32 -66
- 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 +40 -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 +47 -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 +87 -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 +162 -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 +68 -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 +92 -0
- package/dest/rollup/checkpoint_header.d.ts.map +1 -0
- package/dest/rollup/checkpoint_header.js +198 -0
- package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts +27 -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 +87 -0
- package/dest/rollup/checkpoint_rollup_public_inputs.d.ts.map +1 -0
- package/dest/rollup/checkpoint_rollup_public_inputs.js +112 -0
- package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts +100 -0
- package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/checkpoint_root_rollup_private_inputs.js +179 -0
- package/dest/rollup/epoch_constant_data.d.ts +41 -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 +62 -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 +49 -0
- package/dest/rollup/root_rollup_public_inputs.d.ts.map +1 -0
- package/dest/rollup/root_rollup_public_inputs.js +74 -0
- package/dest/rollup/tree_snapshot_diff_hints.d.ts +64 -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 +41 -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 +87 -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 -15
- package/dest/stats/stats.d.ts.map +1 -1
- package/dest/tests/factories.d.ts +145 -131
- package/dest/tests/factories.d.ts.map +1 -1
- package/dest/tests/factories.js +458 -374
- 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/mocks.d.ts +136 -23
- package/dest/tests/mocks.d.ts.map +1 -1
- package/dest/tests/mocks.js +334 -93
- package/dest/trees/append_only_tree_snapshot.d.ts +14 -20
- 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 +66 -30
- 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 -54
- 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 +78 -45
- 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 -64
- 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 +24 -32
- package/dest/tx/block_header.d.ts.map +1 -1
- package/dest/tx/block_header.js +43 -24
- package/dest/tx/call_context.d.ts +8 -23
- 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 -8
- package/dest/tx/capsule.d.ts.map +1 -1
- package/dest/tx/capsule.js +3 -1
- package/dest/tx/execution_payload.d.ts +37 -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 +5 -9
- 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 -52
- 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 +15 -11
- 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 +35 -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 -8
- 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 +63 -82
- 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 +45 -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 +360 -0
- package/dest/tx/profiling.d.ts.map +1 -0
- package/dest/tx/profiling.js +130 -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 +40 -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 -14
- 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 +67 -100
- package/dest/tx/tx.d.ts.map +1 -1
- package/dest/tx/tx.js +160 -150
- 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 -38
- 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 +25 -83
- package/dest/tx/tx_effect.d.ts.map +1 -1
- package/dest/tx/tx_effect.js +87 -270
- package/dest/tx/tx_execution_request.d.ts +11 -33
- 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 -7
- 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 +4 -38
- package/dest/tx/tx_receipt.d.ts.map +1 -1
- package/dest/tx/tx_receipt.js +6 -15
- package/dest/tx/tx_request.d.ts +11 -14
- 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 +24 -0
- package/dest/tx/validator/error_texts.d.ts.map +1 -0
- package/dest/tx/validator/error_texts.js +31 -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 -15
- 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 -35
- 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 +24 -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 +35 -0
- package/dest/zkpassport/index.d.ts.map +1 -0
- package/dest/zkpassport/index.js +82 -0
- package/package.json +48 -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 +15 -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 +15 -1
- package/src/block/block_parameter.ts +8 -0
- package/src/block/body.ts +22 -38
- package/src/block/checkpointed_l2_block.ts +120 -0
- package/src/block/in_block.ts +28 -15
- package/src/block/index.ts +9 -3
- package/src/block/l2_block.ts +131 -64
- package/src/block/l2_block_code_to_purge.ts +32 -55
- package/src/block/l2_block_header.ts +255 -0
- package/src/block/l2_block_info.ts +64 -0
- package/src/block/l2_block_new.ts +211 -0
- package/src/block/l2_block_source.ts +239 -55
- package/src/block/l2_block_stream/index.ts +4 -0
- package/src/block/l2_block_stream/interfaces.ts +41 -0
- package/src/block/l2_block_stream/l2_block_stream.ts +299 -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 +542 -0
- package/src/block/validate_block_result.ts +128 -0
- package/src/checkpoint/checkpoint.ts +136 -0
- package/src/checkpoint/checkpoint_info.ts +52 -0
- package/src/checkpoint/index.ts +3 -0
- package/src/checkpoint/published_checkpoint.ts +105 -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 +3 -3
- package/src/contract/contract_class.ts +9 -26
- package/src/contract/contract_class_id.ts +12 -6
- package/src/contract/contract_class_metadata.ts +8 -0
- 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/contract_metadata.ts +7 -0
- package/src/contract/deployment_info.ts +1 -1
- package/src/contract/index.ts +4 -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 -4
- package/src/contract/private_function_membership_proof.ts +10 -10
- package/src/contract/{unconstrained_function_membership_proof.ts → utility_function_membership_proof.ts} +19 -19
- package/src/database-version/version_manager.ts +78 -25
- package/src/{shared_mutable/shared_mutable_values.ts → delayed_public_mutable/delayed_public_mutable_values.ts} +25 -22
- 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/epoch-helpers/index.ts +88 -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 +49 -30
- package/src/hash/map_slot.ts +2 -2
- package/src/interfaces/allowed_element.ts +23 -0
- package/src/interfaces/api_limit.ts +4 -0
- package/src/interfaces/archiver.ts +108 -35
- package/src/interfaces/aztec-node-admin.ts +102 -0
- package/src/interfaces/aztec-node.ts +279 -185
- package/src/interfaces/block-builder.ts +65 -9
- package/src/interfaces/client.ts +2 -1
- package/src/interfaces/configs.ts +92 -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 +11 -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-client.ts +28 -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 +152 -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 +33 -38
- package/src/kernel/hints/build_nullifier_read_request_hints.ts +32 -62
- 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 +7 -24
- package/src/keys/public_key.ts +1 -1
- package/src/keys/public_keys.ts +23 -3
- package/src/l1-contracts/index.ts +1 -0
- package/src/l1-contracts/slash_factory.ts +179 -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 +22 -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 +44 -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 +223 -0
- package/src/messaging/l2_to_l1_message.ts +131 -37
- package/src/messaging/out_hash.ts +46 -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 +182 -0
- package/src/note/notes_filter.ts +10 -11
- package/src/p2p/attestation_utils.ts +35 -0
- package/src/p2p/block_proposal.ts +224 -34
- package/src/p2p/checkpoint_attestation.ts +143 -0
- package/src/p2p/checkpoint_proposal.ts +337 -0
- package/src/p2p/consensus_payload.ts +58 -32
- package/src/p2p/gossipable.ts +60 -15
- package/src/p2p/index.ts +4 -1
- package/src/p2p/interface.ts +0 -24
- package/src/p2p/signature_utils.ts +12 -11
- package/src/p2p/signed_txs.ts +83 -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 +118 -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 +277 -0
- package/src/rollup/checkpoint_merge_rollup_private_inputs.ts +49 -0
- package/src/rollup/checkpoint_rollup_public_inputs.ts +145 -0
- package/src/rollup/checkpoint_root_rollup_private_inputs.ts +219 -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 +105 -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 -24
- package/src/tests/factories.ts +867 -652
- package/src/tests/mocks.ts +559 -152
- 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 +52 -31
- 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 +40 -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 +75 -106
- package/src/tx/private_tx_constant_data.ts +94 -0
- package/src/tx/processed_tx.ts +58 -49
- package/src/tx/profiling.ts +159 -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 +173 -194
- package/src/tx/tx_constant_data.ts +9 -22
- package/src/tx/tx_context.ts +1 -1
- package/src/tx/tx_effect.ts +142 -311
- package/src/tx/tx_execution_request.ts +17 -4
- package/src/tx/tx_hash.ts +27 -6
- package/src/tx/tx_receipt.ts +4 -39
- package/src/tx/tx_request.ts +18 -8
- package/src/tx/validator/error_texts.ts +38 -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 +119 -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_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/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_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/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/src/avm/avm.ts
CHANGED
|
@@ -1,272 +1,1007 @@
|
|
|
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
|
|
|
5
5
|
import { z } from 'zod';
|
|
6
6
|
|
|
7
|
+
import { FunctionSelector } from '../abi/index.js';
|
|
7
8
|
import { AztecAddress } from '../aztec-address/index.js';
|
|
9
|
+
import { AllContractDeploymentData, ContractDeploymentData } from '../contract/index.js';
|
|
10
|
+
import { SimulationError } from '../errors/simulation_error.js';
|
|
11
|
+
import { computeEffectiveGasFees } from '../fees/transaction_fee.js';
|
|
12
|
+
import { Gas } from '../gas/gas.js';
|
|
13
|
+
import { GasFees } from '../gas/gas_fees.js';
|
|
14
|
+
import { GasSettings } from '../gas/gas_settings.js';
|
|
15
|
+
import { GasUsed } from '../gas/gas_used.js';
|
|
8
16
|
import { PublicKeys } from '../keys/public_keys.js';
|
|
9
|
-
import {
|
|
10
|
-
import {
|
|
17
|
+
import { DebugLog } from '../logs/debug_log.js';
|
|
18
|
+
import { PublicLog } from '../logs/public_log.js';
|
|
19
|
+
import { ScopedL2ToL1Message } from '../messaging/l2_to_l1_message.js';
|
|
20
|
+
import { NullishToUndefined, type ZodFor, schemas } from '../schemas/schemas.js';
|
|
21
|
+
import { AppendOnlyTreeSnapshot } from '../trees/append_only_tree_snapshot.js';
|
|
22
|
+
import { MerkleTreeId } from '../trees/merkle_tree_id.js';
|
|
23
|
+
import { NullifierLeaf, NullifierLeafPreimage } from '../trees/nullifier_leaf.js';
|
|
24
|
+
import { PublicDataTreeLeaf, PublicDataTreeLeafPreimage } from '../trees/public_data_leaf.js';
|
|
25
|
+
import {
|
|
26
|
+
GlobalVariables,
|
|
27
|
+
NestedProcessReturnValues,
|
|
28
|
+
ProtocolContracts,
|
|
29
|
+
PublicCallRequestWithCalldata,
|
|
30
|
+
TreeSnapshots,
|
|
31
|
+
type Tx,
|
|
32
|
+
} from '../tx/index.js';
|
|
33
|
+
import { TxExecutionPhase } from '../tx/processed_tx.js';
|
|
34
|
+
import { WorldStateRevision } from '../world-state/world_state_revision.js';
|
|
11
35
|
import { AvmCircuitPublicInputs } from './avm_circuit_public_inputs.js';
|
|
12
36
|
import { serializeWithMessagePack } from './message_pack.js';
|
|
37
|
+
import { PublicDataWrite } from './public_data_write.js';
|
|
38
|
+
import { RevertCode } from './revert_code.js';
|
|
13
39
|
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
static get schema() {
|
|
18
|
-
return z
|
|
19
|
-
.object({
|
|
20
|
-
contractAddress: AztecAddress.schema,
|
|
21
|
-
calldata: schemas.Fr.array(),
|
|
22
|
-
})
|
|
23
|
-
.transform(({ contractAddress, calldata }) => new AvmEnqueuedCallHint(contractAddress, calldata));
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
|
|
40
|
+
////////////////////////////////////////////////////////////////////////////
|
|
41
|
+
// Hints (contracts)
|
|
42
|
+
////////////////////////////////////////////////////////////////////////////
|
|
27
43
|
export class AvmContractClassHint {
|
|
28
44
|
constructor(
|
|
45
|
+
public readonly hintKey: number,
|
|
29
46
|
public readonly classId: Fr,
|
|
30
|
-
public readonly exists: boolean,
|
|
31
47
|
public readonly artifactHash: Fr,
|
|
32
48
|
public readonly privateFunctionsRoot: Fr,
|
|
33
|
-
public readonly publicBytecodeCommitment: Fr,
|
|
34
49
|
public readonly packedBytecode: Buffer,
|
|
35
50
|
) {}
|
|
36
51
|
|
|
37
52
|
static get schema() {
|
|
38
53
|
return z
|
|
39
54
|
.object({
|
|
55
|
+
hintKey: z.number().int().nonnegative(),
|
|
40
56
|
classId: schemas.Fr,
|
|
41
|
-
exists: z.boolean(),
|
|
42
57
|
artifactHash: schemas.Fr,
|
|
43
58
|
privateFunctionsRoot: schemas.Fr,
|
|
44
|
-
publicBytecodeCommitment: schemas.Fr,
|
|
45
59
|
packedBytecode: schemas.Buffer,
|
|
46
60
|
})
|
|
47
61
|
.transform(
|
|
48
|
-
({
|
|
49
|
-
new AvmContractClassHint(
|
|
50
|
-
classId,
|
|
51
|
-
exists,
|
|
52
|
-
artifactHash,
|
|
53
|
-
privateFunctionsRoot,
|
|
54
|
-
publicBytecodeCommitment,
|
|
55
|
-
packedBytecode,
|
|
56
|
-
),
|
|
62
|
+
({ hintKey, classId, artifactHash, privateFunctionsRoot, packedBytecode }) =>
|
|
63
|
+
new AvmContractClassHint(hintKey, classId, artifactHash, privateFunctionsRoot, packedBytecode),
|
|
57
64
|
);
|
|
58
65
|
}
|
|
66
|
+
|
|
67
|
+
/**
|
|
68
|
+
* Creates an AvmContractClassHint from a plain object without Zod validation.
|
|
69
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
70
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
71
|
+
* @param obj - Plain object containing AvmContractClassHint fields
|
|
72
|
+
* @returns An AvmContractClassHint instance
|
|
73
|
+
*/
|
|
74
|
+
static fromPlainObject(obj: any): AvmContractClassHint {
|
|
75
|
+
if (obj instanceof AvmContractClassHint) {
|
|
76
|
+
return obj;
|
|
77
|
+
}
|
|
78
|
+
return new AvmContractClassHint(
|
|
79
|
+
obj.hintKey,
|
|
80
|
+
Fr.fromPlainObject(obj.classId),
|
|
81
|
+
Fr.fromPlainObject(obj.artifactHash),
|
|
82
|
+
Fr.fromPlainObject(obj.privateFunctionsRoot),
|
|
83
|
+
obj.packedBytecode instanceof Buffer ? obj.packedBytecode : Buffer.from(obj.packedBytecode),
|
|
84
|
+
);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
export class AvmBytecodeCommitmentHint {
|
|
89
|
+
constructor(
|
|
90
|
+
public readonly hintKey: number,
|
|
91
|
+
public readonly classId: Fr,
|
|
92
|
+
public readonly commitment: Fr,
|
|
93
|
+
) {}
|
|
94
|
+
|
|
95
|
+
static get schema() {
|
|
96
|
+
return z
|
|
97
|
+
.object({
|
|
98
|
+
hintKey: z.number().int().nonnegative(),
|
|
99
|
+
classId: schemas.Fr,
|
|
100
|
+
commitment: schemas.Fr,
|
|
101
|
+
})
|
|
102
|
+
.transform(({ hintKey, classId, commitment }) => new AvmBytecodeCommitmentHint(hintKey, classId, commitment));
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
/**
|
|
106
|
+
* Creates an AvmBytecodeCommitmentHint from a plain object without Zod validation.
|
|
107
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
108
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
109
|
+
* @param obj - Plain object containing AvmBytecodeCommitmentHint fields
|
|
110
|
+
* @returns An AvmBytecodeCommitmentHint instance
|
|
111
|
+
*/
|
|
112
|
+
static fromPlainObject(obj: any): AvmBytecodeCommitmentHint {
|
|
113
|
+
if (obj instanceof AvmBytecodeCommitmentHint) {
|
|
114
|
+
return obj;
|
|
115
|
+
}
|
|
116
|
+
return new AvmBytecodeCommitmentHint(
|
|
117
|
+
obj.hintKey,
|
|
118
|
+
Fr.fromPlainObject(obj.classId),
|
|
119
|
+
Fr.fromPlainObject(obj.commitment),
|
|
120
|
+
);
|
|
121
|
+
}
|
|
59
122
|
}
|
|
60
123
|
|
|
61
124
|
export class AvmContractInstanceHint {
|
|
62
125
|
constructor(
|
|
126
|
+
public readonly hintKey: number,
|
|
63
127
|
public readonly address: AztecAddress,
|
|
64
|
-
public readonly exists: boolean,
|
|
65
128
|
public readonly salt: Fr,
|
|
66
129
|
public readonly deployer: AztecAddress,
|
|
67
130
|
public readonly currentContractClassId: Fr,
|
|
68
131
|
public readonly originalContractClassId: Fr,
|
|
69
132
|
public readonly initializationHash: Fr,
|
|
70
133
|
public readonly publicKeys: PublicKeys,
|
|
71
|
-
// public readonly updateMembershipHint: AvmPublicDataReadTreeHint = AvmPublicDataReadTreeHint.empty(),
|
|
72
|
-
public readonly updateMembershipHint: AvmPublicDataReadTreeHint,
|
|
73
|
-
public readonly updatePreimage: Fr[] = [],
|
|
74
134
|
) {}
|
|
75
135
|
|
|
76
136
|
static get schema() {
|
|
77
137
|
return z
|
|
78
138
|
.object({
|
|
139
|
+
hintKey: z.number().int().nonnegative(),
|
|
79
140
|
address: AztecAddress.schema,
|
|
80
|
-
exists: z.boolean(),
|
|
81
141
|
salt: schemas.Fr,
|
|
82
142
|
deployer: AztecAddress.schema,
|
|
83
143
|
currentContractClassId: schemas.Fr,
|
|
84
144
|
originalContractClassId: schemas.Fr,
|
|
85
145
|
initializationHash: schemas.Fr,
|
|
86
146
|
publicKeys: PublicKeys.schema,
|
|
87
|
-
updateMembershipHint: AvmPublicDataReadTreeHint.schema,
|
|
88
|
-
updatePreimage: schemas.Fr.array(),
|
|
89
147
|
})
|
|
90
148
|
.transform(
|
|
91
149
|
({
|
|
150
|
+
hintKey,
|
|
92
151
|
address,
|
|
93
|
-
exists,
|
|
94
152
|
salt,
|
|
95
153
|
deployer,
|
|
96
154
|
currentContractClassId,
|
|
97
155
|
originalContractClassId,
|
|
98
156
|
initializationHash,
|
|
99
157
|
publicKeys,
|
|
100
|
-
updateMembershipHint,
|
|
101
|
-
updatePreimage,
|
|
102
158
|
}) =>
|
|
103
159
|
new AvmContractInstanceHint(
|
|
160
|
+
hintKey,
|
|
104
161
|
address,
|
|
105
|
-
exists,
|
|
106
162
|
salt,
|
|
107
163
|
deployer,
|
|
108
164
|
currentContractClassId,
|
|
109
165
|
originalContractClassId,
|
|
110
166
|
initializationHash,
|
|
111
167
|
publicKeys,
|
|
112
|
-
updateMembershipHint,
|
|
113
|
-
updatePreimage,
|
|
114
168
|
),
|
|
115
169
|
);
|
|
116
170
|
}
|
|
171
|
+
|
|
172
|
+
/**
|
|
173
|
+
* Creates an AvmContractInstanceHint from a plain object without Zod validation.
|
|
174
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
175
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
176
|
+
* @param obj - Plain object containing AvmContractInstanceHint fields
|
|
177
|
+
* @returns An AvmContractInstanceHint instance
|
|
178
|
+
*/
|
|
179
|
+
static fromPlainObject(obj: any): AvmContractInstanceHint {
|
|
180
|
+
if (obj instanceof AvmContractInstanceHint) {
|
|
181
|
+
return obj;
|
|
182
|
+
}
|
|
183
|
+
return new AvmContractInstanceHint(
|
|
184
|
+
obj.hintKey,
|
|
185
|
+
AztecAddress.fromPlainObject(obj.address),
|
|
186
|
+
Fr.fromPlainObject(obj.salt),
|
|
187
|
+
AztecAddress.fromPlainObject(obj.deployer),
|
|
188
|
+
Fr.fromPlainObject(obj.currentContractClassId),
|
|
189
|
+
Fr.fromPlainObject(obj.originalContractClassId),
|
|
190
|
+
Fr.fromPlainObject(obj.initializationHash),
|
|
191
|
+
PublicKeys.fromPlainObject(obj.publicKeys),
|
|
192
|
+
);
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
export class AvmDebugFunctionNameHint {
|
|
197
|
+
constructor(
|
|
198
|
+
public readonly address: AztecAddress,
|
|
199
|
+
public readonly selector: Fr,
|
|
200
|
+
public readonly name: string,
|
|
201
|
+
) {}
|
|
202
|
+
|
|
203
|
+
static get schema() {
|
|
204
|
+
return z
|
|
205
|
+
.object({
|
|
206
|
+
address: AztecAddress.schema,
|
|
207
|
+
selector: schemas.Fr,
|
|
208
|
+
name: z.string(),
|
|
209
|
+
})
|
|
210
|
+
.transform(({ address, selector, name }) => new AvmDebugFunctionNameHint(address, selector, name));
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
/**
|
|
214
|
+
* Creates an AvmDebugFunctionNameHint from a plain object without Zod validation.
|
|
215
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
216
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
217
|
+
* @param obj - Plain object containing AvmDebugFunctionNameHint fields
|
|
218
|
+
* @returns An AvmDebugFunctionNameHint instance
|
|
219
|
+
*/
|
|
220
|
+
static fromPlainObject(obj: any): AvmDebugFunctionNameHint {
|
|
221
|
+
if (obj instanceof AvmDebugFunctionNameHint) {
|
|
222
|
+
return obj;
|
|
223
|
+
}
|
|
224
|
+
return new AvmDebugFunctionNameHint(
|
|
225
|
+
AztecAddress.fromPlainObject(obj.address),
|
|
226
|
+
Fr.fromPlainObject(obj.selector),
|
|
227
|
+
obj.name,
|
|
228
|
+
);
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
|
|
232
|
+
////////////////////////////////////////////////////////////////////////////
|
|
233
|
+
// Hints (merkle db)
|
|
234
|
+
////////////////////////////////////////////////////////////////////////////
|
|
235
|
+
// Hint for MerkleTreeDB.getSiblingPath.
|
|
236
|
+
export class AvmGetSiblingPathHint {
|
|
237
|
+
constructor(
|
|
238
|
+
public readonly hintKey: AppendOnlyTreeSnapshot,
|
|
239
|
+
// params
|
|
240
|
+
public readonly treeId: MerkleTreeId,
|
|
241
|
+
public readonly index: bigint,
|
|
242
|
+
// return
|
|
243
|
+
public readonly path: Fr[],
|
|
244
|
+
) {}
|
|
245
|
+
|
|
246
|
+
static get schema() {
|
|
247
|
+
return z
|
|
248
|
+
.object({
|
|
249
|
+
hintKey: AppendOnlyTreeSnapshot.schema,
|
|
250
|
+
treeId: z.number().int().nonnegative(),
|
|
251
|
+
index: schemas.BigInt,
|
|
252
|
+
path: schemas.Fr.array(),
|
|
253
|
+
})
|
|
254
|
+
.transform(({ hintKey, treeId, index, path }) => new AvmGetSiblingPathHint(hintKey, treeId, index, path));
|
|
255
|
+
}
|
|
256
|
+
|
|
257
|
+
/**
|
|
258
|
+
* Creates an AvmGetSiblingPathHint from a plain object without Zod validation.
|
|
259
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
260
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
261
|
+
* @param obj - Plain object containing AvmGetSiblingPathHint fields
|
|
262
|
+
* @returns An AvmGetSiblingPathHint instance
|
|
263
|
+
*/
|
|
264
|
+
static fromPlainObject(obj: any): AvmGetSiblingPathHint {
|
|
265
|
+
if (obj instanceof AvmGetSiblingPathHint) {
|
|
266
|
+
return obj;
|
|
267
|
+
}
|
|
268
|
+
return new AvmGetSiblingPathHint(
|
|
269
|
+
AppendOnlyTreeSnapshot.fromPlainObject(obj.hintKey),
|
|
270
|
+
obj.treeId,
|
|
271
|
+
typeof obj.index === 'bigint' ? obj.index : BigInt(obj.index),
|
|
272
|
+
obj.path.map((p: any) => Fr.fromPlainObject(p)),
|
|
273
|
+
);
|
|
274
|
+
}
|
|
117
275
|
}
|
|
118
276
|
|
|
119
|
-
|
|
120
|
-
|
|
277
|
+
// Hint for MerkleTreeDB.getPreviousValueIndex.
|
|
278
|
+
export class AvmGetPreviousValueIndexHint {
|
|
279
|
+
constructor(
|
|
280
|
+
public readonly hintKey: AppendOnlyTreeSnapshot,
|
|
281
|
+
// params
|
|
282
|
+
public readonly treeId: MerkleTreeId,
|
|
283
|
+
public readonly value: Fr,
|
|
284
|
+
// return
|
|
285
|
+
public readonly index: bigint,
|
|
286
|
+
public readonly alreadyPresent: boolean,
|
|
287
|
+
) {}
|
|
121
288
|
|
|
122
289
|
static get schema() {
|
|
123
290
|
return z
|
|
124
291
|
.object({
|
|
125
|
-
|
|
292
|
+
hintKey: AppendOnlyTreeSnapshot.schema,
|
|
293
|
+
treeId: z.number().int().nonnegative(),
|
|
126
294
|
value: schemas.Fr,
|
|
127
|
-
|
|
295
|
+
index: schemas.BigInt,
|
|
296
|
+
alreadyPresent: z.boolean(),
|
|
128
297
|
})
|
|
129
|
-
.transform(
|
|
298
|
+
.transform(
|
|
299
|
+
({ hintKey, treeId, value, index, alreadyPresent }) =>
|
|
300
|
+
new AvmGetPreviousValueIndexHint(hintKey, treeId, value, index, alreadyPresent),
|
|
301
|
+
);
|
|
302
|
+
}
|
|
303
|
+
|
|
304
|
+
/**
|
|
305
|
+
* Creates an AvmGetPreviousValueIndexHint from a plain object without Zod validation.
|
|
306
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
307
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
308
|
+
* @param obj - Plain object containing AvmGetPreviousValueIndexHint fields
|
|
309
|
+
* @returns An AvmGetPreviousValueIndexHint instance
|
|
310
|
+
*/
|
|
311
|
+
static fromPlainObject(obj: any): AvmGetPreviousValueIndexHint {
|
|
312
|
+
if (obj instanceof AvmGetPreviousValueIndexHint) {
|
|
313
|
+
return obj;
|
|
314
|
+
}
|
|
315
|
+
return new AvmGetPreviousValueIndexHint(
|
|
316
|
+
AppendOnlyTreeSnapshot.fromPlainObject(obj.hintKey),
|
|
317
|
+
obj.treeId,
|
|
318
|
+
Fr.fromPlainObject(obj.value),
|
|
319
|
+
typeof obj.index === 'bigint' ? obj.index : BigInt(obj.index),
|
|
320
|
+
obj.alreadyPresent,
|
|
321
|
+
);
|
|
130
322
|
}
|
|
131
323
|
}
|
|
132
324
|
|
|
133
|
-
|
|
134
|
-
|
|
325
|
+
type IndexedTreeLeafPreimages = NullifierLeafPreimage | PublicDataTreeLeafPreimage;
|
|
326
|
+
type IndexedTreeLeafPreimagesClasses = typeof NullifierLeafPreimage | typeof PublicDataTreeLeafPreimage;
|
|
327
|
+
|
|
328
|
+
// Hint for MerkleTreeDB.getLeafPreimage.
|
|
329
|
+
// NOTE: I need this factory because in order to get hold of the schema, I need an actual instance of the class,
|
|
330
|
+
// having the type doesn't suffice since TS does type erasure in the end.
|
|
331
|
+
function AvmGetLeafPreimageHintFactory(klass: IndexedTreeLeafPreimagesClasses) {
|
|
332
|
+
return class {
|
|
333
|
+
constructor(
|
|
334
|
+
public readonly hintKey: AppendOnlyTreeSnapshot,
|
|
335
|
+
// params (tree id will be implicit)
|
|
336
|
+
public readonly index: bigint,
|
|
337
|
+
// return
|
|
338
|
+
public readonly leafPreimage: IndexedTreeLeafPreimages,
|
|
339
|
+
) {}
|
|
340
|
+
|
|
341
|
+
static get schema() {
|
|
342
|
+
return z
|
|
343
|
+
.object({
|
|
344
|
+
hintKey: AppendOnlyTreeSnapshot.schema,
|
|
345
|
+
index: schemas.BigInt,
|
|
346
|
+
leafPreimage: klass.schema,
|
|
347
|
+
})
|
|
348
|
+
.transform(({ hintKey, index, leafPreimage }) => new this(hintKey, index, leafPreimage));
|
|
349
|
+
}
|
|
350
|
+
|
|
351
|
+
/**
|
|
352
|
+
* Creates an instance from a plain object without Zod validation.
|
|
353
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
354
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
355
|
+
* @param obj - Plain object containing hint fields
|
|
356
|
+
* @returns An instance
|
|
357
|
+
*/
|
|
358
|
+
static fromPlainObject(obj: any): any {
|
|
359
|
+
if (obj instanceof this) {
|
|
360
|
+
return obj;
|
|
361
|
+
}
|
|
362
|
+
return new this(
|
|
363
|
+
AppendOnlyTreeSnapshot.fromPlainObject(obj.hintKey),
|
|
364
|
+
typeof obj.index === 'bigint' ? obj.index : BigInt(obj.index),
|
|
365
|
+
klass.fromPlainObject(obj.leafPreimage),
|
|
366
|
+
);
|
|
367
|
+
}
|
|
368
|
+
};
|
|
369
|
+
}
|
|
370
|
+
|
|
371
|
+
// Note: only supported for PUBLIC_DATA_TREE and NULLIFIER_TREE.
|
|
372
|
+
export class AvmGetLeafPreimageHintPublicDataTree extends AvmGetLeafPreimageHintFactory(PublicDataTreeLeafPreimage) {}
|
|
373
|
+
export class AvmGetLeafPreimageHintNullifierTree extends AvmGetLeafPreimageHintFactory(NullifierLeafPreimage) {}
|
|
374
|
+
|
|
375
|
+
// Hint for MerkleTreeDB.getLeafValue.
|
|
376
|
+
// Note: only supported for NOTE_HASH_TREE and L1_TO_L2_MESSAGE_TREE.
|
|
377
|
+
export class AvmGetLeafValueHint {
|
|
378
|
+
constructor(
|
|
379
|
+
public readonly hintKey: AppendOnlyTreeSnapshot,
|
|
380
|
+
// params
|
|
381
|
+
public readonly treeId: MerkleTreeId,
|
|
382
|
+
public readonly index: bigint,
|
|
383
|
+
// return
|
|
384
|
+
public readonly value: Fr,
|
|
385
|
+
) {}
|
|
135
386
|
|
|
136
387
|
static get schema() {
|
|
137
388
|
return z
|
|
138
389
|
.object({
|
|
139
|
-
|
|
140
|
-
|
|
390
|
+
hintKey: AppendOnlyTreeSnapshot.schema,
|
|
391
|
+
treeId: z.number().int().nonnegative(),
|
|
392
|
+
index: schemas.BigInt,
|
|
393
|
+
value: schemas.Fr,
|
|
141
394
|
})
|
|
142
|
-
.transform(({
|
|
395
|
+
.transform(({ hintKey, treeId, index, value }) => new AvmGetLeafValueHint(hintKey, treeId, index, value));
|
|
396
|
+
}
|
|
397
|
+
|
|
398
|
+
/**
|
|
399
|
+
* Creates an AvmGetLeafValueHint from a plain object without Zod validation.
|
|
400
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
401
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
402
|
+
* @param obj - Plain object containing AvmGetLeafValueHint fields
|
|
403
|
+
* @returns An AvmGetLeafValueHint instance
|
|
404
|
+
*/
|
|
405
|
+
static fromPlainObject(obj: any): AvmGetLeafValueHint {
|
|
406
|
+
if (obj instanceof AvmGetLeafValueHint) {
|
|
407
|
+
return obj;
|
|
408
|
+
}
|
|
409
|
+
return new AvmGetLeafValueHint(
|
|
410
|
+
AppendOnlyTreeSnapshot.fromPlainObject(obj.hintKey),
|
|
411
|
+
obj.treeId,
|
|
412
|
+
typeof obj.index === 'bigint' ? obj.index : BigInt(obj.index),
|
|
413
|
+
Fr.fromPlainObject(obj.value),
|
|
414
|
+
);
|
|
143
415
|
}
|
|
144
416
|
}
|
|
145
417
|
|
|
146
|
-
|
|
418
|
+
// Hint for MerkleTreeDB.sequentialInsert.
|
|
419
|
+
// NOTE: I need this factory because in order to get hold of the schema, I need an actual instance of the class,
|
|
420
|
+
// having the type doesn't suffice since TS does type erasure in the end.
|
|
421
|
+
function AvmSequentialInsertHintFactory(klass: IndexedTreeLeafPreimagesClasses) {
|
|
422
|
+
return class {
|
|
423
|
+
constructor(
|
|
424
|
+
public readonly hintKey: AppendOnlyTreeSnapshot,
|
|
425
|
+
public readonly stateAfter: AppendOnlyTreeSnapshot,
|
|
426
|
+
// params
|
|
427
|
+
public readonly treeId: MerkleTreeId,
|
|
428
|
+
public readonly leaf: InstanceType<IndexedTreeLeafPreimagesClasses>['leaf'],
|
|
429
|
+
// return
|
|
430
|
+
public readonly lowLeavesWitnessData: {
|
|
431
|
+
leaf: IndexedTreeLeafPreimages;
|
|
432
|
+
index: bigint;
|
|
433
|
+
path: Fr[];
|
|
434
|
+
},
|
|
435
|
+
public readonly insertionWitnessData: {
|
|
436
|
+
leaf: IndexedTreeLeafPreimages;
|
|
437
|
+
index: bigint;
|
|
438
|
+
path: Fr[];
|
|
439
|
+
},
|
|
440
|
+
) {}
|
|
441
|
+
|
|
442
|
+
static get schema() {
|
|
443
|
+
return z
|
|
444
|
+
.object({
|
|
445
|
+
hintKey: AppendOnlyTreeSnapshot.schema,
|
|
446
|
+
stateAfter: AppendOnlyTreeSnapshot.schema,
|
|
447
|
+
treeId: z.number().int().nonnegative(),
|
|
448
|
+
leaf: klass.leafSchema,
|
|
449
|
+
lowLeavesWitnessData: z.object({
|
|
450
|
+
leaf: klass.schema,
|
|
451
|
+
index: schemas.BigInt,
|
|
452
|
+
path: schemas.Fr.array(),
|
|
453
|
+
}),
|
|
454
|
+
insertionWitnessData: z.object({
|
|
455
|
+
leaf: klass.schema,
|
|
456
|
+
index: schemas.BigInt,
|
|
457
|
+
path: schemas.Fr.array(),
|
|
458
|
+
}),
|
|
459
|
+
})
|
|
460
|
+
.transform(
|
|
461
|
+
({ hintKey, stateAfter, treeId, leaf, lowLeavesWitnessData, insertionWitnessData }) =>
|
|
462
|
+
new this(hintKey, stateAfter, treeId, leaf, lowLeavesWitnessData, insertionWitnessData),
|
|
463
|
+
);
|
|
464
|
+
}
|
|
465
|
+
|
|
466
|
+
/**
|
|
467
|
+
* Creates an instance from a plain object without Zod validation.
|
|
468
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
469
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
470
|
+
* @param obj - Plain object containing hint fields
|
|
471
|
+
* @returns An instance
|
|
472
|
+
*/
|
|
473
|
+
static fromPlainObject(obj: any): any {
|
|
474
|
+
if (obj instanceof this) {
|
|
475
|
+
return obj;
|
|
476
|
+
}
|
|
477
|
+
// Determine the leaf class based on the klass parameter
|
|
478
|
+
const LeafClass = klass === PublicDataTreeLeafPreimage ? PublicDataTreeLeaf : NullifierLeaf;
|
|
479
|
+
return new this(
|
|
480
|
+
AppendOnlyTreeSnapshot.fromPlainObject(obj.hintKey),
|
|
481
|
+
AppendOnlyTreeSnapshot.fromPlainObject(obj.stateAfter),
|
|
482
|
+
obj.treeId,
|
|
483
|
+
LeafClass.fromPlainObject(obj.leaf),
|
|
484
|
+
{
|
|
485
|
+
leaf: klass.fromPlainObject(obj.lowLeavesWitnessData.leaf),
|
|
486
|
+
index:
|
|
487
|
+
typeof obj.lowLeavesWitnessData.index === 'bigint'
|
|
488
|
+
? obj.lowLeavesWitnessData.index
|
|
489
|
+
: BigInt(obj.lowLeavesWitnessData.index),
|
|
490
|
+
path: obj.lowLeavesWitnessData.path.map((p: any) => Fr.fromPlainObject(p)),
|
|
491
|
+
},
|
|
492
|
+
{
|
|
493
|
+
leaf: klass.fromPlainObject(obj.insertionWitnessData.leaf),
|
|
494
|
+
index:
|
|
495
|
+
typeof obj.insertionWitnessData.index === 'bigint'
|
|
496
|
+
? obj.insertionWitnessData.index
|
|
497
|
+
: BigInt(obj.insertionWitnessData.index),
|
|
498
|
+
path: obj.insertionWitnessData.path.map((p: any) => Fr.fromPlainObject(p)),
|
|
499
|
+
},
|
|
500
|
+
);
|
|
501
|
+
}
|
|
502
|
+
};
|
|
503
|
+
}
|
|
504
|
+
|
|
505
|
+
// Note: only supported for PUBLIC_DATA_TREE and NULLIFIER_TREE.
|
|
506
|
+
export class AvmSequentialInsertHintPublicDataTree extends AvmSequentialInsertHintFactory(PublicDataTreeLeafPreimage) {}
|
|
507
|
+
export class AvmSequentialInsertHintNullifierTree extends AvmSequentialInsertHintFactory(NullifierLeafPreimage) {}
|
|
508
|
+
|
|
509
|
+
// Hint for MerkleTreeDB.appendLeaves.
|
|
510
|
+
// Note: only supported for NOTE_HASH_TREE and L1_TO_L2_MESSAGE_TREE.
|
|
511
|
+
export class AvmAppendLeavesHint {
|
|
147
512
|
constructor(
|
|
148
|
-
public readonly
|
|
149
|
-
public readonly
|
|
150
|
-
|
|
513
|
+
public readonly hintKey: AppendOnlyTreeSnapshot,
|
|
514
|
+
public readonly stateAfter: AppendOnlyTreeSnapshot,
|
|
515
|
+
// params
|
|
516
|
+
public readonly treeId: MerkleTreeId,
|
|
517
|
+
public readonly leaves: Fr[],
|
|
151
518
|
) {}
|
|
152
519
|
|
|
153
520
|
static get schema() {
|
|
154
521
|
return z
|
|
155
522
|
.object({
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
523
|
+
hintKey: AppendOnlyTreeSnapshot.schema,
|
|
524
|
+
stateAfter: AppendOnlyTreeSnapshot.schema,
|
|
525
|
+
treeId: z.number().int().nonnegative(),
|
|
526
|
+
leaves: schemas.Fr.array(),
|
|
159
527
|
})
|
|
160
528
|
.transform(
|
|
161
|
-
({
|
|
162
|
-
new AvmNullifierReadTreeHint(lowLeafPreimage, lowLeafIndex, lowLeafSiblingPath),
|
|
529
|
+
({ hintKey, stateAfter, treeId, leaves }) => new AvmAppendLeavesHint(hintKey, stateAfter, treeId, leaves),
|
|
163
530
|
);
|
|
164
531
|
}
|
|
532
|
+
|
|
533
|
+
/**
|
|
534
|
+
* Creates an AvmAppendLeavesHint from a plain object without Zod validation.
|
|
535
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
536
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
537
|
+
* @param obj - Plain object containing AvmAppendLeavesHint fields
|
|
538
|
+
* @returns An AvmAppendLeavesHint instance
|
|
539
|
+
*/
|
|
540
|
+
static fromPlainObject(obj: any): AvmAppendLeavesHint {
|
|
541
|
+
if (obj instanceof AvmAppendLeavesHint) {
|
|
542
|
+
return obj;
|
|
543
|
+
}
|
|
544
|
+
return new AvmAppendLeavesHint(
|
|
545
|
+
AppendOnlyTreeSnapshot.fromPlainObject(obj.hintKey),
|
|
546
|
+
AppendOnlyTreeSnapshot.fromPlainObject(obj.stateAfter),
|
|
547
|
+
obj.treeId,
|
|
548
|
+
obj.leaves.map((l: any) => Fr.fromPlainObject(l)),
|
|
549
|
+
);
|
|
550
|
+
}
|
|
165
551
|
}
|
|
166
552
|
|
|
167
|
-
|
|
553
|
+
// Hint for checkpoint actions that don't change the state.
|
|
554
|
+
class AvmCheckpointActionNoStateChangeHint {
|
|
168
555
|
constructor(
|
|
169
|
-
|
|
170
|
-
public readonly
|
|
171
|
-
|
|
556
|
+
// key
|
|
557
|
+
public readonly actionCounter: number,
|
|
558
|
+
// current checkpoint evolution
|
|
559
|
+
public readonly oldCheckpointId: number,
|
|
560
|
+
public readonly newCheckpointId: number,
|
|
172
561
|
) {}
|
|
173
562
|
|
|
174
|
-
static
|
|
175
|
-
return
|
|
563
|
+
static get schema() {
|
|
564
|
+
return z
|
|
565
|
+
.object({
|
|
566
|
+
actionCounter: z.number().int().nonnegative(),
|
|
567
|
+
oldCheckpointId: z.number().int().nonnegative(),
|
|
568
|
+
newCheckpointId: z.number().int().nonnegative(),
|
|
569
|
+
})
|
|
570
|
+
.transform(
|
|
571
|
+
({ actionCounter, oldCheckpointId, newCheckpointId }) =>
|
|
572
|
+
new this(actionCounter, oldCheckpointId, newCheckpointId),
|
|
573
|
+
);
|
|
574
|
+
}
|
|
575
|
+
|
|
576
|
+
/**
|
|
577
|
+
* Creates an instance from a plain object without Zod validation.
|
|
578
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
579
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
580
|
+
* @param obj - Plain object containing hint fields
|
|
581
|
+
* @returns An instance
|
|
582
|
+
*/
|
|
583
|
+
static fromPlainObject(obj: any): any {
|
|
584
|
+
if (obj instanceof this) {
|
|
585
|
+
return obj;
|
|
586
|
+
}
|
|
587
|
+
return new this(obj.actionCounter, obj.oldCheckpointId, obj.newCheckpointId);
|
|
588
|
+
}
|
|
589
|
+
}
|
|
590
|
+
|
|
591
|
+
// Hint for MerkleTreeDB.createCheckpoint.
|
|
592
|
+
export class AvmCreateCheckpointHint extends AvmCheckpointActionNoStateChangeHint {}
|
|
593
|
+
|
|
594
|
+
// Hint for MerkleTreeDB.commitCheckpoint.
|
|
595
|
+
export class AvmCommitCheckpointHint extends AvmCheckpointActionNoStateChangeHint {}
|
|
596
|
+
|
|
597
|
+
// Hint for MerkleTreeDB.revertCheckpoint.
|
|
598
|
+
export class AvmRevertCheckpointHint {
|
|
599
|
+
// We use explicit fields for MessagePack.
|
|
600
|
+
constructor(
|
|
601
|
+
// key
|
|
602
|
+
public readonly actionCounter: number,
|
|
603
|
+
// current checkpoint evolution
|
|
604
|
+
public readonly oldCheckpointId: number,
|
|
605
|
+
public readonly newCheckpointId: number,
|
|
606
|
+
// state evolution
|
|
607
|
+
public readonly stateBefore: TreeSnapshots,
|
|
608
|
+
public readonly stateAfter: TreeSnapshots,
|
|
609
|
+
) {}
|
|
610
|
+
|
|
611
|
+
static create(
|
|
612
|
+
actionCounter: number,
|
|
613
|
+
oldCheckpointId: number,
|
|
614
|
+
newCheckpointId: number,
|
|
615
|
+
stateBefore: Record<MerkleTreeId, AppendOnlyTreeSnapshot>,
|
|
616
|
+
stateAfter: Record<MerkleTreeId, AppendOnlyTreeSnapshot>,
|
|
617
|
+
): AvmRevertCheckpointHint {
|
|
618
|
+
return new AvmRevertCheckpointHint(
|
|
619
|
+
actionCounter,
|
|
620
|
+
oldCheckpointId,
|
|
621
|
+
newCheckpointId,
|
|
622
|
+
new TreeSnapshots(
|
|
623
|
+
stateBefore[MerkleTreeId.L1_TO_L2_MESSAGE_TREE],
|
|
624
|
+
stateBefore[MerkleTreeId.NOTE_HASH_TREE],
|
|
625
|
+
stateBefore[MerkleTreeId.NULLIFIER_TREE],
|
|
626
|
+
stateBefore[MerkleTreeId.PUBLIC_DATA_TREE],
|
|
627
|
+
),
|
|
628
|
+
new TreeSnapshots(
|
|
629
|
+
stateAfter[MerkleTreeId.L1_TO_L2_MESSAGE_TREE],
|
|
630
|
+
stateAfter[MerkleTreeId.NOTE_HASH_TREE],
|
|
631
|
+
stateAfter[MerkleTreeId.NULLIFIER_TREE],
|
|
632
|
+
stateAfter[MerkleTreeId.PUBLIC_DATA_TREE],
|
|
633
|
+
),
|
|
634
|
+
);
|
|
176
635
|
}
|
|
177
636
|
|
|
178
637
|
static get schema() {
|
|
179
638
|
return z
|
|
180
639
|
.object({
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
640
|
+
actionCounter: z.number().int().nonnegative(),
|
|
641
|
+
oldCheckpointId: z.number().int().nonnegative(),
|
|
642
|
+
newCheckpointId: z.number().int().nonnegative(),
|
|
643
|
+
stateBefore: TreeSnapshots.schema,
|
|
644
|
+
stateAfter: TreeSnapshots.schema,
|
|
184
645
|
})
|
|
185
646
|
.transform(
|
|
186
|
-
({
|
|
187
|
-
new
|
|
647
|
+
({ actionCounter, oldCheckpointId, newCheckpointId, stateBefore, stateAfter }) =>
|
|
648
|
+
new AvmRevertCheckpointHint(actionCounter, oldCheckpointId, newCheckpointId, stateBefore, stateAfter),
|
|
188
649
|
);
|
|
189
650
|
}
|
|
651
|
+
|
|
652
|
+
/**
|
|
653
|
+
* Creates an AvmRevertCheckpointHint from a plain object without Zod validation.
|
|
654
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
655
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
656
|
+
* @param obj - Plain object containing AvmRevertCheckpointHint fields
|
|
657
|
+
* @returns An AvmRevertCheckpointHint instance
|
|
658
|
+
*/
|
|
659
|
+
static fromPlainObject(obj: any): AvmRevertCheckpointHint {
|
|
660
|
+
if (obj instanceof AvmRevertCheckpointHint) {
|
|
661
|
+
return obj;
|
|
662
|
+
}
|
|
663
|
+
return new AvmRevertCheckpointHint(
|
|
664
|
+
obj.actionCounter,
|
|
665
|
+
obj.oldCheckpointId,
|
|
666
|
+
obj.newCheckpointId,
|
|
667
|
+
TreeSnapshots.fromPlainObject(obj.stateBefore),
|
|
668
|
+
TreeSnapshots.fromPlainObject(obj.stateAfter),
|
|
669
|
+
);
|
|
670
|
+
}
|
|
190
671
|
}
|
|
191
672
|
|
|
192
|
-
export class
|
|
673
|
+
export class AvmContractDbCreateCheckpointHint extends AvmCheckpointActionNoStateChangeHint {}
|
|
674
|
+
export class AvmContractDbCommitCheckpointHint extends AvmCheckpointActionNoStateChangeHint {}
|
|
675
|
+
export class AvmContractDbRevertCheckpointHint extends AvmCheckpointActionNoStateChangeHint {}
|
|
676
|
+
|
|
677
|
+
////////////////////////////////////////////////////////////////////////////
|
|
678
|
+
// Hints (other)
|
|
679
|
+
////////////////////////////////////////////////////////////////////////////
|
|
680
|
+
export class AvmTxHint {
|
|
193
681
|
constructor(
|
|
194
|
-
|
|
195
|
-
public readonly
|
|
196
|
-
public readonly
|
|
197
|
-
public readonly
|
|
682
|
+
public readonly hash: string,
|
|
683
|
+
public readonly gasSettings: GasSettings,
|
|
684
|
+
public readonly effectiveGasFees: GasFees,
|
|
685
|
+
public readonly nonRevertibleContractDeploymentData: ContractDeploymentData,
|
|
686
|
+
public readonly revertibleContractDeploymentData: ContractDeploymentData,
|
|
687
|
+
public readonly nonRevertibleAccumulatedData: {
|
|
688
|
+
noteHashes: Fr[];
|
|
689
|
+
nullifiers: Fr[];
|
|
690
|
+
l2ToL1Messages: ScopedL2ToL1Message[];
|
|
691
|
+
},
|
|
692
|
+
public readonly revertibleAccumulatedData: {
|
|
693
|
+
noteHashes: Fr[];
|
|
694
|
+
nullifiers: Fr[];
|
|
695
|
+
l2ToL1Messages: ScopedL2ToL1Message[];
|
|
696
|
+
},
|
|
697
|
+
public readonly setupEnqueuedCalls: PublicCallRequestWithCalldata[],
|
|
698
|
+
public readonly appLogicEnqueuedCalls: PublicCallRequestWithCalldata[],
|
|
699
|
+
// We need this to be null and not undefined because that's what
|
|
700
|
+
// MessagePack expects for an std::optional.
|
|
701
|
+
public readonly teardownEnqueuedCall: PublicCallRequestWithCalldata | null,
|
|
702
|
+
public readonly gasUsedByPrivate: Gas,
|
|
703
|
+
public readonly feePayer: AztecAddress,
|
|
198
704
|
) {}
|
|
199
705
|
|
|
706
|
+
static fromTx(tx: Tx, gasFees: GasFees): AvmTxHint {
|
|
707
|
+
const setupCallRequests = tx.getNonRevertiblePublicCallRequestsWithCalldata();
|
|
708
|
+
const appLogicCallRequests = tx.getRevertiblePublicCallRequestsWithCalldata();
|
|
709
|
+
const teardownCallRequest = tx.getTeardownPublicCallRequestWithCalldata();
|
|
710
|
+
const gasSettings = tx.data.constants.txContext.gasSettings;
|
|
711
|
+
const effectiveGasFees = computeEffectiveGasFees(gasFees, gasSettings);
|
|
712
|
+
const allContractDeploymentData = AllContractDeploymentData.fromTx(tx);
|
|
713
|
+
|
|
714
|
+
// For informational purposes. Assumed quick because it should be cached.
|
|
715
|
+
const txHash = tx.getTxHash();
|
|
716
|
+
|
|
717
|
+
return new AvmTxHint(
|
|
718
|
+
txHash.hash.toString(),
|
|
719
|
+
gasSettings,
|
|
720
|
+
effectiveGasFees,
|
|
721
|
+
allContractDeploymentData.getNonRevertibleContractDeploymentData(),
|
|
722
|
+
allContractDeploymentData.getRevertibleContractDeploymentData(),
|
|
723
|
+
{
|
|
724
|
+
noteHashes: tx.data.forPublic!.nonRevertibleAccumulatedData.noteHashes.filter(x => !x.isZero()),
|
|
725
|
+
nullifiers: tx.data.forPublic!.nonRevertibleAccumulatedData.nullifiers.filter(x => !x.isZero()),
|
|
726
|
+
l2ToL1Messages: tx.data.forPublic!.nonRevertibleAccumulatedData.l2ToL1Msgs.filter(x => !x.isEmpty()),
|
|
727
|
+
},
|
|
728
|
+
{
|
|
729
|
+
noteHashes: tx.data.forPublic!.revertibleAccumulatedData.noteHashes.filter(x => !x.isZero()),
|
|
730
|
+
nullifiers: tx.data.forPublic!.revertibleAccumulatedData.nullifiers.filter(x => !x.isZero()),
|
|
731
|
+
l2ToL1Messages: tx.data.forPublic!.revertibleAccumulatedData.l2ToL1Msgs.filter(x => !x.isEmpty()),
|
|
732
|
+
},
|
|
733
|
+
setupCallRequests,
|
|
734
|
+
appLogicCallRequests,
|
|
735
|
+
teardownCallRequest ?? null,
|
|
736
|
+
tx.data.gasUsed,
|
|
737
|
+
tx.data.feePayer,
|
|
738
|
+
);
|
|
739
|
+
}
|
|
740
|
+
|
|
741
|
+
static empty() {
|
|
742
|
+
return new AvmTxHint(
|
|
743
|
+
'',
|
|
744
|
+
GasSettings.empty(),
|
|
745
|
+
GasFees.empty(),
|
|
746
|
+
ContractDeploymentData.empty(),
|
|
747
|
+
ContractDeploymentData.empty(),
|
|
748
|
+
{ noteHashes: [], nullifiers: [], l2ToL1Messages: [] },
|
|
749
|
+
{ noteHashes: [], nullifiers: [], l2ToL1Messages: [] },
|
|
750
|
+
[],
|
|
751
|
+
[],
|
|
752
|
+
null,
|
|
753
|
+
Gas.empty(),
|
|
754
|
+
AztecAddress.zero(),
|
|
755
|
+
);
|
|
756
|
+
}
|
|
757
|
+
|
|
758
|
+
/**
|
|
759
|
+
* Creates an AvmTxHint from a plain object without Zod validation.
|
|
760
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
761
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
762
|
+
* @param obj - Plain object containing AvmTxHint fields
|
|
763
|
+
* @returns An AvmTxHint instance
|
|
764
|
+
*/
|
|
765
|
+
static fromPlainObject(obj: any): AvmTxHint {
|
|
766
|
+
if (obj instanceof AvmTxHint) {
|
|
767
|
+
return obj;
|
|
768
|
+
}
|
|
769
|
+
return new AvmTxHint(
|
|
770
|
+
obj.hash,
|
|
771
|
+
GasSettings.fromPlainObject(obj.gasSettings),
|
|
772
|
+
GasFees.fromPlainObject(obj.effectiveGasFees),
|
|
773
|
+
ContractDeploymentData.fromPlainObject(obj.nonRevertibleContractDeploymentData),
|
|
774
|
+
ContractDeploymentData.fromPlainObject(obj.revertibleContractDeploymentData),
|
|
775
|
+
{
|
|
776
|
+
noteHashes: obj.nonRevertibleAccumulatedData.noteHashes.map((h: any) => Fr.fromPlainObject(h)),
|
|
777
|
+
nullifiers: obj.nonRevertibleAccumulatedData.nullifiers.map((n: any) => Fr.fromPlainObject(n)),
|
|
778
|
+
l2ToL1Messages: obj.nonRevertibleAccumulatedData.l2ToL1Messages.map((m: any) =>
|
|
779
|
+
ScopedL2ToL1Message.fromPlainObject(m),
|
|
780
|
+
),
|
|
781
|
+
},
|
|
782
|
+
{
|
|
783
|
+
noteHashes: obj.revertibleAccumulatedData.noteHashes.map((h: any) => Fr.fromPlainObject(h)),
|
|
784
|
+
nullifiers: obj.revertibleAccumulatedData.nullifiers.map((n: any) => Fr.fromPlainObject(n)),
|
|
785
|
+
l2ToL1Messages: obj.revertibleAccumulatedData.l2ToL1Messages.map((m: any) =>
|
|
786
|
+
ScopedL2ToL1Message.fromPlainObject(m),
|
|
787
|
+
),
|
|
788
|
+
},
|
|
789
|
+
obj.setupEnqueuedCalls.map((c: any) => PublicCallRequestWithCalldata.fromPlainObject(c)),
|
|
790
|
+
obj.appLogicEnqueuedCalls.map((c: any) => PublicCallRequestWithCalldata.fromPlainObject(c)),
|
|
791
|
+
obj.teardownEnqueuedCall ? PublicCallRequestWithCalldata.fromPlainObject(obj.teardownEnqueuedCall) : null,
|
|
792
|
+
Gas.fromPlainObject(obj.gasUsedByPrivate),
|
|
793
|
+
AztecAddress.fromPlainObject(obj.feePayer),
|
|
794
|
+
);
|
|
795
|
+
}
|
|
796
|
+
|
|
200
797
|
static get schema() {
|
|
201
798
|
return z
|
|
202
799
|
.object({
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
800
|
+
hash: z.string(),
|
|
801
|
+
gasSettings: GasSettings.schema,
|
|
802
|
+
effectiveGasFees: GasFees.schema,
|
|
803
|
+
nonRevertibleContractDeploymentData: ContractDeploymentData.schema,
|
|
804
|
+
revertibleContractDeploymentData: ContractDeploymentData.schema,
|
|
805
|
+
nonRevertibleAccumulatedData: z.object({
|
|
806
|
+
noteHashes: schemas.Fr.array(),
|
|
807
|
+
nullifiers: schemas.Fr.array(),
|
|
808
|
+
l2ToL1Messages: ScopedL2ToL1Message.schema.array(),
|
|
809
|
+
}),
|
|
810
|
+
revertibleAccumulatedData: z.object({
|
|
811
|
+
noteHashes: schemas.Fr.array(),
|
|
812
|
+
nullifiers: schemas.Fr.array(),
|
|
813
|
+
l2ToL1Messages: ScopedL2ToL1Message.schema.array(),
|
|
814
|
+
}),
|
|
815
|
+
setupEnqueuedCalls: PublicCallRequestWithCalldata.schema.array(),
|
|
816
|
+
appLogicEnqueuedCalls: PublicCallRequestWithCalldata.schema.array(),
|
|
817
|
+
teardownEnqueuedCall: PublicCallRequestWithCalldata.schema.nullable(),
|
|
818
|
+
gasUsedByPrivate: Gas.schema,
|
|
819
|
+
feePayer: AztecAddress.schema,
|
|
206
820
|
})
|
|
207
821
|
.transform(
|
|
208
|
-
({
|
|
209
|
-
|
|
822
|
+
({
|
|
823
|
+
hash,
|
|
824
|
+
gasSettings,
|
|
825
|
+
effectiveGasFees,
|
|
826
|
+
nonRevertibleContractDeploymentData,
|
|
827
|
+
revertibleContractDeploymentData,
|
|
828
|
+
nonRevertibleAccumulatedData,
|
|
829
|
+
revertibleAccumulatedData,
|
|
830
|
+
setupEnqueuedCalls,
|
|
831
|
+
appLogicEnqueuedCalls,
|
|
832
|
+
teardownEnqueuedCall,
|
|
833
|
+
gasUsedByPrivate,
|
|
834
|
+
feePayer,
|
|
835
|
+
}) =>
|
|
836
|
+
new AvmTxHint(
|
|
837
|
+
hash,
|
|
838
|
+
gasSettings,
|
|
839
|
+
effectiveGasFees,
|
|
840
|
+
nonRevertibleContractDeploymentData,
|
|
841
|
+
revertibleContractDeploymentData,
|
|
842
|
+
nonRevertibleAccumulatedData,
|
|
843
|
+
revertibleAccumulatedData,
|
|
844
|
+
setupEnqueuedCalls,
|
|
845
|
+
appLogicEnqueuedCalls,
|
|
846
|
+
teardownEnqueuedCall,
|
|
847
|
+
gasUsedByPrivate,
|
|
848
|
+
feePayer,
|
|
849
|
+
),
|
|
210
850
|
);
|
|
211
851
|
}
|
|
212
852
|
}
|
|
213
853
|
|
|
214
854
|
export class AvmExecutionHints {
|
|
215
855
|
constructor(
|
|
216
|
-
public readonly
|
|
217
|
-
public
|
|
218
|
-
|
|
219
|
-
public
|
|
220
|
-
|
|
221
|
-
public readonly
|
|
222
|
-
public readonly
|
|
223
|
-
public readonly
|
|
224
|
-
public readonly
|
|
225
|
-
public readonly
|
|
856
|
+
public readonly globalVariables: GlobalVariables,
|
|
857
|
+
public tx: AvmTxHint,
|
|
858
|
+
// Protocol contracts.
|
|
859
|
+
public protocolContracts: ProtocolContracts,
|
|
860
|
+
// Contract hints.
|
|
861
|
+
public readonly contractInstances: AvmContractInstanceHint[] = [],
|
|
862
|
+
public readonly contractClasses: AvmContractClassHint[] = [],
|
|
863
|
+
public readonly bytecodeCommitments: AvmBytecodeCommitmentHint[] = [],
|
|
864
|
+
public readonly debugFunctionNames: AvmDebugFunctionNameHint[] = [],
|
|
865
|
+
public readonly contractDbCreateCheckpointHints: AvmContractDbCreateCheckpointHint[] = [],
|
|
866
|
+
public readonly contractDbCommitCheckpointHints: AvmContractDbCommitCheckpointHint[] = [],
|
|
867
|
+
public readonly contractDbRevertCheckpointHints: AvmContractDbRevertCheckpointHint[] = [],
|
|
868
|
+
// Merkle DB hints.
|
|
869
|
+
public startingTreeRoots: TreeSnapshots = TreeSnapshots.empty(),
|
|
870
|
+
public readonly getSiblingPathHints: AvmGetSiblingPathHint[] = [],
|
|
871
|
+
public readonly getPreviousValueIndexHints: AvmGetPreviousValueIndexHint[] = [],
|
|
872
|
+
public readonly getLeafPreimageHintsPublicDataTree: AvmGetLeafPreimageHintPublicDataTree[] = [],
|
|
873
|
+
public readonly getLeafPreimageHintsNullifierTree: AvmGetLeafPreimageHintNullifierTree[] = [],
|
|
874
|
+
public readonly getLeafValueHints: AvmGetLeafValueHint[] = [],
|
|
875
|
+
public readonly sequentialInsertHintsPublicDataTree: AvmSequentialInsertHintPublicDataTree[] = [],
|
|
876
|
+
public readonly sequentialInsertHintsNullifierTree: AvmSequentialInsertHintNullifierTree[] = [],
|
|
877
|
+
public readonly appendLeavesHints: AvmAppendLeavesHint[] = [],
|
|
878
|
+
public readonly createCheckpointHints: AvmCreateCheckpointHint[] = [],
|
|
879
|
+
public readonly commitCheckpointHints: AvmCommitCheckpointHint[] = [],
|
|
880
|
+
public readonly revertCheckpointHints: AvmRevertCheckpointHint[] = [],
|
|
226
881
|
) {}
|
|
227
882
|
|
|
883
|
+
/**
|
|
884
|
+
* Creates an AvmExecutionHints from a plain object without Zod validation.
|
|
885
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
886
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
887
|
+
* @param obj - Plain object containing AvmExecutionHints fields
|
|
888
|
+
* @returns An AvmExecutionHints instance
|
|
889
|
+
*/
|
|
890
|
+
static fromPlainObject(obj: any): AvmExecutionHints {
|
|
891
|
+
if (obj instanceof AvmExecutionHints) {
|
|
892
|
+
return obj;
|
|
893
|
+
}
|
|
894
|
+
return new AvmExecutionHints(
|
|
895
|
+
GlobalVariables.fromPlainObject(obj.globalVariables),
|
|
896
|
+
AvmTxHint.fromPlainObject(obj.tx),
|
|
897
|
+
ProtocolContracts.fromPlainObject(obj.protocolContracts),
|
|
898
|
+
obj.contractInstances?.map((i: any) => AvmContractInstanceHint.fromPlainObject(i)) || [],
|
|
899
|
+
obj.contractClasses?.map((c: any) => AvmContractClassHint.fromPlainObject(c)) || [],
|
|
900
|
+
obj.bytecodeCommitments?.map((b: any) => AvmBytecodeCommitmentHint.fromPlainObject(b)) || [],
|
|
901
|
+
obj.debugFunctionNames?.map((d: any) => AvmDebugFunctionNameHint.fromPlainObject(d)) || [],
|
|
902
|
+
obj.contractDbCreateCheckpointHints?.map((h: any) => AvmContractDbCreateCheckpointHint.fromPlainObject(h)) || [],
|
|
903
|
+
obj.contractDbCommitCheckpointHints?.map((h: any) => AvmContractDbCommitCheckpointHint.fromPlainObject(h)) || [],
|
|
904
|
+
obj.contractDbRevertCheckpointHints?.map((h: any) => AvmContractDbRevertCheckpointHint.fromPlainObject(h)) || [],
|
|
905
|
+
obj.startingTreeRoots ? TreeSnapshots.fromPlainObject(obj.startingTreeRoots) : TreeSnapshots.empty(),
|
|
906
|
+
obj.getSiblingPathHints?.map((h: any) => AvmGetSiblingPathHint.fromPlainObject(h)) || [],
|
|
907
|
+
obj.getPreviousValueIndexHints?.map((h: any) => AvmGetPreviousValueIndexHint.fromPlainObject(h)) || [],
|
|
908
|
+
obj.getLeafPreimageHintsPublicDataTree?.map((h: any) =>
|
|
909
|
+
AvmGetLeafPreimageHintPublicDataTree.fromPlainObject(h),
|
|
910
|
+
) || [],
|
|
911
|
+
obj.getLeafPreimageHintsNullifierTree?.map((h: any) => AvmGetLeafPreimageHintNullifierTree.fromPlainObject(h)) ||
|
|
912
|
+
[],
|
|
913
|
+
obj.getLeafValueHints?.map((h: any) => AvmGetLeafValueHint.fromPlainObject(h)) || [],
|
|
914
|
+
obj.sequentialInsertHintsPublicDataTree?.map((h: any) =>
|
|
915
|
+
AvmSequentialInsertHintPublicDataTree.fromPlainObject(h),
|
|
916
|
+
) || [],
|
|
917
|
+
obj.sequentialInsertHintsNullifierTree?.map((h: any) =>
|
|
918
|
+
AvmSequentialInsertHintNullifierTree.fromPlainObject(h),
|
|
919
|
+
) || [],
|
|
920
|
+
obj.appendLeavesHints?.map((h: any) => AvmAppendLeavesHint.fromPlainObject(h)) || [],
|
|
921
|
+
obj.createCheckpointHints?.map((h: any) => AvmCreateCheckpointHint.fromPlainObject(h)) || [],
|
|
922
|
+
obj.commitCheckpointHints?.map((h: any) => AvmCommitCheckpointHint.fromPlainObject(h)) || [],
|
|
923
|
+
obj.revertCheckpointHints?.map((h: any) => AvmRevertCheckpointHint.fromPlainObject(h)) || [],
|
|
924
|
+
);
|
|
925
|
+
}
|
|
926
|
+
|
|
228
927
|
static empty() {
|
|
229
|
-
return new AvmExecutionHints(
|
|
928
|
+
return new AvmExecutionHints(GlobalVariables.empty(), AvmTxHint.empty(), ProtocolContracts.empty());
|
|
230
929
|
}
|
|
231
930
|
|
|
232
931
|
static get schema() {
|
|
233
932
|
return z
|
|
234
933
|
.object({
|
|
235
|
-
|
|
934
|
+
globalVariables: GlobalVariables.schema,
|
|
935
|
+
tx: AvmTxHint.schema,
|
|
936
|
+
protocolContracts: ProtocolContracts.schema,
|
|
236
937
|
contractInstances: AvmContractInstanceHint.schema.array(),
|
|
237
938
|
contractClasses: AvmContractClassHint.schema.array(),
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
939
|
+
bytecodeCommitments: AvmBytecodeCommitmentHint.schema.array(),
|
|
940
|
+
debugFunctionNames: AvmDebugFunctionNameHint.schema.array(),
|
|
941
|
+
contractDbCreateCheckpointHints: AvmContractDbCreateCheckpointHint.schema.array(),
|
|
942
|
+
contractDbCommitCheckpointHints: AvmContractDbCommitCheckpointHint.schema.array(),
|
|
943
|
+
contractDbRevertCheckpointHints: AvmContractDbRevertCheckpointHint.schema.array(),
|
|
944
|
+
startingTreeRoots: TreeSnapshots.schema,
|
|
945
|
+
getSiblingPathHints: AvmGetSiblingPathHint.schema.array(),
|
|
946
|
+
getPreviousValueIndexHints: AvmGetPreviousValueIndexHint.schema.array(),
|
|
947
|
+
getLeafPreimageHintsPublicDataTree: AvmGetLeafPreimageHintPublicDataTree.schema.array(),
|
|
948
|
+
getLeafPreimageHintsNullifierTree: AvmGetLeafPreimageHintNullifierTree.schema.array(),
|
|
949
|
+
getLeafValueHints: AvmGetLeafValueHint.schema.array(),
|
|
950
|
+
sequentialInsertHintsPublicDataTree: AvmSequentialInsertHintPublicDataTree.schema.array(),
|
|
951
|
+
sequentialInsertHintsNullifierTree: AvmSequentialInsertHintNullifierTree.schema.array(),
|
|
952
|
+
appendLeavesHints: AvmAppendLeavesHint.schema.array(),
|
|
953
|
+
createCheckpointHints: AvmCreateCheckpointHint.schema.array(),
|
|
954
|
+
commitCheckpointHints: AvmCommitCheckpointHint.schema.array(),
|
|
955
|
+
revertCheckpointHints: AvmRevertCheckpointHint.schema.array(),
|
|
245
956
|
})
|
|
246
957
|
.transform(
|
|
247
958
|
({
|
|
248
|
-
|
|
959
|
+
globalVariables,
|
|
960
|
+
tx,
|
|
961
|
+
protocolContracts,
|
|
249
962
|
contractInstances,
|
|
250
963
|
contractClasses,
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
964
|
+
bytecodeCommitments,
|
|
965
|
+
debugFunctionNames,
|
|
966
|
+
contractDbCreateCheckpointHints,
|
|
967
|
+
contractDbCommitCheckpointHints,
|
|
968
|
+
contractDbRevertCheckpointHints,
|
|
969
|
+
startingTreeRoots,
|
|
970
|
+
getSiblingPathHints,
|
|
971
|
+
getPreviousValueIndexHints,
|
|
972
|
+
getLeafPreimageHintsPublicDataTree,
|
|
973
|
+
getLeafPreimageHintsNullifierTree,
|
|
974
|
+
getLeafValueHints,
|
|
975
|
+
sequentialInsertHintsPublicDataTree,
|
|
976
|
+
sequentialInsertHintsNullifierTree,
|
|
977
|
+
appendLeavesHints,
|
|
978
|
+
createCheckpointHints,
|
|
979
|
+
commitCheckpointHints,
|
|
980
|
+
revertCheckpointHints,
|
|
258
981
|
}) =>
|
|
259
982
|
new AvmExecutionHints(
|
|
260
|
-
|
|
983
|
+
globalVariables,
|
|
984
|
+
tx,
|
|
985
|
+
protocolContracts,
|
|
261
986
|
contractInstances,
|
|
262
987
|
contractClasses,
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
988
|
+
bytecodeCommitments,
|
|
989
|
+
debugFunctionNames,
|
|
990
|
+
contractDbCreateCheckpointHints,
|
|
991
|
+
contractDbCommitCheckpointHints,
|
|
992
|
+
contractDbRevertCheckpointHints,
|
|
993
|
+
startingTreeRoots,
|
|
994
|
+
getSiblingPathHints,
|
|
995
|
+
getPreviousValueIndexHints,
|
|
996
|
+
getLeafPreimageHintsPublicDataTree,
|
|
997
|
+
getLeafPreimageHintsNullifierTree,
|
|
998
|
+
getLeafValueHints,
|
|
999
|
+
sequentialInsertHintsPublicDataTree,
|
|
1000
|
+
sequentialInsertHintsNullifierTree,
|
|
1001
|
+
appendLeavesHints,
|
|
1002
|
+
createCheckpointHints,
|
|
1003
|
+
commitCheckpointHints,
|
|
1004
|
+
revertCheckpointHints,
|
|
270
1005
|
),
|
|
271
1006
|
);
|
|
272
1007
|
}
|
|
@@ -274,28 +1009,28 @@ export class AvmExecutionHints {
|
|
|
274
1009
|
|
|
275
1010
|
export class AvmCircuitInputs {
|
|
276
1011
|
constructor(
|
|
277
|
-
public readonly functionName: string, // only informational
|
|
278
|
-
public readonly calldata: Fr[],
|
|
279
1012
|
public readonly hints: AvmExecutionHints,
|
|
280
1013
|
public publicInputs: AvmCircuitPublicInputs,
|
|
281
1014
|
) {}
|
|
282
1015
|
|
|
283
1016
|
static empty() {
|
|
284
|
-
return new AvmCircuitInputs(
|
|
1017
|
+
return new AvmCircuitInputs(AvmExecutionHints.empty(), AvmCircuitPublicInputs.empty());
|
|
1018
|
+
}
|
|
1019
|
+
|
|
1020
|
+
static fromPlainObject(obj: any): AvmCircuitInputs {
|
|
1021
|
+
return new AvmCircuitInputs(
|
|
1022
|
+
AvmExecutionHints.fromPlainObject(obj.hints),
|
|
1023
|
+
AvmCircuitPublicInputs.fromPlainObject(obj.publicInputs),
|
|
1024
|
+
);
|
|
285
1025
|
}
|
|
286
1026
|
|
|
287
1027
|
static get schema() {
|
|
288
1028
|
return z
|
|
289
1029
|
.object({
|
|
290
|
-
functionName: z.string(),
|
|
291
|
-
calldata: schemas.Fr.array(),
|
|
292
1030
|
hints: AvmExecutionHints.schema,
|
|
293
1031
|
publicInputs: AvmCircuitPublicInputs.schema,
|
|
294
1032
|
})
|
|
295
|
-
.transform(
|
|
296
|
-
({ functionName, calldata, hints, publicInputs }) =>
|
|
297
|
-
new AvmCircuitInputs(functionName, calldata, hints, publicInputs),
|
|
298
|
-
);
|
|
1033
|
+
.transform(({ hints, publicInputs }) => new AvmCircuitInputs(hints, publicInputs));
|
|
299
1034
|
}
|
|
300
1035
|
|
|
301
1036
|
public serializeWithMessagePack(): Buffer {
|
|
@@ -310,3 +1045,471 @@ export class AvmCircuitInputs {
|
|
|
310
1045
|
return jsonParseWithSchema(buf.toString(), this.schema);
|
|
311
1046
|
}
|
|
312
1047
|
}
|
|
1048
|
+
|
|
1049
|
+
// Metadata about a given (enqueued or external) call.
|
|
1050
|
+
export class CallStackMetadata {
|
|
1051
|
+
constructor(
|
|
1052
|
+
public phase: TxExecutionPhase,
|
|
1053
|
+
public contractAddress: Fr,
|
|
1054
|
+
public callerPc: number,
|
|
1055
|
+
public calldata: Fr[],
|
|
1056
|
+
public isStaticCall: boolean,
|
|
1057
|
+
public gasLimit: Gas,
|
|
1058
|
+
public output: Fr[], // returndata or revertdata.
|
|
1059
|
+
public internalCallStackAtExit: number[], // At return/revert time. Last one is exit PC.
|
|
1060
|
+
public haltingMessage: string | undefined,
|
|
1061
|
+
public reverted: boolean,
|
|
1062
|
+
public nested: CallStackMetadata[],
|
|
1063
|
+
public numNestedCalls: number, // This will be different from the size of the nested vector if we went past some limit.
|
|
1064
|
+
) {}
|
|
1065
|
+
|
|
1066
|
+
static get schema(): ZodFor<CallStackMetadata> {
|
|
1067
|
+
return z
|
|
1068
|
+
.object({
|
|
1069
|
+
phase: z.nativeEnum(TxExecutionPhase),
|
|
1070
|
+
contractAddress: Fr.schema,
|
|
1071
|
+
callerPc: z.number(),
|
|
1072
|
+
calldata: Fr.schema.array(),
|
|
1073
|
+
isStaticCall: z.boolean(),
|
|
1074
|
+
gasLimit: Gas.schema,
|
|
1075
|
+
output: Fr.schema.array(),
|
|
1076
|
+
internalCallStackAtExit: z.number().array(),
|
|
1077
|
+
haltingMessage: NullishToUndefined(z.string()),
|
|
1078
|
+
reverted: z.boolean(),
|
|
1079
|
+
nested: CallStackMetadata.schema.array(),
|
|
1080
|
+
numNestedCalls: z.number(),
|
|
1081
|
+
})
|
|
1082
|
+
.transform(
|
|
1083
|
+
({
|
|
1084
|
+
phase,
|
|
1085
|
+
contractAddress,
|
|
1086
|
+
callerPc,
|
|
1087
|
+
calldata,
|
|
1088
|
+
isStaticCall,
|
|
1089
|
+
gasLimit,
|
|
1090
|
+
output,
|
|
1091
|
+
internalCallStackAtExit,
|
|
1092
|
+
haltingMessage,
|
|
1093
|
+
reverted,
|
|
1094
|
+
nested,
|
|
1095
|
+
numNestedCalls,
|
|
1096
|
+
}) =>
|
|
1097
|
+
new CallStackMetadata(
|
|
1098
|
+
phase,
|
|
1099
|
+
contractAddress,
|
|
1100
|
+
callerPc,
|
|
1101
|
+
calldata,
|
|
1102
|
+
isStaticCall,
|
|
1103
|
+
gasLimit,
|
|
1104
|
+
output,
|
|
1105
|
+
internalCallStackAtExit,
|
|
1106
|
+
haltingMessage,
|
|
1107
|
+
reverted,
|
|
1108
|
+
nested,
|
|
1109
|
+
numNestedCalls,
|
|
1110
|
+
),
|
|
1111
|
+
);
|
|
1112
|
+
}
|
|
1113
|
+
|
|
1114
|
+
/**
|
|
1115
|
+
* Creates a CallStackMetadata from a plain object without Zod validation.
|
|
1116
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
1117
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
1118
|
+
* @param obj - Plain object containing CallStackMetadata fields
|
|
1119
|
+
* @returns A CallStackMetadata instance
|
|
1120
|
+
*/
|
|
1121
|
+
static fromPlainObject(obj: any): CallStackMetadata {
|
|
1122
|
+
if (obj instanceof CallStackMetadata) {
|
|
1123
|
+
return obj;
|
|
1124
|
+
}
|
|
1125
|
+
return new CallStackMetadata(
|
|
1126
|
+
obj.phase,
|
|
1127
|
+
Fr.fromPlainObject(obj.contractAddress),
|
|
1128
|
+
obj.callerPc,
|
|
1129
|
+
obj.calldata.map((f: any) => Fr.fromPlainObject(f)),
|
|
1130
|
+
obj.isStaticCall,
|
|
1131
|
+
Gas.fromPlainObject(obj.gasLimit),
|
|
1132
|
+
obj.output.map((f: any) => Fr.fromPlainObject(f)),
|
|
1133
|
+
obj.internalCallStackAtExit.map((p: any) => Number(p)),
|
|
1134
|
+
obj.haltingMessage,
|
|
1135
|
+
obj.reverted,
|
|
1136
|
+
obj.nested.map((n: any) => CallStackMetadata.fromPlainObject(n)),
|
|
1137
|
+
obj.numNestedCalls,
|
|
1138
|
+
);
|
|
1139
|
+
}
|
|
1140
|
+
|
|
1141
|
+
public getRevertReason(): SimulationError | undefined {
|
|
1142
|
+
const failingCall = this.findDeepestRevert([this]);
|
|
1143
|
+
|
|
1144
|
+
if (!failingCall) {
|
|
1145
|
+
return undefined;
|
|
1146
|
+
}
|
|
1147
|
+
|
|
1148
|
+
const { stack, leaf } = failingCall;
|
|
1149
|
+
const aztecCallStack = stack.map(call => ({
|
|
1150
|
+
contractAddress: AztecAddress.fromField(call.contractAddress),
|
|
1151
|
+
functionSelector: call.calldata.length > 0 ? FunctionSelector.fromFieldOrUndefined(call.calldata[0]) : undefined,
|
|
1152
|
+
}));
|
|
1153
|
+
|
|
1154
|
+
// The Noir call stack is the internal call stack at exit of the failing call
|
|
1155
|
+
const noirCallStack = leaf.internalCallStackAtExit.map(pc => `0.${pc}`);
|
|
1156
|
+
|
|
1157
|
+
return new SimulationError(
|
|
1158
|
+
leaf.haltingMessage ?? 'Transaction reverted',
|
|
1159
|
+
aztecCallStack,
|
|
1160
|
+
leaf.output,
|
|
1161
|
+
noirCallStack,
|
|
1162
|
+
);
|
|
1163
|
+
}
|
|
1164
|
+
|
|
1165
|
+
/**
|
|
1166
|
+
* Finds the "rightmost deepest" revert in the call tree.
|
|
1167
|
+
*
|
|
1168
|
+
* At each level, we select the LAST (rightmost) reverted call, then recurse into its
|
|
1169
|
+
* nested calls to find the deepest reverted leaf along that path. The chain stops
|
|
1170
|
+
* when we encounter a non-reverted call (since you can choose not to rethrow).
|
|
1171
|
+
*
|
|
1172
|
+
* Examples (X = reverted, O = passed):
|
|
1173
|
+
*
|
|
1174
|
+
* 1. [X, X, X] at depth 1 -> returns the last X (rightmost)
|
|
1175
|
+
*
|
|
1176
|
+
* 2. [X(depth2), X, X] where first X has a nested revert -> returns the last X at depth 1,
|
|
1177
|
+
* NOT the deeper revert in the first X (rightmost takes priority over depth)
|
|
1178
|
+
*
|
|
1179
|
+
* 3. X -> X -> X -> O -> O -> X (nested chain)
|
|
1180
|
+
* Returns the 3rd X, because the O's break the reverted chain (they didn't rethrow)
|
|
1181
|
+
*
|
|
1182
|
+
* @param calls - Array of call metadata at the current level
|
|
1183
|
+
* @param parentStack - Accumulated stack of parent calls (for building the result)
|
|
1184
|
+
* @returns The deepest reverted call along the rightmost reverted path, or undefined if none
|
|
1185
|
+
*/
|
|
1186
|
+
private findDeepestRevert(
|
|
1187
|
+
calls: CallStackMetadata[],
|
|
1188
|
+
parentStack: CallStackMetadata[] = [],
|
|
1189
|
+
): { stack: CallStackMetadata[]; leaf: CallStackMetadata } | undefined {
|
|
1190
|
+
const lastReverted = calls.findLast(call => call.reverted);
|
|
1191
|
+
if (!lastReverted) {
|
|
1192
|
+
return undefined;
|
|
1193
|
+
}
|
|
1194
|
+
const currentStack = [...parentStack, lastReverted];
|
|
1195
|
+
return this.findDeepestRevert(lastReverted.nested, currentStack) || { stack: currentStack, leaf: lastReverted };
|
|
1196
|
+
}
|
|
1197
|
+
}
|
|
1198
|
+
|
|
1199
|
+
export class PublicTxEffect {
|
|
1200
|
+
constructor(
|
|
1201
|
+
public transactionFee: Fr,
|
|
1202
|
+
public noteHashes: Fr[],
|
|
1203
|
+
public nullifiers: Fr[],
|
|
1204
|
+
public l2ToL1Msgs: ScopedL2ToL1Message[],
|
|
1205
|
+
public publicLogs: PublicLog[],
|
|
1206
|
+
public publicDataWrites: PublicDataWrite[],
|
|
1207
|
+
) {}
|
|
1208
|
+
|
|
1209
|
+
static empty() {
|
|
1210
|
+
return new PublicTxEffect(Fr.ZERO, [], [], [], [], []);
|
|
1211
|
+
}
|
|
1212
|
+
|
|
1213
|
+
static get schema(): ZodFor<PublicTxEffect> {
|
|
1214
|
+
return z
|
|
1215
|
+
.object({
|
|
1216
|
+
transactionFee: Fr.schema,
|
|
1217
|
+
noteHashes: Fr.schema.array(),
|
|
1218
|
+
nullifiers: Fr.schema.array(),
|
|
1219
|
+
l2ToL1Msgs: ScopedL2ToL1Message.schema.array(),
|
|
1220
|
+
publicLogs: PublicLog.schema.array(),
|
|
1221
|
+
publicDataWrites: PublicDataWrite.schema.array(),
|
|
1222
|
+
})
|
|
1223
|
+
.transform(PublicTxEffect.from);
|
|
1224
|
+
}
|
|
1225
|
+
|
|
1226
|
+
static from(obj: any): PublicTxEffect {
|
|
1227
|
+
return new PublicTxEffect(
|
|
1228
|
+
obj.transactionFee,
|
|
1229
|
+
obj.noteHashes,
|
|
1230
|
+
obj.nullifiers,
|
|
1231
|
+
obj.l2ToL1Msgs,
|
|
1232
|
+
obj.publicLogs,
|
|
1233
|
+
obj.publicDataWrites,
|
|
1234
|
+
);
|
|
1235
|
+
}
|
|
1236
|
+
|
|
1237
|
+
static fromPlainObject(obj: any): PublicTxEffect {
|
|
1238
|
+
return new PublicTxEffect(
|
|
1239
|
+
Fr.fromPlainObject(obj.transactionFee),
|
|
1240
|
+
obj.noteHashes.map((h: any) => Fr.fromPlainObject(h)),
|
|
1241
|
+
obj.nullifiers.map((n: any) => Fr.fromPlainObject(n)),
|
|
1242
|
+
obj.l2ToL1Msgs.map((m: any) => ScopedL2ToL1Message.fromPlainObject(m)),
|
|
1243
|
+
obj.publicLogs.map((l: any) => PublicLog.fromPlainObject(l)),
|
|
1244
|
+
obj.publicDataWrites.map((w: any) => PublicDataWrite.fromPlainObject(w)),
|
|
1245
|
+
);
|
|
1246
|
+
}
|
|
1247
|
+
|
|
1248
|
+
equals(other: PublicTxEffect): boolean {
|
|
1249
|
+
return (
|
|
1250
|
+
this.transactionFee.equals(other.transactionFee) &&
|
|
1251
|
+
this.noteHashes.length === other.noteHashes.length &&
|
|
1252
|
+
this.noteHashes.every((h, i) => h.equals(other.noteHashes[i])) &&
|
|
1253
|
+
this.nullifiers.length === other.nullifiers.length &&
|
|
1254
|
+
this.nullifiers.every((h, i) => h.equals(other.nullifiers[i])) &&
|
|
1255
|
+
this.l2ToL1Msgs.length === other.l2ToL1Msgs.length &&
|
|
1256
|
+
this.l2ToL1Msgs.every((m, i) => m.equals(other.l2ToL1Msgs[i])) &&
|
|
1257
|
+
this.publicLogs.length === other.publicLogs.length &&
|
|
1258
|
+
this.publicLogs.every((l, i) => l.equals(other.publicLogs[i])) &&
|
|
1259
|
+
this.publicDataWrites.length === other.publicDataWrites.length &&
|
|
1260
|
+
this.publicDataWrites.every((w, i) => w.equals(other.publicDataWrites[i]))
|
|
1261
|
+
);
|
|
1262
|
+
}
|
|
1263
|
+
}
|
|
1264
|
+
|
|
1265
|
+
export class PublicTxResult {
|
|
1266
|
+
constructor(
|
|
1267
|
+
// Simulation result.
|
|
1268
|
+
public gasUsed: GasUsed,
|
|
1269
|
+
public revertCode: RevertCode,
|
|
1270
|
+
public publicTxEffect: PublicTxEffect,
|
|
1271
|
+
// These are only guaranteed to be present if the simulator is configured to collect them.
|
|
1272
|
+
// TODO(fcarreiro): Remove NestedProcessReturnValues[] once we migrate to the C++ simulator.
|
|
1273
|
+
public callStackMetadata:
|
|
1274
|
+
| CallStackMetadata[] // One per enqueued call. All phases.
|
|
1275
|
+
| NestedProcessReturnValues[], // One per enqueued call. App logic only.
|
|
1276
|
+
public logs: DebugLog[] | undefined,
|
|
1277
|
+
// For the proving request.
|
|
1278
|
+
public hints: AvmExecutionHints | undefined,
|
|
1279
|
+
public publicInputs: AvmCircuitPublicInputs | undefined,
|
|
1280
|
+
) {}
|
|
1281
|
+
|
|
1282
|
+
static empty() {
|
|
1283
|
+
return new PublicTxResult(
|
|
1284
|
+
{
|
|
1285
|
+
totalGas: Gas.empty(),
|
|
1286
|
+
teardownGas: Gas.empty(),
|
|
1287
|
+
publicGas: Gas.empty(),
|
|
1288
|
+
billedGas: Gas.empty(),
|
|
1289
|
+
},
|
|
1290
|
+
RevertCode.OK,
|
|
1291
|
+
PublicTxEffect.empty(),
|
|
1292
|
+
/*callStackMetadata=*/ [] as CallStackMetadata[],
|
|
1293
|
+
/*logs=*/ [],
|
|
1294
|
+
/*hints=*/ AvmExecutionHints.empty(),
|
|
1295
|
+
/*publicInputs=*/ AvmCircuitPublicInputs.empty(),
|
|
1296
|
+
);
|
|
1297
|
+
}
|
|
1298
|
+
|
|
1299
|
+
static get schema(): ZodFor<PublicTxResult> {
|
|
1300
|
+
return z
|
|
1301
|
+
.object({
|
|
1302
|
+
gasUsed: schemas.GasUsed,
|
|
1303
|
+
revertCode: RevertCode.schema,
|
|
1304
|
+
revertReason: NullishToUndefined(SimulationError.schema),
|
|
1305
|
+
publicTxEffect: PublicTxEffect.schema,
|
|
1306
|
+
callStackMetadata: z.union([CallStackMetadata.schema.array(), NestedProcessReturnValues.schema.array()]),
|
|
1307
|
+
logs: NullishToUndefined(DebugLog.schema.array()),
|
|
1308
|
+
// For the proving request.
|
|
1309
|
+
publicInputs: NullishToUndefined(AvmCircuitPublicInputs.schema),
|
|
1310
|
+
hints: NullishToUndefined(AvmExecutionHints.schema),
|
|
1311
|
+
})
|
|
1312
|
+
.transform(
|
|
1313
|
+
({ gasUsed, revertCode, publicTxEffect, callStackMetadata, logs, hints, publicInputs }) =>
|
|
1314
|
+
new PublicTxResult(
|
|
1315
|
+
gasUsed,
|
|
1316
|
+
revertCode as RevertCode,
|
|
1317
|
+
publicTxEffect,
|
|
1318
|
+
callStackMetadata,
|
|
1319
|
+
logs,
|
|
1320
|
+
hints,
|
|
1321
|
+
publicInputs,
|
|
1322
|
+
),
|
|
1323
|
+
);
|
|
1324
|
+
}
|
|
1325
|
+
|
|
1326
|
+
/**
|
|
1327
|
+
* Creates a PublicTxResult from a plain object without Zod validation.
|
|
1328
|
+
* This method is optimized for performance and skips validation, making it suitable
|
|
1329
|
+
* for deserializing trusted data (e.g., from C++ via MessagePack).
|
|
1330
|
+
* @param obj - Plain object containing PublicTxResult fields
|
|
1331
|
+
* @returns A PublicTxResult instance
|
|
1332
|
+
*/
|
|
1333
|
+
static fromPlainObject(obj: any): PublicTxResult {
|
|
1334
|
+
return new PublicTxResult(
|
|
1335
|
+
GasUsed.fromPlainObject(obj.gasUsed),
|
|
1336
|
+
RevertCode.fromPlainObject(obj.revertCode),
|
|
1337
|
+
PublicTxEffect.fromPlainObject(obj.publicTxEffect),
|
|
1338
|
+
obj.callStackMetadata.map(CallStackMetadata.fromPlainObject), // Always CallStackMetadata[] from MessagePack.
|
|
1339
|
+
obj.logs?.map(DebugLog.fromPlainObject),
|
|
1340
|
+
obj.hints ? AvmExecutionHints.fromPlainObject(obj.hints) : undefined,
|
|
1341
|
+
obj.publicInputs ? AvmCircuitPublicInputs.fromPlainObject(obj.publicInputs) : undefined,
|
|
1342
|
+
);
|
|
1343
|
+
}
|
|
1344
|
+
|
|
1345
|
+
/** Returns one level of return values for the app logic phase, one per enqueued call. */
|
|
1346
|
+
public getAppLogicReturnValues(): NestedProcessReturnValues[] {
|
|
1347
|
+
if (this.callStackMetadata.every(metadata => metadata instanceof CallStackMetadata)) {
|
|
1348
|
+
return this.callStackMetadata
|
|
1349
|
+
.filter(metadata => metadata.phase === TxExecutionPhase.APP_LOGIC)
|
|
1350
|
+
.map(metadata => new NestedProcessReturnValues(metadata.output));
|
|
1351
|
+
} else {
|
|
1352
|
+
return (this.callStackMetadata as NestedProcessReturnValues[]).map(
|
|
1353
|
+
metadata => new NestedProcessReturnValues(metadata.values, metadata.nested),
|
|
1354
|
+
);
|
|
1355
|
+
}
|
|
1356
|
+
}
|
|
1357
|
+
|
|
1358
|
+
public findRevertReason(): SimulationError | undefined {
|
|
1359
|
+
if (this.revertCode.isOK()) {
|
|
1360
|
+
return undefined;
|
|
1361
|
+
}
|
|
1362
|
+
|
|
1363
|
+
const callStackMetadata = this.callStackMetadata;
|
|
1364
|
+
// TODO(fcarreiro): Remove this after migration to the C++ simulator.
|
|
1365
|
+
// If the "stack" comes from TS, it will have this field.
|
|
1366
|
+
if ((callStackMetadata as any).revertReason !== undefined) {
|
|
1367
|
+
return (callStackMetadata as any).revertReason;
|
|
1368
|
+
}
|
|
1369
|
+
|
|
1370
|
+
// Handle CallStackMetadata[].
|
|
1371
|
+
let revertReason: SimulationError | undefined = undefined;
|
|
1372
|
+
for (const call of callStackMetadata) {
|
|
1373
|
+
revertReason = (call as CallStackMetadata).getRevertReason();
|
|
1374
|
+
if (revertReason) {
|
|
1375
|
+
break;
|
|
1376
|
+
}
|
|
1377
|
+
}
|
|
1378
|
+
return revertReason;
|
|
1379
|
+
}
|
|
1380
|
+
}
|
|
1381
|
+
|
|
1382
|
+
export class CollectionLimitsConfig {
|
|
1383
|
+
constructor(
|
|
1384
|
+
public readonly maxDebugLogMemoryReads: number,
|
|
1385
|
+
public readonly maxCalldataSizeInFields: number,
|
|
1386
|
+
public readonly maxReturndataSizeInFields: number,
|
|
1387
|
+
public readonly maxCallStackDepth: number,
|
|
1388
|
+
public readonly maxCallStackItems: number,
|
|
1389
|
+
) {}
|
|
1390
|
+
|
|
1391
|
+
static from(obj: Partial<CollectionLimitsConfig>): CollectionLimitsConfig {
|
|
1392
|
+
return new CollectionLimitsConfig(
|
|
1393
|
+
obj.maxDebugLogMemoryReads ?? DEFAULT_MAX_DEBUG_LOG_MEMORY_READS,
|
|
1394
|
+
obj.maxCalldataSizeInFields ?? 300,
|
|
1395
|
+
obj.maxReturndataSizeInFields ?? 300,
|
|
1396
|
+
obj.maxCallStackDepth ?? 5,
|
|
1397
|
+
obj.maxCallStackItems ?? 100,
|
|
1398
|
+
);
|
|
1399
|
+
}
|
|
1400
|
+
|
|
1401
|
+
static empty() {
|
|
1402
|
+
return CollectionLimitsConfig.from({});
|
|
1403
|
+
}
|
|
1404
|
+
|
|
1405
|
+
static get schema() {
|
|
1406
|
+
return z
|
|
1407
|
+
.object({
|
|
1408
|
+
maxDebugLogMemoryReads: z.number(),
|
|
1409
|
+
maxCalldataSizeInFields: z.number(),
|
|
1410
|
+
maxReturndataSizeInFields: z.number(),
|
|
1411
|
+
maxCallStackDepth: z.number(),
|
|
1412
|
+
maxCallStackItems: z.number(),
|
|
1413
|
+
})
|
|
1414
|
+
.transform(
|
|
1415
|
+
({
|
|
1416
|
+
maxDebugLogMemoryReads,
|
|
1417
|
+
maxCalldataSizeInFields,
|
|
1418
|
+
maxReturndataSizeInFields,
|
|
1419
|
+
maxCallStackDepth,
|
|
1420
|
+
maxCallStackItems,
|
|
1421
|
+
}) =>
|
|
1422
|
+
new CollectionLimitsConfig(
|
|
1423
|
+
maxDebugLogMemoryReads,
|
|
1424
|
+
maxCalldataSizeInFields,
|
|
1425
|
+
maxReturndataSizeInFields,
|
|
1426
|
+
maxCallStackDepth,
|
|
1427
|
+
maxCallStackItems,
|
|
1428
|
+
),
|
|
1429
|
+
);
|
|
1430
|
+
}
|
|
1431
|
+
}
|
|
1432
|
+
|
|
1433
|
+
export class PublicSimulatorConfig {
|
|
1434
|
+
constructor(
|
|
1435
|
+
public readonly proverId: Fr,
|
|
1436
|
+
public readonly skipFeeEnforcement: boolean,
|
|
1437
|
+
public readonly collectCallMetadata: boolean, // appLogicReturnValues.
|
|
1438
|
+
public readonly collectHints: boolean, // hints.
|
|
1439
|
+
public readonly collectPublicInputs: boolean, // public inputs.
|
|
1440
|
+
public readonly collectDebugLogs: boolean, // logs.
|
|
1441
|
+
public readonly collectStatistics: boolean, // timings etc.
|
|
1442
|
+
public readonly collectionLimits: CollectionLimitsConfig,
|
|
1443
|
+
) {}
|
|
1444
|
+
|
|
1445
|
+
static from(obj: Partial<PublicSimulatorConfig>): PublicSimulatorConfig {
|
|
1446
|
+
return new PublicSimulatorConfig(
|
|
1447
|
+
obj.proverId ?? Fr.ZERO,
|
|
1448
|
+
obj.skipFeeEnforcement ?? false,
|
|
1449
|
+
obj.collectCallMetadata ?? false,
|
|
1450
|
+
obj.collectHints ?? false,
|
|
1451
|
+
obj.collectPublicInputs ?? false,
|
|
1452
|
+
obj.collectDebugLogs ?? false,
|
|
1453
|
+
obj.collectStatistics ?? false,
|
|
1454
|
+
obj.collectionLimits ?? CollectionLimitsConfig.empty(),
|
|
1455
|
+
);
|
|
1456
|
+
}
|
|
1457
|
+
|
|
1458
|
+
static empty() {
|
|
1459
|
+
return PublicSimulatorConfig.from({});
|
|
1460
|
+
}
|
|
1461
|
+
|
|
1462
|
+
static get schema() {
|
|
1463
|
+
return z
|
|
1464
|
+
.object({
|
|
1465
|
+
proverId: Fr.schema,
|
|
1466
|
+
skipFeeEnforcement: z.boolean(),
|
|
1467
|
+
collectCallMetadata: z.boolean(),
|
|
1468
|
+
collectHints: z.boolean(),
|
|
1469
|
+
collectPublicInputs: z.boolean(),
|
|
1470
|
+
collectDebugLogs: z.boolean(),
|
|
1471
|
+
collectStatistics: z.boolean(),
|
|
1472
|
+
collectionLimits: CollectionLimitsConfig.schema,
|
|
1473
|
+
})
|
|
1474
|
+
.transform(PublicSimulatorConfig.from);
|
|
1475
|
+
}
|
|
1476
|
+
}
|
|
1477
|
+
|
|
1478
|
+
export class AvmFastSimulationInputs {
|
|
1479
|
+
constructor(
|
|
1480
|
+
public readonly wsRevision: WorldStateRevision,
|
|
1481
|
+
public readonly config: PublicSimulatorConfig,
|
|
1482
|
+
public tx: AvmTxHint,
|
|
1483
|
+
public globalVariables: GlobalVariables,
|
|
1484
|
+
public protocolContracts: ProtocolContracts,
|
|
1485
|
+
) {}
|
|
1486
|
+
|
|
1487
|
+
static empty() {
|
|
1488
|
+
return new AvmFastSimulationInputs(
|
|
1489
|
+
WorldStateRevision.empty(),
|
|
1490
|
+
PublicSimulatorConfig.empty(),
|
|
1491
|
+
AvmTxHint.empty(),
|
|
1492
|
+
GlobalVariables.empty(),
|
|
1493
|
+
ProtocolContracts.empty(),
|
|
1494
|
+
);
|
|
1495
|
+
}
|
|
1496
|
+
|
|
1497
|
+
static get schema() {
|
|
1498
|
+
return z
|
|
1499
|
+
.object({
|
|
1500
|
+
wsRevision: WorldStateRevision.schema,
|
|
1501
|
+
config: PublicSimulatorConfig.schema,
|
|
1502
|
+
tx: AvmTxHint.schema,
|
|
1503
|
+
globalVariables: GlobalVariables.schema,
|
|
1504
|
+
protocolContracts: ProtocolContracts.schema,
|
|
1505
|
+
})
|
|
1506
|
+
.transform(
|
|
1507
|
+
({ wsRevision, config, tx, globalVariables, protocolContracts }) =>
|
|
1508
|
+
new AvmFastSimulationInputs(wsRevision, config, tx, globalVariables, protocolContracts),
|
|
1509
|
+
);
|
|
1510
|
+
}
|
|
1511
|
+
|
|
1512
|
+
public serializeWithMessagePack(): Buffer {
|
|
1513
|
+
return serializeWithMessagePack(this);
|
|
1514
|
+
}
|
|
1515
|
+
}
|