mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-06-13 18:41:05 +00:00
Remove im-online pallet from Rococo and Westend (#2265)
Co-authored-by: ordian <write@reusable.software> Co-authored-by: Vladimir Istyufeev <vladimir@parity.io>
This commit is contained in:
@@ -78,7 +78,6 @@ use frame_support::{
|
||||
use frame_system::EnsureRoot;
|
||||
use pallet_grandpa::{fg_primitives, AuthorityId as GrandpaId};
|
||||
use pallet_identity::legacy::IdentityInfo;
|
||||
use pallet_im_online::sr25519::AuthorityId as ImOnlineId;
|
||||
use pallet_session::historical as session_historical;
|
||||
use pallet_transaction_payment::{CurrencyAdapter, FeeDetails, RuntimeDispatchInfo};
|
||||
use sp_core::{ConstU128, OpaqueMetadata, H256};
|
||||
@@ -90,7 +89,8 @@ use sp_runtime::{
|
||||
Verify,
|
||||
},
|
||||
transaction_validity::{TransactionPriority, TransactionSource, TransactionValidity},
|
||||
ApplyExtrinsicResult, FixedU128, KeyTypeId, Perbill, Percent, Permill, RuntimeDebug,
|
||||
ApplyExtrinsicResult, BoundToRuntimeAppPublic, FixedU128, KeyTypeId, Perbill, Percent, Permill,
|
||||
RuntimeAppPublic, RuntimeDebug,
|
||||
};
|
||||
use sp_staking::SessionIndex;
|
||||
#[cfg(any(feature = "std", test))]
|
||||
@@ -354,14 +354,53 @@ impl pallet_timestamp::Config for Runtime {
|
||||
|
||||
impl pallet_authorship::Config for Runtime {
|
||||
type FindAuthor = pallet_session::FindAccountFromAuthorIndex<Self, Babe>;
|
||||
type EventHandler = ImOnline;
|
||||
type EventHandler = ();
|
||||
}
|
||||
|
||||
#[derive(Clone, Debug, PartialEq, Eq, Encode, Decode)]
|
||||
pub struct OldSessionKeys {
|
||||
pub grandpa: <Grandpa as BoundToRuntimeAppPublic>::Public,
|
||||
pub babe: <Babe as BoundToRuntimeAppPublic>::Public,
|
||||
pub im_online: pallet_im_online::sr25519::AuthorityId,
|
||||
pub para_validator: <Initializer as BoundToRuntimeAppPublic>::Public,
|
||||
pub para_assignment: <ParaSessionInfo as BoundToRuntimeAppPublic>::Public,
|
||||
pub authority_discovery: <AuthorityDiscovery as BoundToRuntimeAppPublic>::Public,
|
||||
pub beefy: <Beefy as BoundToRuntimeAppPublic>::Public,
|
||||
}
|
||||
|
||||
impl OpaqueKeys for OldSessionKeys {
|
||||
type KeyTypeIdProviders = ();
|
||||
fn key_ids() -> &'static [KeyTypeId] {
|
||||
&[
|
||||
<<Grandpa as BoundToRuntimeAppPublic>::Public>::ID,
|
||||
<<Babe as BoundToRuntimeAppPublic>::Public>::ID,
|
||||
sp_core::crypto::key_types::IM_ONLINE,
|
||||
<<Initializer as BoundToRuntimeAppPublic>::Public>::ID,
|
||||
<<ParaSessionInfo as BoundToRuntimeAppPublic>::Public>::ID,
|
||||
<<AuthorityDiscovery as BoundToRuntimeAppPublic>::Public>::ID,
|
||||
<<Beefy as BoundToRuntimeAppPublic>::Public>::ID,
|
||||
]
|
||||
}
|
||||
fn get_raw(&self, i: KeyTypeId) -> &[u8] {
|
||||
match i {
|
||||
<<Grandpa as BoundToRuntimeAppPublic>::Public>::ID => self.grandpa.as_ref(),
|
||||
<<Babe as BoundToRuntimeAppPublic>::Public>::ID => self.babe.as_ref(),
|
||||
sp_core::crypto::key_types::IM_ONLINE => self.im_online.as_ref(),
|
||||
<<Initializer as BoundToRuntimeAppPublic>::Public>::ID => self.para_validator.as_ref(),
|
||||
<<ParaSessionInfo as BoundToRuntimeAppPublic>::Public>::ID =>
|
||||
self.para_assignment.as_ref(),
|
||||
<<AuthorityDiscovery as BoundToRuntimeAppPublic>::Public>::ID =>
|
||||
self.authority_discovery.as_ref(),
|
||||
<<Beefy as BoundToRuntimeAppPublic>::Public>::ID => self.beefy.as_ref(),
|
||||
_ => &[],
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl_opaque_keys! {
|
||||
pub struct SessionKeys {
|
||||
pub grandpa: Grandpa,
|
||||
pub babe: Babe,
|
||||
pub im_online: ImOnline,
|
||||
pub para_validator: Initializer,
|
||||
pub para_assignment: ParaSessionInfo,
|
||||
pub authority_discovery: AuthorityDiscovery,
|
||||
@@ -369,6 +408,18 @@ impl_opaque_keys! {
|
||||
}
|
||||
}
|
||||
|
||||
// remove this when removing `OldSessionKeys`
|
||||
fn transform_session_keys(_val: AccountId, old: OldSessionKeys) -> SessionKeys {
|
||||
SessionKeys {
|
||||
grandpa: old.grandpa,
|
||||
babe: old.babe,
|
||||
para_validator: old.para_validator,
|
||||
para_assignment: old.para_assignment,
|
||||
authority_discovery: old.authority_discovery,
|
||||
beefy: old.beefy,
|
||||
}
|
||||
}
|
||||
|
||||
/// Special `ValidatorIdOf` implementation that is just returning the input as result.
|
||||
pub struct ValidatorIdOf;
|
||||
impl sp_runtime::traits::Convert<AccountId, Option<AccountId>> for ValidatorIdOf {
|
||||
@@ -513,22 +564,6 @@ impl pallet_authority_discovery::Config for Runtime {
|
||||
type MaxAuthorities = MaxAuthorities;
|
||||
}
|
||||
|
||||
parameter_types! {
|
||||
pub const ImOnlineUnsignedPriority: TransactionPriority = TransactionPriority::max_value();
|
||||
}
|
||||
|
||||
impl pallet_im_online::Config for Runtime {
|
||||
type AuthorityId = ImOnlineId;
|
||||
type RuntimeEvent = RuntimeEvent;
|
||||
type ValidatorSet = Historical;
|
||||
type NextSessionRotation = Babe;
|
||||
type ReportUnresponsiveness = Offences;
|
||||
type UnsignedPriority = ImOnlineUnsignedPriority;
|
||||
type WeightInfo = weights::pallet_im_online::WeightInfo<Runtime>;
|
||||
type MaxKeys = MaxKeys;
|
||||
type MaxPeerInHeartbeats = MaxPeerInHeartbeats;
|
||||
}
|
||||
|
||||
parameter_types! {
|
||||
pub const MaxSetIdSessionEntries: u32 = BondingDuration::get() * SessionsPerEra::get();
|
||||
}
|
||||
@@ -778,7 +813,6 @@ impl InstanceFilter<RuntimeCall> for ProxyType {
|
||||
// Specifically omitting the entire Balances pallet
|
||||
RuntimeCall::Session(..) |
|
||||
RuntimeCall::Grandpa(..) |
|
||||
RuntimeCall::ImOnline(..) |
|
||||
RuntimeCall::Treasury(..) |
|
||||
RuntimeCall::Bounties(..) |
|
||||
RuntimeCall::ChildBounties(..) |
|
||||
@@ -1292,8 +1326,7 @@ construct_runtime! {
|
||||
TransactionPayment: pallet_transaction_payment::{Pallet, Storage, Event<T>} = 33,
|
||||
|
||||
// Consensus support.
|
||||
// Authorship must be before session in order to note author in the correct session and era
|
||||
// for im-online.
|
||||
// Authorship must be before session in order to note author in the correct session and era.
|
||||
Authorship: pallet_authorship::{Pallet, Storage} = 5,
|
||||
Offences: pallet_offences::{Pallet, Storage, Event} = 7,
|
||||
Historical: session_historical::{Pallet} = 34,
|
||||
@@ -1307,7 +1340,6 @@ construct_runtime! {
|
||||
|
||||
Session: pallet_session::{Pallet, Call, Storage, Event, Config<T>} = 8,
|
||||
Grandpa: pallet_grandpa::{Pallet, Call, Storage, Config<T>, Event, ValidateUnsigned} = 10,
|
||||
ImOnline: pallet_im_online::{Pallet, Call, Storage, Event<T>, ValidateUnsigned, Config<T>} = 11,
|
||||
AuthorityDiscovery: pallet_authority_discovery::{Pallet, Config<T>} = 12,
|
||||
|
||||
// Governance stuff; uncallable initially.
|
||||
@@ -1453,6 +1485,8 @@ pub mod migrations {
|
||||
|
||||
use frame_support::traits::LockIdentifier;
|
||||
use frame_system::pallet_prelude::BlockNumberFor;
|
||||
#[cfg(feature = "try-runtime")]
|
||||
use sp_core::crypto::ByteArray;
|
||||
|
||||
parameter_types! {
|
||||
pub const DemocracyPalletName: &'static str = "Democracy";
|
||||
@@ -1461,6 +1495,7 @@ pub mod migrations {
|
||||
pub const PhragmenElectionPalletName: &'static str = "PhragmenElection";
|
||||
pub const TechnicalMembershipPalletName: &'static str = "TechnicalMembership";
|
||||
pub const TipsPalletName: &'static str = "Tips";
|
||||
pub const ImOnlinePalletName: &'static str = "ImOnline";
|
||||
pub const PhragmenElectionPalletId: LockIdentifier = *b"phrelect";
|
||||
}
|
||||
|
||||
@@ -1497,10 +1532,82 @@ pub mod migrations {
|
||||
type PalletName = TipsPalletName;
|
||||
}
|
||||
|
||||
/// Upgrade Session keys to exclude `ImOnline` key.
|
||||
/// When this is removed, should also remove `OldSessionKeys`.
|
||||
pub struct UpgradeSessionKeys;
|
||||
const UPGRADE_SESSION_KEYS_FROM_SPEC: u32 = 104000;
|
||||
|
||||
impl frame_support::traits::OnRuntimeUpgrade for UpgradeSessionKeys {
|
||||
#[cfg(feature = "try-runtime")]
|
||||
fn pre_upgrade() -> Result<sp_std::vec::Vec<u8>, sp_runtime::TryRuntimeError> {
|
||||
if System::last_runtime_upgrade_spec_version() > UPGRADE_SESSION_KEYS_FROM_SPEC {
|
||||
log::warn!(target: "runtime::session_keys", "Skipping session keys migration pre-upgrade check due to spec version (already applied?)");
|
||||
return Ok(Vec::new())
|
||||
}
|
||||
|
||||
log::info!(target: "runtime::session_keys", "Collecting pre-upgrade session keys state");
|
||||
let key_ids = SessionKeys::key_ids();
|
||||
frame_support::ensure!(
|
||||
key_ids.into_iter().find(|&k| *k == sp_core::crypto::key_types::IM_ONLINE) == None,
|
||||
"New session keys contain the ImOnline key that should have been removed",
|
||||
);
|
||||
let storage_key = pallet_session::QueuedKeys::<Runtime>::hashed_key();
|
||||
let mut state: Vec<u8> = Vec::new();
|
||||
frame_support::storage::unhashed::get::<Vec<(ValidatorId, OldSessionKeys)>>(
|
||||
&storage_key,
|
||||
)
|
||||
.ok_or::<sp_runtime::TryRuntimeError>("Queued keys are not available".into())?
|
||||
.into_iter()
|
||||
.for_each(|(id, keys)| {
|
||||
state.extend_from_slice(id.as_slice());
|
||||
for key_id in key_ids {
|
||||
state.extend_from_slice(keys.get_raw(*key_id));
|
||||
}
|
||||
});
|
||||
frame_support::ensure!(state.len() > 0, "Queued keys are not empty before upgrade");
|
||||
Ok(state)
|
||||
}
|
||||
|
||||
fn on_runtime_upgrade() -> Weight {
|
||||
if System::last_runtime_upgrade_spec_version() > UPGRADE_SESSION_KEYS_FROM_SPEC {
|
||||
log::info!("Skipping session keys upgrade: already applied");
|
||||
return <Runtime as frame_system::Config>::DbWeight::get().reads(1)
|
||||
}
|
||||
log::trace!("Upgrading session keys");
|
||||
Session::upgrade_keys::<OldSessionKeys, _>(transform_session_keys);
|
||||
Perbill::from_percent(50) * BlockWeights::get().max_block
|
||||
}
|
||||
|
||||
#[cfg(feature = "try-runtime")]
|
||||
fn post_upgrade(
|
||||
old_state: sp_std::vec::Vec<u8>,
|
||||
) -> Result<(), sp_runtime::TryRuntimeError> {
|
||||
if System::last_runtime_upgrade_spec_version() > UPGRADE_SESSION_KEYS_FROM_SPEC {
|
||||
log::warn!(target: "runtime::session_keys", "Skipping session keys migration post-upgrade check due to spec version (already applied?)");
|
||||
return Ok(())
|
||||
}
|
||||
|
||||
let key_ids = SessionKeys::key_ids();
|
||||
let mut new_state: Vec<u8> = Vec::new();
|
||||
pallet_session::QueuedKeys::<Runtime>::get().into_iter().for_each(|(id, keys)| {
|
||||
new_state.extend_from_slice(id.as_slice());
|
||||
for key_id in key_ids {
|
||||
new_state.extend_from_slice(keys.get_raw(*key_id));
|
||||
}
|
||||
});
|
||||
frame_support::ensure!(new_state.len() > 0, "Queued keys are not empty after upgrade");
|
||||
frame_support::ensure!(
|
||||
old_state == new_state,
|
||||
"Pre-upgrade and post-upgrade keys do not match!"
|
||||
);
|
||||
log::info!(target: "runtime::session_keys", "Session keys migrated successfully");
|
||||
Ok(())
|
||||
}
|
||||
}
|
||||
|
||||
/// Unreleased migrations. Add new ones here:
|
||||
pub type Unreleased = (
|
||||
pallet_society::migrations::MigrateToV2<Runtime, (), ()>,
|
||||
pallet_im_online::migration::v1::Migration<Runtime>,
|
||||
parachains_configuration::migration::v7::MigrateToV7<Runtime>,
|
||||
assigned_slots::migration::v1::MigrateToV1<Runtime>,
|
||||
parachains_scheduler::migration::v1::MigrateToV1<Runtime>,
|
||||
@@ -1527,6 +1634,12 @@ pub mod migrations {
|
||||
|
||||
pallet_grandpa::migrations::MigrateV4ToV5<Runtime>,
|
||||
parachains_configuration::migration::v10::MigrateToV10<Runtime>,
|
||||
|
||||
// Upgrade `SessionKeys` to exclude `ImOnline`
|
||||
UpgradeSessionKeys,
|
||||
|
||||
// Remove `im-online` pallet on-chain storage
|
||||
frame_support::migrations::RemovePallet<ImOnlinePalletName, <Runtime as frame_system::Config>::DbWeight>,
|
||||
);
|
||||
}
|
||||
|
||||
@@ -1597,7 +1710,6 @@ mod benches {
|
||||
[pallet_conviction_voting, ConvictionVoting]
|
||||
[pallet_nis, Nis]
|
||||
[pallet_identity, Identity]
|
||||
[pallet_im_online, ImOnline]
|
||||
[pallet_indices, Indices]
|
||||
[pallet_message_queue, MessageQueue]
|
||||
[pallet_multisig, Multisig]
|
||||
|
||||
Reference in New Issue
Block a user