mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-05-30 11:41:02 +00:00
4ef53912e6
* define Id type in polkadot-parachain and depend on that in primitives. * fix tests
286 lines
9.1 KiB
Rust
286 lines
9.1 KiB
Rust
// Copyright 2017 Parity Technologies (UK) Ltd.
|
|
// This file is part of Polkadot.
|
|
|
|
// Polkadot is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
|
|
// Polkadot is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with Polkadot. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
//! Polkadot parachain types.
|
|
|
|
use rstd::prelude::*;
|
|
use rstd::cmp::Ordering;
|
|
use super::{Hash, SessionKey};
|
|
|
|
use {AccountId};
|
|
|
|
#[cfg(feature = "std")]
|
|
use primitives::bytes;
|
|
|
|
pub use polkadot_parachain::Id;
|
|
|
|
/// Signature on candidate's block data by a collator.
|
|
pub type CandidateSignature = ::runtime_primitives::Ed25519Signature;
|
|
|
|
/// Identifier for a chain, either one of a number of parachains or the relay chain.
|
|
#[derive(Copy, Clone, PartialEq, Encode, Decode)]
|
|
#[cfg_attr(feature = "std", derive(Debug))]
|
|
pub enum Chain {
|
|
/// The relay chain.
|
|
Relay,
|
|
/// A parachain of the given index.
|
|
Parachain(Id),
|
|
}
|
|
|
|
/// The duty roster specifying what jobs each validator must do.
|
|
#[derive(Clone, PartialEq, Encode, Decode)]
|
|
#[cfg_attr(feature = "std", derive(Default, Debug))]
|
|
pub struct DutyRoster {
|
|
/// Lookup from validator index to chain on which that validator has a duty to validate.
|
|
pub validator_duty: Vec<Chain>,
|
|
}
|
|
|
|
/// An outgoing message
|
|
#[derive(Clone, PartialEq, Eq, Encode, Decode)]
|
|
#[cfg_attr(feature = "std", derive(Serialize, Deserialize, Debug))]
|
|
#[cfg_attr(feature = "std", serde(rename_all = "camelCase"))]
|
|
#[cfg_attr(feature = "std", serde(deny_unknown_fields))]
|
|
pub struct OutgoingMessage {
|
|
/// The target parachain.
|
|
pub target: Id,
|
|
/// The message data.
|
|
pub data: Vec<u8>,
|
|
}
|
|
|
|
impl PartialOrd for OutgoingMessage {
|
|
fn partial_cmp(&self, other: &Self) -> Option<Ordering> {
|
|
Some(self.target.cmp(&other.target))
|
|
}
|
|
}
|
|
|
|
impl Ord for OutgoingMessage {
|
|
fn cmp(&self, other: &Self) -> Ordering {
|
|
self.target.cmp(&other.target)
|
|
}
|
|
}
|
|
|
|
/// Extrinsic data for a parachain candidate.
|
|
///
|
|
/// This is data produced by evaluating the candidate. It contains
|
|
/// full records of all outgoing messages to other parachains.
|
|
#[derive(PartialEq, Eq, Clone, Encode, Decode)]
|
|
#[cfg_attr(feature = "std", derive(Serialize, Deserialize, Debug))]
|
|
#[cfg_attr(feature = "std", serde(rename_all = "camelCase"))]
|
|
#[cfg_attr(feature = "std", serde(deny_unknown_fields))]
|
|
pub struct Extrinsic {
|
|
/// The outgoing messages from the execution of the parachain.
|
|
///
|
|
/// This must be sorted in ascending order by parachain ID.
|
|
pub outgoing_messages: Vec<OutgoingMessage>
|
|
}
|
|
|
|
/// Candidate receipt type.
|
|
#[derive(PartialEq, Eq, Clone, Encode, Decode)]
|
|
#[cfg_attr(feature = "std", derive(Serialize, Deserialize, Debug))]
|
|
#[cfg_attr(feature = "std", serde(rename_all = "camelCase"))]
|
|
#[cfg_attr(feature = "std", serde(deny_unknown_fields))]
|
|
pub struct CandidateReceipt {
|
|
/// The ID of the parachain this is a candidate for.
|
|
pub parachain_index: Id,
|
|
/// The collator's relay-chain account ID
|
|
pub collator: super::AccountId,
|
|
/// Signature on blake2-256 of the block data by collator.
|
|
pub signature: CandidateSignature,
|
|
/// The head-data
|
|
pub head_data: HeadData,
|
|
/// Balance uploads to the relay chain.
|
|
pub balance_uploads: Vec<(super::AccountId, u64)>,
|
|
/// Egress queue roots. Must be sorted lexicographically (ascending)
|
|
/// by parachain ID.
|
|
pub egress_queue_roots: Vec<(Id, Hash)>,
|
|
/// Fees paid from the chain to the relay chain validators
|
|
pub fees: u64,
|
|
/// blake2-256 Hash of block data.
|
|
pub block_data_hash: Hash,
|
|
}
|
|
|
|
impl CandidateReceipt {
|
|
/// Get the blake2_256 hash
|
|
pub fn hash(&self) -> Hash {
|
|
use runtime_primitives::traits::{BlakeTwo256, Hash};
|
|
BlakeTwo256::hash_of(self)
|
|
}
|
|
|
|
/// Check integrity vs. provided block data.
|
|
pub fn check_signature(&self) -> Result<(), ()> {
|
|
use runtime_primitives::traits::Verify;
|
|
|
|
if self.signature.verify(self.block_data_hash.as_ref(), &self.collator) {
|
|
Ok(())
|
|
} else {
|
|
Err(())
|
|
}
|
|
}
|
|
}
|
|
|
|
impl PartialOrd for CandidateReceipt {
|
|
fn partial_cmp(&self, other: &Self) -> Option<Ordering> {
|
|
Some(self.cmp(other))
|
|
}
|
|
}
|
|
|
|
impl Ord for CandidateReceipt {
|
|
fn cmp(&self, other: &Self) -> Ordering {
|
|
// TODO: compare signatures or something more sane
|
|
self.parachain_index.cmp(&other.parachain_index)
|
|
.then_with(|| self.head_data.cmp(&other.head_data))
|
|
}
|
|
}
|
|
|
|
/// A full collation.
|
|
#[derive(PartialEq, Eq, Clone, Encode, Decode)]
|
|
#[cfg_attr(feature = "std", derive(Serialize, Deserialize, Debug))]
|
|
#[cfg_attr(feature = "std", serde(rename_all = "camelCase"))]
|
|
#[cfg_attr(feature = "std", serde(deny_unknown_fields))]
|
|
pub struct Collation {
|
|
/// Block data.
|
|
pub block_data: BlockData,
|
|
/// Candidate receipt itself.
|
|
pub receipt: CandidateReceipt,
|
|
}
|
|
|
|
/// Parachain ingress queue message.
|
|
#[derive(PartialEq, Eq, Clone)]
|
|
#[cfg_attr(feature = "std", derive(Serialize, Deserialize, Encode, Decode, Debug))]
|
|
pub struct Message(#[cfg_attr(feature = "std", serde(with="bytes"))] pub Vec<u8>);
|
|
|
|
/// Consolidated ingress queue data.
|
|
///
|
|
/// This is just an ordered vector of other parachains' egress queues,
|
|
/// obtained according to the routing rules.
|
|
#[derive(Default, PartialEq, Eq, Clone)]
|
|
#[cfg_attr(feature = "std", derive(Serialize, Deserialize, Debug))]
|
|
pub struct ConsolidatedIngress(pub Vec<(Id, Vec<Message>)>);
|
|
|
|
/// Parachain block data.
|
|
///
|
|
/// contains everything required to validate para-block, may contain block and witness data
|
|
#[derive(PartialEq, Eq, Clone, Encode, Decode)]
|
|
#[cfg_attr(feature = "std", derive(Serialize, Deserialize, Debug))]
|
|
pub struct BlockData(#[cfg_attr(feature = "std", serde(with="bytes"))] pub Vec<u8>);
|
|
|
|
impl BlockData {
|
|
/// Compute hash of block data.
|
|
#[cfg(feature = "std")]
|
|
pub fn hash(&self) -> Hash {
|
|
use runtime_primitives::traits::{BlakeTwo256, Hash};
|
|
BlakeTwo256::hash(&self.0[..])
|
|
}
|
|
}
|
|
/// Parachain header raw bytes wrapper type.
|
|
#[derive(PartialEq, Eq)]
|
|
#[cfg_attr(feature = "std", derive(Serialize, Deserialize, Debug))]
|
|
pub struct Header(#[cfg_attr(feature = "std", serde(with="bytes"))] pub Vec<u8>);
|
|
|
|
/// Parachain head data included in the chain.
|
|
#[derive(PartialEq, Eq, Clone, PartialOrd, Ord, Encode, Decode)]
|
|
#[cfg_attr(feature = "std", derive(Serialize, Deserialize, Debug))]
|
|
pub struct HeadData(#[cfg_attr(feature = "std", serde(with="bytes"))] pub Vec<u8>);
|
|
|
|
/// Parachain validation code.
|
|
#[derive(PartialEq, Eq)]
|
|
#[cfg_attr(feature = "std", derive(Serialize, Deserialize, Debug))]
|
|
pub struct ValidationCode(#[cfg_attr(feature = "std", serde(with="bytes"))] pub Vec<u8>);
|
|
|
|
/// Activity bit field
|
|
#[derive(PartialEq, Eq, Clone, Default, Encode, Decode)]
|
|
#[cfg_attr(feature = "std", derive(Serialize, Deserialize, Debug))]
|
|
pub struct Activity(#[cfg_attr(feature = "std", serde(with="bytes"))] pub Vec<u8>);
|
|
|
|
/// Statements which can be made about parachain candidates.
|
|
#[derive(Clone, PartialEq, Eq, Encode)]
|
|
#[cfg_attr(feature = "std", derive(Debug))]
|
|
pub enum Statement {
|
|
/// Proposal of a parachain candidate.
|
|
#[codec(index = "1")]
|
|
Candidate(CandidateReceipt),
|
|
/// State that a parachain candidate is valid.
|
|
#[codec(index = "2")]
|
|
Valid(Hash),
|
|
/// State a candidate is invalid.
|
|
#[codec(index = "3")]
|
|
Invalid(Hash),
|
|
}
|
|
|
|
/// An either implicit or explicit attestation to the validity of a parachain
|
|
/// candidate.
|
|
#[derive(Clone, PartialEq, Decode, Encode)]
|
|
#[cfg_attr(feature = "std", derive(Debug))]
|
|
pub enum ValidityAttestation {
|
|
/// implicit validity attestation by issuing.
|
|
/// This corresponds to issuance of a `Candidate` statement.
|
|
#[codec(index = "1")]
|
|
Implicit(CandidateSignature),
|
|
/// An explicit attestation. This corresponds to issuance of a
|
|
/// `Valid` statement.
|
|
#[codec(index = "2")]
|
|
Explicit(CandidateSignature),
|
|
}
|
|
|
|
/// An attested candidate.
|
|
#[derive(Clone, PartialEq, Decode, Encode)]
|
|
#[cfg_attr(feature = "std", derive(Debug))]
|
|
pub struct AttestedCandidate {
|
|
/// The candidate data.
|
|
pub candidate: CandidateReceipt,
|
|
/// Validity attestations.
|
|
pub validity_votes: Vec<(SessionKey, ValidityAttestation)>,
|
|
}
|
|
|
|
impl AttestedCandidate {
|
|
/// Get the candidate.
|
|
pub fn candidate(&self) -> &CandidateReceipt {
|
|
&self.candidate
|
|
}
|
|
|
|
/// Get the group ID of the candidate.
|
|
pub fn parachain_index(&self) -> Id {
|
|
self.candidate.parachain_index
|
|
}
|
|
}
|
|
|
|
decl_runtime_apis! {
|
|
/// The API for querying the state of parachains on-chain.
|
|
pub trait ParachainHost {
|
|
/// Get the current validators.
|
|
fn validators() -> Vec<AccountId>;
|
|
/// Get the current duty roster.
|
|
fn duty_roster() -> DutyRoster;
|
|
/// Get the currently active parachains.
|
|
fn active_parachains() -> Vec<Id>;
|
|
/// Get the given parachain's head data blob.
|
|
fn parachain_head(id: Id) -> Option<Vec<u8>>;
|
|
/// Get the given parachain's head code blob.
|
|
fn parachain_code(id: Id) -> Option<Vec<u8>>;
|
|
/// Get the ingress roots to a specific parachain at a
|
|
/// block.
|
|
fn ingress(to: Id) -> Option<Vec<(Id, Hash)>>;
|
|
}
|
|
}
|
|
|
|
/// Runtime ID module.
|
|
pub mod id {
|
|
use sr_version::ApiId;
|
|
|
|
/// Parachain host runtime API id.
|
|
pub const PARACHAIN_HOST: ApiId = *b"parahost";
|
|
}
|