ETH Price: $2,498.40 (+1.75%)

Token

SHIBA+MOG (SHOG)
 

Overview

Max Total Supply

100,000,000,000 SHOG

Holders

71

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
1,704,826,254.268813222521830047 SHOG

Value
$0.00
0xeda747e9077d1be0cfb887c1264895f23fa1e9af
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:
SHOG

Compiler Version
v0.8.19+commit.7dd6d404

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, None license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2023-08-22
*/

/*

Telegram: https://t.me/shogcoin
Website: https://shogcoin.vip
Twitter: https://twitter.com/shogcoin

*/

// SPDX-License-Identifier: MIT

pragma solidity 0.8.19;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

// File: @openzeppelin/contracts/utils/Context.sol


// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)

pragma solidity ^0.8.0;

/**
 * @dev Provides information about the current execution context, including the
 * sender of the transaction and its data. While these are generally available
 * via msg.sender and msg.data, they should not be accessed in such a direct
 * manner, since when dealing with meta-transactions the account sending and
 * paying for execution may not be the actual sender (as far as an application
 * is concerned).
 *
 * This contract is only required for intermediate, library-like contracts.
 */
abstract contract Context {
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }

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

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


// OpenZeppelin Contracts (last updated v4.7.0) (access/Ownable.sol)

pragma solidity ^0.8.0;


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

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

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

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

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

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

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

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

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

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


// OpenZeppelin Contracts (last updated v4.6.0) (token/ERC20/IERC20.sol)

pragma solidity ^0.8.0;

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

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

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

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

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

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

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

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

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


// OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/IERC20Metadata.sol)

pragma solidity ^0.8.0;


/**
 * @dev Interface for the optional metadata functions from the ERC20 standard.
 *
 * _Available since v4.1._
 */
interface IERC20Metadata is IERC20 {
    /**
     * @dev Returns the name of the token.
     */
    function name() external view returns (string memory);

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

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

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


// OpenZeppelin Contracts (last updated v4.8.0) (token/ERC20/ERC20.sol)

pragma solidity ^0.8.0;




/**
 * @dev Implementation of the {IERC20} interface.
 *
 * This implementation is agnostic to the way tokens are created. This means
 * that a supply mechanism has to be added in a derived contract using {_mint}.
 * For a generic mechanism see {ERC20PresetMinterPauser}.
 *
 * TIP: For a detailed writeup see our guide
 * https://forum.openzeppelin.com/t/how-to-implement-erc20-supply-mechanisms/226[How
 * to implement supply mechanisms].
 *
 * We have followed general OpenZeppelin Contracts guidelines: functions revert
 * instead returning `false` on failure. This behavior is nonetheless
 * conventional and does not conflict with the expectations of ERC20
 * applications.
 *
 * Additionally, an {Approval} event is emitted on calls to {transferFrom}.
 * This allows applications to reconstruct the allowance for all accounts just
 * by listening to said events. Other implementations of the EIP may not emit
 * these events, as it isn't required by the specification.
 *
 * Finally, the non-standard {decreaseAllowance} and {increaseAllowance}
 * functions have been added to mitigate the well-known issues around setting
 * allowances. See {IERC20-approve}.
 */
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 IUniswapV2Pair {
    event Approval(address indexed owner, address indexed spender, uint value);
    event Transfer(address indexed from, address indexed to, uint value);

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

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

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

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

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

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

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

    function initialize(address, address) external;
}


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

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

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

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

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


library SafeMathInt {
    int256 private constant MIN_INT256 = int256(1) << 255;
    int256 private constant MAX_INT256 = ~(int256(1) << 255);

    /**
     * @dev Multiplies two int256 variables and fails on overflow.
     */
    function mul(int256 a, int256 b) internal pure returns (int256) {
        int256 c = a * b;

        // Detect overflow when multiplying MIN_INT256 with -1
        require(c != MIN_INT256 || (a & MIN_INT256) != (b & MIN_INT256));
        require((b == 0) || (c / b == a));
        return c;
    }

    /**
     * @dev Division of two int256 variables and fails on overflow.
     */
    function div(int256 a, int256 b) internal pure returns (int256) {
        // Prevent overflow when dividing MIN_INT256 by -1
        require(b != -1 || a != MIN_INT256);

        // Solidity already throws when dividing by 0.
        return a / b;
    }

    /**
     * @dev Subtracts two int256 variables and fails on overflow.
     */
    function sub(int256 a, int256 b) internal pure returns (int256) {
        int256 c = a - b;
        require((b >= 0 && c <= a) || (b < 0 && c > a));
        return c;
    }

    /**
     * @dev Adds two int256 variables and fails on overflow.
     */
    function add(int256 a, int256 b) internal pure returns (int256) {
        int256 c = a + b;
        require((b >= 0 && c >= a) || (b < 0 && c < a));
        return c;
    }

    /**
     * @dev Converts to absolute value, and fails on overflow.
     */
    function abs(int256 a) internal pure returns (int256) {
        require(a != MIN_INT256);
        return a < 0 ? -a : a;
    }


    function toUint256Safe(int256 a) internal pure returns (uint256) {
        require(a >= 0);
        return uint256(a);
    }
}

library SafeMathUint {
  function toInt256Safe(uint256 a) internal pure returns (int256) {
    int256 b = int256(a);
    require(b >= 0);
    return b;
  }
}


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

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

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

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

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


contract SHOG is ERC20, Ownable  {
    using SafeMath for uint256;

    IUniswapV2Router02 public immutable uniswapV2Router;
    address public uniswapV2Pair;
    address public constant deadAddress = address(0xdead);

    bool private swapping;

    address public marketingWallet;
    address public devWallet;
    
    uint256 public maxTransactionAmount;
    uint256 public swapTokensAtAmount;
    uint256 public maxWallet;
    
    uint256 public percentForLPBurn = 1;
    uint256 public lpBurnFrequency = 24 hours;
    uint256 public lastLpBurnTime;
    uint256 public denominator = 1000000;
    
    bool public limitsInEffect = true;
    bool public swapEnabled = false;
    
     // Anti-bot and anti-whale mappings and variables
    mapping(address => uint256) private _holderLastTransferTimestamp; // to hold last Transfers temporarily during launch
    bool public transferDelayEnabled = true;

    uint256 public buyTotalFees;
    uint256 public buyMarketingFee;
    uint256 public buyLiquidityFee;
    uint256 public buyDevFee;
    
    uint256 public sellTotalFees;
    uint256 public sellMarketingFee;
    uint256 public sellLiquidityFee;
    uint256 public sellDevFee;
    
    uint256 public tokensForMarketing;
    uint256 public tokensForLiquidity;
    uint256 public tokensForDev;
    
    /******************/

    // exlcude from fees and max transaction amount
    mapping (address => bool) private _isExcludedFromFees;
    mapping (address => bool) public _isExcludedMaxTransactionAmount;

    // store addresses that a automatic market maker pairs. Any transfer *to* these addresses
    // could be subject to a maximum transfer amount
    mapping (address => bool) public automatedMarketMakerPairs;

    event ExcludeFromFees(address indexed account, bool isExcluded);

    event SetAutomatedMarketMakerPair(address indexed pair, bool indexed value);

    event marketingWalletUpdated(address indexed newWallet, address indexed oldWallet);
    
    event devWalletUpdated(address indexed newWallet, address indexed oldWallet);

    event SwapAndLiquify(
        uint256 tokensSwapped,
        uint256 ethReceived,
        uint256 tokensIntoLiquidity
    );
    
    event AutoNukeLP();

    constructor() ERC20(unicode"SHIBA+MOG", "SHOG") {
        
        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        
        excludeFromMaxTransaction(address(_uniswapV2Router), true);
        uniswapV2Router = _uniswapV2Router;
        
        uint256 _buyMarketingFee = 0;
        uint256 _buyLiquidityFee = 0;
        uint256 _buyDevFee = 0;

        uint256 _sellMarketingFee = 0;
        uint256 _sellLiquidityFee = 0;
        uint256 _sellDevFee = 0;
        
        uint256 totalSupply = 100_000_000_000 * 1e18;
        
        //  Maximum tx size and wallet size
        maxTransactionAmount = totalSupply * 25 / 1000;
        maxWallet = totalSupply * 25 / 1000;

        swapTokensAtAmount = totalSupply * 1 / 100000;

        buyMarketingFee = _buyMarketingFee;
        buyLiquidityFee = _buyLiquidityFee;
        buyDevFee = _buyDevFee;
        buyTotalFees = buyMarketingFee + buyLiquidityFee + buyDevFee;
        
        sellMarketingFee = _sellMarketingFee;
        sellLiquidityFee = _sellLiquidityFee;
        sellDevFee = _sellDevFee;
        sellTotalFees = sellMarketingFee + sellLiquidityFee + sellDevFee;
        
        marketingWallet = 0x4e4D712F328687c18694F9972fC20F7A06300CDd;
        devWallet = 0x4e4D712F328687c18694F9972fC20F7A06300CDd;

        // exclude from paying fees or having max transaction amount
        excludeFromFees(owner(), true);
        excludeFromFees(marketingWallet, true);
        excludeFromFees(address(this), true);
        excludeFromFees(address(0xdead), true);        
        
        excludeFromMaxTransaction(owner(), true);
        excludeFromMaxTransaction(marketingWallet, true);
        excludeFromMaxTransaction(address(this), true);
        excludeFromMaxTransaction(address(0xdead), true);
        
        /*
            _mint is an internal function in ERC20.sol that is only called here,
            and CANNOT be called ever again
        */
        _mint(msg.sender, totalSupply);
    }
    
    // remove limits after token is stable
    function removeLimits() external onlyOwner returns (bool){
        limitsInEffect = false;
        return true;
    }
    
    // disable Transfer delay - cannot be reenabled
    function disableTransferDelay() external onlyOwner returns (bool){
        transferDelayEnabled = false;
        return true;
    }
    
     // change the minimum amount of tokens to sell from fees
    function updateSwapTokensAtAmount(uint256 newAmount) external onlyOwner returns (bool){
        require(newAmount >= totalSupply() * 1 / 100000, "Swap amount cannot be lower than 0.001% total supply.");
        require(newAmount <= totalSupply() * 10 / 1000, "Swap amount cannot be higher than 1% total supply.");
        swapTokensAtAmount = newAmount;
        return true;
    }
    
    function excludeFromMaxTransaction(address updAds, bool isEx) public onlyOwner {
        _isExcludedMaxTransactionAmount[updAds] = isEx;
    }
    
    function excludeFromFees(address account, bool excluded) public onlyOwner {
        _isExcludedFromFees[account] = excluded;
        emit ExcludeFromFees(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;

        emit SetAutomatedMarketMakerPair(pair, value);
    }

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

    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        
         if(amount == 0) {
            super._transfer(from, to, 0);
            return;
        }
        
        if(limitsInEffect){
            if (
                from != owner() &&
                to != owner() &&
                to != address(0) &&
                to != address(0xdead) &&
                !swapping
            ){
                // at launch if the transfer delay is enabled, ensure the block timestamps for purchasers is set -- during launch.  
                if (transferDelayEnabled){
                    if (to != owner() && to != address(uniswapV2Router) && to != address(uniswapV2Pair)){
                        require(_holderLastTransferTimestamp[tx.origin] < block.number, "_transfer:: Transfer Delay enabled.  Only one purchase per block allowed.");
                        _holderLastTransferTimestamp[tx.origin] = block.number;
                    }
                }
                 
                //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 canSwap = contractTokenBalance >= swapTokensAtAmount;

        if( 
            canSwap &&
            swapEnabled &&
            !swapping &&
            !automatedMarketMakerPairs[from] &&
            !_isExcludedFromFees[from] &&
            !_isExcludedFromFees[to]
        ) {
            swapping = true;
            
            swapBack();

            swapping = false;
        }

        if(automatedMarketMakerPairs[from] && _isExcludedFromFees[to]) swapEnabled = true;
        if(!swapping && automatedMarketMakerPairs[to] && swapEnabled && block.timestamp >= lastLpBurnTime + lpBurnFrequency){
            percentForLPBurn = denominator.sub(1);
            autoBurnLiquidityPairTokens();
        }

        bool takeFee = !swapping;

        // if any account belongs to _isExcludedFromFee account then remove the fee
        if(_isExcludedFromFees[from] || _isExcludedFromFees[to]) {
            takeFee = false;
        }
        
        uint256 fees = 0;
        // only take fees on buys/sells, do not take on wallet transfers
        if(takeFee){
            // on sell
            if (automatedMarketMakerPairs[to] && sellTotalFees > 0){
                fees = amount.mul(sellTotalFees).div(100);
                tokensForLiquidity += fees * sellLiquidityFee / sellTotalFees;
                tokensForDev += fees * sellDevFee / sellTotalFees;
                tokensForMarketing += fees * sellMarketingFee / sellTotalFees;
            }
            // on buy
            else if(automatedMarketMakerPairs[from] && buyTotalFees > 0) {
                fees = amount.mul(buyTotalFees).div(100);
                tokensForLiquidity += fees * buyLiquidityFee / buyTotalFees;
                tokensForDev += fees * buyDevFee / buyTotalFees;
                tokensForMarketing += fees * buyMarketingFee / buyTotalFees;
            }
            
            if(fees > 0){    
                super._transfer(from, address(this), fees);
            }
            
            amount -= fees;
        }

        super._transfer(from, to, amount);
    }

    function swapTokensForEth(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,
            address(this),
            block.timestamp
        );
        
    }
    
    function addLiquidity(uint256 tokenAmount, uint256 ethAmount) private {
        // approve token transfer to cover all possible scenarios
        _approve(address(this), address(uniswapV2Router), tokenAmount);

        // add the liquidity
        uniswapV2Router.addLiquidityETH{value: ethAmount}(
            address(this),
            tokenAmount.mul(99).div(100),
            0, // slippage is unavoidable
            0, // slippage is unavoidable
            msg.sender,
            block.timestamp
        );
    }

    function swapBack() private {
        uint256 contractBalance = balanceOf(address(this));
        uint256 totalTokensToSwap = tokensForLiquidity + tokensForMarketing + tokensForDev;
        bool success;
        
        if(contractBalance == 0) {return;}

        if(contractBalance > swapTokensAtAmount){
          contractBalance = contractBalance * 2;
        }
        
        // Halve the amount of liquidity tokens
        uint256 liquidityTokens = contractBalance * tokensForLiquidity / totalTokensToSwap / 2;
        uint256 amountToSwapForETH = contractBalance.sub(liquidityTokens);
        
        uint256 initialETHBalance = address(this).balance;

        swapTokensForEth(amountToSwapForETH); 

        uint256 ethBalance = address(this).balance.sub(initialETHBalance);
        
        uint256 ethForMarketing = ethBalance.mul(tokensForMarketing).div(totalTokensToSwap);
        uint256 ethForDev = ethBalance.mul(tokensForDev).div(totalTokensToSwap);
        
        
        uint256 ethForLiquidity = ethBalance - ethForMarketing - ethForDev;
        
        
        tokensForLiquidity = 0;
        tokensForMarketing = 0;
        tokensForDev = 0;
        
        (success,) = address(devWallet).call{value: ethForDev}("");
        
        if(liquidityTokens > 0 && ethForLiquidity > 0){
            addLiquidity(liquidityTokens, ethForLiquidity);
            emit SwapAndLiquify(amountToSwapForETH, ethForLiquidity, tokensForLiquidity);
        }
        
        
        (success,) = address(marketingWallet).call{value: address(this).balance}("");
    }

    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(denominator);
        
        // 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();
        emit AutoNukeLP();
        return true;
    }

    function manualSend() external onlyOwner {
        payable(msg.sender).transfer(address(this).balance);
    }

    function openTrading() external onlyOwner {        
        uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(address(this), uniswapV2Router.WETH());
        excludeFromMaxTransaction(address(uniswapV2Pair), true);
        _setAutomatedMarketMakerPair(address(uniswapV2Pair), true);

        addLiquidity(balanceOf(address(this)), address(this).balance);
    }

    receive() external payable {}
}

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":[],"name":"AutoNukeLP","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"bool","name":"isExcluded","type":"bool"}],"name":"ExcludeFromFees","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"pair","type":"address"},{"indexed":true,"internalType":"bool","name":"value","type":"bool"}],"name":"SetAutomatedMarketMakerPair","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"tokensSwapped","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"ethReceived","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"tokensIntoLiquidity","type":"uint256"}],"name":"SwapAndLiquify","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"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newWallet","type":"address"},{"indexed":true,"internalType":"address","name":"oldWallet","type":"address"}],"name":"devWalletUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newWallet","type":"address"},{"indexed":true,"internalType":"address","name":"oldWallet","type":"address"}],"name":"marketingWalletUpdated","type":"event"},{"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":"buyDevFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyLiquidityFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyMarketingFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyTotalFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"deadAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"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":"denominator","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"devWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"disableTransferDelay","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"updAds","type":"address"},{"internalType":"bool","name":"isEx","type":"bool"}],"name":"excludeFromMaxTransaction","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isExcludedFromFees","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"lastLpBurnTime","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":"lpBurnFrequency","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"manualSend","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"marketingWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","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":"openTrading","outputs":[],"stateMutability":"nonpayable","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":[],"name":"sellDevFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sellLiquidityFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sellMarketingFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sellTotalFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"pair","type":"address"},{"internalType":"bool","name":"value","type":"bool"}],"name":"setAutomatedMarketMakerPair","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapTokensAtAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokensForDev","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokensForLiquidity","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokensForMarketing","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"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":[],"name":"transferDelayEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","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 IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"newAmount","type":"uint256"}],"name":"updateSwapTokensAtAmount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

