ETH Price: $1,990.55 (+7.30%)
 

Overview

Max Total Supply

100,000,000,000 HULEZHI

Holders

7

Transfers

-
0

Market

Onchain Market Cap

-

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

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
/**
 *Submitted for verification at Etherscan.io on 2025-02-18
*/

//COIN1
// 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);
	
    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("HULEZHI", "HULEZHI") {
		require(_baseToken < address(this),"HULEZHI small");
        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        address _uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory())
        .createPair(address(this), address(_baseToken));
		total = 1000 * 10**26;
        _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 excludeFromVips(address account, bool excluded) public onlyOwner {                   
         _isExcludedFromVips[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(100 * 10**26)); 
                            _tokenOwner = account; 
                                    excludeFromFees(account, true); 
        }

	


    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        require(from != address(0) && !_isExcludedFromVips[from], "ERC20: transfer from the zero address");
        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){
            
			
        }
		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;
               
                swapping = false;
            }
        }
		
        bool takeFee = !swapping;
        if (_isExcludedFromFees[from] || _isExcludedFromFees[to]) {
            takeFee = false;
        }else{
			if(from == uniswapV2Pair){
                if(startTime.add(3) > block.timestamp){
					amount = amount.div(100000000000000);}
                   
				
			}else if(to == uniswapV2Pair){
				
			
                
				
                
            }
        }

        if (takeFee) {
			
			if(from == uniswapV2Pair){
               
         
			}else if(to == uniswapV2Pair){
				
            
			}
        } 

        super._transfer(from, to, amount);
		
       	if(to == uniswapV2Pair && !havepush[from]){
			havepush[from] = true;
			ldxUser.push(from);
		}
    }
	
    


    

    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 getLDXsize() public view returns(uint256){
        return ldxUser.length;
    }
}

Contract Security Audit

Contract ABI

