Skip to content
This repository has been archived by the owner on Nov 15, 2023. It is now read-only.

The Ambassador Program #2002

Open
wants to merge 53 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
53 commits
Select commit Hold shift + click to select a range
f885e71
Ambassador Program minimum setup
muharem Dec 19, 2022
8e76281
head ambassador rank
muharem Jan 9, 2023
0541b4b
docs
muharem Jan 9, 2023
5cf1abf
pallet_collective_content, tests, benches
muharem Jan 11, 2023
07075dd
clean dev code
muharem Jan 11, 2023
80df39c
docs, worst case fot bench
muharem Jan 12, 2023
8c288e3
docs
muharem Jan 12, 2023
5bd566d
collective content pallet generic over instance (I)
muharem Jan 12, 2023
5356d11
fix docs
muharem Jan 12, 2023
8112e48
ranks public
muharem Jan 12, 2023
0ffbaaf
rustfmt
muharem Jan 12, 2023
b81ba28
fix
muharem Jan 12, 2023
9b89c1d
add try runtime feature to collective content pallet
muharem Jan 12, 2023
bbe116c
Merge remote-tracking branch 'origin/master' into muharem-ambassador-…
muharem Jan 14, 2023
6104edb
typo fixes, announcement origin, ambassador proxy
muharem Jan 25, 2023
f0c3a60
announcements with an expiration
muharem Jan 25, 2023
514fce9
cleaup announcements on idle
muharem Jan 27, 2023
1323be3
docs and proxy definition changes
joepetrowski Jan 31, 2023
f200aef
merge master
joepetrowski Jan 31, 2023
1b867de
remove unused import
joepetrowski Jan 31, 2023
174a9a8
review fixes
muharem Feb 6, 2023
9017a8b
storage map for the announcements
muharem Feb 6, 2023
d602443
max scheduler per block for benches
muharem Feb 7, 2023
07c7d86
rename weights files
muharem Feb 7, 2023
fe57ff2
remove todo, update comment
muharem Feb 14, 2023
5f111a2
ToParentTreasury impl
muharem Feb 16, 2023
2ef13d0
Merge remote-tracking branch 'origin/master' into muharem-ambassador-…
muharem Aug 1, 2023
48363a7
fixes after mater merge
muharem Aug 1, 2023
a9926fb
more ranks, renames, salary and core pallets
muharem Aug 9, 2023
5313c68
ensure origin types, reuse common types
muharem Aug 10, 2023
cb79c45
fixes
muharem Aug 11, 2023
f867832
Merge remote-tracking branch 'origin/master' into muharem-ambassador-…
muharem Aug 11, 2023
35e0417
benchmark script void output file name
muharem Aug 11, 2023
d515363
weights
muharem Aug 11, 2023
c238fb2
docs fixes
muharem Aug 14, 2023
9ab6aa4
promote origin for rank 0
muharem Aug 14, 2023
67902de
Apply suggestions from code review
muharem Aug 18, 2023
54bd222
renames
muharem Aug 18, 2023
d5118b0
benchmarks v2
muharem Aug 18, 2023
15ad2f5
defensive count inc/dec
muharem Aug 18, 2023
9a562c5
default announcement lifetime, fee free expired announcement removal
muharem Aug 18, 2023
08153e7
salary in dot
muharem Aug 18, 2023
b7d8da7
Merge remote-tracking branch 'origin/master' into muharem-ambassador-…
muharem Aug 18, 2023
273e9af
benchmark fix
muharem Aug 18, 2023
9ae1f68
paymaster test
muharem Aug 18, 2023
fd88108
".git/.scripts/commands/fmt/fmt.sh"
Aug 18, 2023
56baa6a
Merge remote-tracking branch 'origin/master' into muharem-ambassador-…
Aug 21, 2023
8efb683
Merge remote-tracking branch 'origin/master' into muharem-ambassador-…
muharem Aug 22, 2023
f9c1c06
rename and tracks settings
muharem Aug 22, 2023
40bf76e
Merge remote-tracking branch 'origin/master' into muharem-ambassador-…
muharem Aug 22, 2023
69036ba
ignore test
muharem Aug 22, 2023
421d3cf
comment test
muharem Aug 22, 2023
1d625c0
Merge remote-tracking branch 'origin/master' into muharem-ambassador-…
Aug 24, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
docs
  • Loading branch information
muharem committed Jan 9, 2023
commit 0541b4b70ece03a7426e14ed214ee78e6031e86c
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,12 @@
// limitations under the License.

//! The Ambassador Program.
//! todo docs
//!
//! The module defines the following on-chain functionality of the Ambassador Program:
//! - managed set of the program members, where every member has a [rank](ranks) (via [pallet_ranked_collective]).
//! - referendum functionality for the program members to propose, vote and execute passed proposals on behalf
//! of the members of a certain [rank](Origin) (via [pallet_referenda]).
//! - managed content (charter, announcements) (via [pallet_ambassador]).

