ETH Price: $2,398.39 (-3.55%)
Gas: 3.51 Gwei

Token

AI SHIBA INU (AISHIB)
 

Overview

Max Total Supply

589,589,939,806,592.2 AISHIB

Holders

45

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 9 Decimals)

Filtered by Token Holder
Uniswap V2: AISHIB 9
Balance
15,759,638,125,535.992389535 AISHIB

Value
$0.00
0xa646108873b6faccdfe9bf2ca7500cea2ba1f833
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:
AISHIB

Compiler Version
v0.8.20+commit.a1b79de6

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2023-07-23
*/

pragma solidity ^0.8.19;
// SPDX-License-Identifier: Unlicensed

/**
 * @dev Interface of the ERC20 standard as defined in the EIP.
 */
interface IBEP20 {
    /**
     * @dev Returns the amount of tokens in existence.
     */
    function totalSupply() external view returns (uint256);

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

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

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

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

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

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

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

// 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 no longer needed starting with Solidity 0.8. 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 substraction 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. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * 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;
        }
    }
}

/*
 * @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) {
        this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
        return msg.data;
    }
}

/**
 * @dev Collection of functions related to the address type
 */
library Address {
    /**
     * @dev Returns true if `account` is a contract.
     *
     * [IMPORTANT]
     * ====
     * It is unsafe to assume that an address for which this function returns
     * false is an externally-owned account (EOA) and not a contract.
     *
     * Among others, `isContract` will return false for the following
     * types of addresses:
     *
     *  - an externally-owned account
     *  - a contract in construction
     *  - an address where a contract will be created
     *  - an address where a contract lived, but was destroyed
     * ====
     */
    function isContract(address account) internal view returns (bool) {
        // This method relies on extcodesize, which returns 0 for contracts in
        // construction, since the code is only stored at the end of the
        // constructor execution.

        uint256 size;
        // solhint-disable-next-line no-inline-assembly
        assembly { size := extcodesize(account) }
        return size > 0;
    }

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

        // solhint-disable-next-line avoid-low-level-calls, avoid-call-value
        (bool success, ) = recipient.call{ value: amount }("");
        require(success, "Address: unable to send value, recipient may have reverted");
    }

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

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

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

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

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.call{ value: value }(data);
        return _verifyCallResult(success, returndata, errorMessage);
    }

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

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(address target, bytes memory data, string memory errorMessage) internal view returns (bytes memory) {
        require(isContract(target), "Address: static call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.staticcall(data);
        return _verifyCallResult(success, returndata, errorMessage);
    }

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

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.4._
     */
    function functionDelegateCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) {
        require(isContract(target), "Address: delegate call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.delegatecall(data);
        return _verifyCallResult(success, returndata, errorMessage);
    }

    function _verifyCallResult(bool success, bytes memory returndata, string memory errorMessage) private pure returns(bytes memory) {
        if (success) {
            return returndata;
        } else {
            // Look for revert reason and bubble it up if present
            if (returndata.length > 0) {
                // The easiest way to bubble the revert reason is using memory via assembly

                // solhint-disable-next-line no-inline-assembly
                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert(errorMessage);
            }
        }
    }
}

/**
 * @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.
 */
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 () {
        address msgSender = _msgSender();
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }

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

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

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

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

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

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 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 AISHIB is Context, IBEP20, Ownable {
    using SafeMath for uint256;
    using Address for address;

    mapping (address => uint256) private _rOwned;
    mapping (address => uint256) private _tOwned;
    mapping (address => mapping (address => uint256)) private _allowances;

    mapping (address => bool) private _isExcludedFromFee;

    mapping (address => bool) private _isExcluded;
    address[] private _excluded;
	
	address private _burnWalletAddress = 0x000000000000000000000000000000000000dEaD;
   
    uint256 private constant MAX = ~uint256(0);
    uint256 private _tTotal = 589589939806592.2 * 10**9;
    uint256 private _rTotal = (MAX - (MAX % _tTotal));
    uint256 private _tFeeTotal;

    string private _name = "AI SHIBA INU";
    string private _symbol = "AISHIB";
    uint8 private _decimals = 9;
    
    uint256 public _taxFee = 0;
    uint256 private _previousTaxFee = _taxFee;
	
    uint256 public _liquidityFee = 1;
    uint256 private _previousLiquidityFee = _liquidityFee;
	
	uint256 public _burnFee = 1;
    uint256 private _previousBurnFee = _burnFee;
    

    IuniSwapV2Router02 public immutable uniSwapV2Router;
    address public immutable uniSwapV2Pair;
    
    bool inSwapAndLiquify;
    bool public swapAndLiquifyEnabled = true;
    
    uint256 public _maxTxAmount = 589589939806592.2 * 10**9;
    uint256 public numTokensSellToAddToLiquidity = 1000000000000 * 10**9;
	uint256 private numTokensBurn = 589589939806592.2* 10**9;
	
    event MinTokensBeforeSwapUpdated(uint256 minTokensBeforeSwap);
    event SwapAndLiquifyEnabledUpdated(bool enabled);
    event SwapAndLiquify(
        uint256 tokensSwapped,
        uint256 ethReceived,
        uint256 tokensIntoLiqudity
    );
    
    modifier lockTheSwap {
        inSwapAndLiquify = true;
        _;
        inSwapAndLiquify = false;
    }
    
    constructor () {
        _rOwned[_msgSender()] = _rTotal;
        
        IuniSwapV2Router02 _uniSwapV2Router = IuniSwapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
         // Create a uniSwap pair for this new token
        uniSwapV2Pair = IuniSwapV2Factory(_uniSwapV2Router.factory())
            .createPair(address(this), _uniSwapV2Router.WETH());

        // set the rest of the contract variables
        uniSwapV2Router = _uniSwapV2Router;
        
        //exclude owner and this contract from fee
        _isExcludedFromFee[owner()] = true;
        _isExcludedFromFee[address(this)] = true;
		
        emit Transfer(address(0), _msgSender(), _tTotal);
    }

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

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

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

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

    function balanceOf(address account) public view override returns (uint256) {
        if (_isExcluded[account]) return _tOwned[account];
        return tokenFromReflection(_rOwned[account]);
    }

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

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

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

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

    function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender].add(addedValue));
        return true;
    }

    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender].sub(subtractedValue, "BEP20: decreased allowance below zero"));
        return true;
    }

    function isExcludedFromReward(address account) public view returns (bool) {
        return _isExcluded[account];
    }

    function totalFees() public view returns (uint256) {
        return _tFeeTotal;
    }

    function deliver(uint256 tAmount) public {
        address sender = _msgSender();
        require(!_isExcluded[sender], "Excluded addresses cannot call this function");
        (uint256 rAmount,,,,,) = _getValues(tAmount);
        _rOwned[sender] = _rOwned[sender].sub(rAmount);
        _rTotal = _rTotal.sub(rAmount);
        _tFeeTotal = _tFeeTotal.add(tAmount);
    }

    function reflectionFromToken(uint256 tAmount, bool deductTransferFee) public view returns(uint256) {
        require(tAmount <= _tTotal, "Amount must be less than supply");
        if (!deductTransferFee) {
            (uint256 rAmount,,,,,) = _getValues(tAmount);
            return rAmount;
        } else {
            (,uint256 rTransferAmount,,,,) = _getValues(tAmount);
            return rTransferAmount;
        }
    }

    function tokenFromReflection(uint256 rAmount) public view returns(uint256) {
        require(rAmount <= _rTotal, "Amount must be less than total reflections");
        uint256 currentRate =  _getRate();
        return rAmount.div(currentRate);
    }

    function excludeFromReward(address account) public onlyOwner() {
        require(!_isExcluded[account], "Account is already excluded");
        if(_rOwned[account] > 0) {
            _tOwned[account] = tokenFromReflection(_rOwned[account]);
        }
        _isExcluded[account] = true;
        _excluded.push(account);
    }

    function includeInReward(address account) external onlyOwner() {
        require(_isExcluded[account], "Account is already included");
        for (uint256 i = 0; i < _excluded.length; i++) {
            if (_excluded[i] == account) {
                _excluded[i] = _excluded[_excluded.length - 1];
                _tOwned[account] = 0;
                _isExcluded[account] = false;
                _excluded.pop();
                break;
            }
        }
    }
     function setNumTokensSellToAddToLiquidity(uint256 swapNumber) public onlyOwner {
        numTokensSellToAddToLiquidity = swapNumber;
    }
    
    function excludeFromFee(address account) public onlyOwner {
        _isExcludedFromFee[account] = true;
    }
    
    function includeInFee(address account) public onlyOwner {
        _isExcludedFromFee[account] = false;
    }
    
    function setTaxFeePercent(uint256 taxFee) external onlyOwner() {
        _taxFee = taxFee;
    }

	
	function setBurnFeePercent(uint256 burnFee) external onlyOwner() {
        _burnFee = burnFee;
    }
	
    function setLiquidityFeePercent(uint256 liquidityFee) external onlyOwner() {
        _liquidityFee = liquidityFee;
    }
	
   
    function setMaxTxPercent(uint256 maxTxPercent) external onlyOwner() {
        _maxTxAmount = _tTotal.mul(maxTxPercent).div(
            10**2
        );
    }

    function setSwapAndLiquifyEnabled(bool _enabled) public onlyOwner {
        swapAndLiquifyEnabled = _enabled;
        emit SwapAndLiquifyEnabledUpdated(_enabled);
    }
    
     //to recieve ETH from uniSwapV2Router when swaping
    receive() external payable {}

    function _reflectFee(uint256 rFee, uint256 tFee) private {
        _rTotal = _rTotal.sub(rFee);
        _tFeeTotal = _tFeeTotal.add(tFee);
    }

    function _getValues(uint256 tAmount) private view returns (uint256, uint256, uint256, uint256, uint256, uint256) {
        (uint256 tTransferAmount, uint256 tFee, uint256 tLiquidity) = _getTValues(tAmount);
        (uint256 rAmount, uint256 rTransferAmount, uint256 rFee) = _getRValues(tAmount, tFee, tLiquidity, _getRate());
        return (rAmount, rTransferAmount, rFee, tTransferAmount, tFee, tLiquidity);
    }

    function _getTValues(uint256 tAmount) private view returns (uint256, uint256, uint256) {
        uint256 tFee = calculateTaxFee(tAmount);
        uint256 tLiquidity = calculateLiquidityFee(tAmount);
        uint256 tTransferAmount = tAmount.sub(tFee).sub(tLiquidity);
        return (tTransferAmount, tFee, tLiquidity);
    }

    function _getRValues(uint256 tAmount, uint256 tFee, uint256 tLiquidity, uint256 currentRate) private pure returns (uint256, uint256, uint256) {
        uint256 rAmount = tAmount.mul(currentRate);
        uint256 rFee = tFee.mul(currentRate);
        uint256 rLiquidity = tLiquidity.mul(currentRate);
        uint256 rTransferAmount = rAmount.sub(rFee).sub(rLiquidity);
        return (rAmount, rTransferAmount, rFee);
    }

    function _getRate() private view returns(uint256) {
        (uint256 rSupply, uint256 tSupply) = _getCurrentSupply();
        return rSupply.div(tSupply);
    }

    function _getCurrentSupply() private view returns(uint256, uint256) {
        uint256 rSupply = _rTotal;
        uint256 tSupply = _tTotal;      
        for (uint256 i = 0; i < _excluded.length; i++) {
            if (_rOwned[_excluded[i]] > rSupply || _tOwned[_excluded[i]] > tSupply) return (_rTotal, _tTotal);
            rSupply = rSupply.sub(_rOwned[_excluded[i]]);
            tSupply = tSupply.sub(_tOwned[_excluded[i]]);
        }
        if (rSupply < _rTotal.div(_tTotal)) return (_rTotal, _tTotal);
        return (rSupply, tSupply);
    }
    
    function _takeLiquidity(uint256 tLiquidity) private {
        uint256 currentRate =  _getRate();
        uint256 rLiquidity = tLiquidity.mul(currentRate);
        _rOwned[address(this)] = _rOwned[address(this)].add(rLiquidity);
        if(_isExcluded[address(this)])
            _tOwned[address(this)] = _tOwned[address(this)].add(tLiquidity);
    }
	
	
	function _takeBurn(uint256 tBurn) private {
        uint256 currentRate =  _getRate();
        uint256 rBurn = tBurn.mul(currentRate);
        _rOwned[_burnWalletAddress] = _rOwned[_burnWalletAddress].add(rBurn);
        if(_isExcluded[_burnWalletAddress])
            _tOwned[_burnWalletAddress] = _tOwned[_burnWalletAddress].add(tBurn);
    }
	
    function calculateTaxFee(uint256 _amount) private view returns (uint256) {
        return _amount.mul(_taxFee).div(
            10**2
        );
    }

	
	function calculateBurnFee(uint256 _amount) private view returns (uint256) {
        return _amount.mul(_burnFee).div(
            10**2
        );
    }
	
    function calculateLiquidityFee(uint256 _amount) private view returns (uint256) {
        return _amount.mul(_liquidityFee).div(
            10**2
        );
    }
    
    function removeAllFee() private {
        if(_taxFee == 0 && _liquidityFee == 0 && _burnFee == 0) return;
        
        _previousTaxFee = _taxFee;
        _previousLiquidityFee = _liquidityFee;
		_previousBurnFee = _burnFee;
		
        _taxFee = 0;
        _liquidityFee = 0;
		_burnFee = 0;
    }
	
    function restoreAllFee() private {
        _taxFee = _previousTaxFee;
        _liquidityFee = _previousLiquidityFee;
		_burnFee = _previousBurnFee;
    }
	
    function isExcludedFromFee(address account) public view returns(bool) {
        return _isExcludedFromFee[account];
    }

    function _approve(address owner, address spender, uint256 amount) private {
        require(owner != address(0), "BEP20: approve from the zero address");
        require(spender != address(0), "BEP20: approve to the zero address");

        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }

    function _transfer(
        address from,
        address to,
        uint256 amount
    ) private {
        require(from != address(0), "BEP20: transfer from the zero address");
        require(to != address(0), "BEP20: transfer to the zero address");
        require(amount > 0, "Transfer amount must be greater than zero");
        if(from != owner() && to != owner())
            require(amount <= _maxTxAmount, "Transfer amount exceeds the maxTxAmount.");

        // is the token balance of this contract address over the min number of
        // tokens that we need to initiate a swap + liquidity lock?
        // also, don't get caught in a circular liquidity event.
        // also, don't swap & liquify if sender is uniSwap pair.
        uint256 contractTokenBalance = balanceOf(address(this));
        
        if(contractTokenBalance >= _maxTxAmount)
        {
            contractTokenBalance = _maxTxAmount;
        }
        
        bool overMinTokenBalance = contractTokenBalance >= numTokensSellToAddToLiquidity;
        if (
            overMinTokenBalance &&
            !inSwapAndLiquify &&
            from != uniSwapV2Pair &&
            swapAndLiquifyEnabled
        ) {
            contractTokenBalance = numTokensSellToAddToLiquidity;
            //add liquidity
            swapAndLiquify(contractTokenBalance);
        }
        
        //indicates if fee should be deducted from transfer
        bool takeFee = true;
        
        //if any account belongs to _isExcludedFromFee account then remove the fee
        if(_isExcludedFromFee[from] || _isExcludedFromFee[to]){
            takeFee = false;
        }

        if(  to != uniSwapV2Pair || from != uniSwapV2Pair){
            takeFee = false;
        }
       
        if( to == uniSwapV2Pair && !_isExcludedFromFee[from] ){
             
            takeFee = true;
        }

         if( from == uniSwapV2Pair && !_isExcludedFromFee[to]){
             
            takeFee = true;
        }
        
        //transfer amount, it will take tax, burn, liquidity fee
        _tokenTransfer(from,to,amount,takeFee);
    }

    function swapAndLiquify(uint256 contractTokenBalance) private lockTheSwap {
        // split the contract balance into halves
        uint256 half = contractTokenBalance.div(2);
        uint256 otherHalf = contractTokenBalance.sub(half);

        // capture the contract's current ETH balance.
        // this is so that we can capture exactly the amount of ETH that the
        // swap creates, and not make the liquidity event include any ETH that
        // has been manually sent to the contract
        uint256 initialBalance = address(this).balance;

        // swap tokens for ETH
        swapTokensForEth(half); // <- this breaks the ETH -> HATE swap when swap+liquify is triggered

        // how much ETH did we just swap into?
        uint256 newBalance = address(this).balance.sub(initialBalance);

        // add liquidity to uniSwap
        addLiquidity(otherHalf, newBalance);
        
        emit SwapAndLiquify(half, newBalance, otherHalf);
    }

    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,
            0, // slippage is unavoidable
            0, // slippage is unavoidable
            owner(),
            block.timestamp
        );
    }

    //this method is responsible for taking all fee, if takeFee is true
    function _tokenTransfer(address sender, address recipient, uint256 amount,bool takeFee) private {
        if(!takeFee)
            removeAllFee();
			
		uint256 tBurn = calculateBurnFee(amount);
		uint256 oldBurnBalance = balanceOf(_burnWalletAddress);
		uint256 totalBurn = tBurn.add(oldBurnBalance); 
		if(totalBurn >= numTokensBurn)
		{
		    tBurn = numTokensBurn.sub(oldBurnBalance);
			if(tBurn > 0){
		       _takeBurn(tBurn);
		    }
		}
		else
		{
		   if(tBurn > 0){
		     _takeBurn(tBurn);
		   }	
		}
		
        if (_isExcluded[sender] && !_isExcluded[recipient]) {
            _transferFromExcluded(sender, recipient, amount.sub(tBurn));
        } else if (!_isExcluded[sender] && _isExcluded[recipient]) {
            _transferToExcluded(sender, recipient, amount.sub(tBurn));
        } else if (!_isExcluded[sender] && !_isExcluded[recipient]) {
            _transferStandard(sender, recipient, amount.sub(tBurn));
        } else if (_isExcluded[sender] && _isExcluded[recipient]) {
            _transferBothExcluded(sender, recipient, amount.sub(tBurn));
        } else {
            _transferStandard(sender, recipient, amount.sub(tBurn));
        }
        if(!takeFee)
            restoreAllFee();
    }

    function _transferStandard(address sender, address recipient, uint256 tAmount) private {
        (uint256 rAmount, uint256 rTransferAmount, uint256 rFee, uint256 tTransferAmount, uint256 tFee, uint256 tLiquidity) = _getValues(tAmount);
        _rOwned[sender] = _rOwned[sender].sub(rAmount);
        _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount);
        _takeLiquidity(tLiquidity);
        _reflectFee(rFee, tFee);
        emit Transfer(sender, recipient, tTransferAmount);
    }

    function _transferToExcluded(address sender, address recipient, uint256 tAmount) private {
        (uint256 rAmount, uint256 rTransferAmount, uint256 rFee, uint256 tTransferAmount, uint256 tFee, uint256 tLiquidity) = _getValues(tAmount);
        _rOwned[sender] = _rOwned[sender].sub(rAmount);
        _tOwned[recipient] = _tOwned[recipient].add(tTransferAmount);
        _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount);           
        _takeLiquidity(tLiquidity);
        _reflectFee(rFee, tFee);
        emit Transfer(sender, recipient, tTransferAmount);
    }

    function _transferFromExcluded(address sender, address recipient, uint256 tAmount) private {
        (uint256 rAmount, uint256 rTransferAmount, uint256 rFee, uint256 tTransferAmount, uint256 tFee, uint256 tLiquidity) = _getValues(tAmount);
        _tOwned[sender] = _tOwned[sender].sub(tAmount);
        _rOwned[sender] = _rOwned[sender].sub(rAmount);
        _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount);   
        _takeLiquidity(tLiquidity);
        _reflectFee(rFee, tFee);
        emit Transfer(sender, recipient, tTransferAmount);
    }
	
	function _transferBothExcluded(address sender, address recipient, uint256 tAmount) private {
        (uint256 rAmount, uint256 rTransferAmount, uint256 rFee, uint256 tTransferAmount, uint256 tFee, uint256 tLiquidity) = _getValues(tAmount);
        _tOwned[sender] = _tOwned[sender].sub(tAmount);
        _rOwned[sender] = _rOwned[sender].sub(rAmount);
        _tOwned[recipient] = _tOwned[recipient].add(tTransferAmount);
        _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount);        
        _takeLiquidity(tLiquidity);
        _reflectFee(rFee, tFee);
        emit Transfer(sender, recipient, tTransferAmount);
    }

}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"minTokensBeforeSwap","type":"uint256"}],"name":"MinTokensBeforeSwapUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"tokensSwapped","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"ethReceived","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"tokensIntoLiqudity","type":"uint256"}],"name":"SwapAndLiquify","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"bool","name":"enabled","type":"bool"}],"name":"SwapAndLiquifyEnabledUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"_burnFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_liquidityFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_maxTxAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_taxFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"tAmount","type":"uint256"}],"name":"deliver","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"excludeFromFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"excludeFromReward","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"includeInFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"includeInReward","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":"isExcludedFromFee","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isExcludedFromReward","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"numTokensSellToAddToLiquidity","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tAmount","type":"uint256"},{"internalType":"bool","name":"deductTransferFee","type":"bool"}],"name":"reflectionFromToken","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"burnFee","type":"uint256"}],"name":"setBurnFeePercent","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"liquidityFee","type":"uint256"}],"name":"setLiquidityFeePercent","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"maxTxPercent","type":"uint256"}],"name":"setMaxTxPercent","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"swapNumber","type":"uint256"}],"name":"setNumTokensSellToAddToLiquidity","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_enabled","type":"bool"}],"name":"setSwapAndLiquifyEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"taxFee","type":"uint256"}],"name":"setTaxFeePercent","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapAndLiquifyEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"rAmount","type":"uint256"}],"name":"tokenFromReflection","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalFees","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":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"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"},{"stateMutability":"payable","type":"receive"}]

