@aztec/stdlib 0.0.0-test.1 → 0.0.1-commit.023c3e5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dest/abi/abi.d.ts +988 -412
- package/dest/abi/abi.d.ts.map +1 -1
- package/dest/abi/abi.js +79 -45
- package/dest/abi/authorization_selector.d.ts +52 -0
- package/dest/abi/authorization_selector.d.ts.map +1 -0
- package/dest/abi/authorization_selector.js +71 -0
- package/dest/abi/buffer.d.ts +2 -4
- package/dest/abi/buffer.d.ts.map +1 -1
- package/dest/abi/buffer.js +1 -1
- package/dest/abi/contract_artifact.d.ts +18 -5
- package/dest/abi/contract_artifact.d.ts.map +1 -1
- package/dest/abi/contract_artifact.js +79 -56
- package/dest/abi/decoder.d.ts +3 -3
- package/dest/abi/decoder.d.ts.map +1 -1
- package/dest/abi/decoder.js +8 -10
- package/dest/abi/encoder.d.ts +2 -2
- package/dest/abi/encoder.d.ts.map +1 -1
- package/dest/abi/encoder.js +69 -3
- package/dest/abi/event_metadata_definition.d.ts +8 -0
- package/dest/abi/event_metadata_definition.d.ts.map +1 -0
- package/dest/abi/event_selector.d.ts +2 -4
- package/dest/abi/event_selector.d.ts.map +1 -1
- package/dest/abi/event_selector.js +2 -1
- package/dest/abi/function_call.d.ts +9 -4
- package/dest/abi/function_call.d.ts.map +1 -1
- package/dest/abi/function_call.js +6 -2
- package/dest/abi/function_selector.d.ts +3 -4
- package/dest/abi/function_selector.d.ts.map +1 -1
- package/dest/abi/function_selector.js +9 -1
- package/dest/abi/index.d.ts +3 -1
- package/dest/abi/index.d.ts.map +1 -1
- package/dest/abi/index.js +2 -0
- package/dest/abi/mocked_keys.d.ts +1 -1
- package/dest/abi/note_selector.d.ts +2 -4
- package/dest/abi/note_selector.d.ts.map +1 -1
- package/dest/abi/note_selector.js +2 -2
- package/dest/abi/selector.d.ts +2 -5
- package/dest/abi/selector.d.ts.map +1 -1
- package/dest/abi/selector.js +4 -2
- package/dest/abi/utils.d.ts +13 -3
- package/dest/abi/utils.d.ts.map +1 -1
- package/dest/abi/utils.js +14 -0
- package/dest/auth_witness/auth_witness.d.ts +24 -5
- package/dest/auth_witness/auth_witness.d.ts.map +1 -1
- package/dest/auth_witness/auth_witness.js +30 -1
- package/dest/auth_witness/index.d.ts +1 -1
- package/dest/avm/avm.d.ts +11630 -2931
- package/dest/avm/avm.d.ts.map +1 -1
- package/dest/avm/avm.js +947 -132
- package/dest/avm/avm_accumulated_data.d.ts +103 -29
- package/dest/avm/avm_accumulated_data.d.ts.map +1 -1
- package/dest/avm/avm_accumulated_data.js +114 -13
- package/dest/avm/avm_circuit_public_inputs.d.ts +273 -201
- package/dest/avm/avm_circuit_public_inputs.d.ts.map +1 -1
- package/dest/avm/avm_circuit_public_inputs.js +73 -11
- package/dest/avm/avm_proving_request.d.ts +4597 -1115
- package/dest/avm/avm_proving_request.d.ts.map +1 -1
- package/dest/avm/contract_storage_read.d.ts +3 -5
- package/dest/avm/contract_storage_read.d.ts.map +1 -1
- package/dest/avm/contract_storage_read.js +1 -1
- package/dest/avm/contract_storage_update_request.d.ts +3 -5
- package/dest/avm/contract_storage_update_request.d.ts.map +1 -1
- package/dest/avm/contract_storage_update_request.js +1 -1
- package/dest/avm/index.d.ts +2 -2
- package/dest/avm/index.d.ts.map +1 -1
- package/dest/avm/index.js +1 -1
- package/dest/avm/message_pack.d.ts +2 -3
- package/dest/avm/message_pack.d.ts.map +1 -1
- package/dest/avm/message_pack.js +41 -7
- package/dest/avm/public_call_stack_item_compressed.d.ts +3 -5
- package/dest/avm/public_call_stack_item_compressed.d.ts.map +1 -1
- package/dest/avm/public_call_stack_item_compressed.js +1 -1
- package/dest/avm/public_data_read.d.ts +3 -5
- package/dest/avm/public_data_read.d.ts.map +1 -1
- package/dest/avm/public_data_read.js +1 -1
- package/dest/avm/public_data_update_request.d.ts +3 -6
- package/dest/avm/public_data_update_request.d.ts.map +1 -1
- package/dest/avm/public_data_update_request.js +4 -2
- package/dest/avm/public_data_write.d.ts +18 -8
- package/dest/avm/public_data_write.d.ts.map +1 -1
- package/dest/avm/public_data_write.js +32 -2
- package/dest/avm/public_inner_call_request.d.ts +3 -6
- package/dest/avm/public_inner_call_request.d.ts.map +1 -1
- package/dest/avm/public_inner_call_request.js +4 -2
- package/dest/avm/revert_code.d.ts +14 -8
- package/dest/avm/revert_code.d.ts.map +1 -1
- package/dest/avm/revert_code.js +28 -10
- package/dest/aztec-address/index.d.ts +13 -6
- package/dest/aztec-address/index.d.ts.map +1 -1
- package/dest/aztec-address/index.js +29 -4
- package/dest/block/attestation_info.d.ts +32 -0
- package/dest/block/attestation_info.d.ts.map +1 -0
- package/dest/block/attestation_info.js +42 -0
- package/dest/block/block_hash.d.ts +19 -13
- package/dest/block/block_hash.d.ts.map +1 -1
- package/dest/block/block_hash.js +26 -13
- package/dest/block/block_parameter.d.ts +6 -0
- package/dest/block/block_parameter.d.ts.map +1 -0
- package/dest/block/block_parameter.js +8 -0
- package/dest/block/body.d.ts +10 -9
- package/dest/block/body.d.ts.map +1 -1
- package/dest/block/body.js +18 -32
- package/dest/block/checkpointed_l2_block.d.ts +150 -0
- package/dest/block/checkpointed_l2_block.d.ts.map +1 -0
- package/dest/block/checkpointed_l2_block.js +46 -0
- package/dest/block/in_block.d.ts +36 -24
- package/dest/block/in_block.d.ts.map +1 -1
- package/dest/block/in_block.js +21 -12
- package/dest/block/index.d.ts +8 -4
- package/dest/block/index.d.ts.map +1 -1
- package/dest/block/index.js +7 -3
- package/dest/block/l2_block.d.ts +56 -47
- package/dest/block/l2_block.d.ts.map +1 -1
- package/dest/block/l2_block.js +92 -77
- package/dest/block/l2_block_info.d.ts +46 -0
- package/dest/block/l2_block_info.d.ts.map +1 -0
- package/dest/block/l2_block_info.js +41 -0
- package/dest/block/l2_block_source.d.ts +424 -134
- package/dest/block/l2_block_source.d.ts.map +1 -1
- package/dest/block/l2_block_source.js +39 -15
- package/dest/block/l2_block_stream/index.d.ts +5 -0
- package/dest/block/l2_block_stream/index.d.ts.map +1 -0
- package/dest/block/l2_block_stream/index.js +4 -0
- package/dest/block/l2_block_stream/interfaces.d.ts +36 -0
- package/dest/block/l2_block_stream/interfaces.d.ts.map +1 -0
- package/dest/block/l2_block_stream/interfaces.js +1 -0
- package/dest/block/l2_block_stream/l2_block_stream.d.ts +40 -0
- package/dest/block/l2_block_stream/l2_block_stream.d.ts.map +1 -0
- package/dest/block/l2_block_stream/l2_block_stream.js +272 -0
- package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts +27 -0
- package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts.map +1 -0
- package/dest/block/l2_block_stream/l2_tips_memory_store.js +66 -0
- package/dest/block/l2_block_stream/l2_tips_store_base.d.ts +49 -0
- package/dest/block/l2_block_stream/l2_tips_store_base.d.ts.map +1 -0
- package/dest/block/l2_block_stream/l2_tips_store_base.js +179 -0
- package/dest/block/proposal/attestations_and_signers.d.ts +59 -0
- package/dest/block/proposal/attestations_and_signers.d.ts.map +1 -0
- package/dest/block/proposal/attestations_and_signers.js +113 -0
- package/dest/block/proposal/committee_attestation.d.ts +36 -0
- package/dest/block/proposal/committee_attestation.d.ts.map +1 -0
- package/dest/block/proposal/committee_attestation.js +101 -0
- package/dest/block/proposal/index.d.ts +3 -0
- package/dest/block/proposal/index.d.ts.map +1 -0
- package/dest/block/proposal/index.js +2 -0
- package/dest/block/test/index.d.ts +2 -0
- package/dest/block/test/index.d.ts.map +1 -0
- package/dest/block/test/index.js +1 -0
- package/dest/block/test/l2_tips_store_test_suite.d.ts +3 -0
- package/dest/block/test/l2_tips_store_test_suite.d.ts.map +1 -0
- package/dest/block/test/l2_tips_store_test_suite.js +545 -0
- package/dest/block/validate_block_result.d.ts +50 -0
- package/dest/block/validate_block_result.d.ts.map +1 -0
- package/dest/block/validate_block_result.js +85 -0
- package/dest/checkpoint/checkpoint.d.ts +163 -0
- package/dest/checkpoint/checkpoint.d.ts.map +1 -0
- package/dest/checkpoint/checkpoint.js +113 -0
- package/dest/checkpoint/checkpoint_info.d.ts +38 -0
- package/dest/checkpoint/checkpoint_info.d.ts.map +1 -0
- package/dest/checkpoint/checkpoint_info.js +34 -0
- package/dest/checkpoint/index.d.ts +4 -0
- package/dest/checkpoint/index.d.ts.map +1 -0
- package/dest/checkpoint/index.js +3 -0
- package/dest/checkpoint/published_checkpoint.d.ts +240 -0
- package/dest/checkpoint/published_checkpoint.d.ts.map +1 -0
- package/dest/checkpoint/published_checkpoint.js +82 -0
- package/dest/config/chain-config.d.ts +19 -0
- package/dest/config/chain-config.d.ts.map +1 -0
- package/dest/config/{config.js → chain-config.js} +4 -5
- package/dest/config/index.d.ts +3 -2
- package/dest/config/index.d.ts.map +1 -1
- package/dest/config/index.js +2 -1
- package/dest/config/node-rpc-config.d.ts +13 -0
- package/dest/config/node-rpc-config.d.ts.map +1 -0
- package/dest/config/node-rpc-config.js +24 -0
- package/dest/contract/artifact_hash.d.ts +8 -10
- package/dest/contract/artifact_hash.d.ts.map +1 -1
- package/dest/contract/artifact_hash.js +13 -12
- package/dest/contract/complete_address.d.ts +2 -4
- package/dest/contract/complete_address.d.ts.map +1 -1
- package/dest/contract/complete_address.js +1 -1
- package/dest/contract/contract_address.d.ts +3 -3
- package/dest/contract/contract_address.d.ts.map +1 -1
- package/dest/contract/contract_address.js +4 -4
- package/dest/contract/contract_class.d.ts +2 -2
- package/dest/contract/contract_class.d.ts.map +1 -1
- package/dest/contract/contract_class.js +4 -20
- package/dest/contract/contract_class_id.d.ts +3 -5
- package/dest/contract/contract_class_id.d.ts.map +1 -1
- package/dest/contract/contract_class_id.js +9 -7
- package/dest/contract/contract_deployment_data.d.ts +119 -0
- package/dest/contract/contract_deployment_data.d.ts.map +1 -0
- package/dest/contract/contract_deployment_data.js +99 -0
- package/dest/contract/contract_function_dao.d.ts +1 -1
- package/dest/contract/contract_instance.d.ts +15 -16
- package/dest/contract/contract_instance.d.ts.map +1 -1
- package/dest/contract/contract_instance.js +8 -8
- package/dest/contract/contract_instance_update.d.ts +5 -6
- package/dest/contract/contract_instance_update.d.ts.map +1 -1
- package/dest/contract/contract_instance_update.js +7 -7
- package/dest/contract/deployment_info.d.ts +2 -2
- package/dest/contract/deployment_info.d.ts.map +1 -1
- package/dest/contract/index.d.ts +3 -2
- package/dest/contract/index.d.ts.map +1 -1
- package/dest/contract/index.js +2 -1
- package/dest/contract/interfaces/contract_class.d.ts +81 -297
- package/dest/contract/interfaces/contract_class.d.ts.map +1 -1
- package/dest/contract/interfaces/contract_class.js +36 -24
- package/dest/contract/interfaces/contract_data_source.d.ts +14 -21
- package/dest/contract/interfaces/contract_data_source.d.ts.map +1 -1
- package/dest/contract/interfaces/contract_instance.d.ts +50 -41
- package/dest/contract/interfaces/contract_instance.d.ts.map +1 -1
- package/dest/contract/interfaces/contract_instance.js +30 -5
- package/dest/contract/interfaces/contract_instance_update.d.ts +16 -16
- package/dest/contract/interfaces/contract_instance_update.d.ts.map +1 -1
- package/dest/contract/interfaces/contract_instance_update.js +6 -6
- package/dest/contract/interfaces/index.d.ts +1 -1
- package/dest/contract/interfaces/node-info.d.ts +3 -3
- package/dest/contract/interfaces/node-info.d.ts.map +1 -1
- package/dest/contract/interfaces/node-info.js +1 -1
- package/dest/contract/interfaces/protocol_contract_addresses.d.ts +10 -10
- package/dest/contract/interfaces/protocol_contract_addresses.d.ts.map +1 -1
- package/dest/contract/interfaces/protocol_contract_addresses.js +4 -4
- package/dest/contract/partial_address.d.ts +2 -2
- package/dest/contract/partial_address.d.ts.map +1 -1
- package/dest/contract/private_function.d.ts +2 -4
- package/dest/contract/private_function.d.ts.map +1 -1
- package/dest/contract/private_function.js +4 -4
- package/dest/contract/private_function_membership_proof.d.ts +5 -5
- package/dest/contract/private_function_membership_proof.js +11 -11
- package/dest/contract/utility_function_membership_proof.d.ts +27 -0
- package/dest/contract/utility_function_membership_proof.d.ts.map +1 -0
- package/dest/contract/{unconstrained_function_membership_proof.js → utility_function_membership_proof.js} +14 -14
- package/dest/database-version/database_version.d.ts +58 -0
- package/dest/database-version/database_version.d.ts.map +1 -0
- package/dest/database-version/database_version.js +69 -0
- package/dest/database-version/version_manager.d.ts +20 -49
- package/dest/database-version/version_manager.d.ts.map +1 -1
- package/dest/database-version/version_manager.js +33 -75
- package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts +20 -0
- package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts.map +1 -0
- package/dest/{shared_mutable/shared_mutable_values.js → delayed_public_mutable/delayed_public_mutable_values.js} +20 -23
- package/dest/delayed_public_mutable/delayed_public_mutable_values_with_hash.d.ts +15 -0
- package/dest/delayed_public_mutable/delayed_public_mutable_values_with_hash.d.ts.map +1 -0
- package/dest/delayed_public_mutable/delayed_public_mutable_values_with_hash.js +30 -0
- package/dest/delayed_public_mutable/index.d.ts +5 -0
- package/dest/delayed_public_mutable/index.d.ts.map +1 -0
- package/dest/delayed_public_mutable/index.js +4 -0
- package/dest/delayed_public_mutable/scheduled_delay_change.d.ts +10 -0
- package/dest/delayed_public_mutable/scheduled_delay_change.d.ts.map +1 -0
- package/dest/{shared_mutable → delayed_public_mutable}/scheduled_delay_change.js +5 -5
- package/dest/delayed_public_mutable/scheduled_value_change.d.ts +12 -0
- package/dest/delayed_public_mutable/scheduled_value_change.d.ts.map +1 -0
- package/dest/{shared_mutable → delayed_public_mutable}/scheduled_value_change.js +8 -8
- package/dest/deserialization/index.d.ts +11 -0
- package/dest/deserialization/index.d.ts.map +1 -0
- package/dest/deserialization/index.js +10 -0
- package/dest/epoch-helpers/index.d.ts +31 -6
- package/dest/epoch-helpers/index.d.ts.map +1 -1
- package/dest/epoch-helpers/index.js +46 -11
- package/dest/errors/index.d.ts +1 -1
- package/dest/errors/proving_error.d.ts +1 -1
- package/dest/errors/proving_error.d.ts.map +1 -1
- package/dest/errors/simulation_error.d.ts +2 -2
- package/dest/errors/simulation_error.d.ts.map +1 -1
- package/dest/errors/simulation_error.js +2 -2
- package/dest/fees/index.d.ts +1 -1
- package/dest/fees/transaction_fee.d.ts +7 -2
- package/dest/fees/transaction_fee.d.ts.map +1 -1
- package/dest/fees/transaction_fee.js +15 -5
- package/dest/file-store/factory.d.ts +7 -0
- package/dest/file-store/factory.d.ts.map +1 -0
- package/dest/file-store/factory.js +64 -0
- package/dest/file-store/gcs.d.ts +20 -0
- package/dest/file-store/gcs.d.ts.map +1 -0
- package/dest/file-store/gcs.js +115 -0
- package/dest/file-store/http.d.ts +14 -0
- package/dest/file-store/http.d.ts.map +1 -0
- package/dest/file-store/http.js +74 -0
- package/dest/file-store/index.d.ts +3 -0
- package/dest/file-store/index.d.ts.map +1 -0
- package/dest/file-store/index.js +2 -0
- package/dest/file-store/interface.d.ts +28 -0
- package/dest/file-store/interface.d.ts.map +1 -0
- package/dest/file-store/interface.js +1 -0
- package/dest/file-store/local.d.ts +14 -0
- package/dest/file-store/local.d.ts.map +1 -0
- package/dest/file-store/local.js +40 -0
- package/dest/file-store/s3.d.ts +26 -0
- package/dest/file-store/s3.d.ts.map +1 -0
- package/dest/file-store/s3.js +248 -0
- package/dest/gas/gas.d.ts +12 -6
- package/dest/gas/gas.d.ts.map +1 -1
- package/dest/gas/gas.js +20 -3
- package/dest/gas/gas_fees.d.ts +26 -20
- package/dest/gas/gas_fees.d.ts.map +1 -1
- package/dest/gas/gas_fees.js +32 -19
- package/dest/gas/gas_settings.d.ts +35 -29
- package/dest/gas/gas_settings.d.ts.map +1 -1
- package/dest/gas/gas_settings.js +19 -7
- package/dest/gas/gas_used.d.ts +13 -2
- package/dest/gas/gas_used.d.ts.map +1 -1
- package/dest/gas/gas_used.js +19 -1
- package/dest/gas/index.d.ts +1 -1
- package/dest/hash/hash.d.ts +30 -10
- package/dest/hash/hash.d.ts.map +1 -1
- package/dest/hash/hash.js +39 -28
- package/dest/hash/index.d.ts +1 -1
- package/dest/hash/map_slot.d.ts +2 -2
- package/dest/hash/map_slot.d.ts.map +1 -1
- package/dest/hash/map_slot.js +4 -3
- package/dest/interfaces/allowed_element.d.ts +52 -0
- package/dest/interfaces/allowed_element.d.ts.map +1 -0
- package/dest/interfaces/allowed_element.js +18 -0
- package/dest/interfaces/api_limit.d.ts +6 -0
- package/dest/interfaces/api_limit.d.ts.map +1 -0
- package/dest/interfaces/api_limit.js +5 -0
- package/dest/interfaces/archiver.d.ts +55 -3
- package/dest/interfaces/archiver.d.ts.map +1 -1
- package/dest/interfaces/archiver.js +59 -25
- package/dest/interfaces/aztec-node-admin.d.ts +351 -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 +153 -143
- package/dest/interfaces/aztec-node.d.ts.map +1 -1
- package/dest/interfaces/aztec-node.js +54 -44
- package/dest/interfaces/block-builder.d.ts +53 -7
- package/dest/interfaces/block-builder.d.ts.map +1 -1
- package/dest/interfaces/block-builder.js +16 -1
- package/dest/interfaces/client.d.ts +3 -2
- package/dest/interfaces/client.d.ts.map +1 -1
- package/dest/interfaces/client.js +2 -1
- package/dest/interfaces/configs.d.ts +124 -60
- package/dest/interfaces/configs.d.ts.map +1 -1
- package/dest/interfaces/configs.js +24 -23
- package/dest/interfaces/epoch-prover.d.ts +36 -17
- package/dest/interfaces/epoch-prover.d.ts.map +1 -1
- package/dest/interfaces/get_logs_response.d.ts +23 -6
- package/dest/interfaces/get_logs_response.d.ts.map +1 -1
- package/dest/interfaces/get_logs_response.js +5 -4
- package/dest/interfaces/l2_logs_source.d.ts +21 -14
- package/dest/interfaces/l2_logs_source.d.ts.map +1 -1
- package/dest/interfaces/merkle_tree_operations.d.ts +31 -14
- package/dest/interfaces/merkle_tree_operations.d.ts.map +1 -1
- package/dest/interfaces/p2p-bootstrap.d.ts +1 -1
- package/dest/interfaces/p2p.d.ts +19 -8
- package/dest/interfaces/p2p.d.ts.map +1 -1
- package/dest/interfaces/p2p.js +6 -3
- package/dest/interfaces/private_kernel_prover.d.ts +6 -7
- package/dest/interfaces/private_kernel_prover.d.ts.map +1 -1
- package/dest/interfaces/processed-tx-handler.d.ts +1 -1
- package/dest/interfaces/prover-agent.d.ts +32 -7
- package/dest/interfaces/prover-agent.d.ts.map +1 -1
- package/dest/interfaces/prover-agent.js +15 -6
- package/dest/interfaces/prover-broker.d.ts +1 -1
- package/dest/interfaces/prover-client.d.ts +21 -10
- package/dest/interfaces/prover-client.d.ts.map +1 -1
- package/dest/interfaces/prover-client.js +19 -10
- package/dest/interfaces/prover-coordination.d.ts +5 -10
- package/dest/interfaces/prover-coordination.d.ts.map +1 -1
- package/dest/interfaces/prover-coordination.js +1 -7
- package/dest/interfaces/prover-node.d.ts +6 -3
- package/dest/interfaces/prover-node.d.ts.map +1 -1
- package/dest/interfaces/prover-node.js +8 -3
- package/dest/interfaces/proving-job-source.d.ts +1 -1
- package/dest/interfaces/proving-job.d.ts +4875 -1278
- package/dest/interfaces/proving-job.d.ts.map +1 -1
- package/dest/interfaces/proving-job.js +139 -113
- package/dest/interfaces/public_state_source.d.ts +8 -0
- package/dest/interfaces/public_state_source.d.ts.map +1 -0
- package/dest/interfaces/public_state_source.js +1 -0
- package/dest/interfaces/server.d.ts +12 -6
- package/dest/interfaces/server.d.ts.map +1 -1
- package/dest/interfaces/server.js +11 -5
- package/dest/interfaces/server_circuit_prover.d.ts +48 -36
- package/dest/interfaces/server_circuit_prover.d.ts.map +1 -1
- package/dest/interfaces/service.d.ts +4 -3
- package/dest/interfaces/service.d.ts.map +1 -1
- package/dest/interfaces/slasher.d.ts +86 -0
- package/dest/interfaces/slasher.d.ts.map +1 -0
- package/dest/interfaces/slasher.js +23 -0
- package/dest/interfaces/tx_provider.d.ts +24 -0
- package/dest/interfaces/tx_provider.d.ts.map +1 -0
- package/dest/interfaces/tx_provider.js +1 -0
- package/dest/interfaces/validator.d.ts +260 -0
- package/dest/interfaces/validator.d.ts.map +1 -0
- package/dest/interfaces/validator.js +21 -0
- package/dest/interfaces/world_state.d.ts +38 -44
- package/dest/interfaces/world_state.d.ts.map +1 -1
- package/dest/interfaces/world_state.js +4 -3
- package/dest/kernel/claimed_length_array.d.ts +34 -0
- package/dest/kernel/claimed_length_array.d.ts.map +1 -0
- package/dest/kernel/claimed_length_array.js +60 -0
- package/dest/kernel/hiding_kernel_private_inputs.d.ts +19 -0
- package/dest/kernel/hiding_kernel_private_inputs.d.ts.map +1 -0
- package/dest/kernel/hiding_kernel_private_inputs.js +34 -0
- package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts +10 -9
- package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts.map +1 -1
- package/dest/kernel/hints/build_note_hash_read_request_hints.js +34 -27
- package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts +12 -14
- package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts.map +1 -1
- package/dest/kernel/hints/build_nullifier_read_request_hints.js +30 -37
- package/dest/kernel/hints/build_transient_data_hints.d.ts +5 -4
- package/dest/kernel/hints/build_transient_data_hints.d.ts.map +1 -1
- package/dest/kernel/hints/build_transient_data_hints.js +10 -11
- package/dest/kernel/hints/find_private_kernel_reset_dimensions.d.ts +1 -1
- package/dest/kernel/hints/find_private_kernel_reset_dimensions.d.ts.map +1 -1
- package/dest/kernel/hints/find_private_kernel_reset_dimensions.js +2 -4
- package/dest/kernel/hints/index.d.ts +2 -3
- package/dest/kernel/hints/index.d.ts.map +1 -1
- package/dest/kernel/hints/index.js +1 -2
- package/dest/kernel/hints/key_validation_hint.d.ts +5 -11
- package/dest/kernel/hints/key_validation_hint.d.ts.map +1 -1
- package/dest/kernel/hints/key_validation_hint.js +6 -8
- package/dest/kernel/hints/key_validation_request.d.ts +5 -6
- package/dest/kernel/hints/key_validation_request.d.ts.map +1 -1
- package/dest/kernel/hints/key_validation_request.js +2 -1
- package/dest/kernel/hints/key_validation_request_and_generator.d.ts +3 -5
- package/dest/kernel/hints/key_validation_request_and_generator.d.ts.map +1 -1
- package/dest/kernel/hints/key_validation_request_and_generator.js +1 -1
- package/dest/kernel/hints/note_hash_read_request_hints.d.ts +2 -4
- package/dest/kernel/hints/note_hash_read_request_hints.d.ts.map +1 -1
- package/dest/kernel/hints/note_hash_read_request_hints.js +5 -5
- package/dest/kernel/hints/nullifier_read_request_hints.d.ts +5 -6
- package/dest/kernel/hints/nullifier_read_request_hints.d.ts.map +1 -1
- package/dest/kernel/hints/nullifier_read_request_hints.js +4 -4
- package/dest/kernel/hints/private_kernel_reset_hints.d.ts +10 -22
- package/dest/kernel/hints/private_kernel_reset_hints.d.ts.map +1 -1
- package/dest/kernel/hints/private_kernel_reset_hints.js +13 -14
- package/dest/kernel/hints/read_request.d.ts +2 -4
- package/dest/kernel/hints/read_request.d.ts.map +1 -1
- package/dest/kernel/hints/read_request.js +1 -1
- package/dest/kernel/hints/read_request_hints.d.ts +30 -32
- package/dest/kernel/hints/read_request_hints.d.ts.map +1 -1
- package/dest/kernel/hints/read_request_hints.js +28 -28
- package/dest/kernel/hints/scoped_key_validation_request_and_generator.d.ts +3 -5
- package/dest/kernel/hints/scoped_key_validation_request_and_generator.d.ts.map +1 -1
- package/dest/kernel/hints/scoped_value_cache.d.ts +2 -2
- package/dest/kernel/hints/scoped_value_cache.d.ts.map +1 -1
- package/dest/kernel/hints/transient_data_squashing_hint.d.ts +17 -0
- package/dest/kernel/hints/transient_data_squashing_hint.d.ts.map +1 -0
- package/dest/kernel/hints/{transient_data_index_hint.js → transient_data_squashing_hint.js} +9 -7
- package/dest/kernel/hints/tree_leaf_read_request.d.ts +2 -4
- package/dest/kernel/hints/tree_leaf_read_request.d.ts.map +1 -1
- package/dest/kernel/hints/tree_leaf_read_request.js +1 -1
- package/dest/kernel/index.d.ts +5 -3
- package/dest/kernel/index.d.ts.map +1 -1
- package/dest/kernel/index.js +4 -2
- package/dest/kernel/log_hash.d.ts +29 -11
- package/dest/kernel/log_hash.d.ts.map +1 -1
- package/dest/kernel/log_hash.js +76 -15
- package/dest/kernel/note_hash.d.ts +2 -4
- package/dest/kernel/note_hash.d.ts.map +1 -1
- package/dest/kernel/note_hash.js +1 -1
- package/dest/kernel/nullifier.d.ts +4 -6
- package/dest/kernel/nullifier.d.ts.map +1 -1
- package/dest/kernel/nullifier.js +12 -12
- package/dest/kernel/padded_side_effects.d.ts +26 -0
- package/dest/kernel/padded_side_effects.d.ts.map +1 -0
- package/dest/kernel/padded_side_effects.js +51 -0
- package/dest/kernel/private_accumulated_data.d.ts +20 -21
- package/dest/kernel/private_accumulated_data.d.ts.map +1 -1
- package/dest/kernel/private_accumulated_data.js +5 -5
- package/dest/kernel/private_call_data.d.ts +10 -32
- package/dest/kernel/private_call_data.d.ts.map +1 -1
- package/dest/kernel/private_call_data.js +7 -19
- package/dest/kernel/private_call_request.d.ts +3 -5
- package/dest/kernel/private_call_request.d.ts.map +1 -1
- package/dest/kernel/private_call_request.js +2 -2
- package/dest/kernel/private_circuit_public_inputs.d.ts +98 -83
- package/dest/kernel/private_circuit_public_inputs.d.ts.map +1 -1
- package/dest/kernel/private_circuit_public_inputs.js +90 -60
- package/dest/kernel/private_context_inputs.d.ts +4 -4
- package/dest/kernel/private_context_inputs.d.ts.map +1 -1
- package/dest/kernel/private_context_inputs.js +4 -4
- package/dest/kernel/private_kernel_circuit_public_inputs.d.ts +25 -10
- package/dest/kernel/private_kernel_circuit_public_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_circuit_public_inputs.js +15 -7
- package/dest/kernel/private_kernel_data.d.ts +8 -29
- package/dest/kernel/private_kernel_data.d.ts.map +1 -1
- package/dest/kernel/private_kernel_data.js +8 -21
- package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts +17 -10
- package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_init_circuit_private_inputs.js +13 -8
- package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts +2 -4
- package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_prover_output.d.ts +79 -0
- package/dest/kernel/private_kernel_prover_output.d.ts.map +1 -0
- package/dest/kernel/private_kernel_prover_output.js +28 -0
- package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts +10 -9
- package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_reset_circuit_private_inputs.js +10 -6
- package/dest/kernel/private_kernel_reset_dimensions.d.ts +12 -14
- package/dest/kernel/private_kernel_reset_dimensions.d.ts.map +1 -1
- package/dest/kernel/private_kernel_reset_dimensions.js +29 -29
- package/dest/kernel/private_kernel_simulated_output.d.ts +7 -13
- package/dest/kernel/private_kernel_simulated_output.d.ts.map +1 -1
- package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts +21 -5
- package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_tail_circuit_private_inputs.js +14 -6
- package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts +22 -14
- package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_tail_circuit_public_inputs.js +29 -22
- package/dest/kernel/private_log_data.d.ts +3 -6
- package/dest/kernel/private_log_data.d.ts.map +1 -1
- package/dest/kernel/private_log_data.js +9 -4
- package/dest/kernel/private_to_avm_accumulated_data.d.ts +24 -17
- package/dest/kernel/private_to_avm_accumulated_data.d.ts.map +1 -1
- package/dest/kernel/private_to_avm_accumulated_data.js +35 -3
- package/dest/kernel/private_to_public_accumulated_data.d.ts +4 -7
- package/dest/kernel/private_to_public_accumulated_data.d.ts.map +1 -1
- package/dest/kernel/private_to_public_accumulated_data.js +4 -2
- package/dest/kernel/private_to_public_accumulated_data_builder.d.ts +2 -2
- package/dest/kernel/private_to_public_accumulated_data_builder.d.ts.map +1 -1
- package/dest/kernel/private_to_public_accumulated_data_builder.js +1 -1
- package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts +9 -9
- package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts.map +1 -1
- package/dest/kernel/private_to_public_kernel_circuit_public_inputs.js +17 -11
- package/dest/kernel/private_to_rollup_accumulated_data.d.ts +5 -8
- package/dest/kernel/private_to_rollup_accumulated_data.d.ts.map +1 -1
- package/dest/kernel/private_to_rollup_accumulated_data.js +4 -2
- package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts +15 -17
- package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts.map +1 -1
- package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.js +12 -13
- package/dest/kernel/private_validation_requests.d.ts +10 -38
- package/dest/kernel/private_validation_requests.d.ts.map +1 -1
- package/dest/kernel/private_validation_requests.js +13 -31
- package/dest/kernel/public_call_request.d.ts +93 -31
- package/dest/kernel/public_call_request.d.ts.map +1 -1
- package/dest/kernel/public_call_request.js +100 -22
- package/dest/kernel/utils/index.d.ts +1 -1
- package/dest/kernel/utils/interfaces.d.ts +1 -1
- package/dest/kernel/utils/optional_number.d.ts +3 -5
- package/dest/kernel/utils/optional_number.d.ts.map +1 -1
- package/dest/kernel/utils/order_and_comparison.d.ts +1 -4
- package/dest/kernel/utils/order_and_comparison.d.ts.map +1 -1
- package/dest/kernel/utils/order_and_comparison.js +0 -19
- package/dest/keys/derivation.d.ts +7 -8
- package/dest/keys/derivation.d.ts.map +1 -1
- package/dest/keys/derivation.js +15 -25
- package/dest/keys/index.d.ts +1 -1
- package/dest/keys/key_types.d.ts +2 -2
- package/dest/keys/public_key.d.ts +2 -2
- package/dest/keys/public_key.d.ts.map +1 -1
- package/dest/keys/public_keys.d.ts +11 -4
- package/dest/keys/public_keys.d.ts.map +1 -1
- package/dest/keys/public_keys.js +15 -3
- package/dest/keys/utils.d.ts +1 -1
- package/dest/keys/utils.d.ts.map +1 -1
- package/dest/keys/utils.js +7 -3
- package/dest/l1-contracts/index.d.ts +2 -0
- package/dest/l1-contracts/index.d.ts.map +1 -0
- package/dest/l1-contracts/index.js +1 -0
- package/dest/l1-contracts/slash_factory.d.ts +45 -0
- package/dest/l1-contracts/slash_factory.d.ts.map +1 -0
- package/dest/l1-contracts/slash_factory.js +158 -0
- package/dest/logs/contract_class_log.d.ts +72 -18
- package/dest/logs/contract_class_log.d.ts.map +1 -1
- package/dest/logs/contract_class_log.js +139 -82
- package/dest/logs/debug_log.d.ts +21 -0
- package/dest/logs/debug_log.d.ts.map +1 -0
- package/dest/logs/debug_log.js +39 -0
- package/dest/logs/directional_app_tagging_secret.d.ts +40 -0
- package/dest/logs/directional_app_tagging_secret.d.ts.map +1 -0
- package/dest/logs/directional_app_tagging_secret.js +64 -0
- package/dest/logs/extended_contract_class_log.d.ts +1 -3
- package/dest/logs/extended_contract_class_log.d.ts.map +1 -1
- package/dest/logs/extended_public_log.d.ts +11 -5
- package/dest/logs/extended_public_log.d.ts.map +1 -1
- package/dest/logs/index.d.ts +9 -4
- package/dest/logs/index.d.ts.map +1 -1
- package/dest/logs/index.js +8 -3
- package/dest/logs/log_filter.d.ts +1 -1
- package/dest/logs/log_id.d.ts +17 -7
- package/dest/logs/log_id.d.ts.map +1 -1
- package/dest/logs/log_id.js +20 -11
- package/dest/logs/message_context.d.ts +29 -0
- package/dest/logs/message_context.d.ts.map +1 -0
- package/dest/logs/message_context.js +56 -0
- package/dest/logs/pending_tagged_log.d.ts +14 -0
- package/dest/logs/pending_tagged_log.d.ts.map +1 -0
- package/dest/logs/pending_tagged_log.js +34 -0
- package/dest/logs/pre_tag.d.ts +34 -0
- package/dest/logs/pre_tag.d.ts.map +1 -0
- package/dest/logs/pre_tag.js +7 -0
- package/dest/logs/private_log.d.ts +26 -10
- package/dest/logs/private_log.d.ts.map +1 -1
- package/dest/logs/private_log.js +65 -25
- package/dest/logs/public_log.d.ts +37 -14
- package/dest/logs/public_log.d.ts.map +1 -1
- package/dest/logs/public_log.js +144 -36
- package/dest/logs/shared_secret_derivation.d.ts +17 -0
- package/dest/logs/shared_secret_derivation.d.ts.map +1 -0
- package/dest/logs/{l1_payload/shared_secret_derivation.js → shared_secret_derivation.js} +6 -10
- package/dest/logs/siloed_tag.d.ts +23 -0
- package/dest/logs/siloed_tag.d.ts.map +1 -0
- package/dest/logs/siloed_tag.js +31 -0
- package/dest/logs/tag.d.ts +21 -0
- package/dest/logs/tag.d.ts.map +1 -0
- package/dest/logs/tag.js +30 -0
- package/dest/logs/tx_scoped_l2_log.d.ts +34 -45
- package/dest/logs/tx_scoped_l2_log.d.ts.map +1 -1
- package/dest/logs/tx_scoped_l2_log.js +38 -26
- package/dest/messaging/in_hash.d.ts +6 -0
- package/dest/messaging/in_hash.d.ts.map +1 -0
- package/dest/messaging/in_hash.js +10 -0
- package/dest/messaging/inbox_leaf.d.ts +11 -5
- package/dest/messaging/inbox_leaf.d.ts.map +1 -1
- package/dest/messaging/inbox_leaf.js +19 -4
- package/dest/messaging/index.d.ts +4 -1
- package/dest/messaging/index.d.ts.map +1 -1
- package/dest/messaging/index.js +3 -0
- package/dest/messaging/l1_actor.d.ts +2 -4
- package/dest/messaging/l1_actor.d.ts.map +1 -1
- package/dest/messaging/l1_actor.js +2 -2
- package/dest/messaging/l1_to_l2_message.d.ts +2 -4
- package/dest/messaging/l1_to_l2_message.d.ts.map +1 -1
- package/dest/messaging/l1_to_l2_message.js +2 -2
- package/dest/messaging/l1_to_l2_message_source.d.ts +9 -8
- package/dest/messaging/l1_to_l2_message_source.d.ts.map +1 -1
- package/dest/messaging/l2_actor.d.ts +2 -4
- package/dest/messaging/l2_actor.d.ts.map +1 -1
- package/dest/messaging/l2_actor.js +2 -2
- package/dest/messaging/l2_to_l1_membership.d.ts +97 -0
- package/dest/messaging/l2_to_l1_membership.d.ts.map +1 -0
- package/dest/messaging/l2_to_l1_membership.js +181 -0
- package/dest/messaging/l2_to_l1_message.d.ts +128 -19
- package/dest/messaging/l2_to_l1_message.d.ts.map +1 -1
- package/dest/messaging/l2_to_l1_message.js +102 -35
- package/dest/messaging/out_hash.d.ts +43 -0
- package/dest/messaging/out_hash.d.ts.map +1 -0
- package/dest/messaging/out_hash.js +63 -0
- package/dest/noir/index.d.ts +25 -8
- package/dest/noir/index.d.ts.map +1 -1
- package/dest/noir/index.js +6 -5
- package/dest/note/comparator.d.ts +1 -1
- package/dest/note/index.d.ts +2 -2
- package/dest/note/index.d.ts.map +1 -1
- package/dest/note/index.js +1 -1
- package/dest/note/note.d.ts +39 -21
- package/dest/note/note.d.ts.map +1 -1
- package/dest/note/note.js +55 -5
- package/dest/note/note_dao.d.ts +110 -0
- package/dest/note/note_dao.d.ts.map +1 -0
- package/dest/note/note_dao.js +115 -0
- package/dest/note/note_status.d.ts +1 -1
- package/dest/note/notes_filter.d.ts +9 -9
- package/dest/note/notes_filter.d.ts.map +1 -1
- package/dest/note/notes_filter.js +2 -4
- package/dest/p2p/attestation_utils.d.ts +10 -0
- package/dest/p2p/attestation_utils.d.ts.map +1 -0
- package/dest/p2p/attestation_utils.js +21 -0
- package/dest/p2p/block_proposal.d.ts +117 -25
- package/dest/p2p/block_proposal.d.ts.map +1 -1
- package/dest/p2p/block_proposal.js +160 -31
- package/dest/p2p/checkpoint_attestation.d.ts +81 -0
- package/dest/p2p/checkpoint_attestation.d.ts.map +1 -0
- package/dest/p2p/checkpoint_attestation.js +104 -0
- package/dest/p2p/checkpoint_proposal.d.ts +167 -0
- package/dest/p2p/checkpoint_proposal.d.ts.map +1 -0
- package/dest/p2p/checkpoint_proposal.js +229 -0
- package/dest/p2p/client_type.d.ts +1 -1
- package/dest/p2p/consensus_payload.d.ts +42 -24
- package/dest/p2p/consensus_payload.d.ts.map +1 -1
- package/dest/p2p/consensus_payload.js +43 -30
- package/dest/p2p/constants.d.ts +3 -0
- package/dest/p2p/constants.d.ts.map +1 -0
- package/dest/p2p/constants.js +2 -0
- package/dest/p2p/gossipable.d.ts +21 -18
- package/dest/p2p/gossipable.d.ts.map +1 -1
- package/dest/p2p/gossipable.js +52 -4
- package/dest/p2p/index.d.ts +6 -2
- package/dest/p2p/index.d.ts.map +1 -1
- package/dest/p2p/index.js +5 -1
- package/dest/p2p/interface.d.ts +1 -14
- package/dest/p2p/interface.d.ts.map +1 -1
- package/dest/p2p/interface.js +1 -19
- package/dest/p2p/message_validator.d.ts +18 -3
- package/dest/p2p/message_validator.d.ts.map +1 -1
- package/dest/p2p/message_validator.js +2 -1
- package/dest/p2p/peer_error.d.ts +1 -1
- package/dest/p2p/signature_utils.d.ts +8 -7
- package/dest/p2p/signature_utils.d.ts.map +1 -1
- package/dest/p2p/signature_utils.js +10 -6
- package/dest/p2p/signed_txs.d.ts +42 -0
- package/dest/p2p/signed_txs.d.ts.map +1 -0
- package/dest/p2p/signed_txs.js +75 -0
- package/dest/p2p/topic_type.d.ts +9 -11
- package/dest/p2p/topic_type.d.ts.map +1 -1
- package/dest/p2p/topic_type.js +44 -17
- package/dest/parity/index.d.ts +3 -4
- package/dest/parity/index.d.ts.map +1 -1
- package/dest/parity/index.js +2 -3
- package/dest/parity/parity_base_private_inputs.d.ts +35 -0
- package/dest/parity/parity_base_private_inputs.d.ts.map +1 -0
- package/dest/parity/{base_parity_inputs.js → parity_base_private_inputs.js} +11 -7
- package/dest/parity/parity_public_inputs.d.ts +4 -6
- package/dest/parity/parity_public_inputs.d.ts.map +1 -1
- package/dest/parity/parity_public_inputs.js +1 -1
- package/dest/parity/parity_root_private_inputs.d.ts +39 -0
- package/dest/parity/parity_root_private_inputs.d.ts.map +1 -0
- package/dest/parity/{root_parity_inputs.js → parity_root_private_inputs.js} +12 -13
- package/dest/proofs/chonk_proof.d.ts +28 -0
- package/dest/proofs/chonk_proof.d.ts.map +1 -0
- package/dest/proofs/chonk_proof.js +106 -0
- package/dest/proofs/index.d.ts +3 -2
- package/dest/proofs/index.d.ts.map +1 -1
- package/dest/proofs/index.js +2 -1
- package/dest/proofs/proof.d.ts +7 -8
- package/dest/proofs/proof.d.ts.map +1 -1
- package/dest/proofs/proof.js +29 -21
- package/dest/proofs/proof_data.d.ts +33 -0
- package/dest/proofs/proof_data.d.ts.map +1 -0
- package/dest/proofs/proof_data.js +39 -0
- package/dest/proofs/proving_request_type.d.ts +18 -13
- package/dest/proofs/proving_request_type.d.ts.map +1 -1
- package/dest/proofs/proving_request_type.js +17 -11
- package/dest/proofs/recursive_proof.d.ts +5 -22
- package/dest/proofs/recursive_proof.d.ts.map +1 -1
- package/dest/proofs/recursive_proof.js +1 -1
- package/dest/rollup/avm_proof_data.d.ts +4 -16
- package/dest/rollup/avm_proof_data.d.ts.map +1 -1
- package/dest/rollup/avm_proof_data.js +1 -25
- package/dest/rollup/base_rollup_hints.d.ts +36 -37
- package/dest/rollup/base_rollup_hints.d.ts.map +1 -1
- package/dest/rollup/base_rollup_hints.js +41 -40
- package/dest/rollup/block_constant_data.d.ts +51 -0
- package/dest/rollup/block_constant_data.d.ts.map +1 -0
- package/dest/rollup/block_constant_data.js +50 -0
- package/dest/rollup/block_headers_hash.d.ts +4 -0
- package/dest/rollup/block_headers_hash.d.ts.map +1 -0
- package/dest/rollup/block_headers_hash.js +9 -0
- package/dest/rollup/block_merge_rollup_private_inputs.d.ts +50 -0
- package/dest/rollup/block_merge_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/{block_merge_rollup.js → block_merge_rollup_private_inputs.js} +14 -13
- package/dest/rollup/block_rollup_public_inputs.d.ts +128 -0
- package/dest/rollup/block_rollup_public_inputs.d.ts.map +1 -0
- package/dest/rollup/block_rollup_public_inputs.js +87 -0
- package/dest/rollup/block_root_rollup_private_inputs.d.ts +225 -0
- package/dest/rollup/block_root_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/block_root_rollup_private_inputs.js +249 -0
- package/dest/rollup/checkpoint_constant_data.d.ts +77 -0
- package/dest/rollup/checkpoint_constant_data.d.ts.map +1 -0
- package/dest/rollup/checkpoint_constant_data.js +82 -0
- package/dest/rollup/checkpoint_header.d.ts +119 -0
- package/dest/rollup/checkpoint_header.d.ts.map +1 -0
- package/dest/rollup/checkpoint_header.js +214 -0
- package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts +30 -0
- package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/checkpoint_merge_rollup_private_inputs.js +37 -0
- package/dest/rollup/checkpoint_rollup_public_inputs.d.ts +122 -0
- package/dest/rollup/checkpoint_rollup_public_inputs.d.ts.map +1 -0
- package/dest/rollup/checkpoint_rollup_public_inputs.js +116 -0
- package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts +141 -0
- package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/checkpoint_root_rollup_private_inputs.js +190 -0
- package/dest/rollup/epoch_constant_data.d.ts +56 -0
- package/dest/rollup/epoch_constant_data.d.ts.map +1 -0
- package/dest/rollup/epoch_constant_data.js +53 -0
- package/dest/rollup/index.d.ts +21 -17
- package/dest/rollup/index.d.ts.map +1 -1
- package/dest/rollup/index.js +20 -16
- package/dest/rollup/private_tx_base_rollup_private_inputs.d.ts +21 -0
- package/dest/rollup/private_tx_base_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/private_tx_base_rollup_private_inputs.js +42 -0
- package/dest/rollup/public_chonk_verifier_private_inputs.d.ts +21 -0
- package/dest/rollup/public_chonk_verifier_private_inputs.d.ts.map +1 -0
- package/dest/rollup/public_chonk_verifier_private_inputs.js +43 -0
- package/dest/rollup/public_chonk_verifier_public_inputs.d.ts +20 -0
- package/dest/rollup/public_chonk_verifier_public_inputs.d.ts.map +1 -0
- package/dest/rollup/public_chonk_verifier_public_inputs.js +42 -0
- package/dest/rollup/public_tx_base_rollup_private_inputs.d.ts +23 -0
- package/dest/rollup/public_tx_base_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/public_tx_base_rollup_private_inputs.js +46 -0
- package/dest/rollup/root_rollup_private_inputs.d.ts +67 -0
- package/dest/rollup/root_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/root_rollup_private_inputs.js +69 -0
- package/dest/rollup/root_rollup_public_inputs.d.ts +59 -0
- package/dest/rollup/root_rollup_public_inputs.d.ts.map +1 -0
- package/dest/rollup/root_rollup_public_inputs.js +77 -0
- package/dest/rollup/tree_snapshot_diff_hints.d.ts +87 -0
- package/dest/rollup/tree_snapshot_diff_hints.d.ts.map +1 -0
- package/dest/rollup/tree_snapshot_diff_hints.js +75 -0
- package/dest/rollup/tx_merge_rollup_private_inputs.d.ts +44 -0
- package/dest/rollup/tx_merge_rollup_private_inputs.d.ts.map +1 -0
- package/dest/rollup/{merge_rollup.js → tx_merge_rollup_private_inputs.js} +14 -13
- package/dest/rollup/tx_rollup_public_inputs.d.ts +115 -0
- package/dest/rollup/tx_rollup_public_inputs.d.ts.map +1 -0
- package/dest/rollup/{base_or_merge_rollup_public_inputs.js → tx_rollup_public_inputs.js} +17 -22
- package/dest/schemas/index.d.ts +1 -1
- package/dest/schemas/schemas.d.ts +93 -19
- package/dest/schemas/schemas.d.ts.map +1 -1
- package/dest/schemas/schemas.js +15 -2
- package/dest/slashing/empire.d.ts +31 -0
- package/dest/slashing/empire.d.ts.map +1 -0
- package/dest/slashing/empire.js +85 -0
- package/dest/slashing/helpers.d.ts +36 -0
- package/dest/slashing/helpers.d.ts.map +1 -0
- package/dest/slashing/helpers.js +91 -0
- package/dest/slashing/index.d.ts +7 -0
- package/dest/slashing/index.d.ts.map +1 -0
- package/dest/slashing/index.js +6 -0
- package/dest/slashing/interfaces.d.ts +12 -0
- package/dest/slashing/interfaces.d.ts.map +1 -0
- package/dest/slashing/interfaces.js +1 -0
- package/dest/slashing/serialization.d.ts +8 -0
- package/dest/slashing/serialization.d.ts.map +1 -0
- package/dest/slashing/serialization.js +78 -0
- package/dest/slashing/tally.d.ts +23 -0
- package/dest/slashing/tally.d.ts.map +1 -0
- package/dest/slashing/tally.js +60 -0
- package/dest/slashing/types.d.ts +161 -0
- package/dest/slashing/types.d.ts.map +1 -0
- package/dest/slashing/types.js +88 -0
- package/dest/snapshots/download.d.ts +9 -0
- package/dest/snapshots/download.d.ts.map +1 -0
- package/dest/snapshots/download.js +93 -0
- package/dest/snapshots/index.d.ts +4 -0
- package/dest/snapshots/index.d.ts.map +1 -0
- package/dest/snapshots/index.js +3 -0
- package/dest/snapshots/types.d.ts +120 -0
- package/dest/snapshots/types.d.ts.map +1 -0
- package/dest/snapshots/types.js +35 -0
- package/dest/snapshots/upload.d.ts +8 -0
- package/dest/snapshots/upload.d.ts.map +1 -0
- package/dest/snapshots/upload.js +42 -0
- package/dest/stats/index.d.ts +1 -1
- package/dest/stats/stats.d.ts +19 -17
- package/dest/stats/stats.d.ts.map +1 -1
- package/dest/tests/factories.d.ts +143 -131
- package/dest/tests/factories.d.ts.map +1 -1
- package/dest/tests/factories.js +451 -376
- package/dest/tests/fixtures.d.ts +1 -1
- package/dest/tests/index.d.ts +1 -1
- package/dest/tests/jest.d.ts +1 -1
- package/dest/tests/jest.js +1 -1
- package/dest/tests/mocks.d.ts +142 -23
- package/dest/tests/mocks.d.ts.map +1 -1
- package/dest/tests/mocks.js +352 -93
- package/dest/trees/append_only_tree_snapshot.d.ts +14 -8
- package/dest/trees/append_only_tree_snapshot.d.ts.map +1 -1
- package/dest/trees/append_only_tree_snapshot.js +21 -4
- package/dest/trees/database_public_state_source.d.ts +11 -0
- package/dest/trees/database_public_state_source.d.ts.map +1 -0
- package/dest/trees/database_public_state_source.js +18 -0
- package/dest/trees/index.d.ts +2 -2
- package/dest/trees/index.d.ts.map +1 -1
- package/dest/trees/index.js +1 -1
- package/dest/trees/merkle_tree_id.d.ts +17 -9
- package/dest/trees/merkle_tree_id.d.ts.map +1 -1
- package/dest/trees/merkle_tree_id.js +10 -0
- package/dest/trees/nullifier_leaf.d.ts +67 -19
- package/dest/trees/nullifier_leaf.d.ts.map +1 -1
- package/dest/trees/nullifier_leaf.js +70 -23
- package/dest/trees/nullifier_membership_witness.d.ts +40 -45
- package/dest/trees/nullifier_membership_witness.d.ts.map +1 -1
- package/dest/trees/nullifier_membership_witness.js +15 -2
- package/dest/trees/public_data_leaf.d.ts +80 -32
- package/dest/trees/public_data_leaf.d.ts.map +1 -1
- package/dest/trees/public_data_leaf.js +66 -31
- package/dest/trees/public_data_witness.d.ts +47 -54
- package/dest/trees/public_data_witness.d.ts.map +1 -1
- package/dest/trees/public_data_witness.js +21 -5
- package/dest/tx/block_header.d.ts +32 -28
- package/dest/tx/block_header.d.ts.map +1 -1
- package/dest/tx/block_header.js +47 -24
- package/dest/tx/call_context.d.ts +8 -11
- package/dest/tx/call_context.d.ts.map +1 -1
- package/dest/tx/call_context.js +3 -1
- package/dest/tx/capsule.d.ts +5 -5
- package/dest/tx/capsule.d.ts.map +1 -1
- package/dest/tx/capsule.js +3 -1
- package/dest/tx/execution_payload.d.ts +45 -0
- package/dest/tx/execution_payload.d.ts.map +1 -0
- package/dest/tx/execution_payload.js +40 -0
- package/dest/tx/function_data.d.ts +4 -6
- package/dest/tx/function_data.d.ts.map +1 -1
- package/dest/tx/function_data.js +1 -1
- package/dest/tx/global_variable_builder.d.ts +8 -5
- package/dest/tx/global_variable_builder.d.ts.map +1 -1
- package/dest/tx/global_variables.d.ts +76 -44
- package/dest/tx/global_variables.d.ts.map +1 -1
- package/dest/tx/global_variables.js +72 -22
- package/dest/tx/hashed_values.d.ts +19 -9
- package/dest/tx/hashed_values.d.ts.map +1 -1
- package/dest/tx/hashed_values.js +27 -10
- package/dest/tx/in_tx.d.ts +26 -0
- package/dest/tx/in_tx.d.ts.map +1 -0
- package/dest/tx/in_tx.js +14 -0
- package/dest/tx/index.d.ts +11 -4
- package/dest/tx/index.d.ts.map +1 -1
- package/dest/tx/index.js +10 -3
- package/dest/tx/indexed_tx_effect.d.ts +31 -0
- package/dest/tx/indexed_tx_effect.d.ts.map +1 -0
- package/dest/tx/indexed_tx_effect.js +36 -0
- package/dest/tx/offchain_effect.d.ts +14 -0
- package/dest/tx/offchain_effect.d.ts.map +1 -0
- package/dest/tx/offchain_effect.js +4 -0
- package/dest/tx/partial_state_reference.d.ts +12 -5
- package/dest/tx/partial_state_reference.d.ts.map +1 -1
- package/dest/tx/partial_state_reference.js +22 -2
- package/dest/tx/private_execution_result.d.ts +71 -69
- package/dest/tx/private_execution_result.d.ts.map +1 -1
- package/dest/tx/private_execution_result.js +74 -100
- package/dest/tx/private_tx_constant_data.d.ts +60 -0
- package/dest/tx/private_tx_constant_data.d.ts.map +1 -0
- package/dest/tx/private_tx_constant_data.js +69 -0
- package/dest/tx/processed_tx.d.ts +10 -11
- package/dest/tx/processed_tx.d.ts.map +1 -1
- package/dest/tx/processed_tx.js +28 -25
- package/dest/tx/profiling.d.ts +483 -0
- package/dest/tx/profiling.d.ts.map +1 -0
- package/dest/tx/profiling.js +167 -0
- package/dest/tx/protocol_contracts.d.ts +37 -0
- package/dest/tx/protocol_contracts.d.ts.map +1 -0
- package/dest/tx/protocol_contracts.js +58 -0
- package/dest/tx/proven_tx.d.ts +129 -0
- package/dest/tx/proven_tx.d.ts.map +1 -0
- package/dest/tx/proven_tx.js +45 -0
- package/dest/tx/public_call_request_with_calldata.d.ts +46 -0
- package/dest/tx/public_call_request_with_calldata.d.ts.map +1 -0
- package/dest/tx/public_call_request_with_calldata.js +71 -0
- package/dest/tx/public_simulation_output.d.ts +7 -5
- package/dest/tx/public_simulation_output.d.ts.map +1 -1
- package/dest/tx/public_simulation_output.js +16 -9
- package/dest/tx/simulated_tx.d.ts +1194 -46
- package/dest/tx/simulated_tx.d.ts.map +1 -1
- package/dest/tx/simulated_tx.js +52 -47
- package/dest/tx/state_reference.d.ts +18 -12
- package/dest/tx/state_reference.d.ts.map +1 -1
- package/dest/tx/state_reference.js +41 -6
- package/dest/tx/tree_snapshots.d.ts +15 -10
- package/dest/tx/tree_snapshots.d.ts.map +1 -1
- package/dest/tx/tree_snapshots.js +15 -4
- package/dest/tx/tx.d.ts +80 -90
- package/dest/tx/tx.d.ts.map +1 -1
- package/dest/tx/tx.js +165 -152
- package/dest/tx/tx_constant_data.d.ts +9 -43
- package/dest/tx/tx_constant_data.d.ts.map +1 -1
- package/dest/tx/tx_constant_data.js +12 -21
- package/dest/tx/tx_context.d.ts +35 -37
- package/dest/tx/tx_context.d.ts.map +1 -1
- package/dest/tx/tx_context.js +1 -1
- package/dest/tx/tx_effect.d.ts +22 -54
- package/dest/tx/tx_effect.d.ts.map +1 -1
- package/dest/tx/tx_effect.js +85 -275
- package/dest/tx/tx_execution_request.d.ts +15 -8
- package/dest/tx/tx_execution_request.d.ts.map +1 -1
- package/dest/tx/tx_execution_request.js +23 -12
- package/dest/tx/tx_hash.d.ts +13 -6
- package/dest/tx/tx_hash.d.ts.map +1 -1
- package/dest/tx/tx_hash.js +25 -6
- package/dest/tx/tx_receipt.d.ts +45 -45
- package/dest/tx/tx_receipt.d.ts.map +1 -1
- package/dest/tx/tx_receipt.js +50 -28
- package/dest/tx/tx_request.d.ts +13 -11
- package/dest/tx/tx_request.d.ts.map +1 -1
- package/dest/tx/tx_request.js +13 -10
- package/dest/tx/validator/empty_validator.d.ts +1 -1
- package/dest/tx/validator/empty_validator.d.ts.map +1 -1
- package/dest/tx/validator/error_texts.d.ts +25 -0
- package/dest/tx/validator/error_texts.d.ts.map +1 -0
- package/dest/tx/validator/error_texts.js +33 -0
- package/dest/tx/validator/tx_validator.d.ts +3 -4
- package/dest/tx/validator/tx_validator.d.ts.map +1 -1
- package/dest/tx/validator/tx_validator.js +7 -4
- package/dest/types/index.d.ts +1 -1
- package/dest/types/shared.d.ts +10 -12
- package/dest/types/shared.d.ts.map +1 -1
- package/dest/types/shared.js +0 -8
- package/dest/update-checker/index.d.ts +2 -0
- package/dest/update-checker/index.d.ts.map +1 -0
- package/dest/update-checker/index.js +1 -0
- package/dest/update-checker/update-checker.d.ts +49 -0
- package/dest/update-checker/update-checker.d.ts.map +1 -0
- package/dest/update-checker/update-checker.js +130 -0
- package/dest/validators/errors.d.ts +33 -0
- package/dest/validators/errors.d.ts.map +1 -0
- package/dest/validators/errors.js +45 -0
- package/dest/validators/index.d.ts +4 -0
- package/dest/validators/index.d.ts.map +1 -0
- package/dest/validators/index.js +2 -0
- package/dest/validators/schemas.d.ts +650 -0
- package/dest/validators/schemas.d.ts.map +1 -0
- package/dest/validators/schemas.js +52 -0
- package/dest/validators/types.d.ts +53 -0
- package/dest/validators/types.d.ts.map +1 -0
- package/dest/validators/types.js +1 -0
- package/dest/versioning/index.d.ts +1 -1
- package/dest/versioning/versioning.d.ts +6 -6
- package/dest/versioning/versioning.d.ts.map +1 -1
- package/dest/versioning/versioning.js +23 -18
- package/dest/vks/index.d.ts +2 -2
- package/dest/vks/index.d.ts.map +1 -1
- package/dest/vks/index.js +1 -1
- package/dest/vks/verification_key.d.ts +19 -14
- package/dest/vks/verification_key.d.ts.map +1 -1
- package/dest/vks/verification_key.js +30 -12
- package/dest/vks/vk_data.d.ts +30 -0
- package/dest/vks/vk_data.d.ts.map +1 -0
- package/dest/vks/{vk_witness_data.js → vk_data.js} +11 -11
- package/dest/world-state/index.d.ts +2 -0
- package/dest/world-state/index.d.ts.map +1 -0
- package/dest/world-state/index.js +1 -0
- package/dest/world-state/world_state_revision.d.ts +54 -0
- package/dest/world-state/world_state_revision.d.ts.map +1 -0
- package/dest/world-state/world_state_revision.js +44 -0
- package/dest/zkpassport/index.d.ts +34 -0
- package/dest/zkpassport/index.d.ts.map +1 -0
- package/dest/zkpassport/index.js +82 -0
- package/package.json +51 -25
- package/src/abi/abi.ts +138 -102
- package/src/abi/authorization_selector.ts +96 -0
- package/src/abi/buffer.ts +1 -1
- package/src/abi/contract_artifact.ts +101 -70
- package/src/abi/decoder.ts +19 -14
- package/src/abi/encoder.ts +89 -4
- package/src/abi/event_metadata_definition.ts +8 -0
- package/src/abi/event_selector.ts +3 -2
- package/src/abi/function_call.ts +6 -2
- package/src/abi/function_selector.ts +11 -2
- package/src/abi/index.ts +2 -0
- package/src/abi/note_selector.ts +2 -2
- package/src/abi/selector.ts +1 -1
- package/src/abi/utils.ts +32 -0
- package/src/auth_witness/auth_witness.ts +30 -1
- package/src/avm/avm.ts +1330 -127
- package/src/avm/avm_accumulated_data.ts +170 -13
- package/src/avm/avm_circuit_public_inputs.ts +121 -4
- package/src/avm/contract_storage_read.ts +1 -1
- package/src/avm/contract_storage_update_request.ts +1 -1
- package/src/avm/index.ts +1 -1
- package/src/avm/message_pack.ts +38 -3
- package/src/avm/public_call_stack_item_compressed.ts +1 -1
- package/src/avm/public_data_read.ts +1 -1
- package/src/avm/public_data_update_request.ts +1 -1
- package/src/avm/public_data_write.ts +37 -2
- package/src/avm/public_inner_call_request.ts +2 -2
- package/src/avm/revert_code.ts +35 -15
- package/src/aztec-address/index.ts +28 -3
- package/src/block/attestation_info.ts +72 -0
- package/src/block/block_hash.ts +31 -16
- package/src/block/block_parameter.ts +10 -0
- package/src/block/body.ts +24 -39
- package/src/block/checkpointed_l2_block.ts +70 -0
- package/src/block/in_block.ts +28 -15
- package/src/block/index.ts +7 -3
- package/src/block/l2_block.ts +131 -112
- package/src/block/l2_block_info.ts +64 -0
- package/src/block/l2_block_source.ts +267 -54
- package/src/block/l2_block_stream/index.ts +4 -0
- package/src/block/l2_block_stream/interfaces.ts +44 -0
- package/src/block/l2_block_stream/l2_block_stream.ts +307 -0
- package/src/block/l2_block_stream/l2_tips_memory_store.ts +84 -0
- package/src/block/l2_block_stream/l2_tips_store_base.ts +226 -0
- package/src/block/proposal/attestations_and_signers.ts +140 -0
- package/src/block/proposal/committee_attestation.ts +120 -0
- package/src/block/proposal/index.ts +2 -0
- package/src/block/test/index.ts +1 -0
- package/src/block/test/l2_tips_store_test_suite.ts +537 -0
- package/src/block/validate_block_result.ts +129 -0
- package/src/checkpoint/checkpoint.ts +158 -0
- package/src/checkpoint/checkpoint_info.ts +52 -0
- package/src/checkpoint/index.ts +3 -0
- package/src/checkpoint/published_checkpoint.ts +106 -0
- package/src/config/{config.ts → chain-config.ts} +8 -7
- package/src/config/index.ts +2 -1
- package/src/config/node-rpc-config.ts +37 -0
- package/src/contract/artifact_hash.ts +16 -14
- package/src/contract/complete_address.ts +1 -1
- package/src/contract/contract_address.ts +4 -4
- package/src/contract/contract_class.ts +9 -26
- package/src/contract/contract_class_id.ts +13 -7
- package/src/contract/contract_deployment_data.ts +125 -0
- package/src/contract/contract_instance.ts +27 -18
- package/src/contract/contract_instance_update.ts +8 -7
- package/src/contract/deployment_info.ts +1 -1
- package/src/contract/index.ts +2 -1
- package/src/contract/interfaces/contract_class.ts +98 -79
- package/src/contract/interfaces/contract_data_source.ts +14 -22
- package/src/contract/interfaces/contract_instance.ts +48 -16
- package/src/contract/interfaces/contract_instance_update.ts +15 -12
- package/src/contract/interfaces/node-info.ts +3 -3
- package/src/contract/interfaces/protocol_contract_addresses.ts +5 -10
- package/src/contract/partial_address.ts +1 -1
- package/src/contract/private_function.ts +7 -5
- package/src/contract/private_function_membership_proof.ts +11 -11
- package/src/contract/{unconstrained_function_membership_proof.ts → utility_function_membership_proof.ts} +19 -19
- package/src/database-version/database_version.ts +87 -0
- package/src/database-version/version_manager.ts +60 -83
- package/src/{shared_mutable/shared_mutable_values.ts → delayed_public_mutable/delayed_public_mutable_values.ts} +29 -27
- package/src/delayed_public_mutable/delayed_public_mutable_values_with_hash.ts +38 -0
- package/src/delayed_public_mutable/index.ts +4 -0
- package/src/delayed_public_mutable/scheduled_delay_change.ts +17 -0
- package/src/{shared_mutable → delayed_public_mutable}/scheduled_value_change.ts +12 -6
- package/src/deserialization/index.ts +21 -0
- package/src/epoch-helpers/index.ts +97 -20
- package/src/errors/proving_error.ts +5 -1
- package/src/errors/simulation_error.ts +3 -3
- package/src/fees/transaction_fee.ts +29 -9
- package/src/file-store/factory.ts +76 -0
- package/src/file-store/gcs.ts +121 -0
- package/src/file-store/http.ts +70 -0
- package/src/file-store/index.ts +2 -0
- package/src/file-store/interface.ts +25 -0
- package/src/file-store/local.ts +46 -0
- package/src/file-store/s3.ts +250 -0
- package/src/gas/gas.ts +24 -3
- package/src/gas/gas_fees.ts +42 -24
- package/src/gas/gas_settings.ts +31 -10
- package/src/gas/gas_used.ts +22 -1
- package/src/hash/hash.ts +51 -32
- package/src/hash/map_slot.ts +4 -3
- package/src/interfaces/allowed_element.ts +23 -0
- package/src/interfaces/api_limit.ts +5 -0
- package/src/interfaces/archiver.ts +104 -37
- package/src/interfaces/aztec-node-admin.ts +102 -0
- package/src/interfaces/aztec-node.ts +285 -240
- package/src/interfaces/block-builder.ts +83 -10
- package/src/interfaces/client.ts +2 -1
- package/src/interfaces/configs.ts +90 -39
- package/src/interfaces/epoch-prover.ts +46 -17
- package/src/interfaces/get_logs_response.ts +13 -9
- package/src/interfaces/l2_logs_source.ts +24 -13
- package/src/interfaces/merkle_tree_operations.ts +37 -11
- package/src/interfaces/p2p.ts +34 -11
- package/src/interfaces/private_kernel_prover.ts +13 -4
- package/src/interfaces/prover-agent.ts +9 -10
- package/src/interfaces/prover-client.ts +43 -20
- package/src/interfaces/prover-coordination.ts +6 -16
- package/src/interfaces/prover-node.ts +10 -2
- package/src/interfaces/proving-job.ts +244 -139
- package/src/interfaces/public_state_source.ts +9 -0
- package/src/interfaces/server.ts +11 -5
- package/src/interfaces/server_circuit_prover.ts +111 -59
- package/src/interfaces/service.ts +4 -2
- package/src/interfaces/slasher.ts +52 -0
- package/src/interfaces/tx_provider.ts +17 -0
- package/src/interfaces/validator.ts +150 -0
- package/src/interfaces/world_state.ts +45 -29
- package/src/kernel/claimed_length_array.ts +104 -0
- package/src/kernel/hiding_kernel_private_inputs.ts +37 -0
- package/src/kernel/hints/build_note_hash_read_request_hints.ts +47 -41
- package/src/kernel/hints/build_nullifier_read_request_hints.ts +49 -76
- package/src/kernel/hints/build_transient_data_hints.ts +14 -16
- package/src/kernel/hints/find_private_kernel_reset_dimensions.ts +5 -7
- package/src/kernel/hints/index.ts +1 -2
- package/src/kernel/hints/key_validation_hint.ts +5 -7
- package/src/kernel/hints/key_validation_request.ts +2 -1
- package/src/kernel/hints/key_validation_request_and_generator.ts +1 -1
- package/src/kernel/hints/note_hash_read_request_hints.ts +9 -18
- package/src/kernel/hints/nullifier_read_request_hints.ts +11 -20
- package/src/kernel/hints/private_kernel_reset_hints.ts +37 -54
- package/src/kernel/hints/read_request.ts +5 -2
- package/src/kernel/hints/read_request_hints.ts +59 -38
- package/src/kernel/hints/scoped_key_validation_request_and_generator.ts +1 -1
- package/src/kernel/hints/scoped_value_cache.ts +1 -1
- package/src/kernel/hints/{transient_data_index_hint.ts → transient_data_squashing_hint.ts} +10 -7
- package/src/kernel/hints/tree_leaf_read_request.ts +5 -2
- package/src/kernel/index.ts +4 -2
- package/src/kernel/log_hash.ts +87 -15
- package/src/kernel/note_hash.ts +9 -3
- package/src/kernel/nullifier.ts +17 -10
- package/src/kernel/padded_side_effects.ts +73 -0
- package/src/kernel/private_accumulated_data.ts +25 -25
- package/src/kernel/private_call_data.ts +6 -25
- package/src/kernel/private_call_request.ts +2 -2
- package/src/kernel/private_circuit_public_inputs.ts +161 -117
- package/src/kernel/private_context_inputs.ts +3 -3
- package/src/kernel/private_kernel_circuit_public_inputs.ts +21 -6
- package/src/kernel/private_kernel_data.ts +7 -31
- package/src/kernel/private_kernel_init_circuit_private_inputs.ts +12 -5
- package/src/kernel/private_kernel_prover_output.ts +70 -0
- package/src/kernel/private_kernel_reset_circuit_private_inputs.ts +16 -13
- package/src/kernel/private_kernel_reset_dimensions.ts +27 -27
- package/src/kernel/private_kernel_simulated_output.ts +7 -16
- package/src/kernel/private_kernel_tail_circuit_private_inputs.ts +22 -5
- package/src/kernel/private_kernel_tail_circuit_public_inputs.ts +42 -25
- package/src/kernel/private_log_data.ts +14 -5
- package/src/kernel/private_to_avm_accumulated_data.ts +54 -2
- package/src/kernel/private_to_public_accumulated_data.ts +1 -1
- package/src/kernel/private_to_public_accumulated_data_builder.ts +1 -1
- package/src/kernel/private_to_public_kernel_circuit_public_inputs.ts +18 -9
- package/src/kernel/private_to_rollup_accumulated_data.ts +1 -1
- package/src/kernel/private_to_rollup_kernel_circuit_public_inputs.ts +18 -12
- package/src/kernel/private_validation_requests.ts +19 -62
- package/src/kernel/public_call_request.ts +120 -29
- package/src/kernel/utils/optional_number.ts +1 -1
- package/src/kernel/utils/order_and_comparison.ts +0 -25
- package/src/keys/derivation.ts +15 -32
- package/src/keys/key_types.ts +1 -1
- package/src/keys/public_key.ts +1 -1
- package/src/keys/public_keys.ts +23 -3
- package/src/keys/utils.ts +7 -3
- package/src/l1-contracts/index.ts +1 -0
- package/src/l1-contracts/slash_factory.ts +180 -0
- package/src/logs/contract_class_log.ts +168 -66
- package/src/logs/debug_log.ts +51 -0
- package/src/logs/directional_app_tagging_secret.ts +79 -0
- package/src/logs/index.ts +8 -3
- package/src/logs/log_id.ts +23 -11
- package/src/logs/message_context.ts +62 -0
- package/src/logs/pending_tagged_log.ts +41 -0
- package/src/logs/pre_tag.ts +25 -0
- package/src/logs/private_log.ts +79 -26
- package/src/logs/public_log.ts +158 -37
- package/src/logs/shared_secret_derivation.ts +26 -0
- package/src/logs/siloed_tag.ts +45 -0
- package/src/logs/tag.ts +42 -0
- package/src/logs/tx_scoped_l2_log.ts +48 -33
- package/src/messaging/in_hash.ts +12 -0
- package/src/messaging/inbox_leaf.ts +20 -4
- package/src/messaging/index.ts +3 -0
- package/src/messaging/l1_actor.ts +2 -2
- package/src/messaging/l1_to_l2_message.ts +3 -2
- package/src/messaging/l1_to_l2_message_source.ts +9 -7
- package/src/messaging/l2_actor.ts +2 -2
- package/src/messaging/l2_to_l1_membership.ts +225 -0
- package/src/messaging/l2_to_l1_message.ts +131 -37
- package/src/messaging/out_hash.ts +77 -0
- package/src/noir/index.ts +24 -7
- package/src/note/index.ts +1 -1
- package/src/note/note.ts +65 -6
- package/src/note/note_dao.ts +187 -0
- package/src/note/notes_filter.ts +10 -11
- package/src/p2p/attestation_utils.ts +35 -0
- package/src/p2p/block_proposal.ts +249 -36
- package/src/p2p/checkpoint_attestation.ts +143 -0
- package/src/p2p/checkpoint_proposal.ts +355 -0
- package/src/p2p/consensus_payload.ts +53 -32
- package/src/p2p/constants.ts +3 -0
- package/src/p2p/gossipable.ts +60 -15
- package/src/p2p/index.ts +5 -1
- package/src/p2p/interface.ts +0 -24
- package/src/p2p/message_validator.ts +14 -2
- package/src/p2p/signature_utils.ts +12 -11
- package/src/p2p/signed_txs.ts +88 -0
- package/src/p2p/topic_type.ts +35 -15
- package/src/parity/index.ts +2 -3
- package/src/parity/{base_parity_inputs.ts → parity_base_private_inputs.ts} +14 -12
- package/src/parity/parity_public_inputs.ts +1 -1
- package/src/parity/{root_parity_inputs.ts → parity_root_private_inputs.ts} +16 -18
- package/src/proofs/chonk_proof.ts +122 -0
- package/src/proofs/index.ts +2 -1
- package/src/proofs/proof.ts +30 -22
- package/src/proofs/proof_data.ts +60 -0
- package/src/proofs/proving_request_type.ts +14 -9
- package/src/proofs/recursive_proof.ts +1 -1
- package/src/rollup/avm_proof_data.ts +3 -32
- package/src/rollup/base_rollup_hints.ts +42 -41
- package/src/rollup/block_constant_data.ts +73 -0
- package/src/rollup/block_headers_hash.ts +12 -0
- package/src/rollup/{block_merge_rollup.ts → block_merge_rollup_private_inputs.ts} +15 -11
- package/src/rollup/block_rollup_public_inputs.ts +125 -0
- package/src/rollup/block_root_rollup_private_inputs.ts +303 -0
- package/src/rollup/checkpoint_constant_data.ts +124 -0
- package/src/rollup/checkpoint_header.ts +297 -0
- package/src/rollup/checkpoint_merge_rollup_private_inputs.ts +49 -0
- package/src/rollup/checkpoint_rollup_public_inputs.ts +151 -0
- package/src/rollup/checkpoint_root_rollup_private_inputs.ts +232 -0
- package/src/rollup/epoch_constant_data.ts +62 -0
- package/src/rollup/index.ts +20 -16
- package/src/rollup/private_tx_base_rollup_private_inputs.ts +53 -0
- package/src/rollup/public_chonk_verifier_private_inputs.ts +54 -0
- package/src/rollup/public_chonk_verifier_public_inputs.ts +53 -0
- package/src/rollup/public_tx_base_rollup_private_inputs.ts +57 -0
- package/src/rollup/root_rollup_private_inputs.ts +90 -0
- package/src/rollup/root_rollup_public_inputs.ts +108 -0
- package/src/rollup/{state_diff_hints.ts → tree_snapshot_diff_hints.ts} +27 -42
- package/src/rollup/{merge_rollup.ts → tx_merge_rollup_private_inputs.ts} +13 -9
- package/src/rollup/{base_or_merge_rollup_public_inputs.ts → tx_rollup_public_inputs.ts} +18 -26
- package/src/schemas/schemas.ts +27 -1
- package/src/slashing/empire.ts +102 -0
- package/src/slashing/helpers.ts +141 -0
- package/src/slashing/index.ts +6 -0
- package/src/slashing/interfaces.ts +13 -0
- package/src/slashing/serialization.ts +103 -0
- package/src/slashing/tally.ts +87 -0
- package/src/slashing/types.ts +156 -0
- package/src/snapshots/download.ts +123 -0
- package/src/snapshots/index.ts +3 -0
- package/src/snapshots/types.ts +74 -0
- package/src/snapshots/upload.ts +64 -0
- package/src/stats/stats.ts +38 -26
- package/src/tests/factories.ts +852 -657
- package/src/tests/jest.ts +1 -1
- package/src/tests/mocks.ts +578 -151
- package/src/trees/append_only_tree_snapshot.ts +18 -3
- package/src/trees/database_public_state_source.ts +30 -0
- package/src/trees/index.ts +1 -1
- package/src/trees/merkle_tree_id.ts +12 -0
- package/src/trees/nullifier_leaf.ts +81 -22
- package/src/trees/nullifier_membership_witness.ts +18 -2
- package/src/trees/public_data_leaf.ts +73 -30
- package/src/trees/public_data_witness.ts +24 -5
- package/src/tx/block_header.ts +61 -32
- package/src/tx/call_context.ts +1 -1
- package/src/tx/capsule.ts +3 -1
- package/src/tx/execution_payload.ts +60 -0
- package/src/tx/function_data.ts +1 -1
- package/src/tx/global_variable_builder.ts +13 -5
- package/src/tx/global_variables.ts +107 -32
- package/src/tx/hashed_values.ts +30 -10
- package/src/tx/in_tx.ts +24 -0
- package/src/tx/index.ts +10 -3
- package/src/tx/indexed_tx_effect.ts +41 -0
- package/src/tx/offchain_effect.ts +20 -0
- package/src/tx/partial_state_reference.ts +30 -5
- package/src/tx/private_execution_result.ts +76 -107
- package/src/tx/private_tx_constant_data.ts +94 -0
- package/src/tx/processed_tx.ts +58 -49
- package/src/tx/profiling.ts +201 -0
- package/src/tx/protocol_contracts.ts +86 -0
- package/src/tx/proven_tx.ts +62 -0
- package/src/tx/public_call_request_with_calldata.ts +89 -0
- package/src/tx/public_simulation_output.ts +24 -7
- package/src/tx/simulated_tx.ts +66 -76
- package/src/tx/state_reference.ts +49 -6
- package/src/tx/tree_snapshots.ts +30 -14
- package/src/tx/tx.ts +178 -200
- package/src/tx/tx_constant_data.ts +9 -22
- package/src/tx/tx_context.ts +1 -1
- package/src/tx/tx_effect.ts +138 -316
- package/src/tx/tx_execution_request.ts +17 -4
- package/src/tx/tx_hash.ts +27 -6
- package/src/tx/tx_receipt.ts +79 -57
- package/src/tx/tx_request.ts +18 -8
- package/src/tx/validator/error_texts.ts +41 -0
- package/src/tx/validator/tx_validator.ts +13 -6
- package/src/types/shared.ts +10 -9
- package/src/update-checker/index.ts +1 -0
- package/src/update-checker/update-checker.ts +166 -0
- package/src/validators/errors.ts +58 -0
- package/src/validators/index.ts +3 -0
- package/src/validators/schemas.ts +81 -0
- package/src/validators/types.ts +47 -0
- package/src/versioning/versioning.ts +29 -33
- package/src/vks/index.ts +1 -1
- package/src/vks/verification_key.ts +44 -19
- package/src/vks/{vk_witness_data.ts → vk_data.ts} +7 -7
- package/src/world-state/index.ts +1 -0
- package/src/world-state/world_state_revision.ts +63 -0
- package/src/zkpassport/index.ts +118 -0
- package/dest/avm/public_data_hint.d.ts +0 -18
- package/dest/avm/public_data_hint.d.ts.map +0 -1
- package/dest/avm/public_data_hint.js +0 -27
- package/dest/block/l2_block_code_to_purge.d.ts +0 -24
- package/dest/block/l2_block_code_to_purge.d.ts.map +0 -1
- package/dest/block/l2_block_code_to_purge.js +0 -51
- package/dest/block/l2_block_downloader/index.d.ts +0 -3
- package/dest/block/l2_block_downloader/index.d.ts.map +0 -1
- package/dest/block/l2_block_downloader/index.js +0 -2
- package/dest/block/l2_block_downloader/l2_block_downloader.d.ts +0 -58
- package/dest/block/l2_block_downloader/l2_block_downloader.d.ts.map +0 -1
- package/dest/block/l2_block_downloader/l2_block_downloader.js +0 -124
- package/dest/block/l2_block_downloader/l2_block_stream.d.ts +0 -57
- package/dest/block/l2_block_downloader/l2_block_stream.d.ts.map +0 -1
- package/dest/block/l2_block_downloader/l2_block_stream.js +0 -137
- package/dest/block/l2_block_number.d.ts +0 -5
- package/dest/block/l2_block_number.d.ts.map +0 -1
- package/dest/block/l2_block_number.js +0 -6
- package/dest/block/nullifier_with_block_source.d.ts +0 -6
- package/dest/block/nullifier_with_block_source.d.ts.map +0 -1
- package/dest/config/config.d.ts +0 -18
- package/dest/config/config.d.ts.map +0 -1
- package/dest/contract/unconstrained_function_membership_proof.d.ts +0 -27
- package/dest/contract/unconstrained_function_membership_proof.d.ts.map +0 -1
- package/dest/database-version/index.d.ts +0 -2
- package/dest/database-version/index.d.ts.map +0 -1
- package/dest/database-version/index.js +0 -1
- package/dest/event/event.d.ts +0 -24
- package/dest/event/event.d.ts.map +0 -1
- package/dest/event/event.js +0 -13
- package/dest/event/event_metadata.d.ts +0 -38
- package/dest/event/event_metadata.d.ts.map +0 -1
- package/dest/event/event_metadata.js +0 -45
- package/dest/event/index.d.ts +0 -4
- package/dest/event/index.d.ts.map +0 -1
- package/dest/event/index.js +0 -3
- package/dest/event/l1_event_payload.d.ts +0 -52
- package/dest/event/l1_event_payload.d.ts.map +0 -1
- package/dest/event/l1_event_payload.js +0 -64
- package/dest/interfaces/pxe.d.ts +0 -347
- package/dest/interfaces/pxe.d.ts.map +0 -1
- package/dest/interfaces/pxe.js +0 -104
- package/dest/kernel/combined_constant_data.d.ts +0 -73
- package/dest/kernel/combined_constant_data.d.ts.map +0 -1
- package/dest/kernel/combined_constant_data.js +0 -73
- package/dest/kernel/hints/rollup_validation_requests.d.ts +0 -40
- package/dest/kernel/hints/rollup_validation_requests.d.ts.map +0 -1
- package/dest/kernel/hints/rollup_validation_requests.js +0 -57
- package/dest/kernel/hints/transient_data_index_hint.d.ts +0 -20
- package/dest/kernel/hints/transient_data_index_hint.d.ts.map +0 -1
- package/dest/kernel/private_kernel_prover_profile_result.d.ts +0 -25
- package/dest/kernel/private_kernel_prover_profile_result.d.ts.map +0 -1
- package/dest/kernel/private_kernel_prover_profile_result.js +0 -7
- package/dest/logs/indexed_tagging_secret.d.ts +0 -28
- package/dest/logs/indexed_tagging_secret.d.ts.map +0 -1
- package/dest/logs/indexed_tagging_secret.js +0 -50
- package/dest/logs/l1_payload/encrypted_log_payload.d.ts +0 -50
- package/dest/logs/l1_payload/encrypted_log_payload.d.ts.map +0 -1
- package/dest/logs/l1_payload/encrypted_log_payload.js +0 -140
- package/dest/logs/l1_payload/encryption_util.d.ts +0 -24
- package/dest/logs/l1_payload/encryption_util.d.ts.map +0 -1
- package/dest/logs/l1_payload/encryption_util.js +0 -46
- package/dest/logs/l1_payload/index.d.ts +0 -3
- package/dest/logs/l1_payload/index.d.ts.map +0 -1
- package/dest/logs/l1_payload/index.js +0 -2
- package/dest/logs/l1_payload/l1_note_payload.d.ts +0 -82
- package/dest/logs/l1_payload/l1_note_payload.d.ts.map +0 -1
- package/dest/logs/l1_payload/l1_note_payload.js +0 -129
- package/dest/logs/l1_payload/payload.d.ts +0 -60
- package/dest/logs/l1_payload/payload.d.ts.map +0 -1
- package/dest/logs/l1_payload/payload.js +0 -61
- package/dest/logs/l1_payload/shared_secret_derivation.d.ts +0 -16
- package/dest/logs/l1_payload/shared_secret_derivation.d.ts.map +0 -1
- package/dest/logs/log_with_tx_data.d.ts +0 -11
- package/dest/logs/log_with_tx_data.d.ts.map +0 -1
- package/dest/logs/log_with_tx_data.js +0 -36
- package/dest/network/index.d.ts +0 -32
- package/dest/network/index.d.ts.map +0 -1
- package/dest/network/index.js +0 -30
- package/dest/note/extended_note.d.ts +0 -124
- package/dest/note/extended_note.d.ts.map +0 -1
- package/dest/note/extended_note.js +0 -115
- package/dest/p2p/block_attestation.d.ts +0 -49
- package/dest/p2p/block_attestation.d.ts.map +0 -1
- package/dest/p2p/block_attestation.js +0 -78
- package/dest/parity/base_parity_inputs.d.ts +0 -37
- package/dest/parity/base_parity_inputs.d.ts.map +0 -1
- package/dest/parity/root_parity_input.d.ts +0 -54
- package/dest/parity/root_parity_input.d.ts.map +0 -1
- package/dest/parity/root_parity_input.js +0 -50
- package/dest/parity/root_parity_inputs.d.ts +0 -39
- package/dest/parity/root_parity_inputs.d.ts.map +0 -1
- package/dest/proofs/client_ivc_proof.d.ts +0 -21
- package/dest/proofs/client_ivc_proof.d.ts.map +0 -1
- package/dest/proofs/client_ivc_proof.js +0 -44
- package/dest/rollup/base_or_merge_rollup_public_inputs.d.ts +0 -126
- package/dest/rollup/base_or_merge_rollup_public_inputs.d.ts.map +0 -1
- package/dest/rollup/block_merge_rollup.d.ts +0 -45
- package/dest/rollup/block_merge_rollup.d.ts.map +0 -1
- package/dest/rollup/block_root_or_block_merge_public_inputs.d.ts +0 -159
- package/dest/rollup/block_root_or_block_merge_public_inputs.d.ts.map +0 -1
- package/dest/rollup/block_root_or_block_merge_public_inputs.js +0 -136
- package/dest/rollup/block_root_rollup.d.ts +0 -262
- package/dest/rollup/block_root_rollup.d.ts.map +0 -1
- package/dest/rollup/block_root_rollup.js +0 -293
- package/dest/rollup/constant_rollup_data.d.ts +0 -47
- package/dest/rollup/constant_rollup_data.d.ts.map +0 -1
- package/dest/rollup/constant_rollup_data.js +0 -45
- package/dest/rollup/empty_block_root_rollup_inputs.d.ts +0 -54
- package/dest/rollup/empty_block_root_rollup_inputs.d.ts.map +0 -1
- package/dest/rollup/empty_block_root_rollup_inputs.js +0 -68
- package/dest/rollup/merge_rollup.d.ts +0 -45
- package/dest/rollup/merge_rollup.d.ts.map +0 -1
- package/dest/rollup/previous_rollup_block_data.d.ts +0 -58
- package/dest/rollup/previous_rollup_block_data.d.ts.map +0 -1
- package/dest/rollup/previous_rollup_block_data.js +0 -42
- package/dest/rollup/previous_rollup_data.d.ts +0 -58
- package/dest/rollup/previous_rollup_data.d.ts.map +0 -1
- package/dest/rollup/previous_rollup_data.js +0 -42
- package/dest/rollup/private_base_rollup_inputs.d.ts +0 -23
- package/dest/rollup/private_base_rollup_inputs.d.ts.map +0 -1
- package/dest/rollup/private_base_rollup_inputs.js +0 -44
- package/dest/rollup/private_tube_data.d.ts +0 -17
- package/dest/rollup/private_tube_data.d.ts.map +0 -1
- package/dest/rollup/private_tube_data.js +0 -25
- package/dest/rollup/public_base_rollup_inputs.d.ts +0 -25
- package/dest/rollup/public_base_rollup_inputs.d.ts.map +0 -1
- package/dest/rollup/public_base_rollup_inputs.js +0 -48
- package/dest/rollup/public_tube_data.d.ts +0 -17
- package/dest/rollup/public_tube_data.d.ts.map +0 -1
- package/dest/rollup/public_tube_data.js +0 -25
- package/dest/rollup/root_rollup.d.ts +0 -112
- package/dest/rollup/root_rollup.d.ts.map +0 -1
- package/dest/rollup/root_rollup.js +0 -158
- package/dest/rollup/state_diff_hints.d.ts +0 -105
- package/dest/rollup/state_diff_hints.d.ts.map +0 -1
- package/dest/rollup/state_diff_hints.js +0 -85
- package/dest/rollup/tube_inputs.d.ts +0 -40
- package/dest/rollup/tube_inputs.d.ts.map +0 -1
- package/dest/rollup/tube_inputs.js +0 -57
- package/dest/shared_mutable/index.d.ts +0 -5
- package/dest/shared_mutable/index.d.ts.map +0 -1
- package/dest/shared_mutable/index.js +0 -4
- package/dest/shared_mutable/scheduled_delay_change.d.ts +0 -10
- package/dest/shared_mutable/scheduled_delay_change.d.ts.map +0 -1
- package/dest/shared_mutable/scheduled_value_change.d.ts +0 -11
- package/dest/shared_mutable/scheduled_value_change.d.ts.map +0 -1
- package/dest/shared_mutable/shared_mutable_values.d.ts +0 -22
- package/dest/shared_mutable/shared_mutable_values.d.ts.map +0 -1
- package/dest/shared_mutable/shared_mutable_values_with_hash.d.ts +0 -15
- package/dest/shared_mutable/shared_mutable_values_with_hash.d.ts.map +0 -1
- package/dest/shared_mutable/shared_mutable_values_with_hash.js +0 -30
- package/dest/trees/protocol_contract_leaf.d.ts +0 -87
- package/dest/trees/protocol_contract_leaf.d.ts.map +0 -1
- package/dest/trees/protocol_contract_leaf.js +0 -103
- package/dest/tx/content_commitment.d.ts +0 -105
- package/dest/tx/content_commitment.d.ts.map +0 -1
- package/dest/tx/content_commitment.js +0 -96
- package/dest/tx/max_block_number.d.ts +0 -55
- package/dest/tx/max_block_number.d.ts.map +0 -1
- package/dest/tx/max_block_number.js +0 -65
- package/dest/tx/public_execution_request.d.ts +0 -45
- package/dest/tx/public_execution_request.d.ts.map +0 -1
- package/dest/tx/public_execution_request.js +0 -72
- package/dest/vks/vk_witness_data.d.ts +0 -32
- package/dest/vks/vk_witness_data.d.ts.map +0 -1
- package/src/avm/public_data_hint.ts +0 -38
- package/src/block/l2_block_code_to_purge.ts +0 -103
- package/src/block/l2_block_downloader/index.ts +0 -2
- package/src/block/l2_block_downloader/l2_block_downloader.ts +0 -149
- package/src/block/l2_block_downloader/l2_block_stream.ts +0 -179
- package/src/block/l2_block_number.ts +0 -8
- package/src/block/nullifier_with_block_source.ts +0 -7
- package/src/database-version/index.ts +0 -1
- package/src/event/event.ts +0 -16
- package/src/event/event_metadata.ts +0 -56
- package/src/event/index.ts +0 -3
- package/src/event/l1_event_payload.ts +0 -87
- package/src/interfaces/pxe.ts +0 -536
- package/src/kernel/combined_constant_data.ts +0 -128
- package/src/kernel/hints/rollup_validation_requests.ts +0 -73
- package/src/kernel/private_kernel_prover_profile_result.ts +0 -7
- package/src/logs/indexed_tagging_secret.ts +0 -45
- package/src/logs/l1_payload/encrypted_log_payload.ts +0 -202
- package/src/logs/l1_payload/encryption_util.ts +0 -54
- package/src/logs/l1_payload/index.ts +0 -2
- package/src/logs/l1_payload/l1_note_payload.ts +0 -182
- package/src/logs/l1_payload/payload.ts +0 -73
- package/src/logs/l1_payload/shared_secret_derivation.ts +0 -35
- package/src/logs/log_with_tx_data.ts +0 -36
- package/src/network/index.ts +0 -32
- package/src/note/extended_note.ts +0 -168
- package/src/p2p/block_attestation.ts +0 -107
- package/src/parity/root_parity_input.ts +0 -71
- package/src/proofs/client_ivc_proof.ts +0 -61
- package/src/rollup/block_root_or_block_merge_public_inputs.ts +0 -175
- package/src/rollup/block_root_rollup.ts +0 -362
- package/src/rollup/constant_rollup_data.ts +0 -54
- package/src/rollup/empty_block_root_rollup_inputs.ts +0 -85
- package/src/rollup/previous_rollup_block_data.ts +0 -54
- package/src/rollup/previous_rollup_data.ts +0 -54
- package/src/rollup/private_base_rollup_inputs.ts +0 -50
- package/src/rollup/private_tube_data.ts +0 -35
- package/src/rollup/public_base_rollup_inputs.ts +0 -59
- package/src/rollup/public_tube_data.ts +0 -35
- package/src/rollup/root_rollup.ts +0 -206
- package/src/rollup/tube_inputs.ts +0 -70
- package/src/shared_mutable/index.ts +0 -4
- package/src/shared_mutable/scheduled_delay_change.ts +0 -13
- package/src/shared_mutable/shared_mutable_values_with_hash.ts +0 -38
- package/src/trees/protocol_contract_leaf.ts +0 -132
- package/src/tx/content_commitment.ts +0 -133
- package/src/tx/max_block_number.ts +0 -79
- package/src/tx/public_execution_request.ts +0 -97
- /package/dest/{block/nullifier_with_block_source.js → abi/event_metadata_definition.js} +0 -0
|
@@ -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=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1waXJlLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2xhc2hpbmcvZW1waXJlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBLE9BQU8sS0FBSyxFQUFFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxZQUFZLEVBQUUsaUJBQWlCLEVBQUUsY0FBYyxFQUFFLE1BQU0sWUFBWSxDQUFDO0FBQzlHLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFFekM7Ozs7R0FJRztBQUNILHdCQUFnQix3QkFBd0IsQ0FBQyxPQUFPLEVBQUUsV0FBVyxHQUFHLE9BQU8sQ0FNdEU7QUFFRCxzR0FBc0c7QUFDdEcsd0JBQWdCLGdDQUFnQyxDQUFDLE9BQU8sRUFBRSxZQUFZLEdBQUcsaUJBQWlCLEdBQUcsaUJBQWlCLEVBQUUsQ0FRL0c7QUFFRCxrR0FBa0c7QUFDbEcsd0JBQWdCLHdCQUF3QixDQUFDLFFBQVEsRUFBRSxPQUFPLEVBQUUsR0FBRyxjQUFjLEVBQUUsQ0FNOUU7QUFFRDs7Ozs7OztHQU9HO0FBQ0gsd0JBQWdCLHFCQUFxQixDQUFDLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLE9BQU8sR0FBRyxNQUFNLENBUXBFO0FBRUQ7OztHQUdHO0FBQ0gsd0JBQWdCLCtCQUErQixDQUM3QyxPQUFPLEVBQUUsaUJBQWlCLEVBQzFCLFNBQVMsRUFBRTtJQUFFLGlCQUFpQixFQUFFLE1BQU0sQ0FBQztJQUFDLGFBQWEsRUFBRSxNQUFNLENBQUM7SUFBQyxxQkFBcUIsRUFBRSxNQUFNLENBQUE7Q0FBRSxHQUM3RixNQUFNLENBcUNSIn0=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"empire.d.ts","sourceRoot":"","sources":["../../src/slashing/empire.ts"],"names":[],"mappings":"AAGA,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,85 @@
|
|
|
1
|
+
import { EpochNumber, SlotNumber } from '@aztec/foundation/branded-types';
|
|
2
|
+
import { getRoundForSlot, getRoundsForEpoch } from './helpers.js';
|
|
3
|
+
import { OffenseType } from './types.js';
|
|
4
|
+
/**
|
|
5
|
+
* Returns true if the offense is uncontroversial as in it can be verified via L1 data alone,
|
|
6
|
+
* and does not depend on the local view of the node of the L2 p2p network.
|
|
7
|
+
* @param offense - The offense type to check
|
|
8
|
+
*/ export function isOffenseUncontroversial(offense) {
|
|
9
|
+
return offense === OffenseType.PROPOSED_INSUFFICIENT_ATTESTATIONS || offense === OffenseType.PROPOSED_INCORRECT_ATTESTATIONS || offense === OffenseType.ATTESTED_DESCENDANT_OF_INVALID;
|
|
10
|
+
}
|
|
11
|
+
/** Extracts offense identifiers (validator, epoch, offense type) from an Empire-based SlashPayload */ export function getOffenseIdentifiersFromPayload(payload) {
|
|
12
|
+
return payload.slashes.flatMap((slash)=>slash.offenses.map((o)=>({
|
|
13
|
+
validator: slash.validator,
|
|
14
|
+
offenseType: o.offenseType,
|
|
15
|
+
epochOrSlot: o.epochOrSlot
|
|
16
|
+
})));
|
|
17
|
+
}
|
|
18
|
+
/** Creates ValidatorSlashes used to create an Empire-based SlashPayload from a set of Offenses */ export function offensesToValidatorSlash(offenses) {
|
|
19
|
+
return offenses.map((offense)=>({
|
|
20
|
+
validator: offense.validator,
|
|
21
|
+
amount: offense.amount,
|
|
22
|
+
offenses: [
|
|
23
|
+
{
|
|
24
|
+
epochOrSlot: offense.epochOrSlot,
|
|
25
|
+
offenseType: offense.offenseType
|
|
26
|
+
}
|
|
27
|
+
]
|
|
28
|
+
}));
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Sorts offense data by:
|
|
32
|
+
* - Uncontroversial offenses first
|
|
33
|
+
* - Slash amount (descending)
|
|
34
|
+
* - Epoch or slot (ascending, ie oldest first)
|
|
35
|
+
* - Validator address (ascending)
|
|
36
|
+
* - Offense type (descending)
|
|
37
|
+
*/ export function offenseDataComparator(a, b) {
|
|
38
|
+
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);
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Returns the first round in which the offense is eligible for being included in an Empire-based slash payload.
|
|
42
|
+
* Should be equal to to the first round that starts strictly after the offense becomes detectable.
|
|
43
|
+
*/ export function getFirstEligibleRoundForOffense(offense, constants) {
|
|
44
|
+
// TODO(palla/slash): Check for off-by-ones
|
|
45
|
+
switch(offense.offenseType){
|
|
46
|
+
// Inactivity is detected at the end of the epoch, so we flag it as detected in the first fresh round for the next epoch
|
|
47
|
+
case OffenseType.INACTIVITY:
|
|
48
|
+
{
|
|
49
|
+
const epoch = offense.epochOrSlot;
|
|
50
|
+
const detectedEpoch = EpochNumber.fromBigInt(epoch + 1n);
|
|
51
|
+
return getRoundsForEpoch(detectedEpoch, constants)[0] + 1n;
|
|
52
|
+
}
|
|
53
|
+
// These offenses are detected once an epoch is pruned, which happens after the proof submission window
|
|
54
|
+
case OffenseType.VALID_EPOCH_PRUNED:
|
|
55
|
+
case OffenseType.DATA_WITHHOLDING:
|
|
56
|
+
{
|
|
57
|
+
// TODO(palla/slash): Check for off-by-ones especially here
|
|
58
|
+
const epoch = offense.epochOrSlot;
|
|
59
|
+
const detectedEpoch = EpochNumber.fromBigInt(epoch + BigInt(constants.proofSubmissionEpochs));
|
|
60
|
+
return getRoundsForEpoch(detectedEpoch, constants)[0] + 1n;
|
|
61
|
+
}
|
|
62
|
+
// These offenses are detected immediately in the slot they occur, so we assume they are detected in the first round for the following slot
|
|
63
|
+
case OffenseType.PROPOSED_INSUFFICIENT_ATTESTATIONS:
|
|
64
|
+
case OffenseType.PROPOSED_INCORRECT_ATTESTATIONS:
|
|
65
|
+
case OffenseType.ATTESTED_DESCENDANT_OF_INVALID:
|
|
66
|
+
case OffenseType.BROADCASTED_INVALID_BLOCK_PROPOSAL:
|
|
67
|
+
{
|
|
68
|
+
const slot = offense.epochOrSlot;
|
|
69
|
+
const detectedSlot = SlotNumber.fromBigInt(slot + 1n);
|
|
70
|
+
return getRoundForSlot(detectedSlot, constants).round + 1n;
|
|
71
|
+
}
|
|
72
|
+
// Assume these are epoch-based offenses, even though we should never have to process these
|
|
73
|
+
case OffenseType.UNKNOWN:
|
|
74
|
+
{
|
|
75
|
+
const epoch = offense.epochOrSlot;
|
|
76
|
+
const detectedEpoch = EpochNumber.fromBigInt(epoch + 1n);
|
|
77
|
+
return getRoundsForEpoch(detectedEpoch, constants)[0] + 1n;
|
|
78
|
+
}
|
|
79
|
+
default:
|
|
80
|
+
{
|
|
81
|
+
const _ = offense.offenseType;
|
|
82
|
+
throw new Error(`Unknown offense type: ${offense.offenseType}`);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { EpochNumber, SlotNumber } from '@aztec/foundation/branded-types';
|
|
2
|
+
import { type L1RollupConstants } from '../epoch-helpers/index.js';
|
|
3
|
+
import type { SlasherConfig } from '../interfaces/slasher.js';
|
|
4
|
+
import { type Offense, OffenseType } from './types.js';
|
|
5
|
+
/** Returns the voting round number and voting slot within the round for a given L2 slot. */
|
|
6
|
+
export declare function getRoundForSlot(slot: SlotNumber, constants: {
|
|
7
|
+
slashingRoundSize: number;
|
|
8
|
+
}): {
|
|
9
|
+
round: bigint;
|
|
10
|
+
votingSlot: SlotNumber;
|
|
11
|
+
};
|
|
12
|
+
/** Returns the voting round(s) lower and upper bounds (inclusive) covered by the given epoch */
|
|
13
|
+
export declare function getRoundsForEpoch(epoch: EpochNumber, constants: {
|
|
14
|
+
slashingRoundSize: number;
|
|
15
|
+
epochDuration: number;
|
|
16
|
+
}): [bigint, bigint];
|
|
17
|
+
/** Returns the epochs spanned during a given slashing round */
|
|
18
|
+
export declare function getEpochsForRound(round: bigint, constants: {
|
|
19
|
+
slashingRoundSize: number;
|
|
20
|
+
epochDuration: number;
|
|
21
|
+
}): EpochNumber[];
|
|
22
|
+
/** Reads the configured penalty for a given offense type from a slasher config struct */
|
|
23
|
+
export declare function getPenaltyForOffense(offense: OffenseType, config: Pick<SlasherConfig, 'slashAttestDescendantOfInvalidPenalty' | 'slashBroadcastedInvalidBlockPenalty' | 'slashPrunePenalty' | 'slashDataWithholdingPenalty' | 'slashUnknownPenalty' | 'slashInactivityPenalty' | 'slashProposeInvalidAttestationsPenalty'>): bigint;
|
|
24
|
+
/** Returns whether the `epochOrSlot` field for an offense references an epoch or a slot */
|
|
25
|
+
export declare function getTimeUnitForOffense(offense: OffenseType): 'epoch' | 'slot';
|
|
26
|
+
/** Returns the slot for a given offense. If the offense references an epoch, returns the first slot of the epoch. */
|
|
27
|
+
export declare function getSlotForOffense(offense: Pick<Offense, 'epochOrSlot' | 'offenseType'>, constants: Pick<L1RollupConstants, 'epochDuration'>): SlotNumber;
|
|
28
|
+
/** Returns the epoch for a given offense. If the offense type or epoch is not defined, returns undefined. */
|
|
29
|
+
export declare function getEpochForOffense(offense: Pick<Offense, 'epochOrSlot' | 'offenseType'>, constants: Pick<L1RollupConstants, 'epochDuration'>): bigint;
|
|
30
|
+
export declare function getEpochForOffense(offense: Partial<Pick<Offense, 'epochOrSlot' | 'offenseType'>>, constants: Pick<L1RollupConstants, 'epochDuration'>): bigint | undefined;
|
|
31
|
+
/** Returns the slashing round in which a given offense occurred. */
|
|
32
|
+
export declare function getRoundForOffense(offense: Pick<Offense, 'epochOrSlot' | 'offenseType'>, constants: {
|
|
33
|
+
slashingRoundSize: number;
|
|
34
|
+
epochDuration: number;
|
|
35
|
+
}): bigint;
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscGVycy5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NsYXNoaW5nL2hlbHBlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxVQUFVLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUUxRSxPQUFPLEVBQUUsS0FBSyxpQkFBaUIsRUFBd0MsTUFBTSwyQkFBMkIsQ0FBQztBQUN6RyxPQUFPLEtBQUssRUFBRSxhQUFhLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsS0FBSyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sWUFBWSxDQUFDO0FBRXZELDRGQUE0RjtBQUM1Rix3QkFBZ0IsZUFBZSxDQUM3QixJQUFJLEVBQUUsVUFBVSxFQUNoQixTQUFTLEVBQUU7SUFBRSxpQkFBaUIsRUFBRSxNQUFNLENBQUE7Q0FBRSxHQUN2QztJQUFFLEtBQUssRUFBRSxNQUFNLENBQUM7SUFBQyxVQUFVLEVBQUUsVUFBVSxDQUFBO0NBQUUsQ0FNM0M7QUFFRCxnR0FBZ0c7QUFDaEcsd0JBQWdCLGlCQUFpQixDQUMvQixLQUFLLEVBQUUsV0FBVyxFQUNsQixTQUFTLEVBQUU7SUFBRSxpQkFBaUIsRUFBRSxNQUFNLENBQUM7SUFBQyxhQUFhLEVBQUUsTUFBTSxDQUFBO0NBQUUsR0FDOUQsQ0FBQyxNQUFNLEVBQUUsTUFBTSxDQUFDLENBS2xCO0FBRUQsK0RBQStEO0FBQy9ELHdCQUFnQixpQkFBaUIsQ0FDL0IsS0FBSyxFQUFFLE1BQU0sRUFDYixTQUFTLEVBQUU7SUFBRSxpQkFBaUIsRUFBRSxNQUFNLENBQUM7SUFBQyxhQUFhLEVBQUUsTUFBTSxDQUFBO0NBQUUsR0FDOUQsV0FBVyxFQUFFLENBVWY7QUFFRCx5RkFBeUY7QUFDekYsd0JBQWdCLG9CQUFvQixDQUNsQyxPQUFPLEVBQUUsV0FBVyxFQUNwQixNQUFNLEVBQUUsSUFBSSxDQUNWLGFBQWEsRUFDWCx1Q0FBdUMsR0FDdkMscUNBQXFDLEdBQ3JDLG1CQUFtQixHQUNuQiw2QkFBNkIsR0FDN0IscUJBQXFCLEdBQ3JCLHdCQUF3QixHQUN4Qix3Q0FBd0MsQ0FDM0MsVUF1QkY7QUFFRCwyRkFBMkY7QUFDM0Ysd0JBQWdCLHFCQUFxQixDQUFDLE9BQU8sRUFBRSxXQUFXLEdBQUcsT0FBTyxHQUFHLE1BQU0sQ0FpQjVFO0FBRUQscUhBQXFIO0FBQ3JILHdCQUFnQixpQkFBaUIsQ0FDL0IsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUUsYUFBYSxHQUFHLGFBQWEsQ0FBQyxFQUNyRCxTQUFTLEVBQUUsSUFBSSxDQUFDLGlCQUFpQixFQUFFLGVBQWUsQ0FBQyxHQUNsRCxVQUFVLENBS1o7QUFFRCw2R0FBNkc7QUFDN0csd0JBQWdCLGtCQUFrQixDQUNoQyxPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU8sRUFBRSxhQUFhLEdBQUcsYUFBYSxDQUFDLEVBQ3JELFNBQVMsRUFBRSxJQUFJLENBQUMsaUJBQWlCLEVBQUUsZUFBZSxDQUFDLEdBQ2xELE1BQU0sQ0FBQztBQUNWLHdCQUFnQixrQkFBa0IsQ0FDaEMsT0FBTyxFQUFFLE9BQU8sQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLGFBQWEsR0FBRyxhQUFhLENBQUMsQ0FBQyxFQUM5RCxTQUFTLEVBQUUsSUFBSSxDQUFDLGlCQUFpQixFQUFFLGVBQWUsQ0FBQyxHQUNsRCxNQUFNLEdBQUcsU0FBUyxDQUFDO0FBWXRCLG9FQUFvRTtBQUNwRSx3QkFBZ0Isa0JBQWtCLENBQ2hDLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTyxFQUFFLGFBQWEsR0FBRyxhQUFhLENBQUMsRUFDckQsU0FBUyxFQUFFO0lBQUUsaUJBQWlCLEVBQUUsTUFBTSxDQUFDO0lBQUMsYUFBYSxFQUFFLE1BQU0sQ0FBQTtDQUFFLEdBQzlELE1BQU0sQ0FHUiJ9
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../../src/slashing/helpers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAE1E,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,UAAU,EAChB,SAAS,EAAE;IAAE,iBAAiB,EAAE,MAAM,CAAA;CAAE,GACvC;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,UAAU,EAAE,UAAU,CAAA;CAAE,CAM3C;AAED,gGAAgG;AAChG,wBAAgB,iBAAiB,CAC/B,KAAK,EAAE,WAAW,EAClB,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,WAAW,EAAE,CAUf;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,UAAU,CAKZ;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,91 @@
|
|
|
1
|
+
import { EpochNumber, SlotNumber } from '@aztec/foundation/branded-types';
|
|
2
|
+
import { getEpochAtSlot, getSlotRangeForEpoch } from '../epoch-helpers/index.js';
|
|
3
|
+
import { OffenseType } from './types.js';
|
|
4
|
+
/** Returns the voting round number and voting slot within the round for a given L2 slot. */ export function getRoundForSlot(slot, constants) {
|
|
5
|
+
const roundSize = BigInt(constants.slashingRoundSize);
|
|
6
|
+
const slotBigInt = BigInt(slot);
|
|
7
|
+
const round = slotBigInt / roundSize;
|
|
8
|
+
const votingSlot = SlotNumber.fromBigInt(slotBigInt % roundSize);
|
|
9
|
+
return {
|
|
10
|
+
round,
|
|
11
|
+
votingSlot
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
/** Returns the voting round(s) lower and upper bounds (inclusive) covered by the given epoch */ export function getRoundsForEpoch(epoch, constants) {
|
|
15
|
+
const [start, end] = getSlotRangeForEpoch(epoch, constants);
|
|
16
|
+
const startRound = getRoundForSlot(start, constants).round;
|
|
17
|
+
const endRound = getRoundForSlot(end, constants).round;
|
|
18
|
+
return [
|
|
19
|
+
startRound,
|
|
20
|
+
endRound
|
|
21
|
+
];
|
|
22
|
+
}
|
|
23
|
+
/** Returns the epochs spanned during a given slashing round */ export function getEpochsForRound(round, constants) {
|
|
24
|
+
const epochs = [];
|
|
25
|
+
const firstSlot = SlotNumber.fromBigInt(round * BigInt(constants.slashingRoundSize));
|
|
26
|
+
const lastSlot = SlotNumber(firstSlot + constants.slashingRoundSize - 1);
|
|
27
|
+
const startEpoch = getEpochAtSlot(firstSlot, constants);
|
|
28
|
+
const endEpoch = getEpochAtSlot(lastSlot, constants);
|
|
29
|
+
for(let epoch = startEpoch; epoch <= endEpoch; epoch = EpochNumber(epoch + 1)){
|
|
30
|
+
epochs.push(epoch);
|
|
31
|
+
}
|
|
32
|
+
return epochs;
|
|
33
|
+
}
|
|
34
|
+
/** Reads the configured penalty for a given offense type from a slasher config struct */ export function getPenaltyForOffense(offense, config) {
|
|
35
|
+
switch(offense){
|
|
36
|
+
case OffenseType.VALID_EPOCH_PRUNED:
|
|
37
|
+
return config.slashPrunePenalty;
|
|
38
|
+
case OffenseType.DATA_WITHHOLDING:
|
|
39
|
+
return config.slashDataWithholdingPenalty;
|
|
40
|
+
case OffenseType.INACTIVITY:
|
|
41
|
+
return config.slashInactivityPenalty;
|
|
42
|
+
case OffenseType.PROPOSED_INSUFFICIENT_ATTESTATIONS:
|
|
43
|
+
case OffenseType.PROPOSED_INCORRECT_ATTESTATIONS:
|
|
44
|
+
return config.slashProposeInvalidAttestationsPenalty;
|
|
45
|
+
case OffenseType.ATTESTED_DESCENDANT_OF_INVALID:
|
|
46
|
+
return config.slashAttestDescendantOfInvalidPenalty;
|
|
47
|
+
case OffenseType.BROADCASTED_INVALID_BLOCK_PROPOSAL:
|
|
48
|
+
return config.slashBroadcastedInvalidBlockPenalty;
|
|
49
|
+
case OffenseType.UNKNOWN:
|
|
50
|
+
return config.slashUnknownPenalty;
|
|
51
|
+
default:
|
|
52
|
+
{
|
|
53
|
+
const _exhaustiveCheck = offense;
|
|
54
|
+
throw new Error(`Unknown offense type: ${_exhaustiveCheck}`);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
/** Returns whether the `epochOrSlot` field for an offense references an epoch or a slot */ export function getTimeUnitForOffense(offense) {
|
|
59
|
+
switch(offense){
|
|
60
|
+
case OffenseType.ATTESTED_DESCENDANT_OF_INVALID:
|
|
61
|
+
case OffenseType.BROADCASTED_INVALID_BLOCK_PROPOSAL:
|
|
62
|
+
case OffenseType.PROPOSED_INCORRECT_ATTESTATIONS:
|
|
63
|
+
case OffenseType.PROPOSED_INSUFFICIENT_ATTESTATIONS:
|
|
64
|
+
return 'slot';
|
|
65
|
+
case OffenseType.INACTIVITY:
|
|
66
|
+
case OffenseType.DATA_WITHHOLDING:
|
|
67
|
+
case OffenseType.UNKNOWN:
|
|
68
|
+
case OffenseType.VALID_EPOCH_PRUNED:
|
|
69
|
+
return 'epoch';
|
|
70
|
+
default:
|
|
71
|
+
{
|
|
72
|
+
const _exhaustiveCheck = offense;
|
|
73
|
+
throw new Error(`Unknown offense type: ${_exhaustiveCheck}`);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
/** 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) {
|
|
78
|
+
const { epochOrSlot, offenseType } = offense;
|
|
79
|
+
return getTimeUnitForOffense(offenseType) === 'epoch' ? SlotNumber.fromBigInt(epochOrSlot * BigInt(constants.epochDuration)) : SlotNumber.fromBigInt(epochOrSlot);
|
|
80
|
+
}
|
|
81
|
+
export function getEpochForOffense(offense, constants) {
|
|
82
|
+
const { epochOrSlot, offenseType } = offense;
|
|
83
|
+
if (epochOrSlot === undefined || offenseType === undefined) {
|
|
84
|
+
return undefined;
|
|
85
|
+
}
|
|
86
|
+
return getTimeUnitForOffense(offenseType) === 'epoch' ? epochOrSlot : epochOrSlot / BigInt(constants.epochDuration);
|
|
87
|
+
}
|
|
88
|
+
/** Returns the slashing round in which a given offense occurred. */ export function getRoundForOffense(offense, constants) {
|
|
89
|
+
const slot = getSlotForOffense(offense, constants);
|
|
90
|
+
return getRoundForSlot(slot, constants).round;
|
|
91
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export * from './types.js';
|
|
2
|
+
export * from './interfaces.js';
|
|
3
|
+
export * from './helpers.js';
|
|
4
|
+
export * from './empire.js';
|
|
5
|
+
export * from './tally.js';
|
|
6
|
+
export * from './serialization.js';
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zbGFzaGluZy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsb0JBQW9CLENBQUMifQ==
|
|
@@ -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,12 @@
|
|
|
1
|
+
import type { SlotNumber } from '@aztec/foundation/branded-types';
|
|
2
|
+
import type { ProposerSlashAction } from './types.js';
|
|
3
|
+
export interface ProposerSlashActionProvider {
|
|
4
|
+
/**
|
|
5
|
+
* Returns the actions to take for the proposer in the current slot.
|
|
6
|
+
* This can include creating a slash payload or other actions.
|
|
7
|
+
* @param slotNumber - The current slot number
|
|
8
|
+
* @returns The actions to take
|
|
9
|
+
*/
|
|
10
|
+
getProposerActions(slotNumber: SlotNumber): Promise<ProposerSlashAction[]>;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJmYWNlcy5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NsYXNoaW5nL2ludGVyZmFjZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLEVBQUUsVUFBVSxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFFbEUsT0FBTyxLQUFLLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFFdEQsTUFBTSxXQUFXLDJCQUEyQjtJQUMxQzs7Ozs7T0FLRztJQUNILGtCQUFrQixDQUFDLFVBQVUsRUFBRSxVQUFVLEdBQUcsT0FBTyxDQUFDLG1CQUFtQixFQUFFLENBQUMsQ0FBQztDQUM1RSJ9
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"interfaces.d.ts","sourceRoot":"","sources":["../../src/slashing/interfaces.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAElE,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAEtD,MAAM,WAAW,2BAA2B;IAC1C;;;;;OAKG;IACH,kBAAkB,CAAC,UAAU,EAAE,UAAU,GAAG,OAAO,CAAC,mBAAmB,EAAE,CAAC,CAAC;CAC5E"}
|
|
@@ -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=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VyaWFsaXphdGlvbi5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NsYXNoaW5nL3NlcmlhbGl6YXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBSUEsT0FBTyxLQUFLLEVBQ1YsT0FBTyxFQUVQLFlBQVksRUFDWixpQkFBaUIsRUFHbEIsTUFBTSxZQUFZLENBQUM7QUFFcEIsd0JBQWdCLGdCQUFnQixDQUFDLE9BQU8sRUFBRSxPQUFPLEdBQUcsTUFBTSxDQU96RDtBQUVELHdCQUFnQixrQkFBa0IsQ0FBQyxNQUFNLEVBQUUsTUFBTSxHQUFHLE9BQU8sQ0FRMUQ7QUFpQ0Qsd0JBQWdCLHFCQUFxQixDQUFDLE9BQU8sRUFBRSxZQUFZLEdBQUcsTUFBTSxDQU9uRTtBQUVELHdCQUFnQix1QkFBdUIsQ0FBQyxNQUFNLEVBQUUsTUFBTSxHQUFHLFlBQVksQ0FPcEU7QUFFRCx3QkFBZ0IsMEJBQTBCLENBQUMsT0FBTyxFQUFFLGlCQUFpQixHQUFHLE1BQU0sQ0FTN0U7QUFFRCx3QkFBZ0IsNEJBQTRCLENBQUMsTUFBTSxFQUFFLE1BQU0sR0FBRyxpQkFBaUIsQ0FVOUUifQ==
|
|
@@ -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=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFsbHkuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zbGFzaGluZy90YWxseS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDM0QsT0FBTyxLQUFLLEVBQUUsU0FBUyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFHekQsT0FBTyxLQUFLLEVBQUUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sWUFBWSxDQUFDO0FBRTlEOzs7Ozs7O0dBT0c7QUFDSCx3QkFBZ0Isa0NBQWtDLENBQ2hELFFBQVEsRUFBRSxTQUFTLENBQUMsT0FBTyxFQUFFLGFBQWEsQ0FBQyxFQUFFLEVBQzdDLFVBQVUsRUFBRSxVQUFVLEVBQUUsRUFBRSxFQUMxQixtQkFBbUIsRUFBRSxNQUFNLEVBQUUsRUFDN0IsUUFBUSxFQUFFO0lBQ1IsZUFBZSxFQUFFLENBQUMsTUFBTSxFQUFFLE1BQU0sRUFBRSxNQUFNLENBQUMsQ0FBQztJQUMxQyxhQUFhLEVBQUUsTUFBTSxDQUFDO0NBQ3ZCLEdBQ0Esa0JBQWtCLEVBQUUsQ0EyQnRCO0FBZUQ7Ozs7O0dBS0c7QUFDSCx3QkFBZ0IseUJBQXlCLENBQUMsS0FBSyxFQUFFLGtCQUFrQixFQUFFLEdBQUcsTUFBTSxDQWU3RSJ9
|
|
@@ -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
|
+
}
|