mirror of
				https://github.com/Instadapp/dsa-connectors.git
				synced 2024-07-29 22:37:00 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			270 lines
		
	
	
		
			9.2 KiB
		
	
	
	
		
			Solidity
		
	
	
	
	
	
			
		
		
	
	
			270 lines
		
	
	
		
			9.2 KiB
		
	
	
	
		
			Solidity
		
	
	
	
	
	
| //SPDX-License-Identifier: MIT
 | |
| pragma solidity ^0.7.0;
 | |
| 
 | |
| /**
 | |
|  * @title Aave v2.
 | |
|  * @dev Lending & Borrowing.
 | |
|  */
 | |
| 
 | |
| import { TokenInterface } from "../../../common/interfaces.sol";
 | |
| import { Stores } from "../../../common/stores.sol";
 | |
| import { Helpers } from "./helpers.sol";
 | |
| import { Events } from "./events.sol";
 | |
| import { AaveInterface } from "./interface.sol";
 | |
| 
 | |
| abstract contract AaveResolver is Events, Helpers {
 | |
|     /**
 | |
|      * @dev Deposit ETH/ERC20_Token.
 | |
|      * @notice Deposit a token to Aave v2 for lending / collaterization.
 | |
|      * @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)`)
 | |
|      * @param getId ID to retrieve amt.
 | |
|      * @param setId ID stores the amount of tokens deposited.
 | |
|     */
 | |
|     function deposit(
 | |
|         address token,
 | |
|         uint256 amt,
 | |
|         uint256 getId,
 | |
|         uint256 setId
 | |
|     ) external payable returns (string memory _eventName, bytes memory _eventParam) {
 | |
|         uint _amt = getUint(getId, amt);
 | |
| 
 | |
|         AaveInterface aave = AaveInterface(aaveProvider.getLendingPool());
 | |
| 
 | |
|         bool isEth = token == ethAddr;
 | |
|         address _token = isEth ? wethAddr : token;
 | |
| 
 | |
|         TokenInterface tokenContract = TokenInterface(_token);
 | |
| 
 | |
|         if (isEth) {
 | |
|             _amt = _amt == uint(-1) ? address(this).balance : _amt;
 | |
|             convertEthToWeth(isEth, tokenContract, _amt);
 | |
|         } else {
 | |
|             _amt = _amt == uint(-1) ? tokenContract.balanceOf(address(this)) : _amt;
 | |
|         }
 | |
| 
 | |
|         approve(tokenContract, address(aave), _amt);
 | |
| 
 | |
|         aave.deposit(_token, _amt, address(this), referralCode);
 | |
| 
 | |
|         if (!getIsColl(_token)) {
 | |
|             aave.setUserUseReserveAsCollateral(_token, true);
 | |
|         }
 | |
| 
 | |
|         setUint(setId, _amt);
 | |
| 
 | |
|         _eventName = "LogDeposit(address,uint256,uint256,uint256)";
 | |
|         _eventParam = abi.encode(token, _amt, getId, setId);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @dev Withdraw ETH/ERC20_Token.
 | |
|      * @notice Withdraw deposited token from Aave v2
 | |
|      * @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(
 | |
|         address token,
 | |
|         uint256 amt,
 | |
|         uint256 getId,
 | |
|         uint256 setId
 | |
|     ) external payable returns (string memory _eventName, bytes memory _eventParam) {
 | |
|         uint _amt = getUint(getId, amt);
 | |
| 
 | |
|         AaveInterface aave = AaveInterface(aaveProvider.getLendingPool());
 | |
|         bool isEth = token == ethAddr;
 | |
|         address _token = isEth ? wethAddr : token;
 | |
| 
 | |
|         TokenInterface tokenContract = TokenInterface(_token);
 | |
| 
 | |
|         uint initialBal = tokenContract.balanceOf(address(this));
 | |
|         aave.withdraw(_token, _amt, address(this));
 | |
|         uint finalBal = tokenContract.balanceOf(address(this));
 | |
| 
 | |
|         _amt = sub(finalBal, initialBal);
 | |
| 
 | |
|         convertWethToEth(isEth, tokenContract, _amt);
 | |
|         
 | |
|         setUint(setId, _amt);
 | |
| 
 | |
|         _eventName = "LogWithdraw(address,uint256,uint256,uint256)";
 | |
|         _eventParam = abi.encode(token, _amt, getId, setId);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @dev Borrow ETH/ERC20_Token.
 | |
|      * @notice Borrow a token using Aave v2
 | |
|      * @param token The address of the token to borrow.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
 | |
|      * @param amt The amount of the token to borrow.
 | |
|      * @param rateMode The type of borrow debt. (For Stable: 1, Variable: 2)
 | |
|      * @param getId ID to retrieve amt.
 | |
|      * @param setId ID stores the amount of tokens borrowed.
 | |
|     */
 | |
|     function borrow(
 | |
|         address token,
 | |
|         uint256 amt,
 | |
|         uint256 rateMode,
 | |
|         uint256 getId,
 | |
|         uint256 setId
 | |
|     ) external payable returns (string memory _eventName, bytes memory _eventParam) {
 | |
|         uint _amt = getUint(getId, amt);
 | |
| 
 | |
|         AaveInterface aave = AaveInterface(aaveProvider.getLendingPool());
 | |
| 
 | |
|         bool isEth = token == ethAddr;
 | |
|         address _token = isEth ? wethAddr : token;
 | |
| 
 | |
|         aave.borrow(_token, _amt, rateMode, referralCode, address(this));
 | |
|         convertWethToEth(isEth, TokenInterface(_token), _amt);
 | |
| 
 | |
|         setUint(setId, _amt);
 | |
| 
 | |
|         _eventName = "LogBorrow(address,uint256,uint256,uint256,uint256)";
 | |
|         _eventParam = abi.encode(token, _amt, rateMode, getId, setId);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @dev Payback borrowed ETH/ERC20_Token.
 | |
|      * @notice Payback debt owed.
 | |
|      * @param token The address of the token to payback.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
 | |
|      * @param amt The amount of the token to payback. (For max: `uint256(-1)`)
 | |
|      * @param rateMode The type of debt paying back. (For Stable: 1, Variable: 2)
 | |
|      * @param getId ID to retrieve amt.
 | |
|      * @param setId ID stores the amount of tokens paid back.
 | |
|     */
 | |
|     function payback(
 | |
|         address token,
 | |
|         uint256 amt,
 | |
|         uint256 rateMode,
 | |
|         uint256 getId,
 | |
|         uint256 setId
 | |
|     ) external payable returns (string memory _eventName, bytes memory _eventParam) {
 | |
|         uint _amt = getUint(getId, amt);
 | |
| 
 | |
|         AaveInterface aave = AaveInterface(aaveProvider.getLendingPool());
 | |
| 
 | |
|         bool isEth = token == ethAddr;
 | |
|         address _token = isEth ? wethAddr : token;
 | |
| 
 | |
|         TokenInterface tokenContract = TokenInterface(_token);
 | |
|         
 | |
|         if (_amt == uint(-1)) {
 | |
|             uint _amtDSA = isEth ? address(this).balance : tokenContract.balanceOf(address(this));
 | |
|             uint _amtDebt = getPaybackBalance(_token, rateMode);
 | |
|             _amt = _amtDSA <= _amtDebt ? _amtDSA : _amtDebt;
 | |
|         }
 | |
| 
 | |
|         if (isEth) convertEthToWeth(isEth, tokenContract, _amt);
 | |
| 
 | |
|         approve(tokenContract, address(aave), _amt);
 | |
| 
 | |
|         aave.repay(_token, _amt, rateMode, address(this));
 | |
| 
 | |
|         setUint(setId, _amt);
 | |
| 
 | |
|         _eventName = "LogPayback(address,uint256,uint256,uint256,uint256)";
 | |
|         _eventParam = abi.encode(token, _amt, rateMode, getId, setId);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
| 	 * @dev Payback borrowed ETH/ERC20_Token on behalf of a user.
 | |
| 	 * @notice Payback debt owed on behalf os a user.
 | |
| 	 * @param token The address of the token to payback.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
 | |
| 	 * @param amt The amount of the token to payback. (For max: `uint256(-1)`)
 | |
| 	 * @param rateMode The type of debt paying back. (For Stable: 1, Variable: 2)
 | |
| 	 * @param onBehalfOf Address of user who's debt to repay.
 | |
| 	 * @param getId ID to retrieve amt.
 | |
| 	 * @param setId ID stores the amount of tokens paid back.
 | |
| 	 */
 | |
| 	function paybackOnBehalfOf(
 | |
| 		address token,
 | |
| 		uint256 amt,
 | |
| 		uint256 rateMode,
 | |
| 		address onBehalfOf,
 | |
| 		uint256 getId,
 | |
| 		uint256 setId
 | |
| 	)
 | |
| 		external
 | |
| 		payable
 | |
| 		returns (string memory _eventName, bytes memory _eventParam)
 | |
| 	{
 | |
| 		uint256 _amt = getUint(getId, amt);
 | |
| 
 | |
| 		AaveInterface aave = AaveInterface(aaveProvider.getLendingPool());
 | |
| 
 | |
| 		bool isEth = token == ethAddr;
 | |
| 		address _token = isEth ? wethAddr : token;
 | |
| 
 | |
| 		TokenInterface tokenContract = TokenInterface(_token);
 | |
| 
 | |
| 		if (_amt == uint(-1)) {
 | |
| 			uint _amtDSA = isEth ? address(this).balance : tokenContract.balanceOf(address(this));
 | |
| 			uint _amtDebt = getOnBehalfOfPaybackBalance(_token, rateMode, onBehalfOf);
 | |
| 			_amt = _amtDSA <= _amtDebt ? _amtDSA : _amtDebt;
 | |
| 		}
 | |
| 
 | |
| 		if (isEth) convertEthToWeth(isEth, tokenContract, _amt);
 | |
| 
 | |
| 		approve(tokenContract, address(aave), _amt);
 | |
| 
 | |
| 		aave.repay(_token, _amt, rateMode, onBehalfOf);
 | |
| 
 | |
| 		setUint(setId, _amt);
 | |
| 
 | |
| 		_eventName = "LogPaybackOnBehalfOf(address,uint256,uint256,address,uint256,uint256)";
 | |
| 		_eventParam = abi.encode(token, _amt, rateMode, onBehalfOf, getId, setId);
 | |
| 	}
 | |
| 
 | |
|     /**
 | |
|      * @dev Enable collateral
 | |
|      * @notice Enable an array of tokens as collateral
 | |
|      * @param tokens Array of tokens to enable collateral
 | |
|     */
 | |
|     function enableCollateral(
 | |
|         address[] calldata tokens
 | |
|     ) external payable returns (string memory _eventName, bytes memory _eventParam) {
 | |
|         uint _length = tokens.length;
 | |
|         require(_length > 0, "0-tokens-not-allowed");
 | |
| 
 | |
|         AaveInterface aave = AaveInterface(aaveProvider.getLendingPool());
 | |
| 
 | |
|         for (uint i = 0; i < _length; i++) {
 | |
|             address token = tokens[i];
 | |
|             if (getCollateralBalance(token) > 0 && !getIsColl(token)) {
 | |
|                 aave.setUserUseReserveAsCollateral(token, true);
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         _eventName = "LogEnableCollateral(address[])";
 | |
|         _eventParam = abi.encode(tokens);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @dev Swap borrow rate mode
 | |
|      * @notice Swaps user borrow rate mode between variable and stable
 | |
|      * @param token The address of the token to swap borrow rate.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
 | |
|      * @param rateMode Desired borrow rate mode. (Stable = 1, Variable = 2)
 | |
|     */
 | |
|     function swapBorrowRateMode(
 | |
|         address token,
 | |
|         uint rateMode
 | |
|     ) external payable returns (string memory _eventName, bytes memory _eventParam) {
 | |
|         AaveInterface aave = AaveInterface(aaveProvider.getLendingPool());
 | |
| 
 | |
|         uint currentRateMode = rateMode == 1 ? 2 : 1;
 | |
| 
 | |
|         if (getPaybackBalance(token, currentRateMode) > 0) {
 | |
|             aave.swapBorrowRateMode(token, rateMode);
 | |
|         }
 | |
| 
 | |
|         _eventName = "LogSwapRateMode(address,uint256)";
 | |
|         _eventParam = abi.encode(token, rateMode);
 | |
|     }
 | |
| }
 | |
| 
 | |
| contract ConnectV2AaveV2 is AaveResolver {
 | |
|     string constant public name = "AaveV2-v1.2";
 | |
| }
 | 
