Building on Yearn
Welcome! This is the spot to be for all things related to building products on, for, and with Yearn. If you are looking for more general information about Yearn and it's products, check out the Getting Started section of the docs. If you are looking to build, read on!
Core Tools
Yearn Vaults & Smart Contract Integrations
Yearn’s core product is the Vault (also known as yVault) — a set-it-and-forget-it yield aggregator running on top of DeFi’s yield-generating protocols like Compound, Aave, Curve, and Convex.
V3 Vaults
This Repository includes the set of smart contracts that are used for the Yearn 4626-compliant V3 vaults.
Check out the V3 Vaults section of this documentation for more information.
V2 Vaults
This repository includes the set of smart contracts that are used for the Yearn V2 Vaults. It contains the requirements, code, deployment scripts, and tests necessary for the core protocol, including an inheritable template strategy for use with Solidity-based strategies that interact with Yearn Vaults. These contracts are used to create a simple way to generate high risk-adjusted returns for depositors of various assets via best-in-class lending protocols, liquidity pools, and community-made yield farming strategies on Ethereum.
Check out the V2 Vaults section of this documentation for more information.
Strategy Development
A Yearn Strategy is a set of smart contracts that implement different farming strategies that utilize deposited assets to generate yields. Vaults move assets from one farming application to another by switching between strategies. Rewards/profits generated by strategies are regularly updated, harvested, swapped for the original vault asset, and deposited again for compound farming.
V2 and V3 vaults implement strategies differently, so it is important to get familiar with the differences when deciding which Vault product you wish to use. More information about V3 strategies can be found here and information on V2 strategies can be found here
Front-end Integrations
Yearn uses a JavaScript SDK for formatting protocol data and generating transactions for reading/writing protocol data. Yearn SDK integrates several components, both on-chain and off-chain.
The repository here contains a live preview and example usage of the Yearn SDK. Explore this codebase to learn how to start interacting with the Yearn protocol in your own app.
Check out the Front End Integrations section of this documentation for more information about Front End Integrations.
Testing
warning
this section needs updating
You can test Yearn vaults without spending cryptoassets on the available testnet for each network.
To get started, head to the yearn testnet client which is available at: https://hack.yearn.fi/
Make sure to switch your wallet provider to the appropriate testnet network in order to use the protocol testnet without incurring costs on the mainnet network.
Testnet networks are different environments from mainnet and simulate real use cases for development, testing or production. The assets on a testnet are not “real,” meaning that they cannot be withdrawn to your wallet for any real economic value.
Testing is possible through Ethereum Rinkeby
Steps to test
- Go to https://hack.yearn.fi/
- Switch to the testnet you wish to utilize over your wallet provider
- Make sure to have the native asset for the specific network
- Get some tokens from the test client faucet (Ethereum Rinkeby https://faucet.rinkeby.io/)
Make sure to select the correct market in the top right corner. You can find this on the left side of the address. Select the token you need and submit the faucet transaction but be mindful to make sure that you have certain amount of the native asset of the testnet you wish to transact on.
Additional Resources
Workshop: Building and Integrating with Yearn Vaults: https://www.youtube.com/watch?v=urC35PMbpJ4 --> Learn how to leverage the power of Yearn by creating a money-making integration on top of v2 vaults by taking advantage of the brand new EIP-4626: Tokenized Vault Standard! This workshop will guide you through creating a B2B/business router for yearn v2 vaults, which complies with the new EIP-4626. You'll be able to choose from multiple fee strategies for your users to maximize your profit.
Smart Contract parameters: https://docs.yearn.fi/vaults/smart-contracts/vault
https://twitter.com/storming0x/status/1436851219864059906?s=20
Data Analysis
Yearn aims to provide more insights into our products to our customers and partners through analyzing the on-chain and off-chain data. Given that all Yearn protocol data is publicly stored on-chain, there are lots of insights to be gained from analyzing these transactions.
Two common tools for on-chain data analysis are:
- Dune Analytics- Query contract data and generate dashboards with SQL
Here's a list of all the new things you can query for:
- harvests
- deployments
- transactions
- contract_tokens
- contract_strategy
- v2_deployments
Fiddle with them all at https://dune.com/queries/625814
- The Graph- Query contract data with GQL using the Yearn subgraphs
The Graph is a decentralized protocol for indexing and querying data from blockchains, starting with Ethereum. It is an easier way to retrieve specific data from the blockchain, within the ethos of web3, with the advantages of decentralization and reliability.
GraphQL is the underlying query language used in The Graph.
What is the difference between standard RESTFUL API calls and GraphQL calls? The difference is that traditional APIs require the developers to create specific endpoints for users that return specific data. If the user requires more information, they may need to make multiple API calls, sometimes hundreds of API calls, to get the information they require. With The Graph (which uses GraphQL), only one call is needed to a subgraph, as long as the developer has created a flexible schema.
- https://thegraph.com/hosted-service/subgraph/rareweasel/yearn-vaults-v2-mainnet
- https://api.thegraph.com/subgraphs/name/rareweasel/yearn-vaults-v2-mainnet/graphql
Some of the research questions that we are interested in
- Screening profitable liquidity pools for our strategies
- Assessing the impact of TVL on the impermanent loss
- Screening the volume of various pools
- Providing risk metrics to our vaults
- Price volatility of the underlying token
- Addressing the protocol risks
- Optimizing our strategies according to the change in gas fees
- Decide on when to deleverage and trade the governance tokens
- Decide on when to harvest
- Predicting impermanent loss for Uniswap V3 pools
- Portfolio construction across yearn products More details on these topics can be seen in our issues tab.
Data Sources
Yearn SDK [Docs] https://docs.yearn.fi/vaults/yearn-sdk/yearn-stack If you are not sure about which service you should first look into, Yearn SDK can provide you with addresses of contracts and endpoints of yearn’s services.
Yearn API [Docs] Yearn API can provide non-user specific metadata, including the tvl of vaults, apys, fees, and strategy metadata through REST API, without the need to make web3 calls.
Yearn Vision Yearn Vision is the Grafana dashboard of the hosted version of Yearn Exporter. You can download the historical metrics related to our vaults and strategies as json or csv files through the dashboard. For instructions on downloading, please see Downloading query results as csv.
Inspiration
Common use-cases for vaults include:
- Using Vaults as collateral for lending/borrowing
- Using Vaults to generate yield with user funds
In both cases, the protocol integrating with yearn is rewarded with performance fees taken from the vault’s overall profits, the more total volume that a partner contributes to a vault, the bigger share of the profit they receive.
Hundreds of protocols have built exciting functionalities using Yearn’s integration methods. These include:
- Alchemix provides self-repaying loans using vault yields
- Abracadabra provided the first yVault leveraging system that allows users to take loans and keep the yield rolling
- QiDao provides 0% interest loans if you use yVaults as collateral
Here are some ideas on what you can build:
- Use the Vaults as collateral to borrow money and probably get some leverage. (e.g. Abracadabra)
- Build a product that allows you to use yield to do cool stuff: donate yield to an NGO invest the yield in more risky stuff or directional bets paying bills and subscriptions
- Create a metavault on top of multiple vaults. One idea that comes to my mind is having a USD metavault that deposits into multiple dollar-pegged vaults based on some strategy and abstracts the complexity from the user.
- Build a UI that accepts deposits and allows you to move assets across chains.
- Use the vaults as a place to earn interest on funds that are not currently actively being used by the user.
Examples
Skew You: Users can borrow against their options collateral, unlocking a whole new world of capital efficiency.
Possum: Fixed-income product that can turn every farm into two fix/variable pools. Based on the game model, fixed pool users can have guaranteed APY while the variable user gets higher APY with higher risk.
Bowtie: Allows users to borrow against their options collateral.
Additionally, doing a GitHub search for Yearn functionality you are interested in implementing is a good way to find working code examples.
Expectations
Here are some guidelines on how to maximize your chances of 'winning':
- Have your code well documented on Github.
- Have a front end!
- If you created a contract, deploy them to a testnet and ensure your front end properly interacts with them.
- Implement something interesting with your Yearn integration. Simply calling deposit() will not help your submission stand out!
Resources
Yearn GitHub Organization: https://github.com/yearn/
Yearn V2 Documentation: https://github.com/yearn/yearn-vaults