mirror of
https://github.com/Instadapp/dsa-connectors.git
synced 2024-07-29 22:37:00 +00:00
190 lines
3.9 KiB
Solidity
190 lines
3.9 KiB
Solidity
//SPDX-License-Identifier: MIT
|
|
pragma solidity ^0.7.0;
|
|
pragma abicoder v2;
|
|
|
|
import { TokenInterface } from "../../common/interfaces.sol";
|
|
import { DSMath } from "../../common/math.sol";
|
|
import { Basic } from "../../common/basic.sol";
|
|
import { CometInterface, CometRewards } from "./interface.sol";
|
|
|
|
abstract contract Helpers is DSMath, Basic {
|
|
CometRewards internal constant cometRewards =
|
|
CometRewards(0x1B0e765F6224C21223AeA2af16c1C46E38885a40);
|
|
|
|
struct BorrowWithdrawParams {
|
|
address market;
|
|
address token;
|
|
address from;
|
|
address to;
|
|
uint256 amt;
|
|
uint256 getId;
|
|
uint256 setId;
|
|
}
|
|
|
|
function getBaseToken(address market)
|
|
internal
|
|
view
|
|
returns (address baseToken)
|
|
{
|
|
baseToken = CometInterface(market).baseToken();
|
|
}
|
|
|
|
function _supply(
|
|
address market,
|
|
address token,
|
|
address from,
|
|
address to,
|
|
uint256 amt
|
|
) public payable returns (bool success) {
|
|
bytes memory data;
|
|
|
|
if (from == address(0) && to == address(0)) {
|
|
data = abi.encodeWithSignature(
|
|
"supply(address, uint256)",
|
|
token,
|
|
amt
|
|
);
|
|
} else if (from == address(0)) {
|
|
data = abi.encodeWithSignature(
|
|
"supplyTo(address, address, uint256)",
|
|
to,
|
|
token,
|
|
amt
|
|
);
|
|
} else if (from != address(0) && to != address(0)) {
|
|
data = abi.encodeWithSignature(
|
|
"supplyFrom(address, address, address, uint256)",
|
|
from,
|
|
to,
|
|
token,
|
|
amt
|
|
);
|
|
}
|
|
|
|
(success, ) = market.delegatecall(data);
|
|
}
|
|
|
|
function _withdraw(
|
|
address market,
|
|
address token,
|
|
address from,
|
|
address to,
|
|
uint256 amt
|
|
) internal returns (bool success) {
|
|
bytes memory data;
|
|
|
|
if (from == address(0) && to == address(0)) {
|
|
data = abi.encodeWithSignature(
|
|
"withdraw(address, uint256)",
|
|
token,
|
|
amt
|
|
);
|
|
} else if (from == address(0)) {
|
|
data = abi.encodeWithSignature(
|
|
"withdrawTo(address, address, uint256)",
|
|
to,
|
|
token,
|
|
amt
|
|
);
|
|
} else if (from != address(0) && to != address(0)) {
|
|
data = abi.encodeWithSignature(
|
|
"withdrawFrom(address, address, address, uint256)",
|
|
from,
|
|
to,
|
|
token,
|
|
amt
|
|
);
|
|
}
|
|
(success, ) = market.delegatecall(data);
|
|
}
|
|
|
|
function _transfer(
|
|
address market,
|
|
address token,
|
|
address from,
|
|
address to,
|
|
uint256 amt
|
|
) public payable returns (bool success) {
|
|
bytes memory data;
|
|
|
|
if (from == address(0)) {
|
|
data = abi.encodeWithSignature(
|
|
"transferAsset(address, address, uint256)",
|
|
to,
|
|
token,
|
|
amt
|
|
);
|
|
} else {
|
|
data = abi.encodeWithSignature(
|
|
"transferAssetFrom(address, address, address, uint256)",
|
|
from,
|
|
to,
|
|
token,
|
|
amt
|
|
);
|
|
}
|
|
|
|
(success, ) = market.delegatecall(data);
|
|
}
|
|
|
|
function _borrowOrWithdraw(BorrowWithdrawParams memory params)
|
|
internal
|
|
returns (uint256 amt, uint256 setId)
|
|
{
|
|
uint256 _amt = getUint(params.getId, params.amt);
|
|
|
|
require(
|
|
params.market != address(0) && params.token != address(0),
|
|
"invalid market/token address"
|
|
);
|
|
bool isEth = params.token == ethAddr;
|
|
address _token = isEth ? wethAddr : params.token;
|
|
|
|
TokenInterface tokenContract = TokenInterface(_token);
|
|
|
|
uint256 initialBal = getAccountSupplyBalanceOfAsset(
|
|
address(this),
|
|
params.market,
|
|
_token
|
|
);
|
|
bool success = _withdraw(
|
|
params.market,
|
|
_token,
|
|
params.from,
|
|
params.to,
|
|
_amt
|
|
);
|
|
require(success, "borrow-or-withdraw-failed");
|
|
|
|
uint256 finalBal = getAccountSupplyBalanceOfAsset(
|
|
address(this),
|
|
params.market,
|
|
_token
|
|
);
|
|
_amt = sub(finalBal, initialBal);
|
|
|
|
convertWethToEth(isEth, tokenContract, _amt);
|
|
|
|
setUint(params.setId, _amt);
|
|
|
|
amt = _amt;
|
|
setId = params.setId;
|
|
}
|
|
|
|
function getAccountSupplyBalanceOfAsset(
|
|
address account,
|
|
address market,
|
|
address asset
|
|
) internal returns (uint256 balance) {
|
|
if (asset == getBaseToken(market)) {
|
|
//balance in base
|
|
balance = CometInterface(market).balanceOf(account);
|
|
} else {
|
|
//balance in asset denomination
|
|
balance = uint256(
|
|
CometInterface(market).userCollateral(account, asset).balance
|
|
);
|
|
}
|
|
}
|
|
}
|