ETH Price: $1,980.16 (+0.24%)
 

Overview

ETH Balance

0 ETH

Eth Value

$0.00

More Info

Private Name Tags

Multichain Info

No addresses found
Transaction Hash
Method
Block
From
To
Set Stage227140342025-06-16 2:14:11251 days ago1750040051IN
0xdE69eB5E...4bFDA24BF
0 ETH0.000029110.92952753
Buy Token225862022025-05-29 5:03:59269 days ago1748495039IN
0xdE69eB5E...4bFDA24BF
0.0009 ETH0.000358862.55181379
Buy Token225697382025-05-26 21:46:23271 days ago1748295983IN
0xdE69eB5E...4bFDA24BF
0.0624 ETH0.000205761.66554421
Buy Token225695852025-05-26 21:15:47271 days ago1748294147IN
0xdE69eB5E...4bFDA24BF
0.013 ETH0.000207341.67833109
Buy Token225691382025-05-26 19:46:11271 days ago1748288771IN
0xdE69eB5E...4bFDA24BF
0.001 ETH0.000214731.73833968
Buy Token225691342025-05-26 19:45:23271 days ago1748288723IN
0xdE69eB5E...4bFDA24BF
0.005 ETH0.000254361.80874695
Buy Token225690002025-05-26 19:18:23271 days ago1748287103IN
0xdE69eB5E...4bFDA24BF
0.0683 ETH0.000232261.88005669
Buy Token225685702025-05-26 17:52:23271 days ago1748281943IN
0xdE69eB5E...4bFDA24BF
0.0885 ETH0.000278582.25494793
Buy Token225684602025-05-26 17:30:11271 days ago1748280611IN
0xdE69eB5E...4bFDA24BF
0.0698 ETH0.000292332.36627232
Buy Token225683962025-05-26 17:17:11271 days ago1748279831IN
0xdE69eB5E...4bFDA24BF
0 ETH0.000292792.84768566
Buy Token225673872025-05-26 13:53:23271 days ago1748267603IN
0xdE69eB5E...4bFDA24BF
0.004 ETH0.000425963.02897448
Buy Token225673222025-05-26 13:40:23271 days ago1748266823IN
0xdE69eB5E...4bFDA24BF
0.02 ETH0.000212281.71835376
Buy Token225664652025-05-26 10:47:35272 days ago1748256455IN
0xdE69eB5E...4bFDA24BF
0.4651 ETH0.000149461.20979448
Buy Token225664502025-05-26 10:44:35272 days ago1748256275IN
0xdE69eB5E...4bFDA24BF
0.00054 ETH0.000143310.73336467
Buy Token225662032025-05-26 9:54:59272 days ago1748253299IN
0xdE69eB5E...4bFDA24BF
0.0005 ETH0.000216131.10597877
Buy Token225648842025-05-26 5:27:59272 days ago1748237279IN
0xdE69eB5E...4bFDA24BF
0.0028 ETH0.000055080.44595138
Buy Token225647342025-05-26 4:57:23272 days ago1748235443IN
0xdE69eB5E...4bFDA24BF
0.0068 ETH0.000175860.89993977
Buy Token225641012025-05-26 2:49:23272 days ago1748227763IN
0xdE69eB5E...4bFDA24BF
0.005 ETH0.00019431.38169587
Buy Token225640632025-05-26 2:41:47272 days ago1748227307IN
0xdE69eB5E...4bFDA24BF
0 ETH0.000093760.91199176
Buy Token225640452025-05-26 2:38:11272 days ago1748227091IN
0xdE69eB5E...4bFDA24BF
0.011 ETH0.000227050.98876686
Buy Token225640152025-05-26 2:32:11272 days ago1748226731IN
0xdE69eB5E...4bFDA24BF
0.018 ETH0.000185210.87144164
Buy Token225640142025-05-26 2:31:59272 days ago1748226719IN
0xdE69eB5E...4bFDA24BF
0.0119 ETH0.000176440.83019435
Buy Token225639852025-05-26 2:26:11272 days ago1748226371IN
0xdE69eB5E...4bFDA24BF
0.001 ETH0.000119430.84925277
Buy Token225638862025-05-26 2:05:59272 days ago1748225159IN
0xdE69eB5E...4bFDA24BF
0 ETH0.000087420.85029284
Buy Token225638702025-05-26 2:02:47272 days ago1748224967IN
0xdE69eB5E...4bFDA24BF
0 ETH0.000088420.85996676
View all transactions

Latest 25 internal transactions (View All)

Advanced mode:
Parent Transaction Hash Method Block
From
To
Transfer225862022025-05-29 5:03:59269 days ago1748495039
0xdE69eB5E...4bFDA24BF
0.0009 ETH
Transfer225697382025-05-26 21:46:23271 days ago1748295983
0xdE69eB5E...4bFDA24BF
0.0624 ETH
Transfer225695852025-05-26 21:15:47271 days ago1748294147
0xdE69eB5E...4bFDA24BF
0.013 ETH
Transfer225691382025-05-26 19:46:11271 days ago1748288771
0xdE69eB5E...4bFDA24BF
0.001 ETH
Transfer225691342025-05-26 19:45:23271 days ago1748288723
0xdE69eB5E...4bFDA24BF
0.005 ETH
Transfer225690002025-05-26 19:18:23271 days ago1748287103
0xdE69eB5E...4bFDA24BF
0.0683 ETH
Transfer225685702025-05-26 17:52:23271 days ago1748281943
0xdE69eB5E...4bFDA24BF
0.0885 ETH
Transfer225684602025-05-26 17:30:11271 days ago1748280611
0xdE69eB5E...4bFDA24BF
0.0698 ETH
Transfer225673872025-05-26 13:53:23271 days ago1748267603
0xdE69eB5E...4bFDA24BF
0.004 ETH
Transfer225673222025-05-26 13:40:23271 days ago1748266823
0xdE69eB5E...4bFDA24BF
0.02 ETH
Transfer225664652025-05-26 10:47:35272 days ago1748256455
0xdE69eB5E...4bFDA24BF
0.4651 ETH
Transfer225664502025-05-26 10:44:35272 days ago1748256275
0xdE69eB5E...4bFDA24BF
0.00054 ETH
Transfer225662032025-05-26 9:54:59272 days ago1748253299
0xdE69eB5E...4bFDA24BF
0.0005 ETH
Transfer225648842025-05-26 5:27:59272 days ago1748237279
0xdE69eB5E...4bFDA24BF
0.0028 ETH
Transfer225647342025-05-26 4:57:23272 days ago1748235443
0xdE69eB5E...4bFDA24BF
0.0068 ETH
Transfer225641012025-05-26 2:49:23272 days ago1748227763
0xdE69eB5E...4bFDA24BF
0.005 ETH
Transfer225640452025-05-26 2:38:11272 days ago1748227091
0xdE69eB5E...4bFDA24BF
0.011 ETH
Transfer225640152025-05-26 2:32:11272 days ago1748226731
0xdE69eB5E...4bFDA24BF
0.018 ETH
Transfer225640142025-05-26 2:31:59272 days ago1748226719
0xdE69eB5E...4bFDA24BF
0.0119 ETH
Transfer225639852025-05-26 2:26:11272 days ago1748226371
0xdE69eB5E...4bFDA24BF
0.001 ETH
Transfer225637552025-05-26 1:39:11272 days ago1748223551
0xdE69eB5E...4bFDA24BF
0.018 ETH
Transfer225636922025-05-26 1:26:23272 days ago1748222783
0xdE69eB5E...4bFDA24BF
0.0715 ETH
Transfer225636552025-05-26 1:18:59272 days ago1748222339
0xdE69eB5E...4bFDA24BF
0.0052 ETH
Transfer225635232025-05-26 0:52:11272 days ago1748220731
0xdE69eB5E...4bFDA24BF
0.235 ETH
Transfer225635232025-05-26 0:52:11272 days ago1748220731
0xdE69eB5E...4bFDA24BF
0.002 ETH
View All Internal Transactions
Loading...
Loading
Loading...
Loading
Cross-Chain Transactions

Block Transaction Difficulty Gas Used Reward
View All Blocks Produced

Validator Index Block Amount
View All Withdrawals

Transaction Hash Block Value Eth2 PubKey Valid
View All Deposits
Loading...
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
VULPEPRESALE

Compiler Version
v0.8.26+commit.8a97fa7a

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license
/**
 *Submitted for verification at Etherscan.io on 2025-02-22
*/

/**
 *Submitted for verification at BscScan.com on 2024-12-17
*/

// SPDX-License-Identifier: MIT
// File: @openzeppelin/contracts/utils/Context.sol


// OpenZeppelin Contracts (last updated v5.0.1) (utils/Context.sol)

pragma solidity ^0.8.20;

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

    function _contextSuffixLength() internal view virtual returns (uint256) {
        return 0;
    }
}

// File: @openzeppelin/contracts/access/Ownable.sol


// OpenZeppelin Contracts (last updated v5.0.0) (access/Ownable.sol)

pragma solidity ^0.8.20;


/**
 * @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.
 *
 * The initial owner is set to the address provided by the deployer. 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;

    /**
     * @dev The caller account is not authorized to perform an operation.
     */
    error OwnableUnauthorizedAccount(address account);

    /**
     * @dev The owner is not a valid owner account. (eg. `address(0)`)
     */
    error OwnableInvalidOwner(address owner);

    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);

    /**
     * @dev Initializes the contract setting the address provided by the deployer as the initial owner.
     */
    constructor(address initialOwner) {
        if (initialOwner == address(0)) {
            revert OwnableInvalidOwner(address(0));
        }
        _transferOwnership(initialOwner);
    }

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        _checkOwner();
        _;
    }

    /**
     * @dev Returns the address of the current owner.
     */
    function owner() public view virtual returns (address) {
        return _owner;
    }

    /**
     * @dev Throws if the sender is not the owner.
     */
    function _checkOwner() internal view virtual {
        if (owner() != _msgSender()) {
            revert OwnableUnauthorizedAccount(_msgSender());
        }
    }

    /**
     * @dev Leaves the contract without owner. It will not be possible to call
     * `onlyOwner` functions. Can only be called by the current owner.
     *
     * NOTE: Renouncing ownership will leave the contract without an owner,
     * thereby disabling 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 {
        if (newOwner == address(0)) {
            revert OwnableInvalidOwner(address(0));
        }
        _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);
    }
}

// File: @openzeppelin/contracts/token/ERC20/IERC20.sol


// OpenZeppelin Contracts (last updated v5.1.0) (token/ERC20/IERC20.sol)

pragma solidity ^0.8.20;

/**
 * @dev Interface of the ERC-20 standard as defined in the ERC.
 */
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 value of tokens in existence.
     */
    function totalSupply() external view returns (uint256);

    /**
     * @dev Returns the value of tokens owned by `account`.
     */
    function balanceOf(address account) external view returns (uint256);

    /**
     * @dev Moves a `value` amount of 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 value) 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 a `value` amount of tokens 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 value) external returns (bool);

    /**
     * @dev Moves a `value` amount of tokens from `from` to `to` using the
     * allowance mechanism. `value` 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 value) external returns (bool);
}

// File: @openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol


// OpenZeppelin Contracts (last updated v5.1.0) (token/ERC20/extensions/IERC20Metadata.sol)

pragma solidity ^0.8.20;


/**
 * @dev Interface for the optional metadata functions from the ERC-20 standard.
 */
