mirror of
https://github.com/Instadapp/dsa-connectors.git
synced 2024-07-29 22:37:00 +00:00
payback & paybackOnBehalfOf updated
This commit is contained in:
parent
8ebbeaae42
commit
8bc347abb5
|
@ -8,4 +8,12 @@ contract Events {
|
||||||
event LogPayback(address indexed token, uint256 tokenAmt, uint256 indexed rateMode, uint256 getId, uint256 setId);
|
event LogPayback(address indexed token, uint256 tokenAmt, uint256 indexed rateMode, uint256 getId, uint256 setId);
|
||||||
event LogEnableCollateral(address[] tokens);
|
event LogEnableCollateral(address[] tokens);
|
||||||
event LogSwapRateMode(address indexed token, uint256 rateMode);
|
event LogSwapRateMode(address indexed token, uint256 rateMode);
|
||||||
|
event LogPaybackOnBehalfOf(
|
||||||
|
address token,
|
||||||
|
uint256 amt,
|
||||||
|
uint256 rateMode,
|
||||||
|
address onBehalfOf,
|
||||||
|
uint256 getId,
|
||||||
|
uint256 setId
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -40,6 +40,21 @@ abstract contract Helpers is DSMath, Basic {
|
||||||
return rateMode == 1 ? stableDebt : variableDebt;
|
return rateMode == 1 ? stableDebt : variableDebt;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dev Get OnBehalfOf user's total debt balance & fee for an asset
|
||||||
|
* @param token token address of the debt.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
|
||||||
|
* @param rateMode Borrow rate mode (Stable = 1, Variable = 2)
|
||||||
|
*/
|
||||||
|
function getOnBehalfOfPaybackBalance(address token, uint256 rateMode, address onBehalfOf)
|
||||||
|
internal
|
||||||
|
view
|
||||||
|
returns (uint256)
|
||||||
|
{
|
||||||
|
(, uint256 stableDebt, uint256 variableDebt, , , , , , ) = aaveData
|
||||||
|
.getUserReserveData(token, onBehalfOf);
|
||||||
|
return rateMode == 1 ? stableDebt : variableDebt;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @dev Get total collateral balance for an asset
|
* @dev Get total collateral balance for an asset
|
||||||
* @param token token address of the collateral.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
|
* @param token token address of the collateral.(For ETH: 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE)
|
||||||
|
|
|
@ -150,7 +150,11 @@ abstract contract AaveResolver is Events, Helpers {
|
||||||
|
|
||||||
TokenInterface tokenContract = TokenInterface(_token);
|
TokenInterface tokenContract = TokenInterface(_token);
|
||||||
|
|
||||||
_amt = _amt == uint(-1) ? getPaybackBalance(_token, rateMode) : _amt;
|
if (_amt == uint(-1)) {
|
||||||
|
uint _amtDSA = tokenContract.balanceOf(address(this));
|
||||||
|
uint _amtDebt = getPaybackBalance(_token, rateMode);
|
||||||
|
_amt = _amtDSA <= _amtDebt ? _amtDSA : _amtDebt;
|
||||||
|
}
|
||||||
|
|
||||||
if (isEth) convertEthToWeth(isEth, tokenContract, _amt);
|
if (isEth) convertEthToWeth(isEth, tokenContract, _amt);
|
||||||
|
|
||||||
|
@ -164,6 +168,55 @@ abstract contract AaveResolver is Events, Helpers {
|
||||||
_eventParam = abi.encode(token, _amt, rateMode, getId, setId);
|
_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 = tokenContract.balanceOf(onBehalfOf);
|
||||||
|
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
|
* @dev Enable collateral
|
||||||
* @notice Enable an array of tokens as collateral
|
* @notice Enable an array of tokens as collateral
|
||||||
|
|
Loading…
Reference in New Issue
Block a user