MOVR Price: $6.30 (+14.14%)
Gas: 1 GWei

Contract

0x287176dfBEC7E8cee0f876FC7B52960ee1784AdC

Overview

MOVR Balance

Moonriver Chain LogoMoonriver Chain LogoMoonriver Chain Logo9.822040313905983779 MOVR

MOVR Value

$61.88 (@ $6.30/MOVR)

Token Holdings

Transaction Hash
Method
Block
From
To
Send Proxy OFTV2112767922025-04-23 9:23:246 mins ago1745400204IN
0x287176df...ee1784AdC
0.25228497 MOVR0.004407823.3
Send Proxy OFTV2112765892025-04-23 9:02:4827 mins ago1745398968IN
0x287176df...ee1784AdC
0.25487335 MOVR0.001736411.3
Send Proxy OFTV2112765822025-04-23 9:02:0028 mins ago1745398920IN
0x287176df...ee1784AdC
0.25326647 MOVR0.00133571
Send Proxy OFTV2112765012025-04-23 8:53:4836 mins ago1745398428IN
0x287176df...ee1784AdC
0.25534777 MOVR0.003472832.6
Send Proxy OFTV2112758422025-04-23 7:46:241 hr ago1745394384IN
0x287176df...ee1784AdC
0.25646561 MOVR0.004541393.4
Send Proxy OFTV2112758332025-04-23 7:45:301 hr ago1745394330IN
0x287176df...ee1784AdC
0.25646561 MOVR0.001944663.4
Send Proxy OFTV2112756312025-04-23 7:24:422 hrs ago1745393082IN
0x287176df...ee1784AdC
0.25941373 MOVR0.00041740.3125
Send Proxy OFTV2112748512025-04-23 6:03:483 hrs ago1745388228IN
0x287176df...ee1784AdC
0.25762993 MOVR0.000417480.3125
Send Proxy OFTV2112744302025-04-23 5:20:304 hrs ago1745385630IN
0x287176df...ee1784AdC
0.25698516 MOVR0.000417480.3125
Send Proxy OFTV2112743482025-04-23 5:11:364 hrs ago1745385096IN
0x287176df...ee1784AdC
0.25634045 MOVR0.004407823.3
Send Proxy OFTV2112738652025-04-23 4:21:545 hrs ago1745382114IN
0x287176df...ee1784AdC
0.25580668 MOVR0.000417480.3125
Send Proxy OFTV2112734642025-04-23 3:41:065 hrs ago1745379666IN
0x287176df...ee1784AdC
0.25624231 MOVR0.00133571
Send Proxy OFTV2112733862025-04-23 3:33:125 hrs ago1745379192IN
0x287176df...ee1784AdC
0.2570455 MOVR0.004407823.3
Send Proxy OFTV2112733312025-04-23 3:27:246 hrs ago1745378844IN
0x287176df...ee1784AdC
0.25686518 MOVR0.000417480.3125
Send Proxy OFTV2112731522025-04-23 3:09:186 hrs ago1745377758IN
0x287176df...ee1784AdC
0.25744401 MOVR0.000417480.3125
Send Proxy OFTV2112730242025-04-23 2:56:006 hrs ago1745376960IN
0x287176df...ee1784AdC
0.25768718 MOVR0.004541393.4
Send Proxy OFTV2112721012025-04-23 1:20:188 hrs ago1745371218IN
0x287176df...ee1784AdC
0.26101662 MOVR0.000417480.3125
Send Proxy OFTV2112719522025-04-23 1:05:128 hrs ago1745370312IN
0x287176df...ee1784AdC
0.25673238 MOVR0.000417480.3125
Send Proxy OFTV2112718792025-04-23 0:57:308 hrs ago1745369850IN
0x287176df...ee1784AdC
0.25615064 MOVR0.004541393.4
Send Proxy OFTV2112718362025-04-23 0:53:128 hrs ago1745369592IN
0x287176df...ee1784AdC
0.25615064 MOVR0.000417480.3125
Send Proxy OFTV2112714782025-04-23 0:16:009 hrs ago1745367360IN
0x287176df...ee1784AdC
0.25810588 MOVR0.001469271.1
Send Proxy OFTV2112711632025-04-22 23:43:309 hrs ago1745365410IN
0x287176df...ee1784AdC
0.26036064 MOVR0.00133571
Send Proxy OFTV2112711512025-04-22 23:42:129 hrs ago1745365332IN
0x287176df...ee1784AdC
0.17212724 MOVR0.000417190.3125
Send Proxy OFTV2112709962025-04-22 23:26:0610 hrs ago1745364366IN
0x287176df...ee1784AdC
0.26687852 MOVR0.001869981.4
Send Proxy OFTV2112701972025-04-22 22:03:3011 hrs ago1745359410IN
0x287176df...ee1784AdC
0.27613708 MOVR0.001469271.1
View all transactions

Latest 25 internal transactions (View All)

Advanced mode:
Parent Transaction Hash Block From To
112767922025-04-23 9:23:246 mins ago1745400204
0x287176df...ee1784AdC
0.09398541 MOVR
112765822025-04-23 9:02:0028 mins ago1745398920
0x287176df...ee1784AdC
0.09344565 MOVR
112765012025-04-23 8:53:4836 mins ago1745398428
0x287176df...ee1784AdC
0.09488641 MOVR
112758422025-04-23 7:46:241 hr ago1745394384
0x287176df...ee1784AdC
0.09331582 MOVR
112743482025-04-23 5:11:364 hrs ago1745385096
0x287176df...ee1784AdC
0.09381743 MOVR
112733862025-04-23 3:33:125 hrs ago1745379192
0x287176df...ee1784AdC
0.09297349 MOVR
112733312025-04-23 3:27:246 hrs ago1745378844
0x287176df...ee1784AdC
0.09224637 MOVR
112718362025-04-23 0:53:128 hrs ago1745369592
0x287176df...ee1784AdC
0.09184638 MOVR
112714782025-04-23 0:16:009 hrs ago1745367360
0x287176df...ee1784AdC
0.09284038 MOVR
112711632025-04-22 23:43:309 hrs ago1745365410
0x287176df...ee1784AdC
0.09526904 MOVR
112711512025-04-22 23:42:129 hrs ago1745365332
0x287176df...ee1784AdC
0.00708091 MOVR
112709962025-04-22 23:26:0610 hrs ago1745364366
0x287176df...ee1784AdC
0.1003501 MOVR
112696902025-04-22 21:11:0012 hrs ago1745356260
0x287176df...ee1784AdC
0.00963225 MOVR
109574752025-03-31 11:54:3022 days ago1743422070
0x287176df...ee1784AdC
0.08969131 MOVR
108891162025-03-26 14:25:2427 days ago1742999124
0x287176df...ee1784AdC
0.05749163 MOVR
108417822025-03-23 5:05:1231 days ago1742706312
0x287176df...ee1784AdC
0.36578339 MOVR
107058612025-03-13 12:46:4840 days ago1741870008
0x287176df...ee1784AdC
0.09710973 MOVR
104649062025-02-24 10:51:5457 days ago1740394314
0x287176df...ee1784AdC
0.00770446 MOVR
104401052025-02-22 16:52:0059 days ago1740243120
0x287176df...ee1784AdC
0.00722196 MOVR
103544662025-02-16 15:44:1265 days ago1739720652
0x287176df...ee1784AdC
0.0414635 MOVR
103008282025-02-12 20:48:1269 days ago1739393292
0x287176df...ee1784AdC
0.0073165 MOVR
100373722025-01-25 5:51:4888 days ago1737784308
0x287176df...ee1784AdC
0.01880574 MOVR
98694482025-01-13 8:31:54100 days ago1736757114
0x287176df...ee1784AdC
0.0332573 MOVR
98287252025-01-10 10:41:00102 days ago1736505660
0x287176df...ee1784AdC
0.03003599 MOVR
98120692025-01-09 6:00:42104 days ago1736402442
0x287176df...ee1784AdC
0.00429692 MOVR
View All Internal Transactions
Loading...
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
OFTWrapper

Compiler Version
v0.8.20+commit.a1b79de6

Optimization Enabled:
Yes with 800 runs

Other Settings:
default evmVersion
File 1 of 16 : OFTWrapper.sol
// SPDX-License-Identifier: MIT

pragma solidity >=0.8.0;

import "openzeppelin-contracts/security/ReentrancyGuard.sol";
import "mixins/OperatableV2.sol";
import "openzeppelin-contracts/token/ERC20/utils/SafeERC20.sol";
import "interfaces/ILzOFTV2.sol";
import "interfaces/IOFTWrapper.sol";
import "interfaces/ILzApp.sol";


