ETH Price: $2,963.01 (-1.65%)
Gas: 2 Gwei

Contract

0x287176dfBEC7E8cee0f876FC7B52960ee1784AdC
 

Overview

ETH Balance

0.014802743704044057 ETH

Eth Value

$43.86 (@ $2,963.01/ETH)

Token Holdings

Transaction Hash
Method
Block
From
To
Value
Send Proxy OFTV2202442252024-07-06 1:35:4737 hrs ago1720229747IN
0x287176df...ee1784AdC
0.00063307 ETH0.000601292.15191321
Send Proxy OFTV2202436262024-07-05 23:35:3539 hrs ago1720222535IN
0x287176df...ee1784AdC
0.00078663 ETH0.000622.20011277
Send Proxy OFTV2202400362024-07-05 11:34:112 days ago1720179251IN
0x287176df...ee1784AdC
0.00063868 ETH0.002046977.2299826
Send Proxy OFTV2202343802024-07-04 16:36:112 days ago1720110971IN
0x287176df...ee1784AdC
0.00061898 ETH0.0036185712.87129548
Send Proxy OFTV2202343772024-07-04 16:35:352 days ago1720110935IN
0x287176df...ee1784AdC
0.00061312 ETH0.0035649712.59077599
Send Proxy OFTV2202328392024-07-04 11:25:473 days ago1720092347IN
0x287176df...ee1784AdC
0.00058378 ETH0.002518928.96061217
Send Proxy OFTV2202322592024-07-04 9:29:113 days ago1720085351IN
0x287176df...ee1784AdC
0.00067549 ETH0.002673799.51072719
Send Proxy OFTV2202319692024-07-04 8:30:593 days ago1720081859IN
0x287176df...ee1784AdC
0.000581 ETH0.002032997.23169618
Send Proxy OFTV2202189982024-07-02 13:01:475 days ago1719925307IN
0x287176df...ee1784AdC
0.00063598 ETH0.002492768.70757661
Send Proxy OFTV2202188632024-07-02 12:34:355 days ago1719923675IN
0x287176df...ee1784AdC
0.0006362 ETH0.002207637.71158258
Send Proxy OFTV2202182772024-07-02 10:36:355 days ago1719916595IN
0x287176df...ee1784AdC
0.00057833 ETH0.001575335.50286175
Send Proxy OFTV2202162892024-07-02 3:56:355 days ago1719892595IN
0x287176df...ee1784AdC
0.0005545 ETH0.001055513.7543322
Send Proxy OFTV2202143122024-07-01 21:19:115 days ago1719868751IN
0x287176df...ee1784AdC
0.00064063 ETH0.001137483.97388561
Send Proxy OFTV2202140752024-07-01 20:31:475 days ago1719865907IN
0x287176df...ee1784AdC
0.00064046 ETH0.0031401610.96906135
Send Proxy OFTV2202067022024-06-30 19:50:236 days ago1719777023IN
0x287176df...ee1784AdC
0.00055788 ETH0.001038583.69409776
Send Proxy OFTV2202059412024-06-30 17:17:236 days ago1719767843IN
0x287176df...ee1784AdC
0.00056082 ETH0.000833562.94419717
Send Proxy OFTV2202039362024-06-30 10:34:237 days ago1719743663IN
0x287176df...ee1784AdC
0.00056046 ETH0.000643412.28853966
Send Proxy OFTV2201967822024-06-29 10:35:238 days ago1719657323IN
0x287176df...ee1784AdC
0.00058718 ETH0.001060353.70397034
Send Proxy OFTV2201959942024-06-29 7:56:478 days ago1719647807IN
0x287176df...ee1784AdC
0.00055936 ETH0.000616192.17641743
Send Proxy OFTV2201959862024-06-29 7:55:118 days ago1719647711IN
0x287176df...ee1784AdC
0.00055911 ETH0.000684382.43425706
Send Proxy OFTV2201899282024-06-28 11:36:599 days ago1719574619IN
0x287176df...ee1784AdC
0.00063919 ETH0.000980053.4
Send Proxy OFTV2201897722024-06-28 11:05:239 days ago1719572723IN
0x287176df...ee1784AdC
0.00055616 ETH0.001160384.09852272
Send Proxy OFTV2201896302024-06-28 10:36:479 days ago1719571007IN
0x287176df...ee1784AdC
0.00063946 ETH0.001722065.9741889
Send Proxy OFTV2201893732024-06-28 9:45:119 days ago1719567911IN
0x287176df...ee1784AdC
0.0005568 ETH0.001987977.07096082
Send Proxy OFTV2201888422024-06-28 7:58:479 days ago1719561527IN
0x287176df...ee1784AdC
0.00055668 ETH0.001491125.30371648
View all transactions