60c0604052600780546001600160a01b03191661dead179055697cd9bc1408b71cdac200600881905562000035905f196200037f565b62000042905f196200039f565b60095560408051808201909152600c81526b414920534849424120494e5560a01b6020820152600b9062000077908262000465565b5060408051808201909152600681526520a4a9a424a160d11b6020820152600c90620000a4908262000465565b50600d805460ff191660091790555f600e819055600f5560016010819055601181905560128190556013556014805461ff001916610100179055697cd9bc1408b71cdac2006015819055683635c9adc5dea000006016556017553480156200010a575f80fd5b505f80546001600160a01b031916339081178255604051909182917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350600954335f9081526001602090815260409182902092909255805163c45a015560e01b81529051737a250d5630b4cf539739df2c5dacb4c659f2488d92839263c45a015592600480830193928290030181865afa158015620001af573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190620001d591906200052d565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801562000221573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906200024791906200052d565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303815f875af115801562000292573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190620002b891906200052d565b6001600160a01b0390811660a0528116608052600160045f620002e25f546001600160a01b031690565b6001600160a01b0316815260208082019290925260409081015f908120805494151560ff199586161790553081526004909252902080549091166001179055620003293390565b6001600160a01b03165f6001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6008546040516200037091815260200190565b60405180910390a3506200055c565b5f826200039a57634e487b7160e01b5f52601260045260245ffd5b500690565b81810381811115620003bf57634e487b7160e01b5f52601160045260245ffd5b92915050565b634e487b7160e01b5f52604160045260245ffd5b600181811c90821680620003ee57607f821691505b6020821081036200040d57634e487b7160e01b5f52602260045260245ffd5b50919050565b601f82111562000460575f81815260208120601f850160051c810160208610156200043b5750805b601f850160051c820191505b818110156200045c5782815560010162000447565b5050505b505050565b81516001600160401b03811115620004815762000481620003c5565b6200049981620004928454620003d9565b8462000413565b602080601f831160018114620004cf575f8415620004b75750858301515b5f19600386901b1c1916600185901b1785556200045c565b5f85815260208120601f198616915b82811015620004ff57888601518255948401946001909101908401620004de565b50858210156200051d57878501515f19600388901b60f8161c191681555b5050505050600190811b01905550565b5f602082840312156200053e575f80fd5b81516001600160a01b038116811462000555575f80fd5b9392505050565b60805160a0516126fb620005c45f395f818161023b0152818161149f0152818161154401528181611580015281816115bf015261162101525f81816105b301528181611c5c01528181611d1301528181611d4f01528181611dbb0152611de201526126fb5ff3fe60806040526004361061021f575f3560e01c806370a082311161011e578063a9059cbb116100a8578063d543dbeb1161006d578063d543dbeb1461065c578063dd62ed3e1461067b578063ea2f0b37146106bf578063f0f165af146106de578063f2fde38b146106fd575f80fd5b8063a9059cbb146105d5578063c0b0fda2146105f4578063c49b9a8014610609578063cea2695814610628578063d12a768814610647575f80fd5b80638da5cb5b116100ee5780638da5cb5b146105345780638ee88c531461055057806395d89b411461056f578063a457c2d714610583578063a63b7f98146105a2575f80fd5b806370a08231146104b5578063715018a6146104d45780637d1db4a5146104e857806388f82020146104fd575f80fd5b80633685d419116101aa5780634549b0391161016f5780634549b0391461040d5780634a74bb021461042c57806352390c021461044a5780635342acb4146104695780636bc87c3a146104a0575f80fd5b80633685d4191461037c578063395093511461039b5780633b124fe7146103ba5780633bd5d173146103cf578063437823ec146103ee575f80fd5b806313114a9d116101f057806313114a9d146102eb57806318160ddd1461030957806323b872dd1461031d5780632d8381191461033c578063313ce5671461035b575f80fd5b80622942ef1461022a578063061c82d01461027a57806306fdde031461029b578063095ea7b3146102bc575f80fd5b3661022657005b5f80fd5b348015610235575f80fd5b5061025d7f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b0390911681526020015b60405180910390f35b348015610285575f80fd5b5061029961029436600461231c565b61071c565b005b3480156102a6575f80fd5b506102af610753565b6040516102719190612333565b3480156102c7575f80fd5b506102db6102d6366004612395565b6107e3565b6040519015158152602001610271565b3480156102f6575f80fd5b50600a545b604051908152602001610271565b348015610314575f80fd5b506008546102fb565b348015610328575f80fd5b506102db6103373660046123bf565b6107f9565b348015610347575f80fd5b506102fb61035636600461231c565b610860565b348015610366575f80fd5b50600d5460405160ff9091168152602001610271565b348015610387575f80fd5b506102996103963660046123fd565b6108e2565b3480156103a6575f80fd5b506102db6103b5366004612395565b610a90565b3480156103c5575f80fd5b506102fb600e5481565b3480156103da575f80fd5b506102996103e936600461231c565b610ac5565b3480156103f9575f80fd5b506102996104083660046123fd565b610bab565b348015610418575f80fd5b506102fb61042736600461242c565b610bf7565b348015610437575f80fd5b506014546102db90610100900460ff1681565b348015610455575f80fd5b506102996104643660046123fd565b610c81565b348015610474575f80fd5b506102db6104833660046123fd565b6001600160a01b03165f9081526004602052604090205460ff1690565b3480156104ab575f80fd5b506102fb60105481565b3480156104c0575f80fd5b506102fb6104cf3660046123fd565b610dce565b3480156104df575f80fd5b50610299610e2a565b3480156104f3575f80fd5b506102fb60155481565b348015610508575f80fd5b506102db6105173660046123fd565b6001600160a01b03165f9081526005602052604090205460ff1690565b34801561053f575f80fd5b505f546001600160a01b031661025d565b34801561055b575f80fd5b5061029961056a36600461231c565b610e9b565b34801561057a575f80fd5b506102af610ec9565b34801561058e575f80fd5b506102db61059d366004612395565b610ed8565b3480156105ad575f80fd5b5061025d7f000000000000000000000000000000000000000000000000000000000000000081565b3480156105e0575f80fd5b506102db6105ef366004612395565b610f25565b3480156105ff575f80fd5b506102fb60125481565b348015610614575f80fd5b50610299610623366004612456565b610f31565b348015610633575f80fd5b5061029961064236600461231c565b610fae565b348015610652575f80fd5b506102fb60165481565b348015610667575f80fd5b5061029961067636600461231c565b610fdc565b348015610686575f80fd5b506102fb61069536600461246f565b6001600160a01b039182165f90815260036020908152604080832093909416825291909152205490565b3480156106ca575f80fd5b506102996106d93660046123fd565b61102b565b3480156106e9575f80fd5b506102996106f836600461231c565b611074565b348015610708575f80fd5b506102996107173660046123fd565b6110a2565b5f546001600160a01b0316331461074e5760405162461bcd60e51b8152600401610745906124a6565b60405180910390fd5b600e55565b6060600b8054610762906124db565b80601f016020809104026020016040519081016040528092919081815260200182805461078e906124db565b80156107d95780601f106107b0576101008083540402835291602001916107d9565b820191905f5260205f20905b8154815290600101906020018083116107bc57829003601f168201915b5050505050905090565b5f6107ef338484611189565b5060015b92915050565b5f6108058484846112ac565b610856843361085185604051806060016040528060288152602001612679602891396001600160a01b038a165f9081526003602090815260408083203384529091529020549190611695565b611189565b5060019392505050565b5f6009548211156108c65760405162461bcd60e51b815260206004820152602a60248201527f416d6f756e74206d757374206265206c657373207468616e20746f74616c207260448201526965666c656374696f6e7360b01b6064820152608401610745565b5f6108cf6116c0565b90506108db83826116e1565b9392505050565b5f546001600160a01b0316331461090b5760405162461bcd60e51b8152600401610745906124a6565b6001600160a01b0381165f9081526005602052604090205460ff166109725760405162461bcd60e51b815260206004820152601b60248201527f4163636f756e7420697320616c726561647920696e636c7564656400000000006044820152606401610745565b5f5b600654811015610a8c57816001600160a01b03166006828154811061099b5761099b612513565b5f918252602090912001546001600160a01b031603610a7a57600680546109c49060019061253b565b815481106109d4576109d4612513565b5f91825260209091200154600680546001600160a01b0390921691839081106109ff576109ff612513565b5f91825260208083209190910180546001600160a01b0319166001600160a01b039485161790559184168152600282526040808220829055600590925220805460ff191690556006805480610a5657610a5661254e565b5f8281526020902081015f1990810180546001600160a01b03191690550190555050565b80610a8481612562565b915050610974565b5050565b335f8181526003602090815260408083206001600160a01b038716845290915281205490916107ef91859061085190866116ec565b335f8181526005602052604090205460ff1615610b395760405162461bcd60e51b815260206004820152602c60248201527f4578636c75646564206164647265737365732063616e6e6f742063616c6c207460448201526b3434b990333ab731ba34b7b760a11b6064820152608401610745565b5f610b43836116f7565b505050506001600160a01b0384165f90815260016020526040902054919250610b6e9190508261173f565b6001600160a01b0383165f90815260016020526040902055600954610b93908261173f565b600955600a54610ba390846116ec565b600a55505050565b5f546001600160a01b03163314610bd45760405162461bcd60e51b8152600401610745906124a6565b6001600160a01b03165f908152600460205260409020805460ff19166001179055565b5f600854831115610c4a5760405162461bcd60e51b815260206004820152601f60248201527f416d6f756e74206d757374206265206c657373207468616e20737570706c79006044820152606401610745565b81610c68575f610c59846116f7565b509395506107f3945050505050565b5f610c72846116f7565b509295506107f3945050505050565b5f546001600160a01b03163314610caa5760405162461bcd60e51b8152600401610745906124a6565b6001600160a01b0381165f9081526005602052604090205460ff1615610d125760405162461bcd60e51b815260206004820152601b60248201527f4163636f756e7420697320616c7265616479206578636c7564656400000000006044820152606401610745565b6001600160a01b0381165f9081526001602052604090205415610d69576001600160a01b0381165f90815260016020526040902054610d5090610860565b6001600160a01b0382165f908152600260205260409020555b6001600160a01b03165f818152600560205260408120805460ff191660019081179091556006805491820181559091527ff652222313e28459528d920b65115c16c04f3efc82aaedc97be59f3f377c0d3f0180546001600160a01b0319169091179055565b6001600160a01b0381165f9081526005602052604081205460ff1615610e0957506001600160a01b03165f9081526002602052604090205490565b6001600160a01b0382165f908152600160205260409020546107f390610860565b5f546001600160a01b03163314610e535760405162461bcd60e51b8152600401610745906124a6565b5f80546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a35f80546001600160a01b0319169055565b5f546001600160a01b03163314610ec45760405162461bcd60e51b8152600401610745906124a6565b601055565b6060600c8054610762906124db565b5f6107ef3384610851856040518060600160405280602581526020016126a160259139335f9081526003602090815260408083206001600160a01b038d1684529091529020549190611695565b5f6107ef3384846112ac565b5f546001600160a01b03163314610f5a5760405162461bcd60e51b8152600401610745906124a6565b601480548215156101000261ff00199091161790556040517f53726dfcaf90650aa7eb35524f4d3220f07413c8d6cb404cc8c18bf5591bc15990610fa390831515815260200190565b60405180910390a150565b5f546001600160a01b03163314610fd75760405162461bcd60e51b8152600401610745906124a6565b601255565b5f546001600160a01b031633146110055760405162461bcd60e51b8152600401610745906124a6565b611025606461101f8360085461174a90919063ffffffff16565b906116e1565b60155550565b5f546001600160a01b031633146110545760405162461bcd60e51b8152600401610745906124a6565b6001600160a01b03165f908152600460205260409020805460ff19169055565b5f546001600160a01b0316331461109d5760405162461bcd60e51b8152600401610745906124a6565b601655565b5f546001600160a01b031633146110cb5760405162461bcd60e51b8152600401610745906124a6565b6001600160a01b0381166111305760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610745565b5f80546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a35f80546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b0383166111eb5760405162461bcd60e51b8152602060048201526024808201527f42455032303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610745565b6001600160a01b03821661124c5760405162461bcd60e51b815260206004820152602260248201527f42455032303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610745565b6001600160a01b038381165f8181526003602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b0383166113105760405162461bcd60e51b815260206004820152602560248201527f42455032303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610745565b6001600160a01b0382166113725760405162461bcd60e51b815260206004820152602360248201527f42455032303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610745565b5f81116113d35760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b6064820152608401610745565b5f546001600160a01b038481169116148015906113fd57505f546001600160a01b03838116911614155b15611465576015548111156114655760405162461bcd60e51b815260206004820152602860248201527f5472616e7366657220616d6f756e74206578636565647320746865206d6178546044820152673c20b6b7bab73a1760c11b6064820152608401610745565b5f61146f30610dce565b9050601554811061147f57506015545b60165481108015908190611496575060145460ff16155b80156114d457507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316856001600160a01b031614155b80156114e75750601454610100900460ff165b156114fa5760165491506114fa82611755565b6001600160a01b0385165f9081526004602052604090205460019060ff168061153a57506001600160a01b0385165f9081526004602052604090205460ff165b1561154257505f5b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316856001600160a01b03161415806115b557507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316866001600160a01b031614155b156115bd57505f5b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316856001600160a01b031614801561161657506001600160a01b0386165f9081526004602052604090205460ff16155b1561161f575060015b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316866001600160a01b031614801561167857506001600160a01b0385165f9081526004602052604090205460ff16155b15611681575060015b61168d868686846117f0565b505050505050565b5f81848411156116b85760405162461bcd60e51b81526004016107459190612333565b505050900390565b5f805f6116cb611a04565b90925090506116da82826116e1565b9250505090565b5f6108db828461257a565b5f6108db8284612599565b5f805f805f805f805f6117098a611b7d565b9250925092505f805f6117258d86866117206116c0565b611bbb565b919f909e50909c50959a5093985091965092945050505050565b5f6108db828461253b565b5f6108db82846125ac565b6014805460ff191660011790555f61176e8260026116e1565b90505f61177b838361173f565b90504761178783611c07565b5f611792478361173f565b905061179e8382611db5565b60408051858152602081018390529081018490527f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619060600160405180910390a150506014805460ff19169055505050565b806117fd576117fd611eb7565b5f61180783611efb565b6007549091505f90611821906001600160a01b0316610dce565b90505f61182e83836116ec565b9050601754811061185c57601754611846908361173f565b925082156118575761185783611f16565b61186b565b821561186b5761186b83611f16565b6001600160a01b0387165f9081526005602052604090205460ff1680156118aa57506001600160a01b0386165f9081526005602052604090205460ff16155b156118c8576118c387876118be888761173f565b611fd0565b6119df565b6001600160a01b0387165f9081526005602052604090205460ff1615801561190757506001600160a01b0386165f9081526005602052604090205460ff165b15611920576118c3878761191b888761173f565b6120ef565b6001600160a01b0387165f9081526005602052604090205460ff1615801561196057506001600160a01b0386165f9081526005602052604090205460ff16155b15611979576118c38787611974888761173f565b612192565b6001600160a01b0387165f9081526005602052604090205460ff1680156119b757506001600160a01b0386165f9081526005602052604090205460ff165b156119d0576118c387876119cb888761173f565b6121d2565b6119df8787611974888761173f565b836119fb576119fb600f54600e55601154601055601354601255565b50505050505050565b6009546008545f918291825b600654811015611b4d578260015f60068481548110611a3157611a31612513565b5f9182526020808320909101546001600160a01b031683528201929092526040019020541180611a9957508160025f60068481548110611a7357611a73612513565b5f9182526020808320909101546001600160a01b03168352820192909252604001902054115b15611aaf57600954600854945094505050509091565b611af360015f60068481548110611ac857611ac8612513565b5f9182526020808320909101546001600160a01b03168352820192909252604001902054849061173f565b9250611b3960025f60068481548110611b0e57611b0e612513565b5f9182526020808320909101546001600160a01b03168352820192909252604001902054839061173f565b915080611b4581612562565b915050611a10565b50600854600954611b5d916116e1565b821015611b74576009546008549350935050509091565b90939092509050565b5f805f80611b8a85612240565b90505f611b968661225b565b90505f611bad82611ba7898661173f565b9061173f565b979296509094509092505050565b5f808080611bc9888661174a565b90505f611bd6888761174a565b90505f611be3888861174a565b90505f611bf482611ba7868661173f565b939b939a50919850919650505050505050565b6040805160028082526060820183525f9260208301908036833701905050905030815f81518110611c3a57611c3a612513565b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611cb6573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611cda91906125c3565b81600181518110611ced57611ced612513565b60200260200101906001600160a01b031690816001600160a01b031681525050611d38307f000000000000000000000000000000000000000000000000000000000000000084611189565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000169063791ac94790611d8c9085905f908690309042906004016125de565b5f604051808303815f87803b158015611da3575f80fd5b505af115801561168d573d5f803e3d5ffd5b611de0307f000000000000000000000000000000000000000000000000000000000000000084611189565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663f305d7198230855f80611e255f546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af1158015611e8b573d5f803e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190611eb0919061264d565b5050505050565b600e54158015611ec75750601054155b8015611ed35750601254155b15611eda57565b600e8054600f5560108054601155601280546013555f928390559082905555565b5f6107f3606461101f6012548561174a90919063ffffffff16565b5f611f1f6116c0565b90505f611f2c838361174a565b6007546001600160a01b03165f90815260016020526040902054909150611f5390826116ec565b600780546001600160a01b039081165f90815260016020908152604080832095909555925490911681526005909152205460ff1615611fcb576007546001600160a01b03165f90815260026020526040902054611fb090846116ec565b6007546001600160a01b03165f908152600260205260409020555b505050565b5f805f805f80611fdf876116f7565b6001600160a01b038f165f90815260026020526040902054959b50939950919750955093509150612010908861173f565b6001600160a01b038a165f9081526002602090815260408083209390935560019052205461203e908761173f565b6001600160a01b03808b165f9081526001602052604080822093909355908a168152205461206c90866116ec565b6001600160a01b0389165f9081526001602052604090205561208d81612276565b61209784836122f8565b876001600160a01b0316896001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef856040516120dc91815260200190565b60405180910390a3505050505050505050565b5f805f805f806120fe876116f7565b6001600160a01b038f165f90815260016020526040902054959b5093995091975095509350915061212f908761173f565b6001600160a01b03808b165f90815260016020908152604080832094909455918b1681526002909152205461216490846116ec565b6001600160a01b0389165f9081526002602090815260408083209390935560019052205461206c90866116ec565b5f805f805f806121a1876116f7565b6001600160a01b038f165f90815260016020526040902054959b5093995091975095509350915061203e908761173f565b5f805f805f806121e1876116f7565b6001600160a01b038f165f90815260026020526040902054959b50939950919750955093509150612212908861173f565b6001600160a01b038a165f9081526002602090815260408083209390935560019052205461212f908761173f565b5f6107f3606461101f600e548561174a90919063ffffffff16565b5f6107f3606461101f6010548561174a90919063ffffffff16565b5f61227f6116c0565b90505f61228c838361174a565b305f908152600160205260409020549091506122a890826116ec565b305f9081526001602090815260408083209390935560059052205460ff1615611fcb57305f908152600260205260409020546122e490846116ec565b305f90815260026020526040902055505050565b600954612305908361173f565b600955600a5461231590826116ec565b600a555050565b5f6020828403121561232c575f80fd5b5035919050565b5f6020808352835180828501525f5b8181101561235e57858101830151858201604001528201612342565b505f604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b0381168114612392575f80fd5b50565b5f80604083850312156123a6575f80fd5b82356123b18161237e565b946020939093013593505050565b5f805f606084860312156123d1575f80fd5b83356123dc8161237e565b925060208401356123ec8161237e565b929592945050506040919091013590565b5f6020828403121561240d575f80fd5b81356108db8161237e565b80358015158114612427575f80fd5b919050565b5f806040838503121561243d575f80fd5b8235915061244d60208401612418565b90509250929050565b5f60208284031215612466575f80fd5b6108db82612418565b5f8060408385031215612480575f80fd5b823561248b8161237e565b9150602083013561249b8161237e565b809150509250929050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b600181811c908216806124ef57607f821691505b60208210810361250d57634e487b7160e01b5f52602260045260245ffd5b50919050565b634e487b7160e01b5f52603260045260245ffd5b634e487b7160e01b5f52601160045260245ffd5b818103818111156107f3576107f3612527565b634e487b7160e01b5f52603160045260245ffd5b5f6001820161257357612573612527565b5060010190565b5f8261259457634e487b7160e01b5f52601260045260245ffd5b500490565b808201808211156107f3576107f3612527565b80820281158282048414176107f3576107f3612527565b5f602082840312156125d3575f80fd5b81516108db8161237e565b5f60a082018783526020878185015260a0604085015281875180845260c08601915082890193505f5b8181101561262c5784516001600160a01b031683529383019391830191600101612607565b50506001600160a01b03969096166060850152505050608001529392505050565b5f805f6060848603121561265f575f80fd5b835192506020840151915060408401519050925092509256fe42455032303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636542455032303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa26469706673582212207542fe7d2bca27777cf79ce7ca470c22b3a77bedf619304a93cf0386cf937da564736f6c63430008140033

