ETH Price: $3,606.04 (+4.63%)
 

Overview

Max Total Supply

1,000,000 $HOP

Holders

493

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
0.915778746877779099 $HOP

Value
$0.00
0x9152a126aa8219482b9723826c27b66cdb720de1
Loading...
Loading
Loading...
Loading
Loading...
Loading

Click here to update the token information / general information
# Exchange Pair Price  24H Volume % Volume

Contract Source Code Verified (Exact Match)

Contract Name:
HoppiumToken

Compiler Version
v0.8.21+commit.d9974bed

Optimization Enabled:
No with 200 runs

Other Settings:
default evmVersion
File 1 of 9 : TokenTemplate.sol
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.20;

import "@openzeppelin/contracts/access/Ownable.sol";
import "@openzeppelin/contracts/token/ERC20/IERC20.sol";
import "@openzeppelin/contracts/utils/Context.sol";
import "@openzeppelin/contracts/utils/math/SafeMath.sol";
import "@uniswap/v2-core/contracts/interfaces/IUniswapV2Factory.sol";
import "@uniswap/v2-core/contracts/interfaces/IUniswapV2Pair.sol";
import "@uniswap/v2-periphery/contracts/interfaces/IUniswapV2Router02.sol";

bytes32 constant INIT_CODE_HASH = hex"96e8ac4277198ff8b6f785478aa9a39f403cb768dd02cbee326c3e7da348845f";
address constant FACTORY = 0x5C69bEe701ef814a2B6a3EDD4B1652CB9cc5aA6f;

library UniswapV2Library {
    function pairFor(
        address tokenA,
        address tokenB
    ) internal pure returns (address pair) {
        (address token0, address token1) = sortTokens(tokenA, tokenB);
        pair = address(
            uint160(
                uint256(
                    keccak256(
                        abi.encodePacked(
                            hex"ff",
                            FACTORY,
                            keccak256(abi.encodePacked(token0, token1)),
                            INIT_CODE_HASH
                        )
                    )
                )
            )
        );
    }

    function sortTokens(
        address tokenA,
        address tokenB
    ) internal pure returns (address token0, address token1) {
        (token0, token1) = tokenA < tokenB
            ? (tokenA, tokenB)
            : (tokenB, tokenA);
    }
}

contract HoppiumToken is Context, IERC20, Ownable {
    using SafeMath for uint256;
    mapping(address => uint256) private _balances;
    mapping(address => mapping(address => uint256)) private _allowances;
    mapping(address => bool) private _isExcludedFromFee;
    mapping(address => bool) private bots;
    mapping(address => uint256) private _holderLastTransferTimestamp;
    bool public transferDelayEnabled = true;
    address payable private _taxWallet;

    uint256 private _initialBuyTax;
    uint256 private _initialSellTax;
    uint256 private _finalBuyTax;
    uint256 private _finalSellTax;
    uint256 private _reduceBuyTaxAt = 25;
    uint256 private _reduceSellTaxAt = 25;
    uint256 private _preventSwapBefore = 25;
    uint256 private _buyCount;

    uint8 private constant _decimals = 18;
    uint256 private constant _tTotal = 1_000_000 * 10 ** _decimals;
    string private constant _name = unicode"$Hoppium";
    string private constant _symbol = unicode"$HOP";
    uint256 public _maxTxAmount = 20_000 * 10 ** _decimals;
    uint256 public _maxWalletSize = 20_000 * 10 ** _decimals;
    uint256 public _taxSwapThreshold = 2_000 * 10 ** _decimals;
    uint256 public _maxTaxSwap = 5_000 * 10 ** _decimals;

    IUniswapV2Router02 private constant UNISWAP_V2_ROUTER =
        IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);

    address private immutable UNISWAP_V2_PAIR;
    bool private tradingOpen;
    bool private inSwap = false;
    bool private swapEnabled = false;

    event MaxTxAmountUpdated(uint256 _maxTxAmount);

    modifier lockTheSwap() {
        inSwap = true;
        _;
        inSwap = false;
    }

    constructor() {
        _taxWallet = payable(msg.sender);
        _isExcludedFromFee[owner()] = true;
        _isExcludedFromFee[address(this)] = true;
        _isExcludedFromFee[_taxWallet] = true;

        UNISWAP_V2_PAIR = UniswapV2Library.pairFor(
            address(this),
            UNISWAP_V2_ROUTER.WETH()
        );

        _balances[_msgSender()] = _tTotal;
        emit Transfer(address(0), _msgSender(), _tTotal);
    }

    function name() public pure returns (string memory) {
        return _name;
    }

    function symbol() public pure returns (string memory) {
        return _symbol;
    }

    function decimals() public pure returns (uint8) {
        return _decimals;
    }

    function totalSupply() public pure override returns (uint256) {
        return _tTotal;
    }

    function balanceOf(address account) public view override returns (uint256) {
        return _balances[account];
    }

    function transfer(
        address recipient,
        uint256 amount
    ) public override returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

    function allowance(
        address owner,
        address spender
    ) public view override returns (uint256) {
        return _allowances[owner][spender];
    }

    function approve(
        address spender,
        uint256 amount
    ) public override returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) public override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(
            sender,
            _msgSender(),
            _allowances[sender][_msgSender()].sub(
                amount,
                "ERC20: transfer amount exceeds allowance"
            )
        );
        return true;
    }

    function _approve(address owner, address spender, uint256 amount) private {
        require(owner != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");
        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }

    function _transfer(address from, address to, uint256 amount) private {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        require(amount > 0, "Transfer amount must be greater than zero");
        uint256 taxAmount = 0;
        if (from != owner() && to != owner()) {
            taxAmount = amount
                .mul(
                    (_buyCount > _reduceBuyTaxAt)
                        ? _finalBuyTax
                        : _initialBuyTax
                )
                .div(100);

            if (transferDelayEnabled) {
                if (to != address(UNISWAP_V2_ROUTER) && to != UNISWAP_V2_PAIR) {
                    require(
                        _holderLastTransferTimestamp[tx.origin] < block.number,
                        "_transfer:: Transfer Delay enabled.  Only one purchase per block allowed."
                    );
                    _holderLastTransferTimestamp[tx.origin] = block.number;
                }
            }

            if (
                from == UNISWAP_V2_PAIR &&
                to != address(UNISWAP_V2_ROUTER) &&
                !_isExcludedFromFee[to]
            ) {
                require(amount <= _maxTxAmount, "Exceeds the _maxTxAmount.");
                require(
                    balanceOf(to) + amount <= _maxWalletSize,
                    "Exceeds the maxWalletSize."
                );
                if (_buyCount <= 100) {
                    _buyCount++;
                }
            }

            if (to == UNISWAP_V2_PAIR && from != address(this)) {
                taxAmount = amount
                    .mul(
                        (_buyCount > _reduceSellTaxAt)
                            ? _finalSellTax
                            : _initialSellTax
                    )
                    .div(100);
            }

            uint256 contractTokenBalance = balanceOf(address(this));
            if (
                !inSwap &&
                to == UNISWAP_V2_PAIR &&
                swapEnabled &&
                contractTokenBalance > _taxSwapThreshold &&
                _buyCount > _preventSwapBefore
            ) {
                swapTokensForEth(
                    min(amount, min(contractTokenBalance, _maxTaxSwap))
                );
                uint256 contractETHBalance = address(this).balance;
                if (contractETHBalance > 50000000000000000) {
                    sendETHToFee(address(this).balance);
                }
            }
        }

        if (taxAmount > 0) {
            _balances[address(this)] = _balances[address(this)].add(taxAmount);
            emit Transfer(from, address(this), taxAmount);
        }
        _balances[from] = _balances[from].sub(amount);
        _balances[to] = _balances[to].add(amount.sub(taxAmount));
        emit Transfer(from, to, amount.sub(taxAmount));
    }

    function min(uint256 a, uint256 b) private pure returns (uint256) {
        return (a > b) ? b : a;
    }

    function swapTokensForEth(uint256 tokenAmount) private lockTheSwap {
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = UNISWAP_V2_ROUTER.WETH();
        UNISWAP_V2_ROUTER.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0,
            path,
            _taxWallet,
            block.timestamp
        );
    }

    function removeLimits() external onlyOwner {
        _maxTxAmount = _tTotal;
        _maxWalletSize = _tTotal;
        transferDelayEnabled = false;
        emit MaxTxAmountUpdated(_tTotal);
    }

    function sendETHToFee(uint256 amount) private {
        _taxWallet.transfer(amount);
    }

    function openTrading() external payable onlyOwner {
        require(!tradingOpen, "trading is already open");
        _approve(address(this), address(UNISWAP_V2_ROUTER), type(uint256).max);
        UNISWAP_V2_ROUTER.addLiquidityETH{value: address(this).balance}(
            address(this),
            balanceOf(address(this)),
            0,
            0,
            owner(),
            block.timestamp
        );

        _initialBuyTax = 30;
        _initialSellTax = 30;
        _finalBuyTax = 4;
        _finalSellTax = 4;
        swapEnabled = true;
        tradingOpen = true;
    }

    receive() external payable {}

    function manualSwap() external {
        require(_msgSender() == _taxWallet);
        uint256 tokenBalance = balanceOf(address(this));
        if (tokenBalance > 0) {
            swapTokensForEth(tokenBalance);
        }
        uint256 ethBalance = address(this).balance;
        if (ethBalance > 0) {
            sendETHToFee(ethBalance);
        }
    }
    function excludeFromFee(address addy) external onlyOwner {
        _isExcludedFromFee[addy] = true;
    }
}

