The Aptos on-chain governance is a process by which the Aptos community members can create and vote on proposals that minimize the cost of blockchain upgrades. The following describes the scope of these proposals for the Aptos on-chain governance:
- Changes to the blockchain parameters, for example, the epoch duration, and the minimum required and maximum allowed validator stake.
- Changes to the core blockchain code.
- Upgrades to the Aptos Framework modules for fixing bugs or for adding or enhancing the Aptos blockchain functionality.
- Deploying new framework modules (at the address
How a proposal becomes ready to be resolved
See below for a summary description of how a proposal comes to exist and when it becomes ready to be resolved:
- The Aptos community can suggest an Aptos Improvement Proposal (AIP) in the Aptos Foundation AIP GitHub.
- When appropriate, an on-chain proposal can be created for the AIP via the
- Voters can then vote on this proposal on-chain via the
aptos_governancemodule. If there is sufficient support for a proposal, then it can be resolved.
- Governance requires a minimal number of votes to be cast by an expiration threshold. However, if sufficient votes, more than 50% of the total supply, are accumulated prior to that threshold, the proposal can be executed without waiting for the full voting period.
Who can propose
- To either propose or vote, you must stake, but you are not required to run a validator node. However, we recommend that you run validator with a stake as part of the validator set to gain rewards from your stake.
- To create a proposal, the proposer's backing stake pool must have the minimum required proposer stake. The proposer's stake must be locked up for at least as long as the proposal's voting period. This is to avoid potential spammy proposals.
- Proposers can create a proposal by calling
Who can vote
- To vote, you must stake, though you are not required to run a validator node. Your voting power is derived from the backing stake pool.
- Voting power is calculated based on the current epoch's active stake of the proposer or voter's backing stake pool. In addition, the stake pool's lockup must be at least as long as the proposal's duration.
- Verify proposals before voting. Ensure each proposal is linked to its source code, and if there is a corresponding AIP, the AIP is in the title and description.
Each stake pool can be used to vote on each proposal exactly only one time.
Who can resolve
- Anyone can resolve an on-chain proposal that has passed voting requirements by using the
aptos governance execute-proposalcommand from Aptos CLI.
Aptos Improvement Proposals (AIPs)
AIPs are proposals created by the Aptos community or the Aptos Labs team to improve the operations and development of the Aptos chain.
To submit an AIP, create an issue in
Aptos Foundation's GitHub repository using the template
To keep up with new AIPs, check the
#aip-announcements channel on Aptos' discord channel.
To view and vote on on-chain proposals, go to
Aptos' Governance website.
Technical Implementation of Aptos Governance
The majority of the governance logic is in
aptos_governance.move and voting.move.
aptos_governance module outlines how users can interact with Aptos Governance. It's the external-facing module of the Aptos on-chain governance process and contains logic and checks that are specific to Aptos Governance.
voting module is the Aptos governance standard that can be used by DAOs on the Aptos chain to create their own on-chain governance process.
If you are thinking about creating a DAO on Aptos, you can refer to
aptos_governance's usage of the
voting module as an example.
aptos_governance, we rely on the
voting module to create, vote on, and resolve a proposal.
voting::create_proposalto create a proposal on-chain, when an off-chain AIP acquires sufficient importance.
voting::voteto record the vote on a proposal on-chain;
aptos_governance::resolvecan be called by anyone. It calls
voting::resolveto resolve the proposal on-chain.