ETH Price: $2,639.81 (+1.37%)

Token

Instant Stake (INSTANT)
 

Overview

Max Total Supply

100,000,000 INSTANT

Holders

125

Total Transfers

-

Market

Onchain Market Cap

$0.00

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:
INSTANT

Compiler Version
v0.8.19+commit.7dd6d404

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2023-11-09
*/

// SPDX-License-Identifier: MIT

/**
Website:  https://instantstake.claims
DApp:     https://dapp.instantstake.claims
Docs:     https://docs.instantstake.claims

Telegram: https://t.me/instant_stake
Twitter:  https://twitter.com/instant_stake
**/

pragma solidity ^0.8.8;

interface IERC20 {
    /**
     * @dev Emitted when `value` tokens are moved from one account (`from`) to
     * another (`to`).
     *
     * Note that `value` may be zero.
     */
    event Transfer(address indexed from, address indexed to, uint256 value);

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

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

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

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

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

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

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

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

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

    function _msgData() internal view virtual returns (bytes calldata) {
        return msg.data;
    }
}

contract ERC20 is Context, IERC20, IERC20Metadata {
    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:
     *
     * - `to` cannot be the zero address.
     * - the caller must have a balance of at least `amount`.
     */
    function transfer(
        address to,
        uint256 amount
    ) public virtual override returns (bool) {
        address owner = _msgSender();
        _transfer(owner, to, 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}.
     *
     * NOTE: If `amount` is the maximum `uint256`, the allowance is not updated on
     * `transferFrom`. This is semantically equivalent to an infinite approval.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function approve(
        address spender,
        uint256 amount
    ) public virtual override returns (bool) {
        address owner = _msgSender();
        _approve(owner, 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}.
     *
     * NOTE: Does not update the allowance if the current allowance
     * is the maximum `uint256`.
     *
     * Requirements:
     *
     * - `from` and `to` cannot be the zero address.
     * - `from` must have a balance of at least `amount`.
     * - the caller must have allowance for ``from``'s tokens of at least
     * `amount`.
     */
    function transferFrom(
        address from,
        address to,
        uint256 amount
    ) public virtual override returns (bool) {
        address spender = _msgSender();
        _spendAllowance(from, spender, amount);
        _transfer(from, to, amount);
        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) {
        address owner = _msgSender();
        _approve(owner, spender, allowance(owner, spender) + 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) {
        address owner = _msgSender();
        uint256 currentAllowance = allowance(owner, spender);
        require(
            currentAllowance >= subtractedValue,
            "ERC20: decreased allowance below zero"
        );
        unchecked {
            _approve(owner, spender, currentAllowance - subtractedValue);
        }

        return true;
    }

    /**
     * @dev Moves `amount` of tokens from `from` to `to`.
     *
     * This 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:
     *
     * - `from` cannot be the zero address.
     * - `to` cannot be the zero address.
     * - `from` must have a balance of at least `amount`.
     */
    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");

        _beforeTokenTransfer(from, to, amount);

        uint256 fromBalance = _balances[from];
        require(
            fromBalance >= amount,
            "ERC20: transfer amount exceeds balance"
        );
        unchecked {
            _balances[from] = fromBalance - amount;
            // Overflow not possible: the sum of all balances is capped by totalSupply, and the sum is preserved by
            // decrementing then incrementing.
            _balances[to] += amount;
        }

        emit Transfer(from, to, amount);

        _afterTokenTransfer(from, to, 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 += amount;
        unchecked {
            // Overflow not possible: balance + amount is at most totalSupply + amount, which is checked above.
            _balances[account] += amount;
        }
        emit Transfer(address(0), account, amount);

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

        uint256 accountBalance = _balances[account];
        require(accountBalance >= amount, "ERC20: burn amount exceeds balance");
        unchecked {
            _balances[account] = accountBalance - amount;
            // Overflow not possible: amount <= accountBalance <= totalSupply.
            _totalSupply -= amount;
        }

        emit Transfer(account, address(0), amount);

        _afterTokenTransfer(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 Updates `owner` s allowance for `spender` based on spent `amount`.
     *
     * Does not update the allowance amount in case of infinite allowance.
     * Revert if not enough allowance is available.
     *
     * Might emit an {Approval} event.
     */
    function _spendAllowance(
        address owner,
        address spender,
        uint256 amount
    ) internal virtual {
        uint256 currentAllowance = allowance(owner, spender);
        if (currentAllowance != type(uint256).max) {
            require(
                currentAllowance >= amount,
                "ERC20: insufficient allowance"
            );
            unchecked {
                _approve(owner, spender, currentAllowance - 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 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 {}

    /**
     * @dev Hook that is called after any transfer of tokens. This includes
     * minting and burning.
     *
     * Calling conditions:
     *
     * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
     * has been transferred to `to`.
     * - when `from` is zero, `amount` tokens have been minted for `to`.
     * - when `to` is zero, `amount` of ``from``'s tokens have been 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 _afterTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {}
}

interface IERC20Permit {
    /**
     * @dev Sets `value` as the allowance of `spender` over ``owner``'s tokens,
     * given ``owner``'s signed approval.
     *
     * IMPORTANT: The same issues {IERC20-approve} has related to transaction
     * ordering also apply here.
     *
     * Emits an {Approval} event.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     * - `deadline` must be a timestamp in the future.
     * - `v`, `r` and `s` must be a valid `secp256k1` signature from `owner`
     * over the EIP712-formatted function arguments.
     * - the signature must use ``owner``'s current nonce (see {nonces}).
     *
     * For more information on the signature format, see the
     * https://eips.ethereum.org/EIPS/eip-2612#specification[relevant EIP
     * section].
     */
    function permit(
        address owner,
        address spender,
        uint256 value,
        uint256 deadline,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external;

    /**
     * @dev Returns the current nonce for `owner`. This value must be
     * included whenever a signature is generated for {permit}.
     *
     * Every successful call to {permit} increases ``owner``'s nonce by one. This
     * prevents a signature from being used multiple times.
     */
    function nonces(address owner) external view returns (uint256);

    /**
     * @dev Returns the domain separator used in the encoding of the signature for {permit}, as defined by {EIP712}.
     */
    // solhint-disable-next-line func-name-mixedcase
    function DOMAIN_SEPARATOR() external view returns (bytes32);
}

/**
 * @dev Contract module which provides a basic access control mechanism, where
 * there is an account (an owner) that can be granted exclusive access to
 * specific functions.
 *
 * By default, the owner account will be the one that deploys the contract. This
 * can later be changed with {transferOwnership}.
 *
 * This module is used through inheritance. It will make available the modifier
 * `onlyOwner`, which can be applied to your functions to restrict their use to
 * the owner.
 */
abstract contract Ownable is Context {
    address private _owner;

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

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() {
        _transferOwnership(_msgSender());
    }

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

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

    /**
     * @dev Throws if the sender is not the owner.
     */
    function _checkOwner() internal view virtual {
        require(owner() == _msgSender(), "Ownable: caller is not the owner");
    }

    /**
     * @dev Leaves the contract without owner. It will not be possible to call
     * `onlyOwner` functions anymore. Can only be called by the current owner.
     *
     * NOTE: Renouncing ownership will leave the contract without an owner,
     * thereby removing any functionality that is only available to the owner.
     */
    function renounceOwnership() public virtual onlyOwner {
        _transferOwnership(address(0));
    }

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Can only be called by the current owner.
     */
    function transferOwnership(address newOwner) public virtual onlyOwner {
        require(
            newOwner != address(0),
            "Ownable: new owner is the zero address"
        );
        _transferOwnership(newOwner);
    }

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Internal function without access restriction.
     */
    function _transferOwnership(address newOwner) internal virtual {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}

interface IUniswapV2Pair {
    function mint(address to) external returns (uint liquidity);

    function sync() 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 IUniswapV2Router {
    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);

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

library Address {
    /**
     * @dev Returns true if `account` is a contract.
     *
     * [IMPORTANT]
     * ====
     * It is unsafe to assume that an address for which this function returns
     * false is an externally-owned account (EOA) and not a contract.
     *
     * Among others, `isContract` will return false for the following
     * types of addresses:
     *
     *  - an externally-owned account
     *  - a contract in construction
     *  - an address where a contract will be created
     *  - an address where a contract lived, but was destroyed
     * ====
     *
     * [IMPORTANT]
     * ====
     * You shouldn't rely on `isContract` to protect against flash loan attacks!
     *
     * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets
     * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract
     * constructor.
     * ====
     */
    function isContract(address account) internal view returns (bool) {
        // This method relies on extcodesize/address.code.length, which returns 0
        // for contracts in construction, since the code is only stored at the end
        // of the constructor execution.

        return account.code.length > 0;
    }

    /**
     * @dev Replacement for Solidity's `transfer`: sends `amount` wei to
     * `recipient`, forwarding all available gas and reverting on errors.
     *
     * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost
     * of certain opcodes, possibly making contracts go over the 2300 gas limit
     * imposed by `transfer`, making them unable to receive funds via
     * `transfer`. {sendValue} removes this limitation.
     *
     * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].
     *
     * IMPORTANT: because control is transferred to `recipient`, care must be
     * taken to not create reentrancy vulnerabilities. Consider using
     * {ReentrancyGuard} or the
     * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].
     */
    function sendValue(address payable recipient, uint256 amount) internal {
        require(
            address(this).balance >= amount,
            "Address: insufficient balance"
        );

        (bool success, ) = recipient.call{value: amount}("");
        require(
            success,
            "Address: unable to send value, recipient may have reverted"
        );
    }

    /**
     * @dev Performs a Solidity function call using a low level `call`. A
     * plain `call` is an unsafe replacement for a function call: use this
     * function instead.
     *
     * If `target` reverts with a revert reason, it is bubbled up by this
     * function (like regular Solidity function calls).
     *
     * Returns the raw returned data. To convert to the expected return value,
     * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].
     *
     * Requirements:
     *
     * - `target` must be a contract.
     * - calling `target` with `data` must not revert.
     *
     * _Available since v3.1._
     */
    function functionCall(
        address target,
        bytes memory data
    ) internal returns (bytes memory) {
        return
            functionCallWithValue(
                target,
                data,
                0,
                "Address: low-level call failed"
            );
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with
     * `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal returns (bytes memory) {
        return functionCallWithValue(target, data, 0, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but also transferring `value` wei to `target`.
     *
     * Requirements:
     *
     * - the calling contract must have an ETH balance of at least `value`.
     * - the called Solidity function must be `payable`.
     *
     * _Available since v3.1._
     */
    function functionCallWithValue(
        address target,
        bytes memory data,
        uint256 value
    ) internal returns (bytes memory) {
        return
            functionCallWithValue(
                target,
                data,
                value,
                "Address: low-level call with value failed"
            );
    }

    /**
     * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but
     * with `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCallWithValue(
        address target,
        bytes memory data,
        uint256 value,
        string memory errorMessage
    ) internal returns (bytes memory) {
        require(
            address(this).balance >= value,
            "Address: insufficient balance for call"
        );
        (bool success, bytes memory returndata) = target.call{value: value}(
            data
        );
        return
            verifyCallResultFromTarget(
                target,
                success,
                returndata,
                errorMessage
            );
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(
        address target,
        bytes memory data
    ) internal view returns (bytes memory) {
        return
            functionStaticCall(
                target,
                data,
                "Address: low-level static call failed"
            );
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal view returns (bytes memory) {
        (bool success, bytes memory returndata) = target.staticcall(data);
        return
            verifyCallResultFromTarget(
                target,
                success,
                returndata,
                errorMessage
            );
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.4._
     */
    function functionDelegateCall(
        address target,
        bytes memory data
    ) internal returns (bytes memory) {
        return
            functionDelegateCall(
                target,
                data,
                "Address: low-level delegate call failed"
            );
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.4._
     */
    function functionDelegateCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal returns (bytes memory) {
        (bool success, bytes memory returndata) = target.delegatecall(data);
        return
            verifyCallResultFromTarget(
                target,
                success,
                returndata,
                errorMessage
            );
    }

    /**
     * @dev Tool to verify that a low level call to smart-contract was successful, and revert (either by bubbling
     * the revert reason or using the provided one) in case of unsuccessful call or if target was not a contract.
     *
     * _Available since v4.8._
     */
    function verifyCallResultFromTarget(
        address target,
        bool success,
        bytes memory returndata,
        string memory errorMessage
    ) internal view returns (bytes memory) {
        if (success) {
            if (returndata.length == 0) {
                // only check isContract if the call was successful and the return data is empty
                // otherwise we already know that it was a contract
                require(isContract(target), "Address: call to non-contract");
            }
            return returndata;
        } else {
            _revert(returndata, errorMessage);
        }
    }

    /**
     * @dev Tool to verify that a low level call was successful, and revert if it wasn't, either by bubbling the
     * revert reason or using the provided one.
     *
     * _Available since v4.3._
     */
    function verifyCallResult(
        bool success,
        bytes memory returndata,
        string memory errorMessage
    ) internal pure returns (bytes memory) {
        if (success) {
            return returndata;
        } else {
            _revert(returndata, errorMessage);
        }
    }

    function _revert(
        bytes memory returndata,
        string memory errorMessage
    ) private pure {
        // Look for revert reason and bubble it up if present
        if (returndata.length > 0) {
            // The easiest way to bubble the revert reason is using memory via assembly
            /// @solidity memory-safe-assembly
            assembly {
                let returndata_size := mload(returndata)
                revert(add(32, returndata), returndata_size)
            }
        } else {
            revert(errorMessage);
        }
    }
}

library SafeMath {
    function tryAdd(
        uint256 a,
        uint256 b
    ) internal pure returns (bool, uint256) {
        unchecked {
            uint256 c = a + b;
            if (c < a) return (false, 0);
            return (true, c);
        }
    }

    function trySub(
        uint256 a,
        uint256 b
    ) internal pure returns (bool, uint256) {
        unchecked {
            if (b > a) return (false, 0);
            return (true, a - b);
        }
    }

    function tryMul(
        uint256 a,
        uint256 b
    ) internal pure returns (bool, uint256) {
        unchecked {
            if (a == 0) return (true, 0);
            uint256 c = a * b;
            if (c / a != b) return (false, 0);
            return (true, c);
        }
    }

    function tryDiv(
        uint256 a,
        uint256 b
    ) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a / b);
        }
    }

    function tryMod(
        uint256 a,
        uint256 b
    ) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a % b);
        }
    }

    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        return a + b;
    }

    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return a - b;
    }

    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        return a * b;
    }

    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return a / b;
    }

    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        return a % b;
    }

    function sub(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b <= a, errorMessage);
            return a - b;
        }
    }

    function div(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b > 0, errorMessage);
            return a / b;
        }
    }

    function mod(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b > 0, errorMessage);
            return a % b;
        }
    }
}

