mirror of
https://github.com/Instadapp/dsa-connectors.git
synced 2024-07-29 22:37:00 +00:00
Fixed stack too deep error
This commit is contained in:
parent
f2d163c8ae
commit
9da4e18c2c
|
@ -4,6 +4,7 @@ pragma experimental ABIEncoderV2;
|
||||||
|
|
||||||
import { DSMath } from "../../common/math.sol";
|
import { DSMath } from "../../common/math.sol";
|
||||||
import { Basic } from "../../common/basic.sol";
|
import { Basic } from "../../common/basic.sol";
|
||||||
|
import { TokenInterface } from "../../common/interfaces.sol";
|
||||||
import { IStakingRewards, SynthetixMapping } from "./interface.sol";
|
import { IStakingRewards, SynthetixMapping } from "./interface.sol";
|
||||||
|
|
||||||
abstract contract Helpers is DSMath, Basic {
|
abstract contract Helpers is DSMath, Basic {
|
||||||
|
|
|
@ -6,14 +6,13 @@ pragma experimental ABIEncoderV2;
|
||||||
* @dev Stake ERC20 for earning rewards.
|
* @dev Stake ERC20 for earning rewards.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
import { TokenInterface } from "../../common/interfaces.sol";
|
import { TokenInterface } from "../../common/interfaces.sol";
|
||||||
import { Stores } from "../../common/stores.sol";
|
import { Stores } from "../../common/stores.sol";
|
||||||
import { Helpers } from "./helpers.sol";
|
import { Helpers } from "./helpers.sol";
|
||||||
import { Events } from "./events.sol";
|
import { Events } from "./events.sol";
|
||||||
import { IStakingRewards, SynthetixMapping } from "./interface.sol";
|
import { IStakingRewards, SynthetixMapping } from "./interface.sol";
|
||||||
|
|
||||||
contract Main {
|
contract Main is Helpers, Events {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @dev Deposit ERC20.
|
* @dev Deposit ERC20.
|
||||||
|
@ -75,15 +74,15 @@ contract Main {
|
||||||
uint intialBal = rewardToken.balanceOf(address(this));
|
uint intialBal = rewardToken.balanceOf(address(this));
|
||||||
stakingContract.withdraw(_amt);
|
stakingContract.withdraw(_amt);
|
||||||
stakingContract.getReward();
|
stakingContract.getReward();
|
||||||
uint finalBal = rewardToken.balanceOf(address(this));
|
|
||||||
|
|
||||||
uint rewardAmt = sub(finalBal, intialBal);
|
uint rewardAmt = sub(rewardToken.balanceOf(address(this)), intialBal);
|
||||||
|
|
||||||
setUint(setIdAmount, _amt);
|
setUint(setIdAmount, _amt);
|
||||||
setUint(setIdReward, rewardAmt);
|
setUint(setIdReward, rewardAmt);
|
||||||
|
{
|
||||||
_eventName = "LogWithdrawAndClaimedReward(address,bytes32,uint256,uint256,uint256,uint256,uint256)";
|
_eventName = "LogWithdrawAndClaimedReward(address,bytes32,uint256,uint256,uint256,uint256,uint256)";
|
||||||
_eventParam = abi.encode(address(stakingToken), stakingType, _amt, rewardAmt, getId, setIdAmount, setIdReward);
|
_eventParam = abi.encode(address(stakingToken), stakingType, _amt, rewardAmt, getId, setIdAmount, setIdReward);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -116,6 +115,6 @@ contract Main {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
contract connectV2StakeERC20 is main {
|
contract connectV2StakeERC20 is Main {
|
||||||
string public constant name = "Stake-ERC20-v1.0";
|
string public constant name = "Stake-ERC20-v1.0";
|
||||||
}
|
}
|
|
@ -4,10 +4,29 @@ pragma experimental ABIEncoderV2;
|
||||||
import { DSMath } from "../../common/math.sol";
|
import { DSMath } from "../../common/math.sol";
|
||||||
import { Basic } from "../../common/basic.sol";
|
import { Basic } from "../../common/basic.sol";
|
||||||
|
|
||||||
import { IGUniRouter } from "./interface.sol";
|
import { IGUniRouter, IGUniPool, IERC20 } from "./interface.sol";
|
||||||
|
|
||||||
|
|
||||||
abstract contract Helpers is DSMath, Basic {
|
abstract contract Helpers is DSMath, Basic {
|
||||||
|
|
||||||
IGUniRouter public constant gUniRouter = IGUniRouter(0x8CA6fa325bc32f86a12cC4964Edf1f71655007A7);
|
IGUniRouter public constant gUniRouter = IGUniRouter(0x8CA6fa325bc32f86a12cC4964Edf1f71655007A7);
|
||||||
|
|
||||||
|
struct DepositAndSwap {
|
||||||
|
IGUniPool poolContract;
|
||||||
|
IERC20 _token0;
|
||||||
|
IERC20 _token1;
|
||||||
|
uint amount0;
|
||||||
|
uint amount1;
|
||||||
|
uint mintAmount;
|
||||||
|
}
|
||||||
|
|
||||||
|
struct Deposit {
|
||||||
|
IGUniPool poolContract;
|
||||||
|
IERC20 _token0;
|
||||||
|
IERC20 _token1;
|
||||||
|
uint amount0In;
|
||||||
|
uint amount1In;
|
||||||
|
uint mintAmount;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,14 +3,14 @@ pragma experimental ABIEncoderV2;
|
||||||
|
|
||||||
|
|
||||||
import { IERC20 } from "@openzeppelin/contracts/token/ERC20/IERC20.sol";
|
import { IERC20 } from "@openzeppelin/contracts/token/ERC20/IERC20.sol";
|
||||||
interface ERC20WrapperInterface {
|
interface IGUniPool {
|
||||||
|
|
||||||
function token0() external view returns (IERC20);
|
function token0() external view returns (IERC20);
|
||||||
|
|
||||||
function token1() external view returns (IERC20);
|
function token1() external view returns (IERC20);
|
||||||
|
|
||||||
function mint(
|
function mint(
|
||||||
uint256 mintAmount,
|
uint256 amount,
|
||||||
address receiver
|
address receiver
|
||||||
) external
|
) external
|
||||||
returns (
|
returns (
|
||||||
|
|
|
@ -8,7 +8,7 @@ pragma solidity ^0.7.0;
|
||||||
import "@openzeppelin/contracts/token/ERC20/SafeERC20.sol";
|
import "@openzeppelin/contracts/token/ERC20/SafeERC20.sol";
|
||||||
|
|
||||||
import { TokenInterface } from "../../common/interfaces.sol";
|
import { TokenInterface } from "../../common/interfaces.sol";
|
||||||
import { ERC20WrapperInterface, IERC20 } from "./interface.sol";
|
import { IGUniPool, IERC20 } from "./interface.sol";
|
||||||
import { Helpers } from "./helpers.sol";
|
import { Helpers } from "./helpers.sol";
|
||||||
import { Events } from "./events.sol";
|
import { Events } from "./events.sol";
|
||||||
|
|
||||||
|
@ -30,44 +30,48 @@ abstract contract UniswapV3Resolver is Events, Helpers {
|
||||||
uint256 amt0Max,
|
uint256 amt0Max,
|
||||||
uint256 amt1Max,
|
uint256 amt1Max,
|
||||||
uint slippage,
|
uint slippage,
|
||||||
uint256[] getIds,
|
uint256[] calldata getIds,
|
||||||
uint256 setId
|
uint256 setId
|
||||||
) external payable returns (string memory _eventName, bytes memory _eventParam) {
|
) external payable returns (string memory _eventName, bytes memory _eventParam) {
|
||||||
|
|
||||||
amt0Max = getUint(getIds[0], amt0Max);
|
amt0Max = getUint(getIds[0], amt0Max);
|
||||||
amt1Max = getUint(getIds[1], amt1Max);
|
amt1Max = getUint(getIds[1], amt1Max);
|
||||||
|
|
||||||
ERC20WrapperInterface poolContract = ERC20WrapperInterface(pool);
|
Deposit memory depositData;
|
||||||
|
depositData.poolContract = IGUniPool(pool);
|
||||||
|
|
||||||
(uint256 amount0In, uint256 amount1In, uint256 mintAmount) = poolContract.getMintAmounts(amt0Max, amt1Max);
|
(depositData.amount0In, depositData.amount1In, depositData.mintAmount) =
|
||||||
|
depositData.poolContract.getMintAmounts(amt0Max, amt1Max);
|
||||||
|
|
||||||
uint amt0Min = wmul(amt0Max, slippage);
|
uint amt0Min = wmul(amt0Max, slippage);
|
||||||
uint amt1Min = wmul(amt1Max, slippage);
|
uint amt1Min = wmul(amt1Max, slippage);
|
||||||
|
|
||||||
require(
|
require(
|
||||||
amount0In >= amt0Min && amount1In >= amt1Min,
|
depositData.amount0In >= amt0Min && depositData.amount1In >= amt1Min,
|
||||||
"below min amounts"
|
"below min amounts"
|
||||||
);
|
);
|
||||||
|
|
||||||
if (amount0In > 0) {
|
if (depositData.amount0In > 0) {
|
||||||
IERC20 _token0 = poolContract.token0();
|
IERC20 _token0 = depositData.poolContract.token0();
|
||||||
convertEthToWeth(address(_token0) == wethAddr, TokenInterface(address(_token0)), amount0In);
|
convertEthToWeth(address(_token0) == wethAddr, TokenInterface(address(_token0)), depositData.amount0In);
|
||||||
_token0.safeApprove(address(pool), amount0In);
|
_token0.safeApprove(address(pool), depositData.amount0In);
|
||||||
}
|
}
|
||||||
if (amount1In > 0) {
|
if (depositData.amount1In > 0) {
|
||||||
IERC20 _token1 = poolContract.token1();
|
IERC20 _token1 = depositData.poolContract.token1();
|
||||||
convertEthToWeth(address(_token1) == wethAddr, TokenInterface(address(_token1)), amount1In);
|
convertEthToWeth(address(_token1) == wethAddr, TokenInterface(address(_token1)), depositData.amount1In);
|
||||||
_token1.safeApprove(address(pool), amount1In);
|
_token1.safeApprove(address(pool), depositData.amount1In);
|
||||||
}
|
}
|
||||||
|
|
||||||
(uint amount0, uint amount1,) = poolContract.mint(mintAmount, address(this));
|
(uint amount0, uint amount1,) = depositData.poolContract.mint(depositData.mintAmount, address(this));
|
||||||
|
|
||||||
require(amount0 == amount0In && amount1 == amount1In, "unexpected amounts deposited");
|
require(
|
||||||
|
amount0 == depositData.amount0In &&
|
||||||
|
amount1 == depositData.amount1In, "unexpected amounts deposited");
|
||||||
|
|
||||||
setUint(setId, mintAmount);
|
setUint(setId, depositData.mintAmount);
|
||||||
|
|
||||||
_eventName = "LogDepositLiquidity(address,uint256,uint256,uint256,uint256[],uint256)";
|
_eventName = "LogDepositLiquidity(address,uint256,uint256,uint256,uint256[],uint256)";
|
||||||
_eventParam = abi.encode(pool, amount0, amount1, mintAmount, getIds, setId);
|
_eventParam = abi.encode(pool, amount0, amount1, depositData.mintAmount, getIds, setId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -87,12 +91,12 @@ abstract contract UniswapV3Resolver is Events, Helpers {
|
||||||
uint256 minAmtA,
|
uint256 minAmtA,
|
||||||
uint256 minAmtB,
|
uint256 minAmtB,
|
||||||
uint256 getId,
|
uint256 getId,
|
||||||
uint256[] setIds
|
uint256[] calldata setIds
|
||||||
) external payable returns (string memory _eventName, bytes memory _eventParam) {
|
) external payable returns (string memory _eventName, bytes memory _eventParam) {
|
||||||
|
|
||||||
liqAmt = getUint(getId, liqAmt);
|
liqAmt = getUint(getId, liqAmt);
|
||||||
|
|
||||||
ERC20WrapperInterface poolContract = ERC20WrapperInterface(pool);
|
IGUniPool poolContract = IGUniPool(pool);
|
||||||
|
|
||||||
(uint amount0, uint amount1, uint128 liquidityBurned) = poolContract.burn(liqAmt, address(this));
|
(uint amount0, uint amount1, uint128 liquidityBurned) = poolContract.burn(liqAmt, address(this));
|
||||||
|
|
||||||
|
@ -137,66 +141,80 @@ abstract contract UniswapV3Resolver is Events, Helpers {
|
||||||
uint256 getId,
|
uint256 getId,
|
||||||
uint256 setId
|
uint256 setId
|
||||||
) external payable returns (string memory _eventName, bytes memory _eventParam) {
|
) external payable returns (string memory _eventName, bytes memory _eventParam) {
|
||||||
|
DepositAndSwap memory depositAndSwap;
|
||||||
|
depositAndSwap.poolContract = IGUniPool(pool);
|
||||||
|
depositAndSwap._token0 = depositAndSwap.poolContract.token0();
|
||||||
|
depositAndSwap._token1 = depositAndSwap.poolContract.token1();
|
||||||
|
|
||||||
ERC20WrapperInterface poolContract = ERC20WrapperInterface(pool);
|
depositAndSwap.amount0;
|
||||||
IERC20 _token0 = poolContract.token0();
|
depositAndSwap.amount1;
|
||||||
IERC20 _token1 = poolContract.token1();
|
depositAndSwap.mintAmount;
|
||||||
|
|
||||||
uint amount0;
|
if (address(depositAndSwap._token0) == wethAddr) {
|
||||||
uint amount1;
|
depositAndSwap._token1.approve(address(gUniRouter), amount1In);
|
||||||
uint mintAmount;
|
|
||||||
|
(depositAndSwap.amount0, depositAndSwap.amount1, depositAndSwap.mintAmount) =
|
||||||
|
gUniRouter.rebalanceAndAddLiquidityETH{value: amount0In}(
|
||||||
|
depositAndSwap.poolContract,
|
||||||
|
amount0In,
|
||||||
|
amount1In,
|
||||||
|
zeroForOne,
|
||||||
|
swapAmount,
|
||||||
|
swapThreshold,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
address(this)
|
||||||
|
);
|
||||||
|
} else if (address(depositAndSwap._token1) == wethAddr) {
|
||||||
|
depositAndSwap._token0.approve(address(gUniRouter), amount0In);
|
||||||
|
|
||||||
if (address(_token0) == wethAddr) {
|
(depositAndSwap.amount0, depositAndSwap.amount1,depositAndSwap. mintAmount) =
|
||||||
_token1.approve(address(gUniRouter), amount1In);
|
gUniRouter.rebalanceAndAddLiquidityETH{value: amount1In}(
|
||||||
(amount0, amount1, mintAmount) = gUniRouter.rebalanceAndAddLiquidityETH{value: amount0In}(
|
depositAndSwap.poolContract,
|
||||||
poolContract,
|
amount0In,
|
||||||
amount0In,
|
amount1In,
|
||||||
amount1In,
|
zeroForOne,
|
||||||
zeroForOne,
|
swapAmount,
|
||||||
swapAmount,
|
swapThreshold,
|
||||||
swapThreshold,
|
0,
|
||||||
0,
|
0,
|
||||||
0,
|
address(this)
|
||||||
address(this)
|
);
|
||||||
);
|
|
||||||
} else if (address(_token1) == wethAddr) {
|
|
||||||
_token0.approve(address(gUniRouter), amount0In);
|
|
||||||
(amount0, amount1, mintAmount) = gUniRouter.rebalanceAndAddLiquidityETH{value: amount1In}(
|
|
||||||
poolContract,
|
|
||||||
amount0In,
|
|
||||||
amount1In,
|
|
||||||
zeroForOne,
|
|
||||||
swapAmount,
|
|
||||||
swapThreshold,
|
|
||||||
0,
|
|
||||||
0,
|
|
||||||
address(this)
|
|
||||||
);
|
|
||||||
} else {
|
} else {
|
||||||
_token0.approve(address(gUniRouter), amount0In);
|
depositAndSwap._token0.approve(address(gUniRouter), amount0In);
|
||||||
_token1.approve(address(gUniRouter), amount1In);
|
depositAndSwap._token1.approve(address(gUniRouter), amount1In);
|
||||||
(amount0, amount1, mintAmount) = gUniRouter.rebalanceAndAddLiquidity(
|
(depositAndSwap.amount0, depositAndSwap.amount1, depositAndSwap.mintAmount) =
|
||||||
poolContract,
|
gUniRouter.rebalanceAndAddLiquidity(
|
||||||
amount0In,
|
depositAndSwap.poolContract,
|
||||||
amount1In,
|
amount0In,
|
||||||
zeroForOne,
|
amount1In,
|
||||||
swapAmount,
|
zeroForOne,
|
||||||
swapThreshold,
|
swapAmount,
|
||||||
0,
|
swapThreshold,
|
||||||
0,
|
0,
|
||||||
address(this)
|
0,
|
||||||
);
|
address(this)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
setUint(setId, mintAmount);
|
setUint(setId, depositAndSwap.mintAmount);
|
||||||
|
|
||||||
_eventName = "LogSwapAndDepositLiquidity(address,uint256,uint256,uint256,bool,uint256,uint256,uint256)";
|
_eventName = "LogSwapAndDepositLiquidity(address,uint256,uint256,uint256,bool,uint256,uint256,uint256)";
|
||||||
_eventParam = abi.encode(pool, amount0, amount1, mintAmount, zeroForOne, swapAmount, getId, setId);
|
_eventParam = abi.encode(
|
||||||
|
pool,
|
||||||
|
depositAndSwap.amount0,
|
||||||
|
depositAndSwap.amount1,
|
||||||
|
depositAndSwap.mintAmount,
|
||||||
|
zeroForOne,
|
||||||
|
swapAmount,
|
||||||
|
getId,
|
||||||
|
setId
|
||||||
|
);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
contract ConnectV2GUniswapV3ERC20 is UniswapV3Resolver {
|
contract ConnectV2GUniswapV3ERC20 is UniswapV3Resolver {
|
||||||
string public constant name = "GUniswap-v3-ERC20-v1.0";
|
string public constant name = "G-Uniswap-v3-ERC20-v1.0";
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user