Latest 25 internal transactions (View All)

Advanced mode:
Parent Transaction Hash Block From To Value
202442252024-07-06 1:35:4737 hrs ago1720229747
0x287176df...ee1784AdC
0.00029732 ETH
202436262024-07-05 23:35:3539 hrs ago1720222535
0x287176df...ee1784AdC
0.00045229 ETH
202400362024-07-05 11:34:112 days ago1720179251
0x287176df...ee1784AdC
0.00029926 ETH
202343802024-07-04 16:36:112 days ago1720110971
0x287176df...ee1784AdC
0.00029885 ETH
202343772024-07-04 16:35:352 days ago1720110935
0x287176df...ee1784AdC
0.00029299 ETH
202328392024-07-04 11:25:473 days ago1720092347
0x287176df...ee1784AdC
0.00026747 ETH
202322592024-07-04 9:29:113 days ago1720085351
0x287176df...ee1784AdC
0.00035853 ETH
202319692024-07-04 8:30:593 days ago1720081859
0x287176df...ee1784AdC
0.00026647 ETH
202189982024-07-02 13:01:475 days ago1719925307
0x287176df...ee1784AdC
0.00034605 ETH
202188632024-07-02 12:34:355 days ago1719923675
0x287176df...ee1784AdC
0.00034605 ETH
202182772024-07-02 10:36:355 days ago1719916595
0x287176df...ee1784AdC
0.00028785 ETH
202162892024-07-02 3:56:355 days ago1719892595
0x287176df...ee1784AdC
0.00026501 ETH
202143122024-07-01 21:19:115 days ago1719868751
0x287176df...ee1784AdC
0.000352 ETH
202140752024-07-01 20:31:475 days ago1719865907
0x287176df...ee1784AdC
0.000352 ETH
202067022024-06-30 19:50:236 days ago1719777023
0x287176df...ee1784AdC
0.00026542 ETH
202059412024-06-30 17:17:236 days ago1719767843
0x287176df...ee1784AdC
0.00026562 ETH
202039362024-06-30 10:34:237 days ago1719743663
0x287176df...ee1784AdC
0.00026486 ETH
201967822024-06-29 10:35:238 days ago1719657323
0x287176df...ee1784AdC
0.00029174 ETH
201959942024-06-29 7:56:478 days ago1719647807
0x287176df...ee1784AdC
0.00026491 ETH
201959862024-06-29 7:55:118 days ago1719647711
0x287176df...ee1784AdC
0.00026491 ETH
201899282024-06-28 11:36:599 days ago1719574619
0x287176df...ee1784AdC
0.00034854 ETH
201897722024-06-28 11:05:239 days ago1719572723
0x287176df...ee1784AdC
0.00026551 ETH
201896302024-06-28 10:36:479 days ago1719571007
0x287176df...ee1784AdC
0.00034854 ETH
201893732024-06-28 9:45:119 days ago1719567911
0x287176df...ee1784AdC
0.00026524 ETH
201888422024-06-28 7:58:479 days ago1719561527
0x287176df...ee1784AdC
0.00026523 ETH
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

[{"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"}]