contract OFTWrapper is IOFTWrapper, OperatableV2, ReentrancyGuard {
    using SafeERC20 for IERC20;

    address public feeTo;
    IAggregator public aggregator;
    ILzOFTV2 public immutable oft;
    IERC20 public immutable token;

    uint256 public defaultExchangeRate;
    QUOTE_TYPE public defaultQuoteType = QUOTE_TYPE.ORACLE;

    error InvalidQuoteType(QUOTE_TYPE);
    error ErrWithdrawFailed();
    error MessageValueIsLow(uint256);
    error InvalidAddress();

    constructor(uint256 _defaultExchangeRate, address _oft, address _aggregator, address _multisig) OperatableV2(_multisig) {
        defaultExchangeRate = _defaultExchangeRate;
        require(_oft != address(0), "OFTWrapper: invalid oft");
        oft = ILzOFTV2(_oft);
        token = IERC20(oft.token());
        require(_aggregator != address(0), "OFTWrapper: invalid aggregator");
        aggregator = IAggregator(_aggregator);
        token.safeApprove(address(oft), type(uint256).max);
        feeTo = _multisig;
    }

    function setDefaultExchangeRate(uint256 _defaultExchangeRate) external onlyOperators {
        emit LogDefaultExchangeRateChanged(defaultExchangeRate, _defaultExchangeRate);
        defaultExchangeRate = _defaultExchangeRate;
    }

    function setAggregator(IAggregator _aggregator) external onlyOperators {
        if (address(_aggregator) == address(0))
            revert InvalidAddress();
        emit LogOracleImplementationChange(aggregator, _aggregator);
        aggregator = _aggregator;
    }

    function setDefaultQuoteType(QUOTE_TYPE _quoteType) external onlyOperators {
        if (_quoteType > QUOTE_TYPE.FIXED_EXCHANGE_RATE)
            revert InvalidQuoteType(_quoteType);
        emit LogDefaultQuoteTypeChanged(defaultQuoteType, _quoteType);
        defaultQuoteType = _quoteType;
    }

    function setFeeTo(address _feeTo) external onlyOwner {
        if (_feeTo == address(0))
            revert InvalidAddress();
        emit LogFeeToChange(feeTo, _feeTo);
        feeTo = _feeTo;
    }

    function withdrawFees() external {
        uint balance = address(this).balance;
        (bool success, ) = feeTo.call{value: balance}("");
        if (!success)
            revert ErrWithdrawFailed();
        emit LogWrapperFeeWithdrawn(feeTo, balance);
    }

    

    function sendOFTV2(
        uint16 _dstChainId,
        bytes32 _toAddress,
        uint256 _amount,
        ILzCommonOFT.LzCallParams calldata _callParams
    ) external payable override nonReentrant {
        uint fee = _estimateFee();
        if (msg.value < fee)
            revert MessageValueIsLow(msg.value);
        uint256 val = msg.value - fee;
        oft.sendFrom{ value: val }(
            msg.sender,
            _dstChainId,
            _toAddress,
            _amount,
            _callParams
        );
    }

    function sendProxyOFTV2(
        uint16 _dstChainId,
        bytes32 _toAddress,
        uint256 _amount,
        ILzCommonOFT.LzCallParams calldata _callParams
    ) external payable override nonReentrant {
        uint fee = _estimateFee();
        if (msg.value < fee)
            revert MessageValueIsLow(msg.value);
        uint256 val = msg.value - fee;
        token.safeTransferFrom(msg.sender, address(this), _amount);
        oft.sendFrom{ value: val }(
            address(this),
            _dstChainId,
            _toAddress,
            _amount,
            _callParams
        );
    }

    function estimateSendFeeV2(
        uint16 _dstChainId,
        bytes32 _toAddress,
        uint256 _amount,
        bytes calldata _adapterParams
    ) external view override returns (uint nativeFee, uint zroFee) {

        (nativeFee, zroFee) = oft.estimateSendFee(_dstChainId, _toAddress, _amount, false, _adapterParams);
        nativeFee += _estimateFee();
    }

    function _estimateFee() internal view returns (uint256 fee) {
        if (defaultQuoteType == QUOTE_TYPE.ORACLE) {
            fee = (10**aggregator.decimals()) * 1e18 / uint256(aggregator.latestAnswer());
        } else {
            fee = defaultExchangeRate;
        }  
    }

    
    function lzEndpoint() external view returns (ILzEndpoint) {
        return ILzApp(address(oft)).lzEndpoint();
    }

    function minDstGasLookup(uint16 _srcChainId, uint16 _dstChainId) external view returns (uint) {
         return ILzApp(address(oft)).minDstGasLookup(_srcChainId, _dstChainId);
    }
}

File 2 of 16 : ReentrancyGuard.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.9.0) (security/ReentrancyGuard.sol)

pragma solidity ^0.8.0;

/**
 * @dev Contract module that helps prevent reentrant calls to a function.
 *
 * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier
 * available, which can be applied to functions to make sure there are no nested
 * (reentrant) calls to them.
 *
 * Note that because there is a single `nonReentrant` guard, functions marked as
 * `nonReentrant` may not call one another. This can be worked around by making
 * those functions `private`, and then adding `external` `nonReentrant` entry
 * points to them.
 *
 * TIP: If you would like to learn more about reentrancy and alternative ways
 * to protect against it, check out our blog post
 * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul].
 */
abstract contract ReentrancyGuard {
    // Booleans are more expensive than uint256 or any type that takes up a full
    // word because each write operation emits an extra SLOAD to first read the
    // slot's contents, replace the bits taken up by the boolean, and then write
    // back. This is the compiler's defense against contract upgrades and
    // pointer aliasing, and it cannot be disabled.

    // The values being non-zero value makes deployment a bit more expensive,
    // but in exchange the refund on every call to nonReentrant will be lower in
    // amount. Since refunds are capped to a percentage of the total
    // transaction's gas, it is best to keep them low in cases like this one, to
    // increase the likelihood of the full refund coming into effect.
    uint256 private constant _NOT_ENTERED = 1;
    uint256 private constant _ENTERED = 2;

    uint256 private _status;

    constructor() {
        _status = _NOT_ENTERED;
    }

    /**
     * @dev Prevents a contract from calling itself, directly or indirectly.
     * Calling a `nonReentrant` function from another `nonReentrant`
     * function is not supported. It is possible to prevent this from happening
     * by making the `nonReentrant` function external, and making it call a
     * `private` function that does the actual work.
     */
    modifier nonReentrant() {
        _nonReentrantBefore();
        _;
        _nonReentrantAfter();
    }

    function _nonReentrantBefore() private {
        // On the first call to nonReentrant, _status will be _NOT_ENTERED
        require(_status != _ENTERED, "ReentrancyGuard: reentrant call");

        // Any calls to nonReentrant after this point will fail
        _status = _ENTERED;
    }

    function _nonReentrantAfter() private {
        // By storing the original value once again, a refund is triggered (see
        // https://eips.ethereum.org/EIPS/eip-2200)
        _status = _NOT_ENTERED;
    }

    /**
     * @dev Returns true if the reentrancy guard is currently set to "entered", which indicates there is a
     * `nonReentrant` function in the call stack.
     */
    function _reentrancyGuardEntered() internal view returns (bool) {
        return _status == _ENTERED;
    }
}

File 3 of 16 : OperatableV2.sol
// SPDX-License-Identifier: MIT
pragma solidity >=0.8.0;

import "solmate/auth/Owned.sol";

/// @title OperatableV2
/// @notice OperatableV2 is a contract that allows operator management.
/// The difference with OperatableV1 apart from using solmate `Owned` vs `BoringOwnable` is that
/// the constructor is taking in the owner except of using msg.sender.
/// This allows ensuring that the owner is right one.
/// For example, when deploying from a CREATE2 factory, the msg.sender would the factory address
/// which is usually not what we want.
contract OperatableV2 is Owned {
    event OperatorChanged(address indexed, bool);
    error NotAllowedOperator();

    mapping(address => bool) public operators;

    constructor(address _owner) Owned(_owner) {
        operators[_owner] = true;
    }

    modifier onlyOperators() {
        if (!operators[msg.sender]) {
            revert NotAllowedOperator();
        }
        _;
    }

    function setOperator(address operator, bool status) external onlyOwner {
        operators[operator] = status;
        emit OperatorChanged(operator, status);
    }
}

File 4 of 16 : SafeERC20.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.9.0) (token/ERC20/utils/SafeERC20.sol)

pragma solidity ^0.8.0;

import "../IERC20.sol";
import "../extensions/IERC20Permit.sol";
import "../../../utils/Address.sol";

/**
 * @title SafeERC20
 * @dev Wrappers around ERC20 operations that throw on failure (when the token
 * contract returns false). Tokens that return no value (and instead revert or
 * throw on failure) are also supported, non-reverting calls are assumed to be
 * successful.
 * To use this library you can add a `using SafeERC20 for IERC20;` statement to your contract,
 * which allows you to call the safe operations as `token.safeTransfer(...)`, etc.
 */
