FlowDAO is a DAO built on Tezos, and is used to govern Kickflow. It operates on a token voting mechanism using an FA1.2 standard based token. Governance token holders can submit proposals in the DAO and vote on them. Each proposal is associated with a lambda that is executed if the vote passes. It's design was initially inspired by Murmuration, but heavily customised to suit the needs of Kickflow.
$KFL is the governance token operating FlowDAO. It is based on the FA1.2 standard and is customised to store snapshots of balances at block levels at which the balance of an address changes. This aides in the governance process by preventing the need to lock up the governance tokens at any stage of proposal voting. These snapshots are used to retrieve the historical balances, which are used for checking the proposal threshold and for recording the vote weight of voters. Usage of historical balances makes the DAO flash loan resistant as the snapshots contain the balance which an address has held for the entirety of a block level.
FlowDAO is written in SmartPy. To know more, view SmartPy's documentation.
fa12_token.py
: A customised FA1.2 standard based token to operate the DAO.flow_dao.py
: The DAO contract.community_fund.py
: A community fund managed by the DAO, with the ability to transfer tez, FA1.2 & FA2.
View the contract storage and entrypoint descriptions here. For more context view our docs.
deploy
: Scripts assisting deployment of the contracts.helpers
: Scripts assisting test scenarios in contracts.michelson
: Compiled michelson code of the contracts.types
: Scripts representing the types used in the contracts.
A shell script has been provided to assist compilation of the contracts. The script can be run using-
$ bash compile.sh
The compiled michelson files are stored in the michelson folder.
View the README in the deploy folder to know the deployment process.