mirror of
https://github.com/Instadapp/dsa-connectors.git
synced 2024-07-29 22:37:00 +00:00
add: helper
This commit is contained in:
parent
0406bcbf81
commit
a53b419602
80
contracts/optimism/connectors/connext/helpers.sol
Normal file
80
contracts/optimism/connectors/connext/helpers.sol
Normal file
|
@ -0,0 +1,80 @@
|
||||||
|
//SPDX-License-Identifier: MIT
|
||||||
|
pragma solidity ^0.7.0;
|
||||||
|
|
||||||
|
import { TokenInterface } from "../../common/interfaces.sol";
|
||||||
|
import { DSMath } from "../../common/math.sol";
|
||||||
|
import { Basic } from "../../common/basic.sol";
|
||||||
|
import { IConnext } from "./interface.sol";
|
||||||
|
import { IInstaReceiver } from "./interface.sol";
|
||||||
|
|
||||||
|
contract Helpers is DSMath, Basic {
|
||||||
|
/**
|
||||||
|
* @dev Connext Diamond Address
|
||||||
|
*/
|
||||||
|
address internal constant connextAddr = 0x8f7492DE823025b4CfaAB1D34c58963F2af5DEDA;
|
||||||
|
IConnext internal constant connext = IConnext(connextAddr);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dev InstaReceiver Address
|
||||||
|
*/
|
||||||
|
address internal constant instaReceiverAddr = 0x0000000000000000000000000000000000000000; // TODO: Add InstaReceiver address
|
||||||
|
IInstaReceiver internal constant instaReceiver = IInstaReceiver(instaReceiverAddr);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param destination The destination domain ID.
|
||||||
|
* @param asset The address of token to be bridged.
|
||||||
|
* @param delegate Address that can revert or forceLocal on destination.
|
||||||
|
* @param amount The amount to transfer.
|
||||||
|
* @param slippage Maximum amount of slippage the user will accept in BPS.
|
||||||
|
* @param relayerFee Relayer fee paid in origin native asset.
|
||||||
|
* @param callData Encoded calldata to send.
|
||||||
|
*/
|
||||||
|
struct XCallParams {
|
||||||
|
uint32 destination;
|
||||||
|
address to;
|
||||||
|
address asset;
|
||||||
|
address delegate;
|
||||||
|
uint256 amount;
|
||||||
|
uint256 slippage;
|
||||||
|
uint256 relayerFee;
|
||||||
|
bytes callData;
|
||||||
|
}
|
||||||
|
|
||||||
|
function _xcall(XCallParams memory params) internal {
|
||||||
|
uint256 nativeTokenAmt;
|
||||||
|
bool isNative = params.asset == ethAddr;
|
||||||
|
|
||||||
|
if (isNative) {
|
||||||
|
params.amount = params.amount == uint256(-1)
|
||||||
|
? address(this).balance
|
||||||
|
: params.amount;
|
||||||
|
|
||||||
|
// xcall does not take native asset, must wrap
|
||||||
|
TokenInterface tokenContract = TokenInterface(wethAddr);
|
||||||
|
convertEthToWeth(true, tokenContract, params.amount);
|
||||||
|
|
||||||
|
nativeTokenAmt = params.amount;
|
||||||
|
} else {
|
||||||
|
TokenInterface tokenContract = TokenInterface(params.asset);
|
||||||
|
params.amount = params.amount == uint256(-1)
|
||||||
|
? tokenContract.balanceOf(address(this))
|
||||||
|
: params.amount;
|
||||||
|
|
||||||
|
if (params.amount > 0) {
|
||||||
|
tokenContract.approve(connextAddr, params.amount);
|
||||||
|
}
|
||||||
|
|
||||||
|
nativeTokenAmt = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
connext.xcall{ value: params.relayerFee + nativeTokenAmt }(
|
||||||
|
params.destination,
|
||||||
|
params.to,
|
||||||
|
params.asset,
|
||||||
|
params.delegate,
|
||||||
|
params.amount,
|
||||||
|
params.slippage,
|
||||||
|
params.callData
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user