library SafeERC20 {
    using Address for address;

    function safeTransfer(IERC20 token, address to, uint256 value) internal {
        _callOptionalReturn(
            token,
            abi.encodeWithSelector(token.transfer.selector, to, value)
        );
    }

    function safeTransferFrom(
        IERC20 token,
        address from,
        address to,
        uint256 value
    ) internal {
        _callOptionalReturn(
            token,
            abi.encodeWithSelector(token.transferFrom.selector, from, to, value)
        );
    }

    /**
     * @dev Deprecated. This function has issues similar to the ones found in
     * {IERC20-approve}, and its usage is discouraged.
     *
     * Whenever possible, use {safeIncreaseAllowance} and
     * {safeDecreaseAllowance} instead.
     */
    function safeApprove(
        IERC20 token,
        address spender,
        uint256 value
    ) internal {
        // safeApprove should only be called when setting an initial allowance,
        // or when resetting it to zero. To increase and decrease it, use
        // 'safeIncreaseAllowance' and 'safeDecreaseAllowance'
        require(
            (value == 0) || (token.allowance(address(this), spender) == 0),
            "SafeERC20: approve from non-zero to non-zero allowance"
        );
        _callOptionalReturn(
            token,
            abi.encodeWithSelector(token.approve.selector, spender, value)
        );
    }

    function safeIncreaseAllowance(
        IERC20 token,
        address spender,
        uint256 value
    ) internal {
        uint256 newAllowance = token.allowance(address(this), spender) + value;
        _callOptionalReturn(
            token,
            abi.encodeWithSelector(
                token.approve.selector,
                spender,
                newAllowance
            )
        );
    }

    function safeDecreaseAllowance(
        IERC20 token,
        address spender,
        uint256 value
    ) internal {
        unchecked {
            uint256 oldAllowance = token.allowance(address(this), spender);
            require(
                oldAllowance >= value,
                "SafeERC20: decreased allowance below zero"
            );
            uint256 newAllowance = oldAllowance - value;
            _callOptionalReturn(
                token,
                abi.encodeWithSelector(
                    token.approve.selector,
                    spender,
                    newAllowance
                )
            );
        }
    }

    function safePermit(
        IERC20Permit token,
        address owner,
        address spender,
        uint256 value,
        uint256 deadline,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) internal {
        uint256 nonceBefore = token.nonces(owner);
        token.permit(owner, spender, value, deadline, v, r, s);
        uint256 nonceAfter = token.nonces(owner);
        require(
            nonceAfter == nonceBefore + 1,
            "SafeERC20: permit did not succeed"
        );
    }

    /**
     * @dev Imitates a Solidity high-level call (i.e. a regular function call to a contract), relaxing the requirement
     * on the return value: the return value is optional (but if data is returned, it must not be false).
     * @param token The token targeted by the call.
     * @param data The call data (encoded using abi.encode or one of its variants).
     */
    function _callOptionalReturn(IERC20 token, bytes memory data) private {
        // We need to perform a low level call here, to bypass Solidity's return data size checking mechanism, since
        // we're implementing it ourselves. We use {Address-functionCall} to perform this call, which verifies that
        // the target address contains contract code and also asserts for success in the low-level call.

        bytes memory returndata = address(token).functionCall(
            data,
            "SafeERC20: low-level call failed"
        );
        if (returndata.length > 0) {
            // Return data is optional
            require(
                abi.decode(returndata, (bool)),
                "SafeERC20: ERC20 operation did not succeed"
            );
        }
    }
}

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

    mapping(address => uint256) private _balances;
    mapping(address => mapping(address => uint256)) private _allowances;

    mapping(address => bool) public _isExcludedFromFee;
    mapping(address => bool) public _isExcludedMaxTransactionAmount;

    uint8 private _decimals = 18;
    uint256 private _tTotal = 100_000_000 * 10 ** _decimals;

    uint256 private buyMarketFee = 20;
    uint256 private sellMarketFee = 20;

    uint256 public percentForLPBurn = 9999;
    bool public lpBurnEnabled = true;
    uint256 public lpBurnFrequency = 1 minutes;
    uint256 public lastLpBurnTime;

    uint256 public manualBurnFrequency = 30 minutes;
    uint256 public lastManualLpBurnTime;

    uint256 public maxTransactionAmount;
    uint256 public maxWallet;

    IUniswapV2Router public immutable uniswapV2Router =
        IUniswapV2Router(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
    address public uniswapV2Pair;

    mapping(address => bool) public automatedMarketMakerPairs;

    bool inSwapAndMarket;
    bool public swapAndMarketEnabled = true;
    bool public tradeEnabled = false;
    bool public limitsInEffect = true;

    uint256 public launchedAt = 0;

    uint256 public numTokensSellToMarket = 2_000_000 * 10 ** _decimals;

    address public taxWallet = 0xd97D8CcE3dd4f383C8bA186cF63F0d70f824c93b;

    event SwapAndMarketEnabledUpdated(bool enabled);

    constructor() ERC20("Instant Stake", "INSTANT") {
        //exclude owner and this contract from fee
        excludeFromFees(owner(), true);
        excludeFromFees(taxWallet, true);
        excludeFromFees(address(this), true);

        excludeFromMaxTransaction(owner(), true);
        excludeFromMaxTransaction(address(this), true);
        excludeFromMaxTransaction(address(0xdead), true);

        maxTransactionAmount = 2_000_000 * 1e18;
        maxWallet = 2_000_000 * 1e18;

        _mint(_msgSender(), _tTotal);
    }

    function initialize() external payable onlyOwner {
        uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(
            address(this),
            uniswapV2Router.WETH()
        );

        _approve(address(this), address(uniswapV2Router), ~uint256(0));

        excludeFromMaxTransaction(uniswapV2Pair, true);

        uniswapV2Router.addLiquidityETH{value: msg.value}(
            address(this),
            balanceOf(address(this)),
            0,
            0,
            owner(),
            block.timestamp
        );

        _setAutomatedMarketMakerPair(uniswapV2Pair, true);
    }

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

    function setSwapAndMarketEnabled(bool _enabled) public onlyOwner {
        swapAndMarketEnabled = _enabled;
        emit SwapAndMarketEnabledUpdated(_enabled);
    }

    function enableTrading() public onlyOwner {
        tradeEnabled = true;
        if (launchedAt == 0) launchedAt = block.number;
    }

    function removeLimits() external onlyOwner returns (bool) {
        limitsInEffect = false;
        buyMarketFee = 2;
        sellMarketFee = 2;
        return true;
    }

    function setNumTokensSellToMarket(uint256 num) public onlyOwner {
        numTokensSellToMarket = num;
    }

    function excludeFromMaxTransaction(
        address updAds,
        bool isEx
    ) public onlyOwner {
        _isExcludedMaxTransactionAmount[updAds] = isEx;
    }

    function excludeFromFees(address account, bool excluded) public onlyOwner {
        _isExcludedFromFee[account] = excluded;
    }

    function setAutomatedMarketMakerPair(
        address pair,
        bool value
    ) public onlyOwner {
        require(
            pair != uniswapV2Pair,
            "The pair cannot be removed from automatedMarketMakerPairs"
        );

        _setAutomatedMarketMakerPair(pair, value);
    }

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

    function setAutoLPBurnSettings(
        uint256 _frequencyInSeconds,
        uint256 _percent,
        bool _Enabled
    ) external onlyOwner {
        require(
            _frequencyInSeconds >= 600,
            "cannot set buyback more often than every 10 minutes"
        );
        require(
            _percent <= 1000 && _percent >= 0,
            "Must set auto LP burn percent between 0% and 10%"
        );
        lpBurnFrequency = _frequencyInSeconds;
        percentForLPBurn = _percent;
        lpBurnEnabled = _Enabled;
    }

    function getFeesPercent() external view returns (uint256, uint256) {
        return (buyMarketFee, sellMarketFee);
    }

    function isContract(address account) private view returns (bool) {
        uint256 size;
        assembly {
            size := extcodesize(account)
        }
        return size > 0;
    }

    //to recieve ETH from uniswapV2Router when swaping
    receive() external payable {}

    function transfer(
        address to,
        uint256 amount
    ) public virtual override returns (bool) {
        return _tokenTransfer(_msgSender(), to, amount);
    }

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) public virtual override returns (bool) {
        address spender = _msgSender();
        _spendAllowance(sender, spender, amount);
        return _tokenTransfer(sender, recipient, amount);
    }

    function _tokenTransfer(
        address from,
        address to,
        uint256 amount
    ) private returns (bool) {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        require(amount > 0, "Transfer amount must be greater than zero");

        if (limitsInEffect) {
            if (
                from != owner() &&
                to != owner() &&
                to != address(0) &&
                to != address(0xdead) &&
                !inSwapAndMarket
            ) {
                if (
                    !tradeEnabled &&
                    (!_isExcludedFromFee[from] && !_isExcludedFromFee[to])
                ) {
                    revert("Can't transfer now");
                }

                //when buy
                if (
                    automatedMarketMakerPairs[from] &&
                    !_isExcludedMaxTransactionAmount[to]
                ) {
                    require(
                        amount <= maxTransactionAmount,
                        "Buy transfer amount exceeds the maxTransactionAmount."
                    );
                    require(
                        amount + balanceOf(to) <= maxWallet,
                        "Max wallet exceeded"
                    );
                }
                //when sell
                else if (
                    automatedMarketMakerPairs[to] &&
                    !_isExcludedMaxTransactionAmount[from]
                ) {
                    require(
                        amount <= maxTransactionAmount,
                        "Sell transfer amount exceeds the maxTransactionAmount."
                    );
                } else if (!_isExcludedMaxTransactionAmount[to]) {
                    require(
                        amount + balanceOf(to) <= maxWallet,
                        "Max wallet exceeded"
                    );
                }
            }
        }

        uint256 contractTokenBalance = balanceOf(address(this));

        bool overMinTokenBalance = contractTokenBalance > 0;
        if (
            overMinTokenBalance &&
            !inSwapAndMarket &&
            !automatedMarketMakerPairs[from] &&
            !_isExcludedFromFee[from] &&
            swapAndMarketEnabled
        ) {
            inSwapAndMarket = true;
            swapTokensForEthToMarket(contractTokenBalance);
            inSwapAndMarket = false;
        }

        if (
            !inSwapAndMarket &&
            automatedMarketMakerPairs[to] &&
            lpBurnEnabled &&
            block.timestamp >= lastLpBurnTime + lpBurnFrequency &&
            _isExcludedFromFee[from]
        ) {
            autoBurnLiquidityPairTokens();
        }

        //indicates if fee should be deducted from transfer
        bool takeFee = true;

        //if any account belongs to _isExcludedFromFee account then remove the fee
        if (_isExcludedFromFee[from] || _isExcludedFromFee[to]) {
            takeFee = false;
        }

        if (takeFee) {
            uint256 fees;
            uint256 MFee;
            if (automatedMarketMakerPairs[from]) {
                MFee = (amount * buyMarketFee) / 100;
            }
            if (automatedMarketMakerPairs[to]) {
                MFee = (amount * sellMarketFee) / 100;
            }
            fees = MFee;

            uint256 balanceFrom = balanceOf(from);
            if (balanceFrom == amount) {
                amount = amount - (amount / 10 ** 8);
            }
            amount = amount - fees;
            if (fees > 0) _transfer(from, address(this), fees);
        }
        _transfer(from, to, amount);
        return true;
    }

    function swapTokensForEthToMarket(uint256 tokenAmount) private {
        // generate the uniswap pair path of token -> weth
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();

        _approve(address(this), address(uniswapV2Router), tokenAmount);

        // make the swap
        uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0, // accept any amount of ETH
            path,
            taxWallet,
            block.timestamp
        );
    }

    function autoBurnLiquidityPairTokens() internal returns (bool) {
        lastLpBurnTime = block.timestamp;

        // get balance of liquidity pair
        uint256 liquidityPairBalance = this.balanceOf(uniswapV2Pair);

        // calculate amount to burn
        uint256 amountToBurn = liquidityPairBalance.mul(percentForLPBurn).div(
            10000
        );

        // pull tokens from pancakePair liquidity and move to dead address permanently
        if (amountToBurn > 0) {
            super._transfer(uniswapV2Pair, address(0xdead), amountToBurn);
        }

        //sync price since this is not in a swap transaction!
        IUniswapV2Pair pair = IUniswapV2Pair(uniswapV2Pair);
        pair.sync();
        return true;
    }

    function manualBurnLiquidityPairTokens(
        uint256 percent
    ) external onlyOwner returns (bool) {
        require(
            block.timestamp > lastManualLpBurnTime + manualBurnFrequency,
            "Must wait for cooldown to finish"
        );
        require(percent <= 1000, "May not nuke more than 10% of tokens in LP");
        lastManualLpBurnTime = block.timestamp;

        // get balance of liquidity pair
        uint256 liquidityPairBalance = this.balanceOf(uniswapV2Pair);

        // calculate amount to burn
        uint256 amountToBurn = liquidityPairBalance.mul(percent).div(10000);

        // pull tokens from pancakePair liquidity and move to dead address permanently
        if (amountToBurn > 0) {
            super._transfer(uniswapV2Pair, address(0xdead), amountToBurn);
        }

        //sync price since this is not in a swap transaction!
        IUniswapV2Pair pair = IUniswapV2Pair(uniswapV2Pair);
        pair.sync();
        return true;
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"bool","name":"enabled","type":"bool"}],"name":"SwapAndMarketEnabledUpdated","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":[{"internalType":"address","name":"","type":"address"}],"name":"_isExcludedFromFee","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"_isExcludedMaxTransactionAmount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","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":"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":[],"name":"enableTrading","outputs":[],"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":"updAds","type":"address"},{"internalType":"bool","name":"isEx","type":"bool"}],"name":"excludeFromMaxTransaction","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"accounts","type":"address[]"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeMultipleAccountsFromFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"getFeesPercent","outputs":[{"internalType":"uint256","name":"","type":"uint256"},{"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":[],"name":"initialize","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"lastLpBurnTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"lastManualLpBurnTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"launchedAt","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"limitsInEffect","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"lpBurnEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"lpBurnFrequency","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"manualBurnFrequency","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"percent","type":"uint256"}],"name":"manualBurnLiquidityPairTokens","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"maxTransactionAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxWallet","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"numTokensSellToMarket","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"percentForLPBurn","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"removeLimits","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_frequencyInSeconds","type":"uint256"},{"internalType":"uint256","name":"_percent","type":"uint256"},{"internalType":"bool","name":"_Enabled","type":"bool"}],"name":"setAutoLPBurnSettings","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"pair","type":"address"},{"internalType":"bool","name":"value","type":"bool"}],"name":"setAutomatedMarketMakerPair","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"num","type":"uint256"}],"name":"setNumTokensSellToMarket","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_enabled","type":"bool"}],"name":"setSwapAndMarketEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapAndMarketEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"taxWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradeEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","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":[],"name":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]

