Flywheel is a suite of open source token incentives and governance infrastructure using modern and modular solidity patterns to easily interface with other platforms.
It is built by the Tribe DAO using Foundry and Solmate.
Flywheel is completely on-chain and composable, for maximum compatibility with smart contract systems.
Flywheel has two major components, the core incentives engine (including a suite of rewards modules and boosters) and ERC20 token utilities (xERC4626, ERC20MultiVotes, ERC20Gauges).
Production examples of the incentives engine:
- fuse-flywheel used to reward depositors to Fuse lending markets.
The incentives engine is used to reward users for holding tokens in strategies. This can be as simple as vanilla liquidity mining or involve complex vote-escrow and boosting mechanics. Some common strategies include:
- Lending (or borrowing) on Fuse or other platforms.
- Depositing to an ERC-4626 Vault.
The core incentives engine supports a single reward token, and multiple reward tokens can easily be supported by adding multiple flywheels.
The rewards accrue to each strategy via a rewards module. By default, the rewards are distributed pro rata to users holding the strategy over time, but this can be transformed via a booster module.
The rewards module determines how many tokens go to each strategy over time. Assume a single constant or variable reward stream of tokens which needs to be divided amongst all the strategies.
The rewards can be divided according to any algorithm, some examples:
- constant reward stream per second/block
- proportional according to weights. Weights could be determined via liquid governance like Curve gauges.
- dynamically pass through rewards from an upstream plugin. For example passing through convex or balancer rewards to stakers. Convex Fuse Pool example.
To add flywheel to a forge compatible repository, simply run:
forge install fei-protocol/flywheel-v2
Alternatively, fork the flywheel-v2 repository to build directly using the repo.
The FlywheelCore contract maintains all reward amounts for all user,strategy pairs. In order to have fully accurate accounting, the flywheel core needs to be updated every time the composition of the strategy changes. When the strategy is an ERC-20 or ERC-4626, this means that on mint/burn/transfer the accrue
function needs to be called atomically for all affected users.
Example: on Fuse the flywheelPre*
hooks.
The flywheel rewards needs to approve rewardToken
to the FlywheelCore contract so that when users claim their rewards can be transferred from the rewards module to the user. The flywheelRewards must then eventually hold custody over all claimable tokens.
Every time flywheelCore calls getAccruedRewards(), the returned amount needs to be added to (or already held by) the flywheel rewards module.