dsa-connectors/contracts/mainnet/connectors/euler/main.sol

467 lines
13 KiB
Solidity
Raw Normal View History

2022-06-30 23:43:20 +00:00
//SPDX-License-Identifier: MIT
pragma solidity ^0.7.0;
2022-07-06 01:07:56 +00:00
pragma experimental ABIEncoderV2;
2022-06-30 23:43:20 +00:00
import "./helpers.sol";
import { Stores } from "../../common/stores.sol";
import { TokenInterface } from "../../common/interfaces.sol";
import "@openzeppelin/contracts/token/ERC20/SafeERC20.sol";
abstract contract Euler is Helpers {
using SafeERC20 for IERC20;
2022-07-06 13:40:38 +00:00
/**
2022-06-30 23:43:20 +00:00
* @dev Deposit ETH/ERC20_Token.
* @notice Deposit a token to Euler for lending / collaterization.
* @param subAccount Sub-account Id (0 for primary and 1 - 255 for sub-account)
2022-06-30 23:43:20 +00:00
* @param token The address of the token to deposit.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
* @param amt The amount of the token to deposit. (For max: `uint256(-1)`)
2022-07-06 13:40:38 +00:00
* @param enableCollateral True for entering the market
2022-06-30 23:43:20 +00:00
* @param getId ID to retrieve amt.
* @param setId ID stores the amount of tokens deposited.
*/
function deposit(
2022-07-06 13:40:38 +00:00
uint256 subAccount,
2022-06-30 23:43:20 +00:00
address token,
uint256 amt,
2022-07-06 13:40:38 +00:00
bool enableCollateral,
2022-06-30 23:43:20 +00:00
uint256 getId,
uint256 setId
)
external
payable
returns (string memory _eventName, bytes memory _eventParam)
{
uint256 _amt = getUint(getId, amt);
bool isEth = token == ethAddr;
address _token = isEth ? wethAddr : token;
TokenInterface tokenContract = TokenInterface(_token);
if (isEth) {
_amt = _amt == uint256(-1) ? address(this).balance : _amt;
convertEthToWeth(isEth, tokenContract, _amt);
} else {
_amt = _amt == uint256(-1)
? tokenContract.balanceOf(address(this))
: _amt;
}
approve(tokenContract, EULER_MAINNET, _amt);
IEulerEToken eToken = IEulerEToken(markets.underlyingToEToken(_token));
2022-07-07 18:51:06 +00:00
eToken.deposit(subAccount, _amt);
2022-06-30 23:43:20 +00:00
2022-07-06 13:40:38 +00:00
if (enableCollateral) {
markets.enterMarket(subAccount, _token);
}
2022-06-30 23:43:20 +00:00
setUint(setId, _amt);
_eventName = "LogDeposit(uint256,address,uint256,bool,uint256,uint256)";
2022-07-06 13:40:38 +00:00
_eventParam = abi.encode(
subAccount,
token,
_amt,
enableCollateral,
getId,
setId
);
2022-06-30 23:43:20 +00:00
}
2022-07-06 13:40:38 +00:00
/**
2022-06-30 23:43:20 +00:00
* @dev Withdraw ETH/ERC20_Token.
* @notice Withdraw deposited token and earned interest from Euler
2022-07-06 13:40:38 +00:00
* @param subAccount Subaccount number
2022-06-30 23:43:20 +00:00
* @param token The address of the token to withdraw.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
* @param amt The amount of the token to withdraw. (For max: `uint256(-1)`)
* @param getId ID to retrieve amt.
* @param setId ID stores the amount of tokens withdrawn.
*/
function withdraw(
2022-07-06 13:40:38 +00:00
uint256 subAccount,
2022-06-30 23:43:20 +00:00
address token,
uint256 amt,
uint256 getId,
uint256 setId
)
external
payable
returns (string memory _eventName, bytes memory _eventParam)
{
uint256 _amt = getUint(getId, amt);
bool isEth = token == ethAddr;
address _token = isEth ? wethAddr : token;
TokenInterface tokenContract = TokenInterface(_token);
2022-07-06 13:40:38 +00:00
IEulerEToken eToken = IEulerEToken(markets.underlyingToEToken(_token));
2022-08-12 18:56:20 +00:00
address _subAccount = getSubAccount(address(this), subAccount);
_amt = _amt == uint256(-1) ? eToken.balanceOfUnderlying(_subAccount) : _amt;
2022-08-14 13:12:17 +00:00
uint256 initialBal = tokenContract.balanceOf(address(this));
2022-07-07 19:05:48 +00:00
2022-06-30 23:43:20 +00:00
eToken.withdraw(subAccount, _amt);
2022-08-14 13:12:17 +00:00
uint256 finalBal = tokenContract.balanceOf(address(this));
2022-06-30 23:43:20 +00:00
_amt = finalBal - initialBal;
convertWethToEth(isEth, tokenContract, _amt);
setUint(setId, _amt);
_eventName = "LogWithdraw(uint256,address,uint256,uint256,uint256)";
_eventParam = abi.encode(subAccount, token, _amt, getId, setId);
}
/**
* @dev Borrow ETH/ERC20_Token.
* @notice Borrow a token from Euler
2022-07-06 13:40:38 +00:00
* @param subAccount Subaccount number
2022-06-30 23:43:20 +00:00
* @param token The address of the token to borrow.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
2022-07-07 19:05:48 +00:00
* @param amt The amount of the token to borrow.
2022-06-30 23:43:20 +00:00
* @param getId ID to retrieve amt.
* @param setId ID stores the amount of tokens deposited.
*/
2022-07-06 13:40:38 +00:00
function borrow(
uint256 subAccount,
2022-06-30 23:43:20 +00:00
address token,
uint256 amt,
uint256 getId,
uint256 setId
)
external
payable
returns (string memory _eventName, bytes memory _eventParam)
{
2022-07-06 13:40:38 +00:00
uint256 _amt = getUint(getId, amt);
2022-06-30 23:43:20 +00:00
2022-07-06 13:40:38 +00:00
bool isEth = token == ethAddr ? true : false;
address _token = isEth ? wethAddr : token;
2022-06-30 23:43:20 +00:00
2022-07-06 13:40:38 +00:00
IEulerDToken borrowedDToken = IEulerDToken(
markets.underlyingToDToken(_token)
);
borrowedDToken.borrow(subAccount, _amt);
2022-06-30 23:43:20 +00:00
2022-07-06 13:40:38 +00:00
convertWethToEth(isEth, TokenInterface(_token), _amt);
2022-06-30 23:43:20 +00:00
2022-07-06 13:40:38 +00:00
setUint(setId, _amt);
2022-06-30 23:43:20 +00:00
2022-07-06 13:40:38 +00:00
_eventName = "LogBorrow(uint256,address,uint256,uint256,uint256)";
2022-06-30 23:43:20 +00:00
_eventParam = abi.encode(subAccount, token, _amt, getId, setId);
2022-07-06 13:40:38 +00:00
}
2022-06-30 23:43:20 +00:00
/**
* @dev Repay ETH/ERC20_Token.
* @notice Repay a token from Euler
2022-07-06 13:40:38 +00:00
* @param subAccount Subaccount number
2022-06-30 23:43:20 +00:00
* @param token The address of the token to repay.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
* @param amt The amount of the token to repay. (For max: `uint256(-1)`)
* @param getId ID to retrieve amt.
* @param setId ID stores the amount of tokens deposited.
*/
2022-07-06 13:40:38 +00:00
function repay(
uint256 subAccount,
2022-06-30 23:43:20 +00:00
address token,
uint256 amt,
uint256 getId,
uint256 setId
)
external
payable
returns (string memory _eventName, bytes memory _eventParam)
{
2022-07-06 13:40:38 +00:00
uint256 _amt = getUint(getId, amt);
2022-06-30 23:43:20 +00:00
2022-07-09 14:38:16 +00:00
bool isEth = token == ethAddr;
2022-07-06 13:40:38 +00:00
address _token = isEth ? wethAddr : token;
2022-07-09 14:38:16 +00:00
2022-07-06 13:40:38 +00:00
IEulerDToken borrowedDToken = IEulerDToken(
markets.underlyingToDToken(_token)
);
2022-06-30 23:43:20 +00:00
2022-08-12 18:56:20 +00:00
address _subAccount = getSubAccount(address(this), subAccount);
_amt = _amt == uint256(-1) ? borrowedDToken.balanceOf(_subAccount) : _amt;
if (isEth) {
convertEthToWeth(isEth, TokenInterface(_token), _amt);
}
2022-06-30 23:43:20 +00:00
2022-07-07 18:51:06 +00:00
approve(TokenInterface(_token), EULER_MAINNET, _amt);
borrowedDToken.repay(subAccount, _amt);
2022-06-30 23:43:20 +00:00
setUint(setId, _amt);
_eventName = "LogRepay(uint256,address,uint256,uint256,uint256)";
_eventParam = abi.encode(subAccount, token, _amt, getId, setId);
2022-07-06 13:40:38 +00:00
}
2022-06-30 23:43:20 +00:00
/**
* @dev Mint ETH/ERC20_Token.
* @notice Mint a token from Euler. Mint creates an equal amount of deposits and debts. (self-borrow)
2022-07-06 13:40:38 +00:00
* @param subAccount Subaccount number
2022-06-30 23:43:20 +00:00
* @param token The address of the token to mint.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
* @param amt The amount of the token to mint.
* @param getId ID to retrieve amt.
* @param setId ID stores the amount of tokens deposited.
*/
function mint(
2022-07-06 13:40:38 +00:00
uint256 subAccount,
2022-06-30 23:43:20 +00:00
address token,
uint256 amt,
uint256 getId,
uint256 setId
)
external
payable
returns (string memory _eventName, bytes memory _eventParam)
{
2022-07-06 13:40:38 +00:00
uint256 _amt = getUint(getId, amt);
2022-07-06 01:07:56 +00:00
2022-07-06 13:40:38 +00:00
bool isEth = token == ethAddr ? true : false;
address _token = isEth ? wethAddr : token;
2022-06-30 23:43:20 +00:00
IEulerEToken eToken = IEulerEToken(markets.underlyingToEToken(_token));
2022-07-06 13:40:38 +00:00
if (isEth) convertEthToWeth(isEth, TokenInterface(_token), _amt);
2022-06-30 23:43:20 +00:00
eToken.mint(subAccount, _amt);
2022-06-30 23:43:20 +00:00
setUint(setId, _amt);
_eventName = "LogMint(uint256,address,uint256,uint256,uint256)";
_eventParam = abi.encode(subAccount, token, _amt, getId, setId);
2022-07-06 13:40:38 +00:00
}
2022-06-30 23:43:20 +00:00
/**
* @dev Burn ETH/ERC20_Token.
* @notice Burn a token from Euler. Burn removes equal amount of deposits and debts.
2022-07-06 13:40:38 +00:00
* @param subAccount Subaccount number
2022-06-30 23:43:20 +00:00
* @param token The address of the token to burn.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
2022-07-07 19:05:48 +00:00
* @param amt The amount of the token to burn.
2022-06-30 23:43:20 +00:00
* @param getId ID to retrieve amt.
* @param setId ID stores the amount of tokens deposited.
*/
function burn(
2022-07-06 13:40:38 +00:00
uint256 subAccount,
address token,
uint256 amt,
uint256 getId,
2022-06-30 23:43:20 +00:00
uint256 setId
)
external
payable
returns (string memory _eventName, bytes memory _eventParam)
{
2022-07-06 13:40:38 +00:00
uint256 _amt = getUint(getId, amt);
2022-06-30 23:43:20 +00:00
2022-07-06 13:40:38 +00:00
bool isEth = token == ethAddr ? true : false;
address _token = isEth ? wethAddr : token;
2022-06-30 23:43:20 +00:00
IEulerDToken dToken = IEulerDToken(markets.underlyingToDToken(_token));
IEulerEToken eToken = IEulerEToken(markets.underlyingToEToken(_token));
2022-08-14 10:34:45 +00:00
address _subAccount = getSubAccount(address(this), subAccount);
if(_amt == uint256(-1)) {
uint256 _eTokenBalance = eToken.balanceOfUnderlying(_subAccount);
uint256 _dTokenBalance = dToken.balanceOf(_subAccount);
_amt = _eTokenBalance <= _dTokenBalance ? _eTokenBalance : _dTokenBalance;
}
2022-06-30 23:43:20 +00:00
2022-07-06 13:40:38 +00:00
if (isEth) convertEthToWeth(isEth, TokenInterface(_token), _amt);
2022-06-30 23:43:20 +00:00
eToken.burn(subAccount, _amt);
2022-06-30 23:43:20 +00:00
setUint(setId, _amt);
_eventName = "LogBurn(uint256,address,uint256,uint256,uint256)";
_eventParam = abi.encode(subAccount, token, _amt, getId, setId);
2022-07-06 13:40:38 +00:00
}
2022-06-30 23:43:20 +00:00
/**
* @dev ETransfer ETH/ERC20_Token.
* @notice ETransfer deposits from one sub-account to another.
2022-07-06 13:40:38 +00:00
* @param subAccountFrom subAccount from which deposit is transferred
2022-07-06 01:07:56 +00:00
* @param subAccountTo subAccount to which deposit is transferred
2022-06-30 23:43:20 +00:00
* @param token The address of the token to etransfer.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
* @param amt The amount of the token to etransfer. (For max: `uint256(-1)`)
* @param getId ID to retrieve amt.
* @param setId ID stores the amount of tokens deposited.
*/
function eTransfer(
2022-07-06 13:40:38 +00:00
uint256 subAccountFrom,
2022-07-06 01:07:56 +00:00
uint256 subAccountTo,
2022-07-06 13:40:38 +00:00
address token,
uint256 amt,
uint256 getId,
2022-06-30 23:43:20 +00:00
uint256 setId
)
external
payable
returns (string memory _eventName, bytes memory _eventParam)
{
2022-07-06 13:40:38 +00:00
uint256 _amt = getUint(getId, amt);
2022-06-30 23:43:20 +00:00
2022-07-06 13:40:38 +00:00
bool isEth = token == ethAddr ? true : false;
address _token = isEth ? wethAddr : token;
2022-06-30 23:43:20 +00:00
IEulerEToken eToken = IEulerEToken(markets.underlyingToEToken(_token));
2022-08-12 18:56:20 +00:00
address _subAccountFromAddr = getSubAccount(address(this), subAccountFrom);
address _subAccountToAddr = getSubAccount(address(this), subAccountTo);
2022-07-07 19:05:48 +00:00
_amt = _amt == uint256(-1)
2022-08-12 18:56:20 +00:00
? eToken.balanceOf(_subAccountFromAddr)
2022-07-06 13:40:38 +00:00
: _amt;
2022-06-30 23:43:20 +00:00
2022-07-06 13:40:38 +00:00
if (isEth) convertEthToWeth(isEth, TokenInterface(_token), _amt);
2022-06-30 23:43:20 +00:00
2022-08-06 19:40:43 +00:00
eToken.transferFrom(_subAccountFromAddr, _subAccountToAddr, _amt);
2022-06-30 23:43:20 +00:00
setUint(setId, _amt);
_eventName = "LogETransfer(uint256,uint256,address,uint256,uint256,uint256)";
2022-07-06 13:40:38 +00:00
_eventParam = abi.encode(
subAccountFrom,
subAccountTo,
token,
_amt,
getId,
setId
);
}
2022-06-30 23:43:20 +00:00
/**
* @dev DTransfer ETH/ERC20_Token.
* @notice DTransfer deposits from one sub-account to another.
2022-07-06 13:40:38 +00:00
* @param subAccountFrom subAccount from which debt is transferred
2022-07-06 01:07:56 +00:00
* @param subAccountTo subAccount to which debt is transferred
2022-06-30 23:43:20 +00:00
* @param token The address of the token to dtransfer.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
* @param amt The amount of the token to dtransfer. (For max: `uint256(-1)`)
* @param getId ID to retrieve amt.
* @param setId ID stores the amount of tokens deposited.
*/
function dTransfer(
2022-07-06 13:40:38 +00:00
uint256 subAccountFrom,
2022-07-06 01:07:56 +00:00
uint256 subAccountTo,
2022-07-06 13:40:38 +00:00
address token,
uint256 amt,
uint256 getId,
2022-06-30 23:43:20 +00:00
uint256 setId
)
external
payable
returns (string memory _eventName, bytes memory _eventParam)
{
2022-07-06 13:40:38 +00:00
uint256 _amt = getUint(getId, amt);
2022-06-30 23:43:20 +00:00
2022-07-06 13:40:38 +00:00
bool isEth = token == ethAddr ? true : false;
address _token = isEth ? wethAddr : token;
2022-06-30 23:43:20 +00:00
2022-07-06 01:07:56 +00:00
IEulerDToken dToken = IEulerDToken(markets.underlyingToDToken(_token));
2022-06-30 23:43:20 +00:00
2022-08-12 18:56:20 +00:00
address _subAccountFromAddr = getSubAccount(address(this), subAccountFrom);
address _subAccountToAddr = getSubAccount(address(this), subAccountTo);
2022-07-07 19:05:48 +00:00
_amt = _amt == uint256(-1)
2022-08-12 18:56:20 +00:00
? dToken.balanceOf(_subAccountFromAddr)
2022-07-06 13:40:38 +00:00
: _amt;
2022-06-30 23:43:20 +00:00
2022-07-06 13:40:38 +00:00
if (isEth) convertEthToWeth(isEth, TokenInterface(_token), _amt);
2022-06-30 23:43:20 +00:00
2022-08-06 19:40:43 +00:00
dToken.transferFrom(_subAccountFromAddr, _subAccountToAddr, _amt);
2022-06-30 23:43:20 +00:00
setUint(setId, _amt);
_eventName = "LogDTransfer(uint256,uint256,address,uint256,uint256,uint256)";
2022-07-06 13:40:38 +00:00
_eventParam = abi.encode(
subAccountFrom,
subAccountTo,
token,
_amt,
getId,
setId
);
}
2022-07-06 01:07:56 +00:00
2022-07-06 13:52:01 +00:00
/**
2022-08-10 21:39:53 +00:00
* @dev Approve Spender's debt.
2022-08-10 20:37:03 +00:00
* @notice Approve sender to send debt.
* @param subAccountId Subaccount id of receiver
* @param debtSender Address of sender
* @param token The address of the token.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
* @param amt The amount of the token.
2022-07-06 13:52:01 +00:00
* @param setId ID stores the amount of tokens deposited.
*/
2022-08-10 21:39:53 +00:00
function approveSpenderDebt(
2022-07-06 01:07:56 +00:00
uint256 subAccountId,
2022-08-10 20:37:03 +00:00
address debtSender,
2022-07-06 01:07:56 +00:00
address token,
2022-07-06 13:52:01 +00:00
uint256 amt,
2022-07-06 01:07:56 +00:00
uint256 setId
)
external
payable
returns (string memory _eventName, bytes memory _eventParam)
{
bool isEth = token == ethAddr;
address _token = isEth ? wethAddr : token;
IEulerDToken dToken = IEulerDToken(markets.underlyingToDToken(_token));
2022-08-10 20:37:03 +00:00
dToken.approveDebt(subAccountId, debtSender, amt);
2022-07-06 01:07:56 +00:00
2022-08-10 20:37:03 +00:00
setUint(setId, amt);
2022-07-06 01:07:56 +00:00
2022-08-12 18:56:20 +00:00
_eventName = "LogApproveSpenderDebt(uint256,address,address,uint256,uint256)";
_eventParam = abi.encode(subAccountId, debtSender, token, amt, setId);
2022-07-06 13:40:38 +00:00
}
2022-07-06 01:07:56 +00:00
2022-07-06 13:52:01 +00:00
/**
* @dev Enter Market.
* @notice Enter Market.
* @param subAccountId Subaccount number
* @param tokens Array of new token markets to be entered
*/
function enterMarket(uint256 subAccountId, address[] memory tokens)
2022-07-06 13:40:38 +00:00
external
payable
returns (string memory _eventName, bytes memory _eventParam)
2022-07-06 01:07:56 +00:00
{
2022-07-06 13:52:01 +00:00
uint256 _length = tokens.length;
2022-07-06 01:07:56 +00:00
require(_length > 0, "0-markets-not-allowed");
for (uint256 i = 0; i < _length; i++) {
address _token = tokens[i] == ethAddr ? wethAddr : tokens[i];
2022-07-06 13:01:59 +00:00
markets.enterMarket(subAccountId, _token);
2022-07-06 01:07:56 +00:00
}
_eventName = "LogEnterMarket(uint256,address[])";
2022-07-06 13:52:01 +00:00
_eventParam = abi.encode(subAccountId, tokens);
2022-07-06 01:07:56 +00:00
}
2022-07-06 13:52:01 +00:00
/**
* @dev Exit Market.
* @notice Exit Market.
* @param subAccountId Subaccount number
* @param token token address
*/
function exitMarket(uint256 subAccountId, address token)
2022-07-06 13:40:38 +00:00
external
payable
returns (string memory _eventName, bytes memory _eventParam)
2022-07-06 01:07:56 +00:00
{
address _token = token == ethAddr ? wethAddr : token;
2022-07-06 01:07:56 +00:00
markets.exitMarket(subAccountId, _token);
_eventName = "LogExitMarket(uint256,address)";
2022-07-06 13:52:01 +00:00
_eventParam = abi.encode(subAccountId, token);
2022-07-06 01:07:56 +00:00
}
2022-07-05 13:03:47 +00:00
}
contract ConnectV2Euler is Euler {
string public constant name = "Euler-v1.0";
}