@aztec/stdlib 5.0.0-private.20260319 → 5.0.0-rc.1
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 +142 -1081
- package/dest/abi/abi.d.ts.map +1 -1
- package/dest/abi/abi.js +41 -18
- package/dest/abi/authorization_selector.d.ts +4 -7
- package/dest/abi/authorization_selector.d.ts.map +1 -1
- package/dest/abi/buffer.d.ts +14 -4
- package/dest/abi/buffer.d.ts.map +1 -1
- package/dest/abi/buffer.js +25 -4
- package/dest/abi/contract_artifact.d.ts +14 -1
- package/dest/abi/contract_artifact.d.ts.map +1 -1
- package/dest/abi/contract_artifact.js +31 -7
- package/dest/abi/decoder.d.ts +5 -44
- package/dest/abi/decoder.d.ts.map +1 -1
- package/dest/abi/decoder.js +12 -67
- package/dest/abi/encoder.d.ts +1 -1
- package/dest/abi/encoder.d.ts.map +1 -1
- package/dest/abi/encoder.js +32 -6
- package/dest/abi/event_selector.d.ts +4 -7
- package/dest/abi/event_selector.d.ts.map +1 -1
- package/dest/abi/function_call.d.ts +7 -25
- package/dest/abi/function_call.d.ts.map +1 -1
- package/dest/abi/function_selector.d.ts +3 -6
- package/dest/abi/function_selector.d.ts.map +1 -1
- package/dest/abi/function_selector.js +2 -4
- package/dest/abi/function_signature_decoder.d.ts +43 -0
- package/dest/abi/function_signature_decoder.d.ts.map +1 -0
- package/dest/abi/function_signature_decoder.js +66 -0
- package/dest/abi/index.d.ts +2 -1
- package/dest/abi/index.d.ts.map +1 -1
- package/dest/abi/index.js +1 -0
- package/dest/abi/note_selector.d.ts +4 -7
- package/dest/abi/note_selector.d.ts.map +1 -1
- package/dest/abi/note_selector.js +1 -3
- package/dest/abi/selector.d.ts +2 -2
- package/dest/abi/selector.d.ts.map +1 -1
- package/dest/abi/selector.js +1 -1
- package/dest/abi/utils.d.ts +1 -1
- package/dest/abi/utils.d.ts.map +1 -1
- package/dest/abi/utils.js +1 -1
- package/dest/auth_witness/auth_witness.d.ts +2 -2
- package/dest/auth_witness/auth_witness.d.ts.map +1 -1
- package/dest/avm/avm.d.ts +1756 -10463
- package/dest/avm/avm.d.ts.map +1 -1
- package/dest/avm/avm.js +6 -3
- package/dest/avm/avm_accumulated_data.d.ts +22 -86
- package/dest/avm/avm_accumulated_data.d.ts.map +1 -1
- package/dest/avm/avm_circuit_public_inputs.d.ts +180 -932
- package/dest/avm/avm_circuit_public_inputs.d.ts.map +1 -1
- package/dest/avm/avm_proving_request.d.ts +653 -5446
- package/dest/avm/avm_proving_request.d.ts.map +1 -1
- package/dest/avm/message_pack.js +12 -3
- package/dest/avm/public_data_write.d.ts +6 -12
- package/dest/avm/public_data_write.d.ts.map +1 -1
- package/dest/avm/revert_code.d.ts +5 -21
- package/dest/avm/revert_code.d.ts.map +1 -1
- package/dest/avm/revert_code.js +12 -30
- package/dest/aztec-address/index.d.ts +8 -8
- package/dest/aztec-address/index.d.ts.map +1 -1
- package/dest/aztec-address/index.js +9 -6
- package/dest/block/attestation_info.d.ts +3 -2
- package/dest/block/attestation_info.d.ts.map +1 -1
- package/dest/block/attestation_info.js +7 -5
- package/dest/block/block_data.d.ts +13 -38
- package/dest/block/block_data.d.ts.map +1 -1
- package/dest/block/block_data.js +2 -2
- package/dest/block/block_hash.d.ts +11 -10
- package/dest/block/block_hash.d.ts.map +1 -1
- package/dest/block/block_hash.js +10 -9
- package/dest/block/block_parameter.d.ts +37 -4
- package/dest/block/block_parameter.d.ts.map +1 -1
- package/dest/block/block_parameter.js +53 -2
- package/dest/block/in_block.d.ts +5 -24
- package/dest/block/in_block.d.ts.map +1 -1
- package/dest/block/index.d.ts +1 -2
- package/dest/block/index.d.ts.map +1 -1
- package/dest/block/index.js +0 -1
- package/dest/block/l2_block.d.ts +13 -41
- package/dest/block/l2_block.d.ts.map +1 -1
- package/dest/block/l2_block_info.d.ts +10 -29
- package/dest/block/l2_block_info.d.ts.map +1 -1
- package/dest/block/l2_block_info.js +6 -5
- package/dest/block/l2_block_source.d.ts +216 -357
- package/dest/block/l2_block_source.d.ts.map +1 -1
- package/dest/block/l2_block_source.js +67 -1
- package/dest/block/l2_block_stream/interfaces.d.ts +46 -7
- package/dest/block/l2_block_stream/interfaces.d.ts.map +1 -1
- package/dest/block/l2_block_stream/l2_block_stream.d.ts +2 -2
- package/dest/block/l2_block_stream/l2_block_stream.d.ts.map +1 -1
- package/dest/block/l2_block_stream/l2_block_stream.js +57 -21
- package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts +8 -12
- package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts.map +1 -1
- package/dest/block/l2_block_stream/l2_tips_memory_store.js +11 -32
- package/dest/block/l2_block_stream/l2_tips_store_base.d.ts +12 -18
- package/dest/block/l2_block_stream/l2_tips_store_base.d.ts.map +1 -1
- package/dest/block/l2_block_stream/l2_tips_store_base.js +66 -40
- package/dest/block/proposal/attestations_and_signers.d.ts +19 -30
- package/dest/block/proposal/attestations_and_signers.d.ts.map +1 -1
- package/dest/block/proposal/attestations_and_signers.js +26 -18
- package/dest/block/proposal/committee_attestation.d.ts +6 -12
- package/dest/block/proposal/committee_attestation.d.ts.map +1 -1
- package/dest/block/test/l2_tips_store_test_suite.d.ts +1 -1
- package/dest/block/test/l2_tips_store_test_suite.d.ts.map +1 -1
- package/dest/block/test/l2_tips_store_test_suite.js +202 -33
- package/dest/checkpoint/checkpoint.d.ts +30 -96
- package/dest/checkpoint/checkpoint.d.ts.map +1 -1
- package/dest/checkpoint/checkpoint.js +11 -3
- package/dest/checkpoint/checkpoint_data.d.ts +68 -91
- package/dest/checkpoint/checkpoint_data.d.ts.map +1 -1
- package/dest/checkpoint/checkpoint_data.js +12 -0
- package/dest/checkpoint/checkpoint_info.d.ts +7 -23
- package/dest/checkpoint/checkpoint_info.d.ts.map +1 -1
- package/dest/checkpoint/checkpoint_reexecution_tracker.d.ts +60 -0
- package/dest/checkpoint/checkpoint_reexecution_tracker.d.ts.map +1 -0
- package/dest/checkpoint/checkpoint_reexecution_tracker.js +108 -0
- package/dest/checkpoint/digest.d.ts +18 -0
- package/dest/checkpoint/digest.d.ts.map +1 -0
- package/dest/checkpoint/digest.js +12 -0
- package/dest/checkpoint/index.d.ts +4 -1
- package/dest/checkpoint/index.d.ts.map +1 -1
- package/dest/checkpoint/index.js +3 -0
- package/dest/checkpoint/previous_checkpoint_out_hashes.d.ts +33 -0
- package/dest/checkpoint/previous_checkpoint_out_hashes.d.ts.map +1 -0
- package/dest/checkpoint/previous_checkpoint_out_hashes.js +45 -0
- package/dest/checkpoint/published_checkpoint.d.ts +42 -194
- package/dest/checkpoint/published_checkpoint.d.ts.map +1 -1
- package/dest/checkpoint/validate.d.ts +11 -3
- package/dest/checkpoint/validate.d.ts.map +1 -1
- package/dest/checkpoint/validate.js +9 -6
- package/dest/config/chain-config.d.ts +4 -9
- package/dest/config/chain-config.d.ts.map +1 -1
- package/dest/config/chain-config.js +13 -12
- package/dest/config/index.d.ts +2 -2
- package/dest/config/index.d.ts.map +1 -1
- package/dest/config/index.js +1 -1
- package/dest/config/network-consensus-config.d.ts +72 -0
- package/dest/config/network-consensus-config.d.ts.map +1 -0
- package/dest/config/network-consensus-config.js +231 -0
- package/dest/config/sequencer-config.d.ts +7 -3
- package/dest/config/sequencer-config.d.ts.map +1 -1
- package/dest/config/sequencer-config.js +38 -5
- package/dest/contract/complete_address.d.ts +3 -2
- package/dest/contract/complete_address.d.ts.map +1 -1
- package/dest/contract/complete_address.js +6 -2
- package/dest/contract/contract_address.d.ts +5 -5
- package/dest/contract/contract_address.d.ts.map +1 -1
- package/dest/contract/contract_address.js +5 -4
- package/dest/contract/contract_deployment_data.d.ts +15 -61
- package/dest/contract/contract_deployment_data.d.ts.map +1 -1
- package/dest/contract/contract_instance.d.ts +4 -2
- package/dest/contract/contract_instance.d.ts.map +1 -1
- package/dest/contract/contract_instance.js +10 -3
- package/dest/contract/index.d.ts +1 -3
- package/dest/contract/index.d.ts.map +1 -1
- package/dest/contract/index.js +0 -2
- package/dest/contract/interfaces/contract_class.d.ts +17 -241
- package/dest/contract/interfaces/contract_class.d.ts.map +1 -1
- package/dest/contract/interfaces/contract_class.js +1 -28
- package/dest/contract/interfaces/contract_instance.d.ts +41 -95
- package/dest/contract/interfaces/contract_instance.d.ts.map +1 -1
- package/dest/contract/interfaces/contract_instance.js +4 -2
- package/dest/contract/interfaces/contract_instance_update.d.ts +6 -26
- package/dest/contract/interfaces/contract_instance_update.d.ts.map +1 -1
- package/dest/contract/interfaces/node-info.d.ts +11 -1
- package/dest/contract/interfaces/node-info.d.ts.map +1 -1
- package/dest/contract/interfaces/node-info.js +7 -1
- package/dest/contract/interfaces/protocol_contract_addresses.d.ts +2 -12
- package/dest/contract/interfaces/protocol_contract_addresses.d.ts.map +1 -1
- package/dest/contract/private_function.d.ts +1 -1
- package/dest/contract/private_function.d.ts.map +1 -1
- package/dest/contract/private_function.js +2 -4
- package/dest/database-version/database_version.d.ts +5 -11
- package/dest/database-version/database_version.d.ts.map +1 -1
- package/dest/database-version/version_manager.d.ts +6 -2
- package/dest/database-version/version_manager.d.ts.map +1 -1
- package/dest/database-version/version_manager.js +12 -1
- package/dest/deserialization/index.d.ts +35 -3
- package/dest/deserialization/index.d.ts.map +1 -1
- package/dest/deserialization/index.js +32 -1
- package/dest/epoch-helpers/index.d.ts +10 -22
- package/dest/epoch-helpers/index.d.ts.map +1 -1
- package/dest/epoch-helpers/index.js +12 -0
- package/dest/file-store/factory.d.ts +4 -3
- package/dest/file-store/factory.d.ts.map +1 -1
- package/dest/file-store/factory.js +2 -2
- package/dest/file-store/http.d.ts +9 -2
- package/dest/file-store/http.d.ts.map +1 -1
- package/dest/file-store/http.js +20 -9
- package/dest/file-store/index.d.ts +2 -1
- package/dest/file-store/index.d.ts.map +1 -1
- package/dest/gas/fee_math.d.ts +49 -0
- package/dest/gas/fee_math.d.ts.map +1 -0
- package/dest/gas/fee_math.js +80 -0
- package/dest/gas/gas.d.ts +9 -14
- package/dest/gas/gas.d.ts.map +1 -1
- package/dest/gas/gas.js +6 -3
- package/dest/gas/gas_fees.d.ts +13 -14
- package/dest/gas/gas_fees.d.ts.map +1 -1
- package/dest/gas/gas_fees.js +17 -4
- package/dest/gas/gas_settings.d.ts +60 -86
- package/dest/gas/gas_settings.d.ts.map +1 -1
- package/dest/gas/gas_settings.js +49 -9
- package/dest/gas/index.d.ts +3 -1
- package/dest/gas/index.d.ts.map +1 -1
- package/dest/gas/index.js +2 -0
- package/dest/gas/tx_gas_limits.d.ts +72 -0
- package/dest/gas/tx_gas_limits.d.ts.map +1 -0
- package/dest/gas/tx_gas_limits.js +85 -0
- package/dest/ha-signing/config.d.ts +11 -75
- package/dest/ha-signing/config.d.ts.map +1 -1
- package/dest/ha-signing/config.js +9 -18
- package/dest/ha-signing/index.d.ts +2 -2
- package/dest/ha-signing/index.d.ts.map +1 -1
- package/dest/ha-signing/index.js +1 -1
- package/dest/ha-signing/local_config.d.ts +3 -34
- package/dest/ha-signing/local_config.d.ts.map +1 -1
- package/dest/ha-signing/local_config.js +2 -2
- package/dest/ha-signing/types.d.ts +37 -32
- package/dest/ha-signing/types.d.ts.map +1 -1
- package/dest/ha-signing/types.js +13 -6
- package/dest/hash/hash.d.ts +19 -1
- package/dest/hash/hash.d.ts.map +1 -1
- package/dest/hash/hash.js +39 -2
- package/dest/interfaces/allowed_element.d.ts +4 -28
- package/dest/interfaces/allowed_element.d.ts.map +1 -1
- package/dest/interfaces/api_limit.d.ts +1 -1
- package/dest/interfaces/api_limit.js +1 -1
- package/dest/interfaces/archiver.d.ts +20 -32
- package/dest/interfaces/archiver.d.ts.map +1 -1
- package/dest/interfaces/archiver.js +215 -70
- package/dest/interfaces/aztec-node-admin.d.ts +71 -305
- package/dest/interfaces/aztec-node-admin.d.ts.map +1 -1
- package/dest/interfaces/aztec-node-admin.js +60 -17
- package/dest/interfaces/aztec-node-debug.d.ts +34 -0
- package/dest/interfaces/aztec-node-debug.d.ts.map +1 -0
- package/dest/interfaces/aztec-node-debug.js +29 -0
- package/dest/interfaces/aztec-node.d.ts +156 -112
- package/dest/interfaces/aztec-node.d.ts.map +1 -1
- package/dest/interfaces/aztec-node.js +354 -71
- package/dest/interfaces/block-builder.d.ts +5 -1
- package/dest/interfaces/block-builder.d.ts.map +1 -1
- package/dest/interfaces/block_response.d.ts +90 -0
- package/dest/interfaces/block_response.d.ts.map +1 -0
- package/dest/interfaces/block_response.js +30 -0
- package/dest/interfaces/chain_tips.d.ts +50 -0
- package/dest/interfaces/chain_tips.d.ts.map +1 -0
- package/dest/interfaces/chain_tips.js +11 -0
- package/dest/interfaces/checkpoint_parameter.d.ts +14 -0
- package/dest/interfaces/checkpoint_parameter.d.ts.map +1 -0
- package/dest/interfaces/checkpoint_parameter.js +18 -0
- package/dest/interfaces/checkpoint_response.d.ts +122 -0
- package/dest/interfaces/checkpoint_response.d.ts.map +1 -0
- package/dest/interfaces/checkpoint_response.js +26 -0
- package/dest/interfaces/client.d.ts +9 -2
- package/dest/interfaces/client.d.ts.map +1 -1
- package/dest/interfaces/client.js +7 -1
- package/dest/interfaces/configs.d.ts +63 -134
- package/dest/interfaces/configs.d.ts.map +1 -1
- package/dest/interfaces/configs.js +13 -2
- package/dest/interfaces/get_tx_by_hash_options.d.ts +9 -0
- package/dest/interfaces/get_tx_by_hash_options.d.ts.map +1 -0
- package/dest/interfaces/get_tx_by_hash_options.js +4 -0
- package/dest/interfaces/l1_publish_info.d.ts +29 -0
- package/dest/interfaces/l1_publish_info.d.ts.map +1 -0
- package/dest/interfaces/l1_publish_info.js +26 -0
- package/dest/interfaces/l2_logs_source.d.ts +14 -36
- package/dest/interfaces/l2_logs_source.d.ts.map +1 -1
- package/dest/interfaces/l2_logs_source.js +5 -0
- package/dest/interfaces/merkle_tree_operations.d.ts +4 -3
- package/dest/interfaces/merkle_tree_operations.d.ts.map +1 -1
- package/dest/interfaces/p2p-bootstrap.js +8 -2
- package/dest/interfaces/p2p.d.ts +46 -7
- package/dest/interfaces/p2p.d.ts.map +1 -1
- package/dest/interfaces/p2p.js +41 -6
- package/dest/interfaces/private_kernel_prover.d.ts +62 -2
- package/dest/interfaces/private_kernel_prover.d.ts.map +1 -1
- package/dest/interfaces/prover-agent.d.ts +5 -23
- package/dest/interfaces/prover-agent.d.ts.map +1 -1
- package/dest/interfaces/prover-agent.js +4 -1
- package/dest/interfaces/prover-client.d.ts +7 -29
- package/dest/interfaces/prover-client.d.ts.map +1 -1
- package/dest/interfaces/prover-client.js +0 -3
- package/dest/interfaces/prover-node.d.ts +8 -3
- package/dest/interfaces/prover-node.d.ts.map +1 -1
- package/dest/interfaces/prover-node.js +30 -14
- package/dest/interfaces/proving-job-source.js +24 -4
- package/dest/interfaces/proving-job.d.ts +763 -5814
- package/dest/interfaces/proving-job.d.ts.map +1 -1
- package/dest/interfaces/proving-job.js +1 -1
- package/dest/interfaces/public_storage_override.d.ts +22 -0
- package/dest/interfaces/public_storage_override.d.ts.map +1 -0
- package/dest/interfaces/public_storage_override.js +7 -0
- package/dest/interfaces/server.d.ts +6 -2
- package/dest/interfaces/server.d.ts.map +1 -1
- package/dest/interfaces/server.js +5 -1
- package/dest/interfaces/slasher.d.ts +25 -65
- package/dest/interfaces/slasher.d.ts.map +1 -1
- package/dest/interfaces/slasher.js +8 -4
- package/dest/interfaces/tx_provider.d.ts +6 -1
- package/dest/interfaces/tx_provider.d.ts.map +1 -1
- package/dest/interfaces/validator.d.ts +55 -248
- package/dest/interfaces/validator.d.ts.map +1 -1
- package/dest/interfaces/validator.js +8 -2
- package/dest/interfaces/world_state.d.ts +2 -2
- package/dest/interfaces/world_state.d.ts.map +1 -1
- package/dest/kernel/hints/key_validation_request.d.ts +12 -8
- package/dest/kernel/hints/key_validation_request.d.ts.map +1 -1
- package/dest/kernel/hints/key_validation_request.js +20 -18
- package/dest/kernel/index.d.ts +5 -1
- package/dest/kernel/index.d.ts.map +1 -1
- package/dest/kernel/index.js +4 -0
- package/dest/kernel/log_hash.d.ts +6 -2
- package/dest/kernel/log_hash.d.ts.map +1 -1
- package/dest/kernel/log_hash.js +21 -9
- package/dest/kernel/private_circuit_public_inputs.d.ts +2 -2
- package/dest/kernel/private_circuit_public_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_circuit_public_inputs.d.ts +2 -2
- package/dest/kernel/private_kernel_circuit_public_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_init_2_circuit_private_inputs.d.ts +23 -0
- package/dest/kernel/private_kernel_init_2_circuit_private_inputs.d.ts.map +1 -0
- package/dest/kernel/private_kernel_init_2_circuit_private_inputs.js +35 -0
- package/dest/kernel/private_kernel_init_3_circuit_private_inputs.d.ts +24 -0
- package/dest/kernel/private_kernel_init_3_circuit_private_inputs.d.ts.map +1 -0
- package/dest/kernel/private_kernel_init_3_circuit_private_inputs.js +37 -0
- package/dest/kernel/private_kernel_inner_2_circuit_private_inputs.d.ts +16 -0
- package/dest/kernel/private_kernel_inner_2_circuit_private_inputs.d.ts.map +1 -0
- package/dest/kernel/private_kernel_inner_2_circuit_private_inputs.js +23 -0
- package/dest/kernel/private_kernel_inner_3_circuit_private_inputs.d.ts +17 -0
- package/dest/kernel/private_kernel_inner_3_circuit_private_inputs.d.ts.map +1 -0
- package/dest/kernel/private_kernel_inner_3_circuit_private_inputs.js +25 -0
- package/dest/kernel/private_kernel_prover_output.d.ts +3 -29
- package/dest/kernel/private_kernel_prover_output.d.ts.map +1 -1
- package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts +9 -6
- package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts.map +1 -1
- package/dest/kernel/private_kernel_tail_circuit_public_inputs.js +22 -7
- package/dest/kernel/private_to_avm_accumulated_data.d.ts +25 -69
- package/dest/kernel/private_to_avm_accumulated_data.d.ts.map +1 -1
- package/dest/kernel/private_to_avm_accumulated_data.js +11 -5
- package/dest/kernel/private_to_public_accumulated_data.d.ts +4 -3
- package/dest/kernel/private_to_public_accumulated_data.d.ts.map +1 -1
- package/dest/kernel/private_to_public_accumulated_data.js +6 -3
- package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts +5 -4
- package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts.map +1 -1
- package/dest/kernel/private_to_public_kernel_circuit_public_inputs.js +7 -3
- package/dest/kernel/private_to_rollup_accumulated_data.d.ts +5 -4
- package/dest/kernel/private_to_rollup_accumulated_data.d.ts.map +1 -1
- package/dest/kernel/private_to_rollup_accumulated_data.js +6 -3
- package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts +5 -4
- package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts.map +1 -1
- package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.js +7 -3
- package/dest/kernel/public_call_request.d.ts +15 -30
- package/dest/kernel/public_call_request.d.ts.map +1 -1
- package/dest/kernel/public_call_request.js +16 -7
- package/dest/keys/derivation.d.ts +6 -2
- package/dest/keys/derivation.d.ts.map +1 -1
- package/dest/keys/derivation.js +16 -6
- package/dest/keys/public_key.d.ts +22 -3
- package/dest/keys/public_key.d.ts.map +1 -1
- package/dest/keys/public_key.js +20 -1
- package/dest/keys/public_keys.d.ts +55 -82
- package/dest/keys/public_keys.d.ts.map +1 -1
- package/dest/keys/public_keys.js +102 -74
- package/dest/kv-store/config.d.ts +3 -6
- package/dest/kv-store/config.d.ts.map +1 -1
- package/dest/kv-store/config.js +2 -7
- package/dest/l1-contracts/index.d.ts +2 -2
- package/dest/l1-contracts/index.d.ts.map +1 -1
- package/dest/l1-contracts/index.js +1 -1
- package/dest/logs/app_tagging_secret.d.ts +46 -0
- package/dest/logs/app_tagging_secret.d.ts.map +1 -0
- package/dest/logs/app_tagging_secret.js +109 -0
- package/dest/logs/app_tagging_secret_kind.d.ts +7 -0
- package/dest/logs/app_tagging_secret_kind.d.ts.map +1 -0
- package/dest/logs/app_tagging_secret_kind.js +17 -0
- package/dest/logs/contract_class_log.d.ts +16 -34
- package/dest/logs/contract_class_log.d.ts.map +1 -1
- package/dest/logs/contract_class_log.js +11 -9
- package/dest/logs/index.d.ts +7 -7
- package/dest/logs/index.d.ts.map +1 -1
- package/dest/logs/index.js +6 -6
- package/dest/logs/log_cursor.d.ts +51 -0
- package/dest/logs/log_cursor.d.ts.map +1 -0
- package/dest/logs/log_cursor.js +82 -0
- package/dest/logs/log_result.d.ts +54 -0
- package/dest/logs/log_result.d.ts.map +1 -0
- package/dest/logs/log_result.js +56 -0
- package/dest/logs/logs_query.d.ts +82 -0
- package/dest/logs/logs_query.d.ts.map +1 -0
- package/dest/logs/logs_query.js +50 -0
- package/dest/logs/message_context.d.ts +6 -8
- package/dest/logs/message_context.d.ts.map +1 -1
- package/dest/logs/message_context.js +27 -9
- package/dest/logs/pending_tagged_log.d.ts +2 -3
- package/dest/logs/pending_tagged_log.d.ts.map +1 -1
- package/dest/logs/pending_tagged_log.js +2 -2
- package/dest/logs/pre_tag.d.ts +11 -24
- package/dest/logs/pre_tag.d.ts.map +1 -1
- package/dest/logs/pre_tag.js +2 -2
- package/dest/logs/private_log.d.ts +7 -12
- package/dest/logs/private_log.d.ts.map +1 -1
- package/dest/logs/private_log.js +6 -3
- package/dest/logs/query_all_logs_by_tags.d.ts +24 -0
- package/dest/logs/query_all_logs_by_tags.d.ts.map +1 -0
- package/dest/logs/query_all_logs_by_tags.js +64 -0
- package/dest/logs/shared_secret_derivation.d.ts +11 -10
- package/dest/logs/shared_secret_derivation.d.ts.map +1 -1
- package/dest/logs/shared_secret_derivation.js +15 -9
- package/dest/logs/siloed_tag.d.ts +8 -7
- package/dest/logs/siloed_tag.d.ts.map +1 -1
- package/dest/logs/siloed_tag.js +13 -3
- package/dest/logs/tag.d.ts +5 -6
- package/dest/logs/tag.d.ts.map +1 -1
- package/dest/logs/tag.js +4 -0
- package/dest/logs/tagging_index_range.d.ts +13 -31
- package/dest/logs/tagging_index_range.d.ts.map +1 -1
- package/dest/logs/tagging_index_range.js +2 -2
- package/dest/messaging/append_l1_to_l2_messages.d.ts +9 -0
- package/dest/messaging/append_l1_to_l2_messages.d.ts.map +1 -0
- package/dest/messaging/append_l1_to_l2_messages.js +12 -0
- package/dest/messaging/index.d.ts +2 -1
- package/dest/messaging/index.d.ts.map +1 -1
- package/dest/messaging/index.js +1 -0
- package/dest/messaging/l1_to_l2_message.d.ts +3 -2
- package/dest/messaging/l1_to_l2_message.d.ts.map +1 -1
- package/dest/messaging/l1_to_l2_message.js +11 -13
- package/dest/messaging/l2_to_l1_membership.d.ts +43 -6
- package/dest/messaging/l2_to_l1_membership.d.ts.map +1 -1
- package/dest/messaging/l2_to_l1_membership.js +72 -12
- package/dest/messaging/l2_to_l1_message.d.ts +38 -112
- package/dest/messaging/l2_to_l1_message.d.ts.map +1 -1
- package/dest/messaging/l2_to_l1_message.js +21 -12
- package/dest/noir/index.d.ts +3 -1
- package/dest/noir/index.d.ts.map +1 -1
- package/dest/note/note.d.ts +2 -2
- package/dest/note/note.d.ts.map +1 -1
- package/dest/note/note_dao.d.ts +1 -1
- package/dest/note/note_dao.d.ts.map +1 -1
- package/dest/note/note_dao.js +1 -4
- package/dest/p2p/block_proposal.d.ts +31 -14
- package/dest/p2p/block_proposal.d.ts.map +1 -1
- package/dest/p2p/block_proposal.js +57 -39
- package/dest/p2p/checkpoint_attestation.d.ts +15 -9
- package/dest/p2p/checkpoint_attestation.d.ts.map +1 -1
- package/dest/p2p/checkpoint_attestation.js +23 -24
- package/dest/p2p/checkpoint_proposal.d.ts +35 -16
- package/dest/p2p/checkpoint_proposal.d.ts.map +1 -1
- package/dest/p2p/checkpoint_proposal.js +59 -51
- package/dest/p2p/consensus_payload.d.ts +26 -20
- package/dest/p2p/consensus_payload.d.ts.map +1 -1
- package/dest/p2p/consensus_payload.js +38 -19
- package/dest/p2p/gossipable.d.ts +4 -4
- package/dest/p2p/gossipable.d.ts.map +1 -1
- package/dest/p2p/signature_utils.d.ts +28 -19
- package/dest/p2p/signature_utils.d.ts.map +1 -1
- package/dest/p2p/signature_utils.js +118 -21
- package/dest/p2p/signed_txs.d.ts +15 -13
- package/dest/p2p/signed_txs.d.ts.map +1 -1
- package/dest/p2p/signed_txs.js +26 -24
- package/dest/parity/parity_base_private_inputs.d.ts +8 -4
- package/dest/parity/parity_base_private_inputs.d.ts.map +1 -1
- package/dest/parity/parity_base_private_inputs.js +7 -5
- package/dest/parity/parity_public_inputs.d.ts +8 -4
- package/dest/parity/parity_public_inputs.d.ts.map +1 -1
- package/dest/parity/parity_public_inputs.js +6 -3
- package/dest/parity/parity_root_private_inputs.d.ts +2 -2
- package/dest/parity/parity_root_private_inputs.d.ts.map +1 -1
- package/dest/proofs/chonk_proof.d.ts +57 -7
- package/dest/proofs/chonk_proof.d.ts.map +1 -1
- package/dest/proofs/chonk_proof.js +112 -15
- package/dest/proofs/recursive_proof.d.ts +2 -2
- package/dest/proofs/recursive_proof.d.ts.map +1 -1
- package/dest/rollup/block_headers_hash.d.ts +1 -1
- package/dest/rollup/block_headers_hash.d.ts.map +1 -1
- package/dest/rollup/block_headers_hash.js +8 -2
- package/dest/rollup/block_merge_rollup_private_inputs.d.ts +2 -2
- package/dest/rollup/block_merge_rollup_private_inputs.d.ts.map +1 -1
- package/dest/rollup/block_rollup_public_inputs.d.ts +12 -2
- package/dest/rollup/block_rollup_public_inputs.d.ts.map +1 -1
- package/dest/rollup/block_rollup_public_inputs.js +12 -0
- package/dest/rollup/block_root_rollup_private_inputs.d.ts +6 -6
- package/dest/rollup/block_root_rollup_private_inputs.d.ts.map +1 -1
- package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts +2 -2
- package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts.map +1 -1
- package/dest/rollup/checkpoint_rollup_public_inputs.d.ts +9 -2
- package/dest/rollup/checkpoint_rollup_public_inputs.d.ts.map +1 -1
- package/dest/rollup/checkpoint_rollup_public_inputs.js +9 -0
- package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts +5 -5
- package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts.map +1 -1
- package/dest/rollup/private_tx_base_rollup_private_inputs.d.ts +2 -2
- package/dest/rollup/private_tx_base_rollup_private_inputs.d.ts.map +1 -1
- package/dest/rollup/public_chonk_verifier_private_inputs.d.ts +2 -2
- package/dest/rollup/public_chonk_verifier_private_inputs.d.ts.map +1 -1
- package/dest/rollup/public_chonk_verifier_public_inputs.d.ts +2 -2
- package/dest/rollup/public_chonk_verifier_public_inputs.d.ts.map +1 -1
- package/dest/rollup/public_tx_base_rollup_private_inputs.d.ts +2 -2
- package/dest/rollup/public_tx_base_rollup_private_inputs.d.ts.map +1 -1
- package/dest/rollup/root_rollup_private_inputs.d.ts +2 -2
- package/dest/rollup/root_rollup_private_inputs.d.ts.map +1 -1
- package/dest/rollup/root_rollup_public_inputs.d.ts +2 -2
- package/dest/rollup/root_rollup_public_inputs.d.ts.map +1 -1
- package/dest/rollup/tx_merge_rollup_private_inputs.d.ts +2 -2
- package/dest/rollup/tx_merge_rollup_private_inputs.d.ts.map +1 -1
- package/dest/rollup/tx_rollup_public_inputs.d.ts +2 -2
- package/dest/rollup/tx_rollup_public_inputs.d.ts.map +1 -1
- package/dest/schemas/schemas.d.ts +32 -78
- package/dest/schemas/schemas.d.ts.map +1 -1
- package/dest/schemas/schemas.js +2 -2
- package/dest/slashing/helpers.d.ts +2 -2
- package/dest/slashing/helpers.d.ts.map +1 -1
- package/dest/slashing/helpers.js +10 -7
- package/dest/slashing/index.d.ts +2 -3
- package/dest/slashing/index.d.ts.map +1 -1
- package/dest/slashing/index.js +1 -2
- package/dest/slashing/serialization.d.ts +2 -6
- package/dest/slashing/serialization.d.ts.map +1 -1
- package/dest/slashing/serialization.js +0 -60
- package/dest/slashing/types.d.ts +18 -112
- package/dest/slashing/types.d.ts.map +1 -1
- package/dest/slashing/types.js +16 -24
- package/dest/slashing/{tally.d.ts → votes.d.ts} +1 -1
- package/dest/slashing/{tally.d.ts.map → votes.d.ts.map} +1 -1
- package/dest/slashing/{tally.js → votes.js} +1 -1
- package/dest/snapshots/types.d.ts +15 -78
- package/dest/snapshots/types.d.ts.map +1 -1
- package/dest/stats/stats.d.ts +2 -2
- package/dest/stats/stats.d.ts.map +1 -1
- package/dest/tests/factories.d.ts +25 -32
- package/dest/tests/factories.d.ts.map +1 -1
- package/dest/tests/factories.js +85 -82
- package/dest/tests/mocks.d.ts +8 -5
- package/dest/tests/mocks.d.ts.map +1 -1
- package/dest/tests/mocks.js +45 -56
- package/dest/timetable/budgets.d.ts +57 -0
- package/dest/timetable/budgets.d.ts.map +1 -0
- package/dest/timetable/budgets.js +56 -0
- package/dest/timetable/build_proposer_timetable.d.ts +21 -0
- package/dest/timetable/build_proposer_timetable.d.ts.map +1 -0
- package/dest/timetable/build_proposer_timetable.js +17 -0
- package/dest/timetable/consensus_timetable.d.ts +70 -0
- package/dest/timetable/consensus_timetable.d.ts.map +1 -0
- package/dest/timetable/consensus_timetable.js +89 -0
- package/dest/timetable/index.d.ts +5 -37
- package/dest/timetable/index.d.ts.map +1 -1
- package/dest/timetable/index.js +4 -39
- package/dest/timetable/proposer_timetable.d.ts +106 -0
- package/dest/timetable/proposer_timetable.d.ts.map +1 -0
- package/dest/timetable/proposer_timetable.js +132 -0
- package/dest/trees/append_only_tree_snapshot.d.ts +9 -14
- package/dest/trees/append_only_tree_snapshot.d.ts.map +1 -1
- package/dest/trees/append_only_tree_snapshot.js +6 -3
- package/dest/trees/nullifier_leaf.d.ts +19 -42
- package/dest/trees/nullifier_leaf.d.ts.map +1 -1
- package/dest/trees/nullifier_leaf.js +3 -0
- package/dest/trees/nullifier_membership_witness.d.ts +16 -59
- package/dest/trees/nullifier_membership_witness.d.ts.map +1 -1
- package/dest/trees/nullifier_membership_witness.js +2 -14
- package/dest/trees/public_data_leaf.d.ts +21 -53
- package/dest/trees/public_data_leaf.d.ts.map +1 -1
- package/dest/trees/public_data_witness.d.ts +16 -58
- package/dest/trees/public_data_witness.d.ts.map +1 -1
- package/dest/tx/block_header.d.ts +5 -4
- package/dest/tx/block_header.d.ts.map +1 -1
- package/dest/tx/block_header.js +7 -4
- package/dest/tx/call_context.d.ts +4 -14
- package/dest/tx/call_context.d.ts.map +1 -1
- package/dest/tx/capsule.d.ts +7 -3
- package/dest/tx/capsule.d.ts.map +1 -1
- package/dest/tx/capsule.js +9 -3
- package/dest/tx/fee_provider.d.ts +10 -0
- package/dest/tx/fee_provider.d.ts.map +1 -0
- package/dest/tx/fee_provider.js +1 -0
- package/dest/tx/function_data.d.ts +4 -10
- package/dest/tx/function_data.d.ts.map +1 -1
- package/dest/tx/global_variable_builder.d.ts +3 -4
- package/dest/tx/global_variable_builder.d.ts.map +1 -1
- package/dest/tx/global_variables.d.ts +16 -49
- package/dest/tx/global_variables.d.ts.map +1 -1
- package/dest/tx/global_variables.js +8 -12
- package/dest/tx/hashed_values.d.ts +4 -3
- package/dest/tx/hashed_values.d.ts.map +1 -1
- package/dest/tx/hashed_values.js +6 -3
- package/dest/tx/in_tx.d.ts +5 -17
- package/dest/tx/in_tx.d.ts.map +1 -1
- package/dest/tx/index.d.ts +2 -1
- package/dest/tx/index.d.ts.map +1 -1
- package/dest/tx/index.js +1 -0
- package/dest/tx/indexed_tx_effect.d.ts +8 -19
- package/dest/tx/indexed_tx_effect.d.ts.map +1 -1
- package/dest/tx/indexed_tx_effect.js +9 -6
- package/dest/tx/partial_state_reference.d.ts +22 -65
- package/dest/tx/partial_state_reference.d.ts.map +1 -1
- package/dest/tx/partial_state_reference.js +6 -3
- package/dest/tx/private_execution_result.d.ts +6 -16
- package/dest/tx/private_execution_result.d.ts.map +1 -1
- package/dest/tx/profiling.d.ts +54 -352
- package/dest/tx/profiling.d.ts.map +1 -1
- package/dest/tx/profiling.js +4 -4
- package/dest/tx/protocol_contracts.d.ts +5 -9
- package/dest/tx/protocol_contracts.d.ts.map +1 -1
- package/dest/tx/proven_tx.d.ts +30 -74
- package/dest/tx/proven_tx.d.ts.map +1 -1
- package/dest/tx/proven_tx.js +6 -0
- package/dest/tx/public_call_request_with_calldata.d.ts +4 -3
- package/dest/tx/public_call_request_with_calldata.d.ts.map +1 -1
- package/dest/tx/public_call_request_with_calldata.js +6 -3
- package/dest/tx/simulated_tx.d.ts +64 -1143
- package/dest/tx/simulated_tx.d.ts.map +1 -1
- package/dest/tx/simulated_tx.js +13 -11
- package/dest/tx/state_reference.d.ts +30 -117
- package/dest/tx/state_reference.d.ts.map +1 -1
- package/dest/tx/state_reference.js +6 -4
- package/dest/tx/tree_snapshots.d.ts +27 -84
- package/dest/tx/tree_snapshots.d.ts.map +1 -1
- package/dest/tx/tree_snapshots.js +6 -4
- package/dest/tx/tx.d.ts +22 -13
- package/dest/tx/tx.d.ts.map +1 -1
- package/dest/tx/tx.js +44 -22
- package/dest/tx/tx_constant_data.d.ts +4 -3
- package/dest/tx/tx_constant_data.d.ts.map +1 -1
- package/dest/tx/tx_constant_data.js +6 -3
- package/dest/tx/tx_context.d.ts +32 -131
- package/dest/tx/tx_context.d.ts.map +1 -1
- package/dest/tx/tx_context.js +6 -6
- package/dest/tx/tx_hash.d.ts +6 -4
- package/dest/tx/tx_hash.d.ts.map +1 -1
- package/dest/tx/tx_hash.js +13 -5
- package/dest/tx/tx_receipt.d.ts +144 -63
- package/dest/tx/tx_receipt.d.ts.map +1 -1
- package/dest/tx/tx_receipt.js +143 -60
- package/dest/tx/validator/error_texts.d.ts +6 -2
- package/dest/tx/validator/error_texts.d.ts.map +1 -1
- package/dest/tx/validator/error_texts.js +7 -1
- package/dest/tx/validator/tx_validator.d.ts +5 -27
- package/dest/tx/validator/tx_validator.d.ts.map +1 -1
- package/dest/tx/validator/tx_validator.js +0 -4
- package/dest/types/shared.d.ts +4 -12
- package/dest/types/shared.d.ts.map +1 -1
- package/dest/types/shared.js +6 -12
- package/dest/update-checker/dev_version.d.ts +3 -0
- package/dest/update-checker/dev_version.d.ts.map +1 -0
- package/dest/update-checker/dev_version.js +1 -0
- package/dest/update-checker/index.d.ts +2 -1
- package/dest/update-checker/index.d.ts.map +1 -1
- package/dest/update-checker/index.js +1 -0
- package/dest/update-checker/package_version.d.ts +6 -3
- package/dest/update-checker/package_version.d.ts.map +1 -1
- package/dest/update-checker/package_version.js +8 -19
- package/dest/validators/schemas.d.ts +147 -614
- package/dest/validators/schemas.d.ts.map +1 -1
- package/dest/validators/schemas.js +6 -4
- package/dest/validators/types.d.ts +20 -3
- package/dest/validators/types.d.ts.map +1 -1
- package/dest/versioning/versioning.js +1 -1
- package/dest/vks/verification_key.d.ts +4 -139
- package/dest/vks/verification_key.d.ts.map +1 -1
- package/dest/vks/verification_key.js +5 -126
- package/dest/world-state/genesis_data.d.ts +13 -0
- package/dest/world-state/genesis_data.d.ts.map +1 -0
- package/dest/world-state/genesis_data.js +7 -0
- package/dest/world-state/index.d.ts +2 -1
- package/dest/world-state/index.d.ts.map +1 -1
- package/dest/world-state/index.js +1 -0
- package/dest/world-state/world_state_revision.d.ts +15 -26
- package/dest/world-state/world_state_revision.d.ts.map +1 -1
- package/dest/world-state/world_state_revision.js +7 -1
- package/package.json +12 -11
- package/src/abi/abi.ts +78 -21
- package/src/abi/authorization_selector.ts +2 -8
- package/src/abi/buffer.ts +25 -4
- package/src/abi/contract_artifact.ts +30 -6
- package/src/abi/decoder.ts +23 -78
- package/src/abi/encoder.ts +42 -6
- package/src/abi/event_selector.ts +2 -8
- package/src/abi/function_selector.ts +4 -13
- package/src/abi/function_signature_decoder.ts +77 -0
- package/src/abi/index.ts +1 -0
- package/src/abi/note_selector.ts +3 -12
- package/src/abi/selector.ts +1 -1
- package/src/abi/utils.ts +6 -4
- package/src/avm/avm.ts +5 -0
- package/src/avm/message_pack.ts +12 -3
- package/src/avm/revert_code.ts +19 -39
- package/src/aztec-address/index.ts +15 -12
- package/src/block/attestation_info.ts +11 -11
- package/src/block/block_data.ts +3 -4
- package/src/block/block_hash.ts +21 -14
- package/src/block/block_parameter.ts +72 -4
- package/src/block/index.ts +0 -1
- package/src/block/l2_block_info.ts +8 -6
- package/src/block/l2_block_source.ts +216 -147
- package/src/block/l2_block_stream/interfaces.ts +42 -6
- package/src/block/l2_block_stream/l2_block_stream.ts +60 -31
- package/src/block/l2_block_stream/l2_tips_memory_store.ts +17 -41
- package/src/block/l2_block_stream/l2_tips_store_base.ts +64 -60
- package/src/block/proposal/attestations_and_signers.ts +32 -17
- package/src/block/test/l2_tips_store_test_suite.ts +198 -18
- package/src/checkpoint/checkpoint.ts +13 -3
- package/src/checkpoint/checkpoint_data.ts +44 -4
- package/src/checkpoint/checkpoint_reexecution_tracker.ts +167 -0
- package/src/checkpoint/digest.ts +28 -0
- package/src/checkpoint/index.ts +3 -0
- package/src/checkpoint/previous_checkpoint_out_hashes.ts +61 -0
- package/src/checkpoint/validate.ts +16 -6
- package/src/config/chain-config.ts +13 -16
- package/src/config/index.ts +1 -1
- package/src/config/network-consensus-config.ts +302 -0
- package/src/config/sequencer-config.ts +68 -9
- package/src/contract/complete_address.ts +7 -3
- package/src/contract/contract_address.ts +6 -6
- package/src/contract/contract_instance.ts +11 -2
- package/src/contract/index.ts +0 -2
- package/src/contract/interfaces/contract_class.ts +2 -82
- package/src/contract/interfaces/contract_instance.ts +6 -2
- package/src/contract/interfaces/node-info.ts +11 -0
- package/src/contract/private_function.ts +3 -1
- package/src/database-version/version_manager.ts +17 -0
- package/src/deserialization/index.ts +35 -2
- package/src/epoch-helpers/index.ts +24 -0
- package/src/file-store/factory.ts +13 -4
- package/src/file-store/http.ts +29 -10
- package/src/file-store/index.ts +1 -0
- package/src/gas/README.md +123 -0
- package/src/gas/fee_math.ts +120 -0
- package/src/gas/gas.ts +8 -3
- package/src/gas/gas_fees.ts +26 -13
- package/src/gas/gas_settings.ts +63 -15
- package/src/gas/index.ts +2 -0
- package/src/gas/tx_gas_limits.ts +123 -0
- package/src/ha-signing/config.ts +14 -18
- package/src/ha-signing/index.ts +3 -1
- package/src/ha-signing/local_config.ts +2 -2
- package/src/ha-signing/types.ts +48 -34
- package/src/hash/hash.ts +34 -2
- package/src/interfaces/api_limit.ts +1 -1
- package/src/interfaces/archiver.ts +88 -93
- package/src/interfaces/aztec-node-admin.ts +36 -21
- package/src/interfaces/aztec-node-debug.ts +55 -0
- package/src/interfaces/aztec-node.ts +389 -259
- package/src/interfaces/block-builder.ts +4 -0
- package/src/interfaces/block_response.ts +92 -0
- package/src/interfaces/chain_tips.ts +24 -0
- package/src/interfaces/checkpoint_parameter.ts +20 -0
- package/src/interfaces/checkpoint_response.ts +84 -0
- package/src/interfaces/client.ts +8 -1
- package/src/interfaces/configs.ts +64 -7
- package/src/interfaces/get_tx_by_hash_options.ts +14 -0
- package/src/interfaces/l1_publish_info.ts +40 -0
- package/src/interfaces/l2_logs_source.ts +13 -42
- package/src/interfaces/merkle_tree_operations.ts +3 -2
- package/src/interfaces/p2p-bootstrap.ts +2 -2
- package/src/interfaces/p2p.ts +59 -19
- package/src/interfaces/private_kernel_prover.ts +88 -0
- package/src/interfaces/prover-agent.ts +1 -1
- package/src/interfaces/prover-client.ts +3 -8
- package/src/interfaces/prover-node.ts +19 -12
- package/src/interfaces/proving-job-source.ts +4 -4
- package/src/interfaces/proving-job.ts +3 -3
- package/src/interfaces/public_storage_override.ts +26 -0
- package/src/interfaces/server.ts +5 -1
- package/src/interfaces/slasher.ts +17 -10
- package/src/interfaces/tx_provider.ts +6 -0
- package/src/interfaces/validator.ts +45 -15
- package/src/interfaces/world_state.ts +1 -1
- package/src/kernel/hints/key_validation_request.ts +18 -16
- package/src/kernel/index.ts +4 -0
- package/src/kernel/log_hash.ts +29 -9
- package/src/kernel/private_kernel_init_2_circuit_private_inputs.ts +49 -0
- package/src/kernel/private_kernel_init_3_circuit_private_inputs.ts +52 -0
- package/src/kernel/private_kernel_inner_2_circuit_private_inputs.ts +29 -0
- package/src/kernel/private_kernel_inner_3_circuit_private_inputs.ts +31 -0
- package/src/kernel/private_kernel_tail_circuit_public_inputs.ts +29 -14
- package/src/kernel/private_to_avm_accumulated_data.ts +16 -5
- package/src/kernel/private_to_public_accumulated_data.ts +9 -3
- package/src/kernel/private_to_public_kernel_circuit_public_inputs.ts +10 -4
- package/src/kernel/private_to_rollup_accumulated_data.ts +8 -3
- package/src/kernel/private_to_rollup_kernel_circuit_public_inputs.ts +9 -9
- package/src/kernel/public_call_request.ts +22 -7
- package/src/keys/derivation.ts +21 -9
- package/src/keys/public_key.ts +26 -2
- package/src/keys/public_keys.ts +124 -110
- package/src/kv-store/config.ts +3 -10
- package/src/l1-contracts/index.ts +1 -1
- package/src/logs/app_tagging_secret.ts +137 -0
- package/src/logs/app_tagging_secret_kind.ts +21 -0
- package/src/logs/contract_class_log.ts +15 -5
- package/src/logs/index.ts +6 -6
- package/src/logs/log_cursor.ts +110 -0
- package/src/logs/log_result.ts +104 -0
- package/src/logs/logs_query.ts +138 -0
- package/src/logs/message_context.ts +22 -8
- package/src/logs/pending_tagged_log.ts +1 -3
- package/src/logs/pre_tag.ts +3 -6
- package/src/logs/private_log.ts +9 -3
- package/src/logs/query_all_logs_by_tags.ts +98 -0
- package/src/logs/shared_secret_derivation.ts +21 -10
- package/src/logs/siloed_tag.ts +20 -11
- package/src/logs/tag.ts +8 -8
- package/src/logs/tagging_index_range.ts +4 -10
- package/src/messaging/append_l1_to_l2_messages.ts +21 -0
- package/src/messaging/index.ts +1 -0
- package/src/messaging/l1_to_l2_message.ts +12 -9
- package/src/messaging/l2_to_l1_membership.ts +108 -19
- package/src/messaging/l2_to_l1_message.ts +29 -9
- package/src/noir/index.ts +2 -0
- package/src/note/note_dao.ts +1 -4
- package/src/p2p/block_proposal.ts +111 -36
- package/src/p2p/checkpoint_attestation.ts +27 -31
- package/src/p2p/checkpoint_proposal.ts +128 -73
- package/src/p2p/consensus_payload.ts +59 -28
- package/src/p2p/gossipable.ts +4 -4
- package/src/p2p/signature_utils.ts +110 -25
- package/src/p2p/signed_txs.ts +46 -28
- package/src/parity/parity_base_private_inputs.ts +10 -4
- package/src/parity/parity_public_inputs.ts +9 -2
- package/src/proofs/chonk_proof.ts +132 -12
- package/src/rollup/block_headers_hash.ts +11 -2
- package/src/rollup/block_rollup_public_inputs.ts +13 -0
- package/src/rollup/checkpoint_rollup_public_inputs.ts +10 -0
- package/src/schemas/schemas.ts +6 -1
- package/src/slashing/helpers.ts +13 -9
- package/src/slashing/index.ts +1 -2
- package/src/slashing/serialization.ts +1 -81
- package/src/slashing/types.ts +24 -49
- package/src/slashing/{tally.ts → votes.ts} +1 -1
- package/src/stats/stats.ts +4 -0
- package/src/tests/factories.ts +109 -111
- package/src/tests/mocks.ts +72 -71
- package/src/timetable/README.md +609 -0
- package/src/timetable/budgets.ts +87 -0
- package/src/timetable/build_proposer_timetable.ts +42 -0
- package/src/timetable/consensus_timetable.ts +126 -0
- package/src/timetable/index.ts +4 -66
- package/src/timetable/proposer_timetable.ts +190 -0
- package/src/timetable/timetable-example.svg +108 -0
- package/src/trees/append_only_tree_snapshot.ts +8 -3
- package/src/trees/nullifier_leaf.ts +4 -0
- package/src/trees/nullifier_membership_witness.ts +2 -12
- package/src/tx/block_header.ts +10 -5
- package/src/tx/capsule.ts +10 -2
- package/src/tx/fee_provider.ts +10 -0
- package/src/tx/global_variable_builder.ts +2 -3
- package/src/tx/global_variables.ts +10 -18
- package/src/tx/hashed_values.ts +8 -3
- package/src/tx/index.ts +1 -0
- package/src/tx/indexed_tx_effect.ts +18 -6
- package/src/tx/partial_state_reference.ts +8 -3
- package/src/tx/profiling.ts +4 -4
- package/src/tx/proven_tx.ts +6 -0
- package/src/tx/public_call_request_with_calldata.ts +8 -3
- package/src/tx/simulated_tx.ts +22 -21
- package/src/tx/state_reference.ts +9 -4
- package/src/tx/tree_snapshots.ts +9 -4
- package/src/tx/tx.ts +60 -24
- package/src/tx/tx_constant_data.ts +8 -3
- package/src/tx/tx_context.ts +8 -3
- package/src/tx/tx_hash.ts +20 -5
- package/src/tx/tx_receipt.ts +265 -85
- package/src/tx/validator/error_texts.ts +10 -1
- package/src/tx/validator/tx_validator.ts +1 -5
- package/src/types/shared.ts +8 -13
- package/src/update-checker/dev_version.ts +2 -0
- package/src/update-checker/index.ts +1 -0
- package/src/update-checker/package_version.ts +10 -23
- package/src/validators/schemas.ts +6 -4
- package/src/validators/types.ts +21 -2
- package/src/versioning/versioning.ts +1 -1
- package/src/vks/verification_key.ts +5 -184
- package/src/world-state/genesis_data.ts +27 -0
- package/src/world-state/index.ts +1 -0
- package/src/world-state/world_state_revision.ts +9 -1
- package/dest/abi/mocked_keys.d.ts +0 -2
- package/dest/abi/mocked_keys.d.ts.map +0 -1
- package/dest/abi/mocked_keys.js +0 -1
- package/dest/block/checkpointed_l2_block.d.ts +0 -150
- package/dest/block/checkpointed_l2_block.d.ts.map +0 -1
- package/dest/block/checkpointed_l2_block.js +0 -46
- package/dest/config/pipelining-config.d.ts +0 -19
- package/dest/config/pipelining-config.d.ts.map +0 -1
- package/dest/config/pipelining-config.js +0 -18
- package/dest/contract/private_function_membership_proof.d.ts +0 -32
- package/dest/contract/private_function_membership_proof.d.ts.map +0 -1
- package/dest/contract/private_function_membership_proof.js +0 -124
- package/dest/contract/utility_function_membership_proof.d.ts +0 -27
- package/dest/contract/utility_function_membership_proof.d.ts.map +0 -1
- package/dest/contract/utility_function_membership_proof.js +0 -87
- package/dest/interfaces/epoch-prover.d.ts +0 -57
- package/dest/interfaces/epoch-prover.d.ts.map +0 -1
- package/dest/interfaces/epoch-prover.js +0 -1
- package/dest/interfaces/get_logs_response.d.ts +0 -97
- package/dest/interfaces/get_logs_response.d.ts.map +0 -1
- package/dest/interfaces/get_logs_response.js +0 -12
- package/dest/l1-contracts/slash_factory.d.ts +0 -45
- package/dest/l1-contracts/slash_factory.d.ts.map +0 -1
- package/dest/l1-contracts/slash_factory.js +0 -158
- package/dest/logs/extended_contract_class_log.d.ts +0 -51
- package/dest/logs/extended_contract_class_log.d.ts.map +0 -1
- package/dest/logs/extended_contract_class_log.js +0 -67
- package/dest/logs/extended_directional_app_tagging_secret.d.ts +0 -47
- package/dest/logs/extended_directional_app_tagging_secret.d.ts.map +0 -1
- package/dest/logs/extended_directional_app_tagging_secret.js +0 -72
- package/dest/logs/extended_public_log.d.ts +0 -106
- package/dest/logs/extended_public_log.d.ts.map +0 -1
- package/dest/logs/extended_public_log.js +0 -73
- package/dest/logs/log_filter.d.ts +0 -25
- package/dest/logs/log_filter.d.ts.map +0 -1
- package/dest/logs/log_filter.js +0 -12
- package/dest/logs/log_id.d.ts +0 -85
- package/dest/logs/log_id.d.ts.map +0 -1
- package/dest/logs/log_id.js +0 -94
- package/dest/logs/tx_scoped_l2_log.d.ts +0 -51
- package/dest/logs/tx_scoped_l2_log.d.ts.map +0 -1
- package/dest/logs/tx_scoped_l2_log.js +0 -77
- package/dest/slashing/empire.d.ts +0 -31
- package/dest/slashing/empire.d.ts.map +0 -1
- package/dest/slashing/empire.js +0 -87
- package/src/abi/mocked_keys.ts +0 -2
- package/src/block/checkpointed_l2_block.ts +0 -70
- package/src/config/pipelining-config.ts +0 -31
- package/src/contract/private_function_membership_proof.ts +0 -167
- package/src/contract/utility_function_membership_proof.ts +0 -118
- package/src/interfaces/epoch-prover.ts +0 -72
- package/src/interfaces/get_logs_response.ts +0 -35
- package/src/l1-contracts/slash_factory.ts +0 -180
- package/src/logs/extended_contract_class_log.ts +0 -87
- package/src/logs/extended_directional_app_tagging_secret.ts +0 -87
- package/src/logs/extended_public_log.ts +0 -94
- package/src/logs/log_filter.ts +0 -36
- package/src/logs/log_id.ts +0 -125
- package/src/logs/tx_scoped_l2_log.ts +0 -114
- package/src/slashing/empire.ts +0 -104
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
import { Grumpkin } from '@aztec/foundation/crypto/grumpkin';
|
|
2
|
+
import { poseidon2Hash } from '@aztec/foundation/crypto/poseidon';
|
|
3
|
+
import { type Fq, Fr } from '@aztec/foundation/curves/bn254';
|
|
4
|
+
import type { Point } from '@aztec/foundation/curves/grumpkin';
|
|
5
|
+
|
|
6
|
+
import { z } from 'zod';
|
|
7
|
+
|
|
8
|
+
import { AztecAddress } from '../aztec-address/index.js';
|
|
9
|
+
import type { CompleteAddress } from '../contract/complete_address.js';
|
|
10
|
+
import { computeAddressSecret, computePreaddress } from '../keys/derivation.js';
|
|
11
|
+
import { AppTaggingSecretKind } from './app_tagging_secret_kind.js';
|
|
12
|
+
|
|
13
|
+
const AppTaggingSecretKindSchema = z.union([
|
|
14
|
+
z.literal(AppTaggingSecretKind.UNCONSTRAINED),
|
|
15
|
+
z.literal(AppTaggingSecretKind.CONSTRAINED),
|
|
16
|
+
]);
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* Application tagging secret used for log tagging.
|
|
20
|
+
*
|
|
21
|
+
* It bundles a tagging secret with the app contract address. Unconstrained secrets are derived by the simulator from
|
|
22
|
+
* `(sender, recipient, app)` via ECDH. Constrained secrets are supplied to the simulator by the caller as an
|
|
23
|
+
* app-siloed shared secret retrieved from a handshake registry.
|
|
24
|
+
*/
|
|
25
|
+
export class AppTaggingSecret {
|
|
26
|
+
constructor(
|
|
27
|
+
public readonly secret: Fr,
|
|
28
|
+
public readonly app: AztecAddress,
|
|
29
|
+
public readonly kind: AppTaggingSecretKind = AppTaggingSecretKind.UNCONSTRAINED,
|
|
30
|
+
) {}
|
|
31
|
+
|
|
32
|
+
/**
|
|
33
|
+
* Derives shared tagging secret and from that, the app address and recipient derives the directional app tagging
|
|
34
|
+
* secret. Returns undefined if `externalAddress` is an invalid address.
|
|
35
|
+
*
|
|
36
|
+
* @param localAddress - The complete address of entity A in the shared tagging secret derivation scheme
|
|
37
|
+
* @param localIvsk - The incoming viewing secret key of entity A
|
|
38
|
+
* @param externalAddress - The address of entity B in the shared tagging secret derivation scheme
|
|
39
|
+
* @param app - Contract address to silo the secret to
|
|
40
|
+
* @param recipient - Recipient of the log. Defines the "direction of the secret".
|
|
41
|
+
* @returns The secret that can be used along with an index to compute a tag to be included in a log.
|
|
42
|
+
*/
|
|
43
|
+
static async computeUnconstrained(
|
|
44
|
+
localAddress: CompleteAddress,
|
|
45
|
+
localIvsk: Fq,
|
|
46
|
+
externalAddress: AztecAddress,
|
|
47
|
+
app: AztecAddress,
|
|
48
|
+
recipient: AztecAddress,
|
|
49
|
+
): Promise<AppTaggingSecret | undefined> {
|
|
50
|
+
const taggingSecretPoint = await computeSharedTaggingSecret(localAddress, localIvsk, externalAddress);
|
|
51
|
+
if (!taggingSecretPoint) {
|
|
52
|
+
return undefined;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
const appTaggingSecret = await poseidon2Hash([taggingSecretPoint.x, taggingSecretPoint.y, app]);
|
|
56
|
+
const directionalAppTaggingSecret = await poseidon2Hash([appTaggingSecret, recipient]);
|
|
57
|
+
|
|
58
|
+
return new AppTaggingSecret(directionalAppTaggingSecret, app);
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
toString(): string {
|
|
62
|
+
// TODO(F-680): Migrate stored tagging keys and remove the legacy unconstrained format.
|
|
63
|
+
if (this.kind === AppTaggingSecretKind.UNCONSTRAINED) {
|
|
64
|
+
return `${this.secret.toString()}:${this.app.toString()}`;
|
|
65
|
+
}
|
|
66
|
+
return `${this.kind}:${this.secret.toString()}:${this.app.toString()}`;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
static fromString(str: string): AppTaggingSecret {
|
|
70
|
+
const parts = str.split(':');
|
|
71
|
+
if (parts.length === 2) {
|
|
72
|
+
// TODO(F-680): Remove legacy two-part parsing after stored tagging keys are migrated.
|
|
73
|
+
const [secretStr, appStr] = parts;
|
|
74
|
+
return new AppTaggingSecret(Fr.fromString(secretStr), AztecAddress.fromString(appStr));
|
|
75
|
+
}
|
|
76
|
+
if (parts.length === 3) {
|
|
77
|
+
const [kindStr, secretStr, appStr] = parts;
|
|
78
|
+
return new AppTaggingSecret(
|
|
79
|
+
Fr.fromString(secretStr),
|
|
80
|
+
AztecAddress.fromString(appStr),
|
|
81
|
+
appTaggingSecretKindFromString(kindStr),
|
|
82
|
+
);
|
|
83
|
+
}
|
|
84
|
+
throw new Error(`Invalid AppTaggingSecret string: ${str}`);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
/**
|
|
89
|
+
* Parses a stored `AppTaggingSecret` string key.
|
|
90
|
+
*/
|
|
91
|
+
export function appTaggingSecretFromString(str: string): AppTaggingSecret {
|
|
92
|
+
return AppTaggingSecret.fromString(str);
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
export const AppTaggingSecretSchema = z
|
|
96
|
+
.object({
|
|
97
|
+
kind: AppTaggingSecretKindSchema.default(AppTaggingSecretKind.UNCONSTRAINED),
|
|
98
|
+
secret: Fr.schema,
|
|
99
|
+
app: AztecAddress.schema,
|
|
100
|
+
})
|
|
101
|
+
.transform(({ kind, secret, app }) => new AppTaggingSecret(secret, app, kind));
|
|
102
|
+
|
|
103
|
+
function appTaggingSecretKindFromString(kind: string): AppTaggingSecretKind {
|
|
104
|
+
switch (kind) {
|
|
105
|
+
case AppTaggingSecretKind.CONSTRAINED:
|
|
106
|
+
return AppTaggingSecretKind.CONSTRAINED;
|
|
107
|
+
case AppTaggingSecretKind.UNCONSTRAINED:
|
|
108
|
+
return AppTaggingSecretKind.UNCONSTRAINED;
|
|
109
|
+
default:
|
|
110
|
+
throw new Error(`Invalid AppTaggingSecret kind: ${kind}`);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
// Returns shared tagging secret computed with Diffie-Hellman key exchange, or undefined if `externalAddress` is an
|
|
115
|
+
// invalid address.
|
|
116
|
+
async function computeSharedTaggingSecret(
|
|
117
|
+
localAddress: CompleteAddress,
|
|
118
|
+
localIvsk: Fq,
|
|
119
|
+
externalAddress: AztecAddress,
|
|
120
|
+
): Promise<Point | undefined> {
|
|
121
|
+
// Given A (local complete address) -> B (external address) and h == preaddress
|
|
122
|
+
// Compute shared secret as S = (h_A + local_ivsk_A) * Addr_Point_B
|
|
123
|
+
|
|
124
|
+
const knownPreaddress = await computePreaddress(await localAddress.publicKeys.hash(), localAddress.partialAddress);
|
|
125
|
+
|
|
126
|
+
// An invalid address has no corresponding address point
|
|
127
|
+
if (!(await externalAddress.isValid())) {
|
|
128
|
+
return undefined;
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
const externalAddressPoint = await externalAddress.toAddressPoint();
|
|
132
|
+
|
|
133
|
+
// Beware! h_a + local_ivsk_a (also known as the address secret) can lead to an address point with a negative
|
|
134
|
+
// y-coordinate, since there's two possible candidates computeAddressSecret takes care of selecting the one that
|
|
135
|
+
// leads to a positive y-coordinate, which is the only valid address point
|
|
136
|
+
return Grumpkin.mul(externalAddressPoint, await computeAddressSecret(knownPreaddress, localIvsk));
|
|
137
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export const AppTaggingSecretKind = {
|
|
2
|
+
UNCONSTRAINED: 'unconstrained',
|
|
3
|
+
CONSTRAINED: 'constrained',
|
|
4
|
+
} as const;
|
|
5
|
+
|
|
6
|
+
export type AppTaggingSecretKind = (typeof AppTaggingSecretKind)[keyof typeof AppTaggingSecretKind];
|
|
7
|
+
|
|
8
|
+
// Keep in sync with aztec::messages::delivery::OnchainDeliveryMode.
|
|
9
|
+
const ONCHAIN_UNCONSTRAINED_DELIVERY_MODE = 2;
|
|
10
|
+
const ONCHAIN_CONSTRAINED_DELIVERY_MODE = 3;
|
|
11
|
+
|
|
12
|
+
export function appTaggingSecretKindFromDeliveryMode(deliveryMode: number): AppTaggingSecretKind {
|
|
13
|
+
switch (deliveryMode) {
|
|
14
|
+
case ONCHAIN_UNCONSTRAINED_DELIVERY_MODE:
|
|
15
|
+
return AppTaggingSecretKind.UNCONSTRAINED;
|
|
16
|
+
case ONCHAIN_CONSTRAINED_DELIVERY_MODE:
|
|
17
|
+
return AppTaggingSecretKind.CONSTRAINED;
|
|
18
|
+
default:
|
|
19
|
+
throw new Error(`Unrecognized delivery mode for tagging: ${deliveryMode}`);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
@@ -2,7 +2,7 @@ import { CONTRACT_CLASS_LOG_LENGTH, CONTRACT_CLASS_LOG_SIZE_IN_FIELDS } from '@a
|
|
|
2
2
|
import { poseidon2Hash } from '@aztec/foundation/crypto/poseidon';
|
|
3
3
|
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
4
4
|
import { schemas } from '@aztec/foundation/schemas';
|
|
5
|
-
import { BufferReader,
|
|
5
|
+
import { BufferReader, BufferSink, FieldReader, serializeToFields, serializeToSink } from '@aztec/foundation/serialize';
|
|
6
6
|
import type { FieldsOf } from '@aztec/foundation/types';
|
|
7
7
|
|
|
8
8
|
import { inspect } from 'util';
|
|
@@ -56,8 +56,13 @@ export class ContractClassLogFields {
|
|
|
56
56
|
);
|
|
57
57
|
}
|
|
58
58
|
|
|
59
|
-
toBuffer()
|
|
60
|
-
|
|
59
|
+
toBuffer(): Buffer;
|
|
60
|
+
toBuffer(sink: BufferSink): void;
|
|
61
|
+
toBuffer(sink?: BufferSink): Buffer | void {
|
|
62
|
+
if (!sink) {
|
|
63
|
+
return BufferSink.serialize(this);
|
|
64
|
+
}
|
|
65
|
+
serializeToSink(sink, this.fields);
|
|
61
66
|
}
|
|
62
67
|
|
|
63
68
|
static fromBuffer(buffer: Buffer | BufferReader) {
|
|
@@ -169,8 +174,13 @@ export class ContractClassLog {
|
|
|
169
174
|
return new ContractClassLog(AztecAddress.ZERO, ContractClassLogFields.empty(), 0);
|
|
170
175
|
}
|
|
171
176
|
|
|
172
|
-
toBuffer(): Buffer
|
|
173
|
-
|
|
177
|
+
toBuffer(): Buffer;
|
|
178
|
+
toBuffer(sink: BufferSink): void;
|
|
179
|
+
toBuffer(sink?: BufferSink): Buffer | void {
|
|
180
|
+
if (!sink) {
|
|
181
|
+
return BufferSink.serialize(this);
|
|
182
|
+
}
|
|
183
|
+
serializeToSink(sink, this.contractAddress, this.fields, this.emittedLength);
|
|
174
184
|
}
|
|
175
185
|
|
|
176
186
|
static fromBuffer(buffer: Buffer | BufferReader) {
|
package/src/logs/index.ts
CHANGED
|
@@ -1,16 +1,16 @@
|
|
|
1
|
-
export * from './
|
|
1
|
+
export * from './app_tagging_secret_kind.js';
|
|
2
|
+
export * from './app_tagging_secret.js';
|
|
2
3
|
export * from './pre_tag.js';
|
|
3
4
|
export * from './tagging_index_range.js';
|
|
4
5
|
export * from './contract_class_log.js';
|
|
5
6
|
export * from './public_log.js';
|
|
6
7
|
export * from './private_log.js';
|
|
7
8
|
export * from './pending_tagged_log.js';
|
|
8
|
-
export * from './
|
|
9
|
-
export * from './
|
|
10
|
-
export * from './
|
|
11
|
-
export * from './
|
|
9
|
+
export * from './log_result.js';
|
|
10
|
+
export * from './log_cursor.js';
|
|
11
|
+
export * from './logs_query.js';
|
|
12
|
+
export * from './query_all_logs_by_tags.js';
|
|
12
13
|
export * from './shared_secret_derivation.js';
|
|
13
|
-
export * from './tx_scoped_l2_log.js';
|
|
14
14
|
export * from './message_context.js';
|
|
15
15
|
export * from './debug_log.js';
|
|
16
16
|
export * from './debug_log_store.js';
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import { BlockNumber, BlockNumberSchema } from '@aztec/foundation/branded-types';
|
|
2
|
+
import { BufferReader, numToUInt32BE } from '@aztec/foundation/serialize';
|
|
3
|
+
|
|
4
|
+
import { z } from 'zod';
|
|
5
|
+
|
|
6
|
+
import { schemas } from '../schemas/schemas.js';
|
|
7
|
+
import type { LogResultBase } from './log_result.js';
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Cursor identifying a position in a tag's ordered log stream. Used as `afterLog` on `TagQuery` to resume
|
|
11
|
+
* pagination strictly after a previously-seen log.
|
|
12
|
+
*
|
|
13
|
+
* `(blockNumber, txIndexWithinBlock, logIndexWithinTx)` is sufficient to uniquely identify a position
|
|
14
|
+
* and matches the composite-key ordering of the archiver's log index, so the cursor maps directly to a
|
|
15
|
+
* key without a tx-hash lookup. All three fields are always present on {@link LogResult}, so a cursor is
|
|
16
|
+
* constructible from any returned log.
|
|
17
|
+
*/
|
|
18
|
+
export class LogCursor {
|
|
19
|
+
constructor(
|
|
20
|
+
/** The block the cursor points to. */
|
|
21
|
+
public readonly blockNumber: BlockNumber,
|
|
22
|
+
/** The tx index within the block the cursor points to. */
|
|
23
|
+
public readonly txIndexWithinBlock: number,
|
|
24
|
+
/** The log index within the tx the cursor points to. */
|
|
25
|
+
public readonly logIndexWithinTx: number,
|
|
26
|
+
) {}
|
|
27
|
+
|
|
28
|
+
static get schema() {
|
|
29
|
+
return z
|
|
30
|
+
.object({
|
|
31
|
+
blockNumber: BlockNumberSchema,
|
|
32
|
+
txIndexWithinBlock: schemas.Integer,
|
|
33
|
+
logIndexWithinTx: schemas.Integer,
|
|
34
|
+
})
|
|
35
|
+
.transform(
|
|
36
|
+
({ blockNumber, txIndexWithinBlock, logIndexWithinTx }) =>
|
|
37
|
+
new LogCursor(blockNumber, txIndexWithinBlock, logIndexWithinTx),
|
|
38
|
+
);
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
/** Builds a cursor that points at the given log. Pagination resumes strictly after this position. */
|
|
42
|
+
static fromLog(log: Pick<LogResultBase, 'blockNumber' | 'txIndexWithinBlock' | 'logIndexWithinTx'>): LogCursor {
|
|
43
|
+
return new LogCursor(log.blockNumber, log.txIndexWithinBlock, log.logIndexWithinTx);
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
static random(): LogCursor {
|
|
47
|
+
return new LogCursor(
|
|
48
|
+
BlockNumber(Math.floor(Math.random() * 100000) + 1),
|
|
49
|
+
Math.floor(Math.random() * 100),
|
|
50
|
+
Math.floor(Math.random() * 100),
|
|
51
|
+
);
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
toBuffer(): Buffer {
|
|
55
|
+
return Buffer.concat([
|
|
56
|
+
numToUInt32BE(this.blockNumber),
|
|
57
|
+
numToUInt32BE(this.txIndexWithinBlock),
|
|
58
|
+
numToUInt32BE(this.logIndexWithinTx),
|
|
59
|
+
]);
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
static fromBuffer(buffer: Buffer | BufferReader): LogCursor {
|
|
63
|
+
const reader = BufferReader.asReader(buffer);
|
|
64
|
+
const blockNumber = BlockNumber(reader.readNumber());
|
|
65
|
+
const txIndexWithinBlock = reader.readNumber();
|
|
66
|
+
const logIndexWithinTx = reader.readNumber();
|
|
67
|
+
return new LogCursor(blockNumber, txIndexWithinBlock, logIndexWithinTx);
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
equals(other: LogCursor): boolean {
|
|
71
|
+
return (
|
|
72
|
+
this.blockNumber === other.blockNumber &&
|
|
73
|
+
this.txIndexWithinBlock === other.txIndexWithinBlock &&
|
|
74
|
+
this.logIndexWithinTx === other.logIndexWithinTx
|
|
75
|
+
);
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
toString(): string {
|
|
79
|
+
return `${this.blockNumber}-${this.txIndexWithinBlock}-${this.logIndexWithinTx}`;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
/**
|
|
83
|
+
* Parses a `<blockNumber>-<txIndexWithinBlock>-<logIndexWithinTx>` triple into a {@link LogCursor}.
|
|
84
|
+
* Throws on malformed input. Returns `undefined` for an empty / missing value so callers can use
|
|
85
|
+
* this directly as an optional CLI option parser.
|
|
86
|
+
*/
|
|
87
|
+
static parseOptional(value: string): LogCursor | undefined {
|
|
88
|
+
if (!value) {
|
|
89
|
+
return undefined;
|
|
90
|
+
}
|
|
91
|
+
const parts = value.split('-');
|
|
92
|
+
if (parts.length !== 3) {
|
|
93
|
+
throw new Error(`Invalid log cursor "${value}". Expected <blockNumber>-<txIndexWithinBlock>-<logIndexWithinTx>.`);
|
|
94
|
+
}
|
|
95
|
+
const [blockNumberStr, txIndexStr, logIndexStr] = parts;
|
|
96
|
+
const blockNumber = Number(blockNumberStr);
|
|
97
|
+
const txIndexWithinBlock = Number(txIndexStr);
|
|
98
|
+
const logIndexWithinTx = Number(logIndexStr);
|
|
99
|
+
if (!Number.isInteger(blockNumber) || blockNumber < 1) {
|
|
100
|
+
throw new Error(`Invalid log cursor block number: ${blockNumberStr}`);
|
|
101
|
+
}
|
|
102
|
+
if (!Number.isInteger(txIndexWithinBlock) || txIndexWithinBlock < 0) {
|
|
103
|
+
throw new Error(`Invalid log cursor tx index: ${txIndexStr}`);
|
|
104
|
+
}
|
|
105
|
+
if (!Number.isInteger(logIndexWithinTx) || logIndexWithinTx < 0) {
|
|
106
|
+
throw new Error(`Invalid log cursor log index: ${logIndexStr}`);
|
|
107
|
+
}
|
|
108
|
+
return new LogCursor(BlockNumber(blockNumber), txIndexWithinBlock, logIndexWithinTx);
|
|
109
|
+
}
|
|
110
|
+
}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import { BlockNumber, BlockNumberSchema } from '@aztec/foundation/branded-types';
|
|
2
|
+
import { times } from '@aztec/foundation/collection';
|
|
3
|
+
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
4
|
+
import { schemas as foundationSchemas } from '@aztec/foundation/schemas';
|
|
5
|
+
import type { PickIfFlag, Prettify } from '@aztec/foundation/types';
|
|
6
|
+
|
|
7
|
+
import { z } from 'zod';
|
|
8
|
+
|
|
9
|
+
import { BlockHash } from '../block/block_hash.js';
|
|
10
|
+
import { schemas } from '../schemas/schemas.js';
|
|
11
|
+
import { TxHash } from '../tx/tx_hash.js';
|
|
12
|
+
import type { UInt64 } from '../types/shared.js';
|
|
13
|
+
|
|
14
|
+
/** Options for narrowing the shape of a {@link LogResult}. */
|
|
15
|
+
export type LogIncludeOptions = {
|
|
16
|
+
/** When set, the log carries `noteHashes` + all `nullifiers` from its tx effect. Off by default. */
|
|
17
|
+
includeEffects?: boolean;
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
export const LogIncludeOptionsSchema: z.ZodType<LogIncludeOptions> = z.object({
|
|
21
|
+
includeEffects: z.boolean().optional(),
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
/** Required metadata always present on a {@link LogResult}. */
|
|
25
|
+
export type LogResultBase = {
|
|
26
|
+
/** The data contents of the log, with the tag as the first field. */
|
|
27
|
+
logData: Fr[];
|
|
28
|
+
/** The block this log was emitted in. */
|
|
29
|
+
blockNumber: BlockNumber;
|
|
30
|
+
/** The hash of the block this log was emitted in. */
|
|
31
|
+
blockHash: BlockHash;
|
|
32
|
+
/** The timestamp of the block this log was emitted in. */
|
|
33
|
+
blockTimestamp: UInt64;
|
|
34
|
+
/** The hash of the tx this log was emitted in. */
|
|
35
|
+
txHash: TxHash;
|
|
36
|
+
/** The 0-based index of this log's tx within its block. */
|
|
37
|
+
txIndexWithinBlock: number;
|
|
38
|
+
/** The 0-based index of this log within its tx (across both private and public logs for the tx). */
|
|
39
|
+
logIndexWithinTx: number;
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
* A single log returned from {@link L2LogsSource.getPrivateLogsByTags} or {@link L2LogsSource.getPublicLogsByTags}.
|
|
44
|
+
*
|
|
45
|
+
* Generic over the include-options so that flagged fields become required when the caller passes a
|
|
46
|
+
* literal `true`. The default type argument ({@link LogIncludeOptions}) yields the widest shape
|
|
47
|
+
* (all include-fields optional) — this is what the JSON-RPC wire layer validates against.
|
|
48
|
+
*
|
|
49
|
+
* `logData` is the raw field-element payload, with the tag in field 0 (consumers slice it off).
|
|
50
|
+
*
|
|
51
|
+
* @example
|
|
52
|
+
* const l: LogResult<{ includeEffects: true }> = (await node.getPrivateLogsByTags({ tags, includeEffects: true }))[0][0];
|
|
53
|
+
* l.nullifiers; // required, not optional
|
|
54
|
+
*/
|
|
55
|
+
export type LogResult<Opts extends LogIncludeOptions = LogIncludeOptions> = Prettify<
|
|
56
|
+
LogResultBase & PickIfFlag<LogIncludeOptions, Opts, 'includeEffects', { noteHashes: Fr[]; nullifiers: Fr[] }>
|
|
57
|
+
>;
|
|
58
|
+
|
|
59
|
+
/** Zod schema for the widest {@link LogResult} shape (all include-gated fields optional). */
|
|
60
|
+
export const LogResultSchema: z.ZodType<LogResult> = z.object({
|
|
61
|
+
logData: z.array(foundationSchemas.Fr),
|
|
62
|
+
blockNumber: BlockNumberSchema,
|
|
63
|
+
blockHash: BlockHash.schema,
|
|
64
|
+
blockTimestamp: schemas.UInt64,
|
|
65
|
+
txHash: TxHash.schema,
|
|
66
|
+
txIndexWithinBlock: schemas.Integer,
|
|
67
|
+
logIndexWithinTx: schemas.Integer,
|
|
68
|
+
noteHashes: z.array(foundationSchemas.Fr).optional(),
|
|
69
|
+
nullifiers: z.array(foundationSchemas.Fr).optional(),
|
|
70
|
+
});
|
|
71
|
+
|
|
72
|
+
/** Builds a random {@link LogResult} for tests. `includeEffects` populates `noteHashes` + `nullifiers`. */
|
|
73
|
+
export function randomLogResult(includeEffects = false): LogResult {
|
|
74
|
+
const base: LogResultBase = {
|
|
75
|
+
logData: times(3, Fr.random),
|
|
76
|
+
blockNumber: BlockNumber(Math.floor(Math.random() * 100000) + 1),
|
|
77
|
+
blockHash: BlockHash.random(),
|
|
78
|
+
blockTimestamp: BigInt(Math.floor(Date.now() / 1000)),
|
|
79
|
+
txHash: TxHash.random(),
|
|
80
|
+
txIndexWithinBlock: Math.floor(Math.random() * 100),
|
|
81
|
+
logIndexWithinTx: Math.floor(Math.random() * 100),
|
|
82
|
+
};
|
|
83
|
+
if (includeEffects) {
|
|
84
|
+
return { ...base, noteHashes: times(3, Fr.random), nullifiers: times(3, Fr.random) };
|
|
85
|
+
}
|
|
86
|
+
return base;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
/** Human-readable single-line representation, primarily for the CLI `get-logs` command. */
|
|
90
|
+
export function logResultToHumanReadable(log: LogResult): string {
|
|
91
|
+
const head =
|
|
92
|
+
`block ${log.blockNumber} (${log.blockHash.toString()}) ` +
|
|
93
|
+
`tx ${log.txHash.toString()} txIndex ${log.txIndexWithinBlock} logIndex ${log.logIndexWithinTx} ` +
|
|
94
|
+
`ts ${log.blockTimestamp}`;
|
|
95
|
+
const data = `data [${log.logData.map(f => f.toString()).join(', ')}]`;
|
|
96
|
+
const parts = [head, data];
|
|
97
|
+
if (log.noteHashes !== undefined) {
|
|
98
|
+
parts.push(`noteHashes [${log.noteHashes.map(f => f.toString()).join(', ')}]`);
|
|
99
|
+
}
|
|
100
|
+
if (log.nullifiers !== undefined) {
|
|
101
|
+
parts.push(`nullifiers [${log.nullifiers.map(f => f.toString()).join(', ')}]`);
|
|
102
|
+
}
|
|
103
|
+
return parts.join(' | ');
|
|
104
|
+
}
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
import { BlockNumberSchema } from '@aztec/foundation/branded-types';
|
|
2
|
+
import type { BlockNumber } from '@aztec/foundation/branded-types';
|
|
3
|
+
|
|
4
|
+
import { z } from 'zod';
|
|
5
|
+
|
|
6
|
+
import type { AztecAddress } from '../aztec-address/index.js';
|
|
7
|
+
import { BlockHash } from '../block/block_hash.js';
|
|
8
|
+
import { MAX_LOGS_PER_TAG, MAX_RPC_LEN } from '../interfaces/api_limit.js';
|
|
9
|
+
import { type ZodFor, schemas, zodFor } from '../schemas/index.js';
|
|
10
|
+
import { TxHash } from '../tx/tx_hash.js';
|
|
11
|
+
import { LogCursor } from './log_cursor.js';
|
|
12
|
+
import { SiloedTag } from './siloed_tag.js';
|
|
13
|
+
import { Tag } from './tag.js';
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* A tag to query in {@link PrivateLogsQuery} / {@link PublicLogsQuery}, optionally resuming strictly
|
|
17
|
+
* after a previously-seen log via `afterLog`. The bare `T` form means "from the beginning".
|
|
18
|
+
*/
|
|
19
|
+
export type TagQuery<T extends Tag | SiloedTag> = T | { tag: T; afterLog?: LogCursor };
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* Shared fields for {@link PrivateLogsQuery} and {@link PublicLogsQuery}.
|
|
23
|
+
*/
|
|
24
|
+
export type LogsQueryBase = {
|
|
25
|
+
/** Lower block bound, inclusive. */
|
|
26
|
+
fromBlock?: BlockNumber;
|
|
27
|
+
/** Upper block bound, exclusive. */
|
|
28
|
+
toBlock?: BlockNumber;
|
|
29
|
+
/**
|
|
30
|
+
* Restrict results to logs emitted in this transaction. Mutually exclusive with `fromBlock`/`toBlock`
|
|
31
|
+
* (a txHash already pins a block). `txHash` + `afterLog` is allowed and paginates within the tx's logs
|
|
32
|
+
* for that tag.
|
|
33
|
+
*/
|
|
34
|
+
txHash?: TxHash;
|
|
35
|
+
/**
|
|
36
|
+
* Reorg-safety anchor: the latest block hash the caller has synced to. If set and the block is no
|
|
37
|
+
* longer present, the call throws. Distinct from `toBlock`, which is a filter, not a safety check.
|
|
38
|
+
*/
|
|
39
|
+
referenceBlock?: BlockHash;
|
|
40
|
+
/** When set, each log also carries `noteHashes` and all `nullifiers` for note-nonce discovery. */
|
|
41
|
+
includeEffects?: boolean;
|
|
42
|
+
/**
|
|
43
|
+
* Maximum number of logs returned per tag. Capped at {@link MAX_LOGS_PER_TAG} (rejected if higher).
|
|
44
|
+
* Defaults to {@link MAX_LOGS_PER_TAG} when unset. Mainly useful for tests that need to force
|
|
45
|
+
* pagination at a small page size.
|
|
46
|
+
*/
|
|
47
|
+
limitPerTag?: number;
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
/**
|
|
51
|
+
* Query for {@link L2LogsSource.getPrivateLogsByTags}. Returns one inner array per element of `tags`,
|
|
52
|
+
* in input order.
|
|
53
|
+
*/
|
|
54
|
+
export type PrivateLogsQuery = LogsQueryBase & {
|
|
55
|
+
/** Tags to query. Between 1 and {@link MAX_RPC_LEN} entries (inclusive). */
|
|
56
|
+
tags: TagQuery<SiloedTag>[];
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
/**
|
|
60
|
+
* Query for {@link L2LogsSource.getPublicLogsByTags}. Returns one inner array per element of `tags`,
|
|
61
|
+
* in input order.
|
|
62
|
+
*/
|
|
63
|
+
export type PublicLogsQuery = LogsQueryBase & {
|
|
64
|
+
/** Contract address that emitted the logs. Required for public queries. */
|
|
65
|
+
contractAddress: AztecAddress;
|
|
66
|
+
/** Tags to query. Between 1 and {@link MAX_RPC_LEN} entries (inclusive). */
|
|
67
|
+
tags: TagQuery<Tag>[];
|
|
68
|
+
};
|
|
69
|
+
|
|
70
|
+
function tagQuerySchema<T extends Tag | SiloedTag>(tagSchema: ZodFor<T>) {
|
|
71
|
+
return z.union([
|
|
72
|
+
tagSchema,
|
|
73
|
+
z.object({
|
|
74
|
+
tag: tagSchema,
|
|
75
|
+
afterLog: LogCursor.schema.optional(),
|
|
76
|
+
}),
|
|
77
|
+
]) as ZodFor<TagQuery<T>>;
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
const logsQueryBaseShape = {
|
|
81
|
+
fromBlock: BlockNumberSchema.optional(),
|
|
82
|
+
toBlock: BlockNumberSchema.optional(),
|
|
83
|
+
txHash: TxHash.schema.optional(),
|
|
84
|
+
referenceBlock: BlockHash.schema.optional(),
|
|
85
|
+
includeEffects: z.boolean().optional(),
|
|
86
|
+
limitPerTag: z
|
|
87
|
+
.number()
|
|
88
|
+
.int()
|
|
89
|
+
.positive()
|
|
90
|
+
.max(MAX_LOGS_PER_TAG, { message: `limitPerTag must be <= ${MAX_LOGS_PER_TAG}` })
|
|
91
|
+
.optional(),
|
|
92
|
+
};
|
|
93
|
+
|
|
94
|
+
/** Minimal shape required by {@link refineTxHashAndRange}. */
|
|
95
|
+
type TxHashAndRangeFields = {
|
|
96
|
+
/** Tx hash filter. */
|
|
97
|
+
txHash?: TxHash;
|
|
98
|
+
/** Lower block bound. */
|
|
99
|
+
fromBlock?: BlockNumber;
|
|
100
|
+
/** Upper block bound (exclusive). */
|
|
101
|
+
toBlock?: BlockNumber;
|
|
102
|
+
};
|
|
103
|
+
|
|
104
|
+
/**
|
|
105
|
+
* Refinement: a `txHash` already pins a block, so combining it with a block range is contradictory.
|
|
106
|
+
* (`txHash` + `afterLog` is still allowed and is enforced per-tag inside `TagQuery`.) Exported so
|
|
107
|
+
* `aztec.js`'s wallet event-filter schemas can reuse the same rule.
|
|
108
|
+
*/
|
|
109
|
+
export function refineTxHashAndRange<T extends TxHashAndRangeFields>(schema: z.ZodType<T>) {
|
|
110
|
+
return schema.refine(q => !(q.txHash !== undefined && (q.fromBlock !== undefined || q.toBlock !== undefined)), {
|
|
111
|
+
message: '`txHash` is mutually exclusive with `fromBlock`/`toBlock`',
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
export const PrivateLogsQuerySchema: ZodFor<PrivateLogsQuery> = refineTxHashAndRange(
|
|
116
|
+
zodFor<PrivateLogsQuery>()(
|
|
117
|
+
z.object({
|
|
118
|
+
...logsQueryBaseShape,
|
|
119
|
+
tags: z
|
|
120
|
+
.array(tagQuerySchema(SiloedTag.schema))
|
|
121
|
+
.min(1)
|
|
122
|
+
.max(MAX_RPC_LEN, { message: `tags must have at most ${MAX_RPC_LEN} entries` }),
|
|
123
|
+
}),
|
|
124
|
+
),
|
|
125
|
+
);
|
|
126
|
+
|
|
127
|
+
export const PublicLogsQuerySchema: ZodFor<PublicLogsQuery> = refineTxHashAndRange(
|
|
128
|
+
zodFor<PublicLogsQuery>()(
|
|
129
|
+
z.object({
|
|
130
|
+
...logsQueryBaseShape,
|
|
131
|
+
contractAddress: schemas.AztecAddress,
|
|
132
|
+
tags: z
|
|
133
|
+
.array(tagQuerySchema(Tag.schema))
|
|
134
|
+
.min(1)
|
|
135
|
+
.max(MAX_RPC_LEN, { message: `tags must have at most ${MAX_RPC_LEN} entries` }),
|
|
136
|
+
}),
|
|
137
|
+
),
|
|
138
|
+
);
|
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
import { MAX_NOTE_HASHES_PER_TX } from '@aztec/constants';
|
|
2
|
+
import { range } from '@aztec/foundation/array';
|
|
2
3
|
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
3
4
|
|
|
4
|
-
import
|
|
5
|
-
import type { TxEffect } from '../tx/tx_effect.js';
|
|
6
|
-
import type { TxHash } from '../tx/tx_hash.js';
|
|
5
|
+
import { TxHash } from '../tx/tx_hash.js';
|
|
7
6
|
|
|
8
7
|
/**
|
|
9
8
|
* Additional information needed to process a message.
|
|
@@ -19,7 +18,6 @@ export class MessageContext {
|
|
|
19
18
|
public txHash: TxHash,
|
|
20
19
|
public uniqueNoteHashesInTx: Fr[],
|
|
21
20
|
public firstNullifierInTx: Fr,
|
|
22
|
-
public recipient: AztecAddress,
|
|
23
21
|
) {}
|
|
24
22
|
|
|
25
23
|
toFields(): Fr[] {
|
|
@@ -27,7 +25,6 @@ export class MessageContext {
|
|
|
27
25
|
this.txHash.hash,
|
|
28
26
|
...serializeBoundedVec(this.uniqueNoteHashesInTx, MAX_NOTE_HASHES_PER_TX),
|
|
29
27
|
this.firstNullifierInTx,
|
|
30
|
-
this.recipient.toField(),
|
|
31
28
|
];
|
|
32
29
|
}
|
|
33
30
|
|
|
@@ -37,13 +34,26 @@ export class MessageContext {
|
|
|
37
34
|
tx_hash: this.txHash.hash,
|
|
38
35
|
unique_note_hashes_in_tx: this.uniqueNoteHashesInTx,
|
|
39
36
|
first_nullifier_in_tx: this.firstNullifierInTx,
|
|
40
|
-
recipient: this.recipient,
|
|
41
37
|
};
|
|
42
38
|
/* eslint-enable camelcase */
|
|
43
39
|
}
|
|
44
40
|
|
|
45
|
-
static
|
|
46
|
-
return new MessageContext(
|
|
41
|
+
static empty(): MessageContext {
|
|
42
|
+
return new MessageContext(TxHash.zero(), [], Fr.ZERO);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
static toEmptyFields(): Fr[] {
|
|
46
|
+
const serializationLen =
|
|
47
|
+
1 /* txHash */ + MAX_NOTE_HASHES_PER_TX + 1 /* uniqueNoteHashesInTx BVec */ + 1; /* firstNullifierInTx */
|
|
48
|
+
return range(serializationLen).map(_ => Fr.zero());
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
static toSerializedOption(response: MessageContext | null): Fr[] {
|
|
52
|
+
if (response) {
|
|
53
|
+
return [new Fr(1), ...response.toFields()];
|
|
54
|
+
} else {
|
|
55
|
+
return [new Fr(0), ...MessageContext.toEmptyFields()];
|
|
56
|
+
}
|
|
47
57
|
}
|
|
48
58
|
}
|
|
49
59
|
|
|
@@ -55,6 +65,10 @@ export class MessageContext {
|
|
|
55
65
|
* @dev Copied over from pending_tagged_log.ts.
|
|
56
66
|
*/
|
|
57
67
|
function serializeBoundedVec(values: Fr[], maxLength: number): Fr[] {
|
|
68
|
+
if (values.length > maxLength) {
|
|
69
|
+
throw new Error(`Attempted to serialize ${values} values into a BoundedVec with max length ${maxLength}`);
|
|
70
|
+
}
|
|
71
|
+
|
|
58
72
|
const lengthDiff = maxLength - values.length;
|
|
59
73
|
const zeroPaddingArray = Array(lengthDiff).fill(Fr.ZERO);
|
|
60
74
|
const storage = values.concat(zeroPaddingArray);
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { PRIVATE_LOG_SIZE_IN_FIELDS } from '@aztec/constants';
|
|
2
2
|
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
3
3
|
|
|
4
|
-
import type { AztecAddress } from '../aztec-address/index.js';
|
|
5
4
|
import type { TxHash } from '../tx/tx_hash.js';
|
|
6
5
|
import { MessageContext } from './message_context.js';
|
|
7
6
|
|
|
@@ -17,9 +16,8 @@ export class PendingTaggedLog {
|
|
|
17
16
|
txHash: TxHash,
|
|
18
17
|
uniqueNoteHashesInTx: Fr[],
|
|
19
18
|
firstNullifierInTx: Fr,
|
|
20
|
-
recipient: AztecAddress,
|
|
21
19
|
) {
|
|
22
|
-
this.context = new MessageContext(txHash, uniqueNoteHashesInTx, firstNullifierInTx
|
|
20
|
+
this.context = new MessageContext(txHash, uniqueNoteHashesInTx, firstNullifierInTx);
|
|
23
21
|
}
|
|
24
22
|
|
|
25
23
|
toFields(): Fr[] {
|