POL Price: $0.363491 (-2.42%)
 

Overview

POL Balance

Polygon PoS Chain LogoPolygon PoS Chain LogoPolygon PoS Chain Logo2.639660964057505225 POL

POL Value

$0.96 (@ $0.36/POL)

Token Holdings

Multichain Info

No addresses found
Transaction Hash
Method
Block
From
To
Send Proxy OFTV2625368582024-10-02 9:46:2611 days ago1727862386IN
0xE1261E47...2Aa6DfD4c
3.34098399 POL0.0082792230.00000009
Withdraw Fees625035012024-10-01 13:57:0012 days ago1727791020IN
0xE1261E47...2Aa6DfD4c
0 POL0.0013395632.99995393
Send Proxy OFTV2614071562024-09-04 8:34:5239 days ago1725438892IN
0xE1261E47...2Aa6DfD4c
3.27329324 POL0.0102074936.98875217
Send Proxy OFTV2594157872024-07-16 4:30:2689 days ago1721104226IN
0xE1261E47...2Aa6DfD4c
2.35019695 POL0.0083674330.01382228
Withdraw Fees593920352024-07-15 14:05:3790 days ago1721052337IN
0xE1261E47...2Aa6DfD4c
0 POL0.0014614736.00313172
Send Proxy OFTV2583461572024-06-19 10:25:53116 days ago1718792753IN
0xE1261E47...2Aa6DfD4c
2.34674172 POL0.0200769570.29968683
Send Proxy OFTV2583052972024-06-18 9:29:56117 days ago1718702996IN
0xE1261E47...2Aa6DfD4c
1.95028375 POL0.0148984751
Send Proxy OFTV2572559442024-05-22 10:14:58144 days ago1716372898IN
0xE1261E47...2Aa6DfD4c
2.73552717 POL0.0087215730.00001044
Send Proxy OFTV2571893112024-05-20 15:52:09146 days ago1716220329IN
0xE1261E47...2Aa6DfD4c
2.1932784 POL0.009179733.32342276
Send Proxy OFTV2570477102024-05-16 21:38:14149 days ago1715895494IN
0xE1261E47...2Aa6DfD4c
1.51910106 POL0.0107287338
Send Proxy OFTV2568303922024-05-11 5:46:29155 days ago1715406389IN
0xE1261E47...2Aa6DfD4c
1.56490622 POL0.010367236.3
Send Proxy OFTV2567956582024-05-10 8:57:15156 days ago1715331435IN
0xE1261E47...2Aa6DfD4c
2.17624323 POL0.0082706730.00000008
Send Proxy OFTV2567927402024-05-10 7:13:13156 days ago1715325193IN
0xE1261E47...2Aa6DfD4c
1.94301757 POL0.0084887730.00000007
Send Proxy OFTV2567844882024-05-10 2:17:44156 days ago1715307464IN
0xE1261E47...2Aa6DfD4c
1.86080148 POL0.0091924133
Send Proxy OFTV2567542872024-05-09 7:59:37157 days ago1715241577IN
0xE1261E47...2Aa6DfD4c
1.56224891 POL0.0145683551.01
Send Proxy OFTV2567075052024-05-08 3:21:19158 days ago1715138479IN
0xE1261E47...2Aa6DfD4c
1.53434805 POL0.0100016435.02
Send Proxy OFTV2566761502024-05-07 8:04:08159 days ago1715069048IN
0xE1261E47...2Aa6DfD4c
1.50974843 POL0.0140246249.75
Send Proxy OFTV2566761412024-05-07 8:03:48159 days ago1715069028IN
0xE1261E47...2Aa6DfD4c
1.50824946 POL0.014208549.75
Send Proxy OFTV2566652862024-05-07 1:34:56159 days ago1715045696IN
0xE1261E47...2Aa6DfD4c
1.49437049 POL0.0086340630.00000005
Send Proxy OFTV2565888732024-05-05 1:48:13161 days ago1714873693IN
0xE1261E47...2Aa6DfD4c
1.6572044 POL0.0082727430.00000033
Send Proxy OFTV2565300422024-05-03 12:32:40163 days ago1714739560IN
0xE1261E47...2Aa6DfD4c
2.22641042 POL0.0089923632.05959442
Send Proxy OFTV2565300252024-05-03 12:32:04163 days ago1714739524IN
0xE1261E47...2Aa6DfD4c
2.22256822 POL0.0057883297.00240341
Send Proxy OFTV2565300232024-05-03 12:32:00163 days ago1714739520IN
0xE1261E47...2Aa6DfD4c
2.22256822 POL0.0282286899.63778821
Send Proxy OFTV2565272812024-05-03 10:35:26163 days ago1714732526IN
0xE1261E47...2Aa6DfD4c
2.1421697 POL0.0085744230.0000003
Send Proxy OFTV2565239772024-05-03 8:17:18163 days ago1714724238IN
0xE1261E47...2Aa6DfD4c
2.14766216 POL0.0085740630.00000034
View all transactions

