feat: Rebrand Polkadot/Substrate references to PezkuwiChain
This commit systematically rebrands various references from Parity Technologies' Polkadot/Substrate ecosystem to PezkuwiChain within the kurdistan-sdk. Key changes include: - Updated external repository URLs (zombienet-sdk, parity-db, parity-scale-codec, wasm-instrument) to point to pezkuwichain forks. - Modified internal documentation and code comments to reflect PezkuwiChain naming and structure. - Replaced direct references to with or specific paths within the for XCM, Pezkuwi, and other modules. - Cleaned up deprecated issue and PR references in various and files, particularly in and modules. - Adjusted image and logo URLs in documentation to point to PezkuwiChain assets. - Removed or rephrased comments related to external Polkadot/Substrate PRs and issues. This is a significant step towards fully customizing the SDK for the PezkuwiChain ecosystem.
This commit is contained in:
@@ -0,0 +1,332 @@
|
||||
// This file is part of Bizinikiwi.
|
||||
|
||||
// Copyright (C) Parity Technologies (UK) Ltd.
|
||||
// SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
use crate::{self as delegated_staking, types::AgentLedgerOuter};
|
||||
use pezframe_support::{
|
||||
assert_ok, derive_impl,
|
||||
pezpallet_prelude::*,
|
||||
parameter_types,
|
||||
traits::{ConstU64, Currency, VariantCountOf},
|
||||
PalletId,
|
||||
};
|
||||
|
||||
use pezsp_runtime::{traits::IdentityLookup, BuildStorage, Perbill};
|
||||
|
||||
use pezframe_election_provider_support::{
|
||||
bounds::{ElectionBounds, ElectionBoundsBuilder},
|
||||
onchain, SequentialPhragmen,
|
||||
};
|
||||
use pezframe_support::dispatch::RawOrigin;
|
||||
use pezpallet_staking::{ActiveEra, ActiveEraInfo, CurrentEra};
|
||||
use pezsp_core::{ConstBool, U256};
|
||||
use pezsp_runtime::traits::Convert;
|
||||
use pezsp_staking::{Agent, Stake, StakingInterface};
|
||||
|
||||
pub type T = Runtime;
|
||||
type Block = pezframe_system::mocking::MockBlock<Runtime>;
|
||||
pub type AccountId = u128;
|
||||
|
||||
pub const GENESIS_VALIDATOR: AccountId = 1;
|
||||
pub const GENESIS_NOMINATOR_ONE: AccountId = 101;
|
||||
pub const GENESIS_NOMINATOR_TWO: AccountId = 102;
|
||||
|
||||
#[derive_impl(pezframe_system::config_preludes::TestDefaultConfig)]
|
||||
impl pezframe_system::Config for Runtime {
|
||||
type Block = Block;
|
||||
type AccountData = pezpallet_balances::AccountData<Balance>;
|
||||
type AccountId = AccountId;
|
||||
type Lookup = IdentityLookup<Self::AccountId>;
|
||||
}
|
||||
|
||||
impl pezpallet_timestamp::Config for Runtime {
|
||||
type Moment = u64;
|
||||
type OnTimestampSet = ();
|
||||
type MinimumPeriod = ConstU64<5>;
|
||||
type WeightInfo = ();
|
||||
}
|
||||
|
||||
pub type Balance = u128;
|
||||
|
||||
parameter_types! {
|
||||
pub static ExistentialDeposit: Balance = 1;
|
||||
}
|
||||
|
||||
#[derive_impl(pezpallet_balances::config_preludes::TestDefaultConfig)]
|
||||
impl pezpallet_balances::Config for Runtime {
|
||||
type Balance = Balance;
|
||||
type ExistentialDeposit = ExistentialDeposit;
|
||||
type AccountStore = System;
|
||||
type FreezeIdentifier = RuntimeFreezeReason;
|
||||
type MaxFreezes = VariantCountOf<RuntimeFreezeReason>;
|
||||
type RuntimeFreezeReason = RuntimeFreezeReason;
|
||||
}
|
||||
|
||||
pezpallet_staking_reward_curve::build! {
|
||||
const I_NPOS: pezsp_runtime::curve::PiecewiseLinear<'static> = curve!(
|
||||
min_inflation: 0_025_000,
|
||||
max_inflation: 0_100_000,
|
||||
ideal_stake: 0_500_000,
|
||||
falloff: 0_050_000,
|
||||
max_piece_count: 40,
|
||||
test_precision: 0_005_000,
|
||||
);
|
||||
}
|
||||
|
||||
parameter_types! {
|
||||
pub const RewardCurve: &'static pezsp_runtime::curve::PiecewiseLinear<'static> = &I_NPOS;
|
||||
pub static ElectionsBoundsOnChain: ElectionBounds = ElectionBoundsBuilder::default().build();
|
||||
}
|
||||
pub struct OnChainSeqPhragmen;
|
||||
impl onchain::Config for OnChainSeqPhragmen {
|
||||
type System = Runtime;
|
||||
type Solver = SequentialPhragmen<Balance, pezsp_runtime::Perbill>;
|
||||
type DataProvider = Staking;
|
||||
type WeightInfo = ();
|
||||
type MaxWinnersPerPage = ConstU32<100>;
|
||||
type MaxBackersPerWinner = ConstU32<100>;
|
||||
type Sort = ConstBool<true>;
|
||||
type Bounds = ElectionsBoundsOnChain;
|
||||
}
|
||||
|
||||
#[derive_impl(pezpallet_staking::config_preludes::TestDefaultConfig)]
|
||||
impl pezpallet_staking::Config for Runtime {
|
||||
type OldCurrency = Balances;
|
||||
type Currency = Balances;
|
||||
type UnixTime = pezpallet_timestamp::Pallet<Self>;
|
||||
type AdminOrigin = pezframe_system::EnsureRoot<Self::AccountId>;
|
||||
type EraPayout = pezpallet_staking::ConvertCurve<RewardCurve>;
|
||||
type ElectionProvider = onchain::OnChainExecution<OnChainSeqPhragmen>;
|
||||
type GenesisElectionProvider = Self::ElectionProvider;
|
||||
type VoterList = pezpallet_staking::UseNominatorsAndValidatorsMap<Self>;
|
||||
type TargetList = pezpallet_staking::UseValidatorsMap<Self>;
|
||||
type EventListeners = (Pools, DelegatedStaking);
|
||||
type Filter = pezpallet_nomination_pools::AllPoolMembers<Self>;
|
||||
}
|
||||
|
||||
parameter_types! {
|
||||
pub const DelegatedStakingPalletId: PalletId = PalletId(*b"py/dlstk");
|
||||
pub const SlashRewardFraction: Perbill = Perbill::from_percent(10);
|
||||
}
|
||||
impl delegated_staking::Config for Runtime {
|
||||
type RuntimeEvent = RuntimeEvent;
|
||||
type PalletId = DelegatedStakingPalletId;
|
||||
type Currency = Balances;
|
||||
type OnSlash = ();
|
||||
type SlashRewardFraction = SlashRewardFraction;
|
||||
type RuntimeHoldReason = RuntimeHoldReason;
|
||||
type CoreStaking = Staking;
|
||||
}
|
||||
|
||||
pub struct BalanceToU256;
|
||||
impl Convert<Balance, U256> for BalanceToU256 {
|
||||
fn convert(n: Balance) -> U256 {
|
||||
n.into()
|
||||
}
|
||||
}
|
||||
pub struct U256ToBalance;
|
||||
impl Convert<U256, Balance> for U256ToBalance {
|
||||
fn convert(n: U256) -> Balance {
|
||||
n.try_into().unwrap()
|
||||
}
|
||||
}
|
||||
|
||||
parameter_types! {
|
||||
pub static MaxUnbonding: u32 = 8;
|
||||
pub const PoolsPalletId: PalletId = PalletId(*b"py/nopls");
|
||||
}
|
||||
impl pezpallet_nomination_pools::Config for Runtime {
|
||||
type RuntimeEvent = RuntimeEvent;
|
||||
type WeightInfo = ();
|
||||
type Currency = Balances;
|
||||
type RuntimeFreezeReason = RuntimeFreezeReason;
|
||||
type RewardCounter = pezsp_runtime::FixedU128;
|
||||
type BalanceToU256 = BalanceToU256;
|
||||
type U256ToBalance = U256ToBalance;
|
||||
type PostUnbondingPoolsWindow = ConstU32<2>;
|
||||
type PalletId = PoolsPalletId;
|
||||
type MaxMetadataLen = ConstU32<256>;
|
||||
type MaxUnbonding = MaxUnbonding;
|
||||
type MaxPointsToBalance = pezframe_support::traits::ConstU8<10>;
|
||||
type StakeAdapter =
|
||||
pezpallet_nomination_pools::adapter::DelegateStake<Self, Staking, DelegatedStaking>;
|
||||
type AdminOrigin = pezframe_system::EnsureRoot<Self::AccountId>;
|
||||
type BlockNumberProvider = System;
|
||||
type Filter = pezpallet_staking::AllStakers<Runtime>;
|
||||
}
|
||||
|
||||
pezframe_support::construct_runtime!(
|
||||
pub enum Runtime {
|
||||
System: pezframe_system,
|
||||
Timestamp: pezpallet_timestamp,
|
||||
Balances: pezpallet_balances,
|
||||
Staking: pezpallet_staking,
|
||||
Pools: pezpallet_nomination_pools,
|
||||
DelegatedStaking: delegated_staking,
|
||||
}
|
||||
);
|
||||
|
||||
#[derive(Default)]
|
||||
pub struct ExtBuilder {}
|
||||
|
||||
impl ExtBuilder {
|
||||
fn build(self) -> pezsp_io::TestExternalities {
|
||||
pezsp_tracing::try_init_simple();
|
||||
let mut storage =
|
||||
pezframe_system::GenesisConfig::<Runtime>::default().build_storage().unwrap();
|
||||
|
||||
let _ = pezpallet_balances::GenesisConfig::<T> {
|
||||
balances: vec![
|
||||
(GENESIS_VALIDATOR, 10000),
|
||||
(GENESIS_NOMINATOR_ONE, 1000),
|
||||
(GENESIS_NOMINATOR_TWO, 2000),
|
||||
],
|
||||
..Default::default()
|
||||
}
|
||||
.assimilate_storage(&mut storage);
|
||||
|
||||
let stakers = vec![
|
||||
(
|
||||
GENESIS_VALIDATOR,
|
||||
GENESIS_VALIDATOR,
|
||||
1000,
|
||||
pezsp_staking::StakerStatus::<AccountId>::Validator,
|
||||
),
|
||||
(
|
||||
GENESIS_NOMINATOR_ONE,
|
||||
GENESIS_NOMINATOR_ONE,
|
||||
100,
|
||||
pezsp_staking::StakerStatus::<AccountId>::Nominator(vec![1]),
|
||||
),
|
||||
(
|
||||
GENESIS_NOMINATOR_TWO,
|
||||
GENESIS_NOMINATOR_TWO,
|
||||
200,
|
||||
pezsp_staking::StakerStatus::<AccountId>::Nominator(vec![1]),
|
||||
),
|
||||
];
|
||||
|
||||
let _ = pezpallet_staking::GenesisConfig::<T> {
|
||||
stakers: stakers.clone(),
|
||||
// ideal validator count
|
||||
validator_count: 2,
|
||||
minimum_validator_count: 1,
|
||||
invulnerables: vec![],
|
||||
slash_reward_fraction: Perbill::from_percent(10),
|
||||
min_nominator_bond: ExistentialDeposit::get(),
|
||||
min_validator_bond: ExistentialDeposit::get(),
|
||||
..Default::default()
|
||||
}
|
||||
.assimilate_storage(&mut storage);
|
||||
|
||||
let mut ext = pezsp_io::TestExternalities::from(storage);
|
||||
|
||||
ext.execute_with(|| {
|
||||
// for events to be deposited.
|
||||
pezframe_system::Pallet::<Runtime>::set_block_number(1);
|
||||
// set era for staking.
|
||||
start_era(0);
|
||||
});
|
||||
|
||||
ext
|
||||
}
|
||||
pub fn build_and_execute(self, test: impl FnOnce()) {
|
||||
pezsp_tracing::try_init_simple();
|
||||
let mut ext = self.build();
|
||||
ext.execute_with(test);
|
||||
ext.execute_with(|| {
|
||||
#[cfg(feature = "try-runtime")]
|
||||
<AllPalletsWithSystem as pezframe_support::traits::TryState<u64>>::try_state(
|
||||
pezframe_system::Pallet::<Runtime>::block_number(),
|
||||
pezframe_support::traits::TryStateSelect::All,
|
||||
)
|
||||
.unwrap();
|
||||
#[cfg(not(feature = "try-runtime"))]
|
||||
DelegatedStaking::do_try_state().unwrap();
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
/// fund and return who.
|
||||
pub(crate) fn fund(who: &AccountId, amount: Balance) {
|
||||
let _ = Balances::deposit_creating(who, amount);
|
||||
}
|
||||
|
||||
/// Sets up delegation for passed delegators, returns total delegated amount.
|
||||
///
|
||||
/// `delegate_amount` is incremented by the amount `increment` starting with `base_delegate_amount`
|
||||
/// from lower index to higher index of delegators.
|
||||
pub(crate) fn setup_delegation_stake(
|
||||
agent: AccountId,
|
||||
reward_acc: AccountId,
|
||||
delegators: Vec<AccountId>,
|
||||
base_delegate_amount: Balance,
|
||||
increment: Balance,
|
||||
) -> Balance {
|
||||
fund(&agent, 100);
|
||||
assert_ok!(DelegatedStaking::register_agent(RawOrigin::Signed(agent).into(), reward_acc));
|
||||
let mut delegated_amount: Balance = 0;
|
||||
for (index, delegator) in delegators.iter().enumerate() {
|
||||
let amount_to_delegate = base_delegate_amount + increment * index as Balance;
|
||||
delegated_amount += amount_to_delegate;
|
||||
|
||||
fund(delegator, amount_to_delegate + ExistentialDeposit::get());
|
||||
assert_ok!(DelegatedStaking::delegate_to_agent(
|
||||
RawOrigin::Signed(*delegator).into(),
|
||||
agent,
|
||||
amount_to_delegate
|
||||
));
|
||||
}
|
||||
|
||||
// sanity checks
|
||||
assert_eq!(DelegatedStaking::stakeable_balance(Agent::from(agent)), delegated_amount);
|
||||
assert_eq!(AgentLedgerOuter::<T>::get(&agent).unwrap().available_to_bond(), 0);
|
||||
|
||||
delegated_amount
|
||||
}
|
||||
|
||||
pub(crate) fn start_era(era: pezsp_staking::EraIndex) {
|
||||
CurrentEra::<T>::set(Some(era));
|
||||
ActiveEra::<T>::set(Some(ActiveEraInfo { index: era, start: None }));
|
||||
}
|
||||
|
||||
pub(crate) fn eq_stake(who: AccountId, total: Balance, active: Balance) -> bool {
|
||||
Staking::stake(&who).unwrap() == Stake { total, active } &&
|
||||
get_agent_ledger(&who).ledger.stakeable_balance() == total
|
||||
}
|
||||
|
||||
pub(crate) fn get_agent_ledger(agent: &AccountId) -> AgentLedgerOuter<T> {
|
||||
AgentLedgerOuter::<T>::get(agent).expect("delegate should exist")
|
||||
}
|
||||
|
||||
parameter_types! {
|
||||
static ObservedEventsDelegatedStaking: usize = 0;
|
||||
static ObservedEventsPools: usize = 0;
|
||||
}
|
||||
|
||||
pub(crate) fn pool_events_since_last_call() -> Vec<pezpallet_nomination_pools::Event<Runtime>> {
|
||||
let events = System::read_events_for_pallet::<pezpallet_nomination_pools::Event<Runtime>>();
|
||||
let already_seen = ObservedEventsPools::get();
|
||||
ObservedEventsPools::set(events.len());
|
||||
events.into_iter().skip(already_seen).collect()
|
||||
}
|
||||
|
||||
pub(crate) fn events_since_last_call() -> Vec<crate::Event<Runtime>> {
|
||||
let events = System::read_events_for_pallet::<crate::Event<Runtime>>();
|
||||
let already_seen = ObservedEventsDelegatedStaking::get();
|
||||
ObservedEventsDelegatedStaking::set(events.len());
|
||||
events.into_iter().skip(already_seen).collect()
|
||||
}
|
||||
Reference in New Issue
Block a user