Crates.io | pallet-democracy |
lib.rs | pallet-democracy |
version | 38.0.0 |
source | src |
created_at | 2020-02-27 23:20:08.872975 |
updated_at | 2024-09-26 06:31:28.131424 |
description | FRAME pallet for democracy |
homepage | https://paritytech.github.io/polkadot-sdk/ |
repository | https://github.com/paritytech/polkadot-sdk.git |
max_upload_size | |
id | 213377 |
size | 271,669 |
The Democracy pallet handles the administration of general stakeholder voting.
There are two different queues that a proposal can be added to before it becomes a referendum, 1) the proposal queue consisting of all public proposals and 2) the external queue consisting of a single proposal that originates from one of the external origins (such as a collective group).
Every launch period - a length defined in the runtime - the Democracy pallet launches a referendum from a proposal that it takes from either the proposal queue or the external queue in turn. Any token holder in the system can vote on referenda. The voting system uses time-lock voting by allowing the token holder to set their conviction behind a vote. The conviction will dictate the length of time the tokens will be locked, as well as the multiplier that scales the vote power.
A referendum can be either simple majority-carries in which 50%+1 of the votes decide the outcome or adaptive quorum biased. Adaptive quorum biasing makes the threshold for passing or rejecting a referendum higher or lower depending on how the referendum was originally proposed. There are two types of adaptive quorum biasing: 1) positive turnout bias makes a referendum require a super-majority to pass that decreases as turnout increases and 2) negative turnout bias makes a referendum require a super-majority to reject that decreases as turnout increases. Another way to think about the quorum biasing is that positive bias referendums will be rejected by default and negative bias referendums get passed by default.
These calls can be made from any externally held account capable of creating a signed extrinsic.
Basic actions:
propose
- Submits a sensitive action, represented as a hash. Requires a deposit.second
- Signals agreement with a proposal, moves it higher on the proposal queue, and
requires a matching deposit to the original.vote
- Votes in a referendum, either the vote is "Aye" to enact the proposal or "Nay" to
keep the status quo.unvote
- Cancel a previous vote, this must be done by the voter before the vote ends.delegate
- Delegates the voting power (tokens * conviction) to another account.undelegate
- Stops the delegation of voting power to another account.Administration actions that can be done to any account:
reap_vote
- Remove some account's expired votes.unlock
- Redetermine the account's balance lock, potentially making tokens available.Preimage actions:
note_preimage
- Registers the preimage for an upcoming proposal, requires
a deposit that is returned once the proposal is enacted.note_preimage_operational
- same but provided by T::OperationalPreimageOrigin
.note_imminent_preimage
- Registers the preimage for an upcoming proposal.
Does not require a deposit, but the proposal must be in the dispatch queue.note_imminent_preimage_operational
- same but provided by T::OperationalPreimageOrigin
.reap_preimage
- Removes the preimage for an expired proposal. Will only
work under the condition that it's the same account that noted it and
after the voting period, OR it's a different account after the enactment period.This call can only be made by the CancellationOrigin
.
emergency_cancel
- Schedules an emergency cancellation of a referendum.
Can only happen once to a specific referendum.This call can only be made by the ExternalOrigin
.
external_propose
- Schedules a proposal to become a referendum once it is is legal
for an externally proposed referendum.This call can only be made by the ExternalMajorityOrigin
.
external_propose_majority
- Schedules a proposal to become a majority-carries
referendum once it is legal for an externally proposed referendum.This call can only be made by the ExternalDefaultOrigin
.
external_propose_default
- Schedules a proposal to become a negative-turnout-bias
referendum once it is legal for an externally proposed referendum.This call can only be made by the FastTrackOrigin
.
fast_track
- Schedules the current externally proposed proposal that
is "majority-carries" to become a referendum immediately.This call can only be made by the VetoOrigin
.
veto_external
- Vetoes and blacklists the external proposal hash.cancel_referendum
- Removes a referendum.cancel_queued
- Cancels a proposal that is queued for enactment.clear_public_proposal
- Removes all public proposals.License: Apache-2.0
Polkadot SDK stable2409