Skip to content

Commit

Permalink
feat: add governance config fields to global params proposal
Browse files Browse the repository at this point in the history
  • Loading branch information
devwckd committed Jan 8, 2025
1 parent fb6a0c7 commit 98d2dee
Show file tree
Hide file tree
Showing 5 changed files with 59 additions and 11 deletions.
1 change: 1 addition & 0 deletions pallets/governance/src/benchmarks.rs
Original file line number Diff line number Diff line change
Expand Up @@ -118,6 +118,7 @@ benchmarks! {
min_staking_fee: 1,
dividends_participation_weight: Percent::zero(),
proposal_cost: 0,
..Default::default()
};
let data = vec![0];

Expand Down
7 changes: 4 additions & 3 deletions pallets/governance/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -98,9 +98,6 @@ pub mod pallet {
#[pallet::constant]
type MaxApplicationDataLength: Get<u32>;

#[pallet::constant]
type ApplicationExpiration: Get<BlockAmount>;

#[pallet::constant]
type MaxPenaltyPercentage: Get<Percent>;

Expand Down Expand Up @@ -470,6 +467,10 @@ pub mod pallet {
InvalidMinStakingFee,
/// Invalid params given to Emission proposal
InvalidEmissionProposalData,
/// Invalid proposal reward interval given to global params proposal
InvalidProposalRewardInterval,
/// Invalid agent application cost given to global params proposal
InvalidAgentApplicationCost,
}
}

Expand Down
58 changes: 54 additions & 4 deletions pallets/governance/src/proposal.rs
Original file line number Diff line number Diff line change
@@ -1,13 +1,15 @@
use crate::config::GovernanceConfiguration;
use crate::frame::traits::ExistenceRequirement;
use crate::BlockAmount;
use crate::BoundedBTreeSet;
use crate::BoundedVec;
use crate::DebugNoBound;
use crate::NotDelegatingVotingPower;
use crate::TypeInfo;
use crate::{
AccountIdOf, BalanceOf, Block, DaoTreasuryAddress, Error, GlobalGovernanceConfig, Proposals,
UnrewardedProposals,
};
use crate::{GovernanceConfiguration, NotDelegatingVotingPower};
use codec::{Decode, Encode, MaxEncodedLen};
use polkadot_sdk::frame_election_provider_support::Get;
use polkadot_sdk::frame_support::traits::Currency;
Expand Down Expand Up @@ -91,6 +93,12 @@ impl<T: crate::Config> Proposal<T> {
min_staking_fee,
dividends_participation_weight,
proposal_cost,
proposal_expiration,
agent_application_cost,
agent_application_expiration,
proposal_reward_treasury_allocation,
max_proposal_reward_treasury_allocation,
proposal_reward_interval,
} = data;

pallet_torus0::MinNameLength::<T>::set(min_name_length);
Expand All @@ -106,8 +114,15 @@ impl<T: crate::Config> Proposal<T> {
});
pallet_emission0::MaxAllowedWeights::<T>::set(max_allowed_weights);
pallet_emission0::MinStakePerWeight::<T>::set(min_stake_per_weight);
crate::GlobalGovernanceConfig::<T>::mutate(|config| {
config.proposal_cost = proposal_cost;

crate::GlobalGovernanceConfig::<T>::set(GovernanceConfiguration::<T> {
proposal_cost,
proposal_expiration,
agent_application_cost,
agent_application_expiration,
proposal_reward_treasury_allocation,
max_proposal_reward_treasury_allocation,
proposal_reward_interval,
});
}
ProposalData::TransferDaoTreasury { account, amount } => {
Expand Down Expand Up @@ -198,6 +213,12 @@ pub struct GlobalParamsData<T: crate::Config> {
pub min_staking_fee: u8,
pub dividends_participation_weight: Percent,
pub proposal_cost: BalanceOf<T>,
pub proposal_expiration: BlockAmount,
pub agent_application_cost: BalanceOf<T>,
pub agent_application_expiration: BlockAmount,
pub proposal_reward_treasury_allocation: Percent,
pub max_proposal_reward_treasury_allocation: BalanceOf<T>,
pub proposal_reward_interval: BlockAmount,
}

impl<T: crate::Config> Default for GlobalParamsData<T> {
Expand All @@ -213,6 +234,13 @@ impl<T: crate::Config> Default for GlobalParamsData<T> {
dividends_participation_weight:
<T as pallet_torus0::Config>::DefaultDividendsParticipationWeight::get(),
proposal_cost: T::DefaultProposalCost::get(),
proposal_expiration: T::DefaultProposalExpiration::get(),
agent_application_cost: T::DefaultAgentApplicationCost::get(),
agent_application_expiration: T::DefaultAgentApplicationExpiration::get(),
proposal_reward_treasury_allocation: T::DefaultProposalRewardTreasuryAllocation::get(),
max_proposal_reward_treasury_allocation:
T::DefaultMaxProposalRewardTreasuryAllocation::get(),
proposal_reward_interval: T::DefaultProposalRewardInterval::get(),
}
}
}
Expand Down Expand Up @@ -254,6 +282,21 @@ impl<T: crate::Config> GlobalParamsData<T> {
crate::Error::<T>::InvalidProposalCost
);

ensure!(
(5_400..u64::MAX).contains(&self.proposal_expiration),
crate::Error::<T>::InvalidProposalExpiration
);

ensure!(
self.agent_application_cost <= 100_000_000_000_000_000_000_000,
crate::Error::<T>::InvalidAgentApplicationCost
);

ensure!(
self.proposal_reward_interval <= 100_000,
crate::Error::<T>::InvalidProposalRewardInterval
);

Ok(())
}
}
Expand Down Expand Up @@ -381,10 +424,17 @@ fn add_proposal<T: crate::Config>(
.ok()
.expect("blockchain will not exceed 2^64 blocks; QED.");

let expiration_block = match &data {
ProposalData::Emission { .. } => {
(current_block + 21_600).max(current_block + config.proposal_expiration)
}
_ => current_block + config.proposal_expiration,
};

let proposal = Proposal::<T> {
id: proposal_id,
proposer,
expiration_block: current_block + config.proposal_expiration,
expiration_block,
data,
status: ProposalStatus::Open {
votes_for: BoundedBTreeSet::new(),
Expand Down
2 changes: 0 additions & 2 deletions runtime/src/configs.rs
Original file line number Diff line number Diff line change
Expand Up @@ -372,8 +372,6 @@ impl pallet_governance::Config for Runtime {

type MaxApplicationDataLength = ConstU32<256>;

type ApplicationExpiration = ConstU64<2000>;

type MaxPenaltyPercentage = MaxPenaltyPercentage;

type DefaultTreasuryEmissionFee = DefaultTreasuryEmissionFee;
Expand Down
2 changes: 0 additions & 2 deletions test-utils/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -184,8 +184,6 @@ impl pallet_governance::Config for Test {

type MaxApplicationDataLength = ConstU32<256>;

type ApplicationExpiration = ConstU64<2000>;

type MaxPenaltyPercentage = MaxPenaltyPercentage;

type DefaultTreasuryEmissionFee = DefaultTreasuryEmissionFee;
Expand Down

0 comments on commit 98d2dee

Please sign in to comment.