dsa-connectors/contracts/optimism/connectors/hop/main.sol

83 lines
2.0 KiB
Solidity
Raw Normal View History

2022-04-11 12:02:58 +00:00
//SPDX-License-Identifier: MIT
pragma solidity ^0.7.0;
pragma experimental ABIEncoderV2;
/**
* @title Hop.
* @dev Cross chain Bridge.
*/
import { TokenInterface, MemoryInterface } from "../../common/interfaces.sol";
import { Stores } from "../../common/stores.sol";
import "./interface.sol";
import "./helpers.sol";
import "./events.sol";
abstract contract Resolver is Helpers {
/**
* @dev Bridge Token.
* @notice Bridge Token on HOP.
* @param params BridgeParams struct for bridging
* @param bridgeToL1 bool to check which layer to migrate to
* @param getId ID to retrieve amount from last spell.
*/
function bridge(
BridgeParams memory params,
bool bridgeToL1,
uint256 getId
)
external
payable
returns (string memory _eventName, bytes memory _eventParam)
{
if (bridgeToL1) {
require(
params.destinationAmountOutMin == 0,
"destinationAmountOutMin != 0, sending to L1"
);
require(
params.destinationDeadline == 0,
"destinationDeadline != 0, sending to L1"
);
}
params.amount = getUint(getId, params.amount);
bool isEth = params.token == ethAddr;
params.token = params.token == ethAddr ? wethAddr : params.token;
TokenInterface tokenContract = TokenInterface(params.token);
if (isEth) {
params.amount = params.amount == uint256(-1)
? address(this).balance
: params.amount;
convertEthToWeth(isEth, tokenContract, params.amount);
} else {
params.amount = params.amount == uint256(-1)
? tokenContract.balanceOf(address(this))
: params.amount;
}
_swapAndSend(params);
_eventName = "LogBridge(address,uint256,address,uint256,uint256,uint256,uint256,uint256,uint256,uint256)";
_eventParam = abi.encode(
params.token,
params.chainId,
params.recipient,
params.amount,
params.bonderFee,
params.amountOutMin,
params.deadline,
params.destinationAmountOutMin,
params.destinationDeadline,
getId
);
}
}
contract ConnectV2HopOptimism is Resolver {
string public constant name = "Hop-v1.0";
}