@aztec/stdlib 0.0.0-test.1 → 0.0.1-commit.b655e406
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 +316 -323
- package/dest/abi/abi.d.ts.map +1 -1
- package/dest/abi/abi.js +71 -37
- 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 +70 -0
- package/dest/abi/buffer.d.ts +0 -2
- package/dest/abi/buffer.d.ts.map +1 -1
- package/dest/abi/contract_artifact.d.ts +17 -4
- package/dest/abi/contract_artifact.d.ts.map +1 -1
- package/dest/abi/contract_artifact.js +76 -53
- package/dest/abi/decoder.d.ts +1 -1
- package/dest/abi/decoder.d.ts.map +1 -1
- package/dest/abi/decoder.js +8 -10
- package/dest/abi/encoder.d.ts.map +1 -1
- package/dest/abi/encoder.js +68 -2
- 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 +0 -2
- package/dest/abi/event_selector.d.ts.map +1 -1
- package/dest/abi/function_call.d.ts +7 -2
- 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 +0 -2
- package/dest/abi/function_selector.d.ts.map +1 -1
- package/dest/abi/index.d.ts +2 -0
- package/dest/abi/index.d.ts.map +1 -1
- package/dest/abi/index.js +2 -0
- package/dest/abi/note_selector.d.ts +0 -2
- package/dest/abi/note_selector.d.ts.map +1 -1
- package/dest/abi/selector.d.ts +0 -3
- package/dest/abi/selector.d.ts.map +1 -1
- package/dest/abi/utils.d.ts +6 -2
- package/dest/abi/utils.d.ts.map +1 -1
- package/dest/abi/utils.js +7 -0
- package/dest/auth_witness/auth_witness.d.ts +22 -3
- package/dest/auth_witness/auth_witness.d.ts.map +1 -1
- package/dest/auth_witness/auth_witness.js +29 -0
- package/dest/avm/avm.d.ts +8446 -2091
- package/dest/avm/avm.d.ts.map +1 -1
- package/dest/avm/avm.js +371 -131
- package/dest/avm/avm_accumulated_data.d.ts +78 -20
- package/dest/avm/avm_accumulated_data.d.ts.map +1 -1
- package/dest/avm/avm_accumulated_data.js +91 -11
- package/dest/avm/avm_circuit_public_inputs.d.ts +276 -216
- package/dest/avm/avm_circuit_public_inputs.d.ts.map +1 -1
- package/dest/avm/avm_circuit_public_inputs.js +60 -9
- package/dest/avm/avm_proving_request.d.ts +4119 -1161
- package/dest/avm/avm_proving_request.d.ts.map +1 -1
- package/dest/avm/contract_storage_read.d.ts +1 -3
- package/dest/avm/contract_storage_read.d.ts.map +1 -1
- package/dest/avm/contract_storage_update_request.d.ts +1 -3
- package/dest/avm/contract_storage_update_request.d.ts.map +1 -1
- package/dest/avm/index.d.ts +1 -1
- package/dest/avm/index.d.ts.map +1 -1
- package/dest/avm/index.js +1 -1
- package/dest/avm/message_pack.d.ts +1 -2
- package/dest/avm/message_pack.d.ts.map +1 -1
- package/dest/avm/message_pack.js +36 -6
- package/dest/avm/public_call_stack_item_compressed.d.ts +1 -3
- package/dest/avm/public_call_stack_item_compressed.d.ts.map +1 -1
- package/dest/avm/public_data_read.d.ts +1 -3
- package/dest/avm/public_data_read.d.ts.map +1 -1
- package/dest/avm/public_data_update_request.d.ts +1 -4
- package/dest/avm/public_data_update_request.d.ts.map +1 -1
- package/dest/avm/public_data_write.d.ts +5 -3
- package/dest/avm/public_data_write.d.ts.map +1 -1
- package/dest/avm/public_data_write.js +22 -1
- package/dest/avm/public_inner_call_request.d.ts +1 -4
- package/dest/avm/public_inner_call_request.d.ts.map +1 -1
- package/dest/avm/public_inner_call_request.js +1 -1
- package/dest/avm/revert_code.d.ts +0 -3
- package/dest/avm/revert_code.d.ts.map +1 -1
- package/dest/aztec-address/index.d.ts +1 -4
- package/dest/aztec-address/index.d.ts.map +1 -1
- package/dest/block/attestation_info.d.ts +30 -0
- package/dest/block/attestation_info.d.ts.map +1 -0
- package/dest/block/attestation_info.js +39 -0
- package/dest/block/block_hash.d.ts +5 -3
- package/dest/block/block_hash.d.ts.map +1 -1
- package/dest/block/block_hash.js +11 -0
- package/dest/block/body.d.ts +7 -6
- package/dest/block/body.d.ts.map +1 -1
- package/dest/block/body.js +26 -27
- package/dest/block/in_block.d.ts +12 -11
- package/dest/block/in_block.d.ts.map +1 -1
- package/dest/block/in_block.js +4 -4
- package/dest/block/index.d.ts +7 -2
- package/dest/block/index.d.ts.map +1 -1
- package/dest/block/index.js +7 -2
- package/dest/block/l2_block.d.ts +24 -23
- package/dest/block/l2_block.d.ts.map +1 -1
- package/dest/block/l2_block.js +55 -49
- package/dest/block/l2_block_code_to_purge.d.ts +4 -16
- package/dest/block/l2_block_code_to_purge.d.ts.map +1 -1
- package/dest/block/l2_block_code_to_purge.js +26 -17
- package/dest/block/l2_block_header.d.ts +100 -0
- package/dest/block/l2_block_header.d.ts.map +1 -0
- package/dest/block/l2_block_header.js +146 -0
- package/dest/block/l2_block_info.d.ts +41 -0
- package/dest/block/l2_block_info.d.ts.map +1 -0
- package/dest/block/l2_block_info.js +40 -0
- package/dest/block/l2_block_source.d.ts +84 -15
- package/dest/block/l2_block_source.d.ts.map +1 -1
- package/dest/block/l2_block_source.js +11 -0
- package/dest/block/l2_block_stream/index.d.ts +4 -0
- package/dest/block/l2_block_stream/index.d.ts.map +1 -0
- package/dest/block/l2_block_stream/index.js +3 -0
- package/dest/block/l2_block_stream/interfaces.d.ts +26 -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 +35 -0
- package/dest/block/l2_block_stream/l2_block_stream.d.ts.map +1 -0
- package/dest/block/{l2_block_downloader → l2_block_stream}/l2_block_stream.js +70 -19
- package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts +18 -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 +70 -0
- package/dest/block/proposal/attestations_and_signers.d.ts +48 -0
- package/dest/block/proposal/attestations_and_signers.d.ts.map +1 -0
- package/dest/block/proposal/attestations_and_signers.js +99 -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/published_l2_block.d.ts +143 -0
- package/dest/block/published_l2_block.d.ts.map +1 -0
- package/dest/block/published_l2_block.js +63 -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 +106 -0
- package/dest/block/validate_block_result.d.ts +222 -0
- package/dest/block/validate_block_result.d.ts.map +1 -0
- package/dest/block/validate_block_result.js +83 -0
- package/dest/checkpoint/checkpoint_body.d.ts +4 -0
- package/dest/checkpoint/checkpoint_body.d.ts.map +1 -0
- package/dest/checkpoint/checkpoint_body.js +9 -0
- package/dest/checkpoint/index.d.ts +2 -0
- package/dest/checkpoint/index.d.ts.map +1 -0
- package/dest/checkpoint/index.js +1 -0
- package/dest/config/{config.d.ts → chain-config.d.ts} +5 -4
- 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 +2 -1
- 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 +6 -8
- package/dest/contract/artifact_hash.d.ts.map +1 -1
- package/dest/contract/artifact_hash.js +11 -10
- package/dest/contract/complete_address.d.ts +0 -2
- package/dest/contract/complete_address.d.ts.map +1 -1
- package/dest/contract/contract_address.d.ts +1 -1
- package/dest/contract/contract_address.js +1 -1
- package/dest/contract/contract_class.d.ts.map +1 -1
- package/dest/contract/contract_class.js +3 -19
- package/dest/contract/contract_class_id.d.ts +0 -2
- package/dest/contract/contract_class_id.d.ts.map +1 -1
- package/dest/contract/contract_class_id.js +6 -4
- 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_instance.d.ts +13 -14
- package/dest/contract/contract_instance.d.ts.map +1 -1
- package/dest/contract/contract_instance.js +7 -7
- package/dest/contract/contract_instance_update.d.ts +3 -4
- package/dest/contract/contract_instance_update.d.ts.map +1 -1
- package/dest/contract/contract_instance_update.js +6 -6
- 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/index.d.ts +3 -1
- package/dest/contract/index.d.ts.map +1 -1
- package/dest/contract/index.js +3 -1
- package/dest/contract/interfaces/contract_class.d.ts +46 -186
- package/dest/contract/interfaces/contract_class.d.ts.map +1 -1
- package/dest/contract/interfaces/contract_class.js +4 -9
- package/dest/contract/interfaces/contract_data_source.d.ts +10 -18
- package/dest/contract/interfaces/contract_data_source.d.ts.map +1 -1
- package/dest/contract/interfaces/contract_instance.d.ts.map +1 -1
- package/dest/contract/interfaces/contract_instance_update.d.ts +9 -8
- package/dest/contract/interfaces/contract_instance_update.d.ts.map +1 -1
- package/dest/contract/interfaces/contract_instance_update.js +1 -1
- package/dest/contract/interfaces/node-info.d.ts +2 -2
- 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 +9 -9
- 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/private_function.d.ts +0 -2
- package/dest/contract/private_function.d.ts.map +1 -1
- package/dest/contract/private_function_membership_proof.d.ts +2 -2
- package/dest/contract/private_function_membership_proof.js +7 -7
- 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} +13 -13
- package/dest/database-version/version_manager.d.ts +29 -10
- package/dest/database-version/version_manager.d.ts.map +1 -1
- package/dest/database-version/version_manager.js +42 -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} +16 -16
- package/dest/{shared_mutable/shared_mutable_values_with_hash.d.ts → delayed_public_mutable/delayed_public_mutable_values_with_hash.d.ts} +6 -6
- 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 +7 -7
- package/dest/epoch-helpers/index.d.ts +24 -2
- package/dest/epoch-helpers/index.d.ts.map +1 -1
- package/dest/epoch-helpers/index.js +32 -2
- package/dest/errors/proving_error.d.ts.map +1 -1
- package/dest/errors/simulation_error.d.ts.map +1 -1
- package/dest/errors/simulation_error.js +2 -2
- package/dest/fees/transaction_fee.d.ts +5 -0
- 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 +69 -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 +252 -0
- package/dest/gas/gas.d.ts +2 -4
- package/dest/gas/gas.d.ts.map +1 -1
- package/dest/gas/gas.js +4 -1
- package/dest/gas/gas_fees.d.ts +16 -18
- package/dest/gas/gas_fees.d.ts.map +1 -1
- package/dest/gas/gas_fees.js +17 -18
- package/dest/gas/gas_settings.d.ts +25 -27
- package/dest/gas/gas_settings.d.ts.map +1 -1
- package/dest/gas/gas_settings.js +6 -6
- package/dest/hash/hash.d.ts +27 -7
- package/dest/hash/hash.d.ts.map +1 -1
- package/dest/hash/hash.js +36 -24
- package/dest/interfaces/allowed_element.d.ts +53 -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 +4 -0
- package/dest/interfaces/api_limit.d.ts.map +1 -0
- package/dest/interfaces/api_limit.js +3 -0
- package/dest/interfaces/archiver.d.ts +44 -2
- package/dest/interfaces/archiver.d.ts.map +1 -1
- package/dest/interfaces/archiver.js +33 -15
- package/dest/interfaces/aztec-node-admin.d.ts +289 -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 +93 -79
- package/dest/interfaces/aztec-node.d.ts.map +1 -1
- package/dest/interfaces/aztec-node.js +43 -32
- package/dest/interfaces/block-builder.d.ts +40 -4
- package/dest/interfaces/block-builder.d.ts.map +1 -1
- package/dest/interfaces/block-builder.js +1 -1
- package/dest/interfaces/client.d.ts +2 -1
- package/dest/interfaces/client.d.ts.map +1 -1
- package/dest/interfaces/client.js +2 -1
- package/dest/interfaces/configs.d.ts +59 -34
- package/dest/interfaces/configs.d.ts.map +1 -1
- package/dest/interfaces/configs.js +11 -18
- package/dest/interfaces/epoch-prover.d.ts +34 -15
- package/dest/interfaces/epoch-prover.d.ts.map +1 -1
- package/dest/interfaces/get_logs_response.d.ts +1 -1
- package/dest/interfaces/l2_logs_source.d.ts +2 -1
- package/dest/interfaces/l2_logs_source.d.ts.map +1 -1
- package/dest/interfaces/merkle_tree_operations.d.ts +26 -10
- package/dest/interfaces/merkle_tree_operations.d.ts.map +1 -1
- package/dest/interfaces/p2p.d.ts +15 -3
- package/dest/interfaces/p2p.d.ts.map +1 -1
- package/dest/interfaces/p2p.js +6 -2
- package/dest/interfaces/private_kernel_prover.d.ts +5 -6
- package/dest/interfaces/private_kernel_prover.d.ts.map +1 -1
- package/dest/interfaces/prover-agent.d.ts +31 -6
- package/dest/interfaces/prover-agent.d.ts.map +1 -1
- package/dest/interfaces/prover-agent.js +15 -6
- package/dest/interfaces/prover-client.d.ts +5 -5
- package/dest/interfaces/prover-client.d.ts.map +1 -1
- package/dest/interfaces/prover-client.js +8 -6
- package/dest/interfaces/prover-coordination.d.ts +4 -9
- 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 +5 -2
- package/dest/interfaces/prover-node.d.ts.map +1 -1
- package/dest/interfaces/prover-node.js +8 -3
- package/dest/interfaces/proving-job.d.ts +4422 -1342
- package/dest/interfaces/proving-job.d.ts.map +1 -1
- package/dest/interfaces/proving-job.js +136 -105
- 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 +11 -5
- package/dest/interfaces/server.d.ts.map +1 -1
- package/dest/interfaces/server.js +11 -5
- package/dest/interfaces/server_circuit_prover.d.ts +46 -34
- package/dest/interfaces/server_circuit_prover.d.ts.map +1 -1
- package/dest/interfaces/service.d.ts +3 -2
- 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 +163 -0
- package/dest/interfaces/validator.d.ts.map +1 -0
- package/dest/interfaces/validator.js +18 -0
- package/dest/interfaces/world_state.d.ts +23 -21
- package/dest/interfaces/world_state.d.ts.map +1 -1
- package/dest/interfaces/world_state.js +1 -1
- 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 +58 -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 +6 -6
- 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 +18 -20
- package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts +10 -12
- 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 +4 -3
- package/dest/kernel/hints/build_transient_data_hints.d.ts.map +1 -1
- package/dest/kernel/hints/build_transient_data_hints.js +9 -10
- package/dest/kernel/hints/find_private_kernel_reset_dimensions.js +1 -1
- package/dest/kernel/hints/index.d.ts +1 -2
- 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 +3 -9
- package/dest/kernel/hints/key_validation_hint.d.ts.map +1 -1
- package/dest/kernel/hints/key_validation_hint.js +5 -7
- package/dest/kernel/hints/key_validation_request.d.ts +1 -3
- package/dest/kernel/hints/key_validation_request.d.ts.map +1 -1
- package/dest/kernel/hints/key_validation_request_and_generator.d.ts +1 -3
- package/dest/kernel/hints/key_validation_request_and_generator.d.ts.map +1 -1
- package/dest/kernel/hints/note_hash_read_request_hints.d.ts +0 -2
- package/dest/kernel/hints/note_hash_read_request_hints.d.ts.map +1 -1
- package/dest/kernel/hints/note_hash_read_request_hints.js +4 -4
- package/dest/kernel/hints/nullifier_read_request_hints.d.ts +4 -5
- 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 +9 -11
- package/dest/kernel/hints/private_kernel_reset_hints.d.ts.map +1 -1
- package/dest/kernel/hints/private_kernel_reset_hints.js +13 -9
- package/dest/kernel/hints/read_request.d.ts +0 -2
- package/dest/kernel/hints/read_request.d.ts.map +1 -1
- package/dest/kernel/hints/read_request_hints.d.ts +29 -31
- 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 +1 -3
- package/dest/kernel/hints/scoped_key_validation_request_and_generator.d.ts.map +1 -1
- package/dest/kernel/hints/{transient_data_index_hint.d.ts → transient_data_squashing_hint.d.ts} +5 -8
- 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} +5 -5
- package/dest/kernel/hints/tree_leaf_read_request.d.ts +0 -2
- package/dest/kernel/hints/tree_leaf_read_request.d.ts.map +1 -1
- package/dest/kernel/index.d.ts +4 -2
- package/dest/kernel/index.d.ts.map +1 -1
- package/dest/kernel/index.js +4 -2
- package/dest/kernel/log_hash.d.ts +27 -9
- package/dest/kernel/log_hash.d.ts.map +1 -1
- package/dest/kernel/log_hash.js +72 -13
- package/dest/kernel/note_hash.d.ts +0 -2
- package/dest/kernel/note_hash.d.ts.map +1 -1
- package/dest/kernel/nullifier.d.ts +2 -4
- package/dest/kernel/nullifier.d.ts.map +1 -1
- package/dest/kernel/nullifier.js +11 -11
- 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 +19 -20
- 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 +8 -30
- package/dest/kernel/private_call_data.d.ts.map +1 -1
- package/dest/kernel/private_call_data.js +6 -18
- package/dest/kernel/private_call_request.d.ts +1 -3
- package/dest/kernel/private_call_request.d.ts.map +1 -1
- package/dest/kernel/private_call_request.js +1 -1
- package/dest/kernel/private_circuit_public_inputs.d.ts +35 -36
- package/dest/kernel/private_circuit_public_inputs.d.ts.map +1 -1
- package/dest/kernel/private_circuit_public_inputs.js +45 -27
- package/dest/kernel/private_context_inputs.d.ts +2 -2
- 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 +14 -7
- package/dest/kernel/private_kernel_circuit_public_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_circuit_public_inputs.js +9 -5
- package/dest/kernel/private_kernel_data.d.ts +7 -28
- package/dest/kernel/private_kernel_data.d.ts.map +1 -1
- package/dest/kernel/private_kernel_data.js +10 -21
- package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts +6 -7
- package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_init_circuit_private_inputs.js +7 -6
- package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts +1 -3
- 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 +9 -8
- 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 +11 -13
- 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 +6 -12
- package/dest/kernel/private_kernel_simulated_output.d.ts.map +1 -1
- package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts +20 -4
- 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 +20 -12
- package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_tail_circuit_public_inputs.js +28 -21
- package/dest/kernel/private_log_data.d.ts +1 -4
- package/dest/kernel/private_log_data.d.ts.map +1 -1
- package/dest/kernel/private_log_data.js +4 -2
- package/dest/kernel/private_to_avm_accumulated_data.d.ts +4 -13
- package/dest/kernel/private_to_avm_accumulated_data.d.ts.map +1 -1
- package/dest/kernel/private_to_avm_accumulated_data.js +11 -0
- package/dest/kernel/private_to_public_accumulated_data.d.ts +2 -5
- package/dest/kernel/private_to_public_accumulated_data.d.ts.map +1 -1
- package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts +7 -7
- 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 +16 -10
- package/dest/kernel/private_to_rollup_accumulated_data.d.ts +3 -6
- 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 +13 -15
- 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 +11 -12
- package/dest/kernel/private_validation_requests.d.ts +9 -24
- package/dest/kernel/private_validation_requests.d.ts.map +1 -1
- package/dest/kernel/private_validation_requests.js +10 -22
- package/dest/kernel/public_call_request.d.ts +70 -24
- package/dest/kernel/public_call_request.d.ts.map +1 -1
- package/dest/kernel/public_call_request.js +77 -20
- package/dest/kernel/utils/optional_number.d.ts +1 -3
- package/dest/kernel/utils/optional_number.d.ts.map +1 -1
- package/dest/kernel/utils/order_and_comparison.d.ts +0 -3
- 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 +0 -2
- package/dest/keys/derivation.d.ts.map +1 -1
- package/dest/keys/derivation.js +2 -15
- package/dest/keys/public_keys.d.ts +0 -2
- package/dest/keys/public_keys.d.ts.map +1 -1
- package/dest/keys/public_keys.js +0 -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 +44 -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 +54 -16
- package/dest/logs/contract_class_log.d.ts.map +1 -1
- package/dest/logs/contract_class_log.js +110 -79
- package/dest/logs/debug_log.d.ts +13 -0
- package/dest/logs/debug_log.d.ts.map +1 -0
- package/dest/logs/debug_log.js +26 -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 +63 -0
- package/dest/logs/extended_contract_class_log.d.ts +0 -2
- package/dest/logs/extended_contract_class_log.d.ts.map +1 -1
- package/dest/logs/extended_public_log.d.ts +1 -3
- package/dest/logs/extended_public_log.d.ts.map +1 -1
- package/dest/logs/index.d.ts +6 -2
- package/dest/logs/index.d.ts.map +1 -1
- package/dest/logs/index.js +6 -2
- package/dest/logs/log_id.d.ts +0 -2
- package/dest/logs/log_id.d.ts.map +1 -1
- package/dest/logs/log_with_tx_data.d.ts +12 -4
- package/dest/logs/log_with_tx_data.d.ts.map +1 -1
- package/dest/logs/log_with_tx_data.js +23 -10
- 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 +16 -8
- package/dest/logs/private_log.d.ts.map +1 -1
- package/dest/logs/private_log.js +50 -22
- package/dest/logs/public_log.d.ts +26 -12
- package/dest/logs/public_log.d.ts.map +1 -1
- package/dest/logs/public_log.js +128 -34
- package/dest/logs/{l1_payload/shared_secret_derivation.d.ts → shared_secret_derivation.d.ts} +4 -3
- package/dest/logs/shared_secret_derivation.d.ts.map +1 -0
- package/dest/logs/{l1_payload/shared_secret_derivation.js → shared_secret_derivation.js} +5 -9
- package/dest/logs/tx_scoped_l2_log.d.ts +28 -33
- package/dest/logs/tx_scoped_l2_log.d.ts.map +1 -1
- package/dest/logs/tx_scoped_l2_log.js +36 -19
- package/dest/messaging/inbox_leaf.d.ts +8 -3
- package/dest/messaging/inbox_leaf.d.ts.map +1 -1
- package/dest/messaging/inbox_leaf.js +16 -2
- package/dest/messaging/index.d.ts +1 -0
- package/dest/messaging/index.d.ts.map +1 -1
- package/dest/messaging/index.js +1 -0
- package/dest/messaging/l1_actor.d.ts +0 -2
- package/dest/messaging/l1_actor.d.ts.map +1 -1
- package/dest/messaging/l1_to_l2_message.d.ts +0 -2
- package/dest/messaging/l1_to_l2_message.d.ts.map +1 -1
- package/dest/messaging/l1_to_l2_message_source.d.ts +6 -1
- package/dest/messaging/l1_to_l2_message_source.d.ts.map +1 -1
- package/dest/messaging/l2_actor.d.ts +0 -2
- package/dest/messaging/l2_actor.d.ts.map +1 -1
- package/dest/messaging/l2_to_l1_membership.d.ts +14 -0
- package/dest/messaging/l2_to_l1_membership.d.ts.map +1 -0
- package/dest/messaging/l2_to_l1_membership.js +63 -0
- package/dest/messaging/l2_to_l1_message.d.ts +110 -18
- package/dest/messaging/l2_to_l1_message.d.ts.map +1 -1
- package/dest/messaging/l2_to_l1_message.js +83 -37
- package/dest/noir/index.d.ts +19 -2
- package/dest/noir/index.d.ts.map +1 -1
- package/dest/noir/index.js +1 -0
- package/dest/note/index.d.ts +1 -1
- package/dest/note/index.d.ts.map +1 -1
- package/dest/note/index.js +1 -1
- package/dest/note/note.d.ts +39 -6
- package/dest/note/note.d.ts.map +1 -1
- package/dest/note/note.js +51 -4
- package/dest/note/notes_filter.d.ts +5 -7
- package/dest/note/notes_filter.d.ts.map +1 -1
- package/dest/note/notes_filter.js +1 -4
- package/dest/note/unique_note.d.ts +43 -0
- package/dest/note/unique_note.d.ts.map +1 -0
- package/dest/note/unique_note.js +67 -0
- 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_attestation.d.ts +51 -13
- package/dest/p2p/block_attestation.d.ts.map +1 -1
- package/dest/p2p/block_attestation.js +45 -23
- package/dest/p2p/block_proposal.d.ts +26 -10
- package/dest/p2p/block_proposal.d.ts.map +1 -1
- package/dest/p2p/block_proposal.js +47 -20
- package/dest/p2p/consensus_payload.d.ts +216 -20
- package/dest/p2p/consensus_payload.d.ts.map +1 -1
- package/dest/p2p/consensus_payload.js +47 -25
- package/dest/p2p/gossipable.d.ts +18 -17
- package/dest/p2p/gossipable.d.ts.map +1 -1
- package/dest/p2p/gossipable.js +35 -4
- package/dest/p2p/index.d.ts +1 -0
- package/dest/p2p/index.d.ts.map +1 -1
- package/dest/p2p/index.js +1 -0
- package/dest/p2p/interface.d.ts +0 -13
- package/dest/p2p/interface.d.ts.map +1 -1
- package/dest/p2p/interface.js +1 -19
- package/dest/p2p/signature_utils.d.ts +5 -6
- package/dest/p2p/signature_utils.d.ts.map +1 -1
- package/dest/p2p/signature_utils.js +5 -4
- package/dest/p2p/topic_type.d.ts +6 -9
- package/dest/p2p/topic_type.d.ts.map +1 -1
- package/dest/p2p/topic_type.js +35 -15
- package/dest/parity/index.d.ts +2 -3
- package/dest/parity/index.d.ts.map +1 -1
- package/dest/parity/index.js +2 -3
- package/dest/parity/{base_parity_inputs.d.ts → parity_base_private_inputs.d.ts} +9 -11
- package/dest/parity/parity_base_private_inputs.d.ts.map +1 -0
- package/dest/parity/{base_parity_inputs.js → parity_base_private_inputs.js} +10 -6
- package/dest/parity/parity_public_inputs.d.ts +2 -4
- package/dest/parity/parity_public_inputs.d.ts.map +1 -1
- package/dest/parity/parity_root_private_inputs.d.ts +39 -0
- package/dest/parity/parity_root_private_inputs.d.ts.map +1 -0
- package/dest/parity/{root_parity_inputs.js → parity_root_private_inputs.js} +12 -13
- package/dest/proofs/chonk_proof.d.ts +28 -0
- package/dest/proofs/chonk_proof.d.ts.map +1 -0
- package/dest/proofs/chonk_proof.js +101 -0
- package/dest/proofs/index.d.ts +2 -1
- package/dest/proofs/index.d.ts.map +1 -1
- package/dest/proofs/index.js +2 -1
- package/dest/proofs/proof.d.ts +5 -6
- package/dest/proofs/proof.d.ts.map +1 -1
- package/dest/proofs/proof.js +28 -20
- package/dest/proofs/proof_data.d.ts +21 -0
- package/dest/proofs/proof_data.d.ts.map +1 -0
- package/dest/proofs/proof_data.js +22 -0
- package/dest/proofs/proving_request_type.d.ts +17 -12
- 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 +4 -6
- package/dest/proofs/recursive_proof.d.ts.map +1 -1
- package/dest/rollup/avm_proof_data.d.ts +5 -15
- package/dest/rollup/avm_proof_data.d.ts.map +1 -1
- package/dest/rollup/avm_proof_data.js +8 -24
- package/dest/rollup/base_rollup_hints.d.ts +35 -36
- package/dest/rollup/base_rollup_hints.d.ts.map +1 -1
- package/dest/rollup/base_rollup_hints.js +41 -40
- package/dest/rollup/block_constant_data.d.ts +51 -0
- package/dest/rollup/block_constant_data.d.ts.map +1 -0
- package/dest/rollup/block_constant_data.js +50 -0
- package/dest/rollup/{block_merge_rollup.d.ts → block_merge_rollup_private_inputs.d.ts} +19 -14
- 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 +124 -0
- package/dest/rollup/block_rollup_public_inputs.d.ts.map +1 -0
- package/dest/rollup/block_rollup_public_inputs.js +85 -0
- package/dest/rollup/block_root_rollup_private_inputs.d.ts +236 -0
- package/dest/rollup/block_root_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/block_root_rollup_private_inputs.js +257 -0
- package/dest/rollup/checkpoint_constant_data.d.ts +54 -0
- package/dest/rollup/checkpoint_constant_data.d.ts.map +1 -0
- package/dest/rollup/checkpoint_constant_data.js +55 -0
- package/dest/rollup/checkpoint_header.d.ts +83 -0
- package/dest/rollup/checkpoint_header.d.ts.map +1 -0
- package/dest/rollup/checkpoint_header.js +154 -0
- package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts +30 -0
- package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/checkpoint_merge_rollup_private_inputs.js +37 -0
- package/dest/rollup/checkpoint_rollup_public_inputs.d.ts +106 -0
- package/dest/rollup/checkpoint_rollup_public_inputs.d.ts.map +1 -0
- package/dest/rollup/checkpoint_rollup_public_inputs.js +108 -0
- package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts +123 -0
- package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/checkpoint_root_rollup_private_inputs.js +178 -0
- package/dest/rollup/epoch_constant_data.d.ts +56 -0
- package/dest/rollup/epoch_constant_data.d.ts.map +1 -0
- package/dest/rollup/epoch_constant_data.js +53 -0
- package/dest/rollup/index.d.ts +19 -16
- package/dest/rollup/index.d.ts.map +1 -1
- package/dest/rollup/index.js +19 -16
- package/dest/rollup/private_tx_base_rollup_private_inputs.d.ts +21 -0
- package/dest/rollup/private_tx_base_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/private_tx_base_rollup_private_inputs.js +42 -0
- package/dest/rollup/public_chonk_verifier_private_inputs.d.ts +21 -0
- package/dest/rollup/public_chonk_verifier_private_inputs.d.ts.map +1 -0
- package/dest/rollup/public_chonk_verifier_private_inputs.js +43 -0
- package/dest/rollup/public_chonk_verifier_public_inputs.d.ts +20 -0
- package/dest/rollup/public_chonk_verifier_public_inputs.d.ts.map +1 -0
- package/dest/rollup/public_chonk_verifier_public_inputs.js +42 -0
- package/dest/rollup/public_tx_base_rollup_private_inputs.d.ts +23 -0
- package/dest/rollup/public_tx_base_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/public_tx_base_rollup_private_inputs.js +46 -0
- package/dest/rollup/root_rollup_private_inputs.d.ts +67 -0
- package/dest/rollup/root_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/root_rollup_private_inputs.js +69 -0
- package/dest/rollup/root_rollup_public_inputs.d.ts +46 -0
- package/dest/rollup/root_rollup_public_inputs.d.ts.map +1 -0
- package/dest/rollup/root_rollup_public_inputs.js +71 -0
- package/dest/rollup/{state_diff_hints.d.ts → tree_snapshot_diff_hints.d.ts} +22 -40
- 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/{merge_rollup.d.ts → tx_merge_rollup_private_inputs.d.ts} +13 -14
- 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/{base_or_merge_rollup_public_inputs.d.ts → tx_rollup_public_inputs.d.ts} +19 -30
- 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} +16 -21
- package/dest/schemas/schemas.d.ts +6 -6
- package/dest/schemas/schemas.d.ts.map +1 -1
- package/dest/schemas/schemas.js +1 -0
- package/dest/slashing/empire.d.ts +31 -0
- package/dest/slashing/empire.d.ts.map +1 -0
- package/dest/slashing/empire.js +84 -0
- package/dest/slashing/helpers.d.ts +35 -0
- package/dest/slashing/helpers.d.ts.map +1 -0
- package/dest/slashing/helpers.js +89 -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 +11 -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 +162 -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/stats.d.ts +9 -9
- package/dest/stats/stats.d.ts.map +1 -1
- package/dest/tests/factories.d.ts +81 -104
- package/dest/tests/factories.d.ts.map +1 -1
- package/dest/tests/factories.js +386 -303
- package/dest/tests/mocks.d.ts +33 -13
- package/dest/tests/mocks.d.ts.map +1 -1
- package/dest/tests/mocks.js +116 -82
- package/dest/trees/append_only_tree_snapshot.d.ts +7 -6
- package/dest/trees/append_only_tree_snapshot.d.ts.map +1 -1
- package/dest/trees/append_only_tree_snapshot.js +17 -2
- 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 +1 -1
- package/dest/trees/index.d.ts.map +1 -1
- package/dest/trees/index.js +1 -1
- package/dest/trees/merkle_tree_id.d.ts +12 -4
- 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 +49 -17
- package/dest/trees/nullifier_leaf.d.ts.map +1 -1
- package/dest/trees/nullifier_leaf.js +45 -22
- package/dest/trees/nullifier_membership_witness.d.ts +41 -22
- package/dest/trees/nullifier_membership_witness.d.ts.map +1 -1
- package/dest/trees/nullifier_membership_witness.js +14 -1
- package/dest/trees/public_data_leaf.d.ts +60 -28
- package/dest/trees/public_data_leaf.d.ts.map +1 -1
- package/dest/trees/public_data_leaf.js +41 -30
- package/dest/trees/public_data_witness.d.ts +47 -30
- package/dest/trees/public_data_witness.d.ts.map +1 -1
- package/dest/trees/public_data_witness.js +20 -4
- package/dest/tx/block_header.d.ts +15 -17
- package/dest/tx/block_header.d.ts.map +1 -1
- package/dest/tx/block_header.js +20 -19
- package/dest/tx/call_context.d.ts +1 -4
- package/dest/tx/call_context.d.ts.map +1 -1
- package/dest/tx/capsule.d.ts +3 -3
- package/dest/tx/capsule.d.ts.map +1 -1
- package/dest/tx/capsule.js +2 -0
- package/dest/tx/content_commitment.d.ts +24 -81
- package/dest/tx/content_commitment.d.ts.map +1 -1
- package/dest/tx/content_commitment.js +39 -53
- package/dest/tx/function_data.d.ts +0 -2
- package/dest/tx/function_data.d.ts.map +1 -1
- package/dest/tx/global_variable_builder.d.ts +2 -2
- package/dest/tx/global_variable_builder.d.ts.map +1 -1
- package/dest/tx/global_variables.d.ts +29 -31
- package/dest/tx/global_variables.d.ts.map +1 -1
- package/dest/tx/global_variables.js +24 -16
- package/dest/tx/hashed_values.d.ts +17 -7
- package/dest/tx/hashed_values.d.ts.map +1 -1
- package/dest/tx/hashed_values.js +26 -9
- package/dest/tx/index.d.ts +8 -2
- package/dest/tx/index.d.ts.map +1 -1
- package/dest/tx/index.js +8 -2
- package/dest/tx/indexed_tx_effect.d.ts +27 -0
- package/dest/tx/indexed_tx_effect.d.ts.map +1 -0
- package/dest/tx/indexed_tx_effect.js +32 -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 +10 -3
- 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 +55 -35
- package/dest/tx/private_execution_result.d.ts.map +1 -1
- package/dest/tx/private_execution_result.js +66 -78
- package/dest/tx/private_tx_constant_data.d.ts +60 -0
- package/dest/tx/private_tx_constant_data.d.ts.map +1 -0
- package/dest/tx/private_tx_constant_data.js +69 -0
- package/dest/tx/processed_tx.d.ts +6 -8
- package/dest/tx/processed_tx.d.ts.map +1 -1
- package/dest/tx/processed_tx.js +24 -22
- package/dest/tx/profiling.d.ts +360 -0
- package/dest/tx/profiling.d.ts.map +1 -0
- package/dest/tx/profiling.js +129 -0
- package/dest/tx/protocol_contracts.d.ts +29 -0
- package/dest/tx/protocol_contracts.d.ts.map +1 -0
- package/dest/tx/protocol_contracts.js +49 -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 +38 -0
- package/dest/tx/public_call_request_with_calldata.d.ts.map +1 -0
- package/dest/tx/public_call_request_with_calldata.js +57 -0
- package/dest/tx/public_simulation_output.d.ts +3 -3
- package/dest/tx/public_simulation_output.d.ts.map +1 -1
- package/dest/tx/public_simulation_output.js +7 -7
- package/dest/tx/simulated_tx.d.ts +169 -45
- 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 +10 -4
- package/dest/tx/state_reference.d.ts.map +1 -1
- package/dest/tx/state_reference.js +38 -5
- package/dest/tx/tree_snapshots.d.ts +11 -14
- package/dest/tx/tree_snapshots.d.ts.map +1 -1
- package/dest/tx/tree_snapshots.js +3 -3
- package/dest/tx/tx.d.ts +63 -89
- package/dest/tx/tx.d.ts.map +1 -1
- package/dest/tx/tx.js +147 -148
- package/dest/tx/tx_constant_data.d.ts +7 -41
- package/dest/tx/tx_constant_data.d.ts.map +1 -1
- package/dest/tx/tx_constant_data.js +11 -20
- package/dest/tx/tx_context.d.ts +33 -35
- package/dest/tx/tx_context.d.ts.map +1 -1
- package/dest/tx/tx_effect.d.ts +6 -42
- package/dest/tx/tx_effect.d.ts.map +1 -1
- package/dest/tx/tx_effect.js +75 -257
- package/dest/tx/tx_execution_request.d.ts +13 -6
- package/dest/tx/tx_execution_request.d.ts.map +1 -1
- package/dest/tx/tx_execution_request.js +16 -9
- package/dest/tx/tx_hash.d.ts +11 -4
- package/dest/tx/tx_hash.d.ts.map +1 -1
- package/dest/tx/tx_hash.js +24 -5
- package/dest/tx/tx_receipt.d.ts +1 -30
- package/dest/tx/tx_receipt.d.ts.map +1 -1
- package/dest/tx/tx_receipt.js +4 -14
- package/dest/tx/tx_request.d.ts +11 -9
- package/dest/tx/tx_request.d.ts.map +1 -1
- package/dest/tx/tx_request.js +11 -8
- 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 +6 -4
- package/dest/tx/validator/tx_validator.d.ts.map +1 -1
- package/dest/tx/validator/tx_validator.js +3 -0
- package/dest/types/shared.d.ts +9 -11
- 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 +50 -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 +34 -0
- package/dest/validators/errors.d.ts.map +1 -0
- package/dest/validators/errors.js +47 -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 +592 -0
- package/dest/validators/schemas.d.ts.map +1 -0
- package/dest/validators/schemas.js +52 -0
- package/dest/validators/types.d.ts +52 -0
- package/dest/validators/types.d.ts.map +1 -0
- package/dest/validators/types.js +1 -0
- package/dest/versioning/versioning.d.ts +4 -4
- package/dest/versioning/versioning.d.ts.map +1 -1
- package/dest/versioning/versioning.js +23 -18
- package/dest/vks/index.d.ts +1 -1
- package/dest/vks/index.d.ts.map +1 -1
- package/dest/vks/index.js +1 -1
- package/dest/vks/verification_key.d.ts +8 -12
- package/dest/vks/verification_key.d.ts.map +1 -1
- package/dest/vks/verification_key.js +9 -11
- package/dest/vks/{vk_witness_data.d.ts → vk_data.d.ts} +9 -11
- package/dest/vks/vk_data.d.ts.map +1 -0
- package/dest/vks/{vk_witness_data.js → vk_data.js} +10 -10
- 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 +22 -0
- package/dest/world-state/world_state_revision.d.ts.map +1 -0
- package/dest/world-state/world_state_revision.js +21 -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 +40 -23
- package/src/abi/abi.ts +96 -66
- package/src/abi/authorization_selector.ts +95 -0
- package/src/abi/contract_artifact.ts +90 -59
- package/src/abi/decoder.ts +18 -13
- package/src/abi/encoder.ts +88 -3
- package/src/abi/event_metadata_definition.ts +8 -0
- package/src/abi/function_call.ts +5 -1
- package/src/abi/index.ts +2 -0
- package/src/abi/utils.ts +15 -0
- package/src/auth_witness/auth_witness.ts +29 -0
- package/src/avm/avm.ts +452 -123
- package/src/avm/avm_accumulated_data.ts +129 -12
- package/src/avm/avm_circuit_public_inputs.ts +80 -3
- package/src/avm/index.ts +1 -1
- package/src/avm/message_pack.ts +33 -2
- package/src/avm/public_data_write.ts +25 -1
- package/src/avm/public_inner_call_request.ts +1 -1
- package/src/avm/revert_code.ts +5 -5
- package/src/block/attestation_info.ts +62 -0
- package/src/block/block_hash.ts +14 -0
- package/src/block/body.ts +41 -34
- package/src/block/in_block.ts +6 -6
- package/src/block/index.ts +7 -2
- package/src/block/l2_block.ts +59 -64
- package/src/block/l2_block_code_to_purge.ts +32 -49
- package/src/block/l2_block_header.ts +232 -0
- package/src/block/l2_block_info.ts +63 -0
- package/src/block/l2_block_source.ts +100 -13
- package/src/block/l2_block_stream/index.ts +3 -0
- package/src/block/l2_block_stream/interfaces.ts +33 -0
- package/src/block/{l2_block_downloader → l2_block_stream}/l2_block_stream.ts +81 -58
- package/src/block/l2_block_stream/l2_tips_memory_store.ts +75 -0
- package/src/block/proposal/attestations_and_signers.ts +121 -0
- package/src/block/proposal/committee_attestation.ts +120 -0
- package/src/block/proposal/index.ts +2 -0
- package/src/block/published_l2_block.ts +82 -0
- package/src/block/test/index.ts +1 -0
- package/src/block/test/l2_tips_store_test_suite.ts +87 -0
- package/src/block/validate_block_result.ts +122 -0
- package/src/checkpoint/checkpoint_body.ts +10 -0
- package/src/checkpoint/index.ts +1 -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 +14 -12
- package/src/contract/contract_address.ts +1 -1
- package/src/contract/contract_class.ts +7 -24
- package/src/contract/contract_class_id.ts +10 -4
- package/src/contract/contract_class_metadata.ts +8 -0
- package/src/contract/contract_instance.ts +26 -17
- package/src/contract/contract_instance_update.ts +7 -6
- package/src/contract/contract_metadata.ts +7 -0
- package/src/contract/index.ts +3 -1
- package/src/contract/interfaces/contract_class.ts +23 -35
- package/src/contract/interfaces/contract_data_source.ts +11 -20
- package/src/contract/interfaces/contract_instance_update.ts +4 -3
- package/src/contract/interfaces/node-info.ts +3 -3
- package/src/contract/interfaces/protocol_contract_addresses.ts +5 -10
- package/src/contract/private_function.ts +4 -2
- package/src/contract/private_function_membership_proof.ts +7 -7
- package/src/contract/{unconstrained_function_membership_proof.ts → utility_function_membership_proof.ts} +18 -18
- 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} +23 -20
- 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 +11 -5
- package/src/epoch-helpers/index.ts +61 -2
- package/src/errors/proving_error.ts +5 -1
- package/src/errors/simulation_error.ts +2 -2
- package/src/fees/transaction_fee.ts +28 -8
- package/src/file-store/factory.ts +76 -0
- package/src/file-store/gcs.ts +121 -0
- package/src/file-store/http.ts +67 -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 +254 -0
- package/src/gas/gas.ts +9 -2
- package/src/gas/gas_fees.ts +27 -23
- package/src/gas/gas_settings.ts +11 -9
- package/src/hash/hash.ts +45 -27
- package/src/interfaces/allowed_element.ts +21 -0
- package/src/interfaces/api_limit.ts +3 -0
- package/src/interfaces/archiver.ts +67 -25
- package/src/interfaces/aztec-node-admin.ts +99 -0
- package/src/interfaces/aztec-node.ts +196 -137
- package/src/interfaces/block-builder.ts +53 -8
- package/src/interfaces/client.ts +2 -1
- package/src/interfaces/configs.ts +29 -18
- package/src/interfaces/epoch-prover.ts +46 -16
- package/src/interfaces/l2_logs_source.ts +2 -1
- package/src/interfaces/merkle_tree_operations.ts +30 -8
- package/src/interfaces/p2p.ts +29 -4
- package/src/interfaces/private_kernel_prover.ts +13 -4
- package/src/interfaces/prover-agent.ts +9 -10
- package/src/interfaces/prover-client.ts +16 -11
- package/src/interfaces/prover-coordination.ts +6 -16
- package/src/interfaces/prover-node.ts +10 -2
- package/src/interfaces/proving-job.ts +230 -125
- package/src/interfaces/public_state_source.ts +9 -0
- package/src/interfaces/server.ts +11 -5
- package/src/interfaces/server_circuit_prover.ts +110 -58
- package/src/interfaces/service.ts +4 -2
- package/src/interfaces/slasher.ts +50 -0
- package/src/interfaces/tx_provider.ts +17 -0
- package/src/interfaces/validator.ts +95 -0
- package/src/interfaces/world_state.ts +27 -19
- 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 +28 -30
- package/src/kernel/hints/build_nullifier_read_request_hints.ts +31 -61
- package/src/kernel/hints/build_transient_data_hints.ts +12 -14
- package/src/kernel/hints/find_private_kernel_reset_dimensions.ts +3 -3
- package/src/kernel/hints/index.ts +1 -2
- package/src/kernel/hints/key_validation_hint.ts +4 -6
- package/src/kernel/hints/note_hash_read_request_hints.ts +8 -17
- package/src/kernel/hints/nullifier_read_request_hints.ts +11 -20
- package/src/kernel/hints/private_kernel_reset_hints.ts +37 -46
- package/src/kernel/hints/read_request.ts +4 -1
- package/src/kernel/hints/read_request_hints.ts +59 -38
- package/src/kernel/hints/{transient_data_index_hint.ts → transient_data_squashing_hint.ts} +9 -6
- package/src/kernel/hints/tree_leaf_read_request.ts +4 -1
- package/src/kernel/index.ts +4 -2
- package/src/kernel/log_hash.ts +86 -14
- package/src/kernel/note_hash.ts +8 -2
- package/src/kernel/nullifier.ts +16 -9
- 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 +5 -24
- package/src/kernel/private_call_request.ts +1 -1
- package/src/kernel/private_circuit_public_inputs.ts +100 -76
- package/src/kernel/private_context_inputs.ts +2 -2
- package/src/kernel/private_kernel_circuit_public_inputs.ts +13 -5
- package/src/kernel/private_kernel_data.ts +9 -31
- package/src/kernel/private_kernel_init_circuit_private_inputs.ts +5 -4
- 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 +41 -24
- package/src/kernel/private_log_data.ts +13 -4
- package/src/kernel/private_to_avm_accumulated_data.ts +18 -1
- package/src/kernel/private_to_public_kernel_circuit_public_inputs.ts +16 -7
- package/src/kernel/private_to_rollup_kernel_circuit_public_inputs.ts +16 -10
- package/src/kernel/private_validation_requests.ts +20 -51
- package/src/kernel/public_call_request.ts +92 -28
- package/src/kernel/utils/order_and_comparison.ts +0 -25
- package/src/keys/derivation.ts +2 -22
- package/src/keys/public_keys.ts +1 -1
- package/src/l1-contracts/index.ts +1 -0
- package/src/l1-contracts/slash_factory.ts +177 -0
- package/src/logs/contract_class_log.ts +134 -64
- package/src/logs/debug_log.ts +32 -0
- package/src/logs/directional_app_tagging_secret.ts +77 -0
- package/src/logs/index.ts +6 -2
- package/src/logs/log_with_tx_data.ts +19 -9
- 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 +60 -24
- package/src/logs/public_log.ts +137 -37
- package/src/logs/{l1_payload/shared_secret_derivation.ts → shared_secret_derivation.ts} +6 -15
- package/src/logs/tx_scoped_l2_log.ts +37 -25
- package/src/messaging/inbox_leaf.ts +17 -2
- package/src/messaging/index.ts +1 -0
- package/src/messaging/l1_to_l2_message_source.ts +8 -1
- package/src/messaging/l2_to_l1_membership.ts +98 -0
- package/src/messaging/l2_to_l1_message.ts +105 -40
- package/src/noir/index.ts +19 -2
- package/src/note/index.ts +1 -1
- package/src/note/note.ts +61 -5
- package/src/note/notes_filter.ts +6 -10
- package/src/note/unique_note.ts +88 -0
- package/src/p2p/attestation_utils.ts +35 -0
- package/src/p2p/block_attestation.ts +54 -26
- package/src/p2p/block_proposal.ts +63 -19
- package/src/p2p/consensus_payload.ts +62 -29
- package/src/p2p/gossipable.ts +41 -15
- package/src/p2p/index.ts +1 -0
- package/src/p2p/interface.ts +0 -24
- package/src/p2p/signature_utils.ts +7 -9
- package/src/p2p/topic_type.ts +32 -13
- package/src/parity/index.ts +2 -3
- package/src/parity/{base_parity_inputs.ts → parity_base_private_inputs.ts} +13 -11
- 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 +29 -21
- package/src/proofs/proof_data.ts +36 -0
- package/src/proofs/proving_request_type.ts +14 -9
- package/src/rollup/avm_proof_data.ts +8 -30
- package/src/rollup/base_rollup_hints.ts +42 -41
- package/src/rollup/block_constant_data.ts +73 -0
- package/src/rollup/{block_merge_rollup.ts → block_merge_rollup_private_inputs.ts} +15 -11
- package/src/rollup/block_rollup_public_inputs.ts +123 -0
- package/src/rollup/block_root_rollup_private_inputs.ts +312 -0
- package/src/rollup/checkpoint_constant_data.ts +84 -0
- package/src/rollup/checkpoint_header.ts +224 -0
- package/src/rollup/checkpoint_merge_rollup_private_inputs.ts +49 -0
- package/src/rollup/checkpoint_rollup_public_inputs.ts +139 -0
- package/src/rollup/checkpoint_root_rollup_private_inputs.ts +218 -0
- package/src/rollup/epoch_constant_data.ts +62 -0
- package/src/rollup/index.ts +19 -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 +99 -0
- package/src/rollup/{state_diff_hints.ts → tree_snapshot_diff_hints.ts} +26 -41
- 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} +17 -25
- package/src/schemas/schemas.ts +3 -0
- package/src/slashing/empire.ts +100 -0
- package/src/slashing/helpers.ts +136 -0
- package/src/slashing/index.ts +6 -0
- package/src/slashing/interfaces.ts +11 -0
- package/src/slashing/serialization.ts +103 -0
- package/src/slashing/tally.ts +87 -0
- package/src/slashing/types.ts +152 -0
- package/src/snapshots/download.ts +123 -0
- package/src/snapshots/index.ts +3 -0
- package/src/snapshots/types.ts +70 -0
- package/src/snapshots/upload.ts +64 -0
- package/src/stats/stats.ts +28 -19
- package/src/tests/factories.ts +647 -518
- package/src/tests/mocks.ts +186 -135
- package/src/trees/append_only_tree_snapshot.ts +18 -2
- 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 +48 -21
- package/src/trees/nullifier_membership_witness.ts +17 -1
- package/src/trees/public_data_leaf.ts +40 -29
- package/src/trees/public_data_witness.ts +23 -4
- package/src/tx/block_header.ts +23 -21
- package/src/tx/capsule.ts +2 -0
- package/src/tx/content_commitment.ts +48 -77
- package/src/tx/global_variable_builder.ts +2 -2
- package/src/tx/global_variables.ts +37 -22
- package/src/tx/hashed_values.ts +29 -9
- package/src/tx/index.ts +8 -2
- package/src/tx/indexed_tx_effect.ts +39 -0
- package/src/tx/offchain_effect.ts +20 -0
- package/src/tx/partial_state_reference.ts +37 -4
- package/src/tx/private_execution_result.ts +69 -88
- package/src/tx/private_tx_constant_data.ts +94 -0
- package/src/tx/processed_tx.ts +41 -35
- package/src/tx/profiling.ts +161 -0
- package/src/tx/protocol_contracts.ts +70 -0
- package/src/tx/proven_tx.ts +62 -0
- package/src/tx/public_call_request_with_calldata.ts +72 -0
- package/src/tx/public_simulation_output.ts +5 -5
- package/src/tx/simulated_tx.ts +66 -76
- package/src/tx/state_reference.ts +54 -5
- package/src/tx/tree_snapshots.ts +13 -13
- package/src/tx/tx.ts +161 -192
- package/src/tx/tx_constant_data.ts +8 -21
- package/src/tx/tx_effect.ts +128 -293
- package/src/tx/tx_execution_request.ts +14 -3
- package/src/tx/tx_hash.ts +26 -5
- package/src/tx/tx_receipt.ts +1 -37
- package/src/tx/tx_request.ts +16 -6
- package/src/tx/validator/error_texts.ts +38 -0
- package/src/tx/validator/tx_validator.ts +5 -0
- package/src/types/shared.ts +10 -9
- package/src/update-checker/index.ts +1 -0
- package/src/update-checker/update-checker.ts +165 -0
- package/src/validators/errors.ts +59 -0
- package/src/validators/index.ts +3 -0
- package/src/validators/schemas.ts +75 -0
- package/src/validators/types.ts +46 -0
- package/src/versioning/versioning.ts +28 -32
- package/src/vks/index.ts +1 -1
- package/src/vks/verification_key.ts +18 -18
- package/src/vks/{vk_witness_data.ts → vk_data.ts} +6 -6
- package/src/world-state/index.ts +1 -0
- package/src/world-state/world_state_revision.ts +21 -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/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.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.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.map +0 -1
- 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/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.map +0 -1
- 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.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.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.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/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.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/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/network/index.ts +0 -32
- package/src/note/extended_note.ts +0 -168
- 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/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
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import type { Offense, OffenseIdentifier, SlashPayload, SlashPayloadRound, ValidatorSlash } from './types.js';
|
|
2
|
+
import { OffenseType } from './types.js';
|
|
3
|
+
/**
|
|
4
|
+
* Returns true if the offense is uncontroversial as in it can be verified via L1 data alone,
|
|
5
|
+
* and does not depend on the local view of the node of the L2 p2p network.
|
|
6
|
+
* @param offense - The offense type to check
|
|
7
|
+
*/
|
|
8
|
+
export declare function isOffenseUncontroversial(offense: OffenseType): boolean;
|
|
9
|
+
/** Extracts offense identifiers (validator, epoch, offense type) from an Empire-based SlashPayload */
|
|
10
|
+
export declare function getOffenseIdentifiersFromPayload(payload: SlashPayload | SlashPayloadRound): OffenseIdentifier[];
|
|
11
|
+
/** Creates ValidatorSlashes used to create an Empire-based SlashPayload from a set of Offenses */
|
|
12
|
+
export declare function offensesToValidatorSlash(offenses: Offense[]): ValidatorSlash[];
|
|
13
|
+
/**
|
|
14
|
+
* Sorts offense data by:
|
|
15
|
+
* - Uncontroversial offenses first
|
|
16
|
+
* - Slash amount (descending)
|
|
17
|
+
* - Epoch or slot (ascending, ie oldest first)
|
|
18
|
+
* - Validator address (ascending)
|
|
19
|
+
* - Offense type (descending)
|
|
20
|
+
*/
|
|
21
|
+
export declare function offenseDataComparator(a: Offense, b: Offense): number;
|
|
22
|
+
/**
|
|
23
|
+
* Returns the first round in which the offense is eligible for being included in an Empire-based slash payload.
|
|
24
|
+
* Should be equal to to the first round that starts strictly after the offense becomes detectable.
|
|
25
|
+
*/
|
|
26
|
+
export declare function getFirstEligibleRoundForOffense(offense: OffenseIdentifier, constants: {
|
|
27
|
+
slashingRoundSize: number;
|
|
28
|
+
epochDuration: number;
|
|
29
|
+
proofSubmissionEpochs: number;
|
|
30
|
+
}): bigint;
|
|
31
|
+
//# sourceMappingURL=empire.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"empire.d.ts","sourceRoot":"","sources":["../../src/slashing/empire.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,iBAAiB,EAAE,YAAY,EAAE,iBAAiB,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAC9G,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAEzC;;;;GAIG;AACH,wBAAgB,wBAAwB,CAAC,OAAO,EAAE,WAAW,GAAG,OAAO,CAMtE;AAED,sGAAsG;AACtG,wBAAgB,gCAAgC,CAAC,OAAO,EAAE,YAAY,GAAG,iBAAiB,GAAG,iBAAiB,EAAE,CAQ/G;AAED,kGAAkG;AAClG,wBAAgB,wBAAwB,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,cAAc,EAAE,CAM9E;AAED;;;;;;;GAOG;AACH,wBAAgB,qBAAqB,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,OAAO,GAAG,MAAM,CAQpE;AAED;;;GAGG;AACH,wBAAgB,+BAA+B,CAC7C,OAAO,EAAE,iBAAiB,EAC1B,SAAS,EAAE;IAAE,iBAAiB,EAAE,MAAM,CAAC;IAAC,aAAa,EAAE,MAAM,CAAC;IAAC,qBAAqB,EAAE,MAAM,CAAA;CAAE,GAC7F,MAAM,CAqCR"}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { getRoundForSlot, getRoundsForEpoch } from './helpers.js';
|
|
2
|
+
import { OffenseType } from './types.js';
|
|
3
|
+
/**
|
|
4
|
+
* Returns true if the offense is uncontroversial as in it can be verified via L1 data alone,
|
|
5
|
+
* and does not depend on the local view of the node of the L2 p2p network.
|
|
6
|
+
* @param offense - The offense type to check
|
|
7
|
+
*/ export function isOffenseUncontroversial(offense) {
|
|
8
|
+
return offense === OffenseType.PROPOSED_INSUFFICIENT_ATTESTATIONS || offense === OffenseType.PROPOSED_INCORRECT_ATTESTATIONS || offense === OffenseType.ATTESTED_DESCENDANT_OF_INVALID;
|
|
9
|
+
}
|
|
10
|
+
/** Extracts offense identifiers (validator, epoch, offense type) from an Empire-based SlashPayload */ export function getOffenseIdentifiersFromPayload(payload) {
|
|
11
|
+
return payload.slashes.flatMap((slash)=>slash.offenses.map((o)=>({
|
|
12
|
+
validator: slash.validator,
|
|
13
|
+
offenseType: o.offenseType,
|
|
14
|
+
epochOrSlot: o.epochOrSlot
|
|
15
|
+
})));
|
|
16
|
+
}
|
|
17
|
+
/** Creates ValidatorSlashes used to create an Empire-based SlashPayload from a set of Offenses */ export function offensesToValidatorSlash(offenses) {
|
|
18
|
+
return offenses.map((offense)=>({
|
|
19
|
+
validator: offense.validator,
|
|
20
|
+
amount: offense.amount,
|
|
21
|
+
offenses: [
|
|
22
|
+
{
|
|
23
|
+
epochOrSlot: offense.epochOrSlot,
|
|
24
|
+
offenseType: offense.offenseType
|
|
25
|
+
}
|
|
26
|
+
]
|
|
27
|
+
}));
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Sorts offense data by:
|
|
31
|
+
* - Uncontroversial offenses first
|
|
32
|
+
* - Slash amount (descending)
|
|
33
|
+
* - Epoch or slot (ascending, ie oldest first)
|
|
34
|
+
* - Validator address (ascending)
|
|
35
|
+
* - Offense type (descending)
|
|
36
|
+
*/ export function offenseDataComparator(a, b) {
|
|
37
|
+
return Number(isOffenseUncontroversial(b.offenseType)) - Number(isOffenseUncontroversial(a.offenseType)) || Number(b.amount - a.amount) || Number(a.epochOrSlot - b.epochOrSlot) || a.validator.toString().localeCompare(b.validator.toString()) || Number(b.offenseType) - Number(a.offenseType);
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Returns the first round in which the offense is eligible for being included in an Empire-based slash payload.
|
|
41
|
+
* Should be equal to to the first round that starts strictly after the offense becomes detectable.
|
|
42
|
+
*/ export function getFirstEligibleRoundForOffense(offense, constants) {
|
|
43
|
+
// TODO(palla/slash): Check for off-by-ones
|
|
44
|
+
switch(offense.offenseType){
|
|
45
|
+
// Inactivity is detected at the end of the epoch, so we flag it as detected in the first fresh round for the next epoch
|
|
46
|
+
case OffenseType.INACTIVITY:
|
|
47
|
+
{
|
|
48
|
+
const epoch = offense.epochOrSlot;
|
|
49
|
+
const detectedEpoch = epoch + 1n;
|
|
50
|
+
return getRoundsForEpoch(detectedEpoch, constants)[0] + 1n;
|
|
51
|
+
}
|
|
52
|
+
// These offenses are detected once an epoch is pruned, which happens after the proof submission window
|
|
53
|
+
case OffenseType.VALID_EPOCH_PRUNED:
|
|
54
|
+
case OffenseType.DATA_WITHHOLDING:
|
|
55
|
+
{
|
|
56
|
+
// TODO(palla/slash): Check for off-by-ones especially here
|
|
57
|
+
const epoch = offense.epochOrSlot;
|
|
58
|
+
const detectedEpoch = epoch + BigInt(constants.proofSubmissionEpochs);
|
|
59
|
+
return getRoundsForEpoch(detectedEpoch, constants)[0] + 1n;
|
|
60
|
+
}
|
|
61
|
+
// These offenses are detected immediately in the slot they occur, so we assume they are detected in the first round for the following slot
|
|
62
|
+
case OffenseType.PROPOSED_INSUFFICIENT_ATTESTATIONS:
|
|
63
|
+
case OffenseType.PROPOSED_INCORRECT_ATTESTATIONS:
|
|
64
|
+
case OffenseType.ATTESTED_DESCENDANT_OF_INVALID:
|
|
65
|
+
case OffenseType.BROADCASTED_INVALID_BLOCK_PROPOSAL:
|
|
66
|
+
{
|
|
67
|
+
const slot = offense.epochOrSlot;
|
|
68
|
+
const detectedSlot = slot + 1n;
|
|
69
|
+
return getRoundForSlot(detectedSlot, constants).round + 1n;
|
|
70
|
+
}
|
|
71
|
+
// Assume these are epoch-based offenses, even though we should never have to process these
|
|
72
|
+
case OffenseType.UNKNOWN:
|
|
73
|
+
{
|
|
74
|
+
const epoch = offense.epochOrSlot;
|
|
75
|
+
const detectedEpoch = epoch + 1n;
|
|
76
|
+
return getRoundsForEpoch(detectedEpoch, constants)[0] + 1n;
|
|
77
|
+
}
|
|
78
|
+
default:
|
|
79
|
+
{
|
|
80
|
+
const _ = offense.offenseType;
|
|
81
|
+
throw new Error(`Unknown offense type: ${offense.offenseType}`);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { type L1RollupConstants } from '../epoch-helpers/index.js';
|
|
2
|
+
import type { SlasherConfig } from '../interfaces/slasher.js';
|
|
3
|
+
import { type Offense, OffenseType } from './types.js';
|
|
4
|
+
/** Returns the voting round number and voting slot within the round for a given L2 slot. */
|
|
5
|
+
export declare function getRoundForSlot(slot: bigint, constants: {
|
|
6
|
+
slashingRoundSize: number;
|
|
7
|
+
}): {
|
|
8
|
+
round: bigint;
|
|
9
|
+
votingSlot: bigint;
|
|
10
|
+
};
|
|
11
|
+
/** Returns the voting round(s) lower and upper bounds (inclusive) covered by the given epoch */
|
|
12
|
+
export declare function getRoundsForEpoch(epoch: bigint, constants: {
|
|
13
|
+
slashingRoundSize: number;
|
|
14
|
+
epochDuration: number;
|
|
15
|
+
}): [bigint, bigint];
|
|
16
|
+
/** Returns the epochs spanned during a given slashing round */
|
|
17
|
+
export declare function getEpochsForRound(round: bigint, constants: {
|
|
18
|
+
slashingRoundSize: number;
|
|
19
|
+
epochDuration: number;
|
|
20
|
+
}): bigint[];
|
|
21
|
+
/** Reads the configured penalty for a given offense type from a slasher config struct */
|
|
22
|
+
export declare function getPenaltyForOffense(offense: OffenseType, config: Pick<SlasherConfig, 'slashAttestDescendantOfInvalidPenalty' | 'slashBroadcastedInvalidBlockPenalty' | 'slashPrunePenalty' | 'slashDataWithholdingPenalty' | 'slashUnknownPenalty' | 'slashInactivityPenalty' | 'slashProposeInvalidAttestationsPenalty'>): bigint;
|
|
23
|
+
/** Returns whether the `epochOrSlot` field for an offense references an epoch or a slot */
|
|
24
|
+
export declare function getTimeUnitForOffense(offense: OffenseType): 'epoch' | 'slot';
|
|
25
|
+
/** Returns the slot for a given offense. If the offense references an epoch, returns the first slot of the epoch. */
|
|
26
|
+
export declare function getSlotForOffense(offense: Pick<Offense, 'epochOrSlot' | 'offenseType'>, constants: Pick<L1RollupConstants, 'epochDuration'>): bigint;
|
|
27
|
+
/** Returns the epoch for a given offense. If the offense type or epoch is not defined, returns undefined. */
|
|
28
|
+
export declare function getEpochForOffense(offense: Pick<Offense, 'epochOrSlot' | 'offenseType'>, constants: Pick<L1RollupConstants, 'epochDuration'>): bigint;
|
|
29
|
+
export declare function getEpochForOffense(offense: Partial<Pick<Offense, 'epochOrSlot' | 'offenseType'>>, constants: Pick<L1RollupConstants, 'epochDuration'>): bigint | undefined;
|
|
30
|
+
/** Returns the slashing round in which a given offense occurred. */
|
|
31
|
+
export declare function getRoundForOffense(offense: Pick<Offense, 'epochOrSlot' | 'offenseType'>, constants: {
|
|
32
|
+
slashingRoundSize: number;
|
|
33
|
+
epochDuration: number;
|
|
34
|
+
}): bigint;
|
|
35
|
+
//# sourceMappingURL=helpers.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../../src/slashing/helpers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,iBAAiB,EAAwC,MAAM,2BAA2B,CAAC;AACzG,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAC9D,OAAO,EAAE,KAAK,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAEvD,4FAA4F;AAC5F,wBAAgB,eAAe,CAC7B,IAAI,EAAE,MAAM,EACZ,SAAS,EAAE;IAAE,iBAAiB,EAAE,MAAM,CAAA;CAAE,GACvC;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,UAAU,EAAE,MAAM,CAAA;CAAE,CAKvC;AAED,gGAAgG;AAChG,wBAAgB,iBAAiB,CAC/B,KAAK,EAAE,MAAM,EACb,SAAS,EAAE;IAAE,iBAAiB,EAAE,MAAM,CAAC;IAAC,aAAa,EAAE,MAAM,CAAA;CAAE,GAC9D,CAAC,MAAM,EAAE,MAAM,CAAC,CAKlB;AAED,+DAA+D;AAC/D,wBAAgB,iBAAiB,CAC/B,KAAK,EAAE,MAAM,EACb,SAAS,EAAE;IAAE,iBAAiB,EAAE,MAAM,CAAC;IAAC,aAAa,EAAE,MAAM,CAAA;CAAE,GAC9D,MAAM,EAAE,CAUV;AAED,yFAAyF;AACzF,wBAAgB,oBAAoB,CAClC,OAAO,EAAE,WAAW,EACpB,MAAM,EAAE,IAAI,CACV,aAAa,EACX,uCAAuC,GACvC,qCAAqC,GACrC,mBAAmB,GACnB,6BAA6B,GAC7B,qBAAqB,GACrB,wBAAwB,GACxB,wCAAwC,CAC3C,UAuBF;AAED,2FAA2F;AAC3F,wBAAgB,qBAAqB,CAAC,OAAO,EAAE,WAAW,GAAG,OAAO,GAAG,MAAM,CAiB5E;AAED,qHAAqH;AACrH,wBAAgB,iBAAiB,CAC/B,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,aAAa,GAAG,aAAa,CAAC,EACrD,SAAS,EAAE,IAAI,CAAC,iBAAiB,EAAE,eAAe,CAAC,GAClD,MAAM,CAGR;AAED,6GAA6G;AAC7G,wBAAgB,kBAAkB,CAChC,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,aAAa,GAAG,aAAa,CAAC,EACrD,SAAS,EAAE,IAAI,CAAC,iBAAiB,EAAE,eAAe,CAAC,GAClD,MAAM,CAAC;AACV,wBAAgB,kBAAkB,CAChC,OAAO,EAAE,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,aAAa,GAAG,aAAa,CAAC,CAAC,EAC9D,SAAS,EAAE,IAAI,CAAC,iBAAiB,EAAE,eAAe,CAAC,GAClD,MAAM,GAAG,SAAS,CAAC;AAYtB,oEAAoE;AACpE,wBAAgB,kBAAkB,CAChC,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,aAAa,GAAG,aAAa,CAAC,EACrD,SAAS,EAAE;IAAE,iBAAiB,EAAE,MAAM,CAAC;IAAC,aAAa,EAAE,MAAM,CAAA;CAAE,GAC9D,MAAM,CAGR"}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { getEpochAtSlot, getSlotRangeForEpoch } from '../epoch-helpers/index.js';
|
|
2
|
+
import { OffenseType } from './types.js';
|
|
3
|
+
/** Returns the voting round number and voting slot within the round for a given L2 slot. */ export function getRoundForSlot(slot, constants) {
|
|
4
|
+
const roundSize = BigInt(constants.slashingRoundSize);
|
|
5
|
+
const round = slot / roundSize;
|
|
6
|
+
const votingSlot = slot % roundSize;
|
|
7
|
+
return {
|
|
8
|
+
round,
|
|
9
|
+
votingSlot
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
/** Returns the voting round(s) lower and upper bounds (inclusive) covered by the given epoch */ export function getRoundsForEpoch(epoch, constants) {
|
|
13
|
+
const [start, end] = getSlotRangeForEpoch(epoch, constants);
|
|
14
|
+
const startRound = getRoundForSlot(start, constants).round;
|
|
15
|
+
const endRound = getRoundForSlot(end, constants).round;
|
|
16
|
+
return [
|
|
17
|
+
startRound,
|
|
18
|
+
endRound
|
|
19
|
+
];
|
|
20
|
+
}
|
|
21
|
+
/** Returns the epochs spanned during a given slashing round */ export function getEpochsForRound(round, constants) {
|
|
22
|
+
const epochs = [];
|
|
23
|
+
const firstSlot = round * BigInt(constants.slashingRoundSize);
|
|
24
|
+
const lastSlot = firstSlot + BigInt(constants.slashingRoundSize) - 1n;
|
|
25
|
+
const startEpoch = getEpochAtSlot(firstSlot, constants);
|
|
26
|
+
const endEpoch = getEpochAtSlot(lastSlot, constants);
|
|
27
|
+
for(let epoch = startEpoch; epoch <= endEpoch; epoch++){
|
|
28
|
+
epochs.push(epoch);
|
|
29
|
+
}
|
|
30
|
+
return epochs;
|
|
31
|
+
}
|
|
32
|
+
/** Reads the configured penalty for a given offense type from a slasher config struct */ export function getPenaltyForOffense(offense, config) {
|
|
33
|
+
switch(offense){
|
|
34
|
+
case OffenseType.VALID_EPOCH_PRUNED:
|
|
35
|
+
return config.slashPrunePenalty;
|
|
36
|
+
case OffenseType.DATA_WITHHOLDING:
|
|
37
|
+
return config.slashDataWithholdingPenalty;
|
|
38
|
+
case OffenseType.INACTIVITY:
|
|
39
|
+
return config.slashInactivityPenalty;
|
|
40
|
+
case OffenseType.PROPOSED_INSUFFICIENT_ATTESTATIONS:
|
|
41
|
+
case OffenseType.PROPOSED_INCORRECT_ATTESTATIONS:
|
|
42
|
+
return config.slashProposeInvalidAttestationsPenalty;
|
|
43
|
+
case OffenseType.ATTESTED_DESCENDANT_OF_INVALID:
|
|
44
|
+
return config.slashAttestDescendantOfInvalidPenalty;
|
|
45
|
+
case OffenseType.BROADCASTED_INVALID_BLOCK_PROPOSAL:
|
|
46
|
+
return config.slashBroadcastedInvalidBlockPenalty;
|
|
47
|
+
case OffenseType.UNKNOWN:
|
|
48
|
+
return config.slashUnknownPenalty;
|
|
49
|
+
default:
|
|
50
|
+
{
|
|
51
|
+
const _exhaustiveCheck = offense;
|
|
52
|
+
throw new Error(`Unknown offense type: ${_exhaustiveCheck}`);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
/** Returns whether the `epochOrSlot` field for an offense references an epoch or a slot */ export function getTimeUnitForOffense(offense) {
|
|
57
|
+
switch(offense){
|
|
58
|
+
case OffenseType.ATTESTED_DESCENDANT_OF_INVALID:
|
|
59
|
+
case OffenseType.BROADCASTED_INVALID_BLOCK_PROPOSAL:
|
|
60
|
+
case OffenseType.PROPOSED_INCORRECT_ATTESTATIONS:
|
|
61
|
+
case OffenseType.PROPOSED_INSUFFICIENT_ATTESTATIONS:
|
|
62
|
+
return 'slot';
|
|
63
|
+
case OffenseType.INACTIVITY:
|
|
64
|
+
case OffenseType.DATA_WITHHOLDING:
|
|
65
|
+
case OffenseType.UNKNOWN:
|
|
66
|
+
case OffenseType.VALID_EPOCH_PRUNED:
|
|
67
|
+
return 'epoch';
|
|
68
|
+
default:
|
|
69
|
+
{
|
|
70
|
+
const _exhaustiveCheck = offense;
|
|
71
|
+
throw new Error(`Unknown offense type: ${_exhaustiveCheck}`);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
/** Returns the slot for a given offense. If the offense references an epoch, returns the first slot of the epoch. */ export function getSlotForOffense(offense, constants) {
|
|
76
|
+
const { epochOrSlot, offenseType } = offense;
|
|
77
|
+
return getTimeUnitForOffense(offenseType) === 'epoch' ? epochOrSlot * BigInt(constants.epochDuration) : epochOrSlot;
|
|
78
|
+
}
|
|
79
|
+
export function getEpochForOffense(offense, constants) {
|
|
80
|
+
const { epochOrSlot, offenseType } = offense;
|
|
81
|
+
if (epochOrSlot === undefined || offenseType === undefined) {
|
|
82
|
+
return undefined;
|
|
83
|
+
}
|
|
84
|
+
return getTimeUnitForOffense(offenseType) === 'epoch' ? epochOrSlot : epochOrSlot / BigInt(constants.epochDuration);
|
|
85
|
+
}
|
|
86
|
+
/** Returns the slashing round in which a given offense occurred. */ export function getRoundForOffense(offense, constants) {
|
|
87
|
+
const slot = getSlotForOffense(offense, constants);
|
|
88
|
+
return getRoundForSlot(slot, constants).round;
|
|
89
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/slashing/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,iBAAiB,CAAC;AAChC,cAAc,cAAc,CAAC;AAC7B,cAAc,aAAa,CAAC;AAC5B,cAAc,YAAY,CAAC;AAC3B,cAAc,oBAAoB,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { ProposerSlashAction } from './types.js';
|
|
2
|
+
export interface ProposerSlashActionProvider {
|
|
3
|
+
/**
|
|
4
|
+
* Returns the actions to take for the proposer in the current slot.
|
|
5
|
+
* This can include creating a slash payload or other actions.
|
|
6
|
+
* @param slotNumber - The current slot number
|
|
7
|
+
* @returns The actions to take
|
|
8
|
+
*/
|
|
9
|
+
getProposerActions(slotNumber: bigint): Promise<ProposerSlashAction[]>;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=interfaces.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"interfaces.d.ts","sourceRoot":"","sources":["../../src/slashing/interfaces.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAEtD,MAAM,WAAW,2BAA2B;IAC1C;;;;;OAKG;IACH,kBAAkB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,mBAAmB,EAAE,CAAC,CAAC;CACxE"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { Offense, SlashPayload, SlashPayloadRound } from './types.js';
|
|
2
|
+
export declare function serializeOffense(offense: Offense): Buffer;
|
|
3
|
+
export declare function deserializeOffense(buffer: Buffer): Offense;
|
|
4
|
+
export declare function serializeSlashPayload(payload: SlashPayload): Buffer;
|
|
5
|
+
export declare function deserializeSlashPayload(buffer: Buffer): SlashPayload;
|
|
6
|
+
export declare function serializeSlashPayloadRound(payload: SlashPayloadRound): Buffer;
|
|
7
|
+
export declare function deserializeSlashPayloadRound(buffer: Buffer): SlashPayloadRound;
|
|
8
|
+
//# sourceMappingURL=serialization.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"serialization.d.ts","sourceRoot":"","sources":["../../src/slashing/serialization.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EACV,OAAO,EAEP,YAAY,EACZ,iBAAiB,EAGlB,MAAM,YAAY,CAAC;AAEpB,wBAAgB,gBAAgB,CAAC,OAAO,EAAE,OAAO,GAAG,MAAM,CAOzD;AAED,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAQ1D;AAiCD,wBAAgB,qBAAqB,CAAC,OAAO,EAAE,YAAY,GAAG,MAAM,CAOnE;AAED,wBAAgB,uBAAuB,CAAC,MAAM,EAAE,MAAM,GAAG,YAAY,CAOpE;AAED,wBAAgB,0BAA0B,CAAC,OAAO,EAAE,iBAAiB,GAAG,MAAM,CAS7E;AAED,wBAAgB,4BAA4B,CAAC,MAAM,EAAE,MAAM,GAAG,iBAAiB,CAU9E"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { times } from '@aztec/foundation/collection';
|
|
2
|
+
import { EthAddress } from '@aztec/foundation/eth-address';
|
|
3
|
+
import { BufferReader, bigintToUInt64BE, bigintToUInt128BE, serializeToBuffer } from '@aztec/foundation/serialize';
|
|
4
|
+
export function serializeOffense(offense) {
|
|
5
|
+
return serializeToBuffer(offense.validator, bigintToUInt128BE(offense.amount), offense.offenseType, bigintToUInt64BE(offense.epochOrSlot));
|
|
6
|
+
}
|
|
7
|
+
export function deserializeOffense(buffer) {
|
|
8
|
+
const reader = BufferReader.asReader(buffer);
|
|
9
|
+
const validator = reader.readObject(EthAddress);
|
|
10
|
+
const amount = reader.readUInt128();
|
|
11
|
+
const offense = reader.readNumber();
|
|
12
|
+
const epochOrSlot = reader.readUInt64();
|
|
13
|
+
return {
|
|
14
|
+
validator,
|
|
15
|
+
amount,
|
|
16
|
+
offenseType: offense,
|
|
17
|
+
epochOrSlot
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
function serializeValidatorSlashOffense(offense) {
|
|
21
|
+
return serializeToBuffer(bigintToUInt64BE(offense.epochOrSlot), offense.offenseType);
|
|
22
|
+
}
|
|
23
|
+
function deserializeValidatorSlashOffense(buffer) {
|
|
24
|
+
const reader = BufferReader.asReader(buffer);
|
|
25
|
+
return {
|
|
26
|
+
epochOrSlot: reader.readUInt64(),
|
|
27
|
+
offenseType: reader.readNumber()
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
function serializeValidatorSlash(slash) {
|
|
31
|
+
return serializeToBuffer(slash.validator, bigintToUInt128BE(slash.amount), slash.offenses.length, slash.offenses.map(serializeValidatorSlashOffense));
|
|
32
|
+
}
|
|
33
|
+
function deserializeValidatorSlash(buffer) {
|
|
34
|
+
const reader = BufferReader.asReader(buffer);
|
|
35
|
+
const validator = reader.readObject(EthAddress);
|
|
36
|
+
const amount = reader.readUInt128();
|
|
37
|
+
const offensesCount = reader.readNumber();
|
|
38
|
+
const offenses = times(offensesCount, ()=>deserializeValidatorSlashOffense(reader));
|
|
39
|
+
return {
|
|
40
|
+
validator,
|
|
41
|
+
amount,
|
|
42
|
+
offenses
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
export function serializeSlashPayload(payload) {
|
|
46
|
+
return serializeToBuffer(payload.address, payload.slashes.length, payload.slashes.map(serializeValidatorSlash), bigintToUInt64BE(payload.timestamp));
|
|
47
|
+
}
|
|
48
|
+
export function deserializeSlashPayload(buffer) {
|
|
49
|
+
const reader = BufferReader.asReader(buffer);
|
|
50
|
+
const address = reader.readObject(EthAddress);
|
|
51
|
+
const slashesCount = reader.readNumber();
|
|
52
|
+
const slashes = times(slashesCount, ()=>deserializeValidatorSlash(reader));
|
|
53
|
+
const timestamp = reader.readUInt64();
|
|
54
|
+
return {
|
|
55
|
+
address,
|
|
56
|
+
slashes,
|
|
57
|
+
timestamp
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
export function serializeSlashPayloadRound(payload) {
|
|
61
|
+
return serializeToBuffer(payload.address, payload.slashes.length, payload.slashes.map(serializeValidatorSlash), bigintToUInt64BE(payload.timestamp), Number(payload.votes), bigintToUInt64BE(payload.round));
|
|
62
|
+
}
|
|
63
|
+
export function deserializeSlashPayloadRound(buffer) {
|
|
64
|
+
const reader = BufferReader.asReader(buffer);
|
|
65
|
+
const address = reader.readObject(EthAddress);
|
|
66
|
+
const slashesCount = reader.readNumber();
|
|
67
|
+
const slashes = times(slashesCount, ()=>deserializeValidatorSlash(reader));
|
|
68
|
+
const timestamp = reader.readUInt64();
|
|
69
|
+
const votes = BigInt(reader.readNumber());
|
|
70
|
+
const round = reader.readUInt64();
|
|
71
|
+
return {
|
|
72
|
+
address,
|
|
73
|
+
slashes,
|
|
74
|
+
timestamp,
|
|
75
|
+
votes,
|
|
76
|
+
round
|
|
77
|
+
};
|
|
78
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { EthAddress } from '@aztec/foundation/eth-address';
|
|
2
|
+
import type { PartialBy } from '@aztec/foundation/types';
|
|
3
|
+
import type { Offense, ValidatorSlashVote } from './types.js';
|
|
4
|
+
/**
|
|
5
|
+
* Creates a consensus-slash vote for a given set of committees based on a set of Offenses
|
|
6
|
+
* @param offenses - Array of offenses to consider
|
|
7
|
+
* @param committees - Array of committees (each containing array of validator addresses)
|
|
8
|
+
* @param epochsForCommittees - Array of epochs corresponding to each committee
|
|
9
|
+
* @param settings - Settings including slashingAmounts and optional validator override lists
|
|
10
|
+
* @returns Array of ValidatorSlashVote, where each vote is how many slash units the validator in that position should be slashed
|
|
11
|
+
*/
|
|
12
|
+
export declare function getSlashConsensusVotesFromOffenses(offenses: PartialBy<Offense, 'epochOrSlot'>[], committees: EthAddress[][], epochsForCommittees: bigint[], settings: {
|
|
13
|
+
slashingAmounts: [bigint, bigint, bigint];
|
|
14
|
+
epochDuration: number;
|
|
15
|
+
}): ValidatorSlashVote[];
|
|
16
|
+
/**
|
|
17
|
+
* Encodes a set of slash votes into a Buffer for use in a consensus slashing vote transaction.
|
|
18
|
+
* Each vote is represented as a 2-bit value, which represents how many slashing units the validator should be slashed.
|
|
19
|
+
* @param votes - The array of slash votes to encode
|
|
20
|
+
* @returns A Buffer containing the encoded slash votes
|
|
21
|
+
*/
|
|
22
|
+
export declare function encodeSlashConsensusVotes(votes: ValidatorSlashVote[]): Buffer;
|
|
23
|
+
//# sourceMappingURL=tally.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tally.d.ts","sourceRoot":"","sources":["../../src/slashing/tally.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAC3D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AAGzD,OAAO,KAAK,EAAE,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAE9D;;;;;;;GAOG;AACH,wBAAgB,kCAAkC,CAChD,QAAQ,EAAE,SAAS,CAAC,OAAO,EAAE,aAAa,CAAC,EAAE,EAC7C,UAAU,EAAE,UAAU,EAAE,EAAE,EAC1B,mBAAmB,EAAE,MAAM,EAAE,EAC7B,QAAQ,EAAE;IACR,eAAe,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;IAC1C,aAAa,EAAE,MAAM,CAAC;CACvB,GACA,kBAAkB,EAAE,CA2BtB;AAeD;;;;;GAKG;AACH,wBAAgB,yBAAyB,CAAC,KAAK,EAAE,kBAAkB,EAAE,GAAG,MAAM,CAe7E"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { sumBigint } from '@aztec/foundation/bigint';
|
|
2
|
+
import { getEpochForOffense } from './helpers.js';
|
|
3
|
+
/**
|
|
4
|
+
* Creates a consensus-slash vote for a given set of committees based on a set of Offenses
|
|
5
|
+
* @param offenses - Array of offenses to consider
|
|
6
|
+
* @param committees - Array of committees (each containing array of validator addresses)
|
|
7
|
+
* @param epochsForCommittees - Array of epochs corresponding to each committee
|
|
8
|
+
* @param settings - Settings including slashingAmounts and optional validator override lists
|
|
9
|
+
* @returns Array of ValidatorSlashVote, where each vote is how many slash units the validator in that position should be slashed
|
|
10
|
+
*/ export function getSlashConsensusVotesFromOffenses(offenses, committees, epochsForCommittees, settings) {
|
|
11
|
+
const { slashingAmounts } = settings;
|
|
12
|
+
if (committees.length !== epochsForCommittees.length) {
|
|
13
|
+
throw new Error('committees and epochsForCommittees must have the same length');
|
|
14
|
+
}
|
|
15
|
+
const votes = committees.flatMap((committee, committeeIndex)=>{
|
|
16
|
+
const committeeEpoch = epochsForCommittees[committeeIndex];
|
|
17
|
+
return committee.map((validator)=>{
|
|
18
|
+
// Find offenses for this validator in this specific epoch.
|
|
19
|
+
// If an offense has no epoch, it is considered for all epochs due to a slashAlways setting.
|
|
20
|
+
const validatorOffenses = offenses.filter((o)=>o.validator.equals(validator) && (o.epochOrSlot === undefined || getEpochForOffense(o, settings) === committeeEpoch));
|
|
21
|
+
// Sum up the penalties for this validator in this epoch
|
|
22
|
+
const slashAmount = sumBigint(validatorOffenses.map((o)=>o.amount));
|
|
23
|
+
const slashUnits = getSlashUnitsForAmount(slashAmount, slashingAmounts);
|
|
24
|
+
return Number(slashUnits);
|
|
25
|
+
});
|
|
26
|
+
});
|
|
27
|
+
return votes;
|
|
28
|
+
}
|
|
29
|
+
/** Returns the slash vote for the given amount to slash. */ function getSlashUnitsForAmount(amountToSlash, slashingAmounts) {
|
|
30
|
+
if (amountToSlash >= slashingAmounts[2]) {
|
|
31
|
+
return 3;
|
|
32
|
+
} else if (amountToSlash >= slashingAmounts[1]) {
|
|
33
|
+
return 2;
|
|
34
|
+
} else if (amountToSlash >= slashingAmounts[0]) {
|
|
35
|
+
return 1;
|
|
36
|
+
} else {
|
|
37
|
+
return 0;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Encodes a set of slash votes into a Buffer for use in a consensus slashing vote transaction.
|
|
42
|
+
* Each vote is represented as a 2-bit value, which represents how many slashing units the validator should be slashed.
|
|
43
|
+
* @param votes - The array of slash votes to encode
|
|
44
|
+
* @returns A Buffer containing the encoded slash votes
|
|
45
|
+
*/ export function encodeSlashConsensusVotes(votes) {
|
|
46
|
+
if (votes.length % 4 !== 0) {
|
|
47
|
+
throw new Error('Votes array must have a length that is a multiple of 4');
|
|
48
|
+
}
|
|
49
|
+
const buffer = Buffer.alloc(votes.length / 4);
|
|
50
|
+
for(let i = 0; i < votes.length; i += 4){
|
|
51
|
+
// Encode votes to match Solidity's bit order (LSB to MSB)
|
|
52
|
+
// Bits 0-1: validator at index i
|
|
53
|
+
// Bits 2-3: validator at index i+1
|
|
54
|
+
// Bits 4-5: validator at index i+2
|
|
55
|
+
// Bits 6-7: validator at index i+3
|
|
56
|
+
const voteByte = votes[i] | votes[i + 1] << 2 | votes[i + 2] << 4 | votes[i + 3] << 6;
|
|
57
|
+
buffer.writeUInt8(voteByte, i / 4);
|
|
58
|
+
}
|
|
59
|
+
return buffer;
|
|
60
|
+
}
|
|
@@ -0,0 +1,162 @@
|
|
|
1
|
+
import { EthAddress } from '@aztec/foundation/eth-address';
|
|
2
|
+
import { z } from 'zod';
|
|
3
|
+
import { type ZodFor } from '../schemas/index.js';
|
|
4
|
+
export declare enum OffenseType {
|
|
5
|
+
UNKNOWN = 0,
|
|
6
|
+
/** The data for proving an epoch was not publicly available, we slash its committee */
|
|
7
|
+
DATA_WITHHOLDING = 1,
|
|
8
|
+
/** An epoch was not successfully proven in time, we slash its committee */
|
|
9
|
+
VALID_EPOCH_PRUNED = 2,
|
|
10
|
+
/** A proposer failed to attest or propose during an epoch according to the Sentinel */
|
|
11
|
+
INACTIVITY = 3,
|
|
12
|
+
/** A proposer sent an invalid block proposal over the p2p network to the committee */
|
|
13
|
+
BROADCASTED_INVALID_BLOCK_PROPOSAL = 4,
|
|
14
|
+
/** A proposer pushed to L1 a block with insufficient committee attestations */
|
|
15
|
+
PROPOSED_INSUFFICIENT_ATTESTATIONS = 5,
|
|
16
|
+
/** A proposer pushed to L1 a block with incorrect committee attestations (ie signature from a non-committee member) */
|
|
17
|
+
PROPOSED_INCORRECT_ATTESTATIONS = 6,
|
|
18
|
+
/** A committee member attested to a block that was built as a descendent of an invalid block (as in a block with invalid attestations) */
|
|
19
|
+
ATTESTED_DESCENDANT_OF_INVALID = 7
|
|
20
|
+
}
|
|
21
|
+
export declare function getOffenseTypeName(offense: OffenseType): "unknown" | "data_withholding" | "valid_epoch_pruned" | "inactivity" | "broadcasted_invalid_block_proposal" | "proposed_insufficient_attestations" | "proposed_incorrect_attestations" | "attested_descendant_of_invalid";
|
|
22
|
+
export declare const OffenseTypeSchema: z.ZodNativeEnum<typeof OffenseType>;
|
|
23
|
+
export declare const OffenseToBigInt: Record<OffenseType, bigint>;
|
|
24
|
+
export declare function bigIntToOffense(offense: bigint): OffenseType;
|
|
25
|
+
export type Offense = {
|
|
26
|
+
validator: EthAddress;
|
|
27
|
+
amount: bigint;
|
|
28
|
+
offenseType: OffenseType;
|
|
29
|
+
epochOrSlot: bigint;
|
|
30
|
+
};
|
|
31
|
+
export type OffenseIdentifier = Pick<Offense, 'validator' | 'offenseType' | 'epochOrSlot'>;
|
|
32
|
+
export declare const OffenseSchema: z.ZodObject<{
|
|
33
|
+
validator: ZodFor<EthAddress>;
|
|
34
|
+
amount: z.ZodPipeline<z.ZodUnion<[z.ZodBigInt, z.ZodNumber, z.ZodString]>, z.ZodBigInt>;
|
|
35
|
+
offenseType: z.ZodNativeEnum<typeof OffenseType>;
|
|
36
|
+
epochOrSlot: z.ZodPipeline<z.ZodUnion<[z.ZodBigInt, z.ZodNumber, z.ZodString]>, z.ZodBigInt>;
|
|
37
|
+
}, "strip", z.ZodTypeAny, {
|
|
38
|
+
amount: bigint;
|
|
39
|
+
validator: EthAddress;
|
|
40
|
+
offenseType: OffenseType;
|
|
41
|
+
epochOrSlot: bigint;
|
|
42
|
+
}, {
|
|
43
|
+
amount: string | number | bigint;
|
|
44
|
+
offenseType: OffenseType;
|
|
45
|
+
epochOrSlot: string | number | bigint;
|
|
46
|
+
validator?: any;
|
|
47
|
+
}>;
|
|
48
|
+
/** Offense by a validator in the context of a slash payload */
|
|
49
|
+
export type ValidatorSlashOffense = {
|
|
50
|
+
epochOrSlot: bigint;
|
|
51
|
+
offenseType: OffenseType;
|
|
52
|
+
};
|
|
53
|
+
/** Slashed amount and total offenses by a validator in the context of a slash payload */
|
|
54
|
+
export type ValidatorSlash = {
|
|
55
|
+
validator: EthAddress;
|
|
56
|
+
amount: bigint;
|
|
57
|
+
offenses: ValidatorSlashOffense[];
|
|
58
|
+
};
|
|
59
|
+
/** Slash payload as published by the empire slash proposer */
|
|
60
|
+
export type SlashPayload = {
|
|
61
|
+
address: EthAddress;
|
|
62
|
+
slashes: ValidatorSlash[];
|
|
63
|
+
timestamp: bigint;
|
|
64
|
+
};
|
|
65
|
+
/** Slash payload with round information from empire slash proposer */
|
|
66
|
+
export type SlashPayloadRound = SlashPayload & {
|
|
67
|
+
votes: bigint;
|
|
68
|
+
round: bigint;
|
|
69
|
+
};
|
|
70
|
+
export declare const SlashPayloadRoundSchema: z.ZodObject<{
|
|
71
|
+
address: ZodFor<EthAddress>;
|
|
72
|
+
timestamp: z.ZodPipeline<z.ZodUnion<[z.ZodBigInt, z.ZodNumber, z.ZodString]>, z.ZodBigInt>;
|
|
73
|
+
votes: z.ZodPipeline<z.ZodUnion<[z.ZodBigInt, z.ZodNumber, z.ZodString]>, z.ZodBigInt>;
|
|
74
|
+
round: z.ZodPipeline<z.ZodUnion<[z.ZodBigInt, z.ZodNumber, z.ZodString]>, z.ZodBigInt>;
|
|
75
|
+
slashes: z.ZodArray<z.ZodObject<{
|
|
76
|
+
validator: ZodFor<EthAddress>;
|
|
77
|
+
amount: z.ZodPipeline<z.ZodUnion<[z.ZodBigInt, z.ZodNumber, z.ZodString]>, z.ZodBigInt>;
|
|
78
|
+
offenses: z.ZodArray<z.ZodObject<{
|
|
79
|
+
offenseType: z.ZodNativeEnum<typeof OffenseType>;
|
|
80
|
+
epochOrSlot: z.ZodPipeline<z.ZodUnion<[z.ZodBigInt, z.ZodNumber, z.ZodString]>, z.ZodBigInt>;
|
|
81
|
+
}, "strip", z.ZodTypeAny, {
|
|
82
|
+
offenseType: OffenseType;
|
|
83
|
+
epochOrSlot: bigint;
|
|
84
|
+
}, {
|
|
85
|
+
offenseType: OffenseType;
|
|
86
|
+
epochOrSlot: string | number | bigint;
|
|
87
|
+
}>, "many">;
|
|
88
|
+
}, "strip", z.ZodTypeAny, {
|
|
89
|
+
amount: bigint;
|
|
90
|
+
validator: EthAddress;
|
|
91
|
+
offenses: {
|
|
92
|
+
offenseType: OffenseType;
|
|
93
|
+
epochOrSlot: bigint;
|
|
94
|
+
}[];
|
|
95
|
+
}, {
|
|
96
|
+
amount: string | number | bigint;
|
|
97
|
+
offenses: {
|
|
98
|
+
offenseType: OffenseType;
|
|
99
|
+
epochOrSlot: string | number | bigint;
|
|
100
|
+
}[];
|
|
101
|
+
validator?: any;
|
|
102
|
+
}>, "many">;
|
|
103
|
+
}, "strip", z.ZodTypeAny, {
|
|
104
|
+
timestamp: bigint;
|
|
105
|
+
address: EthAddress;
|
|
106
|
+
votes: bigint;
|
|
107
|
+
round: bigint;
|
|
108
|
+
slashes: {
|
|
109
|
+
amount: bigint;
|
|
110
|
+
validator: EthAddress;
|
|
111
|
+
offenses: {
|
|
112
|
+
offenseType: OffenseType;
|
|
113
|
+
epochOrSlot: bigint;
|
|
114
|
+
}[];
|
|
115
|
+
}[];
|
|
116
|
+
}, {
|
|
117
|
+
timestamp: string | number | bigint;
|
|
118
|
+
votes: string | number | bigint;
|
|
119
|
+
round: string | number | bigint;
|
|
120
|
+
slashes: {
|
|
121
|
+
amount: string | number | bigint;
|
|
122
|
+
offenses: {
|
|
123
|
+
offenseType: OffenseType;
|
|
124
|
+
epochOrSlot: string | number | bigint;
|
|
125
|
+
}[];
|
|
126
|
+
validator?: any;
|
|
127
|
+
}[];
|
|
128
|
+
address?: any;
|
|
129
|
+
}>;
|
|
130
|
+
/** Votes for a validator slash in the consensus slash proposer */
|
|
131
|
+
export type ValidatorSlashVote = number;
|
|
132
|
+
export type ProposerSlashAction =
|
|
133
|
+
/** Create a new slash payload on an empire-based slash proposer */
|
|
134
|
+
{
|
|
135
|
+
type: 'create-empire-payload';
|
|
136
|
+
data: ValidatorSlash[];
|
|
137
|
+
}
|
|
138
|
+
/** Vote for a slashing payload on an empire-based slash proposer */
|
|
139
|
+
| {
|
|
140
|
+
type: 'vote-empire-payload';
|
|
141
|
+
payload: EthAddress;
|
|
142
|
+
}
|
|
143
|
+
/** Execute a slashing payload on an empire-based slash proposer */
|
|
144
|
+
| {
|
|
145
|
+
type: 'execute-empire-payload';
|
|
146
|
+
round: bigint;
|
|
147
|
+
}
|
|
148
|
+
/** Vote for offenses on a consensus slashing proposer */
|
|
149
|
+
| {
|
|
150
|
+
type: 'vote-offenses';
|
|
151
|
+
votes: ValidatorSlashVote[];
|
|
152
|
+
committees: EthAddress[][];
|
|
153
|
+
round: bigint;
|
|
154
|
+
}
|
|
155
|
+
/** Execute a slashing round on a consensus slashing proposer */
|
|
156
|
+
| {
|
|
157
|
+
type: 'execute-slash';
|
|
158
|
+
committees: EthAddress[][];
|
|
159
|
+
round: bigint;
|
|
160
|
+
};
|
|
161
|
+
export type ProposerSlashActionType = ProposerSlashAction['type'];
|
|
162
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/slashing/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAE3D,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,KAAK,MAAM,EAAW,MAAM,qBAAqB,CAAC;AAE3D,oBAAY,WAAW;IACrB,OAAO,IAAI;IACX,uFAAuF;IACvF,gBAAgB,IAAI;IACpB,2EAA2E;IAC3E,kBAAkB,IAAI;IACtB,uFAAuF;IACvF,UAAU,IAAI;IACd,sFAAsF;IACtF,kCAAkC,IAAI;IACtC,+EAA+E;IAC/E,kCAAkC,IAAI;IACtC,uHAAuH;IACvH,+BAA+B,IAAI;IACnC,0IAA0I;IAC1I,8BAA8B,IAAI;CACnC;AAED,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,WAAW,6NAqBtD;AAED,eAAO,MAAM,iBAAiB,qCAA4B,CAAC;AAE3D,eAAO,MAAM,eAAe,EAAE,MAAM,CAAC,WAAW,EAAE,MAAM,CASvD,CAAC;AAEF,wBAAgB,eAAe,CAAC,OAAO,EAAE,MAAM,GAAG,WAAW,CAqB5D;AAED,MAAM,MAAM,OAAO,GAAG;IACpB,SAAS,EAAE,UAAU,CAAC;IACtB,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,WAAW,CAAC;IACzB,WAAW,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG,IAAI,CAAC,OAAO,EAAE,WAAW,GAAG,aAAa,GAAG,aAAa,CAAC,CAAC;AAE3F,eAAO,MAAM,aAAa;;;;;;;;;;;;;;;EAKE,CAAC;AAE7B,+DAA+D;AAC/D,MAAM,MAAM,qBAAqB,GAAG;IAClC,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,WAAW,CAAC;CAC1B,CAAC;AAEF,yFAAyF;AACzF,MAAM,MAAM,cAAc,GAAG;IAC3B,SAAS,EAAE,UAAU,CAAC;IACtB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,qBAAqB,EAAE,CAAC;CACnC,CAAC;AAEF,8DAA8D;AAC9D,MAAM,MAAM,YAAY,GAAG;IACzB,OAAO,EAAE,UAAU,CAAC;IACpB,OAAO,EAAE,cAAc,EAAE,CAAC;IAC1B,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,sEAAsE;AACtE,MAAM,MAAM,iBAAiB,GAAG,YAAY,GAAG;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,CAAC;AAEhF,eAAO,MAAM,uBAAuB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAYE,CAAC;AAEvC,kEAAkE;AAClE,MAAM,MAAM,kBAAkB,GAAG,MAAM,CAAC;AAExC,MAAM,MAAM,mBAAmB;AAC7B,mEAAmE;AACjE;IAAE,IAAI,EAAE,uBAAuB,CAAC;IAAC,IAAI,EAAE,cAAc,EAAE,CAAA;CAAE;AAC3D,oEAAoE;GAClE;IAAE,IAAI,EAAE,qBAAqB,CAAC;IAAC,OAAO,EAAE,UAAU,CAAA;CAAE;AACtD,mEAAmE;GACjE;IAAE,IAAI,EAAE,wBAAwB,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE;AACnD,yDAAyD;GACvD;IAAE,IAAI,EAAE,eAAe,CAAC;IAAC,KAAK,EAAE,kBAAkB,EAAE,CAAC;IAAC,UAAU,EAAE,UAAU,EAAE,EAAE,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE;AACnG,gEAAgE;GAC9D;IAAE,IAAI,EAAE,eAAe,CAAC;IAAC,UAAU,EAAE,UAAU,EAAE,EAAE,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,CAAC;AAEzE,MAAM,MAAM,uBAAuB,GAAG,mBAAmB,CAAC,MAAM,CAAC,CAAC"}
|