MOVR Price: $2.31 (+0.11%)

Contract

0x287176dfBEC7E8cee0f876FC7B52960ee1784AdC

Overview

MOVR Balance

Moonriver Chain LogoMoonriver Chain LogoMoonriver Chain Logo49.25020712397546383 MOVR

MOVR Value

$113.81 (@ $2.31/MOVR)

Token Holdings

More Info

Private Name Tags

Transaction Hash
Block
From
To
Send Proxy OFTV2146222712026-01-06 11:29:4818 days ago1767698988IN
0x287176df...ee1784AdC
0.38127806 MOVR0.004406893.2995
Send Proxy OFTV2145968512026-01-04 12:16:1820 days ago1767528978IN
0x287176df...ee1784AdC
0.38450746 MOVR0.004406893.2995
Send Proxy OFTV2145449552025-12-31 12:15:0624 days ago1767183306IN
0x287176df...ee1784AdC
0.4228345 MOVR0.004406893.2995
Send Proxy OFTV2145339652025-12-30 15:50:5424 days ago1767109854IN
0x287176df...ee1784AdC
0.42513056 MOVR0.004406893.2995
Send Proxy OFTV2145221412025-12-29 17:59:5425 days ago1767031194IN
0x287176df...ee1784AdC
0.42385478 MOVR0.004406893.2995
Send Proxy OFTV2145198152025-12-29 13:40:1225 days ago1767015612IN
0x287176df...ee1784AdC
0.42758747 MOVR0.004406893.2995
Send Proxy OFTV2145192202025-12-29 12:33:1826 days ago1767011598IN
0x287176df...ee1784AdC
0.42849804 MOVR0.004406893.2995
Send Proxy OFTV2145185562025-12-29 11:18:1826 days ago1767007098IN
0x287176df...ee1784AdC
0.42001232 MOVR0.004406893.2995
Send Proxy OFTV2145073542025-12-28 14:43:3626 days ago1766933016IN
0x287176df...ee1784AdC
0.40901564 MOVR0.004406893.2995
Send Proxy OFTV2145069422025-12-28 13:58:0626 days ago1766930286IN
0x287176df...ee1784AdC
0.40859786 MOVR0.004406893.2995
Send Proxy OFTV2145065182025-12-28 13:11:4826 days ago1766927508IN
0x287176df...ee1784AdC
0.40808804 MOVR0.004406893.2995
Send Proxy OFTV2144146572025-12-21 11:12:4234 days ago1766315562IN
0x287176df...ee1784AdC
0.41335011 MOVR0.004406893.2995
Send Proxy OFTV2143647172025-12-17 14:41:3037 days ago1765982490IN
0x287176df...ee1784AdC
0.52576861 MOVR0.000417380.3125
Send Proxy OFTV2143646672025-12-17 14:35:3637 days ago1765982136IN
0x287176df...ee1784AdC
0.52255101 MOVR0.000417380.3125
Send Proxy OFTV2143646452025-12-17 14:33:0637 days ago1765981986IN
0x287176df...ee1784AdC
0.52255101 MOVR0.000417380.3125
Send Proxy OFTV2143646392025-12-17 14:32:3037 days ago1765981950IN
0x287176df...ee1784AdC
0.52255101 MOVR0.0000980.3125
Send Proxy OFTV2143646042025-12-17 14:28:2437 days ago1765981704IN
0x287176df...ee1784AdC
0.52267558 MOVR0.000417380.3125
Send Proxy OFTV2143645572025-12-17 14:23:1237 days ago1765981392IN
0x287176df...ee1784AdC
0.52139628 MOVR0.000417380.3125
Send Proxy OFTV2138810252025-11-10 11:30:3675 days ago1762774236IN
0x287176df...ee1784AdC
0.27379682 MOVR0.004406893.2995
Send Proxy OFTV2137865792025-11-03 8:02:3682 days ago1762156956IN
0x287176df...ee1784AdC
0.33006614 MOVR0.004406893.2995
Send Proxy OFTV2137850942025-11-03 5:20:4282 days ago1762147242IN
0x287176df...ee1784AdC
0.47095778 MOVR0.004409953.2995
Send Proxy OFTV2136210352025-10-21 16:55:5494 days ago1761065754IN
0x287176df...ee1784AdC
0.26673664 MOVR0.004540253.4
Send Proxy OFTV2130113192025-09-04 8:57:30142 days ago1756976250IN
0x287176df...ee1784AdC
0.23395553 MOVR0.0046773.5
Send Proxy OFTV2129489432025-08-30 9:25:54147 days ago1756545954IN
0x287176df...ee1784AdC
0.20900364 MOVR0.000417670.3125
Send Proxy OFTV2128827242025-08-25 0:15:00152 days ago1756080900IN
0x287176df...ee1784AdC
0.23108674 MOVR0.004543373.4
View all transactions