interface IERC20Metadata is IERC20 {
    /**
     * @dev Returns the name of the token.
     */
    function name() external view returns (string memory);

    /**
     * @dev Returns the symbol of the token.
     */
    function symbol() external view returns (string memory);

    /**
     * @dev Returns the decimals places of the token.
     */
    function decimals() external view returns (uint8);
}

// File: @chainlink/contracts/src/v0.8/interfaces/AggregatorV3Interface.sol


pragma solidity ^0.8.0;

interface AggregatorV3Interface {
  function decimals() external view returns (uint8);

  function description() external view returns (string memory);

  function version() external view returns (uint256);

  function getRoundData(
    uint80 _roundId
  ) external view returns (uint80 roundId, int256 answer, uint256 startedAt, uint256 updatedAt, uint80 answeredInRound);

  function latestRoundData()
    external
    view
    returns (uint80 roundId, int256 answer, uint256 startedAt, uint256 updatedAt, uint80 answeredInRound);
}

// File: presale.sol


pragma solidity ^0.8.20;





contract VULPEPRESALE is Ownable {
    IERC20 public token;
    IERC20Metadata public tokenMetadata;
    AggregatorV3Interface public priceFeed;
    address public sellerAddress;
    address public paymentAddress;
    address public UsdtAddress;
    bool public presaleActive = true;
    uint256 public totalSold = 0;

    struct Stage {
        uint256 id;
        uint256 price;
        uint256 maxTokens;
        uint256 tokensSold;
        bool active;
    }

    struct SaleRecord {
        uint256 stageId;
        uint256 tokensSold;
        address buyer;
    }

    mapping(address => SaleRecord[]) public referallSalesRecords;

    mapping(uint256 => Stage) public stages;
    uint256 public maxStage = 10;
    uint256 currentStageId = 0;

    /***
     * constructor
     */
    constructor(
        address _seller,
        address _payment,
        address _token
    ) Ownable(msg.sender) {
        transferOwnership(0x8aB654A21D8AC187F94fac01CEbbFCcd575d6C55);
        token = IERC20(_token);
        tokenMetadata = IERC20Metadata(_token);
        sellerAddress = _seller;
        paymentAddress = _payment;
        if (block.chainid == 56) {
            UsdtAddress = 0x55d398326f99059fF775485246999027B3197955; // USDT na BSC
            priceFeed = AggregatorV3Interface(
                0x0567F2323251f0Aab15c8dFb1967E4e8A7D42aeE
            ); // ETH/USD na BSC
        } else if (block.chainid == 1) {
            UsdtAddress = 0xdAC17F958D2ee523a2206206994597C13D831ec7; // USDT na Ethereum
            priceFeed = AggregatorV3Interface(
                0x5f4eC3Df9cbd43714FE2740f5E3616155c5b8419
            ); // ETH/USD na Ethereum
        } else {
            revert("Unsupported network!");
        }
    }

    /***
     * Get the latest ETH/USD price from the Aggregator
     */
    function getEthToUsdPrice() public view returns (int256) {
        (, int256 price, , , ) = priceFeed.latestRoundData();

        return price;
    }

    /***
     * Convert ETH to USD based on the latest price from the Aggregator
     */
    function convertEthToUsd(uint256 ethAmount) public view returns (uint256) {
        int256 ethToUsdPrice = getEthToUsdPrice();

        uint256 usdAmount = (ethAmount * uint256(ethToUsdPrice)) /
            (10**priceFeed.decimals());
        return usdAmount;
    }

    function calculateWeiRequired(uint256 tokenAmount)
        public
        view
        returns (uint256)
    {
        require(presaleActive, "Presale is not active!");
        uint256 _id = getCurrentStageIdActive();
        require(_id > 0, "No active stage available!");

        Stage memory currentStage = stages[_id];

        uint256 totalPayUsd = tokenAmount * currentStage.price; // Calculate total USD needed
        uint256 ethToUsd = convertEthToUsd(1e18); // Get current ETH to USD conversion rate for 1 ETH

        uint256 totalPayInWei = (totalPayUsd * 1e18) / ethToUsd;

        return totalPayInWei;
    }

    function buyTokenWithUsdt(uint256 _amount, address _referallAddress)
        public
    {
        require(presaleActive, "Presale is not active!");
        require(_amount > 0, "Please enter minimum token amount!");

        uint256 _id = getCurrentStageIdActive();
        require(_id > 0, "Stage info not available!");

        Stage storage currentStage = stages[_id];

        uint256 totalPayInUsd = _amount * currentStage.price; // Total payment in USD
        uint256 usdtDecimals = IERC20Metadata(UsdtAddress).decimals();
        uint256 totalPayInUsdt = (totalPayInUsd * (10**usdtDecimals)) / 1e18;

        require(
            IERC20(UsdtAddress).allowance(msg.sender, address(this)) >=
                totalPayInUsdt,
            "Insufficient USDT allowance!"
        );

        // Transfer USDT to seller
        bool paymentSuccess = IERC20(UsdtAddress).transferFrom(
            msg.sender,
            paymentAddress,
            totalPayInUsdt
        );

        require(paymentSuccess, "USDT payment failed!");

        uint256 totalTokenAmount = (_amount * 1e18) /
            (10**(18 - tokenMetadata.decimals()));

        require(
            currentStage.tokensSold + totalTokenAmount <=
                currentStage.maxTokens,
            "Stage token limit exceeded!"
        );

        // Transfer tokens to buyer
        bool tokenTransferSuccess = token.transferFrom(
            sellerAddress,
            msg.sender,
            totalTokenAmount
        );

        currentStage.tokensSold += totalTokenAmount;

        require(tokenTransferSuccess, "Token transfer failed!");

        if (_referallAddress != address(0)) {
            referallSalesRecords[_referallAddress].push(
                SaleRecord({
                    stageId: _id,
                    tokensSold: totalTokenAmount,
                    buyer: msg.sender
                })
            );
        }

        totalSold += totalTokenAmount;
    }

    function buyToken(uint256 _amount, address _referallAddress)
        public
        payable
    {
        require(presaleActive, "Presale is not active!");
        require(_amount >= 0, "Please enter minimum token!");
        uint256 _id = getCurrentStageIdActive();
        require(_id > 0, "Stage info not available!");
        Stage storage currentStage = stages[_id];

        uint256 _totalPayInEther = calculateWeiRequired(_amount);
        require(msg.value >= _totalPayInEther, "Not enough payment!");

        uint256 _totalAmount = _amount * 1e18;
        uint256 _tokenDecimals = tokenMetadata.decimals();
        uint256 _subDecimals = 18 - _tokenDecimals;
        uint256 _totalTokenAmount = _totalAmount / (10**_subDecimals);

        require(
            currentStage.tokensSold + _totalTokenAmount <=
                currentStage.maxTokens,
            "Stage token limit exceeded!"
        );

        // Payment price transfer to seller address
        require(
            payable(paymentAddress).send(msg.value),
            "Failed to transfer ETH payment!"
        );

        // Purchased tokens transfer from seller address to buyer address
        bool success = token.transferFrom(
            sellerAddress,
            msg.sender,
            _totalTokenAmount
        );

        currentStage.tokensSold += _totalTokenAmount;

        require(success, "Failed to transfer token!");

        if (_referallAddress != address(0)) {
            referallSalesRecords[_referallAddress].push(
                SaleRecord({
                    stageId: _id,
                    tokensSold: _totalTokenAmount,
                    buyer: msg.sender
                })
            );
        }

        totalSold += _totalTokenAmount;
    }

    /***
     * @dev update token address
     */
    function setToken(address _token) public onlyOwner {
        require(_token != address(0), "Token is zero address!");
        token = IERC20(_token);
        tokenMetadata = IERC20Metadata(_token);
    }

    /***
     * @dev update price feed address
     */
    function setPriceFeed(address _priceFeed) public onlyOwner {
        require(_priceFeed != address(0), "Token is zero address!");
        priceFeed = AggregatorV3Interface(_priceFeed);
    }

    /***
     * @dev update sellerAddress
     */
    function setSellerAddress(address _seller) public onlyOwner {
        sellerAddress = _seller;
    }

    /***
     * @dev update paementAddress
     */
    function setPaymentAddress(address _payment) public onlyOwner {
        paymentAddress = _payment;
    }

    /***
     * @dev flip presaleActive as true/false
     */
    function flipPresaleActive() public onlyOwner {
        presaleActive = !presaleActive;
    }

    /**
     * @dev Emergency function to withdraw all presale tokens from the contract to the owner's address
     */
    function emergencyWithdraw() public onlyOwner {
        uint256 remainingTokens = token.balanceOf(address(this));
        require(remainingTokens > 0, "No tokens left to withdraw");

        bool success = token.transfer(msg.sender, remainingTokens);
        require(success, "Failed to withdraw tokens");
    }

    /***
     * @dev update maximum stage
     */
    function setMaxStage(uint256 _maxStage) public onlyOwner {
        maxStage = _maxStage;
    }

    /***
     * @dev ading stage info
     */

    function addStage(
        uint256 _price,
        uint256 _maxTokens,
        bool _active
    ) public onlyOwner {
        uint256 _id = currentStageId + 1;
        require(_id <= maxStage, "Maximum stage exceeds!");
        currentStageId += 1;

        stages[_id] = Stage({
            id: _id,
            price: _price,
            maxTokens: _maxTokens,
            tokensSold: 0,
            active: _active
        });
    }

    function setStage(
        uint256 _id,
        uint256 _price,
        uint256 _maxTokens,
        bool _active
    ) public onlyOwner {
        require(stages[_id].id == _id, "ID doesn't exist!");
        stages[_id].price = _price;
        stages[_id].maxTokens = _maxTokens;
        stages[_id].active = _active;
    }

    /***
     * @dev get current stage id active
     */

    function getCurrentStageIdActive() public view returns (uint256) {
        uint256 _id = 0;
        for (uint256 i = 1; i <= currentStageId; i++) {
            if (stages[i].active) {
                _id = i;
                break;
            }
        }
        return _id;
    }

    /***
     * @dev withdrawFunds functions to get remaining funds transfer to seller address
     */
    function withdrawFunds() public onlyOwner {
        require(
            payable(msg.sender).send(address(this).balance),
            "Failed withdraw!"
        );
    }
}