library SafeERC20 {
    using Address for address;

    /**
     * @dev Transfer `value` amount of `token` from the calling contract to `to`. If `token` returns no value,
     * non-reverting calls are assumed to be successful.
     */
    function safeTransfer(IERC20 token, address to, uint256 value) internal {
        _callOptionalReturn(token, abi.encodeWithSelector(token.transfer.selector, to, value));
    }

    /**
     * @dev Transfer `value` amount of `token` from `from` to `to`, spending the approval given by `from` to the
     * calling contract. If `token` returns no value, non-reverting calls are assumed to be successful.
     */
    function safeTransferFrom(IERC20 token, address from, address to, uint256 value) internal {
        _callOptionalReturn(token, abi.encodeWithSelector(token.transferFrom.selector, from, to, value));
    }

    /**
     * @dev Deprecated. This function has issues similar to the ones found in
     * {IERC20-approve}, and its usage is discouraged.
     *
     * Whenever possible, use {safeIncreaseAllowance} and
     * {safeDecreaseAllowance} instead.
     */
    function safeApprove(IERC20 token, address spender, uint256 value) internal {
        // safeApprove should only be called when setting an initial allowance,
        // or when resetting it to zero. To increase and decrease it, use
        // 'safeIncreaseAllowance' and 'safeDecreaseAllowance'
        require(
            (value == 0) || (token.allowance(address(this), spender) == 0),
            "SafeERC20: approve from non-zero to non-zero allowance"
        );
        _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, value));
    }

    /**
     * @dev Increase the calling contract's allowance toward `spender` by `value`. If `token` returns no value,
     * non-reverting calls are assumed to be successful.
     */
    function safeIncreaseAllowance(IERC20 token, address spender, uint256 value) internal {
        uint256 oldAllowance = token.allowance(address(this), spender);
        _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, oldAllowance + value));
    }

    /**
     * @dev Decrease the calling contract's allowance toward `spender` by `value`. If `token` returns no value,
     * non-reverting calls are assumed to be successful.
     */
    function safeDecreaseAllowance(IERC20 token, address spender, uint256 value) internal {
        unchecked {
            uint256 oldAllowance = token.allowance(address(this), spender);
            require(oldAllowance >= value, "SafeERC20: decreased allowance below zero");
            _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, oldAllowance - value));
        }
    }

    /**
     * @dev Set the calling contract's allowance toward `spender` to `value`. If `token` returns no value,
     * non-reverting calls are assumed to be successful. Compatible with tokens that require the approval to be set to
     * 0 before setting it to a non-zero value.
     */
    function forceApprove(IERC20 token, address spender, uint256 value) internal {
        bytes memory approvalCall = abi.encodeWithSelector(token.approve.selector, spender, value);

        if (!_callOptionalReturnBool(token, approvalCall)) {
            _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, 0));
            _callOptionalReturn(token, approvalCall);
        }
    }

    /**
     * @dev Use a ERC-2612 signature to set the `owner` approval toward `spender` on `token`.
     * Revert on invalid signature.
     */
    function safePermit(
        IERC20Permit token,
        address owner,
        address spender,
        uint256 value,
        uint256 deadline,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) internal {
        uint256 nonceBefore = token.nonces(owner);
        token.permit(owner, spender, value, deadline, v, r, s);
        uint256 nonceAfter = token.nonces(owner);
        require(nonceAfter == nonceBefore + 1, "SafeERC20: permit did not succeed");
    }

    /**
     * @dev Imitates a Solidity high-level call (i.e. a regular function call to a contract), relaxing the requirement
     * on the return value: the return value is optional (but if data is returned, it must not be false).
     * @param token The token targeted by the call.
     * @param data The call data (encoded using abi.encode or one of its variants).
     */
    function _callOptionalReturn(IERC20 token, bytes memory data) private {
        // We need to perform a low level call here, to bypass Solidity's return data size checking mechanism, since
        // we're implementing it ourselves. We use {Address-functionCall} to perform this call, which verifies that
        // the target address contains contract code and also asserts for success in the low-level call.

        bytes memory returndata = address(token).functionCall(data, "SafeERC20: low-level call failed");
        require(returndata.length == 0 || abi.decode(returndata, (bool)), "SafeERC20: ERC20 operation did not succeed");
    }

    /**
     * @dev Imitates a Solidity high-level call (i.e. a regular function call to a contract), relaxing the requirement
     * on the return value: the return value is optional (but if data is returned, it must not be false).
     * @param token The token targeted by the call.
     * @param data The call data (encoded using abi.encode or one of its variants).
     *
     * This is a variant of {_callOptionalReturn} that silents catches all reverts and returns a bool instead.
     */
    function _callOptionalReturnBool(IERC20 token, bytes memory data) private returns (bool) {
        // We need to perform a low level call here, to bypass Solidity's return data size checking mechanism, since
        // we're implementing it ourselves. We cannot use {Address-functionCall} here since this should return false
        // and not revert is the subcall reverts.

        (bool success, bytes memory returndata) = address(token).call(data);
        return
            success && (returndata.length == 0 || abi.decode(returndata, (bool))) && Address.isContract(address(token));
    }
}

File 5 of 16 : ILzOFTV2.sol
// SPDX-License-Identifier: MIT
pragma solidity >=0.8.0;

import "interfaces/ILzCommonOFT.sol";

/**
 * @dev Interface of the IOFT core standard
 */
interface ILzOFTV2 is ILzCommonOFT {
    /**
     * @dev send `_amount` amount of token to (`_dstChainId`, `_toAddress`) from `_from`
     * `_from` the owner of token
     * `_dstChainId` the destination chain identifier
     * `_toAddress` can be any size depending on the `dstChainId`.
     * `_amount` the quantity of tokens in wei
     * `_refundAddress` the address LayerZero refunds if too much message fee is sent
     * `_zroPaymentAddress` set to address(0x0) if not paying in ZRO (LayerZero Token)
     * `_adapterParams` is a flexible bytes array to indicate messaging adapter services
     */
    function sendFrom(
        address _from,
        uint16 _dstChainId,
        bytes32 _toAddress,
        uint _amount,
        LzCallParams calldata _callParams
    ) external payable;

    function sendAndCall(
        address _from,
        uint16 _dstChainId,
        bytes32 _toAddress,
        uint _amount,
        bytes calldata _payload,
        uint64 _dstGasForCall,
        LzCallParams calldata _callParams
    ) external payable;
}

File 6 of 16 : IOFTWrapper.sol
// SPDX-License-Identifier: MIT

pragma solidity >=0.8.0;

import "interfaces/ILzCommonOFT.sol";
import "interfaces/IAggregator.sol";

interface IOFTWrapper {
    event LogWrapperFeeWithdrawn(address to, uint256 amount);
    event LogDefaultExchangeRateChanged(uint256 oldExchangeRate, uint256 newExchangeRate);
    event LogOracleImplementationChange(IAggregator indexed oldOracle, IAggregator indexed newOracle);
    event LogDefaultQuoteTypeChanged(QUOTE_TYPE oldValue, QUOTE_TYPE newValue);
    event LogFeeToChange(address indexed oldAddress, address indexed newAddress);

    enum QUOTE_TYPE {
        ORACLE,
        FIXED_EXCHANGE_RATE
    }

    function sendOFTV2(
        uint16 _dstChainId,
        bytes32 _toAddress,
        uint _amount,
        ILzCommonOFT.LzCallParams calldata _callParams
    ) external payable;

    function sendProxyOFTV2(
        uint16 _dstChainId,
        bytes32 _toAddress,
        uint _amount,
        ILzCommonOFT.LzCallParams calldata _callParams
    ) external payable;

    function estimateSendFeeV2(
        uint16 _dstChainId,
        bytes32 _toAddress,
        uint _amount,
        bytes calldata _adapterParams
    ) external view returns (uint nativeFee, uint zroFee);
}

File 7 of 16 : ILzApp.sol
// SPDX-License-Identifier: MIT
pragma solidity >=0.8.0;

import "interfaces/ILzEndpoint.sol";

interface ILzApp {
    function lzReceive(uint16 _srcChainId, bytes calldata _srcAddress, uint64 _nonce, bytes calldata _payload) external;

    function minDstGasLookup(uint16 _srcChainId, uint16 _dstChainId) external view returns (uint);

    function trustedRemoteLookup(uint16 _srcChainId) external view returns (bytes memory);

    function lzEndpoint() external view returns (ILzEndpoint);
}

File 8 of 16 : Owned.sol
// SPDX-License-Identifier: AGPL-3.0-only
pragma solidity >=0.8.0;

/// @notice Simple single owner authorization mixin.
/// @author Solmate (https://github.com/transmissions11/solmate/blob/main/src/auth/Owned.sol)
abstract contract Owned {
    /*//////////////////////////////////////////////////////////////
                                 EVENTS
    //////////////////////////////////////////////////////////////*/

    event OwnershipTransferred(address indexed user, address indexed newOwner);

    /*//////////////////////////////////////////////////////////////
                            OWNERSHIP STORAGE
    //////////////////////////////////////////////////////////////*/

    address public owner;

    modifier onlyOwner() virtual {
        require(msg.sender == owner, "UNAUTHORIZED");

        _;
    }

    /*//////////////////////////////////////////////////////////////
                               CONSTRUCTOR
    //////////////////////////////////////////////////////////////*/

    constructor(address _owner) {
        owner = _owner;

        emit OwnershipTransferred(address(0), _owner);
    }

    /*//////////////////////////////////////////////////////////////
                             OWNERSHIP LOGIC
    //////////////////////////////////////////////////////////////*/

    function transferOwnership(address newOwner) public virtual onlyOwner {
        owner = newOwner;

        emit OwnershipTransferred(msg.sender, newOwner);
    }
}

File 9 of 16 : IERC20.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.9.0) (token/ERC20/IERC20.sol)

pragma solidity ^0.8.0;

/**
 * @dev Interface of the ERC20 standard as defined in the EIP.
 */
interface IERC20 {
    /**
     * @dev Emitted when `value` tokens are moved from one account (`from`) to
     * another (`to`).
     *
     * Note that `value` may be zero.
     */
    event Transfer(address indexed from, address indexed to, uint256 value);

    /**
     * @dev Emitted when the allowance of a `spender` for an `owner` is set by
     * a call to {approve}. `value` is the new allowance.
     */
    event Approval(address indexed owner, address indexed spender, uint256 value);

    /**
     * @dev Returns the amount of tokens in existence.
     */
    function totalSupply() external view returns (uint256);

    /**
     * @dev Returns the amount of tokens owned by `account`.
     */
    function balanceOf(address account) external view returns (uint256);

    /**
     * @dev Moves `amount` tokens from the caller's account to `to`.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transfer(address to, uint256 amount) external returns (bool);

    /**
     * @dev Returns the remaining number of tokens that `spender` will be
     * allowed to spend on behalf of `owner` through {transferFrom}. This is
     * zero by default.
     *
     * This value changes when {approve} or {transferFrom} are called.
     */
    function allowance(address owner, address spender) external view returns (uint256);

    /**
     * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * IMPORTANT: Beware that changing an allowance with this method brings the risk
     * that someone may use both the old and the new allowance by unfortunate
     * transaction ordering. One possible solution to mitigate this race
     * condition is to first reduce the spender's allowance to 0 and set the
     * desired value afterwards:
     * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
     *
     * Emits an {Approval} event.
     */
    function approve(address spender, uint256 amount) external returns (bool);

