Skip to content

o1-labs/mina-on-chain-voting

 
 

Repository files navigation

Mina On-Chain Voting

On-Chain Voting is a protocol developed to help with governing the Mina L1 blockchain.

Vote With Auro Wallet

  1. Ensure you're on the correct network (in this case devnet).
  2. Click on your address to copy it to the clipboard (we'll be using it in the next step).
  3. Click on "Send."

Auro Home

  1. Paste your address into To.
  2. Add 1 in the Amount field.
  3. Depending on how you want to cast your vote, enter either MIP# or no MIP# where # is substituted with the actual MIP number.

Vote Details

  1. Confirm the transaction.

Vote Confirmation

Protocol Specifications

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.)

Voting on a MIP

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:

Voting on a MEF

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.

Proposal Consideration API

Overview

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.


Endpoint

GET /api/mef_proposal_consideration/:round_id/:proposal_id/:start_time/:end_time?ledger_hash

Retrieve details for a specific proposal within a specified time frame. Optionally, you can configure the ledger hash to compute vote weights.

Path Parameters

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.

Query Parameters (optional)

Parameter Type Description
ledger_hash string Ledger hash used to compute weights of the votes.

Response Details

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

Ranked Voting on a MEF

Multi-Winner Proportional Election System

Overview

This repository implements a multi-winner proportional election system using the Instant-Runoff Voting (IRV) algorithm. The system conducts single-winner elections iteratively until the required number of winners is reached or no remaining candidates are left.

Features

  • Instant-Runoff Voting (IRV): Eliminates candidates in rounds until a winner is selected.
  • Multi-Winner Support: Runs multiple rounds of elections to determine multiple winners.
  • Proportional Representation: Ensures fair distribution of winners based on voter preferences.
  • Detailed Election Statistics: Provides election round insights and ranking positions.

Endpoint

GET /api/mef_ranked_vote/:round_id/:start_time/:end_time

Retrieve ranked voting results for a specific funding round within a given time range.

Path Parameters

Parameter Type Description
round_id integer Unique identifier for the funding round.
start_time integer Start time in milliseconds unix timestamp.
end_time integer End time in milliseconds unix timestamp.

Ranked Voting Rules

  • Each voter can rank up to 8 proposals per funding round.
  • The ranking system assigns higher weight to higher-ranked proposals.
  • Votes are aggregated and processed to determine the most preferred proposals based on ranking distribution.

Response Details

Field Type Description
round_id integer Unique identifier of the funding round.
total_votes integer Total number of ranked votes cast by the community.
winners array<string> List of winning proposals based on ranked vote results.
stats array<object> Detailed election statistics for each voting round.
votes array<object> List of individual ranked votes submitted.

Software Development

Install Nix and direnv.

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..

Contributing

Contributions are welcome! This project uses the C4 (Collective Code Construction Contract) process for contributions.

License

This project is licensed under the Mozilla Public License 2.0. See the LICENSE file for the full license text.

About

Mina On-Chain Voting

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 51.3%
  • Rust 38.4%
  • Haskell 4.7%
  • Just 1.8%
  • Nix 1.2%
  • JavaScript 1.1%
  • Other 1.5%