mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-07-05 03:57:24 +00:00
bda8641892
* Draft of new sessions * Reintroduce tuple impls * Move staking module to new session API * More work on staking and grandpa. * Use iterator to avoid cloning and tuple macro * Make runtime build again * Polish the OpaqueKeys devex * Move consensus logic into system & aura. * Fix up system module * Get build mostly going. Stuck at service.rs * Building again * Update srml/staking/src/lib.rs Co-Authored-By: DemiMarie-parity <48690212+DemiMarie-parity@users.noreply.github.com> * Refactoring out Consensus module, AuthorityIdOf, &c. * Refactored out DigestItem::AuthoritiesChanged. Building. * Remove tentative code * Remove invalid comment * Make Seal opaque and introduce nice methods for handling opaque items. * Start to use proper digest for Aura authorities tracking. * Fix up grandpa, remove system::Raw/Log * Refactor Grandpa to use new logging infrastructure. Also make authorityid/sessionkey static. Switch over to storing authorities in a straight Vec. * Building again * Tidy up some AuthorityIds * Expunge most of the rest of the AuthorityKey confusion. Also, de-generify Babe and re-generify Aura. * Remove cruft * Untangle last of the `AuthorityId`s. * Sort out finality_tracker * Refactor median getting * Apply suggestions from code review Co-Authored-By: Robert Habermeier <rphmeier@gmail.com> * Session tests works * Update core/sr-primitives/src/generic/digest.rs Co-Authored-By: DemiMarie-parity <48690212+DemiMarie-parity@users.noreply.github.com> * Session tests works * Fix for staking from @dvc94ch * log an error * fix test runtime build * Some test fixes * Staking mock update to new session api. * Fix build. * Move OpaqueKeys to primitives. * Use on_initialize instead of check_rotate_session. * Update tests to new staking api. * fixup mock * Fix bond_extra_and_withdraw_unbonded_works. * Fix bond_with_little_staked_value_bounded_by_slot_stake. * Fix bond_with_no_staked_value. * Fix change_controller_works. * Fix less_than_needed_candidates_works. * Fix multi_era_reward_should_work. * Fix nominating_and_rewards_should_work. * Fix nominators_also_get_slashed. * Fix phragmen_large_scale_test. * Fix phragmen_poc_works. * Fix phragmen_score_should_be_accurate_on_large_stakes. * Fix phragmen_should_not_overflow. * Fix reward_destination_works. * Fix rewards_should_work. * Fix sessions_and_eras_should_work. * Fix slot_stake_is_least_staked_validator. * Fix too_many_unbond_calls_should_not_work. * Fix wrong_vote_is_null. * Fix runtime. * Fix wasm runtime build. * Update Cargo.lock * Fix warnings. * Fix grandpa tests. * Fix test-runtime build. * Fix template node build. * Fix stuff. * Update Cargo.lock to fix CI * Re-add missing AuRa logs Runtimes are required to know about every digest they receive ― they panic otherwise. This re-adds support for AuRa pre-runtime digests. * Update core/consensus/babe/src/digest.rs Co-Authored-By: DemiMarie-parity <48690212+DemiMarie-parity@users.noreply.github.com> * Kill log trait and all that jazz. * Refactor staking tests. * Fix ci runtime wasm check. * Line length 120. * Make tests build again * Remove trailing commas in function declarations The `extern_functions!` macro doesn’t like them, perhaps due to a bug in rustc. * Fix type error * Fix compilation errors * Fix a test * Another couple of fixes * Fix another test * More test fixes * Another test fix * Bump runtime. * Wrap long line * Fix build, remove redundant code. * Issue to track TODO * Leave the benchmark code alone. * Fix missing `std::time::{Instant, Duration}` * Indentation * Aura ConsensusLog as enum
111 lines
3.2 KiB
Rust
111 lines
3.2 KiB
Rust
// Copyright 2019 Parity Technologies (UK) Ltd.
|
|
// This file is part of Substrate.
|
|
|
|
// Substrate 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.
|
|
|
|
// Substrate 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 Substrate. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
//! Private mplementation details of BABE digests.
|
|
|
|
use primitives::sr25519::{Public, Signature};
|
|
use babe_primitives::BABE_ENGINE_ID;
|
|
use runtime_primitives::{DigestItem, generic::OpaqueDigestItemId};
|
|
use std::fmt::Debug;
|
|
use parity_codec::{Decode, Encode, Codec, Input};
|
|
use schnorrkel::{
|
|
vrf::{VRFProof, VRFOutput, VRF_OUTPUT_LENGTH, VRF_PROOF_LENGTH},
|
|
PUBLIC_KEY_LENGTH,
|
|
};
|
|
|
|
/// A BABE pre-digest. It includes:
|
|
///
|
|
/// * The public key of the author.
|
|
/// * The VRF proof.
|
|
/// * The VRF output.
|
|
/// * The slot number.
|
|
#[derive(Clone, Debug, PartialEq, Eq)]
|
|
pub struct BabePreDigest {
|
|
pub(super) vrf_output: VRFOutput,
|
|
pub(super) proof: VRFProof,
|
|
pub(super) author: Public,
|
|
pub(super) slot_num: u64,
|
|
}
|
|
|
|
/// The prefix used by BABE for its VRF keys.
|
|
pub const BABE_VRF_PREFIX: &'static [u8] = b"substrate-babe-vrf";
|
|
|
|
type TmpDecode = (
|
|
[u8; VRF_OUTPUT_LENGTH],
|
|
[u8; VRF_PROOF_LENGTH],
|
|
[u8; PUBLIC_KEY_LENGTH],
|
|
u64,
|
|
);
|
|
|
|
impl Encode for BabePreDigest {
|
|
fn encode(&self) -> Vec<u8> {
|
|
let tmp: TmpDecode = (
|
|
*self.vrf_output.as_bytes(),
|
|
self.proof.to_bytes(),
|
|
self.author.0,
|
|
self.slot_num,
|
|
);
|
|
parity_codec::Encode::encode(&tmp)
|
|
}
|
|
}
|
|
|
|
impl Decode for BabePreDigest {
|
|
fn decode<R: Input>(i: &mut R) -> Option<Self> {
|
|
let (output, proof, public_key, slot_num): TmpDecode = Decode::decode(i)?;
|
|
Some(BabePreDigest {
|
|
proof: VRFProof::from_bytes(&proof).ok()?,
|
|
vrf_output: VRFOutput::from_bytes(&output).ok()?,
|
|
author: Public(public_key),
|
|
slot_num,
|
|
})
|
|
}
|
|
}
|
|
|
|
/// A digest item which is usable with BABE consensus.
|
|
pub trait CompatibleDigestItem: Sized {
|
|
/// Construct a digest item which contains a BABE pre-digest.
|
|
fn babe_pre_digest(seal: BabePreDigest) -> Self;
|
|
|
|
/// If this item is an BABE pre-digest, return it.
|
|
fn as_babe_pre_digest(&self) -> Option<BabePreDigest>;
|
|
|
|
/// Construct a digest item which contains a BABE seal.
|
|
fn babe_seal(signature: Signature) -> Self;
|
|
|
|
/// If this item is a BABE signature, return the signature.
|
|
fn as_babe_seal(&self) -> Option<Signature>;
|
|
}
|
|
|
|
impl<Hash> CompatibleDigestItem for DigestItem<Hash> where
|
|
Hash: Debug + Send + Sync + Eq + Clone + Codec + 'static
|
|
{
|
|
fn babe_pre_digest(digest: BabePreDigest) -> Self {
|
|
DigestItem::PreRuntime(BABE_ENGINE_ID, digest.encode())
|
|
}
|
|
|
|
fn as_babe_pre_digest(&self) -> Option<BabePreDigest> {
|
|
self.try_to(OpaqueDigestItemId::PreRuntime(&BABE_ENGINE_ID))
|
|
}
|
|
|
|
fn babe_seal(signature: Signature) -> Self {
|
|
DigestItem::Seal(BABE_ENGINE_ID, signature.encode())
|
|
}
|
|
|
|
fn as_babe_seal(&self) -> Option<Signature> {
|
|
self.try_to(OpaqueDigestItemId::Seal(&BABE_ENGINE_ID))
|
|
}
|
|
}
|