Contract Security Audit

Contract ABI

API
[{"inputs":[{"internalType":"address","name":"_seller","type":"address"},{"internalType":"address","name":"_payment","type":"address"},{"internalType":"address","name":"_token","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"OwnableInvalidOwner","type":"error"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"OwnableUnauthorizedAccount","type":"error"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"inputs":[],"name":"UsdtAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_price","type":"uint256"},{"internalType":"uint256","name":"_maxTokens","type":"uint256"},{"internalType":"bool","name":"_active","type":"bool"}],"name":"addStage","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount","type":"uint256"},{"internalType":"address","name":"_referallAddress","type":"address"}],"name":"buyToken","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount","type":"uint256"},{"internalType":"address","name":"_referallAddress","type":"address"}],"name":"buyTokenWithUsdt","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenAmount","type":"uint256"}],"name":"calculateWeiRequired","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"ethAmount","type":"uint256"}],"name":"convertEthToUsd","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"emergencyWithdraw","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"flipPresaleActive","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"getCurrentStageIdActive","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getEthToUsdPrice","outputs":[{"internalType":"int256","name":"","type":"int256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxStage","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":"paymentAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"presaleActive","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"priceFeed","outputs":[{"internalType":"contract AggregatorV3Interface","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"uint256","name":"","type":"uint256"}],"name":"referallSalesRecords","outputs":[{"internalType":"uint256","name":"stageId","type":"uint256"},{"internalType":"uint256","name":"tokensSold","type":"uint256"},{"internalType":"address","name":"buyer","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"sellerAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_maxStage","type":"uint256"}],"name":"setMaxStage","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_payment","type":"address"}],"name":"setPaymentAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_priceFeed","type":"address"}],"name":"setPriceFeed","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_seller","type":"address"}],"name":"setSellerAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"},{"internalType":"uint256","name":"_price","type":"uint256"},{"internalType":"uint256","name":"_maxTokens","type":"uint256"},{"internalType":"bool","name":"_active","type":"bool"}],"name":"setStage","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_token","type":"address"}],"name":"setToken","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"stages","outputs":[{"internalType":"uint256","name":"id","type":"uint256"},{"internalType":"uint256","name":"price","type":"uint256"},{"internalType":"uint256","name":"maxTokens","type":"uint256"},{"internalType":"uint256","name":"tokensSold","type":"uint256"},{"internalType":"bool","name":"active","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"token","outputs":[{"internalType":"contract IERC20","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokenMetadata","outputs":[{"internalType":"contract IERC20Metadata","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSold","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"withdrawFunds","outputs":[],"stateMutability":"nonpayable","type":"function"}]

60806040526006805460ff60a01b1916600160a01b1790555f6007819055600a8055600b5534801561002f575f80fd5b50604051611e1d380380611e1d83398101604081905261004e916102b2565b338061007457604051631e4fbdf760e01b81525f60048201526024015b60405180910390fd5b61007d816101dd565b5061009b738ab654a21d8ac187f94fac01cebbfccd575d6c5561022c565b600180546001600160a01b03199081166001600160a01b038481169182179093556002805483169091179055600480548216868416179055600580549091169184169190911790554660380361013857600680546001600160a01b03199081167355d398326f99059ff775485246999027b31979551790915560038054909116730567f2323251f0aab15c8dfb1967e4e8a7d42aee1790556101d5565b4660010361018d57600680546001600160a01b031990811673dac17f958d2ee523a2206206994597c13d831ec71790915560038054909116735f4ec3df9cbd43714fe2740f5e3616155c5b84191790556101d5565b60405162461bcd60e51b815260206004820152601460248201527f556e737570706f72746564206e6574776f726b21000000000000000000000000604482015260640161006b565b5050506102f2565b5f80546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b610234610269565b6001600160a01b03811661025d57604051631e4fbdf760e01b81525f600482015260240161006b565b610266816101dd565b50565b5f546001600160a01b031633146102955760405163118cdaa760e01b815233600482015260240161006b565b565b80516001600160a01b03811681146102ad575f80fd5b919050565b5f805f606084860312156102c4575f80fd5b6102cd84610297565b92506102db60208501610297565b91506102e960408501610297565b90509250925092565b611b1e806102ff5f395ff3fe6080604052600436106101c5575f3560e01c80638b190376116100f2578063c086381e11610092578063f2fde38b11610062578063f2fde38b14610542578063f44f024014610561578063f5b2cad714610580578063fc0c546a1461059f575f80fd5b8063c086381e146104e7578063d3f7836e14610506578063db2e21bc1461051a578063e08d41141461052e575f80fd5b80639134709e116100cd5780639134709e1461047757806392de21c61461048a578063a12df12e146104a9578063a3e09210146104c8575f80fd5b80638b190376146104275780638da5cb5b146104465780639106d7ba14610462575f80fd5b806361f6230211610168578063741bef1a11610138578063741bef1a14610360578063773110491461037f578063845ddcb2146103935780638603566f14610408575f80fd5b806361f62302146102ef578063633423be1461030e578063715018a61461032d578063724e78da14610341575f80fd5b80633d9b2ae6116101a35780633d9b2ae6146102465780634571a7f11461027d57806353135ca0146102a05780635e1e1004146102d0575f80fd5b8063144fa6d7146101c957806324600fc3146101ea5780632fa5ee3f146101fe575b5f80fd5b3480156101d4575f80fd5b506101e86101e3366004611752565b6105be565b005b3480156101f5575f80fd5b506101e8610646565b348015610209575f80fd5b5061021d610218366004611772565b6106a9565b6040805193845260208401929092526001600160a01b0316908201526060015b60405180910390f35b348015610251575f80fd5b50600454610265906001600160a01b031681565b6040516001600160a01b03909116815260200161023d565b348015610288575f80fd5b50610292600a5481565b60405190815260200161023d565b3480156102ab575f80fd5b506006546102c090600160a01b900460ff1681565b604051901515815260200161023d565b3480156102db575f80fd5b506101e86102ea366004611752565b6106f0565b3480156102fa575f80fd5b50600654610265906001600160a01b031681565b348015610319575f80fd5b50600554610265906001600160a01b031681565b348015610338575f80fd5b506101e861071a565b34801561034c575f80fd5b506101e861035b366004611752565b61072b565b34801561036b575f80fd5b50600354610265906001600160a01b031681565b34801561038a575f80fd5b506101e86107a4565b34801561039e575f80fd5b506103de6103ad36600461179a565b60096020525f9081526040902080546001820154600283015460038401546004909401549293919290919060ff1685565b6040805195865260208601949094529284019190915260608301521515608082015260a00161023d565b348015610413575f80fd5b5061029261042236600461179a565b6107cd565b348015610432575f80fd5b506101e861044136600461179a565b6108e8565b348015610451575f80fd5b505f546001600160a01b0316610265565b34801561046d575f80fd5b5061029260075481565b6101e86104853660046117b1565b6108f5565b348015610495575f80fd5b506101e86104a43660046117b1565b610ce9565b3480156104b4575f80fd5b506101e86104c3366004611752565b6111f2565b3480156104d3575f80fd5b506101e86104e23660046117e8565b61121c565b3480156104f2575f80fd5b5061029261050136600461179a565b6112a3565b348015610511575f80fd5b5061029261134b565b348015610525575f80fd5b506101e86113cc565b348015610539575f80fd5b50610292611554565b34801561054d575f80fd5b506101e861055c366004611752565b61159b565b34801561056c575f80fd5b506101e861057b366004611826565b6115d8565b34801561058b575f80fd5b50600254610265906001600160a01b031681565b3480156105aa575f80fd5b50600154610265906001600160a01b031681565b6105c66116bc565b6001600160a01b03811661061a5760405162461bcd60e51b8152602060048201526016602482015275546f6b656e206973207a65726f20616464726573732160501b60448201526064015b60405180910390fd5b600180546001600160a01b039092166001600160a01b0319928316811790915560028054909216179055565b61064e6116bc565b60405133904780156108fc02915f818181858888f193505050506106a75760405162461bcd60e51b815260206004820152601060248201526f4661696c65642077697468647261772160801b6044820152606401610611565b565b6008602052815f5260405f2081815481106106c2575f80fd5b5f9182526020909120600390910201805460018201546002909201549093509091506001600160a01b031683565b6106f86116bc565b600580546001600160a01b0319166001600160a01b0392909216919091179055565b6107226116bc565b6106a75f6116e8565b6107336116bc565b6001600160a01b0381166107825760405162461bcd60e51b8152602060048201526016602482015275546f6b656e206973207a65726f20616464726573732160501b6044820152606401610611565b600380546001600160a01b0319166001600160a01b0392909216919091179055565b6107ac6116bc565b6006805460ff60a01b198116600160a01b9182900460ff1615909102179055565b6006545f90600160a01b900460ff166107f85760405162461bcd60e51b81526004016106119061185c565b5f610801611554565b90505f81116108525760405162461bcd60e51b815260206004820152601a60248201527f4e6f2061637469766520737461676520617661696c61626c65210000000000006044820152606401610611565b5f818152600960209081526040808320815160a081018352815481526001820154938101849052600282015492810192909252600381015460608301526004015460ff161515608082015291906108a990866118a0565b90505f6108bd670de0b6b3a76400006112a3565b90505f816108d384670de0b6b3a76400006118a0565b6108dd91906118bd565b979650505050505050565b6108f06116bc565b600a55565b600654600160a01b900460ff1661091e5760405162461bcd60e51b81526004016106119061185c565b5f610927611554565b90505f81116109745760405162461bcd60e51b8152602060048201526019602482015278537461676520696e666f206e6f7420617661696c61626c652160381b6044820152606401610611565b5f8181526009602052604081209061098b856107cd565b9050803410156109d35760405162461bcd60e51b81526020600482015260136024820152724e6f7420656e6f756768207061796d656e742160681b6044820152606401610611565b5f6109e686670de0b6b3a76400006118a0565b90505f60025f9054906101000a90046001600160a01b03166001600160a01b031663313ce5676040518163ffffffff1660e01b8152600401602060405180830381865afa158015610a39573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610a5d91906118dc565b60ff1690505f610a6e8260126118fc565b90505f610a7c82600a6119f2565b610a8690856118bd565b90508560020154818760030154610a9d91906119fd565b1115610aeb5760405162461bcd60e51b815260206004820152601b60248201527f537461676520746f6b656e206c696d69742065786365656465642100000000006044820152606401610611565b6005546040516001600160a01b03909116903480156108fc02915f818181858888f19350505050610b5e5760405162461bcd60e51b815260206004820152601f60248201527f4661696c656420746f207472616e7366657220455448207061796d656e7421006044820152606401610611565b600154600480546040516323b872dd60e01b81526001600160a01b0391821692810192909252336024830152604482018490525f9216906323b872dd906064016020604051808303815f875af1158015610bba573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610bde9190611a10565b905081876003015f828254610bf391906119fd565b90915550819050610c465760405162461bcd60e51b815260206004820152601960248201527f4661696c656420746f207472616e7366657220746f6b656e21000000000000006044820152606401610611565b6001600160a01b03891615610cc7576001600160a01b038981165f90815260086020908152604080832081516060810183528d8152808401888152339382019384528254600180820185559387529490952090516003909402019283559251928201929092559051600290910180546001600160a01b031916919092161790555b8160075f828254610cd891906119fd565b909155505050505050505050505050565b600654600160a01b900460ff16610d125760405162461bcd60e51b81526004016106119061185c565b5f8211610d6c5760405162461bcd60e51b815260206004820152602260248201527f506c6561736520656e746572206d696e696d756d20746f6b656e20616d6f756e604482015261742160f01b6064820152608401610611565b5f610d75611554565b90505f8111610dc25760405162461bcd60e51b8152602060048201526019602482015278537461676520696e666f206e6f7420617661696c61626c652160381b6044820152606401610611565b5f8181526009602052604081206001810154909190610de190866118a0565b90505f60065f9054906101000a90046001600160a01b03166001600160a01b031663313ce5676040518163ffffffff1660e01b8152600401602060405180830381865afa158015610e34573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610e5891906118dc565b60ff1690505f670de0b6b3a7640000610e7283600a6119f2565b610e7c90856118a0565b610e8691906118bd565b600654604051636eb1769f60e11b815233600482015230602482015291925082916001600160a01b039091169063dd62ed3e90604401602060405180830381865afa158015610ed7573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610efb9190611a2b565b1015610f495760405162461bcd60e51b815260206004820152601c60248201527f496e73756666696369656e74205553445420616c6c6f77616e636521000000006044820152606401610611565b6006546005546040516323b872dd60e01b81523360048201526001600160a01b039182166024820152604481018490525f9291909116906323b872dd906064016020604051808303815f875af1158015610fa5573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610fc99190611a10565b90508061100f5760405162461bcd60e51b815260206004820152601460248201527355534454207061796d656e74206661696c65642160601b6044820152606401610611565b6002546040805163313ce56760e01b815290515f926001600160a01b03169163313ce5679160048083019260209291908290030181865afa158015611056573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061107a91906118dc565b611085906012611a42565b61109090600a611a5b565b6110a28a670de0b6b3a76400006118a0565b6110ac91906118bd565b905085600201548187600301546110c391906119fd565b11156111115760405162461bcd60e51b815260206004820152601b60248201527f537461676520746f6b656e206c696d69742065786365656465642100000000006044820152606401610611565b600154600480546040516323b872dd60e01b81526001600160a01b0391821692810192909252336024830152604482018490525f9216906323b872dd906064016020604051808303815f875af115801561116d573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906111919190611a10565b905081876003015f8282546111a691906119fd565b90915550819050610c465760405162461bcd60e51b8152602060048201526016602482015275546f6b656e207472616e73666572206661696c65642160501b6044820152606401610611565b6111fa6116bc565b600480546001600160a01b0319166001600160a01b0392909216919091179055565b6112246116bc565b5f8481526009602052604090205484146112745760405162461bcd60e51b8152602060048201526011602482015270494420646f65736e27742065786973742160781b6044820152606401610611565b5f9384526009602052604090932060018101929092556002820155600401805460ff1916911515919091179055565b5f806112ad61134b565b90505f60035f9054906101000a90046001600160a01b03166001600160a01b031663313ce5676040518163ffffffff1660e01b8152600401602060405180830381865afa158015611300573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061132491906118dc565b61132f90600a611a5b565b61133983866118a0565b61134391906118bd565b949350505050565b5f8060035f9054906101000a90046001600160a01b03166001600160a01b031663feaf968c6040518163ffffffff1660e01b815260040160a060405180830381865afa15801561139d573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906113c19190611a82565b509195945050505050565b6113d46116bc565b6001546040516370a0823160e01b81523060048201525f916001600160a01b0316906370a0823190602401602060405180830381865afa15801561141a573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061143e9190611a2b565b90505f811161148f5760405162461bcd60e51b815260206004820152601a60248201527f4e6f20746f6b656e73206c65667420746f2077697468647261770000000000006044820152606401610611565b60015460405163a9059cbb60e01b8152336004820152602481018390525f916001600160a01b03169063a9059cbb906044016020604051808303815f875af11580156114dd573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906115019190611a10565b9050806115505760405162461bcd60e51b815260206004820152601960248201527f4661696c656420746f20776974686472617720746f6b656e73000000000000006044820152606401610611565b5050565b5f8060015b600b548111611595575f8181526009602052604090206004015460ff161561158357809150611595565b8061158d81611ad0565b915050611559565b50919050565b6115a36116bc565b6001600160a01b0381166115cc57604051631e4fbdf760e01b81525f6004820152602401610611565b6115d5816116e8565b50565b6115e06116bc565b5f600b5460016115f091906119fd565b9050600a5481111561163d5760405162461bcd60e51b81526020600482015260166024820152754d6178696d756d20737461676520657863656564732160501b6044820152606401610611565b6001600b5f82825461164f91906119fd565b90915550506040805160a08101825282815260208082019687528183019586525f6060830181815295151560808401908152948152600990915291909120905181559351600185015591516002840155516003830155516004909101805460ff1916911515919091179055565b5f546001600160a01b031633146106a75760405163118cdaa760e01b8152336004820152602401610611565b5f80546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b80356001600160a01b038116811461174d575f80fd5b919050565b5f60208284031215611762575f80fd5b61176b82611737565b9392505050565b5f8060408385031215611783575f80fd5b61178c83611737565b946020939093013593505050565b5f602082840312156117aa575f80fd5b5035919050565b5f80604083850312156117c2575f80fd5b823591506117d260208401611737565b90509250929050565b80151581146115d5575f80fd5b5f805f80608085870312156117fb575f80fd5b843593506020850135925060408501359150606085013561181b816117db565b939692955090935050565b5f805f60608486031215611838575f80fd5b83359250602084013591506040840135611851816117db565b809150509250925092565b60208082526016908201527550726573616c65206973206e6f74206163746976652160501b604082015260600190565b634e487b7160e01b5f52601160045260245ffd5b80820281158282048414176118b7576118b761188c565b92915050565b5f826118d757634e487b7160e01b5f52601260045260245ffd5b500490565b5f602082840312156118ec575f80fd5b815160ff8116811461176b575f80fd5b818103818111156118b7576118b761188c565b6001815b600184111561194a5780850481111561192e5761192e61188c565b600184161561193c57908102905b60019390931c928002611913565b935093915050565b5f82611960575060016118b7565b8161196c57505f6118b7565b8160018114611982576002811461198c576119a8565b60019150506118b7565b60ff84111561199d5761199d61188c565b50506001821b6118b7565b5060208310610133831016604e8410600b84101617156119cb575081810a6118b7565b6119d75f19848461190f565b805f19048211156119ea576119ea61188c565b029392505050565b5f61176b8383611952565b808201808211156118b7576118b761188c565b5f60208284031215611a20575f80fd5b815161176b816117db565b5f60208284031215611a3b575f80fd5b5051919050565b60ff82811682821603908111156118b7576118b761188c565b5f61176b60ff841683611952565b805169ffffffffffffffffffff8116811461174d575f80fd5b5f805f805f60a08688031215611a96575f80fd5b611a9f86611a69565b60208701516040880151606089015192975090955093509150611ac460808701611a69565b90509295509295909350565b5f60018201611ae157611ae161188c565b506001019056fea2646970667358221220813de293a171c82f52d653588bc780c1fcf16ddaa10af24f0704f8ff0c76ac5264736f6c634300081a00330000000000000000000000008ab654a21d8ac187f94fac01cebbfccd575d6c550000000000000000000000003648628caff83a3cbc042ded9e84f8a1079ef54a0000000000000000000000007677cfeb8cad684a1a6c9a8cb1335e680065d11e

Deployed Bytecode

0x6080604052600436106101c5575f3560e01c80638b190376116100f2578063c086381e11610092578063f2fde38b11610062578063f2fde38b14610542578063f44f024014610561578063f5b2cad714610580578063fc0c546a1461059f575f80fd5b8063c086381e146104e7578063d3f7836e14610506578063db2e21bc1461051a578063e08d41141461052e575f80fd5b80639134709e116100cd5780639134709e1461047757806392de21c61461048a578063a12df12e146104a9578063a3e09210146104c8575f80fd5b80638b190376146104275780638da5cb5b146104465780639106d7ba14610462575f80fd5b806361f6230211610168578063741bef1a11610138578063741bef1a14610360578063773110491461037f578063845ddcb2146103935780638603566f14610408575f80fd5b806361f62302146102ef578063633423be1461030e578063715018a61461032d578063724e78da14610341575f80fd5b80633d9b2ae6116101a35780633d9b2ae6146102465780634571a7f11461027d57806353135ca0146102a05780635e1e1004146102d0575f80fd5b8063144fa6d7146101c957806324600fc3146101ea5780632fa5ee3f146101fe575b5f80fd5b3480156101d4575f80fd5b506101e86101e3366004611752565b6105be565b005b3480156101f5575f80fd5b506101e8610646565b348015610209575f80fd5b5061021d610218366004611772565b6106a9565b6040805193845260208401929092526001600160a01b0316908201526060015b60405180910390f35b348015610251575f80fd5b50600454610265906001600160a01b031681565b6040516001600160a01b03909116815260200161023d565b348015610288575f80fd5b50610292600a5481565b60405190815260200161023d565b3480156102ab575f80fd5b506006546102c090600160a01b900460ff1681565b604051901515815260200161023d565b3480156102db575f80fd5b506101e86102ea366004611752565b6106f0565b3480156102fa575f80fd5b50600654610265906001600160a01b031681565b348015610319575f80fd5b50600554610265906001600160a01b031681565b348015610338575f80fd5b506101e861071a565b34801561034c575f80fd5b506101e861035b366004611752565b61072b565b34801561036b575f80fd5b50600354610265906001600160a01b031681565b34801561038a575f80fd5b506101e86107a4565b34801561039e575f80fd5b506103de6103ad36600461179a565b60096020525f9081526040902080546001820154600283015460038401546004909401549293919290919060ff1685565b6040805195865260208601949094529284019190915260608301521515608082015260a00161023d565b348015610413575f80fd5b5061029261042236600461179a565b6107cd565b348015610432575f80fd5b506101e861044136600461179a565b6108e8565b348015610451575f80fd5b505f546001600160a01b0316610265565b34801561046d575f80fd5b5061029260075481565b6101e86104853660046117b1565b6108f5565b348015610495575f80fd5b506101e86104a43660046117b1565b610ce9565b3480156104b4575f80fd5b506101e86104c3366004611752565b6111f2565b3480156104d3575f80fd5b506101e86104e23660046117e8565b61121c565b3480156104f2575f80fd5b5061029261050136600461179a565b6112a3565b348015610511575f80fd5b5061029261134b565b348015610525575f80fd5b506101e86113cc565b348015610539575f80fd5b50610292611554565b34801561054d575f80fd5b506101e861055c366004611752565b61159b565b34801561056c575f80fd5b506101e861057b366004611826565b6115d8565b34801561058b575f80fd5b50600254610265906001600160a01b031681565b3480156105aa575f80fd5b50600154610265906001600160a01b031681565b6105c66116bc565b6001600160a01b03811661061a5760405162461bcd60e51b8152602060048201526016602482015275546f6b656e206973207a65726f20616464726573732160501b60448201526064015b60405180910390fd5b600180546001600160a01b039092166001600160a01b0319928316811790915560028054909216179055565b61064e6116bc565b60405133904780156108fc02915f818181858888f193505050506106a75760405162461bcd60e51b815260206004820152601060248201526f4661696c65642077697468647261772160801b6044820152606401610611565b565b6008602052815f5260405f2081815481106106c2575f80fd5b5f9182526020909120600390910201805460018201546002909201549093509091506001600160a01b031683565b6106f86116bc565b600580546001600160a01b0319166001600160a01b0392909216919091179055565b6107226116bc565b6106a75f6116e8565b6107336116bc565b6001600160a01b0381166107825760405162461bcd60e51b8152602060048201526016602482015275546f6b656e206973207a65726f20616464726573732160501b6044820152606401610611565b600380546001600160a01b0319166001600160a01b0392909216919091179055565b6107ac6116bc565b6006805460ff60a01b198116600160a01b9182900460ff1615909102179055565b6006545f90600160a01b900460ff166107f85760405162461bcd60e51b81526004016106119061185c565b5f610801611554565b90505f81116108525760405162461bcd60e51b815260206004820152601a60248201527f4e6f2061637469766520737461676520617661696c61626c65210000000000006044820152606401610611565b5f818152600960209081526040808320815160a081018352815481526001820154938101849052600282015492810192909252600381015460608301526004015460ff161515608082015291906108a990866118a0565b90505f6108bd670de0b6b3a76400006112a3565b90505f816108d384670de0b6b3a76400006118a0565b6108dd91906118bd565b979650505050505050565b6108f06116bc565b600a55565b600654600160a01b900460ff1661091e5760405162461bcd60e51b81526004016106119061185c565b5f610927611554565b90505f81116109745760405162461bcd60e51b8152602060048201526019602482015278537461676520696e666f206e6f7420617661696c61626c652160381b6044820152606401610611565b5f8181526009602052604081209061098b856107cd565b9050803410156109d35760405162461bcd60e51b81526020600482015260136024820152724e6f7420656e6f756768207061796d656e742160681b6044820152606401610611565b5f6109e686670de0b6b3a76400006118a0565b90505f60025f9054906101000a90046001600160a01b03166001600160a01b031663313ce5676040518163ffffffff1660e01b8152600401602060405180830381865afa158015610a39573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610a5d91906118dc565b60ff1690505f610a6e8260126118fc565b90505f610a7c82600a6119f2565b610a8690856118bd565b90508560020154818760030154610a9d91906119fd565b1115610aeb5760405162461bcd60e51b815260206004820152601b60248201527f537461676520746f6b656e206c696d69742065786365656465642100000000006044820152606401610611565b6005546040516001600160a01b03909116903480156108fc02915f818181858888f19350505050610b5e5760405162461bcd60e51b815260206004820152601f60248201527f4661696c656420746f207472616e7366657220455448207061796d656e7421006044820152606401610611565b600154600480546040516323b872dd60e01b81526001600160a01b0391821692810192909252336024830152604482018490525f9216906323b872dd906064016020604051808303815f875af1158015610bba573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610bde9190611a10565b905081876003015f828254610bf391906119fd565b90915550819050610c465760405162461bcd60e51b815260206004820152601960248201527f4661696c656420746f207472616e7366657220746f6b656e21000000000000006044820152606401610611565b6001600160a01b03891615610cc7576001600160a01b038981165f90815260086020908152604080832081516060810183528d8152808401888152339382019384528254600180820185559387529490952090516003909402019283559251928201929092559051600290910180546001600160a01b031916919092161790555b8160075f828254610cd891906119fd565b909155505050505050505050505050565b600654600160a01b900460ff16610d125760405162461bcd60e51b81526004016106119061185c565b5f8211610d6c5760405162461bcd60e51b815260206004820152602260248201527f506c6561736520656e746572206d696e696d756d20746f6b656e20616d6f756e604482015261742160f01b6064820152608401610611565b5f610d75611554565b90505f8111610dc25760405162461bcd60e51b8152602060048201526019602482015278537461676520696e666f206e6f7420617661696c61626c652160381b6044820152606401610611565b5f8181526009602052604081206001810154909190610de190866118a0565b90505f60065f9054906101000a90046001600160a01b03166001600160a01b031663313ce5676040518163ffffffff1660e01b8152600401602060405180830381865afa158015610e34573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610e5891906118dc565b60ff1690505f670de0b6b3a7640000610e7283600a6119f2565b610e7c90856118a0565b610e8691906118bd565b600654604051636eb1769f60e11b815233600482015230602482015291925082916001600160a01b039091169063dd62ed3e90604401602060405180830381865afa158015610ed7573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610efb9190611a2b565b1015610f495760405162461bcd60e51b815260206004820152601c60248201527f496e73756666696369656e74205553445420616c6c6f77616e636521000000006044820152606401610611565b6006546005546040516323b872dd60e01b81523360048201526001600160a01b039182166024820152604481018490525f9291909116906323b872dd906064016020604051808303815f875af1158015610fa5573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610fc99190611a10565b90508061100f5760405162461bcd60e51b815260206004820152601460248201527355534454207061796d656e74206661696c65642160601b6044820152606401610611565b6002546040805163313ce56760e01b815290515f926001600160a01b03169163313ce5679160048083019260209291908290030181865afa158015611056573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061107a91906118dc565b611085906012611a42565b61109090600a611a5b565b6110a28a670de0b6b3a76400006118a0565b6110ac91906118bd565b905085600201548187600301546110c391906119fd565b11156111115760405162461bcd60e51b815260206004820152601b60248201527f537461676520746f6b656e206c696d69742065786365656465642100000000006044820152606401610611565b600154600480546040516323b872dd60e01b81526001600160a01b0391821692810192909252336024830152604482018490525f9216906323b872dd906064016020604051808303815f875af115801561116d573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906111919190611a10565b905081876003015f8282546111a691906119fd565b90915550819050610c465760405162461bcd60e51b8152602060048201526016602482015275546f6b656e207472616e73666572206661696c65642160501b6044820152606401610611565b6111fa6116bc565b600480546001600160a01b0319166001600160a01b0392909216919091179055565b6112246116bc565b5f8481526009602052604090205484146112745760405162461bcd60e51b8152602060048201526011602482015270494420646f65736e27742065786973742160781b6044820152606401610611565b5f9384526009602052604090932060018101929092556002820155600401805460ff1916911515919091179055565b5f806112ad61134b565b90505f60035f9054906101000a90046001600160a01b03166001600160a01b031663313ce5676040518163ffffffff1660e01b8152600401602060405180830381865afa158015611300573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061132491906118dc565b61132f90600a611a5b565b61133983866118a0565b61134391906118bd565b949350505050565b5f8060035f9054906101000a90046001600160a01b03166001600160a01b031663feaf968c6040518163ffffffff1660e01b815260040160a060405180830381865afa15801561139d573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906113c19190611a82565b509195945050505050565b6113d46116bc565b6001546040516370a0823160e01b81523060048201525f916001600160a01b0316906370a0823190602401602060405180830381865afa15801561141a573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061143e9190611a2b565b90505f811161148f5760405162461bcd60e51b815260206004820152601a60248201527f4e6f20746f6b656e73206c65667420746f2077697468647261770000000000006044820152606401610611565b60015460405163a9059cbb60e01b8152336004820152602481018390525f916001600160a01b03169063a9059cbb906044016020604051808303815f875af11580156114dd573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906115019190611a10565b9050806115505760405162461bcd60e51b815260206004820152601960248201527f4661696c656420746f20776974686472617720746f6b656e73000000000000006044820152606401610611565b5050565b5f8060015b600b548111611595575f8181526009602052604090206004015460ff161561158357809150611595565b8061158d81611ad0565b915050611559565b50919050565b6115a36116bc565b6001600160a01b0381166115cc57604051631e4fbdf760e01b81525f6004820152602401610611565b6115d5816116e8565b50565b6115e06116bc565b5f600b5460016115f091906119fd565b9050600a5481111561163d5760405162461bcd60e51b81526020600482015260166024820152754d6178696d756d20737461676520657863656564732160501b6044820152606401610611565b6001600b5f82825461164f91906119fd565b90915550506040805160a08101825282815260208082019687528183019586525f6060830181815295151560808401908152948152600990915291909120905181559351600185015591516002840155516003830155516004909101805460ff1916911515919091179055565b5f546001600160a01b031633146106a75760405163118cdaa760e01b8152336004820152602401610611565b5f80546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b80356001600160a01b038116811461174d575f80fd5b919050565b5f60208284031215611762575f80fd5b61176b82611737565b9392505050565b5f8060408385031215611783575f80fd5b61178c83611737565b946020939093013593505050565b5f602082840312156117aa575f80fd5b5035919050565b5f80604083850312156117c2575f80fd5b823591506117d260208401611737565b90509250929050565b80151581146115d5575f80fd5b5f805f80608085870312156117fb575f80fd5b843593506020850135925060408501359150606085013561181b816117db565b939692955090935050565b5f805f60608486031215611838575f80fd5b83359250602084013591506040840135611851816117db565b809150509250925092565b60208082526016908201527550726573616c65206973206e6f74206163746976652160501b604082015260600190565b634e487b7160e01b5f52601160045260245ffd5b80820281158282048414176118b7576118b761188c565b92915050565b5f826118d757634e487b7160e01b5f52601260045260245ffd5b500490565b5f602082840312156118ec575f80fd5b815160ff8116811461176b575f80fd5b818103818111156118b7576118b761188c565b6001815b600184111561194a5780850481111561192e5761192e61188c565b600184161561193c57908102905b60019390931c928002611913565b935093915050565b5f82611960575060016118b7565b8161196c57505f6118b7565b8160018114611982576002811461198c576119a8565b60019150506118b7565b60ff84111561199d5761199d61188c565b50506001821b6118b7565b5060208310610133831016604e8410600b84101617156119cb575081810a6118b7565b6119d75f19848461190f565b805f19048211156119ea576119ea61188c565b029392505050565b5f61176b8383611952565b808201808211156118b7576118b761188c565b5f60208284031215611a20575f80fd5b815161176b816117db565b5f60208284031215611a3b575f80fd5b5051919050565b60ff82811682821603908111156118b7576118b761188c565b5f61176b60ff841683611952565b805169ffffffffffffffffffff8116811461174d575f80fd5b5f805f805f60a08688031215611a96575f80fd5b611a9f86611a69565b60208701516040880151606089015192975090955093509150611ac460808701611a69565b90509295509295909350565b5f60018201611ae157611ae161188c565b506001019056fea2646970667358221220813de293a171c82f52d653588bc780c1fcf16ddaa10af24f0704f8ff0c76ac5264736f6c634300081a0033

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

0000000000000000000000008ab654a21d8ac187f94fac01cebbfccd575d6c550000000000000000000000003648628caff83a3cbc042ded9e84f8a1079ef54a0000000000000000000000007677cfeb8cad684a1a6c9a8cb1335e680065d11e

-----Decoded View---------------
Arg [0] : _seller (address): 0x8aB654A21D8AC187F94fac01CEbbFCcd575d6C55
Arg [1] : _payment (address): 0x3648628cAFF83A3CBc042Ded9E84f8A1079eF54A
Arg [2] : _token (address): 0x7677cFEb8caD684a1a6C9a8CB1335E680065D11e

-----Encoded View---------------
3 Constructor Arguments found :
Arg [0] : 0000000000000000000000008ab654a21d8ac187f94fac01cebbfccd575d6c55
Arg [1] : 0000000000000000000000003648628caff83a3cbc042ded9e84f8a1079ef54a
Arg [2] : 0000000000000000000000007677cfeb8cad684a1a6c9a8cb1335e680065d11e


Deployed Bytecode Sourcemap

8632:10018:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;15581:207;;;;;;;;;;-1:-1:-1;15581:207:0;;;;;:::i;:::-;;:::i;:::-;;18473:174;;;;;;;;;;;;;:::i;9231:60::-;;;;;;;;;;-1:-1:-1;9231:60:0;;;;;:::i;:::-;;:::i;:::-;;;;890:25:1;;;946:2;931:18;;924:34;;;;-1:-1:-1;;;;;994:32:1;974:18;;;967:60;878:2;863:18;9231:60:0;;;;;;;;8785:28;;;;;;;;;;-1:-1:-1;8785:28:0;;;;-1:-1:-1;;;;;8785:28:0;;;;;;-1:-1:-1;;;;;1202:32:1;;;1184:51;;1172:2;1157:18;8785:28:0;1038:203:1;9346:28:0;;;;;;;;;;;;;;;;;;;1392:25:1;;;1380:2;1365:18;9346:28:0;1246:177:1;8889:32:0;;;;;;;;;;-1:-1:-1;8889:32:0;;;;-1:-1:-1;;;8889:32:0;;;;;;;;;1593:14:1;;1586:22;1568:41;;1556:2;1541:18;8889:32:0;1428:187:1;16272:106:0;;;;;;;;;;-1:-1:-1;16272:106:0;;;;;:::i;:::-;;:::i;8856:26::-;;;;;;;;;;-1:-1:-1;8856:26:0;;;;-1:-1:-1;;;;;8856:26:0;;;8820:29;;;;;;;;;;-1:-1:-1;8820:29:0;;;;-1:-1:-1;;;;;8820:29:0;;;3464:103;;;;;;;;;;;;;:::i;15854:193::-;;;;;;;;;;-1:-1:-1;15854:193:0;;;;;:::i;:::-;;:::i;8740:38::-;;;;;;;;;;-1:-1:-1;8740:38:0;;;;-1:-1:-1;;;;;8740:38:0;;;16451:95;;;;;;;;;;;;;:::i;9300:39::-;;;;;;;;;;-1:-1:-1;9300:39:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2341:25:1;;;2397:2;2382:18;;2375:34;;;;2425:18;;;2418:34;;;;2483:2;2468:18;;2461:34;2539:14;2532:22;2526:3;2511:19;;2504:51;2328:3;2313:19;9300:39:0;2088:473:1;11039:640:0;;;;;;;;;;-1:-1:-1;11039:640:0;;;;;:::i;:::-;;:::i;17054:96::-;;;;;;;;;;-1:-1:-1;17054:96:0;;;;;:::i;:::-;;:::i;2789:87::-;;;;;;;;;;-1:-1:-1;2835:7:0;2862:6;-1:-1:-1;;;;;2862:6:0;2789:87;;8928:28;;;;;;;;;;;;;;;;13711:1809;;;;;;:::i;:::-;;:::i;11687:2016::-;;;;;;;;;;-1:-1:-1;11687:2016:0;;;;;:::i;:::-;;:::i;16108:102::-;;;;;;;;;;-1:-1:-1;16108:102:0;;;;;:::i;:::-;;:::i;17667:332::-;;;;;;;;;;-1:-1:-1;17667:332:0;;;;;:::i;:::-;;:::i;10759:272::-;;;;;;;;;;-1:-1:-1;10759:272:0;;;;;:::i;:::-;;:::i;10506:153::-;;;;;;;;;;;;;:::i;16676:317::-;;;;;;;;;;;;;:::i;18069:290::-;;;;;;;;;;;;;:::i;3722:220::-;;;;;;;;;;-1:-1:-1;3722:220:0;;;;;:::i;:::-;;:::i;17209:450::-;;;;;;;;;;-1:-1:-1;17209:450:0;;;;;:::i;:::-;;:::i;8698:35::-;;;;;;;;;;-1:-1:-1;8698:35:0;;;;-1:-1:-1;;;;;8698:35:0;;;8672:19;;;;;;;;;;-1:-1:-1;8672:19:0;;;;-1:-1:-1;;;;;8672:19:0;;;15581:207;2675:13;:11;:13::i;:::-;-1:-1:-1;;;;;15651:20:0;::::1;15643:55;;;::::0;-1:-1:-1;;;15643:55:0;;4921:2:1;15643:55:0::1;::::0;::::1;4903:21:1::0;4960:2;4940:18;;;4933:30;-1:-1:-1;;;4979:18:1;;;4972:52;5041:18;;15643:55:0::1;;;;;;;;;15709:5;:22:::0;;-1:-1:-1;;;;;15709:22:0;;::::1;-1:-1:-1::0;;;;;;15709:22:0;;::::1;::::0;::::1;::::0;;;15742:13:::1;:38:::0;;;;::::1;;::::0;;15581:207::o;18473:174::-;2675:13;:11;:13::i;:::-;18548:47:::1;::::0;18556:10:::1;::::0;18573:21:::1;18548:47:::0;::::1;;;::::0;::::1;::::0;;;18573:21;18556:10;18548:47;::::1;;;;;;18526:113;;;::::0;-1:-1:-1;;;18526:113:0;;5272:2:1;18526:113:0::1;::::0;::::1;5254:21:1::0;5311:2;5291:18;;;5284:30;-1:-1:-1;;;5330:18:1;;;5323:46;5386:18;;18526:113:0::1;5070:340:1::0;18526:113:0::1;18473:174::o:0;9231:60::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;9231:60:0;;-1:-1:-1;;;;;;9231:60:0;;:::o;16272:106::-;2675:13;:11;:13::i;:::-;16345:14:::1;:25:::0;;-1:-1:-1;;;;;;16345:25:0::1;-1:-1:-1::0;;;;;16345:25:0;;;::::1;::::0;;;::::1;::::0;;16272:106::o;3464:103::-;2675:13;:11;:13::i;:::-;3529:30:::1;3556:1;3529:18;:30::i;15854:193::-:0;2675:13;:11;:13::i;:::-;-1:-1:-1;;;;;15932:24:0;::::1;15924:59;;;::::0;-1:-1:-1;;;15924:59:0;;4921:2:1;15924:59:0::1;::::0;::::1;4903:21:1::0;4960:2;4940:18;;;4933:30;-1:-1:-1;;;4979:18:1;;;4972:52;5041:18;;15924:59:0::1;4719:346:1::0;15924:59:0::1;15994:9;:45:::0;;-1:-1:-1;;;;;;15994:45:0::1;-1:-1:-1::0;;;;;15994:45:0;;;::::1;::::0;;;::::1;::::0;;15854:193::o;16451:95::-;2675:13;:11;:13::i;:::-;16525::::1;::::0;;-1:-1:-1;;;;16508:30:0;::::1;-1:-1:-1::0;;;16525:13:0;;;::::1;;;16524:14;16508:30:::0;;::::1;;::::0;;16451:95::o;11039:640::-;11171:13;;11138:7;;-1:-1:-1;;;11171:13:0;;;;11163:48;;;;-1:-1:-1;;;11163:48:0;;;;;;;:::i;:::-;11222:11;11236:25;:23;:25::i;:::-;11222:39;;11286:1;11280:3;:7;11272:46;;;;-1:-1:-1;;;11272:46:0;;5968:2:1;11272:46:0;;;5950:21:1;6007:2;5987:18;;;5980:30;6046:28;6026:18;;;6019:56;6092:18;;11272:46:0;5766:350:1;11272:46:0;11331:25;11359:11;;;:6;:11;;;;;;;;11331:39;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:25;11405:32;;:11;:32;:::i;:::-;11383:54;;11478:16;11497:21;11513:4;11497:15;:21::i;:::-;11478:40;-1:-1:-1;11583:21:0;11478:40;11608:18;:11;11622:4;11608:18;:::i;:::-;11607:31;;;;:::i;:::-;11583:55;11039:640;-1:-1:-1;;;;;;;11039:640:0:o;17054:96::-;2675:13;:11;:13::i;:::-;17122:8:::1;:20:::0;17054:96::o;13711:1809::-;13829:13;;-1:-1:-1;;;13829:13:0;;;;13821:48;;;;-1:-1:-1;;;13821:48:0;;;;;;;:::i;:::-;13943:11;13957:25;:23;:25::i;:::-;13943:39;;14007:1;14001:3;:7;13993:45;;;;-1:-1:-1;;;13993:45:0;;7206:2:1;13993:45:0;;;7188:21:1;7245:2;7225:18;;;7218:30;-1:-1:-1;;;7264:18:1;;;7257:55;7329:18;;13993:45:0;7004:349:1;13993:45:0;14049:26;14078:11;;;:6;:11;;;;;;14129:29;14150:7;14129:20;:29::i;:::-;14102:56;;14190:16;14177:9;:29;;14169:61;;;;-1:-1:-1;;;14169:61:0;;7560:2:1;14169:61:0;;;7542:21:1;7599:2;7579:18;;;7572:30;-1:-1:-1;;;7618:18:1;;;7611:49;7677:18;;14169:61:0;7358:343:1;14169:61:0;14243:20;14266:14;:7;14276:4;14266:14;:::i;:::-;14243:37;;14291:22;14316:13;;;;;;;;;-1:-1:-1;;;;;14316:13:0;-1:-1:-1;;;;;14316:22:0;;:24;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;14291:49;;;-1:-1:-1;14351:20:0;14374:19;14291:49;14374:2;:19;:::i;:::-;14351:42;-1:-1:-1;14404:25:0;14448:16;14351:42;14448:2;:16;:::i;:::-;14432:33;;:12;:33;:::i;:::-;14404:61;;14564:12;:22;;;14526:17;14500:12;:23;;;:43;;;;:::i;:::-;:86;;14478:163;;;;-1:-1:-1;;;14478:163:0;;9872:2:1;14478:163:0;;;9854:21:1;9911:2;9891:18;;;9884:30;9950:29;9930:18;;;9923:57;9997:18;;14478:163:0;9670:351:1;14478:163:0;14737:14;;14729:39;;-1:-1:-1;;;;;14737:14:0;;;;14758:9;14729:39;;;;;14737:14;14729:39;14737:14;14729:39;14758:9;14737:14;14729:39;;;;;;;14707:120;;;;-1:-1:-1;;;14707:120:0;;10228:2:1;14707:120:0;;;10210:21:1;10267:2;10247:18;;;10240:30;10306:33;10286:18;;;10279:61;10357:18;;14707:120:0;10026:355:1;14707:120:0;14930:5;;14963:13;;;14930:114;;-1:-1:-1;;;14930:114:0;;-1:-1:-1;;;;;14963:13:0;;;14930:114;;;10588:51:1;;;;14991:10:0;10655:18:1;;;10648:60;10724:18;;;10717:34;;;14915:12:0;;14930:5;;:18;;10561::1;;14930:114:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;14915:129;;15084:17;15057:12;:23;;;:44;;;;;;;:::i;:::-;;;;-1:-1:-1;15122:7:0;;-1:-1:-1;15114:45:0;;;;-1:-1:-1;;;15114:45:0;;11214:2:1;15114:45:0;;;11196:21:1;11253:2;11233:18;;;11226:30;11292:27;11272:18;;;11265:55;11337:18;;15114:45:0;11012:349:1;15114:45:0;-1:-1:-1;;;;;15176:30:0;;;15172:298;;-1:-1:-1;;;;;15223:38:0;;;;;;;:20;:38;;;;;;;;15285:158;;;;;;;;;;;;;;;;15413:10;15285:158;;;;;;15223:235;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;15223:235:0;;;;;;;;15172:298;15495:17;15482:9;;:30;;;;;;;:::i;:::-;;;;-1:-1:-1;;;;;;;;;;;;13711:1809:0:o;11687:2016::-;11796:13;;-1:-1:-1;;;11796:13:0;;;;11788:48;;;;-1:-1:-1;;;11788:48:0;;;;;;;:::i;:::-;11865:1;11855:7;:11;11847:58;;;;-1:-1:-1;;;11847:58:0;;11568:2:1;11847:58:0;;;11550:21:1;11607:2;11587:18;;;11580:30;11646:34;11626:18;;;11619:62;-1:-1:-1;;;11697:18:1;;;11690:32;11739:19;;11847:58:0;11366:398:1;11847:58:0;11918:11;11932:25;:23;:25::i;:::-;11918:39;;11982:1;11976:3;:7;11968:45;;;;-1:-1:-1;;;11968:45:0;;7206:2:1;11968:45:0;;;7188:21:1;7245:2;7225:18;;;7218:30;-1:-1:-1;;;7264:18:1;;;7257:55;7329:18;;11968:45:0;7004:349:1;11968:45:0;12026:26;12055:11;;;:6;:11;;;;;12113:18;;;;12055:11;;12026:26;12103:28;;:7;:28;:::i;:::-;12079:52;;12166:20;12204:11;;;;;;;;;-1:-1:-1;;;;;12204:11:0;-1:-1:-1;;;;;12189:36:0;;:38;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;12166:61;;;-1:-1:-1;12238:22:0;12302:4;12281:16;12166:61;12281:2;:16;:::i;:::-;12264:34;;:13;:34;:::i;:::-;12263:43;;;;:::i;:::-;12348:11;;12341:56;;-1:-1:-1;;;12341:56:0;;12371:10;12341:56;;;11943:51:1;12391:4:0;12010:18:1;;;12003:60;12238:68:0;;-1:-1:-1;12238:68:0;;-1:-1:-1;;;;;12348:11:0;;;;12341:29;;11916:18:1;;12341:56:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;:91;;12319:169;;;;-1:-1:-1;;;12319:169:0;;12511:2:1;12319:169:0;;;12493:21:1;12550:2;12530:18;;;12523:30;12589;12569:18;;;12562:58;12637:18;;12319:169:0;12309:352:1;12319:169:0;12566:11;;12631:14;;12559:126;;-1:-1:-1;;;12559:126:0;;12606:10;12559:126;;;10588:51:1;-1:-1:-1;;;;;12631:14:0;;;10655:18:1;;;10648:60;10724:18;;;10717:34;;;12537:19:0;;12566:11;;;;;12559:32;;10561:18:1;;12559:126:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;12537:148;;12706:14;12698:47;;;;-1:-1:-1;;;12698:47:0;;12868:2:1;12698:47:0;;;12850:21:1;12907:2;12887:18;;;12880:30;-1:-1:-1;;;12926:18:1;;;12919:50;12986:18;;12698:47:0;12666:344:1;12698:47:0;12828:13;;:24;;;-1:-1:-1;;;12828:24:0;;;;12758;;-1:-1:-1;;;;;12828:13:0;;:22;;:24;;;;;;;;;;;;;;:13;:24;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;12823:29;;:2;:29;:::i;:::-;12818:35;;:2;:35;:::i;:::-;12786:14;:7;12796:4;12786:14;:::i;:::-;12785:69;;;;:::i;:::-;12758:96;;12952:12;:22;;;12915:16;12889:12;:23;;;:42;;;;:::i;:::-;:85;;12867:162;;;;-1:-1:-1;;;12867:162:0;;9872:2:1;12867:162:0;;;9854:21:1;9911:2;9891:18;;;9884:30;9950:29;9930:18;;;9923:57;9997:18;;12867:162:0;9670:351:1;12867:162:0;13107:5;;13140:13;;;13107:113;;-1:-1:-1;;;13107:113:0;;-1:-1:-1;;;;;13140:13:0;;;13107:113;;;10588:51:1;;;;13168:10:0;10655:18:1;;;10648:60;10724:18;;;10717:34;;;13079:25:0;;13107:5;;:18;;10561::1;;13107:113:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;13079:141;;13260:16;13233:12;:23;;;:43;;;;;;;:::i;:::-;;;;-1:-1:-1;13297:20:0;;-1:-1:-1;13289:55:0;;;;-1:-1:-1;;;13289:55:0;;13518:2:1;13289:55:0;;;13500:21:1;13557:2;13537:18;;;13530:30;-1:-1:-1;;;13576:18:1;;;13569:52;13638:18;;13289:55:0;13316:346:1;16108:102:0;2675:13;:11;:13::i;:::-;16179::::1;:23:::0;;-1:-1:-1;;;;;;16179:23:0::1;-1:-1:-1::0;;;;;16179:23:0;;;::::1;::::0;;;::::1;::::0;;16108:102::o;17667:332::-;2675:13;:11;:13::i;:::-;17827:11:::1;::::0;;;:6:::1;:11;::::0;;;;:14;:21;::::1;17819:51;;;::::0;-1:-1:-1;;;17819:51:0;;13869:2:1;17819:51:0::1;::::0;::::1;13851:21:1::0;13908:2;13888:18;;;13881:30;-1:-1:-1;;;13927:18:1;;;13920:47;13984:18;;17819:51:0::1;13667:341:1::0;17819:51:0::1;17881:11;::::0;;;:6:::1;:11;::::0;;;;;:17:::1;::::0;::::1;:26:::0;;;;17918:21:::1;::::0;::::1;:34:::0;17963:18:::1;;:28:::0;;-1:-1:-1;;17963:28:0::1;::::0;::::1;;::::0;;;::::1;::::0;;17667:332::o;10759:272::-;10824:7;10844:20;10867:18;:16;:18::i;:::-;10844:41;;10898:17;10975:9;;;;;;;;;-1:-1:-1;;;;;10975:9:0;-1:-1:-1;;;;;10975:18:0;;:20;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;10971:24;;:2;:24;:::i;:::-;10919:34;10939:13;10919:9;:34;:::i;:::-;10918:78;;;;:::i;:::-;10898:98;10759:272;-1:-1:-1;;;;10759:272:0:o;10506:153::-;10555:6;10577:12;10599:9;;;;;;;;;-1:-1:-1;;;;;10599:9:0;-1:-1:-1;;;;;10599:25:0;;:27;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1;10574:52:0;;10506:153;-1:-1:-1;;;;;10506:153:0:o;16676:317::-;2675:13;:11;:13::i;:::-;16759:5:::1;::::0;:30:::1;::::0;-1:-1:-1;;;16759:30:0;;16783:4:::1;16759:30;::::0;::::1;1184:51:1::0;16733:23:0::1;::::0;-1:-1:-1;;;;;16759:5:0::1;::::0;:15:::1;::::0;1157:18:1;;16759:30:0::1;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;16733:56;;16826:1;16808:15;:19;16800:58;;;::::0;-1:-1:-1;;;16800:58:0;;14975:2:1;16800:58:0::1;::::0;::::1;14957:21:1::0;15014:2;14994:18;;;14987:30;15053:28;15033:18;;;15026:56;15099:18;;16800:58:0::1;14773:350:1::0;16800:58:0::1;16886:5;::::0;:43:::1;::::0;-1:-1:-1;;;16886:43:0;;16901:10:::1;16886:43;::::0;::::1;15302:51:1::0;15369:18;;;15362:34;;;16871:12:0::1;::::0;-1:-1:-1;;;;;16886:5:0::1;::::0;:14:::1;::::0;15275:18:1;;16886:43:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;16871:58;;16948:7;16940:45;;;::::0;-1:-1:-1;;;16940:45:0;;15609:2:1;16940:45:0::1;::::0;::::1;15591:21:1::0;15648:2;15628:18;;;15621:30;15687:27;15667:18;;;15660:55;15732:18;;16940:45:0::1;15407:349:1::0;16940:45:0::1;16722:271;;16676:317::o:0;18069:290::-;18125:7;;18188:1;18171:160;18196:14;;18191:1;:19;18171:160;;18236:9;;;;:6;:9;;;;;:16;;;;;18232:88;;;18279:1;18273:7;;18299:5;;18232:88;18212:3;;;;:::i;:::-;;;;18171:160;;;-1:-1:-1;18348:3:0;18069:290;-1:-1:-1;18069:290:0:o;3722:220::-;2675:13;:11;:13::i;:::-;-1:-1:-1;;;;;3807:22:0;::::1;3803:93;;3853:31;::::0;-1:-1:-1;;;3853:31:0;;3881:1:::1;3853:31;::::0;::::1;1184:51:1::0;1157:18;;3853:31:0::1;1038:203:1::0;3803:93:0::1;3906:28;3925:8;3906:18;:28::i;:::-;3722:220:::0;:::o;17209:450::-;2675:13;:11;:13::i;:::-;17339:11:::1;17353:14;;17370:1;17353:18;;;;:::i;:::-;17339:32;;17397:8;;17390:3;:15;;17382:50;;;::::0;-1:-1:-1;;;17382:50:0;;16103:2:1;17382:50:0::1;::::0;::::1;16085:21:1::0;16142:2;16122:18;;;16115:30;-1:-1:-1;;;16161:18:1;;;16154:52;16223:18;;17382:50:0::1;15901:346:1::0;17382:50:0::1;17461:1;17443:14;;:19;;;;;;;:::i;:::-;::::0;;;-1:-1:-1;;17489:162:0::1;::::0;;::::1;::::0;::::1;::::0;;;;;::::1;::::0;;::::1;::::0;;;;;;;;;-1:-1:-1;17489:162:0;;;;;;;::::1;;::::0;;;;;;17475:11;;;:6:::1;:11:::0;;;;;;;:176;;;;;;::::1;::::0;::::1;::::0;;;::::1;::::0;::::1;::::0;;::::1;::::0;::::1;::::0;;::::1;::::0;;::::1;::::0;;-1:-1:-1;;17475:176:0::1;::::0;::::1;;::::0;;;::::1;::::0;;17209:450::o;2954:166::-;2835:7;2862:6;-1:-1:-1;;;;;2862:6:0;878:10;3014:23;3010:103;;3061:40;;-1:-1:-1;;;3061:40:0;;878:10;3061:40;;;1184:51:1;1157:18;;3061:40:0;1038:203:1;4102:191:0;4176:16;4195:6;;-1:-1:-1;;;;;4212:17:0;;;-1:-1:-1;;;;;;4212:17:0;;;;;;4245:40;;4195:6;;;;;;;4245:40;;4176:16;4245:40;4165:128;4102:191;:::o;14:173:1:-;82:20;;-1:-1:-1;;;;;131:31:1;;121:42;;111:70;;177:1;174;167:12;111:70;14:173;;;:::o;192:186::-;251:6;304:2;292:9;283:7;279:23;275:32;272:52;;;320:1;317;310:12;272:52;343:29;362:9;343:29;:::i;:::-;333:39;192:186;-1:-1:-1;;;192:186:1:o;383:300::-;451:6;459;512:2;500:9;491:7;487:23;483:32;480:52;;;528:1;525;518:12;480:52;551:29;570:9;551:29;:::i;:::-;541:39;649:2;634:18;;;;621:32;;-1:-1:-1;;;383:300:1:o;1857:226::-;1916:6;1969:2;1957:9;1948:7;1944:23;1940:32;1937:52;;;1985:1;1982;1975:12;1937:52;-1:-1:-1;2030:23:1;;1857:226;-1:-1:-1;1857:226:1:o;2566:300::-;2634:6;2642;2695:2;2683:9;2674:7;2670:23;2666:32;2663:52;;;2711:1;2708;2701:12;2663:52;2756:23;;;-1:-1:-1;2822:38:1;2856:2;2841:18;;2822:38;:::i;:::-;2812:48;;2566:300;;;;;:::o;2871:118::-;2957:5;2950:13;2943:21;2936:5;2933:32;2923:60;;2979:1;2976;2969:12;2994:602;3077:6;3085;3093;3101;3154:3;3142:9;3133:7;3129:23;3125:33;3122:53;;;3171:1;3168;3161:12;3122:53;3216:23;;;-1:-1:-1;3336:2:1;3321:18;;3308:32;;-1:-1:-1;3439:2:1;3424:18;;3411:32;;-1:-1:-1;3521:2:1;3506:18;;3493:32;3534:30;3493:32;3534:30;:::i;:::-;2994:602;;;;-1:-1:-1;2994:602:1;;-1:-1:-1;;2994:602:1:o;3781:481::-;3855:6;3863;3871;3924:2;3912:9;3903:7;3899:23;3895:32;3892:52;;;3940:1;3937;3930:12;3892:52;3985:23;;;-1:-1:-1;4105:2:1;4090:18;;4077:32;;-1:-1:-1;4187:2:1;4172:18;;4159:32;4200:30;4159:32;4200:30;:::i;:::-;4249:7;4239:17;;;3781:481;;;;;:::o;5415:346::-;5617:2;5599:21;;;5656:2;5636:18;;;5629:30;-1:-1:-1;;;5690:2:1;5675:18;;5668:52;5752:2;5737:18;;5415:346::o;6121:127::-;6182:10;6177:3;6173:20;6170:1;6163:31;6213:4;6210:1;6203:15;6237:4;6234:1;6227:15;6253:168;6326:9;;;6357;;6374:15;;;6368:22;;6354:37;6344:71;;6395:18;;:::i;:::-;6253:168;;;;:::o;6426:217::-;6466:1;6492;6482:132;;6536:10;6531:3;6527:20;6524:1;6517:31;6571:4;6568:1;6561:15;6599:4;6596:1;6589:15;6482:132;-1:-1:-1;6628:9:1;;6426:217::o;7706:273::-;7774:6;7827:2;7815:9;7806:7;7802:23;7798:32;7795:52;;;7843:1;7840;7833:12;7795:52;7875:9;7869:16;7925:4;7918:5;7914:16;7907:5;7904:27;7894:55;;7945:1;7942;7935:12;7984:128;8051:9;;;8072:11;;;8069:37;;;8086:18;;:::i;8117:375::-;8205:1;8223:5;8237:249;8258:1;8248:8;8245:15;8237:249;;;8308:4;8303:3;8299:14;8293:4;8290:24;8287:50;;;8317:18;;:::i;:::-;8367:1;8357:8;8353:16;8350:49;;;8381:16;;;;8350:49;8464:1;8460:16;;;;;8420:15;;8237:249;;;8117:375;;;;;;:::o;8497:902::-;8546:5;8576:8;8566:80;;-1:-1:-1;8617:1:1;8631:5;;8566:80;8665:4;8655:76;;-1:-1:-1;8702:1:1;8716:5;;8655:76;8747:4;8765:1;8760:59;;;;8833:1;8828:174;;;;8740:262;;8760:59;8790:1;8781:10;;8804:5;;;8828:174;8865:3;8855:8;8852:17;8849:43;;;8872:18;;:::i;:::-;-1:-1:-1;;8928:1:1;8914:16;;8987:5;;8740:262;;9086:2;9076:8;9073:16;9067:3;9061:4;9058:13;9054:36;9048:2;9038:8;9035:16;9030:2;9024:4;9021:12;9017:35;9014:77;9011:203;;;-1:-1:-1;9123:19:1;;;9199:5;;9011:203;9246:42;-1:-1:-1;;9271:8:1;9265:4;9246:42;:::i;:::-;9324:6;9320:1;9316:6;9312:19;9303:7;9300:32;9297:58;;;9335:18;;:::i;:::-;9373:20;;8497:902;-1:-1:-1;;;8497:902:1:o;9404:131::-;9464:5;9493:36;9520:8;9514:4;9493:36;:::i;9540:125::-;9605:9;;;9626:10;;;9623:36;;;9639:18;;:::i;10762:245::-;10829:6;10882:2;10870:9;10861:7;10857:23;10853:32;10850:52;;;10898:1;10895;10888:12;10850:52;10930:9;10924:16;10949:28;10971:5;10949:28;:::i;12074:230::-;12144:6;12197:2;12185:9;12176:7;12172:23;12168:32;12165:52;;;12213:1;12210;12203:12;12165:52;-1:-1:-1;12258:16:1;;12074:230;-1:-1:-1;12074:230:1:o;13015:151::-;13105:4;13098:12;;;13084;;;13080:31;;13123:14;;13120:40;;;13140:18;;:::i;13171:140::-;13229:5;13258:47;13299:4;13289:8;13285:19;13279:4;13258:47;:::i;14013:179::-;14091:13;;14144:22;14133:34;;14123:45;;14113:73;;14182:1;14179;14172:12;14197:571;14300:6;14308;14316;14324;14332;14385:3;14373:9;14364:7;14360:23;14356:33;14353:53;;;14402:1;14399;14392:12;14353:53;14425:39;14454:9;14425:39;:::i;:::-;14504:2;14489:18;;14483:25;14570:2;14555:18;;14549:25;14664:2;14649:18;;14643:25;14415:49;;-1:-1:-1;14483:25:1;;-1:-1:-1;14549:25:1;-1:-1:-1;14643:25:1;-1:-1:-1;14713:49:1;14757:3;14742:19;;14713:49;:::i;:::-;14703:59;;14197:571;;;;;;;;:::o;15761:135::-;15800:3;15821:17;;;15818:43;;15841:18;;:::i;:::-;-1:-1:-1;15888:1:1;15877:13;;15761:135::o

Swarm Source

ipfs://813de293a171c82f52d653588bc780c1fcf16ddaa10af24f0704f8ff0c76ac52

Block Uncle Number Difficulty Gas Used Reward
View All Uncles
Loading...
Loading
Loading...
Loading
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.