More Info
Private Name Tags
ContractCreator
Latest 11 from a total of 11 transactions
Transaction Hash |
Method
|
Block
|
From
|
To
|
|||||
---|---|---|---|---|---|---|---|---|---|
Portal In | 17479041 | 598 days ago | IN | 0 ETH | 0.02246626 | ||||
Portal In | 17243587 | 632 days ago | IN | 0 ETH | 0.01160381 | ||||
Portal In | 17001896 | 666 days ago | IN | 5 ETH | 0.00446185 | ||||
Portal In | 16994470 | 667 days ago | IN | 0 ETH | 0.02825757 | ||||
Portal In | 16964809 | 671 days ago | IN | 0 ETH | 0.00988155 | ||||
Portal In | 16895235 | 681 days ago | IN | 0 ETH | 0.01387109 | ||||
Portal In | 16888560 | 682 days ago | IN | 0 ETH | 0.00778471 | ||||
Portal In | 16651250 | 715 days ago | IN | 0 ETH | 0.069095 | ||||
Portal In | 16515168 | 734 days ago | IN | 0.01 ETH | 0.00387817 | ||||
Portal In | 16514158 | 734 days ago | IN | 0 ETH | 0.00891583 | ||||
Portal In | 16126224 | 788 days ago | IN | 0 ETH | 0.00982579 |
Latest 25 internal transactions (View All)
Advanced mode:
Parent Transaction Hash | Block |
From
|
To
|
|||
---|---|---|---|---|---|---|
18335115 | 478 days ago | 2.09154599 ETH | ||||
18335115 | 478 days ago | 2.09154599 ETH | ||||
18209516 | 496 days ago | 11.17745544 ETH | ||||
18209516 | 496 days ago | 11.17745544 ETH | ||||
18160859 | 503 days ago | 44.97103679 ETH | ||||
18160859 | 503 days ago | 44.97103679 ETH | ||||
18145641 | 505 days ago | 6.25477481 ETH | ||||
18145641 | 505 days ago | 6.25477481 ETH | ||||
18083709 | 514 days ago | 22.29269013 ETH | ||||
18083709 | 514 days ago | 22.29269013 ETH | ||||
18078034 | 514 days ago | 8.64639045 ETH | ||||
18078034 | 514 days ago | 8.64639045 ETH | ||||
18060709 | 517 days ago | 2.8253795 ETH | ||||
18060709 | 517 days ago | 2.8253795 ETH | ||||
18009331 | 524 days ago | 7.85870537 ETH | ||||
18009331 | 524 days ago | 7.85870537 ETH | ||||
18005102 | 525 days ago | 0.49774697 ETH | ||||
18005102 | 525 days ago | 0.49774697 ETH | ||||
17858556 | 545 days ago | 12.2228952 ETH | ||||
17858556 | 545 days ago | 12.2228952 ETH | ||||
17652624 | 574 days ago | 1.93589459 ETH | ||||
17652624 | 574 days ago | 1.93589459 ETH | ||||
17243587 | 632 days ago | 0.0997 ETH | ||||
17243587 | 632 days ago | 0.0997 ETH | ||||
17215751 | 635 days ago | 333.56988865 ETH |
Loading...
Loading
Contract Source Code Verified (Exact Match)
Contract Name:
CurvePortalIn
Compiler Version
v0.8.11+commit.d7f03943
Contract Source Code (Solidity Standard Json-Input format)
/// Copyright (C) 2022 Portals.fi /// @author Portals.fi /// @notice This contract adds liquidity to Curve pools using any ERC20 token or the network token. /// SPDX-License-Identifier: GPL-3.0 pragma solidity 0.8.11; import "../base/PortalBaseV2.sol"; import "./interface/ICurveAddressProvider.sol"; import "./interface/ICurvePool.sol"; import "./interface/ICurveRegistry.sol"; /// Thrown when insufficient liquidity is received after deposit /// @param buyAmount The amount of liquidity received /// @param minBuyAmount The minimum acceptable quantity of liquidity received error InsufficientBuy(uint256 buyAmount, uint256 minBuyAmount); contract CurvePortalIn is PortalBaseV2 { using SafeTransferLib for address; using SafeTransferLib for ERC20; /// @notice Emitted when a portal is entered /// @param sellToken The ERC20 token address to spend (address(0) if network token) /// @param sellAmount The quantity of sellToken to Portal in /// @param buyToken The ERC20 token address to buy (address(0) if network token) /// @param buyAmount The quantity of buyToken received /// @param fee The fee in BPS /// @param sender The msg.sender /// @param partner The front end operator address event PortalIn( address sellToken, uint256 sellAmount, address buyToken, uint256 buyAmount, uint256 fee, address indexed sender, address indexed partner ); constructor( bytes32 protocolId, PortalType portalType, IPortalRegistry registry, address exchange, address wrappedNetworkToken, uint256 fee ) PortalBaseV2( protocolId, portalType, registry, exchange, wrappedNetworkToken, fee ) {} /// @notice Add liquidity to Curve pools with network tokens/ERC20 tokens /// @dev This contract can call itself in cases where the pool is a metapool. /// In these cases, transfers, events and fees are omitted. /// @param sellToken The ERC20 token address to spend (address(0) if network token) /// @param sellAmount The quantity of sellToken to Portal in /// @param intermediateToken The intermediate token to swap to (must be one of the pool tokens) /// @param buyToken The curve pool token address /// NOTE This may be different from the swap/deposit address! /// @param minBuyAmount The minimum quantity of buyTokens to receive. Reverts otherwise /// @param target The excecution target for the intermediate swap /// @param data The encoded call for the intermediate swap /// @param partner The front end operator address /// @param poolData Encoded pool data including the following: /// pool The address of the swap/deposit contract /// numCoins The number of coins in the pool /// The index of the intermediateToken in the pool /// depositUnderlying A boolean value specifying whether to deposit the unwrapped version of intermediateToken /// @return buyAmount The quantity of buyToken acquired function portalIn( address sellToken, uint256 sellAmount, address intermediateToken, address buyToken, uint256 minBuyAmount, address target, bytes calldata data, address partner, bytes calldata poolData ) external payable pausable returns (uint256 buyAmount) { uint256 amount = sellAmount; if (msg.sender != address(this)) { amount = _transferFromCaller(sellToken, sellAmount); amount = _getFeeAmount(amount); } amount = _execute(sellToken, amount, intermediateToken, target, data); buyAmount = _deposit(intermediateToken, amount, buyToken, poolData); if (buyAmount < minBuyAmount) revert InsufficientBuy(buyAmount, minBuyAmount); if (msg.sender != address(this)) { ERC20(buyToken).safeTransfer(msg.sender, buyAmount); emit PortalIn( sellToken, sellAmount, buyToken, buyAmount, fee, msg.sender, partner ); } } /// @notice Deposits the sellToken into the pool using the correct interface based on the /// number of coins in the pool /// @param sellToken The token address to swap from /// @param sellAmount The quantity of tokens to sell /// @param buyToken The curve pool token address /// @param poolData Encoded pool data including the following: /// pool The address of the swap/deposit contract /// numCoins The number of coins in the pool /// The index of the intermediateToken in the pool /// depositUnderlying A boolean value specifying whether to deposit the unwrapped version of intermediateToken /// @return liquidity The quantity of LP tokens acquired function _deposit( address sellToken, uint256 sellAmount, address buyToken, bytes calldata poolData ) internal returns (uint256) { ( address pool, uint256 numCoins, uint256 coinIndex, bool depositUnderlying ) = abi.decode(poolData, (address, uint256, uint256, bool)); uint256 valueToSend; if (sellToken == address(0)) { valueToSend = sellAmount; } else { _approve(sellToken, pool, sellAmount); } uint256 balance = _getBalance(address(this), buyToken); ICurvePool _pool = ICurvePool(pool); if (numCoins == 2) { uint256[2] memory _amounts; _amounts[coinIndex] = sellAmount; depositUnderlying ? _pool.add_liquidity{ value: valueToSend }(_amounts, 0, true) : _pool.add_liquidity{ value: valueToSend }(_amounts, 0); } else if (numCoins == 3) { uint256[3] memory _amounts; _amounts[coinIndex] = sellAmount; depositUnderlying ? _pool.add_liquidity{ value: valueToSend }(_amounts, 0, true) : _pool.add_liquidity{ value: valueToSend }(_amounts, 0); } else { uint256[4] memory _amounts; _amounts[coinIndex] = sellAmount; depositUnderlying ? _pool.add_liquidity{ value: valueToSend }(_amounts, 0, true) : _pool.add_liquidity{ value: valueToSend }(_amounts, 0); } return _getBalance(address(this), buyToken) - balance; } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts v4.4.1 (access/Ownable.sol) pragma solidity ^0.8.0; import "../utils/Context.sol"; /** * @dev Contract module which provides a basic access control mechanism, where * there is an account (an owner) that can be granted exclusive access to * specific functions. * * By default, the owner account will be the one that deploys the contract. This * can later be changed with {transferOwnership}. * * This module is used through inheritance. It will make available the modifier * `onlyOwner`, which can be applied to your functions to restrict their use to * the owner. */ abstract contract Ownable is Context { address private _owner; event OwnershipTransferred(address indexed previousOwner, address indexed newOwner); /** * @dev Initializes the contract setting the deployer as the initial owner. */ constructor() { _transferOwnership(_msgSender()); } /** * @dev Returns the address of the current owner. */ function owner() public view virtual returns (address) { return _owner; } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { require(owner() == _msgSender(), "Ownable: caller is not the owner"); _; } /** * @dev Leaves the contract without owner. It will not be possible to call * `onlyOwner` functions anymore. Can only be called by the current owner. * * NOTE: Renouncing ownership will leave the contract without an owner, * thereby removing any functionality that is only available to the owner. */ function renounceOwnership() public virtual onlyOwner { _transferOwnership(address(0)); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Can only be called by the current owner. */ function transferOwnership(address newOwner) public virtual onlyOwner { require(newOwner != address(0), "Ownable: new owner is the zero address"); _transferOwnership(newOwner); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Internal function without access restriction. */ function _transferOwnership(address newOwner) internal virtual { address oldOwner = _owner; _owner = newOwner; emit OwnershipTransferred(oldOwner, newOwner); } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts v4.4.1 (utils/Context.sol) pragma solidity ^0.8.0; /** * @dev Provides information about the current execution context, including the * sender of the transaction and its data. While these are generally available * via msg.sender and msg.data, they should not be accessed in such a direct * manner, since when dealing with meta-transactions the account sending and * paying for execution may not be the actual sender (as far as an application * is concerned). * * This contract is only required for intermediate, library-like contracts. */ abstract contract Context { function _msgSender() internal view virtual returns (address) { return msg.sender; } function _msgData() internal view virtual returns (bytes calldata) { return msg.data; } }
/// Copyright (C) 2022 Portals.fi /// @author Portals.fi /// @notice Base contract inherited by Portals /// SPDX-License-Identifier: GPL-3.0 pragma solidity 0.8.11; import "@openzeppelin/contracts/access/Ownable.sol"; import "./interface/IPortalBase.sol"; import "../libraries/solmate/utils/SafeTransferLib.sol"; import "../interface/IWETH.sol"; import "../interface/IPortalRegistry.sol"; abstract contract PortalBaseV2 is IPortalBase, Ownable { using SafeTransferLib for address; using SafeTransferLib for ERC20; // Active status of this contract. If false, contract is active (i.e un-paused) bool public paused; // Fee in basis points (bps) uint256 public fee; // The Portal Registry IPortalRegistry public registry; // The address of the exchange used for swaps address public immutable exchange; // The address of the wrapped network token (e.g. WETH, wMATIC, wFTM, wAVAX, etc.) address public immutable wrappedNetworkToken; // Circuit breaker modifier pausable() { require(!paused, "Paused"); _; } constructor( bytes32 protocolId, PortalType portalType, IPortalRegistry _registry, address _exchange, address _wrappedNetworkToken, uint256 _fee ) { wrappedNetworkToken = _wrappedNetworkToken; setFee(_fee); exchange = _exchange; registry = _registry; registry.addPortal(address(this), portalType, protocolId); transferOwnership(registry.owner()); } /// @notice Transfers tokens or the network token from the caller to this contract /// @param token The address of the token to transfer (address(0) if network token) /// @param quantity The quantity of tokens to transfer from the caller /// @dev quantity must == msg.value when token == address(0) /// @dev msg.value must == 0 when token != address(0) /// @return The quantity of tokens or network tokens transferred from the caller to this contract function _transferFromCaller(address token, uint256 quantity) internal virtual returns (uint256) { if (token == address(0)) { require( msg.value > 0 && msg.value == quantity, "Invalid quantity or msg.value" ); return msg.value; } require( quantity > 0 && msg.value == 0, "Invalid quantity or msg.value" ); ERC20(token).safeTransferFrom(msg.sender, address(this), quantity); return quantity; } /// @notice Returns the quantity of tokens or network tokens after accounting for the fee /// @param quantity The quantity of tokens to subtract the fee from /// @return The quantity of tokens or network tokens to transact with less the fee function _getFeeAmount(uint256 quantity) internal view returns (uint256) { return registry.isPortal(msg.sender) ? quantity : quantity - (quantity * fee) / 10000; } /// @notice Executes swap or portal data at the target address /// @param sellToken The sell token /// @param sellAmount The quantity of sellToken (in sellToken base units) to send /// @param buyToken The buy token /// @param target The execution target for the data /// @param data The swap or portal data /// @return amountBought Quantity of buyToken acquired function _execute( address sellToken, uint256 sellAmount, address buyToken, address target, bytes memory data ) internal virtual returns (uint256 amountBought) { if (sellToken == buyToken) { return sellAmount; } if (sellToken == address(0) && buyToken == wrappedNetworkToken) { IWETH(wrappedNetworkToken).deposit{ value: sellAmount }(); return sellAmount; } if (sellToken == wrappedNetworkToken && buyToken == address(0)) { IWETH(wrappedNetworkToken).withdraw(sellAmount); return sellAmount; } uint256 valueToSend; if (sellToken == address(0)) { valueToSend = sellAmount; } else { _approve(sellToken, target, sellAmount); } uint256 initialBalance = _getBalance(address(this), buyToken); require( target == exchange || registry.isPortal(target), "Unauthorized target" ); (bool success, bytes memory returnData) = target.call{ value: valueToSend }(data); require(success, string(returnData)); amountBought = _getBalance(address(this), buyToken) - initialBalance; require(amountBought > 0, "Invalid execution"); } /// @notice Get the token or network token balance of an account /// @param account The owner of the tokens or network tokens whose balance is being queried /// @param token The address of the token (address(0) if network token) /// @return The owner's token or network token balance function _getBalance(address account, address token) internal view returns (uint256) { if (token == address(0)) { return account.balance; } else { return ERC20(token).balanceOf(account); } } /// @notice Approve a token for spending with finite allowance /// @param token The ERC20 token to approve /// @param spender The spender of the token /// @param amount The allowance to grant to the spender function _approve( address token, address spender, uint256 amount ) internal { ERC20 _token = ERC20(token); _token.safeApprove(spender, 0); _token.safeApprove(spender, amount); } /// @notice Collects tokens or network tokens from this contract /// @param tokens An array of the tokens to withdraw (address(0) if network token) function collect(address[] calldata tokens) external { address collector = registry.collector(); uint256 qty; for (uint256 i = 0; i < tokens.length; i++) { if (tokens[i] == address(0)) { qty = address(this).balance; collector.safeTransferETH(qty); } else { qty = ERC20(tokens[i]).balanceOf(address(this)); ERC20(tokens[i]).safeTransfer(collector, qty); } emit Collect(tokens[i], qty); } } /// @dev Pause or unpause the contract function pause() external onlyOwner { paused = !paused; emit Pause(paused); } /// @notice Sets the fee /// @param _fee The new fee amount between 0.06-1% function setFee(uint256 _fee) public onlyOwner { require(_fee >= 6 && _fee <= 100, "Invalid Fee"); emit Fee(fee, _fee); fee = _fee; } /// @notice Updates the registry /// @param _registry The address of the new registry function updateRegistry(IPortalRegistry _registry) external onlyOwner { registry = _registry; emit UpdateRegistry(address(registry)); } /// @notice Reverts if networks tokens are sent directly to this contract receive() external payable { require(msg.sender != tx.origin); } }
/// Copyright (C) 2022 Portals.fi /// @author Portals.fi /// @notice Interface for the Base contract inherited by Portals /// SPDX-License-Identifier: GPL-3.0 pragma solidity 0.8.11; interface IPortalBase { /// @notice Emitted when a portal is collected /// @param token The ERC20 token address to collect (address(0) if network token) /// @param amount The quantity of th token to collect event Collect(address token, uint256 amount); /// @notice Emitted when the fee is changed /// @param oldFee The ERC20 token address to collect (address(0) if network token) /// @param newFee The quantity of th token to collect event Fee(uint256 oldFee, uint256 newFee); /// @notice Emitted when a portal is paused /// @param paused The active status of this contract. If false, contract is active (i.e un-paused) event Pause(bool paused); /// @notice Emitted when the registry is upated /// @param registry The address of the new registry event UpdateRegistry(address registry); }
/// SPDX-License-Identifier: GPL-3.0 pragma solidity ^0.8.11; interface ICurveAddressProvider { function get_registry() external view returns (address); function get_address(uint256 _id) external view returns (address); }
/// SPDX-License-Identifier: GPL-3.0 pragma solidity ^0.8.11; interface ICurvePool { function add_liquidity(uint256[2] memory _amounts, uint256 _min_mint_amount) external payable; function add_liquidity( uint256[2] memory _amounts, uint256 _min_mint_amount, bool _use_underlying ) external payable; function add_liquidity(uint256[3] memory _amounts, uint256 _min_mint_amount) external payable; function add_liquidity( uint256[3] memory _amounts, uint256 _min_mint_amount, bool _use_underlying ) external payable; function add_liquidity(uint256[4] memory _amounts, uint256 _min_mint_amount) external payable; function add_liquidity( uint256[4] memory _amounts, uint256 _min_mint_amount, bool _use_underlying ) external payable; function coins(uint256 i) external view returns (address); function remove_liquidity_one_coin( uint256 _token_amount, int128 i, uint256 min_amount ) external; function remove_liquidity_one_coin( uint256 token_amount, uint256 i, uint256 min_amount ) external; function remove_liquidity_one_coin( uint256 token_amount, uint256 i, uint256 min_amount, bool _use_underlying ) external; function remove_liquidity_one_coin( uint256 token_amount, int128 i, uint256 min_amount, bool _use_underlying ) external; }
/// SPDX-License-Identifier: GPL-3.0 pragma solidity ^0.8.11; interface ICurveRegistry { function get_coins(address _pool) external view returns (address[8] memory); function get_n_coins(address _pool) external view returns (uint256); }
/// SPDX-License-Identifier: GPL-3.0 pragma solidity 0.8.11; enum PortalType { IN, OUT } interface IPortalRegistry { function addPortal( address portal, PortalType portalType, bytes32 protocolId ) external; function addPortalFactory( address portalFactory, PortalType portalType, bytes32 protocolId ) external; function removePortal(bytes32 protocolId, PortalType portalType) external; function owner() external view returns (address owner); function registrars(address origin) external view returns (bool isDeployer); function collector() external view returns (address collector); function isPortal(address portal) external view returns (bool isPortal); }
/// SPDX-License-Identifier: GPL-3.0 pragma solidity 0.8.11; interface IWETH { function deposit() external payable; function withdraw(uint256 wad) external; }
// SPDX-License-Identifier: AGPL-3.0-only pragma solidity >=0.8.0; /// @notice Modern and gas efficient ERC20 + EIP-2612 implementation. /// @author Solmate (https://github.com/transmissions11/solmate/blob/main/src/tokens/ERC20.sol) /// @author Modified from Uniswap (https://github.com/Uniswap/uniswap-v2-core/blob/master/contracts/UniswapV2ERC20.sol) /// @dev Do not manually set balances without updating totalSupply, as the sum of all user balances must not exceed it. abstract contract ERC20 { /*////////////////////////////////////////////////////////////// EVENTS //////////////////////////////////////////////////////////////*/ event Transfer(address indexed from, address indexed to, uint256 amount); event Approval( address indexed owner, address indexed spender, uint256 amount ); /*////////////////////////////////////////////////////////////// METADATA STORAGE //////////////////////////////////////////////////////////////*/ string public name; string public symbol; uint8 public immutable decimals; /*////////////////////////////////////////////////////////////// ERC20 STORAGE //////////////////////////////////////////////////////////////*/ uint256 public totalSupply; mapping(address => uint256) public balanceOf; mapping(address => mapping(address => uint256)) public allowance; /*////////////////////////////////////////////////////////////// EIP-2612 STORAGE //////////////////////////////////////////////////////////////*/ uint256 internal immutable INITIAL_CHAIN_ID; bytes32 internal immutable INITIAL_DOMAIN_SEPARATOR; mapping(address => uint256) public nonces; /*////////////////////////////////////////////////////////////// CONSTRUCTOR //////////////////////////////////////////////////////////////*/ constructor( string memory _name, string memory _symbol, uint8 _decimals ) { name = _name; symbol = _symbol; decimals = _decimals; INITIAL_CHAIN_ID = block.chainid; INITIAL_DOMAIN_SEPARATOR = computeDomainSeparator(); } /*////////////////////////////////////////////////////////////// ERC20 LOGIC //////////////////////////////////////////////////////////////*/ function approve(address spender, uint256 amount) public virtual returns (bool) { allowance[msg.sender][spender] = amount; emit Approval(msg.sender, spender, amount); return true; } function transfer(address to, uint256 amount) public virtual returns (bool) { balanceOf[msg.sender] -= amount; // Cannot overflow because the sum of all user // balances can't exceed the max uint256 value. unchecked { balanceOf[to] += amount; } emit Transfer(msg.sender, to, amount); return true; } function transferFrom( address from, address to, uint256 amount ) public virtual returns (bool) { uint256 allowed = allowance[from][msg.sender]; // Saves gas for limited approvals. if (allowed != type(uint256).max) allowance[from][msg.sender] = allowed - amount; balanceOf[from] -= amount; // Cannot overflow because the sum of all user // balances can't exceed the max uint256 value. unchecked { balanceOf[to] += amount; } emit Transfer(from, to, amount); return true; } /*////////////////////////////////////////////////////////////// EIP-2612 LOGIC //////////////////////////////////////////////////////////////*/ function permit( address owner, address spender, uint256 value, uint256 deadline, uint8 v, bytes32 r, bytes32 s ) public virtual { require(deadline >= block.timestamp, "PERMIT_DEADLINE_EXPIRED"); // Unchecked because the only math done is incrementing // the owner's nonce which cannot realistically overflow. unchecked { address recoveredAddress = ecrecover( keccak256( abi.encodePacked( "\x19\x01", DOMAIN_SEPARATOR(), keccak256( abi.encode( keccak256( "Permit(address owner,address spender,uint256 value,uint256 nonce,uint256 deadline)" ), owner, spender, value, nonces[owner]++, deadline ) ) ) ), v, r, s ); require( recoveredAddress != address(0) && recoveredAddress == owner, "INVALID_SIGNER" ); allowance[recoveredAddress][spender] = value; } emit Approval(owner, spender, value); } function DOMAIN_SEPARATOR() public view virtual returns (bytes32) { return block.chainid == INITIAL_CHAIN_ID ? INITIAL_DOMAIN_SEPARATOR : computeDomainSeparator(); } function computeDomainSeparator() internal view virtual returns (bytes32) { return keccak256( abi.encode( keccak256( "EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)" ), keccak256(bytes(name)), keccak256("1"), block.chainid, address(this) ) ); } /*////////////////////////////////////////////////////////////// INTERNAL MINT/BURN LOGIC //////////////////////////////////////////////////////////////*/ function _mint(address to, uint256 amount) internal virtual { totalSupply += amount; // Cannot overflow because the sum of all user // balances can't exceed the max uint256 value. unchecked { balanceOf[to] += amount; } emit Transfer(address(0), to, amount); } function _burn(address from, uint256 amount) internal virtual { balanceOf[from] -= amount; // Cannot underflow because a user's balance // will never be larger than the total supply. unchecked { totalSupply -= amount; } emit Transfer(from, address(0), amount); } }
// SPDX-License-Identifier: AGPL-3.0-only pragma solidity >=0.8.0; import { ERC20 } from "../tokens/ERC20.sol"; /// @notice Safe ETH and ERC20 transfer library that gracefully handles missing return values. /// @author Solmate (https://github.com/transmissions11/solmate/blob/main/src/utils/SafeTransferLib.sol) /// @dev Use with caution! Some functions in this library knowingly create dirty bits at the destination of the free memory pointer. /// @dev Note that none of the functions in this library check that a token has code at all! That responsibility is delegated to the caller. library SafeTransferLib { /*////////////////////////////////////////////////////////////// ETH OPERATIONS //////////////////////////////////////////////////////////////*/ function safeTransferETH(address to, uint256 amount) internal { bool success; assembly { // Transfer the ETH and store if it succeeded or not. success := call(gas(), to, amount, 0, 0, 0, 0) } require(success, "ETH_TRANSFER_FAILED"); } /*////////////////////////////////////////////////////////////// ERC20 OPERATIONS //////////////////////////////////////////////////////////////*/ function safeTransferFrom( ERC20 token, address from, address to, uint256 amount ) internal { bool success; assembly { // Get a pointer to some free memory. let freeMemoryPointer := mload(0x40) // Write the abi-encoded calldata into memory, beginning with the function selector. mstore( freeMemoryPointer, 0x23b872dd00000000000000000000000000000000000000000000000000000000 ) mstore(add(freeMemoryPointer, 4), from) // Append the "from" argument. mstore(add(freeMemoryPointer, 36), to) // Append the "to" argument. mstore(add(freeMemoryPointer, 68), amount) // Append the "amount" argument. success := and( // Set success to whether the call reverted, if not we check it either // returned exactly 1 (can't just be non-zero data), or had no return data. or( and(eq(mload(0), 1), gt(returndatasize(), 31)), iszero(returndatasize()) ), // We use 100 because the length of our calldata totals up like so: 4 + 32 * 3. // We use 0 and 32 to copy up to 32 bytes of return data into the scratch space. // Counterintuitively, this call must be positioned second to the or() call in the // surrounding and() call or else returndatasize() will be zero during the computation. call(gas(), token, 0, freeMemoryPointer, 100, 0, 32) ) } require(success, "TRANSFER_FROM_FAILED"); } function safeTransfer( ERC20 token, address to, uint256 amount ) internal { bool success; assembly { // Get a pointer to some free memory. let freeMemoryPointer := mload(0x40) // Write the abi-encoded calldata into memory, beginning with the function selector. mstore( freeMemoryPointer, 0xa9059cbb00000000000000000000000000000000000000000000000000000000 ) mstore(add(freeMemoryPointer, 4), to) // Append the "to" argument. mstore(add(freeMemoryPointer, 36), amount) // Append the "amount" argument. success := and( // Set success to whether the call reverted, if not we check it either // returned exactly 1 (can't just be non-zero data), or had no return data. or( and(eq(mload(0), 1), gt(returndatasize(), 31)), iszero(returndatasize()) ), // We use 68 because the length of our calldata totals up like so: 4 + 32 * 2. // We use 0 and 32 to copy up to 32 bytes of return data into the scratch space. // Counterintuitively, this call must be positioned second to the or() call in the // surrounding and() call or else returndatasize() will be zero during the computation. call(gas(), token, 0, freeMemoryPointer, 68, 0, 32) ) } require(success, "TRANSFER_FAILED"); } function safeApprove( ERC20 token, address to, uint256 amount ) internal { bool success; assembly { // Get a pointer to some free memory. let freeMemoryPointer := mload(0x40) // Write the abi-encoded calldata into memory, beginning with the function selector. mstore( freeMemoryPointer, 0x095ea7b300000000000000000000000000000000000000000000000000000000 ) mstore(add(freeMemoryPointer, 4), to) // Append the "to" argument. mstore(add(freeMemoryPointer, 36), amount) // Append the "amount" argument. success := and( // Set success to whether the call reverted, if not we check it either // returned exactly 1 (can't just be non-zero data), or had no return data. or( and(eq(mload(0), 1), gt(returndatasize(), 31)), iszero(returndatasize()) ), // We use 68 because the length of our calldata totals up like so: 4 + 32 * 2. // We use 0 and 32 to copy up to 32 bytes of return data into the scratch space. // Counterintuitively, this call must be positioned second to the or() call in the // surrounding and() call or else returndatasize() will be zero during the computation. call(gas(), token, 0, freeMemoryPointer, 68, 0, 32) ) } require(success, "APPROVE_FAILED"); } }
{ "evmVersion": "london", "libraries": {}, "metadata": { "bytecodeHash": "ipfs", "useLiteralContent": true }, "optimizer": { "enabled": true, "runs": 1000 }, "remappings": [], "outputSelection": { "*": { "*": [ "evm.bytecode", "evm.deployedBytecode", "devdoc", "userdoc", "metadata", "abi" ] } } }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[{"internalType":"bytes32","name":"protocolId","type":"bytes32"},{"internalType":"enum PortalType","name":"portalType","type":"uint8"},{"internalType":"contract IPortalRegistry","name":"registry","type":"address"},{"internalType":"address","name":"exchange","type":"address"},{"internalType":"address","name":"wrappedNetworkToken","type":"address"},{"internalType":"uint256","name":"fee","type":"uint256"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[{"internalType":"uint256","name":"buyAmount","type":"uint256"},{"internalType":"uint256","name":"minBuyAmount","type":"uint256"}],"name":"InsufficientBuy","type":"error"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"token","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Collect","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"oldFee","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"newFee","type":"uint256"}],"name":"Fee","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"bool","name":"paused","type":"bool"}],"name":"Pause","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"sellToken","type":"address"},{"indexed":false,"internalType":"uint256","name":"sellAmount","type":"uint256"},{"indexed":false,"internalType":"address","name":"buyToken","type":"address"},{"indexed":false,"internalType":"uint256","name":"buyAmount","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"fee","type":"uint256"},{"indexed":true,"internalType":"address","name":"sender","type":"address"},{"indexed":true,"internalType":"address","name":"partner","type":"address"}],"name":"PortalIn","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"registry","type":"address"}],"name":"UpdateRegistry","type":"event"},{"inputs":[{"internalType":"address[]","name":"tokens","type":"address[]"}],"name":"collect","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"exchange","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"fee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pause","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"paused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"sellToken","type":"address"},{"internalType":"uint256","name":"sellAmount","type":"uint256"},{"internalType":"address","name":"intermediateToken","type":"address"},{"internalType":"address","name":"buyToken","type":"address"},{"internalType":"uint256","name":"minBuyAmount","type":"uint256"},{"internalType":"address","name":"target","type":"address"},{"internalType":"bytes","name":"data","type":"bytes"},{"internalType":"address","name":"partner","type":"address"},{"internalType":"bytes","name":"poolData","type":"bytes"}],"name":"portalIn","outputs":[{"internalType":"uint256","name":"buyAmount","type":"uint256"}],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"registry","outputs":[{"internalType":"contract IPortalRegistry","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_fee","type":"uint256"}],"name":"setFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"contract IPortalRegistry","name":"_registry","type":"address"}],"name":"updateRegistry","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"wrappedNetworkToken","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]
Contract Creation Code
60c06040523480156200001157600080fd5b506040516200215638038062002156833981016040819052620000349162000377565b858585858585620000453362000172565b6001600160a01b03821660a0526200005d81620001c2565b6001600160a01b03838116608052600280546001600160a01b031916918616918217905560405163dc54e91360e01b815263dc54e91390620000a890309089908b90600401620003f6565b600060405180830381600087803b158015620000c357600080fd5b505af1158015620000d8573d6000803e3d6000fd5b5050505062000160600260009054906101000a90046001600160a01b03166001600160a01b0316638da5cb5b6040518163ffffffff1660e01b8152600401602060405180830381865afa15801562000134573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200015a919062000436565b620002a1565b5050505050505050505050506200045d565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6000546001600160a01b03163314620002115760405162461bcd60e51b815260206004820181905260248201526000805160206200213683398151915260448201526064015b60405180910390fd5b6006811015801562000224575060648111155b620002605760405162461bcd60e51b815260206004820152600b60248201526a496e76616c69642046656560a81b604482015260640162000208565b60015460408051918252602082018390527fa6205f24a082c01e6c705e20c1a026c246eedf9800b87b84440f05e8271aaf27910160405180910390a1600155565b6000546001600160a01b03163314620002ec5760405162461bcd60e51b8152602060048201819052602482015260008051602062002136833981519152604482015260640162000208565b6001600160a01b038116620003535760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840162000208565b6200035e8162000172565b50565b6001600160a01b03811681146200035e57600080fd5b60008060008060008060c087890312156200039157600080fd5b86519550602087015160028110620003a857600080fd5b6040880151909550620003bb8162000361565b6060880151909450620003ce8162000361565b6080880151909350620003e18162000361565b8092505060a087015190509295509295509295565b6001600160a01b038416815260608101600284106200042557634e487b7160e01b600052602160045260246000fd5b602082019390935260400152919050565b6000602082840312156200044957600080fd5b8151620004568162000361565b9392505050565b60805160a051611c90620004a66000396000818161010101528181610dbe01528181610df901528181610e750152610eef01526000818161024b0152610f8d0152611c906000f3fe6080604052600436106100d65760003560e01c80638456cb591161007f578063d2f7265a11610059578063d2f7265a14610239578063ddca3f431461026d578063e6baeb7a14610291578063f2fde38b146102a457600080fd5b80638456cb59146101e65780638da5cb5b146101fb578063a4520aee1461021957600080fd5b806369fe0e2d116100b057806369fe0e2d14610191578063715018a6146101b15780637b103999146101c657600080fd5b8063041bf7bc146100ef5780631a5da6c8146101405780635c975abb1461016057600080fd5b366100ea57333214156100e857600080fd5b005b600080fd5b3480156100fb57600080fd5b506101237f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b0390911681526020015b60405180910390f35b34801561014c57600080fd5b506100e861015b36600461177d565b6102c4565b34801561016c57600080fd5b5060005461018190600160a01b900460ff1681565b6040519015158152602001610137565b34801561019d57600080fd5b506100e86101ac3660046117a1565b610384565b3480156101bd57600080fd5b506100e861047d565b3480156101d257600080fd5b50600254610123906001600160a01b031681565b3480156101f257600080fd5b506100e86104e3565b34801561020757600080fd5b506000546001600160a01b0316610123565b34801561022557600080fd5b506100e86102343660046117ba565b6105be565b34801561024557600080fd5b506101237f000000000000000000000000000000000000000000000000000000000000000081565b34801561027957600080fd5b5061028360015481565b604051908152602001610137565b61028361029f366004611888565b6107f7565b3480156102b057600080fd5b506100e86102bf36600461177d565b6109ba565b6000546001600160a01b031633146103235760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064015b60405180910390fd5b6002805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0383169081179091556040519081527fe882cd4ecccebb4897bd9859948ab1e5a95e1ff3a4769e6c2893f05230e912639060200160405180910390a150565b6000546001600160a01b031633146103de5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640161031a565b600681101580156103f0575060648111155b61043c5760405162461bcd60e51b815260206004820152600b60248201527f496e76616c696420466565000000000000000000000000000000000000000000604482015260640161031a565b60015460408051918252602082018390527fa6205f24a082c01e6c705e20c1a026c246eedf9800b87b84440f05e8271aaf27910160405180910390a1600155565b6000546001600160a01b031633146104d75760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640161031a565b6104e16000610a9c565b565b6000546001600160a01b0316331461053d5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640161031a565b6000805460ff600160a01b80830482161581027fffffffffffffffffffffff00ffffffffffffffffffffffffffffffffffffffff90931692909217928390556040517f9422424b175dda897495a07b091ef74a3ef715cf6d866fc972954c1c7f459304936105b49390049091161515815260200190565b60405180910390a1565b600254604080517f913e77ad00000000000000000000000000000000000000000000000000000000815290516000926001600160a01b03169163913e77ad9160048083019260209291908290030181865afa158015610621573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610645919061196f565b90506000805b838110156107f05760008585838181106106675761066761198c565b905060200201602081019061067c919061177d565b6001600160a01b031614156106a6574791506106a16001600160a01b03841683610af9565b610775565b8484828181106106b8576106b861198c565b90506020020160208101906106cd919061177d565b6040516370a0823160e01b81523060048201526001600160a01b0391909116906370a0823190602401602060405180830381865afa158015610713573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061073791906119a2565b915061077583838787858181106107505761075061198c565b9050602002016020810190610765919061177d565b6001600160a01b03169190610b59565b7f4256a058fa2b123d727576d3d31e3a272db98ee5fe264e229610ce43dc8499998585838181106107a8576107a861198c565b90506020020160208101906107bd919061177d565b604080516001600160a01b039092168252602082018590520160405180910390a1806107e8816119d1565b91505061064b565b5050505050565b60008054600160a01b900460ff16156108525760405162461bcd60e51b815260206004820152600660248201527f5061757365640000000000000000000000000000000000000000000000000000604482015260640161031a565b8a333014610872576108648d8d610bfe565b905061086f81610ce8565b90505b6108b58d828d8b8b8b8080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250610d8792505050565b90506108c48b828c8787611179565b91508882101561090a576040517fc634b00600000000000000000000000000000000000000000000000000000000815260048101839052602481018a905260440161031a565b3330146109aa576109256001600160a01b038b163384610b59565b846001600160a01b0316336001600160a01b03167fc4d7bc58a132fd4a1b9d658b0a30809bcfb6b4959c1d3d4eb2e300d3a15099be8f8f8e876001546040516109a19594939291906001600160a01b03958616815260208101949094529190931660408301526060820192909252608081019190915260a00190565b60405180910390a35b509b9a5050505050505050505050565b6000546001600160a01b03163314610a145760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640161031a565b6001600160a01b038116610a905760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201527f6464726573730000000000000000000000000000000000000000000000000000606482015260840161031a565b610a9981610a9c565b50565b600080546001600160a01b0383811673ffffffffffffffffffffffffffffffffffffffff19831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b600080600080600085875af1905080610b545760405162461bcd60e51b815260206004820152601360248201527f4554485f5452414e534645525f4641494c454400000000000000000000000000604482015260640161031a565b505050565b60006040517fa9059cbb000000000000000000000000000000000000000000000000000000008152836004820152826024820152602060006044836000895af13d15601f3d1160016000511416171691505080610bf85760405162461bcd60e51b815260206004820152600f60248201527f5452414e534645525f4641494c45440000000000000000000000000000000000604482015260640161031a565b50505050565b60006001600160a01b038316610c7057600034118015610c1d57508134145b610c695760405162461bcd60e51b815260206004820152601d60248201527f496e76616c6964207175616e74697479206f72206d73672e76616c7565000000604482015260640161031a565b5034610ce2565b600082118015610c7e575034155b610cca5760405162461bcd60e51b815260206004820152601d60248201527f496e76616c6964207175616e74697479206f72206d73672e76616c7565000000604482015260640161031a565b610cdf6001600160a01b03841633308561150e565b50805b92915050565b6002546040516313eb467160e01b81523360048201526000916001600160a01b0316906313eb467190602401602060405180830381865afa158015610d31573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610d5591906119fa565b610d835761271060015483610d6a9190611a17565b610d749190611a36565b610d7e9083611a58565b610ce2565b5090565b6000836001600160a01b0316866001600160a01b03161415610daa575083611170565b6001600160a01b038616158015610df257507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316846001600160a01b0316145b15610e73577f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663d0e30db0866040518263ffffffff1660e01b81526004016000604051808303818588803b158015610e5257600080fd5b505af1158015610e66573d6000803e3d6000fd5b5050505050849050611170565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316866001600160a01b0316148015610ebb57506001600160a01b038416155b15610f5b576040517f2e1a7d4d000000000000000000000000000000000000000000000000000000008152600481018690527f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031690632e1a7d4d90602401600060405180830381600087803b158015610f3b57600080fd5b505af1158015610f4f573d6000803e3d6000fd5b50505050849050611170565b60006001600160a01b038716610f72575084610f7d565b610f7d8785886115b3565b6000610f8930876115dd565b90507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316856001600160a01b0316148061103457506002546040516313eb467160e01b81526001600160a01b038781166004830152909116906313eb467190602401602060405180830381865afa158015611010573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061103491906119fa565b6110805760405162461bcd60e51b815260206004820152601360248201527f556e617574686f72697a65642074617267657400000000000000000000000000604482015260640161031a565b600080866001600160a01b0316848760405161109c9190611a9b565b60006040518083038185875af1925050503d80600081146110d9576040519150601f19603f3d011682016040523d82523d6000602084013e6110de565b606091505b50915091508181906111035760405162461bcd60e51b815260040161031a9190611ab7565b508261110f308a6115dd565b6111199190611a58565b94506000851161116b5760405162461bcd60e51b815260206004820152601160248201527f496e76616c696420657865637574696f6e000000000000000000000000000000604482015260640161031a565b505050505b95945050505050565b60008080808061118b86880188611aea565b9296509094509250905060006001600160a01b038b166111ac5750886111b7565b6111b78b868c6115b3565b60006111c3308b6115dd565b90508560028614156112fb576111d761170e565b8c8187600281106111ea576111ea61198c565b602002015284611275576040517f0b4c7e4d0000000000000000000000000000000000000000000000000000000081526001600160a01b03831690630b4c7e4d90869061123e908590600090600401611b57565b6000604051808303818588803b15801561125757600080fd5b505af115801561126b573d6000803e3d6000fd5b50505050506112f5565b6040517fee22be230000000000000000000000000000000000000000000000000000000081526001600160a01b0383169063ee22be239086906112c2908590600090600190600401611b72565b6000604051808303818588803b1580156112db57600080fd5b505af11580156112ef573d6000803e3d6000fd5b50505050505b506114e8565b85600314156113c05761130c61172c565b8c81876003811061131f5761131f61198c565b602002015284611373576040517f4515cef30000000000000000000000000000000000000000000000000000000081526001600160a01b03831690634515cef390869061123e908590600090600401611bb9565b6040517f2b6e993a0000000000000000000000000000000000000000000000000000000081526001600160a01b03831690632b6e993a9086906112c2908590600090600190600401611bd4565b6113c861174a565b8c8187600481106113db576113db61198c565b602002015284611466576040517f029b2f340000000000000000000000000000000000000000000000000000000081526001600160a01b0383169063029b2f3490869061142f908590600090600401611c1b565b6000604051808303818588803b15801561144857600080fd5b505af115801561145c573d6000803e3d6000fd5b50505050506114e6565b6040517fdc3a2d810000000000000000000000000000000000000000000000000000000081526001600160a01b0383169063dc3a2d819086906114b3908590600090600190600401611c36565b6000604051808303818588803b1580156114cc57600080fd5b505af11580156114e0573d6000803e3d6000fd5b50505050505b505b816114f3308d6115dd565b6114fd9190611a58565b9d9c50505050505050505050505050565b60006040517f23b872dd0000000000000000000000000000000000000000000000000000000081528460048201528360248201528260448201526020600060648360008a5af13d15601f3d11600160005114161716915050806107f05760405162461bcd60e51b815260206004820152601460248201527f5452414e534645525f46524f4d5f4641494c4544000000000000000000000000604482015260640161031a565b826115c96001600160a01b03821684600061166f565b610bf86001600160a01b038216848461166f565b60006001600160a01b0382166115fe57506001600160a01b03821631610ce2565b6040516370a0823160e01b81526001600160a01b0384811660048301528316906370a0823190602401602060405180830381865afa158015611644573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061166891906119a2565b9050610ce2565b60006040517f095ea7b3000000000000000000000000000000000000000000000000000000008152836004820152826024820152602060006044836000895af13d15601f3d1160016000511416171691505080610bf85760405162461bcd60e51b815260206004820152600e60248201527f415050524f56455f4641494c4544000000000000000000000000000000000000604482015260640161031a565b60405180604001604052806002906020820280368337509192915050565b60405180606001604052806003906020820280368337509192915050565b60405180608001604052806004906020820280368337509192915050565b6001600160a01b0381168114610a9957600080fd5b60006020828403121561178f57600080fd5b813561179a81611768565b9392505050565b6000602082840312156117b357600080fd5b5035919050565b600080602083850312156117cd57600080fd5b823567ffffffffffffffff808211156117e557600080fd5b818501915085601f8301126117f957600080fd5b81358181111561180857600080fd5b8660208260051b850101111561181d57600080fd5b60209290920196919550909350505050565b803561183a81611768565b919050565b60008083601f84011261185157600080fd5b50813567ffffffffffffffff81111561186957600080fd5b60208301915083602082850101111561188157600080fd5b9250929050565b60008060008060008060008060008060006101208c8e0312156118aa57600080fd5b6118b48c35611768565b8b359a5060208c013599506118cc60408d0135611768565b60408c013598506118df60608d0161182f565b975060808c013596506118f460a08d0161182f565b955067ffffffffffffffff8060c08e0135111561191057600080fd5b6119208e60c08f01358f0161183f565b909650945061193160e08e0161182f565b9350806101008e0135111561194557600080fd5b506119578d6101008e01358e0161183f565b81935080925050509295989b509295989b9093969950565b60006020828403121561198157600080fd5b815161179a81611768565b634e487b7160e01b600052603260045260246000fd5b6000602082840312156119b457600080fd5b5051919050565b634e487b7160e01b600052601160045260246000fd5b60006000198214156119e5576119e56119bb565b5060010190565b8015158114610a9957600080fd5b600060208284031215611a0c57600080fd5b815161179a816119ec565b6000816000190483118215151615611a3157611a316119bb565b500290565b600082611a5357634e487b7160e01b600052601260045260246000fd5b500490565b600082821015611a6a57611a6a6119bb565b500390565b60005b83811015611a8a578181015183820152602001611a72565b83811115610bf85750506000910152565b60008251611aad818460208701611a6f565b9190910192915050565b6020815260008251806020840152611ad6816040850160208701611a6f565b601f01601f19169190910160400192915050565b60008060008060808587031215611b0057600080fd5b8435611b0b81611768565b935060208501359250604085013591506060850135611b29816119ec565b939692955090935050565b8060005b6002811015610bf8578151845260209384019390910190600101611b38565b60608101611b658285611b34565b8260408301529392505050565b60808101611b808286611b34565b8360408301528215156060830152949350505050565b8060005b6003811015610bf8578151845260209384019390910190600101611b9a565b60808101611bc78285611b96565b8260608301529392505050565b60a08101611be28286611b96565b8360608301528215156080830152949350505050565b8060005b6004811015610bf8578151845260209384019390910190600101611bfc565b60a08101611c298285611bf8565b8260808301529392505050565b60c08101611c448286611bf8565b83608083015282151560a083015294935050505056fea26469706673582212201d09c56d24fef507a3a260fc8a06dc00d8880435c7672df105e69fb207c9259664736f6c634300080b00334f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657263757276650000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000ea49d02c248b357b99670d9e9741f54f72df9cb3000000000000000000000000def1c0ded9bec7f1a1670819833240f027b25eff000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2000000000000000000000000000000000000000000000000000000000000001e
Deployed Bytecode
0x6080604052600436106100d65760003560e01c80638456cb591161007f578063d2f7265a11610059578063d2f7265a14610239578063ddca3f431461026d578063e6baeb7a14610291578063f2fde38b146102a457600080fd5b80638456cb59146101e65780638da5cb5b146101fb578063a4520aee1461021957600080fd5b806369fe0e2d116100b057806369fe0e2d14610191578063715018a6146101b15780637b103999146101c657600080fd5b8063041bf7bc146100ef5780631a5da6c8146101405780635c975abb1461016057600080fd5b366100ea57333214156100e857600080fd5b005b600080fd5b3480156100fb57600080fd5b506101237f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc281565b6040516001600160a01b0390911681526020015b60405180910390f35b34801561014c57600080fd5b506100e861015b36600461177d565b6102c4565b34801561016c57600080fd5b5060005461018190600160a01b900460ff1681565b6040519015158152602001610137565b34801561019d57600080fd5b506100e86101ac3660046117a1565b610384565b3480156101bd57600080fd5b506100e861047d565b3480156101d257600080fd5b50600254610123906001600160a01b031681565b3480156101f257600080fd5b506100e86104e3565b34801561020757600080fd5b506000546001600160a01b0316610123565b34801561022557600080fd5b506100e86102343660046117ba565b6105be565b34801561024557600080fd5b506101237f000000000000000000000000def1c0ded9bec7f1a1670819833240f027b25eff81565b34801561027957600080fd5b5061028360015481565b604051908152602001610137565b61028361029f366004611888565b6107f7565b3480156102b057600080fd5b506100e86102bf36600461177d565b6109ba565b6000546001600160a01b031633146103235760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064015b60405180910390fd5b6002805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0383169081179091556040519081527fe882cd4ecccebb4897bd9859948ab1e5a95e1ff3a4769e6c2893f05230e912639060200160405180910390a150565b6000546001600160a01b031633146103de5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640161031a565b600681101580156103f0575060648111155b61043c5760405162461bcd60e51b815260206004820152600b60248201527f496e76616c696420466565000000000000000000000000000000000000000000604482015260640161031a565b60015460408051918252602082018390527fa6205f24a082c01e6c705e20c1a026c246eedf9800b87b84440f05e8271aaf27910160405180910390a1600155565b6000546001600160a01b031633146104d75760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640161031a565b6104e16000610a9c565b565b6000546001600160a01b0316331461053d5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640161031a565b6000805460ff600160a01b80830482161581027fffffffffffffffffffffff00ffffffffffffffffffffffffffffffffffffffff90931692909217928390556040517f9422424b175dda897495a07b091ef74a3ef715cf6d866fc972954c1c7f459304936105b49390049091161515815260200190565b60405180910390a1565b600254604080517f913e77ad00000000000000000000000000000000000000000000000000000000815290516000926001600160a01b03169163913e77ad9160048083019260209291908290030181865afa158015610621573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610645919061196f565b90506000805b838110156107f05760008585838181106106675761066761198c565b905060200201602081019061067c919061177d565b6001600160a01b031614156106a6574791506106a16001600160a01b03841683610af9565b610775565b8484828181106106b8576106b861198c565b90506020020160208101906106cd919061177d565b6040516370a0823160e01b81523060048201526001600160a01b0391909116906370a0823190602401602060405180830381865afa158015610713573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061073791906119a2565b915061077583838787858181106107505761075061198c565b9050602002016020810190610765919061177d565b6001600160a01b03169190610b59565b7f4256a058fa2b123d727576d3d31e3a272db98ee5fe264e229610ce43dc8499998585838181106107a8576107a861198c565b90506020020160208101906107bd919061177d565b604080516001600160a01b039092168252602082018590520160405180910390a1806107e8816119d1565b91505061064b565b5050505050565b60008054600160a01b900460ff16156108525760405162461bcd60e51b815260206004820152600660248201527f5061757365640000000000000000000000000000000000000000000000000000604482015260640161031a565b8a333014610872576108648d8d610bfe565b905061086f81610ce8565b90505b6108b58d828d8b8b8b8080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250610d8792505050565b90506108c48b828c8787611179565b91508882101561090a576040517fc634b00600000000000000000000000000000000000000000000000000000000815260048101839052602481018a905260440161031a565b3330146109aa576109256001600160a01b038b163384610b59565b846001600160a01b0316336001600160a01b03167fc4d7bc58a132fd4a1b9d658b0a30809bcfb6b4959c1d3d4eb2e300d3a15099be8f8f8e876001546040516109a19594939291906001600160a01b03958616815260208101949094529190931660408301526060820192909252608081019190915260a00190565b60405180910390a35b509b9a5050505050505050505050565b6000546001600160a01b03163314610a145760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640161031a565b6001600160a01b038116610a905760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201527f6464726573730000000000000000000000000000000000000000000000000000606482015260840161031a565b610a9981610a9c565b50565b600080546001600160a01b0383811673ffffffffffffffffffffffffffffffffffffffff19831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b600080600080600085875af1905080610b545760405162461bcd60e51b815260206004820152601360248201527f4554485f5452414e534645525f4641494c454400000000000000000000000000604482015260640161031a565b505050565b60006040517fa9059cbb000000000000000000000000000000000000000000000000000000008152836004820152826024820152602060006044836000895af13d15601f3d1160016000511416171691505080610bf85760405162461bcd60e51b815260206004820152600f60248201527f5452414e534645525f4641494c45440000000000000000000000000000000000604482015260640161031a565b50505050565b60006001600160a01b038316610c7057600034118015610c1d57508134145b610c695760405162461bcd60e51b815260206004820152601d60248201527f496e76616c6964207175616e74697479206f72206d73672e76616c7565000000604482015260640161031a565b5034610ce2565b600082118015610c7e575034155b610cca5760405162461bcd60e51b815260206004820152601d60248201527f496e76616c6964207175616e74697479206f72206d73672e76616c7565000000604482015260640161031a565b610cdf6001600160a01b03841633308561150e565b50805b92915050565b6002546040516313eb467160e01b81523360048201526000916001600160a01b0316906313eb467190602401602060405180830381865afa158015610d31573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610d5591906119fa565b610d835761271060015483610d6a9190611a17565b610d749190611a36565b610d7e9083611a58565b610ce2565b5090565b6000836001600160a01b0316866001600160a01b03161415610daa575083611170565b6001600160a01b038616158015610df257507f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc26001600160a01b0316846001600160a01b0316145b15610e73577f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc26001600160a01b031663d0e30db0866040518263ffffffff1660e01b81526004016000604051808303818588803b158015610e5257600080fd5b505af1158015610e66573d6000803e3d6000fd5b5050505050849050611170565b7f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc26001600160a01b0316866001600160a01b0316148015610ebb57506001600160a01b038416155b15610f5b576040517f2e1a7d4d000000000000000000000000000000000000000000000000000000008152600481018690527f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc26001600160a01b031690632e1a7d4d90602401600060405180830381600087803b158015610f3b57600080fd5b505af1158015610f4f573d6000803e3d6000fd5b50505050849050611170565b60006001600160a01b038716610f72575084610f7d565b610f7d8785886115b3565b6000610f8930876115dd565b90507f000000000000000000000000def1c0ded9bec7f1a1670819833240f027b25eff6001600160a01b0316856001600160a01b0316148061103457506002546040516313eb467160e01b81526001600160a01b038781166004830152909116906313eb467190602401602060405180830381865afa158015611010573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061103491906119fa565b6110805760405162461bcd60e51b815260206004820152601360248201527f556e617574686f72697a65642074617267657400000000000000000000000000604482015260640161031a565b600080866001600160a01b0316848760405161109c9190611a9b565b60006040518083038185875af1925050503d80600081146110d9576040519150601f19603f3d011682016040523d82523d6000602084013e6110de565b606091505b50915091508181906111035760405162461bcd60e51b815260040161031a9190611ab7565b508261110f308a6115dd565b6111199190611a58565b94506000851161116b5760405162461bcd60e51b815260206004820152601160248201527f496e76616c696420657865637574696f6e000000000000000000000000000000604482015260640161031a565b505050505b95945050505050565b60008080808061118b86880188611aea565b9296509094509250905060006001600160a01b038b166111ac5750886111b7565b6111b78b868c6115b3565b60006111c3308b6115dd565b90508560028614156112fb576111d761170e565b8c8187600281106111ea576111ea61198c565b602002015284611275576040517f0b4c7e4d0000000000000000000000000000000000000000000000000000000081526001600160a01b03831690630b4c7e4d90869061123e908590600090600401611b57565b6000604051808303818588803b15801561125757600080fd5b505af115801561126b573d6000803e3d6000fd5b50505050506112f5565b6040517fee22be230000000000000000000000000000000000000000000000000000000081526001600160a01b0383169063ee22be239086906112c2908590600090600190600401611b72565b6000604051808303818588803b1580156112db57600080fd5b505af11580156112ef573d6000803e3d6000fd5b50505050505b506114e8565b85600314156113c05761130c61172c565b8c81876003811061131f5761131f61198c565b602002015284611373576040517f4515cef30000000000000000000000000000000000000000000000000000000081526001600160a01b03831690634515cef390869061123e908590600090600401611bb9565b6040517f2b6e993a0000000000000000000000000000000000000000000000000000000081526001600160a01b03831690632b6e993a9086906112c2908590600090600190600401611bd4565b6113c861174a565b8c8187600481106113db576113db61198c565b602002015284611466576040517f029b2f340000000000000000000000000000000000000000000000000000000081526001600160a01b0383169063029b2f3490869061142f908590600090600401611c1b565b6000604051808303818588803b15801561144857600080fd5b505af115801561145c573d6000803e3d6000fd5b50505050506114e6565b6040517fdc3a2d810000000000000000000000000000000000000000000000000000000081526001600160a01b0383169063dc3a2d819086906114b3908590600090600190600401611c36565b6000604051808303818588803b1580156114cc57600080fd5b505af11580156114e0573d6000803e3d6000fd5b50505050505b505b816114f3308d6115dd565b6114fd9190611a58565b9d9c50505050505050505050505050565b60006040517f23b872dd0000000000000000000000000000000000000000000000000000000081528460048201528360248201528260448201526020600060648360008a5af13d15601f3d11600160005114161716915050806107f05760405162461bcd60e51b815260206004820152601460248201527f5452414e534645525f46524f4d5f4641494c4544000000000000000000000000604482015260640161031a565b826115c96001600160a01b03821684600061166f565b610bf86001600160a01b038216848461166f565b60006001600160a01b0382166115fe57506001600160a01b03821631610ce2565b6040516370a0823160e01b81526001600160a01b0384811660048301528316906370a0823190602401602060405180830381865afa158015611644573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061166891906119a2565b9050610ce2565b60006040517f095ea7b3000000000000000000000000000000000000000000000000000000008152836004820152826024820152602060006044836000895af13d15601f3d1160016000511416171691505080610bf85760405162461bcd60e51b815260206004820152600e60248201527f415050524f56455f4641494c4544000000000000000000000000000000000000604482015260640161031a565b60405180604001604052806002906020820280368337509192915050565b60405180606001604052806003906020820280368337509192915050565b60405180608001604052806004906020820280368337509192915050565b6001600160a01b0381168114610a9957600080fd5b60006020828403121561178f57600080fd5b813561179a81611768565b9392505050565b6000602082840312156117b357600080fd5b5035919050565b600080602083850312156117cd57600080fd5b823567ffffffffffffffff808211156117e557600080fd5b818501915085601f8301126117f957600080fd5b81358181111561180857600080fd5b8660208260051b850101111561181d57600080fd5b60209290920196919550909350505050565b803561183a81611768565b919050565b60008083601f84011261185157600080fd5b50813567ffffffffffffffff81111561186957600080fd5b60208301915083602082850101111561188157600080fd5b9250929050565b60008060008060008060008060008060006101208c8e0312156118aa57600080fd5b6118b48c35611768565b8b359a5060208c013599506118cc60408d0135611768565b60408c013598506118df60608d0161182f565b975060808c013596506118f460a08d0161182f565b955067ffffffffffffffff8060c08e0135111561191057600080fd5b6119208e60c08f01358f0161183f565b909650945061193160e08e0161182f565b9350806101008e0135111561194557600080fd5b506119578d6101008e01358e0161183f565b81935080925050509295989b509295989b9093969950565b60006020828403121561198157600080fd5b815161179a81611768565b634e487b7160e01b600052603260045260246000fd5b6000602082840312156119b457600080fd5b5051919050565b634e487b7160e01b600052601160045260246000fd5b60006000198214156119e5576119e56119bb565b5060010190565b8015158114610a9957600080fd5b600060208284031215611a0c57600080fd5b815161179a816119ec565b6000816000190483118215151615611a3157611a316119bb565b500290565b600082611a5357634e487b7160e01b600052601260045260246000fd5b500490565b600082821015611a6a57611a6a6119bb565b500390565b60005b83811015611a8a578181015183820152602001611a72565b83811115610bf85750506000910152565b60008251611aad818460208701611a6f565b9190910192915050565b6020815260008251806020840152611ad6816040850160208701611a6f565b601f01601f19169190910160400192915050565b60008060008060808587031215611b0057600080fd5b8435611b0b81611768565b935060208501359250604085013591506060850135611b29816119ec565b939692955090935050565b8060005b6002811015610bf8578151845260209384019390910190600101611b38565b60608101611b658285611b34565b8260408301529392505050565b60808101611b808286611b34565b8360408301528215156060830152949350505050565b8060005b6003811015610bf8578151845260209384019390910190600101611b9a565b60808101611bc78285611b96565b8260608301529392505050565b60a08101611be28286611b96565b8360608301528215156080830152949350505050565b8060005b6004811015610bf8578151845260209384019390910190600101611bfc565b60a08101611c298285611bf8565b8260808301529392505050565b60c08101611c448286611bf8565b83608083015282151560a083015294935050505056fea26469706673582212201d09c56d24fef507a3a260fc8a06dc00d8880435c7672df105e69fb207c9259664736f6c634300080b0033
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
63757276650000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000ea49d02c248b357b99670d9e9741f54f72df9cb3000000000000000000000000def1c0ded9bec7f1a1670819833240f027b25eff000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2000000000000000000000000000000000000000000000000000000000000001e
-----Decoded View---------------
Arg [0] : protocolId (bytes32): 0x6375727665000000000000000000000000000000000000000000000000000000
Arg [1] : portalType (uint8): 0
Arg [2] : registry (address): 0xEa49D02c248b357B99670d9E9741F54f72dF9Cb3
Arg [3] : exchange (address): 0xDef1C0ded9bec7F1a1670819833240f027b25EfF
Arg [4] : wrappedNetworkToken (address): 0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2
Arg [5] : fee (uint256): 30
-----Encoded View---------------
6 Constructor Arguments found :
Arg [0] : 6375727665000000000000000000000000000000000000000000000000000000
Arg [1] : 0000000000000000000000000000000000000000000000000000000000000000
Arg [2] : 000000000000000000000000ea49d02c248b357b99670d9e9741f54f72df9cb3
Arg [3] : 000000000000000000000000def1c0ded9bec7f1a1670819833240f027b25eff
Arg [4] : 000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2
Arg [5] : 000000000000000000000000000000000000000000000000000000000000001e
Loading...
Loading
Loading...
Loading
Multichain Portfolio | 30 Chains
Chain | Token | Portfolio % | Price | Amount | Value |
---|---|---|---|---|---|
ETH | 49.11% | $1 | 66.7603 | $66.76 | |
ETH | Ether (ETH) | 34.39% | $3,110.28 | 0.015 | $46.75 |
ETH | 8.33% | $3,645.02 | 0.00310603 | $11.32 | |
ETH | 4.16% | $2.21 | 2.5565 | $5.65 | |
ETH | 2.71% | $0.651241 | 5.6632 | $3.69 | |
ETH | 0.69% | $3,110.28 | 0.0003 | $0.933 | |
ETH | 0.49% | $3,370.7 | 0.00019848 | $0.669 | |
FTM | 0.12% | $0.508399 | 0.3098 | $0.157518 | |
POL | <0.01% | $0.373187 | 0.005 | $0.001866 |
Loading...
Loading
[ Download: CSV Export ]
[ Download: CSV Export ]
A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.