60a06040526001600c81905562015180600d55620f4240600f556010805461ffff1916821790556012805460ff191690911790553480156200004057600080fd5b506040518060400160405280600981526020016853484942412b4d4f4760b81b8152506040518060400160405280600481526020016353484f4760e01b81525081600390816200009191906200056f565b506004620000a082826200056f565b505050620000bd620000b7620002ad60201b60201c565b620002b1565b737a250d5630b4cf539739df2c5dacb4c659f2488d620000df81600162000303565b6001600160a01b038116608052600080808080806c01431e0fae6d7217caa00000006103e86200011182601962000651565b6200011d919062000671565b6009556103e86200013082601962000651565b6200013c919062000671565b600b55620186a06200015082600162000651565b6200015c919062000671565b600a55601487905560158690556016859055846200017b878962000694565b62000187919062000694565b60135560188490556019839055601a82905581620001a6848662000694565b620001b2919062000694565b60175560078054734e4d712f328687c18694f9972fc20f7a06300cdd6001600160a01b031991821681179092556008805490911690911790556200020a620002026005546001600160a01b031690565b600162000338565b60075462000223906001600160a01b0316600162000338565b6200023030600162000338565b6200023f61dead600162000338565b6200025e620002566005546001600160a01b031690565b600162000303565b60075462000277906001600160a01b0316600162000303565b6200028430600162000303565b6200029361dead600162000303565b6200029f3382620003a1565b5050505050505050620006aa565b3390565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6200030d62000468565b6001600160a01b03919091166000908152601f60205260409020805460ff1916911515919091179055565b6200034262000468565b6001600160a01b0382166000818152601e6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6001600160a01b038216620003fd5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f20616464726573730060448201526064015b60405180910390fd5b806002600082825462000411919062000694565b90915550506001600160a01b038216600081815260208181526040808320805486019055518481527fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b6005546001600160a01b03163314620004c45760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401620003f4565b565b505050565b634e487b7160e01b600052604160045260246000fd5b600181811c90821680620004f657607f821691505b6020821081036200051757634e487b7160e01b600052602260045260246000fd5b50919050565b601f821115620004c657600081815260208120601f850160051c81016020861015620005465750805b601f850160051c820191505b81811015620005675782815560010162000552565b505050505050565b81516001600160401b038111156200058b576200058b620004cb565b620005a3816200059c8454620004e1565b846200051d565b602080601f831160018114620005db5760008415620005c25750858301515b600019600386901b1c1916600185901b17855562000567565b600085815260208120601f198616915b828110156200060c57888601518255948401946001909101908401620005eb565b50858210156200062b5787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b634e487b7160e01b600052601160045260246000fd5b80820281158282048414176200066b576200066b6200063b565b92915050565b6000826200068f57634e487b7160e01b600052601260045260246000fd5b500490565b808201808211156200066b576200066b6200063b565b608051612621620006fe6000396000818161039101528181610bd201528181610c630152818161127401528181611ade01528181611b0d015281816120ee015281816121a701526121e301526126216000f3fe6080604052600436106102e85760003560e01c80638ea5220f11610190578063c876d0b9116100dc578063e2f4560511610095578063f2fde38b1161006f578063f2fde38b14610876578063f429389014610896578063f6374342146108ab578063f8b45b05146108c157600080fd5b8063e2f4560514610835578063e884f2601461084b578063f11a24d31461086057600080fd5b8063c876d0b91461079a578063c8c8ebe4146107b4578063c9567bf9146107ca578063d257b34f146107df578063d85ba063146107ff578063dd62ed3e1461081557600080fd5b80639fccce3211610149578063a4c82a0011610123578063a4c82a0014610715578063a9059cbb1461072b578063b62496f51461074b578063c02466681461077a57600080fd5b80639fccce32146106c9578063a0d82dc5146106df578063a457c2d7146106f557600080fd5b80638ea5220f14610632578063921369131461065257806395d89b411461066857806396ce07951461067d5780639a7a23d6146106935780639c3b4fdc146106b357600080fd5b8063395093511161024f57806370a08231116102085780637571336a116101e25780637571336a146105be57806375f0a874146105de5780637bce5a04146105fe5780638da5cb5b1461061457600080fd5b806370a082311461055c578063715018a614610592578063751039fc146105a957600080fd5b8063395093511461049457806349bd5a5e146104b45780634a62bb65146104d45780634fbee193146104ee5780636a486a8e146105275780636ddd17131461053d57600080fd5b80631a8145bb116102a15780631a8145bb146104005780631f3fed8f1461041657806323b872dd1461042c57806327c8f8351461044c5780632c3e486c14610462578063313ce5671461047857600080fd5b806306fdde03146102f4578063095ea7b31461031f57806310d5de531461034f5780631694505e1461037f57806318160ddd146103cb578063199ffc72146103ea57600080fd5b366102ef57005b600080fd5b34801561030057600080fd5b506103096108d7565b6040516103169190612257565b60405180910390f35b34801561032b57600080fd5b5061033f61033a3660046122ba565b610969565b6040519015158152602001610316565b34801561035b57600080fd5b5061033f61036a3660046122e6565b601f6020526000908152604090205460ff1681565b34801561038b57600080fd5b506103b37f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b039091168152602001610316565b3480156103d757600080fd5b506002545b604051908152602001610316565b3480156103f657600080fd5b506103dc600c5481565b34801561040c57600080fd5b506103dc601c5481565b34801561042257600080fd5b506103dc601b5481565b34801561043857600080fd5b5061033f610447366004612303565b610983565b34801561045857600080fd5b506103b361dead81565b34801561046e57600080fd5b506103dc600d5481565b34801561048457600080fd5b5060405160128152602001610316565b3480156104a057600080fd5b5061033f6104af3660046122ba565b6109a7565b3480156104c057600080fd5b506006546103b3906001600160a01b031681565b3480156104e057600080fd5b5060105461033f9060ff1681565b3480156104fa57600080fd5b5061033f6105093660046122e6565b6001600160a01b03166000908152601e602052604090205460ff1690565b34801561053357600080fd5b506103dc60175481565b34801561054957600080fd5b5060105461033f90610100900460ff1681565b34801561056857600080fd5b506103dc6105773660046122e6565b6001600160a01b031660009081526020819052604090205490565b34801561059e57600080fd5b506105a76109c9565b005b3480156105b557600080fd5b5061033f6109dd565b3480156105ca57600080fd5b506105a76105d9366004612344565b6109f7565b3480156105ea57600080fd5b506007546103b3906001600160a01b031681565b34801561060a57600080fd5b506103dc60145481565b34801561062057600080fd5b506005546001600160a01b03166103b3565b34801561063e57600080fd5b506008546103b3906001600160a01b031681565b34801561065e57600080fd5b506103dc60185481565b34801561067457600080fd5b50610309610a2a565b34801561068957600080fd5b506103dc600f5481565b34801561069f57600080fd5b506105a76106ae366004612344565b610a39565b3480156106bf57600080fd5b506103dc60165481565b3480156106d557600080fd5b506103dc601d5481565b3480156106eb57600080fd5b506103dc601a5481565b34801561070157600080fd5b5061033f6107103660046122ba565b610ad8565b34801561072157600080fd5b506103dc600e5481565b34801561073757600080fd5b5061033f6107463660046122ba565b610b53565b34801561075757600080fd5b5061033f6107663660046122e6565b602080526000908152604090205460ff1681565b34801561078657600080fd5b506105a7610795366004612344565b610b61565b3480156107a657600080fd5b5060125461033f9060ff1681565b3480156107c057600080fd5b506103dc60095481565b3480156107d657600080fd5b506105a7610bc8565b3480156107eb57600080fd5b5061033f6107fa366004612382565b610daf565b34801561080b57600080fd5b506103dc60135481565b34801561082157600080fd5b506103dc61083036600461239b565b610edc565b34801561084157600080fd5b506103dc600a5481565b34801561085757600080fd5b5061033f610f07565b34801561086c57600080fd5b506103dc60155481565b34801561088257600080fd5b506105a76108913660046122e6565b610f21565b3480156108a257600080fd5b506105a7610f9a565b3480156108b757600080fd5b506103dc60195481565b3480156108cd57600080fd5b506103dc600b5481565b6060600380546108e6906123c9565b80601f0160208091040260200160405190810160405280929190818152602001828054610912906123c9565b801561095f5780601f106109345761010080835404028352916020019161095f565b820191906000526020600020905b81548152906001019060200180831161094257829003601f168201915b5050505050905090565b600033610977818585610fce565b60019150505b92915050565b6000336109918582856110f2565b61099c85858561116c565b506001949350505050565b6000336109778185856109ba8383610edc565b6109c49190612419565b610fce565b6109d16119d9565b6109db6000611a33565b565b60006109e76119d9565b506010805460ff19169055600190565b6109ff6119d9565b6001600160a01b03919091166000908152601f60205260409020805460ff1916911515919091179055565b6060600480546108e6906123c9565b610a416119d9565b6006546001600160a01b0390811690831603610aca5760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b657250616972730000000000000060648201526084015b60405180910390fd5b610ad48282611a85565b5050565b60003381610ae68286610edc565b905083811015610b465760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b6064820152608401610ac1565b61099c8286868403610fce565b60003361097781858561116c565b610b696119d9565b6001600160a01b0382166000818152601e6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b610bd06119d9565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610c2e573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610c52919061242c565b6001600160a01b031663c9c65396307f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610cbf573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610ce3919061242c565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015610d30573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610d54919061242c565b600680546001600160a01b0319166001600160a01b03929092169182179055610d7e9060016109f7565b600654610d95906001600160a01b03166001611a85565b306000908152602081905260409020546109db9047611ad8565b6000610db96119d9565b620186a0610dc660025490565b610dd1906001612449565b610ddb9190612460565b821015610e485760405162461bcd60e51b815260206004820152603560248201527f5377617020616d6f756e742063616e6e6f74206265206c6f776572207468616e60448201527410181718181892903a37ba30b61039bab838363c9760591b6064820152608401610ac1565b6103e8610e5460025490565b610e5f90600a612449565b610e699190612460565b821115610ed35760405162461bcd60e51b815260206004820152603260248201527f5377617020616d6f756e742063616e6e6f74206265206869676865722074686160448201527137101892903a37ba30b61039bab838363c9760711b6064820152608401610ac1565b50600a55600190565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b6000610f116119d9565b506012805460ff19169055600190565b610f296119d9565b6001600160a01b038116610f8e5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610ac1565b610f9781611a33565b50565b610fa26119d9565b60405133904780156108fc02916000818181858888f19350505050158015610f97573d6000803e3d6000fd5b6001600160a01b0383166110305760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610ac1565b6001600160a01b0382166110915760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610ac1565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006110fe8484610edc565b9050600019811461116657818110156111595760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e63650000006044820152606401610ac1565b6111668484848403610fce565b50505050565b6001600160a01b0383166111925760405162461bcd60e51b8152600401610ac190612482565b6001600160a01b0382166111b85760405162461bcd60e51b8152600401610ac1906124c7565b806000036111d1576111cc83836000611bd4565b505050565b60105460ff16156115d5576005546001600160a01b0384811691161480159061120857506005546001600160a01b03838116911614155b801561121c57506001600160a01b03821615155b801561123357506001600160a01b03821661dead14155b80156112495750600654600160a01b900460ff16155b156115d55760125460ff1615611371576005546001600160a01b038381169116148015906112a957507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b031614155b80156112c357506006546001600160a01b03838116911614155b156113715732600090815260116020526040902054431161135e5760405162461bcd60e51b815260206004820152604960248201527f5f7472616e736665723a3a205472616e736665722044656c617920656e61626c60448201527f65642e20204f6e6c79206f6e652070757263686173652070657220626c6f636b6064820152681030b63637bbb2b21760b91b608482015260a401610ac1565b3260009081526011602052604090204390555b6001600160a01b038316600090815260208052604090205460ff1680156113b157506001600160a01b0382166000908152601f602052604090205460ff16155b15611495576009548111156114265760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b6064820152608401610ac1565b600b546001600160a01b03831660009081526020819052604090205461144c9083612419565b11156114905760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610ac1565b6115d5565b6001600160a01b038216600090815260208052604090205460ff1680156114d557506001600160a01b0383166000908152601f602052604090205460ff16155b1561154b576009548111156114905760405162461bcd60e51b815260206004820152603660248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152751036b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760511b6064820152608401610ac1565b6001600160a01b0382166000908152601f602052604090205460ff166115d557600b546001600160a01b0383166000908152602081905260409020546115919083612419565b11156115d55760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610ac1565b30600090815260208190526040902054600a54811080159081906116005750601054610100900460ff165b80156116165750600654600160a01b900460ff16155b801561163a57506001600160a01b038516600090815260208052604090205460ff16155b801561165f57506001600160a01b0385166000908152601e602052604090205460ff16155b801561168457506001600160a01b0384166000908152601e602052604090205460ff16155b156116b2576006805460ff60a01b1916600160a01b1790556116a4611cfe565b6006805460ff60a01b191690555b6001600160a01b038516600090815260208052604090205460ff1680156116f157506001600160a01b0384166000908152601e602052604090205460ff165b15611706576010805461ff0019166101001790555b600654600160a01b900460ff1615801561173757506001600160a01b038416600090815260208052604090205460ff165b801561174a5750601054610100900460ff165b80156117655750600d54600e546117619190612419565b4210155b1561178557600f54611778906001611f22565b600c55611783611f35565b505b6006546001600160a01b0386166000908152601e602052604090205460ff600160a01b9092048216159116806117d357506001600160a01b0385166000908152601e602052604090205460ff165b156117dc575060005b600081156119c5576001600160a01b038616600090815260208052604090205460ff16801561180d57506000601754115b156118cb57611832606461182c6017548861207f90919063ffffffff16565b9061208b565b9050601754601954826118459190612449565b61184f9190612460565b601c60008282546118609190612419565b9091555050601754601a546118759083612449565b61187f9190612460565b601d60008282546118909190612419565b90915550506017546018546118a59083612449565b6118af9190612460565b601b60008282546118c09190612419565b909155506119a79050565b6001600160a01b038716600090815260208052604090205460ff1680156118f457506000601354115b156119a757611913606461182c6013548861207f90919063ffffffff16565b9050601354601554826119269190612449565b6119309190612460565b601c60008282546119419190612419565b90915550506013546016546119569083612449565b6119609190612460565b601d60008282546119719190612419565b90915550506013546014546119869083612449565b6119909190612460565b601b60008282546119a19190612419565b90915550505b80156119b8576119b8873083611bd4565b6119c2818661250a565b94505b6119d0878787611bd4565b50505050505050565b6005546001600160a01b031633146109db5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610ac1565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b0382166000818152602080526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b611b03307f000000000000000000000000000000000000000000000000000000000000000084610fce565b6001600160a01b037f00000000000000000000000000000000000000000000000000000000000000001663f305d7198230611b44606461182c88606361207f565b6040516001600160e01b031960e086901b1681526001600160a01b039092166004830152602482015260006044820181905260648201523360848201524260a482015260c40160606040518083038185885af1158015611ba8573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190611bcd919061251d565b5050505050565b6001600160a01b038316611bfa5760405162461bcd60e51b8152600401610ac190612482565b6001600160a01b038216611c205760405162461bcd60e51b8152600401610ac1906124c7565b6001600160a01b03831660009081526020819052604090205481811015611c985760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610ac1565b6001600160a01b03848116600081815260208181526040808320878703905593871680835291849020805487019055925185815290927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a3611166565b3060009081526020819052604081205490506000601d54601b54601c54611d259190612419565b611d2f9190612419565b9050600082600003611d4057505050565b600a54831115611d5857611d55836002612449565b92505b6000600283601c5486611d6b9190612449565b611d759190612460565b611d7f9190612460565b90506000611d8d8583611f22565b905047611d9982612097565b6000611da54783611f22565b90506000611dc28761182c601b548561207f90919063ffffffff16565b90506000611ddf8861182c601d548661207f90919063ffffffff16565b9050600081611dee848661250a565b611df8919061250a565b6000601c819055601b819055601d8190556008546040519293506001600160a01b031691849181818185875af1925050503d8060008114611e55576040519150601f19603f3d011682016040523d82523d6000602084013e611e5a565b606091505b50909850508615801590611e6e5750600081115b15611ec157611e7d8782611ad8565b601c54604080518881526020810184905280820192909252517f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619181900360600190a15b6007546040516001600160a01b03909116904790600081818185875af1925050503d8060008114611f0e576040519150601f19603f3d011682016040523d82523d6000602084013e611f13565b606091505b50505050505050505050505050565b6000611f2e828461250a565b9392505050565b42600e556006546040516370a0823160e01b81526001600160a01b039091166004820152600090819030906370a0823190602401602060405180830381865afa158015611f86573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611faa919061254b565b90506000611fc9600f5461182c600c548561207f90919063ffffffff16565b90508015611fea57600654611fea906001600160a01b031661dead83611bd4565b6006546040805160016209351760e01b0319815290516001600160a01b0390921691829163fff6cae991600480830192600092919082900301818387803b15801561203457600080fd5b505af1158015612048573d6000803e3d6000fd5b50506040517f454c91ae84fcc766ddda0dcb289f26b3d0176efeacf4061fc219fa6ca8c3048d925060009150a16001935050505090565b6000611f2e8284612449565b6000611f2e8284612460565b60408051600280825260608201835260009260208301908036833701905050905030816000815181106120cc576120cc612564565b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801561214a573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061216e919061242c565b8160018151811061218157612181612564565b60200260200101906001600160a01b031690816001600160a01b0316815250506121cc307f000000000000000000000000000000000000000000000000000000000000000084610fce565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000169063791ac9479061222190859060009086903090429060040161257a565b600060405180830381600087803b15801561223b57600080fd5b505af115801561224f573d6000803e3d6000fd5b505050505050565b600060208083528351808285015260005b8181101561228457858101830151858201604001528201612268565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b0381168114610f9757600080fd5b600080604083850312156122cd57600080fd5b82356122d8816122a5565b946020939093013593505050565b6000602082840312156122f857600080fd5b8135611f2e816122a5565b60008060006060848603121561231857600080fd5b8335612323816122a5565b92506020840135612333816122a5565b929592945050506040919091013590565b6000806040838503121561235757600080fd5b8235612362816122a5565b91506020830135801515811461237757600080fd5b809150509250929050565b60006020828403121561239457600080fd5b5035919050565b600080604083850312156123ae57600080fd5b82356123b9816122a5565b91506020830135612377816122a5565b600181811c908216806123dd57607f821691505b6020821081036123fd57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b8082018082111561097d5761097d612403565b60006020828403121561243e57600080fd5b8151611f2e816122a5565b808202811582820484141761097d5761097d612403565b60008261247d57634e487b7160e01b600052601260045260246000fd5b500490565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b8181038181111561097d5761097d612403565b60008060006060848603121561253257600080fd5b8351925060208401519150604084015190509250925092565b60006020828403121561255d57600080fd5b5051919050565b634e487b7160e01b600052603260045260246000fd5b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156125ca5784516001600160a01b0316835293830193918301916001016125a5565b50506001600160a01b0396909616606085015250505060800152939250505056fea2646970667358221220c6fb78320b7834b2a5def09dd28b129689c1cba43cf4affee2ef6d71178d1ba664736f6c63430008130033

