Removed trade with fees and optimised Kyber code.

This commit is contained in:
Sowmayjain 2018-12-01 00:51:24 +05:30
parent 15fbd1768c
commit b621b492d4
2 changed files with 22 additions and 78 deletions

View File

@ -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);
}
} }

View File

@ -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.");
} }