File 2 of 9 : IUniswapV2Router02.sol
pragma solidity >=0.6.2;

import './IUniswapV2Router01.sol';

interface IUniswapV2Router02 is IUniswapV2Router01 {
    function removeLiquidityETHSupportingFeeOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountETH);
    function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountETH);

    function swapExactTokensForTokensSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
    function swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external payable;
    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
}

File 3 of 9 : IUniswapV2Pair.sol
pragma solidity >=0.5.0;

interface IUniswapV2Pair {
    event Approval(address indexed owner, address indexed spender, uint value);
    event Transfer(address indexed from, address indexed to, uint value);

    function name() external pure returns (string memory);
    function symbol() external pure returns (string memory);
    function decimals() external pure returns (uint8);
    function totalSupply() external view returns (uint);
    function balanceOf(address owner) external view returns (uint);
    function allowance(address owner, address spender) external view returns (uint);

    function approve(address spender, uint value) external returns (bool);
    function transfer(address to, uint value) external returns (bool);
    function transferFrom(address from, address to, uint value) external returns (bool);

    function DOMAIN_SEPARATOR() external view returns (bytes32);
    function PERMIT_TYPEHASH() external pure returns (bytes32);
    function nonces(address owner) external view returns (uint);

    function permit(address owner, address spender, uint value, uint deadline, uint8 v, bytes32 r, bytes32 s) external;

    event Mint(address indexed sender, uint amount0, uint amount1);
    event Burn(address indexed sender, uint amount0, uint amount1, address indexed to);
    event Swap(
        address indexed sender,
        uint amount0In,
        uint amount1In,
        uint amount0Out,
        uint amount1Out,
        address indexed to
    );
    event Sync(uint112 reserve0, uint112 reserve1);

    function MINIMUM_LIQUIDITY() external pure returns (uint);
    function factory() external view returns (address);
    function token0() external view returns (address);
    function token1() external view returns (address);
    function getReserves() external view returns (uint112 reserve0, uint112 reserve1, uint32 blockTimestampLast);
    function price0CumulativeLast() external view returns (uint);
    function price1CumulativeLast() external view returns (uint);
    function kLast() external view returns (uint);

    function mint(address to) external returns (uint liquidity);
    function burn(address to) external returns (uint amount0, uint amount1);
    function swap(uint amount0Out, uint amount1Out, address to, bytes calldata data) external;
    function skim(address to) external;
    function sync() external;

    function initialize(address, address) external;
}

File 4 of 9 : IUniswapV2Factory.sol
pragma solidity >=0.5.0;

interface IUniswapV2Factory {
    event PairCreated(address indexed token0, address indexed token1, address pair, uint);

    function feeTo() external view returns (address);
    function feeToSetter() external view returns (address);

    function getPair(address tokenA, address tokenB) external view returns (address pair);
    function allPairs(uint) external view returns (address pair);
    function allPairsLength() external view returns (uint);

    function createPair(address tokenA, address tokenB) external returns (address pair);

    function setFeeTo(address) external;
    function setFeeToSetter(address) external;
}

File 5 of 9 : SafeMath.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.9.0) (utils/math/SafeMath.sol)

pragma solidity ^0.8.0;

// CAUTION
// This version of SafeMath should only be used with Solidity 0.8 or later,
// because it relies on the compiler's built in overflow checks.

/**
 * @dev Wrappers over Solidity's arithmetic operations.
 *
 * NOTE: `SafeMath` is generally not needed starting with Solidity 0.8, since the compiler
 * now has built in overflow checking.
 */
library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            uint256 c = a + b;
            if (c < a) return (false, 0);
            return (true, c);
        }
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b > a) return (false, 0);
            return (true, a - b);
        }
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryMul(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
            // benefit is lost if 'b' is also tested.
            // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522
            if (a == 0) return (true, 0);
            uint256 c = a * b;
            if (c / a != b) return (false, 0);
            return (true, c);
        }
    }

    /**
     * @dev Returns the division of two unsigned integers, with a division by zero flag.
     *
     * _Available since v3.4._
     */
    function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a / b);
        }
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers, with a division by zero flag.
     *
     * _Available since v3.4._
     */
    function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a % b);
        }
    }

    /**
     * @dev Returns the addition of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `+` operator.
     *
     * Requirements:
     *
     * - Addition cannot overflow.
     */
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        return a + b;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return a - b;
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `*` operator.
     *
     * Requirements:
     *
     * - Multiplication cannot overflow.
     */
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        return a * b;
    }

    /**
     * @dev Returns the integer division of two unsigned integers, reverting on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator.
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return a / b;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * reverting when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        return a % b;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
     * overflow (when the result is negative).
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {trySub}.
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        unchecked {
            require(b <= a, errorMessage);
            return a - b;
        }
    }

    /**
     * @dev Returns the integer division of two unsigned integers, reverting with custom message on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        unchecked {
            require(b > 0, errorMessage);
            return a / b;
        }
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * reverting with custom message when dividing by zero.
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {tryMod}.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        unchecked {
            require(b > 0, errorMessage);
            return a % b;
        }
    }
}

File 6 of 9 : Context.sol
// 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;
    }
}

File 7 of 9 : IERC20.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.6.0) (token/ERC20/IERC20.sol)

pragma solidity ^0.8.0;

/**
 * @dev Interface of the ERC20 standard as defined in the EIP.
 */