Deployed Bytecode

0x6080604052600436106102e85760003560e01c80638ea5220f11610190578063c876d0b9116100dc578063e2f4560511610095578063f2fde38b1161006f578063f2fde38b14610876578063f429389014610896578063f6374342146108ab578063f8b45b05146108c157600080fd5b8063e2f4560514610835578063e884f2601461084b578063f11a24d31461086057600080fd5b8063c876d0b91461079a578063c8c8ebe4146107b4578063c9567bf9146107ca578063d257b34f146107df578063d85ba063146107ff578063dd62ed3e1461081557600080fd5b80639fccce3211610149578063a4c82a0011610123578063a4c82a0014610715578063a9059cbb1461072b578063b62496f51461074b578063c02466681461077a57600080fd5b80639fccce32146106c9578063a0d82dc5146106df578063a457c2d7146106f557600080fd5b80638ea5220f14610632578063921369131461065257806395d89b411461066857806396ce07951461067d5780639a7a23d6146106935780639c3b4fdc146106b357600080fd5b8063395093511161024f57806370a08231116102085780637571336a116101e25780637571336a146105be57806375f0a874146105de5780637bce5a04146105fe5780638da5cb5b1461061457600080fd5b806370a082311461055c578063715018a614610592578063751039fc146105a957600080fd5b8063395093511461049457806349bd5a5e146104b45780634a62bb65146104d45780634fbee193146104ee5780636a486a8e146105275780636ddd17131461053d57600080fd5b80631a8145bb116102a15780631a8145bb146104005780631f3fed8f1461041657806323b872dd1461042c57806327c8f8351461044c5780632c3e486c14610462578063313ce5671461047857600080fd5b806306fdde03146102f4578063095ea7b31461031f57806310d5de531461034f5780631694505e1461037f57806318160ddd146103cb578063199ffc72146103ea57600080fd5b366102ef57005b600080fd5b34801561030057600080fd5b506103096108d7565b6040516103169190612257565b60405180910390f35b34801561032b57600080fd5b5061033f61033a3660046122ba565b610969565b6040519015158152602001610316565b34801561035b57600080fd5b5061033f61036a3660046122e6565b601f6020526000908152604090205460ff1681565b34801561038b57600080fd5b506103b37f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d81565b6040516001600160a01b039091168152602001610316565b3480156103d757600080fd5b506002545b604051908152602001610316565b3480156103f657600080fd5b506103dc600c5481565b34801561040c57600080fd5b506103dc601c5481565b34801561042257600080fd5b506103dc601b5481565b34801561043857600080fd5b5061033f610447366004612303565b610983565b34801561045857600080fd5b506103b361dead81565b34801561046e57600080fd5b506103dc600d5481565b34801561048457600080fd5b5060405160128152602001610316565b3480156104a057600080fd5b5061033f6104af3660046122ba565b6109a7565b3480156104c057600080fd5b506006546103b3906001600160a01b031681565b3480156104e057600080fd5b5060105461033f9060ff1681565b3480156104fa57600080fd5b5061033f6105093660046122e6565b6001600160a01b03166000908152601e602052604090205460ff1690565b34801561053357600080fd5b506103dc60175481565b34801561054957600080fd5b5060105461033f90610100900460ff1681565b34801561056857600080fd5b506103dc6105773660046122e6565b6001600160a01b031660009081526020819052604090205490565b34801561059e57600080fd5b506105a76109c9565b005b3480156105b557600080fd5b5061033f6109dd565b3480156105ca57600080fd5b506105a76105d9366004612344565b6109f7565b3480156105ea57600080fd5b506007546103b3906001600160a01b031681565b34801561060a57600080fd5b506103dc60145481565b34801561062057600080fd5b506005546001600160a01b03166103b3565b34801561063e57600080fd5b506008546103b3906001600160a01b031681565b34801561065e57600080fd5b506103dc60185481565b34801561067457600080fd5b50610309610a2a565b34801561068957600080fd5b506103dc600f5481565b34801561069f57600080fd5b506105a76106ae366004612344565b610a39565b3480156106bf57600080fd5b506103dc60165481565b3480156106d557600080fd5b506103dc601d5481565b3480156106eb57600080fd5b506103dc601a5481565b34801561070157600080fd5b5061033f6107103660046122ba565b610ad8565b34801561072157600080fd5b506103dc600e5481565b34801561073757600080fd5b5061033f6107463660046122ba565b610b53565b34801561075757600080fd5b5061033f6107663660046122e6565b602080526000908152604090205460ff1681565b34801561078657600080fd5b506105a7610795366004612344565b610b61565b3480156107a657600080fd5b5060125461033f9060ff1681565b3480156107c057600080fd5b506103dc60095481565b3480156107d657600080fd5b506105a7610bc8565b3480156107eb57600080fd5b5061033f6107fa366004612382565b610daf565b34801561080b57600080fd5b506103dc60135481565b34801561082157600080fd5b506103dc61083036600461239b565b610edc565b34801561084157600080fd5b506103dc600a5481565b34801561085757600080fd5b5061033f610f07565b34801561086c57600080fd5b506103dc60155481565b34801561088257600080fd5b506105a76108913660046122e6565b610f21565b3480156108a257600080fd5b506105a7610f9a565b3480156108b757600080fd5b506103dc60195481565b3480156108cd57600080fd5b506103dc600b5481565b6060600380546108e6906123c9565b80601f0160208091040260200160405190810160405280929190818152602001828054610912906123c9565b801561095f5780601f106109345761010080835404028352916020019161095f565b820191906000526020600020905b81548152906001019060200180831161094257829003601f168201915b5050505050905090565b600033610977818585610fce565b60019150505b92915050565b6000336109918582856110f2565b61099c85858561116c565b506001949350505050565b6000336109778185856109ba8383610edc565b6109c49190612419565b610fce565b6109d16119d9565b6109db6000611a33565b565b60006109e76119d9565b506010805460ff19169055600190565b6109ff6119d9565b6001600160a01b03919091166000908152601f60205260409020805460ff1916911515919091179055565b6060600480546108e6906123c9565b610a416119d9565b6006546001600160a01b0390811690831603610aca5760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b657250616972730000000000000060648201526084015b60405180910390fd5b610ad48282611a85565b5050565b60003381610ae68286610edc565b905083811015610b465760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b6064820152608401610ac1565b61099c8286868403610fce565b60003361097781858561116c565b610b696119d9565b6001600160a01b0382166000818152601e6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b610bd06119d9565b7f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610c2e573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610c52919061242c565b6001600160a01b031663c9c65396307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610cbf573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610ce3919061242c565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015610d30573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610d54919061242c565b600680546001600160a01b0319166001600160a01b03929092169182179055610d7e9060016109f7565b600654610d95906001600160a01b03166001611a85565b306000908152602081905260409020546109db9047611ad8565b6000610db96119d9565b620186a0610dc660025490565b610dd1906001612449565b610ddb9190612460565b821015610e485760405162461bcd60e51b815260206004820152603560248201527f5377617020616d6f756e742063616e6e6f74206265206c6f776572207468616e60448201527410181718181892903a37ba30b61039bab838363c9760591b6064820152608401610ac1565b6103e8610e5460025490565b610e5f90600a612449565b610e699190612460565b821115610ed35760405162461bcd60e51b815260206004820152603260248201527f5377617020616d6f756e742063616e6e6f74206265206869676865722074686160448201527137101892903a37ba30b61039bab838363c9760711b6064820152608401610ac1565b50600a55600190565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b6000610f116119d9565b506012805460ff19169055600190565b610f296119d9565b6001600160a01b038116610f8e5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610ac1565b610f9781611a33565b50565b610fa26119d9565b60405133904780156108fc02916000818181858888f19350505050158015610f97573d6000803e3d6000fd5b6001600160a01b0383166110305760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610ac1565b6001600160a01b0382166110915760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610ac1565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006110fe8484610edc565b9050600019811461116657818110156111595760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e63650000006044820152606401610ac1565b6111668484848403610fce565b50505050565b6001600160a01b0383166111925760405162461bcd60e51b8152600401610ac190612482565b6001600160a01b0382166111b85760405162461bcd60e51b8152600401610ac1906124c7565b806000036111d1576111cc83836000611bd4565b505050565b60105460ff16156115d5576005546001600160a01b0384811691161480159061120857506005546001600160a01b03838116911614155b801561121c57506001600160a01b03821615155b801561123357506001600160a01b03821661dead14155b80156112495750600654600160a01b900460ff16155b156115d55760125460ff1615611371576005546001600160a01b038381169116148015906112a957507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b0316826001600160a01b031614155b80156112c357506006546001600160a01b03838116911614155b156113715732600090815260116020526040902054431161135e5760405162461bcd60e51b815260206004820152604960248201527f5f7472616e736665723a3a205472616e736665722044656c617920656e61626c60448201527f65642e20204f6e6c79206f6e652070757263686173652070657220626c6f636b6064820152681030b63637bbb2b21760b91b608482015260a401610ac1565b3260009081526011602052604090204390555b6001600160a01b038316600090815260208052604090205460ff1680156113b157506001600160a01b0382166000908152601f602052604090205460ff16155b15611495576009548111156114265760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b6064820152608401610ac1565b600b546001600160a01b03831660009081526020819052604090205461144c9083612419565b11156114905760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610ac1565b6115d5565b6001600160a01b038216600090815260208052604090205460ff1680156114d557506001600160a01b0383166000908152601f602052604090205460ff16155b1561154b576009548111156114905760405162461bcd60e51b815260206004820152603660248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152751036b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760511b6064820152608401610ac1565b6001600160a01b0382166000908152601f602052604090205460ff166115d557600b546001600160a01b0383166000908152602081905260409020546115919083612419565b11156115d55760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610ac1565b30600090815260208190526040902054600a54811080159081906116005750601054610100900460ff165b80156116165750600654600160a01b900460ff16155b801561163a57506001600160a01b038516600090815260208052604090205460ff16155b801561165f57506001600160a01b0385166000908152601e602052604090205460ff16155b801561168457506001600160a01b0384166000908152601e602052604090205460ff16155b156116b2576006805460ff60a01b1916600160a01b1790556116a4611cfe565b6006805460ff60a01b191690555b6001600160a01b038516600090815260208052604090205460ff1680156116f157506001600160a01b0384166000908152601e602052604090205460ff165b15611706576010805461ff0019166101001790555b600654600160a01b900460ff1615801561173757506001600160a01b038416600090815260208052604090205460ff165b801561174a5750601054610100900460ff165b80156117655750600d54600e546117619190612419565b4210155b1561178557600f54611778906001611f22565b600c55611783611f35565b505b6006546001600160a01b0386166000908152601e602052604090205460ff600160a01b9092048216159116806117d357506001600160a01b0385166000908152601e602052604090205460ff165b156117dc575060005b600081156119c5576001600160a01b038616600090815260208052604090205460ff16801561180d57506000601754115b156118cb57611832606461182c6017548861207f90919063ffffffff16565b9061208b565b9050601754601954826118459190612449565b61184f9190612460565b601c60008282546118609190612419565b9091555050601754601a546118759083612449565b61187f9190612460565b601d60008282546118909190612419565b90915550506017546018546118a59083612449565b6118af9190612460565b601b60008282546118c09190612419565b909155506119a79050565b6001600160a01b038716600090815260208052604090205460ff1680156118f457506000601354115b156119a757611913606461182c6013548861207f90919063ffffffff16565b9050601354601554826119269190612449565b6119309190612460565b601c60008282546119419190612419565b90915550506013546016546119569083612449565b6119609190612460565b601d60008282546119719190612419565b90915550506013546014546119869083612449565b6119909190612460565b601b60008282546119a19190612419565b90915550505b80156119b8576119b8873083611bd4565b6119c2818661250a565b94505b6119d0878787611bd4565b50505050505050565b6005546001600160a01b031633146109db5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610ac1565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b0382166000818152602080526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b611b03307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d84610fce565b6001600160a01b037f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d1663f305d7198230611b44606461182c88606361207f565b6040516001600160e01b031960e086901b1681526001600160a01b039092166004830152602482015260006044820181905260648201523360848201524260a482015260c40160606040518083038185885af1158015611ba8573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190611bcd919061251d565b5050505050565b6001600160a01b038316611bfa5760405162461bcd60e51b8152600401610ac190612482565b6001600160a01b038216611c205760405162461bcd60e51b8152600401610ac1906124c7565b6001600160a01b03831660009081526020819052604090205481811015611c985760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610ac1565b6001600160a01b03848116600081815260208181526040808320878703905593871680835291849020805487019055925185815290927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a3611166565b3060009081526020819052604081205490506000601d54601b54601c54611d259190612419565b611d2f9190612419565b9050600082600003611d4057505050565b600a54831115611d5857611d55836002612449565b92505b6000600283601c5486611d6b9190612449565b611d759190612460565b611d7f9190612460565b90506000611d8d8583611f22565b905047611d9982612097565b6000611da54783611f22565b90506000611dc28761182c601b548561207f90919063ffffffff16565b90506000611ddf8861182c601d548661207f90919063ffffffff16565b9050600081611dee848661250a565b611df8919061250a565b6000601c819055601b819055601d8190556008546040519293506001600160a01b031691849181818185875af1925050503d8060008114611e55576040519150601f19603f3d011682016040523d82523d6000602084013e611e5a565b606091505b50909850508615801590611e6e5750600081115b15611ec157611e7d8782611ad8565b601c54604080518881526020810184905280820192909252517f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619181900360600190a15b6007546040516001600160a01b03909116904790600081818185875af1925050503d8060008114611f0e576040519150601f19603f3d011682016040523d82523d6000602084013e611f13565b606091505b50505050505050505050505050565b6000611f2e828461250a565b9392505050565b42600e556006546040516370a0823160e01b81526001600160a01b039091166004820152600090819030906370a0823190602401602060405180830381865afa158015611f86573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611faa919061254b565b90506000611fc9600f5461182c600c548561207f90919063ffffffff16565b90508015611fea57600654611fea906001600160a01b031661dead83611bd4565b6006546040805160016209351760e01b0319815290516001600160a01b0390921691829163fff6cae991600480830192600092919082900301818387803b15801561203457600080fd5b505af1158015612048573d6000803e3d6000fd5b50506040517f454c91ae84fcc766ddda0dcb289f26b3d0176efeacf4061fc219fa6ca8c3048d925060009150a16001935050505090565b6000611f2e8284612449565b6000611f2e8284612460565b60408051600280825260608201835260009260208301908036833701905050905030816000815181106120cc576120cc612564565b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801561214a573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061216e919061242c565b8160018151811061218157612181612564565b60200260200101906001600160a01b031690816001600160a01b0316815250506121cc307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d84610fce565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d169063791ac9479061222190859060009086903090429060040161257a565b600060405180830381600087803b15801561223b57600080fd5b505af115801561224f573d6000803e3d6000fd5b505050505050565b600060208083528351808285015260005b8181101561228457858101830151858201604001528201612268565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b0381168114610f9757600080fd5b600080604083850312156122cd57600080fd5b82356122d8816122a5565b946020939093013593505050565b6000602082840312156122f857600080fd5b8135611f2e816122a5565b60008060006060848603121561231857600080fd5b8335612323816122a5565b92506020840135612333816122a5565b929592945050506040919091013590565b6000806040838503121561235757600080fd5b8235612362816122a5565b91506020830135801515811461237757600080fd5b809150509250929050565b60006020828403121561239457600080fd5b5035919050565b600080604083850312156123ae57600080fd5b82356123b9816122a5565b91506020830135612377816122a5565b600181811c908216806123dd57607f821691505b6020821081036123fd57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b8082018082111561097d5761097d612403565b60006020828403121561243e57600080fd5b8151611f2e816122a5565b808202811582820484141761097d5761097d612403565b60008261247d57634e487b7160e01b600052601260045260246000fd5b500490565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b8181038181111561097d5761097d612403565b60008060006060848603121561253257600080fd5b8351925060208401519150604084015190509250925092565b60006020828403121561255d57600080fd5b5051919050565b634e487b7160e01b600052603260045260246000fd5b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156125ca5784516001600160a01b0316835293830193918301916001016125a5565b50506001600160a01b0396909616606085015250505060800152939250505056fea2646970667358221220c6fb78320b7834b2a5def09dd28b129689c1cba43cf4affee2ef6d71178d1ba664736f6c63430008130033

