55 releases (major breaking)

new 39.0.0 Jan 13, 2025
38.0.0 Sep 26, 2024
37.0.0 Jul 18, 2024
36.0.0 Jul 12, 2024
2.0.0-alpha.5 Mar 24, 2020

#160 in Magic Beans

Download history 225/week @ 2024-09-25 40/week @ 2024-10-02 97/week @ 2024-10-09 101/week @ 2024-10-16 206/week @ 2024-10-23 257/week @ 2024-10-30 5489/week @ 2024-11-06 25358/week @ 2024-11-13 24335/week @ 2024-11-20 24613/week @ 2024-11-27 25564/week @ 2024-12-04 21975/week @ 2024-12-11 17600/week @ 2024-12-18 5839/week @ 2024-12-25 17746/week @ 2025-01-01 15881/week @ 2025-01-08

60,328 downloads per month
Used in 10 crates (via polkadot-sdk)

Apache-2.0

2.5MB
40K SLoC

Scored Pool Module

The module maintains a scored membership pool. Each entity in the pool can be attributed a Score. From this pool a set Members is constructed. This set contains the MemberCount highest scoring entities. Unscored entities are never part of Members.

If an entity wants to be part of the pool a deposit is required. The deposit is returned when the entity withdraws or when it is removed by an entity with the appropriate authority.

Every Period blocks the set of Members is refreshed from the highest scoring members in the pool and, no matter if changes occurred, T::MembershipChanged::set_members_sorted is invoked. On first load T::MembershipInitialized::initialize_members is invoked with the initial Members set.

It is possible to withdraw candidacy/resign your membership at any time. If an entity is currently a member, this results in removal from the Pool and Members; the entity is immediately replaced by the next highest scoring candidate in the pool, if available.

Interface

Public Functions

  • submit_candidacy - Submit candidacy to become a member. Requires a deposit.
  • withdraw_candidacy - Withdraw candidacy. Deposit is returned.
  • score - Attribute a quantitative score to an entity.
  • kick - Remove an entity from the pool and members. Deposit is returned.
  • change_member_count - Changes the amount of candidates taken into Members.

Usage

use pallet_scored_pool::{self as scored_pool};

#[frame_support::pallet]
pub mod pallet {
    use super::*;
    use frame_support::pallet_prelude::*;
    use frame_system::pallet_prelude::*;

    #[pallet::pallet]
    pub struct Pallet<T>(_);

    #[pallet::config]
    pub trait Config: frame_system::Config + scored_pool::Config {}

    #[pallet::call]
    impl<T: Config> Pallet<T> {
        #[pallet::weight(0)]
        pub fn candidate(origin: OriginFor<T>) -> DispatchResult {
            let who = ensure_signed(origin)?;

            let _ = <scored_pool::Pallet<T>>::submit_candidacy(
                T::RuntimeOrigin::from(Some(who.clone()).into())
            );
            Ok(())
        }
    }
}

Dependencies

This module depends on the System module.

License: Apache-2.0

Release

Polkadot SDK Stable 2412

Dependencies

~18–32MB
~530K SLoC