60c06040526006805460ff191690553480156200001b57600080fd5b5060405162001ee338038062001ee38339810160408190526200003e916200061e565b600080546001600160a01b0319166001600160a01b038316908117825560405183928392917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a3506001600160a01b039081166000908152600160208190526040909120805460ff191682179055600255600585905583166200010b5760405162461bcd60e51b815260206004820152601760248201527f4f4654577261707065723a20696e76616c6964206f667400000000000000000060448201526064015b60405180910390fd5b6001600160a01b038316608081905260408051637e062a3560e11b8152905163fc0c546a916004808201926020929091908290030181865afa15801562000156573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200017c919062000672565b6001600160a01b0390811660a0528216620001da5760405162461bcd60e51b815260206004820152601e60248201527f4f4654577261707065723a20696e76616c69642061676772656761746f720000604482015260640162000102565b600480546001600160a01b0319166001600160a01b038481169190911790915560805160a051620002109216906000196200023a565b600380546001600160a01b0319166001600160a01b0392909216919091179055506200074e915050565b801580620002b85750604051636eb1769f60e11b81523060048201526001600160a01b03838116602483015284169063dd62ed3e90604401602060405180830381865afa15801562000290573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620002b6919062000697565b155b6200032c5760405162461bcd60e51b815260206004820152603660248201527f5361666545524332303a20617070726f76652066726f6d206e6f6e2d7a65726f60448201527f20746f206e6f6e2d7a65726f20616c6c6f77616e636500000000000000000000606482015260840162000102565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b0390811663095ea7b360e01b17909152620003849185916200038916565b505050565b6040805180820190915260208082527f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c656490820152600090620003d8906001600160a01b0385169084906200045d565b9050805160001480620003fc575080806020019051810190620003fc9190620006b1565b620003845760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6044820152691bdd081cdd58d8d9595960b21b606482015260840162000102565b60606200046e848460008562000476565b949350505050565b606082471015620004d95760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f6044820152651c8818d85b1b60d21b606482015260840162000102565b600080866001600160a01b03168587604051620004f79190620006fb565b60006040518083038185875af1925050503d806000811462000536576040519150601f19603f3d011682016040523d82523d6000602084013e6200053b565b606091505b5090925090506200054f878383876200055a565b979650505050505050565b60608315620005ce578251600003620005c6576001600160a01b0385163b620005c65760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000604482015260640162000102565b50816200046e565b6200046e8383815115620005e55781518083602001fd5b8060405162461bcd60e51b815260040162000102919062000719565b80516001600160a01b03811681146200061957600080fd5b919050565b600080600080608085870312156200063557600080fd5b84519350620006476020860162000601565b9250620006576040860162000601565b9150620006676060860162000601565b905092959194509250565b6000602082840312156200068557600080fd5b620006908262000601565b9392505050565b600060208284031215620006aa57600080fd5b5051919050565b600060208284031215620006c457600080fd5b815180151581146200069057600080fd5b60005b83811015620006f2578181015183820152602001620006d8565b50506000910152565b600082516200070f818460208701620006d5565b9190910192915050565b60208152600082518060208401526200073a816040850160208701620006d5565b601f01601f19169190910160400192915050565b60805160a0516117456200079e600039600081816104190152610797015260008181610350015281816105490152818161068d015281816107d601528181610839015261098501526117456000f3fe60806040526004361061015f5760003560e01c80638cfd8f5c116100c0578063ed5a0fc011610074578063f46901ed11610059578063f46901ed146103c7578063f9120af6146103e7578063fc0c546a1461040757600080fd5b8063ed5a0fc014610387578063f2fde38b146103a757600080fd5b806390ed2083116100a557806390ed20831461031e5780639b5215f61461033e578063b353aaa71461037257600080fd5b80638cfd8f5c146102de5780638da5cb5b146102fe57600080fd5b8063476343ee11610117578063558a7297116100fc578063558a7297146102765780636ee296c91461029657806376025ec9146102cb57600080fd5b8063476343ee1461024c5780634da38ad81461026357600080fd5b806321f3c9f21161014857806321f3c9f2146101e15780632362189a14610208578063245a7bfc1461022c57600080fd5b8063017e7e581461016457806313e7c9d8146101a1575b600080fd5b34801561017057600080fd5b50600354610184906001600160a01b031681565b6040516001600160a01b0390911681526020015b60405180910390f35b3480156101ad57600080fd5b506101d16101bc366004611137565b60016020526000908152604090205460ff1681565b6040519015158152602001610198565b3480156101ed57600080fd5b506006546101fb9060ff1681565b604051610198919061118c565b34801561021457600080fd5b5061021e60055481565b604051908152602001610198565b34801561023857600080fd5b50600454610184906001600160a01b031681565b34801561025857600080fd5b5061026161043b565b005b6102616102713660046111b1565b6104fd565b34801561028257600080fd5b50610261610291366004611225565b6105e0565b3480156102a257600080fd5b506102b66102b136600461125e565b610688565b60408051928352602083019190915201610198565b6102616102d93660046111b1565b610745565b3480156102ea57600080fd5b5061021e6102f93660046112f2565b610815565b34801561030a57600080fd5b50600054610184906001600160a01b031681565b34801561032a57600080fd5b50610261610339366004611325565b6108b5565b34801561034a57600080fd5b506101847f000000000000000000000000000000000000000000000000000000000000000081565b34801561037e57600080fd5b50610184610981565b34801561039357600080fd5b506102616103a2366004611346565b610a0a565b3480156103b357600080fd5b506102616103c2366004611137565b610a7b565b3480156103d357600080fd5b506102616103e2366004611137565b610b1c565b3480156103f357600080fd5b50610261610402366004611137565b610bf5565b34801561041357600080fd5b506101847f000000000000000000000000000000000000000000000000000000000000000081565b60035460405147916000916001600160a01b039091169083908381818185875af1925050503d806000811461048c576040519150601f19603f3d011682016040523d82523d6000602084013e610491565b606091505b50509050806104b35760405163f5ef1ce360e01b815260040160405180910390fd5b600354604080516001600160a01b039092168252602082018490527febe72af9d0a9f9afca2ea0bada9230f49d3c9e86f4948f37097d108a49363d53910160405180910390a15050565b610505610cb5565b600061050f610d0c565b9050803410156105395760405163b621805960e01b81523460048201526024015b60405180910390fd5b60006105458234611375565b90507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663695ef6bf8233898989896040518763ffffffff1660e01b815260040161059c9594939291906113b1565b6000604051808303818588803b1580156105b557600080fd5b505af11580156105c9573d6000803e3d6000fd5b505050505050506105da6001600255565b50505050565b6000546001600160a01b031633146106295760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610530565b6001600160a01b038216600081815260016020908152604091829020805460ff191685151590811790915591519182527f193de8d500b5cb7b720089b258a39e9c1d0b840019a73ae7c51c3f9101732b02910160405180910390a25050565b6000807f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663365260b4888888600089896040518763ffffffff1660e01b81526004016106e29695949392919061146a565b6040805180830381865afa1580156106fe573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061072291906114a8565b909250905061072f610d0c565b61073990836114cc565b91509550959350505050565b61074d610cb5565b6000610757610d0c565b90508034101561077c5760405163b621805960e01b8152346004820152602401610530565b60006107888234611375565b90506107bf6001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016333087610e2f565b60405163695ef6bf60e01b81526001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000169063695ef6bf90839061059c9030908b908b908b908b906004016113b1565b60405163233f63d760e21b815261ffff8084166004830152821660248201526000907f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031690638cfd8f5c90604401602060405180830381865afa158015610888573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108ac91906114df565b90505b92915050565b3360009081526001602052604090205460ff166108e55760405163de19c8b360e01b815260040160405180910390fd5b60018160018111156108f9576108f9611154565b111561091a578060405163d05ccdf360e01b8152600401610530919061118c565b6006546040517f80e60928263e6642de6e8a1117b4f00062107c445212b88f6a02187940eccf2c916109539160ff9091169084906114f8565b60405180910390a16006805482919060ff19166001838181111561097957610979611154565b021790555050565b60007f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663b353aaa76040518163ffffffff1660e01b8152600401602060405180830381865afa1580156109e1573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a059190611513565b905090565b3360009081526001602052604090205460ff16610a3a5760405163de19c8b360e01b815260040160405180910390fd5b60055460408051918252602082018390527f4c0bffc5595fd0c1705c52132244fdac73f66274c586f059483928f66e7b6d98910160405180910390a1600555565b6000546001600160a01b03163314610ac45760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610530565b6000805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0383169081178255604051909133917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a350565b6000546001600160a01b03163314610b655760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610530565b6001600160a01b038116610b8c5760405163e6c4247b60e01b815260040160405180910390fd5b6003546040516001600160a01b038084169216907fbcf71d3ed47385ef899b4ae7d10b0da92fce93b66f947859b6b12c39faa6abba90600090a36003805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b3360009081526001602052604090205460ff16610c255760405163de19c8b360e01b815260040160405180910390fd5b6001600160a01b038116610c4c5760405163e6c4247b60e01b815260040160405180910390fd5b6004546040516001600160a01b038084169216907f8e0352ee1de57032a7c8ddf4cb1daa3ff929d0a8534e42a124811b2fa033cccd90600090a36004805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b6002805403610d065760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c006044820152606401610530565b60028055565b60008060065460ff166001811115610d2657610d26611154565b03610e285760048054604080516350d25bcd60e01b815290516001600160a01b03909216926350d25bcd9282820192602092908290030181865afa158015610d72573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610d9691906114df565b600480546040805163313ce56760e01b815290516001600160a01b039092169263313ce5679282820192602092908290030181865afa158015610ddd573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e019190611530565b610e0c90600a611637565b610e1e90670de0b6b3a7640000611646565b610a05919061165d565b5060055490565b604080516001600160a01b038581166024830152848116604483015260648083018590528351808403909101815260849092018352602080830180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff166323b872dd60e01b17905283518085019094528084527f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564908401526105da92879291600091610edc918516908490610f74565b9050805160001480610efd575080806020019051810190610efd919061167f565b610f6f5760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e60448201527f6f742073756363656564000000000000000000000000000000000000000000006064820152608401610530565b505050565b6060610f838484600085610f8d565b90505b9392505050565b6060824710156110055760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f60448201527f722063616c6c00000000000000000000000000000000000000000000000000006064820152608401610530565b600080866001600160a01b0316858760405161102191906116c0565b60006040518083038185875af1925050503d806000811461105e576040519150601f19603f3d011682016040523d82523d6000602084013e611063565b606091505b509150915061107487838387611081565b925050505b949350505050565b606083156110f05782516000036110e9576001600160a01b0385163b6110e95760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610530565b5081611079565b61107983838151156111055781518083602001fd5b8060405162461bcd60e51b815260040161053091906116dc565b6001600160a01b038116811461113457600080fd5b50565b60006020828403121561114957600080fd5b8135610f868161111f565b634e487b7160e01b600052602160045260246000fd5b6002811061118857634e487b7160e01b600052602160045260246000fd5b9052565b602081016108af828461116a565b803561ffff811681146111ac57600080fd5b919050565b600080600080608085870312156111c757600080fd5b6111d08561119a565b93506020850135925060408501359150606085013567ffffffffffffffff8111156111fa57600080fd5b85016060818803121561120c57600080fd5b939692955090935050565b801515811461113457600080fd5b6000806040838503121561123857600080fd5b82356112438161111f565b9150602083013561125381611217565b809150509250929050565b60008060008060006080868803121561127657600080fd5b61127f8661119a565b94506020860135935060408601359250606086013567ffffffffffffffff808211156112aa57600080fd5b818801915088601f8301126112be57600080fd5b8135818111156112cd57600080fd5b8960208285010111156112df57600080fd5b9699959850939650602001949392505050565b6000806040838503121561130557600080fd5b61130e8361119a565b915061131c6020840161119a565b90509250929050565b60006020828403121561133757600080fd5b813560028110610f8657600080fd5b60006020828403121561135857600080fd5b5035919050565b634e487b7160e01b600052601160045260246000fd5b818103818111156108af576108af61135f565b81835281816020850137506000828201602090810191909152601f909101601f19169091010190565b60006001600160a01b03808816835261ffff8716602084015285604084015284606084015260a0608084015283356113e88161111f565b811660a084015260208401356113fd8161111f565b1660c0830152604083013536849003601e1901811261141b57600080fd5b830160208101903567ffffffffffffffff81111561143857600080fd5b80360382131561144757600080fd5b606060e085015261145d61010085018284611388565b9998505050505050505050565b61ffff87168152856020820152846040820152831515606082015260a06080820152600061149c60a083018486611388565b98975050505050505050565b600080604083850312156114bb57600080fd5b505080516020909101519092909150565b808201808211156108af576108af61135f565b6000602082840312156114f157600080fd5b5051919050565b60408101611506828561116a565b610f86602083018461116a565b60006020828403121561152557600080fd5b8151610f868161111f565b60006020828403121561154257600080fd5b815160ff81168114610f8657600080fd5b600181815b8085111561158e5781600019048211156115745761157461135f565b8085161561158157918102915b93841c9390800290611558565b509250929050565b6000826115a5575060016108af565b816115b2575060006108af565b81600181146115c857600281146115d2576115ee565b60019150506108af565b60ff8411156115e3576115e361135f565b50506001821b6108af565b5060208310610133831016604e8410600b8410161715611611575081810a6108af565b61161b8383611553565b806000190482111561162f5761162f61135f565b029392505050565b60006108ac60ff841683611596565b80820281158282048414176108af576108af61135f565b60008261167a57634e487b7160e01b600052601260045260246000fd5b500490565b60006020828403121561169157600080fd5b8151610f8681611217565b60005b838110156116b757818101518382015260200161169f565b50506000910152565b600082516116d281846020870161169c565b9190910192915050565b60208152600082518060208401526116fb81604085016020870161169c565b601f01601f1916919091016040019291505056fea2646970667358221220033825713a4a6533dd80b32604dbbfeb95e0c4c4c593c23e4b7b1421806a790d64736f6c634300081400330000000000000000000000000000000000000000000000000001ea772b12c461000000000000000000000000439a5f0f5e8d149dda9a0ca367d4a8e4d6f83c100000000000000000000000005f4ec3df9cbd43714fe2740f5e3616155c5b8419000000000000000000000000df2c270f610dc35d8ffda5b453e74db5471e126b