    /**
     * @dev Moves `amount` tokens from `from` to `to` using the
     * allowance mechanism. `amount` is then deducted from the caller's
     * allowance.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transferFrom(address from, address to, uint256 amount) external returns (bool);
}

File 10 of 16 : IERC20Permit.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.9.0) (token/ERC20/extensions/IERC20Permit.sol)

pragma solidity ^0.8.0;

/**
 * @dev Interface of the ERC20 Permit extension allowing approvals to be made via signatures, as defined in
 * https://eips.ethereum.org/EIPS/eip-2612[EIP-2612].
 *
 * Adds the {permit} method, which can be used to change an account's ERC20 allowance (see {IERC20-allowance}) by
 * presenting a message signed by the account. By not relying on {IERC20-approve}, the token holder account doesn't
 * need to send a transaction, and thus is not required to hold Ether at all.
 */
interface IERC20Permit {
    /**
     * @dev Sets `value` as the allowance of `spender` over ``owner``'s tokens,
     * given ``owner``'s signed approval.
     *
     * IMPORTANT: The same issues {IERC20-approve} has related to transaction
     * ordering also apply here.
     *
     * Emits an {Approval} event.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     * - `deadline` must be a timestamp in the future.
     * - `v`, `r` and `s` must be a valid `secp256k1` signature from `owner`
     * over the EIP712-formatted function arguments.
     * - the signature must use ``owner``'s current nonce (see {nonces}).
     *
     * For more information on the signature format, see the
     * https://eips.ethereum.org/EIPS/eip-2612#specification[relevant EIP
     * section].
     */
    function permit(
        address owner,
        address spender,
        uint256 value,
        uint256 deadline,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external;

    /**
     * @dev Returns the current nonce for `owner`. This value must be
     * included whenever a signature is generated for {permit}.
     *
     * Every successful call to {permit} increases ``owner``'s nonce by one. This
     * prevents a signature from being used multiple times.
     */
    function nonces(address owner) external view returns (uint256);

    /**
     * @dev Returns the domain separator used in the encoding of the signature for {permit}, as defined by {EIP712}.
     */
    // solhint-disable-next-line func-name-mixedcase
    function DOMAIN_SEPARATOR() external view returns (bytes32);
}

File 11 of 16 : Address.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.9.0) (utils/Address.sol)

pragma solidity ^0.8.1;

/**
 * @dev Collection of functions related to the address type
 */
library Address {
    /**
     * @dev Returns true if `account` is a contract.
     *
     * [IMPORTANT]
     * ====
     * It is unsafe to assume that an address for which this function returns
     * false is an externally-owned account (EOA) and not a contract.
     *
     * Among others, `isContract` will return false for the following
     * types of addresses:
     *
     *  - an externally-owned account
     *  - a contract in construction
     *  - an address where a contract will be created
     *  - an address where a contract lived, but was destroyed
     *
     * Furthermore, `isContract` will also return true if the target contract within
     * the same transaction is already scheduled for destruction by `SELFDESTRUCT`,
     * which only has an effect at the end of a transaction.
     * ====
     *
     * [IMPORTANT]
     * ====
     * You shouldn't rely on `isContract` to protect against flash loan attacks!
     *
     * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets
     * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract
     * constructor.
     * ====
     */
    function isContract(address account) internal view returns (bool) {
        // This method relies on extcodesize/address.code.length, which returns 0
        // for contracts in construction, since the code is only stored at the end
        // of the constructor execution.

        return account.code.length > 0;
    }

    /**
     * @dev Replacement for Solidity's `transfer`: sends `amount` wei to
     * `recipient`, forwarding all available gas and reverting on errors.
     *
     * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost
     * of certain opcodes, possibly making contracts go over the 2300 gas limit
     * imposed by `transfer`, making them unable to receive funds via
     * `transfer`. {sendValue} removes this limitation.
     *
     * https://consensys.net/diligence/blog/2019/09/stop-using-soliditys-transfer-now/[Learn more].
     *
     * IMPORTANT: because control is transferred to `recipient`, care must be
     * taken to not create reentrancy vulnerabilities. Consider using
     * {ReentrancyGuard} or the
     * https://solidity.readthedocs.io/en/v0.8.0/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].
     */
    function sendValue(address payable recipient, uint256 amount) internal {
        require(address(this).balance >= amount, "Address: insufficient balance");

        (bool success, ) = recipient.call{value: amount}("");
        require(success, "Address: unable to send value, recipient may have reverted");
    }

    /**
     * @dev Performs a Solidity function call using a low level `call`. A
     * plain `call` is an unsafe replacement for a function call: use this
     * function instead.
     *
     * If `target` reverts with a revert reason, it is bubbled up by this
     * function (like regular Solidity function calls).
     *
     * Returns the raw returned data. To convert to the expected return value,
     * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].
     *
     * Requirements:
     *
     * - `target` must be a contract.
     * - calling `target` with `data` must not revert.
     *
     * _Available since v3.1._
     */
    function functionCall(address target, bytes memory data) internal returns (bytes memory) {
        return functionCallWithValue(target, data, 0, "Address: low-level call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with
     * `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal returns (bytes memory) {
        return functionCallWithValue(target, data, 0, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but also transferring `value` wei to `target`.
     *
     * Requirements:
     *
     * - the calling contract must have an ETH balance of at least `value`.
     * - the called Solidity function must be `payable`.
     *
     * _Available since v3.1._
     */
    function functionCallWithValue(address target, bytes memory data, uint256 value) internal returns (bytes memory) {
        return functionCallWithValue(target, data, value, "Address: low-level call with value failed");
    }

    /**
     * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but
     * with `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCallWithValue(
        address target,
        bytes memory data,
        uint256 value,
        string memory errorMessage
    ) internal returns (bytes memory) {
        require(address(this).balance >= value, "Address: insufficient balance for call");
        (bool success, bytes memory returndata) = target.call{value: value}(data);
        return verifyCallResultFromTarget(target, success, returndata, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {
        return functionStaticCall(target, data, "Address: low-level static call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal view returns (bytes memory) {
        (bool success, bytes memory returndata) = target.staticcall(data);
        return verifyCallResultFromTarget(target, success, returndata, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.4._
     */
    function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {
        return functionDelegateCall(target, data, "Address: low-level delegate call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.4._
     */
    function functionDelegateCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal returns (bytes memory) {
        (bool success, bytes memory returndata) = target.delegatecall(data);
        return verifyCallResultFromTarget(target, success, returndata, errorMessage);
    }

    /**
     * @dev Tool to verify that a low level call to smart-contract was successful, and revert (either by bubbling
     * the revert reason or using the provided one) in case of unsuccessful call or if target was not a contract.
     *
     * _Available since v4.8._
     */
    function verifyCallResultFromTarget(
        address target,
        bool success,
        bytes memory returndata,
        string memory errorMessage
    ) internal view returns (bytes memory) {
        if (success) {
            if (returndata.length == 0) {
                // only check isContract if the call was successful and the return data is empty
                // otherwise we already know that it was a contract
                require(isContract(target), "Address: call to non-contract");
            }
            return returndata;
        } else {
            _revert(returndata, errorMessage);
        }
    }

    /**
     * @dev Tool to verify that a low level call was successful, and revert if it wasn't, either by bubbling the
     * revert reason or using the provided one.
     *
     * _Available since v4.3._
     */
    function verifyCallResult(
        bool success,
        bytes memory returndata,
        string memory errorMessage
    ) internal pure returns (bytes memory) {
        if (success) {
            return returndata;
        } else {
            _revert(returndata, errorMessage);
        }
    }

    function _revert(bytes memory returndata, string memory errorMessage) private pure {
        // Look for revert reason and bubble it up if present
        if (returndata.length > 0) {
            // The easiest way to bubble the revert reason is using memory via assembly
            /// @solidity memory-safe-assembly
            assembly {
                let returndata_size := mload(returndata)
                revert(add(32, returndata), returndata_size)
            }
        } else {
            revert(errorMessage);
        }
    }
}

File 12 of 16 : ILzCommonOFT.sol
// SPDX-License-Identifier: MIT
pragma solidity >=0.8.0;

import "openzeppelin-contracts/utils/introspection/IERC165.sol";

/**
 * @dev Interface of the IOFT core standard
 */
interface ILzCommonOFT is IERC165 {
    struct LzCallParams {
        address payable refundAddress;
        address zroPaymentAddress;
        bytes adapterParams;
    }

    /**
     * @dev estimate send token `_tokenId` to (`_dstChainId`, `_toAddress`)
     * _dstChainId - L0 defined chain id to send tokens too
     * _toAddress - dynamic bytes array which contains the address to whom you are sending tokens to on the dstChain
     * _amount - amount of the tokens to transfer
     * _useZro - indicates to use zro to pay L0 fees
     * _adapterParam - flexible bytes array to indicate messaging adapter services in L0
     */
    function estimateSendFee(
        uint16 _dstChainId,
        bytes32 _toAddress,
        uint _amount,
        bool _useZro,
        bytes calldata _adapterParams
    ) external view returns (uint nativeFee, uint zroFee);

    function estimateSendAndCallFee(
        uint16 _dstChainId,
        bytes32 _toAddress,
        uint _amount,
        bytes calldata _payload,
        uint64 _dstGasForCall,
        bool _useZro,
        bytes calldata _adapterParams
    ) external view returns (uint nativeFee, uint zroFee);

    /**
     * @dev returns the circulating amount of tokens on current chain
     */
    function circulatingSupply() external view returns (uint);

    /**
     * @dev returns the address of the ERC20 token
     */
    function token() external view returns (address);
}

File 13 of 16 : IAggregator.sol
// SPDX-License-Identifier: MIT
pragma solidity >=0.8.0;

interface IAggregator {
    function decimals() external view returns (uint8);

    function latestAnswer() external view returns (int256 answer);

    function latestRoundData()
        external
        view
        returns (
            uint80 roundId,
            int256 answer,
            uint256 startedAt,
            uint256 updatedAt,
            uint80 answeredInRound
        );
}

File 14 of 16 : ILzEndpoint.sol
// SPDX-License-Identifier: MIT
pragma solidity >=0.8.0;

import "./ILzUserApplicationConfig.sol";

interface ILzEndpoint is ILzUserApplicationConfig {
    function defaultSendLibrary() external view returns (address);

    // @notice send a LayerZero message to the specified address at a LayerZero endpoint.
    // @param _dstChainId - the destination chain identifier
    // @param _destination - the address on destination chain (in bytes). address length/format may vary by chains
    // @param _payload - a custom bytes payload to send to the destination contract
    // @param _refundAddress - if the source transaction is cheaper than the amount of value passed, refund the additional amount to this address
    // @param _zroPaymentAddress - the address of the ZRO token holder who would pay for the transaction
    // @param _adapterParams - parameters for custom functionality. e.g. receive airdropped native gas from the relayer on destination
    function send(
        uint16 _dstChainId,
        bytes calldata _destination,
        bytes calldata _payload,
        address payable _refundAddress,
        address _zroPaymentAddress,
        bytes calldata _adapterParams
    ) external payable;

    // @notice used by the messaging library to publish verified payload
    // @param _srcChainId - the source chain identifier
    // @param _srcAddress - the source contract (as bytes) at the source chain
    // @param _dstAddress - the address on destination chain
    // @param _nonce - the unbound message ordering nonce
    // @param _gasLimit - the gas limit for external contract execution
    // @param _payload - verified payload to send to the destination contract
    function receivePayload(
        uint16 _srcChainId,
        bytes calldata _srcAddress,
        address _dstAddress,
        uint64 _nonce,
        uint _gasLimit,
        bytes calldata _payload
    ) external;

    // @notice get the inboundNonce of a lzApp from a source chain which could be EVM or non-EVM chain
    // @param _srcChainId - the source chain identifier
    // @param _srcAddress - the source chain contract address
    function getInboundNonce(uint16 _srcChainId, bytes calldata _srcAddress) external view returns (uint64);

    // @notice get the outboundNonce from this source chain which, consequently, is always an EVM
    // @param _srcAddress - the source chain contract address
    function getOutboundNonce(uint16 _dstChainId, address _srcAddress) external view returns (uint64);

    // @notice gets a quote in source native gas, for the amount that send() requires to pay for message delivery
    // @param _dstChainId - the destination chain identifier
    // @param _userApplication - the user app address on this EVM chain
    // @param _payload - the custom message to send over LayerZero
    // @param _payInZRO - if false, user app pays the protocol fee in native token
    // @param _adapterParam - parameters for the adapter service, e.g. send some dust native token to dstChain
    function estimateFees(
        uint16 _dstChainId,
        address _userApplication,
        bytes calldata _payload,
        bool _payInZRO,
        bytes calldata _adapterParam
    ) external view returns (uint nativeFee, uint zroFee);

    // @notice get this Endpoint's immutable source identifier
    function getChainId() external view returns (uint16);

    // @notice the interface to retry failed message on this Endpoint destination
    // @param _srcChainId - the source chain identifier
    // @param _srcAddress - the source chain contract address
    // @param _payload - the payload to be retried
    function retryPayload(uint16 _srcChainId, bytes calldata _srcAddress, bytes calldata _payload) external;

    // @notice query if any STORED payload (message blocking) at the endpoint.
    // @param _srcChainId - the source chain identifier
    // @param _srcAddress - the source chain contract address
    function hasStoredPayload(uint16 _srcChainId, bytes calldata _srcAddress) external view returns (bool);

    // @notice query if the _libraryAddress is valid for sending msgs.
    // @param _userApplication - the user app address on this EVM chain
    function getSendLibraryAddress(address _userApplication) external view returns (address);

    // @notice query if the _libraryAddress is valid for receiving msgs.
    // @param _userApplication - the user app address on this EVM chain
    function getReceiveLibraryAddress(address _userApplication) external view returns (address);

    // @notice query if the non-reentrancy guard for send() is on
    // @return true if the guard is on. false otherwise
    function isSendingPayload() external view returns (bool);

    // @notice query if the non-reentrancy guard for receive() is on
    // @return true if the guard is on. false otherwise
    function isReceivingPayload() external view returns (bool);

    // @notice get the configuration of the LayerZero messaging library of the specified version
    // @param _version - messaging library version
    // @param _chainId - the chainId for the pending config change
    // @param _userApplication - the contract address of the user application
    // @param _configType - type of configuration. every messaging library has its own convention.
    function getConfig(uint16 _version, uint16 _chainId, address _userApplication, uint _configType) external view returns (bytes memory);

    // @notice get the send() LayerZero messaging library version
    // @param _userApplication - the contract address of the user application
    function getSendVersion(address _userApplication) external view returns (uint16);

    // @notice get the lzReceive() LayerZero messaging library version
    // @param _userApplication - the contract address of the user application
    function getReceiveVersion(address _userApplication) external view returns (uint16);
}

File 15 of 16 : IERC165.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)

pragma solidity ^0.8.0;

/**
 * @dev Interface of the ERC165 standard, as defined in the
 * https://eips.ethereum.org/EIPS/eip-165[EIP].
 *
 * Implementers can declare support of contract interfaces, which can then be
 * queried by others ({ERC165Checker}).
 *
 * For an implementation, see {ERC165}.
 */
interface IERC165 {
    /**
     * @dev Returns true if this contract implements the interface defined by
     * `interfaceId`. See the corresponding
     * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]
     * to learn more about how these ids are created.
     *
     * This function call must use less than 30 000 gas.
     */
    function supportsInterface(bytes4 interfaceId) external view returns (bool);
}

File 16 of 16 : ILzUserApplicationConfig.sol
// SPDX-License-Identifier: MIT
pragma solidity >=0.5.0;

interface ILzUserApplicationConfig {
    // @notice set the configuration of the LayerZero messaging library of the specified version
    // @param _version - messaging library version
    // @param _chainId - the chainId for the pending config change
    // @param _configType - type of configuration. every messaging library has its own convention.
    // @param _config - configuration in the bytes. can encode arbitrary content.
    function setConfig(uint16 _version, uint16 _chainId, uint _configType, bytes calldata _config) external;

    // @notice set the send() LayerZero messaging library version to _version
    // @param _version - new messaging library version
    function setSendVersion(uint16 _version) external;

    // @notice set the lzReceive() LayerZero messaging library version to _version
    // @param _version - new messaging library version
    function setReceiveVersion(uint16 _version) external;

    // @notice Only when the UA needs to resume the message flow in blocking mode and clear the stored payload
    // @param _srcChainId - the chainId of the source chain
    // @param _srcAddress - the contract address of the source contract at the source chain
    function forceResumeReceive(uint16 _srcChainId, bytes calldata _srcAddress) external;
}

Settings
{
  "remappings": [
    "/=src/",
    "BoringSolidity/=lib/BoringSolidity/contracts/",
    "ExcessivelySafeCall/=lib/ExcessivelySafeCall/src/",
    "cauldrons/=src/cauldrons/",
    "ds-test/=lib/forge-std/lib/ds-test/src/",
    "forge-deploy/=lib/forge-deploy/contracts/",
    "forge-std/=lib/forge-std/src/",
    "generated/=generated/",
    "interfaces/=src/interfaces/",
    "lenses/=src/lenses/",
    "libraries/=src/libraries/",
    "mixins/=src/mixins/",
    "openzeppelin-contracts-upgradeabl/=lib/openzeppelin-contracts-upgradeable/contracts/",
    "openzeppelin-contracts/=lib/openzeppelin-contracts/contracts/",
    "oracles/=src/oracles/",
    "periphery/=src/periphery/",
    "solady/=lib/solady/src/",
    "solmate/=lib/solmate/src/",
    "strategies/=src/strategies/",
    "surl/=lib/surl/src/",
    "swappers/=src/swappers/",
    "tokens/=src/tokens/",
    "utils/=utils/"
  ],
  "optimizer": {
    "enabled": true,
    "runs": 800
  },
  "metadata": {
    "useLiteralContent": false,
    "bytecodeHash": "ipfs",
    "appendCBOR": true
  },
  "outputSelection": {
    "*": {
      "*": [
        "evm.bytecode",
        "evm.deployedBytecode",
        "devdoc",
        "userdoc",
        "metadata",
        "abi"
      ]
    }
  },
  "evmVersion": "paris",
  "libraries": {}
}

Contract Security Audit

Contract ABI

API
[{"inputs":[{"internalType":"uint256","name":"_defaultExchangeRate","type":"uint256"},{"internalType":"address","name":"_oft","type":"address"},{"internalType":"address","name":"_aggregator","type":"address"},{"internalType":"address","name":"_multisig","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[],"name":"ErrWithdrawFailed","type":"error"},{"inputs":[],"name":"InvalidAddress","type":"error"},{"inputs":[{"internalType":"enum IOFTWrapper.QUOTE_TYPE","name":"","type":"uint8"}],"name":"InvalidQuoteType","type":"error"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"MessageValueIsLow","type":"error"},{"inputs":[],"name":"NotAllowedOperator","type":"error"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"oldExchangeRate","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"newExchangeRate","type":"uint256"}],"name":"LogDefaultExchangeRateChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"enum IOFTWrapper.QUOTE_TYPE","name":"oldValue","type":"uint8"},{"indexed":false,"internalType":"enum IOFTWrapper.QUOTE_TYPE","name":"newValue","type":"uint8"}],"name":"LogDefaultQuoteTypeChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"oldAddress","type":"address"},{"indexed":true,"internalType":"address","name":"newAddress","type":"address"}],"name":"LogFeeToChange","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"contract IAggregator","name":"oldOracle","type":"address"},{"indexed":true,"internalType":"contract IAggregator","name":"newOracle","type":"address"}],"name":"LogOracleImplementationChange","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"LogWrapperFeeWithdrawn","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"","type":"address"},{"indexed":false,"internalType":"bool","name":"","type":"bool"}],"name":"OperatorChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"inputs":[],"name":"aggregator","outputs":[{"internalType":"contract IAggregator","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"defaultExchangeRate","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"defaultQuoteType","outputs":[{"internalType":"enum IOFTWrapper.QUOTE_TYPE","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint16","name":"_dstChainId","type":"uint16"},{"internalType":"bytes32","name":"_toAddress","type":"bytes32"},{"internalType":"uint256","name":"_amount","type":"uint256"},{"internalType":"bytes","name":"_adapterParams","type":"bytes"}],"name":"estimateSendFeeV2","outputs":[{"internalType":"uint256","name":"nativeFee","type":"uint256"},{"internalType":"uint256","name":"zroFee","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"feeTo","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"lzEndpoint","outputs":[{"internalType":"contract ILzEndpoint","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint16","name":"_srcChainId","type":"uint16"},{"internalType":"uint16","name":"_dstChainId","type":"uint16"}],"name":"minDstGasLookup","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"oft","outputs":[{"internalType":"contract ILzOFTV2","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"operators","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint16","name":"_dstChainId","type":"uint16"},{"internalType":"bytes32","name":"_toAddress","type":"bytes32"},{"internalType":"uint256","name":"_amount","type":"uint256"},{"components":[{"internalType":"address payable","name":"refundAddress","type":"address"},{"internalType":"address","name":"zroPaymentAddress","type":"address"},{"internalType":"bytes","name":"adapterParams","type":"bytes"}],"internalType":"struct ILzCommonOFT.LzCallParams","name":"_callParams","type":"tuple"}],"name":"sendOFTV2","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"uint16","name":"_dstChainId","type":"uint16"},{"internalType":"bytes32","name":"_toAddress","type":"bytes32"},{"internalType":"uint256","name":"_amount","type":"uint256"},{"components":[{"internalType":"address payable","name":"refundAddress","type":"address"},{"internalType":"address","name":"zroPaymentAddress","type":"address"},{"internalType":"bytes","name":"adapterParams","type":"bytes"}],"internalType":"struct ILzCommonOFT.LzCallParams","name":"_callParams","type":"tuple"}],"name":"sendProxyOFTV2","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"contract IAggregator","name":"_aggregator","type":"address"}],"name":"setAggregator","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_defaultExchangeRate","type":"uint256"}],"name":"setDefaultExchangeRate","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"enum IOFTWrapper.QUOTE_TYPE","name":"_quoteType","type":"uint8"}],"name":"setDefaultQuoteType","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_feeTo","type":"address"}],"name":"setFeeTo","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"operator","type":"address"},{"internalType":"bool","name":"status","type":"bool"}],"name":"setOperator","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"token","outputs":[{"internalType":"contract IERC20","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"withdrawFees","outputs":[],"stateMutability":"nonpayable","type":"function"}]

60c06040526006805460ff191690553480156200001b57600080fd5b5060405162001ee338038062001ee38339810160408190526200003e916200061e565b600080546001600160a01b0319166001600160a01b038316908117825560405183928392917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a3506001600160a01b039081166000908152600160208190526040909120805460ff191682179055600255600585905583166200010b5760405162461bcd60e51b815260206004820152601760248201527f4f4654577261707065723a20696e76616c6964206f667400000000000000000060448201526064015b60405180910390fd5b6001600160a01b038316608081905260408051637e062a3560e11b8152905163fc0c546a916004808201926020929091908290030181865afa15801562000156573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200017c919062000672565b6001600160a01b0390811660a0528216620001da5760405162461bcd60e51b815260206004820152601e60248201527f4f4654577261707065723a20696e76616c69642061676772656761746f720000604482015260640162000102565b600480546001600160a01b0319166001600160a01b038481169190911790915560805160a051620002109216906000196200023a565b600380546001600160a01b0319166001600160a01b0392909216919091179055506200074e915050565b801580620002b85750604051636eb1769f60e11b81523060048201526001600160a01b03838116602483015284169063dd62ed3e90604401602060405180830381865afa15801562000290573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620002b6919062000697565b155b6200032c5760405162461bcd60e51b815260206004820152603660248201527f5361666545524332303a20617070726f76652066726f6d206e6f6e2d7a65726f60448201527f20746f206e6f6e2d7a65726f20616c6c6f77616e636500000000000000000000606482015260840162000102565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b0390811663095ea7b360e01b17909152620003849185916200038916565b505050565b6040805180820190915260208082527f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c656490820152600090620003d8906001600160a01b0385169084906200045d565b9050805160001480620003fc575080806020019051810190620003fc9190620006b1565b620003845760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6044820152691bdd081cdd58d8d9595960b21b606482015260840162000102565b60606200046e848460008562000476565b949350505050565b606082471015620004d95760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f6044820152651c8818d85b1b60d21b606482015260840162000102565b600080866001600160a01b03168587604051620004f79190620006fb565b60006040518083038185875af1925050503d806000811462000536576040519150601f19603f3d011682016040523d82523d6000602084013e6200053b565b606091505b5090925090506200054f878383876200055a565b979650505050505050565b60608315620005ce578251600003620005c6576001600160a01b0385163b620005c65760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000604482015260640162000102565b50816200046e565b6200046e8383815115620005e55781518083602001fd5b8060405162461bcd60e51b815260040162000102919062000719565b80516001600160a01b03811681146200061957600080fd5b919050565b600080600080608085870312156200063557600080fd5b84519350620006476020860162000601565b9250620006576040860162000601565b9150620006676060860162000601565b905092959194509250565b6000602082840312156200068557600080fd5b620006908262000601565b9392505050565b600060208284031215620006aa57600080fd5b5051919050565b600060208284031215620006c457600080fd5b815180151581146200069057600080fd5b60005b83811015620006f2578181015183820152602001620006d8565b50506000910152565b600082516200070f818460208701620006d5565b9190910192915050565b60208152600082518060208401526200073a816040850160208701620006d5565b601f01601f19169190910160400192915050565b60805160a0516117456200079e600039600081816104190152610797015260008181610350015281816105490152818161068d015281816107d601528181610839015261098501526117456000f3fe60806040526004361061015f5760003560e01c80638cfd8f5c116100c0578063ed5a0fc011610074578063f46901ed11610059578063f46901ed146103c7578063f9120af6146103e7578063fc0c546a1461040757600080fd5b8063ed5a0fc014610387578063f2fde38b146103a757600080fd5b806390ed2083116100a557806390ed20831461031e5780639b5215f61461033e578063b353aaa71461037257600080fd5b80638cfd8f5c146102de5780638da5cb5b146102fe57600080fd5b8063476343ee11610117578063558a7297116100fc578063558a7297146102765780636ee296c91461029657806376025ec9146102cb57600080fd5b8063476343ee1461024c5780634da38ad81461026357600080fd5b806321f3c9f21161014857806321f3c9f2146101e15780632362189a14610208578063245a7bfc1461022c57600080fd5b8063017e7e581461016457806313e7c9d8146101a1575b600080fd5b34801561017057600080fd5b50600354610184906001600160a01b031681565b6040516001600160a01b0390911681526020015b60405180910390f35b3480156101ad57600080fd5b506101d16101bc366004611137565b60016020526000908152604090205460ff1681565b6040519015158152602001610198565b3480156101ed57600080fd5b506006546101fb9060ff1681565b604051610198919061118c565b34801561021457600080fd5b5061021e60055481565b604051908152602001610198565b34801561023857600080fd5b50600454610184906001600160a01b031681565b34801561025857600080fd5b5061026161043b565b005b6102616102713660046111b1565b6104fd565b34801561028257600080fd5b50610261610291366004611225565b6105e0565b3480156102a257600080fd5b506102b66102b136600461125e565b610688565b60408051928352602083019190915201610198565b6102616102d93660046111b1565b610745565b3480156102ea57600080fd5b5061021e6102f93660046112f2565b610815565b34801561030a57600080fd5b50600054610184906001600160a01b031681565b34801561032a57600080fd5b50610261610339366004611325565b6108b5565b34801561034a57600080fd5b506101847f000000000000000000000000000000000000000000000000000000000000000081565b34801561037e57600080fd5b50610184610981565b34801561039357600080fd5b506102616103a2366004611346565b610a0a565b3480156103b357600080fd5b506102616103c2366004611137565b610a7b565b3480156103d357600080fd5b506102616103e2366004611137565b610b1c565b3480156103f357600080fd5b50610261610402366004611137565b610bf5565b34801561041357600080fd5b506101847f000000000000000000000000000000000000000000000000000000000000000081565b60035460405147916000916001600160a01b039091169083908381818185875af1925050503d806000811461048c576040519150601f19603f3d011682016040523d82523d6000602084013e610491565b606091505b50509050806104b35760405163f5ef1ce360e01b815260040160405180910390fd5b600354604080516001600160a01b039092168252602082018490527febe72af9d0a9f9afca2ea0bada9230f49d3c9e86f4948f37097d108a49363d53910160405180910390a15050565b610505610cb5565b600061050f610d0c565b9050803410156105395760405163b621805960e01b81523460048201526024015b60405180910390fd5b60006105458234611375565b90507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663695ef6bf8233898989896040518763ffffffff1660e01b815260040161059c9594939291906113b1565b6000604051808303818588803b1580156105b557600080fd5b505af11580156105c9573d6000803e3d6000fd5b505050505050506105da6001600255565b50505050565b6000546001600160a01b031633146106295760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610530565b6001600160a01b038216600081815260016020908152604091829020805460ff191685151590811790915591519182527f193de8d500b5cb7b720089b258a39e9c1d0b840019a73ae7c51c3f9101732b02910160405180910390a25050565b6000807f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663365260b4888888600089896040518763ffffffff1660e01b81526004016106e29695949392919061146a565b6040805180830381865afa1580156106fe573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061072291906114a8565b909250905061072f610d0c565b61073990836114cc565b91509550959350505050565b61074d610cb5565b6000610757610d0c565b90508034101561077c5760405163b621805960e01b8152346004820152602401610530565b60006107888234611375565b90506107bf6001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016333087610e2f565b60405163695ef6bf60e01b81526001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000169063695ef6bf90839061059c9030908b908b908b908b906004016113b1565b60405163233f63d760e21b815261ffff8084166004830152821660248201526000907f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031690638cfd8f5c90604401602060405180830381865afa158015610888573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108ac91906114df565b90505b92915050565b3360009081526001602052604090205460ff166108e55760405163de19c8b360e01b815260040160405180910390fd5b60018160018111156108f9576108f9611154565b111561091a578060405163d05ccdf360e01b8152600401610530919061118c565b6006546040517f80e60928263e6642de6e8a1117b4f00062107c445212b88f6a02187940eccf2c916109539160ff9091169084906114f8565b60405180910390a16006805482919060ff19166001838181111561097957610979611154565b021790555050565b60007f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663b353aaa76040518163ffffffff1660e01b8152600401602060405180830381865afa1580156109e1573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a059190611513565b905090565b3360009081526001602052604090205460ff16610a3a5760405163de19c8b360e01b815260040160405180910390fd5b60055460408051918252602082018390527f4c0bffc5595fd0c1705c52132244fdac73f66274c586f059483928f66e7b6d98910160405180910390a1600555565b6000546001600160a01b03163314610ac45760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610530565b6000805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0383169081178255604051909133917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a350565b6000546001600160a01b03163314610b655760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610530565b6001600160a01b038116610b8c5760405163e6c4247b60e01b815260040160405180910390fd5b6003546040516001600160a01b038084169216907fbcf71d3ed47385ef899b4ae7d10b0da92fce93b66f947859b6b12c39faa6abba90600090a36003805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b3360009081526001602052604090205460ff16610c255760405163de19c8b360e01b815260040160405180910390fd5b6001600160a01b038116610c4c5760405163e6c4247b60e01b815260040160405180910390fd5b6004546040516001600160a01b038084169216907f8e0352ee1de57032a7c8ddf4cb1daa3ff929d0a8534e42a124811b2fa033cccd90600090a36004805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b6002805403610d065760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c006044820152606401610530565b60028055565b60008060065460ff166001811115610d2657610d26611154565b03610e285760048054604080516350d25bcd60e01b815290516001600160a01b03909216926350d25bcd9282820192602092908290030181865afa158015610d72573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610d9691906114df565b600480546040805163313ce56760e01b815290516001600160a01b039092169263313ce5679282820192602092908290030181865afa158015610ddd573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e019190611530565b610e0c90600a611637565b610e1e90670de0b6b3a7640000611646565b610a05919061165d565b5060055490565b604080516001600160a01b038581166024830152848116604483015260648083018590528351808403909101815260849092018352602080830180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff166323b872dd60e01b17905283518085019094528084527f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564908401526105da92879291600091610edc918516908490610f74565b9050805160001480610efd575080806020019051810190610efd919061167f565b610f6f5760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e60448201527f6f742073756363656564000000000000000000000000000000000000000000006064820152608401610530565b505050565b6060610f838484600085610f8d565b90505b9392505050565b6060824710156110055760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f60448201527f722063616c6c00000000000000000000000000000000000000000000000000006064820152608401610530565b600080866001600160a01b0316858760405161102191906116c0565b60006040518083038185875af1925050503d806000811461105e576040519150601f19603f3d011682016040523d82523d6000602084013e611063565b606091505b509150915061107487838387611081565b925050505b949350505050565b606083156110f05782516000036110e9576001600160a01b0385163b6110e95760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610530565b5081611079565b61107983838151156111055781518083602001fd5b8060405162461bcd60e51b815260040161053091906116dc565b6001600160a01b038116811461113457600080fd5b50565b60006020828403121561114957600080fd5b8135610f868161111f565b634e487b7160e01b600052602160045260246000fd5b6002811061118857634e487b7160e01b600052602160045260246000fd5b9052565b602081016108af828461116a565b803561ffff811681146111ac57600080fd5b919050565b600080600080608085870312156111c757600080fd5b6111d08561119a565b93506020850135925060408501359150606085013567ffffffffffffffff8111156111fa57600080fd5b85016060818803121561120c57600080fd5b939692955090935050565b801515811461113457600080fd5b6000806040838503121561123857600080fd5b82356112438161111f565b9150602083013561125381611217565b809150509250929050565b60008060008060006080868803121561127657600080fd5b61127f8661119a565b94506020860135935060408601359250606086013567ffffffffffffffff808211156112aa57600080fd5b818801915088601f8301126112be57600080fd5b8135818111156112cd57600080fd5b8960208285010111156112df57600080fd5b9699959850939650602001949392505050565b6000806040838503121561130557600080fd5b61130e8361119a565b915061131c6020840161119a565b90509250929050565b60006020828403121561133757600080fd5b813560028110610f8657600080fd5b60006020828403121561135857600080fd5b5035919050565b634e487b7160e01b600052601160045260246000fd5b818103818111156108af576108af61135f565b81835281816020850137506000828201602090810191909152601f909101601f19169091010190565b60006001600160a01b03808816835261ffff8716602084015285604084015284606084015260a0608084015283356113e88161111f565b811660a084015260208401356113fd8161111f565b1660c0830152604083013536849003601e1901811261141b57600080fd5b830160208101903567ffffffffffffffff81111561143857600080fd5b80360382131561144757600080fd5b606060e085015261145d61010085018284611388565b9998505050505050505050565b61ffff87168152856020820152846040820152831515606082015260a06080820152600061149c60a083018486611388565b98975050505050505050565b600080604083850312156114bb57600080fd5b505080516020909101519092909150565b808201808211156108af576108af61135f565b6000602082840312156114f157600080fd5b5051919050565b60408101611506828561116a565b610f86602083018461116a565b60006020828403121561152557600080fd5b8151610f868161111f565b60006020828403121561154257600080fd5b815160ff81168114610f8657600080fd5b600181815b8085111561158e5781600019048211156115745761157461135f565b8085161561158157918102915b93841c9390800290611558565b509250929050565b6000826115a5575060016108af565b816115b2575060006108af565b81600181146115c857600281146115d2576115ee565b60019150506108af565b60ff8411156115e3576115e361135f565b50506001821b6108af565b5060208310610133831016604e8410600b8410161715611611575081810a6108af565b61161b8383611553565b806000190482111561162f5761162f61135f565b029392505050565b60006108ac60ff841683611596565b80820281158282048414176108af576108af61135f565b60008261167a57634e487b7160e01b600052601260045260246000fd5b500490565b60006020828403121561169157600080fd5b8151610f8681611217565b60005b838110156116b757818101518382015260200161169f565b50506000910152565b600082516116d281846020870161169c565b9190910192915050565b60208152600082518060208401526116fb81604085016020870161169c565b601f01601f1916919091016040019291505056fea2646970667358221220033825713a4a6533dd80b32604dbbfeb95e0c4c4c593c23e4b7b1421806a790d64736f6c6343000814003300000000000000000000000000000000000000000000000002e213e812ac8340000000000000000000000000ef2dbdfec54c466f7ff92c9c5c75abb6794f01950000000000000000000000003f8bfbdc1e79777511c00ad8591cef888c2113c1000000000000000000000000fc88aa661c44b4ede197644ba971764ac59afa62

Deployed Bytecode

0x60806040526004361061015f5760003560e01c80638cfd8f5c116100c0578063ed5a0fc011610074578063f46901ed11610059578063f46901ed146103c7578063f9120af6146103e7578063fc0c546a1461040757600080fd5b8063ed5a0fc014610387578063f2fde38b146103a757600080fd5b806390ed2083116100a557806390ed20831461031e5780639b5215f61461033e578063b353aaa71461037257600080fd5b80638cfd8f5c146102de5780638da5cb5b146102fe57600080fd5b8063476343ee11610117578063558a7297116100fc578063558a7297146102765780636ee296c91461029657806376025ec9146102cb57600080fd5b8063476343ee1461024c5780634da38ad81461026357600080fd5b806321f3c9f21161014857806321f3c9f2146101e15780632362189a14610208578063245a7bfc1461022c57600080fd5b8063017e7e581461016457806313e7c9d8146101a1575b600080fd5b34801561017057600080fd5b50600354610184906001600160a01b031681565b6040516001600160a01b0390911681526020015b60405180910390f35b3480156101ad57600080fd5b506101d16101bc366004611137565b60016020526000908152604090205460ff1681565b6040519015158152602001610198565b3480156101ed57600080fd5b506006546101fb9060ff1681565b604051610198919061118c565b34801561021457600080fd5b5061021e60055481565b604051908152602001610198565b34801561023857600080fd5b50600454610184906001600160a01b031681565b34801561025857600080fd5b5061026161043b565b005b6102616102713660046111b1565b6104fd565b34801561028257600080fd5b50610261610291366004611225565b6105e0565b3480156102a257600080fd5b506102b66102b136600461125e565b610688565b60408051928352602083019190915201610198565b6102616102d93660046111b1565b610745565b3480156102ea57600080fd5b5061021e6102f93660046112f2565b610815565b34801561030a57600080fd5b50600054610184906001600160a01b031681565b34801561032a57600080fd5b50610261610339366004611325565b6108b5565b34801561034a57600080fd5b506101847f000000000000000000000000ef2dbdfec54c466f7ff92c9c5c75abb6794f019581565b34801561037e57600080fd5b50610184610981565b34801561039357600080fd5b506102616103a2366004611346565b610a0a565b3480156103b357600080fd5b506102616103c2366004611137565b610a7b565b3480156103d357600080fd5b506102616103e2366004611137565b610b1c565b3480156103f357600080fd5b50610261610402366004611137565b610bf5565b34801561041357600080fd5b506101847f0000000000000000000000000cae51e1032e8461f4806e26332c030e34de3adb81565b60035460405147916000916001600160a01b039091169083908381818185875af1925050503d806000811461048c576040519150601f19603f3d011682016040523d82523d6000602084013e610491565b606091505b50509050806104b35760405163f5ef1ce360e01b815260040160405180910390fd5b600354604080516001600160a01b039092168252602082018490527febe72af9d0a9f9afca2ea0bada9230f49d3c9e86f4948f37097d108a49363d53910160405180910390a15050565b610505610cb5565b600061050f610d0c565b9050803410156105395760405163b621805960e01b81523460048201526024015b60405180910390fd5b60006105458234611375565b90507f000000000000000000000000ef2dbdfec54c466f7ff92c9c5c75abb6794f01956001600160a01b031663695ef6bf8233898989896040518763ffffffff1660e01b815260040161059c9594939291906113b1565b6000604051808303818588803b1580156105b557600080fd5b505af11580156105c9573d6000803e3d6000fd5b505050505050506105da6001600255565b50505050565b6000546001600160a01b031633146106295760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610530565b6001600160a01b038216600081815260016020908152604091829020805460ff191685151590811790915591519182527f193de8d500b5cb7b720089b258a39e9c1d0b840019a73ae7c51c3f9101732b02910160405180910390a25050565b6000807f000000000000000000000000ef2dbdfec54c466f7ff92c9c5c75abb6794f01956001600160a01b031663365260b4888888600089896040518763ffffffff1660e01b81526004016106e29695949392919061146a565b6040805180830381865afa1580156106fe573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061072291906114a8565b909250905061072f610d0c565b61073990836114cc565b91509550959350505050565b61074d610cb5565b6000610757610d0c565b90508034101561077c5760405163b621805960e01b8152346004820152602401610530565b60006107888234611375565b90506107bf6001600160a01b037f0000000000000000000000000cae51e1032e8461f4806e26332c030e34de3adb16333087610e2f565b60405163695ef6bf60e01b81526001600160a01b037f000000000000000000000000ef2dbdfec54c466f7ff92c9c5c75abb6794f0195169063695ef6bf90839061059c9030908b908b908b908b906004016113b1565b60405163233f63d760e21b815261ffff8084166004830152821660248201526000907f000000000000000000000000ef2dbdfec54c466f7ff92c9c5c75abb6794f01956001600160a01b031690638cfd8f5c90604401602060405180830381865afa158015610888573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108ac91906114df565b90505b92915050565b3360009081526001602052604090205460ff166108e55760405163de19c8b360e01b815260040160405180910390fd5b60018160018111156108f9576108f9611154565b111561091a578060405163d05ccdf360e01b8152600401610530919061118c565b6006546040517f80e60928263e6642de6e8a1117b4f00062107c445212b88f6a02187940eccf2c916109539160ff9091169084906114f8565b60405180910390a16006805482919060ff19166001838181111561097957610979611154565b021790555050565b60007f000000000000000000000000ef2dbdfec54c466f7ff92c9c5c75abb6794f01956001600160a01b031663b353aaa76040518163ffffffff1660e01b8152600401602060405180830381865afa1580156109e1573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a059190611513565b905090565b3360009081526001602052604090205460ff16610a3a5760405163de19c8b360e01b815260040160405180910390fd5b60055460408051918252602082018390527f4c0bffc5595fd0c1705c52132244fdac73f66274c586f059483928f66e7b6d98910160405180910390a1600555565b6000546001600160a01b03163314610ac45760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610530565b6000805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0383169081178255604051909133917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a350565b6000546001600160a01b03163314610b655760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610530565b6001600160a01b038116610b8c5760405163e6c4247b60e01b815260040160405180910390fd5b6003546040516001600160a01b038084169216907fbcf71d3ed47385ef899b4ae7d10b0da92fce93b66f947859b6b12c39faa6abba90600090a36003805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b3360009081526001602052604090205460ff16610c255760405163de19c8b360e01b815260040160405180910390fd5b6001600160a01b038116610c4c5760405163e6c4247b60e01b815260040160405180910390fd5b6004546040516001600160a01b038084169216907f8e0352ee1de57032a7c8ddf4cb1daa3ff929d0a8534e42a124811b2fa033cccd90600090a36004805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b6002805403610d065760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c006044820152606401610530565b60028055565b60008060065460ff166001811115610d2657610d26611154565b03610e285760048054604080516350d25bcd60e01b815290516001600160a01b03909216926350d25bcd9282820192602092908290030181865afa158015610d72573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610d9691906114df565b600480546040805163313ce56760e01b815290516001600160a01b039092169263313ce5679282820192602092908290030181865afa158015610ddd573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e019190611530565b610e0c90600a611637565b610e1e90670de0b6b3a7640000611646565b610a05919061165d565b5060055490565b604080516001600160a01b038581166024830152848116604483015260648083018590528351808403909101815260849092018352602080830180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff166323b872dd60e01b17905283518085019094528084527f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564908401526105da92879291600091610edc918516908490610f74565b9050805160001480610efd575080806020019051810190610efd919061167f565b610f6f5760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e60448201527f6f742073756363656564000000000000000000000000000000000000000000006064820152608401610530565b505050565b6060610f838484600085610f8d565b90505b9392505050565b6060824710156110055760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f60448201527f722063616c6c00000000000000000000000000000000000000000000000000006064820152608401610530565b600080866001600160a01b0316858760405161102191906116c0565b60006040518083038185875af1925050503d806000811461105e576040519150601f19603f3d011682016040523d82523d6000602084013e611063565b606091505b509150915061107487838387611081565b925050505b949350505050565b606083156110f05782516000036110e9576001600160a01b0385163b6110e95760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610530565b5081611079565b61107983838151156111055781518083602001fd5b8060405162461bcd60e51b815260040161053091906116dc565b6001600160a01b038116811461113457600080fd5b50565b60006020828403121561114957600080fd5b8135610f868161111f565b634e487b7160e01b600052602160045260246000fd5b6002811061118857634e487b7160e01b600052602160045260246000fd5b9052565b602081016108af828461116a565b803561ffff811681146111ac57600080fd5b919050565b600080600080608085870312156111c757600080fd5b6111d08561119a565b93506020850135925060408501359150606085013567ffffffffffffffff8111156111fa57600080fd5b85016060818803121561120c57600080fd5b939692955090935050565b801515811461113457600080fd5b6000806040838503121561123857600080fd5b82356112438161111f565b9150602083013561125381611217565b809150509250929050565b60008060008060006080868803121561127657600080fd5b61127f8661119a565b94506020860135935060408601359250606086013567ffffffffffffffff808211156112aa57600080fd5b818801915088601f8301126112be57600080fd5b8135818111156112cd57600080fd5b8960208285010111156112df57600080fd5b9699959850939650602001949392505050565b6000806040838503121561130557600080fd5b61130e8361119a565b915061131c6020840161119a565b90509250929050565b60006020828403121561133757600080fd5b813560028110610f8657600080fd5b60006020828403121561135857600080fd5b5035919050565b634e487b7160e01b600052601160045260246000fd5b818103818111156108af576108af61135f565b81835281816020850137506000828201602090810191909152601f909101601f19169091010190565b60006001600160a01b03808816835261ffff8716602084015285604084015284606084015260a0608084015283356113e88161111f565b811660a084015260208401356113fd8161111f565b1660c0830152604083013536849003601e1901811261141b57600080fd5b830160208101903567ffffffffffffffff81111561143857600080fd5b80360382131561144757600080fd5b606060e085015261145d61010085018284611388565b9998505050505050505050565b61ffff87168152856020820152846040820152831515606082015260a06080820152600061149c60a083018486611388565b98975050505050505050565b600080604083850312156114bb57600080fd5b505080516020909101519092909150565b808201808211156108af576108af61135f565b6000602082840312156114f157600080fd5b5051919050565b60408101611506828561116a565b610f86602083018461116a565b60006020828403121561152557600080fd5b8151610f868161111f565b60006020828403121561154257600080fd5b815160ff81168114610f8657600080fd5b600181815b8085111561158e5781600019048211156115745761157461135f565b8085161561158157918102915b93841c9390800290611558565b509250929050565b6000826115a5575060016108af565b816115b2575060006108af565b81600181146115c857600281146115d2576115ee565b60019150506108af565b60ff8411156115e3576115e361135f565b50506001821b6108af565b5060208310610133831016604e8410600b8410161715611611575081810a6108af565b61161b8383611553565b806000190482111561162f5761162f61135f565b029392505050565b60006108ac60ff841683611596565b80820281158282048414176108af576108af61135f565b60008261167a57634e487b7160e01b600052601260045260246000fd5b500490565b60006020828403121561169157600080fd5b8151610f8681611217565b60005b838110156116b757818101518382015260200161169f565b50506000910152565b600082516116d281846020870161169c565b9190910192915050565b60208152600082518060208401526116fb81604085016020870161169c565b601f01601f1916919091016040019291505056fea2646970667358221220033825713a4a6533dd80b32604dbbfeb95e0c4c4c593c23e4b7b1421806a790d64736f6c63430008140033

Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)

00000000000000000000000000000000000000000000000002e213e812ac8340000000000000000000000000ef2dbdfec54c466f7ff92c9c5c75abb6794f01950000000000000000000000003f8bfbdc1e79777511c00ad8591cef888c2113c1000000000000000000000000fc88aa661c44b4ede197644ba971764ac59afa62

-----Decoded View---------------
Arg [0] : _defaultExchangeRate (uint256): 207750420279100224
Arg [1] : _oft (address): 0xeF2dBDfeC54c466F7Ff92C9c5c75aBB6794f0195
Arg [2] : _aggregator (address): 0x3f8BFbDc1e79777511c00Ad8591cef888C2113C1
Arg [3] : _multisig (address): 0xfc88aa661C44B4EdE197644ba971764AC59AFa62

-----Encoded View---------------
4 Constructor Arguments found :
Arg [0] : 00000000000000000000000000000000000000000000000002e213e812ac8340
Arg [1] : 000000000000000000000000ef2dbdfec54c466f7ff92c9c5c75abb6794f0195
Arg [2] : 0000000000000000000000003f8bfbdc1e79777511c00ad8591cef888c2113c1
Arg [3] : 000000000000000000000000fc88aa661c44b4ede197644ba971764ac59afa62


Block Transaction Gas Used Reward
view all blocks collator

Block Uncle Number Difficulty Gas Used Reward
View All Uncles
Loading...
Loading
Loading...
Loading
Loading...
Loading

Validator Index Block Amount
View All Withdrawals

Transaction Hash Block Value Eth2 PubKey Valid
View All Deposits
[ Download: CSV Export  ]
[ Download: CSV Export  ]

A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.