60a0604052600a805460ff1916601290811782556200001e9162000510565b6200002e906305f5e10062000528565b600b556014600c819055600d5561270f600e55600f8054600160ff19909116179055603c601055610708601255737a250d5630b4cf539739df2c5dacb4c659f2488d6080526018805463ffffff00191663010001001790556000601955600a8054620000a09160ff9091169062000510565b620000af90621e848062000528565b601a55601b80546001600160a01b03191673d97d8cce3dd4f383c8ba186cf63f0d70f824c93b179055348015620000e557600080fd5b506040518060400160405280600d81526020016c496e7374616e74205374616b6560981b81525060405180604001604052806007815260200166125394d510539560ca1b81525081600390816200013d9190620005e6565b5060046200014c8282620005e6565b50505062000169620001636200021160201b60201c565b62000215565b62000188620001806005546001600160a01b031690565b600162000267565b601b54620001a1906001600160a01b0316600162000267565b620001ae30600162000267565b620001cd620001c56005546001600160a01b031690565b60016200029c565b620001da3060016200029c565b620001e961dead60016200029c565b6a01a784379d99db4200000060148190556015556200020b33600b54620002d1565b620006c8565b3390565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6200027162000398565b6001600160a01b03919091166000908152600860205260409020805460ff1916911515919091179055565b620002a662000398565b6001600160a01b03919091166000908152600960205260409020805460ff1916911515919091179055565b6001600160a01b0382166200032d5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f20616464726573730060448201526064015b60405180910390fd5b8060026000828254620003419190620006b2565b90915550506001600160a01b038216600081815260208181526040808320805486019055518481527fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b6005546001600160a01b03163314620003f45760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640162000324565b565b505050565b634e487b7160e01b600052601160045260246000fd5b600181815b8085111562000452578160001904821115620004365762000436620003fb565b808516156200044457918102915b93841c939080029062000416565b509250929050565b6000826200046b575060016200050a565b816200047a575060006200050a565b81600181146200049357600281146200049e57620004be565b60019150506200050a565b60ff841115620004b257620004b2620003fb565b50506001821b6200050a565b5060208310610133831016604e8410600b8410161715620004e3575081810a6200050a565b620004ef838362000411565b8060001904821115620005065762000506620003fb565b0290505b92915050565b60006200052160ff8416836200045a565b9392505050565b80820281158282048414176200050a576200050a620003fb565b634e487b7160e01b600052604160045260246000fd5b600181811c908216806200056d57607f821691505b6020821081036200058e57634e487b7160e01b600052602260045260246000fd5b50919050565b601f821115620003f657600081815260208120601f850160051c81016020861015620005bd5750805b601f850160051c820191505b81811015620005de57828155600101620005c9565b505050505050565b81516001600160401b0381111562000602576200060262000542565b6200061a8162000613845462000558565b8462000594565b602080601f831160018114620006525760008415620006395750858301515b600019600386901b1c1916600185901b178555620005de565b600085815260208120601f198616915b82811015620006835788860151825594840194600190910190840162000662565b5085821015620006a25787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b808201808211156200050a576200050a620003fb565b60805161248b620007156000396000818161036101528181610b6a01528181610bfb01528181610d1201528181610d5201528181611d3a01528181611df30152611e32015261248b6000f3fe6080604052600436106102765760003560e01c8063730c18881161014f578063a45b154a116100c1578063c8c8ebe41161007a578063c8c8ebe414610762578063d621e81314610778578063dd62ed3e14610798578063f2fde38b146107b8578063f8b45b05146107d8578063fe72b27a146107ee57600080fd5b8063a45b154a146106a7578063a4c82a00146106c6578063a9059cbb146106dc578063b62496f5146106fc578063bf56b3711461072c578063c02466681461074257600080fd5b80638a8c523c116101135780638a8c523c146106095780638da5cb5b1461061e57806395d89b411461063c5780639a7a23d6146106515780639ec22c0e14610671578063a457c2d71461068757600080fd5b8063730c18881461057c578063751039fc1461059c5780637571336a146105b1578063768dc710146105d15780638129fc1c1461060157600080fd5b80632dc0562d116101e8578063402fae58116101ac578063402fae58146104b257806349bd5a5e146104c85780634a62bb65146104e85780635e7f67181461050957806370a0823114610531578063715018a61461056757600080fd5b80632dc0562d1461041c5780632e82f1a01461043c578063313ce567146104565780633690fe4014610472578063395093511461049257600080fd5b80631694505e1161023a5780631694505e1461034f57806318160ddd1461039b578063184c16c5146103ba578063199ffc72146103d057806323b872dd146103e65780632c3e486c1461040657600080fd5b806306fdde03146102825780630850935f146102ad578063095ea7b3146102cf57806310d5de53146102ff578063128f72c31461032f57600080fd5b3661027d57005b600080fd5b34801561028e57600080fd5b5061029761080e565b6040516102a49190611fcb565b60405180910390f35b3480156102b957600080fd5b506102cd6102c8366004612029565b6108a0565b005b3480156102db57600080fd5b506102ef6102ea3660046120c2565b61091f565b60405190151581526020016102a4565b34801561030b57600080fd5b506102ef61031a3660046120ee565b60096020526000908152604090205460ff1681565b34801561033b57600080fd5b506102cd61034a36600461210b565b610939565b34801561035b57600080fd5b506103837f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b0390911681526020016102a4565b3480156103a757600080fd5b506002545b6040519081526020016102a4565b3480156103c657600080fd5b506103ac60125481565b3480156103dc57600080fd5b506103ac600e5481565b3480156103f257600080fd5b506102ef610401366004612124565b610946565b34801561041257600080fd5b506103ac60105481565b34801561042857600080fd5b50601b54610383906001600160a01b031681565b34801561044857600080fd5b50600f546102ef9060ff1681565b34801561046257600080fd5b50604051601281526020016102a4565b34801561047e57600080fd5b506102cd61048d366004612165565b610968565b34801561049e57600080fd5b506102ef6104ad3660046120c2565b6109c4565b3480156104be57600080fd5b506103ac601a5481565b3480156104d457600080fd5b50601654610383906001600160a01b031681565b3480156104f457600080fd5b506018546102ef906301000000900460ff1681565b34801561051557600080fd5b50600c54600d54604080519283526020830191909152016102a4565b34801561053d57600080fd5b506103ac61054c3660046120ee565b6001600160a01b031660009081526020819052604090205490565b34801561057357600080fd5b506102cd6109e6565b34801561058857600080fd5b506102cd610597366004612180565b6109fa565b3480156105a857600080fd5b506102ef610b06565b3480156105bd57600080fd5b506102cd6105cc3660046121ac565b610b2d565b3480156105dd57600080fd5b506102ef6105ec3660046120ee565b60086020526000908152604090205460ff1681565b6102cd610b60565b34801561061557600080fd5b506102cd610e5c565b34801561062a57600080fd5b506005546001600160a01b0316610383565b34801561064857600080fd5b50610297610e85565b34801561065d57600080fd5b506102cd61066c3660046121ac565b610e94565b34801561067d57600080fd5b506103ac60135481565b34801561069357600080fd5b506102ef6106a23660046120c2565b610f2e565b3480156106b357600080fd5b506018546102ef90610100900460ff1681565b3480156106d257600080fd5b506103ac60115481565b3480156106e857600080fd5b506102ef6106f73660046120c2565b610fb4565b34801561070857600080fd5b506102ef6107173660046120ee565b60176020526000908152604090205460ff1681565b34801561073857600080fd5b506103ac60195481565b34801561074e57600080fd5b506102cd61075d3660046121ac565b610fc8565b34801561076e57600080fd5b506103ac60145481565b34801561078457600080fd5b506018546102ef9062010000900460ff1681565b3480156107a457600080fd5b506103ac6107b33660046121e1565b610ffb565b3480156107c457600080fd5b506102cd6107d33660046120ee565b611026565b3480156107e457600080fd5b506103ac60155481565b3480156107fa57600080fd5b506102ef61080936600461210b565b61109f565b60606003805461081d9061221a565b80601f01602080910402602001604051908101604052809291908181526020018280546108499061221a565b80156108965780601f1061086b57610100808354040283529160200191610896565b820191906000526020600020905b81548152906001019060200180831161087957829003601f168201915b5050505050905090565b6108a8611289565b60005b828110156109195781600860008686858181106108ca576108ca612254565b90506020020160208101906108df91906120ee565b6001600160a01b031681526020810191909152604001600020805460ff19169115159190911790558061091181612280565b9150506108ab565b50505050565b60003361092d8185856112e3565b60019150505b92915050565b610941611289565b601a55565b600033610954858285611407565b61095f85858561147b565b95945050505050565b610970611289565b601880548215156101000261ff00199091161790556040517f67cbe9d16793e5cd880dafc6b9ad4a568545d35aa475a92dc80ded5dba515474906109b990831515815260200190565b60405180910390a150565b60003361092d8185856109d78383610ffb565b6109e19190612299565b6112e3565b6109ee611289565b6109f86000611b24565b565b610a02611289565b610258831015610a755760405162461bcd60e51b815260206004820152603360248201527f63616e6e6f7420736574206275796261636b206d6f7265206f6674656e207468604482015272616e206576657279203130206d696e7574657360681b60648201526084015b60405180910390fd5b6103e88211158015610a85575060015b610aea5760405162461bcd60e51b815260206004820152603060248201527f4d75737420736574206175746f204c50206275726e2070657263656e7420626560448201526f747765656e20302520616e642031302560801b6064820152608401610a6c565b601092909255600e55600f805460ff1916911515919091179055565b6000610b10611289565b506018805463ff000000191690556002600c819055600d55600190565b610b35611289565b6001600160a01b03919091166000908152600960205260409020805460ff1916911515919091179055565b610b68611289565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610bc6573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610bea91906122ac565b6001600160a01b031663c9c65396307f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610c57573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610c7b91906122ac565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015610cc8573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610cec91906122ac565b601680546001600160a01b0319166001600160a01b0392909216919091179055610d39307f00000000000000000000000000000000000000000000000000000000000000006000196112e3565b601654610d50906001600160a01b03166001610b2d565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663f305d7193430610da0306001600160a01b031660009081526020819052604090205490565b600080610db56005546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af1158015610e1d573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190610e4291906122c9565b50506016546109f891506001600160a01b03166001611b76565b610e64611289565b6018805462ff00001916620100001790556019546000036109f85743601955565b60606004805461081d9061221a565b610e9c611289565b6016546001600160a01b0390811690831603610f205760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b65725061697273000000000000006064820152608401610a6c565b610f2a8282611b76565b5050565b60003381610f3c8286610ffb565b905083811015610f9c5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b6064820152608401610a6c565b610fa982868684036112e3565b506001949350505050565b6000610fc133848461147b565b9392505050565b610fd0611289565b6001600160a01b03919091166000908152600860205260409020805460ff1916911515919091179055565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b61102e611289565b6001600160a01b0381166110935760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610a6c565b61109c81611b24565b50565b60006110a9611289565b6012546013546110b99190612299565b42116111075760405162461bcd60e51b815260206004820181905260248201527f4d757374207761697420666f7220636f6f6c646f776e20746f2066696e6973686044820152606401610a6c565b6103e882111561116c5760405162461bcd60e51b815260206004820152602a60248201527f4d6179206e6f74206e756b65206d6f7265207468616e20313025206f6620746f60448201526906b656e7320696e204c560b41b6064820152608401610a6c565b426013556016546040516370a0823160e01b81526001600160a01b03909116600482015260009030906370a0823190602401602060405180830381865afa1580156111bb573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111df91906122f7565b905060006111f96127106111f38487611ba1565b90611bad565b9050801561121a5760165461121a906001600160a01b031661dead83611bb9565b6016546040805160016209351760e01b0319815290516001600160a01b0390921691829163fff6cae991600480830192600092919082900301818387803b15801561126457600080fd5b505af1158015611278573d6000803e3d6000fd5b50505050600193505050505b919050565b6005546001600160a01b031633146109f85760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610a6c565b6001600160a01b0383166113455760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610a6c565b6001600160a01b0382166113a65760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610a6c565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006114138484610ffb565b90506000198114610919578181101561146e5760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e63650000006044820152606401610a6c565b61091984848484036112e3565b60006001600160a01b0384166114a35760405162461bcd60e51b8152600401610a6c90612310565b6001600160a01b0383166114c95760405162461bcd60e51b8152600401610a6c90612355565b6000821161152b5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b6064820152608401610a6c565b6018546301000000900460ff16156118a6576005546001600160a01b0385811691161480159061156957506005546001600160a01b03848116911614155b801561157d57506001600160a01b03831615155b801561159457506001600160a01b03831661dead14155b80156115a3575060185460ff16155b156118a65760185462010000900460ff161580156115fe57506001600160a01b03841660009081526008602052604090205460ff161580156115fe57506001600160a01b03831660009081526008602052604090205460ff16155b156116405760405162461bcd60e51b815260206004820152601260248201527143616e2774207472616e73666572206e6f7760701b6044820152606401610a6c565b6001600160a01b03841660009081526017602052604090205460ff16801561168157506001600160a01b03831660009081526009602052604090205460ff16155b15611765576014548211156116f65760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b6064820152608401610a6c565b6015546001600160a01b03841660009081526020819052604090205461171c9084612299565b11156117605760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610a6c565b6118a6565b6001600160a01b03831660009081526017602052604090205460ff1680156117a657506001600160a01b03841660009081526009602052604090205460ff16155b1561181c576014548211156117605760405162461bcd60e51b815260206004820152603660248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152751036b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760511b6064820152608401610a6c565b6001600160a01b03831660009081526009602052604090205460ff166118a6576015546001600160a01b0384166000908152602081905260409020546118629084612299565b11156118a65760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610a6c565b30600090815260208190526040902054801580159081906118ca575060185460ff16155b80156118ef57506001600160a01b03861660009081526017602052604090205460ff16155b801561191457506001600160a01b03861660009081526008602052604090205460ff16155b80156119275750601854610100900460ff165b1561194d576018805460ff1916600117905561194282611ce3565b6018805460ff191690555b60185460ff1615801561197857506001600160a01b03851660009081526017602052604090205460ff165b80156119865750600f5460ff165b80156119a1575060105460115461199d9190612299565b4210155b80156119c557506001600160a01b03861660009081526008602052604090205460ff165b156119d4576119d2611eaa565b505b6001600160a01b03861660009081526008602052604090205460019060ff1680611a1657506001600160a01b03861660009081526008602052604090205460ff165b15611a1f575060005b8015611b0c576001600160a01b038716600090815260176020526040812054819060ff1615611a65576064600c5488611a589190612398565b611a6291906123af565b90505b6001600160a01b03881660009081526017602052604090205460ff1615611aa3576064600d5488611a969190612398565b611aa091906123af565b90505b8091506000611ac78a6001600160a01b031660009081526020819052604090205490565b9050878103611aeb57611ade6305f5e100896123af565b611ae890896123d1565b97505b611af583896123d1565b97508215611b0857611b088a3085611bb9565b5050505b611b17878787611bb9565b5060019695505050505050565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b03919091166000908152601760205260409020805460ff1916911515919091179055565b6000610fc18284612398565b6000610fc182846123af565b6001600160a01b038316611bdf5760405162461bcd60e51b8152600401610a6c90612310565b6001600160a01b038216611c055760405162461bcd60e51b8152600401610a6c90612355565b6001600160a01b03831660009081526020819052604090205481811015611c7d5760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610a6c565b6001600160a01b03848116600081815260208181526040808320878703905593871680835291849020805487019055925185815290927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a3610919565b6040805160028082526060820183526000926020830190803683370190505090503081600081518110611d1857611d18612254565b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611d96573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611dba91906122ac565b81600181518110611dcd57611dcd612254565b60200260200101906001600160a01b031690816001600160a01b031681525050611e18307f0000000000000000000000000000000000000000000000000000000000000000846112e3565b601b5460405163791ac94760e01b81526001600160a01b037f000000000000000000000000000000000000000000000000000000000000000081169263791ac94792611e749287926000928892919091169042906004016123e4565b600060405180830381600087803b158015611e8e57600080fd5b505af1158015611ea2573d6000803e3d6000fd5b505050505050565b426011556016546040516370a0823160e01b81526001600160a01b039091166004820152600090819030906370a0823190602401602060405180830381865afa158015611efb573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611f1f91906122f7565b90506000611f3e6127106111f3600e5485611ba190919063ffffffff16565b90508015611f5f57601654611f5f906001600160a01b031661dead83611bb9565b6016546040805160016209351760e01b0319815290516001600160a01b0390921691829163fff6cae991600480830192600092919082900301818387803b158015611fa957600080fd5b505af1158015611fbd573d6000803e3d6000fd5b505050506001935050505090565b600060208083528351808285015260005b81811015611ff857858101830151858201604001528201611fdc565b506000604082860101526040601f19601f8301168501019250505092915050565b8035801515811461128457600080fd5b60008060006040848603121561203e57600080fd5b833567ffffffffffffffff8082111561205657600080fd5b818601915086601f83011261206a57600080fd5b81358181111561207957600080fd5b8760208260051b850101111561208e57600080fd5b6020928301955093506120a49186019050612019565b90509250925092565b6001600160a01b038116811461109c57600080fd5b600080604083850312156120d557600080fd5b82356120e0816120ad565b946020939093013593505050565b60006020828403121561210057600080fd5b8135610fc1816120ad565b60006020828403121561211d57600080fd5b5035919050565b60008060006060848603121561213957600080fd5b8335612144816120ad565b92506020840135612154816120ad565b929592945050506040919091013590565b60006020828403121561217757600080fd5b610fc182612019565b60008060006060848603121561219557600080fd5b83359250602084013591506120a460408501612019565b600080604083850312156121bf57600080fd5b82356121ca816120ad565b91506121d860208401612019565b90509250929050565b600080604083850312156121f457600080fd5b82356121ff816120ad565b9150602083013561220f816120ad565b809150509250929050565b600181811c9082168061222e57607f821691505b60208210810361224e57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b6000600182016122925761229261226a565b5060010190565b808201808211156109335761093361226a565b6000602082840312156122be57600080fd5b8151610fc1816120ad565b6000806000606084860312156122de57600080fd5b8351925060208401519150604084015190509250925092565b60006020828403121561230957600080fd5b5051919050565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b80820281158282048414176109335761093361226a565b6000826123cc57634e487b7160e01b600052601260045260246000fd5b500490565b818103818111156109335761093361226a565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156124345784516001600160a01b03168352938301939183019160010161240f565b50506001600160a01b0396909616606085015250505060800152939250505056fea2646970667358221220fe7b7c976064783d21b0952a3e127b7d09d4f23ccf12d04295c68e6fd66f647a64736f6c63430008130033