Deployed Bytecode

0x60806040526004361061015f5760003560e01c80638cfd8f5c116100c0578063ed5a0fc011610074578063f46901ed11610059578063f46901ed146103c7578063f9120af6146103e7578063fc0c546a1461040757600080fd5b8063ed5a0fc014610387578063f2fde38b146103a757600080fd5b806390ed2083116100a557806390ed20831461031e5780639b5215f61461033e578063b353aaa71461037257600080fd5b80638cfd8f5c146102de5780638da5cb5b146102fe57600080fd5b8063476343ee11610117578063558a7297116100fc578063558a7297146102765780636ee296c91461029657806376025ec9146102cb57600080fd5b8063476343ee1461024c5780634da38ad81461026357600080fd5b806321f3c9f21161014857806321f3c9f2146101e15780632362189a14610208578063245a7bfc1461022c57600080fd5b8063017e7e581461016457806313e7c9d8146101a1575b600080fd5b34801561017057600080fd5b50600354610184906001600160a01b031681565b6040516001600160a01b0390911681526020015b60405180910390f35b3480156101ad57600080fd5b506101d16101bc366004611137565b60016020526000908152604090205460ff1681565b6040519015158152602001610198565b3480156101ed57600080fd5b506006546101fb9060ff1681565b604051610198919061118c565b34801561021457600080fd5b5061021e60055481565b604051908152602001610198565b34801561023857600080fd5b50600454610184906001600160a01b031681565b34801561025857600080fd5b5061026161043b565b005b6102616102713660046111b1565b6104fd565b34801561028257600080fd5b50610261610291366004611225565b6105e0565b3480156102a257600080fd5b506102b66102b136600461125e565b610688565b60408051928352602083019190915201610198565b6102616102d93660046111b1565b610745565b3480156102ea57600080fd5b5061021e6102f93660046112f2565b610815565b34801561030a57600080fd5b50600054610184906001600160a01b031681565b34801561032a57600080fd5b50610261610339366004611325565b6108b5565b34801561034a57600080fd5b506101847f000000000000000000000000439a5f0f5e8d149dda9a0ca367d4a8e4d6f83c1081565b34801561037e57600080fd5b50610184610981565b34801561039357600080fd5b506102616103a2366004611346565b610a0a565b3480156103b357600080fd5b506102616103c2366004611137565b610a7b565b3480156103d357600080fd5b506102616103e2366004611137565b610b1c565b3480156103f357600080fd5b50610261610402366004611137565b610bf5565b34801561041357600080fd5b506101847f00000000000000000000000099d8a9c45b2eca8864373a26d1459e3dff1e17f381565b60035460405147916000916001600160a01b039091169083908381818185875af1925050503d806000811461048c576040519150601f19603f3d011682016040523d82523d6000602084013e610491565b606091505b50509050806104b35760405163f5ef1ce360e01b815260040160405180910390fd5b600354604080516001600160a01b039092168252602082018490527febe72af9d0a9f9afca2ea0bada9230f49d3c9e86f4948f37097d108a49363d53910160405180910390a15050565b610505610cb5565b600061050f610d0c565b9050803410156105395760405163b621805960e01b81523460048201526024015b60405180910390fd5b60006105458234611375565b90507f000000000000000000000000439a5f0f5e8d149dda9a0ca367d4a8e4d6f83c106001600160a01b031663695ef6bf8233898989896040518763ffffffff1660e01b815260040161059c9594939291906113b1565b6000604051808303818588803b1580156105b557600080fd5b505af11580156105c9573d6000803e3d6000fd5b505050505050506105da6001600255565b50505050565b6000546001600160a01b031633146106295760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610530565b6001600160a01b038216600081815260016020908152604091829020805460ff191685151590811790915591519182527f193de8d500b5cb7b720089b258a39e9c1d0b840019a73ae7c51c3f9101732b02910160405180910390a25050565b6000807f000000000000000000000000439a5f0f5e8d149dda9a0ca367d4a8e4d6f83c106001600160a01b031663365260b4888888600089896040518763ffffffff1660e01b81526004016106e29695949392919061146a565b6040805180830381865afa1580156106fe573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061072291906114a8565b909250905061072f610d0c565b61073990836114cc565b91509550959350505050565b61074d610cb5565b6000610757610d0c565b90508034101561077c5760405163b621805960e01b8152346004820152602401610530565b60006107888234611375565b90506107bf6001600160a01b037f00000000000000000000000099d8a9c45b2eca8864373a26d1459e3dff1e17f316333087610e2f565b60405163695ef6bf60e01b81526001600160a01b037f000000000000000000000000439a5f0f5e8d149dda9a0ca367d4a8e4d6f83c10169063695ef6bf90839061059c9030908b908b908b908b906004016113b1565b60405163233f63d760e21b815261ffff8084166004830152821660248201526000907f000000000000000000000000439a5f0f5e8d149dda9a0ca367d4a8e4d6f83c106001600160a01b031690638cfd8f5c90604401602060405180830381865afa158015610888573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108ac91906114df565b90505b92915050565b3360009081526001602052604090205460ff166108e55760405163de19c8b360e01b815260040160405180910390fd5b60018160018111156108f9576108f9611154565b111561091a578060405163d05ccdf360e01b8152600401610530919061118c565b6006546040517f80e60928263e6642de6e8a1117b4f00062107c445212b88f6a02187940eccf2c916109539160ff9091169084906114f8565b60405180910390a16006805482919060ff19166001838181111561097957610979611154565b021790555050565b60007f000000000000000000000000439a5f0f5e8d149dda9a0ca367d4a8e4d6f83c106001600160a01b031663b353aaa76040518163ffffffff1660e01b8152600401602060405180830381865afa1580156109e1573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a059190611513565b905090565b3360009081526001602052604090205460ff16610a3a5760405163de19c8b360e01b815260040160405180910390fd5b60055460408051918252602082018390527f4c0bffc5595fd0c1705c52132244fdac73f66274c586f059483928f66e7b6d98910160405180910390a1600555565b6000546001600160a01b03163314610ac45760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610530565b6000805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0383169081178255604051909133917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a350565b6000546001600160a01b03163314610b655760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610530565b6001600160a01b038116610b8c5760405163e6c4247b60e01b815260040160405180910390fd5b6003546040516001600160a01b038084169216907fbcf71d3ed47385ef899b4ae7d10b0da92fce93b66f947859b6b12c39faa6abba90600090a36003805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b3360009081526001602052604090205460ff16610c255760405163de19c8b360e01b815260040160405180910390fd5b6001600160a01b038116610c4c5760405163e6c4247b60e01b815260040160405180910390fd5b6004546040516001600160a01b038084169216907f8e0352ee1de57032a7c8ddf4cb1daa3ff929d0a8534e42a124811b2fa033cccd90600090a36004805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b6002805403610d065760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c006044820152606401610530565b60028055565b60008060065460ff166001811115610d2657610d26611154565b03610e285760048054604080516350d25bcd60e01b815290516001600160a01b03909216926350d25bcd9282820192602092908290030181865afa158015610d72573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610d9691906114df565b600480546040805163313ce56760e01b815290516001600160a01b039092169263313ce5679282820192602092908290030181865afa158015610ddd573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e019190611530565b610e0c90600a611637565b610e1e90670de0b6b3a7640000611646565b610a05919061165d565b5060055490565b604080516001600160a01b038581166024830152848116604483015260648083018590528351808403909101815260849092018352602080830180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff166323b872dd60e01b17905283518085019094528084527f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564908401526105da92879291600091610edc918516908490610f74565b9050805160001480610efd575080806020019051810190610efd919061167f565b610f6f5760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e60448201527f6f742073756363656564000000000000000000000000000000000000000000006064820152608401610530565b505050565b6060610f838484600085610f8d565b90505b9392505050565b6060824710156110055760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f60448201527f722063616c6c00000000000000000000000000000000000000000000000000006064820152608401610530565b600080866001600160a01b0316858760405161102191906116c0565b60006040518083038185875af1925050503d806000811461105e576040519150601f19603f3d011682016040523d82523d6000602084013e611063565b606091505b509150915061107487838387611081565b925050505b949350505050565b606083156110f05782516000036110e9576001600160a01b0385163b6110e95760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610530565b5081611079565b61107983838151156111055781518083602001fd5b8060405162461bcd60e51b815260040161053091906116dc565b6001600160a01b038116811461113457600080fd5b50565b60006020828403121561114957600080fd5b8135610f868161111f565b634e487b7160e01b600052602160045260246000fd5b6002811061118857634e487b7160e01b600052602160045260246000fd5b9052565b602081016108af828461116a565b803561ffff811681146111ac57600080fd5b919050565b600080600080608085870312156111c757600080fd5b6111d08561119a565b93506020850135925060408501359150606085013567ffffffffffffffff8111156111fa57600080fd5b85016060818803121561120c57600080fd5b939692955090935050565b801515811461113457600080fd5b6000806040838503121561123857600080fd5b82356112438161111f565b9150602083013561125381611217565b809150509250929050565b60008060008060006080868803121561127657600080fd5b61127f8661119a565b94506020860135935060408601359250606086013567ffffffffffffffff808211156112aa57600080fd5b818801915088601f8301126112be57600080fd5b8135818111156112cd57600080fd5b8960208285010111156112df57600080fd5b9699959850939650602001949392505050565b6000806040838503121561130557600080fd5b61130e8361119a565b915061131c6020840161119a565b90509250929050565b60006020828403121561133757600080fd5b813560028110610f8657600080fd5b60006020828403121561135857600080fd5b5035919050565b634e487b7160e01b600052601160045260246000fd5b818103818111156108af576108af61135f565b81835281816020850137506000828201602090810191909152601f909101601f19169091010190565b60006001600160a01b03808816835261ffff8716602084015285604084015284606084015260a0608084015283356113e88161111f565b811660a084015260208401356113fd8161111f565b1660c0830152604083013536849003601e1901811261141b57600080fd5b830160208101903567ffffffffffffffff81111561143857600080fd5b80360382131561144757600080fd5b606060e085015261145d61010085018284611388565b9998505050505050505050565b61ffff87168152856020820152846040820152831515606082015260a06080820152600061149c60a083018486611388565b98975050505050505050565b600080604083850312156114bb57600080fd5b505080516020909101519092909150565b808201808211156108af576108af61135f565b6000602082840312156114f157600080fd5b5051919050565b60408101611506828561116a565b610f86602083018461116a565b60006020828403121561152557600080fd5b8151610f868161111f565b60006020828403121561154257600080fd5b815160ff81168114610f8657600080fd5b600181815b8085111561158e5781600019048211156115745761157461135f565b8085161561158157918102915b93841c9390800290611558565b509250929050565b6000826115a5575060016108af565b816115b2575060006108af565b81600181146115c857600281146115d2576115ee565b60019150506108af565b60ff8411156115e3576115e361135f565b50506001821b6108af565b5060208310610133831016604e8410600b8410161715611611575081810a6108af565b61161b8383611553565b806000190482111561162f5761162f61135f565b029392505050565b60006108ac60ff841683611596565b80820281158282048414176108af576108af61135f565b60008261167a57634e487b7160e01b600052601260045260246000fd5b500490565b60006020828403121561169157600080fd5b8151610f8681611217565b60005b838110156116b757818101518382015260200161169f565b50506000910152565b600082516116d281846020870161169c565b9190910192915050565b60208152600082518060208401526116fb81604085016020870161169c565b601f01601f1916919091016040019291505056fea2646970667358221220033825713a4a6533dd80b32604dbbfeb95e0c4c4c593c23e4b7b1421806a790d64736f6c63430008140033

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

