On-Chain Voting is a protocol developed to help with governing the Mina L1 blockchain.
Vote With Auro Wallet
- Ensure you're on the correct network (in this case devnet).
- Click on your address to copy it to the clipboard (we'll be using it in the next step).
- Click on "Send."
- Paste your address into
To
. - Add
1
in theAmount
field. - Depending on how you want to cast your vote, enter either
MIP#
orno MIP#
where#
is substituted with the actual MIP number.
- Confirm the transaction.
The On-Chain Voting Protocol is designed to provide community members with a transparent and secure method of participating in the decision-making process for the Mina blockchain. The aim for this protocol is to provide stakeholders with the ability to vote on MIPs (Mina Improvement Proposals) with ease.
(Individual MIPs should be created by following the process described on the GitHub repository.)
To cast a vote on a particular MIP, a user must send a transaction to themselves with a specially-constructed memo field. The memo field must adhere to the following convention.
For example:
To vote in favor of 'MIP1', the memo field must be populated with: 'MIP1'
Similarly, if the intent is to vote against 'MIP1', the memo field must
contain: 'no MIP1'.
The transaction amount must be 0, with the user only paying for the transaction fee.
For more details, see:
- The article by Granola
- The FAQ
To cast a vote on a particular MEF, a user must send a transaction to themselves with a specially-constructed memo field. The memo field must adhere to the following convention.
For example:
To vote in favor of a MEF for funding round 1 and proposal #1, the memo field must be populated with: 'MEF1 YES 1'
Similarly, if the intent is to vote against proposal #1, the memo field must
contain: 'MEF1 NO 1'.
Vote With Auro Wallet
- Ensure you're on the correct network (e.g., devnet).
- Click on your wallet address to copy it to the clipboard (you’ll need it in step 4).
- Navigate to the Send feature in the wallet.
- In the To field, paste your own wallet address.
- Enter the amount field (can be 0 MINA).
- To cast your vote:
- Enter MEF[ROUND_ID] YES [PROPOSAL_ID] in the Memo field to vote in favor of the proposal.
- Enter MEF[ROUND_ID] NO [PROPOSAL_ID] in the Memo field to vote against the proposal.
- Replace [PROPOSAL_ID] with the actual proposal ID you are voting for and [ROUND_ID] the actual funding round.
- Confirm and submit the transaction. Your vote will be recorded on-chain.
The Proposal Consideration API allows users to fetch detailed data about a proposal, including community votes, staking weights, and vote details within a specified time range.
Retrieve details for a specific proposal within a specified time frame. Optionally, you can configure the ledger hash to compute vote weights.
Parameter | Type | Description |
---|---|---|
round_id |
integer |
Unique identifier for the funding round. |
proposal_id |
integer |
Unique identifier for the proposal. |
start_time |
integer |
Proposal start time in milliseconds unix timestamp. |
end_time |
integer |
Proposal end time in milliseconds unix timestamp. |
Parameter | Type | Description |
---|---|---|
ledger_hash |
string |
Ledger hash used to compute weights of the votes. |
Field | Description |
---|---|
round_id |
Unique identifier of the funding round. |
proposal_id |
Unique identifier of the proposal. |
total_community_votes |
Total number of votes cast by the community. |
total_positive_community_votes |
Total number of positive votes cast by the community. |
total_negative_community_votes |
Total number of negative votes cast by the community. |
total_stake_weight |
Total staking weight applied to the proposal. |
positive_stake_weight |
Staking weight supporting the proposal. |
negative_stake_weight |
Staking weight opposing the proposal. |
vote_status |
Current status of the proposal. |
elegible |
Elegible status |
The .envrc
will instruct direnv
to use Nix to install the prerequisites for development on this
repo.
Without Nix, you will need to install, most notably:
- just
- libpq
- rustup
- libiconv
- llvm
- nodejs
- pkg-config
- podman/Docker
- pnpm (and issue
pnpm env use --global 18
)
Configure your .env
file. See the .env.example
.
Optionally issue just install
to install yet more dependencies.
Issue just
to see the possible development actions. Examine Justfile to see how they
work.
For more information about Diesel and database migrations, see the official docs..
Contributions are welcome! This project uses the C4 (Collective Code Construction Contract) process for contributions.
This project is licensed under the Mozilla Public License 2.0. See the LICENSE file for the full license text.