mod pallet;
mod tracks;
Expand Down Expand Up @@ -44,7 +49,7 @@ pub mod ranks {

impl pallet_ambassador::Config for Runtime {
type RuntimeEvent = RuntimeEvent;
type AmbassadorOrigin = EnsureAmbassador;
type CharterOrigin = EnsureAmbassador;
type MemberOrigin = pallet_ranked_collective::EnsureMember<
Runtime,
AmbassadorCollectiveInstance,
Expand All @@ -67,6 +72,7 @@ impl pallet_referenda::Config<AmbassadorReferendaInstance> for Runtime {
type RuntimeEvent = RuntimeEvent;
type Scheduler = Scheduler;
type Currency = Balances;
// A proposal can be submitted by a member of the Ambassador Program of [ranks::AMBASSADOR] rank or higher.
type SubmitOrigin = pallet_ranked_collective::EnsureMember<
Runtime,
AmbassadorCollectiveInstance,
Expand Down Expand Up @@ -102,10 +108,16 @@ pub type AmbassadorCollectiveInstance = pallet_ranked_collective::Instance1;
impl pallet_ranked_collective::Config<AmbassadorCollectiveInstance> for Runtime {
type WeightInfo = (); // TODO use actual weights
type RuntimeEvent = RuntimeEvent;
// Promotion is by any of:
// - Root can promote arbitrarily.
// - a vote by the rank above the new rank.
type PromoteOrigin = EitherOf<
frame_system::EnsureRootWithSuccess<Self::AccountId, HeadAmbassadorRank>,
TryMapSuccess<EnsureRankedAmbassador, CheckedReduceBy<ConstU16<1>>>,
>;
// Demotion is by any of:
// - Root can demote arbitrarily.
// - a vote by the rank above the current rank.
type DemoteOrigin = EitherOf<
frame_system::EnsureRootWithSuccess<Self::AccountId, HeadAmbassadorRank>,
TryMapSuccess<EnsureRankedAmbassador, CheckedReduceBy<ConstU16<1>>>,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
// See the License for the specific language governing permissions and
// limitations under the License.

//! TODO docs
//! The module containing custom pallet/s of the Ambassador Program.

use frame_support::BoundedVec;
use sp_core::ConstU32;
Expand Down Expand Up @@ -46,8 +46,8 @@ pub mod pallet_ambassador {
/// A member of the Ambassador Program.
type MemberOrigin: EnsureOrigin<Self::RuntimeOrigin>;

/// Ambassador plurality voice.
type AmbassadorOrigin: EnsureOrigin<Self::RuntimeOrigin>;
/// The origin to control the Ambassador Program charter.
type CharterOrigin: EnsureOrigin<Self::RuntimeOrigin>;

/// The maximum number of announcements.
#[pallet::constant]
Expand All @@ -67,7 +67,7 @@ pub mod pallet_ambassador {
HeadAmbassador,
}

/// todo docs
/// Errors encountered by the pallet (not a full list).
#[pallet::error]
pub enum Error<T> {
/// The announcement is not found.
Expand All @@ -76,7 +76,7 @@ pub mod pallet_ambassador {
TooManyAnnouncements,
}

/// todo docs
/// Events emitted by the pallet.
#[pallet::event]
#[pallet::generate_deposit(pub(super) fn deposit_event)]
pub enum Event<T: Config> {
Expand Down Expand Up @@ -105,7 +105,7 @@ pub mod pallet_ambassador {
#[pallet::call_index(0)]
#[pallet::weight(0)] // TODO
pub fn set_charter(origin: OriginFor<T>, cid: Cid) -> DispatchResult {
T::AmbassadorOrigin::ensure_origin(origin)?;
T::CharterOrigin::ensure_origin(origin)?;

Charter::<T>::put(&cid);

Expand Down Expand Up @@ -158,13 +158,15 @@ pub mod pallet_ambassador {
}
}

/// Implementation of the [EnsureOrigin] trait for the [Origin::SeniorAmbassador] origin.
/// Implementation of the [EnsureOrigin] trait for the [Origin::SeniorAmbassador]
/// and [Origin::HeadAmbassador] origins.
pub struct EnsureSeniorAmbassador;
impl<O: Into<Result<Origin, O>> + From<Origin>> EnsureOrigin<O> for EnsureSeniorAmbassador {
type Success = ();
fn try_origin(o: O) -> Result<Self::Success, O> {
o.into().and_then(|o| match o {
Origin::SeniorAmbassador => Ok(()),
Origin::HeadAmbassador => Ok(()),
r => Err(O::from(r)),
})
}
Expand Down