interface IERC20 {
    /**
     * @dev Emitted when `value` tokens are moved from one account (`from`) to
     * another (`to`).
     *
     * Note that `value` may be zero.
     */
    event Transfer(address indexed from, address indexed to, uint256 value);

    /**
     * @dev Emitted when the allowance of a `spender` for an `owner` is set by
     * a call to {approve}. `value` is the new allowance.
     */
    event Approval(address indexed owner, address indexed spender, uint256 value);

    /**
     * @dev Returns the amount of tokens in existence.
     */
    function totalSupply() external view returns (uint256);

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

    /**
     * @dev Moves `amount` tokens from the caller's account to `to`.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transfer(address to, uint256 amount) external returns (bool);

    /**
     * @dev Returns the remaining number of tokens that `spender` will be
     * allowed to spend on behalf of `owner` through {transferFrom}. This is
     * zero by default.
     *
     * This value changes when {approve} or {transferFrom} are called.
     */
    function allowance(address owner, address spender) external view returns (uint256);

    /**
     * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * IMPORTANT: Beware that changing an allowance with this method brings the risk
     * that someone may use both the old and the new allowance by unfortunate
     * transaction ordering. One possible solution to mitigate this race
     * condition is to first reduce the spender's allowance to 0 and set the
     * desired value afterwards:
     * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
     *
     * Emits an {Approval} event.
     */
    function approve(address spender, uint256 amount) external returns (bool);

