mirror of
https://github.com/Instadapp/InstaContract.git
synced 2024-07-29 22:47:45 +00:00
Removed trade with fees and optimised Kyber code.
This commit is contained in:
parent
15fbd1768c
commit
b621b492d4
|
@ -18,12 +18,6 @@ library SafeMath {
|
||||||
return c;
|
return c;
|
||||||
}
|
}
|
||||||
|
|
||||||
function sub(uint256 a, uint256 b) internal pure returns (uint256) {
|
|
||||||
require(b <= a, "Assertion Failed");
|
|
||||||
uint256 c = a - b;
|
|
||||||
return c;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
interface IERC20 {
|
interface IERC20 {
|
||||||
|
@ -85,13 +79,9 @@ contract Trade is Registry {
|
||||||
uint destAmt,
|
uint destAmt,
|
||||||
address beneficiary,
|
address beneficiary,
|
||||||
uint minConversionRate,
|
uint minConversionRate,
|
||||||
address referral,
|
address affiliate
|
||||||
uint cut,
|
|
||||||
address partner
|
|
||||||
);
|
);
|
||||||
|
|
||||||
address public eth = 0x00eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee;
|
|
||||||
|
|
||||||
function getExpectedPrice(
|
function getExpectedPrice(
|
||||||
address src,
|
address src,
|
||||||
address dest,
|
address dest,
|
||||||
|
@ -112,44 +102,23 @@ contract Trade is Registry {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
struct TradeUints {
|
|
||||||
uint srcAmt;
|
|
||||||
uint ethQty;
|
|
||||||
uint srcAmtWithFees;
|
|
||||||
uint cut;
|
|
||||||
uint destAmt;
|
|
||||||
int ethBalAfterTrade; // it can be neagtive
|
|
||||||
}
|
|
||||||
|
|
||||||
function executeTrade(
|
function executeTrade(
|
||||||
address src, // token to sell
|
address src, // token to sell
|
||||||
address dest, // token to buy
|
address dest, // token to buy
|
||||||
uint srcAmt, // amount of token for sell
|
uint srcAmt, // amount of token for sell
|
||||||
uint srcAmtWithFees, // amount of token for sell + fees // equal or greater than srcAmt
|
|
||||||
uint minConversionRate, // minimum slippage rate
|
uint minConversionRate, // minimum slippage rate
|
||||||
uint maxDestAmt, // max amount of dest token
|
uint maxDestAmt // max amount of dest token
|
||||||
address partner // affiliate partner
|
|
||||||
) public payable returns (uint destAmt)
|
) public payable returns (uint destAmt)
|
||||||
{
|
{
|
||||||
|
|
||||||
require(srcAmtWithFees >= srcAmt, "srcAmtWithFees can't be small than scrAmt");
|
address eth = getAddress("eth");
|
||||||
if (src == eth) {
|
uint ethQty = getToken(
|
||||||
require(srcAmtWithFees == msg.value, "Not enough ETH to cover the trade.");
|
msg.sender, src, srcAmt, eth
|
||||||
}
|
|
||||||
|
|
||||||
TradeUints memory tradeSpecs;
|
|
||||||
Kyber kyberFunctions = Kyber(getAddress("kyber"));
|
|
||||||
|
|
||||||
tradeSpecs.srcAmt = srcAmt;
|
|
||||||
tradeSpecs.srcAmtWithFees = srcAmtWithFees;
|
|
||||||
tradeSpecs.cut = srcAmtWithFees.sub(srcAmt);
|
|
||||||
tradeSpecs.ethQty = getToken(
|
|
||||||
msg.sender,
|
|
||||||
src,
|
|
||||||
srcAmt,
|
|
||||||
srcAmtWithFees
|
|
||||||
);
|
);
|
||||||
tradeSpecs.destAmt = kyberFunctions.trade.value(tradeSpecs.ethQty)(
|
|
||||||
|
// Interacting with Kyber Proxy Contract
|
||||||
|
Kyber kyberFunctions = Kyber(getAddress("kyber"));
|
||||||
|
destAmt = kyberFunctions.trade.value(ethQty)(
|
||||||
src,
|
src,
|
||||||
srcAmt,
|
srcAmt,
|
||||||
dest,
|
dest,
|
||||||
|
@ -159,27 +128,19 @@ contract Trade is Registry {
|
||||||
getAddress("admin")
|
getAddress("admin")
|
||||||
);
|
);
|
||||||
|
|
||||||
// factoring maxDestAmt situation
|
// maxDestAmt usecase implementated
|
||||||
if (src == eth && address(this).balance > tradeSpecs.cut) {
|
if (src == eth && address(this).balance > 0) {
|
||||||
msg.sender.transfer(address(this).balance.sub(tradeSpecs.cut));
|
msg.sender.transfer(address(this).balance);
|
||||||
} else if (src != eth) {
|
} else if (src != eth) { // as there is no balanceOf of eth
|
||||||
IERC20 srcTkn = IERC20(src);
|
IERC20 srcTkn = IERC20(src);
|
||||||
uint srcBal = srcTkn.balanceOf(address(this));
|
uint srcBal = srcTkn.balanceOf(address(this));
|
||||||
if (srcBal > tradeSpecs.cut) {
|
if (srcBal > 0) {
|
||||||
srcTkn.transfer(msg.sender, srcBal.sub(tradeSpecs.cut));
|
srcTkn.transfer(msg.sender, srcBal);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
emit KyberTrade(
|
emit KyberTrade(
|
||||||
src,
|
src, srcAmt, dest, destAmt, msg.sender, minConversionRate, getAddress("admin")
|
||||||
srcAmt,
|
|
||||||
dest,
|
|
||||||
destAmt,
|
|
||||||
msg.sender,
|
|
||||||
minConversionRate,
|
|
||||||
getAddress("admin"),
|
|
||||||
tradeSpecs.cut,
|
|
||||||
partner
|
|
||||||
);
|
);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -188,7 +149,7 @@ contract Trade is Registry {
|
||||||
address trader,
|
address trader,
|
||||||
address src,
|
address src,
|
||||||
uint srcAmt,
|
uint srcAmt,
|
||||||
uint srcAmtWithFees
|
address eth
|
||||||
) internal returns (uint ethQty)
|
) internal returns (uint ethQty)
|
||||||
{
|
{
|
||||||
if (src == eth) {
|
if (src == eth) {
|
||||||
|
@ -196,7 +157,8 @@ contract Trade is Registry {
|
||||||
ethQty = srcAmt;
|
ethQty = srcAmt;
|
||||||
} else {
|
} else {
|
||||||
IERC20 tokenFunctions = IERC20(src);
|
IERC20 tokenFunctions = IERC20(src);
|
||||||
tokenFunctions.transferFrom(trader, address(this), srcAmtWithFees);
|
tokenFunctions.transferFrom(trader, address(this), srcAmt);
|
||||||
|
ethQty = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -205,24 +167,10 @@ contract Trade is Registry {
|
||||||
|
|
||||||
contract InstaKyber is Trade {
|
contract InstaKyber is Trade {
|
||||||
|
|
||||||
event ERC20Collected(address addr, uint amount);
|
|
||||||
event ETHCollected(uint amount);
|
|
||||||
|
|
||||||
constructor(address rAddr) public {
|
constructor(address rAddr) public {
|
||||||
addressRegistry = rAddr;
|
addressRegistry = rAddr;
|
||||||
}
|
}
|
||||||
|
|
||||||
function () public payable {}
|
function () public payable {}
|
||||||
|
|
||||||
function collectERC20(address tknAddr, uint amount) public onlyAdmin {
|
|
||||||
IERC20 tkn = IERC20(tknAddr);
|
|
||||||
tkn.transfer(msg.sender, amount);
|
|
||||||
emit ERC20Collected(tknAddr, amount);
|
|
||||||
}
|
|
||||||
|
|
||||||
function collectETH(uint amount) public onlyAdmin {
|
|
||||||
msg.sender.transfer(amount);
|
|
||||||
emit ETHCollected(amount);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
|
@ -57,10 +57,8 @@ interface InstaKyber {
|
||||||
address src,
|
address src,
|
||||||
address dest,
|
address dest,
|
||||||
uint srcAmt,
|
uint srcAmt,
|
||||||
uint srcAmtToFetch,
|
|
||||||
uint minConversionRate,
|
uint minConversionRate,
|
||||||
uint maxDestAmt,
|
uint maxDestAmt
|
||||||
address partner
|
|
||||||
) external payable returns (uint destAmt);
|
) external payable returns (uint destAmt);
|
||||||
|
|
||||||
function getExpectedPrice(
|
function getExpectedPrice(
|
||||||
|
@ -162,7 +160,7 @@ contract RepayLoan is IssueLoan {
|
||||||
function wipeDAI(uint daiWipe, address borrower) public payable returns (uint mkrCharged) {
|
function wipeDAI(uint daiWipe, address borrower) public payable returns (uint mkrCharged) {
|
||||||
address dai = getAddress("dai");
|
address dai = getAddress("dai");
|
||||||
address mkr = getAddress("mkr");
|
address mkr = getAddress("mkr");
|
||||||
address eth = 0x00eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee;
|
address eth = getAddress("eth");
|
||||||
|
|
||||||
IERC20 daiTkn = IERC20(dai);
|
IERC20 daiTkn = IERC20(dai);
|
||||||
IERC20 mkrTkn = IERC20(mkr);
|
IERC20 mkrTkn = IERC20(mkr);
|
||||||
|
@ -213,10 +211,8 @@ contract RepayLoan is IssueLoan {
|
||||||
eth,
|
eth,
|
||||||
mkr,
|
mkr,
|
||||||
ethQty,
|
ethQty,
|
||||||
ethQty,
|
|
||||||
minRate,
|
minRate,
|
||||||
mkrCharged,
|
mkrCharged
|
||||||
address(this)
|
|
||||||
);
|
);
|
||||||
require(mkrCharged == mkrBought, "ETH not sufficient to cover the MKR fees.");
|
require(mkrCharged == mkrBought, "ETH not sufficient to cover the MKR fees.");
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user