Skip to content

Commit

Permalink
Technical committee as collective body is set for the WhitelistOrigin (
Browse files Browse the repository at this point in the history
…#351)

## Description
<!-- Describe what change this PR is implementing -->
This PR sets the WhitelistOrigin that has permission to approve
pre-images (and therefore referendums) to the Technical Committee
Collective body. This way, we will be able to upgrade the runtime via
the `Whitelisted Caller` track without applying the SUDO call every
time.


## Types of Changes
Please select the branch type you are merging and fill in the relevant
template.
<!--- Check the following box with an x if the following applies: -->
- [ ] Hotfix
- [ ] Release
- [ ] Fix or Feature

## Fix or Feature
<!--- Check the following box with an x if the following applies: -->

### Types of Changes
<!--- What types of changes does your code introduce? -->
- [x] Tech Debt (Code improvements)
- [ ] Bug fix (non-breaking change which fixes an issue)
- [x] New feature (non-breaking change which adds functionality)
- [ ] Breaking change (fix or feature that would cause existing
functionality to change)
- [ ] Dependency upgrade (A change in substrate or any 3rd party crate
version)

### Migrations and Hooks
<!--- Check the following box with an x if the following applies: -->
- [ ] This change requires a runtime migration.
- [ ] Modifies `on_initialize`
- [ ] Modifies `on_finalize`

### Checklist for Fix or Feature
<!--- All boxes need to be checked. Follow this checklist before
requiring PR review -->
- [x] Change has been tested locally.
- [ ] Change adds / updates tests if applicable.
- [x] Changelog doc updated.
- [x] `spec_version` has been incremented.
- [ ] `network-relayer`'s
[events](https://github.com/Cerebellum-Network/network-relayer/blob/dev-cere/shared/substrate/events.go)
have been updated according to the blockchain events if applicable.
- [ ] All CI checks have been passed successfully

## Checklist for Hotfix
<!--- All boxes need to be checked. Follow this checklist before
requiring PR review -->
- [ ] Changelog has been updated.
- [ ] Crate version has been updated.
- [ ] `spec_version` has been incremented.
- [ ] Transaction version has been updated if required.
- [ ] Pull Request to `dev` has been created.
- [ ] Pull Request to `staging` has been created.
- [ ] `network-relayer`'s
[events](https://github.com/Cerebellum-Network/network-relayer/blob/dev-cere/shared/substrate/events.go)
have been updated according to the blockchain events if applicable.
- [ ] All CI checks have been passed successfully

## Checklist for Release
<!--- All boxes need to be checked. Follow this checklist before
requiring PR review -->
- [ ] Change has been deployed to Devnet.
- [ ] Change has been tested in Devnet.
- [ ] Change has been deployed to Qanet.
- [ ] Change has been tested in Qanet.
- [ ] Change has been deployed to Testnet.
- [ ] Change has been tested in Testnet.
- [ ] Changelog has been updated.
- [ ] Crate version has been updated.
- [ ] Spec version has been updated.
- [ ] Transaction version has been updated if required.
- [ ] All CI checks have been passed successfully
  • Loading branch information
yahortsaryk authored Jun 5, 2024
1 parent cd94cdc commit 2cc56b5
Show file tree
Hide file tree
Showing 8 changed files with 86 additions and 23 deletions.
5 changes: 5 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,11 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
- [C] Changes is `Cere` Runtime
- [D] Changes is `Cere Dev` Runtime

## [5.3.1]

### Changed

- [C,D] `WhitelistOrigin` is set to the Technical Committee Collective Body

## [5.3.0]

Expand Down
32 changes: 16 additions & 16 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
[workspace.package]
version = "5.3.0"
version = "5.3.1"
authors = ["Cerebellum-Network"]
edition = "2021"
homepage = "https://cere.network/"
Expand Down
8 changes: 8 additions & 0 deletions node/service/src/chain_spec.rs
Original file line number Diff line number Diff line change
Expand Up @@ -212,6 +212,14 @@ pub fn cere_dev_genesis(
ddc_clusters: Default::default(),
ddc_nodes: Default::default(),
ddc_payouts: Default::default(),
tech_comm: cere_dev::TechCommConfig {
members: endowed_accounts
.iter()
.take((endowed_accounts.len() + 1) / 2)
.cloned()
.collect(),
phantom: Default::default(),
},
}
}

Expand Down
7 changes: 5 additions & 2 deletions runtime/cere-dev/src/governance/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -44,8 +44,11 @@ impl pallet_whitelist::Config for Runtime {
type WeightInfo = pallet_whitelist::weights::SubstrateWeight<Runtime>;
type RuntimeCall = RuntimeCall;
type RuntimeEvent = RuntimeEvent;
type WhitelistOrigin = EnsureRoot<Self::AccountId>;
type DispatchWhitelistedOrigin = EitherOf<EnsureRoot<Self::AccountId>, WhitelistedCaller>;
type WhitelistOrigin = EitherOfDiverse<
EnsureRoot<AccountId>,
pallet_collective::EnsureMembers<AccountId, TechCommCollective, 2>,
>;
type DispatchWhitelistedOrigin = EitherOf<EnsureRoot<AccountId>, WhitelistedCaller>;
type Preimages = Preimage;
}

Expand Down
24 changes: 23 additions & 1 deletion runtime/cere-dev/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -140,7 +140,7 @@ pub const VERSION: RuntimeVersion = RuntimeVersion {
// and set impl_version to 0. If only runtime
// implementation changes and behavior does not, then leave spec_version as
// is and increment impl_version.
spec_version: 53003,
spec_version: 53100,
impl_version: 0,
apis: RUNTIME_API_VERSIONS,
transaction_version: 17,
Expand Down Expand Up @@ -1180,6 +1180,26 @@ impl pallet_ddc_payouts::Config for Runtime {
type VoteScoreToU64 = IdentityConvert; // used for UseNominatorsAndValidatorsMap
}

parameter_types! {
pub const TechnicalMotionDuration: BlockNumber = 5 * DAYS;
pub const TechnicalMaxProposals: u32 = 100;
pub const TechnicalMaxMembers: u32 = 100;
}

type TechCommCollective = pallet_collective::Instance3;
impl pallet_collective::Config<TechCommCollective> for Runtime {
type RuntimeOrigin = RuntimeOrigin;
type Proposal = RuntimeCall;
type RuntimeEvent = RuntimeEvent;
type MotionDuration = TechnicalMotionDuration;
type MaxProposals = TechnicalMaxProposals;
type MaxMembers = TechnicalMaxMembers;
type SetMembersOrigin = EnsureRoot<AccountId>;
type DefaultVote = pallet_collective::PrimeDefaultVote;
type WeightInfo = pallet_collective::weights::SubstrateWeight<Runtime>;
type MaxProposalWeight = MaxCollectivesProposalWeight;
}

construct_runtime!(
pub struct Runtime
{
Expand Down Expand Up @@ -1231,6 +1251,7 @@ construct_runtime!(
Origins: pallet_custom_origins::{Origin},
Whitelist: pallet_whitelist::{Pallet, Call, Storage, Event<T>},
// End OpenGov.
TechComm: pallet_collective::<Instance3>,
}
);

Expand Down Expand Up @@ -1403,6 +1424,7 @@ mod benches {
[pallet_conviction_voting, ConvictionVoting]
[pallet_referenda, Referenda]
[pallet_whitelist, Whitelist]
[pallet_collective, TechComm]
);
}

Expand Down
7 changes: 5 additions & 2 deletions runtime/cere/src/governance/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -44,8 +44,11 @@ impl pallet_whitelist::Config for Runtime {
type WeightInfo = pallet_whitelist::weights::SubstrateWeight<Runtime>;
type RuntimeCall = RuntimeCall;
type RuntimeEvent = RuntimeEvent;
type WhitelistOrigin = EnsureRoot<Self::AccountId>;
type DispatchWhitelistedOrigin = EitherOf<EnsureRoot<Self::AccountId>, WhitelistedCaller>;
type WhitelistOrigin = EitherOfDiverse<
EnsureRoot<AccountId>,
pallet_collective::EnsureMembers<AccountId, TechCommCollective, 3>,
>;
type DispatchWhitelistedOrigin = EitherOf<EnsureRoot<AccountId>, WhitelistedCaller>;
type Preimages = Preimage;
}

Expand Down
24 changes: 23 additions & 1 deletion runtime/cere/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -134,7 +134,7 @@ pub const VERSION: RuntimeVersion = RuntimeVersion {
// and set impl_version to 0. If only runtime
// implementation changes and behavior does not, then leave spec_version as
// is and increment impl_version.
spec_version: 53003,
spec_version: 53100,
impl_version: 0,
apis: RUNTIME_API_VERSIONS,
transaction_version: 17,
Expand Down Expand Up @@ -1182,6 +1182,26 @@ impl pallet_ddc_staking::Config for Runtime {
type NodeCreator = pallet_ddc_nodes::Pallet<Runtime>;
}

parameter_types! {
pub const TechnicalMotionDuration: BlockNumber = 5 * DAYS;
pub const TechnicalMaxProposals: u32 = 100;
pub const TechnicalMaxMembers: u32 = 100;
}

type TechCommCollective = pallet_collective::Instance3;
impl pallet_collective::Config<TechCommCollective> for Runtime {
type RuntimeOrigin = RuntimeOrigin;
type Proposal = RuntimeCall;
type RuntimeEvent = RuntimeEvent;
type MotionDuration = TechnicalMotionDuration;
type MaxProposals = TechnicalMaxProposals;
type MaxMembers = TechnicalMaxMembers;
type SetMembersOrigin = EnsureRoot<AccountId>;
type DefaultVote = pallet_collective::PrimeDefaultVote;
type WeightInfo = pallet_collective::weights::SubstrateWeight<Runtime>;
type MaxProposalWeight = MaxCollectivesProposalWeight;
}

construct_runtime!(
pub struct Runtime
{
Expand Down Expand Up @@ -1233,6 +1253,7 @@ construct_runtime!(
Origins: pallet_custom_origins::{Origin},
Whitelist: pallet_whitelist::{Pallet, Call, Storage, Event<T>},
// End OpenGov.
TechComm: pallet_collective::<Instance3>,
}
);

Expand Down Expand Up @@ -1405,6 +1426,7 @@ mod benches {
[pallet_conviction_voting, ConvictionVoting]
[pallet_referenda, Referenda]
[pallet_whitelist, Whitelist]
[pallet_collective, TechComm]
);
}

Expand Down

0 comments on commit 2cc56b5

Please sign in to comment.