#![cfg_attr(not(feature = "std"), no_std)]
#![allow(incomplete_features)]
#![feature(generic_const_exprs)]
#![feature(associated_type_defaults)]
#[cfg(feature = "std")]
pub mod execution_prover;
pub mod fraud_proof;
#[cfg(feature = "std")]
mod host_functions;
mod runtime_interface;
pub mod storage_proof;
#[cfg(test)]
pub mod test_ethereum_tx;
#[cfg(test)]
mod tests;
pub mod verification;
#[cfg(not(feature = "std"))]
extern crate alloc;
use crate::fraud_proof::FraudProof;
use crate::storage_proof::FraudProofStorageKeyRequest;
#[cfg(not(feature = "std"))]
use alloc::vec::Vec;
use codec::{Decode, Encode};
#[cfg(feature = "std")]
pub use host_functions::{
FraudProofExtension, FraudProofHostFunctions, FraudProofHostFunctionsImpl,
};
pub use runtime_interface::fraud_proof_runtime_interface;
#[cfg(feature = "std")]
pub use runtime_interface::fraud_proof_runtime_interface::HostFunctions;
use scale_info::TypeInfo;
use sp_core::H256;
use sp_domains::DomainAllowlistUpdates;
use sp_runtime::traits::{Header as HeaderT, NumberFor};
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_runtime_primitives::{Balance, Moment};
#[repr(u8)]
pub enum InvalidTransactionCode {
TransactionProof = 101,
ExecutionReceipt = 102,
Bundle = 103,
FraudProof = 104,
BundleStorageFeePayment = 105,
}
impl From<InvalidTransactionCode> for InvalidTransaction {
#[inline]
fn from(invalid_code: InvalidTransactionCode) -> Self {
InvalidTransaction::Custom(invalid_code as u8)
}
}
impl From<InvalidTransactionCode> for TransactionValidity {
#[inline]
fn from(invalid_code: InvalidTransactionCode) -> Self {
InvalidTransaction::Custom(invalid_code as u8).into()
}
}
#[derive(Debug, Decode, Encode, TypeInfo, PartialEq, Eq, Clone)]
pub enum StorageKeyRequest {
Transfers,
}
#[derive(Debug, Decode, Encode, TypeInfo, PartialEq, Eq, Clone)]
pub enum SetCodeExtrinsic {
None,
EncodedExtrinsic(Vec<u8>),
}
#[derive(Debug, Decode, Encode, TypeInfo, PartialEq, Eq, Clone)]
pub enum DomainChainAllowlistUpdateExtrinsic {
None,
EncodedExtrinsic(Vec<u8>),
}
#[derive(Debug, Decode, Encode, TypeInfo, PartialEq, Eq, Clone)]
pub struct DomainInherentExtrinsicData {
pub timestamp: Moment,
pub maybe_domain_runtime_upgrade: Option<Vec<u8>>,
pub consensus_transaction_byte_fee: Balance,
pub domain_chain_allowlist: DomainAllowlistUpdates,
pub maybe_sudo_runtime_call: Option<Vec<u8>>,
}
impl PassBy for DomainInherentExtrinsicData {
type PassBy = pass_by::Codec<Self>;
}
#[derive(Debug, Decode, Encode, TypeInfo, PartialEq, Eq, Clone)]
pub struct DomainInherentExtrinsic {
domain_timestamp_extrinsic: Vec<u8>,
maybe_domain_chain_allowlist_extrinsic: Option<Vec<u8>>,
consensus_chain_byte_fee_extrinsic: Vec<u8>,
maybe_domain_set_code_extrinsic: Option<Vec<u8>>,
maybe_domain_sudo_call_extrinsic: Option<Vec<u8>>,
}
#[derive(Debug, Decode, Encode, TypeInfo, PartialEq, Eq, Clone)]
pub enum DomainStorageKeyRequest {
BlockFees,
Transfers,
}
impl PassBy for DomainStorageKeyRequest {
type PassBy = pass_by::Codec<Self>;
}
#[derive(Debug, Decode, Encode, TypeInfo, PartialEq, Eq, Clone)]
pub enum StatelessDomainRuntimeCall {
IsTxInRange {
opaque_extrinsic: OpaqueExtrinsic,
domain_tx_range: U256,
bundle_vrf_hash: U256,
},
IsInherentExtrinsic(OpaqueExtrinsic),
IsDecodableExtrinsic(OpaqueExtrinsic),
IsValidDomainSudoCall(Vec<u8>),
}
impl PassBy for StatelessDomainRuntimeCall {
type PassBy = pass_by::Codec<Self>;
}
sp_api::decl_runtime_apis! {
pub trait FraudProofApi<DomainHeader: HeaderT> {
fn submit_fraud_proof_unsigned(fraud_proof: FraudProof<NumberFor<Block>, Block::Hash, DomainHeader, H256>);
fn fraud_proof_storage_key(req: FraudProofStorageKeyRequest<NumberFor<Block>>) -> Vec<u8>;
}
}