Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/curvefi/curve-aragon-voting


https://github.com/curvefi/curve-aragon-voting

Last synced: about 2 months ago
JSON representation

Awesome Lists containing this project

README

        

### Curve Voting(Aragon Voting fork)

[Voting.sol](https://github.com/curvefi/curve-aragon-voting/blob/master/contracts/Voting.sol)
[SPECS](https://github.com/curvefi/curve-aragon-voting/blob/master/SPECS.md)

[Audit](https://github.com/curvefi/curve-aragon-voting/blob/master/CURVE-VOTING-SMART-CONTRACT%20Certificate.pdf)

## Description

Curve Voting app is a fork of Aragon Voting App with the following additions:

* Added minimum balance `minBalance` a user must have in order to create a vote

* Added minimum time between one user creating a new vote

* Removed possibility to change votes

* Vote's time must end before a vote can be enacted

* There's a switch to enable/disable creating votes controlled by roles `ENABLE_VOTE_CREATION` and `DISABLE_VOTE_CREATION`.

Once testing votes is done, the `DISABLE_VOTE_CREATION` role should be set to `0x0000000000000000000000000000000000000000` - noone

Voting app will have `CREATE_VOTES_ROLE` permissions set to anyone(`0xffffffffffffffffffffffffffffffffffffffff`) because the balance check will be done inside the Voting app and not through a forwarder

To incentivize people to vote early and not wait and see what's the outcome of the vote and vote near the end of vote,
the voting power they had for the snapshot of for that vote is getting smaller proportional to the time left for that vote(with a cutoff period of `voteTime` / 2 between creation of vote and when decrease starts to happen)

To prevent DAO to set unrealistic limits for `minBalance` and `minTime`, `minBalance` is required to be the equivalent of at least `10000` tokens locked for `one year` (1e18 precision) (which equals to `2500000000000000000000`)
and `minTime` is required to be between half a day and 2 weeks

Those limits are set when initializing the app

# How to deploy and initialize the app

## Edit [arapp.json](./arapp.json) specifying the app name `appName`, which you'll then use to install the app

## Deploying the app to aragonPM

[Install Aragon CLI](https://github.com/aragon/aragon-cli)
Preferably, for easier usage, install [frame.sh](https://frame.sh/)

Run `aragon apm publish major --environment mainnet --use-frame`

## Installing the app in a DAO

`dao install $DAO_ADDRESS $APP_ADDRESS --app-init-args $VOTING_ESCROW $ACCEPTANCE_PCT $QUORUM_PCT $VOTE_TIME $MIN_BALANCE $MIN_TIME $MIN_BALANCE_LOWER_LIMIT $MIN_BALANCE_UPPER_LIMIT $MIN_TIME_LOWER_LIMIT $MIN_TIME_UPPER_LIMIT --use-frame --env aragon:mainnet`

where

`$DAO_ADDRESS` = Address of DAO to install the app to

`$APP_ADDRESS` = the `appName` you specified in `arapp.json`

`$VOTING_ESCROW` - The VotingEscrow address deployed from [Curve DAO contracts deployment guide](https://github.com/curvefi/curve-dao-contracts/blob/master/scripts/README.md)

`$ACCEPTANCE_PCT` = Percentage of yeas in casted votes for a vote to succeed (expressed as a percentage of 10^18; eg. 10^16 = 1%, 10^18 = 100%)

i.e 510000000000000000 = 51%

`$QUORUM_PCT` = Percentage of yeas in total possible votes for a vote to succeed (expressed as a percentage of 10^18; eg. 10^16 = 1%, 10^18 = 100%)

`$VOTE_TIME` = Seconds that a vote will be open for token holders to vote (unless enough yeas or nays have been cast to make an early decision)

`MIN_TIME` = The minumum time that has to pass between a user's last creating of vote and him creating new vote

`$MIN_BALANCE` = The minimum balance a user can have to create a new vote - `2500` means `2500e18`

`$MIN_BALANCE_LOWER_LIMIT` = The lowest `MIN_BALANCE` can be set to

`$MIN_BALANCE_UPPER_LIMIT` = The highest `MIN_BALANCE` can be set to

`$MIN_TIME_LOWER_LIMIT` = The lowest `MIN_TIME` can be set to

`$MIN_TIME_UPPER_LIMIT` = The highest `MIN_TIME` can be set to

## Roles added in addition to standard Voting App roles

`SET_MIN_BALANCE_ROLE` = Role to set `MIN_BALANCE`, should be set to and managed by Voting app itself
`SET_MIN_TIME_ROLE` = Role to set `MIN_TIME`, should be set to
`ENABLE_VOTE_CREATION` = Role to enable vote creation
`DISABLE_VOTE_CREATION` = Role to disable vote creation, should be set to and managed by `0x0000000000000000000000000000000000000000` to give up control to DAO