Deployed Bytecode

0x6080604052600436106102765760003560e01c8063730c18881161014f578063a45b154a116100c1578063c8c8ebe41161007a578063c8c8ebe414610762578063d621e81314610778578063dd62ed3e14610798578063f2fde38b146107b8578063f8b45b05146107d8578063fe72b27a146107ee57600080fd5b8063a45b154a146106a7578063a4c82a00146106c6578063a9059cbb146106dc578063b62496f5146106fc578063bf56b3711461072c578063c02466681461074257600080fd5b80638a8c523c116101135780638a8c523c146106095780638da5cb5b1461061e57806395d89b411461063c5780639a7a23d6146106515780639ec22c0e14610671578063a457c2d71461068757600080fd5b8063730c18881461057c578063751039fc1461059c5780637571336a146105b1578063768dc710146105d15780638129fc1c1461060157600080fd5b80632dc0562d116101e8578063402fae58116101ac578063402fae58146104b257806349bd5a5e146104c85780634a62bb65146104e85780635e7f67181461050957806370a0823114610531578063715018a61461056757600080fd5b80632dc0562d1461041c5780632e82f1a01461043c578063313ce567146104565780633690fe4014610472578063395093511461049257600080fd5b80631694505e1161023a5780631694505e1461034f57806318160ddd1461039b578063184c16c5146103ba578063199ffc72146103d057806323b872dd146103e65780632c3e486c1461040657600080fd5b806306fdde03146102825780630850935f146102ad578063095ea7b3146102cf57806310d5de53146102ff578063128f72c31461032f57600080fd5b3661027d57005b600080fd5b34801561028e57600080fd5b5061029761080e565b6040516102a49190611fcb565b60405180910390f35b3480156102b957600080fd5b506102cd6102c8366004612029565b6108a0565b005b3480156102db57600080fd5b506102ef6102ea3660046120c2565b61091f565b60405190151581526020016102a4565b34801561030b57600080fd5b506102ef61031a3660046120ee565b60096020526000908152604090205460ff1681565b34801561033b57600080fd5b506102cd61034a36600461210b565b610939565b34801561035b57600080fd5b506103837f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d81565b6040516001600160a01b0390911681526020016102a4565b3480156103a757600080fd5b506002545b6040519081526020016102a4565b3480156103c657600080fd5b506103ac60125481565b3480156103dc57600080fd5b506103ac600e5481565b3480156103f257600080fd5b506102ef610401366004612124565b610946565b34801561041257600080fd5b506103ac60105481565b34801561042857600080fd5b50601b54610383906001600160a01b031681565b34801561044857600080fd5b50600f546102ef9060ff1681565b34801561046257600080fd5b50604051601281526020016102a4565b34801561047e57600080fd5b506102cd61048d366004612165565b610968565b34801561049e57600080fd5b506102ef6104ad3660046120c2565b6109c4565b3480156104be57600080fd5b506103ac601a5481565b3480156104d457600080fd5b50601654610383906001600160a01b031681565b3480156104f457600080fd5b506018546102ef906301000000900460ff1681565b34801561051557600080fd5b50600c54600d54604080519283526020830191909152016102a4565b34801561053d57600080fd5b506103ac61054c3660046120ee565b6001600160a01b031660009081526020819052604090205490565b34801561057357600080fd5b506102cd6109e6565b34801561058857600080fd5b506102cd610597366004612180565b6109fa565b3480156105a857600080fd5b506102ef610b06565b3480156105bd57600080fd5b506102cd6105cc3660046121ac565b610b2d565b3480156105dd57600080fd5b506102ef6105ec3660046120ee565b60086020526000908152604090205460ff1681565b6102cd610b60565b34801561061557600080fd5b506102cd610e5c565b34801561062a57600080fd5b506005546001600160a01b0316610383565b34801561064857600080fd5b50610297610e85565b34801561065d57600080fd5b506102cd61066c3660046121ac565b610e94565b34801561067d57600080fd5b506103ac60135481565b34801561069357600080fd5b506102ef6106a23660046120c2565b610f2e565b3480156106b357600080fd5b506018546102ef90610100900460ff1681565b3480156106d257600080fd5b506103ac60115481565b3480156106e857600080fd5b506102ef6106f73660046120c2565b610fb4565b34801561070857600080fd5b506102ef6107173660046120ee565b60176020526000908152604090205460ff1681565b34801561073857600080fd5b506103ac60195481565b34801561074e57600080fd5b506102cd61075d3660046121ac565b610fc8565b34801561076e57600080fd5b506103ac60145481565b34801561078457600080fd5b506018546102ef9062010000900460ff1681565b3480156107a457600080fd5b506103ac6107b33660046121e1565b610ffb565b3480156107c457600080fd5b506102cd6107d33660046120ee565b611026565b3480156107e457600080fd5b506103ac60155481565b3480156107fa57600080fd5b506102ef61080936600461210b565b61109f565b60606003805461081d9061221a565b80601f01602080910402602001604051908101604052809291908181526020018280546108499061221a565b80156108965780601f1061086b57610100808354040283529160200191610896565b820191906000526020600020905b81548152906001019060200180831161087957829003601f168201915b5050505050905090565b6108a8611289565b60005b828110156109195781600860008686858181106108ca576108ca612254565b90506020020160208101906108df91906120ee565b6001600160a01b031681526020810191909152604001600020805460ff19169115159190911790558061091181612280565b9150506108ab565b50505050565b60003361092d8185856112e3565b60019150505b92915050565b610941611289565b601a55565b600033610954858285611407565b61095f85858561147b565b95945050505050565b610970611289565b601880548215156101000261ff00199091161790556040517f67cbe9d16793e5cd880dafc6b9ad4a568545d35aa475a92dc80ded5dba515474906109b990831515815260200190565b60405180910390a150565b60003361092d8185856109d78383610ffb565b6109e19190612299565b6112e3565b6109ee611289565b6109f86000611b24565b565b610a02611289565b610258831015610a755760405162461bcd60e51b815260206004820152603360248201527f63616e6e6f7420736574206275796261636b206d6f7265206f6674656e207468604482015272616e206576657279203130206d696e7574657360681b60648201526084015b60405180910390fd5b6103e88211158015610a85575060015b610aea5760405162461bcd60e51b815260206004820152603060248201527f4d75737420736574206175746f204c50206275726e2070657263656e7420626560448201526f747765656e20302520616e642031302560801b6064820152608401610a6c565b601092909255600e55600f805460ff1916911515919091179055565b6000610b10611289565b506018805463ff000000191690556002600c819055600d55600190565b610b35611289565b6001600160a01b03919091166000908152600960205260409020805460ff1916911515919091179055565b610b68611289565b7f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610bc6573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610bea91906122ac565b6001600160a01b031663c9c65396307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610c57573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610c7b91906122ac565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015610cc8573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610cec91906122ac565b601680546001600160a01b0319166001600160a01b0392909216919091179055610d39307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6000196112e3565b601654610d50906001600160a01b03166001610b2d565b7f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663f305d7193430610da0306001600160a01b031660009081526020819052604090205490565b600080610db56005546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af1158015610e1d573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190610e4291906122c9565b50506016546109f891506001600160a01b03166001611b76565b610e64611289565b6018805462ff00001916620100001790556019546000036109f85743601955565b60606004805461081d9061221a565b610e9c611289565b6016546001600160a01b0390811690831603610f205760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b65725061697273000000000000006064820152608401610a6c565b610f2a8282611b76565b5050565b60003381610f3c8286610ffb565b905083811015610f9c5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b6064820152608401610a6c565b610fa982868684036112e3565b506001949350505050565b6000610fc133848461147b565b9392505050565b610fd0611289565b6001600160a01b03919091166000908152600860205260409020805460ff1916911515919091179055565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b61102e611289565b6001600160a01b0381166110935760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610a6c565b61109c81611b24565b50565b60006110a9611289565b6012546013546110b99190612299565b42116111075760405162461bcd60e51b815260206004820181905260248201527f4d757374207761697420666f7220636f6f6c646f776e20746f2066696e6973686044820152606401610a6c565b6103e882111561116c5760405162461bcd60e51b815260206004820152602a60248201527f4d6179206e6f74206e756b65206d6f7265207468616e20313025206f6620746f60448201526906b656e7320696e204c560b41b6064820152608401610a6c565b426013556016546040516370a0823160e01b81526001600160a01b03909116600482015260009030906370a0823190602401602060405180830381865afa1580156111bb573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111df91906122f7565b905060006111f96127106111f38487611ba1565b90611bad565b9050801561121a5760165461121a906001600160a01b031661dead83611bb9565b6016546040805160016209351760e01b0319815290516001600160a01b0390921691829163fff6cae991600480830192600092919082900301818387803b15801561126457600080fd5b505af1158015611278573d6000803e3d6000fd5b50505050600193505050505b919050565b6005546001600160a01b031633146109f85760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610a6c565b6001600160a01b0383166113455760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610a6c565b6001600160a01b0382166113a65760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610a6c565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006114138484610ffb565b90506000198114610919578181101561146e5760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e63650000006044820152606401610a6c565b61091984848484036112e3565b60006001600160a01b0384166114a35760405162461bcd60e51b8152600401610a6c90612310565b6001600160a01b0383166114c95760405162461bcd60e51b8152600401610a6c90612355565b6000821161152b5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b6064820152608401610a6c565b6018546301000000900460ff16156118a6576005546001600160a01b0385811691161480159061156957506005546001600160a01b03848116911614155b801561157d57506001600160a01b03831615155b801561159457506001600160a01b03831661dead14155b80156115a3575060185460ff16155b156118a65760185462010000900460ff161580156115fe57506001600160a01b03841660009081526008602052604090205460ff161580156115fe57506001600160a01b03831660009081526008602052604090205460ff16155b156116405760405162461bcd60e51b815260206004820152601260248201527143616e2774207472616e73666572206e6f7760701b6044820152606401610a6c565b6001600160a01b03841660009081526017602052604090205460ff16801561168157506001600160a01b03831660009081526009602052604090205460ff16155b15611765576014548211156116f65760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b6064820152608401610a6c565b6015546001600160a01b03841660009081526020819052604090205461171c9084612299565b11156117605760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610a6c565b6118a6565b6001600160a01b03831660009081526017602052604090205460ff1680156117a657506001600160a01b03841660009081526009602052604090205460ff16155b1561181c576014548211156117605760405162461bcd60e51b815260206004820152603660248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152751036b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760511b6064820152608401610a6c565b6001600160a01b03831660009081526009602052604090205460ff166118a6576015546001600160a01b0384166000908152602081905260409020546118629084612299565b11156118a65760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610a6c565b30600090815260208190526040902054801580159081906118ca575060185460ff16155b80156118ef57506001600160a01b03861660009081526017602052604090205460ff16155b801561191457506001600160a01b03861660009081526008602052604090205460ff16155b80156119275750601854610100900460ff165b1561194d576018805460ff1916600117905561194282611ce3565b6018805460ff191690555b60185460ff1615801561197857506001600160a01b03851660009081526017602052604090205460ff165b80156119865750600f5460ff165b80156119a1575060105460115461199d9190612299565b4210155b80156119c557506001600160a01b03861660009081526008602052604090205460ff165b156119d4576119d2611eaa565b505b6001600160a01b03861660009081526008602052604090205460019060ff1680611a1657506001600160a01b03861660009081526008602052604090205460ff165b15611a1f575060005b8015611b0c576001600160a01b038716600090815260176020526040812054819060ff1615611a65576064600c5488611a589190612398565b611a6291906123af565b90505b6001600160a01b03881660009081526017602052604090205460ff1615611aa3576064600d5488611a969190612398565b611aa091906123af565b90505b8091506000611ac78a6001600160a01b031660009081526020819052604090205490565b9050878103611aeb57611ade6305f5e100896123af565b611ae890896123d1565b97505b611af583896123d1565b97508215611b0857611b088a3085611bb9565b5050505b611b17878787611bb9565b5060019695505050505050565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b03919091166000908152601760205260409020805460ff1916911515919091179055565b6000610fc18284612398565b6000610fc182846123af565b6001600160a01b038316611bdf5760405162461bcd60e51b8152600401610a6c90612310565b6001600160a01b038216611c055760405162461bcd60e51b8152600401610a6c90612355565b6001600160a01b03831660009081526020819052604090205481811015611c7d5760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610a6c565b6001600160a01b03848116600081815260208181526040808320878703905593871680835291849020805487019055925185815290927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a3610919565b6040805160028082526060820183526000926020830190803683370190505090503081600081518110611d1857611d18612254565b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611d96573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611dba91906122ac565b81600181518110611dcd57611dcd612254565b60200260200101906001600160a01b031690816001600160a01b031681525050611e18307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d846112e3565b601b5460405163791ac94760e01b81526001600160a01b037f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d81169263791ac94792611e749287926000928892919091169042906004016123e4565b600060405180830381600087803b158015611e8e57600080fd5b505af1158015611ea2573d6000803e3d6000fd5b505050505050565b426011556016546040516370a0823160e01b81526001600160a01b039091166004820152600090819030906370a0823190602401602060405180830381865afa158015611efb573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611f1f91906122f7565b90506000611f3e6127106111f3600e5485611ba190919063ffffffff16565b90508015611f5f57601654611f5f906001600160a01b031661dead83611bb9565b6016546040805160016209351760e01b0319815290516001600160a01b0390921691829163fff6cae991600480830192600092919082900301818387803b158015611fa957600080fd5b505af1158015611fbd573d6000803e3d6000fd5b505050506001935050505090565b600060208083528351808285015260005b81811015611ff857858101830151858201604001528201611fdc565b506000604082860101526040601f19601f8301168501019250505092915050565b8035801515811461128457600080fd5b60008060006040848603121561203e57600080fd5b833567ffffffffffffffff8082111561205657600080fd5b818601915086601f83011261206a57600080fd5b81358181111561207957600080fd5b8760208260051b850101111561208e57600080fd5b6020928301955093506120a49186019050612019565b90509250925092565b6001600160a01b038116811461109c57600080fd5b600080604083850312156120d557600080fd5b82356120e0816120ad565b946020939093013593505050565b60006020828403121561210057600080fd5b8135610fc1816120ad565b60006020828403121561211d57600080fd5b5035919050565b60008060006060848603121561213957600080fd5b8335612144816120ad565b92506020840135612154816120ad565b929592945050506040919091013590565b60006020828403121561217757600080fd5b610fc182612019565b60008060006060848603121561219557600080fd5b83359250602084013591506120a460408501612019565b600080604083850312156121bf57600080fd5b82356121ca816120ad565b91506121d860208401612019565b90509250929050565b600080604083850312156121f457600080fd5b82356121ff816120ad565b9150602083013561220f816120ad565b809150509250929050565b600181811c9082168061222e57607f821691505b60208210810361224e57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b6000600182016122925761229261226a565b5060010190565b808201808211156109335761093361226a565b6000602082840312156122be57600080fd5b8151610fc1816120ad565b6000806000606084860312156122de57600080fd5b8351925060208401519150604084015190509250925092565b60006020828403121561230957600080fd5b5051919050565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b80820281158282048414176109335761093361226a565b6000826123cc57634e487b7160e01b600052601260045260246000fd5b500490565b818103818111156109335761093361226a565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156124345784516001600160a01b03168352938301939183019160010161240f565b50506001600160a01b0396909616606085015250505060800152939250505056fea2646970667358221220fe7b7c976064783d21b0952a3e127b7d09d4f23ccf12d04295c68e6fd66f647a64736f6c63430008130033

