mirror of
https://github.com/Instadapp/dsa-connectors.git
synced 2024-07-29 22:37:00 +00:00
uniswapv3-swap connector-optimism
This commit is contained in:
parent
1fdafa2e33
commit
ace03d7097
|
@ -32,4 +32,22 @@ contract Events {
|
||||||
);
|
);
|
||||||
|
|
||||||
event LogBurnPosition(uint256 tokenId);
|
event LogBurnPosition(uint256 tokenId);
|
||||||
|
|
||||||
|
event LogBuy(
|
||||||
|
address indexed buyToken,
|
||||||
|
address indexed sellToken,
|
||||||
|
uint256 buyAmt,
|
||||||
|
uint256 sellAmt,
|
||||||
|
uint256 getId,
|
||||||
|
uint256 setId
|
||||||
|
);
|
||||||
|
|
||||||
|
event LogSell(
|
||||||
|
address indexed buyToken,
|
||||||
|
address indexed sellToken,
|
||||||
|
uint256 buyAmt,
|
||||||
|
uint256 sellAmt,
|
||||||
|
uint256 getId,
|
||||||
|
uint256 setId
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,6 +10,7 @@ pragma abicoder v2;
|
||||||
import {TokenInterface} from "../../../common/interfaces.sol";
|
import {TokenInterface} from "../../../common/interfaces.sol";
|
||||||
import {Helpers} from "./helpers.sol";
|
import {Helpers} from "./helpers.sol";
|
||||||
import {Events} from "./events.sol";
|
import {Events} from "./events.sol";
|
||||||
|
import "./interface.sol";
|
||||||
|
|
||||||
abstract contract UniswapResolver is Helpers, Events {
|
abstract contract UniswapResolver is Helpers, Events {
|
||||||
/**
|
/**
|
||||||
|
@ -204,6 +205,123 @@ abstract contract UniswapResolver is Helpers, Events {
|
||||||
_eventName = "LogBurnPosition(uint256)";
|
_eventName = "LogBurnPosition(uint256)";
|
||||||
_eventParam = abi.encode(tokenId);
|
_eventParam = abi.encode(tokenId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dev Buy Function
|
||||||
|
* @notice Swap token(sellAddr) with token(buyAddr), buy token with minimum sell token
|
||||||
|
* @param buyAddr token to be bought
|
||||||
|
* @param sellAddr token to be sold
|
||||||
|
* @param fee pool fees for buyAddr-sellAddr token pair
|
||||||
|
* @param buyAmt amount of token to be bought
|
||||||
|
* @param getId Id to get buyAmt
|
||||||
|
* @param setId Id to store sellAmt
|
||||||
|
*/
|
||||||
|
function buy(
|
||||||
|
address buyAddr,
|
||||||
|
address sellAddr,
|
||||||
|
uint24 fee,
|
||||||
|
uint256 buyAmt,
|
||||||
|
uint256 unitAmt,
|
||||||
|
uint256 getId,
|
||||||
|
uint256 setId
|
||||||
|
) external payable returns (string memory _eventName, bytes memory _eventParam) {
|
||||||
|
uint _buyAmt = getUint(getId, buyAmt);
|
||||||
|
(TokenInterface _buyAddr, TokenInterface _sellAddr) = changeEthAddress(buyAddr, sellAddr);
|
||||||
|
|
||||||
|
// uint _slippageAmt = convert18ToDec(_sellAddr.decimals(),
|
||||||
|
// wmul(unitAmt, convertTo18(_buyAddr.decimals(), _buyAmt))
|
||||||
|
// );
|
||||||
|
|
||||||
|
bool isEth = address(_sellAddr) == wethAddr;
|
||||||
|
convertEthToWeth(isEth, _sellAddr, uint256(-1));
|
||||||
|
approve(_sellAddr, address(swapRouter), uint256(-1));
|
||||||
|
ISwapRouter.ExactOutputSingleParams memory params;
|
||||||
|
|
||||||
|
{
|
||||||
|
params = ISwapRouter.ExactOutputSingleParams({
|
||||||
|
tokenIn: sellAddr,
|
||||||
|
tokenOut: buyAddr,
|
||||||
|
fee: fee,
|
||||||
|
recipient: address(this),
|
||||||
|
deadline: block.timestamp + 1,
|
||||||
|
amountOut: _buyAmt,
|
||||||
|
amountInMaximum: uint256(-1),
|
||||||
|
sqrtPriceLimitX96: 0
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
uint _sellAmt = swapRouter.exactOutputSingle(params);
|
||||||
|
|
||||||
|
isEth = address(_buyAddr) == wethAddr;
|
||||||
|
convertWethToEth(isEth, _buyAddr, _buyAmt);
|
||||||
|
|
||||||
|
setUint(setId, _sellAmt);
|
||||||
|
|
||||||
|
_eventName = "LogBuy(address,address,uint256,uint256,uint256,uint256)";
|
||||||
|
_eventParam = abi.encode(buyAddr, sellAddr, _buyAmt, _sellAmt, getId, setId);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dev Sell Function
|
||||||
|
* @notice Swap token(sellAddr) with token(buyAddr), sell token to get maximum amount of buy token
|
||||||
|
* @param buyAddr token to be bought
|
||||||
|
* @param sellAddr token to be sold
|
||||||
|
* @param fee pool fees for buyAddr-sellAddr token pair
|
||||||
|
* @param sellAmt amount of token to be sold
|
||||||
|
* @param getId Id to get sellAmount
|
||||||
|
* @param setId Id to store buyAmount
|
||||||
|
*/
|
||||||
|
function sell(
|
||||||
|
address buyAddr,
|
||||||
|
address sellAddr,
|
||||||
|
uint24 fee,
|
||||||
|
uint256 sellAmt,
|
||||||
|
uint256 unitAmt,
|
||||||
|
uint256 getId,
|
||||||
|
uint256 setId
|
||||||
|
) external payable returns (string memory _eventName, bytes memory _eventParam) {
|
||||||
|
uint _sellAmt = getUint(getId, sellAmt);
|
||||||
|
(TokenInterface _buyAddr, TokenInterface _sellAddr) = changeEthAddress(buyAddr, sellAddr);
|
||||||
|
|
||||||
|
if (_sellAmt == uint(-1)) {
|
||||||
|
_sellAmt = sellAddr == ethAddr ?
|
||||||
|
address(this).balance :
|
||||||
|
_sellAddr.balanceOf(address(this));
|
||||||
|
}
|
||||||
|
|
||||||
|
// uint _slippageAmt = convert18ToDec(_buyAddr.decimals(),
|
||||||
|
// wmul(unitAmt, convertTo18(_sellAddr.decimals(), _sellAmt))
|
||||||
|
// );
|
||||||
|
// require(_slippageAmt <= _expectedAmt, "Too much slippage");
|
||||||
|
|
||||||
|
bool isEth = address(_sellAddr) == wethAddr;
|
||||||
|
convertEthToWeth(isEth, _sellAddr, _sellAmt);
|
||||||
|
approve(_sellAddr, address(swapRouter), _sellAmt);
|
||||||
|
ISwapRouter.ExactInputSingleParams memory params;
|
||||||
|
|
||||||
|
{
|
||||||
|
params = ISwapRouter.ExactInputSingleParams({
|
||||||
|
tokenIn: sellAddr,
|
||||||
|
tokenOut: buyAddr,
|
||||||
|
fee: fee,
|
||||||
|
recipient: address(this),
|
||||||
|
deadline: block.timestamp + 1,
|
||||||
|
amountIn: _sellAmt,
|
||||||
|
amountOutMinimum: 0,
|
||||||
|
sqrtPriceLimitX96: 0
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
uint _buyAmt = swapRouter.exactInputSingle(params);
|
||||||
|
|
||||||
|
isEth = address(_buyAddr) == wethAddr;
|
||||||
|
convertWethToEth(isEth, _buyAddr, _buyAmt);
|
||||||
|
|
||||||
|
setUint(setId, _buyAmt);
|
||||||
|
|
||||||
|
_eventName = "LogSell(address,address,uint256,uint256,uint256,uint256)";
|
||||||
|
_eventParam = abi.encode(buyAddr, sellAddr, _buyAmt, _sellAmt, getId, setId);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
contract ConnectV2UniswapV3Optimism is UniswapResolver {
|
contract ConnectV2UniswapV3Optimism is UniswapResolver {
|
||||||
|
|
Loading…
Reference in New Issue
Block a user