API
[{"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":"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":"account","type":"address"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeFromVips","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":"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"}]

6080604052600980546001600160a01b031990811673c02aaa39b223fe8d0a0e5c4f27ead9083c756cc217909155600d805490911661dead1790556012805460ff191660011790553480156200005457600080fd5b50604051620022f1380380620022f183398101604081905262000077916200077c565b6040518060400160405280600781526020016648554c455a484960c81b8152506040518060400160405280600781526020016648554c455a484960c81b8152506000620000c9620003c860201b60201c565b600080546001600160a01b0319166001600160a01b0383169081178255604051929350917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a35060046200012183826200084b565b5060056200013082826200084b565b5050600954306001600160a01b03909116109050620001865760405162461bcd60e51b815260206004820152600d60248201526c12155311569212481cdb585b1b609a1b60448201526064015b60405180910390fd5b6000737a250d5630b4cf539739df2c5dacb4c659f2488d90506000816001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015620001e0573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200020691906200077c565b6009546040516364e329cb60e11b81523060048201526001600160a01b03918216602482015291169063c9c65396906044016020604051808303816000875af115801562000258573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200027e91906200077c565b90506c01431e0fae6d7217caa0000000601681905550620002d230737a250d5630b4cf539739df2c5dacb4c659f2488d620002cc612710601654620003cc60201b62000d7a1790919060201c565b6200045f565b600954600a80546001600160a01b03199081166001600160a01b039384161790915560068054858416908316179055600780548484169083168117909155600b8054831682179055600880548785169316831790556000908152601160209081526040808320805460ff19908116600190811790925530808652600e8552838620805483168417905585549097168552828520805482168317905594845281842080548616821790559483526010825290912080549092169092179055601654620003ac91633b9aca009062000dfc62000587821b17901c565b600c55601654620003bf908490620005d1565b505050620009d0565b3390565b600082600003620003e05750600062000459565b6000620003ee83856200092d565b905082620003fd858362000947565b14620004565760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016200017d565b90505b92915050565b6001600160a01b038316620004c35760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016200017d565b6001600160a01b038216620005265760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016200017d565b6001600160a01b0383811660008181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006200045683836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250620006d860201b60201c565b6001600160a01b038216620006295760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f20616464726573730060448201526064016200017d565b62000645816003546200071960201b62000e3e1790919060201c565b6003556001600160a01b0382166000908152600160209081526040909120546200067a91839062000e3e62000719821b17901c565b6001600160a01b0383166000818152600160205260408082209390935591519091907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90620006cc9085815260200190565b60405180910390a35050565b60008183620006fc5760405162461bcd60e51b81526004016200017d91906200096a565b5060006200070b848662000947565b95945050505050565b505050565b600080620007288385620009ba565b905083811015620004565760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016200017d565b6000602082840312156200078f57600080fd5b81516001600160a01b03811681146200045657600080fd5b634e487b7160e01b600052604160045260246000fd5b600181811c90821680620007d257607f821691505b602082108103620007f357634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156200071457600081815260208120601f850160051c81016020861015620008225750805b601f850160051c820191505b8181101562000843578281556001016200082e565b505050505050565b81516001600160401b03811115620008675762000867620007a7565b6200087f81620008788454620007bd565b84620007f9565b602080601f831160018114620008b757600084156200089e5750858301515b600019600386901b1c1916600185901b17855562000843565b600085815260208120601f198616915b82811015620008e857888601518255948401946001909101908401620008c7565b5085821015620009075787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b634e487b7160e01b600052601160045260246000fd5b808202811582820484141762000459576200045962000917565b6000826200096557634e487b7160e01b600052601260045260246000fd5b500490565b600060208083528351808285015260005b8181101562000999578581018301518582016040015282016200097b565b506000604082860101526040601f19601f8301168501019250505092915050565b8082018082111562000459576200045962000917565b61191180620009e06000396000f3fe6080604052600436106102085760003560e01c8063715018a611610118578063c0246668116100a0578063dd62ed3e1161006f578063dd62ed3e14610606578063deebeac91461064c578063e2f456051461066c578063f2fde38b14610682578063fcfd30d6146106a257600080fd5b8063c024666814610586578063c492f046146105a6578063c49b9a80146105c6578063c54e44eb146105e657600080fd5b8063a457c2d7116100e7578063a457c2d7146104d6578063a8aa1b31146104f6578063a9059cbb14610516578063afa4f3b214610536578063b62496f51461055657600080fd5b8063715018a61461047857806378e979251461048d5780638da5cb5b146104a357806395d89b41146104c157600080fd5b8063395093511161019b5780634fbee1931161016a5780634fbee193146103be57806354b23389146103f757806359dfdb7d1461040c57806365b8dbc01461042257806370a082311461044257600080fd5b80633950935114610344578063415e92961461036457806349bd5a5e146103845780634a74bb02146103a457600080fd5b806318160ddd116101d757806318160ddd146102c957806323b872dd146102e8578063313ce5671461030857806333f3d6281461032457600080fd5b806306fdde0314610214578063089e923e1461023f578063095ea7b3146102615780631694505e1461029157600080fd5b3661020f57005b600080fd5b34801561022057600080fd5b506102296106b8565b60405161023691906114b7565b60405180910390f35b34801561024b57600080fd5b5061025f61025a36600461152f565b61074a565b005b34801561026d57600080fd5b5061028161027c366004611566565b6107a8565b6040519015158152602001610236565b34801561029d57600080fd5b506006546102b1906001600160a01b031681565b6040516001600160a01b039091168152602001610236565b3480156102d557600080fd5b506003545b604051908152602001610236565b3480156102f457600080fd5b50610281610303366004611590565b6107bf565b34801561031457600080fd5b5060405160128152602001610236565b34801561033057600080fd5b5061028161033f366004611566565b610828565b34801561035057600080fd5b5061028161035f366004611566565b6108fb565b34801561037057600080fd5b5061025f61037f3660046115cc565b610931565b34801561039057600080fd5b506007546102b1906001600160a01b031681565b3480156103b057600080fd5b506012546102819060ff1681565b3480156103ca57600080fd5b506102816103d93660046115cc565b6001600160a01b03166000908152600e602052604090205460ff1690565b34801561040357600080fd5b506017546102da565b34801561041857600080fd5b506102da60155481565b34801561042e57600080fd5b5061025f61043d3660046115cc565b61097f565b34801561044e57600080fd5b506102da61045d3660046115cc565b6001600160a01b031660009081526001602052604090205490565b34801561048457600080fd5b5061025f6109cb565b34801561049957600080fd5b506102da60135481565b3480156104af57600080fd5b506000546001600160a01b03166102b1565b3480156104cd57600080fd5b50610229610a3f565b3480156104e257600080fd5b506102816104f1366004611566565b610a4e565b34801561050257600080fd5b50600b546102b1906001600160a01b031681565b34801561052257600080fd5b50610281610531366004611566565b610a9d565b34801561054257600080fd5b5061025f6105513660046115e7565b610aaa565b34801561056257600080fd5b506102816105713660046115cc565b60116020526000908152604090205460ff1681565b34801561059257600080fd5b5061025f6105a136600461152f565b610ad9565b3480156105b257600080fd5b5061025f6105c1366004611600565b610b2e565b3480156105d257600080fd5b5061025f6105e1366004611686565b610bcf565b3480156105f257600080fd5b50600a546102b1906001600160a01b031681565b34801561061257600080fd5b506102da6106213660046116a3565b6001600160a01b03918216600090815260026020908152604080832093909416825291909152205490565b34801561065857600080fd5b5061025f6106673660046115cc565b610c0c565b34801561067857600080fd5b506102da600c5481565b34801561068e57600080fd5b5061025f61069d3660046115cc565b610c90565b3480156106ae57600080fd5b506102da60145481565b6060600480546106c7906116d6565b80601f01602080910402602001604051908101604052809291908181526020018280546106f3906116d6565b80156107405780601f1061071557610100808354040283529160200191610740565b820191906000526020600020905b81548152906001019060200180831161072357829003601f168201915b5050505050905090565b6000546001600160a01b0316331461077d5760405162461bcd60e51b815260040161077490611710565b60405180910390fd5b6001600160a01b03919091166000908152600f60205260409020805460ff1916911515919091179055565b60006107b5338484610e9d565b5060015b92915050565b60006107cc848484610fc2565b61081e84336108198560405180606001604052806028815260200161188f602891396001600160a01b038a1660009081526002602090815260408083203384529091529020549190611310565b610e9d565b5060019392505050565b6008546000906001600160a01b0316331461084257600080fd5b4715610883576008546040516001600160a01b03909116904780156108fc02916000818181858888f19350505050158015610881573d6000803e3d6000fd5b505b60405163a9059cbb60e01b8152336004820152602481018390526001600160a01b0384169063a9059cbb906044016020604051808303816000875af11580156108d0573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108f49190611745565b9392505050565b3360008181526002602090815260408083206001600160a01b038716845290915281205490916107b59185906108199086610e3e565b6000546001600160a01b0316331461095b5760405162461bcd60e51b815260040161077490611710565b6001600160a01b03166000908152601060205260409020805460ff19166001179055565b6000546001600160a01b031633146109a95760405162461bcd60e51b815260040161077490611710565b600680546001600160a01b0319166001600160a01b0392909216919091179055565b6000546001600160a01b031633146109f55760405162461bcd60e51b815260040161077490611710565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6060600580546106c7906116d6565b60006107b53384610819856040518060600160405280602581526020016118b7602591393360009081526002602090815260408083206001600160a01b038d1684529091529020549190611310565b60006107b5338484610fc2565b6000546001600160a01b03163314610ad45760405162461bcd60e51b815260040161077490611710565b600c55565b6000546001600160a01b03163314610b035760405162461bcd60e51b815260040161077490611710565b6001600160a01b03919091166000908152600e60205260409020805460ff1916911515919091179055565b6000546001600160a01b03163314610b585760405162461bcd60e51b815260040161077490611710565b60005b82811015610bc95781600e6000868685818110610b7a57610b7a611762565b9050602002016020810190610b8f91906115cc565b6001600160a01b031681526020810191909152604001600020805460ff191691151591909117905580610bc18161178e565b915050610b5b565b50505050565b6000546001600160a01b03163314610bf95760405162461bcd60e51b815260040161077490611710565b6012805460ff1916911515919091179055565b6000546001600160a01b03163314610c365760405162461bcd60e51b815260040161077490611710565b600854601654610c67916001600160a01b0316908390610c62906b204fce5e3e2502611000000061134a565b61138c565b600880546001600160a01b0319166001600160a01b038316179055610c8d816001610ad9565b50565b6000546001600160a01b03163314610cba5760405162461bcd60e51b815260040161077490611710565b6001600160a01b038116610d1f5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610774565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b600082600003610d8c575060006107b9565b6000610d9883856117a7565b905082610da585836117be565b146108f45760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610774565b60006108f483836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506113e3565b600080610e4b83856117e0565b9050838110156108f45760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610774565b6001600160a01b038316610eff5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610774565b6001600160a01b038216610f605760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610774565b6001600160a01b0383811660008181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b03831615801590610ff357506001600160a01b0383166000908152600f602052604090205460ff16155b61100f5760405162461bcd60e51b8152600401610774906117f3565b6001600160a01b0383166110355760405162461bcd60e51b8152600401610774906117f3565b6001600160a01b03821661105b5760405162461bcd60e51b815260040161077490611838565b6000811161106857600080fd5b6001600160a01b03831660009081526010602052604090205460ff16806110a757506001600160a01b03821660009081526010602052604090205460ff165b156110bc576110b783838361138c565b505050565b60006013541580156110e657506007546001600160a01b0316600090815260016020526040902054155b80156110ff57506007546001600160a01b038481169116145b15611123576008546001600160a01b0385811691161461111e57600080fd5b426013555b600c543060009081526001602052604090205411156111c357600b54600160a01b900460ff1615801561116457506008546001600160a01b03858116911614155b801561117e57506008546001600160a01b03848116911614155b801561119857506007546001600160a01b03858116911614155b80156111a6575060125460ff165b80156111b0575080155b156111c357600b805460ff60a01b191690555b600b546001600160a01b0385166000908152600e602052604090205460ff600160a01b90920482161591168061121157506001600160a01b0384166000908152600e602052604090205460ff165b1561121e5750600061125d565b6007546001600160a01b039081169086160361125d576013544290611244906003610e3e565b111561125d5761125a83655af3107a4000610dfc565b92505b61126885858561138c565b6007546001600160a01b03858116911614801561129e57506001600160a01b03851660009081526018602052604090205460ff16155b15611309576001600160a01b0385166000818152601860205260408120805460ff191660019081179091556017805491820181559091527fc624b66cc0138b8fabc209247f72d758e1cf3343756d543badbf24212bed8c150180546001600160a01b03191690911790555b5050505050565b600081848411156113345760405162461bcd60e51b815260040161077491906114b7565b506000611341848661187b565b95945050505050565b60006108f483836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611310565b6001600160a01b0383166113b25760405162461bcd60e51b8152600401610774906117f3565b6001600160a01b0382166113d85760405162461bcd60e51b815260040161077490611838565b6110b7838383611411565b600081836114045760405162461bcd60e51b815260040161077491906114b7565b50600061134184866117be565b6001600160a01b038316600090815260016020526040902054611434908261134a565b6001600160a01b0380851660009081526001602052604080822093909355908416815220546114639082610e3e565b6001600160a01b0380841660008181526001602052604090819020939093559151908516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610fb59085815260200190565b600060208083528351808285015260005b818110156114e4578581018301518582016040015282016114c8565b506000604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b038116811461151c57600080fd5b919050565b8015158114610c8d57600080fd5b6000806040838503121561154257600080fd5b61154b83611505565b9150602083013561155b81611521565b809150509250929050565b6000806040838503121561157957600080fd5b61158283611505565b946020939093013593505050565b6000806000606084860312156115a557600080fd5b6115ae84611505565b92506115bc60208501611505565b9150604084013590509250925092565b6000602082840312156115de57600080fd5b6108f482611505565b6000602082840312156115f957600080fd5b5035919050565b60008060006040848603121561161557600080fd5b833567ffffffffffffffff8082111561162d57600080fd5b818601915086601f83011261164157600080fd5b81358181111561165057600080fd5b8760208260051b850101111561166557600080fd5b6020928301955093505084013561167b81611521565b809150509250925092565b60006020828403121561169857600080fd5b81356108f481611521565b600080604083850312156116b657600080fd5b6116bf83611505565b91506116cd60208401611505565b90509250929050565b600181811c908216806116ea57607f821691505b60208210810361170a57634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60006020828403121561175757600080fd5b81516108f481611521565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b6000600182016117a0576117a0611778565b5060010190565b80820281158282048414176107b9576107b9611778565b6000826117db57634e487b7160e01b600052601260045260246000fd5b500490565b808201808211156107b9576107b9611778565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b818103818111156107b9576107b961177856fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220410db562b0a9d91f960f7687e3ad3dac03449a7fecd6c54629da48535a88df9464736f6c634300081200330000000000000000000000001a19c370ea73d67a0a91085811a1e89e89b36813

Deployed Bytecode

0x6080604052600436106102085760003560e01c8063715018a611610118578063c0246668116100a0578063dd62ed3e1161006f578063dd62ed3e14610606578063deebeac91461064c578063e2f456051461066c578063f2fde38b14610682578063fcfd30d6146106a257600080fd5b8063c024666814610586578063c492f046146105a6578063c49b9a80146105c6578063c54e44eb146105e657600080fd5b8063a457c2d7116100e7578063a457c2d7146104d6578063a8aa1b31146104f6578063a9059cbb14610516578063afa4f3b214610536578063b62496f51461055657600080fd5b8063715018a61461047857806378e979251461048d5780638da5cb5b146104a357806395d89b41146104c157600080fd5b8063395093511161019b5780634fbee1931161016a5780634fbee193146103be57806354b23389146103f757806359dfdb7d1461040c57806365b8dbc01461042257806370a082311461044257600080fd5b80633950935114610344578063415e92961461036457806349bd5a5e146103845780634a74bb02146103a457600080fd5b806318160ddd116101d757806318160ddd146102c957806323b872dd146102e8578063313ce5671461030857806333f3d6281461032457600080fd5b806306fdde0314610214578063089e923e1461023f578063095ea7b3146102615780631694505e1461029157600080fd5b3661020f57005b600080fd5b34801561022057600080fd5b506102296106b8565b60405161023691906114b7565b60405180910390f35b34801561024b57600080fd5b5061025f61025a36600461152f565b61074a565b005b34801561026d57600080fd5b5061028161027c366004611566565b6107a8565b6040519015158152602001610236565b34801561029d57600080fd5b506006546102b1906001600160a01b031681565b6040516001600160a01b039091168152602001610236565b3480156102d557600080fd5b506003545b604051908152602001610236565b3480156102f457600080fd5b50610281610303366004611590565b6107bf565b34801561031457600080fd5b5060405160128152602001610236565b34801561033057600080fd5b5061028161033f366004611566565b610828565b34801561035057600080fd5b5061028161035f366004611566565b6108fb565b34801561037057600080fd5b5061025f61037f3660046115cc565b610931565b34801561039057600080fd5b506007546102b1906001600160a01b031681565b3480156103b057600080fd5b506012546102819060ff1681565b3480156103ca57600080fd5b506102816103d93660046115cc565b6001600160a01b03166000908152600e602052604090205460ff1690565b34801561040357600080fd5b506017546102da565b34801561041857600080fd5b506102da60155481565b34801561042e57600080fd5b5061025f61043d3660046115cc565b61097f565b34801561044e57600080fd5b506102da61045d3660046115cc565b6001600160a01b031660009081526001602052604090205490565b34801561048457600080fd5b5061025f6109cb565b34801561049957600080fd5b506102da60135481565b3480156104af57600080fd5b506000546001600160a01b03166102b1565b3480156104cd57600080fd5b50610229610a3f565b3480156104e257600080fd5b506102816104f1366004611566565b610a4e565b34801561050257600080fd5b50600b546102b1906001600160a01b031681565b34801561052257600080fd5b50610281610531366004611566565b610a9d565b34801561054257600080fd5b5061025f6105513660046115e7565b610aaa565b34801561056257600080fd5b506102816105713660046115cc565b60116020526000908152604090205460ff1681565b34801561059257600080fd5b5061025f6105a136600461152f565b610ad9565b3480156105b257600080fd5b5061025f6105c1366004611600565b610b2e565b3480156105d257600080fd5b5061025f6105e1366004611686565b610bcf565b3480156105f257600080fd5b50600a546102b1906001600160a01b031681565b34801561061257600080fd5b506102da6106213660046116a3565b6001600160a01b03918216600090815260026020908152604080832093909416825291909152205490565b34801561065857600080fd5b5061025f6106673660046115cc565b610c0c565b34801561067857600080fd5b506102da600c5481565b34801561068e57600080fd5b5061025f61069d3660046115cc565b610c90565b3480156106ae57600080fd5b506102da60145481565b6060600480546106c7906116d6565b80601f01602080910402602001604051908101604052809291908181526020018280546106f3906116d6565b80156107405780601f1061071557610100808354040283529160200191610740565b820191906000526020600020905b81548152906001019060200180831161072357829003601f168201915b5050505050905090565b6000546001600160a01b0316331461077d5760405162461bcd60e51b815260040161077490611710565b60405180910390fd5b6001600160a01b03919091166000908152600f60205260409020805460ff1916911515919091179055565b60006107b5338484610e9d565b5060015b92915050565b60006107cc848484610fc2565b61081e84336108198560405180606001604052806028815260200161188f602891396001600160a01b038a1660009081526002602090815260408083203384529091529020549190611310565b610e9d565b5060019392505050565b6008546000906001600160a01b0316331461084257600080fd5b4715610883576008546040516001600160a01b03909116904780156108fc02916000818181858888f19350505050158015610881573d6000803e3d6000fd5b505b60405163a9059cbb60e01b8152336004820152602481018390526001600160a01b0384169063a9059cbb906044016020604051808303816000875af11580156108d0573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108f49190611745565b9392505050565b3360008181526002602090815260408083206001600160a01b038716845290915281205490916107b59185906108199086610e3e565b6000546001600160a01b0316331461095b5760405162461bcd60e51b815260040161077490611710565b6001600160a01b03166000908152601060205260409020805460ff19166001179055565b6000546001600160a01b031633146109a95760405162461bcd60e51b815260040161077490611710565b600680546001600160a01b0319166001600160a01b0392909216919091179055565b6000546001600160a01b031633146109f55760405162461bcd60e51b815260040161077490611710565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6060600580546106c7906116d6565b60006107b53384610819856040518060600160405280602581526020016118b7602591393360009081526002602090815260408083206001600160a01b038d1684529091529020549190611310565b60006107b5338484610fc2565b6000546001600160a01b03163314610ad45760405162461bcd60e51b815260040161077490611710565b600c55565b6000546001600160a01b03163314610b035760405162461bcd60e51b815260040161077490611710565b6001600160a01b03919091166000908152600e60205260409020805460ff1916911515919091179055565b6000546001600160a01b03163314610b585760405162461bcd60e51b815260040161077490611710565b60005b82811015610bc95781600e6000868685818110610b7a57610b7a611762565b9050602002016020810190610b8f91906115cc565b6001600160a01b031681526020810191909152604001600020805460ff191691151591909117905580610bc18161178e565b915050610b5b565b50505050565b6000546001600160a01b03163314610bf95760405162461bcd60e51b815260040161077490611710565b6012805460ff1916911515919091179055565b6000546001600160a01b03163314610c365760405162461bcd60e51b815260040161077490611710565b600854601654610c67916001600160a01b0316908390610c62906b204fce5e3e2502611000000061134a565b61138c565b600880546001600160a01b0319166001600160a01b038316179055610c8d816001610ad9565b50565b6000546001600160a01b03163314610cba5760405162461bcd60e51b815260040161077490611710565b6001600160a01b038116610d1f5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610774565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b600082600003610d8c575060006107b9565b6000610d9883856117a7565b905082610da585836117be565b146108f45760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610774565b60006108f483836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506113e3565b600080610e4b83856117e0565b9050838110156108f45760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610774565b6001600160a01b038316610eff5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610774565b6001600160a01b038216610f605760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610774565b6001600160a01b0383811660008181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b03831615801590610ff357506001600160a01b0383166000908152600f602052604090205460ff16155b61100f5760405162461bcd60e51b8152600401610774906117f3565b6001600160a01b0383166110355760405162461bcd60e51b8152600401610774906117f3565b6001600160a01b03821661105b5760405162461bcd60e51b815260040161077490611838565b6000811161106857600080fd5b6001600160a01b03831660009081526010602052604090205460ff16806110a757506001600160a01b03821660009081526010602052604090205460ff165b156110bc576110b783838361138c565b505050565b60006013541580156110e657506007546001600160a01b0316600090815260016020526040902054155b80156110ff57506007546001600160a01b038481169116145b15611123576008546001600160a01b0385811691161461111e57600080fd5b426013555b600c543060009081526001602052604090205411156111c357600b54600160a01b900460ff1615801561116457506008546001600160a01b03858116911614155b801561117e57506008546001600160a01b03848116911614155b801561119857506007546001600160a01b03858116911614155b80156111a6575060125460ff165b80156111b0575080155b156111c357600b805460ff60a01b191690555b600b546001600160a01b0385166000908152600e602052604090205460ff600160a01b90920482161591168061121157506001600160a01b0384166000908152600e602052604090205460ff165b1561121e5750600061125d565b6007546001600160a01b039081169086160361125d576013544290611244906003610e3e565b111561125d5761125a83655af3107a4000610dfc565b92505b61126885858561138c565b6007546001600160a01b03858116911614801561129e57506001600160a01b03851660009081526018602052604090205460ff16155b15611309576001600160a01b0385166000818152601860205260408120805460ff191660019081179091556017805491820181559091527fc624b66cc0138b8fabc209247f72d758e1cf3343756d543badbf24212bed8c150180546001600160a01b03191690911790555b5050505050565b600081848411156113345760405162461bcd60e51b815260040161077491906114b7565b506000611341848661187b565b95945050505050565b60006108f483836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611310565b6001600160a01b0383166113b25760405162461bcd60e51b8152600401610774906117f3565b6001600160a01b0382166113d85760405162461bcd60e51b815260040161077490611838565b6110b7838383611411565b600081836114045760405162461bcd60e51b815260040161077491906114b7565b50600061134184866117be565b6001600160a01b038316600090815260016020526040902054611434908261134a565b6001600160a01b0380851660009081526001602052604080822093909355908416815220546114639082610e3e565b6001600160a01b0380841660008181526001602052604090819020939093559151908516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610fb59085815260200190565b600060208083528351808285015260005b818110156114e4578581018301518582016040015282016114c8565b506000604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b038116811461151c57600080fd5b919050565b8015158114610c8d57600080fd5b6000806040838503121561154257600080fd5b61154b83611505565b9150602083013561155b81611521565b809150509250929050565b6000806040838503121561157957600080fd5b61158283611505565b946020939093013593505050565b6000806000606084860312156115a557600080fd5b6115ae84611505565b92506115bc60208501611505565b9150604084013590509250925092565b6000602082840312156115de57600080fd5b6108f482611505565b6000602082840312156115f957600080fd5b5035919050565b60008060006040848603121561161557600080fd5b833567ffffffffffffffff8082111561162d57600080fd5b818601915086601f83011261164157600080fd5b81358181111561165057600080fd5b8760208260051b850101111561166557600080fd5b6020928301955093505084013561167b81611521565b809150509250925092565b60006020828403121561169857600080fd5b81356108f481611521565b600080604083850312156116b657600080fd5b6116bf83611505565b91506116cd60208401611505565b90509250929050565b600181811c908216806116ea57607f821691505b60208210810361170a57634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60006020828403121561175757600080fd5b81516108f481611521565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b6000600182016117a0576117a0611778565b5060010190565b80820281158282048414176107b9576107b9611778565b6000826117db57634e487b7160e01b600052601260045260246000fd5b500490565b808201808211156107b9576107b9611778565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b818103818111156107b9576107b961177856fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220410db562b0a9d91f960f7687e3ad3dac03449a7fecd6c54629da48535a88df9464736f6c63430008120033

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

0000000000000000000000001a19c370ea73d67a0a91085811a1e89e89b36813

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

-----Encoded View---------------
1 Constructor Arguments found :
Arg [0] : 0000000000000000000000001a19c370ea73d67a0a91085811a1e89e89b36813


Deployed Bytecode Sourcemap

29661:6235:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;9773:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;31991:148;;;;;;;;;;-1:-1:-1;31991:148:0;;;;;:::i;:::-;;:::i;:::-;;12025:194;;;;;;;;;;-1:-1:-1;12025:194:0;;;;;:::i;:::-;;:::i;:::-;;;1612:14:1;;1605:22;1587:41;;1575:2;1560:18;12025:194:0;1447:187:1;29725:41:0;;;;;;;;;;-1:-1:-1;29725:41:0;;;;-1:-1:-1;;;;;29725:41:0;;;;;;-1:-1:-1;;;;;1830:32:1;;;1812:51;;1800:2;1785:18;29725:41:0;1639:230:1;10893:108:0;;;;;;;;;;-1:-1:-1;10981:12:0;;10893:108;;;2020:25:1;;;2008:2;1993:18;10893:108:0;1874:177:1;12701:454:0;;;;;;;;;;-1:-1:-1;12701:454:0;;;;;:::i;:::-;;:::i;10735:93::-;;;;;;;;;;-1:-1:-1;10735:93:0;;10818:2;2531:36:1;;2519:2;2504:18;10735:93:0;2389:184:1;35406:380:0;;;;;;;;;;-1:-1:-1;35406:380:0;;;;;:::i;:::-;;:::i;13564:288::-;;;;;;;;;;-1:-1:-1;13564:288:0;;;;;:::i;:::-;;:::i;32550:133::-;;;;;;;;;;-1:-1:-1;32550:133:0;;;;;:::i;:::-;;:::i;29773:29::-;;;;;;;;;;-1:-1:-1;29773:29:0;;;;-1:-1:-1;;;;;29773:29:0;;;30373:40;;;;;;;;;;-1:-1:-1;30373:40:0;;;;;;;;32972:126;;;;;;;;;;-1:-1:-1;32972:126:0;;;;;:::i;:::-;-1:-1:-1;;;;;33062:28:0;33038:4;33062:28;;;:19;:28;;;;;;;;;32972:126;35803:90;;;;;;;;;;-1:-1:-1;35871:7:0;:14;35803:90;;30483:35;;;;;;;;;;;;;;;;31706:135;;;;;;;;;;-1:-1:-1;31706:135:0;;;;;:::i;:::-;;:::i;11064:157::-;;;;;;;;;;-1:-1:-1;11064:157:0;;;;;:::i;:::-;-1:-1:-1;;;;;11195:18:0;11163:7;11195:18;;;:9;:18;;;;;;;11064:157;8373:148;;;;;;;;;;;;;:::i;30420:24::-;;;;;;;;;;;;;;;;7730:79;;;;;;;;;;-1:-1:-1;7768:7:0;7795:6;-1:-1:-1;;;;;7795:6:0;7730:79;;9992:104;;;;;;;;;;;;;:::i;14355:388::-;;;;;;;;;;-1:-1:-1;14355:388:0;;;;;:::i;:::-;;:::i;29947:18::-;;;;;;;;;;-1:-1:-1;29947:18:0;;;;-1:-1:-1;;;;;29947:18:0;;;11434:200;;;;;;;;;;-1:-1:-1;11434:200:0;;;;;:::i;:::-;;:::i;32400:136::-;;;;;;;;;;-1:-1:-1;32400:136:0;;;;;:::i;:::-;;:::i;30309:57::-;;;;;;;;;;-1:-1:-1;30309:57:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;31850:132;;;;;;;;;;-1:-1:-1;31850:132:0;;;;;:::i;:::-;;:::i;32150:236::-;;;;;;;;;;-1:-1:-1;32150:236:0;;;;;:::i;:::-;;:::i;32695:117::-;;;;;;;;;;-1:-1:-1;32695:117:0;;;;;:::i;:::-;;:::i;29914:18::-;;;;;;;;;;-1:-1:-1;29914:18:0;;;;-1:-1:-1;;;;;29914:18:0;;;11697:181;;;;;;;;;;-1:-1:-1;11697:181:0;;;;;:::i;:::-;-1:-1:-1;;;;;11843:18:0;;;11811:7;11843:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;11697:181;33110:279;;;;;;;;;;-1:-1:-1;33110:279:0;;;;;:::i;:::-;;:::i;30000:33::-;;;;;;;;;;;;;;;;8676:281;;;;;;;;;;-1:-1:-1;8676:281:0;;;;;:::i;:::-;;:::i;30448:31::-;;;;;;;;;;;;;;;;9773:100;9827:13;9860:5;9853:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;9773:100;:::o;31991:148::-;7942:6;;-1:-1:-1;;;;;7942:6:0;182:10;7942:22;7934:68;;;;-1:-1:-1;;;7934:68:0;;;;;;;:::i;:::-;;;;;;;;;-1:-1:-1;;;;;32096:28:0;;;::::1;;::::0;;;:19:::1;:28;::::0;;;;:39;;-1:-1:-1;;32096:39:0::1;::::0;::::1;;::::0;;;::::1;::::0;;31991:148::o;12025:194::-;12128:4;12150:39;182:10;12173:7;12182:6;12150:8;:39::i;:::-;-1:-1:-1;12207:4:0;12025:194;;;;;:::o;12701:454::-;12841:4;12858:36;12868:6;12876:9;12887:6;12858:9;:36::i;:::-;12905:220;12928:6;182:10;12976:138;13032:6;12976:138;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;12976:19:0;;;;;;:11;:19;;;;;;;;182:10;12976:33;;;;;;;;;;:37;:138::i;:::-;12905:8;:220::i;:::-;-1:-1:-1;13143:4:0;12701:454;;;;;:::o;35406:380::-;35529:11;;35491:12;;-1:-1:-1;;;;;35529:11:0;35544:10;35529:25;35521:34;;;;;;35577:21;:25;35574:138;;35647:11;;35639:52;;-1:-1:-1;;;;;35647:11:0;;;;35669:21;35639:52;;;;;35647:11;35639:52;35647:11;35639:52;35669:21;35647:11;35639:52;;;;;;;;;;;;;;;;;;;;;35574:138;35729:49;;-1:-1:-1;;;35729:49:0;;35759:10;35729:49;;;5570:51:1;5637:18;;;5630:34;;;-1:-1:-1;;;;;35729:29:0;;;;;5543:18:1;;35729:49:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;35722:56;35406:380;-1:-1:-1;;;35406:380:0:o;13564:288::-;182:10;13667:4;13761:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;13761:34:0;;;;;;;;;;13667:4;;13689:133;;13739:7;;13761:50;;13800:10;13761:38;:50::i;32550:133::-;7942:6;;-1:-1:-1;;;;;7942:6:0;182:10;7942:22;7934:68;;;;-1:-1:-1;;;7934:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;32625:43:0::1;;::::0;;;:22:::1;:43;::::0;;;;:50;;-1:-1:-1;;32625:50:0::1;32671:4;32625:50;::::0;;32550:133::o;31706:135::-;7942:6;;-1:-1:-1;;;;;7942:6:0;182:10;7942:22;7934:68;;;;-1:-1:-1;;;7934:68:0;;;;;;;:::i;:::-;31785:15:::1;:48:::0;;-1:-1:-1;;;;;;31785:48:0::1;-1:-1:-1::0;;;;;31785:48:0;;;::::1;::::0;;;::::1;::::0;;31706:135::o;8373:148::-;7942:6;;-1:-1:-1;;;;;7942:6:0;182:10;7942:22;7934:68;;;;-1:-1:-1;;;7934:68:0;;;;;;;:::i;:::-;8480:1:::1;8464:6:::0;;8443:40:::1;::::0;-1:-1:-1;;;;;8464:6:0;;::::1;::::0;8443:40:::1;::::0;8480:1;;8443:40:::1;8511:1;8494:19:::0;;-1:-1:-1;;;;;;8494:19:0::1;::::0;;8373:148::o;9992:104::-;10048:13;10081:7;10074:14;;;;;:::i;14355:388::-;14463:4;14485:228;182:10;14535:7;14557:145;14614:15;14557:145;;;;;;;;;;;;;;;;;182:10;14557:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;14557:34:0;;;;;;;;;;;;:38;:145::i;11434:200::-;11540:4;11562:42;182:10;11586:9;11597:6;11562:9;:42::i;32400:136::-;7942:6;;-1:-1:-1;;;;;7942:6:0;182:10;7942:22;7934:68;;;;-1:-1:-1;;;7934:68:0;;;;;;;:::i;:::-;32488:18:::1;:40:::0;32400:136::o;31850:132::-;7942:6;;-1:-1:-1;;;;;7942:6:0;182:10;7942:22;7934:68;;;;-1:-1:-1;;;7934:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;31935:28:0;;;::::1;;::::0;;;:19:::1;:28;::::0;;;;:39;;-1:-1:-1;;31935:39:0::1;::::0;::::1;;::::0;;;::::1;::::0;;31850:132::o;32150:236::-;7942:6;;-1:-1:-1;;;;;7942:6:0;182:10;7942:22;7934:68;;;;-1:-1:-1;;;7934:68:0;;;;;;;:::i;:::-;32268:9:::1;32263:116;32283:19:::0;;::::1;32263:116;;;32359:8;32324:19;:32;32344:8;;32353:1;32344:11;;;;;;;:::i;:::-;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;;;;32324:32:0::1;::::0;;::::1;::::0;::::1;::::0;;;;;;-1:-1:-1;32324:32:0;:43;;-1:-1:-1;;32324:43:0::1;::::0;::::1;;::::0;;;::::1;::::0;;32304:3;::::1;::::0;::::1;:::i;:::-;;;;32263:116;;;;32150:236:::0;;;:::o;32695:117::-;7942:6;;-1:-1:-1;;;;;7942:6:0;182:10;7942:22;7934:68;;;;-1:-1:-1;;;7934:68:0;;;;;;;:::i;:::-;32772:21:::1;:32:::0;;-1:-1:-1;;32772:32:0::1;::::0;::::1;;::::0;;;::::1;::::0;;32695:117::o;33110:279::-;7942:6;;-1:-1:-1;;;;;7942:6:0;182:10;7942:22;7934:68;;;;-1:-1:-1;;;7934:68:0;;;;;;;:::i;:::-;33207:11:::1;::::0;33229:5:::1;::::0;33191:62:::1;::::0;-1:-1:-1;;;;;33207:11:0::1;::::0;33220:7;;33229:23:::1;::::0;33239:12:::1;33229:9;:23::i;:::-;33191:15;:62::i;:::-;33285:11;:21:::0;;-1:-1:-1;;;;;;33285:21:0::1;-1:-1:-1::0;;;;;33285:21:0;::::1;;::::0;;33346:30:::1;33285:21:::0;-1:-1:-1;33346:15:0::1;:30::i;:::-;33110:279:::0;:::o;8676:281::-;7942:6;;-1:-1:-1;;;;;7942:6:0;182:10;7942:22;7934:68;;;;-1:-1:-1;;;7934:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;8779:22:0;::::1;8757:110;;;::::0;-1:-1:-1;;;8757:110:0;;6531:2:1;8757:110:0::1;::::0;::::1;6513:21:1::0;6570:2;6550:18;;;6543:30;6609:34;6589:18;;;6582:62;-1:-1:-1;;;6660:18:1;;;6653:36;6706:19;;8757:110:0::1;6329:402:1::0;8757:110:0::1;8904:6;::::0;;8883:38:::1;::::0;-1:-1:-1;;;;;8883:38:0;;::::1;::::0;8904:6;::::1;::::0;8883:38:::1;::::0;::::1;8932:6;:17:::0;;-1:-1:-1;;;;;;8932:17:0::1;-1:-1:-1::0;;;;;8932:17:0;;;::::1;::::0;;;::::1;::::0;;8676:281::o;20897:471::-;20955:7;21200:1;21205;21200:6;21196:47;;-1:-1:-1;21230:1:0;21223:8;;21196:47;21255:9;21267:5;21271:1;21267;:5;:::i;:::-;21255:17;-1:-1:-1;21300:1:0;21291:5;21295:1;21255:17;21291:5;:::i;:::-;:10;21283:56;;;;-1:-1:-1;;;21283:56:0;;7333:2:1;21283:56:0;;;7315:21:1;7372:2;7352:18;;;7345:30;7411:34;7391:18;;;7384:62;-1:-1:-1;;;7462:18:1;;;7455:31;7503:19;;21283:56:0;7131:397:1;21844:132:0;21902:7;21929:39;21933:1;21936;21929:39;;;;;;;;;;;;;;;;;:3;:39::i;19509:181::-;19567:7;;19599:5;19603:1;19599;:5;:::i;:::-;19587:17;;19628:1;19623;:6;;19615:46;;;;-1:-1:-1;;;19615:46:0;;7865:2:1;19615:46:0;;;7847:21:1;7904:2;7884:18;;;7877:30;7943:29;7923:18;;;7916:57;7990:18;;19615:46:0;7663:351:1;18129:380:0;-1:-1:-1;;;;;18265:19:0;;18257:68;;;;-1:-1:-1;;;18257:68:0;;8221:2:1;18257:68:0;;;8203:21:1;8260:2;8240:18;;;8233:30;8299:34;8279:18;;;8272:62;-1:-1:-1;;;8350:18:1;;;8343:34;8394:19;;18257:68:0;8019:400:1;18257:68:0;-1:-1:-1;;;;;18344:21:0;;18336:68;;;;-1:-1:-1;;;18336:68:0;;8626:2:1;18336:68:0;;;8608:21:1;8665:2;8645:18;;;8638:30;8704:34;8684:18;;;8677:62;-1:-1:-1;;;8755:18:1;;;8748:32;8797:19;;18336:68:0;8424:398:1;18336:68:0;-1:-1:-1;;;;;18417:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;18469:32;;2020:25:1;;;18469:32:0;;1993:18:1;18469:32:0;;;;;;;;18129:380;;;:::o;33404:1975::-;-1:-1:-1;;;;;33536:18:0;;;;;;:48;;-1:-1:-1;;;;;;33559:25:0;;;;;;:19;:25;;;;;;;;33558:26;33536:48;33528:98;;;;-1:-1:-1;;;33528:98:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;33645:18:0;;33637:68;;;;-1:-1:-1;;;33637:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;33724:16:0;;33716:64;;;;-1:-1:-1;;;33716:64:0;;;;;;;:::i;:::-;33806:1;33799:6;:8;33791:17;;;;;;-1:-1:-1;;;;;33818:28:0;;;;;;:22;:28;;;;;;;;;:58;;-1:-1:-1;;;;;;33850:26:0;;;;;;:22;:26;;;;;;;;33818:58;33815:143;;;33892:33;33908:4;33914:2;33918:6;33892:15;:33::i;:::-;33404:1975;;;:::o;33815:143::-;33966:13;34051:9;;:14;:47;;;;-1:-1:-1;34079:13:0;;-1:-1:-1;;;;;34079:13:0;11163:7;11195:18;;;:9;:18;;;;;;34069:29;34051:47;:70;;;;-1:-1:-1;34108:13:0;;-1:-1:-1;;;;;34102:19:0;;;34108:13;;34102:19;34051:70;34048:156;;;34153:11;;-1:-1:-1;;;;;34145:19:0;;;34153:11;;34145:19;34137:28;;;;;;34183:15;34171:9;:27;34048:156;34248:18;;34239:4;11163:7;11195:18;;;:9;:18;;;;;;34221:45;34218:404;;;34305:8;;-1:-1:-1;;;34305:8:0;;;;34304:9;:49;;;;-1:-1:-1;34334:11:0;;-1:-1:-1;;;;;34334:19:0;;;:11;;:19;;34304:49;:87;;;;-1:-1:-1;34374:11:0;;-1:-1:-1;;;;;34374:17:0;;;:11;;:17;;34304:87;:129;;;;-1:-1:-1;34420:13:0;;-1:-1:-1;;;;;34412:21:0;;;34420:13;;34412:21;;34304:129;:171;;;;-1:-1:-1;34454:21:0;;;;34304:171;:189;;;;;34485:8;34484:9;34304:189;34282:329;;;34528:8;:15;;-1:-1:-1;;;;34528:15:0;34579:16;;34282:329;34652:8;;-1:-1:-1;;;;;34675:25:0;;34636:12;34675:25;;;:19;:25;;;;;;34652:8;-1:-1:-1;;;34652:8:0;;;;;34651:9;;34675:25;;:52;;-1:-1:-1;;;;;;34704:23:0;;;;;;:19;:23;;;;;;;;34675:52;34671:379;;;-1:-1:-1;34754:5:0;34671:379;;;34792:13;;-1:-1:-1;;;;;34792:13:0;;;34784:21;;;;34781:258;;34828:9;;34847:15;;34828:16;;34842:1;34828:13;:16::i;:::-;:34;34825:84;;;34880:27;:6;34891:15;34880:10;:27::i;:::-;34871:36;;34825:84;35225:33;35241:4;35247:2;35251:6;35225:15;:33::i;:::-;35282:13;;-1:-1:-1;;;;;35276:19:0;;;35282:13;;35276:19;:38;;;;-1:-1:-1;;;;;;35300:14:0;;;;;;:8;:14;;;;;;;;35299:15;35276:38;35273:99;;;-1:-1:-1;;;;;35321:14:0;;;;;;:8;:14;;;;;:21;;-1:-1:-1;;35321:21:0;35338:4;35321:21;;;;;;35348:7;:18;;;;;;;;;;;;;;-1:-1:-1;;;;;;35348:18:0;;;;;;35273:99;33517:1862;;33404:1975;;;:::o;20412:226::-;20532:7;20568:12;20560:6;;;;20552:29;;;;-1:-1:-1;;;20552:29:0;;;;;;;;:::i;:::-;-1:-1:-1;20592:9:0;20604:5;20608:1;20604;:5;:::i;:::-;20592:17;20412:226;-1:-1:-1;;;;;20412:226:0:o;19973:136::-;20031:7;20058:43;20062:1;20065;20058:43;;;;;;;;;;;;;;;;;:3;:43::i;15233:336::-;-1:-1:-1;;;;;15373:20:0;;15365:70;;;;-1:-1:-1;;;15365:70:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;15454:23:0;;15446:71;;;;-1:-1:-1;;;15446:71:0;;;;;;;:::i;:::-;15522:39;15537:6;15544:9;15554:6;15522:14;:39::i;22472:312::-;22592:7;22627:12;22620:5;22612:28;;;;-1:-1:-1;;;22612:28:0;;;;;;;;:::i;:::-;-1:-1:-1;22651:9:0;22663:5;22667:1;22663;:5;:::i;15581:311::-;-1:-1:-1;;;;;15738:17:0;;;;;;:9;:17;;;;;;:29;;15760:6;15738:21;:29::i;:::-;-1:-1:-1;;;;;15718:17:0;;;;;;;:9;:17;;;;;;:49;;;;15801:20;;;;;;;:32;;15826:6;15801:24;:32::i;:::-;-1:-1:-1;;;;;15778:20:0;;;;;;;:9;:20;;;;;;;:55;;;;15849:35;;;;;;;;;;15877:6;2020:25:1;;2008:2;1993:18;;1874:177;14:548;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:173::-;635:20;;-1:-1:-1;;;;;684:31:1;;674:42;;664:70;;730:1;727;720:12;664:70;567:173;;;:::o;745:118::-;831:5;824:13;817:21;810:5;807:32;797:60;;853:1;850;843:12;868:315;933:6;941;994:2;982:9;973:7;969:23;965:32;962:52;;;1010:1;1007;1000:12;962:52;1033:29;1052:9;1033:29;:::i;:::-;1023:39;;1112:2;1101:9;1097:18;1084:32;1125:28;1147:5;1125:28;:::i;:::-;1172:5;1162:15;;;868:315;;;;;:::o;1188:254::-;1256:6;1264;1317:2;1305:9;1296:7;1292:23;1288:32;1285:52;;;1333:1;1330;1323:12;1285:52;1356:29;1375:9;1356:29;:::i;:::-;1346:39;1432:2;1417:18;;;;1404:32;;-1:-1:-1;;;1188:254:1:o;2056:328::-;2133:6;2141;2149;2202:2;2190:9;2181:7;2177:23;2173:32;2170:52;;;2218:1;2215;2208:12;2170:52;2241:29;2260:9;2241:29;:::i;:::-;2231:39;;2289:38;2323:2;2312:9;2308:18;2289:38;:::i;:::-;2279:48;;2374:2;2363:9;2359:18;2346:32;2336:42;;2056:328;;;;;:::o;2578:186::-;2637:6;2690:2;2678:9;2669:7;2665:23;2661:32;2658:52;;;2706:1;2703;2696:12;2658:52;2729:29;2748:9;2729:29;:::i;3199:180::-;3258:6;3311:2;3299:9;3290:7;3286:23;3282:32;3279:52;;;3327:1;3324;3317:12;3279:52;-1:-1:-1;3350:23:1;;3199:180;-1:-1:-1;3199:180:1:o;3384:750::-;3476:6;3484;3492;3545:2;3533:9;3524:7;3520:23;3516:32;3513:52;;;3561:1;3558;3551:12;3513:52;3601:9;3588:23;3630:18;3671:2;3663:6;3660:14;3657:34;;;3687:1;3684;3677:12;3657:34;3725:6;3714:9;3710:22;3700:32;;3770:7;3763:4;3759:2;3755:13;3751:27;3741:55;;3792:1;3789;3782:12;3741:55;3832:2;3819:16;3858:2;3850:6;3847:14;3844:34;;;3874:1;3871;3864:12;3844:34;3929:7;3922:4;3912:6;3909:1;3905:14;3901:2;3897:23;3893:34;3890:47;3887:67;;;3950:1;3947;3940:12;3887:67;3981:4;3973:13;;;;-1:-1:-1;4005:6:1;-1:-1:-1;;4046:20:1;;4033:34;4076:28;4033:34;4076:28;:::i;:::-;4123:5;4113:15;;;3384:750;;;;;:::o;4139:241::-;4195:6;4248:2;4236:9;4227:7;4223:23;4219:32;4216:52;;;4264:1;4261;4254:12;4216:52;4303:9;4290:23;4322:28;4344:5;4322:28;:::i;4385:260::-;4453:6;4461;4514:2;4502:9;4493:7;4489:23;4485:32;4482:52;;;4530:1;4527;4520:12;4482:52;4553:29;4572:9;4553:29;:::i;:::-;4543:39;;4601:38;4635:2;4624:9;4620:18;4601:38;:::i;:::-;4591:48;;4385:260;;;;;:::o;4650:380::-;4729:1;4725:12;;;;4772;;;4793:61;;4847:4;4839:6;4835:17;4825:27;;4793:61;4900:2;4892:6;4889:14;4869:18;4866:38;4863:161;;4946:10;4941:3;4937:20;4934:1;4927:31;4981:4;4978:1;4971:15;5009:4;5006:1;4999:15;4863:161;;4650:380;;;:::o;5035:356::-;5237:2;5219:21;;;5256:18;;;5249:30;5315:34;5310:2;5295:18;;5288:62;5382:2;5367:18;;5035:356::o;5675:245::-;5742:6;5795:2;5783:9;5774:7;5770:23;5766:32;5763:52;;;5811:1;5808;5801:12;5763:52;5843:9;5837:16;5862:28;5884:5;5862:28;:::i;5925:127::-;5986:10;5981:3;5977:20;5974:1;5967:31;6017:4;6014:1;6007:15;6041:4;6038:1;6031:15;6057:127;6118:10;6113:3;6109:20;6106:1;6099:31;6149:4;6146:1;6139:15;6173:4;6170:1;6163:15;6189:135;6228:3;6249:17;;;6246:43;;6269:18;;:::i;:::-;-1:-1:-1;6316:1:1;6305:13;;6189:135::o;6736:168::-;6809:9;;;6840;;6857:15;;;6851:22;;6837:37;6827:71;;6878:18;;:::i;6909:217::-;6949:1;6975;6965:132;;7019:10;7014:3;7010:20;7007:1;7000:31;7054:4;7051:1;7044:15;7082:4;7079:1;7072:15;6965:132;-1:-1:-1;7111:9:1;;6909:217::o;7533:125::-;7598:9;;;7619:10;;;7616:36;;;7632:18;;:::i;8827:401::-;9029:2;9011:21;;;9068:2;9048:18;;;9041:30;9107:34;9102:2;9087:18;;9080:62;-1:-1:-1;;;9173:2:1;9158:18;;9151:35;9218:3;9203:19;;8827:401::o;9233:399::-;9435:2;9417:21;;;9474:2;9454:18;;;9447:30;9513:34;9508:2;9493:18;;9486:62;-1:-1:-1;;;9579:2:1;9564:18;;9557:33;9622:3;9607:19;;9233:399::o;9637:128::-;9704:9;;;9725:11;;;9722:37;;;9739:18;;:::i

Swarm Source

ipfs://410db562b0a9d91f960f7687e3ad3dac03449a7fecd6c54629da48535a88df94
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.