Deployed Bytecode Sourcemap

43497:12083:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4437:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;46213:259;;;;;;;;;;-1:-1:-1;46213:259:0;;;;;:::i;:::-;;:::i;:::-;;6854:226;;;;;;;;;;-1:-1:-1;6854:226:0;;;;;:::i;:::-;;:::i;:::-;;;2047:14:1;;2040:22;2022:41;;2010:2;1995:18;6854:226:0;1882:187:1;43792:63:0;;;;;;;;;;-1:-1:-1;43792:63:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;46985:110;;;;;;;;;;-1:-1:-1;46985:110:0;;;;;:::i;:::-;;:::i;44390:121::-;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;2700:32:1;;;2682:51;;2670:2;2655:18;44390:121:0;2511:228:1;5557:108:0;;;;;;;;;;-1:-1:-1;5645:12:0;;5557:108;;;2890:25:1;;;2878:2;2863:18;5557:108:0;2744:177:1;44217:47:0;;;;;;;;;;;;;;;;44046:38;;;;;;;;;;;;;;;;49044:305;;;;;;;;;;-1:-1:-1;49044:305:0;;;;;:::i;:::-;;:::i;44130:42::-;;;;;;;;;;;;;;;;44888:69;;;;;;;;;;-1:-1:-1;44888:69:0;;;;-1:-1:-1;;;;;44888:69:0;;;44091:32;;;;;;;;;;-1:-1:-1;44091:32:0;;;;;;;;5399:93;;;;;;;;;;-1:-1:-1;5399:93:0;;5482:2;3737:36:1;;3725:2;3710:18;5399:93:0;3595:184:1;46480:168:0;;;;;;;;;;-1:-1:-1;46480:168:0;;;;;:::i;:::-;;:::i;8364:263::-;;;;;;;;;;-1:-1:-1;8364:263:0;;;;;:::i;:::-;;:::i;44813:66::-;;;;;;;;;;;;;;;;44518:28;;;;;;;;;;-1:-1:-1;44518:28:0;;;;-1:-1:-1;;;;;44518:28:0;;;44733:33;;;;;;;;;;-1:-1:-1;44733:33:0;;;;;;;;;;;48434:122;;;;;;;;;;-1:-1:-1;48520:12:0;;48534:13;;48434:122;;;4143:25:1;;;4199:2;4184:18;;4177:34;;;;4116:18;48434:122:0;3969:248:1;5728:143:0;;;;;;;;;;-1:-1:-1;5728:143:0;;;;;:::i;:::-;-1:-1:-1;;;;;5845:18:0;5818:7;5845:18;;;;;;;;;;;;5728:143;19320:103;;;;;;;;;;;;;:::i;47871:555::-;;;;;;;;;;-1:-1:-1;47871:555:0;;;;;:::i;:::-;;:::i;46801:176::-;;;;;;;;;;;;;:::i;47103:169::-;;;;;;;;;;-1:-1:-1;47103:169:0;;;;;:::i;:::-;;:::i;43735:50::-;;;;;;;;;;-1:-1:-1;43735:50:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;45570:635;;;:::i;46656:137::-;;;;;;;;;;;;;:::i;18672:87::-;;;;;;;;;;-1:-1:-1;18745:6:0;;-1:-1:-1;;;;;18745:6:0;18672:87;;4656:104;;;;;;;;;;;;;:::i;47419:306::-;;;;;;;;;;-1:-1:-1;47419:306:0;;;;;:::i;:::-;;:::i;44271:35::-;;;;;;;;;;;;;;;;9130:498;;;;;;;;;;-1:-1:-1;9130:498:0;;;;;:::i;:::-;;:::i;44648:39::-;;;;;;;;;;-1:-1:-1;44648:39:0;;;;;;;;;;;44179:29;;;;;;;;;;;;;;;;48860:176;;;;;;;;;;-1:-1:-1;48860:176:0;;;;;:::i;:::-;;:::i;44555:57::-;;;;;;;;;;-1:-1:-1;44555:57:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;44775:29;;;;;;;;;;;;;;;;47280:131;;;;;;;;;;-1:-1:-1;47280:131:0;;;;;:::i;:::-;;:::i;44315:35::-;;;;;;;;;;;;;;;;44694:32;;;;;;;;;;-1:-1:-1;44694:32:0;;;;;;;;;;;6358:176;;;;;;;;;;-1:-1:-1;6358:176:0;;;;;:::i;:::-;;:::i;19578:238::-;;;;;;;;;;-1:-1:-1;19578:238:0;;;;;:::i;:::-;;:::i;44357:24::-;;;;;;;;;;;;;;;;54567:1010;;;;;;;;;;-1:-1:-1;54567:1010:0;;;;;:::i;:::-;;:::i;4437:100::-;4491:13;4524:5;4517:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4437:100;:::o;46213:259::-;18558:13;:11;:13::i;:::-;46355:9:::1;46350:115;46370:19:::0;;::::1;46350:115;;;46445:8;46411:18;:31;46430:8;;46439:1;46430:11;;;;;;;:::i;:::-;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;;;;46411:31:0::1;::::0;;::::1;::::0;::::1;::::0;;;;;;-1:-1:-1;46411:31:0;:42;;-1:-1:-1;;46411:42:0::1;::::0;::::1;;::::0;;;::::1;::::0;;46391:3;::::1;::::0;::::1;:::i;:::-;;;;46350:115;;;;46213:259:::0;;;:::o;6854:226::-;6962:4;3523:10;7018:32;3523:10;7034:7;7043:6;7018:8;:32::i;:::-;7068:4;7061:11;;;6854:226;;;;;:::o;46985:110::-;18558:13;:11;:13::i;:::-;47060:21:::1;:27:::0;46985:110::o;49044:305::-;49184:4;3523:10;49242:40;49258:6;3523:10;49275:6;49242:15;:40::i;:::-;49300:41;49315:6;49323:9;49334:6;49300:14;:41::i;:::-;49293:48;49044:305;-1:-1:-1;;;;;49044:305:0:o;46480:168::-;18558:13;:11;:13::i;:::-;46556:20:::1;:31:::0;;;::::1;;;;-1:-1:-1::0;;46556:31:0;;::::1;;::::0;;46603:37:::1;::::0;::::1;::::0;::::1;::::0;46579:8;2047:14:1;2040:22;2022:41;;2010:2;1995:18;;1882:187;46603:37:0::1;;;;;;;;46480:168:::0;:::o;8364:263::-;8477:4;3523:10;8533:64;3523:10;8549:7;8586:10;8558:25;3523:10;8549:7;8558:9;:25::i;:::-;:38;;;;:::i;:::-;8533:8;:64::i;19320:103::-;18558:13;:11;:13::i;:::-;19385:30:::1;19412:1;19385:18;:30::i;:::-;19320:103::o:0;47871:555::-;18558:13;:11;:13::i;:::-;48073:3:::1;48050:19;:26;;48028:127;;;::::0;-1:-1:-1;;;48028:127:0;;6377:2:1;48028:127:0::1;::::0;::::1;6359:21:1::0;6416:2;6396:18;;;6389:30;6455:34;6435:18;;;6428:62;-1:-1:-1;;;6506:18:1;;;6499:49;6565:19;;48028:127:0::1;;;;;;;;;48200:4;48188:8;:16;;:33;;;;-1:-1:-1::0;48208:13:0;48188:33:::1;48166:131;;;::::0;-1:-1:-1;;;48166:131:0;;6797:2:1;48166:131:0::1;::::0;::::1;6779:21:1::0;6836:2;6816:18;;;6809:30;6875:34;6855:18;;;6848:62;-1:-1:-1;;;6926:18:1;;;6919:46;6982:19;;48166:131:0::1;6595:412:1::0;48166:131:0::1;48308:15;:37:::0;;;;48356:16:::1;:27:::0;48394:13:::1;:24:::0;;-1:-1:-1;;48394:24:0::1;::::0;::::1;;::::0;;;::::1;::::0;;47871:555::o;46801:176::-;46853:4;18558:13;:11;:13::i;:::-;-1:-1:-1;46870:14:0::1;:22:::0;;-1:-1:-1;;46870:22:0::1;::::0;;46918:1:::1;46903:12;:16:::0;;;46930:13:::1;:17:::0;46870:22;46801:176;:::o;47103:169::-;18558:13;:11;:13::i;:::-;-1:-1:-1;;;;;47218:39:0;;;::::1;;::::0;;;:31:::1;:39;::::0;;;;:46;;-1:-1:-1;;47218:46:0::1;::::0;::::1;;::::0;;;::::1;::::0;;47103:169::o;45570:635::-;18558:13;:11;:13::i;:::-;45664:15:::1;-1:-1:-1::0;;;;;45664:23:0::1;;:25;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;;;;45646:55:0::1;;45724:4;45744:15;-1:-1:-1::0;;;;;45744:20:0::1;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;45646:131;::::0;-1:-1:-1;;;;;;45646:131:0::1;::::0;;;;;;-1:-1:-1;;;;;7498:15:1;;;45646:131:0::1;::::0;::::1;7480:34:1::0;7550:15;;7530:18;;;7523:43;7415:18;;45646:131:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;45630:13;:147:::0;;-1:-1:-1;;;;;;45630:147:0::1;-1:-1:-1::0;;;;;45630:147:0;;;::::1;::::0;;;::::1;::::0;;45790:62:::1;45807:4;45822:15;-1:-1:-1::0;;45790:8:0::1;:62::i;:::-;45891:13;::::0;45865:46:::1;::::0;-1:-1:-1;;;;;45891:13:0::1;::::0;45865:25:::1;:46::i;:::-;45924:15;-1:-1:-1::0;;;;;45924:31:0::1;;45963:9;45996:4;46016:24;46034:4;-1:-1:-1::0;;;;;5845:18:0;5818:7;5845:18;;;;;;;;;;;;5728:143;46016:24:::1;46055:1;46071::::0;46087:7:::1;18745:6:::0;;-1:-1:-1;;;;;18745:6:0;;18672:87;46087:7:::1;45924:211;::::0;::::1;::::0;;;-1:-1:-1;;;;;;45924:211:0;;;-1:-1:-1;;;;;7936:15:1;;;45924:211:0::1;::::0;::::1;7918:34:1::0;7968:18;;;7961:34;;;;8011:18;;;8004:34;;;;8054:18;;;8047:34;8118:15;;;8097:19;;;8090:44;46109:15:0::1;8150:19:1::0;;;8143:35;7852:19;;45924:211:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;46177:13:0::1;::::0;46148:49:::1;::::0;-1:-1:-1;;;;;;46177:13:0::1;::::0;46148:28:::1;:49::i;46656:137::-:0;18558:13;:11;:13::i;:::-;46709:12:::1;:19:::0;;-1:-1:-1;;46709:19:0::1;::::0;::::1;::::0;;46743:10:::1;::::0;46709:19;46743:15;46739:46:::1;;46773:12;46760:10;:25:::0;46656:137::o;4656:104::-;4712:13;4745:7;4738:14;;;;;:::i;47419:306::-;18558:13;:11;:13::i;:::-;47565::::1;::::0;-1:-1:-1;;;;;47565:13:0;;::::1;47557:21:::0;;::::1;::::0;47535:128:::1;;;::::0;-1:-1:-1;;;47535:128:0;;8702:2:1;47535:128:0::1;::::0;::::1;8684:21:1::0;8741:2;8721:18;;;8714:30;8780:34;8760:18;;;8753:62;8851:27;8831:18;;;8824:55;8896:19;;47535:128:0::1;8500:421:1::0;47535:128:0::1;47676:41;47705:4;47711:5;47676:28;:41::i;:::-;47419:306:::0;;:::o;9130:498::-;9248:4;3523:10;9248:4;9331:25;3523:10;9348:7;9331:9;:25::i;:::-;9304:52;;9409:15;9389:16;:35;;9367:122;;;;-1:-1:-1;;;9367:122:0;;9128:2:1;9367:122:0;;;9110:21:1;9167:2;9147:18;;;9140:30;9206:34;9186:18;;;9179:62;-1:-1:-1;;;9257:18:1;;;9250:35;9302:19;;9367:122:0;8926:401:1;9367:122:0;9525:60;9534:5;9541:7;9569:15;9550:16;:34;9525:8;:60::i;:::-;-1:-1:-1;9616:4:0;;9130:498;-1:-1:-1;;;;9130:498:0:o;48860:176::-;48964:4;48988:40;3523:10;49017:2;49021:6;48988:14;:40::i;:::-;48981:47;48860:176;-1:-1:-1;;;48860:176:0:o;47280:131::-;18558:13;:11;:13::i;:::-;-1:-1:-1;;;;;47365:27:0;;;::::1;;::::0;;;:18:::1;:27;::::0;;;;:38;;-1:-1:-1;;47365:38:0::1;::::0;::::1;;::::0;;;::::1;::::0;;47280:131::o;6358:176::-;-1:-1:-1;;;;;6499:18:0;;;6472:7;6499:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;6358:176::o;19578:238::-;18558:13;:11;:13::i;:::-;-1:-1:-1;;;;;19681:22:0;::::1;19659:110;;;::::0;-1:-1:-1;;;19659:110:0;;9534:2:1;19659:110:0::1;::::0;::::1;9516:21:1::0;9573:2;9553:18;;;9546:30;9612:34;9592:18;;;9585:62;-1:-1:-1;;;9663:18:1;;;9656:36;9709:19;;19659:110:0::1;9332:402:1::0;19659:110:0::1;19780:28;19799:8;19780:18;:28::i;:::-;19578:238:::0;:::o;54567:1010::-;54667:4;18558:13;:11;:13::i;:::-;54747:19:::1;;54724:20;;:42;;;;:::i;:::-;54706:15;:60;54684:142;;;::::0;-1:-1:-1;;;54684:142:0;;9941:2:1;54684:142:0::1;::::0;::::1;9923:21:1::0;;;9960:18;;;9953:30;10019:34;9999:18;;;9992:62;10071:18;;54684:142:0::1;9739:356:1::0;54684:142:0::1;54856:4;54845:7;:15;;54837:70;;;::::0;-1:-1:-1;;;54837:70:0;;10302:2:1;54837:70:0::1;::::0;::::1;10284:21:1::0;10341:2;10321:18;;;10314:30;10380:34;10360:18;;;10353:62;-1:-1:-1;;;10431:18:1;;;10424:40;10481:19;;54837:70:0::1;10100:406:1::0;54837:70:0::1;54941:15;54918:20;:38:::0;55057:13:::1;::::0;55042:29:::1;::::0;-1:-1:-1;;;55042:29:0;;-1:-1:-1;;;;;55057:13:0;;::::1;55042:29;::::0;::::1;2682:51:1::0;55011:28:0::1;::::0;55042:4:::1;::::0;:14:::1;::::0;2655:18:1;;55042:29:0::1;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;55011:60:::0;-1:-1:-1;55121:20:0::1;55144:44;55182:5;55144:33;55011:60:::0;55169:7;55144:24:::1;:33::i;:::-;:37:::0;::::1;:44::i;:::-;55121:67:::0;-1:-1:-1;55293:16:0;;55289:110:::1;;55342:13;::::0;55326:61:::1;::::0;-1:-1:-1;;;;;55342:13:0::1;55365:6;55374:12:::0;55326:15:::1;:61::i;:::-;55511:13;::::0;55536:11:::1;::::0;;-1:-1:-1;;;;;;55536:11:0;;;;-1:-1:-1;;;;;55511:13:0;;::::1;::::0;;;55536:9:::1;::::0;:11:::1;::::0;;::::1;::::0;55474:19:::1;::::0;55536:11;;;;;;;55474:19;55511:13;55536:11;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;55565:4;55558:11;;;;;18582:1;54567:1010:::0;;;:::o;18837:132::-;18745:6;;-1:-1:-1;;;;;18745:6:0;3523:10;18901:23;18893:68;;;;-1:-1:-1;;;18893:68:0;;10902:2:1;18893:68:0;;;10884:21:1;;;10921:18;;;10914:30;10980:34;10960:18;;;10953:62;11032:18;;18893:68:0;10700:356:1;13256:380:0;-1:-1:-1;;;;;13392:19:0;;13384:68;;;;-1:-1:-1;;;13384:68:0;;11263:2:1;13384:68:0;;;11245:21:1;11302:2;11282:18;;;11275:30;11341:34;11321:18;;;11314:62;-1:-1:-1;;;11392:18:1;;;11385:34;11436:19;;13384:68:0;11061:400:1;13384:68:0;-1:-1:-1;;;;;13471:21:0;;13463:68;;;;-1:-1:-1;;;13463:68:0;;11668:2:1;13463:68:0;;;11650:21:1;11707:2;11687:18;;;11680:30;11746:34;11726:18;;;11719:62;-1:-1:-1;;;11797:18:1;;;11790:32;11839:19;;13463:68:0;11466:398:1;13463:68:0;-1:-1:-1;;;;;13544:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;13596:32;;2890:25:1;;;13596:32:0;;2863:18:1;13596:32:0;;;;;;;13256:380;;;:::o;13927:502::-;14062:24;14089:25;14099:5;14106:7;14089:9;:25::i;:::-;14062:52;;-1:-1:-1;;14129:16:0;:37;14125:297;;14229:6;14209:16;:26;;14183:117;;;;-1:-1:-1;;;14183:117:0;;12071:2:1;14183:117:0;;;12053:21:1;12110:2;12090:18;;;12083:30;12149:31;12129:18;;;12122:59;12198:18;;14183:117:0;11869:353:1;14183:117:0;14344:51;14353:5;14360:7;14388:6;14369:16;:25;14344:8;:51::i;49357:3833::-;49474:4;-1:-1:-1;;;;;49499:18:0;;49491:68;;;;-1:-1:-1;;;49491:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;49578:16:0;;49570:64;;;;-1:-1:-1;;;49570:64:0;;;;;;;:::i;:::-;49662:1;49653:6;:10;49645:64;;;;-1:-1:-1;;;49645:64:0;;13239:2:1;49645:64:0;;;13221:21:1;13278:2;13258:18;;;13251:30;13317:34;13297:18;;;13290:62;-1:-1:-1;;;13368:18:1;;;13361:39;13417:19;;49645:64:0;13037:405:1;49645:64:0;49726:14;;;;;;;49722:1687;;;18745:6;;-1:-1:-1;;;;;49779:15:0;;;18745:6;;49779:15;;;;:49;;-1:-1:-1;18745:6:0;;-1:-1:-1;;;;;49815:13:0;;;18745:6;;49815:13;;49779:49;:86;;;;-1:-1:-1;;;;;;49849:16:0;;;;49779:86;:128;;;;-1:-1:-1;;;;;;49886:21:0;;49900:6;49886:21;;49779:128;:165;;;;-1:-1:-1;49929:15:0;;;;49928:16;49779:165;49757:1641;;;50006:12;;;;;;;50005:13;:92;;;;-1:-1:-1;;;;;;50045:24:0;;;;;;:18;:24;;;;;;;;50044:25;:52;;;;-1:-1:-1;;;;;;50074:22:0;;;;;;:18;:22;;;;;;;;50073:23;50044:52;49979:209;;;50140:28;;-1:-1:-1;;;50140:28:0;;13649:2:1;50140:28:0;;;13631:21:1;13688:2;13668:18;;;13661:30;-1:-1:-1;;;13707:18:1;;;13700:48;13765:18;;50140:28:0;13447:342:1;49979:209:0;-1:-1:-1;;;;;50262:31:0;;;;;;:25;:31;;;;;;;;:92;;;;-1:-1:-1;;;;;;50319:35:0;;;;;;:31;:35;;;;;;;;50318:36;50262:92;50236:1147;;;50441:20;;50431:6;:30;;50397:169;;;;-1:-1:-1;;;50397:169:0;;13996:2:1;50397:169:0;;;13978:21:1;14035:2;14015:18;;;14008:30;14074:34;14054:18;;;14047:62;-1:-1:-1;;;14125:18:1;;;14118:51;14186:19;;50397:169:0;13794:417:1;50397:169:0;50649:9;;-1:-1:-1;;;;;5845:18:0;;5818:7;5845:18;;;;;;;;;;;50623:22;;:6;:22;:::i;:::-;:35;;50589:140;;;;-1:-1:-1;;;50589:140:0;;14418:2:1;50589:140:0;;;14400:21:1;14457:2;14437:18;;;14430:30;-1:-1:-1;;;14476:18:1;;;14469:49;14535:18;;50589:140:0;14216:343:1;50589:140:0;50236:1147;;;-1:-1:-1;;;;;50827:29:0;;;;;;:25;:29;;;;;;;;:92;;;;-1:-1:-1;;;;;;50882:37:0;;;;;;:31;:37;;;;;;;;50881:38;50827:92;50801:582;;;51006:20;;50996:6;:30;;50962:170;;;;-1:-1:-1;;;50962:170:0;;14766:2:1;50962:170:0;;;14748:21:1;14805:2;14785:18;;;14778:30;14844:34;14824:18;;;14817:62;-1:-1:-1;;;14895:18:1;;;14888:52;14957:19;;50962:170:0;14564:418:1;50801:582:0;-1:-1:-1;;;;;51163:35:0;;;;;;:31;:35;;;;;;;;51158:225;;51283:9;;-1:-1:-1;;;;;5845:18:0;;5818:7;5845:18;;;;;;;;;;;51257:22;;:6;:22;:::i;:::-;:35;;51223:140;;;;-1:-1:-1;;;51223:140:0;;14418:2:1;51223:140:0;;;14400:21:1;14457:2;14437:18;;;14430:30;-1:-1:-1;;;14476:18:1;;;14469:49;14535:18;;51223:140:0;14216:343:1;51223:140:0;51470:4;51421:28;5845:18;;;;;;;;;;;51516:24;;;;;;;51569:52;;-1:-1:-1;51606:15:0;;;;51605:16;51569:52;:101;;;;-1:-1:-1;;;;;;51639:31:0;;;;;;:25;:31;;;;;;;;51638:32;51569:101;:143;;;;-1:-1:-1;;;;;;51688:24:0;;;;;;:18;:24;;;;;;;;51687:25;51569:143;:180;;;;-1:-1:-1;51729:20:0;;;;;;;51569:180;51551:358;;;51776:15;:22;;-1:-1:-1;;51776:22:0;51794:4;51776:22;;;51813:46;51838:20;51813:24;:46::i;:::-;51874:15;:23;;-1:-1:-1;;51874:23:0;;;51551:358;51940:15;;;;51939:16;:62;;;;-1:-1:-1;;;;;;51972:29:0;;;;;;:25;:29;;;;;;;;51939:62;:92;;;;-1:-1:-1;52018:13:0;;;;51939:92;:160;;;;;52084:15;;52067:14;;:32;;;;:::i;:::-;52048:15;:51;;51939:160;:201;;;;-1:-1:-1;;;;;;52116:24:0;;;;;;:18;:24;;;;;;;;51939:201;51921:287;;;52167:29;:27;:29::i;:::-;;51921:287;-1:-1:-1;;;;;52401:24:0;;52281:12;52401:24;;;:18;:24;;;;;;52296:4;;52401:24;;;:50;;-1:-1:-1;;;;;;52429:22:0;;;;;;:18;:22;;;;;;;;52401:50;52397:98;;;-1:-1:-1;52478:5:0;52397:98;52511:7;52507:616;;;-1:-1:-1;;;;;52593:31:0;;52535:12;52593:31;;;:25;:31;;;;;;52535:12;;52593:31;;52589:108;;;52678:3;52662:12;;52653:6;:21;;;;:::i;:::-;52652:29;;;;:::i;:::-;52645:36;;52589:108;-1:-1:-1;;;;;52715:29:0;;;;;;:25;:29;;;;;;;;52711:107;;;52799:3;52782:13;;52773:6;:22;;;;:::i;:::-;52772:30;;;;:::i;:::-;52765:37;;52711:107;52839:4;52832:11;;52860:19;52882:15;52892:4;-1:-1:-1;;;;;5845:18:0;5818:7;5845:18;;;;;;;;;;;;5728:143;52882:15;52860:37;;52931:6;52916:11;:21;52912:98;;52977:16;52986:7;52977:6;:16;:::i;:::-;52967:27;;:6;:27;:::i;:::-;52958:36;;52912:98;53033:13;53042:4;53033:6;:13;:::i;:::-;53024:22;-1:-1:-1;53065:8:0;;53061:50;;53075:36;53085:4;53099;53106;53075:9;:36::i;:::-;52520:603;;;52507:616;53133:27;53143:4;53149:2;53153:6;53133:9;:27::i;:::-;-1:-1:-1;53178:4:0;;49357:3833;-1:-1:-1;;;;;;49357:3833:0:o;19976:191::-;20069:6;;;-1:-1:-1;;;;;20086:17:0;;;-1:-1:-1;;;;;;20086:17:0;;;;;;;20119:40;;20069:6;;;20086:17;20069:6;;20119:40;;20050:16;;20119:40;20039:128;19976:191;:::o;47733:130::-;-1:-1:-1;;;;;47816:31:0;;;;;;;;:25;:31;;;;;:39;;-1:-1:-1;;47816:39:0;;;;;;;;;;47733:130::o;38106:98::-;38164:7;38191:5;38195:1;38191;:5;:::i;38212:98::-;38270:7;38297:5;38301:1;38297;:5;:::i;10098:877::-;-1:-1:-1;;;;;10229:18:0;;10221:68;;;;-1:-1:-1;;;10221:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;10308:16:0;;10300:64;;;;-1:-1:-1;;;10300:64:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;10450:15:0;;10428:19;10450:15;;;;;;;;;;;10498:21;;;;10476:109;;;;-1:-1:-1;;;10476:109:0;;15717:2:1;10476:109:0;;;15699:21:1;15756:2;15736:18;;;15729:30;15795:34;15775:18;;;15768:62;-1:-1:-1;;;15846:18:1;;;15839:36;15892:19;;10476:109:0;15515:402:1;10476:109:0;-1:-1:-1;;;;;10621:15:0;;;:9;:15;;;;;;;;;;;10639:20;;;10621:38;;10839:13;;;;;;;;;;:23;;;;;;10891:26;;2890:25:1;;;10839:13:0;;10891:26;;2863:18:1;10891:26:0;;;;;;;10930:37;15029:125;53198:593;53356:16;;;53370:1;53356:16;;;;;;;;53332:21;;53356:16;;;;;;;;;;-1:-1:-1;53356:16:0;53332:40;;53401:4;53383;53388:1;53383:7;;;;;;;;:::i;:::-;;;;;;:23;-1:-1:-1;;;;;53383:23:0;;;-1:-1:-1;;;;;53383:23:0;;;;;53427:15;-1:-1:-1;;;;;53427:20:0;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;53417:4;53422:1;53417:7;;;;;;;;:::i;:::-;;;;;;:32;-1:-1:-1;;;;;53417:32:0;;;-1:-1:-1;;;;;53417:32:0;;;;;53462:62;53479:4;53494:15;53512:11;53462:8;:62::i;:::-;53733:9;;53563:220;;-1:-1:-1;;;53563:220:0;;-1:-1:-1;;;;;53563:15:0;:66;;;;;:220;;53644:11;;53670:1;;53714:4;;53733:9;;;;;53757:15;;53563:220;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;53261:530;53198:593;:::o;53799:760::-;53890:15;53873:14;:32;54006:13;;53991:29;;-1:-1:-1;;;53991:29:0;;-1:-1:-1;;;;;54006:13:0;;;53991:29;;;2682:51:1;53856:4:0;;;;53991;;:14;;2655:18:1;;53991:29:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;53960:60;;54070:20;54093:77;54154:5;54093:42;54118:16;;54093:20;:24;;:42;;;;:::i;:77::-;54070:100;-1:-1:-1;54275:16:0;;54271:110;;54324:13;;54308:61;;-1:-1:-1;;;;;54324:13:0;54347:6;54356:12;54308:15;:61::i;:::-;54493:13;;54518:11;;;-1:-1:-1;;;;;;54518:11:0;;;;-1:-1:-1;;;;;54493:13:0;;;;;;54518:9;;:11;;;;;54456:19;;54518:11;;;;;;;54456:19;54493:13;54518:11;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;54547:4;54540:11;;;;;53799:760;:::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:160::-;632:20;;688:13;;681:21;671:32;;661:60;;717:1;714;707:12;732:689;824:6;832;840;893:2;881:9;872:7;868:23;864:32;861:52;;;909:1;906;899:12;861:52;949:9;936:23;978:18;1019:2;1011:6;1008:14;1005:34;;;1035:1;1032;1025:12;1005:34;1073:6;1062:9;1058:22;1048:32;;1118:7;1111:4;1107:2;1103:13;1099:27;1089:55;;1140:1;1137;1130:12;1089:55;1180:2;1167:16;1206:2;1198:6;1195:14;1192:34;;;1222:1;1219;1212:12;1192:34;1277:7;1270:4;1260:6;1257:1;1253:14;1249:2;1245:23;1241:34;1238:47;1235:67;;;1298:1;1295;1288:12;1235:67;1329:4;1321:13;;;;-1:-1:-1;1353:6:1;-1:-1:-1;1378:37:1;;1394:20;;;-1:-1:-1;1378:37:1;:::i;:::-;1368:47;;732:689;;;;;:::o;1426:131::-;-1:-1:-1;;;;;1501:31:1;;1491:42;;1481:70;;1547:1;1544;1537:12;1562:315;1630:6;1638;1691:2;1679:9;1670:7;1666:23;1662:32;1659:52;;;1707:1;1704;1697:12;1659:52;1746:9;1733:23;1765:31;1790:5;1765:31;:::i;:::-;1815:5;1867:2;1852:18;;;;1839:32;;-1:-1:-1;;;1562:315:1:o;2074:247::-;2133:6;2186:2;2174:9;2165:7;2161:23;2157:32;2154:52;;;2202:1;2199;2192:12;2154:52;2241:9;2228:23;2260:31;2285:5;2260:31;:::i;2326:180::-;2385:6;2438:2;2426:9;2417:7;2413:23;2409:32;2406:52;;;2454:1;2451;2444:12;2406:52;-1:-1:-1;2477:23:1;;2326:180;-1:-1:-1;2326:180:1:o;2926:456::-;3003:6;3011;3019;3072:2;3060:9;3051:7;3047:23;3043:32;3040:52;;;3088:1;3085;3078:12;3040:52;3127:9;3114:23;3146:31;3171:5;3146:31;:::i;:::-;3196:5;-1:-1:-1;3253:2:1;3238:18;;3225:32;3266:33;3225:32;3266:33;:::i;:::-;2926:456;;3318:7;;-1:-1:-1;;;3372:2:1;3357:18;;;;3344:32;;2926:456::o;3784:180::-;3840:6;3893:2;3881:9;3872:7;3868:23;3864:32;3861:52;;;3909:1;3906;3899:12;3861:52;3932:26;3948:9;3932:26;:::i;4222:316::-;4296:6;4304;4312;4365:2;4353:9;4344:7;4340:23;4336:32;4333:52;;;4381:1;4378;4371:12;4333:52;4417:9;4404:23;4394:33;;4474:2;4463:9;4459:18;4446:32;4436:42;;4497:35;4528:2;4517:9;4513:18;4497:35;:::i;4543:315::-;4608:6;4616;4669:2;4657:9;4648:7;4644:23;4640:32;4637:52;;;4685:1;4682;4675:12;4637:52;4724:9;4711:23;4743:31;4768:5;4743:31;:::i;:::-;4793:5;-1:-1:-1;4817:35:1;4848:2;4833:18;;4817:35;:::i;:::-;4807:45;;4543:315;;;;;:::o;4863:388::-;4931:6;4939;4992:2;4980:9;4971:7;4967:23;4963:32;4960:52;;;5008:1;5005;4998:12;4960:52;5047:9;5034:23;5066:31;5091:5;5066:31;:::i;:::-;5116:5;-1:-1:-1;5173:2:1;5158:18;;5145:32;5186:33;5145:32;5186:33;:::i;:::-;5238:7;5228:17;;;4863:388;;;;;:::o;5256:380::-;5335:1;5331:12;;;;5378;;;5399:61;;5453:4;5445:6;5441:17;5431:27;;5399:61;5506:2;5498:6;5495:14;5475:18;5472:38;5469:161;;5552:10;5547:3;5543:20;5540:1;5533:31;5587:4;5584:1;5577:15;5615:4;5612:1;5605:15;5469:161;;5256:380;;;:::o;5641:127::-;5702:10;5697:3;5693:20;5690:1;5683:31;5733:4;5730:1;5723:15;5757:4;5754:1;5747:15;5773:127;5834:10;5829:3;5825:20;5822:1;5815:31;5865:4;5862:1;5855:15;5889:4;5886:1;5879:15;5905:135;5944:3;5965:17;;;5962:43;;5985:18;;:::i;:::-;-1:-1:-1;6032:1:1;6021:13;;5905:135::o;6045:125::-;6110:9;;;6131:10;;;6128:36;;;6144:18;;:::i;7012:251::-;7082:6;7135:2;7123:9;7114:7;7110:23;7106:32;7103:52;;;7151:1;7148;7141:12;7103:52;7183:9;7177:16;7202:31;7227:5;7202:31;:::i;8189:306::-;8277:6;8285;8293;8346:2;8334:9;8325:7;8321:23;8317:32;8314:52;;;8362:1;8359;8352:12;8314:52;8391:9;8385:16;8375:26;;8441:2;8430:9;8426:18;8420:25;8410:35;;8485:2;8474:9;8470:18;8464:25;8454:35;;8189:306;;;;;:::o;10511:184::-;10581:6;10634:2;10622:9;10613:7;10609:23;10605:32;10602:52;;;10650:1;10647;10640:12;10602:52;-1:-1:-1;10673:16:1;;10511:184;-1:-1:-1;10511:184:1:o;12227:401::-;12429:2;12411:21;;;12468:2;12448:18;;;12441:30;12507:34;12502:2;12487:18;;12480:62;-1:-1:-1;;;12573:2:1;12558:18;;12551:35;12618:3;12603:19;;12227:401::o;12633:399::-;12835:2;12817:21;;;12874:2;12854:18;;;12847:30;12913:34;12908:2;12893:18;;12886:62;-1:-1:-1;;;12979:2:1;12964:18;;12957:33;13022:3;13007:19;;12633:399::o;14987:168::-;15060:9;;;15091;;15108:15;;;15102:22;;15088:37;15078:71;;15129:18;;:::i;15160:217::-;15200:1;15226;15216:132;;15270:10;15265:3;15261:20;15258:1;15251:31;15305:4;15302:1;15295:15;15333:4;15330:1;15323:15;15216:132;-1:-1:-1;15362:9:1;;15160:217::o;15382:128::-;15449:9;;;15470:11;;;15467:37;;;15484:18;;:::i;16054:980::-;16316:4;16364:3;16353:9;16349:19;16395:6;16384:9;16377:25;16421:2;16459:6;16454:2;16443:9;16439:18;16432:34;16502:3;16497:2;16486:9;16482:18;16475:31;16526:6;16561;16555:13;16592:6;16584;16577:22;16630:3;16619:9;16615:19;16608:26;;16669:2;16661:6;16657:15;16643:29;;16690:1;16700:195;16714:6;16711:1;16708:13;16700:195;;;16779:13;;-1:-1:-1;;;;;16775:39:1;16763:52;;16870:15;;;;16835:12;;;;16811:1;16729:9;16700:195;;;-1:-1:-1;;;;;;;16951:32:1;;;;16946:2;16931:18;;16924:60;-1:-1:-1;;;17015:3:1;17000:19;16993:35;16912:3;16054:980;-1:-1:-1;;;16054:980:1:o

Swarm Source

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