0000000000000000000000000000000000000000000000000001ea772b12c461000000000000000000000000439a5f0f5e8d149dda9a0ca367d4a8e4d6f83c100000000000000000000000005f4ec3df9cbd43714fe2740f5e3616155c5b8419000000000000000000000000df2c270f610dc35d8ffda5b453e74db5471e126b

-----Decoded View---------------
Arg [0] : _defaultExchangeRate (uint256): 539272521368673
Arg [1] : _oft (address): 0x439a5f0f5E8d149DDA9a0Ca367D4a8e4D6f83C10
Arg [2] : _aggregator (address): 0x5f4eC3Df9cbd43714FE2740f5E3616155c5b8419
Arg [3] : _multisig (address): 0xDF2C270f610Dc35d8fFDA5B453E74db5471E126B

-----Encoded View---------------
4 Constructor Arguments found :
Arg [0] : 0000000000000000000000000000000000000000000000000001ea772b12c461
Arg [1] : 000000000000000000000000439a5f0f5e8d149dda9a0ca367d4a8e4d6f83c10
Arg [2] : 0000000000000000000000005f4ec3df9cbd43714fe2740f5e3616155c5b8419
Arg [3] : 000000000000000000000000df2c270f610dc35d8ffda5b453e74db5471e126b


Block Transaction Difficulty Gas Used Reward
View All Blocks Produced

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

Validator Index Block Amount
View All Withdrawals

Transaction Hash Block Value Eth2 PubKey Valid
View All Deposits
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.