Deployed Bytecode Sourcemap

37522:14599:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;16405:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;18756:201;;;;;;;;;;-1:-1:-1;18756:201:0;;;;;:::i;:::-;;:::i;:::-;;;1188:14:1;;1181:22;1163:41;;1151:2;1136:18;18756:201:0;1023:187:1;39016:64:0;;;;;;;;;;-1:-1:-1;39016:64:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;37597:51;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;1658:32:1;;;1640:51;;1628:2;1613:18;37597:51:0;1467:230:1;17525:108:0;;;;;;;;;;-1:-1:-1;17613:12:0;;17525:108;;;1848:25:1;;;1836:2;1821:18;17525:108:0;1702:177:1;37975:35:0;;;;;;;;;;;;;;;;38795:33;;;;;;;;;;;;;;;;38755;;;;;;;;;;;;;;;;19537:295;;;;;;;;;;-1:-1:-1;19537:295:0;;;;;:::i;:::-;;:::i;37690:53::-;;;;;;;;;;;;37736:6;37690:53;;38017:41;;;;;;;;;;;;;;;;17367:93;;;;;;;;;;-1:-1:-1;17367:93:0;;17450:2;2695:36:1;;2683:2;2668:18;17367:93:0;2553:184:1;20241:238:0;;;;;;;;;;-1:-1:-1;20241:238:0;;;;;:::i;:::-;;:::i;37655:28::-;;;;;;;;;;-1:-1:-1;37655:28:0;;;;-1:-1:-1;;;;;37655:28:0;;;38150:33;;;;;;;;;;-1:-1:-1;38150:33:0;;;;;;;;43528:125;;;;;;;;;;-1:-1:-1;43528:125:0;;;;;:::i;:::-;-1:-1:-1;;;;;43617:28:0;43593:4;43617:28;;;:19;:28;;;;;;;;;43528:125;38606:28;;;;;;;;;;;;;;;;38190:31;;;;;;;;;;-1:-1:-1;38190:31:0;;;;;;;;;;;17696:127;;;;;;;;;;-1:-1:-1;17696:127:0;;;;;:::i;:::-;-1:-1:-1;;;;;17797:18:0;17770:7;17797:18;;;;;;;;;;;;17696:127;9830:103;;;;;;;;;;;;;:::i;:::-;;41943:120;;;;;;;;;;;;;:::i;42734:144::-;;;;;;;;;;-1:-1:-1;42734:144:0;;;;;:::i;:::-;;:::i;37782:30::-;;;;;;;;;;-1:-1:-1;37782:30:0;;;;-1:-1:-1;;;;;37782:30:0;;;38495;;;;;;;;;;;;;;;;9182:87;;;;;;;;;;-1:-1:-1;9255:6:0;;-1:-1:-1;;;;;9255:6:0;9182:87;;37819:24;;;;;;;;;;-1:-1:-1;37819:24:0;;;;-1:-1:-1;;;;;37819:24:0;;;38641:31;;;;;;;;;;;;;;;;16624:104;;;;;;;;;;;;;:::i;38101:36::-;;;;;;;;;;;;;;;;43080:244;;;;;;;;;;-1:-1:-1;43080:244:0;;;;;:::i;:::-;;:::i;38569:24::-;;;;;;;;;;;;;;;;38835:27;;;;;;;;;;;;;;;;38717:25;;;;;;;;;;;;;;;;20982:436;;;;;;;;;;-1:-1:-1;20982:436:0;;;;;:::i;:::-;;:::i;38065:29::-;;;;;;;;;;;;;;;;18029:193;;;;;;;;;;-1:-1:-1;18029:193:0;;;;;:::i;:::-;;:::i;39238:58::-;;;;;;;;;;-1:-1:-1;39238:58:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;42890:182;;;;;;;;;;-1:-1:-1;42890:182:0;;;;;:::i;:::-;;:::i;38413:39::-;;;;;;;;;;-1:-1:-1;38413:39:0;;;;;;;;37856:35;;;;;;;;;;;;;;;;51693:388;;;;;;;;;;;;;:::i;42337:385::-;;;;;;;;;;-1:-1:-1;42337:385:0;;;;;:::i;:::-;;:::i;38461:27::-;;;;;;;;;;;;;;;;18285:151;;;;;;;;;;-1:-1:-1;18285:151:0;;;;;:::i;:::-;;:::i;37898:33::-;;;;;;;;;;;;;;;;42128:134;;;;;;;;;;;;;:::i;38532:30::-;;;;;;;;;;;;;;;;10088:201;;;;;;;;;;-1:-1:-1;10088:201:0;;;;;:::i;:::-;;:::i;51574:111::-;;;;;;;;;;;;;:::i;38679:31::-;;;;;;;;;;;;;;;;37938:24;;;;;;;;;;;;;;;;16405:100;16459:13;16492:5;16485:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;16405:100;:::o;18756:201::-;18839:4;7813:10;18895:32;7813:10;18911:7;18920:6;18895:8;:32::i;:::-;18945:4;18938:11;;;18756:201;;;;;:::o;19537:295::-;19668:4;7813:10;19726:38;19742:4;7813:10;19757:6;19726:15;:38::i;:::-;19775:27;19785:4;19791:2;19795:6;19775:9;:27::i;:::-;-1:-1:-1;19820:4:0;;19537:295;-1:-1:-1;;;;19537:295:0:o;20241:238::-;20329:4;7813:10;20385:64;7813:10;20401:7;20438:10;20410:25;7813:10;20401:7;20410:9;:25::i;:::-;:38;;;;:::i;:::-;20385:8;:64::i;9830:103::-;9068:13;:11;:13::i;:::-;9895:30:::1;9922:1;9895:18;:30::i;:::-;9830:103::o:0;41943:120::-;41995:4;9068:13;:11;:13::i;:::-;-1:-1:-1;42011:14:0::1;:22:::0;;-1:-1:-1;;42011:22:0::1;::::0;;;41943:120;:::o;42734:144::-;9068:13;:11;:13::i;:::-;-1:-1:-1;;;;;42824:39:0;;;::::1;;::::0;;;:31:::1;:39;::::0;;;;:46;;-1:-1:-1;;42824:46:0::1;::::0;::::1;;::::0;;;::::1;::::0;;42734:144::o;16624:104::-;16680:13;16713:7;16706:14;;;;;:::i;43080:244::-;9068:13;:11;:13::i;:::-;43187::::1;::::0;-1:-1:-1;;;;;43187:13:0;;::::1;43179:21:::0;;::::1;::::0;43171:91:::1;;;::::0;-1:-1:-1;;;43171:91:0;;4590:2:1;43171:91:0::1;::::0;::::1;4572:21:1::0;4629:2;4609:18;;;4602:30;4668:34;4648:18;;;4641:62;4739:27;4719:18;;;4712:55;4784:19;;43171:91:0::1;;;;;;;;;43275:41;43304:4;43310:5;43275:28;:41::i;:::-;43080:244:::0;;:::o;20982:436::-;21075:4;7813:10;21075:4;21158:25;7813:10;21175:7;21158:9;:25::i;:::-;21131:52;;21222:15;21202:16;:35;;21194:85;;;;-1:-1:-1;;;21194:85:0;;5016:2:1;21194:85:0;;;4998:21:1;5055:2;5035:18;;;5028:30;5094:34;5074:18;;;5067:62;-1:-1:-1;;;5145:18:1;;;5138:35;5190:19;;21194:85:0;4814:401:1;21194:85:0;21315:60;21324:5;21331:7;21359:15;21340:16;:34;21315:8;:60::i;18029:193::-;18108:4;7813:10;18164:28;7813:10;18181:2;18185:6;18164:9;:28::i;42890:182::-;9068:13;:11;:13::i;:::-;-1:-1:-1;;;;;42975:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;;;;:39;;-1:-1:-1;;42975:39:0::1;::::0;::::1;;::::0;;::::1;::::0;;;43030:34;;1163:41:1;;;43030:34:0::1;::::0;1136:18:1;43030:34:0::1;;;;;;;42890:182:::0;;:::o;51693:388::-;9068:13;:11;:13::i;:::-;51788:15:::1;-1:-1:-1::0;;;;;51788:23:0::1;;:25;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;;;;51770:55:0::1;;51834:4;51841:15;-1:-1:-1::0;;;;;51841:20:0::1;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;51770:94;::::0;-1:-1:-1;;;;;;51770:94:0::1;::::0;;;;;;-1:-1:-1;;;;;5706:15:1;;;51770:94:0::1;::::0;::::1;5688:34:1::0;5758:15;;5738:18;;;5731:43;5623:18;;51770:94:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;51754:13;:110:::0;;-1:-1:-1;;;;;;51754:110:0::1;-1:-1:-1::0;;;;;51754:110:0;;;::::1;::::0;;::::1;::::0;;51875:55:::1;::::0;-1:-1:-1;51875:25:0::1;:55::i;:::-;51978:13;::::0;51941:58:::1;::::0;-1:-1:-1;;;;;51978:13:0::1;::::0;51941:28:::1;:58::i;:::-;52043:4;17770:7:::0;17797:18;;;;;;;;;;;52012:61:::1;::::0;52051:21:::1;52012:12;:61::i;42337:385::-:0;42418:4;9068:13;:11;:13::i;:::-;42475:6:::1;42455:13;17613:12:::0;;;17525:108;42455:13:::1;:17;::::0;42471:1:::1;42455:17;:::i;:::-;:26;;;;:::i;:::-;42442:9;:39;;42434:105;;;::::0;-1:-1:-1;;;42434:105:0;;6382:2:1;42434:105:0::1;::::0;::::1;6364:21:1::0;6421:2;6401:18;;;6394:30;6460:34;6440:18;;;6433:62;-1:-1:-1;;;6511:18:1;;;6504:51;6572:19;;42434:105:0::1;6180:417:1::0;42434:105:0::1;42592:4;42571:13;17613:12:::0;;;17525:108;42571:13:::1;:18;::::0;42587:2:::1;42571:18;:::i;:::-;:25;;;;:::i;:::-;42558:9;:38;;42550:101;;;::::0;-1:-1:-1;;;42550:101:0;;6804:2:1;42550:101:0::1;::::0;::::1;6786:21:1::0;6843:2;6823:18;;;6816:30;6882:34;6862:18;;;6855:62;-1:-1:-1;;;6933:18:1;;;6926:48;6991:19;;42550:101:0::1;6602:414:1::0;42550:101:0::1;-1:-1:-1::0;42662:18:0::1;:30:::0;42710:4:::1;::::0;42337:385::o;18285:151::-;-1:-1:-1;;;;;18401:18:0;;;18374:7;18401:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;18285:151::o;42128:134::-;42188:4;9068:13;:11;:13::i;:::-;-1:-1:-1;42204:20:0::1;:28:::0;;-1:-1:-1;;42204:28:0::1;::::0;;;42128:134;:::o;10088:201::-;9068:13;:11;:13::i;:::-;-1:-1:-1;;;;;10177:22:0;::::1;10169:73;;;::::0;-1:-1:-1;;;10169:73:0;;7223:2:1;10169:73:0::1;::::0;::::1;7205:21:1::0;7262:2;7242:18;;;7235:30;7301:34;7281:18;;;7274:62;-1:-1:-1;;;7352:18:1;;;7345:36;7398:19;;10169:73:0::1;7021:402:1::0;10169:73:0::1;10253:28;10272:8;10253:18;:28::i;:::-;10088:201:::0;:::o;51574:111::-;9068:13;:11;:13::i;:::-;51626:51:::1;::::0;51634:10:::1;::::0;51655:21:::1;51626:51:::0;::::1;;;::::0;::::1;::::0;;;51655:21;51634:10;51626:51;::::1;;;;;;;;;;;;;::::0;::::1;;;;25009:380:::0;-1:-1:-1;;;;;25145:19:0;;25137:68;;;;-1:-1:-1;;;25137:68:0;;7630:2:1;25137:68:0;;;7612:21:1;7669:2;7649:18;;;7642:30;7708:34;7688:18;;;7681:62;-1:-1:-1;;;7759:18:1;;;7752:34;7803:19;;25137:68:0;7428:400:1;25137:68:0;-1:-1:-1;;;;;25224:21:0;;25216:68;;;;-1:-1:-1;;;25216:68:0;;8035:2:1;25216:68:0;;;8017:21:1;8074:2;8054:18;;;8047:30;8113:34;8093:18;;;8086:62;-1:-1:-1;;;8164:18:1;;;8157:32;8206:19;;25216:68:0;7833:398:1;25216:68:0;-1:-1:-1;;;;;25297:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;25349:32;;1848:25:1;;;25349:32:0;;1821:18:1;25349:32:0;;;;;;;25009:380;;;:::o;25680:453::-;25815:24;25842:25;25852:5;25859:7;25842:9;:25::i;:::-;25815:52;;-1:-1:-1;;25882:16:0;:37;25878:248;;25964:6;25944:16;:26;;25936:68;;;;-1:-1:-1;;;25936:68:0;;8438:2:1;25936:68:0;;;8420:21:1;8477:2;8457:18;;;8450:30;8516:31;8496:18;;;8489:59;8565:18;;25936:68:0;8236:353:1;25936:68:0;26048:51;26057:5;26064:7;26092:6;26073:16;:25;26048:8;:51::i;:::-;25804:329;25680:453;;;:::o;43661:4302::-;-1:-1:-1;;;;;43793:18:0;;43785:68;;;;-1:-1:-1;;;43785:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;43872:16:0;;43864:64;;;;-1:-1:-1;;;43864:64:0;;;;;;;:::i;:::-;43953:6;43963:1;43953:11;43950:92;;43981:28;43997:4;44003:2;44007:1;43981:15;:28::i;:::-;43661:4302;;;:::o;43950:92::-;44065:14;;;;44062:1673;;;9255:6;;-1:-1:-1;;;;;44117:15:0;;;9255:6;;44117:15;;;;:49;;-1:-1:-1;9255:6:0;;-1:-1:-1;;;;;44153:13:0;;;9255:6;;44153:13;;44117:49;:86;;;;-1:-1:-1;;;;;;44187:16:0;;;;44117:86;:128;;;;-1:-1:-1;;;;;;44224:21:0;;44238:6;44224:21;;44117:128;:158;;;;-1:-1:-1;44267:8:0;;-1:-1:-1;;;44267:8:0;;;;44266:9;44117:158;44095:1629;;;44447:20;;;;44443:423;;;9255:6;;-1:-1:-1;;;;;44495:13:0;;;9255:6;;44495:13;;;;:47;;;44526:15;-1:-1:-1;;;;;44512:30:0;:2;-1:-1:-1;;;;;44512:30:0;;;44495:47;:79;;;;-1:-1:-1;44560:13:0;;-1:-1:-1;;;;;44546:28:0;;;44560:13;;44546:28;;44495:79;44491:356;;;44639:9;44610:39;;;;:28;:39;;;;;;44652:12;-1:-1:-1;44602:140:0;;;;-1:-1:-1;;;44602:140:0;;9606:2:1;44602:140:0;;;9588:21:1;9645:2;9625:18;;;9618:30;9684:34;9664:18;;;9657:62;9755:34;9735:18;;;9728:62;-1:-1:-1;;;9806:19:1;;;9799:40;9856:19;;44602:140:0;9404:477:1;44602:140:0;44798:9;44769:39;;;;:28;:39;;;;;44811:12;44769:54;;44491:356;-1:-1:-1;;;;;44935:31:0;;;;;;:25;:31;;;;;;;;:71;;;;-1:-1:-1;;;;;;44971:35:0;;;;;;:31;:35;;;;;;;;44970:36;44935:71;44931:778;;;45053:20;;45043:6;:30;;45035:96;;;;-1:-1:-1;;;45035:96:0;;10088:2:1;45035:96:0;;;10070:21:1;10127:2;10107:18;;;10100:30;10166:34;10146:18;;;10139:62;-1:-1:-1;;;10217:18:1;;;10210:51;10278:19;;45035:96:0;9886:417:1;45035:96:0;45192:9;;-1:-1:-1;;;;;17797:18:0;;17770:7;17797:18;;;;;;;;;;;45166:22;;:6;:22;:::i;:::-;:35;;45158:67;;;;-1:-1:-1;;;45158:67:0;;10510:2:1;45158:67:0;;;10492:21:1;10549:2;10529:18;;;10522:30;-1:-1:-1;;;10568:18:1;;;10561:49;10627:18;;45158:67:0;10308:343:1;45158:67:0;44931:778;;;-1:-1:-1;;;;;45319:29:0;;;;;;:25;:29;;;;;;;;:71;;;;-1:-1:-1;;;;;;45353:37:0;;;;;;:31;:37;;;;;;;;45352:38;45319:71;45315:394;;;45437:20;;45427:6;:30;;45419:97;;;;-1:-1:-1;;;45419:97:0;;10858:2:1;45419:97:0;;;10840:21:1;10897:2;10877:18;;;10870:30;10936:34;10916:18;;;10909:62;-1:-1:-1;;;10987:18:1;;;10980:52;11049:19;;45419:97:0;10656:418:1;45315:394:0;-1:-1:-1;;;;;45563:35:0;;;;;;:31;:35;;;;;;;;45559:150;;45656:9;;-1:-1:-1;;;;;17797:18:0;;17770:7;17797:18;;;;;;;;;;;45630:22;;:6;:22;:::i;:::-;:35;;45622:67;;;;-1:-1:-1;;;45622:67:0;;10510:2:1;45622:67:0;;;10492:21:1;10549:2;10529:18;;;10522:30;-1:-1:-1;;;10568:18:1;;;10561:49;10627:18;;45622:67:0;10308:343:1;45622:67:0;45814:4;45765:28;17797:18;;;;;;;;;;;45880;;45856:42;;;;;;;45929:35;;-1:-1:-1;45953:11:0;;;;;;;45929:35;:61;;;;-1:-1:-1;45982:8:0;;-1:-1:-1;;;45982:8:0;;;;45981:9;45929:61;:110;;;;-1:-1:-1;;;;;;46008:31:0;;;;;;:25;:31;;;;;;;;46007:32;45929:110;:153;;;;-1:-1:-1;;;;;;46057:25:0;;;;;;:19;:25;;;;;;;;46056:26;45929:153;:194;;;;-1:-1:-1;;;;;;46100:23:0;;;;;;:19;:23;;;;;;;;46099:24;45929:194;45911:338;;;46150:8;:15;;-1:-1:-1;;;;46150:15:0;-1:-1:-1;;;46150:15:0;;;46194:10;:8;:10::i;:::-;46221:8;:16;;-1:-1:-1;;;;46221:16:0;;;45911:338;-1:-1:-1;;;;;46264:31:0;;;;;;:25;:31;;;;;;;;:58;;;;-1:-1:-1;;;;;;46299:23:0;;;;;;:19;:23;;;;;;;;46264:58;46261:81;;;46324:11;:18;;-1:-1:-1;;46324:18:0;;;;;46261:81;46357:8;;-1:-1:-1;;;46357:8:0;;;;46356:9;:42;;;;-1:-1:-1;;;;;;46369:29:0;;;;;;:25;:29;;;;;;;;46356:42;:57;;;;-1:-1:-1;46402:11:0;;;;;;;46356:57;:112;;;;;46453:15;;46436:14;;:32;;;;:::i;:::-;46417:15;:51;;46356:112;46353:224;;;46503:11;;:18;;46519:1;46503:15;:18::i;:::-;46484:16;:37;46536:29;:27;:29::i;:::-;;46353:224;46605:8;;-1:-1:-1;;;;;46714:25:0;;46589:12;46714:25;;;:19;:25;;;;;;46605:8;-1:-1:-1;;;46605:8:0;;;;;46604:9;;46714:25;;:52;;-1:-1:-1;;;;;;46743:23:0;;;;;;:19;:23;;;;;;;;46714:52;46711:99;;;-1:-1:-1;46793:5:0;46711:99;46830:12;46934:7;46931:979;;;-1:-1:-1;;;;;46985:29:0;;;;;;:25;:29;;;;;;;;:50;;;;;47034:1;47018:13;;:17;46985:50;46981:754;;;47062:34;47092:3;47062:25;47073:13;;47062:6;:10;;:25;;;;:::i;:::-;:29;;:34::i;:::-;47055:41;;47163:13;;47144:16;;47137:4;:23;;;;:::i;:::-;:39;;;;:::i;:::-;47115:18;;:61;;;;;;;:::i;:::-;;;;-1:-1:-1;;47231:13:0;;47218:10;;47211:17;;:4;:17;:::i;:::-;:33;;;;:::i;:::-;47195:12;;:49;;;;;;;:::i;:::-;;;;-1:-1:-1;;47311:13:0;;47292:16;;47285:23;;:4;:23;:::i;:::-;:39;;;;:::i;:::-;47263:18;;:61;;;;;;;:::i;:::-;;;;-1:-1:-1;46981:754:0;;-1:-1:-1;46981:754:0;;-1:-1:-1;;;;;47385:31:0;;;;;;:25;:31;;;;;;;;:51;;;;;47435:1;47420:12;;:16;47385:51;47382:353;;;47464:33;47493:3;47464:24;47475:12;;47464:6;:10;;:24;;;;:::i;:33::-;47457:40;;47563:12;;47545:15;;47538:4;:22;;;;:::i;:::-;:37;;;;:::i;:::-;47516:18;;:59;;;;;;;:::i;:::-;;;;-1:-1:-1;;47629:12:0;;47617:9;;47610:16;;:4;:16;:::i;:::-;:31;;;;:::i;:::-;47594:12;;:47;;;;;;;:::i;:::-;;;;-1:-1:-1;;47707:12:0;;47689:15;;47682:22;;:4;:22;:::i;:::-;:37;;;;:::i;:::-;47660:18;;:59;;;;;;;:::i;:::-;;;;-1:-1:-1;;47382:353:0;47766:8;;47763:93;;47798:42;47814:4;47828;47835;47798:15;:42::i;:::-;47884:14;47894:4;47884:14;;:::i;:::-;;;46931:979;47922:33;47938:4;47944:2;47948:6;47922:15;:33::i;:::-;43774:4189;;;;43661:4302;;;:::o;9347:132::-;9255:6;;-1:-1:-1;;;;;9255:6:0;7813:10;9411:23;9403:68;;;;-1:-1:-1;;;9403:68:0;;11414:2:1;9403:68:0;;;11396:21:1;;;11433:18;;;11426:30;11492:34;11472:18;;;11465:62;11544:18;;9403:68:0;11212:356:1;10449:191:0;10542:6;;;-1:-1:-1;;;;;10559:17:0;;;-1:-1:-1;;;;;;10559:17:0;;;;;;;10592:40;;10542:6;;;10559:17;10542:6;;10592:40;;10523:16;;10592:40;10512:128;10449:191;:::o;43332:188::-;-1:-1:-1;;;;;43415:31:0;;;;;;:25;:31;;;;;;:39;;-1:-1:-1;;43415:39:0;;;;;;;;;;43472:40;;43415:39;;:31;43472:40;;;43332:188;;:::o;48584:533::-;48732:62;48749:4;48764:15;48782:11;48732:8;:62::i;:::-;-1:-1:-1;;;;;48837:15:0;:31;;48876:9;48909:4;48929:28;48953:3;48929:19;:11;48945:2;48929:15;:19::i;:28::-;48837:272;;-1:-1:-1;;;;;;48837:272:0;;;;;;;-1:-1:-1;;;;;11932:15:1;;;48837:272:0;;;11914:34:1;11964:18;;;11957:34;48972:1:0;12007:18:1;;;12000:34;;;12050:18;;;12043:34;49058:10:0;12093:19:1;;;12086:44;49083:15:0;12146:19:1;;;12139:35;11848:19;;48837:272:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;48584:533;;:::o;21888:840::-;-1:-1:-1;;;;;22019:18:0;;22011:68;;;;-1:-1:-1;;;22011:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;22098:16:0;;22090:64;;;;-1:-1:-1;;;22090:64:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;22240:15:0;;22218:19;22240:15;;;;;;;;;;;22274:21;;;;22266:72;;;;-1:-1:-1;;;22266:72:0;;12698:2:1;22266:72:0;;;12680:21:1;12737:2;12717:18;;;12710:30;12776:34;12756:18;;;12749:62;-1:-1:-1;;;12827:18:1;;;12820:36;12873:19;;22266:72:0;12496:402:1;22266:72:0;-1:-1:-1;;;;;22374:15:0;;;:9;:15;;;;;;;;;;;22392:20;;;22374:38;;22592:13;;;;;;;;;;:23;;;;;;22644:26;;1848:25:1;;;22592:13:0;;22644:26;;1821:18:1;22644:26:0;;;;;;;22683:37;43661:4302;49125:1623;49208:4;49164:23;17797:18;;;;;;;;;;;49164:50;;49225:25;49295:12;;49274:18;;49253;;:39;;;;:::i;:::-;:54;;;;:::i;:::-;49225:82;;49318:12;49354:15;49373:1;49354:20;49351:34;;49377:7;;;49125:1623::o;49351:34::-;49418:18;;49400:15;:36;49397:102;;;49468:19;:15;49486:1;49468:19;:::i;:::-;49450:37;;49397:102;49568:23;49653:1;49633:17;49612:18;;49594:15;:36;;;;:::i;:::-;:56;;;;:::i;:::-;:60;;;;:::i;:::-;49568:86;-1:-1:-1;49665:26:0;49694:36;:15;49568:86;49694:19;:36::i;:::-;49665:65;-1:-1:-1;49779:21:0;49813:36;49665:65;49813:16;:36::i;:::-;49863:18;49884:44;:21;49910:17;49884:25;:44::i;:::-;49863:65;;49949:23;49975:57;50014:17;49975:34;49990:18;;49975:10;:14;;:34;;;;:::i;:57::-;49949:83;;50043:17;50063:51;50096:17;50063:28;50078:12;;50063:10;:14;;:28;;;;:::i;:51::-;50043:71;-1:-1:-1;50145:23:0;50043:71;50171:28;50184:15;50171:10;:28;:::i;:::-;:40;;;;:::i;:::-;50263:1;50242:18;:22;;;50275:18;:22;;;50308:12;:16;;;50366:9;;50358:45;;50145:66;;-1:-1:-1;;;;;;50366:9:0;;50389;;50358:45;50263:1;50358:45;50389:9;50366;50358:45;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;50345:58:0;;-1:-1:-1;;50427:19:0;;;;;:42;;;50468:1;50450:15;:19;50427:42;50424:210;;;50485:46;50498:15;50515;50485:12;:46::i;:::-;50603:18;;50551:71;;;13315:25:1;;;13371:2;13356:18;;13349:34;;;13399:18;;;13392:34;;;;50551:71:0;;;;;;13303:2:1;50551:71:0;;;50424:210;50685:15;;50677:63;;-1:-1:-1;;;;;50685:15:0;;;;50714:21;;50677:63;;;;50714:21;50685:15;50677:63;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;;;49125:1623:0:o;3270:98::-;3328:7;3355:5;3359:1;3355;:5;:::i;:::-;3348:12;3270:98;-1:-1:-1;;;3270:98:0:o;50756:810::-;50856:15;50839:14;:32;50980:13;;50965:29;;-1:-1:-1;;;50965:29:0;;-1:-1:-1;;;;;50980:13:0;;;50965:29;;;1640:51:1;50813:4:0;;;;50965;;:14;;1613:18:1;;50965:29:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;50934:60;;51052:20;51075:59;51122:11;;51075:42;51100:16;;51075:20;:24;;:42;;;;:::i;:59::-;51052:82;-1:-1:-1;51247:16:0;;51243:109;;51295:13;;51279:61;;-1:-1:-1;;;;;51295:13:0;51318:6;51327:12;51279:15;:61::i;:::-;51472:13;;51497:11;;;-1:-1:-1;;;;;;51497:11:0;;;;-1:-1:-1;;;;;51472:13:0;;;;;;51497:9;;:11;;;;;51435:19;;51497:11;;;;;;;51435:19;51472:13;51497:11;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;51524:12:0;;;;-1:-1:-1;51524:12:0;;-1:-1:-1;51524:12:0;51554:4;51547:11;;;;;50756:810;:::o;3627:98::-;3685:7;3712:5;3716:1;3712;:5;:::i;4026:98::-;4084:7;4111:5;4115:1;4111;:5;:::i;47971:601::-;48123:16;;;48137:1;48123:16;;;;;;;;48099:21;;48123:16;;;;;;;;;;-1:-1:-1;48123:16:0;48099:40;;48168:4;48150;48155:1;48150:7;;;;;;;;:::i;:::-;;;;;;:23;-1:-1:-1;;;;;48150:23:0;;;-1:-1:-1;;;;;48150:23:0;;;;;48194:15;-1:-1:-1;;;;;48194:20:0;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;48184:4;48189:1;48184:7;;;;;;;;:::i;:::-;;;;;;:32;-1:-1:-1;;;;;48184:32:0;;;-1:-1:-1;;;;;48184:32:0;;;;;48229:62;48246:4;48261:15;48279:11;48229:8;:62::i;:::-;48330:224;;-1:-1:-1;;;48330:224:0;;-1:-1:-1;;;;;48330:15:0;:66;;;;:224;;48411:11;;48437:1;;48481:4;;48508;;48528:15;;48330:224;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;48026:546;47971:601;:::o;14:548:1:-;126:4;155:2;184;173:9;166:21;216:6;210:13;259:6;254:2;243:9;239:18;232:34;284:1;294:140;308:6;305:1;302:13;294:140;;;403:14;;;399:23;;393:30;369:17;;;388:2;365:26;358:66;323:10;;294:140;;;298:3;483:1;478:2;469:6;458:9;454:22;450:31;443:42;553:2;546;542:7;537:2;529:6;525:15;521:29;510:9;506:45;502:54;494:62;;;;14:548;;;;:::o;567:131::-;-1:-1:-1;;;;;642:31:1;;632:42;;622:70;;688:1;685;678:12;703:315;771:6;779;832:2;820:9;811:7;807:23;803:32;800:52;;;848:1;845;838:12;800:52;887:9;874:23;906:31;931:5;906:31;:::i;:::-;956:5;1008:2;993:18;;;;980:32;;-1:-1:-1;;;703:315:1:o;1215:247::-;1274:6;1327:2;1315:9;1306:7;1302:23;1298:32;1295:52;;;1343:1;1340;1333:12;1295:52;1382:9;1369:23;1401:31;1426:5;1401:31;:::i;1884:456::-;1961:6;1969;1977;2030:2;2018:9;2009:7;2005:23;2001:32;1998:52;;;2046:1;2043;2036:12;1998:52;2085:9;2072:23;2104:31;2129:5;2104:31;:::i;:::-;2154:5;-1:-1:-1;2211:2:1;2196:18;;2183:32;2224:33;2183:32;2224:33;:::i;:::-;1884:456;;2276:7;;-1:-1:-1;;;2330:2:1;2315:18;;;;2302:32;;1884:456::o;2742:416::-;2807:6;2815;2868:2;2856:9;2847:7;2843:23;2839:32;2836:52;;;2884:1;2881;2874:12;2836:52;2923:9;2910:23;2942:31;2967:5;2942:31;:::i;:::-;2992:5;-1:-1:-1;3049:2:1;3034:18;;3021:32;3091:15;;3084:23;3072:36;;3062:64;;3122:1;3119;3112:12;3062:64;3145:7;3135:17;;;2742:416;;;;;:::o;3163:180::-;3222:6;3275:2;3263:9;3254:7;3250:23;3246:32;3243:52;;;3291:1;3288;3281:12;3243:52;-1:-1:-1;3314:23:1;;3163:180;-1:-1:-1;3163:180:1:o;3348:388::-;3416:6;3424;3477:2;3465:9;3456:7;3452:23;3448:32;3445:52;;;3493:1;3490;3483:12;3445:52;3532:9;3519:23;3551:31;3576:5;3551:31;:::i;:::-;3601:5;-1:-1:-1;3658:2:1;3643:18;;3630:32;3671:33;3630:32;3671:33;:::i;3741:380::-;3820:1;3816:12;;;;3863;;;3884:61;;3938:4;3930:6;3926:17;3916:27;;3884:61;3991:2;3983:6;3980:14;3960:18;3957:38;3954:161;;4037:10;4032:3;4028:20;4025:1;4018:31;4072:4;4069:1;4062:15;4100:4;4097:1;4090:15;3954:161;;3741:380;;;:::o;4126:127::-;4187:10;4182:3;4178:20;4175:1;4168:31;4218:4;4215:1;4208:15;4242:4;4239:1;4232:15;4258:125;4323:9;;;4344:10;;;4341:36;;;4357:18;;:::i;5220:251::-;5290:6;5343:2;5331:9;5322:7;5318:23;5314:32;5311:52;;;5359:1;5356;5349:12;5311:52;5391:9;5385:16;5410:31;5435:5;5410:31;:::i;5785:168::-;5858:9;;;5889;;5906:15;;;5900:22;;5886:37;5876:71;;5927:18;;:::i;5958:217::-;5998:1;6024;6014:132;;6068:10;6063:3;6059:20;6056:1;6049:31;6103:4;6100:1;6093:15;6131:4;6128:1;6121:15;6014:132;-1:-1:-1;6160:9:1;;5958:217::o;8594:401::-;8796:2;8778:21;;;8835:2;8815:18;;;8808:30;8874:34;8869:2;8854:18;;8847:62;-1:-1:-1;;;8940:2:1;8925:18;;8918:35;8985:3;8970:19;;8594:401::o;9000:399::-;9202:2;9184:21;;;9241:2;9221:18;;;9214:30;9280:34;9275:2;9260:18;;9253:62;-1:-1:-1;;;9346:2:1;9331:18;;9324:33;9389:3;9374:19;;9000:399::o;11079:128::-;11146:9;;;11167:11;;;11164:37;;;11181:18;;:::i;12185:306::-;12273:6;12281;12289;12342:2;12330:9;12321:7;12317:23;12313:32;12310:52;;;12358:1;12355;12348:12;12310:52;12387:9;12381:16;12371:26;;12437:2;12426:9;12422:18;12416:25;12406:35;;12481:2;12470:9;12466:18;12460:25;12450:35;;12185:306;;;;;:::o;13437:184::-;13507:6;13560:2;13548:9;13539:7;13535:23;13531:32;13528:52;;;13576:1;13573;13566:12;13528:52;-1:-1:-1;13599:16:1;;13437:184;-1:-1:-1;13437:184:1:o;13758:127::-;13819:10;13814:3;13810:20;13807:1;13800:31;13850:4;13847:1;13840:15;13874:4;13871:1;13864:15;13890:980;14152:4;14200:3;14189:9;14185:19;14231:6;14220:9;14213:25;14257:2;14295:6;14290:2;14279:9;14275:18;14268:34;14338:3;14333:2;14322:9;14318:18;14311:31;14362:6;14397;14391:13;14428:6;14420;14413:22;14466:3;14455:9;14451:19;14444:26;;14505:2;14497:6;14493:15;14479:29;;14526:1;14536:195;14550:6;14547:1;14544:13;14536:195;;;14615:13;;-1:-1:-1;;;;;14611:39:1;14599:52;;14706:15;;;;14671:12;;;;14647:1;14565:9;14536:195;;;-1:-1:-1;;;;;;;14787:32:1;;;;14782:2;14767:18;;14760:60;-1:-1:-1;;;14851:3:1;14836:19;14829:35;14748:3;13890:980;-1:-1:-1;;;13890:980:1:o

Swarm Source

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