Skip to content

Latest commit

 

History

History
64 lines (37 loc) · 3.64 KB

README.md

File metadata and controls

64 lines (37 loc) · 3.64 KB

Cream-Leverage-Contract

Introduction & Demo

OneClickLeverage app allows users to easily create flexible leverage position and deleverage them on Cream Finance.

Grabacion.de.pantalla.2021-09-07.a.la.s.10.35.58.p.m.mov

UI & UX

Set-up

  • First, users need to create an account but only at the beginning.

Screen Shot 2021-09-07 at 22 28 21

Easy-to-Use

  • With ETH, users can take leverage with one click. With ERC20 tokens listed on Cream Finance, approval for the account is necessary.
  • As the demo shows, users can dynamically specify how much they leverage or deleverage your position by a slider on the user interface.
  • Expected outcomes of users' positions, such as debt ratio, leverage, liquidation price, and Net APY are explicitly shown to them.

Gas-Efficient

  • Although users need to create an account first, overall, it's incredibly cost-efficient because flashloan drastically reduces the gas cost to take higher(3~5x) leverage. This is because there is no need to deposit, borrow, and swap multiple times to increase collateral more than the initial deposit.

Technical Architecture

Leverage Positions on Cream

All of leverage positions are made on CreamV2 a.k.a IronBank instead of V1 because cyTokens have looser debt ratio which allows higher leverage.

Contract Wallet

The contract wallet manages leverage positions is a modified fork of Instadap's DSA(DeFi Smart Account) contract. This model enables multiple flexible strategies by several kinds of DeFi protocol connectors.

※Note: One of the reasons we built the contract wallet is we realized that it's technologically quite challenging to let users take leverage position with the typical contract model working as a proxy interface between users and cr/cy tokens.

Especially in that model, cr/cytoken a user is supposed to receive is sent to contract instead of the user. This is because msg.sender for cr/cy tokens is the contract between them instead of the original caller(user). msg.origin may solve this, but it's proven not secure.

Flashloan

When a position is created by utilizing flashloan, the liquidity (flashloaned funds) is taken by CreamV1 instead of the same cyToken pool to avoid reversions caused by reentrancy. When testing, it threw the error re-enter.

※Note: We aren't 100% sure that it stems from the reentrancy guard, but it's likely. The transaction didn't succeed when the collateral and debt's liquidity source(cr/cy token) are the same.

Workflow

Screen Shot 2021-09-07 at 20 05 28

Screen Shot 2021-09-07 at 20 06 26

Build

※Note: First, you need to chnage the network on Metamask to localhost:8545 and chnage its network id into 1 like below.

Screen Shot 2021-09-07 at 22 16 02

And then, you need to import an account which has the enough ETH balance. If needed, you can just import one of the hardhat account, private key: 0x59c6995e998f97a5a0044966f0945389dc9e86dae88c7a8412f4603b6b78690d

git clone https://github.com/OneClickLeverage/Cream-Leverage-Contract.git
cd Cream-Leverage-Contract
./_init // npm i && run node 
./_start // deploy contracts && npm start