Skip to content

Commit

Permalink
Re-arrange InvalidExtrinsicsRootProof data to make it easier to combine
Browse files Browse the repository at this point in the history
  • Loading branch information
teor2345 committed Dec 12, 2024
1 parent 3b039e9 commit 90428cc
Show file tree
Hide file tree
Showing 6 changed files with 58 additions and 43 deletions.
8 changes: 5 additions & 3 deletions crates/sp-domains-fraud-proof/src/fraud_proof.rs
Original file line number Diff line number Diff line change
Expand Up @@ -493,10 +493,12 @@ pub struct ValidBundleProof<Number, Hash, DomainHeader: HeaderT> {
pub struct InvalidExtrinsicsRootProof {
/// Valid Bundle digests
pub valid_bundle_digests: Vec<ValidBundleDigest>,
/// Block randomness storage proof
pub block_randomness_proof: BlockRandomnessProof,

/// The storage proof used during verification
pub domain_inherent_extrinsic_data_proof: DomainInherentExtrinsicDataProof,
pub invalid_extrinsics_data_proof: InvalidExtrinsicsDataProof,

/// Optional sudo extrinsic call storage proof
pub domain_sudo_call_proof: DomainSudoCallStorageProof,
}

#[derive(Clone, Debug, Decode, Encode, Eq, PartialEq, TypeInfo)]
Expand Down
2 changes: 2 additions & 0 deletions crates/sp-domains-fraud-proof/src/host_functions.rs
Original file line number Diff line number Diff line change
Expand Up @@ -262,6 +262,8 @@ where
domain_inherent_extrinsic_data: DomainInherentExtrinsicData,
) -> Option<DomainInherentExtrinsic> {
let DomainInherentExtrinsicData {
// Used by caller
block_randomness: _,
timestamp,
maybe_domain_runtime_upgrade,
consensus_transaction_byte_fee,
Expand Down
3 changes: 2 additions & 1 deletion crates/sp-domains-fraud-proof/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ use sp_runtime::transaction_validity::{InvalidTransaction, TransactionValidity};
use sp_runtime::OpaqueExtrinsic;
use sp_runtime_interface::pass_by;
use sp_runtime_interface::pass_by::PassBy;
use subspace_core_primitives::U256;
use subspace_core_primitives::{Randomness, U256};
use subspace_runtime_primitives::{Balance, Moment};

/// Custom invalid validity code for the extrinsics in pallet-domains.
Expand Down Expand Up @@ -108,6 +108,7 @@ pub enum DomainChainAllowlistUpdateExtrinsic {

#[derive(Debug, Decode, Encode, TypeInfo, PartialEq, Eq, Clone)]
pub struct DomainInherentExtrinsicData {
pub block_randomness: Randomness,
pub timestamp: Moment,
pub maybe_domain_runtime_upgrade: Option<Vec<u8>>,
pub consensus_transaction_byte_fee: Balance,
Expand Down
44 changes: 26 additions & 18 deletions crates/sp-domains-fraud-proof/src/storage_proof.rs
Original file line number Diff line number Diff line change
Expand Up @@ -414,16 +414,27 @@ impl MaybeDomainRuntimeUpgradedProof {
}

#[derive(Clone, Debug, Decode, Encode, Eq, PartialEq, TypeInfo)]
pub struct DomainInherentExtrinsicDataProof {
pub struct InvalidExtrinsicsDataProof {
/// Block randomness storage proof
pub block_randomness_proof: BlockRandomnessProof,

/// Block timestamp storage proof
pub timestamp_proof: TimestampStorageProof,

/// Optional domain runtime code upgrade storage proof
pub maybe_domain_runtime_upgrade_proof: MaybeDomainRuntimeUpgradedProof,

/// Boolean indicating if dynamic cost of storage was used (but as a storage proof)
pub dynamic_cost_of_storage_proof: DynamicCostOfStorageProof,

/// Transaction fee storage proof
pub consensus_chain_byte_fee_proof: ConsensusTransactionByteFeeProof,

/// Change in the allowed chains storage proof
pub domain_chain_allowlist_proof: DomainChainsAllowlistUpdateStorageProof,
pub domain_sudo_call_proof: DomainSudoCallStorageProof,
}

impl DomainInherentExtrinsicDataProof {
impl InvalidExtrinsicsDataProof {
#[cfg(feature = "std")]
#[allow(clippy::let_and_return)]
pub fn generate<
Expand All @@ -437,6 +448,8 @@ impl DomainInherentExtrinsicDataProof {
block_hash: Block::Hash,
maybe_runtime_id: Option<RuntimeId>,
) -> Result<Self, GenerationError> {
let block_randomness_proof =
BlockRandomnessProof::generate(proof_provider, block_hash, (), storage_key_provider)?;
let timestamp_proof =
TimestampStorageProof::generate(proof_provider, block_hash, (), storage_key_provider)?;
let maybe_domain_runtime_upgrade_proof = MaybeDomainRuntimeUpgradedProof::generate(
Expand Down Expand Up @@ -464,20 +477,13 @@ impl DomainInherentExtrinsicDataProof {
storage_key_provider,
)?;

let domain_sudo_call_proof = DomainSudoCallStorageProof::generate(
proof_provider,
block_hash,
domain_id,
storage_key_provider,
)?;

Ok(Self {
block_randomness_proof,
timestamp_proof,
maybe_domain_runtime_upgrade_proof,
dynamic_cost_of_storage_proof,
consensus_chain_byte_fee_proof,
domain_chain_allowlist_proof,
domain_sudo_call_proof,
})
}

Expand All @@ -487,6 +493,12 @@ impl DomainInherentExtrinsicDataProof {
runtime_id: RuntimeId,
state_root: &Block::Hash,
) -> Result<DomainInherentExtrinsicData, VerificationError> {
let block_randomness = <BlockRandomnessProof as BasicStorageProof<Block>>::verify::<SKP>(
self.block_randomness_proof.clone(),
(),
state_root,
)?;

let timestamp = <TimestampStorageProof as BasicStorageProof<Block>>::verify::<SKP>(
self.timestamp_proof.clone(),
(),
Expand Down Expand Up @@ -523,18 +535,14 @@ impl DomainInherentExtrinsicDataProof {
state_root,
)?;

let domain_sudo_call = <DomainSudoCallStorageProof as BasicStorageProof<Block>>::verify::<
SKP,
>(
self.domain_sudo_call_proof.clone(), domain_id, state_root
)?;

Ok(DomainInherentExtrinsicData {
block_randomness,
timestamp,
maybe_domain_runtime_upgrade,
consensus_transaction_byte_fee,
domain_chain_allowlist,
maybe_sudo_runtime_call: domain_sudo_call.maybe_call,
// Populated by caller
maybe_sudo_runtime_call: None,
})
}
}
Expand Down
24 changes: 13 additions & 11 deletions crates/sp-domains-fraud-proof/src/verification.rs
Original file line number Diff line number Diff line change
Expand Up @@ -65,19 +65,24 @@ where
{
let InvalidExtrinsicsRootProof {
valid_bundle_digests,
block_randomness_proof,
domain_inherent_extrinsic_data_proof,
..
invalid_extrinsics_data_proof,
domain_sudo_call_proof,
} = fraud_proof;

let domain_inherent_extrinsic_data = domain_inherent_extrinsic_data_proof
.verify::<CBlock, SKP>(domain_id, runtime_id, &state_root)?;
let mut domain_inherent_extrinsic_data =
invalid_extrinsics_data_proof.verify::<CBlock, SKP>(domain_id, runtime_id, &state_root)?;

let block_randomness = <BlockRandomnessProof as BasicStorageProof<CBlock>>::verify::<SKP>(
block_randomness_proof.clone(),
(),
let domain_sudo_call = <DomainSudoCallStorageProof as BasicStorageProof<CBlock>>::verify::<SKP>(
domain_sudo_call_proof.clone(),
domain_id,
&state_root,
)?;
domain_inherent_extrinsic_data.maybe_sudo_runtime_call = domain_sudo_call.maybe_call;

let shuffling_seed = H256::from_slice(
extrinsics_shuffling_seed::<Hashing>(domain_inherent_extrinsic_data.block_randomness)
.as_ref(),
);

let DomainInherentExtrinsic {
domain_timestamp_extrinsic,
Expand Down Expand Up @@ -110,9 +115,6 @@ where
bundle_extrinsics_digests.extend(bundle_digest.bundle_digest.clone());
}

let shuffling_seed =
H256::from_slice(extrinsics_shuffling_seed::<Hashing>(block_randomness).as_ref());

let mut ordered_extrinsics = deduplicate_and_shuffle_extrinsics(
bundle_extrinsics_digests,
Randomness::from(shuffling_seed.to_fixed_bytes()),
Expand Down
20 changes: 10 additions & 10 deletions domains/client/domain-operator/src/fraud_proof.rs
Original file line number Diff line number Diff line change
Expand Up @@ -379,33 +379,33 @@ where
let maybe_domain_runtime_code_proof =
self.maybe_generate_domain_runtime_code_proof_for_receipt(domain_id, local_receipt)?;

let block_randomness_proof = BlockRandomnessProof::generate(
self.consensus_client.as_ref(),
consensus_block_hash,
(),
&self.storage_key_provider,
)?;

let maybe_runtime_id =
self.is_domain_runtime_updraded_at(domain_id, consensus_block_hash)?;

let domain_inherent_extrinsic_data_proof = DomainInherentExtrinsicDataProof::generate(
let invalid_extrinsics_data_proof = InvalidExtrinsicsDataProof::generate(
&self.storage_key_provider,
self.consensus_client.as_ref(),
domain_id,
consensus_block_hash,
maybe_runtime_id,
)?;

let domain_sudo_call_proof = DomainSudoCallStorageProof::generate(
self.consensus_client.as_ref(),
consensus_block_hash,
domain_id,
&self.storage_key_provider,
)?;

let invalid_domain_extrinsics_root_proof = FraudProof {
domain_id,
bad_receipt_hash,
maybe_mmr_proof: Some(mmr_proof),
maybe_domain_runtime_code_proof,
proof: FraudProofVariant::InvalidExtrinsicsRoot(InvalidExtrinsicsRootProof {
valid_bundle_digests,
block_randomness_proof,
domain_inherent_extrinsic_data_proof,
invalid_extrinsics_data_proof,
domain_sudo_call_proof,
}),
};

Expand Down

0 comments on commit 90428cc

Please sign in to comment.