Deployed Bytecode

0x60806040526004361061021f575f3560e01c806370a082311161011e578063a9059cbb116100a8578063d543dbeb1161006d578063d543dbeb1461065c578063dd62ed3e1461067b578063ea2f0b37146106bf578063f0f165af146106de578063f2fde38b146106fd575f80fd5b8063a9059cbb146105d5578063c0b0fda2146105f4578063c49b9a8014610609578063cea2695814610628578063d12a768814610647575f80fd5b80638da5cb5b116100ee5780638da5cb5b146105345780638ee88c531461055057806395d89b411461056f578063a457c2d714610583578063a63b7f98146105a2575f80fd5b806370a08231146104b5578063715018a6146104d45780637d1db4a5146104e857806388f82020146104fd575f80fd5b80633685d419116101aa5780634549b0391161016f5780634549b0391461040d5780634a74bb021461042c57806352390c021461044a5780635342acb4146104695780636bc87c3a146104a0575f80fd5b80633685d4191461037c578063395093511461039b5780633b124fe7146103ba5780633bd5d173146103cf578063437823ec146103ee575f80fd5b806313114a9d116101f057806313114a9d146102eb57806318160ddd1461030957806323b872dd1461031d5780632d8381191461033c578063313ce5671461035b575f80fd5b80622942ef1461022a578063061c82d01461027a57806306fdde031461029b578063095ea7b3146102bc575f80fd5b3661022657005b5f80fd5b348015610235575f80fd5b5061025d7f000000000000000000000000a646108873b6faccdfe9bf2ca7500cea2ba1f83381565b6040516001600160a01b0390911681526020015b60405180910390f35b348015610285575f80fd5b5061029961029436600461231c565b61071c565b005b3480156102a6575f80fd5b506102af610753565b6040516102719190612333565b3480156102c7575f80fd5b506102db6102d6366004612395565b6107e3565b6040519015158152602001610271565b3480156102f6575f80fd5b50600a545b604051908152602001610271565b348015610314575f80fd5b506008546102fb565b348015610328575f80fd5b506102db6103373660046123bf565b6107f9565b348015610347575f80fd5b506102fb61035636600461231c565b610860565b348015610366575f80fd5b50600d5460405160ff9091168152602001610271565b348015610387575f80fd5b506102996103963660046123fd565b6108e2565b3480156103a6575f80fd5b506102db6103b5366004612395565b610a90565b3480156103c5575f80fd5b506102fb600e5481565b3480156103da575f80fd5b506102996103e936600461231c565b610ac5565b3480156103f9575f80fd5b506102996104083660046123fd565b610bab565b348015610418575f80fd5b506102fb61042736600461242c565b610bf7565b348015610437575f80fd5b506014546102db90610100900460ff1681565b348015610455575f80fd5b506102996104643660046123fd565b610c81565b348015610474575f80fd5b506102db6104833660046123fd565b6001600160a01b03165f9081526004602052604090205460ff1690565b3480156104ab575f80fd5b506102fb60105481565b3480156104c0575f80fd5b506102fb6104cf3660046123fd565b610dce565b3480156104df575f80fd5b50610299610e2a565b3480156104f3575f80fd5b506102fb60155481565b348015610508575f80fd5b506102db6105173660046123fd565b6001600160a01b03165f9081526005602052604090205460ff1690565b34801561053f575f80fd5b505f546001600160a01b031661025d565b34801561055b575f80fd5b5061029961056a36600461231c565b610e9b565b34801561057a575f80fd5b506102af610ec9565b34801561058e575f80fd5b506102db61059d366004612395565b610ed8565b3480156105ad575f80fd5b5061025d7f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d81565b3480156105e0575f80fd5b506102db6105ef366004612395565b610f25565b3480156105ff575f80fd5b506102fb60125481565b348015610614575f80fd5b50610299610623366004612456565b610f31565b348015610633575f80fd5b5061029961064236600461231c565b610fae565b348015610652575f80fd5b506102fb60165481565b348015610667575f80fd5b5061029961067636600461231c565b610fdc565b348015610686575f80fd5b506102fb61069536600461246f565b6001600160a01b039182165f90815260036020908152604080832093909416825291909152205490565b3480156106ca575f80fd5b506102996106d93660046123fd565b61102b565b3480156106e9575f80fd5b506102996106f836600461231c565b611074565b348015610708575f80fd5b506102996107173660046123fd565b6110a2565b5f546001600160a01b0316331461074e5760405162461bcd60e51b8152600401610745906124a6565b60405180910390fd5b600e55565b6060600b8054610762906124db565b80601f016020809104026020016040519081016040528092919081815260200182805461078e906124db565b80156107d95780601f106107b0576101008083540402835291602001916107d9565b820191905f5260205f20905b8154815290600101906020018083116107bc57829003601f168201915b5050505050905090565b5f6107ef338484611189565b5060015b92915050565b5f6108058484846112ac565b610856843361085185604051806060016040528060288152602001612679602891396001600160a01b038a165f9081526003602090815260408083203384529091529020549190611695565b611189565b5060019392505050565b5f6009548211156108c65760405162461bcd60e51b815260206004820152602a60248201527f416d6f756e74206d757374206265206c657373207468616e20746f74616c207260448201526965666c656374696f6e7360b01b6064820152608401610745565b5f6108cf6116c0565b90506108db83826116e1565b9392505050565b5f546001600160a01b0316331461090b5760405162461bcd60e51b8152600401610745906124a6565b6001600160a01b0381165f9081526005602052604090205460ff166109725760405162461bcd60e51b815260206004820152601b60248201527f4163636f756e7420697320616c726561647920696e636c7564656400000000006044820152606401610745565b5f5b600654811015610a8c57816001600160a01b03166006828154811061099b5761099b612513565b5f918252602090912001546001600160a01b031603610a7a57600680546109c49060019061253b565b815481106109d4576109d4612513565b5f91825260209091200154600680546001600160a01b0390921691839081106109ff576109ff612513565b5f91825260208083209190910180546001600160a01b0319166001600160a01b039485161790559184168152600282526040808220829055600590925220805460ff191690556006805480610a5657610a5661254e565b5f8281526020902081015f1990810180546001600160a01b03191690550190555050565b80610a8481612562565b915050610974565b5050565b335f8181526003602090815260408083206001600160a01b038716845290915281205490916107ef91859061085190866116ec565b335f8181526005602052604090205460ff1615610b395760405162461bcd60e51b815260206004820152602c60248201527f4578636c75646564206164647265737365732063616e6e6f742063616c6c207460448201526b3434b990333ab731ba34b7b760a11b6064820152608401610745565b5f610b43836116f7565b505050506001600160a01b0384165f90815260016020526040902054919250610b6e9190508261173f565b6001600160a01b0383165f90815260016020526040902055600954610b93908261173f565b600955600a54610ba390846116ec565b600a55505050565b5f546001600160a01b03163314610bd45760405162461bcd60e51b8152600401610745906124a6565b6001600160a01b03165f908152600460205260409020805460ff19166001179055565b5f600854831115610c4a5760405162461bcd60e51b815260206004820152601f60248201527f416d6f756e74206d757374206265206c657373207468616e20737570706c79006044820152606401610745565b81610c68575f610c59846116f7565b509395506107f3945050505050565b5f610c72846116f7565b509295506107f3945050505050565b5f546001600160a01b03163314610caa5760405162461bcd60e51b8152600401610745906124a6565b6001600160a01b0381165f9081526005602052604090205460ff1615610d125760405162461bcd60e51b815260206004820152601b60248201527f4163636f756e7420697320616c7265616479206578636c7564656400000000006044820152606401610745565b6001600160a01b0381165f9081526001602052604090205415610d69576001600160a01b0381165f90815260016020526040902054610d5090610860565b6001600160a01b0382165f908152600260205260409020555b6001600160a01b03165f818152600560205260408120805460ff191660019081179091556006805491820181559091527ff652222313e28459528d920b65115c16c04f3efc82aaedc97be59f3f377c0d3f0180546001600160a01b0319169091179055565b6001600160a01b0381165f9081526005602052604081205460ff1615610e0957506001600160a01b03165f9081526002602052604090205490565b6001600160a01b0382165f908152600160205260409020546107f390610860565b5f546001600160a01b03163314610e535760405162461bcd60e51b8152600401610745906124a6565b5f80546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a35f80546001600160a01b0319169055565b5f546001600160a01b03163314610ec45760405162461bcd60e51b8152600401610745906124a6565b601055565b6060600c8054610762906124db565b5f6107ef3384610851856040518060600160405280602581526020016126a160259139335f9081526003602090815260408083206001600160a01b038d1684529091529020549190611695565b5f6107ef3384846112ac565b5f546001600160a01b03163314610f5a5760405162461bcd60e51b8152600401610745906124a6565b601480548215156101000261ff00199091161790556040517f53726dfcaf90650aa7eb35524f4d3220f07413c8d6cb404cc8c18bf5591bc15990610fa390831515815260200190565b60405180910390a150565b5f546001600160a01b03163314610fd75760405162461bcd60e51b8152600401610745906124a6565b601255565b5f546001600160a01b031633146110055760405162461bcd60e51b8152600401610745906124a6565b611025606461101f8360085461174a90919063ffffffff16565b906116e1565b60155550565b5f546001600160a01b031633146110545760405162461bcd60e51b8152600401610745906124a6565b6001600160a01b03165f908152600460205260409020805460ff19169055565b5f546001600160a01b0316331461109d5760405162461bcd60e51b8152600401610745906124a6565b601655565b5f546001600160a01b031633146110cb5760405162461bcd60e51b8152600401610745906124a6565b6001600160a01b0381166111305760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610745565b5f80546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a35f80546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b0383166111eb5760405162461bcd60e51b8152602060048201526024808201527f42455032303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610745565b6001600160a01b03821661124c5760405162461bcd60e51b815260206004820152602260248201527f42455032303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610745565b6001600160a01b038381165f8181526003602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b0383166113105760405162461bcd60e51b815260206004820152602560248201527f42455032303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610745565b6001600160a01b0382166113725760405162461bcd60e51b815260206004820152602360248201527f42455032303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610745565b5f81116113d35760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b6064820152608401610745565b5f546001600160a01b038481169116148015906113fd57505f546001600160a01b03838116911614155b15611465576015548111156114655760405162461bcd60e51b815260206004820152602860248201527f5472616e7366657220616d6f756e74206578636565647320746865206d6178546044820152673c20b6b7bab73a1760c11b6064820152608401610745565b5f61146f30610dce565b9050601554811061147f57506015545b60165481108015908190611496575060145460ff16155b80156114d457507f000000000000000000000000a646108873b6faccdfe9bf2ca7500cea2ba1f8336001600160a01b0316856001600160a01b031614155b80156114e75750601454610100900460ff165b156114fa5760165491506114fa82611755565b6001600160a01b0385165f9081526004602052604090205460019060ff168061153a57506001600160a01b0385165f9081526004602052604090205460ff165b1561154257505f5b7f000000000000000000000000a646108873b6faccdfe9bf2ca7500cea2ba1f8336001600160a01b0316856001600160a01b03161415806115b557507f000000000000000000000000a646108873b6faccdfe9bf2ca7500cea2ba1f8336001600160a01b0316866001600160a01b031614155b156115bd57505f5b7f000000000000000000000000a646108873b6faccdfe9bf2ca7500cea2ba1f8336001600160a01b0316856001600160a01b031614801561161657506001600160a01b0386165f9081526004602052604090205460ff16155b1561161f575060015b7f000000000000000000000000a646108873b6faccdfe9bf2ca7500cea2ba1f8336001600160a01b0316866001600160a01b031614801561167857506001600160a01b0385165f9081526004602052604090205460ff16155b15611681575060015b61168d868686846117f0565b505050505050565b5f81848411156116b85760405162461bcd60e51b81526004016107459190612333565b505050900390565b5f805f6116cb611a04565b90925090506116da82826116e1565b9250505090565b5f6108db828461257a565b5f6108db8284612599565b5f805f805f805f805f6117098a611b7d565b9250925092505f805f6117258d86866117206116c0565b611bbb565b919f909e50909c50959a5093985091965092945050505050565b5f6108db828461253b565b5f6108db82846125ac565b6014805460ff191660011790555f61176e8260026116e1565b90505f61177b838361173f565b90504761178783611c07565b5f611792478361173f565b905061179e8382611db5565b60408051858152602081018390529081018490527f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619060600160405180910390a150506014805460ff19169055505050565b806117fd576117fd611eb7565b5f61180783611efb565b6007549091505f90611821906001600160a01b0316610dce565b90505f61182e83836116ec565b9050601754811061185c57601754611846908361173f565b925082156118575761185783611f16565b61186b565b821561186b5761186b83611f16565b6001600160a01b0387165f9081526005602052604090205460ff1680156118aa57506001600160a01b0386165f9081526005602052604090205460ff16155b156118c8576118c387876118be888761173f565b611fd0565b6119df565b6001600160a01b0387165f9081526005602052604090205460ff1615801561190757506001600160a01b0386165f9081526005602052604090205460ff165b15611920576118c3878761191b888761173f565b6120ef565b6001600160a01b0387165f9081526005602052604090205460ff1615801561196057506001600160a01b0386165f9081526005602052604090205460ff16155b15611979576118c38787611974888761173f565b612192565b6001600160a01b0387165f9081526005602052604090205460ff1680156119b757506001600160a01b0386165f9081526005602052604090205460ff165b156119d0576118c387876119cb888761173f565b6121d2565b6119df8787611974888761173f565b836119fb576119fb600f54600e55601154601055601354601255565b50505050505050565b6009546008545f918291825b600654811015611b4d578260015f60068481548110611a3157611a31612513565b5f9182526020808320909101546001600160a01b031683528201929092526040019020541180611a9957508160025f60068481548110611a7357611a73612513565b5f9182526020808320909101546001600160a01b03168352820192909252604001902054115b15611aaf57600954600854945094505050509091565b611af360015f60068481548110611ac857611ac8612513565b5f9182526020808320909101546001600160a01b03168352820192909252604001902054849061173f565b9250611b3960025f60068481548110611b0e57611b0e612513565b5f9182526020808320909101546001600160a01b03168352820192909252604001902054839061173f565b915080611b4581612562565b915050611a10565b50600854600954611b5d916116e1565b821015611b74576009546008549350935050509091565b90939092509050565b5f805f80611b8a85612240565b90505f611b968661225b565b90505f611bad82611ba7898661173f565b9061173f565b979296509094509092505050565b5f808080611bc9888661174a565b90505f611bd6888761174a565b90505f611be3888861174a565b90505f611bf482611ba7868661173f565b939b939a50919850919650505050505050565b6040805160028082526060820183525f9260208301908036833701905050905030815f81518110611c3a57611c3a612513565b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611cb6573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611cda91906125c3565b81600181518110611ced57611ced612513565b60200260200101906001600160a01b031690816001600160a01b031681525050611d38307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d84611189565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d169063791ac94790611d8c9085905f908690309042906004016125de565b5f604051808303815f87803b158015611da3575f80fd5b505af115801561168d573d5f803e3d5ffd5b611de0307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d84611189565b7f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663f305d7198230855f80611e255f546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af1158015611e8b573d5f803e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190611eb0919061264d565b5050505050565b600e54158015611ec75750601054155b8015611ed35750601254155b15611eda57565b600e8054600f5560108054601155601280546013555f928390559082905555565b5f6107f3606461101f6012548561174a90919063ffffffff16565b5f611f1f6116c0565b90505f611f2c838361174a565b6007546001600160a01b03165f90815260016020526040902054909150611f5390826116ec565b600780546001600160a01b039081165f90815260016020908152604080832095909555925490911681526005909152205460ff1615611fcb576007546001600160a01b03165f90815260026020526040902054611fb090846116ec565b6007546001600160a01b03165f908152600260205260409020555b505050565b5f805f805f80611fdf876116f7565b6001600160a01b038f165f90815260026020526040902054959b50939950919750955093509150612010908861173f565b6001600160a01b038a165f9081526002602090815260408083209390935560019052205461203e908761173f565b6001600160a01b03808b165f9081526001602052604080822093909355908a168152205461206c90866116ec565b6001600160a01b0389165f9081526001602052604090205561208d81612276565b61209784836122f8565b876001600160a01b0316896001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef856040516120dc91815260200190565b60405180910390a3505050505050505050565b5f805f805f806120fe876116f7565b6001600160a01b038f165f90815260016020526040902054959b5093995091975095509350915061212f908761173f565b6001600160a01b03808b165f90815260016020908152604080832094909455918b1681526002909152205461216490846116ec565b6001600160a01b0389165f9081526002602090815260408083209390935560019052205461206c90866116ec565b5f805f805f806121a1876116f7565b6001600160a01b038f165f90815260016020526040902054959b5093995091975095509350915061203e908761173f565b5f805f805f806121e1876116f7565b6001600160a01b038f165f90815260026020526040902054959b50939950919750955093509150612212908861173f565b6001600160a01b038a165f9081526002602090815260408083209390935560019052205461212f908761173f565b5f6107f3606461101f600e548561174a90919063ffffffff16565b5f6107f3606461101f6010548561174a90919063ffffffff16565b5f61227f6116c0565b90505f61228c838361174a565b305f908152600160205260409020549091506122a890826116ec565b305f9081526001602090815260408083209390935560059052205460ff1615611fcb57305f908152600260205260409020546122e490846116ec565b305f90815260026020526040902055505050565b600954612305908361173f565b600955600a5461231590826116ec565b600a555050565b5f6020828403121561232c575f80fd5b5035919050565b5f6020808352835180828501525f5b8181101561235e57858101830151858201604001528201612342565b505f604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b0381168114612392575f80fd5b50565b5f80604083850312156123a6575f80fd5b82356123b18161237e565b946020939093013593505050565b5f805f606084860312156123d1575f80fd5b83356123dc8161237e565b925060208401356123ec8161237e565b929592945050506040919091013590565b5f6020828403121561240d575f80fd5b81356108db8161237e565b80358015158114612427575f80fd5b919050565b5f806040838503121561243d575f80fd5b8235915061244d60208401612418565b90509250929050565b5f60208284031215612466575f80fd5b6108db82612418565b5f8060408385031215612480575f80fd5b823561248b8161237e565b9150602083013561249b8161237e565b809150509250929050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b600181811c908216806124ef57607f821691505b60208210810361250d57634e487b7160e01b5f52602260045260245ffd5b50919050565b634e487b7160e01b5f52603260045260245ffd5b634e487b7160e01b5f52601160045260245ffd5b818103818111156107f3576107f3612527565b634e487b7160e01b5f52603160045260245ffd5b5f6001820161257357612573612527565b5060010190565b5f8261259457634e487b7160e01b5f52601260045260245ffd5b500490565b808201808211156107f3576107f3612527565b80820281158282048414176107f3576107f3612527565b5f602082840312156125d3575f80fd5b81516108db8161237e565b5f60a082018783526020878185015260a0604085015281875180845260c08601915082890193505f5b8181101561262c5784516001600160a01b031683529383019391830191600101612607565b50506001600160a01b03969096166060850152505050608001529392505050565b5f805f6060848603121561265f575f80fd5b835192506020840151915060408401519050925092509256fe42455032303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636542455032303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa26469706673582212207542fe7d2bca27777cf79ce7ca470c22b3a77bedf619304a93cf0386cf937da564736f6c63430008140033