Latest 25 internal transactions (View All)

Parent Transaction Hash Block From To
146222712026-01-06 11:29:4818 days ago1767698988
0x287176df...ee1784AdC
0.01680253 MOVR
145968512026-01-04 12:16:1820 days ago1767528978
0x287176df...ee1784AdC
0.01645975 MOVR
145449552025-12-31 12:15:0624 days ago1767183306
0x287176df...ee1784AdC
0.01725837 MOVR
145339652025-12-30 15:50:5424 days ago1767109854
0x287176df...ee1784AdC
0.01771098 MOVR
145221412025-12-29 17:59:5425 days ago1767031194
0x287176df...ee1784AdC
0.01728626 MOVR
145198152025-12-29 13:40:1225 days ago1767015612
0x287176df...ee1784AdC
0.01725204 MOVR
145192202025-12-29 12:33:1826 days ago1767011598
0x287176df...ee1784AdC
0.01870228 MOVR
145185562025-12-29 11:18:1826 days ago1767007098
0x287176df...ee1784AdC
0.01597331 MOVR
145073542025-12-28 14:43:3626 days ago1766933016
0x287176df...ee1784AdC
0.01708394 MOVR
145069422025-12-28 13:58:0626 days ago1766930286
0x287176df...ee1784AdC
0.01595034 MOVR
145065182025-12-28 13:11:4826 days ago1766927508
0x287176df...ee1784AdC
0.01601544 MOVR
144146572025-12-21 11:12:4234 days ago1766315562
0x287176df...ee1784AdC
0.01731149 MOVR
143647172025-12-17 14:41:3037 days ago1765982490
0x287176df...ee1784AdC
0.12543478 MOVR
143646672025-12-17 14:35:3637 days ago1765982136
0x287176df...ee1784AdC
0.12530234 MOVR
143646452025-12-17 14:33:0637 days ago1765981986
0x287176df...ee1784AdC
0.12530234 MOVR
143646042025-12-17 14:28:2437 days ago1765981704
0x287176df...ee1784AdC
0.12542691 MOVR
143645572025-12-17 14:23:1237 days ago1765981392
0x287176df...ee1784AdC
0.12541424 MOVR
137850942025-11-03 5:20:4282 days ago1762147242
0x287176df...ee1784AdC
0.15752938 MOVR
136210352025-10-21 16:55:5494 days ago1761065754
0x287176df...ee1784AdC
0.01882421 MOVR
130113192025-09-04 8:57:30142 days ago1756976250
0x287176df...ee1784AdC
0.05947375 MOVR
128826422025-08-25 0:04:42152 days ago1756080282
0x287176df...ee1784AdC
0.08062688 MOVR
128793812025-08-24 17:27:42152 days ago1756056462
0x287176df...ee1784AdC
0.08508902 MOVR
128793352025-08-24 17:21:12152 days ago1756056072
0x287176df...ee1784AdC
0.08373357 MOVR
128755242025-08-24 9:28:48153 days ago1756027728
0x287176df...ee1784AdC
0.08101198 MOVR
128641642025-08-23 10:30:12154 days ago1755945012
0x287176df...ee1784AdC
0.082238 MOVR
View All Internal Transactions
Cross-Chain 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
// 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);
    }
}

// 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;
    }
}

// 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);
    }
}

// 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));
    }
}

// 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;
}

// 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);
}

// 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);
}

// 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);
    }
}

// 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);
}

// 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);
}

// 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);
        }
    }
}

// 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);
}

// 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
        );
}

// 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);
}

// 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);
}

// 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
0x287176dfBEC7E8cee0f876FC7B52960ee1784AdC
Loading...
Loading
[ 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.