Latest 25 internal transactions (View All)

Parent Transaction Hash Block From To
625368582024-10-02 9:46:2611 days ago1727862386
0xE1261E47...2Aa6DfD4c
0.70132303 POL
625035012024-10-01 13:57:0012 days ago1727791020
0xE1261E47...2Aa6DfD4c
4.47123947 POL
614071562024-09-04 8:34:5239 days ago1725438892
0xE1261E47...2Aa6DfD4c
0.62849028 POL
594157872024-07-16 4:30:2689 days ago1721104226
0xE1261E47...2Aa6DfD4c
0.52376044 POL
593920352024-07-15 14:05:3790 days ago1721052337
0xE1261E47...2Aa6DfD4c
568.75015423 POL
583461572024-06-19 10:25:53116 days ago1718792753
0xE1261E47...2Aa6DfD4c
0.60266721 POL
583052972024-06-18 9:29:56117 days ago1718702996
0xE1261E47...2Aa6DfD4c
0.14180272 POL
572559442024-05-22 10:14:58144 days ago1716372898
0xE1261E47...2Aa6DfD4c
1.35675339 POL
571893112024-05-20 15:52:09146 days ago1716220329
0xE1261E47...2Aa6DfD4c
0.74395553 POL
570477102024-05-16 21:38:14149 days ago1715895494
0xE1261E47...2Aa6DfD4c
0.06464812 POL
568303922024-05-11 5:46:29155 days ago1715406389
0xE1261E47...2Aa6DfD4c
0.09655953 POL
567956582024-05-10 8:57:15156 days ago1715331435
0xE1261E47...2Aa6DfD4c
0.74372343 POL
567927402024-05-10 7:13:13156 days ago1715325193
0xE1261E47...2Aa6DfD4c
0.51120653 POL
567844882024-05-10 2:17:44156 days ago1715307464
0xE1261E47...2Aa6DfD4c
0.42168432 POL
567542872024-05-09 7:59:37157 days ago1715241577
0xE1261E47...2Aa6DfD4c
0.09651652 POL
567075052024-05-08 3:21:19158 days ago1715138479
0xE1261E47...2Aa6DfD4c
0.08769839 POL
566761502024-05-07 8:04:08159 days ago1715069048
0xE1261E47...2Aa6DfD4c
0.08783966 POL
566761412024-05-07 8:03:48159 days ago1715069028
0xE1261E47...2Aa6DfD4c
0.0878066 POL
566652862024-05-07 1:34:56159 days ago1715045696
0xE1261E47...2Aa6DfD4c
0.08759361 POL
565888732024-05-05 1:48:13161 days ago1714873693
0xE1261E47...2Aa6DfD4c
0.27479767 POL
565300422024-05-03 12:32:40163 days ago1714739560
0xE1261E47...2Aa6DfD4c
0.85032676 POL
565300232024-05-03 12:32:00163 days ago1714739520
0xE1261E47...2Aa6DfD4c
0.84813561 POL
565272812024-05-03 10:35:26163 days ago1714732526
0xE1261E47...2Aa6DfD4c
0.75391023 POL
565239772024-05-03 8:17:18163 days ago1714724238
0xE1261E47...2Aa6DfD4c
0.75411245 POL
565239672024-05-03 8:16:36163 days ago1714724196
0xE1261E47...2Aa6DfD4c
0.7534318 POL
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.FIXED_EXCHANGE_RATE;

    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) {}

    modifier onlyOperators() {
        if (!operators[msg.sender] && msg.sender != owner) {
            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"}]

60c06040526006805460ff191660011790553480156200001e57600080fd5b5060405162001f1638038062001f16833981016040819052620000419162000606565b600080546001600160a01b0319166001600160a01b038316908117825560405183928392917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a35050600160025560058490556001600160a01b038316620000f35760405162461bcd60e51b815260206004820152601760248201527f4f4654577261707065723a20696e76616c6964206f667400000000000000000060448201526064015b60405180910390fd5b6001600160a01b038316608081905260408051637e062a3560e11b8152905163fc0c546a916004808201926020929091908290030181865afa1580156200013e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200016491906200065a565b6001600160a01b0390811660a0528216620001c25760405162461bcd60e51b815260206004820152601e60248201527f4f4654577261707065723a20696e76616c69642061676772656761746f7200006044820152606401620000ea565b600480546001600160a01b0319166001600160a01b038481169190911790915560805160a051620001f892169060001962000222565b600380546001600160a01b0319166001600160a01b03929092169190911790555062000736915050565b801580620002a05750604051636eb1769f60e11b81523060048201526001600160a01b03838116602483015284169063dd62ed3e90604401602060405180830381865afa15801562000278573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200029e91906200067f565b155b620003145760405162461bcd60e51b815260206004820152603660248201527f5361666545524332303a20617070726f76652066726f6d206e6f6e2d7a65726f60448201527f20746f206e6f6e2d7a65726f20616c6c6f77616e6365000000000000000000006064820152608401620000ea565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b0390811663095ea7b360e01b179091526200036c9185916200037116565b505050565b6040805180820190915260208082527f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c656490820152600090620003c0906001600160a01b03851690849062000445565b9050805160001480620003e4575080806020019051810190620003e4919062000699565b6200036c5760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6044820152691bdd081cdd58d8d9595960b21b6064820152608401620000ea565b60606200045684846000856200045e565b949350505050565b606082471015620004c15760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f6044820152651c8818d85b1b60d21b6064820152608401620000ea565b600080866001600160a01b03168587604051620004df9190620006e3565b60006040518083038185875af1925050503d80600081146200051e576040519150601f19603f3d011682016040523d82523d6000602084013e62000523565b606091505b509092509050620005378783838762000542565b979650505050505050565b60608315620005b6578251600003620005ae576001600160a01b0385163b620005ae5760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401620000ea565b508162000456565b620004568383815115620005cd5781518083602001fd5b8060405162461bcd60e51b8152600401620000ea919062000701565b80516001600160a01b03811681146200060157600080fd5b919050565b600080600080608085870312156200061d57600080fd5b845193506200062f60208601620005e9565b92506200063f60408601620005e9565b91506200064f60608601620005e9565b905092959194509250565b6000602082840312156200066d57600080fd5b6200067882620005e9565b9392505050565b6000602082840312156200069257600080fd5b5051919050565b600060208284031215620006ac57600080fd5b815180151581146200067857600080fd5b60005b83811015620006da578181015183820152602001620006c0565b50506000910152565b60008251620006f7818460208701620006bd565b9190910192915050565b602081526000825180602084015262000722816040850160208701620006bd565b601f01601f19169190910160400192915050565b60805160a05161179062000786600039600081816104190152610797015260008181610350015281816105490152818161068d015281816107d601528181610839015261099e01526117906000f3fe60806040526004361061015f5760003560e01c80638cfd8f5c116100c0578063ed5a0fc011610074578063f46901ed11610059578063f46901ed146103c7578063f9120af6146103e7578063fc0c546a1461040757600080fd5b8063ed5a0fc014610387578063f2fde38b146103a757600080fd5b806390ed2083116100a557806390ed20831461031e5780639b5215f61461033e578063b353aaa71461037257600080fd5b80638cfd8f5c146102de5780638da5cb5b146102fe57600080fd5b8063476343ee11610117578063558a7297116100fc578063558a7297146102765780636ee296c91461029657806376025ec9146102cb57600080fd5b8063476343ee1461024c5780634da38ad81461026357600080fd5b806321f3c9f21161014857806321f3c9f2146101e15780632362189a14610208578063245a7bfc1461022c57600080fd5b8063017e7e581461016457806313e7c9d8146101a1575b600080fd5b34801561017057600080fd5b50600354610184906001600160a01b031681565b6040516001600160a01b0390911681526020015b60405180910390f35b3480156101ad57600080fd5b506101d16101bc366004611182565b60016020526000908152604090205460ff1681565b6040519015158152602001610198565b3480156101ed57600080fd5b506006546101fb9060ff1681565b60405161019891906111d7565b34801561021457600080fd5b5061021e60055481565b604051908152602001610198565b34801561023857600080fd5b50600454610184906001600160a01b031681565b34801561025857600080fd5b5061026161043b565b005b6102616102713660046111fc565b6104fd565b34801561028257600080fd5b50610261610291366004611270565b6105e0565b3480156102a257600080fd5b506102b66102b13660046112a9565b610688565b60408051928352602083019190915201610198565b6102616102d93660046111fc565b610745565b3480156102ea57600080fd5b5061021e6102f936600461133d565b610815565b34801561030a57600080fd5b50600054610184906001600160a01b031681565b34801561032a57600080fd5b50610261610339366004611370565b6108b5565b34801561034a57600080fd5b506101847f000000000000000000000000000000000000000000000000000000000000000081565b34801561037e57600080fd5b5061018461099a565b34801561039357600080fd5b506102616103a2366004611391565b610a23565b3480156103b357600080fd5b506102616103c2366004611182565b610aad565b3480156103d357600080fd5b506102616103e2366004611182565b610b4e565b3480156103f357600080fd5b50610261610402366004611182565b610c27565b34801561041357600080fd5b506101847f000000000000000000000000000000000000000000000000000000000000000081565b60035460405147916000916001600160a01b039091169083908381818185875af1925050503d806000811461048c576040519150601f19603f3d011682016040523d82523d6000602084013e610491565b606091505b50509050806104b35760405163f5ef1ce360e01b815260040160405180910390fd5b600354604080516001600160a01b039092168252602082018490527febe72af9d0a9f9afca2ea0bada9230f49d3c9e86f4948f37097d108a49363d53910160405180910390a15050565b610505610d00565b600061050f610d57565b9050803410156105395760405163b621805960e01b81523460048201526024015b60405180910390fd5b600061054582346113c0565b90507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663695ef6bf8233898989896040518763ffffffff1660e01b815260040161059c9594939291906113fc565b6000604051808303818588803b1580156105b557600080fd5b505af11580156105c9573d6000803e3d6000fd5b505050505050506105da6001600255565b50505050565b6000546001600160a01b031633146106295760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610530565b6001600160a01b038216600081815260016020908152604091829020805460ff191685151590811790915591519182527f193de8d500b5cb7b720089b258a39e9c1d0b840019a73ae7c51c3f9101732b02910160405180910390a25050565b6000807f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663365260b4888888600089896040518763ffffffff1660e01b81526004016106e2969594939291906114b5565b6040805180830381865afa1580156106fe573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061072291906114f3565b909250905061072f610d57565b6107399083611517565b91509550959350505050565b61074d610d00565b6000610757610d57565b90508034101561077c5760405163b621805960e01b8152346004820152602401610530565b600061078882346113c0565b90506107bf6001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016333087610e7a565b60405163695ef6bf60e01b81526001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000169063695ef6bf90839061059c9030908b908b908b908b906004016113fc565b60405163233f63d760e21b815261ffff8084166004830152821660248201526000907f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031690638cfd8f5c90604401602060405180830381865afa158015610888573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108ac919061152a565b90505b92915050565b3360009081526001602052604090205460ff161580156108e057506000546001600160a01b03163314155b156108fe5760405163de19c8b360e01b815260040160405180910390fd5b60018160018111156109125761091261119f565b1115610933578060405163d05ccdf360e01b815260040161053091906111d7565b6006546040517f80e60928263e6642de6e8a1117b4f00062107c445212b88f6a02187940eccf2c9161096c9160ff909116908490611543565b60405180910390a16006805482919060ff1916600183818111156109925761099261119f565b021790555050565b60007f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663b353aaa76040518163ffffffff1660e01b8152600401602060405180830381865afa1580156109fa573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a1e919061155e565b905090565b3360009081526001602052604090205460ff16158015610a4e57506000546001600160a01b03163314155b15610a6c5760405163de19c8b360e01b815260040160405180910390fd5b60055460408051918252602082018390527f4c0bffc5595fd0c1705c52132244fdac73f66274c586f059483928f66e7b6d98910160405180910390a1600555565b6000546001600160a01b03163314610af65760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610530565b6000805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0383169081178255604051909133917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a350565b6000546001600160a01b03163314610b975760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610530565b6001600160a01b038116610bbe5760405163e6c4247b60e01b815260040160405180910390fd5b6003546040516001600160a01b038084169216907fbcf71d3ed47385ef899b4ae7d10b0da92fce93b66f947859b6b12c39faa6abba90600090a36003805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b3360009081526001602052604090205460ff16158015610c5257506000546001600160a01b03163314155b15610c705760405163de19c8b360e01b815260040160405180910390fd5b6001600160a01b038116610c975760405163e6c4247b60e01b815260040160405180910390fd5b6004546040516001600160a01b038084169216907f8e0352ee1de57032a7c8ddf4cb1daa3ff929d0a8534e42a124811b2fa033cccd90600090a36004805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b6002805403610d515760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c006044820152606401610530565b60028055565b60008060065460ff166001811115610d7157610d7161119f565b03610e735760048054604080516350d25bcd60e01b815290516001600160a01b03909216926350d25bcd9282820192602092908290030181865afa158015610dbd573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610de1919061152a565b600480546040805163313ce56760e01b815290516001600160a01b039092169263313ce5679282820192602092908290030181865afa158015610e28573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e4c919061157b565b610e5790600a611682565b610e6990670de0b6b3a7640000611691565b610a1e91906116a8565b5060055490565b604080516001600160a01b038581166024830152848116604483015260648083018590528351808403909101815260849092018352602080830180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff166323b872dd60e01b17905283518085019094528084527f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564908401526105da92879291600091610f27918516908490610fbf565b9050805160001480610f48575080806020019051810190610f4891906116ca565b610fba5760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e60448201527f6f742073756363656564000000000000000000000000000000000000000000006064820152608401610530565b505050565b6060610fce8484600085610fd8565b90505b9392505050565b6060824710156110505760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f60448201527f722063616c6c00000000000000000000000000000000000000000000000000006064820152608401610530565b600080866001600160a01b0316858760405161106c919061170b565b60006040518083038185875af1925050503d80600081146110a9576040519150601f19603f3d011682016040523d82523d6000602084013e6110ae565b606091505b50915091506110bf878383876110cc565b925050505b949350505050565b6060831561113b578251600003611134576001600160a01b0385163b6111345760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610530565b50816110c4565b6110c483838151156111505781518083602001fd5b8060405162461bcd60e51b81526004016105309190611727565b6001600160a01b038116811461117f57600080fd5b50565b60006020828403121561119457600080fd5b8135610fd18161116a565b634e487b7160e01b600052602160045260246000fd5b600281106111d357634e487b7160e01b600052602160045260246000fd5b9052565b602081016108af82846111b5565b803561ffff811681146111f757600080fd5b919050565b6000806000806080858703121561121257600080fd5b61121b856111e5565b93506020850135925060408501359150606085013567ffffffffffffffff81111561124557600080fd5b85016060818803121561125757600080fd5b939692955090935050565b801515811461117f57600080fd5b6000806040838503121561128357600080fd5b823561128e8161116a565b9150602083013561129e81611262565b809150509250929050565b6000806000806000608086880312156112c157600080fd5b6112ca866111e5565b94506020860135935060408601359250606086013567ffffffffffffffff808211156112f557600080fd5b818801915088601f83011261130957600080fd5b81358181111561131857600080fd5b89602082850101111561132a57600080fd5b9699959850939650602001949392505050565b6000806040838503121561135057600080fd5b611359836111e5565b9150611367602084016111e5565b90509250929050565b60006020828403121561138257600080fd5b813560028110610fd157600080fd5b6000602082840312156113a357600080fd5b5035919050565b634e487b7160e01b600052601160045260246000fd5b818103818111156108af576108af6113aa565b81835281816020850137506000828201602090810191909152601f909101601f19169091010190565b60006001600160a01b03808816835261ffff8716602084015285604084015284606084015260a0608084015283356114338161116a565b811660a084015260208401356114488161116a565b1660c0830152604083013536849003601e1901811261146657600080fd5b830160208101903567ffffffffffffffff81111561148357600080fd5b80360382131561149257600080fd5b606060e08501526114a8610100850182846113d3565b9998505050505050505050565b61ffff87168152856020820152846040820152831515606082015260a0608082015260006114e760a0830184866113d3565b98975050505050505050565b6000806040838503121561150657600080fd5b505080516020909101519092909150565b808201808211156108af576108af6113aa565b60006020828403121561153c57600080fd5b5051919050565b6040810161155182856111b5565b610fd160208301846111b5565b60006020828403121561157057600080fd5b8151610fd18161116a565b60006020828403121561158d57600080fd5b815160ff81168114610fd157600080fd5b600181815b808511156115d95781600019048211156115bf576115bf6113aa565b808516156115cc57918102915b93841c93908002906115a3565b509250929050565b6000826115f0575060016108af565b816115fd575060006108af565b8160018114611613576002811461161d57611639565b60019150506108af565b60ff84111561162e5761162e6113aa565b50506001821b6108af565b5060208310610133831016604e8410600b841016171561165c575081810a6108af565b611666838361159e565b806000190482111561167a5761167a6113aa565b029392505050565b60006108ac60ff8416836115e1565b80820281158282048414176108af576108af6113aa565b6000826116c557634e487b7160e01b600052601260045260246000fd5b500490565b6000602082840312156116dc57600080fd5b8151610fd181611262565b60005b838110156117025781810151838201526020016116ea565b50506000910152565b6000825161171d8184602087016116e7565b9190910192915050565b60208152600082518060208401526117468160408501602087016116e7565b601f01601f1916919091016040019291505056fea2646970667358221220c93f7b0d6c6e3603726266afa66e888a7609b25f29e168151e0f1c9646a68cc564736f6c634300081400330000000000000000000000000000000000000000000000001582b4c9a9db0000000000000000000000000000ca0d86afc25c57a6d2acdf331cabd4c9cee05533000000000000000000000000ab594600376ec9fd91f8e885dadf0ce036862de000000000000000000000000041186a5ff8f3b48f0ffc71a4cc958a997710daee

Deployed Bytecode

0x60806040526004361061015f5760003560e01c80638cfd8f5c116100c0578063ed5a0fc011610074578063f46901ed11610059578063f46901ed146103c7578063f9120af6146103e7578063fc0c546a1461040757600080fd5b8063ed5a0fc014610387578063f2fde38b146103a757600080fd5b806390ed2083116100a557806390ed20831461031e5780639b5215f61461033e578063b353aaa71461037257600080fd5b80638cfd8f5c146102de5780638da5cb5b146102fe57600080fd5b8063476343ee11610117578063558a7297116100fc578063558a7297146102765780636ee296c91461029657806376025ec9146102cb57600080fd5b8063476343ee1461024c5780634da38ad81461026357600080fd5b806321f3c9f21161014857806321f3c9f2146101e15780632362189a14610208578063245a7bfc1461022c57600080fd5b8063017e7e581461016457806313e7c9d8146101a1575b600080fd5b34801561017057600080fd5b50600354610184906001600160a01b031681565b6040516001600160a01b0390911681526020015b60405180910390f35b3480156101ad57600080fd5b506101d16101bc366004611182565b60016020526000908152604090205460ff1681565b6040519015158152602001610198565b3480156101ed57600080fd5b506006546101fb9060ff1681565b60405161019891906111d7565b34801561021457600080fd5b5061021e60055481565b604051908152602001610198565b34801561023857600080fd5b50600454610184906001600160a01b031681565b34801561025857600080fd5b5061026161043b565b005b6102616102713660046111fc565b6104fd565b34801561028257600080fd5b50610261610291366004611270565b6105e0565b3480156102a257600080fd5b506102b66102b13660046112a9565b610688565b60408051928352602083019190915201610198565b6102616102d93660046111fc565b610745565b3480156102ea57600080fd5b5061021e6102f936600461133d565b610815565b34801561030a57600080fd5b50600054610184906001600160a01b031681565b34801561032a57600080fd5b50610261610339366004611370565b6108b5565b34801561034a57600080fd5b506101847f000000000000000000000000ca0d86afc25c57a6d2acdf331cabd4c9cee0553381565b34801561037e57600080fd5b5061018461099a565b34801561039357600080fd5b506102616103a2366004611391565b610a23565b3480156103b357600080fd5b506102616103c2366004611182565b610aad565b3480156103d357600080fd5b506102616103e2366004611182565b610b4e565b3480156103f357600080fd5b50610261610402366004611182565b610c27565b34801561041357600080fd5b506101847f00000000000000000000000049a0400587a7f65072c87c4910449fdcc5c4724281565b60035460405147916000916001600160a01b039091169083908381818185875af1925050503d806000811461048c576040519150601f19603f3d011682016040523d82523d6000602084013e610491565b606091505b50509050806104b35760405163f5ef1ce360e01b815260040160405180910390fd5b600354604080516001600160a01b039092168252602082018490527febe72af9d0a9f9afca2ea0bada9230f49d3c9e86f4948f37097d108a49363d53910160405180910390a15050565b610505610d00565b600061050f610d57565b9050803410156105395760405163b621805960e01b81523460048201526024015b60405180910390fd5b600061054582346113c0565b90507f000000000000000000000000ca0d86afc25c57a6d2acdf331cabd4c9cee055336001600160a01b031663695ef6bf8233898989896040518763ffffffff1660e01b815260040161059c9594939291906113fc565b6000604051808303818588803b1580156105b557600080fd5b505af11580156105c9573d6000803e3d6000fd5b505050505050506105da6001600255565b50505050565b6000546001600160a01b031633146106295760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610530565b6001600160a01b038216600081815260016020908152604091829020805460ff191685151590811790915591519182527f193de8d500b5cb7b720089b258a39e9c1d0b840019a73ae7c51c3f9101732b02910160405180910390a25050565b6000807f000000000000000000000000ca0d86afc25c57a6d2acdf331cabd4c9cee055336001600160a01b031663365260b4888888600089896040518763ffffffff1660e01b81526004016106e2969594939291906114b5565b6040805180830381865afa1580156106fe573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061072291906114f3565b909250905061072f610d57565b6107399083611517565b91509550959350505050565b61074d610d00565b6000610757610d57565b90508034101561077c5760405163b621805960e01b8152346004820152602401610530565b600061078882346113c0565b90506107bf6001600160a01b037f00000000000000000000000049a0400587a7f65072c87c4910449fdcc5c4724216333087610e7a565b60405163695ef6bf60e01b81526001600160a01b037f000000000000000000000000ca0d86afc25c57a6d2acdf331cabd4c9cee05533169063695ef6bf90839061059c9030908b908b908b908b906004016113fc565b60405163233f63d760e21b815261ffff8084166004830152821660248201526000907f000000000000000000000000ca0d86afc25c57a6d2acdf331cabd4c9cee055336001600160a01b031690638cfd8f5c90604401602060405180830381865afa158015610888573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108ac919061152a565b90505b92915050565b3360009081526001602052604090205460ff161580156108e057506000546001600160a01b03163314155b156108fe5760405163de19c8b360e01b815260040160405180910390fd5b60018160018111156109125761091261119f565b1115610933578060405163d05ccdf360e01b815260040161053091906111d7565b6006546040517f80e60928263e6642de6e8a1117b4f00062107c445212b88f6a02187940eccf2c9161096c9160ff909116908490611543565b60405180910390a16006805482919060ff1916600183818111156109925761099261119f565b021790555050565b60007f000000000000000000000000ca0d86afc25c57a6d2acdf331cabd4c9cee055336001600160a01b031663b353aaa76040518163ffffffff1660e01b8152600401602060405180830381865afa1580156109fa573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a1e919061155e565b905090565b3360009081526001602052604090205460ff16158015610a4e57506000546001600160a01b03163314155b15610a6c5760405163de19c8b360e01b815260040160405180910390fd5b60055460408051918252602082018390527f4c0bffc5595fd0c1705c52132244fdac73f66274c586f059483928f66e7b6d98910160405180910390a1600555565b6000546001600160a01b03163314610af65760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610530565b6000805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0383169081178255604051909133917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a350565b6000546001600160a01b03163314610b975760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610530565b6001600160a01b038116610bbe5760405163e6c4247b60e01b815260040160405180910390fd5b6003546040516001600160a01b038084169216907fbcf71d3ed47385ef899b4ae7d10b0da92fce93b66f947859b6b12c39faa6abba90600090a36003805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b3360009081526001602052604090205460ff16158015610c5257506000546001600160a01b03163314155b15610c705760405163de19c8b360e01b815260040160405180910390fd5b6001600160a01b038116610c975760405163e6c4247b60e01b815260040160405180910390fd5b6004546040516001600160a01b038084169216907f8e0352ee1de57032a7c8ddf4cb1daa3ff929d0a8534e42a124811b2fa033cccd90600090a36004805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b6002805403610d515760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c006044820152606401610530565b60028055565b60008060065460ff166001811115610d7157610d7161119f565b03610e735760048054604080516350d25bcd60e01b815290516001600160a01b03909216926350d25bcd9282820192602092908290030181865afa158015610dbd573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610de1919061152a565b600480546040805163313ce56760e01b815290516001600160a01b039092169263313ce5679282820192602092908290030181865afa158015610e28573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e4c919061157b565b610e5790600a611682565b610e6990670de0b6b3a7640000611691565b610a1e91906116a8565b5060055490565b604080516001600160a01b038581166024830152848116604483015260648083018590528351808403909101815260849092018352602080830180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff166323b872dd60e01b17905283518085019094528084527f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564908401526105da92879291600091610f27918516908490610fbf565b9050805160001480610f48575080806020019051810190610f4891906116ca565b610fba5760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e60448201527f6f742073756363656564000000000000000000000000000000000000000000006064820152608401610530565b505050565b6060610fce8484600085610fd8565b90505b9392505050565b6060824710156110505760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f60448201527f722063616c6c00000000000000000000000000000000000000000000000000006064820152608401610530565b600080866001600160a01b0316858760405161106c919061170b565b60006040518083038185875af1925050503d80600081146110a9576040519150601f19603f3d011682016040523d82523d6000602084013e6110ae565b606091505b50915091506110bf878383876110cc565b925050505b949350505050565b6060831561113b578251600003611134576001600160a01b0385163b6111345760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610530565b50816110c4565b6110c483838151156111505781518083602001fd5b8060405162461bcd60e51b81526004016105309190611727565b6001600160a01b038116811461117f57600080fd5b50565b60006020828403121561119457600080fd5b8135610fd18161116a565b634e487b7160e01b600052602160045260246000fd5b600281106111d357634e487b7160e01b600052602160045260246000fd5b9052565b602081016108af82846111b5565b803561ffff811681146111f757600080fd5b919050565b6000806000806080858703121561121257600080fd5b61121b856111e5565b93506020850135925060408501359150606085013567ffffffffffffffff81111561124557600080fd5b85016060818803121561125757600080fd5b939692955090935050565b801515811461117f57600080fd5b6000806040838503121561128357600080fd5b823561128e8161116a565b9150602083013561129e81611262565b809150509250929050565b6000806000806000608086880312156112c157600080fd5b6112ca866111e5565b94506020860135935060408601359250606086013567ffffffffffffffff808211156112f557600080fd5b818801915088601f83011261130957600080fd5b81358181111561131857600080fd5b89602082850101111561132a57600080fd5b9699959850939650602001949392505050565b6000806040838503121561135057600080fd5b611359836111e5565b9150611367602084016111e5565b90509250929050565b60006020828403121561138257600080fd5b813560028110610fd157600080fd5b6000602082840312156113a357600080fd5b5035919050565b634e487b7160e01b600052601160045260246000fd5b818103818111156108af576108af6113aa565b81835281816020850137506000828201602090810191909152601f909101601f19169091010190565b60006001600160a01b03808816835261ffff8716602084015285604084015284606084015260a0608084015283356114338161116a565b811660a084015260208401356114488161116a565b1660c0830152604083013536849003601e1901811261146657600080fd5b830160208101903567ffffffffffffffff81111561148357600080fd5b80360382131561149257600080fd5b606060e08501526114a8610100850182846113d3565b9998505050505050505050565b61ffff87168152856020820152846040820152831515606082015260a0608082015260006114e760a0830184866113d3565b98975050505050505050565b6000806040838503121561150657600080fd5b505080516020909101519092909150565b808201808211156108af576108af6113aa565b60006020828403121561153c57600080fd5b5051919050565b6040810161155182856111b5565b610fd160208301846111b5565b60006020828403121561157057600080fd5b8151610fd18161116a565b60006020828403121561158d57600080fd5b815160ff81168114610fd157600080fd5b600181815b808511156115d95781600019048211156115bf576115bf6113aa565b808516156115cc57918102915b93841c93908002906115a3565b509250929050565b6000826115f0575060016108af565b816115fd575060006108af565b8160018114611613576002811461161d57611639565b60019150506108af565b60ff84111561162e5761162e6113aa565b50506001821b6108af565b5060208310610133831016604e8410600b841016171561165c575081810a6108af565b611666838361159e565b806000190482111561167a5761167a6113aa565b029392505050565b60006108ac60ff8416836115e1565b80820281158282048414176108af576108af6113aa565b6000826116c557634e487b7160e01b600052601260045260246000fd5b500490565b6000602082840312156116dc57600080fd5b8151610fd181611262565b60005b838110156117025781810151838201526020016116ea565b50506000910152565b6000825161171d8184602087016116e7565b9190910192915050565b60208152600082518060208401526117468160408501602087016116e7565b601f01601f1916919091016040019291505056fea2646970667358221220c93f7b0d6c6e3603726266afa66e888a7609b25f29e168151e0f1c9646a68cc564736f6c63430008140033

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

0000000000000000000000000000000000000000000000001582b4c9a9db0000000000000000000000000000ca0d86afc25c57a6d2acdf331cabd4c9cee05533000000000000000000000000ab594600376ec9fd91f8e885dadf0ce036862de000000000000000000000000041186a5ff8f3b48f0ffc71a4cc958a997710daee

-----Decoded View---------------
Arg [0] : _defaultExchangeRate (uint256): 1550000000000000000
Arg [1] : _oft (address): 0xca0d86afc25c57a6d2aCdf331CaBd4C9CEE05533
Arg [2] : _aggregator (address): 0xAB594600376Ec9fD91F8e885dADF0CE036862dE0
Arg [3] : _multisig (address): 0x41186A5ff8F3b48f0FFc71A4cc958A997710DAeE

-----Encoded View---------------
4 Constructor Arguments found :
Arg [0] : 0000000000000000000000000000000000000000000000001582b4c9a9db0000
Arg [1] : 000000000000000000000000ca0d86afc25c57a6d2acdf331cabd4c9cee05533
Arg [2] : 000000000000000000000000ab594600376ec9fd91f8e885dadf0ce036862de0
Arg [3] : 00000000000000000000000041186a5ff8f3b48f0ffc71a4cc958a997710daee


Block Transaction 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
[ 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.