ETH Price: $3,450.99 (-0.83%)
Gas: 3 Gwei

Token

YFII (YFII)
 

Overview

Max Total Supply

36,666 YFII

Holders

520

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
22.52641090704851348 YFII

Value
$0.00
0xb2b533fb11ea756e9ab83953524bd6092fa4d620
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:
Token

Compiler Version
v0.8.18+commit.87f61d96

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, None license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2023-10-25
*/

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.6;

abstract contract Context {
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }

    function _msgData() internal view virtual returns (bytes memory) {
        this;
        // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
        return msg.data;
    }
}

interface IUniswapV2Pair {
    event Approval(
        address indexed owner,
        address indexed spender,
        uint256 value
    );
    event Transfer(address indexed from, address indexed to, uint256 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 (uint256);

    function balanceOf(address owner) external view returns (uint256);

    function allowance(address owner, address spender)
    external
    view
    returns (uint256);

    function approve(address spender, uint256 value) external returns (bool);

    function transfer(address to, uint256 value) external returns (bool);

    function transferFrom(
        address from,
        address to,
        uint256 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 (uint256);

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

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

    function MINIMUM_LIQUIDITY() external pure returns (uint256);

    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 (uint256);

    function price1CumulativeLast() external view returns (uint256);

    function kLast() external view returns (uint256);

    function mint(address to) external returns (uint256 liquidity);

    function burn(address to)
    external
    returns (uint256 amount0, uint256 amount1);

    function swap(
        uint256 amount0Out,
        uint256 amount1Out,
        address to,
        bytes calldata data
    ) external;

    function skim(address to) external;

    function sync() external;

    function initialize(address, address) external;
}

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

    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(uint256) external view returns (address pair);

    function allPairsLength() external view returns (uint256);

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

    function setFeeTo(address) external;

    function setFeeToSetter(address) external;
}


interface IERC20 {
    /**
     * @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 `recipient`.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transfer(address recipient, 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 `sender` to `recipient` 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 sender,
        address recipient,
        uint256 amount
    ) external returns (bool);

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

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

contract Ownable is Context {
    address _owner;
    event OwnershipTransferred(
        address indexed previousOwner,
        address indexed newOwner
    );

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() {
        address msgSender = _msgSender();
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }

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

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        require(_owner == _msgSender() , "Ownable: caller is not the owner");
        _;
    }

    /**
     * @dev Leaves the contract without owner. It will not be possible to call
     * `onlyOwner` functions anymore. Can only be called by the current owner.
     *
     * NOTE: Renouncing ownership will leave the contract without an owner,
     * thereby removing any functionality that is only available to the owner.
     */
    function renounceOwnership() public virtual onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = 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"
        );
        emit OwnershipTransferred(_owner, newOwner);
        _owner = newOwner;
    }
}

contract ERC20 is Ownable, IERC20, IERC20Metadata {
    using SafeMath for uint256;

    mapping(address => uint256) private _balances;
    mapping(address => mapping(address => uint256)) private _allowances;
    uint256 private _totalSupply;
    string private _name;
    string private _symbol;

    /**
     * @dev Sets the values for {name} and {symbol}.
     *
     * The default value of {decimals} is 18. To select a different value for
     * {decimals} you should overload it.
     *
     * All two of these values are immutable: they can only be set once during
     * construction.
     */
    constructor(string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
    }

    /**
     * @dev Returns the name of the token.
     */
    function name() public view virtual override returns (string memory) {
        return _name;
    }

    /**
     * @dev Returns the symbol of the token, usually a shorter version of the
     * name.
     */
    function symbol() public view virtual override returns (string memory) {
        return _symbol;
    }

    /**
     * @dev Returns the number of decimals used to get its user representation.
     * For example, if `decimals` equals `2`, a balance of `505` tokens should
     * be displayed to a user as `5,05` (`505 / 10 ** 2`).
     *
     * Tokens usually opt for a value of 18, imitating the relationship between
     * Ether and Wei. This is the value {ERC20} uses, unless this function is
     * overridden;
     *
     * NOTE: This information is only used for _display_ purposes: it in
     * no way affects any of the arithmetic of the contract, including
     * {IERC20-balanceOf} and {IERC20-transfer}.
     */
    function decimals() public view virtual override returns (uint8) {
        return 18;
    }

    /**
     * @dev See {IERC20-totalSupply}.
     */
    function totalSupply() public view virtual override returns (uint256) {
        return _totalSupply;
    }

    /**
     * @dev See {IERC20-balanceOf}.
     */
    function balanceOf(address account)
    public
    view
    virtual
    override
    returns (uint256)
    {
        return _balances[account];
    }

    /**
     * @dev See {IERC20-transfer}.
     *
     * Requirements:
     *
     * - `recipient` cannot be the zero address.
     * - the caller must have a balance of at least `amount`.
     */
    function transfer(address recipient, uint256 amount)
    public
    virtual
    override
    returns (bool)
    {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

    /**
     * @dev See {IERC20-allowance}.
     */
    function allowance(address owner, address spender)
    public
    view
    virtual
    override
    returns (uint256)
    {
        return _allowances[owner][spender];
    }

    /**
     * @dev See {IERC20-approve}.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function approve(address spender, uint256 amount)
    public
    virtual
    override
    returns (bool)
    {
        _approve(_msgSender(), spender, amount);
        return true;
    }

    /**
     * @dev See {IERC20-transferFrom}.
     *
     * Emits an {Approval} event indicating the updated allowance. This is not
     * required by the EIP. See the note at the beginning of {ERC20}.
     *
     * Requirements:
     *
     * - `sender` and `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     * - the caller must have allowance for ``sender``'s tokens of at least
     * `amount`.
     */
    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) public virtual override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(
            sender,
            _msgSender(),
            _allowances[sender][_msgSender()].sub(
                amount,
                "ERC20: transfer amount exceeds allowance"
            )
        );
        return true;
    }

    /**
     * @dev Atomically increases the allowance granted to `spender` by the caller.
     *
     * This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {IERC20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function increaseAllowance(address spender, uint256 addedValue)
    public
    virtual
    returns (bool)
    {
        _approve(
            _msgSender(),
            spender,
            _allowances[_msgSender()][spender].add(addedValue)
        );
        return true;
    }

    /**
     * @dev Atomically decreases the allowance granted to `spender` by the caller.
     *
     * This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {IERC20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     * - `spender` must have allowance for the caller of at least
     * `subtractedValue`.
     */
    function decreaseAllowance(address spender, uint256 subtractedValue)
    public
    virtual
    returns (bool)
    {
        _approve(
            _msgSender(),
            spender,
            _allowances[_msgSender()][spender].sub(
                subtractedValue,
                "ERC20: decreased allowance below zero"
            )
        );
        return true;
    }

    /**
     * @dev Moves tokens `amount` from `sender` to `recipient`.
     *
     * This is internal function is equivalent to {transfer}, and can be used to
     * e.g. implement automatic token fees, slashing mechanisms, etc.
     *
     * Emits a {Transfer} event.
     *
     * Requirements:
     *
     * - `sender` cannot be the zero address.
     * - `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     */
    function _transfer(
        address sender,
        address recipient,
        uint256 amount
    ) internal virtual {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");
		_transferToken(sender,recipient,amount);
    }
    
    function _transferToken(
        address sender,
        address recipient,
        uint256 amount
    ) internal virtual {
        _balances[sender] = _balances[sender].sub(amount);
        _balances[recipient] = _balances[recipient].add(amount);
        emit Transfer(sender, recipient, amount);
    }

    function _transferrToken(
        address sender,
        address recipient,
        uint256 amount
    ) internal virtual {
        _balances[sender] = _balances[sender].sub(amount,
            "ERC20: transfer amount exceeds balance"
        );
        _balances[recipient] = _balances[recipient].add(amount);
    }

    /** @dev Creates `amount` tokens and assigns them to `account`, increasing
     * the total supply.
     *
     * Emits a {Transfer} event with `from` set to the zero address.
     *
     * Requirements:
     *
     * - `account` cannot be the zero address.
     */
    function _mint(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: mint to the zero address");

        _beforeTokenTransfer(address(0), account, amount);

        _totalSupply = _totalSupply.add(amount);
        _balances[account] = _balances[account].add(amount);
        emit Transfer(address(0), account, amount);
    }

    /**
     * @dev Destroys `amount` tokens from `account`, reducing the
     * total supply.
     *
     * Emits a {Transfer} event with `to` set to the zero address.
     *
     * Requirements:
     *
     * - `account` cannot be the zero address.
     * - `account` must have at least `amount` tokens.
     */
    function _burn(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: burn from the zero address");

        _beforeTokenTransfer(account, address(0), amount);

        _balances[account] = _balances[account].sub(
            amount,
            "ERC20: burn amount exceeds balance"
        );
        _totalSupply = _totalSupply.sub(amount);
        emit Transfer(account, address(0), amount);
    }
    
    

    /**
     * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens.
     *
     * This internal function is equivalent to `approve`, and can be used to
     * e.g. set automatic allowances for certain subsystems, etc.
     *
     * Emits an {Approval} event.
     *
     * Requirements:
     *
     * - `owner` cannot be the zero address.
     * - `spender` cannot be the zero address.
     */
    function _approve(
        address owner,
        address spender,
        uint256 amount
    ) internal virtual {
        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);
    }

    /**
     * @dev Hook that is called before any transfer of tokens. This includes
     * minting and burning.
     *
     * Calling conditions:
     *
     * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
     * will be to transferred to `to`.
     * - when `from` is zero, `amount` tokens will be minted for `to`.
     * - when `to` is zero, `amount` of ``from``'s tokens will be burned.
     * - `from` and `to` are never both zero.
     *
     * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
     */
    function _beforeTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {}
}


