@aztec/stdlib 0.0.1-commit.7d4e6cd → 0.0.1-commit.808bf7f90
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/function_call.d.ts +47 -9
- package/dest/abi/function_call.d.ts.map +1 -1
- package/dest/abi/function_call.js +20 -3
- package/dest/abi/utils.d.ts +7 -1
- package/dest/abi/utils.d.ts.map +1 -1
- package/dest/abi/utils.js +7 -0
- package/dest/auth_witness/auth_witness.d.ts +2 -1
- package/dest/auth_witness/auth_witness.d.ts.map +1 -1
- package/dest/auth_witness/auth_witness.js +3 -3
- package/dest/avm/avm.d.ts +62 -62
- package/dest/avm/avm_accumulated_data.d.ts +30 -3
- package/dest/avm/avm_accumulated_data.d.ts.map +1 -1
- package/dest/avm/avm_circuit_public_inputs.d.ts +9 -9
- package/dest/avm/avm_proving_request.d.ts +299 -299
- package/dest/avm/contract_storage_read.d.ts +13 -1
- package/dest/avm/contract_storage_read.d.ts.map +1 -1
- package/dest/avm/contract_storage_update_request.d.ts +13 -1
- package/dest/avm/contract_storage_update_request.d.ts.map +1 -1
- package/dest/avm/public_call_stack_item_compressed.d.ts +3 -1
- package/dest/avm/public_call_stack_item_compressed.d.ts.map +1 -1
- package/dest/avm/public_data_read.d.ts +10 -1
- package/dest/avm/public_data_read.d.ts.map +1 -1
- package/dest/avm/public_data_update_request.d.ts +10 -1
- package/dest/avm/public_data_update_request.d.ts.map +1 -1
- package/dest/avm/public_data_write.d.ts +7 -1
- package/dest/avm/public_data_write.d.ts.map +1 -1
- package/dest/avm/public_inner_call_request.d.ts +4 -1
- package/dest/avm/public_inner_call_request.d.ts.map +1 -1
- package/dest/avm/revert_code.d.ts +4 -4
- package/dest/avm/revert_code.d.ts.map +1 -1
- package/dest/block/block_data.d.ts +52 -0
- package/dest/block/block_data.d.ts.map +1 -0
- package/dest/block/block_data.js +12 -0
- package/dest/block/block_hash.d.ts +18 -14
- package/dest/block/block_hash.d.ts.map +1 -1
- package/dest/block/block_hash.js +22 -20
- package/dest/block/block_parameter.d.ts +4 -3
- package/dest/block/block_parameter.d.ts.map +1 -1
- package/dest/block/block_parameter.js +2 -0
- package/dest/block/body.d.ts +1 -1
- package/dest/block/body.d.ts.map +1 -1
- package/dest/block/body.js +2 -1
- package/dest/block/checkpointed_l2_block.d.ts +20 -137
- package/dest/block/checkpointed_l2_block.d.ts.map +1 -1
- package/dest/block/checkpointed_l2_block.js +7 -45
- package/dest/block/in_block.d.ts +9 -9
- package/dest/block/in_block.d.ts.map +1 -1
- package/dest/block/in_block.js +5 -5
- package/dest/block/index.d.ts +2 -3
- package/dest/block/index.d.ts.map +1 -1
- package/dest/block/index.js +1 -2
- package/dest/block/l2_block.d.ts +56 -59
- package/dest/block/l2_block.d.ts.map +1 -1
- package/dest/block/l2_block.js +64 -110
- package/dest/block/l2_block_source.d.ts +84 -39
- package/dest/block/l2_block_source.d.ts.map +1 -1
- package/dest/block/l2_block_source.js +2 -1
- package/dest/block/l2_block_stream/interfaces.d.ts +9 -6
- package/dest/block/l2_block_stream/interfaces.d.ts.map +1 -1
- package/dest/block/l2_block_stream/l2_block_stream.d.ts +6 -3
- package/dest/block/l2_block_stream/l2_block_stream.d.ts.map +1 -1
- package/dest/block/l2_block_stream/l2_block_stream.js +37 -34
- package/dest/block/l2_block_stream/l2_tips_store_base.d.ts +3 -3
- package/dest/block/l2_block_stream/l2_tips_store_base.d.ts.map +1 -1
- package/dest/block/test/l2_tips_store_test_suite.d.ts +1 -1
- package/dest/block/test/l2_tips_store_test_suite.d.ts.map +1 -1
- package/dest/block/test/l2_tips_store_test_suite.js +2 -7
- package/dest/block/validate_block_result.d.ts +1 -1
- package/dest/block/validate_block_result.d.ts.map +1 -1
- package/dest/block/validate_block_result.js +5 -4
- package/dest/checkpoint/checkpoint.d.ts +43 -19
- package/dest/checkpoint/checkpoint.d.ts.map +1 -1
- package/dest/checkpoint/checkpoint.js +37 -14
- package/dest/checkpoint/checkpoint_data.d.ts +120 -0
- package/dest/checkpoint/checkpoint_data.d.ts.map +1 -0
- package/dest/checkpoint/checkpoint_data.js +26 -0
- package/dest/checkpoint/index.d.ts +2 -1
- package/dest/checkpoint/index.d.ts.map +1 -1
- package/dest/checkpoint/index.js +1 -0
- package/dest/checkpoint/published_checkpoint.d.ts +33 -16
- package/dest/checkpoint/published_checkpoint.d.ts.map +1 -1
- package/dest/checkpoint/published_checkpoint.js +5 -5
- package/dest/config/index.d.ts +2 -1
- package/dest/config/index.d.ts.map +1 -1
- package/dest/config/index.js +1 -0
- package/dest/config/node-rpc-config.js +1 -1
- package/dest/config/sequencer-config.d.ts +10 -0
- package/dest/config/sequencer-config.d.ts.map +1 -0
- package/dest/config/sequencer-config.js +18 -0
- package/dest/contract/complete_address.d.ts +4 -1
- package/dest/contract/complete_address.d.ts.map +1 -1
- package/dest/contract/contract_address.js +4 -4
- package/dest/contract/contract_class.d.ts +2 -3
- package/dest/contract/contract_class.d.ts.map +1 -1
- package/dest/contract/contract_class_id.d.ts +2 -2
- package/dest/contract/contract_class_id.d.ts.map +1 -1
- package/dest/contract/contract_class_id.js +6 -5
- package/dest/contract/contract_deployment_data.d.ts +5 -5
- package/dest/contract/index.d.ts +1 -3
- package/dest/contract/index.d.ts.map +1 -1
- package/dest/contract/index.js +0 -2
- package/dest/contract/interfaces/contract_instance.d.ts +16 -16
- package/dest/contract/interfaces/node-info.d.ts +3 -1
- package/dest/contract/interfaces/node-info.d.ts.map +1 -1
- package/dest/contract/interfaces/node-info.js +2 -1
- package/dest/contract/private_function.d.ts +1 -1
- package/dest/contract/private_function.d.ts.map +1 -1
- package/dest/contract/private_function.js +3 -4
- package/dest/contract/private_function_membership_proof.d.ts +1 -1
- package/dest/contract/private_function_membership_proof.js +1 -1
- package/dest/database-version/database_version.d.ts +58 -0
- package/dest/database-version/database_version.d.ts.map +1 -0
- package/dest/database-version/database_version.js +69 -0
- package/dest/database-version/version_manager.d.ts +3 -49
- package/dest/database-version/version_manager.d.ts.map +1 -1
- package/dest/database-version/version_manager.js +1 -66
- package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts +2 -2
- package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts.map +1 -1
- package/dest/delayed_public_mutable/delayed_public_mutable_values.js +7 -10
- package/dest/deserialization/index.d.ts +11 -0
- package/dest/deserialization/index.d.ts.map +1 -0
- package/dest/deserialization/index.js +10 -0
- package/dest/epoch-helpers/index.d.ts +7 -1
- package/dest/epoch-helpers/index.d.ts.map +1 -1
- package/dest/epoch-helpers/index.js +9 -3
- package/dest/errors/proving_error.d.ts +2 -2
- package/dest/errors/proving_error.d.ts.map +1 -1
- package/dest/file-store/local.d.ts +3 -3
- package/dest/file-store/local.d.ts.map +1 -1
- package/dest/file-store/local.js +13 -4
- package/dest/file-store/s3.d.ts +1 -1
- package/dest/file-store/s3.d.ts.map +1 -1
- package/dest/file-store/s3.js +11 -3
- package/dest/ha-signing/config.d.ts +101 -0
- package/dest/ha-signing/config.d.ts.map +1 -0
- package/dest/ha-signing/config.js +92 -0
- package/dest/ha-signing/index.d.ts +3 -0
- package/dest/ha-signing/index.d.ts.map +1 -0
- package/dest/ha-signing/index.js +2 -0
- package/dest/ha-signing/types.d.ts +85 -0
- package/dest/ha-signing/types.d.ts.map +1 -0
- package/dest/ha-signing/types.js +32 -0
- package/dest/hash/hash.d.ts +2 -1
- package/dest/hash/hash.d.ts.map +1 -1
- package/dest/hash/hash.js +16 -10
- package/dest/hash/map_slot.d.ts +1 -1
- package/dest/hash/map_slot.d.ts.map +1 -1
- package/dest/hash/map_slot.js +4 -3
- package/dest/interfaces/api_limit.d.ts +2 -1
- package/dest/interfaces/api_limit.d.ts.map +1 -1
- package/dest/interfaces/api_limit.js +1 -0
- package/dest/interfaces/archiver.d.ts +1 -1
- package/dest/interfaces/archiver.d.ts.map +1 -1
- package/dest/interfaces/archiver.js +23 -15
- package/dest/interfaces/aztec-node-admin.d.ts +101 -28
- package/dest/interfaces/aztec-node-admin.d.ts.map +1 -1
- package/dest/interfaces/aztec-node-admin.js +12 -4
- package/dest/interfaces/aztec-node.d.ts +66 -69
- package/dest/interfaces/aztec-node.d.ts.map +1 -1
- package/dest/interfaces/aztec-node.js +10 -16
- package/dest/interfaces/block-builder.d.ts +22 -14
- package/dest/interfaces/block-builder.d.ts.map +1 -1
- package/dest/interfaces/block-builder.js +7 -0
- package/dest/interfaces/configs.d.ts +24 -9
- package/dest/interfaces/configs.d.ts.map +1 -1
- package/dest/interfaces/configs.js +4 -1
- package/dest/interfaces/get_logs_response.d.ts +16 -9
- package/dest/interfaces/get_logs_response.d.ts.map +1 -1
- package/dest/interfaces/l2_logs_source.d.ts +14 -5
- package/dest/interfaces/l2_logs_source.d.ts.map +1 -1
- package/dest/interfaces/merkle_tree_operations.d.ts +2 -2
- package/dest/interfaces/merkle_tree_operations.d.ts.map +1 -1
- package/dest/interfaces/p2p.d.ts +2 -2
- package/dest/interfaces/p2p.d.ts.map +1 -1
- package/dest/interfaces/prover-broker.d.ts +16 -1
- package/dest/interfaces/prover-broker.d.ts.map +1 -1
- package/dest/interfaces/prover-broker.js +4 -1
- package/dest/interfaces/prover-client.d.ts +15 -1
- package/dest/interfaces/prover-client.d.ts.map +1 -1
- package/dest/interfaces/prover-client.js +12 -1
- package/dest/interfaces/proving-job.d.ts +216 -216
- package/dest/interfaces/slasher.d.ts +9 -1
- package/dest/interfaces/slasher.d.ts.map +1 -1
- package/dest/interfaces/slasher.js +2 -0
- package/dest/interfaces/tx_provider.d.ts +3 -3
- package/dest/interfaces/tx_provider.d.ts.map +1 -1
- package/dest/interfaces/validator.d.ts +118 -16
- package/dest/interfaces/validator.d.ts.map +1 -1
- package/dest/interfaces/validator.js +6 -3
- package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts +1 -1
- 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 +16 -6
- package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts +3 -3
- package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts.map +1 -1
- package/dest/kernel/hints/build_nullifier_read_request_hints.js +16 -8
- package/dest/kernel/hints/index.d.ts +2 -2
- package/dest/kernel/hints/index.js +2 -2
- package/dest/kernel/hints/key_validation_hint.d.ts +2 -1
- package/dest/kernel/hints/key_validation_hint.d.ts.map +1 -1
- package/dest/kernel/hints/key_validation_request.d.ts +2 -1
- package/dest/kernel/hints/key_validation_request.d.ts.map +1 -1
- package/dest/kernel/hints/key_validation_request_and_separator.d.ts +24 -0
- package/dest/kernel/hints/key_validation_request_and_separator.d.ts.map +1 -0
- package/dest/kernel/hints/{key_validation_request_and_generator.js → key_validation_request_and_separator.js} +12 -15
- package/dest/kernel/hints/private_kernel_reset_hints.d.ts +13 -1
- package/dest/kernel/hints/private_kernel_reset_hints.d.ts.map +1 -1
- package/dest/kernel/hints/read_request.d.ts +7 -1
- package/dest/kernel/hints/read_request.d.ts.map +1 -1
- package/dest/kernel/hints/read_request_hints.d.ts +7 -1
- package/dest/kernel/hints/read_request_hints.d.ts.map +1 -1
- package/dest/kernel/hints/{scoped_key_validation_request_and_generator.d.ts → scoped_key_validation_request_and_separator.d.ts} +8 -8
- package/dest/kernel/hints/{scoped_key_validation_request_and_generator.d.ts.map → scoped_key_validation_request_and_separator.d.ts.map} +1 -1
- package/dest/kernel/hints/{scoped_key_validation_request_and_generator.js → scoped_key_validation_request_and_separator.js} +6 -6
- package/dest/kernel/private_accumulated_data.d.ts +23 -1
- package/dest/kernel/private_accumulated_data.d.ts.map +1 -1
- package/dest/kernel/private_call_data.d.ts +25 -1
- package/dest/kernel/private_call_data.d.ts.map +1 -1
- package/dest/kernel/private_call_request.d.ts +16 -1
- package/dest/kernel/private_call_request.d.ts.map +1 -1
- package/dest/kernel/private_circuit_public_inputs.d.ts +81 -8
- package/dest/kernel/private_circuit_public_inputs.d.ts.map +1 -1
- package/dest/kernel/private_circuit_public_inputs.js +16 -16
- package/dest/kernel/private_kernel_circuit_public_inputs.d.ts +33 -3
- package/dest/kernel/private_kernel_circuit_public_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_circuit_public_inputs.js +4 -4
- package/dest/kernel/private_kernel_data.d.ts +7 -1
- package/dest/kernel/private_kernel_data.d.ts.map +1 -1
- package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts +22 -1
- package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts +7 -1
- package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts +4 -1
- package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts +12 -3
- package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_tail_circuit_private_inputs.js +4 -4
- package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts +25 -3
- package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_tail_circuit_public_inputs.js +7 -7
- package/dest/kernel/private_to_avm_accumulated_data.d.ts +2 -2
- package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts +3 -3
- 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 +7 -7
- package/dest/kernel/private_to_rollup_accumulated_data.d.ts +17 -1
- package/dest/kernel/private_to_rollup_accumulated_data.d.ts.map +1 -1
- package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts +18 -3
- 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 +7 -7
- package/dest/kernel/private_validation_requests.d.ts +13 -4
- package/dest/kernel/private_validation_requests.d.ts.map +1 -1
- package/dest/kernel/private_validation_requests.js +9 -9
- package/dest/kernel/public_call_request.d.ts +22 -1
- package/dest/kernel/public_call_request.d.ts.map +1 -1
- package/dest/kernel/utils/optional_number.d.ts +7 -1
- package/dest/kernel/utils/optional_number.d.ts.map +1 -1
- package/dest/keys/derivation.d.ts +3 -3
- package/dest/keys/derivation.js +15 -15
- package/dest/keys/key_types.d.ts +3 -3
- package/dest/keys/key_types.d.ts.map +1 -1
- package/dest/keys/public_keys.d.ts +5 -1
- package/dest/keys/public_keys.d.ts.map +1 -1
- package/dest/keys/public_keys.js +2 -2
- package/dest/keys/utils.d.ts +1 -1
- package/dest/keys/utils.d.ts.map +1 -1
- package/dest/keys/utils.js +8 -4
- package/dest/l1-contracts/slash_factory.d.ts +1 -1
- package/dest/l1-contracts/slash_factory.d.ts.map +1 -1
- package/dest/l1-contracts/slash_factory.js +1 -0
- package/dest/logs/debug_log_store.d.ts +30 -0
- package/dest/logs/debug_log_store.d.ts.map +1 -0
- package/dest/logs/debug_log_store.js +30 -0
- package/dest/logs/extended_contract_class_log.d.ts +3 -1
- package/dest/logs/extended_contract_class_log.d.ts.map +1 -1
- package/dest/logs/extended_public_log.d.ts +17 -9
- package/dest/logs/extended_public_log.d.ts.map +1 -1
- package/dest/logs/index.d.ts +2 -1
- package/dest/logs/index.d.ts.map +1 -1
- package/dest/logs/index.js +1 -0
- package/dest/logs/log_id.d.ts +21 -14
- package/dest/logs/log_id.d.ts.map +1 -1
- package/dest/logs/log_id.js +20 -17
- package/dest/logs/private_log.d.ts +2 -2
- package/dest/logs/private_log.d.ts.map +1 -1
- package/dest/logs/siloed_tag.d.ts +1 -1
- package/dest/logs/siloed_tag.d.ts.map +1 -1
- package/dest/logs/siloed_tag.js +2 -5
- package/dest/messaging/inbox_leaf.d.ts +3 -1
- package/dest/messaging/inbox_leaf.d.ts.map +1 -1
- package/dest/messaging/l1_actor.d.ts +7 -1
- package/dest/messaging/l1_actor.d.ts.map +1 -1
- package/dest/messaging/l1_to_l2_message.d.ts +6 -1
- package/dest/messaging/l1_to_l2_message.d.ts.map +1 -1
- package/dest/messaging/l2_actor.d.ts +7 -1
- package/dest/messaging/l2_actor.d.ts.map +1 -1
- package/dest/messaging/l2_to_l1_membership.d.ts +3 -3
- package/dest/messaging/l2_to_l1_membership.d.ts.map +1 -1
- package/dest/messaging/l2_to_l1_membership.js +8 -6
- package/dest/messaging/out_hash.d.ts +41 -4
- package/dest/messaging/out_hash.d.ts.map +1 -1
- package/dest/messaging/out_hash.js +52 -26
- package/dest/note/index.d.ts +1 -2
- package/dest/note/index.d.ts.map +1 -1
- package/dest/note/index.js +0 -1
- package/dest/note/note_dao.d.ts +36 -5
- package/dest/note/note_dao.d.ts.map +1 -1
- package/dest/note/note_dao.js +15 -12
- package/dest/p2p/attestation_utils.d.ts +11 -1
- package/dest/p2p/attestation_utils.d.ts.map +1 -1
- package/dest/p2p/attestation_utils.js +45 -0
- package/dest/p2p/block_proposal.d.ts +23 -8
- package/dest/p2p/block_proposal.d.ts.map +1 -1
- package/dest/p2p/block_proposal.js +26 -10
- package/dest/p2p/checkpoint_attestation.d.ts +6 -1
- package/dest/p2p/checkpoint_attestation.d.ts.map +1 -1
- package/dest/p2p/checkpoint_attestation.js +1 -1
- package/dest/p2p/checkpoint_proposal.d.ts +34 -9
- package/dest/p2p/checkpoint_proposal.d.ts.map +1 -1
- package/dest/p2p/checkpoint_proposal.js +46 -20
- package/dest/p2p/consensus_payload.d.ts +15 -5
- package/dest/p2p/consensus_payload.d.ts.map +1 -1
- package/dest/p2p/consensus_payload.js +22 -18
- package/dest/p2p/constants.d.ts +5 -0
- package/dest/p2p/constants.d.ts.map +1 -0
- package/dest/p2p/constants.js +3 -0
- package/dest/p2p/index.d.ts +2 -1
- package/dest/p2p/index.d.ts.map +1 -1
- package/dest/p2p/index.js +1 -0
- package/dest/p2p/message_validator.d.ts +18 -3
- package/dest/p2p/message_validator.d.ts.map +1 -1
- package/dest/p2p/message_validator.js +2 -1
- package/dest/p2p/signed_txs.d.ts +3 -1
- package/dest/p2p/signed_txs.d.ts.map +1 -1
- package/dest/p2p/signed_txs.js +6 -1
- package/dest/p2p/topic_type.js +2 -1
- package/dest/parity/parity_base_private_inputs.d.ts +3 -1
- package/dest/parity/parity_base_private_inputs.d.ts.map +1 -1
- package/dest/parity/parity_public_inputs.d.ts +4 -1
- package/dest/parity/parity_public_inputs.d.ts.map +1 -1
- package/dest/parity/parity_root_private_inputs.d.ts +2 -1
- package/dest/parity/parity_root_private_inputs.d.ts.map +1 -1
- package/dest/proofs/chonk_proof.d.ts +1 -1
- package/dest/proofs/chonk_proof.d.ts.map +1 -1
- package/dest/proofs/chonk_proof.js +9 -4
- package/dest/proofs/proof.d.ts +4 -1
- package/dest/proofs/proof.d.ts.map +1 -1
- package/dest/proofs/recursive_proof.d.ts +10 -1
- package/dest/proofs/recursive_proof.d.ts.map +1 -1
- package/dest/rollup/base_rollup_hints.d.ts +34 -1
- package/dest/rollup/base_rollup_hints.d.ts.map +1 -1
- package/dest/rollup/block_constant_data.d.ts +12 -1
- package/dest/rollup/block_constant_data.d.ts.map +1 -1
- package/dest/rollup/block_headers_hash.js +1 -1
- package/dest/rollup/block_merge_rollup_private_inputs.d.ts +4 -1
- package/dest/rollup/block_merge_rollup_private_inputs.d.ts.map +1 -1
- package/dest/rollup/block_rollup_public_inputs.d.ts +44 -3
- package/dest/rollup/block_rollup_public_inputs.d.ts.map +1 -1
- package/dest/rollup/block_rollup_public_inputs.js +2 -2
- package/dest/rollup/block_root_rollup_private_inputs.d.ts +64 -1
- package/dest/rollup/block_root_rollup_private_inputs.d.ts.map +1 -1
- package/dest/rollup/checkpoint_constant_data.d.ts +10 -1
- package/dest/rollup/checkpoint_constant_data.d.ts.map +1 -1
- package/dest/rollup/checkpoint_header.d.ts +31 -4
- package/dest/rollup/checkpoint_header.d.ts.map +1 -1
- package/dest/rollup/checkpoint_header.js +23 -7
- package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts +4 -1
- package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts.map +1 -1
- package/dest/rollup/checkpoint_rollup_public_inputs.d.ts +45 -10
- package/dest/rollup/checkpoint_rollup_public_inputs.d.ts.map +1 -1
- package/dest/rollup/checkpoint_rollup_public_inputs.js +11 -7
- package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts +44 -3
- package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts.map +1 -1
- package/dest/rollup/checkpoint_root_rollup_private_inputs.js +13 -2
- package/dest/rollup/epoch_constant_data.d.ts +16 -1
- package/dest/rollup/epoch_constant_data.d.ts.map +1 -1
- package/dest/rollup/root_rollup_private_inputs.d.ts +6 -1
- package/dest/rollup/root_rollup_private_inputs.d.ts.map +1 -1
- package/dest/rollup/root_rollup_public_inputs.d.ts +17 -7
- package/dest/rollup/root_rollup_public_inputs.d.ts.map +1 -1
- package/dest/rollup/root_rollup_public_inputs.js +7 -4
- package/dest/rollup/tree_snapshot_diff_hints.d.ts +24 -1
- package/dest/rollup/tree_snapshot_diff_hints.d.ts.map +1 -1
- package/dest/rollup/tx_merge_rollup_private_inputs.d.ts +4 -1
- package/dest/rollup/tx_merge_rollup_private_inputs.d.ts.map +1 -1
- package/dest/rollup/tx_rollup_public_inputs.d.ts +29 -1
- package/dest/rollup/tx_rollup_public_inputs.d.ts.map +1 -1
- package/dest/schemas/schemas.d.ts +1 -1
- package/dest/slashing/empire.d.ts +1 -1
- package/dest/slashing/empire.d.ts.map +1 -1
- package/dest/slashing/empire.js +2 -0
- package/dest/slashing/helpers.d.ts +2 -2
- package/dest/slashing/helpers.d.ts.map +1 -1
- package/dest/slashing/helpers.js +6 -0
- package/dest/slashing/tally.d.ts +2 -1
- package/dest/slashing/tally.d.ts.map +1 -1
- package/dest/slashing/tally.js +6 -2
- package/dest/slashing/types.d.ts +7 -3
- package/dest/slashing/types.d.ts.map +1 -1
- package/dest/slashing/types.js +13 -1
- package/dest/stats/stats.d.ts +1 -3
- package/dest/stats/stats.d.ts.map +1 -1
- package/dest/tests/factories.d.ts +2 -4
- package/dest/tests/factories.d.ts.map +1 -1
- package/dest/tests/factories.js +18 -27
- package/dest/tests/jest.js +1 -1
- package/dest/tests/mocks.d.ts +24 -15
- package/dest/tests/mocks.d.ts.map +1 -1
- package/dest/tests/mocks.js +63 -40
- package/dest/timetable/index.d.ts +37 -0
- package/dest/timetable/index.d.ts.map +1 -0
- package/dest/timetable/index.js +39 -0
- package/dest/trees/append_only_tree_snapshot.d.ts +13 -1
- package/dest/trees/append_only_tree_snapshot.d.ts.map +1 -1
- package/dest/trees/nullifier_leaf.d.ts +13 -1
- package/dest/trees/nullifier_leaf.d.ts.map +1 -1
- package/dest/trees/nullifier_membership_witness.d.ts +10 -1
- package/dest/trees/nullifier_membership_witness.d.ts.map +1 -1
- package/dest/trees/public_data_leaf.d.ts +17 -1
- package/dest/trees/public_data_leaf.d.ts.map +1 -1
- package/dest/trees/public_data_leaf.js +7 -6
- package/dest/trees/public_data_witness.d.ts +11 -1
- package/dest/trees/public_data_witness.d.ts.map +1 -1
- package/dest/tx/block_header.d.ts +14 -2
- package/dest/tx/block_header.d.ts.map +1 -1
- package/dest/tx/block_header.js +6 -2
- package/dest/tx/call_context.d.ts +13 -1
- package/dest/tx/call_context.d.ts.map +1 -1
- package/dest/tx/capsule.d.ts +4 -1
- package/dest/tx/capsule.d.ts.map +1 -1
- package/dest/tx/execution_payload.d.ts +9 -1
- package/dest/tx/execution_payload.d.ts.map +1 -1
- package/dest/tx/function_data.d.ts +4 -2
- package/dest/tx/function_data.d.ts.map +1 -1
- package/dest/tx/global_variables.d.ts +12 -4
- package/dest/tx/global_variables.d.ts.map +1 -1
- package/dest/tx/hashed_values.d.ts +7 -1
- package/dest/tx/hashed_values.d.ts.map +1 -1
- package/dest/tx/in_tx.d.ts +4 -4
- package/dest/tx/indexed_tx_effect.d.ts +5 -5
- package/dest/tx/indexed_tx_effect.d.ts.map +1 -1
- package/dest/tx/indexed_tx_effect.js +3 -2
- package/dest/tx/partial_state_reference.d.ts +4 -1
- package/dest/tx/partial_state_reference.d.ts.map +1 -1
- package/dest/tx/private_execution_result.d.ts +23 -2
- package/dest/tx/private_execution_result.d.ts.map +1 -1
- package/dest/tx/private_execution_result.js +1 -1
- package/dest/tx/private_tx_constant_data.d.ts +16 -1
- package/dest/tx/private_tx_constant_data.d.ts.map +1 -1
- package/dest/tx/profiling.d.ts +152 -29
- package/dest/tx/profiling.d.ts.map +1 -1
- package/dest/tx/profiling.js +47 -10
- package/dest/tx/protocol_contracts.d.ts +2 -2
- package/dest/tx/protocol_contracts.d.ts.map +1 -1
- package/dest/tx/protocol_contracts.js +2 -2
- package/dest/tx/public_call_request_with_calldata.d.ts +7 -1
- package/dest/tx/public_call_request_with_calldata.d.ts.map +1 -1
- package/dest/tx/public_simulation_output.d.ts +4 -2
- package/dest/tx/public_simulation_output.d.ts.map +1 -1
- package/dest/tx/public_simulation_output.js +7 -3
- package/dest/tx/state_reference.d.ts +3 -1
- package/dest/tx/state_reference.d.ts.map +1 -1
- package/dest/tx/tx.d.ts +24 -1
- package/dest/tx/tx.d.ts.map +1 -1
- package/dest/tx/tx.js +6 -3
- package/dest/tx/tx_context.d.ts +2 -1
- package/dest/tx/tx_context.d.ts.map +1 -1
- package/dest/tx/tx_effect.d.ts +32 -6
- package/dest/tx/tx_effect.d.ts.map +1 -1
- package/dest/tx/tx_effect.js +0 -7
- package/dest/tx/tx_execution_request.d.ts +30 -1
- package/dest/tx/tx_execution_request.d.ts.map +1 -1
- package/dest/tx/tx_hash.d.ts +2 -1
- package/dest/tx/tx_hash.d.ts.map +1 -1
- package/dest/tx/tx_receipt.d.ts +62 -14
- package/dest/tx/tx_receipt.d.ts.map +1 -1
- package/dest/tx/tx_receipt.js +55 -16
- package/dest/tx/tx_request.d.ts +6 -1
- package/dest/tx/tx_request.d.ts.map +1 -1
- package/dest/tx/tx_request.js +2 -2
- package/dest/tx/validator/empty_validator.d.ts +2 -2
- package/dest/tx/validator/empty_validator.d.ts.map +1 -1
- package/dest/tx/validator/error_texts.d.ts +3 -2
- package/dest/tx/validator/error_texts.d.ts.map +1 -1
- package/dest/tx/validator/error_texts.js +3 -1
- package/dest/tx/validator/tx_validator.d.ts +2 -2
- package/dest/tx/validator/tx_validator.d.ts.map +1 -1
- package/dest/types/shared.d.ts +4 -1
- package/dest/types/shared.d.ts.map +1 -1
- package/dest/validators/schemas.d.ts +38 -38
- package/dest/validators/schemas.d.ts.map +1 -1
- package/dest/validators/schemas.js +4 -3
- package/dest/validators/types.d.ts +3 -3
- package/dest/validators/types.d.ts.map +1 -1
- package/dest/vks/verification_key.d.ts +22 -1
- package/dest/vks/verification_key.d.ts.map +1 -1
- package/dest/vks/vk_data.d.ts +7 -1
- package/dest/vks/vk_data.d.ts.map +1 -1
- package/dest/zkpassport/index.d.ts +3 -4
- package/dest/zkpassport/index.d.ts.map +1 -1
- package/dest/zkpassport/index.js +9 -9
- package/package.json +27 -13
- package/src/abi/function_call.ts +25 -3
- package/src/abi/utils.ts +17 -0
- package/src/auth_witness/auth_witness.ts +3 -3
- package/src/block/block_data.ts +26 -0
- package/src/block/block_hash.ts +26 -25
- package/src/block/block_parameter.ts +4 -2
- package/src/block/body.ts +2 -1
- package/src/block/checkpointed_l2_block.ts +8 -58
- package/src/block/in_block.ts +6 -6
- package/src/block/index.ts +1 -2
- package/src/block/l2_block.ts +102 -150
- package/src/block/l2_block_source.ts +93 -42
- package/src/block/l2_block_stream/interfaces.ts +8 -5
- package/src/block/l2_block_stream/l2_block_stream.ts +45 -37
- package/src/block/l2_block_stream/l2_tips_store_base.ts +2 -2
- package/src/block/test/l2_tips_store_test_suite.ts +4 -9
- package/src/block/validate_block_result.ts +5 -4
- package/src/checkpoint/checkpoint.ts +61 -21
- package/src/checkpoint/checkpoint_data.ts +51 -0
- package/src/checkpoint/index.ts +1 -0
- package/src/checkpoint/published_checkpoint.ts +7 -4
- package/src/config/index.ts +1 -0
- package/src/config/node-rpc-config.ts +1 -1
- package/src/config/sequencer-config.ts +29 -0
- package/src/contract/contract_address.ts +4 -4
- package/src/contract/contract_class.ts +3 -3
- package/src/contract/contract_class_id.ts +6 -5
- package/src/contract/index.ts +0 -2
- package/src/contract/interfaces/node-info.ts +3 -0
- package/src/contract/private_function.ts +3 -4
- package/src/contract/private_function_membership_proof.ts +1 -1
- package/src/database-version/database_version.ts +87 -0
- package/src/database-version/version_manager.ts +1 -77
- package/src/delayed_public_mutable/delayed_public_mutable_values.ts +9 -10
- package/src/deserialization/index.ts +21 -0
- package/src/epoch-helpers/index.ts +13 -1
- package/src/file-store/local.ts +15 -5
- package/src/file-store/s3.ts +12 -3
- package/src/ha-signing/config.ts +149 -0
- package/src/ha-signing/index.ts +18 -0
- package/src/ha-signing/types.ts +112 -0
- package/src/hash/hash.ts +14 -10
- package/src/hash/map_slot.ts +3 -2
- package/src/interfaces/api_limit.ts +1 -0
- package/src/interfaces/archiver.ts +23 -24
- package/src/interfaces/aztec-node-admin.ts +26 -2
- package/src/interfaces/aztec-node.ts +86 -135
- package/src/interfaces/block-builder.ts +41 -23
- package/src/interfaces/configs.ts +13 -4
- package/src/interfaces/l2_logs_source.ts +17 -4
- package/src/interfaces/merkle_tree_operations.ts +1 -1
- package/src/interfaces/p2p.ts +1 -1
- package/src/interfaces/prover-broker.ts +22 -0
- package/src/interfaces/prover-client.ts +22 -0
- package/src/interfaces/slasher.ts +4 -0
- package/src/interfaces/tx_provider.ts +2 -2
- package/src/interfaces/validator.ts +20 -12
- package/src/kernel/hints/build_note_hash_read_request_hints.ts +17 -6
- package/src/kernel/hints/build_nullifier_read_request_hints.ts +17 -14
- package/src/kernel/hints/index.ts +2 -2
- package/src/kernel/hints/{key_validation_request_and_generator.ts → key_validation_request_and_separator.ts} +12 -15
- package/src/kernel/hints/{scoped_key_validation_request_and_generator.ts → scoped_key_validation_request_and_separator.ts} +10 -10
- package/src/kernel/private_circuit_public_inputs.ts +14 -14
- package/src/kernel/private_kernel_circuit_public_inputs.ts +2 -2
- package/src/kernel/private_kernel_tail_circuit_private_inputs.ts +2 -2
- package/src/kernel/private_kernel_tail_circuit_public_inputs.ts +5 -5
- package/src/kernel/private_to_public_kernel_circuit_public_inputs.ts +5 -5
- package/src/kernel/private_to_rollup_kernel_circuit_public_inputs.ts +5 -5
- package/src/kernel/private_validation_requests.ts +8 -8
- package/src/keys/derivation.ts +15 -15
- package/src/keys/key_types.ts +6 -2
- package/src/keys/public_keys.ts +2 -2
- package/src/keys/utils.ts +8 -4
- package/src/l1-contracts/slash_factory.ts +1 -0
- package/src/logs/debug_log_store.ts +54 -0
- package/src/logs/index.ts +1 -0
- package/src/logs/log_id.ts +22 -18
- package/src/logs/siloed_tag.ts +2 -2
- package/src/messaging/l2_to_l1_membership.ts +8 -6
- package/src/messaging/out_hash.ts +60 -29
- package/src/note/index.ts +0 -1
- package/src/note/note_dao.ts +18 -13
- package/src/p2p/attestation_utils.ts +56 -0
- package/src/p2p/block_proposal.ts +36 -15
- package/src/p2p/checkpoint_attestation.ts +6 -1
- package/src/p2p/checkpoint_proposal.ts +74 -24
- package/src/p2p/consensus_payload.ts +25 -17
- package/src/p2p/constants.ts +6 -0
- package/src/p2p/index.ts +1 -0
- package/src/p2p/message_validator.ts +14 -2
- package/src/p2p/signed_txs.ts +6 -1
- package/src/p2p/topic_type.ts +1 -1
- package/src/proofs/chonk_proof.ts +9 -5
- package/src/rollup/block_headers_hash.ts +1 -1
- package/src/rollup/block_rollup_public_inputs.ts +2 -2
- package/src/rollup/checkpoint_header.ts +22 -2
- package/src/rollup/checkpoint_rollup_public_inputs.ts +16 -10
- package/src/rollup/checkpoint_root_rollup_private_inputs.ts +14 -1
- package/src/rollup/root_rollup_public_inputs.ts +11 -8
- package/src/slashing/empire.ts +3 -1
- package/src/slashing/helpers.ts +8 -0
- package/src/slashing/tally.ts +8 -2
- package/src/slashing/types.ts +14 -0
- package/src/stats/stats.ts +0 -2
- package/src/tests/factories.ts +23 -43
- package/src/tests/jest.ts +1 -1
- package/src/tests/mocks.ts +90 -55
- package/src/timetable/index.ts +66 -0
- package/src/trees/public_data_leaf.ts +11 -5
- package/src/tx/block_header.ts +12 -4
- package/src/tx/global_variables.ts +3 -3
- package/src/tx/indexed_tx_effect.ts +3 -2
- package/src/tx/private_execution_result.ts +1 -1
- package/src/tx/profiling.ts +51 -9
- package/src/tx/protocol_contracts.ts +2 -2
- package/src/tx/public_simulation_output.ts +4 -0
- package/src/tx/tx.ts +8 -9
- package/src/tx/tx_effect.ts +0 -9
- package/src/tx/tx_receipt.ts +85 -18
- package/src/tx/tx_request.ts +2 -2
- package/src/tx/validator/empty_validator.ts +1 -1
- package/src/tx/validator/error_texts.ts +4 -1
- package/src/tx/validator/tx_validator.ts +1 -1
- package/src/validators/schemas.ts +8 -1
- package/src/validators/types.ts +5 -4
- package/src/zkpassport/index.ts +11 -12
- package/dest/block/l2_block_code_to_purge.d.ts +0 -11
- package/dest/block/l2_block_code_to_purge.d.ts.map +0 -1
- package/dest/block/l2_block_code_to_purge.js +0 -55
- package/dest/block/l2_block_header.d.ts +0 -94
- package/dest/block/l2_block_header.d.ts.map +0 -1
- package/dest/block/l2_block_header.js +0 -160
- package/dest/block/l2_block_new.d.ts +0 -134
- package/dest/block/l2_block_new.d.ts.map +0 -1
- package/dest/block/l2_block_new.js +0 -155
- package/dest/contract/contract_class_metadata.d.ts +0 -8
- package/dest/contract/contract_class_metadata.d.ts.map +0 -1
- package/dest/contract/contract_class_metadata.js +0 -1
- package/dest/contract/contract_metadata.d.ts +0 -7
- package/dest/contract/contract_metadata.d.ts.map +0 -1
- package/dest/contract/contract_metadata.js +0 -1
- package/dest/database-version/index.d.ts +0 -2
- package/dest/database-version/index.d.ts.map +0 -1
- package/dest/database-version/index.js +0 -1
- package/dest/kernel/hints/key_validation_request_and_generator.d.ts +0 -25
- package/dest/kernel/hints/key_validation_request_and_generator.d.ts.map +0 -1
- package/dest/note/notes_filter.d.ts +0 -27
- package/dest/note/notes_filter.d.ts.map +0 -1
- package/dest/note/notes_filter.js +0 -11
- package/src/block/l2_block_code_to_purge.ts +0 -80
- package/src/block/l2_block_header.ts +0 -255
- package/src/block/l2_block_new.ts +0 -211
- package/src/contract/contract_class_metadata.ts +0 -8
- package/src/contract/contract_metadata.ts +0 -7
- package/src/database-version/index.ts +0 -1
- package/src/note/notes_filter.ts +0 -38
|
@@ -17,6 +17,12 @@ export type ActualProverConfig = {
|
|
|
17
17
|
proverTestDelayMs: number;
|
|
18
18
|
/** If using realistic delays, what percentage of realistic times to apply. */
|
|
19
19
|
proverTestDelayFactor: number;
|
|
20
|
+
/**
|
|
21
|
+
* Whether to abort pending proving jobs when the orchestrator is cancelled.
|
|
22
|
+
* When false (default), jobs remain in the broker queue and can be reused on restart/reorg.
|
|
23
|
+
* When true, jobs are explicitly cancelled with the broker, which prevents reuse.
|
|
24
|
+
*/
|
|
25
|
+
cancelJobsOnStop: boolean;
|
|
20
26
|
};
|
|
21
27
|
|
|
22
28
|
/**
|
|
@@ -29,6 +35,8 @@ export type ProverConfig = ActualProverConfig & {
|
|
|
29
35
|
proverId?: EthAddress;
|
|
30
36
|
/** Number of proving agents to start within the prover. */
|
|
31
37
|
proverAgentCount: number;
|
|
38
|
+
/** Where to store proving request. Must be accessible to both prover node and agents. If not set will inline-encode the parameters */
|
|
39
|
+
proofStore?: string;
|
|
32
40
|
/** Store for failed proof inputs. */
|
|
33
41
|
failedProofStore?: string;
|
|
34
42
|
};
|
|
@@ -42,7 +50,9 @@ export const ProverConfigSchema = zodFor<ProverConfig>()(
|
|
|
42
50
|
proverTestDelayMs: z.number(),
|
|
43
51
|
proverTestDelayFactor: z.number(),
|
|
44
52
|
proverAgentCount: z.number(),
|
|
53
|
+
proofStore: z.string().optional(),
|
|
45
54
|
failedProofStore: z.string().optional(),
|
|
55
|
+
cancelJobsOnStop: z.boolean(),
|
|
46
56
|
}),
|
|
47
57
|
);
|
|
48
58
|
|
|
@@ -80,11 +90,23 @@ export const proverConfigMappings: ConfigMappingsType<ProverConfig> = {
|
|
|
80
90
|
description: 'The number of prover agents to start',
|
|
81
91
|
...numberConfigHelper(1),
|
|
82
92
|
},
|
|
93
|
+
proofStore: {
|
|
94
|
+
env: 'PROVER_PROOF_STORE',
|
|
95
|
+
description: 'Optional proof input store for the prover',
|
|
96
|
+
},
|
|
83
97
|
failedProofStore: {
|
|
84
98
|
env: 'PROVER_FAILED_PROOF_STORE',
|
|
85
99
|
description:
|
|
86
100
|
'Store for failed proof inputs. Google cloud storage is only supported at the moment. Set this value as gs://bucket-name/path/to/store.',
|
|
87
101
|
},
|
|
102
|
+
cancelJobsOnStop: {
|
|
103
|
+
env: 'PROVER_CANCEL_JOBS_ON_STOP',
|
|
104
|
+
description:
|
|
105
|
+
'Whether to abort pending proving jobs when the orchestrator is cancelled. ' +
|
|
106
|
+
'When false (default), jobs remain in the broker queue and can be reused on restart/reorg. ' +
|
|
107
|
+
'When true, jobs are explicitly cancelled with the broker, which prevents reuse.',
|
|
108
|
+
...booleanConfigHelper(false),
|
|
109
|
+
},
|
|
88
110
|
};
|
|
89
111
|
|
|
90
112
|
function parseProverId(str?: string) {
|
|
@@ -18,6 +18,8 @@ export interface SlasherConfig {
|
|
|
18
18
|
slashDataWithholdingPenalty: bigint;
|
|
19
19
|
slashInactivityPenalty: bigint;
|
|
20
20
|
slashBroadcastedInvalidBlockPenalty: bigint;
|
|
21
|
+
slashDuplicateProposalPenalty: bigint;
|
|
22
|
+
slashDuplicateAttestationPenalty: bigint;
|
|
21
23
|
slashProposeInvalidAttestationsPenalty: bigint;
|
|
22
24
|
slashAttestDescendantOfInvalidPenalty: bigint;
|
|
23
25
|
slashUnknownPenalty: bigint;
|
|
@@ -40,6 +42,8 @@ export const SlasherConfigSchema = zodFor<SlasherConfig>()(
|
|
|
40
42
|
slashInactivityConsecutiveEpochThreshold: z.number(),
|
|
41
43
|
slashInactivityPenalty: schemas.BigInt,
|
|
42
44
|
slashProposeInvalidAttestationsPenalty: schemas.BigInt,
|
|
45
|
+
slashDuplicateProposalPenalty: schemas.BigInt,
|
|
46
|
+
slashDuplicateAttestationPenalty: schemas.BigInt,
|
|
43
47
|
slashAttestDescendantOfInvalidPenalty: schemas.BigInt,
|
|
44
48
|
slashUnknownPenalty: schemas.BigInt,
|
|
45
49
|
slashOffenseExpirationRounds: z.number(),
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { L2Block } from '@aztec/stdlib/block';
|
|
2
2
|
import type { BlockProposal } from '@aztec/stdlib/p2p';
|
|
3
3
|
import { type Tx, TxHash } from '@aztec/stdlib/tx';
|
|
4
4
|
|
|
@@ -13,5 +13,5 @@ export interface ITxProvider {
|
|
|
13
13
|
opts: { pinnedPeer: PeerId | undefined; deadline: Date },
|
|
14
14
|
): Promise<{ txs: Tx[]; missingTxs: TxHash[] }>;
|
|
15
15
|
|
|
16
|
-
getTxsForBlock(block:
|
|
16
|
+
getTxsForBlock(block: L2Block, opts: { deadline: Date }): Promise<{ txs: Tx[]; missingTxs: TxHash[] }>;
|
|
17
17
|
}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import type { BlockNumber, CheckpointNumber, SlotNumber } from '@aztec/foundation/branded-types';
|
|
1
2
|
import type { SecretValue } from '@aztec/foundation/config';
|
|
2
3
|
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
3
4
|
import type { EthAddress } from '@aztec/foundation/eth-address';
|
|
@@ -19,12 +20,13 @@ import type { PeerId } from '@libp2p/interface';
|
|
|
19
20
|
import { z } from 'zod';
|
|
20
21
|
|
|
21
22
|
import type { CommitteeAttestationsAndSigners } from '../block/index.js';
|
|
23
|
+
import { type ValidatorHASignerConfig, ValidatorHASignerConfigSchema } from '../ha-signing/index.js';
|
|
22
24
|
import { AllowedElementSchema } from './allowed_element.js';
|
|
23
25
|
|
|
24
26
|
/**
|
|
25
27
|
* Validator client configuration
|
|
26
28
|
*/
|
|
27
|
-
export
|
|
29
|
+
export type ValidatorClientConfig = ValidatorHASignerConfig & {
|
|
28
30
|
/** The private keys of the validators participating in attestation duties */
|
|
29
31
|
validatorPrivateKeys?: SecretValue<`0x${string}`[]>;
|
|
30
32
|
|
|
@@ -43,27 +45,28 @@ export interface ValidatorClientConfig {
|
|
|
43
45
|
/** Whether to re-execute transactions in a block proposal before attesting */
|
|
44
46
|
validatorReexecute: boolean;
|
|
45
47
|
|
|
46
|
-
/** Will re-execute until this many milliseconds are left in the slot */
|
|
47
|
-
validatorReexecuteDeadlineMs: number;
|
|
48
|
-
|
|
49
48
|
/** Whether to always reexecute block proposals, even for non-validator nodes or when out of the currnet committee */
|
|
50
49
|
alwaysReexecuteBlockProposals?: boolean;
|
|
51
50
|
|
|
52
51
|
/** Whether to run in fisherman mode: validates all proposals and attestations but does not broadcast attestations or participate in consensus */
|
|
53
52
|
fishermanMode?: boolean;
|
|
54
53
|
|
|
55
|
-
|
|
56
|
-
/** Skip checkpoint proposal validation and always attest (default: true) */
|
|
54
|
+
/** Skip checkpoint proposal validation and always attest (default: false) */
|
|
57
55
|
skipCheckpointProposalValidation?: boolean;
|
|
58
56
|
|
|
59
|
-
|
|
60
|
-
/** Skip pushing re-executed blocks to archiver (default: true) */
|
|
57
|
+
/** Skip pushing re-executed blocks to archiver (default: false) */
|
|
61
58
|
skipPushProposedBlocksToArchiver?: boolean;
|
|
62
|
-
|
|
59
|
+
|
|
60
|
+
/** Agree to attest to equivocated checkpoint proposals (for testing purposes only) */
|
|
61
|
+
attestToEquivocatedProposals?: boolean;
|
|
62
|
+
};
|
|
63
63
|
|
|
64
64
|
export type ValidatorClientFullConfig = ValidatorClientConfig &
|
|
65
65
|
Pick<SequencerConfig, 'txPublicSetupAllowList' | 'broadcastInvalidBlockProposal'> &
|
|
66
|
-
Pick<
|
|
66
|
+
Pick<
|
|
67
|
+
SlasherConfig,
|
|
68
|
+
'slashBroadcastedInvalidBlockPenalty' | 'slashDuplicateProposalPenalty' | 'slashDuplicateAttestationPenalty'
|
|
69
|
+
> & {
|
|
67
70
|
/**
|
|
68
71
|
* Whether transactions are disabled for this node
|
|
69
72
|
* @remarks This should match the property in P2PConfig. It's not picked from there to avoid circular dependencies.
|
|
@@ -72,17 +75,17 @@ export type ValidatorClientFullConfig = ValidatorClientConfig &
|
|
|
72
75
|
};
|
|
73
76
|
|
|
74
77
|
export const ValidatorClientConfigSchema = zodFor<Omit<ValidatorClientConfig, 'validatorPrivateKeys'>>()(
|
|
75
|
-
|
|
78
|
+
ValidatorHASignerConfigSchema.extend({
|
|
76
79
|
validatorAddresses: z.array(schemas.EthAddress).optional(),
|
|
77
80
|
disableValidator: z.boolean(),
|
|
78
81
|
disabledValidators: z.array(schemas.EthAddress),
|
|
79
82
|
attestationPollingIntervalMs: z.number().min(0),
|
|
80
83
|
validatorReexecute: z.boolean(),
|
|
81
|
-
validatorReexecuteDeadlineMs: z.number().min(0),
|
|
82
84
|
alwaysReexecuteBlockProposals: z.boolean().optional(),
|
|
83
85
|
fishermanMode: z.boolean().optional(),
|
|
84
86
|
skipCheckpointProposalValidation: z.boolean().optional(),
|
|
85
87
|
skipPushProposedBlocksToArchiver: z.boolean().optional(),
|
|
88
|
+
attestToEquivocatedProposals: z.boolean().optional(),
|
|
86
89
|
}),
|
|
87
90
|
);
|
|
88
91
|
|
|
@@ -91,6 +94,8 @@ export const ValidatorClientFullConfigSchema = zodFor<Omit<ValidatorClientFullCo
|
|
|
91
94
|
txPublicSetupAllowList: z.array(AllowedElementSchema).optional(),
|
|
92
95
|
broadcastInvalidBlockProposal: z.boolean().optional(),
|
|
93
96
|
slashBroadcastedInvalidBlockPenalty: schemas.BigInt,
|
|
97
|
+
slashDuplicateProposalPenalty: schemas.BigInt,
|
|
98
|
+
slashDuplicateAttestationPenalty: schemas.BigInt,
|
|
94
99
|
disableTransactions: z.boolean().optional(),
|
|
95
100
|
}),
|
|
96
101
|
);
|
|
@@ -116,6 +121,7 @@ export interface Validator {
|
|
|
116
121
|
createCheckpointProposal(
|
|
117
122
|
checkpointHeader: CheckpointHeader,
|
|
118
123
|
archive: Fr,
|
|
124
|
+
feeAssetPriceModifier: bigint,
|
|
119
125
|
lastBlockInfo: CreateCheckpointProposalLastBlockData | undefined,
|
|
120
126
|
proposerAddress: EthAddress | undefined,
|
|
121
127
|
options: CheckpointProposalOptions,
|
|
@@ -148,5 +154,7 @@ export interface Validator {
|
|
|
148
154
|
signAttestationsAndSigners(
|
|
149
155
|
attestationsAndSigners: CommitteeAttestationsAndSigners,
|
|
150
156
|
proposer: EthAddress,
|
|
157
|
+
slot: SlotNumber,
|
|
158
|
+
blockNumber: BlockNumber | CheckpointNumber,
|
|
151
159
|
): Promise<Signature>;
|
|
152
160
|
}
|
|
@@ -76,17 +76,28 @@ export async function buildNoteHashReadRequestHintsFromResetActions<PENDING exte
|
|
|
76
76
|
builder.addPendingReadRequest(hint.readRequestIndex, hint.pendingValueIndex);
|
|
77
77
|
});
|
|
78
78
|
|
|
79
|
+
// Collect all settled read requests
|
|
80
|
+
const settledRequests: { index: number; readRequest: ScopedReadRequest }[] = [];
|
|
79
81
|
for (let i = 0; i < resetActions.actions.length; i++) {
|
|
80
82
|
if (resetActions.actions[i] === ReadRequestActionEnum.READ_AS_SETTLED) {
|
|
81
|
-
|
|
82
|
-
const membershipWitness = await oracle.getNoteHashMembershipWitness(readRequest.value);
|
|
83
|
-
if (!membershipWitness) {
|
|
84
|
-
throw new Error('Read request is reading an unknown note hash.');
|
|
85
|
-
}
|
|
86
|
-
builder.addSettledReadRequest(i, membershipWitness, readRequest.value);
|
|
83
|
+
settledRequests.push({ index: i, readRequest: noteHashReadRequests.array[i] });
|
|
87
84
|
}
|
|
88
85
|
}
|
|
89
86
|
|
|
87
|
+
// Fetch all membership witnesses in parallel
|
|
88
|
+
const membershipWitnesses = await Promise.all(
|
|
89
|
+
settledRequests.map(({ readRequest }) => oracle.getNoteHashMembershipWitness(readRequest.value)),
|
|
90
|
+
);
|
|
91
|
+
|
|
92
|
+
// Add settled read requests to builder
|
|
93
|
+
for (let i = 0; i < settledRequests.length; i++) {
|
|
94
|
+
const membershipWitness = membershipWitnesses[i];
|
|
95
|
+
if (!membershipWitness) {
|
|
96
|
+
throw new Error('Read request is reading an unknown note hash.');
|
|
97
|
+
}
|
|
98
|
+
builder.addSettledReadRequest(settledRequests[i].index, membershipWitness, settledRequests[i].readRequest.value);
|
|
99
|
+
}
|
|
100
|
+
|
|
90
101
|
const noteHashMap: Map<bigint, { noteHash: ScopedNoteHash; index: number }[]> = new Map();
|
|
91
102
|
noteHashes.getActiveItems().forEach((noteHash, index) => {
|
|
92
103
|
const value = noteHash.value.toBigInt();
|
|
@@ -6,7 +6,6 @@ import {
|
|
|
6
6
|
import type { Fr } from '@aztec/foundation/curves/bn254';
|
|
7
7
|
import { MembershipWitness } from '@aztec/foundation/trees';
|
|
8
8
|
|
|
9
|
-
import { siloNullifier } from '../../hash/hash.js';
|
|
10
9
|
import type { NullifierLeafPreimage } from '../../trees/nullifier_leaf.js';
|
|
11
10
|
import type { ClaimedLengthArray } from '../claimed_length_array.js';
|
|
12
11
|
import type { ScopedNullifier } from '../nullifier.js';
|
|
@@ -74,7 +73,6 @@ export async function buildNullifierReadRequestHintsFromResetActions<PENDING ext
|
|
|
74
73
|
resetActions: ReadRequestResetActions<typeof MAX_NULLIFIER_READ_REQUESTS_PER_TX>,
|
|
75
74
|
maxPending: PENDING = MAX_NULLIFIER_READ_REQUESTS_PER_TX as PENDING,
|
|
76
75
|
maxSettled: SETTLED = MAX_NULLIFIER_READ_REQUESTS_PER_TX as SETTLED,
|
|
77
|
-
siloed = false,
|
|
78
76
|
) {
|
|
79
77
|
const builder = new NullifierReadRequestHintsBuilder(maxPending, maxSettled);
|
|
80
78
|
|
|
@@ -82,21 +80,28 @@ export async function buildNullifierReadRequestHintsFromResetActions<PENDING ext
|
|
|
82
80
|
builder.addPendingReadRequest(hint.readRequestIndex, hint.pendingValueIndex);
|
|
83
81
|
});
|
|
84
82
|
|
|
83
|
+
// Collect all settled read requests
|
|
84
|
+
const settledRequests: { index: number; readRequest: ScopedReadRequest }[] = [];
|
|
85
85
|
for (let i = 0; i < resetActions.actions.length; i++) {
|
|
86
86
|
if (resetActions.actions[i] === ReadRequestActionEnum.READ_AS_SETTLED) {
|
|
87
|
-
|
|
88
|
-
const siloedValue = siloed
|
|
89
|
-
? readRequest.value
|
|
90
|
-
: await siloNullifier(readRequest.contractAddress, readRequest.value);
|
|
91
|
-
const membershipWitnessWithPreimage = await oracle.getNullifierMembershipWitness(siloedValue);
|
|
92
|
-
builder.addSettledReadRequest(
|
|
93
|
-
i,
|
|
94
|
-
membershipWitnessWithPreimage.membershipWitness,
|
|
95
|
-
membershipWitnessWithPreimage.leafPreimage,
|
|
96
|
-
);
|
|
87
|
+
settledRequests.push({ index: i, readRequest: nullifierReadRequests.array[i] });
|
|
97
88
|
}
|
|
98
89
|
}
|
|
99
90
|
|
|
91
|
+
const siloedValues = settledRequests.map(({ readRequest }) => readRequest.value);
|
|
92
|
+
|
|
93
|
+
// Fetch all membership witnesses in parallel
|
|
94
|
+
const membershipWitnesses = await Promise.all(siloedValues.map(value => oracle.getNullifierMembershipWitness(value)));
|
|
95
|
+
|
|
96
|
+
// Add settled read requests to builder
|
|
97
|
+
for (let i = 0; i < settledRequests.length; i++) {
|
|
98
|
+
builder.addSettledReadRequest(
|
|
99
|
+
settledRequests[i].index,
|
|
100
|
+
membershipWitnesses[i].membershipWitness,
|
|
101
|
+
membershipWitnesses[i].leafPreimage,
|
|
102
|
+
);
|
|
103
|
+
}
|
|
104
|
+
|
|
100
105
|
return builder.toHints();
|
|
101
106
|
}
|
|
102
107
|
|
|
@@ -109,7 +114,6 @@ export async function buildNullifierReadRequestHints<PENDING extends number, SET
|
|
|
109
114
|
futureNullifiers: ScopedNullifier[],
|
|
110
115
|
maxPending: PENDING = MAX_NULLIFIER_READ_REQUESTS_PER_TX as PENDING,
|
|
111
116
|
maxSettled: SETTLED = MAX_NULLIFIER_READ_REQUESTS_PER_TX as SETTLED,
|
|
112
|
-
siloed = false,
|
|
113
117
|
) {
|
|
114
118
|
const resetActions = getNullifierReadRequestResetActions(nullifierReadRequests, nullifiers, futureNullifiers);
|
|
115
119
|
return await buildNullifierReadRequestHintsFromResetActions(
|
|
@@ -118,6 +122,5 @@ export async function buildNullifierReadRequestHints<PENDING extends number, SET
|
|
|
118
122
|
resetActions,
|
|
119
123
|
maxPending,
|
|
120
124
|
maxSettled,
|
|
121
|
-
siloed,
|
|
122
125
|
);
|
|
123
126
|
}
|
|
@@ -6,10 +6,10 @@ export * from './note_hash_read_request_hints.js';
|
|
|
6
6
|
export * from './nullifier_read_request_hints.js';
|
|
7
7
|
export * from './read_request_hints.js';
|
|
8
8
|
export * from './key_validation_hint.js';
|
|
9
|
-
export * from './
|
|
9
|
+
export * from './key_validation_request_and_separator.js';
|
|
10
10
|
export * from './read_request.js';
|
|
11
11
|
export * from './key_validation_request.js';
|
|
12
|
-
export * from './
|
|
12
|
+
export * from './scoped_key_validation_request_and_separator.js';
|
|
13
13
|
export * from './transient_data_squashing_hint.js';
|
|
14
14
|
export * from './private_kernel_reset_hints.js';
|
|
15
15
|
export * from './tree_leaf_read_request.js';
|
|
@@ -5,48 +5,45 @@ import { BufferReader, FieldReader, serializeToBuffer } from '@aztec/foundation/
|
|
|
5
5
|
import { KeyValidationRequest } from './key_validation_request.js';
|
|
6
6
|
|
|
7
7
|
/**
|
|
8
|
-
* Request for validating keys used in the app
|
|
8
|
+
* Request for validating keys used in the app, along with a domain separator for the key type.
|
|
9
9
|
*/
|
|
10
|
-
export class
|
|
10
|
+
export class KeyValidationRequestAndSeparator {
|
|
11
11
|
constructor(
|
|
12
12
|
/** The key validation request. */
|
|
13
13
|
public readonly request: KeyValidationRequest,
|
|
14
|
-
/**
|
|
15
|
-
|
|
16
|
-
* Note: This generator constrains that a correct key type gets validated in the kernel.
|
|
17
|
-
*/
|
|
18
|
-
public readonly skAppGenerator: Fr,
|
|
14
|
+
/** Domain separator for the key type, used along with sk_m to derive the sk_app stored in the request. */
|
|
15
|
+
public readonly keyTypeDomainSeparator: Fr,
|
|
19
16
|
) {}
|
|
20
17
|
|
|
21
18
|
toBuffer() {
|
|
22
|
-
return serializeToBuffer(this.request, this.
|
|
19
|
+
return serializeToBuffer(this.request, this.keyTypeDomainSeparator);
|
|
23
20
|
}
|
|
24
21
|
|
|
25
22
|
static fromBuffer(buffer: Buffer | BufferReader) {
|
|
26
23
|
const reader = BufferReader.asReader(buffer);
|
|
27
|
-
return new
|
|
24
|
+
return new KeyValidationRequestAndSeparator(reader.readObject(KeyValidationRequest), Fr.fromBuffer(reader));
|
|
28
25
|
}
|
|
29
26
|
|
|
30
27
|
toFields(): Fr[] {
|
|
31
|
-
const fields = [...this.request.toFields(), this.
|
|
28
|
+
const fields = [...this.request.toFields(), this.keyTypeDomainSeparator];
|
|
32
29
|
if (fields.length !== KEY_VALIDATION_REQUEST_AND_GENERATOR_LENGTH) {
|
|
33
30
|
throw new Error(
|
|
34
|
-
`Invalid number of fields for
|
|
31
|
+
`Invalid number of fields for KeyValidationRequestAndSeparator. Expected ${KEY_VALIDATION_REQUEST_AND_GENERATOR_LENGTH}, got ${fields.length}`,
|
|
35
32
|
);
|
|
36
33
|
}
|
|
37
34
|
return fields;
|
|
38
35
|
}
|
|
39
36
|
|
|
40
|
-
static fromFields(fields: Fr[] | FieldReader):
|
|
37
|
+
static fromFields(fields: Fr[] | FieldReader): KeyValidationRequestAndSeparator {
|
|
41
38
|
const reader = FieldReader.asReader(fields);
|
|
42
|
-
return new
|
|
39
|
+
return new KeyValidationRequestAndSeparator(KeyValidationRequest.fromFields(reader), reader.readField());
|
|
43
40
|
}
|
|
44
41
|
|
|
45
42
|
isEmpty() {
|
|
46
|
-
return this.request.isEmpty() && this.
|
|
43
|
+
return this.request.isEmpty() && this.keyTypeDomainSeparator.isZero();
|
|
47
44
|
}
|
|
48
45
|
|
|
49
46
|
static empty() {
|
|
50
|
-
return new
|
|
47
|
+
return new KeyValidationRequestAndSeparator(KeyValidationRequest.empty(), Fr.ZERO);
|
|
51
48
|
}
|
|
52
49
|
}
|
|
@@ -3,14 +3,14 @@ import type { Fr } from '@aztec/foundation/curves/bn254';
|
|
|
3
3
|
import { BufferReader, FieldReader, serializeToBuffer } from '@aztec/foundation/serialize';
|
|
4
4
|
|
|
5
5
|
import { AztecAddress } from '../../aztec-address/index.js';
|
|
6
|
-
import {
|
|
6
|
+
import { KeyValidationRequestAndSeparator } from './key_validation_request_and_separator.js';
|
|
7
7
|
|
|
8
8
|
/**
|
|
9
9
|
* Request for validating keys used in the app.
|
|
10
10
|
*/
|
|
11
|
-
export class
|
|
11
|
+
export class ScopedKeyValidationRequestAndSeparator {
|
|
12
12
|
constructor(
|
|
13
|
-
public readonly request:
|
|
13
|
+
public readonly request: KeyValidationRequestAndSeparator,
|
|
14
14
|
public readonly contractAddress: AztecAddress,
|
|
15
15
|
) {}
|
|
16
16
|
|
|
@@ -20,8 +20,8 @@ export class ScopedKeyValidationRequestAndGenerator {
|
|
|
20
20
|
|
|
21
21
|
static fromBuffer(buffer: Buffer | BufferReader) {
|
|
22
22
|
const reader = BufferReader.asReader(buffer);
|
|
23
|
-
return new
|
|
24
|
-
|
|
23
|
+
return new ScopedKeyValidationRequestAndSeparator(
|
|
24
|
+
KeyValidationRequestAndSeparator.fromBuffer(reader),
|
|
25
25
|
AztecAddress.fromBuffer(reader),
|
|
26
26
|
);
|
|
27
27
|
}
|
|
@@ -30,16 +30,16 @@ export class ScopedKeyValidationRequestAndGenerator {
|
|
|
30
30
|
const fields = [...this.request.toFields(), this.contractAddress.toField()];
|
|
31
31
|
if (fields.length !== SCOPED_KEY_VALIDATION_REQUEST_AND_GENERATOR_LENGTH) {
|
|
32
32
|
throw new Error(
|
|
33
|
-
`Invalid number of fields for
|
|
33
|
+
`Invalid number of fields for ScopedKeyValidationRequestAndSeparator. Expected ${SCOPED_KEY_VALIDATION_REQUEST_AND_GENERATOR_LENGTH}, got ${fields.length}`,
|
|
34
34
|
);
|
|
35
35
|
}
|
|
36
36
|
return fields;
|
|
37
37
|
}
|
|
38
38
|
|
|
39
|
-
static fromFields(fields: Fr[] | FieldReader):
|
|
39
|
+
static fromFields(fields: Fr[] | FieldReader): ScopedKeyValidationRequestAndSeparator {
|
|
40
40
|
const reader = FieldReader.asReader(fields);
|
|
41
|
-
return new
|
|
42
|
-
|
|
41
|
+
return new ScopedKeyValidationRequestAndSeparator(
|
|
42
|
+
KeyValidationRequestAndSeparator.fromFields(reader),
|
|
43
43
|
AztecAddress.fromFields(reader),
|
|
44
44
|
);
|
|
45
45
|
}
|
|
@@ -49,6 +49,6 @@ export class ScopedKeyValidationRequestAndGenerator {
|
|
|
49
49
|
}
|
|
50
50
|
|
|
51
51
|
static empty() {
|
|
52
|
-
return new
|
|
52
|
+
return new ScopedKeyValidationRequestAndSeparator(KeyValidationRequestAndSeparator.empty(), AztecAddress.ZERO);
|
|
53
53
|
}
|
|
54
54
|
}
|
|
@@ -21,7 +21,7 @@ import {
|
|
|
21
21
|
} from '@aztec/foundation/serialize';
|
|
22
22
|
import type { FieldsOf } from '@aztec/foundation/types';
|
|
23
23
|
|
|
24
|
-
import {
|
|
24
|
+
import { KeyValidationRequestAndSeparator } from '../kernel/hints/key_validation_request_and_separator.js';
|
|
25
25
|
import { CountedLogHash } from '../kernel/log_hash.js';
|
|
26
26
|
import { PrivateCallRequest } from '../kernel/private_call_request.js';
|
|
27
27
|
import { PrivateLogData } from '../kernel/private_log_data.js';
|
|
@@ -80,7 +80,7 @@ export class PrivateCircuitPublicInputs {
|
|
|
80
80
|
/**
|
|
81
81
|
* The highest timestamp of a block in which the transaction can still be included.
|
|
82
82
|
*/
|
|
83
|
-
public
|
|
83
|
+
public expirationTimestamp: UInt64,
|
|
84
84
|
/**
|
|
85
85
|
* The side effect counter at the start of this call.
|
|
86
86
|
*/
|
|
@@ -106,10 +106,10 @@ export class PrivateCircuitPublicInputs {
|
|
|
106
106
|
*/
|
|
107
107
|
public nullifierReadRequests: ClaimedLengthArray<ScopedReadRequest, typeof MAX_NULLIFIER_READ_REQUESTS_PER_CALL>,
|
|
108
108
|
/**
|
|
109
|
-
* Key validation requests and
|
|
109
|
+
* Key validation requests and separators created by the corresponding function call.
|
|
110
110
|
*/
|
|
111
|
-
public
|
|
112
|
-
|
|
111
|
+
public keyValidationRequestsAndSeparators: ClaimedLengthArray<
|
|
112
|
+
KeyValidationRequestAndSeparator,
|
|
113
113
|
typeof MAX_KEY_VALIDATION_REQUESTS_PER_CALL
|
|
114
114
|
>,
|
|
115
115
|
/**
|
|
@@ -178,7 +178,7 @@ export class PrivateCircuitPublicInputs {
|
|
|
178
178
|
reader.readObject(ClaimedLengthArrayFromBuffer(ScopedReadRequest, MAX_NOTE_HASH_READ_REQUESTS_PER_CALL)),
|
|
179
179
|
reader.readObject(ClaimedLengthArrayFromBuffer(ScopedReadRequest, MAX_NULLIFIER_READ_REQUESTS_PER_CALL)),
|
|
180
180
|
reader.readObject(
|
|
181
|
-
ClaimedLengthArrayFromBuffer(
|
|
181
|
+
ClaimedLengthArrayFromBuffer(KeyValidationRequestAndSeparator, MAX_KEY_VALIDATION_REQUESTS_PER_CALL),
|
|
182
182
|
),
|
|
183
183
|
reader.readObject(ClaimedLengthArrayFromBuffer(PrivateCallRequest, MAX_PRIVATE_CALL_STACK_LENGTH_PER_CALL)),
|
|
184
184
|
reader.readObject(ClaimedLengthArrayFromBuffer(CountedPublicCallRequest, MAX_ENQUEUED_CALLS_PER_CALL)),
|
|
@@ -209,7 +209,7 @@ export class PrivateCircuitPublicInputs {
|
|
|
209
209
|
reader.readObject(ClaimedLengthArrayFromFields(ScopedReadRequest, MAX_NOTE_HASH_READ_REQUESTS_PER_CALL)),
|
|
210
210
|
reader.readObject(ClaimedLengthArrayFromFields(ScopedReadRequest, MAX_NULLIFIER_READ_REQUESTS_PER_CALL)),
|
|
211
211
|
reader.readObject(
|
|
212
|
-
ClaimedLengthArrayFromFields(
|
|
212
|
+
ClaimedLengthArrayFromFields(KeyValidationRequestAndSeparator, MAX_KEY_VALIDATION_REQUESTS_PER_CALL),
|
|
213
213
|
),
|
|
214
214
|
reader.readObject(ClaimedLengthArrayFromFields(PrivateCallRequest, MAX_PRIVATE_CALL_STACK_LENGTH_PER_CALL)),
|
|
215
215
|
reader.readObject(ClaimedLengthArrayFromFields(CountedPublicCallRequest, MAX_ENQUEUED_CALLS_PER_CALL)),
|
|
@@ -242,7 +242,7 @@ export class PrivateCircuitPublicInputs {
|
|
|
242
242
|
Fr.ZERO,
|
|
243
243
|
ClaimedLengthArray.empty(ScopedReadRequest, MAX_NOTE_HASH_READ_REQUESTS_PER_CALL),
|
|
244
244
|
ClaimedLengthArray.empty(ScopedReadRequest, MAX_NULLIFIER_READ_REQUESTS_PER_CALL),
|
|
245
|
-
ClaimedLengthArray.empty(
|
|
245
|
+
ClaimedLengthArray.empty(KeyValidationRequestAndSeparator, MAX_KEY_VALIDATION_REQUESTS_PER_CALL),
|
|
246
246
|
ClaimedLengthArray.empty(PrivateCallRequest, MAX_PRIVATE_CALL_STACK_LENGTH_PER_CALL),
|
|
247
247
|
ClaimedLengthArray.empty(CountedPublicCallRequest, MAX_ENQUEUED_CALLS_PER_CALL),
|
|
248
248
|
PublicCallRequest.empty(),
|
|
@@ -263,14 +263,14 @@ export class PrivateCircuitPublicInputs {
|
|
|
263
263
|
this.txContext.isEmpty() &&
|
|
264
264
|
this.minRevertibleSideEffectCounter.isZero() &&
|
|
265
265
|
!this.isFeePayer &&
|
|
266
|
-
!this.
|
|
266
|
+
!this.expirationTimestamp &&
|
|
267
267
|
this.startSideEffectCounter.isZero() &&
|
|
268
268
|
this.endSideEffectCounter.isZero() &&
|
|
269
269
|
this.expectedNonRevertibleSideEffectCounter.isZero() &&
|
|
270
270
|
this.expectedRevertibleSideEffectCounter.isZero() &&
|
|
271
271
|
this.noteHashReadRequests.isEmpty() &&
|
|
272
272
|
this.nullifierReadRequests.isEmpty() &&
|
|
273
|
-
this.
|
|
273
|
+
this.keyValidationRequestsAndSeparators.isEmpty() &&
|
|
274
274
|
this.privateCallRequests.isEmpty() &&
|
|
275
275
|
this.publicCallRequests.isEmpty() &&
|
|
276
276
|
this.publicTeardownCallRequest.isEmpty() &&
|
|
@@ -296,14 +296,14 @@ export class PrivateCircuitPublicInputs {
|
|
|
296
296
|
fields.txContext,
|
|
297
297
|
fields.minRevertibleSideEffectCounter,
|
|
298
298
|
fields.isFeePayer,
|
|
299
|
-
fields.
|
|
299
|
+
fields.expirationTimestamp,
|
|
300
300
|
fields.startSideEffectCounter,
|
|
301
301
|
fields.endSideEffectCounter,
|
|
302
302
|
fields.expectedNonRevertibleSideEffectCounter,
|
|
303
303
|
fields.expectedRevertibleSideEffectCounter,
|
|
304
304
|
fields.noteHashReadRequests,
|
|
305
305
|
fields.nullifierReadRequests,
|
|
306
|
-
fields.
|
|
306
|
+
fields.keyValidationRequestsAndSeparators,
|
|
307
307
|
fields.privateCallRequests,
|
|
308
308
|
fields.publicCallRequests,
|
|
309
309
|
fields.publicTeardownCallRequest,
|
|
@@ -330,14 +330,14 @@ export class PrivateCircuitPublicInputs {
|
|
|
330
330
|
this.txContext,
|
|
331
331
|
this.minRevertibleSideEffectCounter,
|
|
332
332
|
this.isFeePayer,
|
|
333
|
-
bigintToUInt64BE(this.
|
|
333
|
+
bigintToUInt64BE(this.expirationTimestamp),
|
|
334
334
|
this.startSideEffectCounter,
|
|
335
335
|
this.endSideEffectCounter,
|
|
336
336
|
this.expectedNonRevertibleSideEffectCounter,
|
|
337
337
|
this.expectedRevertibleSideEffectCounter,
|
|
338
338
|
this.noteHashReadRequests,
|
|
339
339
|
this.nullifierReadRequests,
|
|
340
|
-
this.
|
|
340
|
+
this.keyValidationRequestsAndSeparators,
|
|
341
341
|
this.privateCallRequests,
|
|
342
342
|
this.publicCallRequests,
|
|
343
343
|
this.publicTeardownCallRequest,
|
|
@@ -41,7 +41,7 @@ export class PrivateKernelCircuitPublicInputs {
|
|
|
41
41
|
/**
|
|
42
42
|
* The timestamp by which the transaction must be included in a block.
|
|
43
43
|
*/
|
|
44
|
-
public
|
|
44
|
+
public expirationTimestamp: UInt64,
|
|
45
45
|
/**
|
|
46
46
|
* Wether this is a private only tx or not
|
|
47
47
|
*/
|
|
@@ -72,7 +72,7 @@ export class PrivateKernelCircuitPublicInputs {
|
|
|
72
72
|
this.end,
|
|
73
73
|
this.publicTeardownCallRequest,
|
|
74
74
|
this.feePayer,
|
|
75
|
-
bigintToUInt64BE(this.
|
|
75
|
+
bigintToUInt64BE(this.expirationTimestamp),
|
|
76
76
|
this.isPrivateOnly,
|
|
77
77
|
this.claimedFirstNullifier,
|
|
78
78
|
this.claimedRevertibleCounter,
|
|
@@ -20,7 +20,7 @@ export class PrivateKernelTailCircuitPrivateInputs {
|
|
|
20
20
|
/**
|
|
21
21
|
* The timestamp by which the transaction must be included in a block.
|
|
22
22
|
*/
|
|
23
|
-
public
|
|
23
|
+
public expirationTimestampUpperBound: UInt64,
|
|
24
24
|
) {}
|
|
25
25
|
|
|
26
26
|
isForPublic() {
|
|
@@ -38,7 +38,7 @@ export class PrivateKernelTailCircuitPrivateInputs {
|
|
|
38
38
|
return serializeToBuffer(
|
|
39
39
|
this.previousKernel,
|
|
40
40
|
this.paddedSideEffectAmounts,
|
|
41
|
-
bigintToUInt64BE(this.
|
|
41
|
+
bigintToUInt64BE(this.expirationTimestampUpperBound),
|
|
42
42
|
);
|
|
43
43
|
}
|
|
44
44
|
|
|
@@ -116,7 +116,7 @@ export class PrivateKernelTailCircuitPublicInputs {
|
|
|
116
116
|
/**
|
|
117
117
|
* The timestamp by which the transaction must be included in a block.
|
|
118
118
|
*/
|
|
119
|
-
public
|
|
119
|
+
public expirationTimestamp: UInt64,
|
|
120
120
|
|
|
121
121
|
public forPublic?: PartialPrivateTailPublicInputsForPublic,
|
|
122
122
|
public forRollup?: PartialPrivateTailPublicInputsForRollup,
|
|
@@ -146,7 +146,7 @@ export class PrivateKernelTailCircuitPublicInputs {
|
|
|
146
146
|
this.constants.getSize() +
|
|
147
147
|
this.gasUsed.getSize() +
|
|
148
148
|
this.feePayer.size +
|
|
149
|
-
8 //
|
|
149
|
+
8 // expirationTimestamp
|
|
150
150
|
);
|
|
151
151
|
}
|
|
152
152
|
|
|
@@ -161,7 +161,7 @@ export class PrivateKernelTailCircuitPublicInputs {
|
|
|
161
161
|
this.forPublic.publicTeardownCallRequest,
|
|
162
162
|
this.gasUsed,
|
|
163
163
|
this.feePayer,
|
|
164
|
-
this.
|
|
164
|
+
this.expirationTimestamp,
|
|
165
165
|
);
|
|
166
166
|
}
|
|
167
167
|
|
|
@@ -180,7 +180,7 @@ export class PrivateKernelTailCircuitPublicInputs {
|
|
|
180
180
|
this.forRollup.end,
|
|
181
181
|
this.gasUsed,
|
|
182
182
|
this.feePayer,
|
|
183
|
-
this.
|
|
183
|
+
this.expirationTimestamp,
|
|
184
184
|
);
|
|
185
185
|
}
|
|
186
186
|
|
|
@@ -298,7 +298,7 @@ export class PrivateKernelTailCircuitPublicInputs {
|
|
|
298
298
|
this.constants,
|
|
299
299
|
this.gasUsed,
|
|
300
300
|
this.feePayer,
|
|
301
|
-
bigintToUInt64BE(this.
|
|
301
|
+
bigintToUInt64BE(this.expirationTimestamp),
|
|
302
302
|
isForPublic ? this.forPublic!.toBuffer() : this.forRollup!.toBuffer(),
|
|
303
303
|
);
|
|
304
304
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { DomainSeparator, PRIVATE_TO_PUBLIC_KERNEL_CIRCUIT_PUBLIC_INPUTS_LENGTH } from '@aztec/constants';
|
|
2
2
|
import { poseidon2HashWithSeparator } from '@aztec/foundation/crypto/poseidon';
|
|
3
3
|
import type { Fr } from '@aztec/foundation/curves/bn254';
|
|
4
4
|
import { bufferSchemaFor } from '@aztec/foundation/schemas';
|
|
@@ -21,7 +21,7 @@ export class PrivateToPublicKernelCircuitPublicInputs {
|
|
|
21
21
|
public publicTeardownCallRequest: PublicCallRequest,
|
|
22
22
|
public gasUsed: Gas,
|
|
23
23
|
public feePayer: AztecAddress,
|
|
24
|
-
public
|
|
24
|
+
public expirationTimestamp: UInt64,
|
|
25
25
|
) {}
|
|
26
26
|
|
|
27
27
|
toBuffer() {
|
|
@@ -32,7 +32,7 @@ export class PrivateToPublicKernelCircuitPublicInputs {
|
|
|
32
32
|
this.publicTeardownCallRequest,
|
|
33
33
|
this.gasUsed,
|
|
34
34
|
this.feePayer,
|
|
35
|
-
bigintToUInt64BE(this.
|
|
35
|
+
bigintToUInt64BE(this.expirationTimestamp),
|
|
36
36
|
);
|
|
37
37
|
}
|
|
38
38
|
|
|
@@ -44,7 +44,7 @@ export class PrivateToPublicKernelCircuitPublicInputs {
|
|
|
44
44
|
fields.publicTeardownCallRequest,
|
|
45
45
|
fields.gasUsed,
|
|
46
46
|
fields.feePayer,
|
|
47
|
-
fields.
|
|
47
|
+
fields.expirationTimestamp,
|
|
48
48
|
] as const;
|
|
49
49
|
}
|
|
50
50
|
|
|
@@ -92,7 +92,7 @@ export class PrivateToPublicKernelCircuitPublicInputs {
|
|
|
92
92
|
}
|
|
93
93
|
|
|
94
94
|
hash() {
|
|
95
|
-
return poseidon2HashWithSeparator(this.toFields(),
|
|
95
|
+
return poseidon2HashWithSeparator(this.toFields(), DomainSeparator.PUBLIC_TX_HASH);
|
|
96
96
|
}
|
|
97
97
|
|
|
98
98
|
toJSON() {
|