3000+ Slots, 20+ Cryptos, 75K Raffle, Sports Promos - World's largest Crypto Casino & Sportsbook - Provably Fair!
Play in crypto to make deposits and withdrawals easy! Register and get a free daily shot at a 100 000 $ jackpot.
Monthly Wagering Contest - $500,000+ rewards. Provably Fair, Low House Edge and best VIP Program!
Daily free Spin 50000 Matic ,760% Deposit Bonus, 20%Rakeback, And Get 1000000 Matic free bonus on BC.Game
Deposit BONUS 300% and Cashbacks. without verification!
Join Metawin for the ultimate Web3 Casino Experience. FrictionlessĀ Signup & InstantĀ Withdrawals. Play Now & Earn $MWIN Points.
Overview
POL Balance
POL Value
$0.96 (@ $0.36/POL)Token Holdings
Could not find any matches!
- ERC-20 Tokens (65)322.79614261 POLPolygon Toke... (POL)$117.25@0.363215,000 WPOL [ POL-MAT.COM ] Visit to claim reward! (WPOL [...)43,767 AAVE [ACCESS AAVE.ASIA]! AAVE.asia (AAVE [...)100 AIAPEAIApe Coin (AIAPE)155 BABYANDYBabyandy (BABYAN...)10,000 BOSQUEBOSQUE (BOSQUE)20 CODOGECoDoge (CODOGE)0.00000892 MIMMagic Intern... (MIM)0.1 COSMetaCos (COS)10,000 $mPEPE Š”LŠlŠ ā· mpepe.comPEPE ($mPEPE...)10,000 $mPEPE Š”LŠlŠ ā· mpepe.comPEPE ($mPEPE...)10,000 PAAMGAMING.COM GET THE POINTS NOWParam (PAAMGA...)100 POLYCRABPolyCrab (POLYCR...)44.731106 SIMSimba Empire888ERC20 ***200 WGCWild Goat Coin$0.01@0.000180,000 Pepe-erc.vipYou Earned $... (Pepe-e...)0.322 pZCXZEN Exchange Token$0.03@0.081110,000 ZIKTOKEN.COM-AIRDROPSWAPZkash (ZIKTOK...)9,543 TokenERC-20 TOKEN*[Suspicious]989 TokenERC-20 TOKEN*[Suspicious]1 TokenERC-20 TOKEN*[Suspicious]1 TokenERC-20 TOKEN*[Suspicious]1 TokenERC-20 TOKEN*[Suspicious]1 TokenERC-20 TOKEN*[Suspicious]1 TokenERC-20 TOKEN*[Suspicious]1 TokenERC-20 TOKEN*[Suspicious]10,000 TokenERC-20 TOKEN*[Suspicious]10,000 TokenERC-20 TOKEN*[Suspicious]10,000 TokenERC-20 TOKEN*[Suspicious]10,000 TokenERC-20 TOKEN*[Suspicious]10,000 TokenERC-20 TOKEN*[Suspicious]10,000 TokenERC-20 TOKEN*[Suspicious]10,000 TokenERC-20 TOKEN*[Unsafe]10,000 TokenERC-20 TOKEN*[Unsafe]10,000 TokenERC-20 TOKEN*[Unsafe]1,250 TokenERC-20 TOKEN*[Spam]1,250 TokenERC-20 TOKEN*[Spam]1,250 TokenERC-20 TOKEN*[Spam]1,250 TokenERC-20 TOKEN*[Spam]1,250 TokenERC-20 TOKEN*[Spam]8,400 TokenERC-20 TOKEN*[Spam]4,376 TokenERC-20 TOKEN*[Spam]956 TokenERC-20 TOKEN*[Spam]900,000,000,000,000 TokenERC-20 TOKEN*[Spam]9,000,000,000 TokenERC-20 TOKEN*[Spam]1 TokenERC-20 TOKEN*[Spam]1 TokenERC-20 TOKEN*[Spam]1 TokenERC-20 TOKEN*[Spam]1 TokenERC-20 TOKEN*[Spam]1 TokenERC-20 TOKEN*[Spam]1 TokenERC-20 TOKEN*[Spam]1 TokenERC-20 TOKEN*[Spam]1 TokenERC-20 TOKEN*[Spam]1 TokenERC-20 TOKEN*[Spam]1 TokenERC-20 TOKEN*[Spam]1 TokenERC-20 TOKEN*[Spam]40 TokenERC-20 TOKEN*[Spam]1 TokenERC-20 TOKEN*[Spam]1 TokenERC-20 TOKEN*[Spam]88,888 TokenERC-20 TOKEN*[Spam]10,000 TokenERC-20 TOKEN*[Spam]777 TokenERC-20 TOKEN*[Spam]7,777 TokenERC-20 TOKEN*[Spam]1 TokenERC-20 TOKEN*[Spam]NFT Tokens (24)GIVEAWAY$100,000,000ERC-11551000-rewards.xyz1000$ AirDropERC-1155NFTVoucher5000$ CYBERERC-1155AAVE-V3-POSAave Positions AirdropERC-1155UNI-V3-PoSUniswap V3 Positions NFT-V1ERC-1155UNI-V3-PoSUniswap V3 Positions NFT-V1ERC-1155UNI-V3-PoSUniswap V3 Positions NFT-V1ERC-1155ERC-1155 TOKEN*[Suspicious]ERC-1155 TOKEN*[Suspicious]ERC-1155 TOKEN*[Suspicious]ERC-1155 TOKEN*[Spam]ERC-1155 TOKEN*[Spam]ERC-1155 TOKEN*[Spam]ERC-1155 TOKEN*[Spam]ERC-1155 TOKEN*[Spam]
- Transactions
- Internal Transactions
- Token Transfers (ERC-20)
- NFT Transfers
- Contract
- Events
- Multichain Portfolio
Advanced Filter- Filter by Tx Type:
- Tx
- Internal Tx
- ERC-20
- NFTs
Latest 25 from a total of 5,370 transactions
Transaction Hash MethodBlockFromToSend Proxy OFTV2 62536858 2024-10-02 9:46:26 11 days ago 1727862386 IN 3.34098399 POL$1.21 0.00827922 30.00000009 Withdraw Fees 62503501 2024-10-01 13:57:00 12 days ago 1727791020 IN 0 POL$0.00 0.00133956 32.99995393 Send Proxy OFTV2 61407156 2024-09-04 8:34:52 39 days ago 1725438892 IN 3.27329324 POL$1.19 0.01020749 36.98875217 Send Proxy OFTV2 59415787 2024-07-16 4:30:26 89 days ago 1721104226 IN 2.35019695 POL$0.85 0.00836743 30.01382228 Withdraw Fees 59392035 2024-07-15 14:05:37 90 days ago 1721052337 IN 0 POL$0.00 0.00146147 36.00313172 Send Proxy OFTV2 58346157 2024-06-19 10:25:53 116 days ago 1718792753 IN 2.34674172 POL$0.85 0.02007695 70.29968683 Send Proxy OFTV2 58305297 2024-06-18 9:29:56 117 days ago 1718702996 IN 1.95028375 POL$0.71 0.01489847 51 Send Proxy OFTV2 57255944 2024-05-22 10:14:58 144 days ago 1716372898 IN 2.73552717 POL$0.99 0.00872157 30.00001044 Send Proxy OFTV2 57189311 2024-05-20 15:52:09 146 days ago 1716220329 IN 2.1932784 POL$0.80 0.0091797 33.32342276 Send Proxy OFTV2 57047710 2024-05-16 21:38:14 149 days ago 1715895494 IN 1.51910106 POL$0.55 0.01072873 38 Send Proxy OFTV2 56830392 2024-05-11 5:46:29 155 days ago 1715406389 IN 1.56490622 POL$0.57 0.0103672 36.3 Send Proxy OFTV2 56795658 2024-05-10 8:57:15 156 days ago 1715331435 IN 2.17624323 POL$0.79 0.00827067 30.00000008 Send Proxy OFTV2 56792740 2024-05-10 7:13:13 156 days ago 1715325193 IN 1.94301757 POL$0.71 0.00848877 30.00000007 Send Proxy OFTV2 56784488 2024-05-10 2:17:44 156 days ago 1715307464 IN 1.86080148 POL$0.68 0.00919241 33 Send Proxy OFTV2 56754287 2024-05-09 7:59:37 157 days ago 1715241577 IN 1.56224891 POL$0.57 0.01456835 51.01 Send Proxy OFTV2 56707505 2024-05-08 3:21:19 158 days ago 1715138479 IN 1.53434805 POL$0.56 0.01000164 35.02 Send Proxy OFTV2 56676150 2024-05-07 8:04:08 159 days ago 1715069048 IN 1.50974843 POL$0.55 0.01402462 49.75 Send Proxy OFTV2 56676141 2024-05-07 8:03:48 159 days ago 1715069028 IN 1.50824946 POL$0.55 0.0142085 49.75 Send Proxy OFTV2 56665286 2024-05-07 1:34:56 159 days ago 1715045696 IN 1.49437049 POL$0.54 0.00863406 30.00000005 Send Proxy OFTV2 56588873 2024-05-05 1:48:13 161 days ago 1714873693 IN 1.6572044 POL$0.60 0.00827274 30.00000033 Send Proxy OFTV2 56530042 2024-05-03 12:32:40 163 days ago 1714739560 IN 2.22641042 POL$0.81 0.00899236 32.05959442 Send Proxy OFTV2 56530025 2024-05-03 12:32:04 163 days ago 1714739524 IN 2.22256822 POL$0.81 0.00578832 97.00240341 Send Proxy OFTV2 56530023 2024-05-03 12:32:00 163 days ago 1714739520 IN 2.22256822 POL$0.81 0.02822868 99.63778821 Send Proxy OFTV2 56527281 2024-05-03 10:35:26 163 days ago 1714732526 IN 2.1421697 POL$0.78 0.00857442 30.0000003 Send Proxy OFTV2 56523977 2024-05-03 8:17:18 163 days ago 1714724238 IN 2.14766216 POL$0.78 0.00857406 30.00000034 Latest 25 internal transactions (View All)
Parent Transaction Hash Block From To 62536858 2024-10-02 9:46:26 11 days ago 1727862386 0.70132303 POL$0.25 62503501 2024-10-01 13:57:00 12 days ago 1727791020 4.47123947 POL$1.63 61407156 2024-09-04 8:34:52 39 days ago 1725438892 0.62849028 POL$0.23 59415787 2024-07-16 4:30:26 89 days ago 1721104226 0.52376044 POL$0.19 59392035 2024-07-15 14:05:37 90 days ago 1721052337 568.75015423 POL$206.74 58346157 2024-06-19 10:25:53 116 days ago 1718792753 0.60266721 POL$0.22 58305297 2024-06-18 9:29:56 117 days ago 1718702996 0.14180272 POL$0.05 57255944 2024-05-22 10:14:58 144 days ago 1716372898 1.35675339 POL$0.49 57189311 2024-05-20 15:52:09 146 days ago 1716220329 0.74395553 POL$0.27 57047710 2024-05-16 21:38:14 149 days ago 1715895494 0.06464812 POL$0.02 56830392 2024-05-11 5:46:29 155 days ago 1715406389 0.09655953 POL$0.04 56795658 2024-05-10 8:57:15 156 days ago 1715331435 0.74372343 POL$0.27 56792740 2024-05-10 7:13:13 156 days ago 1715325193 0.51120653 POL$0.19 56784488 2024-05-10 2:17:44 156 days ago 1715307464 0.42168432 POL$0.15 56754287 2024-05-09 7:59:37 157 days ago 1715241577 0.09651652 POL$0.04 56707505 2024-05-08 3:21:19 158 days ago 1715138479 0.08769839 POL$0.03 56676150 2024-05-07 8:04:08 159 days ago 1715069048 0.08783966 POL$0.03 56676141 2024-05-07 8:03:48 159 days ago 1715069028 0.0878066 POL$0.03 56665286 2024-05-07 1:34:56 159 days ago 1715045696 0.08759361 POL$0.03 56588873 2024-05-05 1:48:13 161 days ago 1714873693 0.27479767 POL$0.10 56530042 2024-05-03 12:32:40 163 days ago 1714739560 0.85032676 POL$0.31 56530023 2024-05-03 12:32:00 163 days ago 1714739520 0.84813561 POL$0.31 56527281 2024-05-03 10:35:26 163 days ago 1714732526 0.75391023 POL$0.27 56523977 2024-05-03 8:17:18 163 days ago 1714724238 0.75411245 POL$0.27 56523967 2024-05-03 8:16:36 163 days ago 1714724196 0.7534318 POL$0.27 Loading...LoadingContract Name:OFTWrapper
Compiler Versionv0.8.20+commit.a1b79de6
Optimization Enabled:Yes with 800 runs
Other Settings:default evmVersionContract Source Code (Solidity Standard Json-Input format)
// 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); } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.9.0) (security/ReentrancyGuard.sol) pragma solidity ^0.8.0; /** * @dev Contract module that helps prevent reentrant calls to a function. * * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier * available, which can be applied to functions to make sure there are no nested * (reentrant) calls to them. * * Note that because there is a single `nonReentrant` guard, functions marked as * `nonReentrant` may not call one another. This can be worked around by making * those functions `private`, and then adding `external` `nonReentrant` entry * points to them. * * TIP: If you would like to learn more about reentrancy and alternative ways * to protect against it, check out our blog post * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul]. */ abstract contract ReentrancyGuard { // Booleans are more expensive than uint256 or any type that takes up a full // word because each write operation emits an extra SLOAD to first read the // slot's contents, replace the bits taken up by the boolean, and then write // back. This is the compiler's defense against contract upgrades and // pointer aliasing, and it cannot be disabled. // The values being non-zero value makes deployment a bit more expensive, // but in exchange the refund on every call to nonReentrant will be lower in // amount. Since refunds are capped to a percentage of the total // transaction's gas, it is best to keep them low in cases like this one, to // increase the likelihood of the full refund coming into effect. uint256 private constant _NOT_ENTERED = 1; uint256 private constant _ENTERED = 2; uint256 private _status; constructor() { _status = _NOT_ENTERED; } /** * @dev Prevents a contract from calling itself, directly or indirectly. * Calling a `nonReentrant` function from another `nonReentrant` * function is not supported. It is possible to prevent this from happening * by making the `nonReentrant` function external, and making it call a * `private` function that does the actual work. */ modifier nonReentrant() { _nonReentrantBefore(); _; _nonReentrantAfter(); } function _nonReentrantBefore() private { // On the first call to nonReentrant, _status will be _NOT_ENTERED require(_status != _ENTERED, "ReentrancyGuard: reentrant call"); // Any calls to nonReentrant after this point will fail _status = _ENTERED; } function _nonReentrantAfter() private { // By storing the original value once again, a refund is triggered (see // https://eips.ethereum.org/EIPS/eip-2200) _status = _NOT_ENTERED; } /** * @dev Returns true if the reentrancy guard is currently set to "entered", which indicates there is a * `nonReentrant` function in the call stack. */ function _reentrancyGuardEntered() internal view returns (bool) { return _status == _ENTERED; } }
// SPDX-License-Identifier: MIT pragma solidity >=0.8.0; import "solmate/auth/Owned.sol"; /// @title OperatableV2 /// @notice OperatableV2 is a contract that allows operator management. /// The difference with OperatableV1 apart from using solmate `Owned` vs `BoringOwnable` is that /// the constructor is taking in the owner except of using msg.sender. /// This allows ensuring that the owner is right one. /// For example, when deploying from a CREATE2 factory, the msg.sender would the factory address /// which is usually not what we want. contract OperatableV2 is Owned { event OperatorChanged(address indexed, bool); error NotAllowedOperator(); mapping(address => bool) public operators; constructor(address _owner) Owned(_owner) {} 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); } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.9.0) (token/ERC20/utils/SafeERC20.sol) pragma solidity ^0.8.0; import "../IERC20.sol"; import "../extensions/IERC20Permit.sol"; import "../../../utils/Address.sol"; /** * @title SafeERC20 * @dev Wrappers around ERC20 operations that throw on failure (when the token * contract returns false). Tokens that return no value (and instead revert or * throw on failure) are also supported, non-reverting calls are assumed to be * successful. * To use this library you can add a `using SafeERC20 for IERC20;` statement to your contract, * which allows you to call the safe operations as `token.safeTransfer(...)`, etc. */ library SafeERC20 { using Address for address; /** * @dev Transfer `value` amount of `token` from the calling contract to `to`. If `token` returns no value, * non-reverting calls are assumed to be successful. */ function safeTransfer(IERC20 token, address to, uint256 value) internal { _callOptionalReturn(token, abi.encodeWithSelector(token.transfer.selector, to, value)); } /** * @dev Transfer `value` amount of `token` from `from` to `to`, spending the approval given by `from` to the * calling contract. If `token` returns no value, non-reverting calls are assumed to be successful. */ function safeTransferFrom(IERC20 token, address from, address to, uint256 value) internal { _callOptionalReturn(token, abi.encodeWithSelector(token.transferFrom.selector, from, to, value)); } /** * @dev Deprecated. This function has issues similar to the ones found in * {IERC20-approve}, and its usage is discouraged. * * Whenever possible, use {safeIncreaseAllowance} and * {safeDecreaseAllowance} instead. */ function safeApprove(IERC20 token, address spender, uint256 value) internal { // safeApprove should only be called when setting an initial allowance, // or when resetting it to zero. To increase and decrease it, use // 'safeIncreaseAllowance' and 'safeDecreaseAllowance' require( (value == 0) || (token.allowance(address(this), spender) == 0), "SafeERC20: approve from non-zero to non-zero allowance" ); _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, value)); } /** * @dev Increase the calling contract's allowance toward `spender` by `value`. If `token` returns no value, * non-reverting calls are assumed to be successful. */ function safeIncreaseAllowance(IERC20 token, address spender, uint256 value) internal { uint256 oldAllowance = token.allowance(address(this), spender); _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, oldAllowance + value)); } /** * @dev Decrease the calling contract's allowance toward `spender` by `value`. If `token` returns no value, * non-reverting calls are assumed to be successful. */ function safeDecreaseAllowance(IERC20 token, address spender, uint256 value) internal { unchecked { uint256 oldAllowance = token.allowance(address(this), spender); require(oldAllowance >= value, "SafeERC20: decreased allowance below zero"); _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, oldAllowance - value)); } } /** * @dev Set the calling contract's allowance toward `spender` to `value`. If `token` returns no value, * non-reverting calls are assumed to be successful. Compatible with tokens that require the approval to be set to * 0 before setting it to a non-zero value. */ function forceApprove(IERC20 token, address spender, uint256 value) internal { bytes memory approvalCall = abi.encodeWithSelector(token.approve.selector, spender, value); if (!_callOptionalReturnBool(token, approvalCall)) { _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, 0)); _callOptionalReturn(token, approvalCall); } } /** * @dev Use a ERC-2612 signature to set the `owner` approval toward `spender` on `token`. * Revert on invalid signature. */ function safePermit( IERC20Permit token, address owner, address spender, uint256 value, uint256 deadline, uint8 v, bytes32 r, bytes32 s ) internal { uint256 nonceBefore = token.nonces(owner); token.permit(owner, spender, value, deadline, v, r, s); uint256 nonceAfter = token.nonces(owner); require(nonceAfter == nonceBefore + 1, "SafeERC20: permit did not succeed"); } /** * @dev Imitates a Solidity high-level call (i.e. a regular function call to a contract), relaxing the requirement * on the return value: the return value is optional (but if data is returned, it must not be false). * @param token The token targeted by the call. * @param data The call data (encoded using abi.encode or one of its variants). */ function _callOptionalReturn(IERC20 token, bytes memory data) private { // We need to perform a low level call here, to bypass Solidity's return data size checking mechanism, since // we're implementing it ourselves. We use {Address-functionCall} to perform this call, which verifies that // the target address contains contract code and also asserts for success in the low-level call. bytes memory returndata = address(token).functionCall(data, "SafeERC20: low-level call failed"); require(returndata.length == 0 || abi.decode(returndata, (bool)), "SafeERC20: ERC20 operation did not succeed"); } /** * @dev Imitates a Solidity high-level call (i.e. a regular function call to a contract), relaxing the requirement * on the return value: the return value is optional (but if data is returned, it must not be false). * @param token The token targeted by the call. * @param data The call data (encoded using abi.encode or one of its variants). * * This is a variant of {_callOptionalReturn} that silents catches all reverts and returns a bool instead. */ function _callOptionalReturnBool(IERC20 token, bytes memory data) private returns (bool) { // We need to perform a low level call here, to bypass Solidity's return data size checking mechanism, since // we're implementing it ourselves. We cannot use {Address-functionCall} here since this should return false // and not revert is the subcall reverts. (bool success, bytes memory returndata) = address(token).call(data); return success && (returndata.length == 0 || abi.decode(returndata, (bool))) && Address.isContract(address(token)); } }
// SPDX-License-Identifier: MIT pragma solidity >=0.8.0; import "interfaces/ILzCommonOFT.sol"; /** * @dev Interface of the IOFT core standard */ interface ILzOFTV2 is ILzCommonOFT { /** * @dev send `_amount` amount of token to (`_dstChainId`, `_toAddress`) from `_from` * `_from` the owner of token * `_dstChainId` the destination chain identifier * `_toAddress` can be any size depending on the `dstChainId`. * `_amount` the quantity of tokens in wei * `_refundAddress` the address LayerZero refunds if too much message fee is sent * `_zroPaymentAddress` set to address(0x0) if not paying in ZRO (LayerZero Token) * `_adapterParams` is a flexible bytes array to indicate messaging adapter services */ function sendFrom( address _from, uint16 _dstChainId, bytes32 _toAddress, uint _amount, LzCallParams calldata _callParams ) external payable; function sendAndCall( address _from, uint16 _dstChainId, bytes32 _toAddress, uint _amount, bytes calldata _payload, uint64 _dstGasForCall, LzCallParams calldata _callParams ) external payable; }
// SPDX-License-Identifier: MIT pragma solidity >=0.8.0; import "interfaces/ILzCommonOFT.sol"; import "interfaces/IAggregator.sol"; interface IOFTWrapper { event LogWrapperFeeWithdrawn(address to, uint256 amount); event LogDefaultExchangeRateChanged(uint256 oldExchangeRate, uint256 newExchangeRate); event LogOracleImplementationChange(IAggregator indexed oldOracle, IAggregator indexed newOracle); event LogDefaultQuoteTypeChanged(QUOTE_TYPE oldValue, QUOTE_TYPE newValue); event LogFeeToChange(address indexed oldAddress, address indexed newAddress); enum QUOTE_TYPE { ORACLE, FIXED_EXCHANGE_RATE } function sendOFTV2( uint16 _dstChainId, bytes32 _toAddress, uint _amount, ILzCommonOFT.LzCallParams calldata _callParams ) external payable; function sendProxyOFTV2( uint16 _dstChainId, bytes32 _toAddress, uint _amount, ILzCommonOFT.LzCallParams calldata _callParams ) external payable; function estimateSendFeeV2( uint16 _dstChainId, bytes32 _toAddress, uint _amount, bytes calldata _adapterParams ) external view returns (uint nativeFee, uint zroFee); }
// SPDX-License-Identifier: MIT pragma solidity >=0.8.0; import "interfaces/ILzEndpoint.sol"; interface ILzApp { function lzReceive(uint16 _srcChainId, bytes calldata _srcAddress, uint64 _nonce, bytes calldata _payload) external; function minDstGasLookup(uint16 _srcChainId, uint16 _dstChainId) external view returns (uint); function trustedRemoteLookup(uint16 _srcChainId) external view returns (bytes memory); function lzEndpoint() external view returns (ILzEndpoint); }
// SPDX-License-Identifier: AGPL-3.0-only pragma solidity >=0.8.0; /// @notice Simple single owner authorization mixin. /// @author Solmate (https://github.com/transmissions11/solmate/blob/main/src/auth/Owned.sol) abstract contract Owned { /*////////////////////////////////////////////////////////////// EVENTS //////////////////////////////////////////////////////////////*/ event OwnershipTransferred(address indexed user, address indexed newOwner); /*////////////////////////////////////////////////////////////// OWNERSHIP STORAGE //////////////////////////////////////////////////////////////*/ address public owner; modifier onlyOwner() virtual { require(msg.sender == owner, "UNAUTHORIZED"); _; } /*////////////////////////////////////////////////////////////// CONSTRUCTOR //////////////////////////////////////////////////////////////*/ constructor(address _owner) { owner = _owner; emit OwnershipTransferred(address(0), _owner); } /*////////////////////////////////////////////////////////////// OWNERSHIP LOGIC //////////////////////////////////////////////////////////////*/ function transferOwnership(address newOwner) public virtual onlyOwner { owner = newOwner; emit OwnershipTransferred(msg.sender, newOwner); } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.9.0) (token/ERC20/IERC20.sol) pragma solidity ^0.8.0; /** * @dev Interface of the ERC20 standard as defined in the EIP. */ interface IERC20 { /** * @dev Emitted when `value` tokens are moved from one account (`from`) to * another (`to`). * * Note that `value` may be zero. */ event Transfer(address indexed from, address indexed to, uint256 value); /** * @dev Emitted when the allowance of a `spender` for an `owner` is set by * a call to {approve}. `value` is the new allowance. */ event Approval(address indexed owner, address indexed spender, uint256 value); /** * @dev Returns the amount of tokens in existence. */ function totalSupply() external view returns (uint256); /** * @dev Returns the amount of tokens owned by `account`. */ function balanceOf(address account) external view returns (uint256); /** * @dev Moves `amount` tokens from the caller's account to `to`. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transfer(address to, uint256 amount) external returns (bool); /** * @dev Returns the remaining number of tokens that `spender` will be * allowed to spend on behalf of `owner` through {transferFrom}. This is * zero by default. * * This value changes when {approve} or {transferFrom} are called. */ function allowance(address owner, address spender) external view returns (uint256); /** * @dev Sets `amount` as the allowance of `spender` over the caller's tokens. * * Returns a boolean value indicating whether the operation succeeded. * * IMPORTANT: Beware that changing an allowance with this method brings the risk * that someone may use both the old and the new allowance by unfortunate * transaction ordering. One possible solution to mitigate this race * condition is to first reduce the spender's allowance to 0 and set the * desired value afterwards: * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729 * * Emits an {Approval} event. */ function approve(address spender, uint256 amount) external returns (bool); /** * @dev Moves `amount` tokens from `from` to `to` using the * allowance mechanism. `amount` is then deducted from the caller's * allowance. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transferFrom(address from, address to, uint256 amount) external returns (bool); }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.9.0) (token/ERC20/extensions/IERC20Permit.sol) pragma solidity ^0.8.0; /** * @dev Interface of the ERC20 Permit extension allowing approvals to be made via signatures, as defined in * https://eips.ethereum.org/EIPS/eip-2612[EIP-2612]. * * Adds the {permit} method, which can be used to change an account's ERC20 allowance (see {IERC20-allowance}) by * presenting a message signed by the account. By not relying on {IERC20-approve}, the token holder account doesn't * need to send a transaction, and thus is not required to hold Ether at all. */ interface IERC20Permit { /** * @dev Sets `value` as the allowance of `spender` over ``owner``'s tokens, * given ``owner``'s signed approval. * * IMPORTANT: The same issues {IERC20-approve} has related to transaction * ordering also apply here. * * Emits an {Approval} event. * * Requirements: * * - `spender` cannot be the zero address. * - `deadline` must be a timestamp in the future. * - `v`, `r` and `s` must be a valid `secp256k1` signature from `owner` * over the EIP712-formatted function arguments. * - the signature must use ``owner``'s current nonce (see {nonces}). * * For more information on the signature format, see the * https://eips.ethereum.org/EIPS/eip-2612#specification[relevant EIP * section]. */ function permit( address owner, address spender, uint256 value, uint256 deadline, uint8 v, bytes32 r, bytes32 s ) external; /** * @dev Returns the current nonce for `owner`. This value must be * included whenever a signature is generated for {permit}. * * Every successful call to {permit} increases ``owner``'s nonce by one. This * prevents a signature from being used multiple times. */ function nonces(address owner) external view returns (uint256); /** * @dev Returns the domain separator used in the encoding of the signature for {permit}, as defined by {EIP712}. */ // solhint-disable-next-line func-name-mixedcase function DOMAIN_SEPARATOR() external view returns (bytes32); }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.9.0) (utils/Address.sol) pragma solidity ^0.8.1; /** * @dev Collection of functions related to the address type */ library Address { /** * @dev Returns true if `account` is a contract. * * [IMPORTANT] * ==== * It is unsafe to assume that an address for which this function returns * false is an externally-owned account (EOA) and not a contract. * * Among others, `isContract` will return false for the following * types of addresses: * * - an externally-owned account * - a contract in construction * - an address where a contract will be created * - an address where a contract lived, but was destroyed * * Furthermore, `isContract` will also return true if the target contract within * the same transaction is already scheduled for destruction by `SELFDESTRUCT`, * which only has an effect at the end of a transaction. * ==== * * [IMPORTANT] * ==== * You shouldn't rely on `isContract` to protect against flash loan attacks! * * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract * constructor. * ==== */ function isContract(address account) internal view returns (bool) { // This method relies on extcodesize/address.code.length, which returns 0 // for contracts in construction, since the code is only stored at the end // of the constructor execution. return account.code.length > 0; } /** * @dev Replacement for Solidity's `transfer`: sends `amount` wei to * `recipient`, forwarding all available gas and reverting on errors. * * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost * of certain opcodes, possibly making contracts go over the 2300 gas limit * imposed by `transfer`, making them unable to receive funds via * `transfer`. {sendValue} removes this limitation. * * https://consensys.net/diligence/blog/2019/09/stop-using-soliditys-transfer-now/[Learn more]. * * IMPORTANT: because control is transferred to `recipient`, care must be * taken to not create reentrancy vulnerabilities. Consider using * {ReentrancyGuard} or the * https://solidity.readthedocs.io/en/v0.8.0/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern]. */ function sendValue(address payable recipient, uint256 amount) internal { require(address(this).balance >= amount, "Address: insufficient balance"); (bool success, ) = recipient.call{value: amount}(""); require(success, "Address: unable to send value, recipient may have reverted"); } /** * @dev Performs a Solidity function call using a low level `call`. A * plain `call` is an unsafe replacement for a function call: use this * function instead. * * If `target` reverts with a revert reason, it is bubbled up by this * function (like regular Solidity function calls). * * Returns the raw returned data. To convert to the expected return value, * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`]. * * Requirements: * * - `target` must be a contract. * - calling `target` with `data` must not revert. * * _Available since v3.1._ */ function functionCall(address target, bytes memory data) internal returns (bytes memory) { return functionCallWithValue(target, data, 0, "Address: low-level call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with * `errorMessage` as a fallback revert reason when `target` reverts. * * _Available since v3.1._ */ function functionCall( address target, bytes memory data, string memory errorMessage ) internal returns (bytes memory) { return functionCallWithValue(target, data, 0, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but also transferring `value` wei to `target`. * * Requirements: * * - the calling contract must have an ETH balance of at least `value`. * - the called Solidity function must be `payable`. * * _Available since v3.1._ */ function functionCallWithValue(address target, bytes memory data, uint256 value) internal returns (bytes memory) { return functionCallWithValue(target, data, value, "Address: low-level call with value failed"); } /** * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but * with `errorMessage` as a fallback revert reason when `target` reverts. * * _Available since v3.1._ */ function functionCallWithValue( address target, bytes memory data, uint256 value, string memory errorMessage ) internal returns (bytes memory) { require(address(this).balance >= value, "Address: insufficient balance for call"); (bool success, bytes memory returndata) = target.call{value: value}(data); return verifyCallResultFromTarget(target, success, returndata, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but performing a static call. * * _Available since v3.3._ */ function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) { return functionStaticCall(target, data, "Address: low-level static call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`], * but performing a static call. * * _Available since v3.3._ */ function functionStaticCall( address target, bytes memory data, string memory errorMessage ) internal view returns (bytes memory) { (bool success, bytes memory returndata) = target.staticcall(data); return verifyCallResultFromTarget(target, success, returndata, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but performing a delegate call. * * _Available since v3.4._ */ function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) { return functionDelegateCall(target, data, "Address: low-level delegate call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`], * but performing a delegate call. * * _Available since v3.4._ */ function functionDelegateCall( address target, bytes memory data, string memory errorMessage ) internal returns (bytes memory) { (bool success, bytes memory returndata) = target.delegatecall(data); return verifyCallResultFromTarget(target, success, returndata, errorMessage); } /** * @dev Tool to verify that a low level call to smart-contract was successful, and revert (either by bubbling * the revert reason or using the provided one) in case of unsuccessful call or if target was not a contract. * * _Available since v4.8._ */ function verifyCallResultFromTarget( address target, bool success, bytes memory returndata, string memory errorMessage ) internal view returns (bytes memory) { if (success) { if (returndata.length == 0) { // only check isContract if the call was successful and the return data is empty // otherwise we already know that it was a contract require(isContract(target), "Address: call to non-contract"); } return returndata; } else { _revert(returndata, errorMessage); } } /** * @dev Tool to verify that a low level call was successful, and revert if it wasn't, either by bubbling the * revert reason or using the provided one. * * _Available since v4.3._ */ function verifyCallResult( bool success, bytes memory returndata, string memory errorMessage ) internal pure returns (bytes memory) { if (success) { return returndata; } else { _revert(returndata, errorMessage); } } function _revert(bytes memory returndata, string memory errorMessage) private pure { // Look for revert reason and bubble it up if present if (returndata.length > 0) { // The easiest way to bubble the revert reason is using memory via assembly /// @solidity memory-safe-assembly assembly { let returndata_size := mload(returndata) revert(add(32, returndata), returndata_size) } } else { revert(errorMessage); } } }
// SPDX-License-Identifier: MIT pragma solidity >=0.8.0; import "openzeppelin-contracts/utils/introspection/IERC165.sol"; /** * @dev Interface of the IOFT core standard */ interface ILzCommonOFT is IERC165 { struct LzCallParams { address payable refundAddress; address zroPaymentAddress; bytes adapterParams; } /** * @dev estimate send token `_tokenId` to (`_dstChainId`, `_toAddress`) * _dstChainId - L0 defined chain id to send tokens too * _toAddress - dynamic bytes array which contains the address to whom you are sending tokens to on the dstChain * _amount - amount of the tokens to transfer * _useZro - indicates to use zro to pay L0 fees * _adapterParam - flexible bytes array to indicate messaging adapter services in L0 */ function estimateSendFee( uint16 _dstChainId, bytes32 _toAddress, uint _amount, bool _useZro, bytes calldata _adapterParams ) external view returns (uint nativeFee, uint zroFee); function estimateSendAndCallFee( uint16 _dstChainId, bytes32 _toAddress, uint _amount, bytes calldata _payload, uint64 _dstGasForCall, bool _useZro, bytes calldata _adapterParams ) external view returns (uint nativeFee, uint zroFee); /** * @dev returns the circulating amount of tokens on current chain */ function circulatingSupply() external view returns (uint); /** * @dev returns the address of the ERC20 token */ function token() external view returns (address); }
// SPDX-License-Identifier: MIT pragma solidity >=0.8.0; interface IAggregator { function decimals() external view returns (uint8); function latestAnswer() external view returns (int256 answer); function latestRoundData() external view returns ( uint80 roundId, int256 answer, uint256 startedAt, uint256 updatedAt, uint80 answeredInRound ); }
// SPDX-License-Identifier: MIT pragma solidity >=0.8.0; import "./ILzUserApplicationConfig.sol"; interface ILzEndpoint is ILzUserApplicationConfig { function defaultSendLibrary() external view returns (address); // @notice send a LayerZero message to the specified address at a LayerZero endpoint. // @param _dstChainId - the destination chain identifier // @param _destination - the address on destination chain (in bytes). address length/format may vary by chains // @param _payload - a custom bytes payload to send to the destination contract // @param _refundAddress - if the source transaction is cheaper than the amount of value passed, refund the additional amount to this address // @param _zroPaymentAddress - the address of the ZRO token holder who would pay for the transaction // @param _adapterParams - parameters for custom functionality. e.g. receive airdropped native gas from the relayer on destination function send( uint16 _dstChainId, bytes calldata _destination, bytes calldata _payload, address payable _refundAddress, address _zroPaymentAddress, bytes calldata _adapterParams ) external payable; // @notice used by the messaging library to publish verified payload // @param _srcChainId - the source chain identifier // @param _srcAddress - the source contract (as bytes) at the source chain // @param _dstAddress - the address on destination chain // @param _nonce - the unbound message ordering nonce // @param _gasLimit - the gas limit for external contract execution // @param _payload - verified payload to send to the destination contract function receivePayload( uint16 _srcChainId, bytes calldata _srcAddress, address _dstAddress, uint64 _nonce, uint _gasLimit, bytes calldata _payload ) external; // @notice get the inboundNonce of a lzApp from a source chain which could be EVM or non-EVM chain // @param _srcChainId - the source chain identifier // @param _srcAddress - the source chain contract address function getInboundNonce(uint16 _srcChainId, bytes calldata _srcAddress) external view returns (uint64); // @notice get the outboundNonce from this source chain which, consequently, is always an EVM // @param _srcAddress - the source chain contract address function getOutboundNonce(uint16 _dstChainId, address _srcAddress) external view returns (uint64); // @notice gets a quote in source native gas, for the amount that send() requires to pay for message delivery // @param _dstChainId - the destination chain identifier // @param _userApplication - the user app address on this EVM chain // @param _payload - the custom message to send over LayerZero // @param _payInZRO - if false, user app pays the protocol fee in native token // @param _adapterParam - parameters for the adapter service, e.g. send some dust native token to dstChain function estimateFees( uint16 _dstChainId, address _userApplication, bytes calldata _payload, bool _payInZRO, bytes calldata _adapterParam ) external view returns (uint nativeFee, uint zroFee); // @notice get this Endpoint's immutable source identifier function getChainId() external view returns (uint16); // @notice the interface to retry failed message on this Endpoint destination // @param _srcChainId - the source chain identifier // @param _srcAddress - the source chain contract address // @param _payload - the payload to be retried function retryPayload(uint16 _srcChainId, bytes calldata _srcAddress, bytes calldata _payload) external; // @notice query if any STORED payload (message blocking) at the endpoint. // @param _srcChainId - the source chain identifier // @param _srcAddress - the source chain contract address function hasStoredPayload(uint16 _srcChainId, bytes calldata _srcAddress) external view returns (bool); // @notice query if the _libraryAddress is valid for sending msgs. // @param _userApplication - the user app address on this EVM chain function getSendLibraryAddress(address _userApplication) external view returns (address); // @notice query if the _libraryAddress is valid for receiving msgs. // @param _userApplication - the user app address on this EVM chain function getReceiveLibraryAddress(address _userApplication) external view returns (address); // @notice query if the non-reentrancy guard for send() is on // @return true if the guard is on. false otherwise function isSendingPayload() external view returns (bool); // @notice query if the non-reentrancy guard for receive() is on // @return true if the guard is on. false otherwise function isReceivingPayload() external view returns (bool); // @notice get the configuration of the LayerZero messaging library of the specified version // @param _version - messaging library version // @param _chainId - the chainId for the pending config change // @param _userApplication - the contract address of the user application // @param _configType - type of configuration. every messaging library has its own convention. function getConfig(uint16 _version, uint16 _chainId, address _userApplication, uint _configType) external view returns (bytes memory); // @notice get the send() LayerZero messaging library version // @param _userApplication - the contract address of the user application function getSendVersion(address _userApplication) external view returns (uint16); // @notice get the lzReceive() LayerZero messaging library version // @param _userApplication - the contract address of the user application function getReceiveVersion(address _userApplication) external view returns (uint16); }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol) pragma solidity ^0.8.0; /** * @dev Interface of the ERC165 standard, as defined in the * https://eips.ethereum.org/EIPS/eip-165[EIP]. * * Implementers can declare support of contract interfaces, which can then be * queried by others ({ERC165Checker}). * * For an implementation, see {ERC165}. */ interface IERC165 { /** * @dev Returns true if this contract implements the interface defined by * `interfaceId`. See the corresponding * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section] * to learn more about how these ids are created. * * This function call must use less than 30 000 gas. */ function supportsInterface(bytes4 interfaceId) external view returns (bool); }
// SPDX-License-Identifier: MIT pragma solidity >=0.5.0; interface ILzUserApplicationConfig { // @notice set the configuration of the LayerZero messaging library of the specified version // @param _version - messaging library version // @param _chainId - the chainId for the pending config change // @param _configType - type of configuration. every messaging library has its own convention. // @param _config - configuration in the bytes. can encode arbitrary content. function setConfig(uint16 _version, uint16 _chainId, uint _configType, bytes calldata _config) external; // @notice set the send() LayerZero messaging library version to _version // @param _version - new messaging library version function setSendVersion(uint16 _version) external; // @notice set the lzReceive() LayerZero messaging library version to _version // @param _version - new messaging library version function setReceiveVersion(uint16 _version) external; // @notice Only when the UA needs to resume the message flow in blocking mode and clear the stored payload // @param _srcChainId - the chainId of the source chain // @param _srcAddress - the contract address of the source contract at the source chain function forceResumeReceive(uint16 _srcChainId, bytes calldata _srcAddress) external; }
{ "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
- No Contract Security Audit Submitted- Submit Audit Here
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"}]
Contract Creation Code
60c06040526006805460ff191660011790553480156200001e57600080fd5b5060405162001f1638038062001f16833981016040819052620000419162000606565b600080546001600160a01b0319166001600160a01b038316908117825560405183928392917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a35050600160025560058490556001600160a01b038316620000f35760405162461bcd60e51b815260206004820152601760248201527f4f4654577261707065723a20696e76616c6964206f667400000000000000000060448201526064015b60405180910390fd5b6001600160a01b038316608081905260408051637e062a3560e11b8152905163fc0c546a916004808201926020929091908290030181865afa1580156200013e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200016491906200065a565b6001600160a01b0390811660a0528216620001c25760405162461bcd60e51b815260206004820152601e60248201527f4f4654577261707065723a20696e76616c69642061676772656761746f7200006044820152606401620000ea565b600480546001600160a01b0319166001600160a01b038481169190911790915560805160a051620001f892169060001962000222565b600380546001600160a01b0319166001600160a01b03929092169190911790555062000736915050565b801580620002a05750604051636eb1769f60e11b81523060048201526001600160a01b03838116602483015284169063dd62ed3e90604401602060405180830381865afa15801562000278573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200029e91906200067f565b155b620003145760405162461bcd60e51b815260206004820152603660248201527f5361666545524332303a20617070726f76652066726f6d206e6f6e2d7a65726f60448201527f20746f206e6f6e2d7a65726f20616c6c6f77616e6365000000000000000000006064820152608401620000ea565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b0390811663095ea7b360e01b179091526200036c9185916200037116565b505050565b6040805180820190915260208082527f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c656490820152600090620003c0906001600160a01b03851690849062000445565b9050805160001480620003e4575080806020019051810190620003e4919062000699565b6200036c5760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6044820152691bdd081cdd58d8d9595960b21b6064820152608401620000ea565b60606200045684846000856200045e565b949350505050565b606082471015620004c15760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f6044820152651c8818d85b1b60d21b6064820152608401620000ea565b600080866001600160a01b03168587604051620004df9190620006e3565b60006040518083038185875af1925050503d80600081146200051e576040519150601f19603f3d011682016040523d82523d6000602084013e62000523565b606091505b509092509050620005378783838762000542565b979650505050505050565b60608315620005b6578251600003620005ae576001600160a01b0385163b620005ae5760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401620000ea565b508162000456565b620004568383815115620005cd5781518083602001fd5b8060405162461bcd60e51b8152600401620000ea919062000701565b80516001600160a01b03811681146200060157600080fd5b919050565b600080600080608085870312156200061d57600080fd5b845193506200062f60208601620005e9565b92506200063f60408601620005e9565b91506200064f60608601620005e9565b905092959194509250565b6000602082840312156200066d57600080fd5b6200067882620005e9565b9392505050565b6000602082840312156200069257600080fd5b5051919050565b600060208284031215620006ac57600080fd5b815180151581146200067857600080fd5b60005b83811015620006da578181015183820152602001620006c0565b50506000910152565b60008251620006f7818460208701620006bd565b9190910192915050565b602081526000825180602084015262000722816040850160208701620006bd565b601f01601f19169190910160400192915050565b60805160a05161179062000786600039600081816104190152610797015260008181610350015281816105490152818161068d015281816107d601528181610839015261099e01526117906000f3fe60806040526004361061015f5760003560e01c80638cfd8f5c116100c0578063ed5a0fc011610074578063f46901ed11610059578063f46901ed146103c7578063f9120af6146103e7578063fc0c546a1461040757600080fd5b8063ed5a0fc014610387578063f2fde38b146103a757600080fd5b806390ed2083116100a557806390ed20831461031e5780639b5215f61461033e578063b353aaa71461037257600080fd5b80638cfd8f5c146102de5780638da5cb5b146102fe57600080fd5b8063476343ee11610117578063558a7297116100fc578063558a7297146102765780636ee296c91461029657806376025ec9146102cb57600080fd5b8063476343ee1461024c5780634da38ad81461026357600080fd5b806321f3c9f21161014857806321f3c9f2146101e15780632362189a14610208578063245a7bfc1461022c57600080fd5b8063017e7e581461016457806313e7c9d8146101a1575b600080fd5b34801561017057600080fd5b50600354610184906001600160a01b031681565b6040516001600160a01b0390911681526020015b60405180910390f35b3480156101ad57600080fd5b506101d16101bc366004611182565b60016020526000908152604090205460ff1681565b6040519015158152602001610198565b3480156101ed57600080fd5b506006546101fb9060ff1681565b60405161019891906111d7565b34801561021457600080fd5b5061021e60055481565b604051908152602001610198565b34801561023857600080fd5b50600454610184906001600160a01b031681565b34801561025857600080fd5b5061026161043b565b005b6102616102713660046111fc565b6104fd565b34801561028257600080fd5b50610261610291366004611270565b6105e0565b3480156102a257600080fd5b506102b66102b13660046112a9565b610688565b60408051928352602083019190915201610198565b6102616102d93660046111fc565b610745565b3480156102ea57600080fd5b5061021e6102f936600461133d565b610815565b34801561030a57600080fd5b50600054610184906001600160a01b031681565b34801561032a57600080fd5b50610261610339366004611370565b6108b5565b34801561034a57600080fd5b506101847f000000000000000000000000000000000000000000000000000000000000000081565b34801561037e57600080fd5b5061018461099a565b34801561039357600080fd5b506102616103a2366004611391565b610a23565b3480156103b357600080fd5b506102616103c2366004611182565b610aad565b3480156103d357600080fd5b506102616103e2366004611182565b610b4e565b3480156103f357600080fd5b50610261610402366004611182565b610c27565b34801561041357600080fd5b506101847f000000000000000000000000000000000000000000000000000000000000000081565b60035460405147916000916001600160a01b039091169083908381818185875af1925050503d806000811461048c576040519150601f19603f3d011682016040523d82523d6000602084013e610491565b606091505b50509050806104b35760405163f5ef1ce360e01b815260040160405180910390fd5b600354604080516001600160a01b039092168252602082018490527febe72af9d0a9f9afca2ea0bada9230f49d3c9e86f4948f37097d108a49363d53910160405180910390a15050565b610505610d00565b600061050f610d57565b9050803410156105395760405163b621805960e01b81523460048201526024015b60405180910390fd5b600061054582346113c0565b90507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663695ef6bf8233898989896040518763ffffffff1660e01b815260040161059c9594939291906113fc565b6000604051808303818588803b1580156105b557600080fd5b505af11580156105c9573d6000803e3d6000fd5b505050505050506105da6001600255565b50505050565b6000546001600160a01b031633146106295760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610530565b6001600160a01b038216600081815260016020908152604091829020805460ff191685151590811790915591519182527f193de8d500b5cb7b720089b258a39e9c1d0b840019a73ae7c51c3f9101732b02910160405180910390a25050565b6000807f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663365260b4888888600089896040518763ffffffff1660e01b81526004016106e2969594939291906114b5565b6040805180830381865afa1580156106fe573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061072291906114f3565b909250905061072f610d57565b6107399083611517565b91509550959350505050565b61074d610d00565b6000610757610d57565b90508034101561077c5760405163b621805960e01b8152346004820152602401610530565b600061078882346113c0565b90506107bf6001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016333087610e7a565b60405163695ef6bf60e01b81526001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000169063695ef6bf90839061059c9030908b908b908b908b906004016113fc565b60405163233f63d760e21b815261ffff8084166004830152821660248201526000907f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031690638cfd8f5c90604401602060405180830381865afa158015610888573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108ac919061152a565b90505b92915050565b3360009081526001602052604090205460ff161580156108e057506000546001600160a01b03163314155b156108fe5760405163de19c8b360e01b815260040160405180910390fd5b60018160018111156109125761091261119f565b1115610933578060405163d05ccdf360e01b815260040161053091906111d7565b6006546040517f80e60928263e6642de6e8a1117b4f00062107c445212b88f6a02187940eccf2c9161096c9160ff909116908490611543565b60405180910390a16006805482919060ff1916600183818111156109925761099261119f565b021790555050565b60007f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663b353aaa76040518163ffffffff1660e01b8152600401602060405180830381865afa1580156109fa573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a1e919061155e565b905090565b3360009081526001602052604090205460ff16158015610a4e57506000546001600160a01b03163314155b15610a6c5760405163de19c8b360e01b815260040160405180910390fd5b60055460408051918252602082018390527f4c0bffc5595fd0c1705c52132244fdac73f66274c586f059483928f66e7b6d98910160405180910390a1600555565b6000546001600160a01b03163314610af65760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610530565b6000805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0383169081178255604051909133917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a350565b6000546001600160a01b03163314610b975760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610530565b6001600160a01b038116610bbe5760405163e6c4247b60e01b815260040160405180910390fd5b6003546040516001600160a01b038084169216907fbcf71d3ed47385ef899b4ae7d10b0da92fce93b66f947859b6b12c39faa6abba90600090a36003805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b3360009081526001602052604090205460ff16158015610c5257506000546001600160a01b03163314155b15610c705760405163de19c8b360e01b815260040160405180910390fd5b6001600160a01b038116610c975760405163e6c4247b60e01b815260040160405180910390fd5b6004546040516001600160a01b038084169216907f8e0352ee1de57032a7c8ddf4cb1daa3ff929d0a8534e42a124811b2fa033cccd90600090a36004805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b6002805403610d515760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c006044820152606401610530565b60028055565b60008060065460ff166001811115610d7157610d7161119f565b03610e735760048054604080516350d25bcd60e01b815290516001600160a01b03909216926350d25bcd9282820192602092908290030181865afa158015610dbd573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610de1919061152a565b600480546040805163313ce56760e01b815290516001600160a01b039092169263313ce5679282820192602092908290030181865afa158015610e28573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e4c919061157b565b610e5790600a611682565b610e6990670de0b6b3a7640000611691565b610a1e91906116a8565b5060055490565b604080516001600160a01b038581166024830152848116604483015260648083018590528351808403909101815260849092018352602080830180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff166323b872dd60e01b17905283518085019094528084527f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564908401526105da92879291600091610f27918516908490610fbf565b9050805160001480610f48575080806020019051810190610f4891906116ca565b610fba5760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e60448201527f6f742073756363656564000000000000000000000000000000000000000000006064820152608401610530565b505050565b6060610fce8484600085610fd8565b90505b9392505050565b6060824710156110505760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f60448201527f722063616c6c00000000000000000000000000000000000000000000000000006064820152608401610530565b600080866001600160a01b0316858760405161106c919061170b565b60006040518083038185875af1925050503d80600081146110a9576040519150601f19603f3d011682016040523d82523d6000602084013e6110ae565b606091505b50915091506110bf878383876110cc565b925050505b949350505050565b6060831561113b578251600003611134576001600160a01b0385163b6111345760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610530565b50816110c4565b6110c483838151156111505781518083602001fd5b8060405162461bcd60e51b81526004016105309190611727565b6001600160a01b038116811461117f57600080fd5b50565b60006020828403121561119457600080fd5b8135610fd18161116a565b634e487b7160e01b600052602160045260246000fd5b600281106111d357634e487b7160e01b600052602160045260246000fd5b9052565b602081016108af82846111b5565b803561ffff811681146111f757600080fd5b919050565b6000806000806080858703121561121257600080fd5b61121b856111e5565b93506020850135925060408501359150606085013567ffffffffffffffff81111561124557600080fd5b85016060818803121561125757600080fd5b939692955090935050565b801515811461117f57600080fd5b6000806040838503121561128357600080fd5b823561128e8161116a565b9150602083013561129e81611262565b809150509250929050565b6000806000806000608086880312156112c157600080fd5b6112ca866111e5565b94506020860135935060408601359250606086013567ffffffffffffffff808211156112f557600080fd5b818801915088601f83011261130957600080fd5b81358181111561131857600080fd5b89602082850101111561132a57600080fd5b9699959850939650602001949392505050565b6000806040838503121561135057600080fd5b611359836111e5565b9150611367602084016111e5565b90509250929050565b60006020828403121561138257600080fd5b813560028110610fd157600080fd5b6000602082840312156113a357600080fd5b5035919050565b634e487b7160e01b600052601160045260246000fd5b818103818111156108af576108af6113aa565b81835281816020850137506000828201602090810191909152601f909101601f19169091010190565b60006001600160a01b03808816835261ffff8716602084015285604084015284606084015260a0608084015283356114338161116a565b811660a084015260208401356114488161116a565b1660c0830152604083013536849003601e1901811261146657600080fd5b830160208101903567ffffffffffffffff81111561148357600080fd5b80360382131561149257600080fd5b606060e08501526114a8610100850182846113d3565b9998505050505050505050565b61ffff87168152856020820152846040820152831515606082015260a0608082015260006114e760a0830184866113d3565b98975050505050505050565b6000806040838503121561150657600080fd5b505080516020909101519092909150565b808201808211156108af576108af6113aa565b60006020828403121561153c57600080fd5b5051919050565b6040810161155182856111b5565b610fd160208301846111b5565b60006020828403121561157057600080fd5b8151610fd18161116a565b60006020828403121561158d57600080fd5b815160ff81168114610fd157600080fd5b600181815b808511156115d95781600019048211156115bf576115bf6113aa565b808516156115cc57918102915b93841c93908002906115a3565b509250929050565b6000826115f0575060016108af565b816115fd575060006108af565b8160018114611613576002811461161d57611639565b60019150506108af565b60ff84111561162e5761162e6113aa565b50506001821b6108af565b5060208310610133831016604e8410600b841016171561165c575081810a6108af565b611666838361159e565b806000190482111561167a5761167a6113aa565b029392505050565b60006108ac60ff8416836115e1565b80820281158282048414176108af576108af6113aa565b6000826116c557634e487b7160e01b600052601260045260246000fd5b500490565b6000602082840312156116dc57600080fd5b8151610fd181611262565b60005b838110156117025781810151838201526020016116ea565b50506000910152565b6000825161171d8184602087016116e7565b9190910192915050565b60208152600082518060208401526117468160408501602087016116e7565b601f01601f1916919091016040019291505056fea2646970667358221220c93f7b0d6c6e3603726266afa66e888a7609b25f29e168151e0f1c9646a68cc564736f6c634300081400330000000000000000000000000000000000000000000000001582b4c9a9db0000000000000000000000000000ca0d86afc25c57a6d2acdf331cabd4c9cee05533000000000000000000000000ab594600376ec9fd91f8e885dadf0ce036862de000000000000000000000000041186a5ff8f3b48f0ffc71a4cc958a997710daeeDeployed 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] : 00000000000000000000000041186a5ff8f3b48f0ffc71a4cc958a997710daeeLoading...LoadingLoading...Loading
Loading...Loading
Loading...LoadingLoading...LoadingLoading...LoadingLoading...LoadingLoading...LoadingMultichain Portfolio | 27 Chains
Chain Token Portfolio % Price Amount Value POL Polygon (POL)100.00% $0.363486 2.6397 $0.95948 [ 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.
Address QR Code
My Address - Private Name Tag or Note
My Name Tag:
Private Name Tags (up to 35 characters) can be used for easy identification of addressesPrivate Note:
A private note (up to 500 characters) can be attached to this address.
Please DO NOT store any passwords or private keys here.Compiler specific version warnings:
The compiled contract might be susceptible to VerbatimInvalidDeduplication (low-severity), FullInlinerNonExpressionSplitArgumentEvaluationOrder (low-severity), MissingSideEffectsOnSelectorAccess (low-severity) Solidity Compiler Bugs.
Connect a Wallet
Connecting wallet for read function is optional, useful if you want to call certain functions or simply use your wallet's node.Connect a Wallet
Connecting wallet for read function is optional, useful if you want to call certain functions or simply use your wallet's node.Connect a Wallet
Connecting wallet for read function is optional, useful if you want to call certain functions or simply use your wallet's node.Notice
The migration from MATIC to POL is now live. To find out more, please visit Polygon Official Announcement .
Before You Copy
This website uses cookies to improve your experience. By continuing to use this website, you agree to its Terms and Privacy Policy.