mirror of
https://github.com/Instadapp/dsa-connectors.git
synced 2024-07-29 22:37:00 +00:00
Morpho-Compound: changes added
This commit is contained in:
parent
3eba9e8d71
commit
bc9abcd4d6
|
@ -71,5 +71,9 @@ contract Events {
|
||||||
uint256 setId
|
uint256 setId
|
||||||
);
|
);
|
||||||
|
|
||||||
event LogClaimed(address[] tokenAddresses, bool tradeForMorphoToken);
|
event LogClaimed(
|
||||||
|
address[] tokenAddresses,
|
||||||
|
bool tradeForMorphoToken,
|
||||||
|
uint256 amountOfRewards
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,6 +10,28 @@ abstract contract Helpers is Stores, Basic {
|
||||||
IMorphoCore public constant MORPHO_COMPOUND =
|
IMorphoCore public constant MORPHO_COMPOUND =
|
||||||
IMorphoCore(0x8888882f8f843896699869179fB6E4f7e3B58888);
|
IMorphoCore(0x8888882f8f843896699869179fB6E4f7e3B58888);
|
||||||
|
|
||||||
IMorphoCompoundLens public constant morphoCompoundLens =
|
IMorphoCompoundLens public constant MORPHO_COMPOUND_LENS =
|
||||||
IMorphoCompoundLens(0x930f1b46e1D081Ec1524efD95752bE3eCe51EF67);
|
IMorphoCompoundLens(0x930f1b46e1D081Ec1524efD95752bE3eCe51EF67);
|
||||||
|
|
||||||
|
function _performEthToWethConversion(
|
||||||
|
address _tokenAddress,
|
||||||
|
uint256 _amount,
|
||||||
|
uint256 _getId
|
||||||
|
) internal returns (TokenInterface _tokenContract, uint256 _amt) {
|
||||||
|
_amt = getUint(_getId, _amount);
|
||||||
|
|
||||||
|
bool _isETH = _tokenAddress == ethAddr;
|
||||||
|
|
||||||
|
_tokenContract = _isETH
|
||||||
|
? TokenInterface(wethAddr)
|
||||||
|
: TokenInterface(_tokenAddress);
|
||||||
|
|
||||||
|
if (_amt == uint256(-1)) {
|
||||||
|
_amt = _isETH
|
||||||
|
? address(this).balance
|
||||||
|
: _tokenContract.balanceOf(address(this));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_isETH) convertEthToWeth(_isETH, _tokenContract, _amt);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,9 +33,9 @@ interface IMorphoCore {
|
||||||
) external;
|
) external;
|
||||||
|
|
||||||
function claimRewards(
|
function claimRewards(
|
||||||
address[] calldata _tokenAddresses,
|
address[] calldata _cTokenAddresses,
|
||||||
bool _tradeForMorphoToken
|
bool _tradeForMorphoToken
|
||||||
) external;
|
) external returns (uint256 amountOfRewards);
|
||||||
}
|
}
|
||||||
|
|
||||||
interface IMorphoCompoundLens {
|
interface IMorphoCompoundLens {
|
||||||
|
|
|
@ -25,24 +25,14 @@ abstract contract MorphoCompound is Helpers, Events {
|
||||||
payable
|
payable
|
||||||
returns (string memory _eventName, bytes memory _eventParam)
|
returns (string memory _eventName, bytes memory _eventParam)
|
||||||
{
|
{
|
||||||
uint256 _amt = getUint(_getId, _amount);
|
(
|
||||||
|
TokenInterface _tokenContract,
|
||||||
|
uint256 _amt
|
||||||
|
) = _performEthToWethConversion(_tokenAddress, _amount, _getId);
|
||||||
|
|
||||||
bool _isETH = _tokenAddress == ethAddr;
|
approve(_tokenContract, address(MORPHO_COMPOUND), _amt);
|
||||||
|
|
||||||
TokenInterface _tokenContract = _isETH
|
MORPHO_COMPOUND.supply(_poolTokenAddress, address(this), _amt);
|
||||||
? TokenInterface(wethAddr)
|
|
||||||
: TokenInterface(_tokenAddress);
|
|
||||||
|
|
||||||
if (_amt == uint256(-1)) {
|
|
||||||
_amt = _isETH
|
|
||||||
? address(this).balance
|
|
||||||
: _tokenContract.balanceOf(address(this));
|
|
||||||
}
|
|
||||||
|
|
||||||
convertEthToWeth(_isETH, _tokenContract, _amt);
|
|
||||||
|
|
||||||
approve(_tokenContract, address(morphoCompound), _amt);
|
|
||||||
morphoCompound.supply(_poolTokenAddress, address(this), _amt);
|
|
||||||
|
|
||||||
setUint(_setId, _amt);
|
setUint(_setId, _amt);
|
||||||
|
|
||||||
|
@ -78,24 +68,14 @@ abstract contract MorphoCompound is Helpers, Events {
|
||||||
payable
|
payable
|
||||||
returns (string memory _eventName, bytes memory _eventParam)
|
returns (string memory _eventName, bytes memory _eventParam)
|
||||||
{
|
{
|
||||||
uint256 _amt = getUint(_getId, _amount);
|
(
|
||||||
|
TokenInterface _tokenContract,
|
||||||
|
uint256 _amt
|
||||||
|
) = _performEthToWethConversion(_tokenAddress, _amount, _getId);
|
||||||
|
|
||||||
bool _isETH = _tokenAddress == ethAddr;
|
approve(_tokenContract, address(MORPHO_COMPOUND), _amt);
|
||||||
|
|
||||||
TokenInterface _tokenContract = _isETH
|
MORPHO_COMPOUND.supply(
|
||||||
? TokenInterface(wethAddr)
|
|
||||||
: TokenInterface(_tokenAddress);
|
|
||||||
|
|
||||||
if (_amt == uint256(-1)) {
|
|
||||||
_amt = _isETH
|
|
||||||
? address(this).balance
|
|
||||||
: _tokenContract.balanceOf(address(this));
|
|
||||||
}
|
|
||||||
|
|
||||||
convertEthToWeth(_isETH, _tokenContract, _amt);
|
|
||||||
|
|
||||||
approve(_tokenContract, address(morphoCompound), _amt);
|
|
||||||
morphoCompound.supply(
|
|
||||||
_poolTokenAddress,
|
_poolTokenAddress,
|
||||||
address(this),
|
address(this),
|
||||||
_amt,
|
_amt,
|
||||||
|
@ -137,24 +117,14 @@ abstract contract MorphoCompound is Helpers, Events {
|
||||||
payable
|
payable
|
||||||
returns (string memory _eventName, bytes memory _eventParam)
|
returns (string memory _eventName, bytes memory _eventParam)
|
||||||
{
|
{
|
||||||
uint256 _amt = getUint(_getId, _amount);
|
(
|
||||||
|
TokenInterface _tokenContract,
|
||||||
|
uint256 _amt
|
||||||
|
) = _performEthToWethConversion(_tokenAddress, _amount, _getId);
|
||||||
|
|
||||||
bool _isETH = _tokenAddress == ethAddr;
|
approve(_tokenContract, address(MORPHO_COMPOUND), _amt);
|
||||||
|
|
||||||
TokenInterface _tokenContract = _isETH
|
MORPHO_COMPOUND.supply(_poolTokenAddress, _onBehalf, _amt);
|
||||||
? TokenInterface(wethAddr)
|
|
||||||
: TokenInterface(_tokenAddress);
|
|
||||||
|
|
||||||
if (_amt == uint256(-1)) {
|
|
||||||
_amt = _isETH
|
|
||||||
? address(this).balance
|
|
||||||
: _tokenContract.balanceOf(address(this));
|
|
||||||
}
|
|
||||||
|
|
||||||
convertEthToWeth(_isETH, _tokenContract, _amt);
|
|
||||||
|
|
||||||
approve(_tokenContract, address(morphoCompound), _amt);
|
|
||||||
morphoCompound.supply(_poolTokenAddress, _onBehalf, _amt);
|
|
||||||
|
|
||||||
setUint(_setId, _amt);
|
setUint(_setId, _amt);
|
||||||
|
|
||||||
|
@ -193,9 +163,9 @@ abstract contract MorphoCompound is Helpers, Events {
|
||||||
|
|
||||||
bool _isETH = _tokenAddress == ethAddr;
|
bool _isETH = _tokenAddress == ethAddr;
|
||||||
|
|
||||||
morphoCompound.borrow(_poolTokenAddress, _amt);
|
MORPHO_COMPOUND.borrow(_poolTokenAddress, _amt);
|
||||||
|
|
||||||
convertWethToEth(_isETH, TokenInterface(wethAddr), _amt);
|
if (_isETH) convertWethToEth(_isETH, TokenInterface(wethAddr), _amt);
|
||||||
|
|
||||||
setUint(_setId, _amt);
|
setUint(_setId, _amt);
|
||||||
|
|
||||||
|
@ -235,9 +205,9 @@ abstract contract MorphoCompound is Helpers, Events {
|
||||||
|
|
||||||
bool _isETH = _tokenAddress == ethAddr;
|
bool _isETH = _tokenAddress == ethAddr;
|
||||||
|
|
||||||
morphoCompound.borrow(_poolTokenAddress, _amt, _maxGasForMatching);
|
MORPHO_COMPOUND.borrow(_poolTokenAddress, _amt, _maxGasForMatching);
|
||||||
|
|
||||||
convertWethToEth(_isETH, TokenInterface(wethAddr), _amt);
|
if (_isETH) convertWethToEth(_isETH, TokenInterface(wethAddr), _amt);
|
||||||
|
|
||||||
setUint(_setId, _amt);
|
setUint(_setId, _amt);
|
||||||
|
|
||||||
|
@ -274,18 +244,17 @@ abstract contract MorphoCompound is Helpers, Events {
|
||||||
{
|
{
|
||||||
uint256 _amt = getUint(_getId, _amount);
|
uint256 _amt = getUint(_getId, _amount);
|
||||||
bool _isETH = _tokenAddress == ethAddr;
|
bool _isETH = _tokenAddress == ethAddr;
|
||||||
address _token = _isETH ? wethAddr : _tokenAddress;
|
|
||||||
|
|
||||||
if (_amt == uint256(-1)) {
|
if (_amt == uint256(-1)) {
|
||||||
(, , _amt) = morphoCompoundLens.getCurrentSupplyBalanceInOf(
|
(, , _amt) = MORPHO_COMPOUND_LENS.getCurrentSupplyBalanceInOf(
|
||||||
_poolTokenAddress,
|
_poolTokenAddress,
|
||||||
address(this)
|
address(this)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
morphoCompound.withdraw(_poolTokenAddress, _amt);
|
MORPHO_COMPOUND.withdraw(_poolTokenAddress, _amt);
|
||||||
|
|
||||||
convertWethToEth(_isETH, TokenInterface(_token), _amt);
|
if (_isETH) convertWethToEth(_isETH, TokenInterface(wethAddr), _amt);
|
||||||
|
|
||||||
setUint(_setId, _amt);
|
setUint(_setId, _amt);
|
||||||
|
|
||||||
|
@ -322,8 +291,8 @@ abstract contract MorphoCompound is Helpers, Events {
|
||||||
bool _isETH = _tokenAddress == ethAddr;
|
bool _isETH = _tokenAddress == ethAddr;
|
||||||
uint256 _amt = getUint(_getId, _amount);
|
uint256 _amt = getUint(_getId, _amount);
|
||||||
|
|
||||||
TokenInterface _tokenContract = _isETH
|
TokenInterface _tokenContract = _isETH
|
||||||
? TokenInterface(wethAddr)
|
? TokenInterface(wethAddr)
|
||||||
: TokenInterface(_tokenAddress);
|
: TokenInterface(_tokenAddress);
|
||||||
|
|
||||||
if (_amt == uint256(-1)) {
|
if (_amt == uint256(-1)) {
|
||||||
|
@ -331,17 +300,17 @@ abstract contract MorphoCompound is Helpers, Events {
|
||||||
? address(this).balance
|
? address(this).balance
|
||||||
: _tokenContract.balanceOf(address(this));
|
: _tokenContract.balanceOf(address(this));
|
||||||
|
|
||||||
(, , uint256 _amtDebt) = morphoCompoundLens
|
(, , uint256 _amtDebt) = MORPHO_COMPOUND_LENS
|
||||||
.getCurrentBorrowBalanceInOf(_poolTokenAddress, address(this));
|
.getCurrentBorrowBalanceInOf(_poolTokenAddress, address(this));
|
||||||
|
|
||||||
_amt = _amtDSA <= _amtDebt ? _amtDSA : _amtDebt;
|
_amt = _amtDSA < _amtDebt ? _amtDSA : _amtDebt;
|
||||||
}
|
}
|
||||||
|
|
||||||
convertEthToWeth(_isETH, _tokenContract, _amt);
|
if (_isETH) convertEthToWeth(_isETH, _tokenContract, _amt);
|
||||||
|
|
||||||
approve(_tokenContract, address(morphoCompound), _amt);
|
approve(_tokenContract, address(MORPHO_COMPOUND), _amt);
|
||||||
|
|
||||||
morphoCompound.repay(_poolTokenAddress, address(this), _amt);
|
MORPHO_COMPOUND.repay(_poolTokenAddress, address(this), _amt);
|
||||||
|
|
||||||
setUint(_setId, _amt);
|
setUint(_setId, _amt);
|
||||||
|
|
||||||
|
@ -379,9 +348,9 @@ abstract contract MorphoCompound is Helpers, Events {
|
||||||
{
|
{
|
||||||
bool _isETH = _tokenAddress == ethAddr;
|
bool _isETH = _tokenAddress == ethAddr;
|
||||||
uint256 _amt = getUint(_getId, _amount);
|
uint256 _amt = getUint(_getId, _amount);
|
||||||
|
|
||||||
TokenInterface _tokenContract = _isETH
|
TokenInterface _tokenContract = _isETH
|
||||||
? TokenInterface(wethAddr)
|
? TokenInterface(wethAddr)
|
||||||
: TokenInterface(_tokenAddress);
|
: TokenInterface(_tokenAddress);
|
||||||
|
|
||||||
if (_amt == uint256(-1)) {
|
if (_amt == uint256(-1)) {
|
||||||
|
@ -389,17 +358,17 @@ abstract contract MorphoCompound is Helpers, Events {
|
||||||
? address(this).balance
|
? address(this).balance
|
||||||
: _tokenContract.balanceOf(address(this));
|
: _tokenContract.balanceOf(address(this));
|
||||||
|
|
||||||
(, , uint256 _amtDebt) = morphoCompoundLens
|
(, , uint256 _amtDebt) = MORPHO_COMPOUND_LENS
|
||||||
.getCurrentBorrowBalanceInOf(_poolTokenAddress, _onBehalf);
|
.getCurrentBorrowBalanceInOf(_poolTokenAddress, _onBehalf);
|
||||||
|
|
||||||
_amt = _amtDSA <= _amtDebt ? _amtDSA : _amtDebt;
|
_amt = _amtDSA < _amtDebt ? _amtDSA : _amtDebt;
|
||||||
}
|
}
|
||||||
|
|
||||||
convertEthToWeth(_isETH, _tokenContract, _amt);
|
if (_isETH) convertEthToWeth(_isETH, _tokenContract, _amt);
|
||||||
|
|
||||||
approve(_tokenContract, address(morphoCompound), _amt);
|
approve(_tokenContract, address(MORPHO_COMPOUND), _amt);
|
||||||
|
|
||||||
morphoCompound.repay(_poolTokenAddress, _onBehalf, _amt);
|
MORPHO_COMPOUND.repay(_poolTokenAddress, _onBehalf, _amt);
|
||||||
|
|
||||||
setUint(_setId, _amt);
|
setUint(_setId, _amt);
|
||||||
|
|
||||||
|
@ -428,10 +397,17 @@ abstract contract MorphoCompound is Helpers, Events {
|
||||||
payable
|
payable
|
||||||
returns (string memory _eventName, bytes memory _eventParam)
|
returns (string memory _eventName, bytes memory _eventParam)
|
||||||
{
|
{
|
||||||
morphoCompound.claimRewards(_poolTokenAddresses, _tradeForMorphoToken);
|
uint256 _amountOfRewards = MORPHO_COMPOUND.claimRewards(
|
||||||
|
_poolTokenAddresses,
|
||||||
|
_tradeForMorphoToken
|
||||||
|
);
|
||||||
|
|
||||||
_eventName = "LogClaimed(address[],bool)";
|
_eventName = "LogClaimed(address[],bool,uint256)";
|
||||||
_eventParam = abi.encode(_poolTokenAddresses, _tradeForMorphoToken);
|
_eventParam = abi.encode(
|
||||||
|
_poolTokenAddresses,
|
||||||
|
_tradeForMorphoToken,
|
||||||
|
_amountOfRewards
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user