    /**
     * @dev Moves `amount` tokens from `from` to `to` using the
     * allowance mechanism. `amount` is then deducted from the caller's
     * allowance.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transferFrom(
        address from,
        address to,
        uint256 amount
    ) external returns (bool);
}

File 8 of 9 : Ownable.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.7.0) (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 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 {
        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);
    }
}

File 9 of 9 : IUniswapV2Router01.sol
pragma solidity >=0.6.2;

interface IUniswapV2Router01 {
    function factory() external pure returns (address);
    function WETH() external pure returns (address);

    function addLiquidity(
        address tokenA,
        address tokenB,
        uint amountADesired,
        uint amountBDesired,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB, uint liquidity);
    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external payable returns (uint amountToken, uint amountETH, uint liquidity);
    function removeLiquidity(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB);
    function removeLiquidityETH(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountToken, uint amountETH);
    function removeLiquidityWithPermit(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountA, uint amountB);
    function removeLiquidityETHWithPermit(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountToken, uint amountETH);
    function swapExactTokensForTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);
    function swapTokensForExactTokens(
        uint amountOut,
        uint amountInMax,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);
    function swapExactETHForTokens(uint amountOutMin, address[] calldata path, address to, uint deadline)
        external
        payable
        returns (uint[] memory amounts);
    function swapTokensForExactETH(uint amountOut, uint amountInMax, address[] calldata path, address to, uint deadline)
        external
        returns (uint[] memory amounts);
    function swapExactTokensForETH(uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline)
        external
        returns (uint[] memory amounts);
    function swapETHForExactTokens(uint amountOut, address[] calldata path, address to, uint deadline)
        external
        payable
        returns (uint[] memory amounts);

    function quote(uint amountA, uint reserveA, uint reserveB) external pure returns (uint amountB);
    function getAmountOut(uint amountIn, uint reserveIn, uint reserveOut) external pure returns (uint amountOut);
    function getAmountIn(uint amountOut, uint reserveIn, uint reserveOut) external pure returns (uint amountIn);
    function getAmountsOut(uint amountIn, address[] calldata path) external view returns (uint[] memory amounts);
    function getAmountsIn(uint amountOut, address[] calldata path) external view returns (uint[] memory amounts);
}

Settings
{
  "optimizer": {
    "enabled": false,
    "runs": 200
  },
  "outputSelection": {
    "*": {
      "*": [
        "evm.bytecode",
        "evm.deployedBytecode",
        "devdoc",
        "userdoc",
        "metadata",
        "abi"
      ]
    }
  }
}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"_maxTxAmount","type":"uint256"}],"name":"MaxTxAmountUpdated","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":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"_maxTaxSwap","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_maxTxAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_maxWalletSize","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_taxSwapThreshold","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"pure","type":"function"},{"inputs":[{"internalType":"address","name":"addy","type":"address"}],"name":"excludeFromFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"manualSwap","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"openTrading","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"removeLimits","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"pure","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"transferDelayEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

60a0604052600160065f6101000a81548160ff0219169083151502179055506019600b556019600c556019600d556012600a6200003d9190620007db565b614e206200004c91906200082b565b600f556012600a6200005f9190620007db565b614e206200006e91906200082b565b6010556012600a620000819190620007db565b6107d06200009091906200082b565b6011556012600a620000a39190620007db565b611388620000b291906200082b565b6012555f601360016101000a81548160ff0219169083151502179055505f601360026101000a81548160ff021916908315150217905550348015620000f5575f80fd5b50620001166200010a6200045a60201b60201c565b6200046160201b60201c565b33600660016101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550600160035f6200016c6200052260201b60201c565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff021916908315150217905550600160035f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff021916908315150217905550600160035f600660019054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff0219169083151502179055506200031c30737a250d5630b4cf539739df2c5dacb4c659f2488d73ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015620002ea573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190620003109190620008da565b6200054960201b60201c565b73ffffffffffffffffffffffffffffffffffffffff1660808173ffffffffffffffffffffffffffffffffffffffff16815250506012600a6200035f9190620007db565b620f42406200036f91906200082b565b60015f620003826200045a60201b60201c565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2081905550620003cf6200045a60201b60201c565b73ffffffffffffffffffffffffffffffffffffffff165f73ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6012600a6200042d9190620007db565b620f42406200043d91906200082b565b6040516200044c91906200091b565b60405180910390a362000a86565b5f33905090565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050815f806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b5f805f6200055e8585620005f960201b60201c565b91509150735c69bee701ef814a2b6a3edd4b1652cb9cc5aa6f82826040516020016200058c92919062000983565b604051602081830303815290604052805190602001207f96e8ac4277198ff8b6f785478aa9a39f403cb768dd02cbee326c3e7da348845f604051602001620005d79392919062000a37565b604051602081830303815290604052805190602001205f1c9250505092915050565b5f808273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1610620006375782846200063a565b83835b80925081935050509250929050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f8160011c9050919050565b5f808291508390505b6001851115620006d357808604811115620006ab57620006aa62000649565b5b6001851615620006bb5780820291505b8081029050620006cb8562000676565b94506200068b565b94509492505050565b5f82620006ed5760019050620007bf565b81620006fc575f9050620007bf565b8160018114620007155760028114620007205762000756565b6001915050620007bf565b60ff84111562000735576200073462000649565b5b8360020a9150848211156200074f576200074e62000649565b5b50620007bf565b5060208310610133831016604e8410600b8410161715620007905782820a9050838111156200078a576200078962000649565b5b620007bf565b6200079f848484600162000682565b92509050818404811115620007b957620007b862000649565b5b81810290505b9392505050565b5f819050919050565b5f60ff82169050919050565b5f620007e782620007c6565b9150620007f483620007cf565b9250620008237fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8484620006dc565b905092915050565b5f6200083782620007c6565b91506200084483620007c6565b92508282026200085481620007c6565b915082820484148315176200086e576200086d62000649565b5b5092915050565b5f80fd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f620008a48262000879565b9050919050565b620008b68162000898565b8114620008c1575f80fd5b50565b5f81519050620008d481620008ab565b92915050565b5f60208284031215620008f257620008f162000875565b5b5f6200090184828501620008c4565b91505092915050565b6200091581620007c6565b82525050565b5f602082019050620009305f8301846200090a565b92915050565b5f8160601b9050919050565b5f6200094e8262000936565b9050919050565b5f620009618262000942565b9050919050565b6200097d620009778262000898565b62000955565b82525050565b5f62000990828562000968565b601482019150620009a2828462000968565b6014820191508190509392505050565b5f81905092915050565b7fff000000000000000000000000000000000000000000000000000000000000005f82015250565b5f620009f2600183620009b2565b9150620009ff82620009bc565b600182019050919050565b5f819050919050565b5f819050919050565b62000a3162000a2b8262000a0a565b62000a13565b82525050565b5f62000a4382620009e4565b915062000a51828662000968565b60148201915062000a63828562000a1c565b60208201915062000a75828462000a1c565b602082019150819050949350505050565b608051612a0e62000ab45f395f8181610f50015281816110690152818161121c015261130b0152612a0e5ff3fe60806040526004361061012d575f3560e01c8063751039fc116100aa578063a9059cbb1161006e578063a9059cbb146103a6578063bf474bed146103e2578063c876d0b91461040c578063c9567bf914610436578063dd62ed3e14610440578063f2fde38b1461047c57610134565b8063751039fc146102e85780637d1db4a5146102fe5780638da5cb5b146103285780638f9a55c01461035257806395d89b411461037c57610134565b8063313ce567116100f1578063313ce5671461022e578063437823ec1461025857806351bc3c851461028057806370a0823114610296578063715018a6146102d257610134565b806306fdde0314610138578063095ea7b3146101625780630faee56f1461019e57806318160ddd146101c857806323b872dd146101f257610134565b3661013457005b5f80fd5b348015610143575f80fd5b5061014c6104a4565b6040516101599190611bb9565b60405180910390f35b34801561016d575f80fd5b5061018860048036038101906101839190611c6a565b6104e1565b6040516101959190611cc2565b60405180910390f35b3480156101a9575f80fd5b506101b26104fe565b6040516101bf9190611cea565b60405180910390f35b3480156101d3575f80fd5b506101dc610504565b6040516101e99190611cea565b60405180910390f35b3480156101fd575f80fd5b5061021860048036038101906102139190611d03565b610526565b6040516102259190611cc2565b60405180910390f35b348015610239575f80fd5b506102426105fa565b60405161024f9190611d6e565b60405180910390f35b348015610263575f80fd5b5061027e60048036038101906102799190611d87565b610602565b005b34801561028b575f80fd5b50610294610662565b005b3480156102a1575f80fd5b506102bc60048036038101906102b79190611d87565b6106fa565b6040516102c99190611cea565b60405180910390f35b3480156102dd575f80fd5b506102e6610740565b005b3480156102f3575f80fd5b506102fc610753565b005b348015610309575f80fd5b5061031261080c565b60405161031f9190611cea565b60405180910390f35b348015610333575f80fd5b5061033c610812565b6040516103499190611dc1565b60405180910390f35b34801561035d575f80fd5b50610366610839565b6040516103739190611cea565b60405180910390f35b348015610387575f80fd5b5061039061083f565b60405161039d9190611bb9565b60405180910390f35b3480156103b1575f80fd5b506103cc60048036038101906103c79190611c6a565b61087c565b6040516103d99190611cc2565b60405180910390f35b3480156103ed575f80fd5b506103f6610899565b6040516104039190611cea565b60405180910390f35b348015610417575f80fd5b5061042061089f565b60405161042d9190611cc2565b60405180910390f35b61043e6108b1565b005b34801561044b575f80fd5b5061046660048036038101906104619190611dda565b610a49565b6040516104739190611cea565b60405180910390f35b348015610487575f80fd5b506104a2600480360381019061049d9190611d87565b610acb565b005b60606040518060400160405280600881526020017f24486f707069756d000000000000000000000000000000000000000000000000815250905090565b5f6104f46104ed610b4d565b8484610b54565b6001905092915050565b60125481565b5f6012600a6105139190611f74565b620f42406105219190611fbe565b905090565b5f610532848484610d17565b6105ef8461053e610b4d565b6105ea856040518060600160405280602881526020016129b16028913960025f8b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6105a1610b4d565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546116809092919063ffffffff16565b610b54565b600190509392505050565b5f6012905090565b61060a6116d4565b600160035f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff02191690831515021790555050565b600660019054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166106a3610b4d565b73ffffffffffffffffffffffffffffffffffffffff16146106c2575f80fd5b5f6106cc306106fa565b90505f8111156106e0576106df81611752565b5b5f4790505f8111156106f6576106f581611999565b5b5050565b5f60015f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b6107486116d4565b6107515f611a02565b565b61075b6116d4565b6012600a6107699190611f74565b620f42406107779190611fbe565b600f819055506012600a61078b9190611f74565b620f42406107999190611fbe565b6010819055505f60065f6101000a81548160ff0219169083151502179055507f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6012600a6107e79190611f74565b620f42406107f59190611fbe565b6040516108029190611cea565b60405180910390a1565b600f5481565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60105481565b60606040518060400160405280600481526020017f24484f5000000000000000000000000000000000000000000000000000000000815250905090565b5f61088f610888610b4d565b8484610d17565b6001905092915050565b60115481565b60065f9054906101000a900460ff1681565b6108b96116d4565b60135f9054906101000a900460ff1615610908576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016108ff90612049565b60405180910390fd5b61094730737a250d5630b4cf539739df2c5dacb4c659f2488d7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff610b54565b737a250d5630b4cf539739df2c5dacb4c659f2488d73ffffffffffffffffffffffffffffffffffffffff1663f305d7194730610982306106fa565b5f8061098c610812565b426040518863ffffffff1660e01b81526004016109ae969594939291906120a9565b60606040518083038185885af11580156109ca573d5f803e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906109ef919061211c565b505050601e600781905550601e60088190555060046009819055506004600a819055506001601360026101000a81548160ff021916908315150217905550600160135f6101000a81548160ff021916908315150217905550565b5f60025f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b610ad36116d4565b5f73ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1603610b41576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610b38906121dc565b60405180910390fd5b610b4a81611a02565b50565b5f33905090565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603610bc2576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610bb99061226a565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603610c30576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c27906122f8565b60405180910390fd5b8060025f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92583604051610d0a9190611cea565b60405180910390a3505050565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603610d85576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d7c90612386565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603610df3576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610dea90612414565b60405180910390fd5b5f8111610e35576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610e2c906124a2565b60405180910390fd5b5f610e3e610812565b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614158015610eac5750610e7c610812565b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b156113d057610eed6064610edf600b54600e5411610ecc57600754610ed0565b6009545b85611ac390919063ffffffff16565b611ad890919063ffffffff16565b905060065f9054906101000a900460ff161561106757737a250d5630b4cf539739df2c5dacb4c659f2488d73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614158015610f9f57507f000000000000000000000000000000000000000000000000000000000000000073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b15611066574360055f3273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205410611023576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161101a90612556565b60405180910390fd5b4360055f3273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055505b5b7f000000000000000000000000000000000000000000000000000000000000000073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff161480156111025750737a250d5630b4cf539739df2c5dacb4c659f2488d73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b8015611155575060035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b1561121a57600f5482111561119f576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611196906125be565b60405180910390fd5b601054826111ac856106fa565b6111b691906125dc565b11156111f7576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016111ee90612659565b60405180910390fd5b6064600e541161121957600e5f81548092919061121390612677565b91905055505b5b7f000000000000000000000000000000000000000000000000000000000000000073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff161480156112a157503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b156112e5576112e260646112d4600c54600e54116112c1576008546112c5565b600a545b85611ac390919063ffffffff16565b611ad890919063ffffffff16565b90505b5f6112ef306106fa565b9050601360019054906101000a900460ff1615801561135957507f000000000000000000000000000000000000000000000000000000000000000073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b80156113715750601360029054906101000a900460ff165b801561137e575060115481115b801561138d5750600d54600e54115b156113ce576113af6113aa846113a584601254611aed565b611aed565b611752565b5f47905066b1a2bc2ec500008111156113cc576113cb47611999565b5b505b505b5f8111156114cf576114288160015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611b0590919063ffffffff16565b60015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef836040516114c69190611cea565b60405180910390a35b61151f8260015f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611b1a90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055506115c26115768284611b1a90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611b0590919063ffffffff16565b60015f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6116658486611b1a90919063ffffffff16565b6040516116729190611cea565b60405180910390a350505050565b5f8383111582906116c7576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116be9190611bb9565b60405180910390fd5b5082840390509392505050565b6116dc610b4d565b73ffffffffffffffffffffffffffffffffffffffff166116fa610812565b73ffffffffffffffffffffffffffffffffffffffff1614611750576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161174790612708565b60405180910390fd5b565b6001601360016101000a81548160ff0219169083151502179055505f600267ffffffffffffffff81111561178957611788612726565b5b6040519080825280602002602001820160405280156117b75781602001602082028036833780820191505090505b50905030815f815181106117ce576117cd612753565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff1681525050737a250d5630b4cf539739df2c5dacb4c659f2488d73ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611865573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906118899190612794565b8160018151811061189d5761189c612753565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff1681525050737a250d5630b4cf539739df2c5dacb4c659f2488d73ffffffffffffffffffffffffffffffffffffffff1663791ac947835f84600660019054906101000a900473ffffffffffffffffffffffffffffffffffffffff16426040518663ffffffff1660e01b815260040161194e9594939291906128c8565b5f604051808303815f87803b158015611965575f80fd5b505af1158015611977573d5f803e3d5ffd5b50505050505f601360016101000a81548160ff02191690831515021790555050565b600660019054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f193505050501580156119fe573d5f803e3d5ffd5b5050565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050815f806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b5f8183611ad09190611fbe565b905092915050565b5f8183611ae5919061294d565b905092915050565b5f818311611afb5782611afd565b815b905092915050565b5f8183611b1291906125dc565b905092915050565b5f8183611b27919061297d565b905092915050565b5f81519050919050565b5f82825260208201905092915050565b5f5b83811015611b66578082015181840152602081019050611b4b565b5f8484015250505050565b5f601f19601f8301169050919050565b5f611b8b82611b2f565b611b958185611b39565b9350611ba5818560208601611b49565b611bae81611b71565b840191505092915050565b5f6020820190508181035f830152611bd18184611b81565b905092915050565b5f80fd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f611c0682611bdd565b9050919050565b611c1681611bfc565b8114611c20575f80fd5b50565b5f81359050611c3181611c0d565b92915050565b5f819050919050565b611c4981611c37565b8114611c53575f80fd5b50565b5f81359050611c6481611c40565b92915050565b5f8060408385031215611c8057611c7f611bd9565b5b5f611c8d85828601611c23565b9250506020611c9e85828601611c56565b9150509250929050565b5f8115159050919050565b611cbc81611ca8565b82525050565b5f602082019050611cd55f830184611cb3565b92915050565b611ce481611c37565b82525050565b5f602082019050611cfd5f830184611cdb565b92915050565b5f805f60608486031215611d1a57611d19611bd9565b5b5f611d2786828701611c23565b9350506020611d3886828701611c23565b9250506040611d4986828701611c56565b9150509250925092565b5f60ff82169050919050565b611d6881611d53565b82525050565b5f602082019050611d815f830184611d5f565b92915050565b5f60208284031215611d9c57611d9b611bd9565b5b5f611da984828501611c23565b91505092915050565b611dbb81611bfc565b82525050565b5f602082019050611dd45f830184611db2565b92915050565b5f8060408385031215611df057611def611bd9565b5b5f611dfd85828601611c23565b9250506020611e0e85828601611c23565b9150509250929050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f8160011c9050919050565b5f808291508390505b6001851115611e9a57808604811115611e7657611e75611e18565b5b6001851615611e855780820291505b8081029050611e9385611e45565b9450611e5a565b94509492505050565b5f82611eb25760019050611f6d565b81611ebf575f9050611f6d565b8160018114611ed55760028114611edf57611f0e565b6001915050611f6d565b60ff841115611ef157611ef0611e18565b5b8360020a915084821115611f0857611f07611e18565b5b50611f6d565b5060208310610133831016604e8410600b8410161715611f435782820a905083811115611f3e57611f3d611e18565b5b611f6d565b611f508484846001611e51565b92509050818404811115611f6757611f66611e18565b5b81810290505b9392505050565b5f611f7e82611c37565b9150611f8983611d53565b9250611fb67fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8484611ea3565b905092915050565b5f611fc882611c37565b9150611fd383611c37565b9250828202611fe181611c37565b91508282048414831517611ff857611ff7611e18565b5b5092915050565b7f74726164696e6720697320616c7265616479206f70656e0000000000000000005f82015250565b5f612033601783611b39565b915061203e82611fff565b602082019050919050565b5f6020820190508181035f83015261206081612027565b9050919050565b5f819050919050565b5f819050919050565b5f61209361208e61208984612067565b612070565b611c37565b9050919050565b6120a381612079565b82525050565b5f60c0820190506120bc5f830189611db2565b6120c96020830188611cdb565b6120d6604083018761209a565b6120e3606083018661209a565b6120f06080830185611db2565b6120fd60a0830184611cdb565b979650505050505050565b5f8151905061211681611c40565b92915050565b5f805f6060848603121561213357612132611bd9565b5b5f61214086828701612108565b935050602061215186828701612108565b925050604061216286828701612108565b9150509250925092565b7f4f776e61626c653a206e6577206f776e657220697320746865207a65726f20615f8201527f6464726573730000000000000000000000000000000000000000000000000000602082015250565b5f6121c6602683611b39565b91506121d18261216c565b604082019050919050565b5f6020820190508181035f8301526121f3816121ba565b9050919050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f612254602483611b39565b915061225f826121fa565b604082019050919050565b5f6020820190508181035f83015261228181612248565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f6122e2602283611b39565b91506122ed82612288565b604082019050919050565b5f6020820190508181035f83015261230f816122d6565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f2061645f8201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b5f612370602583611b39565b915061237b82612316565b604082019050919050565b5f6020820190508181035f83015261239d81612364565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f20616464725f8201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b5f6123fe602383611b39565b9150612409826123a4565b604082019050919050565b5f6020820190508181035f83015261242b816123f2565b9050919050565b7f5472616e7366657220616d6f756e74206d7573742062652067726561746572205f8201527f7468616e207a65726f0000000000000000000000000000000000000000000000602082015250565b5f61248c602983611b39565b915061249782612432565b604082019050919050565b5f6020820190508181035f8301526124b981612480565b9050919050565b7f5f7472616e736665723a3a205472616e736665722044656c617920656e61626c5f8201527f65642e20204f6e6c79206f6e652070757263686173652070657220626c6f636b60208201527f20616c6c6f7765642e0000000000000000000000000000000000000000000000604082015250565b5f612540604983611b39565b915061254b826124c0565b606082019050919050565b5f6020820190508181035f83015261256d81612534565b9050919050565b7f4578636565647320746865205f6d61785478416d6f756e742e000000000000005f82015250565b5f6125a8601983611b39565b91506125b382612574565b602082019050919050565b5f6020820190508181035f8301526125d58161259c565b9050919050565b5f6125e682611c37565b91506125f183611c37565b925082820190508082111561260957612608611e18565b5b92915050565b7f4578636565647320746865206d617857616c6c657453697a652e0000000000005f82015250565b5f612643601a83611b39565b915061264e8261260f565b602082019050919050565b5f6020820190508181035f83015261267081612637565b9050919050565b5f61268182611c37565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff82036126b3576126b2611e18565b5b600182019050919050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f6126f2602083611b39565b91506126fd826126be565b602082019050919050565b5f6020820190508181035f83015261271f816126e6565b9050919050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b5f8151905061278e81611c0d565b92915050565b5f602082840312156127a9576127a8611bd9565b5b5f6127b684828501612780565b91505092915050565b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b6127f181611bfc565b82525050565b5f61280283836127e8565b60208301905092915050565b5f602082019050919050565b5f612824826127bf565b61282e81856127c9565b9350612839836127d9565b805f5b8381101561286957815161285088826127f7565b975061285b8361280e565b92505060018101905061283c565b5085935050505092915050565b5f61289061288b61288684611bdd565b612070565b611bdd565b9050919050565b5f6128a182612876565b9050919050565b5f6128b282612897565b9050919050565b6128c2816128a8565b82525050565b5f60a0820190506128db5f830188611cdb565b6128e8602083018761209a565b81810360408301526128fa818661281a565b905061290960608301856128b9565b6129166080830184611cdb565b9695505050505050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f61295782611c37565b915061296283611c37565b92508261297257612971612920565b5b828204905092915050565b5f61298782611c37565b915061299283611c37565b92508282039050818111156129aa576129a9611e18565b5b9291505056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a2646970667358221220b70b310f806c8eadbed4f712bf117d6b514e1b66d94d866ad69f03b8fc52b33264736f6c63430008150033

Deployed Bytecode

0x60806040526004361061012d575f3560e01c8063751039fc116100aa578063a9059cbb1161006e578063a9059cbb146103a6578063bf474bed146103e2578063c876d0b91461040c578063c9567bf914610436578063dd62ed3e14610440578063f2fde38b1461047c57610134565b8063751039fc146102e85780637d1db4a5146102fe5780638da5cb5b146103285780638f9a55c01461035257806395d89b411461037c57610134565b8063313ce567116100f1578063313ce5671461022e578063437823ec1461025857806351bc3c851461028057806370a0823114610296578063715018a6146102d257610134565b806306fdde0314610138578063095ea7b3146101625780630faee56f1461019e57806318160ddd146101c857806323b872dd146101f257610134565b3661013457005b5f80fd5b348015610143575f80fd5b5061014c6104a4565b6040516101599190611bb9565b60405180910390f35b34801561016d575f80fd5b5061018860048036038101906101839190611c6a565b6104e1565b6040516101959190611cc2565b60405180910390f35b3480156101a9575f80fd5b506101b26104fe565b6040516101bf9190611cea565b60405180910390f35b3480156101d3575f80fd5b506101dc610504565b6040516101e99190611cea565b60405180910390f35b3480156101fd575f80fd5b5061021860048036038101906102139190611d03565b610526565b6040516102259190611cc2565b60405180910390f35b348015610239575f80fd5b506102426105fa565b60405161024f9190611d6e565b60405180910390f35b348015610263575f80fd5b5061027e60048036038101906102799190611d87565b610602565b005b34801561028b575f80fd5b50610294610662565b005b3480156102a1575f80fd5b506102bc60048036038101906102b79190611d87565b6106fa565b6040516102c99190611cea565b60405180910390f35b3480156102dd575f80fd5b506102e6610740565b005b3480156102f3575f80fd5b506102fc610753565b005b348015610309575f80fd5b5061031261080c565b60405161031f9190611cea565b60405180910390f35b348015610333575f80fd5b5061033c610812565b6040516103499190611dc1565b60405180910390f35b34801561035d575f80fd5b50610366610839565b6040516103739190611cea565b60405180910390f35b348015610387575f80fd5b5061039061083f565b60405161039d9190611bb9565b60405180910390f35b3480156103b1575f80fd5b506103cc60048036038101906103c79190611c6a565b61087c565b6040516103d99190611cc2565b60405180910390f35b3480156103ed575f80fd5b506103f6610899565b6040516104039190611cea565b60405180910390f35b348015610417575f80fd5b5061042061089f565b60405161042d9190611cc2565b60405180910390f35b61043e6108b1565b005b34801561044b575f80fd5b5061046660048036038101906104619190611dda565b610a49565b6040516104739190611cea565b60405180910390f35b348015610487575f80fd5b506104a2600480360381019061049d9190611d87565b610acb565b005b60606040518060400160405280600881526020017f24486f707069756d000000000000000000000000000000000000000000000000815250905090565b5f6104f46104ed610b4d565b8484610b54565b6001905092915050565b60125481565b5f6012600a6105139190611f74565b620f42406105219190611fbe565b905090565b5f610532848484610d17565b6105ef8461053e610b4d565b6105ea856040518060600160405280602881526020016129b16028913960025f8b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6105a1610b4d565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546116809092919063ffffffff16565b610b54565b600190509392505050565b5f6012905090565b61060a6116d4565b600160035f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff02191690831515021790555050565b600660019054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166106a3610b4d565b73ffffffffffffffffffffffffffffffffffffffff16146106c2575f80fd5b5f6106cc306106fa565b90505f8111156106e0576106df81611752565b5b5f4790505f8111156106f6576106f581611999565b5b5050565b5f60015f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b6107486116d4565b6107515f611a02565b565b61075b6116d4565b6012600a6107699190611f74565b620f42406107779190611fbe565b600f819055506012600a61078b9190611f74565b620f42406107999190611fbe565b6010819055505f60065f6101000a81548160ff0219169083151502179055507f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6012600a6107e79190611f74565b620f42406107f59190611fbe565b6040516108029190611cea565b60405180910390a1565b600f5481565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60105481565b60606040518060400160405280600481526020017f24484f5000000000000000000000000000000000000000000000000000000000815250905090565b5f61088f610888610b4d565b8484610d17565b6001905092915050565b60115481565b60065f9054906101000a900460ff1681565b6108b96116d4565b60135f9054906101000a900460ff1615610908576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016108ff90612049565b60405180910390fd5b61094730737a250d5630b4cf539739df2c5dacb4c659f2488d7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff610b54565b737a250d5630b4cf539739df2c5dacb4c659f2488d73ffffffffffffffffffffffffffffffffffffffff1663f305d7194730610982306106fa565b5f8061098c610812565b426040518863ffffffff1660e01b81526004016109ae969594939291906120a9565b60606040518083038185885af11580156109ca573d5f803e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906109ef919061211c565b505050601e600781905550601e60088190555060046009819055506004600a819055506001601360026101000a81548160ff021916908315150217905550600160135f6101000a81548160ff021916908315150217905550565b5f60025f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b610ad36116d4565b5f73ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1603610b41576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610b38906121dc565b60405180910390fd5b610b4a81611a02565b50565b5f33905090565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603610bc2576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610bb99061226a565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603610c30576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c27906122f8565b60405180910390fd5b8060025f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92583604051610d0a9190611cea565b60405180910390a3505050565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603610d85576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d7c90612386565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603610df3576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610dea90612414565b60405180910390fd5b5f8111610e35576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610e2c906124a2565b60405180910390fd5b5f610e3e610812565b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614158015610eac5750610e7c610812565b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b156113d057610eed6064610edf600b54600e5411610ecc57600754610ed0565b6009545b85611ac390919063ffffffff16565b611ad890919063ffffffff16565b905060065f9054906101000a900460ff161561106757737a250d5630b4cf539739df2c5dacb4c659f2488d73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614158015610f9f57507f00000000000000000000000091225905e874c11c832485d4c6ce252ed88ecb5b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b15611066574360055f3273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205410611023576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161101a90612556565b60405180910390fd5b4360055f3273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055505b5b7f00000000000000000000000091225905e874c11c832485d4c6ce252ed88ecb5b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff161480156111025750737a250d5630b4cf539739df2c5dacb4c659f2488d73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b8015611155575060035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b1561121a57600f5482111561119f576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611196906125be565b60405180910390fd5b601054826111ac856106fa565b6111b691906125dc565b11156111f7576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016111ee90612659565b60405180910390fd5b6064600e541161121957600e5f81548092919061121390612677565b91905055505b5b7f00000000000000000000000091225905e874c11c832485d4c6ce252ed88ecb5b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff161480156112a157503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b156112e5576112e260646112d4600c54600e54116112c1576008546112c5565b600a545b85611ac390919063ffffffff16565b611ad890919063ffffffff16565b90505b5f6112ef306106fa565b9050601360019054906101000a900460ff1615801561135957507f00000000000000000000000091225905e874c11c832485d4c6ce252ed88ecb5b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b80156113715750601360029054906101000a900460ff165b801561137e575060115481115b801561138d5750600d54600e54115b156113ce576113af6113aa846113a584601254611aed565b611aed565b611752565b5f47905066b1a2bc2ec500008111156113cc576113cb47611999565b5b505b505b5f8111156114cf576114288160015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611b0590919063ffffffff16565b60015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef836040516114c69190611cea565b60405180910390a35b61151f8260015f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611b1a90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055506115c26115768284611b1a90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611b0590919063ffffffff16565b60015f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6116658486611b1a90919063ffffffff16565b6040516116729190611cea565b60405180910390a350505050565b5f8383111582906116c7576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116be9190611bb9565b60405180910390fd5b5082840390509392505050565b6116dc610b4d565b73ffffffffffffffffffffffffffffffffffffffff166116fa610812565b73ffffffffffffffffffffffffffffffffffffffff1614611750576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161174790612708565b60405180910390fd5b565b6001601360016101000a81548160ff0219169083151502179055505f600267ffffffffffffffff81111561178957611788612726565b5b6040519080825280602002602001820160405280156117b75781602001602082028036833780820191505090505b50905030815f815181106117ce576117cd612753565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff1681525050737a250d5630b4cf539739df2c5dacb4c659f2488d73ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611865573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906118899190612794565b8160018151811061189d5761189c612753565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff1681525050737a250d5630b4cf539739df2c5dacb4c659f2488d73ffffffffffffffffffffffffffffffffffffffff1663791ac947835f84600660019054906101000a900473ffffffffffffffffffffffffffffffffffffffff16426040518663ffffffff1660e01b815260040161194e9594939291906128c8565b5f604051808303815f87803b158015611965575f80fd5b505af1158015611977573d5f803e3d5ffd5b50505050505f601360016101000a81548160ff02191690831515021790555050565b600660019054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f193505050501580156119fe573d5f803e3d5ffd5b5050565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050815f806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b5f8183611ad09190611fbe565b905092915050565b5f8183611ae5919061294d565b905092915050565b5f818311611afb5782611afd565b815b905092915050565b5f8183611b1291906125dc565b905092915050565b5f8183611b27919061297d565b905092915050565b5f81519050919050565b5f82825260208201905092915050565b5f5b83811015611b66578082015181840152602081019050611b4b565b5f8484015250505050565b5f601f19601f8301169050919050565b5f611b8b82611b2f565b611b958185611b39565b9350611ba5818560208601611b49565b611bae81611b71565b840191505092915050565b5f6020820190508181035f830152611bd18184611b81565b905092915050565b5f80fd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f611c0682611bdd565b9050919050565b611c1681611bfc565b8114611c20575f80fd5b50565b5f81359050611c3181611c0d565b92915050565b5f819050919050565b611c4981611c37565b8114611c53575f80fd5b50565b5f81359050611c6481611c40565b92915050565b5f8060408385031215611c8057611c7f611bd9565b5b5f611c8d85828601611c23565b9250506020611c9e85828601611c56565b9150509250929050565b5f8115159050919050565b611cbc81611ca8565b82525050565b5f602082019050611cd55f830184611cb3565b92915050565b611ce481611c37565b82525050565b5f602082019050611cfd5f830184611cdb565b92915050565b5f805f60608486031215611d1a57611d19611bd9565b5b5f611d2786828701611c23565b9350506020611d3886828701611c23565b9250506040611d4986828701611c56565b9150509250925092565b5f60ff82169050919050565b611d6881611d53565b82525050565b5f602082019050611d815f830184611d5f565b92915050565b5f60208284031215611d9c57611d9b611bd9565b5b5f611da984828501611c23565b91505092915050565b611dbb81611bfc565b82525050565b5f602082019050611dd45f830184611db2565b92915050565b5f8060408385031215611df057611def611bd9565b5b5f611dfd85828601611c23565b9250506020611e0e85828601611c23565b9150509250929050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f8160011c9050919050565b5f808291508390505b6001851115611e9a57808604811115611e7657611e75611e18565b5b6001851615611e855780820291505b8081029050611e9385611e45565b9450611e5a565b94509492505050565b5f82611eb25760019050611f6d565b81611ebf575f9050611f6d565b8160018114611ed55760028114611edf57611f0e565b6001915050611f6d565b60ff841115611ef157611ef0611e18565b5b8360020a915084821115611f0857611f07611e18565b5b50611f6d565b5060208310610133831016604e8410600b8410161715611f435782820a905083811115611f3e57611f3d611e18565b5b611f6d565b611f508484846001611e51565b92509050818404811115611f6757611f66611e18565b5b81810290505b9392505050565b5f611f7e82611c37565b9150611f8983611d53565b9250611fb67fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8484611ea3565b905092915050565b5f611fc882611c37565b9150611fd383611c37565b9250828202611fe181611c37565b91508282048414831517611ff857611ff7611e18565b5b5092915050565b7f74726164696e6720697320616c7265616479206f70656e0000000000000000005f82015250565b5f612033601783611b39565b915061203e82611fff565b602082019050919050565b5f6020820190508181035f83015261206081612027565b9050919050565b5f819050919050565b5f819050919050565b5f61209361208e61208984612067565b612070565b611c37565b9050919050565b6120a381612079565b82525050565b5f60c0820190506120bc5f830189611db2565b6120c96020830188611cdb565b6120d6604083018761209a565b6120e3606083018661209a565b6120f06080830185611db2565b6120fd60a0830184611cdb565b979650505050505050565b5f8151905061211681611c40565b92915050565b5f805f6060848603121561213357612132611bd9565b5b5f61214086828701612108565b935050602061215186828701612108565b925050604061216286828701612108565b9150509250925092565b7f4f776e61626c653a206e6577206f776e657220697320746865207a65726f20615f8201527f6464726573730000000000000000000000000000000000000000000000000000602082015250565b5f6121c6602683611b39565b91506121d18261216c565b604082019050919050565b5f6020820190508181035f8301526121f3816121ba565b9050919050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f612254602483611b39565b915061225f826121fa565b604082019050919050565b5f6020820190508181035f83015261228181612248565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f6122e2602283611b39565b91506122ed82612288565b604082019050919050565b5f6020820190508181035f83015261230f816122d6565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f2061645f8201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b5f612370602583611b39565b915061237b82612316565b604082019050919050565b5f6020820190508181035f83015261239d81612364565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f20616464725f8201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b5f6123fe602383611b39565b9150612409826123a4565b604082019050919050565b5f6020820190508181035f83015261242b816123f2565b9050919050565b7f5472616e7366657220616d6f756e74206d7573742062652067726561746572205f8201527f7468616e207a65726f0000000000000000000000000000000000000000000000602082015250565b5f61248c602983611b39565b915061249782612432565b604082019050919050565b5f6020820190508181035f8301526124b981612480565b9050919050565b7f5f7472616e736665723a3a205472616e736665722044656c617920656e61626c5f8201527f65642e20204f6e6c79206f6e652070757263686173652070657220626c6f636b60208201527f20616c6c6f7765642e0000000000000000000000000000000000000000000000604082015250565b5f612540604983611b39565b915061254b826124c0565b606082019050919050565b5f6020820190508181035f83015261256d81612534565b9050919050565b7f4578636565647320746865205f6d61785478416d6f756e742e000000000000005f82015250565b5f6125a8601983611b39565b91506125b382612574565b602082019050919050565b5f6020820190508181035f8301526125d58161259c565b9050919050565b5f6125e682611c37565b91506125f183611c37565b925082820190508082111561260957612608611e18565b5b92915050565b7f4578636565647320746865206d617857616c6c657453697a652e0000000000005f82015250565b5f612643601a83611b39565b915061264e8261260f565b602082019050919050565b5f6020820190508181035f83015261267081612637565b9050919050565b5f61268182611c37565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff82036126b3576126b2611e18565b5b600182019050919050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f6126f2602083611b39565b91506126fd826126be565b602082019050919050565b5f6020820190508181035f83015261271f816126e6565b9050919050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b5f8151905061278e81611c0d565b92915050565b5f602082840312156127a9576127a8611bd9565b5b5f6127b684828501612780565b91505092915050565b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b6127f181611bfc565b82525050565b5f61280283836127e8565b60208301905092915050565b5f602082019050919050565b5f612824826127bf565b61282e81856127c9565b9350612839836127d9565b805f5b8381101561286957815161285088826127f7565b975061285b8361280e565b92505060018101905061283c565b5085935050505092915050565b5f61289061288b61288684611bdd565b612070565b611bdd565b9050919050565b5f6128a182612876565b9050919050565b5f6128b282612897565b9050919050565b6128c2816128a8565b82525050565b5f60a0820190506128db5f830188611cdb565b6128e8602083018761209a565b81810360408301526128fa818661281a565b905061290960608301856128b9565b6129166080830184611cdb565b9695505050505050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f61295782611c37565b915061296283611c37565b92508261297257612971612920565b5b828204905092915050565b5f61298782611c37565b915061299283611c37565b92508282039050818111156129aa576129a9611e18565b5b9291505056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a2646970667358221220b70b310f806c8eadbed4f712bf117d6b514e1b66d94d866ad69f03b8fc52b33264736f6c63430008150033

Loading...
Loading
Loading...
Loading
[ Download: CSV Export  ]
[ Download: CSV Export  ]

A token is a representation of an on-chain or off-chain asset. The token page shows information such as price, total supply, holders, transfers and social links. Learn more about this page in our Knowledge Base.