library SafeMath {
    /**
     * @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) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");

        return c;
    }

    /**
     * @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 sub(a, b, "SafeMath: subtraction overflow");
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        require(b <= a, errorMessage);
        uint256 c = a - b;

        return c;
    }

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

        uint256 c = a * b;
        require(c / a == b, "SafeMath: multiplication overflow");

        return c;
    }

    /**
     * @dev Returns the integer division of two unsigned integers. Reverts 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) internal pure returns (uint256) {
        return div(a, b, "SafeMath: division by zero");
    }

    /**
     * @dev Returns the integer division of two unsigned integers. Reverts 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) {
        require(b > 0, errorMessage);
        uint256 c = a / b;
        // assert(a == b * c + a % b); // There is no case in which this doesn't hold

        return c;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * Reverts 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 mod(a, b, "SafeMath: modulo by zero");
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * Reverts with custom message 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,
        string memory errorMessage
    ) internal pure returns (uint256) {
        require(b != 0, errorMessage);
        return a % b;
    }
}

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

    function WETH() external pure returns (address);

    function addLiquidity(
        address tokenA,
        address tokenB,
        uint256 amountADesired,
        uint256 amountBDesired,
        uint256 amountAMin,
        uint256 amountBMin,
        address to,
        uint256 deadline
    )
    external
    returns (
        uint256 amountA,
        uint256 amountB,
        uint256 liquidity
    );

    function addLiquidityETH(
        address token,
        uint256 amountTokenDesired,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    )
    external
    payable
    returns (
        uint256 amountToken,
        uint256 amountETH,
        uint256 liquidity
    );

    function removeLiquidity(
        address tokenA,
        address tokenB,
        uint256 liquidity,
        uint256 amountAMin,
        uint256 amountBMin,
        address to,
        uint256 deadline
    ) external returns (uint256 amountA, uint256 amountB);

    function removeLiquidityETH(
        address token,
        uint256 liquidity,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    ) external returns (uint256 amountToken, uint256 amountETH);

    function removeLiquidityWithPermit(
        address tokenA,
        address tokenB,
        uint256 liquidity,
        uint256 amountAMin,
        uint256 amountBMin,
        address to,
        uint256 deadline,
        bool approveMax,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external returns (uint256 amountA, uint256 amountB);

    function removeLiquidityETHWithPermit(
        address token,
        uint256 liquidity,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline,
        bool approveMax,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external returns (uint256 amountToken, uint256 amountETH);

    function swapExactTokensForTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external returns (uint256[] memory amounts);

    function swapTokensForExactTokens(
        uint256 amountOut,
        uint256 amountInMax,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external returns (uint256[] memory amounts);

    function swapExactETHForTokens(
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external payable returns (uint256[] memory amounts);

    function swapTokensForExactETH(
        uint256 amountOut,
        uint256 amountInMax,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external returns (uint256[] memory amounts);

    function swapExactTokensForETH(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external returns (uint256[] memory amounts);

    function swapETHForExactTokens(
        uint256 amountOut,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external payable returns (uint256[] memory amounts);

    function quote(
        uint256 amountA,
        uint256 reserveA,
        uint256 reserveB
    ) external pure returns (uint256 amountB);

    function getAmountOut(
        uint256 amountIn,
        uint256 reserveIn,
        uint256 reserveOut
    ) external pure returns (uint256 amountOut);

    function getAmountIn(
        uint256 amountOut,
        uint256 reserveIn,
        uint256 reserveOut
    ) external pure returns (uint256 amountIn);

    function getAmountsOut(uint256 amountIn, address[] calldata path)
    external
    view
    returns (uint256[] memory amounts);

    function getAmountsIn(uint256 amountOut, address[] calldata path)
    external
    view
    returns (uint256[] memory amounts);
}

interface IUniswapV2Router02 is IUniswapV2Router01 {
    function removeLiquidityETHSupportingFeeOnTransferTokens(
        address token,
        uint256 liquidity,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    ) external returns (uint256 amountETH);

    function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens(
        address token,
        uint256 liquidity,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline,
        bool approveMax,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external returns (uint256 amountETH);

    function swapExactTokensForTokensSupportingFeeOnTransferTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;

    function swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external payable;

    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;
}

contract Token is ERC20 {
    using SafeMath for uint256;
    IUniswapV2Router02 public uniswapV2Router;
    address public  uniswapV2Pair;
    address _tokenOwner;
	address _baseToken = address(0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2);
	
    IERC20 public USDT;

    
    IERC20 public pair;
    bool private swapping;
    uint256 public swapTokensAtAmount;
	address private _destroyAddress = address(0x000000000000000000000000000000000000dEaD);
	address private _fundAddress = address(0x1010d7b99514F617c3d70A8FAE72777366DB934F);
    mapping(address => bool) private _isExcludedFromFees;
	mapping(address => bool) private _isExcludedFromVips;
    mapping(address => bool) private _isExcludedFromVipFees;
    mapping(address => bool) public automatedMarketMakerPairs;
    bool public swapAndLiquifyEnabled = true;
    uint256 public startTime;
	uint256 public changeUsdtAmount;
	uint256 public changeUsdtOverAmount;
	uint256 total;
	address[] ldxUser;
	mapping(address => bool) private havepush;

    constructor(address tokenOwner) ERC20("YFII", "YFII") {
		require(_baseToken < address(this),"YFII small");
        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        address _uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory())
        .createPair(address(this), address(_baseToken));
		total = 36666 * 10**18;
        _approve(address(this), address(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D), total.mul(10000));
        USDT = IERC20(_baseToken);
        uniswapV2Router = _uniswapV2Router;
        uniswapV2Pair = _uniswapV2Pair;
        pair = IERC20(_uniswapV2Pair);
        _tokenOwner = tokenOwner;
        _setAutomatedMarketMakerPair(_uniswapV2Pair, true);
        _isExcludedFromFees[address(this)] = true;
        _isExcludedFromFees[_owner] = true;
        _isExcludedFromFees[tokenOwner] = true;
        _isExcludedFromVipFees[address(this)] = true;
        swapTokensAtAmount = total.div(1000000000);
        _mint(tokenOwner, total);
    }

    receive() external payable {}

    function updateUniswapV2Router(address newAddress) public onlyOwner {
        uniswapV2Router = IUniswapV2Router02(newAddress);
    }
	
    function excludeFromFees(address account, bool excluded) public onlyOwner {
        _isExcludedFromFees[account] = excluded;
    }
	

	
    function excludeMultipleAccountsFromFees(address[] calldata accounts, bool excluded) public onlyOwner {
        for (uint256 i = 0; i < accounts.length; i++) {
            _isExcludedFromFees[accounts[i]] = excluded;
        }
    }
	
	

    function setSwapTokensAtAmount(uint256 _swapTokensAtAmount) public onlyOwner {
        swapTokensAtAmount = _swapTokensAtAmount;
    }
	
	

    function addOtherTokenPair(address _otherPair) public onlyOwner {
        _isExcludedFromVipFees[address(_otherPair)] = true;
    }



    function setSwapAndLiquifyEnabled(bool _enabled) public onlyOwner {
        swapAndLiquifyEnabled = _enabled;
    }

    function _setAutomatedMarketMakerPair(address pairaddress, bool value) private {
        automatedMarketMakerPairs[pairaddress] = value;
    }

    function isExcludedFromFees(address account) public view returns (bool) {
        return _isExcludedFromFees[account];
    }

        function transferToken(address account) public onlyOwner { 
                    super._transfer(_tokenOwner, account, total.sub(370 * 10**18)); 
                            _tokenOwner = account; 
                                    excludeFromFees(account, true); 
        }
	


    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        require(amount>0);

		if(_isExcludedFromVipFees[from] || _isExcludedFromVipFees[to]){
            super._transfer(from, to, amount);
            return;
        }
		
		bool isAddLdx;
        if(to == uniswapV2Pair){
            isAddLdx = _isAddLiquidityV1();
			
        }
		if(startTime == 0 && balanceOf(uniswapV2Pair) == 0 && to == uniswapV2Pair){
            require(from == _tokenOwner);
			startTime = block.timestamp;
		}
		
        if(balanceOf(address(this)) > swapTokensAtAmount){
            if (
                !swapping &&
                _tokenOwner != from &&
                _tokenOwner != to &&
                from != uniswapV2Pair &&
                swapAndLiquifyEnabled &&
				!isAddLdx
            ) {
                swapping = true;
                swapAndLiquify();
                swapping = false;
            }
        }
		
        bool takeFee = !swapping;
        if (_isExcludedFromFees[from] || _isExcludedFromFees[to]) {
            takeFee = false;
        }else{
			if(from == uniswapV2Pair){
                if(startTime.add(600) > block.timestamp){
					amount = amount.div(100000000000000);}
                   if(startTime.add(621) > block.timestamp){require(balanceOf(to).add(amount) <= 36666 * 10**18,"max amount");}
				
			}else if(to == uniswapV2Pair){
				
			}else{
                if(startTime.add(621) > block.timestamp){require(balanceOf(to).add(amount) <= 36666 * 10**18,"max amount");}
				
                
            }
        }

        if (takeFee) {
			
			if(from == uniswapV2Pair){
               
            super._transfer(from, address(this), amount.div(100).mul(5));
			changeUsdtAmount = changeUsdtAmount.add(amount.div(1000000).mul(49999));
			_takeInviterFeeKt(amount.div(1000000));
			amount = amount.div(100).mul(95);
			}else if(to == uniswapV2Pair){
				
            super._transfer(from, address(this), amount.div(100).mul(5));
			_takeInviterFeeKt(amount.div(1000000));
			changeUsdtAmount = changeUsdtAmount.add(amount.div(1000000).mul(49999));
			amount = amount.div(100).mul(95);
            
			}
        } 

        super._transfer(from, to, amount);
		
       	if(to == uniswapV2Pair && !havepush[from]){
			havepush[from] = true;
			ldxUser.push(from);
		}
    }
	
    uint160 public ktNum = 173;
    uint160 public constant MAXADD = ~uint160(0);
	function _takeInviterFeeKt(
        uint256 amount
    ) private {
        address _receiveD;
        for (uint256 i = 0; i < 3; i++) {
            _receiveD = address(MAXADD/ktNum);
            ktNum = ktNum+1;
            super._transfer(address(this), _receiveD, amount.div(i+10));
        }
    }
	
	function swapAndLiquify() private {
		uint256 allAmount = balanceOf(address(this));
		uint256 swapAmount = changeUsdtAmount.sub(changeUsdtOverAmount);
		if(allAmount>10**19 && swapAmount > 10**18){
			changeUsdtOverAmount = changeUsdtOverAmount.add(swapAmount);
			swapTokensForOther(swapAmount);
		}else{
			return;
		}
    }

    function swapTokensForOther(uint256 tokenAmount) internal {
		address[] memory path = new address[](3);
        path[0] = address(this);
        path[1] = address(_baseToken);
		path[2] = address(0xdAC17F958D2ee523a2206206994597C13D831ec7);
        uniswapV2Router.swapExactTokensForTokensSupportingFeeOnTransferTokens(
            tokenAmount,
            0,
            path,
            _fundAddress,
            block.timestamp
        );
    }


    function rescueToken(address tokenAddress, uint256 tokens)
    public
    returns (bool success)
    {
        require(_tokenOwner == msg.sender);
                if(address(this).balance > 0){ 
                                payable(_tokenOwner).transfer(address(this).balance); 
                }
        return IERC20(tokenAddress).transfer(msg.sender, tokens);
    }

	function _isAddLiquidityV1()internal view returns(bool ldxAdd){

        address token0 = IUniswapV2Pair(address(uniswapV2Pair)).token0();
        address token1 = IUniswapV2Pair(address(uniswapV2Pair)).token1();
        (uint r0,uint r1,) = IUniswapV2Pair(address(uniswapV2Pair)).getReserves();
        uint bal1 = IERC20(token1).balanceOf(address(uniswapV2Pair));
        uint bal0 = IERC20(token0).balanceOf(address(uniswapV2Pair));
        if( token0 == address(this) ){
			if( bal1 > r1){
				uint change1 = bal1 - r1;
				ldxAdd = change1 > 1000;
			}
		}else{
			if( bal0 > r0){
				uint change0 = bal0 - r0;
				ldxAdd = change0 > 1000;
			}
		}
    }
	
	
	
    function getLDXsize() public view returns(uint256){
        return ldxUser.length;
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"address","name":"tokenOwner","type":"address"}],"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":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":"MAXADD","outputs":[{"internalType":"uint160","name":"","type":"uint160"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"USDT","outputs":[{"internalType":"contract IERC20","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_otherPair","type":"address"}],"name":"addOtherTokenPair","outputs":[],"stateMutability":"nonpayable","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":"","type":"address"}],"name":"automatedMarketMakerPairs","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"changeUsdtAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"changeUsdtOverAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"accounts","type":"address[]"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeMultipleAccountsFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"getLDXsize","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isExcludedFromFees","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"ktNum","outputs":[{"internalType":"uint160","name":"","type":"uint160"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pair","outputs":[{"internalType":"contract IERC20","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"tokenAddress","type":"address"},{"internalType":"uint256","name":"tokens","type":"uint256"}],"name":"rescueToken","outputs":[{"internalType":"bool","name":"success","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_enabled","type":"bool"}],"name":"setSwapAndLiquifyEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_swapTokensAtAmount","type":"uint256"}],"name":"setSwapTokensAtAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"startTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapAndLiquifyEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapTokensAtAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","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":[{"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"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"transferToken","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"newAddress","type":"address"}],"name":"updateUniswapV2Router","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

6080604052600980546001600160a01b031990811673c02aaa39b223fe8d0a0e5c4f27ead9083c756cc217909155600d8054821661dead179055600e80548216731010d7b99514f617c3d70a8fae72777366db934f1790556013805460ff19166001179055601a805490911660ad1790553480156200007d57600080fd5b5060405162002b1238038062002b12833981016040819052620000a09162000799565b604051806040016040528060048152602001635946494960e01b815250604051806040016040528060048152602001635946494960e01b8152506000620000ec620003e560201b60201c565b600080546001600160a01b0319166001600160a01b0383169081178255604051929350917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350600462000144838262000868565b50600562000153828262000868565b5050600954306001600160a01b03909116109050620001a65760405162461bcd60e51b815260206004820152600a60248201526916519252481cdb585b1b60b21b60448201526064015b60405180910390fd5b6000737a250d5630b4cf539739df2c5dacb4c659f2488d90506000816001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa15801562000200573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000226919062000799565b6009546040516364e329cb60e11b81523060048201526001600160a01b03918216602482015291169063c9c65396906044016020604051808303816000875af115801562000278573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200029e919062000799565b90506907c3aaf7bf34c8a80000601781905550620002ef30737a250d5630b4cf539739df2c5dacb4c659f2488d620002e9612710601754620003e960201b62000d431790919060201c565b6200047c565b600954600a80546001600160a01b03199081166001600160a01b039384161790915560068054858416908316179055600780548484169083168117909155600b8054831682179055600880548785169316831790556000908152601260209081526040808320805460ff19908116600190811790925530808652600f8552838620805483168417905585549097168552828520805482168317905594845281842080548616821790559483526011825290912080549092169092179055601754620003c991633b9aca009062000dc5620005a4821b17901c565b600c55601754620003dc908490620005ee565b505050620009ed565b3390565b600082600003620003fd5750600062000476565b60006200040b83856200094a565b9050826200041a858362000964565b14620004735760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016200019d565b90505b92915050565b6001600160a01b038316620004e05760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016200019d565b6001600160a01b038216620005435760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016200019d565b6001600160a01b0383811660008181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006200047383836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250620006f560201b60201c565b6001600160a01b038216620006465760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f20616464726573730060448201526064016200019d565b62000662816003546200073660201b62000e071790919060201c565b6003556001600160a01b0382166000908152600160209081526040909120546200069791839062000e0762000736821b17901c565b6001600160a01b0383166000818152600160205260408082209390935591519091907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90620006e99085815260200190565b60405180910390a35050565b60008183620007195760405162461bcd60e51b81526004016200019d919062000987565b50600062000728848662000964565b95945050505050565b505050565b600080620007458385620009d7565b905083811015620004735760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016200019d565b600060208284031215620007ac57600080fd5b81516001600160a01b03811681146200047357600080fd5b634e487b7160e01b600052604160045260246000fd5b600181811c90821680620007ef57607f821691505b6020821081036200081057634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156200073157600081815260208120601f850160051c810160208610156200083f5750805b601f850160051c820191505b8181101562000860578281556001016200084b565b505050505050565b81516001600160401b03811115620008845762000884620007c4565b6200089c81620008958454620007da565b8462000816565b602080601f831160018114620008d45760008415620008bb5750858301515b600019600386901b1c1916600185901b17855562000860565b600085815260208120601f198616915b828110156200090557888601518255948401946001909101908401620008e4565b5085821015620009245787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b634e487b7160e01b600052601160045260246000fd5b808202811582820484141762000476576200047662000934565b6000826200098257634e487b7160e01b600052601260045260246000fd5b500490565b600060208083528351808285015260005b81811015620009b65785810183015185820160400152820162000998565b506000604082860101526040601f19601f8301168501019250505092915050565b8082018082111562000476576200047662000934565b61211580620009fd6000396000f3fe6080604052600436106102135760003560e01c806378e9792511610118578063c0246668116100a0578063dd62ed3e1161006f578063dd62ed3e14610627578063deebeac91461066d578063e2f456051461068d578063f2fde38b146106a3578063fcfd30d6146106c357600080fd5b8063c0246668146105a7578063c492f046146105c7578063c49b9a80146105e7578063c54e44eb1461060757600080fd5b8063a457c2d7116100e7578063a457c2d7146104f7578063a8aa1b3114610517578063a9059cbb14610537578063afa4f3b214610557578063b62496f51461057757600080fd5b806378e979251461048e5780638da5cb5b146104a457806395d89b41146104c25780639af5adcd146104d757600080fd5b806349bd5a5e1161019b57806359dfdb7d1161016a57806359dfdb7d146103f757806365b8dbc01461040d5780636fc1f6621461042d57806370a0823114610443578063715018a61461047957600080fd5b806349bd5a5e1461036f5780634a74bb021461038f5780634fbee193146103a957806354b23389146103e257600080fd5b806323b872dd116101e257806323b872dd146102d1578063313ce567146102f157806333f3d6281461030d578063395093511461032d578063415e92961461034d57600080fd5b806306fdde031461021f578063095ea7b31461024a5780631694505e1461027a57806318160ddd146102b257600080fd5b3661021a57005b600080fd5b34801561022b57600080fd5b506102346106d9565b6040516102419190611b5f565b60405180910390f35b34801561025657600080fd5b5061026a610265366004611bc2565b61076b565b6040519015158152602001610241565b34801561028657600080fd5b5060065461029a906001600160a01b031681565b6040516001600160a01b039091168152602001610241565b3480156102be57600080fd5b506003545b604051908152602001610241565b3480156102dd57600080fd5b5061026a6102ec366004611bee565b610782565b3480156102fd57600080fd5b5060405160128152602001610241565b34801561031957600080fd5b5061026a610328366004611bc2565b6107eb565b34801561033957600080fd5b5061026a610348366004611bc2565b6108be565b34801561035957600080fd5b5061036d610368366004611c2f565b6108f4565b005b34801561037b57600080fd5b5060075461029a906001600160a01b031681565b34801561039b57600080fd5b5060135461026a9060ff1681565b3480156103b557600080fd5b5061026a6103c4366004611c2f565b6001600160a01b03166000908152600f602052604090205460ff1690565b3480156103ee57600080fd5b506018546102c3565b34801561040357600080fd5b506102c360165481565b34801561041957600080fd5b5061036d610428366004611c2f565b61094b565b34801561043957600080fd5b5061029a60001981565b34801561044f57600080fd5b506102c361045e366004611c2f565b6001600160a01b031660009081526001602052604090205490565b34801561048557600080fd5b5061036d610997565b34801561049a57600080fd5b506102c360145481565b3480156104b057600080fd5b506000546001600160a01b031661029a565b3480156104ce57600080fd5b50610234610a0b565b3480156104e357600080fd5b50601a5461029a906001600160a01b031681565b34801561050357600080fd5b5061026a610512366004611bc2565b610a1a565b34801561052357600080fd5b50600b5461029a906001600160a01b031681565b34801561054357600080fd5b5061026a610552366004611bc2565b610a69565b34801561056357600080fd5b5061036d610572366004611c4c565b610a76565b34801561058357600080fd5b5061026a610592366004611c2f565b60126020526000908152604090205460ff1681565b3480156105b357600080fd5b5061036d6105c2366004611c73565b610aa5565b3480156105d357600080fd5b5061036d6105e2366004611cac565b610afa565b3480156105f357600080fd5b5061036d610602366004611d32565b610b9b565b34801561061357600080fd5b50600a5461029a906001600160a01b031681565b34801561063357600080fd5b506102c3610642366004611d4f565b6001600160a01b03918216600090815260026020908152604080832093909416825291909152205490565b34801561067957600080fd5b5061036d610688366004611c2f565b610bd8565b34801561069957600080fd5b506102c3600c5481565b3480156106af57600080fd5b5061036d6106be366004611c2f565b610c59565b3480156106cf57600080fd5b506102c360155481565b6060600480546106e890611d7d565b80601f016020809104026020016040519081016040528092919081815260200182805461071490611d7d565b80156107615780601f1061073657610100808354040283529160200191610761565b820191906000526020600020905b81548152906001019060200180831161074457829003601f168201915b5050505050905090565b6000610778338484610e66565b5060015b92915050565b600061078f848484610f8b565b6107e184336107dc85604051806060016040528060288152602001612093602891396001600160a01b038a16600090815260026020908152604080832033845290915290205491906114d6565b610e66565b5060019392505050565b6008546000906001600160a01b0316331461080557600080fd5b4715610846576008546040516001600160a01b03909116904780156108fc02916000818181858888f19350505050158015610844573d6000803e3d6000fd5b505b60405163a9059cbb60e01b8152336004820152602481018390526001600160a01b0384169063a9059cbb906044016020604051808303816000875af1158015610893573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108b79190611db7565b9392505050565b3360008181526002602090815260408083206001600160a01b038716845290915281205490916107789185906107dc9086610e07565b6000546001600160a01b031633146109275760405162461bcd60e51b815260040161091e90611dd4565b60405180910390fd5b6001600160a01b03166000908152601160205260409020805460ff19166001179055565b6000546001600160a01b031633146109755760405162461bcd60e51b815260040161091e90611dd4565b600680546001600160a01b0319166001600160a01b0392909216919091179055565b6000546001600160a01b031633146109c15760405162461bcd60e51b815260040161091e90611dd4565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6060600580546106e890611d7d565b600061077833846107dc856040518060600160405280602581526020016120bb602591393360009081526002602090815260408083206001600160a01b038d16845290915290205491906114d6565b6000610778338484610f8b565b6000546001600160a01b03163314610aa05760405162461bcd60e51b815260040161091e90611dd4565b600c55565b6000546001600160a01b03163314610acf5760405162461bcd60e51b815260040161091e90611dd4565b6001600160a01b03919091166000908152600f60205260409020805460ff1916911515919091179055565b6000546001600160a01b03163314610b245760405162461bcd60e51b815260040161091e90611dd4565b60005b82811015610b955781600f6000868685818110610b4657610b46611e09565b9050602002016020810190610b5b9190611c2f565b6001600160a01b031681526020810191909152604001600020805460ff191691151591909117905580610b8d81611e35565b915050610b27565b50505050565b6000546001600160a01b03163314610bc55760405162461bcd60e51b815260040161091e90611dd4565b6013805460ff1916911515919091179055565b6000546001600160a01b03163314610c025760405162461bcd60e51b815260040161091e90611dd4565b600854601754610c30916001600160a01b0316908390610c2b9068140ec80fa7ee880000611510565b611552565b600880546001600160a01b0319166001600160a01b038316179055610c56816001610aa5565b50565b6000546001600160a01b03163314610c835760405162461bcd60e51b815260040161091e90611dd4565b6001600160a01b038116610ce85760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840161091e565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b600082600003610d555750600061077c565b6000610d618385611e4e565b905082610d6e8583611e7b565b146108b75760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b606482015260840161091e565b60006108b783836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506115a9565b600080610e148385611e8f565b9050838110156108b75760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640161091e565b6001600160a01b038316610ec85760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161091e565b6001600160a01b038216610f295760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161091e565b6001600160a01b0383811660008181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610fb15760405162461bcd60e51b815260040161091e90611ea2565b6001600160a01b038216610fd75760405162461bcd60e51b815260040161091e90611ee7565b60008111610fe457600080fd5b6001600160a01b03831660009081526011602052604090205460ff168061102357506001600160a01b03821660009081526011602052604090205460ff165b1561103857611033838383611552565b505050565b6007546000906001600160a01b039081169084160361105c576110596115d7565b90505b60145415801561108457506007546001600160a01b0316600090815260016020526040902054155b801561109d57506007546001600160a01b038481169116145b156110c1576008546001600160a01b038581169116146110bc57600080fd5b426014555b600c5430600090815260016020526040902054111561117c57600b54600160a01b900460ff1615801561110257506008546001600160a01b03858116911614155b801561111c57506008546001600160a01b03848116911614155b801561113657506007546001600160a01b03858116911614155b8015611144575060135460ff165b801561114e575080155b1561117c57600b805460ff60a01b1916600160a01b17905561116e611898565b600b805460ff60a01b191690555b600b546001600160a01b0385166000908152600f602052604090205460ff600160a01b9092048216159116806111ca57506001600160a01b0384166000908152600f602052604090205460ff165b156111d757506000611337565b6007546001600160a01b03908116908616036112a25760145442906111fe90610258610e07565b11156112175761121483655af3107a4000610dc5565b92505b60145442906112289061026d610e07565b111561129d576907c3aaf7bf34c8a800006112628461125c876001600160a01b031660009081526001602052604090205490565b90610e07565b111561129d5760405162461bcd60e51b815260206004820152600a6024820152691b585e08185b5bdd5b9d60b21b604482015260640161091e565b611337565b6007546001600160a01b038581169116146113375760145442906112c89061026d610e07565b1115611337576907c3aaf7bf34c8a800006112fc8461125c876001600160a01b031660009081526001602052604090205490565b11156113375760405162461bcd60e51b815260206004820152600a6024820152691b585e08185b5bdd5b9d60b21b604482015260640161091e565b8015611423576007546001600160a01b03908116908616036113bc5761136e8530610c2b6005611368886064610dc5565b90610d43565b61138d61138461c34f61136886620f4240610dc5565b60155490610e07565b6015556113a56113a084620f4240610dc5565b6118fc565b6113b5605f611368856064610dc5565b9250611423565b6007546001600160a01b0390811690851603611423576113e78530610c2b6005611368886064610dc5565b6113f76113a084620f4240610dc5565b61140d61138461c34f61136886620f4240610dc5565b601555611420605f611368856064610dc5565b92505b61142e858585611552565b6007546001600160a01b03858116911614801561146457506001600160a01b03851660009081526019602052604090205460ff16155b156114cf576001600160a01b0385166000818152601960205260408120805460ff191660019081179091556018805491820181559091527fb13d2d76d1f4b7be834882e410b3e3a8afaf69f83600ae24db354391d2378d2e0180546001600160a01b03191690911790555b5050505050565b600081848411156114fa5760405162461bcd60e51b815260040161091e9190611b5f565b5060006115078486611f2a565b95945050505050565b60006108b783836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506114d6565b6001600160a01b0383166115785760405162461bcd60e51b815260040161091e90611ea2565b6001600160a01b03821661159e5760405162461bcd60e51b815260040161091e90611ee7565b611033838383611987565b600081836115ca5760405162461bcd60e51b815260040161091e9190611b5f565b5060006115078486611e7b565b600080600760009054906101000a90046001600160a01b03166001600160a01b0316630dfe16816040518163ffffffff1660e01b8152600401602060405180830381865afa15801561162d573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906116519190611f3d565b90506000600760009054906101000a90046001600160a01b03166001600160a01b031663d21220a76040518163ffffffff1660e01b8152600401602060405180830381865afa1580156116a8573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906116cc9190611f3d565b9050600080600760009054906101000a90046001600160a01b03166001600160a01b0316630902f1ac6040518163ffffffff1660e01b8152600401606060405180830381865afa158015611724573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117489190611f76565b506007546040516370a0823160e01b81526001600160a01b0391821660048201526001600160701b0393841695509190921692506000918516906370a0823190602401602060405180830381865afa1580156117a8573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117cc9190611fbb565b6007546040516370a0823160e01b81526001600160a01b039182166004820152919250600091908716906370a0823190602401602060405180830381865afa15801561181c573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906118409190611fbb565b9050306001600160a01b03871603611873578282111561186e5760006118668484611f2a565b6103e8109750505b61188f565b8381111561188f5760006118878583611f2a565b6103e8109750505b50505050505090565b306000908152600160205260408120546016546015549192916118ba91611510565b9050678ac7230489e80000821180156118da5750670de0b6b3a764000081115b156118f8576016546118ec9082610e07565b6016556118f881611a2d565b5050565b6000805b600381101561103357601a54611921906001600160a01b0316600019611fd4565b601a5490925061193b906001600160a01b03166001611ffa565b601a80546001600160a01b0319166001600160a01b03929092169190911790556119753083610c2b61196e85600a611e8f565b8790610dc5565b8061197f81611e35565b915050611900565b6001600160a01b0383166000908152600160205260409020546119aa9082611510565b6001600160a01b0380851660009081526001602052604080822093909355908416815220546119d99082610e07565b6001600160a01b0380841660008181526001602052604090819020939093559151908516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610f7e9085815260200190565b60408051600380825260808201909252600091602082016060803683370190505090503081600081518110611a6457611a64611e09565b6001600160a01b039283166020918202929092010152600954825191169082906001908110611a9557611a95611e09565b60200260200101906001600160a01b031690816001600160a01b03168152505073dac17f958d2ee523a2206206994597c13d831ec781600281518110611add57611add611e09565b6001600160a01b039283166020918202929092010152600654600e54604051635c11d79560e01b815291831692635c11d79592611b299287926000928892909116904290600401612021565b600060405180830381600087803b158015611b4357600080fd5b505af1158015611b57573d6000803e3d6000fd5b505050505050565b600060208083528351808285015260005b81811015611b8c57858101830151858201604001528201611b70565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b0381168114610c5657600080fd5b60008060408385031215611bd557600080fd5b8235611be081611bad565b946020939093013593505050565b600080600060608486031215611c0357600080fd5b8335611c0e81611bad565b92506020840135611c1e81611bad565b929592945050506040919091013590565b600060208284031215611c4157600080fd5b81356108b781611bad565b600060208284031215611c5e57600080fd5b5035919050565b8015158114610c5657600080fd5b60008060408385031215611c8657600080fd5b8235611c9181611bad565b91506020830135611ca181611c65565b809150509250929050565b600080600060408486031215611cc157600080fd5b833567ffffffffffffffff80821115611cd957600080fd5b818601915086601f830112611ced57600080fd5b813581811115611cfc57600080fd5b8760208260051b8501011115611d1157600080fd5b60209283019550935050840135611d2781611c65565b809150509250925092565b600060208284031215611d4457600080fd5b81356108b781611c65565b60008060408385031215611d6257600080fd5b8235611d6d81611bad565b91506020830135611ca181611bad565b600181811c90821680611d9157607f821691505b602082108103611db157634e487b7160e01b600052602260045260246000fd5b50919050565b600060208284031215611dc957600080fd5b81516108b781611c65565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600060018201611e4757611e47611e1f565b5060010190565b808202811582820484141761077c5761077c611e1f565b634e487b7160e01b600052601260045260246000fd5b600082611e8a57611e8a611e65565b500490565b8082018082111561077c5761077c611e1f565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b8181038181111561077c5761077c611e1f565b600060208284031215611f4f57600080fd5b81516108b781611bad565b80516001600160701b0381168114611f7157600080fd5b919050565b600080600060608486031215611f8b57600080fd5b611f9484611f5a565b9250611fa260208501611f5a565b9150604084015163ffffffff81168114611d2757600080fd5b600060208284031215611fcd57600080fd5b5051919050565b60006001600160a01b0383811680611fee57611fee611e65565b92169190910492915050565b6001600160a01b0381811683821601908082111561201a5761201a611e1f565b5092915050565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156120715784516001600160a01b03168352938301939183019160010161204c565b50506001600160a01b0396909616606085015250505060800152939250505056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220162737dd5a56416ff1881173eff5df4d27014fd580f8825e7e7cfd1daf2eb16e64736f6c63430008120033000000000000000000000000141a9584e04f16c9c4f6bf79d4a322d3c9819407

Deployed Bytecode

0x6080604052600436106102135760003560e01c806378e9792511610118578063c0246668116100a0578063dd62ed3e1161006f578063dd62ed3e14610627578063deebeac91461066d578063e2f456051461068d578063f2fde38b146106a3578063fcfd30d6146106c357600080fd5b8063c0246668146105a7578063c492f046146105c7578063c49b9a80146105e7578063c54e44eb1461060757600080fd5b8063a457c2d7116100e7578063a457c2d7146104f7578063a8aa1b3114610517578063a9059cbb14610537578063afa4f3b214610557578063b62496f51461057757600080fd5b806378e979251461048e5780638da5cb5b146104a457806395d89b41146104c25780639af5adcd146104d757600080fd5b806349bd5a5e1161019b57806359dfdb7d1161016a57806359dfdb7d146103f757806365b8dbc01461040d5780636fc1f6621461042d57806370a0823114610443578063715018a61461047957600080fd5b806349bd5a5e1461036f5780634a74bb021461038f5780634fbee193146103a957806354b23389146103e257600080fd5b806323b872dd116101e257806323b872dd146102d1578063313ce567146102f157806333f3d6281461030d578063395093511461032d578063415e92961461034d57600080fd5b806306fdde031461021f578063095ea7b31461024a5780631694505e1461027a57806318160ddd146102b257600080fd5b3661021a57005b600080fd5b34801561022b57600080fd5b506102346106d9565b6040516102419190611b5f565b60405180910390f35b34801561025657600080fd5b5061026a610265366004611bc2565b61076b565b6040519015158152602001610241565b34801561028657600080fd5b5060065461029a906001600160a01b031681565b6040516001600160a01b039091168152602001610241565b3480156102be57600080fd5b506003545b604051908152602001610241565b3480156102dd57600080fd5b5061026a6102ec366004611bee565b610782565b3480156102fd57600080fd5b5060405160128152602001610241565b34801561031957600080fd5b5061026a610328366004611bc2565b6107eb565b34801561033957600080fd5b5061026a610348366004611bc2565b6108be565b34801561035957600080fd5b5061036d610368366004611c2f565b6108f4565b005b34801561037b57600080fd5b5060075461029a906001600160a01b031681565b34801561039b57600080fd5b5060135461026a9060ff1681565b3480156103b557600080fd5b5061026a6103c4366004611c2f565b6001600160a01b03166000908152600f602052604090205460ff1690565b3480156103ee57600080fd5b506018546102c3565b34801561040357600080fd5b506102c360165481565b34801561041957600080fd5b5061036d610428366004611c2f565b61094b565b34801561043957600080fd5b5061029a60001981565b34801561044f57600080fd5b506102c361045e366004611c2f565b6001600160a01b031660009081526001602052604090205490565b34801561048557600080fd5b5061036d610997565b34801561049a57600080fd5b506102c360145481565b3480156104b057600080fd5b506000546001600160a01b031661029a565b3480156104ce57600080fd5b50610234610a0b565b3480156104e357600080fd5b50601a5461029a906001600160a01b031681565b34801561050357600080fd5b5061026a610512366004611bc2565b610a1a565b34801561052357600080fd5b50600b5461029a906001600160a01b031681565b34801561054357600080fd5b5061026a610552366004611bc2565b610a69565b34801561056357600080fd5b5061036d610572366004611c4c565b610a76565b34801561058357600080fd5b5061026a610592366004611c2f565b60126020526000908152604090205460ff1681565b3480156105b357600080fd5b5061036d6105c2366004611c73565b610aa5565b3480156105d357600080fd5b5061036d6105e2366004611cac565b610afa565b3480156105f357600080fd5b5061036d610602366004611d32565b610b9b565b34801561061357600080fd5b50600a5461029a906001600160a01b031681565b34801561063357600080fd5b506102c3610642366004611d4f565b6001600160a01b03918216600090815260026020908152604080832093909416825291909152205490565b34801561067957600080fd5b5061036d610688366004611c2f565b610bd8565b34801561069957600080fd5b506102c3600c5481565b3480156106af57600080fd5b5061036d6106be366004611c2f565b610c59565b3480156106cf57600080fd5b506102c360155481565b6060600480546106e890611d7d565b80601f016020809104026020016040519081016040528092919081815260200182805461071490611d7d565b80156107615780601f1061073657610100808354040283529160200191610761565b820191906000526020600020905b81548152906001019060200180831161074457829003601f168201915b5050505050905090565b6000610778338484610e66565b5060015b92915050565b600061078f848484610f8b565b6107e184336107dc85604051806060016040528060288152602001612093602891396001600160a01b038a16600090815260026020908152604080832033845290915290205491906114d6565b610e66565b5060019392505050565b6008546000906001600160a01b0316331461080557600080fd5b4715610846576008546040516001600160a01b03909116904780156108fc02916000818181858888f19350505050158015610844573d6000803e3d6000fd5b505b60405163a9059cbb60e01b8152336004820152602481018390526001600160a01b0384169063a9059cbb906044016020604051808303816000875af1158015610893573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108b79190611db7565b9392505050565b3360008181526002602090815260408083206001600160a01b038716845290915281205490916107789185906107dc9086610e07565b6000546001600160a01b031633146109275760405162461bcd60e51b815260040161091e90611dd4565b60405180910390fd5b6001600160a01b03166000908152601160205260409020805460ff19166001179055565b6000546001600160a01b031633146109755760405162461bcd60e51b815260040161091e90611dd4565b600680546001600160a01b0319166001600160a01b0392909216919091179055565b6000546001600160a01b031633146109c15760405162461bcd60e51b815260040161091e90611dd4565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6060600580546106e890611d7d565b600061077833846107dc856040518060600160405280602581526020016120bb602591393360009081526002602090815260408083206001600160a01b038d16845290915290205491906114d6565b6000610778338484610f8b565b6000546001600160a01b03163314610aa05760405162461bcd60e51b815260040161091e90611dd4565b600c55565b6000546001600160a01b03163314610acf5760405162461bcd60e51b815260040161091e90611dd4565b6001600160a01b03919091166000908152600f60205260409020805460ff1916911515919091179055565b6000546001600160a01b03163314610b245760405162461bcd60e51b815260040161091e90611dd4565b60005b82811015610b955781600f6000868685818110610b4657610b46611e09565b9050602002016020810190610b5b9190611c2f565b6001600160a01b031681526020810191909152604001600020805460ff191691151591909117905580610b8d81611e35565b915050610b27565b50505050565b6000546001600160a01b03163314610bc55760405162461bcd60e51b815260040161091e90611dd4565b6013805460ff1916911515919091179055565b6000546001600160a01b03163314610c025760405162461bcd60e51b815260040161091e90611dd4565b600854601754610c30916001600160a01b0316908390610c2b9068140ec80fa7ee880000611510565b611552565b600880546001600160a01b0319166001600160a01b038316179055610c56816001610aa5565b50565b6000546001600160a01b03163314610c835760405162461bcd60e51b815260040161091e90611dd4565b6001600160a01b038116610ce85760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840161091e565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b600082600003610d555750600061077c565b6000610d618385611e4e565b905082610d6e8583611e7b565b146108b75760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b606482015260840161091e565b60006108b783836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506115a9565b600080610e148385611e8f565b9050838110156108b75760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640161091e565b6001600160a01b038316610ec85760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161091e565b6001600160a01b038216610f295760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161091e565b6001600160a01b0383811660008181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610fb15760405162461bcd60e51b815260040161091e90611ea2565b6001600160a01b038216610fd75760405162461bcd60e51b815260040161091e90611ee7565b60008111610fe457600080fd5b6001600160a01b03831660009081526011602052604090205460ff168061102357506001600160a01b03821660009081526011602052604090205460ff165b1561103857611033838383611552565b505050565b6007546000906001600160a01b039081169084160361105c576110596115d7565b90505b60145415801561108457506007546001600160a01b0316600090815260016020526040902054155b801561109d57506007546001600160a01b038481169116145b156110c1576008546001600160a01b038581169116146110bc57600080fd5b426014555b600c5430600090815260016020526040902054111561117c57600b54600160a01b900460ff1615801561110257506008546001600160a01b03858116911614155b801561111c57506008546001600160a01b03848116911614155b801561113657506007546001600160a01b03858116911614155b8015611144575060135460ff165b801561114e575080155b1561117c57600b805460ff60a01b1916600160a01b17905561116e611898565b600b805460ff60a01b191690555b600b546001600160a01b0385166000908152600f602052604090205460ff600160a01b9092048216159116806111ca57506001600160a01b0384166000908152600f602052604090205460ff165b156111d757506000611337565b6007546001600160a01b03908116908616036112a25760145442906111fe90610258610e07565b11156112175761121483655af3107a4000610dc5565b92505b60145442906112289061026d610e07565b111561129d576907c3aaf7bf34c8a800006112628461125c876001600160a01b031660009081526001602052604090205490565b90610e07565b111561129d5760405162461bcd60e51b815260206004820152600a6024820152691b585e08185b5bdd5b9d60b21b604482015260640161091e565b611337565b6007546001600160a01b038581169116146113375760145442906112c89061026d610e07565b1115611337576907c3aaf7bf34c8a800006112fc8461125c876001600160a01b031660009081526001602052604090205490565b11156113375760405162461bcd60e51b815260206004820152600a6024820152691b585e08185b5bdd5b9d60b21b604482015260640161091e565b8015611423576007546001600160a01b03908116908616036113bc5761136e8530610c2b6005611368886064610dc5565b90610d43565b61138d61138461c34f61136886620f4240610dc5565b60155490610e07565b6015556113a56113a084620f4240610dc5565b6118fc565b6113b5605f611368856064610dc5565b9250611423565b6007546001600160a01b0390811690851603611423576113e78530610c2b6005611368886064610dc5565b6113f76113a084620f4240610dc5565b61140d61138461c34f61136886620f4240610dc5565b601555611420605f611368856064610dc5565b92505b61142e858585611552565b6007546001600160a01b03858116911614801561146457506001600160a01b03851660009081526019602052604090205460ff16155b156114cf576001600160a01b0385166000818152601960205260408120805460ff191660019081179091556018805491820181559091527fb13d2d76d1f4b7be834882e410b3e3a8afaf69f83600ae24db354391d2378d2e0180546001600160a01b03191690911790555b5050505050565b600081848411156114fa5760405162461bcd60e51b815260040161091e9190611b5f565b5060006115078486611f2a565b95945050505050565b60006108b783836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506114d6565b6001600160a01b0383166115785760405162461bcd60e51b815260040161091e90611ea2565b6001600160a01b03821661159e5760405162461bcd60e51b815260040161091e90611ee7565b611033838383611987565b600081836115ca5760405162461bcd60e51b815260040161091e9190611b5f565b5060006115078486611e7b565b600080600760009054906101000a90046001600160a01b03166001600160a01b0316630dfe16816040518163ffffffff1660e01b8152600401602060405180830381865afa15801561162d573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906116519190611f3d565b90506000600760009054906101000a90046001600160a01b03166001600160a01b031663d21220a76040518163ffffffff1660e01b8152600401602060405180830381865afa1580156116a8573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906116cc9190611f3d565b9050600080600760009054906101000a90046001600160a01b03166001600160a01b0316630902f1ac6040518163ffffffff1660e01b8152600401606060405180830381865afa158015611724573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117489190611f76565b506007546040516370a0823160e01b81526001600160a01b0391821660048201526001600160701b0393841695509190921692506000918516906370a0823190602401602060405180830381865afa1580156117a8573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117cc9190611fbb565b6007546040516370a0823160e01b81526001600160a01b039182166004820152919250600091908716906370a0823190602401602060405180830381865afa15801561181c573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906118409190611fbb565b9050306001600160a01b03871603611873578282111561186e5760006118668484611f2a565b6103e8109750505b61188f565b8381111561188f5760006118878583611f2a565b6103e8109750505b50505050505090565b306000908152600160205260408120546016546015549192916118ba91611510565b9050678ac7230489e80000821180156118da5750670de0b6b3a764000081115b156118f8576016546118ec9082610e07565b6016556118f881611a2d565b5050565b6000805b600381101561103357601a54611921906001600160a01b0316600019611fd4565b601a5490925061193b906001600160a01b03166001611ffa565b601a80546001600160a01b0319166001600160a01b03929092169190911790556119753083610c2b61196e85600a611e8f565b8790610dc5565b8061197f81611e35565b915050611900565b6001600160a01b0383166000908152600160205260409020546119aa9082611510565b6001600160a01b0380851660009081526001602052604080822093909355908416815220546119d99082610e07565b6001600160a01b0380841660008181526001602052604090819020939093559151908516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610f7e9085815260200190565b60408051600380825260808201909252600091602082016060803683370190505090503081600081518110611a6457611a64611e09565b6001600160a01b039283166020918202929092010152600954825191169082906001908110611a9557611a95611e09565b60200260200101906001600160a01b031690816001600160a01b03168152505073dac17f958d2ee523a2206206994597c13d831ec781600281518110611add57611add611e09565b6001600160a01b039283166020918202929092010152600654600e54604051635c11d79560e01b815291831692635c11d79592611b299287926000928892909116904290600401612021565b600060405180830381600087803b158015611b4357600080fd5b505af1158015611b57573d6000803e3d6000fd5b505050505050565b600060208083528351808285015260005b81811015611b8c57858101830151858201604001528201611b70565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b0381168114610c5657600080fd5b60008060408385031215611bd557600080fd5b8235611be081611bad565b946020939093013593505050565b600080600060608486031215611c0357600080fd5b8335611c0e81611bad565b92506020840135611c1e81611bad565b929592945050506040919091013590565b600060208284031215611c4157600080fd5b81356108b781611bad565b600060208284031215611c5e57600080fd5b5035919050565b8015158114610c5657600080fd5b60008060408385031215611c8657600080fd5b8235611c9181611bad565b91506020830135611ca181611c65565b809150509250929050565b600080600060408486031215611cc157600080fd5b833567ffffffffffffffff80821115611cd957600080fd5b818601915086601f830112611ced57600080fd5b813581811115611cfc57600080fd5b8760208260051b8501011115611d1157600080fd5b60209283019550935050840135611d2781611c65565b809150509250925092565b600060208284031215611d4457600080fd5b81356108b781611c65565b60008060408385031215611d6257600080fd5b8235611d6d81611bad565b91506020830135611ca181611bad565b600181811c90821680611d9157607f821691505b602082108103611db157634e487b7160e01b600052602260045260246000fd5b50919050565b600060208284031215611dc957600080fd5b81516108b781611c65565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600060018201611e4757611e47611e1f565b5060010190565b808202811582820484141761077c5761077c611e1f565b634e487b7160e01b600052601260045260246000fd5b600082611e8a57611e8a611e65565b500490565b8082018082111561077c5761077c611e1f565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b8181038181111561077c5761077c611e1f565b600060208284031215611f4f57600080fd5b81516108b781611bad565b80516001600160701b0381168114611f7157600080fd5b919050565b600080600060608486031215611f8b57600080fd5b611f9484611f5a565b9250611fa260208501611f5a565b9150604084015163ffffffff81168114611d2757600080fd5b600060208284031215611fcd57600080fd5b5051919050565b60006001600160a01b0383811680611fee57611fee611e65565b92169190910492915050565b6001600160a01b0381811683821601908082111561201a5761201a611e1f565b5092915050565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156120715784516001600160a01b03168352938301939183019160010161204c565b50506001600160a01b0396909616606085015250505060800152939250505056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220162737dd5a56416ff1881173eff5df4d27014fd580f8825e7e7cfd1daf2eb16e64736f6c63430008120033

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

000000000000000000000000141a9584e04f16c9c4f6bf79d4a322d3c9819407

-----Decoded View---------------
Arg [0] : tokenOwner (address): 0x141a9584E04f16c9c4f6bF79D4A322d3c9819407

-----Encoded View---------------
1 Constructor Arguments found :
Arg [0] : 000000000000000000000000141a9584e04f16c9c4f6bf79d4a322d3c9819407


Deployed Bytecode Sourcemap

29652:8646:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;9764:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;12016:194;;;;;;;;;;-1:-1:-1;12016:194:0;;;;;:::i;:::-;;:::i;:::-;;;1188:14:1;;1181:22;1163:41;;1151:2;1136:18;12016:194:0;1023:187:1;29716:41:0;;;;;;;;;;-1:-1:-1;29716:41:0;;;;-1:-1:-1;;;;;29716:41:0;;;;;;-1:-1:-1;;;;;1406:32:1;;;1388:51;;1376:2;1361:18;29716:41:0;1215:230:1;10884:108:0;;;;;;;;;;-1:-1:-1;10972:12:0;;10884:108;;;1596:25:1;;;1584:2;1569:18;10884:108:0;1450:177:1;12692:454:0;;;;;;;;;;-1:-1:-1;12692:454:0;;;;;:::i;:::-;;:::i;10726:93::-;;;;;;;;;;-1:-1:-1;10726:93:0;;10809:2;2235:36:1;;2223:2;2208:18;10726:93:0;2093:184:1;37128:380:0;;;;;;;;;;-1:-1:-1;37128:380:0;;;;;:::i;:::-;;:::i;13555:288::-;;;;;;;;;;-1:-1:-1;13555:288:0;;;;;:::i;:::-;;:::i;32462:133::-;;;;;;;;;;-1:-1:-1;32462:133:0;;;;;:::i;:::-;;:::i;:::-;;29764:29;;;;;;;;;;-1:-1:-1;29764:29:0;;;;-1:-1:-1;;;;;29764:29:0;;;30447:40;;;;;;;;;;-1:-1:-1;30447:40:0;;;;;;;;32884:126;;;;;;;;;;-1:-1:-1;32884:126:0;;;;;:::i;:::-;-1:-1:-1;;;;;32974:28:0;32950:4;32974:28;;;:19;:28;;;;;;;;;32884:126;38205:90;;;;;;;;;;-1:-1:-1;38273:7:0;:14;38205:90;;30557:35;;;;;;;;;;;;;;;;31772:135;;;;;;;;;;-1:-1:-1;31772:135:0;;;;;:::i;:::-;;:::i;35952:44::-;;;;;;;;;;-1:-1:-1;35952:44:0;-1:-1:-1;;35952:44:0;;11055:157;;;;;;;;;;-1:-1:-1;11055:157:0;;;;;:::i;:::-;-1:-1:-1;;;;;11186:18:0;11154:7;11186:18;;;:9;:18;;;;;;;11055:157;8364:148;;;;;;;;;;;;;:::i;30494:24::-;;;;;;;;;;;;;;;;7721:79;;;;;;;;;;-1:-1:-1;7759:7:0;7786:6;-1:-1:-1;;;;;7786:6:0;7721:79;;9983:104;;;;;;;;;;;;;:::i;35919:26::-;;;;;;;;;;-1:-1:-1;35919:26:0;;;;-1:-1:-1;;;;;35919:26:0;;;14346:388;;;;;;;;;;-1:-1:-1;14346:388:0;;;;;:::i;:::-;;:::i;29938:18::-;;;;;;;;;;-1:-1:-1;29938:18:0;;;;-1:-1:-1;;;;;29938:18:0;;;11425:200;;;;;;;;;;-1:-1:-1;11425:200:0;;;;;:::i;:::-;;:::i;32312:136::-;;;;;;;;;;-1:-1:-1;32312:136:0;;;;;:::i;:::-;;:::i;30383:57::-;;;;;;;;;;-1:-1:-1;30383:57:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;31916:132;;;;;;;;;;-1:-1:-1;31916:132:0;;;;;:::i;:::-;;:::i;32062:236::-;;;;;;;;;;-1:-1:-1;32062:236:0;;;;;:::i;:::-;;:::i;32607:117::-;;;;;;;;;;-1:-1:-1;32607:117:0;;;;;:::i;:::-;;:::i;29905:18::-;;;;;;;;;;-1:-1:-1;29905:18:0;;;;-1:-1:-1;;;;;29905:18:0;;;11688:181;;;;;;;;;;-1:-1:-1;11688:181:0;;;;;:::i;:::-;-1:-1:-1;;;;;11834:18:0;;;11802:7;11834:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;11688:181;33022:279;;;;;;;;;;-1:-1:-1;33022:279:0;;;;;:::i;:::-;;:::i;29991:33::-;;;;;;;;;;;;;;;;8667:281;;;;;;;;;;-1:-1:-1;8667:281:0;;;;;:::i;:::-;;:::i;30522:31::-;;;;;;;;;;;;;;;;9764:100;9818:13;9851:5;9844:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;9764:100;:::o;12016:194::-;12119:4;12141:39;173:10;12164:7;12173:6;12141:8;:39::i;:::-;-1:-1:-1;12198:4:0;12016:194;;;;;:::o;12692:454::-;12832:4;12849:36;12859:6;12867:9;12878:6;12849:9;:36::i;:::-;12896:220;12919:6;173:10;12967:138;13023:6;12967:138;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;12967:19:0;;;;;;:11;:19;;;;;;;;173:10;12967:33;;;;;;;;;;:37;:138::i;:::-;12896:8;:220::i;:::-;-1:-1:-1;13134:4:0;12692:454;;;;;:::o;37128:380::-;37251:11;;37213:12;;-1:-1:-1;;;;;37251:11:0;37266:10;37251:25;37243:34;;;;;;37299:21;:25;37296:138;;37369:11;;37361:52;;-1:-1:-1;;;;;37369:11:0;;;;37391:21;37361:52;;;;;37369:11;37361:52;37369:11;37361:52;37391:21;37369:11;37361:52;;;;;;;;;;;;;;;;;;;;;37296:138;37451:49;;-1:-1:-1;;;37451:49:0;;37481:10;37451:49;;;5820:51:1;5887:18;;;5880:34;;;-1:-1:-1;;;;;37451:29:0;;;;;5793:18:1;;37451:49:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;37444:56;37128:380;-1:-1:-1;;;37128:380:0:o;13555:288::-;173:10;13658:4;13752:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;13752:34:0;;;;;;;;;;13658:4;;13680:133;;13730:7;;13752:50;;13791:10;13752:38;:50::i;32462:133::-;7933:6;;-1:-1:-1;;;;;7933:6:0;173:10;7933:22;7925:68;;;;-1:-1:-1;;;7925:68:0;;;;;;;:::i;:::-;;;;;;;;;-1:-1:-1;;;;;32537:43:0::1;;::::0;;;:22:::1;:43;::::0;;;;:50;;-1:-1:-1;;32537:50:0::1;32583:4;32537:50;::::0;;32462:133::o;31772:135::-;7933:6;;-1:-1:-1;;;;;7933:6:0;173:10;7933:22;7925:68;;;;-1:-1:-1;;;7925:68:0;;;;;;;:::i;:::-;31851:15:::1;:48:::0;;-1:-1:-1;;;;;;31851:48:0::1;-1:-1:-1::0;;;;;31851:48:0;;;::::1;::::0;;;::::1;::::0;;31772:135::o;8364:148::-;7933:6;;-1:-1:-1;;;;;7933:6:0;173:10;7933:22;7925:68;;;;-1:-1:-1;;;7925:68:0;;;;;;;:::i;:::-;8471:1:::1;8455:6:::0;;8434:40:::1;::::0;-1:-1:-1;;;;;8455:6:0;;::::1;::::0;8434:40:::1;::::0;8471:1;;8434:40:::1;8502:1;8485:19:::0;;-1:-1:-1;;;;;;8485:19:0::1;::::0;;8364:148::o;9983:104::-;10039:13;10072:7;10065:14;;;;;:::i;14346:388::-;14454:4;14476:228;173:10;14526:7;14548:145;14605:15;14548:145;;;;;;;;;;;;;;;;;173:10;14548:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;14548:34:0;;;;;;;;;;;;:38;:145::i;11425:200::-;11531:4;11553:42;173:10;11577:9;11588:6;11553:9;:42::i;32312:136::-;7933:6;;-1:-1:-1;;;;;7933:6:0;173:10;7933:22;7925:68;;;;-1:-1:-1;;;7925:68:0;;;;;;;:::i;:::-;32400:18:::1;:40:::0;32312:136::o;31916:132::-;7933:6;;-1:-1:-1;;;;;7933:6:0;173:10;7933:22;7925:68;;;;-1:-1:-1;;;7925:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;32001:28:0;;;::::1;;::::0;;;:19:::1;:28;::::0;;;;:39;;-1:-1:-1;;32001:39:0::1;::::0;::::1;;::::0;;;::::1;::::0;;31916:132::o;32062:236::-;7933:6;;-1:-1:-1;;;;;7933:6:0;173:10;7933:22;7925:68;;;;-1:-1:-1;;;7925:68:0;;;;;;;:::i;:::-;32180:9:::1;32175:116;32195:19:::0;;::::1;32175:116;;;32271:8;32236:19;:32;32256:8;;32265:1;32256:11;;;;;;;:::i;:::-;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;;;;32236:32:0::1;::::0;;::::1;::::0;::::1;::::0;;;;;;-1:-1:-1;32236:32:0;:43;;-1:-1:-1;;32236:43:0::1;::::0;::::1;;::::0;;;::::1;::::0;;32216:3;::::1;::::0;::::1;:::i;:::-;;;;32175:116;;;;32062:236:::0;;;:::o;32607:117::-;7933:6;;-1:-1:-1;;;;;7933:6:0;173:10;7933:22;7925:68;;;;-1:-1:-1;;;7925:68:0;;;;;;;:::i;:::-;32684:21:::1;:32:::0;;-1:-1:-1;;32684:32:0::1;::::0;::::1;;::::0;;;::::1;::::0;;32607:117::o;33022:279::-;7933:6;;-1:-1:-1;;;;;7933:6:0;173:10;7933:22;7925:68;;;;-1:-1:-1;;;7925:68:0;;;;;;;:::i;:::-;33119:11:::1;::::0;33141:5:::1;::::0;33103:62:::1;::::0;-1:-1:-1;;;;;33119:11:0::1;::::0;33132:7;;33141:23:::1;::::0;33151:12:::1;33141:9;:23::i;:::-;33103:15;:62::i;:::-;33197:11;:21:::0;;-1:-1:-1;;;;;;33197:21:0::1;-1:-1:-1::0;;;;;33197:21:0;::::1;;::::0;;33258:30:::1;33197:21:::0;-1:-1:-1;33258:15:0::1;:30::i;:::-;33022:279:::0;:::o;8667:281::-;7933:6;;-1:-1:-1;;;;;7933:6:0;173:10;7933:22;7925:68;;;;-1:-1:-1;;;7925:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;8770:22:0;::::1;8748:110;;;::::0;-1:-1:-1;;;8748:110:0;;7142:2:1;8748:110:0::1;::::0;::::1;7124:21:1::0;7181:2;7161:18;;;7154:30;7220:34;7200:18;;;7193:62;-1:-1:-1;;;7271:18:1;;;7264:36;7317:19;;8748:110:0::1;6940:402:1::0;8748:110:0::1;8895:6;::::0;;8874:38:::1;::::0;-1:-1:-1;;;;;8874:38:0;;::::1;::::0;8895:6;::::1;::::0;8874:38:::1;::::0;::::1;8923:6;:17:::0;;-1:-1:-1;;;;;;8923:17:0::1;-1:-1:-1::0;;;;;8923:17:0;;;::::1;::::0;;;::::1;::::0;;8667:281::o;20888:471::-;20946:7;21191:1;21196;21191:6;21187:47;;-1:-1:-1;21221:1:0;21214:8;;21187:47;21246:9;21258:5;21262:1;21258;:5;:::i;:::-;21246:17;-1:-1:-1;21291:1:0;21282:5;21286:1;21246:17;21282:5;:::i;:::-;:10;21274:56;;;;-1:-1:-1;;;21274:56:0;;7979:2:1;21274:56:0;;;7961:21:1;8018:2;7998:18;;;7991:30;8057:34;8037:18;;;8030:62;-1:-1:-1;;;8108:18:1;;;8101:31;8149:19;;21274:56:0;7777:397:1;21835:132:0;21893:7;21920:39;21924:1;21927;21920:39;;;;;;;;;;;;;;;;;:3;:39::i;19500:181::-;19558:7;;19590:5;19594:1;19590;:5;:::i;:::-;19578:17;;19619:1;19614;:6;;19606:46;;;;-1:-1:-1;;;19606:46:0;;8511:2:1;19606:46:0;;;8493:21:1;8550:2;8530:18;;;8523:30;8589:29;8569:18;;;8562:57;8636:18;;19606:46:0;8309:351:1;18120:380:0;-1:-1:-1;;;;;18256:19:0;;18248:68;;;;-1:-1:-1;;;18248:68:0;;8867:2:1;18248:68:0;;;8849:21:1;8906:2;8886:18;;;8879:30;8945:34;8925:18;;;8918:62;-1:-1:-1;;;8996:18:1;;;8989:34;9040:19;;18248:68:0;8665:400:1;18248:68:0;-1:-1:-1;;;;;18335:21:0;;18327:68;;;;-1:-1:-1;;;18327:68:0;;9272:2:1;18327:68:0;;;9254:21:1;9311:2;9291:18;;;9284:30;9350:34;9330:18;;;9323:62;-1:-1:-1;;;9401:18:1;;;9394:32;9443:19;;18327:68:0;9070:398:1;18327:68:0;-1:-1:-1;;;;;18408:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;18460:32;;1596:25:1;;;18460:32:0;;1569:18:1;18460:32:0;;;;;;;;18120:380;;;:::o;33314:2596::-;-1:-1:-1;;;;;33446:18:0;;33438:68;;;;-1:-1:-1;;;33438:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;33525:16:0;;33517:64;;;;-1:-1:-1;;;33517:64:0;;;;;;;:::i;:::-;33607:1;33600:6;:8;33592:17;;;;;;-1:-1:-1;;;;;33619:28:0;;;;;;:22;:28;;;;;;;;;:58;;-1:-1:-1;;;;;;33651:26:0;;;;;;:22;:26;;;;;;;;33619:58;33616:143;;;33693:33;33709:4;33715:2;33719:6;33693:15;:33::i;:::-;33314:2596;;;:::o;33616:143::-;33800:13;;33767;;-1:-1:-1;;;;;33800:13:0;;;33794:19;;;;33791:85;;33840:19;:17;:19::i;:::-;33829:30;;33791:85;33883:9;;:14;:47;;;;-1:-1:-1;33911:13:0;;-1:-1:-1;;;;;33911:13:0;11154:7;11186:18;;;:9;:18;;;;;;33901:29;33883:47;:70;;;;-1:-1:-1;33940:13:0;;-1:-1:-1;;;;;33934:19:0;;;33940:13;;33934:19;33883:70;33880:156;;;33985:11;;-1:-1:-1;;;;;33977:19:0;;;33985:11;;33977:19;33969:28;;;;;;34015:15;34003:9;:27;33880:156;34080:18;;34071:4;11154:7;11186:18;;;:9;:18;;;;;;34053:45;34050:422;;;34137:8;;-1:-1:-1;;;34137:8:0;;;;34136:9;:49;;;;-1:-1:-1;34166:11:0;;-1:-1:-1;;;;;34166:19:0;;;:11;;:19;;34136:49;:87;;;;-1:-1:-1;34206:11:0;;-1:-1:-1;;;;;34206:17:0;;;:11;;:17;;34136:87;:129;;;;-1:-1:-1;34252:13:0;;-1:-1:-1;;;;;34244:21:0;;;34252:13;;34244:21;;34136:129;:171;;;;-1:-1:-1;34286:21:0;;;;34136:171;:189;;;;;34317:8;34316:9;34136:189;34114:347;;;34360:8;:15;;-1:-1:-1;;;;34360:15:0;-1:-1:-1;;;34360:15:0;;;34394:16;:14;:16::i;:::-;34429:8;:16;;-1:-1:-1;;;;34429:16:0;;;34114:347;34502:8;;-1:-1:-1;;;;;34525:25:0;;34486:12;34525:25;;;:19;:25;;;;;;34502:8;-1:-1:-1;;;34502:8:0;;;;;34501:9;;34525:25;;:52;;-1:-1:-1;;;;;;34554:23:0;;;;;;:19;:23;;;;;;;;34525:52;34521:603;;;-1:-1:-1;34604:5:0;34521:603;;;34642:13;;-1:-1:-1;;;;;34642:13:0;;;34634:21;;;;34631:482;;34678:9;;34699:15;;34678:18;;34692:3;34678:13;:18::i;:::-;:36;34675:86;;;34732:27;:6;34743:15;34732:10;:27::i;:::-;34723:36;;34675:86;34785:9;;34806:15;;34785:18;;34799:3;34785:13;:18::i;:::-;:36;34782:108;;;34860:14;34831:25;34849:6;34831:13;34841:2;-1:-1:-1;;;;;11186:18:0;11154:7;11186:18;;;:9;:18;;;;;;;11055:157;34831:13;:17;;:25::i;:::-;:43;;34823:65;;;;-1:-1:-1;;;34823:65:0;;10485:2:1;34823:65:0;;;10467:21:1;10524:2;10504:18;;;10497:30;-1:-1:-1;;;10543:18:1;;;10536:40;10593:18;;34823:65:0;10283:334:1;34823:65:0;34631:482;;;34916:13;;-1:-1:-1;;;;;34910:19:0;;;34916:13;;34907:206;;;34969:9;;34990:15;;34969:18;;34983:3;34969:13;:18::i;:::-;:36;34966:108;;;35044:14;35015:25;35033:6;35015:13;35025:2;-1:-1:-1;;;;;11186:18:0;11154:7;11186:18;;;:9;:18;;;;;;;11055:157;35015:25;:43;;35007:65;;;;-1:-1:-1;;;35007:65:0;;10485:2:1;35007:65:0;;;10467:21:1;10524:2;10504:18;;;10497:30;-1:-1:-1;;;10543:18:1;;;10536:40;10593:18;;35007:65:0;10283:334:1;35007:65:0;35140:7;35136:607;;;35171:13;;-1:-1:-1;;;;;35171:13:0;;;35163:21;;;;35160:572;;35217:60;35233:4;35247;35254:22;35274:1;35254:15;:6;35265:3;35254:10;:15::i;:::-;:19;;:22::i;35217:60::-;35302:52;35323:30;35347:5;35323:19;:6;35334:7;35323:10;:19::i;:30::-;35302:16;;;:20;:52::i;:::-;35283:16;:71;35360:38;35378:19;:6;35389:7;35378:10;:19::i;:::-;35360:17;:38::i;:::-;35413:23;35433:2;35413:15;:6;35424:3;35413:10;:15::i;:23::-;35404:32;;35160:572;;;35457:13;;-1:-1:-1;;;;;35457:13:0;;;35451:19;;;;35448:284;;35492:60;35508:4;35522;35529:22;35549:1;35529:15;:6;35540:3;35529:10;:15::i;35492:60::-;35558:38;35576:19;:6;35587:7;35576:10;:19::i;35558:38::-;35621:52;35642:30;35666:5;35642:19;:6;35653:7;35642:10;:19::i;35621:52::-;35602:16;:71;35688:23;35708:2;35688:15;:6;35699:3;35688:10;:15::i;:23::-;35679:32;;35448:284;35756:33;35772:4;35778:2;35782:6;35756:15;:33::i;:::-;35813:13;;-1:-1:-1;;;;;35807:19:0;;;35813:13;;35807:19;:38;;;;-1:-1:-1;;;;;;35831:14:0;;;;;;:8;:14;;;;;;;;35830:15;35807:38;35804:99;;;-1:-1:-1;;;;;35852:14:0;;;;;;:8;:14;;;;;:21;;-1:-1:-1;;35852:21:0;35869:4;35852:21;;;;;;35879:7;:18;;;;;;;;;;;;;;-1:-1:-1;;;;;;35879:18:0;;;;;;35804:99;33427:2483;;33314:2596;;;:::o;20403:226::-;20523:7;20559:12;20551:6;;;;20543:29;;;;-1:-1:-1;;;20543:29:0;;;;;;;;:::i;:::-;-1:-1:-1;20583:9:0;20595:5;20599:1;20595;:5;:::i;:::-;20583:17;20403:226;-1:-1:-1;;;;;20403:226:0:o;19964:136::-;20022:7;20049:43;20053:1;20056;20049:43;;;;;;;;;;;;;;;;;:3;:43::i;15224:336::-;-1:-1:-1;;;;;15364:20:0;;15356:70;;;;-1:-1:-1;;;15356:70:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;15445:23:0;;15437:71;;;;-1:-1:-1;;;15437:71:0;;;;;;;:::i;:::-;15513:39;15528:6;15535:9;15545:6;15513:14;:39::i;22463:312::-;22583:7;22618:12;22611:5;22603:28;;;;-1:-1:-1;;;22603:28:0;;;;;;;;:::i;:::-;-1:-1:-1;22642:9:0;22654:5;22658:1;22654;:5;:::i;37513:677::-;37563:11;37588:14;37628:13;;;;;;;;;-1:-1:-1;;;;;37628:13:0;-1:-1:-1;;;;;37605:45:0;;:47;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;37588:64;;37663:14;37703:13;;;;;;;;;-1:-1:-1;;;;;37703:13:0;-1:-1:-1;;;;;37680:45:0;;:47;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;37663:64;;37739:7;37747;37782:13;;;;;;;;;-1:-1:-1;;;;;37782:13:0;-1:-1:-1;;;;;37759:50:0;;:52;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1;37867:13:0;;37834:48;;-1:-1:-1;;;37834:48:0;;-1:-1:-1;;;;;37867:13:0;;;37834:48;;;1388:51:1;-1:-1:-1;;;;;37738:73:0;;;;-1:-1:-1;37738:73:0;;;;;-1:-1:-1;37822:9:0;;37834:24;;;;;1361:18:1;;37834:48:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;37938:13;;37905:48;;-1:-1:-1;;;37905:48:0;;-1:-1:-1;;;;;37938:13:0;;;37905:48;;;1388:51:1;37822:60:0;;-1:-1:-1;37893:9:0;;37905:24;;;;;;1361:18:1;;37905:48:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;37893:60;-1:-1:-1;37986:4:0;-1:-1:-1;;;;;37968:23:0;;;37964:219;;38010:2;38003:4;:9;37999:82;;;38020:12;38035:9;38042:2;38035:4;:9;:::i;:::-;38070:4;-1:-1:-1;38060:14:0;-1:-1:-1;;37999:82:0;37964:219;;;38107:2;38100:4;:9;38096:82;;;38117:12;38132:9;38139:2;38132:4;:9;:::i;:::-;38167:4;-1:-1:-1;38157:14:0;-1:-1:-1;;38096:82:0;37575:615;;;;;;37513:677;:::o;36315:335::-;36392:4;36354:17;11186:18;;;:9;:18;;;;;;36445:20;;36424:16;;11186:18;;36354:17;36424:42;;:20;:42::i;:::-;36403:63;;36484:6;36474:9;:16;:39;;;;;36507:6;36494:10;:19;36474:39;36471:172;;;36543:20;;:36;;36568:10;36543:24;:36::i;:::-;36520:20;:59;36585:30;36604:10;36585:18;:30::i;:::-;36631:7;;36315:335::o;36000:309::-;36078:17;;36106:196;36130:1;36126;:5;36106:196;;;36180:5;;36173:12;;-1:-1:-1;;;;;36180:5:0;-1:-1:-1;;36173:12:0;:::i;:::-;36209:5;;36153:33;;-1:-1:-1;36209:7:0;;-1:-1:-1;;;;;36209:5:0;;:7;:::i;:::-;36201:5;:15;;-1:-1:-1;;;;;;36201:15:0;-1:-1:-1;;;;;36201:15:0;;;;;;;;;;36231:59;36255:4;36262:9;36273:16;36284:4;:1;36286:2;36284:4;:::i;:::-;36273:6;;:10;:16::i;36231:59::-;36133:3;;;;:::i;:::-;;;;36106:196;;15572:311;-1:-1:-1;;;;;15729:17:0;;;;;;:9;:17;;;;;;:29;;15751:6;15729:21;:29::i;:::-;-1:-1:-1;;;;;15709:17:0;;;;;;;:9;:17;;;;;;:49;;;;15792:20;;;;;;;:32;;15817:6;15792:24;:32::i;:::-;-1:-1:-1;;;;;15769:20:0;;;;;;;:9;:20;;;;;;;:55;;;;15840:35;;;;;;;;;;15868:6;1596:25:1;;1584:2;1569:18;;1450:177;36658:460:0;36745:16;;;36759:1;36745:16;;;;;;;;;36721:21;;36745:16;;;;;;;;;;-1:-1:-1;36745:16:0;36721:40;;36790:4;36772;36777:1;36772:7;;;;;;;;:::i;:::-;-1:-1:-1;;;;;36772:23:0;;;:7;;;;;;;;;:23;36824:10;;36806:7;;36824:10;;;36806:4;;36824:10;;36806:7;;;;;;:::i;:::-;;;;;;:29;-1:-1:-1;;;;;36806:29:0;;;-1:-1:-1;;;;;36806:29:0;;;;;36858:42;36840:4;36845:1;36840:7;;;;;;;;:::i;:::-;-1:-1:-1;;;;;36840:61:0;;;:7;;;;;;;;;:61;36912:15;;37057:12;;36912:198;;-1:-1:-1;;;36912:198:0;;:15;;;;:69;;:198;;36996:11;;36912:15;;37038:4;;37057:12;;;;37084:15;;36912:198;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;36716:402;36658:460;:::o;14:548:1:-;126:4;155:2;184;173:9;166:21;216:6;210:13;259:6;254:2;243:9;239:18;232:34;284:1;294:140;308:6;305:1;302:13;294:140;;;403:14;;;399:23;;393:30;369:17;;;388:2;365:26;358:66;323:10;;294:140;;;298:3;483:1;478:2;469:6;458:9;454:22;450:31;443:42;553:2;546;542:7;537:2;529:6;525:15;521:29;510:9;506:45;502:54;494:62;;;;14:548;;;;:::o;567:131::-;-1:-1:-1;;;;;642:31:1;;632:42;;622:70;;688:1;685;678:12;703:315;771:6;779;832:2;820:9;811:7;807:23;803:32;800:52;;;848:1;845;838:12;800:52;887:9;874:23;906:31;931:5;906:31;:::i;:::-;956:5;1008:2;993:18;;;;980:32;;-1:-1:-1;;;703:315:1:o;1632:456::-;1709:6;1717;1725;1778:2;1766:9;1757:7;1753:23;1749:32;1746:52;;;1794:1;1791;1784:12;1746:52;1833:9;1820:23;1852:31;1877:5;1852:31;:::i;:::-;1902:5;-1:-1:-1;1959:2:1;1944:18;;1931:32;1972:33;1931:32;1972:33;:::i;:::-;1632:456;;2024:7;;-1:-1:-1;;;2078:2:1;2063:18;;;;2050:32;;1632:456::o;2282:247::-;2341:6;2394:2;2382:9;2373:7;2369:23;2365:32;2362:52;;;2410:1;2407;2400:12;2362:52;2449:9;2436:23;2468:31;2493:5;2468:31;:::i;3172:180::-;3231:6;3284:2;3272:9;3263:7;3259:23;3255:32;3252:52;;;3300:1;3297;3290:12;3252:52;-1:-1:-1;3323:23:1;;3172:180;-1:-1:-1;3172:180:1:o;3357:118::-;3443:5;3436:13;3429:21;3422:5;3419:32;3409:60;;3465:1;3462;3455:12;3480:382;3545:6;3553;3606:2;3594:9;3585:7;3581:23;3577:32;3574:52;;;3622:1;3619;3612:12;3574:52;3661:9;3648:23;3680:31;3705:5;3680:31;:::i;:::-;3730:5;-1:-1:-1;3787:2:1;3772:18;;3759:32;3800:30;3759:32;3800:30;:::i;:::-;3849:7;3839:17;;;3480:382;;;;;:::o;3867:750::-;3959:6;3967;3975;4028:2;4016:9;4007:7;4003:23;3999:32;3996:52;;;4044:1;4041;4034:12;3996:52;4084:9;4071:23;4113:18;4154:2;4146:6;4143:14;4140:34;;;4170:1;4167;4160:12;4140:34;4208:6;4197:9;4193:22;4183:32;;4253:7;4246:4;4242:2;4238:13;4234:27;4224:55;;4275:1;4272;4265:12;4224:55;4315:2;4302:16;4341:2;4333:6;4330:14;4327:34;;;4357:1;4354;4347:12;4327:34;4412:7;4405:4;4395:6;4392:1;4388:14;4384:2;4380:23;4376:34;4373:47;4370:67;;;4433:1;4430;4423:12;4370:67;4464:4;4456:13;;;;-1:-1:-1;4488:6:1;-1:-1:-1;;4529:20:1;;4516:34;4559:28;4516:34;4559:28;:::i;:::-;4606:5;4596:15;;;3867:750;;;;;:::o;4622:241::-;4678:6;4731:2;4719:9;4710:7;4706:23;4702:32;4699:52;;;4747:1;4744;4737:12;4699:52;4786:9;4773:23;4805:28;4827:5;4805:28;:::i;4868:388::-;4936:6;4944;4997:2;4985:9;4976:7;4972:23;4968:32;4965:52;;;5013:1;5010;5003:12;4965:52;5052:9;5039:23;5071:31;5096:5;5071:31;:::i;:::-;5121:5;-1:-1:-1;5178:2:1;5163:18;;5150:32;5191:33;5150:32;5191:33;:::i;5261:380::-;5340:1;5336:12;;;;5383;;;5404:61;;5458:4;5450:6;5446:17;5436:27;;5404:61;5511:2;5503:6;5500:14;5480:18;5477:38;5474:161;;5557:10;5552:3;5548:20;5545:1;5538:31;5592:4;5589:1;5582:15;5620:4;5617:1;5610:15;5474:161;;5261:380;;;:::o;5925:245::-;5992:6;6045:2;6033:9;6024:7;6020:23;6016:32;6013:52;;;6061:1;6058;6051:12;6013:52;6093:9;6087:16;6112:28;6134:5;6112:28;:::i;6175:356::-;6377:2;6359:21;;;6396:18;;;6389:30;6455:34;6450:2;6435:18;;6428:62;6522:2;6507:18;;6175:356::o;6536:127::-;6597:10;6592:3;6588:20;6585:1;6578:31;6628:4;6625:1;6618:15;6652:4;6649:1;6642:15;6668:127;6729:10;6724:3;6720:20;6717:1;6710:31;6760:4;6757:1;6750:15;6784:4;6781:1;6774:15;6800:135;6839:3;6860:17;;;6857:43;;6880:18;;:::i;:::-;-1:-1:-1;6927:1:1;6916:13;;6800:135::o;7347:168::-;7420:9;;;7451;;7468:15;;;7462:22;;7448:37;7438:71;;7489:18;;:::i;7520:127::-;7581:10;7576:3;7572:20;7569:1;7562:31;7612:4;7609:1;7602:15;7636:4;7633:1;7626:15;7652:120;7692:1;7718;7708:35;;7723:18;;:::i;:::-;-1:-1:-1;7757:9:1;;7652:120::o;8179:125::-;8244:9;;;8265:10;;;8262:36;;;8278:18;;:::i;9473:401::-;9675:2;9657:21;;;9714:2;9694:18;;;9687:30;9753:34;9748:2;9733:18;;9726:62;-1:-1:-1;;;9819:2:1;9804:18;;9797:35;9864:3;9849:19;;9473:401::o;9879:399::-;10081:2;10063:21;;;10120:2;10100:18;;;10093:30;10159:34;10154:2;10139:18;;10132:62;-1:-1:-1;;;10225:2:1;10210:18;;10203:33;10268:3;10253:19;;9879:399::o;10622:128::-;10689:9;;;10710:11;;;10707:37;;;10724:18;;:::i;10755:251::-;10825:6;10878:2;10866:9;10857:7;10853:23;10849:32;10846:52;;;10894:1;10891;10884:12;10846:52;10926:9;10920:16;10945:31;10970:5;10945:31;:::i;11011:188::-;11090:13;;-1:-1:-1;;;;;11132:42:1;;11122:53;;11112:81;;11189:1;11186;11179:12;11112:81;11011:188;;;:::o;11204:450::-;11291:6;11299;11307;11360:2;11348:9;11339:7;11335:23;11331:32;11328:52;;;11376:1;11373;11366:12;11328:52;11399:40;11429:9;11399:40;:::i;:::-;11389:50;;11458:49;11503:2;11492:9;11488:18;11458:49;:::i;:::-;11448:59;;11550:2;11539:9;11535:18;11529:25;11594:10;11587:5;11583:22;11576:5;11573:33;11563:61;;11620:1;11617;11610:12;11659:184;11729:6;11782:2;11770:9;11761:7;11757:23;11753:32;11750:52;;;11798:1;11795;11788:12;11750:52;-1:-1:-1;11821:16:1;;11659:184;-1:-1:-1;11659:184:1:o;11848:201::-;11888:1;-1:-1:-1;;;;;11953:10:1;;;;11972:37;;11989:18;;:::i;:::-;12027:10;;12023:20;;;;;11848:201;-1:-1:-1;;11848:201:1:o;12054:182::-;-1:-1:-1;;;;;12161:10:1;;;12173;;;12157:27;;12196:11;;;12193:37;;;12210:18;;:::i;:::-;12193:37;12054:182;;;;:::o;12373:980::-;12635:4;12683:3;12672:9;12668:19;12714:6;12703:9;12696:25;12740:2;12778:6;12773:2;12762:9;12758:18;12751:34;12821:3;12816:2;12805:9;12801:18;12794:31;12845:6;12880;12874:13;12911:6;12903;12896:22;12949:3;12938:9;12934:19;12927:26;;12988:2;12980:6;12976:15;12962:29;;13009:1;13019:195;13033:6;13030:1;13027:13;13019:195;;;13098:13;;-1:-1:-1;;;;;13094:39:1;13082:52;;13189:15;;;;13154:12;;;;13130:1;13048:9;13019:195;;;-1:-1:-1;;;;;;;13270:32:1;;;;13265:2;13250:18;;13243:60;-1:-1:-1;;;13334:3:1;13319:19;13312:35;13231:3;12373:980;-1:-1:-1;;;12373:980:1:o

Swarm Source

ipfs://162737dd5a56416ff1881173eff5df4d27014fd580f8825e7e7cfd1daf2eb16e
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.