mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-27 16:17:59 +00:00
969720c2ad
* babe: secondary blocks with VRF * Fix node runtime compile * Fix test-utils runtime interface * Fix babe tests * typo: v == 2 * babe: support online configuration upgrades * Fix rpc tests * Fix runtime version tests * Switch to use NextConfigDescriptor instead of changing runtime interface * Fix tests * epoch-changes: map function that allows converting with different epoch types * Add migration script for the epoch config change * Fix docs for PrimaryAndSecondaryVRFSlots * Add docs of `SecondaryVRF` in babe crate * babe-primitives: Secondary -> SecondaryPlain * babe-client: Secondary -> SecondaryPlain * Fix migration tests * test-utils-runtime: Secondary -> SecondaryPlain * Fix missing name change in test-utils-runtime * Fix migration: Epoch should be EpochV0 * Update client/consensus/babe/src/lib.rs Co-Authored-By: André Silva <123550+andresilva@users.noreply.github.com> * Fix new epochChanges version * Fix babe-primitives naming changes * Fix merge issues in babe-client Co-authored-by: André Silva <123550+andresilva@users.noreply.github.com> Co-authored-by: André Silva <andre.beat@gmail.com>
65 lines
1.6 KiB
Rust
65 lines
1.6 KiB
Rust
use codec::{Encode, Decode};
|
|
use sc_consensus_epochs::Epoch as EpochT;
|
|
use crate::{
|
|
Epoch, SlotNumber, AuthorityId, BabeAuthorityWeight, BabeGenesisConfiguration,
|
|
BabeEpochConfiguration, VRF_OUTPUT_LENGTH, NextEpochDescriptor,
|
|
};
|
|
|
|
/// BABE epoch information, version 0.
|
|
#[derive(Decode, Encode, PartialEq, Eq, Clone, Debug)]
|
|
pub struct EpochV0 {
|
|
/// The epoch index.
|
|
pub epoch_index: u64,
|
|
/// The starting slot of the epoch.
|
|
pub start_slot: SlotNumber,
|
|
/// The duration of this epoch.
|
|
pub duration: SlotNumber,
|
|
/// The authorities and their weights.
|
|
pub authorities: Vec<(AuthorityId, BabeAuthorityWeight)>,
|
|
/// Randomness for this epoch.
|
|
pub randomness: [u8; VRF_OUTPUT_LENGTH],
|
|
}
|
|
|
|
impl EpochT for EpochV0 {
|
|
type NextEpochDescriptor = NextEpochDescriptor;
|
|
type SlotNumber = SlotNumber;
|
|
|
|
fn increment(
|
|
&self,
|
|
descriptor: NextEpochDescriptor
|
|
) -> EpochV0 {
|
|
EpochV0 {
|
|
epoch_index: self.epoch_index + 1,
|
|
start_slot: self.start_slot + self.duration,
|
|
duration: self.duration,
|
|
authorities: descriptor.authorities,
|
|
randomness: descriptor.randomness,
|
|
}
|
|
}
|
|
|
|
fn start_slot(&self) -> SlotNumber {
|
|
self.start_slot
|
|
}
|
|
|
|
fn end_slot(&self) -> SlotNumber {
|
|
self.start_slot + self.duration
|
|
}
|
|
}
|
|
|
|
impl EpochV0 {
|
|
/// Migrate the sturct to current epoch version.
|
|
pub fn migrate(self, config: &BabeGenesisConfiguration) -> Epoch {
|
|
Epoch {
|
|
epoch_index: self.epoch_index,
|
|
start_slot: self.start_slot,
|
|
duration: self.duration,
|
|
authorities: self.authorities,
|
|
randomness: self.randomness,
|
|
config: BabeEpochConfiguration {
|
|
c: config.c,
|
|
allowed_slots: config.allowed_slots,
|
|
},
|
|
}
|
|
}
|
|
}
|