Deployed Bytecode Sourcemap

28759:20091:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;29950:38;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;178:32:1;;;160:51;;148:2;133:18;29950:38:0;;;;;;;;35812:98;;;;;;;;;;-1:-1:-1;35812:98:0;;;;;:::i;:::-;;:::i;:::-;;31370:83;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;32282:161::-;;;;;;;;;;-1:-1:-1;32282:161:0;;;;;:::i;:::-;;:::i;:::-;;;1581:14:1;;1574:22;1556:41;;1544:2;1529:18;32282:161:0;1416:187:1;33403:87:0;;;;;;;;;;-1:-1:-1;33472:10:0;;33403:87;;;1754:25:1;;;1742:2;1727:18;33403:87:0;1608:177:1;31647:95:0;;;;;;;;;;-1:-1:-1;31727:7:0;;31647:95;;32451:313;;;;;;;;;;-1:-1:-1;32451:313:0;;;;;:::i;:::-;;:::i;34327:253::-;;;;;;;;;;-1:-1:-1;34327:253:0;;;;;:::i;:::-;;:::i;31556:83::-;;;;;;;;;;-1:-1:-1;31622:9:0;;31556:83;;31622:9;;;;2393:36:1;;2381:2;2366:18;31556:83:0;2251:184:1;34929:479:0;;;;;;;;;;-1:-1:-1;34929:479:0;;;;;:::i;:::-;;:::i;32772:218::-;;;;;;;;;;-1:-1:-1;32772:218:0;;;;;:::i;:::-;;:::i;29617:26::-;;;;;;;;;;;;;;;;33498:377;;;;;;;;;;-1:-1:-1;33498:377:0;;;;;:::i;:::-;;:::i;35567:111::-;;;;;;;;;;-1:-1:-1;35567:111:0;;;;;:::i;:::-;;:::i;33883:436::-;;;;;;;;;;-1:-1:-1;33883:436:0;;;;;:::i;:::-;;:::i;30029:40::-;;;;;;;;;;-1:-1:-1;30029:40:0;;;;;;;;;;;34588:333;;;;;;;;;;-1:-1:-1;34588:333:0;;;;;:::i;:::-;;:::i;40426:123::-;;;;;;;;;;-1:-1:-1;40426:123:0;;;;;:::i;:::-;-1:-1:-1;;;;;40514:27:0;40490:4;40514:27;;;:18;:27;;;;;;;;;40426:123;29701:32;;;;;;;;;;;;;;;;31750:198;;;;;;;;;;-1:-1:-1;31750:198:0;;;;;:::i;:::-;;:::i;20242:148::-;;;;;;;;;;;;;:::i;30082:55::-;;;;;;;;;;;;;;;;33275:120;;;;;;;;;;-1:-1:-1;33275:120:0;;;;;:::i;:::-;-1:-1:-1;;;;;33367:20:0;33343:4;33367:20;;;:11;:20;;;;;;;;;33275:120;19599:79;;;;;;;;;;-1:-1:-1;19637:7:0;19664:6;-1:-1:-1;;;;;19664:6:0;19599:79;;36029:122;;;;;;;;;;-1:-1:-1;36029:122:0;;;;;:::i;:::-;;:::i;31461:87::-;;;;;;;;;;;;;:::i;32998:269::-;;;;;;;;;;-1:-1:-1;32998:269:0;;;;;:::i;:::-;;:::i;29892:51::-;;;;;;;;;;;;;;;31956:167;;;;;;;;;;-1:-1:-1;31956:167:0;;;;;:::i;:::-;;:::i;29800:27::-;;;;;;;;;;;;;;;;36335:171;;;;;;;;;;-1:-1:-1;36335:171:0;;;;;:::i;:::-;;:::i;35918:102::-;;;;;;;;;;-1:-1:-1;35918:102:0;;;;;:::i;:::-;;:::i;30144:68::-;;;;;;;;;;;;;;;;36165:162;;;;;;;;;;-1:-1:-1;36165:162:0;;;;;:::i;:::-;;:::i;32131:143::-;;;;;;;;;;-1:-1:-1;32131:143:0;;;;;:::i;:::-;-1:-1:-1;;;;;32239:18:0;;;32212:7;32239:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;32131:143;35690:110;;;;;;;;;;-1:-1:-1;35690:110:0;;;;;:::i;:::-;;:::i;35415:140::-;;;;;;;;;;-1:-1:-1;35415:140:0;;;;;:::i;:::-;;:::i;20545:244::-;;;;;;;;;;-1:-1:-1;20545:244:0;;;;;:::i;:::-;;:::i;35812:98::-;19811:6;;-1:-1:-1;;;;;19811:6:0;10391:10;19811:22;19803:67;;;;-1:-1:-1;;;19803:67:0;;;;;;;:::i;:::-;;;;;;;;;35886:7:::1;:16:::0;35812:98::o;31370:83::-;31407:13;31440:5;31433:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;31370:83;:::o;32282:161::-;32357:4;32374:39;10391:10;32397:7;32406:6;32374:8;:39::i;:::-;-1:-1:-1;32431:4:0;32282:161;;;;;:::o;32451:313::-;32549:4;32566:36;32576:6;32584:9;32595:6;32566:9;:36::i;:::-;32613:121;32622:6;10391:10;32644:89;32682:6;32644:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;32644:19:0;;;;;;:11;:19;;;;;;;;10391:10;32644:33;;;;;;;;;;:37;:89::i;:::-;32613:8;:121::i;:::-;-1:-1:-1;32752:4:0;32451:313;;;;;:::o;34327:253::-;34393:7;34432;;34421;:18;;34413:73;;;;-1:-1:-1;;;34413:73:0;;4871:2:1;34413:73:0;;;4853:21:1;4910:2;4890:18;;;4883:30;4949:34;4929:18;;;4922:62;-1:-1:-1;;;5000:18:1;;;4993:40;5050:19;;34413:73:0;4669:406:1;34413:73:0;34497:19;34520:10;:8;:10::i;:::-;34497:33;-1:-1:-1;34548:24:0;:7;34497:33;34548:11;:24::i;:::-;34541:31;34327:253;-1:-1:-1;;;34327:253:0:o;34929:479::-;19811:6;;-1:-1:-1;;;;;19811:6:0;10391:10;19811:22;19803:67;;;;-1:-1:-1;;;19803:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;35011:20:0;::::1;;::::0;;;:11:::1;:20;::::0;;;;;::::1;;35003:60;;;::::0;-1:-1:-1;;;35003:60:0;;5282:2:1;35003:60:0::1;::::0;::::1;5264:21:1::0;5321:2;5301:18;;;5294:30;5360:29;5340:18;;;5333:57;5407:18;;35003:60:0::1;5080:351:1::0;35003:60:0::1;35079:9;35074:327;35098:9;:16:::0;35094:20;::::1;35074:327;;;35156:7;-1:-1:-1::0;;;;;35140:23:0::1;:9;35150:1;35140:12;;;;;;;;:::i;:::-;;::::0;;;::::1;::::0;;;::::1;::::0;-1:-1:-1;;;;;35140:12:0::1;:23:::0;35136:254:::1;;35199:9;35209:16:::0;;:20:::1;::::0;35228:1:::1;::::0;35209:20:::1;:::i;:::-;35199:31;;;;;;;;:::i;:::-;;::::0;;;::::1;::::0;;;::::1;::::0;35184:9:::1;:12:::0;;-1:-1:-1;;;;;35199:31:0;;::::1;::::0;35194:1;;35184:12;::::1;;;;;:::i;:::-;;::::0;;;::::1;::::0;;;;;;::::1;:46:::0;;-1:-1:-1;;;;;;35184:46:0::1;-1:-1:-1::0;;;;;35184:46:0;;::::1;;::::0;;35249:16;;::::1;::::0;;:7:::1;:16:::0;;;;;;:20;;;35288:11:::1;:20:::0;;;;:28;;-1:-1:-1;;35288:28:0::1;::::0;;35335:9:::1;:15:::0;;;::::1;;;;:::i;:::-;;::::0;;;::::1;::::0;;;;-1:-1:-1;;35335:15:0;;;;;-1:-1:-1;;;;;;35335:15:0::1;::::0;;;;;35074:327:::1;34929:479:::0;:::o;35136:254::-:1;35116:3:::0;::::1;::::0;::::1;:::i;:::-;;;;35074:327;;;;34929:479:::0;:::o;32772:218::-;10391:10;32860:4;32909:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;32909:34:0;;;;;;;;;;32860:4;;32877:83;;32900:7;;32909:50;;32948:10;32909:38;:50::i;33498:377::-;10391:10;33550:14;33599:19;;;:11;:19;;;;;;;;33598:20;33590:77;;;;-1:-1:-1;;;33590:77:0;;6307:2:1;33590:77:0;;;6289:21:1;6346:2;6326:18;;;6319:30;6385:34;6365:18;;;6358:62;-1:-1:-1;;;6436:18:1;;;6429:42;6488:19;;33590:77:0;6105:408:1;33590:77:0;33679:15;33703:19;33714:7;33703:10;:19::i;:::-;-1:-1:-1;;;;;;;;;33751:15:0;;;;;;:7;:15;;;;;;33678:44;;-1:-1:-1;33751:28:0;;:15;-1:-1:-1;33678:44:0;33751:19;:28::i;:::-;-1:-1:-1;;;;;33733:15:0;;;;;;:7;:15;;;;;:46;33800:7;;:20;;33812:7;33800:11;:20::i;:::-;33790:7;:30;33844:10;;:23;;33859:7;33844:14;:23::i;:::-;33831:10;:36;-1:-1:-1;;;33498:377:0:o;35567:111::-;19811:6;;-1:-1:-1;;;;;19811:6:0;10391:10;19811:22;19803:67;;;;-1:-1:-1;;;19803:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;35636:27:0::1;;::::0;;;:18:::1;:27;::::0;;;;:34;;-1:-1:-1;;35636:34:0::1;35666:4;35636:34;::::0;;35567:111::o;33883:436::-;33973:7;34012;;34001;:18;;33993:62;;;;-1:-1:-1;;;33993:62:0;;6720:2:1;33993:62:0;;;6702:21:1;6759:2;6739:18;;;6732:30;6798:33;6778:18;;;6771:61;6849:18;;33993:62:0;6518:355:1;33993:62:0;34071:17;34066:246;;34106:15;34130:19;34141:7;34130:10;:19::i;:::-;-1:-1:-1;34105:44:0;;-1:-1:-1;34164:14:0;;-1:-1:-1;;;;;34164:14:0;34066:246;34213:23;34244:19;34255:7;34244:10;:19::i;:::-;-1:-1:-1;34211:52:0;;-1:-1:-1;34278:22:0;;-1:-1:-1;;;;;34278:22:0;34588:333;19811:6;;-1:-1:-1;;;;;19811:6:0;10391:10;19811:22;19803:67;;;;-1:-1:-1;;;19803:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;34671:20:0;::::1;;::::0;;;:11:::1;:20;::::0;;;;;::::1;;34670:21;34662:61;;;::::0;-1:-1:-1;;;34662:61:0;;7080:2:1;34662:61:0::1;::::0;::::1;7062:21:1::0;7119:2;7099:18;;;7092:30;7158:29;7138:18;;;7131:57;7205:18;;34662:61:0::1;6878:351:1::0;34662:61:0::1;-1:-1:-1::0;;;;;34737:16:0;::::1;34756:1;34737:16:::0;;;:7:::1;:16;::::0;;;;;:20;34734:108:::1;;-1:-1:-1::0;;;;;34813:16:0;::::1;;::::0;;;:7:::1;:16;::::0;;;;;34793:37:::1;::::0;:19:::1;:37::i;:::-;-1:-1:-1::0;;;;;34774:16:0;::::1;;::::0;;;:7:::1;:16;::::0;;;;:56;34734:108:::1;-1:-1:-1::0;;;;;34852:20:0::1;;::::0;;;:11:::1;:20;::::0;;;;:27;;-1:-1:-1;;34852:27:0::1;34875:4;34852:27:::0;;::::1;::::0;;;34890:9:::1;:23:::0;;;;::::1;::::0;;;;;;::::1;::::0;;-1:-1:-1;;;;;;34890:23:0::1;::::0;;::::1;::::0;;34588:333::o;31750:198::-;-1:-1:-1;;;;;31840:20:0;;31816:7;31840:20;;;:11;:20;;;;;;;;31836:49;;;-1:-1:-1;;;;;;31869:16:0;;;;;:7;:16;;;;;;;31750:198::o;31836:49::-;-1:-1:-1;;;;;31923:16:0;;;;;;:7;:16;;;;;;31903:37;;:19;:37::i;20242:148::-;19811:6;;-1:-1:-1;;;;;19811:6:0;10391:10;19811:22;19803:67;;;;-1:-1:-1;;;19803:67:0;;;;;;;:::i;:::-;20349:1:::1;20333:6:::0;;20312:40:::1;::::0;-1:-1:-1;;;;;20333:6:0;;::::1;::::0;20312:40:::1;::::0;20349:1;;20312:40:::1;20380:1;20363:19:::0;;-1:-1:-1;;;;;;20363:19:0::1;::::0;;20242:148::o;36029:122::-;19811:6;;-1:-1:-1;;;;;19811:6:0;10391:10;19811:22;19803:67;;;;-1:-1:-1;;;19803:67:0;;;;;;;:::i;:::-;36115:13:::1;:28:::0;36029:122::o;31461:87::-;31500:13;31533:7;31526:14;;;;;:::i;32998:269::-;33091:4;33108:129;10391:10;33131:7;33140:96;33179:15;33140:96;;;;;;;;;;;;;;;;;10391:10;33140:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;33140:34:0;;;;;;;;;;;;:38;:96::i;31956:167::-;32034:4;32051:42;10391:10;32075:9;32086:6;32051:9;:42::i;36335:171::-;19811:6;;-1:-1:-1;;;;;19811:6:0;10391:10;19811:22;19803:67;;;;-1:-1:-1;;;19803:67:0;;;;;;;:::i;:::-;36412:21:::1;:32:::0;;;::::1;;;;-1:-1:-1::0;;36412:32:0;;::::1;;::::0;;36460:38:::1;::::0;::::1;::::0;::::1;::::0;36436:8;1581:14:1;1574:22;1556:41;;1544:2;1529:18;;1416:187;36460:38:0::1;;;;;;;;36335:171:::0;:::o;35918:102::-;19811:6;;-1:-1:-1;;;;;19811:6:0;10391:10;19811:22;19803:67;;;;-1:-1:-1;;;19803:67:0;;;;;;;:::i;:::-;35994:8:::1;:18:::0;35918:102::o;36165:162::-;19811:6;;-1:-1:-1;;;;;19811:6:0;10391:10;19811:22;19803:67;;;;-1:-1:-1;;;19803:67:0;;;;;;;:::i;:::-;36259:60:::1;36303:5;36259:25;36271:12;36259:7;;:11;;:25;;;;:::i;:::-;:29:::0;::::1;:60::i;:::-;36244:12;:75:::0;-1:-1:-1;36165:162:0:o;35690:110::-;19811:6;;-1:-1:-1;;;;;19811:6:0;10391:10;19811:22;19803:67;;;;-1:-1:-1;;;19803:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;35757:27:0::1;35787:5;35757:27:::0;;;:18:::1;:27;::::0;;;;:35;;-1:-1:-1;;35757:35:0::1;::::0;;35690:110::o;35415:140::-;19811:6;;-1:-1:-1;;;;;19811:6:0;10391:10;19811:22;19803:67;;;;-1:-1:-1;;;19803:67:0;;;;;;;:::i;:::-;35505:29:::1;:42:::0;35415:140::o;20545:244::-;19811:6;;-1:-1:-1;;;;;19811:6:0;10391:10;19811:22;19803:67;;;;-1:-1:-1;;;19803:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;20634:22:0;::::1;20626:73;;;::::0;-1:-1:-1;;;20626:73:0;;7436:2:1;20626:73:0::1;::::0;::::1;7418:21:1::0;7475:2;7455:18;;;7448:30;7514:34;7494:18;;;7487:62;-1:-1:-1;;;7565:18:1;;;7558:36;7611:19;;20626:73:0::1;7234:402:1::0;20626:73:0::1;20736:6;::::0;;20715:38:::1;::::0;-1:-1:-1;;;;;20715:38:0;;::::1;::::0;20736:6;::::1;::::0;20715:38:::1;::::0;::::1;20764:6;:17:::0;;-1:-1:-1;;;;;;20764:17:0::1;-1:-1:-1::0;;;;;20764:17:0;;;::::1;::::0;;;::::1;::::0;;20545:244::o;40557:337::-;-1:-1:-1;;;;;40650:19:0;;40642:68;;;;-1:-1:-1;;;40642:68:0;;7843:2:1;40642:68:0;;;7825:21:1;7882:2;7862:18;;;7855:30;7921:34;7901:18;;;7894:62;-1:-1:-1;;;7972:18:1;;;7965:34;8016:19;;40642:68:0;7641:400:1;40642:68:0;-1:-1:-1;;;;;40729:21:0;;40721:68;;;;-1:-1:-1;;;40721:68:0;;8248:2:1;40721:68:0;;;8230:21:1;8287:2;8267:18;;;8260:30;8326:34;8306:18;;;8299:62;-1:-1:-1;;;8377:18:1;;;8370:32;8419:19;;40721:68:0;8046:398:1;40721:68:0;-1:-1:-1;;;;;40802:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;40854:32;;1754:25:1;;;40854:32:0;;1727:18:1;40854:32:0;;;;;;;40557:337;;;:::o;40902:2168::-;-1:-1:-1;;;;;41024:18:0;;41016:68;;;;-1:-1:-1;;;41016:68:0;;8651:2:1;41016:68:0;;;8633:21:1;8690:2;8670:18;;;8663:30;8729:34;8709:18;;;8702:62;-1:-1:-1;;;8780:18:1;;;8773:35;8825:19;;41016:68:0;8449:401:1;41016:68:0;-1:-1:-1;;;;;41103:16:0;;41095:64;;;;-1:-1:-1;;;41095:64:0;;9057:2:1;41095:64:0;;;9039:21:1;9096:2;9076:18;;;9069:30;9135:34;9115:18;;;9108:62;-1:-1:-1;;;9186:18:1;;;9179:33;9229:19;;41095:64:0;8855:399:1;41095:64:0;41187:1;41178:6;:10;41170:64;;;;-1:-1:-1;;;41170:64:0;;9461:2:1;41170:64:0;;;9443:21:1;9500:2;9480:18;;;9473:30;9539:34;9519:18;;;9512:62;-1:-1:-1;;;9590:18:1;;;9583:39;9639:19;;41170:64:0;9259:405:1;41170:64:0;19637:7;19664:6;-1:-1:-1;;;;;41248:15:0;;;19664:6;;41248:15;;;;:32;;-1:-1:-1;19637:7:0;19664:6;-1:-1:-1;;;;;41267:13:0;;;19664:6;;41267:13;;41248:32;41245:125;;;41313:12;;41303:6;:22;;41295:75;;;;-1:-1:-1;;;41295:75:0;;9871:2:1;41295:75:0;;;9853:21:1;9910:2;9890:18;;;9883:30;9949:34;9929:18;;;9922:62;-1:-1:-1;;;10000:18:1;;;9993:38;10048:19;;41295:75:0;9669:404:1;41295:75:0;41665:28;41696:24;41714:4;41696:9;:24::i;:::-;41665:55;;41768:12;;41744:20;:36;41741:112;;-1:-1:-1;41829:12:0;;41741:112;41924:29;;41900:53;;;;;;;41982;;-1:-1:-1;42019:16:0;;;;42018:17;41982:53;:91;;;;;42060:13;-1:-1:-1;;;;;42052:21:0;:4;-1:-1:-1;;;;;42052:21:0;;;41982:91;:129;;;;-1:-1:-1;42090:21:0;;;;;;;41982:129;41964:318;;;42161:29;;42138:52;;42234:36;42249:20;42234:14;:36::i;:::-;-1:-1:-1;;;;;42490:24:0;;42363:12;42490:24;;;:18;:24;;;;;;42378:4;;42490:24;;;:50;;-1:-1:-1;;;;;;42518:22:0;;;;;;:18;:22;;;;;;;;42490:50;42487:96;;;-1:-1:-1;42566:5:0;42487:96;42606:13;-1:-1:-1;;;;;42600:19:0;:2;-1:-1:-1;;;;;42600:19:0;;;:44;;;;42631:13;-1:-1:-1;;;;;42623:21:0;:4;-1:-1:-1;;;;;42623:21:0;;;42600:44;42595:92;;;-1:-1:-1;42670:5:0;42595:92;42716:13;-1:-1:-1;;;;;42710:19:0;:2;-1:-1:-1;;;;;42710:19:0;;:48;;;;-1:-1:-1;;;;;;42734:24:0;;;;;;:18;:24;;;;;;;;42733:25;42710:48;42706:110;;;-1:-1:-1;42800:4:0;42706:110;42841:13;-1:-1:-1;;;;;42833:21:0;:4;-1:-1:-1;;;;;42833:21:0;;:48;;;;-1:-1:-1;;;;;;42859:22:0;;;;;;:18;:22;;;;;;;;42858:23;42833:48;42829:109;;;-1:-1:-1;42922:4:0;42829:109;43024:38;43039:4;43044:2;43047:6;43054:7;43024:14;:38::i;:::-;41005:2065;;;40902:2168;;;:::o;7761:206::-;7847:7;7908:12;7900:6;;;;7892:29;;;;-1:-1:-1;;;7892:29:0;;;;;;;;:::i;:::-;-1:-1:-1;;;7943:5:0;;;7761:206::o;37969:163::-;38010:7;38031:15;38048;38067:19;:17;:19::i;:::-;38030:56;;-1:-1:-1;38030:56:0;-1:-1:-1;38104:20:0;38030:56;;38104:11;:20::i;:::-;38097:27;;;;37969:163;:::o;6619:98::-;6677:7;6704:5;6708:1;6704;:5;:::i;5482:98::-;5540:7;5567:5;5571:1;5567;:5;:::i;36767:419::-;36826:7;36835;36844;36853;36862;36871;36892:23;36917:12;36931:18;36953:20;36965:7;36953:11;:20::i;:::-;36891:82;;;;;;36985:15;37002:23;37027:12;37043:50;37055:7;37064:4;37070:10;37082;:8;:10::i;:::-;37043:11;:50::i;:::-;36984:109;;;;-1:-1:-1;36984:109:0;;-1:-1:-1;37144:15:0;;-1:-1:-1;37161:4:0;;-1:-1:-1;37167:10:0;;-1:-1:-1;36767:419:0;;-1:-1:-1;;;;;36767:419:0:o;5863:98::-;5921:7;5948:5;5952:1;5948;:5;:::i;6220:98::-;6278:7;6305:5;6309:1;6305;:5;:::i;43078:985::-;30576:16;:23;;-1:-1:-1;;30576:23:0;30595:4;30576:23;;;:16;43229:27:::1;:20:::0;43254:1:::1;43229:24;:27::i;:::-;43214:42:::0;-1:-1:-1;43267:17:0::1;43287:30;:20:::0;43214:42;43287:24:::1;:30::i;:::-;43267:50:::0;-1:-1:-1;43620:21:0::1;43686:22;43703:4:::0;43686:16:::1;:22::i;:::-;43839:18;43860:41;:21;43886:14:::0;43860:25:::1;:41::i;:::-;43839:62;;43951:35;43964:9;43975:10;43951:12;:35::i;:::-;44012:43;::::0;;10805:25:1;;;10861:2;10846:18;;10839:34;;;10889:18;;;10882:34;;;44012:43:0::1;::::0;10793:2:1;10778:18;44012:43:0::1;;;;;;;-1:-1:-1::0;;30622:16:0;:24;;-1:-1:-1;;30622:24:0;;;-1:-1:-1;;;43078:985:0:o;45262:1257::-;45373:7;45369:40;;45395:14;:12;:14::i;:::-;45419:13;45435:24;45452:6;45435:16;:24::i;:::-;45499:18;;45419:40;;-1:-1:-1;45464:22:0;;45489:29;;-1:-1:-1;;;;;45499:18:0;45489:9;:29::i;:::-;45464:54;-1:-1:-1;45523:17:0;45543:25;:5;45464:54;45543:9;:25::i;:::-;45523:45;;45590:13;;45577:9;:26;45574:220;;45625:13;;:33;;45643:14;45625:17;:33::i;:::-;45617:41;-1:-1:-1;45667:9:0;;45664:51;;45689:16;45699:5;45689:9;:16::i;:::-;45574:220;;;45743:9;;45740:48;;45763:16;45773:5;45763:9;:16::i;:::-;-1:-1:-1;;;;;45812:19:0;;;;;;:11;:19;;;;;;;;:46;;;;-1:-1:-1;;;;;;45836:22:0;;;;;;:11;:22;;;;;;;;45835:23;45812:46;45808:652;;;45875:59;45897:6;45905:9;45916:17;:6;45927:5;45916:10;:17::i;:::-;45875:21;:59::i;:::-;45808:652;;;-1:-1:-1;;;;;45957:19:0;;;;;;:11;:19;;;;;;;;45956:20;:46;;;;-1:-1:-1;;;;;;45980:22:0;;;;;;:11;:22;;;;;;;;45956:46;45952:508;;;46019:57;46039:6;46047:9;46058:17;:6;46069:5;46058:10;:17::i;:::-;46019:19;:57::i;45952:508::-;-1:-1:-1;;;;;46099:19:0;;;;;;:11;:19;;;;;;;;46098:20;:47;;;;-1:-1:-1;;;;;;46123:22:0;;;;;;:11;:22;;;;;;;;46122:23;46098:47;46094:366;;;46162:55;46180:6;46188:9;46199:17;:6;46210:5;46199:10;:17::i;:::-;46162;:55::i;46094:366::-;-1:-1:-1;;;;;46239:19:0;;;;;;:11;:19;;;;;;;;:45;;;;-1:-1:-1;;;;;;46262:22:0;;;;;;:11;:22;;;;;;;;46239:45;46235:225;;;46301:59;46323:6;46331:9;46342:17;:6;46353:5;46342:10;:17::i;:::-;46301:21;:59::i;46235:225::-;46393:55;46411:6;46419:9;46430:17;:6;46441:5;46430:10;:17::i;46393:55::-;46474:7;46470:41;;46496:15;40314;;40304:7;:25;40356:21;;40340:13;:37;40393:16;;40382:8;:27;40260:157;46496:15;45358:1161;;;45262:1257;;;;:::o;38140:561::-;38237:7;;38273;;38190;;;;;38297:289;38321:9;:16;38317:20;;38297:289;;;38387:7;38363;:21;38371:9;38381:1;38371:12;;;;;;;;:::i;:::-;;;;;;;;;;;;;-1:-1:-1;;;;;38371:12:0;38363:21;;;;;;;;;;;;;:31;;:66;;;38422:7;38398;:21;38406:9;38416:1;38406:12;;;;;;;;:::i;:::-;;;;;;;;;;;;;-1:-1:-1;;;;;38406:12:0;38398:21;;;;;;;;;;;;;:31;38363:66;38359:97;;;38439:7;;38448;;38431:25;;;;;;;38140:561;;:::o;38359:97::-;38481:34;38493:7;:21;38501:9;38511:1;38501:12;;;;;;;;:::i;:::-;;;;;;;;;;;;;-1:-1:-1;;;;;38501:12:0;38493:21;;;;;;;;;;;;;38481:7;;:11;:34::i;:::-;38471:44;;38540:34;38552:7;:21;38560:9;38570:1;38560:12;;;;;;;;:::i;:::-;;;;;;;;;;;;;-1:-1:-1;;;;;38560:12:0;38552:21;;;;;;;;;;;;;38540:7;;:11;:34::i;:::-;38530:44;-1:-1:-1;38339:3:0;;;;:::i;:::-;;;;38297:289;;;-1:-1:-1;38622:7:0;;38610;;:20;;:11;:20::i;:::-;38600:7;:30;38596:61;;;38640:7;;38649;;38632:25;;;;;;38140:561;;:::o;38596:61::-;38676:7;;38685;;-1:-1:-1;38140:561:0;-1:-1:-1;38140:561:0:o;37194:330::-;37254:7;37263;37272;37292:12;37307:24;37323:7;37307:15;:24::i;:::-;37292:39;;37342:18;37363:30;37385:7;37363:21;:30::i;:::-;37342:51;-1:-1:-1;37404:23:0;37430:33;37342:51;37430:17;:7;37442:4;37430:11;:17::i;:::-;:21;;:33::i;:::-;37404:59;37499:4;;-1:-1:-1;37505:10:0;;-1:-1:-1;37194:330:0;;-1:-1:-1;;;37194:330:0:o;37532:429::-;37647:7;;;;37703:24;:7;37715:11;37703;:24::i;:::-;37685:42;-1:-1:-1;37738:12:0;37753:21;:4;37762:11;37753:8;:21::i;:::-;37738:36;-1:-1:-1;37785:18:0;37806:27;:10;37821:11;37806:14;:27::i;:::-;37785:48;-1:-1:-1;37844:23:0;37870:33;37785:48;37870:17;:7;37882:4;37870:11;:17::i;:33::-;37922:7;;;;-1:-1:-1;37948:4:0;;-1:-1:-1;37532:429:0;;-1:-1:-1;;;;;;;37532:429:0:o;44071:589::-;44221:16;;;44235:1;44221:16;;;;;;;;44197:21;;44221:16;;;;;;;;;;-1:-1:-1;44221:16:0;44197:40;;44266:4;44248;44253:1;44248:7;;;;;;;;:::i;:::-;;;;;;:23;-1:-1:-1;;;;;44248:23:0;;;-1:-1:-1;;;;;44248:23:0;;;;;44292:15;-1:-1:-1;;;;;44292:20:0;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;44282:4;44287:1;44282:7;;;;;;;;:::i;:::-;;;;;;:32;-1:-1:-1;;;;;44282:32:0;;;-1:-1:-1;;;;;44282:32:0;;;;;44327:62;44344:4;44359:15;44377:11;44327:8;:62::i;:::-;44428:224;;-1:-1:-1;;;44428:224:0;;-1:-1:-1;;;;;44428:15:0;:66;;;;:224;;44509:11;;44535:1;;44579:4;;44606;;44626:15;;44428:224;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;44668:513;44816:62;44833:4;44848:15;44866:11;44816:8;:62::i;:::-;44921:15;-1:-1:-1;;;;;44921:31:0;;44960:9;44993:4;45013:11;45039:1;45082;45125:7;19637;19664:6;-1:-1:-1;;;;;19664:6:0;;19599:79;45125:7;44921:252;;;;;;-1:-1:-1;;;;;;44921:252:0;;;-1:-1:-1;;;;;12659:15:1;;;44921:252:0;;;12641:34:1;12691:18;;;12684:34;;;;12734:18;;;12727:34;;;;12777:18;;;12770:34;12841:15;;;12820:19;;;12813:44;45147:15:0;12873:19:1;;;12866:35;12575:19;;44921:252:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;44668:513;;:::o;39941:310::-;39987:7;;:12;:34;;;;-1:-1:-1;40003:13:0;;:18;39987:34;:51;;;;-1:-1:-1;40025:8:0;;:13;39987:51;39984:63;;;39941:310::o;39984:63::-;40085:7;;;40067:15;:25;40127:13;;;40103:21;:37;40164:8;;;40145:16;:27;-1:-1:-1;40187:11:0;;;;40209:17;;;;40231:12;39941:310::o;39598:156::-;39663:7;39690:56;39730:5;39690:21;39702:8;;39690:7;:11;;:21;;;;:::i;39077:350::-;39130:19;39153:10;:8;:10::i;:::-;39130:33;-1:-1:-1;39174:13:0;39190:22;:5;39130:33;39190:9;:22::i;:::-;39261:18;;-1:-1:-1;;;;;39261:18:0;39253:27;;;;:7;:27;;;;;;39174:38;;-1:-1:-1;39253:38:0;;39174;39253:31;:38::i;:::-;39231:18;;;-1:-1:-1;;;;;39231:18:0;;;39223:27;;;;:7;:27;;;;;;;;:68;;;;39317:18;;;;;39305:31;;:11;:31;;;;;;;39302:117;;;39389:18;;-1:-1:-1;;;;;39389:18:0;39381:27;;;;:7;:27;;;;;;:38;;39413:5;39381:31;:38::i;:::-;39359:18;;-1:-1:-1;;;;;39359:18:0;39351:27;;;;:7;:27;;;;;:68;39302:117;39119:308;;39077:350;:::o;47631:566::-;47734:15;47751:23;47776:12;47790:23;47815:12;47829:18;47851:19;47862:7;47851:10;:19::i;:::-;-1:-1:-1;;;;;47899:15:0;;;;;;:7;:15;;;;;;47733:137;;-1:-1:-1;47733:137:0;;-1:-1:-1;47733:137:0;;-1:-1:-1;47733:137:0;-1:-1:-1;47733:137:0;-1:-1:-1;47733:137:0;-1:-1:-1;47899:28:0;;47919:7;47899:19;:28::i;:::-;-1:-1:-1;;;;;47881:15:0;;;;;;:7;:15;;;;;;;;:46;;;;47956:7;:15;;;;:28;;47976:7;47956:19;:28::i;:::-;-1:-1:-1;;;;;47938:15:0;;;;;;;:7;:15;;;;;;:46;;;;48016:18;;;;;;;:39;;48039:15;48016:22;:39::i;:::-;-1:-1:-1;;;;;47995:18:0;;;;;;:7;:18;;;;;:60;48069:26;48084:10;48069:14;:26::i;:::-;48106:23;48118:4;48124;48106:11;:23::i;:::-;48162:9;-1:-1:-1;;;;;48145:44:0;48154:6;-1:-1:-1;;;;;48145:44:0;;48173:15;48145:44;;;;1754:25:1;;1742:2;1727:18;;1608:177;48145:44:0;;;;;;;;47722:475;;;;;;47631:566;;;:::o;47037:586::-;47138:15;47155:23;47180:12;47194:23;47219:12;47233:18;47255:19;47266:7;47255:10;:19::i;:::-;-1:-1:-1;;;;;47303:15:0;;;;;;:7;:15;;;;;;47137:137;;-1:-1:-1;47137:137:0;;-1:-1:-1;47137:137:0;;-1:-1:-1;47137:137:0;-1:-1:-1;47137:137:0;-1:-1:-1;47137:137:0;-1:-1:-1;47303:28:0;;47137:137;47303:19;:28::i;:::-;-1:-1:-1;;;;;47285:15:0;;;;;;;:7;:15;;;;;;;;:46;;;;47363:18;;;;;:7;:18;;;;;:39;;47386:15;47363:22;:39::i;:::-;-1:-1:-1;;;;;47342:18:0;;;;;;:7;:18;;;;;;;;:60;;;;47434:7;:18;;;;:39;;47457:15;47434:22;:39::i;46527:502::-;46626:15;46643:23;46668:12;46682:23;46707:12;46721:18;46743:19;46754:7;46743:10;:19::i;:::-;-1:-1:-1;;;;;46791:15:0;;;;;;:7;:15;;;;;;46625:137;;-1:-1:-1;46625:137:0;;-1:-1:-1;46625:137:0;;-1:-1:-1;46625:137:0;-1:-1:-1;46625:137:0;-1:-1:-1;46625:137:0;-1:-1:-1;46791:28:0;;46625:137;46791:19;:28::i;48203:642::-;48306:15;48323:23;48348:12;48362:23;48387:12;48401:18;48423:19;48434:7;48423:10;:19::i;:::-;-1:-1:-1;;;;;48471:15:0;;;;;;:7;:15;;;;;;48305:137;;-1:-1:-1;48305:137:0;;-1:-1:-1;48305:137:0;;-1:-1:-1;48305:137:0;-1:-1:-1;48305:137:0;-1:-1:-1;48305:137:0;-1:-1:-1;48471:28:0;;48491:7;48471:19;:28::i;:::-;-1:-1:-1;;;;;48453:15:0;;;;;;:7;:15;;;;;;;;:46;;;;48528:7;:15;;;;:28;;48548:7;48528:19;:28::i;39436:154::-;39500:7;39527:55;39566:5;39527:20;39539:7;;39527;:11;;:20;;;;:::i;39763:166::-;39833:7;39860:61;39905:5;39860:26;39872:13;;39860:7;:11;;:26;;;;:::i;38713:355::-;38776:19;38799:10;:8;:10::i;:::-;38776:33;-1:-1:-1;38820:18:0;38841:27;:10;38776:33;38841:14;:27::i;:::-;38920:4;38904:22;;;;:7;:22;;;;;;38820:48;;-1:-1:-1;38904:38:0;;38820:48;38904:26;:38::i;:::-;38895:4;38879:22;;;;:7;:22;;;;;;;;:63;;;;38956:11;:26;;;;;;38953:107;;;39038:4;39022:22;;;;:7;:22;;;;;;:38;;39049:10;39022:26;:38::i;:::-;39013:4;38997:22;;;;:7;:22;;;;;:63;38765:303;;38713:355;:::o;36612:147::-;36690:7;;:17;;36702:4;36690:11;:17::i;:::-;36680:7;:27;36731:10;;:20;;36746:4;36731:14;:20::i;:::-;36718:10;:33;-1:-1:-1;;36612:147:0:o;222:180:1:-;281:6;334:2;322:9;313:7;309:23;305:32;302:52;;;350:1;347;340:12;302:52;-1:-1:-1;373:23:1;;222:180;-1:-1:-1;222:180:1:o;407:548::-;519:4;548:2;577;566:9;559:21;609:6;603:13;652:6;647:2;636:9;632:18;625:34;677:1;687:140;701:6;698:1;695:13;687:140;;;796:14;;;792:23;;786:30;762:17;;;781:2;758:26;751:66;716:10;;687:140;;;691:3;876:1;871:2;862:6;851:9;847:22;843:31;836:42;946:2;939;935:7;930:2;922:6;918:15;914:29;903:9;899:45;895:54;887:62;;;;407:548;;;;:::o;960:131::-;-1:-1:-1;;;;;1035:31:1;;1025:42;;1015:70;;1081:1;1078;1071:12;1015:70;960:131;:::o;1096:315::-;1164:6;1172;1225:2;1213:9;1204:7;1200:23;1196:32;1193:52;;;1241:1;1238;1231:12;1193:52;1280:9;1267:23;1299:31;1324:5;1299:31;:::i;:::-;1349:5;1401:2;1386:18;;;;1373:32;;-1:-1:-1;;;1096:315:1:o;1790:456::-;1867:6;1875;1883;1936:2;1924:9;1915:7;1911:23;1907:32;1904:52;;;1952:1;1949;1942:12;1904:52;1991:9;1978:23;2010:31;2035:5;2010:31;:::i;:::-;2060:5;-1:-1:-1;2117:2:1;2102:18;;2089:32;2130:33;2089:32;2130:33;:::i;:::-;1790:456;;2182:7;;-1:-1:-1;;;2236:2:1;2221:18;;;;2208:32;;1790:456::o;2440:247::-;2499:6;2552:2;2540:9;2531:7;2527:23;2523:32;2520:52;;;2568:1;2565;2558:12;2520:52;2607:9;2594:23;2626:31;2651:5;2626:31;:::i;2692:160::-;2757:20;;2813:13;;2806:21;2796:32;;2786:60;;2842:1;2839;2832:12;2786:60;2692:160;;;:::o;2857:248::-;2922:6;2930;2983:2;2971:9;2962:7;2958:23;2954:32;2951:52;;;2999:1;2996;2989:12;2951:52;3035:9;3022:23;3012:33;;3064:35;3095:2;3084:9;3080:18;3064:35;:::i;:::-;3054:45;;2857:248;;;;;:::o;3345:180::-;3401:6;3454:2;3442:9;3433:7;3429:23;3425:32;3422:52;;;3470:1;3467;3460:12;3422:52;3493:26;3509:9;3493:26;:::i;3530:388::-;3598:6;3606;3659:2;3647:9;3638:7;3634:23;3630:32;3627:52;;;3675:1;3672;3665:12;3627:52;3714:9;3701:23;3733:31;3758:5;3733:31;:::i;:::-;3783:5;-1:-1:-1;3840:2:1;3825:18;;3812:32;3853:33;3812:32;3853:33;:::i;:::-;3905:7;3895:17;;;3530:388;;;;;:::o;3923:356::-;4125:2;4107:21;;;4144:18;;;4137:30;4203:34;4198:2;4183:18;;4176:62;4270:2;4255:18;;3923:356::o;4284:380::-;4363:1;4359:12;;;;4406;;;4427:61;;4481:4;4473:6;4469:17;4459:27;;4427:61;4534:2;4526:6;4523:14;4503:18;4500:38;4497:161;;4580:10;4575:3;4571:20;4568:1;4561:31;4615:4;4612:1;4605:15;4643:4;4640:1;4633:15;4497:161;;4284:380;;;:::o;5436:127::-;5497:10;5492:3;5488:20;5485:1;5478:31;5528:4;5525:1;5518:15;5552:4;5549:1;5542:15;5568:127;5629:10;5624:3;5620:20;5617:1;5610:31;5660:4;5657:1;5650:15;5684:4;5681:1;5674:15;5700:128;5767:9;;;5788:11;;;5785:37;;;5802:18;;:::i;5833:127::-;5894:10;5889:3;5885:20;5882:1;5875:31;5925:4;5922:1;5915:15;5949:4;5946:1;5939:15;5965:135;6004:3;6025:17;;;6022:43;;6045:18;;:::i;:::-;-1:-1:-1;6092:1:1;6081:13;;5965:135::o;10078:217::-;10118:1;10144;10134:132;;10188:10;10183:3;10179:20;10176:1;10169:31;10223:4;10220:1;10213:15;10251:4;10248:1;10241:15;10134:132;-1:-1:-1;10280:9:1;;10078:217::o;10300:125::-;10365:9;;;10386:10;;;10383:36;;;10399:18;;:::i;10430:168::-;10503:9;;;10534;;10551:15;;;10545:22;;10531:37;10521:71;;10572:18;;:::i;11059:251::-;11129:6;11182:2;11170:9;11161:7;11157:23;11153:32;11150:52;;;11198:1;11195;11188:12;11150:52;11230:9;11224:16;11249:31;11274:5;11249:31;:::i;11315:980::-;11577:4;11625:3;11614:9;11610:19;11656:6;11645:9;11638:25;11682:2;11720:6;11715:2;11704:9;11700:18;11693:34;11763:3;11758:2;11747:9;11743:18;11736:31;11787:6;11822;11816:13;11853:6;11845;11838:22;11891:3;11880:9;11876:19;11869:26;;11930:2;11922:6;11918:15;11904:29;;11951:1;11961:195;11975:6;11972:1;11969:13;11961:195;;;12040:13;;-1:-1:-1;;;;;12036:39:1;12024:52;;12131:15;;;;12096:12;;;;12072:1;11990:9;11961:195;;;-1:-1:-1;;;;;;;12212:32:1;;;;12207:2;12192:18;;12185:60;-1:-1:-1;;;12276:3:1;12261:19;12254:35;12173:3;11315:980;-1:-1:-1;;;11315:980:1:o;12912:306::-;13000:6;13008;13016;13069:2;13057:9;13048:7;13044:23;13040:32;13037:52;;;13085:1;13082;13075:12;13037:52;13114:9;13108:16;13098:26;;13164:2;13153:9;13149:18;13143:25;13133:35;;13208:2;13197:9;13193:18;13187:25;13177:35;;12912:306;;;;;:::o

Swarm Source

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