mirror of
https://github.com/Instadapp/dsa-connectors.git
synced 2024-07-29 22:37:00 +00:00
281 lines
11 KiB
Solidity
281 lines
11 KiB
Solidity
//SPDX-License-Identifier: MIT
|
|
pragma solidity ^0.7.0;
|
|
|
|
/**
|
|
* @title Curve USD.
|
|
* @dev Collateralized Borrowing.
|
|
*/
|
|
|
|
import { TokenInterface, AccountInterface } from "../../common/interfaces.sol";
|
|
import { Helpers } from "./helpers.sol";
|
|
import { Events } from "./events.sol";
|
|
import "./interface.sol";
|
|
|
|
abstract contract CurveUSDResolver is Helpers, Events {
|
|
/**
|
|
* @dev Create loan
|
|
* @dev If a user already has an existing loan, the function will revert.
|
|
* @param collateral Collateral token address.(For ETH: `0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE`)
|
|
* @param amt Amount of collateral (For max: `uint256(-1)`)
|
|
* @param debtAmt Stablecoin debt to take (For max: `uint256(-1)`)
|
|
* @param numBands Number of bands to deposit into (to do autoliquidation-deliquidation), can only be from MIN_TICKS(4) to MAX_TICKS(50)
|
|
* @param controllerVersion Controller version,
|
|
* @param getId ID to retrieve amt.
|
|
* @param setId ID stores the amount of debt borrowed.
|
|
*/
|
|
function createLoan(
|
|
address collateral,
|
|
uint256 amt,
|
|
uint256 debtAmt,
|
|
uint256 numBands,
|
|
uint256 controllerVersion,
|
|
uint256 getId,
|
|
uint256 setId
|
|
) external returns (string memory _eventName, bytes memory _eventParam) {
|
|
uint256 _amt = getUint(getId, amt);
|
|
|
|
bool _isEth = collateral == ethAddr;
|
|
address _collateralAddress = _isEth ? wethAddr : collateral;
|
|
TokenInterface collateralContract = TokenInterface(_collateralAddress);
|
|
|
|
// Get controller address of collateral.
|
|
IController controller = getController(_collateralAddress, controllerVersion);
|
|
|
|
if (_isEth) {
|
|
_amt = _amt == uint256(-1) ? address(this).balance : _amt;
|
|
convertEthToWeth(_isEth, collateralContract, _amt);
|
|
} else {
|
|
_amt = _amt == uint256(-1) ? collateralContract.balanceOf(address(this)) : _amt;
|
|
}
|
|
|
|
approve(collateralContract, address(controller), _amt);
|
|
|
|
uint256 _debtAmt = debtAmt == uint256(-1) ? controller.max_borrowable(_amt, numBands) : debtAmt;
|
|
|
|
controller.create_loan(_amt, _debtAmt, numBands);
|
|
|
|
setUint(setId, _debtAmt);
|
|
_eventName = "LogCreateLoan(address,uint256,uint256,uint256,uint256,uin256,uin256)";
|
|
_eventParam = abi.encode(collateral, _amt, _debtAmt, numBands, controllerVersion, getId, setId);
|
|
}
|
|
|
|
/**
|
|
* @dev Add collateral
|
|
* @notice Add extra collateral to avoid bad liqidations
|
|
* @param collateral Collateral token address.(For ETH: `0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE`)
|
|
* @param amt Amount of collateral (For max: `uint256(-1)`)
|
|
* @param controllerVersion Controller version,
|
|
* @param getId ID to retrieve amt.
|
|
* @param setId ID stores the collateral amount of tokens added.
|
|
*/
|
|
function addCollateral(
|
|
address collateral,
|
|
uint256 amt,
|
|
uint256 controllerVersion,
|
|
uint256 getId,
|
|
uint256 setId
|
|
) external returns (string memory _eventName, bytes memory _eventParam) {
|
|
uint _amt = getUint(getId, amt);
|
|
|
|
bool _isEth = collateral == ethAddr;
|
|
address _collateralAddress = _isEth ? wethAddr : collateral;
|
|
|
|
// Get controller address of collateral.
|
|
IController controller = getController(_collateralAddress, controllerVersion);
|
|
TokenInterface collateralContract = TokenInterface(_collateralAddress);
|
|
|
|
if (_isEth) {
|
|
_amt = _amt == uint(-1) ? address(this).balance : _amt;
|
|
convertEthToWeth(_isEth, collateralContract, _amt);
|
|
} else {
|
|
_amt = _amt == uint(-1) ? collateralContract.balanceOf(address(this)) : _amt;
|
|
}
|
|
|
|
approve(collateralContract, address(controller), _amt);
|
|
controller.add_collateral(_amt, address(this));
|
|
|
|
setUint(setId, _amt);
|
|
|
|
_eventName = "LogAddCollateral(address,uint256,uint256,uint256,uint256)";
|
|
_eventParam = abi.encode(collateral, amt, controllerVersion, getId, setId);
|
|
}
|
|
|
|
/**
|
|
* @dev Remove ETH/ERC20_Token Collateral.
|
|
* @notice Remove some collateral without repaying the debt
|
|
* @param collateral Collateral token address.(For ETH: `0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE`)
|
|
* @param amt Remove collateral amount (For max: `uint256(-1)`)
|
|
* @param controllerVersion controller version
|
|
* @param getId ID to retrieve amt.
|
|
* @param setId ID stores the amount of tokens deposited.
|
|
*/
|
|
function removeCollateral(
|
|
address collateral,
|
|
uint256 amt,
|
|
uint256 controllerVersion,
|
|
uint256 getId,
|
|
uint256 setId
|
|
) external returns (string memory _eventName, bytes memory _eventParam) {
|
|
uint _amt = getUint(getId, amt);
|
|
|
|
bool _isEth = collateral == ethAddr;
|
|
address _collateralAddress = _isEth ? wethAddr : collateral;
|
|
|
|
IController controller = getController(_collateralAddress, controllerVersion);
|
|
|
|
// remove_collateral will unwrap the eth.
|
|
controller.remove_collateral(_amt, _isEth);
|
|
|
|
setUint(setId, _amt);
|
|
_eventName = "LogRemoveCollateral(address,uint256,uint256,uint256,uint256)";
|
|
_eventParam = abi.encode(collateral, amt, controllerVersion, getId, setId);
|
|
}
|
|
|
|
/**
|
|
* @dev Borrow more stablecoins while adding more collateral (not necessary)
|
|
* @param collateral Collateral token address.(For ETH: `0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE`)
|
|
* @param debtAmt Stablecoin debt to take for borrow more (For max: `uint256(-1)`)
|
|
* @param controllerVersion controller version
|
|
* @param getId ID to retrieve amt.
|
|
* @param setId ID stores the amount of tokens deposited.
|
|
*/
|
|
function borrowMore(
|
|
address collateral,
|
|
uint256 debtAmt,
|
|
uint256 controllerVersion,
|
|
uint256 getId,
|
|
uint256 setId
|
|
) external returns (string memory _eventName, bytes memory _eventParam) {
|
|
uint _amt = getUint(getId, debtAmt);
|
|
|
|
bool _isEth = collateral == ethAddr;
|
|
|
|
address _collateralAddress = _isEth ? wethAddr : collateral;
|
|
IController controller = getController(_collateralAddress, controllerVersion);
|
|
|
|
uint256[4] memory res = controller.user_state(address(this));
|
|
uint256 _debtAmt = debtAmt == uint(-1)
|
|
? controller.max_borrowable(res[0], res[3]) - res[2]
|
|
: debtAmt;
|
|
|
|
controller.borrow_more(0, _debtAmt);
|
|
|
|
setUint(setId, _amt);
|
|
_eventName = "LogBorrowMore(address,uint256,uint256,uin256,uin256)";
|
|
_eventParam = abi.encode(collateral, debtAmt, controllerVersion, getId, setId);
|
|
}
|
|
|
|
/**
|
|
* @dev Borrow more stablecoins while adding more collateral (not necessary)
|
|
* @param collateral Collateral token address.(For ETH: `0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE`)
|
|
* @param colAmt Collateral amount for borrow more (For max: `uint256(-1)`)
|
|
* @param debtAmt Stablecoin debt to take for borrow more (For max: `uint256(-1)`)
|
|
* @param controllerVersion controller version
|
|
* @param getId ID to retrieve amt.
|
|
* @param setId ID stores the amount of tokens deposited.
|
|
*/
|
|
function addCollateralAndBorrowMore(
|
|
address collateral,
|
|
uint256 colAmt,
|
|
uint256 debtAmt,
|
|
uint256 controllerVersion,
|
|
uint256 getId,
|
|
uint256 setId
|
|
) external returns (string memory _eventName, bytes memory _eventParam) {
|
|
uint _amt = getUint(getId, colAmt);
|
|
|
|
bool _isEth = collateral == ethAddr;
|
|
address _collateralAddress = _isEth ? wethAddr : collateral;
|
|
TokenInterface collateralContract = TokenInterface(_collateralAddress);
|
|
|
|
IController controller = getController(_collateralAddress, controllerVersion);
|
|
|
|
if (_isEth) {
|
|
_amt = _amt == uint(-1) ? address(this).balance : _amt;
|
|
convertEthToWeth(_isEth, collateralContract, _amt);
|
|
} else {
|
|
_amt = _amt == uint(-1) ? collateralContract.balanceOf(address(this)) : _amt;
|
|
}
|
|
|
|
approve(collateralContract, address(controller), _amt);
|
|
|
|
uint256[4] memory res = controller.user_state(address(this));
|
|
uint256 _debtAmt = debtAmt == uint(-1)
|
|
? controller.max_borrowable(_amt + res[0], res[3]) - res[2]
|
|
: debtAmt;
|
|
|
|
controller.borrow_more(_amt, _debtAmt);
|
|
|
|
setUint(setId, _amt);
|
|
_eventName = "LogAddCollateralAndBorrowMore(address,uint256,uint256,uint256,uin256,uin256)";
|
|
_eventParam = abi.encode(collateral, colAmt, debtAmt, controllerVersion, getId, setId);
|
|
}
|
|
|
|
/**
|
|
* @dev Repay Curve-USD.
|
|
* @param collateral Collateral token address.(For ETH: `0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE`)
|
|
* @param amt repay amount (For max: `uint256(-1)`)
|
|
* @param controllerVersion Controller version.
|
|
* @param getId ID to retrieve amt.
|
|
* @param setId ID stores the amount of debt borrowed.
|
|
*/
|
|
function repay(
|
|
address collateral,
|
|
uint256 amt,
|
|
uint256 controllerVersion,
|
|
uint256 getId,
|
|
uint256 setId
|
|
) external payable returns (string memory _eventName, bytes memory _eventParam) {
|
|
uint _amt = getUint(getId, amt);
|
|
|
|
bool _isEth = collateral == ethAddr;
|
|
address _collateralAddress = _isEth ? wethAddr : collateral;
|
|
IController controller = getController(_collateralAddress, controllerVersion);
|
|
|
|
TokenInterface stableCoin = TokenInterface(CRV_USD);
|
|
_amt = _amt == uint(-1) ? stableCoin.balanceOf(address(this)) : _amt;
|
|
|
|
approve(stableCoin, address(controller), _amt);
|
|
|
|
controller.repay(_amt);
|
|
|
|
setUint(setId, _amt);
|
|
_eventName = "LogRepay(address,uint256,uint256,uint256,uint256)";
|
|
_eventParam = abi.encode(collateral, amt, controllerVersion, getId, setId);
|
|
}
|
|
|
|
/**
|
|
* @dev Peform a bad liquidation (or self-liquidation) of user if health is not good
|
|
* @param collateral collateral token address
|
|
* @param minReceiveAmt Minimal amount of stablecoin to receive (to avoid liquidators being sandwiched)
|
|
* @param controllerVersion controller version.
|
|
* @param getId ID to retrieve amt.
|
|
* @param setId ID stores the amount of debt borrowed.
|
|
*/
|
|
function selfLiquidate(
|
|
address collateral,
|
|
uint256 minReceiveAmt,
|
|
uint256 controllerVersion,
|
|
uint256 getId,
|
|
uint256 setId
|
|
) external payable returns (string memory _eventName, bytes memory _eventParam) {
|
|
uint _minReceiveAmt = getUint(getId, minReceiveAmt);
|
|
|
|
bool _isEth = collateral == ethAddr;
|
|
address _collateralAddress = _isEth ? wethAddr : collateral;
|
|
IController controller = getController(_collateralAddress, controllerVersion);
|
|
|
|
TokenInterface stableCoin = TokenInterface(CRV_USD);
|
|
approve(stableCoin, address(controller), _minReceiveAmt);
|
|
|
|
controller.liquidate(address(this), _minReceiveAmt, _isEth);
|
|
|
|
setUint(setId, _minReceiveAmt);
|
|
_eventName = "LogLiquidate(address,uint256,uint256,uint256,uint256)";
|
|
_eventParam = abi.encode(collateral, _minReceiveAmt, controllerVersion, getId, setId);
|
|
}
|
|
}
|
|
|
|
contract ConnectV2CurveUSD is CurveUSDResolver {
|
|
string public constant name = "CurveUSD-v1.0";
|
|
} |