ETH Price: $3,939.95 (+7.36%)

Token

Tsuki (TSUKI)
 

Overview

Max Total Supply

10,000 TSUKI

Holders

5,070

Market

Volume (24H)

N/A

Min Price (24H)

N/A

Max Price (24H)

N/A
Filtered by Token Holder
wmtc.eth
Balance
1 TSUKI
0xb87849ad7f7eca46ebde44e4259975d02ca3f027
Loading...
Loading
Loading...
Loading
Loading...
Loading

OVERVIEW

Tales of Tsuki is a collection of 9,999 beautiful, brave Waifus and their adorable, loyal companions, ready to fantasize on the Ethereum Blockchain.

# Exchange Pair Price  24H Volume % Volume

Contract Source Code Verified (Exact Match)

Contract Name:
Tsuki

Compiler Version
v0.8.7+commit.e28d00a7

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2022-02-20
*/

// File: @openzeppelin/contracts/token/ERC721/IERC721Receiver.sol


// OpenZeppelin Contracts v4.4.1 (token/ERC721/IERC721Receiver.sol)

pragma solidity ^0.8.0;

/**
 * @title ERC721 token receiver interface
 * @dev Interface for any contract that wants to support safeTransfers
 * from ERC721 asset contracts.
 */
interface IERC721Receiver {
    /**
     * @dev Whenever an {IERC721} `tokenId` token is transferred to this contract via {IERC721-safeTransferFrom}
     * by `operator` from `from`, this function is called.
     *
     * It must return its Solidity selector to confirm the token transfer.
     * If any other value is returned or the interface is not implemented by the recipient, the transfer will be reverted.
     *
     * The selector can be obtained in Solidity with `IERC721.onERC721Received.selector`.
     */
    function onERC721Received(
        address operator,
        address from,
        uint256 tokenId,
        bytes calldata data
    ) external returns (bytes4);
}

// File: @openzeppelin/contracts/utils/introspection/IERC165.sol


// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)

pragma solidity ^0.8.0;

/**
 * @dev Interface of the ERC165 standard, as defined in the
 * https://eips.ethereum.org/EIPS/eip-165[EIP].
 *
 * Implementers can declare support of contract interfaces, which can then be
 * queried by others ({ERC165Checker}).
 *
 * For an implementation, see {ERC165}.
 */
interface IERC165 {
    /**
     * @dev Returns true if this contract implements the interface defined by
     * `interfaceId`. See the corresponding
     * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]
     * to learn more about how these ids are created.
     *
     * This function call must use less than 30 000 gas.
     */
    function supportsInterface(bytes4 interfaceId) external view returns (bool);
}

// File: @openzeppelin/contracts/utils/introspection/ERC165.sol


// OpenZeppelin Contracts v4.4.1 (utils/introspection/ERC165.sol)

pragma solidity ^0.8.0;


/**
 * @dev Implementation of the {IERC165} interface.
 *
 * Contracts that want to implement ERC165 should inherit from this contract and override {supportsInterface} to check
 * for the additional interface id that will be supported. For example:
 *
 * ```solidity
 * function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {
 *     return interfaceId == type(MyInterface).interfaceId || super.supportsInterface(interfaceId);
 * }
 * ```
 *
 * Alternatively, {ERC165Storage} provides an easier to use but more expensive implementation.
 */
abstract contract ERC165 is IERC165 {
    /**
     * @dev See {IERC165-supportsInterface}.
     */
    function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {
        return interfaceId == type(IERC165).interfaceId;
    }
}

// File: @openzeppelin/contracts/token/ERC721/IERC721.sol


// OpenZeppelin Contracts v4.4.1 (token/ERC721/IERC721.sol)

pragma solidity ^0.8.0;


/**
 * @dev Required interface of an ERC721 compliant contract.
 */
interface IERC721 is IERC165 {
    /**
     * @dev Emitted when `tokenId` token is transferred from `from` to `to`.
     */
    event Transfer(address indexed from, address indexed to, uint256 indexed tokenId);

    /**
     * @dev Emitted when `owner` enables `approved` to manage the `tokenId` token.
     */
    event Approval(address indexed owner, address indexed approved, uint256 indexed tokenId);

    /**
     * @dev Emitted when `owner` enables or disables (`approved`) `operator` to manage all of its assets.
     */
    event ApprovalForAll(address indexed owner, address indexed operator, bool approved);

    /**
     * @dev Returns the number of tokens in ``owner``'s account.
     */
    function balanceOf(address owner) external view returns (uint256 balance);

    /**
     * @dev Returns the owner of the `tokenId` token.
     *
     * Requirements:
     *
     * - `tokenId` must exist.
     */
    function ownerOf(uint256 tokenId) external view returns (address owner);

    /**
     * @dev Safely transfers `tokenId` token from `from` to `to`, checking first that contract recipients
     * are aware of the ERC721 protocol to prevent tokens from being forever locked.
     *
     * Requirements:
     *
     * - `from` cannot be the zero address.
     * - `to` cannot be the zero address.
     * - `tokenId` token must exist and be owned by `from`.
     * - If the caller is not `from`, it must be have been allowed to move this token by either {approve} or {setApprovalForAll}.
     * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.
     *
     * Emits a {Transfer} event.
     */
    function safeTransferFrom(
        address from,
        address to,
        uint256 tokenId
    ) external;

    /**
     * @dev Transfers `tokenId` token from `from` to `to`.
     *
     * WARNING: Usage of this method is discouraged, use {safeTransferFrom} whenever possible.
     *
     * Requirements:
     *
     * - `from` cannot be the zero address.
     * - `to` cannot be the zero address.
     * - `tokenId` token must be owned by `from`.
     * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.
     *
     * Emits a {Transfer} event.
     */
    function transferFrom(
        address from,
        address to,
        uint256 tokenId
    ) external;

    /**
     * @dev Gives permission to `to` to transfer `tokenId` token to another account.
     * The approval is cleared when the token is transferred.
     *
     * Only a single account can be approved at a time, so approving the zero address clears previous approvals.
     *
     * Requirements:
     *
     * - The caller must own the token or be an approved operator.
     * - `tokenId` must exist.
     *
     * Emits an {Approval} event.
     */
    function approve(address to, uint256 tokenId) external;

    /**
     * @dev Returns the account approved for `tokenId` token.
     *
     * Requirements:
     *
     * - `tokenId` must exist.
     */
    function getApproved(uint256 tokenId) external view returns (address operator);

    /**
     * @dev Approve or remove `operator` as an operator for the caller.
     * Operators can call {transferFrom} or {safeTransferFrom} for any token owned by the caller.
     *
     * Requirements:
     *
     * - The `operator` cannot be the caller.
     *
     * Emits an {ApprovalForAll} event.
     */
    function setApprovalForAll(address operator, bool _approved) external;

    /**
     * @dev Returns if the `operator` is allowed to manage all of the assets of `owner`.
     *
     * See {setApprovalForAll}
     */
    function isApprovedForAll(address owner, address operator) external view returns (bool);

    /**
     * @dev Safely transfers `tokenId` token from `from` to `to`.
     *
     * Requirements:
     *
     * - `from` cannot be the zero address.
     * - `to` cannot be the zero address.
     * - `tokenId` token must exist and be owned by `from`.
     * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.
     * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.
     *
     * Emits a {Transfer} event.
     */
    function safeTransferFrom(
        address from,
        address to,
        uint256 tokenId,
        bytes calldata data
    ) external;
}

// File: @openzeppelin/contracts/token/ERC721/extensions/IERC721Enumerable.sol


// OpenZeppelin Contracts v4.4.1 (token/ERC721/extensions/IERC721Enumerable.sol)

pragma solidity ^0.8.0;


/**
 * @title ERC-721 Non-Fungible Token Standard, optional enumeration extension
 * @dev See https://eips.ethereum.org/EIPS/eip-721
 */
interface IERC721Enumerable is IERC721 {
    /**
     * @dev Returns the total amount of tokens stored by the contract.
     */
    function totalSupply() external view returns (uint256);

    /**
     * @dev Returns a token ID owned by `owner` at a given `index` of its token list.
     * Use along with {balanceOf} to enumerate all of ``owner``'s tokens.
     */
    function tokenOfOwnerByIndex(address owner, uint256 index) external view returns (uint256 tokenId);

    /**
     * @dev Returns a token ID at a given `index` of all the tokens stored by the contract.
     * Use along with {totalSupply} to enumerate all tokens.
     */
    function tokenByIndex(uint256 index) external view returns (uint256);
}

// File: @openzeppelin/contracts/token/ERC721/extensions/IERC721Metadata.sol


// OpenZeppelin Contracts v4.4.1 (token/ERC721/extensions/IERC721Metadata.sol)

pragma solidity ^0.8.0;


/**
 * @title ERC-721 Non-Fungible Token Standard, optional metadata extension
 * @dev See https://eips.ethereum.org/EIPS/eip-721
 */
interface IERC721Metadata is IERC721 {
    /**
     * @dev Returns the token collection name.
     */
    function name() external view returns (string memory);

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

    /**
     * @dev Returns the Uniform Resource Identifier (URI) for `tokenId` token.
     */
    function tokenURI(uint256 tokenId) external view returns (string memory);
}

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


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

pragma solidity ^0.8.0;

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

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

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

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

        (bool success, bytes memory returndata) = target.delegatecall(data);
        return verifyCallResult(success, returndata, errorMessage);
    }

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

                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert(errorMessage);
            }
        }
    }
}

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


// OpenZeppelin Contracts v4.4.1 (token/ERC20/IERC20.sol)

pragma solidity ^0.8.0;

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

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

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

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

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

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

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

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

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


// OpenZeppelin Contracts v4.4.1 (token/ERC20/utils/SafeERC20.sol)

pragma solidity ^0.8.0;



/**
 * @title SafeERC20
 * @dev Wrappers around ERC20 operations that throw on failure (when the token
 * contract returns false). Tokens that return no value (and instead revert or
 * throw on failure) are also supported, non-reverting calls are assumed to be
 * successful.
 * To use this library you can add a `using SafeERC20 for IERC20;` statement to your contract,
 * which allows you to call the safe operations as `token.safeTransfer(...)`, etc.
 */
library SafeERC20 {
    using Address for address;

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

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

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

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

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

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

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

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


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

pragma solidity ^0.8.0;

/**
 * @dev String operations.
 */
library Strings {
    bytes16 private constant _HEX_SYMBOLS = "0123456789abcdef";

    /**
     * @dev Converts a `uint256` to its ASCII `string` decimal representation.
     */
    function toString(uint256 value) internal pure returns (string memory) {
        // Inspired by OraclizeAPI's implementation - MIT licence
        // https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol

        if (value == 0) {
            return "0";
        }
        uint256 temp = value;
        uint256 digits;
        while (temp != 0) {
            digits++;
            temp /= 10;
        }
        bytes memory buffer = new bytes(digits);
        while (value != 0) {
            digits -= 1;
            buffer[digits] = bytes1(uint8(48 + uint256(value % 10)));
            value /= 10;
        }
        return string(buffer);
    }

    /**
     * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation.
     */
    function toHexString(uint256 value) internal pure returns (string memory) {
        if (value == 0) {
            return "0x00";
        }
        uint256 temp = value;
        uint256 length = 0;
        while (temp != 0) {
            length++;
            temp >>= 8;
        }
        return toHexString(value, length);
    }

    /**
     * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length.
     */
    function toHexString(uint256 value, uint256 length) internal pure returns (string memory) {
        bytes memory buffer = new bytes(2 * length + 2);
        buffer[0] = "0";
        buffer[1] = "x";
        for (uint256 i = 2 * length + 1; i > 1; --i) {
            buffer[i] = _HEX_SYMBOLS[value & 0xf];
            value >>= 4;
        }
        require(value == 0, "Strings: hex length insufficient");
        return string(buffer);
    }
}

// File: @openzeppelin/contracts/utils/cryptography/ECDSA.sol


// OpenZeppelin Contracts v4.4.1 (utils/cryptography/ECDSA.sol)

pragma solidity ^0.8.0;


/**
 * @dev Elliptic Curve Digital Signature Algorithm (ECDSA) operations.
 *
 * These functions can be used to verify that a message was signed by the holder
 * of the private keys of a given address.
 */
library ECDSA {
    enum RecoverError {
        NoError,
        InvalidSignature,
        InvalidSignatureLength,
        InvalidSignatureS,
        InvalidSignatureV
    }

    function _throwError(RecoverError error) private pure {
        if (error == RecoverError.NoError) {
            return; // no error: do nothing
        } else if (error == RecoverError.InvalidSignature) {
            revert("ECDSA: invalid signature");
        } else if (error == RecoverError.InvalidSignatureLength) {
            revert("ECDSA: invalid signature length");
        } else if (error == RecoverError.InvalidSignatureS) {
            revert("ECDSA: invalid signature 's' value");
        } else if (error == RecoverError.InvalidSignatureV) {
            revert("ECDSA: invalid signature 'v' value");
        }
    }

    /**
     * @dev Returns the address that signed a hashed message (`hash`) with
     * `signature` or error string. This address can then be used for verification purposes.
     *
     * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:
     * this function rejects them by requiring the `s` value to be in the lower
     * half order, and the `v` value to be either 27 or 28.
     *
     * IMPORTANT: `hash` _must_ be the result of a hash operation for the
     * verification to be secure: it is possible to craft signatures that
     * recover to arbitrary addresses for non-hashed data. A safe way to ensure
     * this is by receiving a hash of the original message (which may otherwise
     * be too long), and then calling {toEthSignedMessageHash} on it.
     *
     * Documentation for signature generation:
     * - with https://web3js.readthedocs.io/en/v1.3.4/web3-eth-accounts.html#sign[Web3.js]
     * - with https://docs.ethers.io/v5/api/signer/#Signer-signMessage[ethers]
     *
     * _Available since v4.3._
     */
    function tryRecover(bytes32 hash, bytes memory signature) internal pure returns (address, RecoverError) {
        // Check the signature length
        // - case 65: r,s,v signature (standard)
        // - case 64: r,vs signature (cf https://eips.ethereum.org/EIPS/eip-2098) _Available since v4.1._
        if (signature.length == 65) {
            bytes32 r;
            bytes32 s;
            uint8 v;
            // ecrecover takes the signature parameters, and the only way to get them
            // currently is to use assembly.
            assembly {
                r := mload(add(signature, 0x20))
                s := mload(add(signature, 0x40))
                v := byte(0, mload(add(signature, 0x60)))
            }
            return tryRecover(hash, v, r, s);
        } else if (signature.length == 64) {
            bytes32 r;
            bytes32 vs;
            // ecrecover takes the signature parameters, and the only way to get them
            // currently is to use assembly.
            assembly {
                r := mload(add(signature, 0x20))
                vs := mload(add(signature, 0x40))
            }
            return tryRecover(hash, r, vs);
        } else {
            return (address(0), RecoverError.InvalidSignatureLength);
        }
    }

    /**
     * @dev Returns the address that signed a hashed message (`hash`) with
     * `signature`. This address can then be used for verification purposes.
     *
     * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:
     * this function rejects them by requiring the `s` value to be in the lower
     * half order, and the `v` value to be either 27 or 28.
     *
     * IMPORTANT: `hash` _must_ be the result of a hash operation for the
     * verification to be secure: it is possible to craft signatures that
     * recover to arbitrary addresses for non-hashed data. A safe way to ensure
     * this is by receiving a hash of the original message (which may otherwise
     * be too long), and then calling {toEthSignedMessageHash} on it.
     */
    function recover(bytes32 hash, bytes memory signature) internal pure returns (address) {
        (address recovered, RecoverError error) = tryRecover(hash, signature);
        _throwError(error);
        return recovered;
    }

    /**
     * @dev Overload of {ECDSA-tryRecover} that receives the `r` and `vs` short-signature fields separately.
     *
     * See https://eips.ethereum.org/EIPS/eip-2098[EIP-2098 short signatures]
     *
     * _Available since v4.3._
     */
    function tryRecover(
        bytes32 hash,
        bytes32 r,
        bytes32 vs
    ) internal pure returns (address, RecoverError) {
        bytes32 s;
        uint8 v;
        assembly {
            s := and(vs, 0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff)
            v := add(shr(255, vs), 27)
        }
        return tryRecover(hash, v, r, s);
    }

    /**
     * @dev Overload of {ECDSA-recover} that receives the `r and `vs` short-signature fields separately.
     *
     * _Available since v4.2._
     */
    function recover(
        bytes32 hash,
        bytes32 r,
        bytes32 vs
    ) internal pure returns (address) {
        (address recovered, RecoverError error) = tryRecover(hash, r, vs);
        _throwError(error);
        return recovered;
    }

    /**
     * @dev Overload of {ECDSA-tryRecover} that receives the `v`,
     * `r` and `s` signature fields separately.
     *
     * _Available since v4.3._
     */
    function tryRecover(
        bytes32 hash,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) internal pure returns (address, RecoverError) {
        // EIP-2 still allows signature malleability for ecrecover(). Remove this possibility and make the signature
        // unique. Appendix F in the Ethereum Yellow paper (https://ethereum.github.io/yellowpaper/paper.pdf), defines
        // the valid range for s in (301): 0 < s < secp256k1n ÷ 2 + 1, and for v in (302): v ∈ {27, 28}. Most
        // signatures from current libraries generate a unique signature with an s-value in the lower half order.
        //
        // If your library generates malleable signatures, such as s-values in the upper range, calculate a new s-value
        // with 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141 - s1 and flip v from 27 to 28 or
        // vice versa. If your library also generates signatures with 0/1 for v instead 27/28, add 27 to v to accept
        // these malleable signatures as well.
        if (uint256(s) > 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0) {
            return (address(0), RecoverError.InvalidSignatureS);
        }
        if (v != 27 && v != 28) {
            return (address(0), RecoverError.InvalidSignatureV);
        }

        // If the signature is valid (and not malleable), return the signer address
        address signer = ecrecover(hash, v, r, s);
        if (signer == address(0)) {
            return (address(0), RecoverError.InvalidSignature);
        }

        return (signer, RecoverError.NoError);
    }

    /**
     * @dev Overload of {ECDSA-recover} that receives the `v`,
     * `r` and `s` signature fields separately.
     */
    function recover(
        bytes32 hash,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) internal pure returns (address) {
        (address recovered, RecoverError error) = tryRecover(hash, v, r, s);
        _throwError(error);
        return recovered;
    }

    /**
     * @dev Returns an Ethereum Signed Message, created from a `hash`. This
     * produces hash corresponding to the one signed with the
     * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]
     * JSON-RPC method as part of EIP-191.
     *
     * See {recover}.
     */
    function toEthSignedMessageHash(bytes32 hash) internal pure returns (bytes32) {
        // 32 is the length in bytes of hash,
        // enforced by the type signature above
        return keccak256(abi.encodePacked("\x19Ethereum Signed Message:\n32", hash));
    }

    /**
     * @dev Returns an Ethereum Signed Message, created from `s`. This
     * produces hash corresponding to the one signed with the
     * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]
     * JSON-RPC method as part of EIP-191.
     *
     * See {recover}.
     */
    function toEthSignedMessageHash(bytes memory s) internal pure returns (bytes32) {
        return keccak256(abi.encodePacked("\x19Ethereum Signed Message:\n", Strings.toString(s.length), s));
    }

    /**
     * @dev Returns an Ethereum Signed Typed Data, created from a
     * `domainSeparator` and a `structHash`. This produces hash corresponding
     * to the one signed with the
     * https://eips.ethereum.org/EIPS/eip-712[`eth_signTypedData`]
     * JSON-RPC method as part of EIP-712.
     *
     * See {recover}.
     */
    function toTypedDataHash(bytes32 domainSeparator, bytes32 structHash) internal pure returns (bytes32) {
        return keccak256(abi.encodePacked("\x19\x01", domainSeparator, structHash));
    }
}

// File: @openzeppelin/contracts/utils/cryptography/draft-EIP712.sol


// OpenZeppelin Contracts v4.4.1 (utils/cryptography/draft-EIP712.sol)

pragma solidity ^0.8.0;


/**
 * @dev https://eips.ethereum.org/EIPS/eip-712[EIP 712] is a standard for hashing and signing of typed structured data.
 *
 * The encoding specified in the EIP is very generic, and such a generic implementation in Solidity is not feasible,
 * thus this contract does not implement the encoding itself. Protocols need to implement the type-specific encoding
 * they need in their contracts using a combination of `abi.encode` and `keccak256`.
 *
 * This contract implements the EIP 712 domain separator ({_domainSeparatorV4}) that is used as part of the encoding
 * scheme, and the final step of the encoding to obtain the message digest that is then signed via ECDSA
 * ({_hashTypedDataV4}).
 *
 * The implementation of the domain separator was designed to be as efficient as possible while still properly updating
 * the chain id to protect against replay attacks on an eventual fork of the chain.
 *
 * NOTE: This contract implements the version of the encoding known as "v4", as implemented by the JSON RPC method
 * https://docs.metamask.io/guide/signing-data.html[`eth_signTypedDataV4` in MetaMask].
 *
 * _Available since v3.4._
 */
abstract contract EIP712 {
    /* solhint-disable var-name-mixedcase */
    // Cache the domain separator as an immutable value, but also store the chain id that it corresponds to, in order to
    // invalidate the cached domain separator if the chain id changes.
    bytes32 private immutable _CACHED_DOMAIN_SEPARATOR;
    uint256 private immutable _CACHED_CHAIN_ID;
    address private immutable _CACHED_THIS;

    bytes32 private immutable _HASHED_NAME;
    bytes32 private immutable _HASHED_VERSION;
    bytes32 private immutable _TYPE_HASH;

    /* solhint-enable var-name-mixedcase */

    /**
     * @dev Initializes the domain separator and parameter caches.
     *
     * The meaning of `name` and `version` is specified in
     * https://eips.ethereum.org/EIPS/eip-712#definition-of-domainseparator[EIP 712]:
     *
     * - `name`: the user readable name of the signing domain, i.e. the name of the DApp or the protocol.
     * - `version`: the current major version of the signing domain.
     *
     * NOTE: These parameters cannot be changed except through a xref:learn::upgrading-smart-contracts.adoc[smart
     * contract upgrade].
     */
    constructor(string memory name, string memory version) {
        bytes32 hashedName = keccak256(bytes(name));
        bytes32 hashedVersion = keccak256(bytes(version));
        bytes32 typeHash = keccak256(
            "EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)"
        );
        _HASHED_NAME = hashedName;
        _HASHED_VERSION = hashedVersion;
        _CACHED_CHAIN_ID = block.chainid;
        _CACHED_DOMAIN_SEPARATOR = _buildDomainSeparator(typeHash, hashedName, hashedVersion);
        _CACHED_THIS = address(this);
        _TYPE_HASH = typeHash;
    }

    /**
     * @dev Returns the domain separator for the current chain.
     */
    function _domainSeparatorV4() internal view returns (bytes32) {
        if (address(this) == _CACHED_THIS && block.chainid == _CACHED_CHAIN_ID) {
            return _CACHED_DOMAIN_SEPARATOR;
        } else {
            return _buildDomainSeparator(_TYPE_HASH, _HASHED_NAME, _HASHED_VERSION);
        }
    }

    function _buildDomainSeparator(
        bytes32 typeHash,
        bytes32 nameHash,
        bytes32 versionHash
    ) private view returns (bytes32) {
        return keccak256(abi.encode(typeHash, nameHash, versionHash, block.chainid, address(this)));
    }

    /**
     * @dev Given an already https://eips.ethereum.org/EIPS/eip-712#definition-of-hashstruct[hashed struct], this
     * function returns the hash of the fully encoded EIP712 message for this domain.
     *
     * This hash can be used together with {ECDSA-recover} to obtain the signer of a message. For example:
     *
     * ```solidity
     * bytes32 digest = _hashTypedDataV4(keccak256(abi.encode(
     *     keccak256("Mail(address to,string contents)"),
     *     mailTo,
     *     keccak256(bytes(mailContents))
     * )));
     * address signer = ECDSA.recover(digest, signature);
     * ```
     */
    function _hashTypedDataV4(bytes32 structHash) internal view virtual returns (bytes32) {
        return ECDSA.toTypedDataHash(_domainSeparatorV4(), structHash);
    }
}

// File: hardhat/console.sol


pragma solidity >= 0.4.22 <0.9.0;

library console {
	address constant CONSOLE_ADDRESS = address(0x000000000000000000636F6e736F6c652e6c6f67);

	function _sendLogPayload(bytes memory payload) private view {
		uint256 payloadLength = payload.length;
		address consoleAddress = CONSOLE_ADDRESS;
		assembly {
			let payloadStart := add(payload, 32)
			let r := staticcall(gas(), consoleAddress, payloadStart, payloadLength, 0, 0)
		}
	}

	function log() internal view {
		_sendLogPayload(abi.encodeWithSignature("log()"));
	}

	function logInt(int p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(int)", p0));
	}

	function logUint(uint p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint)", p0));
	}

	function logString(string memory p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string)", p0));
	}

	function logBool(bool p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool)", p0));
	}

	function logAddress(address p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address)", p0));
	}

	function logBytes(bytes memory p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes)", p0));
	}

	function logBytes1(bytes1 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes1)", p0));
	}

	function logBytes2(bytes2 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes2)", p0));
	}

	function logBytes3(bytes3 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes3)", p0));
	}

	function logBytes4(bytes4 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes4)", p0));
	}

	function logBytes5(bytes5 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes5)", p0));
	}

	function logBytes6(bytes6 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes6)", p0));
	}

	function logBytes7(bytes7 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes7)", p0));
	}

	function logBytes8(bytes8 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes8)", p0));
	}

	function logBytes9(bytes9 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes9)", p0));
	}

	function logBytes10(bytes10 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes10)", p0));
	}

	function logBytes11(bytes11 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes11)", p0));
	}

	function logBytes12(bytes12 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes12)", p0));
	}

	function logBytes13(bytes13 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes13)", p0));
	}

	function logBytes14(bytes14 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes14)", p0));
	}

	function logBytes15(bytes15 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes15)", p0));
	}

	function logBytes16(bytes16 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes16)", p0));
	}

	function logBytes17(bytes17 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes17)", p0));
	}

	function logBytes18(bytes18 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes18)", p0));
	}

	function logBytes19(bytes19 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes19)", p0));
	}

	function logBytes20(bytes20 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes20)", p0));
	}

	function logBytes21(bytes21 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes21)", p0));
	}

	function logBytes22(bytes22 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes22)", p0));
	}

	function logBytes23(bytes23 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes23)", p0));
	}

	function logBytes24(bytes24 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes24)", p0));
	}

	function logBytes25(bytes25 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes25)", p0));
	}

	function logBytes26(bytes26 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes26)", p0));
	}

	function logBytes27(bytes27 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes27)", p0));
	}

	function logBytes28(bytes28 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes28)", p0));
	}

	function logBytes29(bytes29 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes29)", p0));
	}

	function logBytes30(bytes30 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes30)", p0));
	}

	function logBytes31(bytes31 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes31)", p0));
	}

	function logBytes32(bytes32 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes32)", p0));
	}

	function log(uint p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint)", p0));
	}

	function log(string memory p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string)", p0));
	}

	function log(bool p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool)", p0));
	}

	function log(address p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address)", p0));
	}

	function log(uint p0, uint p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint)", p0, p1));
	}

	function log(uint p0, string memory p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string)", p0, p1));
	}

	function log(uint p0, bool p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool)", p0, p1));
	}

	function log(uint p0, address p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address)", p0, p1));
	}

	function log(string memory p0, uint p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint)", p0, p1));
	}

	function log(string memory p0, string memory p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string)", p0, p1));
	}

	function log(string memory p0, bool p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool)", p0, p1));
	}

	function log(string memory p0, address p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address)", p0, p1));
	}

	function log(bool p0, uint p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint)", p0, p1));
	}

	function log(bool p0, string memory p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string)", p0, p1));
	}

	function log(bool p0, bool p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool)", p0, p1));
	}

	function log(bool p0, address p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address)", p0, p1));
	}

	function log(address p0, uint p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint)", p0, p1));
	}

	function log(address p0, string memory p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string)", p0, p1));
	}

	function log(address p0, bool p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool)", p0, p1));
	}

	function log(address p0, address p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address)", p0, p1));
	}

	function log(uint p0, uint p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,uint)", p0, p1, p2));
	}

	function log(uint p0, uint p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,string)", p0, p1, p2));
	}

	function log(uint p0, uint p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,bool)", p0, p1, p2));
	}

	function log(uint p0, uint p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,address)", p0, p1, p2));
	}

	function log(uint p0, string memory p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,uint)", p0, p1, p2));
	}

	function log(uint p0, string memory p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,string)", p0, p1, p2));
	}

	function log(uint p0, string memory p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,bool)", p0, p1, p2));
	}

	function log(uint p0, string memory p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,address)", p0, p1, p2));
	}

	function log(uint p0, bool p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,uint)", p0, p1, p2));
	}

	function log(uint p0, bool p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,string)", p0, p1, p2));
	}

	function log(uint p0, bool p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,bool)", p0, p1, p2));
	}

	function log(uint p0, bool p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,address)", p0, p1, p2));
	}

	function log(uint p0, address p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,uint)", p0, p1, p2));
	}

	function log(uint p0, address p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,string)", p0, p1, p2));
	}

	function log(uint p0, address p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,bool)", p0, p1, p2));
	}

	function log(uint p0, address p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,address)", p0, p1, p2));
	}

	function log(string memory p0, uint p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,uint)", p0, p1, p2));
	}

	function log(string memory p0, uint p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,string)", p0, p1, p2));
	}

	function log(string memory p0, uint p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,bool)", p0, p1, p2));
	}

	function log(string memory p0, uint p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,address)", p0, p1, p2));
	}

	function log(string memory p0, string memory p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,uint)", p0, p1, p2));
	}

	function log(string memory p0, string memory p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,string)", p0, p1, p2));
	}

	function log(string memory p0, string memory p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,bool)", p0, p1, p2));
	}

	function log(string memory p0, string memory p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,address)", p0, p1, p2));
	}

	function log(string memory p0, bool p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,uint)", p0, p1, p2));
	}

	function log(string memory p0, bool p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,string)", p0, p1, p2));
	}

	function log(string memory p0, bool p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,bool)", p0, p1, p2));
	}

	function log(string memory p0, bool p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,address)", p0, p1, p2));
	}

	function log(string memory p0, address p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,uint)", p0, p1, p2));
	}

	function log(string memory p0, address p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,string)", p0, p1, p2));
	}

	function log(string memory p0, address p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,bool)", p0, p1, p2));
	}

	function log(string memory p0, address p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,address)", p0, p1, p2));
	}

	function log(bool p0, uint p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,uint)", p0, p1, p2));
	}

	function log(bool p0, uint p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,string)", p0, p1, p2));
	}

	function log(bool p0, uint p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,bool)", p0, p1, p2));
	}

	function log(bool p0, uint p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,address)", p0, p1, p2));
	}

	function log(bool p0, string memory p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,uint)", p0, p1, p2));
	}

	function log(bool p0, string memory p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,string)", p0, p1, p2));
	}

	function log(bool p0, string memory p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,bool)", p0, p1, p2));
	}

	function log(bool p0, string memory p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,address)", p0, p1, p2));
	}

	function log(bool p0, bool p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,uint)", p0, p1, p2));
	}

	function log(bool p0, bool p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,string)", p0, p1, p2));
	}

	function log(bool p0, bool p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,bool)", p0, p1, p2));
	}

	function log(bool p0, bool p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,address)", p0, p1, p2));
	}

	function log(bool p0, address p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,uint)", p0, p1, p2));
	}

	function log(bool p0, address p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,string)", p0, p1, p2));
	}

	function log(bool p0, address p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,bool)", p0, p1, p2));
	}

	function log(bool p0, address p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,address)", p0, p1, p2));
	}

	function log(address p0, uint p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,uint)", p0, p1, p2));
	}

	function log(address p0, uint p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,string)", p0, p1, p2));
	}

	function log(address p0, uint p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,bool)", p0, p1, p2));
	}

	function log(address p0, uint p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,address)", p0, p1, p2));
	}

	function log(address p0, string memory p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,uint)", p0, p1, p2));
	}

	function log(address p0, string memory p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,string)", p0, p1, p2));
	}

	function log(address p0, string memory p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,bool)", p0, p1, p2));
	}

	function log(address p0, string memory p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,address)", p0, p1, p2));
	}

	function log(address p0, bool p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,uint)", p0, p1, p2));
	}

	function log(address p0, bool p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,string)", p0, p1, p2));
	}

	function log(address p0, bool p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,bool)", p0, p1, p2));
	}

	function log(address p0, bool p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,address)", p0, p1, p2));
	}

	function log(address p0, address p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,uint)", p0, p1, p2));
	}

	function log(address p0, address p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,string)", p0, p1, p2));
	}

	function log(address p0, address p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,bool)", p0, p1, p2));
	}

	function log(address p0, address p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,address)", p0, p1, p2));
	}

	function log(uint p0, uint p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,uint,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,uint,string)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,uint,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,uint,address)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,string,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,string,string)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,string,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,string,address)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,bool,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,bool,string)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,bool,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,bool,address)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,address,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,address,string)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,address,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,address,address)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,uint,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,uint,string)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,uint,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,uint,address)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,string,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,string,string)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,string,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,string,address)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,bool,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,bool,string)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,bool,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,bool,address)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,address,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,address,string)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,address,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,address,address)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,uint,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,uint,string)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,uint,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,uint,address)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,string,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,string,string)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,string,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,string,address)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,bool,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,bool,string)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,bool,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,bool,address)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,address,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,address,string)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,address,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,address,address)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,uint,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,uint,string)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,uint,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,uint,address)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,string,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,string,string)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,string,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,string,address)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,bool,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,bool,string)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,bool,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,bool,address)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,address,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,address,string)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,address,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,address,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,uint,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,uint,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,uint,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,uint,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,string,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,string,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,string,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,string,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,bool,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,bool,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,bool,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,bool,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,address,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,address,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,address,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,address,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,uint,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,uint,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,uint,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,uint,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,string,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,string,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,string,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,string,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,bool,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,bool,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,bool,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,bool,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,address,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,address,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,address,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,address,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,uint,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,uint,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,uint,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,uint,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,string,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,string,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,string,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,string,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,bool,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,bool,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,bool,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,bool,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,address,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,address,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,address,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,address,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,uint,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,uint,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,uint,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,uint,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,string,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,string,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,string,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,string,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,bool,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,bool,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,bool,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,bool,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,address,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,address,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,address,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,address,address)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,uint,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,uint,string)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,uint,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,uint,address)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,string,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,string,string)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,string,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,string,address)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,bool,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,bool,string)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,bool,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,bool,address)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,address,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,address,string)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,address,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,address,address)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,uint,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,uint,string)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,uint,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,uint,address)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,string,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,string,string)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,string,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,string,address)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,bool,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,bool,string)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,bool,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,bool,address)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,address,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,address,string)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,address,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,address,address)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,uint,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,uint,string)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,uint,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,uint,address)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,string,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,string,string)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,string,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,string,address)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,bool,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,bool,string)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,bool,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,bool,address)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,address,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,address,string)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,address,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,address,address)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,uint,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,uint,string)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,uint,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,uint,address)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,string,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,string,string)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,string,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,string,address)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,bool,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,bool,string)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,bool,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,bool,address)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,address,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,address,string)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,address,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,address,address)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,uint,uint)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,uint,string)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,uint,bool)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,uint,address)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,string,uint)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,string,string)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,string,bool)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,string,address)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,bool,uint)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,bool,string)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,bool,bool)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,bool,address)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,address,uint)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,address,string)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,address,bool)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,address,address)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,uint,uint)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,uint,string)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,uint,bool)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,uint,address)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,string,uint)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,string,string)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,string,bool)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,string,address)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,bool,uint)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,bool,string)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,bool,bool)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,bool,address)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,address,uint)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,address,string)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,address,bool)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,address,address)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,uint,uint)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,uint,string)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,uint,bool)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,uint,address)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,string,uint)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,string,string)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,string,bool)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,string,address)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,bool,uint)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,bool,string)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,bool,bool)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,bool,address)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,address,uint)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,address,string)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,address,bool)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,address,address)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,uint,uint)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,uint,string)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,uint,bool)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,uint,address)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,string,uint)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,string,string)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,string,bool)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,string,address)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,bool,uint)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,bool,string)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,bool,bool)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,bool,address)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,address,uint)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,address,string)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,address,bool)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,address,address)", p0, p1, p2, p3));
	}

}

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


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

pragma solidity ^0.8.0;

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

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

// File: erc721a/contracts/ERC721A.sol


// Creator: Chiru Labs

pragma solidity ^0.8.4;









error ApprovalCallerNotOwnerNorApproved();
error ApprovalQueryForNonexistentToken();
error ApproveToCaller();
error ApprovalToCurrentOwner();
error BalanceQueryForZeroAddress();
error MintedQueryForZeroAddress();
error BurnedQueryForZeroAddress();
error MintToZeroAddress();
error MintZeroQuantity();
error OwnerIndexOutOfBounds();
error OwnerQueryForNonexistentToken();
error TokenIndexOutOfBounds();
error TransferCallerNotOwnerNorApproved();
error TransferFromIncorrectOwner();
error TransferToNonERC721ReceiverImplementer();
error TransferToZeroAddress();
error URIQueryForNonexistentToken();

/**
 * @dev Implementation of https://eips.ethereum.org/EIPS/eip-721[ERC721] Non-Fungible Token Standard, including
 * the Metadata and Enumerable extension. Built to optimize for lower gas during batch mints.
 *
 * Assumes serials are sequentially minted starting at 0 (e.g. 0, 1, 2, 3..).
 *
 * Assumes that an owner cannot have more than 2**64 - 1 (max value of uint64) of supply.
 *
 * Assumes that the maximum token id cannot exceed 2**128 - 1 (max value of uint128).
 */
contract ERC721A is Context, ERC165, IERC721, IERC721Metadata, IERC721Enumerable {
    using Address for address;
    using Strings for uint256;

    // Compiler will pack this into a single 256bit word.
    struct TokenOwnership {
        // The address of the owner.
        address addr;
        // Keeps track of the start time of ownership with minimal overhead for tokenomics.
        uint64 startTimestamp;
        // Whether the token has been burned.
        bool burned;
    }

    // Compiler will pack this into a single 256bit word.
    struct AddressData {
        // Realistically, 2**64-1 is more than enough.
        uint64 balance;
        // Keeps track of mint count with minimal overhead for tokenomics.
        uint64 numberMinted;
        // Keeps track of burn count with minimal overhead for tokenomics.
        uint64 numberBurned;
    }

    // Compiler will pack the following 
    // _currentIndex and _burnCounter into a single 256bit word.
    
    // The tokenId of the next token to be minted.
    uint128 internal _currentIndex;

    // The number of tokens burned.
    uint128 internal _burnCounter;

    // Token name
    string private _name;

    // Token symbol
    string private _symbol;

    // Mapping from token ID to ownership details
    // An empty struct value does not necessarily mean the token is unowned. See ownershipOf implementation for details.
    mapping(uint256 => TokenOwnership) internal _ownerships;

    // Mapping owner address to address data
    mapping(address => AddressData) private _addressData;

    // Mapping from token ID to approved address
    mapping(uint256 => address) private _tokenApprovals;

    // Mapping from owner to operator approvals
    mapping(address => mapping(address => bool)) private _operatorApprovals;

    constructor(string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
    }

    /**
     * @dev See {IERC721Enumerable-totalSupply}.
     */
    function totalSupply() public view override returns (uint256) {
        // Counter underflow is impossible as _burnCounter cannot be incremented
        // more than _currentIndex times
        unchecked {
            return _currentIndex - _burnCounter;    
        }
    }

    /**
     * @dev See {IERC721Enumerable-tokenByIndex}.
     * This read function is O(totalSupply). If calling from a separate contract, be sure to test gas first.
     * It may also degrade with extremely large collection sizes (e.g >> 10000), test for your use case.
     */
    function tokenByIndex(uint256 index) public view override returns (uint256) {
        uint256 numMintedSoFar = _currentIndex;
        uint256 tokenIdsIdx;

        // Counter overflow is impossible as the loop breaks when
        // uint256 i is equal to another uint256 numMintedSoFar.
        unchecked {
            for (uint256 i; i < numMintedSoFar; i++) {
                TokenOwnership memory ownership = _ownerships[i];
                if (!ownership.burned) {
                    if (tokenIdsIdx == index) {
                        return i;
                    }
                    tokenIdsIdx++;
                }
            }
        }
        revert TokenIndexOutOfBounds();
    }

    /**
     * @dev See {IERC721Enumerable-tokenOfOwnerByIndex}.
     * This read function is O(totalSupply). If calling from a separate contract, be sure to test gas first.
     * It may also degrade with extremely large collection sizes (e.g >> 10000), test for your use case.
     */
    function tokenOfOwnerByIndex(address owner, uint256 index) public view override returns (uint256) {
        if (index >= balanceOf(owner)) revert OwnerIndexOutOfBounds();
        uint256 numMintedSoFar = _currentIndex;
        uint256 tokenIdsIdx;
        address currOwnershipAddr;

        // Counter overflow is impossible as the loop breaks when
        // uint256 i is equal to another uint256 numMintedSoFar.
        unchecked {
            for (uint256 i; i < numMintedSoFar; i++) {
                TokenOwnership memory ownership = _ownerships[i];
                if (ownership.burned) {
                    continue;
                }
                if (ownership.addr != address(0)) {
                    currOwnershipAddr = ownership.addr;
                }
                if (currOwnershipAddr == owner) {
                    if (tokenIdsIdx == index) {
                        return i;
                    }
                    tokenIdsIdx++;
                }
            }
        }

        // Execution should never reach this point.
        revert();
    }

    /**
     * @dev See {IERC165-supportsInterface}.
     */
    function supportsInterface(bytes4 interfaceId) public view virtual override(ERC165, IERC165) returns (bool) {
        return
            interfaceId == type(IERC721).interfaceId ||
            interfaceId == type(IERC721Metadata).interfaceId ||
            interfaceId == type(IERC721Enumerable).interfaceId ||
            super.supportsInterface(interfaceId);
    }

    /**
     * @dev See {IERC721-balanceOf}.
     */
    function balanceOf(address owner) public view override returns (uint256) {
        if (owner == address(0)) revert BalanceQueryForZeroAddress();
        return uint256(_addressData[owner].balance);
    }

    function _numberMinted(address owner) internal view returns (uint256) {
        if (owner == address(0)) revert MintedQueryForZeroAddress();
        return uint256(_addressData[owner].numberMinted);
    }

    function _numberBurned(address owner) internal view returns (uint256) {
        if (owner == address(0)) revert BurnedQueryForZeroAddress();
        return uint256(_addressData[owner].numberBurned);
    }

    /**
     * Gas spent here starts off proportional to the maximum mint batch size.
     * It gradually moves to O(1) as tokens get transferred around in the collection over time.
     */
    function ownershipOf(uint256 tokenId) internal view returns (TokenOwnership memory) {
        uint256 curr = tokenId;

        unchecked {
            if (curr < _currentIndex) {
                TokenOwnership memory ownership = _ownerships[curr];
                if (!ownership.burned) {
                    if (ownership.addr != address(0)) {
                        return ownership;
                    }
                    // Invariant: 
                    // There will always be an ownership that has an address and is not burned 
                    // before an ownership that does not have an address and is not burned.
                    // Hence, curr will not underflow.
                    while (true) {
                        curr--;
                        ownership = _ownerships[curr];
                        if (ownership.addr != address(0)) {
                            return ownership;
                        }
                    }
                }
            }
        }
        revert OwnerQueryForNonexistentToken();
    }

    /**
     * @dev See {IERC721-ownerOf}.
     */
    function ownerOf(uint256 tokenId) public view override returns (address) {
        return ownershipOf(tokenId).addr;
    }

    /**
     * @dev See {IERC721Metadata-name}.
     */
    function name() public view virtual override returns (string memory) {
        return _name;
    }

    /**
     * @dev See {IERC721Metadata-symbol}.
     */
    function symbol() public view virtual override returns (string memory) {
        return _symbol;
    }

    /**
     * @dev See {IERC721Metadata-tokenURI}.
     */
    function tokenURI(uint256 tokenId) public view virtual override returns (string memory) {
        if (!_exists(tokenId)) revert URIQueryForNonexistentToken();

        string memory baseURI = _baseURI();
        return bytes(baseURI).length != 0 ? string(abi.encodePacked(baseURI, tokenId.toString())) : '';
    }

    /**
     * @dev Base URI for computing {tokenURI}. If set, the resulting URI for each
     * token will be the concatenation of the `baseURI` and the `tokenId`. Empty
     * by default, can be overriden in child contracts.
     */
    function _baseURI() internal view virtual returns (string memory) {
        return '';
    }

    /**
     * @dev See {IERC721-approve}.
     */
    function approve(address to, uint256 tokenId) public override {
        address owner = ERC721A.ownerOf(tokenId);
        if (to == owner) revert ApprovalToCurrentOwner();

        if (_msgSender() != owner && !isApprovedForAll(owner, _msgSender())) {
            revert ApprovalCallerNotOwnerNorApproved();
        }

        _approve(to, tokenId, owner);
    }

    /**
     * @dev See {IERC721-getApproved}.
     */
    function getApproved(uint256 tokenId) public view override returns (address) {
        if (!_exists(tokenId)) revert ApprovalQueryForNonexistentToken();

        return _tokenApprovals[tokenId];
    }

    /**
     * @dev See {IERC721-setApprovalForAll}.
     */
    function setApprovalForAll(address operator, bool approved) public override {
        if (operator == _msgSender()) revert ApproveToCaller();

        _operatorApprovals[_msgSender()][operator] = approved;
        emit ApprovalForAll(_msgSender(), operator, approved);
    }

    /**
     * @dev See {IERC721-isApprovedForAll}.
     */
    function isApprovedForAll(address owner, address operator) public view virtual override returns (bool) {
        return _operatorApprovals[owner][operator];
    }

    /**
     * @dev See {IERC721-transferFrom}.
     */
    function transferFrom(
        address from,
        address to,
        uint256 tokenId
    ) public virtual override {
        _transfer(from, to, tokenId);
    }

    /**
     * @dev See {IERC721-safeTransferFrom}.
     */
    function safeTransferFrom(
        address from,
        address to,
        uint256 tokenId
    ) public virtual override {
        safeTransferFrom(from, to, tokenId, '');
    }

    /**
     * @dev See {IERC721-safeTransferFrom}.
     */
    function safeTransferFrom(
        address from,
        address to,
        uint256 tokenId,
        bytes memory _data
    ) public virtual override {
        _transfer(from, to, tokenId);
        if (!_checkOnERC721Received(from, to, tokenId, _data)) {
            revert TransferToNonERC721ReceiverImplementer();
        }
    }

    /**
     * @dev Returns whether `tokenId` exists.
     *
     * Tokens can be managed by their owner or approved accounts via {approve} or {setApprovalForAll}.
     *
     * Tokens start existing when they are minted (`_mint`),
     */
    function _exists(uint256 tokenId) internal view returns (bool) {
        return tokenId < _currentIndex && !_ownerships[tokenId].burned;
    }

    function _safeMint(address to, uint256 quantity) internal {
        _safeMint(to, quantity, '');
    }

    /**
     * @dev Safely mints `quantity` tokens and transfers them to `to`.
     *
     * Requirements:
     *
     * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called for each safe transfer.
     * - `quantity` must be greater than 0.
     *
     * Emits a {Transfer} event.
     */
    function _safeMint(
        address to,
        uint256 quantity,
        bytes memory _data
    ) internal {
        _mint(to, quantity, _data, true);
    }

    /**
     * @dev Mints `quantity` tokens and transfers them to `to`.
     *
     * Requirements:
     *
     * - `to` cannot be the zero address.
     * - `quantity` must be greater than 0.
     *
     * Emits a {Transfer} event.
     */
    function _mint(
        address to,
        uint256 quantity,
        bytes memory _data,
        bool safe
    ) internal {
        uint256 startTokenId = _currentIndex;
        if (to == address(0)) revert MintToZeroAddress();
        if (quantity == 0) revert MintZeroQuantity();

        _beforeTokenTransfers(address(0), to, startTokenId, quantity);

        // Overflows are incredibly unrealistic.
        // balance or numberMinted overflow if current value of either + quantity > 3.4e38 (2**128) - 1
        // updatedIndex overflows if _currentIndex + quantity > 3.4e38 (2**128) - 1
        unchecked {
            _addressData[to].balance += uint64(quantity);
            _addressData[to].numberMinted += uint64(quantity);

            _ownerships[startTokenId].addr = to;
            _ownerships[startTokenId].startTimestamp = uint64(block.timestamp);

            uint256 updatedIndex = startTokenId;

            for (uint256 i; i < quantity; i++) {
                emit Transfer(address(0), to, updatedIndex);
                if (safe && !_checkOnERC721Received(address(0), to, updatedIndex, _data)) {
                    revert TransferToNonERC721ReceiverImplementer();
                }
                updatedIndex++;
            }

            _currentIndex = uint128(updatedIndex);
        }
        _afterTokenTransfers(address(0), to, startTokenId, quantity);
    }

    /**
     * @dev Transfers `tokenId` from `from` to `to`.
     *
     * Requirements:
     *
     * - `to` cannot be the zero address.
     * - `tokenId` token must be owned by `from`.
     *
     * Emits a {Transfer} event.
     */
    function _transfer(
        address from,
        address to,
        uint256 tokenId
    ) private {
        TokenOwnership memory prevOwnership = ownershipOf(tokenId);

        bool isApprovedOrOwner = (_msgSender() == prevOwnership.addr ||
            isApprovedForAll(prevOwnership.addr, _msgSender()) ||
            getApproved(tokenId) == _msgSender());

        if (!isApprovedOrOwner) revert TransferCallerNotOwnerNorApproved();
        if (prevOwnership.addr != from) revert TransferFromIncorrectOwner();
        if (to == address(0)) revert TransferToZeroAddress();

        _beforeTokenTransfers(from, to, tokenId, 1);

        // Clear approvals from the previous owner
        _approve(address(0), tokenId, prevOwnership.addr);

        // Underflow of the sender's balance is impossible because we check for
        // ownership above and the recipient's balance can't realistically overflow.
        // Counter overflow is incredibly unrealistic as tokenId would have to be 2**128.
        unchecked {
            _addressData[from].balance -= 1;
            _addressData[to].balance += 1;

            _ownerships[tokenId].addr = to;
            _ownerships[tokenId].startTimestamp = uint64(block.timestamp);

            // If the ownership slot of tokenId+1 is not explicitly set, that means the transfer initiator owns it.
            // Set the slot of tokenId+1 explicitly in storage to maintain correctness for ownerOf(tokenId+1) calls.
            uint256 nextTokenId = tokenId + 1;
            if (_ownerships[nextTokenId].addr == address(0)) {
                // This will suffice for checking _exists(nextTokenId),
                // as a burned slot cannot contain the zero address.
                if (nextTokenId < _currentIndex) {
                    _ownerships[nextTokenId].addr = prevOwnership.addr;
                    _ownerships[nextTokenId].startTimestamp = prevOwnership.startTimestamp;
                }
            }
        }

        emit Transfer(from, to, tokenId);
        _afterTokenTransfers(from, to, tokenId, 1);
    }

    /**
     * @dev Destroys `tokenId`.
     * The approval is cleared when the token is burned.
     *
     * Requirements:
     *
     * - `tokenId` must exist.
     *
     * Emits a {Transfer} event.
     */
    function _burn(uint256 tokenId) internal virtual {
        TokenOwnership memory prevOwnership = ownershipOf(tokenId);

        _beforeTokenTransfers(prevOwnership.addr, address(0), tokenId, 1);

        // Clear approvals from the previous owner
        _approve(address(0), tokenId, prevOwnership.addr);

        // Underflow of the sender's balance is impossible because we check for
        // ownership above and the recipient's balance can't realistically overflow.
        // Counter overflow is incredibly unrealistic as tokenId would have to be 2**128.
        unchecked {
            _addressData[prevOwnership.addr].balance -= 1;
            _addressData[prevOwnership.addr].numberBurned += 1;

            // Keep track of who burned the token, and the timestamp of burning.
            _ownerships[tokenId].addr = prevOwnership.addr;
            _ownerships[tokenId].startTimestamp = uint64(block.timestamp);
            _ownerships[tokenId].burned = true;

            // If the ownership slot of tokenId+1 is not explicitly set, that means the burn initiator owns it.
            // Set the slot of tokenId+1 explicitly in storage to maintain correctness for ownerOf(tokenId+1) calls.
            uint256 nextTokenId = tokenId + 1;
            if (_ownerships[nextTokenId].addr == address(0)) {
                // This will suffice for checking _exists(nextTokenId),
                // as a burned slot cannot contain the zero address.
                if (nextTokenId < _currentIndex) {
                    _ownerships[nextTokenId].addr = prevOwnership.addr;
                    _ownerships[nextTokenId].startTimestamp = prevOwnership.startTimestamp;
                }
            }
        }

        emit Transfer(prevOwnership.addr, address(0), tokenId);
        _afterTokenTransfers(prevOwnership.addr, address(0), tokenId, 1);

        // Overflow not possible, as _burnCounter cannot be exceed _currentIndex times.
        unchecked { 
            _burnCounter++;
        }
    }

    /**
     * @dev Approve `to` to operate on `tokenId`
     *
     * Emits a {Approval} event.
     */
    function _approve(
        address to,
        uint256 tokenId,
        address owner
    ) private {
        _tokenApprovals[tokenId] = to;
        emit Approval(owner, to, tokenId);
    }

    /**
     * @dev Internal function to invoke {IERC721Receiver-onERC721Received} on a target address.
     * The call is not executed if the target address is not a contract.
     *
     * @param from address representing the previous owner of the given token ID
     * @param to target address that will receive the tokens
     * @param tokenId uint256 ID of the token to be transferred
     * @param _data bytes optional data to send along with the call
     * @return bool whether the call correctly returned the expected magic value
     */
    function _checkOnERC721Received(
        address from,
        address to,
        uint256 tokenId,
        bytes memory _data
    ) private returns (bool) {
        if (to.isContract()) {
            try IERC721Receiver(to).onERC721Received(_msgSender(), from, tokenId, _data) returns (bytes4 retval) {
                return retval == IERC721Receiver(to).onERC721Received.selector;
            } catch (bytes memory reason) {
                if (reason.length == 0) {
                    revert TransferToNonERC721ReceiverImplementer();
                } else {
                    assembly {
                        revert(add(32, reason), mload(reason))
                    }
                }
            }
        } else {
            return true;
        }
    }

    /**
     * @dev Hook that is called before a set of serially-ordered token ids are about to be transferred. This includes minting.
     * And also called before burning one token.
     *
     * startTokenId - the first token id to be transferred
     * quantity - the amount to be transferred
     *
     * Calling conditions:
     *
     * - When `from` and `to` are both non-zero, `from`'s `tokenId` will be
     * transferred to `to`.
     * - When `from` is zero, `tokenId` will be minted for `to`.
     * - When `to` is zero, `tokenId` will be burned by `from`.
     * - `from` and `to` are never both zero.
     */
    function _beforeTokenTransfers(
        address from,
        address to,
        uint256 startTokenId,
        uint256 quantity
    ) internal virtual {}

    /**
     * @dev Hook that is called after a set of serially-ordered token ids have been transferred. This includes
     * minting.
     * And also called after one token has been burned.
     *
     * startTokenId - the first token id to be transferred
     * quantity - the amount to be transferred
     *
     * Calling conditions:
     *
     * - When `from` and `to` are both non-zero, `from`'s `tokenId` has been
     * transferred to `to`.
     * - When `from` is zero, `tokenId` has been minted for `to`.
     * - When `to` is zero, `tokenId` has been burned by `from`.
     * - `from` and `to` are never both zero.
     */
    function _afterTokenTransfers(
        address from,
        address to,
        uint256 startTokenId,
        uint256 quantity
    ) internal virtual {}
}

// File: @openzeppelin/contracts/finance/PaymentSplitter.sol


// OpenZeppelin Contracts v4.4.1 (finance/PaymentSplitter.sol)

pragma solidity ^0.8.0;




/**
 * @title PaymentSplitter
 * @dev This contract allows to split Ether payments among a group of accounts. The sender does not need to be aware
 * that the Ether will be split in this way, since it is handled transparently by the contract.
 *
 * The split can be in equal parts or in any other arbitrary proportion. The way this is specified is by assigning each
 * account to a number of shares. Of all the Ether that this contract receives, each account will then be able to claim
 * an amount proportional to the percentage of total shares they were assigned.
 *
 * `PaymentSplitter` follows a _pull payment_ model. This means that payments are not automatically forwarded to the
 * accounts but kept in this contract, and the actual transfer is triggered as a separate step by calling the {release}
 * function.
 *
 * NOTE: This contract assumes that ERC20 tokens will behave similarly to native tokens (Ether). Rebasing tokens, and
 * tokens that apply fees during transfers, are likely to not be supported as expected. If in doubt, we encourage you
 * to run tests before sending real value to this contract.
 */
contract PaymentSplitter is Context {
    event PayeeAdded(address account, uint256 shares);
    event PaymentReleased(address to, uint256 amount);
    event ERC20PaymentReleased(IERC20 indexed token, address to, uint256 amount);
    event PaymentReceived(address from, uint256 amount);

    uint256 private _totalShares;
    uint256 private _totalReleased;

    mapping(address => uint256) private _shares;
    mapping(address => uint256) private _released;
    address[] private _payees;

    mapping(IERC20 => uint256) private _erc20TotalReleased;
    mapping(IERC20 => mapping(address => uint256)) private _erc20Released;

    /**
     * @dev Creates an instance of `PaymentSplitter` where each account in `payees` is assigned the number of shares at
     * the matching position in the `shares` array.
     *
     * All addresses in `payees` must be non-zero. Both arrays must have the same non-zero length, and there must be no
     * duplicates in `payees`.
     */
    constructor(address[] memory payees, uint256[] memory shares_) payable {
        require(payees.length == shares_.length, "PaymentSplitter: payees and shares length mismatch");
        require(payees.length > 0, "PaymentSplitter: no payees");

        for (uint256 i = 0; i < payees.length; i++) {
            _addPayee(payees[i], shares_[i]);
        }
    }

    /**
     * @dev The Ether received will be logged with {PaymentReceived} events. Note that these events are not fully
     * reliable: it's possible for a contract to receive Ether without triggering this function. This only affects the
     * reliability of the events, and not the actual splitting of Ether.
     *
     * To learn more about this see the Solidity documentation for
     * https://solidity.readthedocs.io/en/latest/contracts.html#fallback-function[fallback
     * functions].
     */
    receive() external payable virtual {
        emit PaymentReceived(_msgSender(), msg.value);
    }

    /**
     * @dev Getter for the total shares held by payees.
     */
    function totalShares() public view returns (uint256) {
        return _totalShares;
    }

    /**
     * @dev Getter for the total amount of Ether already released.
     */
    function totalReleased() public view returns (uint256) {
        return _totalReleased;
    }

    /**
     * @dev Getter for the total amount of `token` already released. `token` should be the address of an IERC20
     * contract.
     */
    function totalReleased(IERC20 token) public view returns (uint256) {
        return _erc20TotalReleased[token];
    }

    /**
     * @dev Getter for the amount of shares held by an account.
     */
    function shares(address account) public view returns (uint256) {
        return _shares[account];
    }

    /**
     * @dev Getter for the amount of Ether already released to a payee.
     */
    function released(address account) public view returns (uint256) {
        return _released[account];
    }

    /**
     * @dev Getter for the amount of `token` tokens already released to a payee. `token` should be the address of an
     * IERC20 contract.
     */
    function released(IERC20 token, address account) public view returns (uint256) {
        return _erc20Released[token][account];
    }

    /**
     * @dev Getter for the address of the payee number `index`.
     */
    function payee(uint256 index) public view returns (address) {
        return _payees[index];
    }

    /**
     * @dev Triggers a transfer to `account` of the amount of Ether they are owed, according to their percentage of the
     * total shares and their previous withdrawals.
     */
    function release(address payable account) public virtual {
        require(_shares[account] > 0, "PaymentSplitter: account has no shares");

        uint256 totalReceived = address(this).balance + totalReleased();
        uint256 payment = _pendingPayment(account, totalReceived, released(account));

        require(payment != 0, "PaymentSplitter: account is not due payment");

        _released[account] += payment;
        _totalReleased += payment;

        Address.sendValue(account, payment);
        emit PaymentReleased(account, payment);
    }

    /**
     * @dev Triggers a transfer to `account` of the amount of `token` tokens they are owed, according to their
     * percentage of the total shares and their previous withdrawals. `token` must be the address of an IERC20
     * contract.
     */
    function release(IERC20 token, address account) public virtual {
        require(_shares[account] > 0, "PaymentSplitter: account has no shares");

        uint256 totalReceived = token.balanceOf(address(this)) + totalReleased(token);
        uint256 payment = _pendingPayment(account, totalReceived, released(token, account));

        require(payment != 0, "PaymentSplitter: account is not due payment");

        _erc20Released[token][account] += payment;
        _erc20TotalReleased[token] += payment;

        SafeERC20.safeTransfer(token, account, payment);
        emit ERC20PaymentReleased(token, account, payment);
    }

    /**
     * @dev internal logic for computing the pending payment of an `account` given the token historical balances and
     * already released amounts.
     */
    function _pendingPayment(
        address account,
        uint256 totalReceived,
        uint256 alreadyReleased
    ) private view returns (uint256) {
        return (totalReceived * _shares[account]) / _totalShares - alreadyReleased;
    }

    /**
     * @dev Add a new payee to the contract.
     * @param account The address of the payee to add.
     * @param shares_ The number of shares owned by the payee.
     */
    function _addPayee(address account, uint256 shares_) private {
        require(account != address(0), "PaymentSplitter: account is the zero address");
        require(shares_ > 0, "PaymentSplitter: shares are 0");
        require(_shares[account] == 0, "PaymentSplitter: account already has shares");

        _payees.push(account);
        _shares[account] = shares_;
        _totalShares = _totalShares + shares_;
        emit PayeeAdded(account, shares_);
    }
}

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


// OpenZeppelin Contracts v4.4.1 (access/Ownable.sol)

pragma solidity ^0.8.0;


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

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

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

    /**
     * @dev Returns the address of the current owner.
     */
    function owner() public view virtual 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 {
        _transferOwnership(address(0));
    }

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

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

// File: contracts/WhiteList.sol

pragma solidity ^0.8.0;





contract WhiteList is Ownable, EIP712 {

    bytes32 constant public MINT_CALL_HASH_TYPE = keccak256("mint(address receiver)");

    address public whitelistSigner;

    constructor() EIP712("TsukiWhiteList", "1") {}

    function setWhitelistSigner(address _address) external onlyOwner {
        whitelistSigner = _address;
    }

    function recoverSigner(address sender, bytes memory signature) public view returns (address) {
        return ECDSA.recover(getDigest(sender), signature);
    }

    function getDigest(address sender) public view returns (bytes32) {
       bytes32 messageDigest = keccak256(abi.encodePacked("\x19Ethereum Signed Message:\n32",
           ECDSA.toTypedDataHash(_domainSeparatorV4(),
               keccak256(abi.encode(MINT_CALL_HASH_TYPE, sender))
       )));
       return messageDigest;
   }

    modifier isUserWhileList(address sender, bytes memory signature) {
        require(recoverSigner(sender, signature) == whitelistSigner
            ,
            "User is not on whitelist"
        );
        _;
    }

    function getDomainSeparatorV4()  external view onlyOwner  returns (bytes32) {
        return _domainSeparatorV4();
    }
}
// File: contracts/PreSales.sol

pragma solidity ^0.8.0;


contract PreSales is Ownable {
    uint256 public preSalesStartTime;
    uint256 public preSalesEndTime;

    modifier isPreSalesActive() {
        require(
            isPreSalesActivated(),
            "PreSalesActivation: Sale is not activated"
        );
        _;
    }

    constructor() {
        //20 Feb 2022 09:00:00 EST == 20 Feb 2022 11:00:00 GMT at this site https://www.epochconverter.com/
        preSalesStartTime = 1645365600;
        //20 Feb 2022 20:59:59 EST == 20 Feb 2022 22:59:59 GMT at this site https://www.epochconverter.com/
        preSalesEndTime = 1645408799;
    }

    function isPreSalesActivated() public view returns (bool) {
        return
            preSalesStartTime > 0 &&
            preSalesEndTime > 0 &&
            block.timestamp >= preSalesStartTime &&
            block.timestamp <= preSalesEndTime;
    }

    // 1645365600: start time at 20 Feb 2022 09:00:00 EST in seconds
    // 1645408799: end time at 20 Feb 2022 20:59:59 EST in seconds
    function setPreSalesTime(uint256 _startTime, uint256 _endTime)
        external
        onlyOwner
    {
        require(
            _endTime >= _startTime,
            "PreSalesActivation: End time should be later than start time"
        );
        preSalesStartTime = _startTime;
        preSalesEndTime = _endTime;
    }
}
// File: contracts/PublicSales.sol

pragma solidity ^0.8.0;


contract PublicSales is Ownable {
    uint256 public publicSalesStartTime;

    modifier isPublicSalesActive() {
        require(
            isPublicSalesActivated(),
            "PublicSalesActivation: Sale is not activated"
        );
        _;
    }

    constructor() {
        //20 Feb 2022 23:00:00 GMT == 20 Feb 2022 21:00:00 GMT at this site https://www.epochconverter.com/
        publicSalesStartTime = 1645408800;
    }

    function isPublicSalesActivated() public view returns (bool) {
        return
            publicSalesStartTime > 0 && block.timestamp >= publicSalesStartTime;
    }

    // 1644069600: start time at 05 Feb 2022 (2 PM UTC+0) in seconds
    function setPublicSalesTime(uint256 _startTime) external onlyOwner {
        publicSalesStartTime = _startTime;
    }
}
// File: contracts/Tsuki.sol

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








contract Tsuki is Ownable, PublicSales, PreSales, WhiteList, ERC721A, PaymentSplitter{

//FOR PRODUCTION
    uint256 public constant TOTAL_MAX_QTY = 10000;
    uint256 public constant GIFT_MAX_QTY = 50;
    uint256 public constant SALES_MAX_QTY = TOTAL_MAX_QTY - GIFT_MAX_QTY;
    uint256 public constant PRESALES_MAX_QTY = 9000;
    uint256 public constant PRE_SALES_PRICE = 0.1 ether;
    uint256 public constant PUBLIC_SALES_PRICE = 0.15 ether;
    uint256 public constant MAX_QTY_PER_MINTER = 4;
    uint256 public constant MAX_QTY_PER_MINT = 2;
    uint256 public constant MAX_QTY_PER_MINTER_PRE_SALES = 2;

    address[] private addressList = [
	0x30be53552A0d71c8AF783F453a92876E0A516a3a, //V1
	0x6Fbf82ccaedD96A943A1BFFda209b9A48F796027, //V2
	0x812B50c025f0d950Df1E9B4F59C79BB00b08401c, //ASU
    0x9AAB019c4C67e5501C0c84BBDBd2540972392145,  //ARU
    0xab73bE9C25F6963B6E5aD6574D0C2eeccb27288E //community          
	];

	uint256[] private shareList = [2375, 2375, 2375, 2375, 500];

    uint256 public preSalesMintedQty = 0;
    uint256 public publicSalesMintedQty = 0;
    uint256 public giftedQty = 0;

    mapping(address => uint256) public preSalesMinterToTokenQty;
    mapping(address => uint256) public publicSalesMinterToTokenQty;

    bool public canRenounceOwnership = false;
    bool public paused = false;
    bool public revealed = false;

    string private baseTokenURI;
    string private notRevealedUri;

    constructor(string memory _notRevealedUri) ERC721A("Tsuki", "TSUKI") PaymentSplitter( addressList, shareList) {
        notRevealedUri = _notRevealedUri;
    }

    function getPrice() public view returns (uint256) {
        if (isPublicSalesActivated()) {
            return PUBLIC_SALES_PRICE;
        }
        return PRE_SALES_PRICE;
    }

    function preSalesMint(
        uint256 _mintQty,
        bytes memory signature
    )
        external
        payable
        isPreSalesActive
        isUserWhileList(msg.sender, signature )
    {
        require(
            preSalesMintedQty + publicSalesMintedQty + _mintQty <=
                TOTAL_MAX_QTY,
            "Exceed sales max limit"
        );

        require(
            preSalesMintedQty + _mintQty <= PRESALES_MAX_QTY,
            "Exceed pre-sales max limit"
        );

        require(
            preSalesMinterToTokenQty[msg.sender] + _mintQty <= MAX_QTY_PER_MINTER_PRE_SALES,
            "Exceed signed quantity"
        );

        require(tx.origin == msg.sender,"CONTRACTS_NOT_ALLOWED_TO_MINT");

        require(!paused, "The contract is paused!");
        
        require(msg.value >= _mintQty * getPrice(), "Incorrect ETH");

        preSalesMinterToTokenQty[msg.sender] += _mintQty;
        preSalesMintedQty += _mintQty;

        _safeMint(msg.sender, _mintQty);
    }

    function publicSalesMint(uint256 _mintQty)
        external
        payable
        isPublicSalesActive
    {     
         require(
            preSalesMintedQty + publicSalesMintedQty + _mintQty <=
                SALES_MAX_QTY,
            "Exceed sales max limit"
        );
        require(_mintQty <= MAX_QTY_PER_MINT, 
        "Exceed max mint per mint.");

        require(
            publicSalesMinterToTokenQty[msg.sender] + _mintQty <=
                MAX_QTY_PER_MINTER,
            "Exceed max mint per minter"
        );

        require(tx.origin == msg.sender,"CONTRACTS_NOT_ALLOWED_TO_MINT");

        require(!paused, "The contract is paused!");
        
        require(msg.value >= _mintQty * getPrice(), "Incorrect ETH");

        publicSalesMinterToTokenQty[msg.sender] += _mintQty;
        publicSalesMintedQty += _mintQty;

        _safeMint(msg.sender, _mintQty);
    }

    function gift(address[] calldata receivers) external onlyOwner {
        require(
            giftedQty + receivers.length <= GIFT_MAX_QTY,
            "Exceed gift max limit"
        );

        giftedQty += receivers.length;

        for (uint256 i = 0; i < receivers.length; i++) {
            _safeMint(receivers[i], 1);
        }
    }

    function setNotRevealedURI(string memory _notRevealedURI) external onlyOwner {
        notRevealedUri = _notRevealedURI;
    }

    function setBaseTokenURI(string memory _baseTokenURI) external onlyOwner {
        baseTokenURI = _baseTokenURI;
    } 

    function _baseURI() internal view override virtual returns (string memory) {
	    return baseTokenURI;
	}
   
    function setRevealed(bool _state) external  onlyOwner {
        revealed = _state;
    } 

    function setPaused(bool _state) external  onlyOwner {
        paused = _state;
    }

    function setCanRenounceOwnership(bool _state) external  onlyOwner {
        canRenounceOwnership = _state;
    }    

    function tokenURI(uint256 tokenId)
        public
        view
        virtual
        override
        returns (string memory)
    {
        require(
        _exists(tokenId),
        "ERC721Metadata: URI query for nonexistent token"
        );
        
        if(!revealed) {
            return notRevealedUri;
        }

        string memory currentBaseURI = _baseURI();

        return bytes(currentBaseURI).length > 0
            ? string(abi.encodePacked(currentBaseURI, Strings.toString(tokenId)))
            : "";
    }

    function renounceOwnership() override public onlyOwner{
        require(canRenounceOwnership,"Not the time to Renounce Ownership");
        _transferOwnership(address(0));
    }

    function withdraw() public payable onlyOwner {
        (bool success, ) = payable(msg.sender).call{value: address(this).balance}("");
        require(success);
	}

	function withdrawSplit() public onlyOwner {
        for (uint256 i = 0; i < addressList.length; i++) {
            address payable wallet = payable(addressList[i]);
            release(wallet);
        }
    }

}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"string","name":"_notRevealedUri","type":"string"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[],"name":"ApprovalCallerNotOwnerNorApproved","type":"error"},{"inputs":[],"name":"ApprovalQueryForNonexistentToken","type":"error"},{"inputs":[],"name":"ApprovalToCurrentOwner","type":"error"},{"inputs":[],"name":"ApproveToCaller","type":"error"},{"inputs":[],"name":"BalanceQueryForZeroAddress","type":"error"},{"inputs":[],"name":"MintToZeroAddress","type":"error"},{"inputs":[],"name":"MintZeroQuantity","type":"error"},{"inputs":[],"name":"OwnerIndexOutOfBounds","type":"error"},{"inputs":[],"name":"OwnerQueryForNonexistentToken","type":"error"},{"inputs":[],"name":"TokenIndexOutOfBounds","type":"error"},{"inputs":[],"name":"TransferCallerNotOwnerNorApproved","type":"error"},{"inputs":[],"name":"TransferFromIncorrectOwner","type":"error"},{"inputs":[],"name":"TransferToNonERC721ReceiverImplementer","type":"error"},{"inputs":[],"name":"TransferToZeroAddress","type":"error"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"approved","type":"address"},{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"operator","type":"address"},{"indexed":false,"internalType":"bool","name":"approved","type":"bool"}],"name":"ApprovalForAll","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"contract IERC20","name":"token","type":"address"},{"indexed":false,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"ERC20PaymentReleased","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":"address","name":"account","type":"address"},{"indexed":false,"internalType":"uint256","name":"shares","type":"uint256"}],"name":"PayeeAdded","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"from","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"PaymentReceived","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"PaymentReleased","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"GIFT_MAX_QTY","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MAX_QTY_PER_MINT","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MAX_QTY_PER_MINTER","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MAX_QTY_PER_MINTER_PRE_SALES","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MINT_CALL_HASH_TYPE","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"PRESALES_MAX_QTY","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"PRE_SALES_PRICE","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"PUBLIC_SALES_PRICE","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"SALES_MAX_QTY","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"TOTAL_MAX_QTY","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"approve","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"canRenounceOwnership","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"getApproved","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"}],"name":"getDigest","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getDomainSeparatorV4","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getPrice","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"receivers","type":"address[]"}],"name":"gift","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"giftedQty","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"operator","type":"address"}],"name":"isApprovedForAll","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"isPreSalesActivated","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"isPublicSalesActivated","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"ownerOf","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"paused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"index","type":"uint256"}],"name":"payee","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"preSalesEndTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_mintQty","type":"uint256"},{"internalType":"bytes","name":"signature","type":"bytes"}],"name":"preSalesMint","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"preSalesMintedQty","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"preSalesMinterToTokenQty","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"preSalesStartTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_mintQty","type":"uint256"}],"name":"publicSalesMint","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"publicSalesMintedQty","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"publicSalesMinterToTokenQty","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"publicSalesStartTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"bytes","name":"signature","type":"bytes"}],"name":"recoverSigner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address payable","name":"account","type":"address"}],"name":"release","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"contract IERC20","name":"token","type":"address"},{"internalType":"address","name":"account","type":"address"}],"name":"release","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"contract IERC20","name":"token","type":"address"},{"internalType":"address","name":"account","type":"address"}],"name":"released","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"released","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"revealed","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"safeTransferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"bytes","name":"_data","type":"bytes"}],"name":"safeTransferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"operator","type":"address"},{"internalType":"bool","name":"approved","type":"bool"}],"name":"setApprovalForAll","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"string","name":"_baseTokenURI","type":"string"}],"name":"setBaseTokenURI","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_state","type":"bool"}],"name":"setCanRenounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"string","name":"_notRevealedURI","type":"string"}],"name":"setNotRevealedURI","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_state","type":"bool"}],"name":"setPaused","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_startTime","type":"uint256"},{"internalType":"uint256","name":"_endTime","type":"uint256"}],"name":"setPreSalesTime","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_startTime","type":"uint256"}],"name":"setPublicSalesTime","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_state","type":"bool"}],"name":"setRevealed","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"}],"name":"setWhitelistSigner","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"shares","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes4","name":"interfaceId","type":"bytes4"}],"name":"supportsInterface","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":"index","type":"uint256"}],"name":"tokenByIndex","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"uint256","name":"index","type":"uint256"}],"name":"tokenOfOwnerByIndex","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"tokenURI","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"contract IERC20","name":"token","type":"address"}],"name":"totalReleased","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalReleased","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalShares","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":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"transferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"whitelistSigner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"withdraw","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"withdrawSplit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

6101e06040527330be53552a0d71c8af783f453a92876e0a516a3a610140908152736fbf82ccaedd96a943a1bffda209b9a48f7960276101605273812b50c025f0d950df1e9b4f59c79bb00b08401c61018052739aab019c4c67e5501c0c84bbdbd25409723921456101a05273ab73be9c25f6963b6e5ad6574d0c2eeccb27288e6101c05262000094906013906005620006d2565b506040805160a0810182526109478082526020820181905291810182905260608101919091526101f46080820152620000d29060149060056200073c565b50600060158190556016819055601755601a805462ffffff19169055348015620000fb57600080fd5b50604051620045ed380380620045ed8339810160408190526200011e9162000814565b60138054806020026020016040519081016040528092919081815260200182805480156200017657602002820191906000526020600020905b81546001600160a01b0316815260019091019060200180831162000157575b50505050506014805480602002602001604051908101604052809291908181526020018280548015620001c957602002820191906000526020600020905b815481526020019060010190808311620001b4575b5050505050604051806040016040528060058152602001645473756b6960d81b815250604051806040016040528060058152602001645453554b4960d81b8152506040518060400160405280600e81526020016d151cdd5ada55da1a5d19531a5cdd60921b815250604051806040016040528060018152602001603160f81b815250620002656200025f6200049060201b60201c565b62000494565b636212f2206001556362124960600255636212f21f600355815160208084019190912082518383012060e08290526101008190524660a0818152604080517f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f81880181905281830187905260608201869052608082019490945230818401528151808203909301835260c00190528051940193909320919290916080523060601b60c052610120525050835162000326925060069150602085019062000780565b5080516200033c90600790602084019062000780565b5050508051825114620003b15760405162461bcd60e51b815260206004820152603260248201527f5061796d656e7453706c69747465723a2070617965657320616e6420736861726044820152710cae640d8cadccee8d040dad2e6dac2e8c6d60731b60648201526084015b60405180910390fd5b6000825111620004045760405162461bcd60e51b815260206004820152601a60248201527f5061796d656e7453706c69747465723a206e6f207061796565730000000000006044820152606401620003a8565b60005b825181101562000470576200045b8382815181106200042a576200042a6200097c565b60200260200101518383815181106200044757620004476200097c565b6020026020010151620004e460201b60201c565b80620004678162000948565b91505062000407565b50508151620004889150601c90602084019062000780565b5050620009a8565b3390565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6001600160a01b038216620005515760405162461bcd60e51b815260206004820152602c60248201527f5061796d656e7453706c69747465723a206163636f756e74206973207468652060448201526b7a65726f206164647265737360a01b6064820152608401620003a8565b60008111620005a35760405162461bcd60e51b815260206004820152601d60248201527f5061796d656e7453706c69747465723a207368617265732061726520300000006044820152606401620003a8565b6001600160a01b0382166000908152600e6020526040902054156200061f5760405162461bcd60e51b815260206004820152602b60248201527f5061796d656e7453706c69747465723a206163636f756e7420616c726561647960448201526a206861732073686172657360a81b6064820152608401620003a8565b60108054600181019091557f1b6847dc741a1b0cd08d278845f9d819d87b734759afb55fe2de5cb82a9ae6720180546001600160a01b0319166001600160a01b0384169081179091556000908152600e60205260409020819055600c5462000689908290620008f0565b600c55604080516001600160a01b0384168152602081018390527f40c340f65e17194d14ddddb073d3c9f888e3cb52b5aae0c6c7706b4fbc905fac910160405180910390a15050565b8280548282559060005260206000209081019282156200072a579160200282015b828111156200072a57825182546001600160a01b0319166001600160a01b03909116178255602090920191600190910190620006f3565b5062000738929150620007fd565b5090565b8280548282559060005260206000209081019282156200072a579160200282015b828111156200072a578251829061ffff169055916020019190600101906200075d565b8280546200078e906200090b565b90600052602060002090601f016020900481019282620007b257600085556200072a565b82601f10620007cd57805160ff19168380011785556200072a565b828001600101855582156200072a579182015b828111156200072a578251825591602001919060010190620007e0565b5b80821115620007385760008155600101620007fe565b600060208083850312156200082857600080fd5b82516001600160401b03808211156200084057600080fd5b818501915085601f8301126200085557600080fd5b8151818111156200086a576200086a62000992565b604051601f8201601f19908116603f0116810190838211818310171562000895576200089562000992565b816040528281528886848701011115620008ae57600080fd5b600093505b82841015620008d25784840186015181850187015292850192620008b3565b82841115620008e45760008684830101525b98975050505050505050565b6000821982111562000906576200090662000966565b500190565b600181811c908216806200092057607f821691505b602082108114156200094257634e487b7160e01b600052602260045260246000fd5b50919050565b60006000198214156200095f576200095f62000966565b5060010190565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b60805160a05160c05160601c60e0516101005161012051613bf2620009fb60003960006124ae015260006124fd015260006124d8015260006124310152600061245b015260006124850152613bf26000f3fe6080604052600436106103fd5760003560e01c80637b2ca38611610213578063bd34fc5711610123578063e0a80853116100ab578063e985e9c51161007a578063e985e9c514610bed578063ed39039b14610c36578063ef81b4d414610c56578063f2c4ce1e14610c76578063f2fde38b14610c9657600080fd5b8063e0a8085314610b82578063e33b7de314610ba2578063e53e3a0414610bb7578063e6c3819c14610bd757600080fd5b8063d1ca131f116100f2578063d1ca131f14610ada578063d338143814610afa578063d6eec46a14610b1a578063d79779b214610b36578063dee816e614610b6c57600080fd5b8063bd34fc5714610a3a578063c688387f14610a50578063c87b56dd14610a84578063ce7c2ac214610aa457600080fd5b80639c123661116101a6578063a78a673f11610175578063a78a673f146109c5578063ac501c41146109db578063ae4384f1146109f0578063b7329d2b14610a05578063b88d4fde14610a1a57600080fd5b80639c123661146109675780639e47efb81461097d578063a22cb46514610990578063a50e89ff146109b057600080fd5b80638f7be8f2116101e25780638f7be8f2146108da57806395d89b41146109075780639852595c1461091c57806398d5fdca1461095257600080fd5b80637b2ca3861461086657806382afe550146108805780638b83209b1461089c5780638da5cb5b146108bc57600080fd5b8063397d0c0c1161030e5780634def4d1a116102a157806360869d9b1161027057806360869d9b146107c45780636352211e146107e457806370a0823114610804578063715018a614610824578063791eef071461083957600080fd5b80634def4d1a146107455780634f6ccce71461076557806351830227146107855780635c975abb146107a557600080fd5b806342842e0e116102dd57806342842e0e146106dc57806347fc6e76146106fc57806348b75044146107125780634d192b831461073257600080fd5b8063397d0c0c146106635780633a98ef39146106795780633ccfd60b1461068e578063406072a91461069657600080fd5b8063163e1e6111610391578063191655871161036057806319165587146105ce57806323b872dd146105ee5780632f745c591461060e57806330176e131461062e5780633354fe341461064e57600080fd5b8063163e1e611461055f578063167877581461053557806316c38b3c1461057f57806318160ddd1461059f57600080fd5b8063081812fc116103cd578063081812fc146104db578063095ea7b314610513578063122be4a31461053557806313c65a6e1461054a57600080fd5b806226275e1461044b57806301e3b4361461047357806301ffc9a71461048957806306fdde03146104b957600080fd5b36610446577f6ef95f06320e7a25a04a175ca677b7052bdd97131872c2192525a629f51be77033604080516001600160a01b0390921682523460208301520160405180910390a1005b600080fd5b34801561045757600080fd5b50610460610cb6565b6040519081526020015b60405180910390f35b34801561047f57600080fd5b5061046060155481565b34801561049557600080fd5b506104a96104a436600461378a565b610cc6565b604051901515815260200161046a565b3480156104c557600080fd5b506104ce610d33565b60405161046a9190613944565b3480156104e757600080fd5b506104fb6104f636600461380c565b610dc5565b6040516001600160a01b03909116815260200161046a565b34801561051f57600080fd5b5061053361052e3660046136b0565b610e09565b005b34801561054157600080fd5b50610460600281565b34801561055657600080fd5b50610460610e97565b34801561056b57600080fd5b5061053361057a3660046136dc565b610ed8565b34801561058b57600080fd5b5061053361059a366004613750565b610fc2565b3480156105ab57600080fd5b506104606005546001600160801b03600160801b82048116918116919091031690565b3480156105da57600080fd5b506105336105e9366004613531565b611006565b3480156105fa57600080fd5b50610533610609366004613587565b611134565b34801561061a57600080fd5b506104606106293660046136b0565b61113f565b34801561063a57600080fd5b506105336106493660046137c4565b61123b565b34801561065a57600080fd5b50610460603281565b34801561066f57600080fd5b5061046060025481565b34801561068557600080fd5b50600c54610460565b61053361127c565b3480156106a257600080fd5b506104606106b136600461354e565b6001600160a01b03918216600090815260126020908152604080832093909416825291909152205490565b3480156106e857600080fd5b506105336106f7366004613587565b6112fe565b34801561070857600080fd5b5061046061232881565b34801561071e57600080fd5b5061053361072d36600461354e565b611319565b61053361074036600461380c565b611501565b34801561075157600080fd5b50610533610760366004613750565b6117d0565b34801561077157600080fd5b5061046061078036600461380c565b61180d565b34801561079157600080fd5b50601a546104a99062010000900460ff1681565b3480156107b157600080fd5b50601a546104a990610100900460ff1681565b3480156107d057600080fd5b506105336107df36600461380c565b6118b9565b3480156107f057600080fd5b506104fb6107ff36600461380c565b6118e8565b34801561081057600080fd5b5061046061081f366004613531565b6118fa565b34801561083057600080fd5b50610533611948565b34801561084557600080fd5b50610460610854366004613531565b60186020526000908152604090205481565b34801561087257600080fd5b50601a546104a99060ff1681565b34801561088c57600080fd5b5061046067016345785d8a000081565b3480156108a857600080fd5b506104fb6108b736600461380c565b6119db565b3480156108c857600080fd5b506000546001600160a01b03166104fb565b3480156108e657600080fd5b506104606108f5366004613531565b60196020526000908152604090205481565b34801561091357600080fd5b506104ce611a0b565b34801561092857600080fd5b50610460610937366004613531565b6001600160a01b03166000908152600f602052604090205490565b34801561095e57600080fd5b50610460611a1a565b34801561097357600080fd5b5061046060165481565b61053361098b36600461383e565b611a43565b34801561099c57600080fd5b506105336109ab366004613633565b611d82565b3480156109bc57600080fd5b50610533611e18565b3480156109d157600080fd5b5061046060035481565b3480156109e757600080fd5b50610460600481565b3480156109fc57600080fd5b506104a9611e97565b348015610a1157600080fd5b506104a9611eaf565b348015610a2657600080fd5b50610533610a353660046135c8565b611ee3565b348015610a4657600080fd5b5061046060175481565b348015610a5c57600080fd5b506104607ff59780ff8f4ba89ed09d6c9fc5aec79093994c7234326cb09aafc9bf724f074181565b348015610a9057600080fd5b506104ce610a9f36600461380c565b611f17565b348015610ab057600080fd5b50610460610abf366004613531565b6001600160a01b03166000908152600e602052604090205490565b348015610ae657600080fd5b50610460610af5366004613531565b612084565b348015610b0657600080fd5b50610533610b15366004613531565b61216c565b348015610b2657600080fd5b50610460670214e8348c4f000081565b348015610b4257600080fd5b50610460610b51366004613531565b6001600160a01b031660009081526011602052604090205490565b348015610b7857600080fd5b5061046061271081565b348015610b8e57600080fd5b50610533610b9d366004613750565b6121b8565b348015610bae57600080fd5b50600d54610460565b348015610bc357600080fd5b506104fb610bd2366004613661565b6121fe565b348015610be357600080fd5b5061046060015481565b348015610bf957600080fd5b506104a9610c0836600461354e565b6001600160a01b039182166000908152600b6020908152604080832093909416825291909152205460ff1690565b348015610c4257600080fd5b50610533610c5136600461386e565b612212565b348015610c6257600080fd5b506004546104fb906001600160a01b031681565b348015610c8257600080fd5b50610533610c913660046137c4565b6122bd565b348015610ca257600080fd5b50610533610cb1366004613531565b6122fa565b610cc36032612710613a68565b81565b60006001600160e01b031982166380ac58cd60e01b1480610cf757506001600160e01b03198216635b5e139f60e01b145b80610d1257506001600160e01b0319821663780e9d6360e01b145b80610d2d57506301ffc9a760e01b6001600160e01b03198316145b92915050565b606060068054610d4290613aab565b80601f0160208091040260200160405190810160405280929190818152602001828054610d6e90613aab565b8015610dbb5780601f10610d9057610100808354040283529160200191610dbb565b820191906000526020600020905b815481529060010190602001808311610d9e57829003601f168201915b5050505050905090565b6000610dd082612392565b610ded576040516333d1c03960e21b815260040160405180910390fd5b506000908152600a60205260409020546001600160a01b031690565b6000610e14826118e8565b9050806001600160a01b0316836001600160a01b03161415610e495760405163250fdee360e21b815260040160405180910390fd5b336001600160a01b03821614801590610e695750610e678133610c08565b155b15610e87576040516367d9dca160e11b815260040160405180910390fd5b610e928383836123c8565b505050565b600080546001600160a01b03163314610ecb5760405162461bcd60e51b8152600401610ec2906139e8565b60405180910390fd5b610ed3612424565b905090565b6000546001600160a01b03163314610f025760405162461bcd60e51b8152600401610ec2906139e8565b601754603290610f13908390613a1d565b1115610f595760405162461bcd60e51b8152602060048201526015602482015274115e18d959590819da599d081b585e081b1a5b5a5d605a1b6044820152606401610ec2565b8181905060176000828254610f6e9190613a1d565b90915550600090505b81811015610e9257610fb0838383818110610f9457610f94613b57565b9050602002016020810190610fa99190613531565b600161254b565b80610fba81613ae6565b915050610f77565b6000546001600160a01b03163314610fec5760405162461bcd60e51b8152600401610ec2906139e8565b601a80549115156101000261ff0019909216919091179055565b6001600160a01b0381166000908152600e602052604090205461103b5760405162461bcd60e51b8152600401610ec290613957565b6000611046600d5490565b6110509047613a1d565b9050600061107d8383611078866001600160a01b03166000908152600f602052604090205490565b612565565b90508061109c5760405162461bcd60e51b8152600401610ec29061399d565b6001600160a01b0383166000908152600f6020526040812080548392906110c4908490613a1d565b9250508190555080600d60008282546110dd9190613a1d565b909155506110ed905083826125ab565b604080516001600160a01b0385168152602081018390527fdf20fd1e76bc69d672e4814fafb2c449bba3a5369d8359adf9e05e6fde87b056910160405180910390a1505050565b610e928383836126c4565b600061114a836118fa565b8210611169576040516306ed618760e11b815260040160405180910390fd5b6005546001600160801b0316600080805b8381101561123557600081815260086020908152604091829020825160608101845290546001600160a01b0381168252600160a01b81046001600160401b031692820192909252600160e01b90910460ff1615801592820192909252906111e1575061122d565b80516001600160a01b0316156111f657805192505b876001600160a01b0316836001600160a01b0316141561122b578684141561122457509350610d2d92505050565b6001909301925b505b60010161117a565b50600080fd5b6000546001600160a01b031633146112655760405162461bcd60e51b8152600401610ec2906139e8565b805161127890601b906020840190613403565b5050565b6000546001600160a01b031633146112a65760405162461bcd60e51b8152600401610ec2906139e8565b604051600090339047908381818185875af1925050503d80600081146112e8576040519150601f19603f3d011682016040523d82523d6000602084013e6112ed565b606091505b50509050806112fb57600080fd5b50565b610e9283838360405180602001604052806000815250611ee3565b6001600160a01b0381166000908152600e602052604090205461134e5760405162461bcd60e51b8152600401610ec290613957565b6001600160a01b0382166000908152601160205260408120546040516370a0823160e01b81523060048201526001600160a01b038516906370a082319060240160206040518083038186803b1580156113a657600080fd5b505afa1580156113ba573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906113de9190613825565b6113e89190613a1d565b90506000611421838361107887876001600160a01b03918216600090815260126020908152604080832093909416825291909152205490565b9050806114405760405162461bcd60e51b8152600401610ec29061399d565b6001600160a01b03808516600090815260126020908152604080832093871683529290529081208054839290611477908490613a1d565b90915550506001600160a01b038416600090815260116020526040812080548392906114a4908490613a1d565b909155506114b590508484836128e1565b604080516001600160a01b038581168252602082018490528616917f3be5b7a71e84ed12875d241991c70855ac5817d847039e17a9d895c1ceb0f18a910160405180910390a250505050565b611509611e97565b61156a5760405162461bcd60e51b815260206004820152602c60248201527f5075626c696353616c657341637469766174696f6e3a2053616c65206973206e60448201526b1bdd081858dd1a5d985d195960a21b6064820152608401610ec2565b6115776032612710613a68565b816016546015546115889190613a1d565b6115929190613a1d565b11156115d95760405162461bcd60e51b8152602060048201526016602482015275115e18d95959081cd85b195cc81b585e081b1a5b5a5d60521b6044820152606401610ec2565b600281111561162a5760405162461bcd60e51b815260206004820152601960248201527f457863656564206d6178206d696e7420706572206d696e742e000000000000006044820152606401610ec2565b33600090815260196020526040902054600490611648908390613a1d565b11156116965760405162461bcd60e51b815260206004820152601a60248201527f457863656564206d6178206d696e7420706572206d696e7465720000000000006044820152606401610ec2565b3233146116e55760405162461bcd60e51b815260206004820152601d60248201527f434f4e5452414354535f4e4f545f414c4c4f5745445f544f5f4d494e540000006044820152606401610ec2565b601a54610100900460ff16156117375760405162461bcd60e51b815260206004820152601760248201527654686520636f6e7472616374206973207061757365642160481b6044820152606401610ec2565b61173f611a1a565b6117499082613a49565b3410156117885760405162461bcd60e51b815260206004820152600d60248201526c092dcc6dee4e4cac6e8408aa89609b1b6044820152606401610ec2565b33600090815260196020526040812080548392906117a7908490613a1d565b9250508190555080601660008282546117c09190613a1d565b909155506112fb9050338261254b565b6000546001600160a01b031633146117fa5760405162461bcd60e51b8152600401610ec2906139e8565b601a805460ff1916911515919091179055565b6005546000906001600160801b031681805b8281101561189f57600081815260086020908152604091829020825160608101845290546001600160a01b0381168252600160a01b81046001600160401b031692820192909252600160e01b90910460ff16151591810182905290611896578583141561188f5750949350505050565b6001909201915b5060010161181f565b506040516329c8c00760e21b815260040160405180910390fd5b6000546001600160a01b031633146118e35760405162461bcd60e51b8152600401610ec2906139e8565b600155565b60006118f382612933565b5192915050565b60006001600160a01b038216611923576040516323d3ad8160e21b815260040160405180910390fd5b506001600160a01b03166000908152600960205260409020546001600160401b031690565b6000546001600160a01b031633146119725760405162461bcd60e51b8152600401610ec2906139e8565b601a5460ff166119cf5760405162461bcd60e51b815260206004820152602260248201527f4e6f74207468652074696d6520746f2052656e6f756e6365204f776e65727368604482015261069760f41b6064820152608401610ec2565b6119d96000612a57565b565b6000601082815481106119f0576119f0613b57565b6000918252602090912001546001600160a01b031692915050565b606060078054610d4290613aab565b6000611a24611e97565b15611a365750670214e8348c4f000090565b5067016345785d8a000090565b611a4b611eaf565b611aa95760405162461bcd60e51b815260206004820152602960248201527f50726553616c657341637469766174696f6e3a2053616c65206973206e6f74206044820152681858dd1a5d985d195960ba1b6064820152608401610ec2565b600454339082906001600160a01b0316611ac383836121fe565b6001600160a01b031614611b195760405162461bcd60e51b815260206004820152601860248201527f55736572206973206e6f74206f6e2077686974656c69737400000000000000006044820152606401610ec2565b61271084601654601554611b2d9190613a1d565b611b379190613a1d565b1115611b7e5760405162461bcd60e51b8152602060048201526016602482015275115e18d95959081cd85b195cc81b585e081b1a5b5a5d60521b6044820152606401610ec2565b61232884601554611b8f9190613a1d565b1115611bdd5760405162461bcd60e51b815260206004820152601a60248201527f457863656564207072652d73616c6573206d6178206c696d69740000000000006044820152606401610ec2565b33600090815260186020526040902054600290611bfb908690613a1d565b1115611c425760405162461bcd60e51b8152602060048201526016602482015275457863656564207369676e6564207175616e7469747960501b6044820152606401610ec2565b323314611c915760405162461bcd60e51b815260206004820152601d60248201527f434f4e5452414354535f4e4f545f414c4c4f5745445f544f5f4d494e540000006044820152606401610ec2565b601a54610100900460ff1615611ce35760405162461bcd60e51b815260206004820152601760248201527654686520636f6e7472616374206973207061757365642160481b6044820152606401610ec2565b611ceb611a1a565b611cf59085613a49565b341015611d345760405162461bcd60e51b815260206004820152600d60248201526c092dcc6dee4e4cac6e8408aa89609b1b6044820152606401610ec2565b3360009081526018602052604081208054869290611d53908490613a1d565b925050819055508360156000828254611d6c9190613a1d565b90915550611d7c9050338561254b565b50505050565b6001600160a01b038216331415611dac5760405163b06307db60e01b815260040160405180910390fd5b336000818152600b602090815260408083206001600160a01b03871680855290835292819020805460ff191686151590811790915590519081529192917f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a35050565b6000546001600160a01b03163314611e425760405162461bcd60e51b8152600401610ec2906139e8565b60005b6013548110156112fb57600060138281548110611e6457611e64613b57565b6000918252602090912001546001600160a01b03169050611e8481611006565b5080611e8f81613ae6565b915050611e45565b600080600154118015610ed357505060015442101590565b600080600254118015611ec457506000600354115b8015611ed257506002544210155b8015610ed357505060035442111590565b611eee8484846126c4565b611efa84848484612aa7565b611d7c576040516368d2bf6b60e11b815260040160405180910390fd5b6060611f2282612392565b611f865760405162461bcd60e51b815260206004820152602f60248201527f4552433732314d657461646174613a2055524920717565727920666f72206e6f60448201526e3732bc34b9ba32b73a103a37b5b2b760891b6064820152608401610ec2565b601a5462010000900460ff1661202857601c8054611fa390613aab565b80601f0160208091040260200160405190810160405280929190818152602001828054611fcf90613aab565b801561201c5780601f10611ff15761010080835404028352916020019161201c565b820191906000526020600020905b815481529060010190602001808311611fff57829003601f168201915b50505050509050919050565b6000612032612bb5565b90506000815111612052576040518060200160405280600081525061207d565b8061205c84612bc4565b60405160200161206d9291906138d8565b6040516020818303038152906040525b9392505050565b600080612119612092612424565b604080517ff59780ff8f4ba89ed09d6c9fc5aec79093994c7234326cb09aafc9bf724f07416020808301919091526001600160a01b0388168284015282518083038401815260608301845280519082012061190160f01b6080840152608283019490945260a2808301949094528251808303909401845260c2909101909152815191012090565b6040517f19457468657265756d205369676e6564204d6573736167653a0a3332000000006020820152603c810191909152605c0160408051601f1981840301815291905280516020909101209392505050565b6000546001600160a01b031633146121965760405162461bcd60e51b8152600401610ec2906139e8565b600480546001600160a01b0319166001600160a01b0392909216919091179055565b6000546001600160a01b031633146121e25760405162461bcd60e51b8152600401610ec2906139e8565b601a8054911515620100000262ff000019909216919091179055565b600061207d61220c84612084565b83612cc1565b6000546001600160a01b0316331461223c5760405162461bcd60e51b8152600401610ec2906139e8565b818110156122b25760405162461bcd60e51b815260206004820152603c60248201527f50726553616c657341637469766174696f6e3a20456e642074696d652073686f60448201527f756c64206265206c61746572207468616e2073746172742074696d65000000006064820152608401610ec2565b600291909155600355565b6000546001600160a01b031633146122e75760405162461bcd60e51b8152600401610ec2906139e8565b805161127890601c906020840190613403565b6000546001600160a01b031633146123245760405162461bcd60e51b8152600401610ec2906139e8565b6001600160a01b0381166123895760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610ec2565b6112fb81612a57565b6005546000906001600160801b031682108015610d2d575050600090815260086020526040902054600160e01b900460ff161590565b6000828152600a602052604080822080546001600160a01b0319166001600160a01b0387811691821790925591518593918516917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591a4505050565b6000306001600160a01b037f00000000000000000000000000000000000000000000000000000000000000001614801561247d57507f000000000000000000000000000000000000000000000000000000000000000046145b156124a757507f000000000000000000000000000000000000000000000000000000000000000090565b50604080517f00000000000000000000000000000000000000000000000000000000000000006020808301919091527f0000000000000000000000000000000000000000000000000000000000000000828401527f000000000000000000000000000000000000000000000000000000000000000060608301524660808301523060a0808401919091528351808403909101815260c0909201909252805191012090565b611278828260405180602001604052806000815250612ce5565b600c546001600160a01b0384166000908152600e60205260408120549091839161258f9086613a49565b6125999190613a35565b6125a39190613a68565b949350505050565b804710156125fb5760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a20696e73756666696369656e742062616c616e63650000006044820152606401610ec2565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114612648576040519150601f19603f3d011682016040523d82523d6000602084013e61264d565b606091505b5050905080610e925760405162461bcd60e51b815260206004820152603a60248201527f416464726573733a20756e61626c6520746f2073656e642076616c75652c207260448201527f6563697069656e74206d617920686176652072657665727465640000000000006064820152608401610ec2565b60006126cf82612933565b80519091506000906001600160a01b0316336001600160a01b031614806126fd575081516126fd9033610c08565b8061271857503361270d84610dc5565b6001600160a01b0316145b90508061273857604051632ce44b5f60e11b815260040160405180910390fd5b846001600160a01b031682600001516001600160a01b03161461276d5760405162a1148160e81b815260040160405180910390fd5b6001600160a01b03841661279457604051633a954ecd60e21b815260040160405180910390fd5b6127a460008484600001516123c8565b6001600160a01b038581166000908152600960209081526040808320805467ffffffffffffffff198082166001600160401b0392831660001901831617909255898616808652838620805493841693831660019081018416949094179055898652600890945282852080546001600160e01b031916909417600160a01b429092169190910217909255908601808352912054909116612897576005546001600160801b031681101561289757825160008281526008602090815260409091208054918601516001600160401b0316600160a01b026001600160e01b03199092166001600160a01b03909316929092171790555b5082846001600160a01b0316866001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a45b5050505050565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b179052610e92908490612cf2565b604080516060810182526000808252602082018190529181019190915260055482906001600160801b0316811015612a3e57600081815260086020908152604091829020825160608101845290546001600160a01b0381168252600160a01b81046001600160401b031692820192909252600160e01b90910460ff16151591810182905290612a3c5780516001600160a01b0316156129d3579392505050565b5060001901600081815260086020908152604091829020825160608101845290546001600160a01b038116808352600160a01b82046001600160401b031693830193909352600160e01b900460ff1615159281019290925215612a37579392505050565b6129d3565b505b604051636f96cda160e11b815260040160405180910390fd5b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b60006001600160a01b0384163b15612baa57604051630a85bd0160e11b81526001600160a01b0385169063150b7a0290612aeb903390899088908890600401613907565b602060405180830381600087803b158015612b0557600080fd5b505af1925050508015612b35575060408051601f3d908101601f19168201909252612b32918101906137a7565b60015b612b90573d808015612b63576040519150601f19603f3d011682016040523d82523d6000602084013e612b68565b606091505b508051612b88576040516368d2bf6b60e11b815260040160405180910390fd5b805181602001fd5b6001600160e01b031916630a85bd0160e11b1490506125a3565b506001949350505050565b6060601b8054610d4290613aab565b606081612be85750506040805180820190915260018152600360fc1b602082015290565b8160005b8115612c125780612bfc81613ae6565b9150612c0b9050600a83613a35565b9150612bec565b6000816001600160401b03811115612c2c57612c2c613b6d565b6040519080825280601f01601f191660200182016040528015612c56576020820181803683370190505b5090505b84156125a357612c6b600183613a68565b9150612c78600a86613b01565b612c83906030613a1d565b60f81b818381518110612c9857612c98613b57565b60200101906001600160f81b031916908160001a905350612cba600a86613a35565b9450612c5a565b6000806000612cd08585612dc4565b91509150612cdd81612e34565b509392505050565b610e928383836001612fef565b6000612d47826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b03166131779092919063ffffffff16565b805190915015610e925780806020019051810190612d65919061376d565b610e925760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6044820152691bdd081cdd58d8d9595960b21b6064820152608401610ec2565b600080825160411415612dfb5760208301516040840151606085015160001a612def87828585613186565b94509450505050612e2d565b825160401415612e255760208301516040840151612e1a868383613273565b935093505050612e2d565b506000905060025b9250929050565b6000816004811115612e4857612e48613b41565b1415612e515750565b6001816004811115612e6557612e65613b41565b1415612eb35760405162461bcd60e51b815260206004820152601860248201527f45434453413a20696e76616c6964207369676e617475726500000000000000006044820152606401610ec2565b6002816004811115612ec757612ec7613b41565b1415612f155760405162461bcd60e51b815260206004820152601f60248201527f45434453413a20696e76616c6964207369676e6174757265206c656e677468006044820152606401610ec2565b6003816004811115612f2957612f29613b41565b1415612f825760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202773272076616c604482015261756560f01b6064820152608401610ec2565b6004816004811115612f9657612f96613b41565b14156112fb5760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202776272076616c604482015261756560f01b6064820152608401610ec2565b6005546001600160801b03166001600160a01b03851661302157604051622e076360e81b815260040160405180910390fd5b8361303f5760405163b562e8dd60e01b815260040160405180910390fd5b6001600160a01b038516600081815260096020908152604080832080546001600160801b031981166001600160401b038083168c0181169182176801000000000000000067ffffffffffffffff1990941690921783900481168c018116909202179091558584526008909252822080546001600160e01b031916909317600160a01b42909216919091021790915581905b858110156131515760405182906001600160a01b038916906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a483801561312757506131256000888488612aa7565b155b15613145576040516368d2bf6b60e11b815260040160405180910390fd5b600191820191016130d0565b50600580546001600160801b0319166001600160801b03929092169190911790556128da565b60606125a384846000856132a2565b6000807f7fffffffffffffffffffffffffffffff5d576e7357a4501ddfe92f46681b20a08311156131bd575060009050600361326a565b8460ff16601b141580156131d557508460ff16601c14155b156131e6575060009050600461326a565b6040805160008082526020820180845289905260ff881692820192909252606081018690526080810185905260019060a0016020604051602081039080840390855afa15801561323a573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b0381166132635760006001925092505061326a565b9150600090505b94509492505050565b6000806001600160ff1b03831660ff84901c601b0161329487828885613186565b935093505050935093915050565b6060824710156133035760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f6044820152651c8818d85b1b60d21b6064820152608401610ec2565b843b6133515760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610ec2565b600080866001600160a01b0316858760405161336d91906138bc565b60006040518083038185875af1925050503d80600081146133aa576040519150601f19603f3d011682016040523d82523d6000602084013e6133af565b606091505b50915091506133bf8282866133ca565b979650505050505050565b606083156133d957508161207d565b8251156133e95782518084602001fd5b8160405162461bcd60e51b8152600401610ec29190613944565b82805461340f90613aab565b90600052602060002090601f0160209004810192826134315760008555613477565b82601f1061344a57805160ff1916838001178555613477565b82800160010185558215613477579182015b8281111561347757825182559160200191906001019061345c565b50613483929150613487565b5090565b5b808211156134835760008155600101613488565b60006001600160401b03808411156134b6576134b6613b6d565b604051601f8501601f19908116603f011681019082821181831017156134de576134de613b6d565b816040528093508581528686860111156134f757600080fd5b858560208301376000602087830101525050509392505050565b600082601f83011261352257600080fd5b61207d8383356020850161349c565b60006020828403121561354357600080fd5b813561207d81613b83565b6000806040838503121561356157600080fd5b823561356c81613b83565b9150602083013561357c81613b83565b809150509250929050565b60008060006060848603121561359c57600080fd5b83356135a781613b83565b925060208401356135b781613b83565b929592945050506040919091013590565b600080600080608085870312156135de57600080fd5b84356135e981613b83565b935060208501356135f981613b83565b92506040850135915060608501356001600160401b0381111561361b57600080fd5b61362787828801613511565b91505092959194509250565b6000806040838503121561364657600080fd5b823561365181613b83565b9150602083013561357c81613b98565b6000806040838503121561367457600080fd5b823561367f81613b83565b915060208301356001600160401b0381111561369a57600080fd5b6136a685828601613511565b9150509250929050565b600080604083850312156136c357600080fd5b82356136ce81613b83565b946020939093013593505050565b600080602083850312156136ef57600080fd5b82356001600160401b038082111561370657600080fd5b818501915085601f83011261371a57600080fd5b81358181111561372957600080fd5b8660208260051b850101111561373e57600080fd5b60209290920196919550909350505050565b60006020828403121561376257600080fd5b813561207d81613b98565b60006020828403121561377f57600080fd5b815161207d81613b98565b60006020828403121561379c57600080fd5b813561207d81613ba6565b6000602082840312156137b957600080fd5b815161207d81613ba6565b6000602082840312156137d657600080fd5b81356001600160401b038111156137ec57600080fd5b8201601f810184136137fd57600080fd5b6125a38482356020840161349c565b60006020828403121561381e57600080fd5b5035919050565b60006020828403121561383757600080fd5b5051919050565b6000806040838503121561385157600080fd5b8235915060208301356001600160401b0381111561369a57600080fd5b6000806040838503121561388157600080fd5b50508035926020909101359150565b600081518084526138a8816020860160208601613a7f565b601f01601f19169290920160200192915050565b600082516138ce818460208701613a7f565b9190910192915050565b600083516138ea818460208801613a7f565b8351908301906138fe818360208801613a7f565b01949350505050565b6001600160a01b038581168252841660208201526040810183905260806060820181905260009061393a90830184613890565b9695505050505050565b60208152600061207d6020830184613890565b60208082526026908201527f5061796d656e7453706c69747465723a206163636f756e7420686173206e6f2060408201526573686172657360d01b606082015260800190565b6020808252602b908201527f5061796d656e7453706c69747465723a206163636f756e74206973206e6f742060408201526a191d59481c185e5b595b9d60aa1b606082015260800190565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60008219821115613a3057613a30613b15565b500190565b600082613a4457613a44613b2b565b500490565b6000816000190483118215151615613a6357613a63613b15565b500290565b600082821015613a7a57613a7a613b15565b500390565b60005b83811015613a9a578181015183820152602001613a82565b83811115611d7c5750506000910152565b600181811c90821680613abf57607f821691505b60208210811415613ae057634e487b7160e01b600052602260045260246000fd5b50919050565b6000600019821415613afa57613afa613b15565b5060010190565b600082613b1057613b10613b2b565b500690565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052601260045260246000fd5b634e487b7160e01b600052602160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b6001600160a01b03811681146112fb57600080fd5b80151581146112fb57600080fd5b6001600160e01b0319811681146112fb57600080fdfea26469706673582212208a240ab2424212620871c9030a120776f1a5d2cd1c6c1a23ee8da0645a42082664736f6c634300080700330000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000005068747470733a2f2f7473756b692e6d7970696e6174612e636c6f75642f697066732f516d66553153747032754546534c6765344c4a6b4c5837526b6e46423274554e506170713859717731343762427700000000000000000000000000000000

Deployed Bytecode

0x6080604052600436106103fd5760003560e01c80637b2ca38611610213578063bd34fc5711610123578063e0a80853116100ab578063e985e9c51161007a578063e985e9c514610bed578063ed39039b14610c36578063ef81b4d414610c56578063f2c4ce1e14610c76578063f2fde38b14610c9657600080fd5b8063e0a8085314610b82578063e33b7de314610ba2578063e53e3a0414610bb7578063e6c3819c14610bd757600080fd5b8063d1ca131f116100f2578063d1ca131f14610ada578063d338143814610afa578063d6eec46a14610b1a578063d79779b214610b36578063dee816e614610b6c57600080fd5b8063bd34fc5714610a3a578063c688387f14610a50578063c87b56dd14610a84578063ce7c2ac214610aa457600080fd5b80639c123661116101a6578063a78a673f11610175578063a78a673f146109c5578063ac501c41146109db578063ae4384f1146109f0578063b7329d2b14610a05578063b88d4fde14610a1a57600080fd5b80639c123661146109675780639e47efb81461097d578063a22cb46514610990578063a50e89ff146109b057600080fd5b80638f7be8f2116101e25780638f7be8f2146108da57806395d89b41146109075780639852595c1461091c57806398d5fdca1461095257600080fd5b80637b2ca3861461086657806382afe550146108805780638b83209b1461089c5780638da5cb5b146108bc57600080fd5b8063397d0c0c1161030e5780634def4d1a116102a157806360869d9b1161027057806360869d9b146107c45780636352211e146107e457806370a0823114610804578063715018a614610824578063791eef071461083957600080fd5b80634def4d1a146107455780634f6ccce71461076557806351830227146107855780635c975abb146107a557600080fd5b806342842e0e116102dd57806342842e0e146106dc57806347fc6e76146106fc57806348b75044146107125780634d192b831461073257600080fd5b8063397d0c0c146106635780633a98ef39146106795780633ccfd60b1461068e578063406072a91461069657600080fd5b8063163e1e6111610391578063191655871161036057806319165587146105ce57806323b872dd146105ee5780632f745c591461060e57806330176e131461062e5780633354fe341461064e57600080fd5b8063163e1e611461055f578063167877581461053557806316c38b3c1461057f57806318160ddd1461059f57600080fd5b8063081812fc116103cd578063081812fc146104db578063095ea7b314610513578063122be4a31461053557806313c65a6e1461054a57600080fd5b806226275e1461044b57806301e3b4361461047357806301ffc9a71461048957806306fdde03146104b957600080fd5b36610446577f6ef95f06320e7a25a04a175ca677b7052bdd97131872c2192525a629f51be77033604080516001600160a01b0390921682523460208301520160405180910390a1005b600080fd5b34801561045757600080fd5b50610460610cb6565b6040519081526020015b60405180910390f35b34801561047f57600080fd5b5061046060155481565b34801561049557600080fd5b506104a96104a436600461378a565b610cc6565b604051901515815260200161046a565b3480156104c557600080fd5b506104ce610d33565b60405161046a9190613944565b3480156104e757600080fd5b506104fb6104f636600461380c565b610dc5565b6040516001600160a01b03909116815260200161046a565b34801561051f57600080fd5b5061053361052e3660046136b0565b610e09565b005b34801561054157600080fd5b50610460600281565b34801561055657600080fd5b50610460610e97565b34801561056b57600080fd5b5061053361057a3660046136dc565b610ed8565b34801561058b57600080fd5b5061053361059a366004613750565b610fc2565b3480156105ab57600080fd5b506104606005546001600160801b03600160801b82048116918116919091031690565b3480156105da57600080fd5b506105336105e9366004613531565b611006565b3480156105fa57600080fd5b50610533610609366004613587565b611134565b34801561061a57600080fd5b506104606106293660046136b0565b61113f565b34801561063a57600080fd5b506105336106493660046137c4565b61123b565b34801561065a57600080fd5b50610460603281565b34801561066f57600080fd5b5061046060025481565b34801561068557600080fd5b50600c54610460565b61053361127c565b3480156106a257600080fd5b506104606106b136600461354e565b6001600160a01b03918216600090815260126020908152604080832093909416825291909152205490565b3480156106e857600080fd5b506105336106f7366004613587565b6112fe565b34801561070857600080fd5b5061046061232881565b34801561071e57600080fd5b5061053361072d36600461354e565b611319565b61053361074036600461380c565b611501565b34801561075157600080fd5b50610533610760366004613750565b6117d0565b34801561077157600080fd5b5061046061078036600461380c565b61180d565b34801561079157600080fd5b50601a546104a99062010000900460ff1681565b3480156107b157600080fd5b50601a546104a990610100900460ff1681565b3480156107d057600080fd5b506105336107df36600461380c565b6118b9565b3480156107f057600080fd5b506104fb6107ff36600461380c565b6118e8565b34801561081057600080fd5b5061046061081f366004613531565b6118fa565b34801561083057600080fd5b50610533611948565b34801561084557600080fd5b50610460610854366004613531565b60186020526000908152604090205481565b34801561087257600080fd5b50601a546104a99060ff1681565b34801561088c57600080fd5b5061046067016345785d8a000081565b3480156108a857600080fd5b506104fb6108b736600461380c565b6119db565b3480156108c857600080fd5b506000546001600160a01b03166104fb565b3480156108e657600080fd5b506104606108f5366004613531565b60196020526000908152604090205481565b34801561091357600080fd5b506104ce611a0b565b34801561092857600080fd5b50610460610937366004613531565b6001600160a01b03166000908152600f602052604090205490565b34801561095e57600080fd5b50610460611a1a565b34801561097357600080fd5b5061046060165481565b61053361098b36600461383e565b611a43565b34801561099c57600080fd5b506105336109ab366004613633565b611d82565b3480156109bc57600080fd5b50610533611e18565b3480156109d157600080fd5b5061046060035481565b3480156109e757600080fd5b50610460600481565b3480156109fc57600080fd5b506104a9611e97565b348015610a1157600080fd5b506104a9611eaf565b348015610a2657600080fd5b50610533610a353660046135c8565b611ee3565b348015610a4657600080fd5b5061046060175481565b348015610a5c57600080fd5b506104607ff59780ff8f4ba89ed09d6c9fc5aec79093994c7234326cb09aafc9bf724f074181565b348015610a9057600080fd5b506104ce610a9f36600461380c565b611f17565b348015610ab057600080fd5b50610460610abf366004613531565b6001600160a01b03166000908152600e602052604090205490565b348015610ae657600080fd5b50610460610af5366004613531565b612084565b348015610b0657600080fd5b50610533610b15366004613531565b61216c565b348015610b2657600080fd5b50610460670214e8348c4f000081565b348015610b4257600080fd5b50610460610b51366004613531565b6001600160a01b031660009081526011602052604090205490565b348015610b7857600080fd5b5061046061271081565b348015610b8e57600080fd5b50610533610b9d366004613750565b6121b8565b348015610bae57600080fd5b50600d54610460565b348015610bc357600080fd5b506104fb610bd2366004613661565b6121fe565b348015610be357600080fd5b5061046060015481565b348015610bf957600080fd5b506104a9610c0836600461354e565b6001600160a01b039182166000908152600b6020908152604080832093909416825291909152205460ff1690565b348015610c4257600080fd5b50610533610c5136600461386e565b612212565b348015610c6257600080fd5b506004546104fb906001600160a01b031681565b348015610c8257600080fd5b50610533610c913660046137c4565b6122bd565b348015610ca257600080fd5b50610533610cb1366004613531565b6122fa565b610cc36032612710613a68565b81565b60006001600160e01b031982166380ac58cd60e01b1480610cf757506001600160e01b03198216635b5e139f60e01b145b80610d1257506001600160e01b0319821663780e9d6360e01b145b80610d2d57506301ffc9a760e01b6001600160e01b03198316145b92915050565b606060068054610d4290613aab565b80601f0160208091040260200160405190810160405280929190818152602001828054610d6e90613aab565b8015610dbb5780601f10610d9057610100808354040283529160200191610dbb565b820191906000526020600020905b815481529060010190602001808311610d9e57829003601f168201915b5050505050905090565b6000610dd082612392565b610ded576040516333d1c03960e21b815260040160405180910390fd5b506000908152600a60205260409020546001600160a01b031690565b6000610e14826118e8565b9050806001600160a01b0316836001600160a01b03161415610e495760405163250fdee360e21b815260040160405180910390fd5b336001600160a01b03821614801590610e695750610e678133610c08565b155b15610e87576040516367d9dca160e11b815260040160405180910390fd5b610e928383836123c8565b505050565b600080546001600160a01b03163314610ecb5760405162461bcd60e51b8152600401610ec2906139e8565b60405180910390fd5b610ed3612424565b905090565b6000546001600160a01b03163314610f025760405162461bcd60e51b8152600401610ec2906139e8565b601754603290610f13908390613a1d565b1115610f595760405162461bcd60e51b8152602060048201526015602482015274115e18d959590819da599d081b585e081b1a5b5a5d605a1b6044820152606401610ec2565b8181905060176000828254610f6e9190613a1d565b90915550600090505b81811015610e9257610fb0838383818110610f9457610f94613b57565b9050602002016020810190610fa99190613531565b600161254b565b80610fba81613ae6565b915050610f77565b6000546001600160a01b03163314610fec5760405162461bcd60e51b8152600401610ec2906139e8565b601a80549115156101000261ff0019909216919091179055565b6001600160a01b0381166000908152600e602052604090205461103b5760405162461bcd60e51b8152600401610ec290613957565b6000611046600d5490565b6110509047613a1d565b9050600061107d8383611078866001600160a01b03166000908152600f602052604090205490565b612565565b90508061109c5760405162461bcd60e51b8152600401610ec29061399d565b6001600160a01b0383166000908152600f6020526040812080548392906110c4908490613a1d565b9250508190555080600d60008282546110dd9190613a1d565b909155506110ed905083826125ab565b604080516001600160a01b0385168152602081018390527fdf20fd1e76bc69d672e4814fafb2c449bba3a5369d8359adf9e05e6fde87b056910160405180910390a1505050565b610e928383836126c4565b600061114a836118fa565b8210611169576040516306ed618760e11b815260040160405180910390fd5b6005546001600160801b0316600080805b8381101561123557600081815260086020908152604091829020825160608101845290546001600160a01b0381168252600160a01b81046001600160401b031692820192909252600160e01b90910460ff1615801592820192909252906111e1575061122d565b80516001600160a01b0316156111f657805192505b876001600160a01b0316836001600160a01b0316141561122b578684141561122457509350610d2d92505050565b6001909301925b505b60010161117a565b50600080fd5b6000546001600160a01b031633146112655760405162461bcd60e51b8152600401610ec2906139e8565b805161127890601b906020840190613403565b5050565b6000546001600160a01b031633146112a65760405162461bcd60e51b8152600401610ec2906139e8565b604051600090339047908381818185875af1925050503d80600081146112e8576040519150601f19603f3d011682016040523d82523d6000602084013e6112ed565b606091505b50509050806112fb57600080fd5b50565b610e9283838360405180602001604052806000815250611ee3565b6001600160a01b0381166000908152600e602052604090205461134e5760405162461bcd60e51b8152600401610ec290613957565b6001600160a01b0382166000908152601160205260408120546040516370a0823160e01b81523060048201526001600160a01b038516906370a082319060240160206040518083038186803b1580156113a657600080fd5b505afa1580156113ba573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906113de9190613825565b6113e89190613a1d565b90506000611421838361107887876001600160a01b03918216600090815260126020908152604080832093909416825291909152205490565b9050806114405760405162461bcd60e51b8152600401610ec29061399d565b6001600160a01b03808516600090815260126020908152604080832093871683529290529081208054839290611477908490613a1d565b90915550506001600160a01b038416600090815260116020526040812080548392906114a4908490613a1d565b909155506114b590508484836128e1565b604080516001600160a01b038581168252602082018490528616917f3be5b7a71e84ed12875d241991c70855ac5817d847039e17a9d895c1ceb0f18a910160405180910390a250505050565b611509611e97565b61156a5760405162461bcd60e51b815260206004820152602c60248201527f5075626c696353616c657341637469766174696f6e3a2053616c65206973206e60448201526b1bdd081858dd1a5d985d195960a21b6064820152608401610ec2565b6115776032612710613a68565b816016546015546115889190613a1d565b6115929190613a1d565b11156115d95760405162461bcd60e51b8152602060048201526016602482015275115e18d95959081cd85b195cc81b585e081b1a5b5a5d60521b6044820152606401610ec2565b600281111561162a5760405162461bcd60e51b815260206004820152601960248201527f457863656564206d6178206d696e7420706572206d696e742e000000000000006044820152606401610ec2565b33600090815260196020526040902054600490611648908390613a1d565b11156116965760405162461bcd60e51b815260206004820152601a60248201527f457863656564206d6178206d696e7420706572206d696e7465720000000000006044820152606401610ec2565b3233146116e55760405162461bcd60e51b815260206004820152601d60248201527f434f4e5452414354535f4e4f545f414c4c4f5745445f544f5f4d494e540000006044820152606401610ec2565b601a54610100900460ff16156117375760405162461bcd60e51b815260206004820152601760248201527654686520636f6e7472616374206973207061757365642160481b6044820152606401610ec2565b61173f611a1a565b6117499082613a49565b3410156117885760405162461bcd60e51b815260206004820152600d60248201526c092dcc6dee4e4cac6e8408aa89609b1b6044820152606401610ec2565b33600090815260196020526040812080548392906117a7908490613a1d565b9250508190555080601660008282546117c09190613a1d565b909155506112fb9050338261254b565b6000546001600160a01b031633146117fa5760405162461bcd60e51b8152600401610ec2906139e8565b601a805460ff1916911515919091179055565b6005546000906001600160801b031681805b8281101561189f57600081815260086020908152604091829020825160608101845290546001600160a01b0381168252600160a01b81046001600160401b031692820192909252600160e01b90910460ff16151591810182905290611896578583141561188f5750949350505050565b6001909201915b5060010161181f565b506040516329c8c00760e21b815260040160405180910390fd5b6000546001600160a01b031633146118e35760405162461bcd60e51b8152600401610ec2906139e8565b600155565b60006118f382612933565b5192915050565b60006001600160a01b038216611923576040516323d3ad8160e21b815260040160405180910390fd5b506001600160a01b03166000908152600960205260409020546001600160401b031690565b6000546001600160a01b031633146119725760405162461bcd60e51b8152600401610ec2906139e8565b601a5460ff166119cf5760405162461bcd60e51b815260206004820152602260248201527f4e6f74207468652074696d6520746f2052656e6f756e6365204f776e65727368604482015261069760f41b6064820152608401610ec2565b6119d96000612a57565b565b6000601082815481106119f0576119f0613b57565b6000918252602090912001546001600160a01b031692915050565b606060078054610d4290613aab565b6000611a24611e97565b15611a365750670214e8348c4f000090565b5067016345785d8a000090565b611a4b611eaf565b611aa95760405162461bcd60e51b815260206004820152602960248201527f50726553616c657341637469766174696f6e3a2053616c65206973206e6f74206044820152681858dd1a5d985d195960ba1b6064820152608401610ec2565b600454339082906001600160a01b0316611ac383836121fe565b6001600160a01b031614611b195760405162461bcd60e51b815260206004820152601860248201527f55736572206973206e6f74206f6e2077686974656c69737400000000000000006044820152606401610ec2565b61271084601654601554611b2d9190613a1d565b611b379190613a1d565b1115611b7e5760405162461bcd60e51b8152602060048201526016602482015275115e18d95959081cd85b195cc81b585e081b1a5b5a5d60521b6044820152606401610ec2565b61232884601554611b8f9190613a1d565b1115611bdd5760405162461bcd60e51b815260206004820152601a60248201527f457863656564207072652d73616c6573206d6178206c696d69740000000000006044820152606401610ec2565b33600090815260186020526040902054600290611bfb908690613a1d565b1115611c425760405162461bcd60e51b8152602060048201526016602482015275457863656564207369676e6564207175616e7469747960501b6044820152606401610ec2565b323314611c915760405162461bcd60e51b815260206004820152601d60248201527f434f4e5452414354535f4e4f545f414c4c4f5745445f544f5f4d494e540000006044820152606401610ec2565b601a54610100900460ff1615611ce35760405162461bcd60e51b815260206004820152601760248201527654686520636f6e7472616374206973207061757365642160481b6044820152606401610ec2565b611ceb611a1a565b611cf59085613a49565b341015611d345760405162461bcd60e51b815260206004820152600d60248201526c092dcc6dee4e4cac6e8408aa89609b1b6044820152606401610ec2565b3360009081526018602052604081208054869290611d53908490613a1d565b925050819055508360156000828254611d6c9190613a1d565b90915550611d7c9050338561254b565b50505050565b6001600160a01b038216331415611dac5760405163b06307db60e01b815260040160405180910390fd5b336000818152600b602090815260408083206001600160a01b03871680855290835292819020805460ff191686151590811790915590519081529192917f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a35050565b6000546001600160a01b03163314611e425760405162461bcd60e51b8152600401610ec2906139e8565b60005b6013548110156112fb57600060138281548110611e6457611e64613b57565b6000918252602090912001546001600160a01b03169050611e8481611006565b5080611e8f81613ae6565b915050611e45565b600080600154118015610ed357505060015442101590565b600080600254118015611ec457506000600354115b8015611ed257506002544210155b8015610ed357505060035442111590565b611eee8484846126c4565b611efa84848484612aa7565b611d7c576040516368d2bf6b60e11b815260040160405180910390fd5b6060611f2282612392565b611f865760405162461bcd60e51b815260206004820152602f60248201527f4552433732314d657461646174613a2055524920717565727920666f72206e6f60448201526e3732bc34b9ba32b73a103a37b5b2b760891b6064820152608401610ec2565b601a5462010000900460ff1661202857601c8054611fa390613aab565b80601f0160208091040260200160405190810160405280929190818152602001828054611fcf90613aab565b801561201c5780601f10611ff15761010080835404028352916020019161201c565b820191906000526020600020905b815481529060010190602001808311611fff57829003601f168201915b50505050509050919050565b6000612032612bb5565b90506000815111612052576040518060200160405280600081525061207d565b8061205c84612bc4565b60405160200161206d9291906138d8565b6040516020818303038152906040525b9392505050565b600080612119612092612424565b604080517ff59780ff8f4ba89ed09d6c9fc5aec79093994c7234326cb09aafc9bf724f07416020808301919091526001600160a01b0388168284015282518083038401815260608301845280519082012061190160f01b6080840152608283019490945260a2808301949094528251808303909401845260c2909101909152815191012090565b6040517f19457468657265756d205369676e6564204d6573736167653a0a3332000000006020820152603c810191909152605c0160408051601f1981840301815291905280516020909101209392505050565b6000546001600160a01b031633146121965760405162461bcd60e51b8152600401610ec2906139e8565b600480546001600160a01b0319166001600160a01b0392909216919091179055565b6000546001600160a01b031633146121e25760405162461bcd60e51b8152600401610ec2906139e8565b601a8054911515620100000262ff000019909216919091179055565b600061207d61220c84612084565b83612cc1565b6000546001600160a01b0316331461223c5760405162461bcd60e51b8152600401610ec2906139e8565b818110156122b25760405162461bcd60e51b815260206004820152603c60248201527f50726553616c657341637469766174696f6e3a20456e642074696d652073686f60448201527f756c64206265206c61746572207468616e2073746172742074696d65000000006064820152608401610ec2565b600291909155600355565b6000546001600160a01b031633146122e75760405162461bcd60e51b8152600401610ec2906139e8565b805161127890601c906020840190613403565b6000546001600160a01b031633146123245760405162461bcd60e51b8152600401610ec2906139e8565b6001600160a01b0381166123895760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610ec2565b6112fb81612a57565b6005546000906001600160801b031682108015610d2d575050600090815260086020526040902054600160e01b900460ff161590565b6000828152600a602052604080822080546001600160a01b0319166001600160a01b0387811691821790925591518593918516917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591a4505050565b6000306001600160a01b037f00000000000000000000000033a237b384b7065c815f7c745d73a0acf140449c1614801561247d57507f000000000000000000000000000000000000000000000000000000000000000146145b156124a757507f77b5c75f2230fe1afa15931d71d4d50364f2212a9147f27635c03904a9176ee990565b50604080517f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f6020808301919091527f7dc4e3562c2d39c1d8e089e2cd1e5dd7798b8e941c4eb3bfd30806124b99196f828401527fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc660608301524660808301523060a0808401919091528351808403909101815260c0909201909252805191012090565b611278828260405180602001604052806000815250612ce5565b600c546001600160a01b0384166000908152600e60205260408120549091839161258f9086613a49565b6125999190613a35565b6125a39190613a68565b949350505050565b804710156125fb5760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a20696e73756666696369656e742062616c616e63650000006044820152606401610ec2565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114612648576040519150601f19603f3d011682016040523d82523d6000602084013e61264d565b606091505b5050905080610e925760405162461bcd60e51b815260206004820152603a60248201527f416464726573733a20756e61626c6520746f2073656e642076616c75652c207260448201527f6563697069656e74206d617920686176652072657665727465640000000000006064820152608401610ec2565b60006126cf82612933565b80519091506000906001600160a01b0316336001600160a01b031614806126fd575081516126fd9033610c08565b8061271857503361270d84610dc5565b6001600160a01b0316145b90508061273857604051632ce44b5f60e11b815260040160405180910390fd5b846001600160a01b031682600001516001600160a01b03161461276d5760405162a1148160e81b815260040160405180910390fd5b6001600160a01b03841661279457604051633a954ecd60e21b815260040160405180910390fd5b6127a460008484600001516123c8565b6001600160a01b038581166000908152600960209081526040808320805467ffffffffffffffff198082166001600160401b0392831660001901831617909255898616808652838620805493841693831660019081018416949094179055898652600890945282852080546001600160e01b031916909417600160a01b429092169190910217909255908601808352912054909116612897576005546001600160801b031681101561289757825160008281526008602090815260409091208054918601516001600160401b0316600160a01b026001600160e01b03199092166001600160a01b03909316929092171790555b5082846001600160a01b0316866001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a45b5050505050565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b179052610e92908490612cf2565b604080516060810182526000808252602082018190529181019190915260055482906001600160801b0316811015612a3e57600081815260086020908152604091829020825160608101845290546001600160a01b0381168252600160a01b81046001600160401b031692820192909252600160e01b90910460ff16151591810182905290612a3c5780516001600160a01b0316156129d3579392505050565b5060001901600081815260086020908152604091829020825160608101845290546001600160a01b038116808352600160a01b82046001600160401b031693830193909352600160e01b900460ff1615159281019290925215612a37579392505050565b6129d3565b505b604051636f96cda160e11b815260040160405180910390fd5b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b60006001600160a01b0384163b15612baa57604051630a85bd0160e11b81526001600160a01b0385169063150b7a0290612aeb903390899088908890600401613907565b602060405180830381600087803b158015612b0557600080fd5b505af1925050508015612b35575060408051601f3d908101601f19168201909252612b32918101906137a7565b60015b612b90573d808015612b63576040519150601f19603f3d011682016040523d82523d6000602084013e612b68565b606091505b508051612b88576040516368d2bf6b60e11b815260040160405180910390fd5b805181602001fd5b6001600160e01b031916630a85bd0160e11b1490506125a3565b506001949350505050565b6060601b8054610d4290613aab565b606081612be85750506040805180820190915260018152600360fc1b602082015290565b8160005b8115612c125780612bfc81613ae6565b9150612c0b9050600a83613a35565b9150612bec565b6000816001600160401b03811115612c2c57612c2c613b6d565b6040519080825280601f01601f191660200182016040528015612c56576020820181803683370190505b5090505b84156125a357612c6b600183613a68565b9150612c78600a86613b01565b612c83906030613a1d565b60f81b818381518110612c9857612c98613b57565b60200101906001600160f81b031916908160001a905350612cba600a86613a35565b9450612c5a565b6000806000612cd08585612dc4565b91509150612cdd81612e34565b509392505050565b610e928383836001612fef565b6000612d47826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b03166131779092919063ffffffff16565b805190915015610e925780806020019051810190612d65919061376d565b610e925760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6044820152691bdd081cdd58d8d9595960b21b6064820152608401610ec2565b600080825160411415612dfb5760208301516040840151606085015160001a612def87828585613186565b94509450505050612e2d565b825160401415612e255760208301516040840151612e1a868383613273565b935093505050612e2d565b506000905060025b9250929050565b6000816004811115612e4857612e48613b41565b1415612e515750565b6001816004811115612e6557612e65613b41565b1415612eb35760405162461bcd60e51b815260206004820152601860248201527f45434453413a20696e76616c6964207369676e617475726500000000000000006044820152606401610ec2565b6002816004811115612ec757612ec7613b41565b1415612f155760405162461bcd60e51b815260206004820152601f60248201527f45434453413a20696e76616c6964207369676e6174757265206c656e677468006044820152606401610ec2565b6003816004811115612f2957612f29613b41565b1415612f825760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202773272076616c604482015261756560f01b6064820152608401610ec2565b6004816004811115612f9657612f96613b41565b14156112fb5760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202776272076616c604482015261756560f01b6064820152608401610ec2565b6005546001600160801b03166001600160a01b03851661302157604051622e076360e81b815260040160405180910390fd5b8361303f5760405163b562e8dd60e01b815260040160405180910390fd5b6001600160a01b038516600081815260096020908152604080832080546001600160801b031981166001600160401b038083168c0181169182176801000000000000000067ffffffffffffffff1990941690921783900481168c018116909202179091558584526008909252822080546001600160e01b031916909317600160a01b42909216919091021790915581905b858110156131515760405182906001600160a01b038916906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a483801561312757506131256000888488612aa7565b155b15613145576040516368d2bf6b60e11b815260040160405180910390fd5b600191820191016130d0565b50600580546001600160801b0319166001600160801b03929092169190911790556128da565b60606125a384846000856132a2565b6000807f7fffffffffffffffffffffffffffffff5d576e7357a4501ddfe92f46681b20a08311156131bd575060009050600361326a565b8460ff16601b141580156131d557508460ff16601c14155b156131e6575060009050600461326a565b6040805160008082526020820180845289905260ff881692820192909252606081018690526080810185905260019060a0016020604051602081039080840390855afa15801561323a573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b0381166132635760006001925092505061326a565b9150600090505b94509492505050565b6000806001600160ff1b03831660ff84901c601b0161329487828885613186565b935093505050935093915050565b6060824710156133035760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f6044820152651c8818d85b1b60d21b6064820152608401610ec2565b843b6133515760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610ec2565b600080866001600160a01b0316858760405161336d91906138bc565b60006040518083038185875af1925050503d80600081146133aa576040519150601f19603f3d011682016040523d82523d6000602084013e6133af565b606091505b50915091506133bf8282866133ca565b979650505050505050565b606083156133d957508161207d565b8251156133e95782518084602001fd5b8160405162461bcd60e51b8152600401610ec29190613944565b82805461340f90613aab565b90600052602060002090601f0160209004810192826134315760008555613477565b82601f1061344a57805160ff1916838001178555613477565b82800160010185558215613477579182015b8281111561347757825182559160200191906001019061345c565b50613483929150613487565b5090565b5b808211156134835760008155600101613488565b60006001600160401b03808411156134b6576134b6613b6d565b604051601f8501601f19908116603f011681019082821181831017156134de576134de613b6d565b816040528093508581528686860111156134f757600080fd5b858560208301376000602087830101525050509392505050565b600082601f83011261352257600080fd5b61207d8383356020850161349c565b60006020828403121561354357600080fd5b813561207d81613b83565b6000806040838503121561356157600080fd5b823561356c81613b83565b9150602083013561357c81613b83565b809150509250929050565b60008060006060848603121561359c57600080fd5b83356135a781613b83565b925060208401356135b781613b83565b929592945050506040919091013590565b600080600080608085870312156135de57600080fd5b84356135e981613b83565b935060208501356135f981613b83565b92506040850135915060608501356001600160401b0381111561361b57600080fd5b61362787828801613511565b91505092959194509250565b6000806040838503121561364657600080fd5b823561365181613b83565b9150602083013561357c81613b98565b6000806040838503121561367457600080fd5b823561367f81613b83565b915060208301356001600160401b0381111561369a57600080fd5b6136a685828601613511565b9150509250929050565b600080604083850312156136c357600080fd5b82356136ce81613b83565b946020939093013593505050565b600080602083850312156136ef57600080fd5b82356001600160401b038082111561370657600080fd5b818501915085601f83011261371a57600080fd5b81358181111561372957600080fd5b8660208260051b850101111561373e57600080fd5b60209290920196919550909350505050565b60006020828403121561376257600080fd5b813561207d81613b98565b60006020828403121561377f57600080fd5b815161207d81613b98565b60006020828403121561379c57600080fd5b813561207d81613ba6565b6000602082840312156137b957600080fd5b815161207d81613ba6565b6000602082840312156137d657600080fd5b81356001600160401b038111156137ec57600080fd5b8201601f810184136137fd57600080fd5b6125a38482356020840161349c565b60006020828403121561381e57600080fd5b5035919050565b60006020828403121561383757600080fd5b5051919050565b6000806040838503121561385157600080fd5b8235915060208301356001600160401b0381111561369a57600080fd5b6000806040838503121561388157600080fd5b50508035926020909101359150565b600081518084526138a8816020860160208601613a7f565b601f01601f19169290920160200192915050565b600082516138ce818460208701613a7f565b9190910192915050565b600083516138ea818460208801613a7f565b8351908301906138fe818360208801613a7f565b01949350505050565b6001600160a01b038581168252841660208201526040810183905260806060820181905260009061393a90830184613890565b9695505050505050565b60208152600061207d6020830184613890565b60208082526026908201527f5061796d656e7453706c69747465723a206163636f756e7420686173206e6f2060408201526573686172657360d01b606082015260800190565b6020808252602b908201527f5061796d656e7453706c69747465723a206163636f756e74206973206e6f742060408201526a191d59481c185e5b595b9d60aa1b606082015260800190565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60008219821115613a3057613a30613b15565b500190565b600082613a4457613a44613b2b565b500490565b6000816000190483118215151615613a6357613a63613b15565b500290565b600082821015613a7a57613a7a613b15565b500390565b60005b83811015613a9a578181015183820152602001613a82565b83811115611d7c5750506000910152565b600181811c90821680613abf57607f821691505b60208210811415613ae057634e487b7160e01b600052602260045260246000fd5b50919050565b6000600019821415613afa57613afa613b15565b5060010190565b600082613b1057613b10613b2b565b500690565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052601260045260246000fd5b634e487b7160e01b600052602160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b6001600160a01b03811681146112fb57600080fd5b80151581146112fb57600080fd5b6001600160e01b0319811681146112fb57600080fdfea26469706673582212208a240ab2424212620871c9030a120776f1a5d2cd1c6c1a23ee8da0645a42082664736f6c63430008070033

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

0000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000005068747470733a2f2f7473756b692e6d7970696e6174612e636c6f75642f697066732f516d66553153747032754546534c6765344c4a6b4c5837526b6e46423274554e506170713859717731343762427700000000000000000000000000000000

-----Decoded View---------------
Arg [0] : _notRevealedUri (string): https://tsuki.mypinata.cloud/ipfs/QmfU1Stp2uEFSLge4LJkLX7RknFB2tUNPapq8Yqw147bBw

-----Encoded View---------------
5 Constructor Arguments found :
Arg [0] : 0000000000000000000000000000000000000000000000000000000000000020
Arg [1] : 0000000000000000000000000000000000000000000000000000000000000050
Arg [2] : 68747470733a2f2f7473756b692e6d7970696e6174612e636c6f75642f697066
Arg [3] : 732f516d66553153747032754546534c6765344c4a6b4c5837526b6e46423274
Arg [4] : 554e506170713859717731343762427700000000000000000000000000000000


Deployed Bytecode Sourcemap

141893:6010:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;131295:40;105428:10;131295:40;;;-1:-1:-1;;;;;10262:32:1;;;10244:51;;131325:9:0;10326:2:1;10311:18;;10304:34;10217:18;131295:40:0;;;;;;;141893:6010;;;;;142105:68;;;;;;;;;;;;;:::i;:::-;;;11459:25:1;;;11447:2;11432:18;142105:68:0;;;;;;;;142914:36;;;;;;;;;;;;;;;;111589:372;;;;;;;;;;-1:-1:-1;111589:372:0;;;;;:::i;:::-;;:::i;:::-;;;11286:14:1;;11279:22;11261:41;;11249:2;11234:18;111589:372:0;11121:187:1;114199:100:0;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;115702:204::-;;;;;;;;;;-1:-1:-1;115702:204:0;;;;;:::i;:::-;;:::i;:::-;;;-1:-1:-1;;;;;10018:32:1;;;10000:51;;9988:2;9973:18;115702:204:0;9854:203:1;115265:371:0;;;;;;;;;;-1:-1:-1;115265:371:0;;;;;:::i;:::-;;:::i;:::-;;142407:44;;;;;;;;;;;;142450:1;142407:44;;139343:122;;;;;;;;;;;;;:::i;145706:351::-;;;;;;;;;;-1:-1:-1;145706:351:0;;;;;:::i;:::-;;:::i;146547:86::-;;;;;;;;;;-1:-1:-1;146547:86:0;;;;;:::i;:::-;;:::i;108826:280::-;;;;;;;;;;;;109071:12;;-1:-1:-1;;;;;;;;109071:12:0;;;;109055:13;;;:28;;;;109048:35;;108826:280;133081:566;;;;;;;;;;-1:-1:-1;133081:566:0;;;;;:::i;:::-;;:::i;116559:170::-;;;;;;;;;;-1:-1:-1;116559:170:0;;;;;:::i;:::-;;:::i;110412:1105::-;;;;;;;;;;-1:-1:-1;110412:1105:0;;;;;:::i;:::-;;:::i;146201:120::-;;;;;;;;;;-1:-1:-1;146201:120:0;;;;;:::i;:::-;;:::i;142057:41::-;;;;;;;;;;;;142096:2;142057:41;;139570:32;;;;;;;;;;;;;;;;131426:91;;;;;;;;;;-1:-1:-1;131497:12:0;;131426:91;;147514:165;;;:::i;132555:135::-;;;;;;;;;;-1:-1:-1;132555:135:0;;;;;:::i;:::-;-1:-1:-1;;;;;132652:21:0;;;132625:7;132652:21;;;:14;:21;;;;;;;;:30;;;;;;;;;;;;;132555:135;116800:185;;;;;;;;;;-1:-1:-1;116800:185:0;;;;;:::i;:::-;;:::i;142180:47::-;;;;;;;;;;;;142223:4;142180:47;;133915:641;;;;;;;;;;-1:-1:-1;133915:641:0;;;;;:::i;:::-;;:::i;144774:924::-;;;;;;:::i;:::-;;:::i;146641:114::-;;;;;;;;;;-1:-1:-1;146641:114:0;;;;;:::i;:::-;;:::i;109399:713::-;;;;;;;;;;-1:-1:-1;109399:713:0;;;;;:::i;:::-;;:::i;143257:28::-;;;;;;;;;;-1:-1:-1;143257:28:0;;;;;;;;;;;143224:26;;;;;;;;;;-1:-1:-1;143224:26:0;;;;;;;;;;;141664:119;;;;;;;;;;-1:-1:-1;141664:119:0;;;;;:::i;:::-;;:::i;114008:124::-;;;;;;;;;;-1:-1:-1;114008:124:0;;;;;:::i;:::-;;:::i;112025:206::-;;;;;;;;;;-1:-1:-1;112025:206:0;;;;;:::i;:::-;;:::i;147326:180::-;;;;;;;;;;;;;:::i;143040:59::-;;;;;;;;;;-1:-1:-1;143040:59:0;;;;;:::i;:::-;;;;;;;;;;;;;;143177:40;;;;;;;;;;-1:-1:-1;143177:40:0;;;;;;;;142234:51;;;;;;;;;;;;142276:9;142234:51;;132781:100;;;;;;;;;;-1:-1:-1;132781:100:0;;;;;:::i;:::-;;:::i;136716:87::-;;;;;;;;;;-1:-1:-1;136762:7:0;136789:6;-1:-1:-1;;;;;136789:6:0;136716:87;;143106:62;;;;;;;;;;-1:-1:-1;143106:62:0;;;;;:::i;:::-;;;;;;;;;;;;;;114368:104;;;;;;;;;;;;;:::i;132277:109::-;;;;;;;;;;-1:-1:-1;132277:109:0;;;;;:::i;:::-;-1:-1:-1;;;;;132360:18:0;132333:7;132360:18;;;:9;:18;;;;;;;132277:109;143535:183;;;;;;;;;;;;;:::i;142957:39::-;;;;;;;;;;;;;;;;143726:1040;;;;;;:::i;:::-;;:::i;115978:279::-;;;;;;;;;;-1:-1:-1;115978:279:0;;;;;:::i;:::-;;:::i;147684:214::-;;;;;;;;;;;;;:::i;139609:30::-;;;;;;;;;;;;;;;;142354:46;;;;;;;;;;;;142399:1;142354:46;;141419:167;;;;;;;;;;;;;:::i;140155:258::-;;;;;;;;;;;;;:::i;117056:342::-;;;;;;;;;;-1:-1:-1;117056:342:0;;;;;:::i;:::-;;:::i;143003:28::-;;;;;;;;;;;;;;;;138302:81;;;;;;;;;;;;138348:35;138302:81;;146767:551;;;;;;;;;;-1:-1:-1;146767:551:0;;;;;:::i;:::-;;:::i;132073:105::-;;;;;;;;;;-1:-1:-1;132073:105:0;;;;;:::i;:::-;-1:-1:-1;;;;;132154:16:0;132127:7;132154:16;;;:7;:16;;;;;;;132073:105;138773:333;;;;;;;;;;-1:-1:-1;138773:333:0;;;;;:::i;:::-;;:::i;138485:110::-;;;;;;;;;;-1:-1:-1;138485:110:0;;;;;:::i;:::-;;:::i;142292:55::-;;;;;;;;;;;;142337:10;142292:55;;131863:119;;;;;;;;;;-1:-1:-1;131863:119:0;;;;;:::i;:::-;-1:-1:-1;;;;;131948:26:0;131921:7;131948:26;;;:19;:26;;;;;;;131863:119;142005:45;;;;;;;;;;;;142045:5;142005:45;;146448:90;;;;;;;;;;-1:-1:-1;146448:90:0;;;;;:::i;:::-;;:::i;131611:95::-;;;;;;;;;;-1:-1:-1;131684:14:0;;131611:95;;138603:162;;;;;;;;;;-1:-1:-1;138603:162:0;;;;;:::i;:::-;;:::i;141004:35::-;;;;;;;;;;;;;;;;116328:164;;;;;;;;;;-1:-1:-1;116328:164:0;;;;;:::i;:::-;-1:-1:-1;;;;;116449:25:0;;;116425:4;116449:25;;;:18;:25;;;;;;;;:35;;;;;;;;;;;;;;;116328:164;140559:334;;;;;;;;;;-1:-1:-1;140559:334:0;;;;;:::i;:::-;;:::i;138392:30::-;;;;;;;;;;-1:-1:-1;138392:30:0;;;;-1:-1:-1;;;;;138392:30:0;;;146065:128;;;;;;;;;;-1:-1:-1;146065:128:0;;;;;:::i;:::-;;:::i;137625:201::-;;;;;;;;;;-1:-1:-1;137625:201:0;;;;;:::i;:::-;;:::i;142105:68::-;142145:28;142096:2;142045:5;142145:28;:::i;:::-;142105:68;:::o;111589:372::-;111691:4;-1:-1:-1;;;;;;111728:40:0;;-1:-1:-1;;;111728:40:0;;:105;;-1:-1:-1;;;;;;;111785:48:0;;-1:-1:-1;;;111785:48:0;111728:105;:172;;;-1:-1:-1;;;;;;;111850:50:0;;-1:-1:-1;;;111850:50:0;111728:172;:225;;;-1:-1:-1;;;;;;;;;;2922:40:0;;;111917:36;111708:245;111589:372;-1:-1:-1;;111589:372:0:o;114199:100::-;114253:13;114286:5;114279:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;114199:100;:::o;115702:204::-;115770:7;115795:16;115803:7;115795;:16::i;:::-;115790:64;;115820:34;;-1:-1:-1;;;115820:34:0;;;;;;;;;;;115790:64;-1:-1:-1;115874:24:0;;;;:15;:24;;;;;;-1:-1:-1;;;;;115874:24:0;;115702:204::o;115265:371::-;115338:13;115354:24;115370:7;115354:15;:24::i;:::-;115338:40;;115399:5;-1:-1:-1;;;;;115393:11:0;:2;-1:-1:-1;;;;;115393:11:0;;115389:48;;;115413:24;;-1:-1:-1;;;115413:24:0;;;;;;;;;;;115389:48;105428:10;-1:-1:-1;;;;;115454:21:0;;;;;;:63;;-1:-1:-1;115480:37:0;115497:5;105428:10;116328:164;:::i;115480:37::-;115479:38;115454:63;115450:138;;;115541:35;;-1:-1:-1;;;115541:35:0;;;;;;;;;;;115450:138;115600:28;115609:2;115613:7;115622:5;115600:8;:28::i;:::-;115327:309;115265:371;;:::o;139343:122::-;139410:7;136789:6;;-1:-1:-1;;;;;136789:6:0;105428:10;136936:23;136928:68;;;;-1:-1:-1;;;136928:68:0;;;;;;;:::i;:::-;;;;;;;;;139437:20:::1;:18;:20::i;:::-;139430:27;;139343:122:::0;:::o;145706:351::-;136762:7;136789:6;-1:-1:-1;;;;;136789:6:0;105428:10;136936:23;136928:68;;;;-1:-1:-1;;;136928:68:0;;;;;;;:::i;:::-;145802:9:::1;::::0;142096:2:::1;::::0;145802:28:::1;::::0;145814:9;;145802:28:::1;:::i;:::-;:44;;145780:115;;;::::0;-1:-1:-1;;;145780:115:0;;19291:2:1;145780:115:0::1;::::0;::::1;19273:21:1::0;19330:2;19310:18;;;19303:30;-1:-1:-1;;;19349:18:1;;;19342:51;19410:18;;145780:115:0::1;19089:345:1::0;145780:115:0::1;145921:9;;:16;;145908:9;;:29;;;;;;;:::i;:::-;::::0;;;-1:-1:-1;145955:9:0::1;::::0;-1:-1:-1;145950:100:0::1;145970:20:::0;;::::1;145950:100;;;146012:26;146022:9;;146032:1;146022:12;;;;;;;:::i;:::-;;;;;;;;;;;;;;:::i;:::-;146036:1;146012:9;:26::i;:::-;145992:3:::0;::::1;::::0;::::1;:::i;:::-;;;;145950:100;;146547:86:::0;136762:7;136789:6;-1:-1:-1;;;;;136789:6:0;105428:10;136936:23;136928:68;;;;-1:-1:-1;;;136928:68:0;;;;;;;:::i;:::-;146610:6:::1;:15:::0;;;::::1;;;;-1:-1:-1::0;;146610:15:0;;::::1;::::0;;;::::1;::::0;;146547:86::o;133081:566::-;-1:-1:-1;;;;;133157:16:0;;133176:1;133157:16;;;:7;:16;;;;;;133149:71;;;;-1:-1:-1;;;133149:71:0;;;;;;;:::i;:::-;133233:21;133281:15;131684:14;;;131611:95;133281:15;133257:39;;:21;:39;:::i;:::-;133233:63;;133307:15;133325:58;133341:7;133350:13;133365:17;133374:7;-1:-1:-1;;;;;132360:18:0;132333:7;132360:18;;;:9;:18;;;;;;;132277:109;133365:17;133325:15;:58::i;:::-;133307:76;-1:-1:-1;133404:12:0;133396:68;;;;-1:-1:-1;;;133396:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;133477:18:0;;;;;;:9;:18;;;;;:29;;133499:7;;133477:18;:29;;133499:7;;133477:29;:::i;:::-;;;;;;;;133535:7;133517:14;;:25;;;;;;;:::i;:::-;;;;-1:-1:-1;133555:35:0;;-1:-1:-1;133573:7:0;133582;133555:17;:35::i;:::-;133606:33;;;-1:-1:-1;;;;;10262:32:1;;10244:51;;10326:2;10311:18;;10304:34;;;133606:33:0;;10217:18:1;133606:33:0;;;;;;;133138:509;;133081:566;:::o;116559:170::-;116693:28;116703:4;116709:2;116713:7;116693:9;:28::i;110412:1105::-;110501:7;110534:16;110544:5;110534:9;:16::i;:::-;110525:5;:25;110521:61;;110559:23;;-1:-1:-1;;;110559:23:0;;;;;;;;;;;110521:61;110618:13;;-1:-1:-1;;;;;110618:13:0;110593:22;;;110868:557;110888:14;110884:1;:18;110868:557;;;110928:31;110962:14;;;:11;:14;;;;;;;;;110928:48;;;;;;;;;-1:-1:-1;;;;;110928:48:0;;;;-1:-1:-1;;;110928:48:0;;-1:-1:-1;;;;;110928:48:0;;;;;;;;-1:-1:-1;;;110928:48:0;;;;;;;;;;;;;;;;110995:73;;111040:8;;;110995:73;111090:14;;-1:-1:-1;;;;;111090:28:0;;111086:111;;111163:14;;;-1:-1:-1;111086:111:0;111240:5;-1:-1:-1;;;;;111219:26:0;:17;-1:-1:-1;;;;;111219:26:0;;111215:195;;;111289:5;111274:11;:20;111270:85;;;-1:-1:-1;111330:1:0;-1:-1:-1;111323:8:0;;-1:-1:-1;;;111323:8:0;111270:85;111377:13;;;;;111215:195;110909:516;110868:557;110904:3;;110868:557;;;;111501:8;;;146201:120;136762:7;136789:6;-1:-1:-1;;;;;136789:6:0;105428:10;136936:23;136928:68;;;;-1:-1:-1;;;136928:68:0;;;;;;;:::i;:::-;146285:28;;::::1;::::0;:12:::1;::::0;:28:::1;::::0;::::1;::::0;::::1;:::i;:::-;;146201:120:::0;:::o;147514:165::-;136762:7;136789:6;-1:-1:-1;;;;;136789:6:0;105428:10;136936:23;136928:68;;;;-1:-1:-1;;;136928:68:0;;;;;;;:::i;:::-;147589:58:::1;::::0;147571:12:::1;::::0;147597:10:::1;::::0;147621:21:::1;::::0;147571:12;147589:58;147571:12;147589:58;147621:21;147597:10;147589:58:::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;147570:77;;;147666:7;147658:16;;;::::0;::::1;;147559:120;147514:165::o:0;116800:185::-;116938:39;116955:4;116961:2;116965:7;116938:39;;;;;;;;;;;;:16;:39::i;133915:641::-;-1:-1:-1;;;;;133997:16:0;;134016:1;133997:16;;;:7;:16;;;;;;133989:71;;;;-1:-1:-1;;;133989:71:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;131948:26:0;;134073:21;131948:26;;;:19;:26;;;;;;134097:30;;-1:-1:-1;;;134097:30:0;;134121:4;134097:30;;;10000:51:1;-1:-1:-1;;;;;134097:15:0;;;;;9973:18:1;;134097:30:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;:53;;;;:::i;:::-;134073:77;;134161:15;134179:65;134195:7;134204:13;134219:24;134228:5;134235:7;-1:-1:-1;;;;;132652:21:0;;;132625:7;132652:21;;;:14;:21;;;;;;;;:30;;;;;;;;;;;;;132555:135;134179:65;134161:83;-1:-1:-1;134265:12:0;134257:68;;;;-1:-1:-1;;;134257:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;134338:21:0;;;;;;;:14;:21;;;;;;;;:30;;;;;;;;;;;:41;;134372:7;;134338:21;:41;;134372:7;;134338:41;:::i;:::-;;;;-1:-1:-1;;;;;;;134390:26:0;;;;;;:19;:26;;;;;:37;;134420:7;;134390:26;:37;;134420:7;;134390:37;:::i;:::-;;;;-1:-1:-1;134440:47:0;;-1:-1:-1;134463:5:0;134470:7;134479;134440:22;:47::i;:::-;134503:45;;;-1:-1:-1;;;;;10262:32:1;;;10244:51;;10326:2;10311:18;;10304:34;;;134503:45:0;;;;;10217:18:1;134503:45:0;;;;;;;133978:578;;133915:641;;:::o;144774:924::-;141112:24;:22;:24::i;:::-;141090:118;;;;-1:-1:-1;;;141090:118:0;;16464:2:1;141090:118:0;;;16446:21:1;16503:2;16483:18;;;16476:30;16542:34;16522:18;;;16515:62;-1:-1:-1;;;16593:18:1;;;16586:42;16645:19;;141090:118:0;16262:408:1;141090:118:0;142145:28:::1;142096:2;142045:5;142145:28;:::i;:::-;144968:8;144945:20;;144925:17;;:40;;;;:::i;:::-;:51;;;;:::i;:::-;:85;;144903:157;;;::::0;-1:-1:-1;;;144903:157:0;;20044:2:1;144903:157:0::1;::::0;::::1;20026:21:1::0;20083:2;20063:18;;;20056:30;-1:-1:-1;;;20102:18:1;;;20095:52;20164:18;;144903:157:0::1;19842:346:1::0;144903:157:0::1;142450:1;145079:8;:28;;145071:76;;;::::0;-1:-1:-1;;;145071:76:0;;22230:2:1;145071:76:0::1;::::0;::::1;22212:21:1::0;22269:2;22249:18;;;22242:30;22308:27;22288:18;;;22281:55;22353:18;;145071:76:0::1;22028:349:1::0;145071:76:0::1;145210:10;145182:39;::::0;;;:27:::1;:39;::::0;;;;;142399:1:::1;::::0;145182:50:::1;::::0;145224:8;;145182:50:::1;:::i;:::-;:89;;145160:165;;;::::0;-1:-1:-1;;;145160:165:0;;21108:2:1;145160:165:0::1;::::0;::::1;21090:21:1::0;21147:2;21127:18;;;21120:30;21186:28;21166:18;;;21159:56;21232:18;;145160:165:0::1;20906:350:1::0;145160:165:0::1;145346:9;145359:10;145346:23;145338:64;;;::::0;-1:-1:-1;;;145338:64:0;;14289:2:1;145338:64:0::1;::::0;::::1;14271:21:1::0;14328:2;14308:18;;;14301:30;14367:31;14347:18;;;14340:59;14416:18;;145338:64:0::1;14087:353:1::0;145338:64:0::1;145424:6;::::0;::::1;::::0;::::1;;;145423:7;145415:43;;;::::0;-1:-1:-1;;;145415:43:0;;20756:2:1;145415:43:0::1;::::0;::::1;20738:21:1::0;20795:2;20775:18;;;20768:30;-1:-1:-1;;;20814:18:1;;;20807:53;20877:18;;145415:43:0::1;20554:347:1::0;145415:43:0::1;145511:10;:8;:10::i;:::-;145500:21;::::0;:8;:21:::1;:::i;:::-;145487:9;:34;;145479:60;;;::::0;-1:-1:-1;;;145479:60:0;;15769:2:1;145479:60:0::1;::::0;::::1;15751:21:1::0;15808:2;15788:18;;;15781:30;-1:-1:-1;;;15827:18:1;;;15820:43;15880:18;;145479:60:0::1;15567:337:1::0;145479:60:0::1;145580:10;145552:39;::::0;;;:27:::1;:39;::::0;;;;:51;;145595:8;;145552:39;:51:::1;::::0;145595:8;;145552:51:::1;:::i;:::-;;;;;;;;145638:8;145614:20;;:32;;;;;;;:::i;:::-;::::0;;;-1:-1:-1;145659:31:0::1;::::0;-1:-1:-1;145669:10:0::1;145681:8:::0;145659:9:::1;:31::i;146641:114::-:0;136762:7;136789:6;-1:-1:-1;;;;;136789:6:0;105428:10;136936:23;136928:68;;;;-1:-1:-1;;;136928:68:0;;;;;;;:::i;:::-;146718:20:::1;:29:::0;;-1:-1:-1;;146718:29:0::1;::::0;::::1;;::::0;;;::::1;::::0;;146641:114::o;109399:713::-;109511:13;;109466:7;;-1:-1:-1;;;;;109511:13:0;109466:7;;109725:328;109745:14;109741:1;:18;109725:328;;;109785:31;109819:14;;;:11;:14;;;;;;;;;109785:48;;;;;;;;;-1:-1:-1;;;;;109785:48:0;;;;-1:-1:-1;;;109785:48:0;;-1:-1:-1;;;;;109785:48:0;;;;;;;;-1:-1:-1;;;109785:48:0;;;;;;;;;;;;;;109852:186;;109917:5;109902:11;:20;109898:85;;;-1:-1:-1;109958:1:0;109399:713;-1:-1:-1;;;;109399:713:0:o;109898:85::-;110005:13;;;;;109852:186;-1:-1:-1;109761:3:0;;109725:328;;;;110081:23;;-1:-1:-1;;;110081:23:0;;;;;;;;;;;141664:119;136762:7;136789:6;-1:-1:-1;;;;;136789:6:0;105428:10;136936:23;136928:68;;;;-1:-1:-1;;;136928:68:0;;;;;;;:::i;:::-;141742:20:::1;:33:::0;141664:119::o;114008:124::-;114072:7;114099:20;114111:7;114099:11;:20::i;:::-;:25;;114008:124;-1:-1:-1;;114008:124:0:o;112025:206::-;112089:7;-1:-1:-1;;;;;112113:19:0;;112109:60;;112141:28;;-1:-1:-1;;;112141:28:0;;;;;;;;;;;112109:60;-1:-1:-1;;;;;;112195:19:0;;;;;:12;:19;;;;;:27;-1:-1:-1;;;;;112195:27:0;;112025:206::o;147326:180::-;136762:7;136789:6;-1:-1:-1;;;;;136789:6:0;105428:10;136936:23;136928:68;;;;-1:-1:-1;;;136928:68:0;;;;;;;:::i;:::-;147399:20:::1;::::0;::::1;;147391:66;;;::::0;-1:-1:-1;;;147391:66:0;;22584:2:1;147391:66:0::1;::::0;::::1;22566:21:1::0;22623:2;22603:18;;;22596:30;22662:34;22642:18;;;22635:62;-1:-1:-1;;;22713:18:1;;;22706:32;22755:19;;147391:66:0::1;22382:398:1::0;147391:66:0::1;147468:30;147495:1;147468:18;:30::i;:::-;147326:180::o:0;132781:100::-;132832:7;132859;132867:5;132859:14;;;;;;;;:::i;:::-;;;;;;;;;;;-1:-1:-1;;;;;132859:14:0;;132781:100;-1:-1:-1;;132781:100:0:o;114368:104::-;114424:13;114457:7;114450:14;;;;;:::i;143535:183::-;143576:7;143600:24;:22;:24::i;:::-;143596:82;;;-1:-1:-1;142337:10:0;;143535:183::o;143596:82::-;-1:-1:-1;142276:9:0;;143535:183::o;143726:1040::-;139709:21;:19;:21::i;:::-;139687:112;;;;-1:-1:-1;;;139687:112:0;;13450:2:1;139687:112:0;;;13432:21:1;13489:2;13469:18;;;13462:30;13528:34;13508:18;;;13501:62;-1:-1:-1;;;13579:18:1;;;13572:39;13628:19;;139687:112:0;13248:405:1;139687:112:0;139234:15:::1;::::0;143901:10:::1;::::0;143913:9;;-1:-1:-1;;;;;139234:15:0::1;139198:32;143901:10:::0;143913:9;139198:13:::1;:32::i;:::-;-1:-1:-1::0;;;;;139198:51:0::1;;139190:125;;;::::0;-1:-1:-1;;;139190:125:0;;16111:2:1;139190:125:0::1;::::0;::::1;16093:21:1::0;16150:2;16130:18;;;16123:30;16189:26;16169:18;;;16162:54;16233:18;;139190:125:0::1;15909:348:1::0;139190:125:0::1;142045:5:::2;144006:8;143983:20;;143963:17;;:40;;;;:::i;:::-;:51;;;;:::i;:::-;:85;;143941:157;;;::::0;-1:-1:-1;;;143941:157:0;;20044:2:1;143941:157:0::2;::::0;::::2;20026:21:1::0;20083:2;20063:18;;;20056:30;-1:-1:-1;;;20102:18:1;;;20095:52;20164:18;;143941:157:0::2;19842:346:1::0;143941:157:0::2;142223:4;144153:8;144133:17;;:28;;;;:::i;:::-;:48;;144111:124;;;::::0;-1:-1:-1;;;144111:124:0;;15007:2:1;144111:124:0::2;::::0;::::2;14989:21:1::0;15046:2;15026:18;;;15019:30;15085:28;15065:18;;;15058:56;15131:18;;144111:124:0::2;14805:350:1::0;144111:124:0::2;144295:10;144270:36;::::0;;;:24:::2;:36;::::0;;;;;142513:1:::2;::::0;144270:47:::2;::::0;144309:8;;144270:47:::2;:::i;:::-;:79;;144248:151;;;::::0;-1:-1:-1;;;144248:151:0;;21463:2:1;144248:151:0::2;::::0;::::2;21445:21:1::0;21502:2;21482:18;;;21475:30;-1:-1:-1;;;21521:18:1;;;21514:52;21583:18;;144248:151:0::2;21261:346:1::0;144248:151:0::2;144420:9;144433:10;144420:23;144412:64;;;::::0;-1:-1:-1;;;144412:64:0;;14289:2:1;144412:64:0::2;::::0;::::2;14271:21:1::0;14328:2;14308:18;;;14301:30;14367:31;14347:18;;;14340:59;14416:18;;144412:64:0::2;14087:353:1::0;144412:64:0::2;144498:6;::::0;::::2;::::0;::::2;;;144497:7;144489:43;;;::::0;-1:-1:-1;;;144489:43:0;;20756:2:1;144489:43:0::2;::::0;::::2;20738:21:1::0;20795:2;20775:18;;;20768:30;-1:-1:-1;;;20814:18:1;;;20807:53;20877:18;;144489:43:0::2;20554:347:1::0;144489:43:0::2;144585:10;:8;:10::i;:::-;144574:21;::::0;:8;:21:::2;:::i;:::-;144561:9;:34;;144553:60;;;::::0;-1:-1:-1;;;144553:60:0;;15769:2:1;144553:60:0::2;::::0;::::2;15751:21:1::0;15808:2;15788:18;;;15781:30;-1:-1:-1;;;15827:18:1;;;15820:43;15880:18;;144553:60:0::2;15567:337:1::0;144553:60:0::2;144651:10;144626:36;::::0;;;:24:::2;:36;::::0;;;;:48;;144666:8;;144626:36;:48:::2;::::0;144666:8;;144626:48:::2;:::i;:::-;;;;;;;;144706:8;144685:17;;:29;;;;;;;:::i;:::-;::::0;;;-1:-1:-1;144727:31:0::2;::::0;-1:-1:-1;144737:10:0::2;144749:8:::0;144727:9:::2;:31::i;:::-;139810:1:::1;;143726:1040:::0;;:::o;115978:279::-;-1:-1:-1;;;;;116069:24:0;;105428:10;116069:24;116065:54;;;116102:17;;-1:-1:-1;;;116102:17:0;;;;;;;;;;;116065:54;105428:10;116132:32;;;;:18;:32;;;;;;;;-1:-1:-1;;;;;116132:42:0;;;;;;;;;;;;:53;;-1:-1:-1;;116132:53:0;;;;;;;;;;116201:48;;11261:41:1;;;116132:42:0;;105428:10;116201:48;;11234:18:1;116201:48:0;;;;;;;115978:279;;:::o;147684:214::-;136762:7;136789:6;-1:-1:-1;;;;;136789:6:0;105428:10;136936:23;136928:68;;;;-1:-1:-1;;;136928:68:0;;;;;;;:::i;:::-;147742:9:::1;147737:154;147761:11;:18:::0;147757:22;::::1;147737:154;;;147801:22;147834:11;147846:1;147834:14;;;;;;;;:::i;:::-;;::::0;;;::::1;::::0;;;::::1;::::0;-1:-1:-1;;;;;147834:14:0::1;::::0;-1:-1:-1;147864:15:0::1;147834:14:::0;147864:7:::1;:15::i;:::-;-1:-1:-1::0;147781:3:0;::::1;::::0;::::1;:::i;:::-;;;;147737:154;;141419:167:::0;141474:4;141534:1;141511:20;;:24;:67;;;;-1:-1:-1;;141558:20:0;;141539:15;:39;;;141419:167::o;140155:258::-;140207:4;140264:1;140244:17;;:21;:57;;;;;140300:1;140282:15;;:19;140244:57;:110;;;;;140337:17;;140318:15;:36;;140244:110;:161;;;;-1:-1:-1;;140390:15:0;;140371;:34;;;140155:258::o;117056:342::-;117223:28;117233:4;117239:2;117243:7;117223:9;:28::i;:::-;117267:48;117290:4;117296:2;117300:7;117309:5;117267:22;:48::i;:::-;117262:129;;117339:40;;-1:-1:-1;;;117339:40:0;;;;;;;;;;;146767:551;146885:13;146934:16;146942:7;146934;:16::i;:::-;146916:105;;;;-1:-1:-1;;;146916:105:0;;21814:2:1;146916:105:0;;;21796:21:1;21853:2;21833:18;;;21826:30;21892:34;21872:18;;;21865:62;-1:-1:-1;;;21943:18:1;;;21936:45;21998:19;;146916:105:0;21612:411:1;146916:105:0;147046:8;;;;;;;147042:62;;147078:14;147071:21;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;146767:551;;;:::o;147042:62::-;147116:28;147147:10;:8;:10::i;:::-;147116:41;;147208:1;147183:14;147177:28;:32;:133;;;;;;;;;;;;;;;;;147249:14;147265:25;147282:7;147265:16;:25::i;:::-;147232:59;;;;;;;;;:::i;:::-;;;;;;;;;;;;;147177:133;147170:140;146767:551;-1:-1:-1;;;146767:551:0:o;138773:333::-;138829:7;138848:21;138947:120;138969:20;:18;:20::i;:::-;139017:39;;;138348:35;139017:39;;;;11669:25:1;;;;-1:-1:-1;;;;;11730:32:1;;11710:18;;;11703:60;139017:39:0;;;;;;;;;11642:18:1;;;139017:39:0;;139007:50;;;;;;-1:-1:-1;;;36382:57:0;;;9505:27:1;9548:11;;;9541:27;;;;9584:12;;;;9577:28;;;;36382:57:0;;;;;;;;;;9621:12:1;;;;36382:57:0;;;36372:68;;;;;;36252:196;138947:120;138882:186;;9104:66:1;138882:186:0;;;9092:79:1;9187:12;;;9180:28;;;;9224:12;;138882:186:0;;;-1:-1:-1;;138882:186:0;;;;;;;;;138872:197;;138882:186;138872:197;;;;;138773:333;-1:-1:-1;;;138773:333:0:o;138485:110::-;136762:7;136789:6;-1:-1:-1;;;;;136789:6:0;105428:10;136936:23;136928:68;;;;-1:-1:-1;;;136928:68:0;;;;;;;:::i;:::-;138561:15:::1;:26:::0;;-1:-1:-1;;;;;;138561:26:0::1;-1:-1:-1::0;;;;;138561:26:0;;;::::1;::::0;;;::::1;::::0;;138485:110::o;146448:90::-;136762:7;136789:6;-1:-1:-1;;;;;136789:6:0;105428:10;136936:23;136928:68;;;;-1:-1:-1;;;136928:68:0;;;;;;;:::i;:::-;146513:8:::1;:17:::0;;;::::1;;::::0;::::1;-1:-1:-1::0;;146513:17:0;;::::1;::::0;;;::::1;::::0;;146448:90::o;138603:162::-;138687:7;138714:43;138728:17;138738:6;138728:9;:17::i;:::-;138747:9;138714:13;:43::i;140559:334::-;136762:7;136789:6;-1:-1:-1;;;;;136789:6:0;105428:10;136936:23;136928:68;;;;-1:-1:-1;;;136928:68:0;;;;;;;:::i;:::-;140709:10:::1;140697:8;:22;;140675:132;;;::::0;-1:-1:-1;;;140675:132:0;;13860:2:1;140675:132:0::1;::::0;::::1;13842:21:1::0;13899:2;13879:18;;;13872:30;13938:34;13918:18;;;13911:62;14009:30;13989:18;;;13982:58;14057:19;;140675:132:0::1;13658:424:1::0;140675:132:0::1;140818:17;:30:::0;;;;140859:15:::1;:26:::0;140559:334::o;146065:128::-;136762:7;136789:6;-1:-1:-1;;;;;136789:6:0;105428:10;136936:23;136928:68;;;;-1:-1:-1;;;136928:68:0;;;;;;;:::i;:::-;146153:32;;::::1;::::0;:14:::1;::::0;:32:::1;::::0;::::1;::::0;::::1;:::i;137625:201::-:0;136762:7;136789:6;-1:-1:-1;;;;;136789:6:0;105428:10;136936:23;136928:68;;;;-1:-1:-1;;;136928:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;137714:22:0;::::1;137706:73;;;::::0;-1:-1:-1;;;137706:73:0;;15362:2:1;137706:73:0::1;::::0;::::1;15344:21:1::0;15401:2;15381:18;;;15374:30;15440:34;15420:18;;;15413:62;-1:-1:-1;;;15491:18:1;;;15484:36;15537:19;;137706:73:0::1;15160:402:1::0;137706:73:0::1;137790:28;137809:8;137790:18;:28::i;117653:144::-:0;117744:13;;117710:4;;-1:-1:-1;;;;;117744:13:0;117734:23;;:55;;;;-1:-1:-1;;117762:20:0;;;;:11;:20;;;;;:27;-1:-1:-1;;;117762:27:0;;;;117761:28;;117653:144::o;124869:196::-;124984:24;;;;:15;:24;;;;;;:29;;-1:-1:-1;;;;;;124984:29:0;-1:-1:-1;;;;;124984:29:0;;;;;;;;;125029:28;;124984:24;;125029:28;;;;;;;124869:196;;;:::o;39685:314::-;39738:7;39770:4;-1:-1:-1;;;;;39779:12:0;39762:29;;:66;;;;;39812:16;39795:13;:33;39762:66;39758:234;;;-1:-1:-1;39852:24:0;;39685:314::o;39758:234::-;-1:-1:-1;40188:73:0;;;39938:10;40188:73;;;;12033:25:1;;;;39950:12:0;12074:18:1;;;12067:34;39964:15:0;12117:18:1;;;12110:34;40232:13:0;12160:18:1;;;12153:34;40255:4:0;12203:19:1;;;;12196:61;;;;40188:73:0;;;;;;;;;;12005:19:1;;;;40188:73:0;;;40178:84;;;;;;139343:122::o;117805:104::-;117874:27;117884:2;117888:8;117874:27;;;;;;;;;;;;:9;:27::i;134734:248::-;134944:12;;-1:-1:-1;;;;;134924:16:0;;134880:7;134924:16;;;:7;:16;;;;;;134880:7;;134959:15;;134908:32;;:13;:32;:::i;:::-;134907:49;;;;:::i;:::-;:67;;;;:::i;:::-;134900:74;134734:248;-1:-1:-1;;;;134734:248:0:o;11867:317::-;11982:6;11957:21;:31;;11949:73;;;;-1:-1:-1;;;11949:73:0;;18114:2:1;11949:73:0;;;18096:21:1;18153:2;18133:18;;;18126:30;18192:31;18172:18;;;18165:59;18241:18;;11949:73:0;17912:353:1;11949:73:0;12036:12;12054:9;-1:-1:-1;;;;;12054:14:0;12076:6;12054:33;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;12035:52;;;12106:7;12098:78;;;;-1:-1:-1;;;12098:78:0;;17284:2:1;12098:78:0;;;17266:21:1;17323:2;17303:18;;;17296:30;17362:34;17342:18;;;17335:62;17433:28;17413:18;;;17406:56;17479:19;;12098:78:0;17082:422:1;120370:2112:0;120485:35;120523:20;120535:7;120523:11;:20::i;:::-;120598:18;;120485:58;;-1:-1:-1;120556:22:0;;-1:-1:-1;;;;;120582:34:0;105428:10;-1:-1:-1;;;;;120582:34:0;;:101;;;-1:-1:-1;120650:18:0;;120633:50;;105428:10;116328:164;:::i;120633:50::-;120582:154;;;-1:-1:-1;105428:10:0;120700:20;120712:7;120700:11;:20::i;:::-;-1:-1:-1;;;;;120700:36:0;;120582:154;120556:181;;120755:17;120750:66;;120781:35;;-1:-1:-1;;;120781:35:0;;;;;;;;;;;120750:66;120853:4;-1:-1:-1;;;;;120831:26:0;:13;:18;;;-1:-1:-1;;;;;120831:26:0;;120827:67;;120866:28;;-1:-1:-1;;;120866:28:0;;;;;;;;;;;120827:67;-1:-1:-1;;;;;120909:16:0;;120905:52;;120934:23;;-1:-1:-1;;;120934:23:0;;;;;;;;;;;120905:52;121078:49;121095:1;121099:7;121108:13;:18;;;121078:8;:49::i;:::-;-1:-1:-1;;;;;121423:18:0;;;;;;;:12;:18;;;;;;;;:31;;-1:-1:-1;;121423:31:0;;;-1:-1:-1;;;;;121423:31:0;;;-1:-1:-1;;121423:31:0;;;;;;;121469:16;;;;;;;;;:29;;;;;;;;-1:-1:-1;121469:29:0;;;;;;;;;;;121515:20;;;:11;:20;;;;;;:30;;-1:-1:-1;;;;;;121560:61:0;;;;-1:-1:-1;;;121605:15:0;121560:61;;;;;;;;;;;121895:11;;;121925:24;;;;;:29;121895:11;;121925:29;121921:445;;122150:13;;-1:-1:-1;;;;;122150:13:0;122136:27;;122132:219;;;122220:18;;;122188:24;;;:11;:24;;;;;;;;:50;;122303:28;;;;-1:-1:-1;;;;;122261:70:0;-1:-1:-1;;;122261:70:0;-1:-1:-1;;;;;;122261:70:0;;;-1:-1:-1;;;;;122188:50:0;;;122261:70;;;;;;;122132:219;121398:979;122413:7;122409:2;-1:-1:-1;;;;;122394:27:0;122403:4;-1:-1:-1;;;;;122394:27:0;;;;;;;;;;;122432:42;120474:2008;;120370:2112;;;:::o;21469:211::-;21613:58;;;-1:-1:-1;;;;;10262:32:1;;21613:58:0;;;10244:51:1;10311:18;;;;10304:34;;;21613:58:0;;;;;;;;;;10217:18:1;;;;21613:58:0;;;;;;;;-1:-1:-1;;;;;21613:58:0;-1:-1:-1;;;21613:58:0;;;21586:86;;21606:5;;21586:19;:86::i;112863:1083::-;-1:-1:-1;;;;;;;;;;;;;;;;;;;;;;;;;113029:13:0;;112973:7;;-1:-1:-1;;;;;113029:13:0;113022:20;;113018:861;;;113063:31;113097:17;;;:11;:17;;;;;;;;;113063:51;;;;;;;;;-1:-1:-1;;;;;113063:51:0;;;;-1:-1:-1;;;113063:51:0;;-1:-1:-1;;;;;113063:51:0;;;;;;;;-1:-1:-1;;;113063:51:0;;;;;;;;;;;;;;113133:731;;113183:14;;-1:-1:-1;;;;;113183:28:0;;113179:101;;113247:9;112863:1083;-1:-1:-1;;;112863:1083:0:o;113179:101::-;-1:-1:-1;;;113624:6:0;113669:17;;;;:11;:17;;;;;;;;;113657:29;;;;;;;;;-1:-1:-1;;;;;113657:29:0;;;;;-1:-1:-1;;;113657:29:0;;-1:-1:-1;;;;;113657:29:0;;;;;;;;-1:-1:-1;;;113657:29:0;;;;;;;;;;;;;113717:28;113713:109;;113785:9;112863:1083;-1:-1:-1;;;112863:1083:0:o;113713:109::-;113584:261;;;113044:835;113018:861;113907:31;;-1:-1:-1;;;113907:31:0;;;;;;;;;;;137986:191;138060:16;138079:6;;-1:-1:-1;;;;;138096:17:0;;;-1:-1:-1;;;;;;138096:17:0;;;;;;138129:40;;138079:6;;;;;;;138129:40;;138060:16;138129:40;138049:128;137986:191;:::o;125630:790::-;125785:4;-1:-1:-1;;;;;125806:13:0;;10868:20;10916:8;125802:611;;125842:72;;-1:-1:-1;;;125842:72:0;;-1:-1:-1;;;;;125842:36:0;;;;;:72;;105428:10;;125893:4;;125899:7;;125908:5;;125842:72;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;125842:72:0;;;;;;;;-1:-1:-1;;125842:72:0;;;;;;;;;;;;:::i;:::-;;;125838:520;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;126088:13:0;;126084:259;;126138:40;;-1:-1:-1;;;126138:40:0;;;;;;;;;;;126084:259;126293:6;126287:13;126278:6;126274:2;126270:15;126263:38;125838:520;-1:-1:-1;;;;;;125965:55:0;-1:-1:-1;;;125965:55:0;;-1:-1:-1;125958:62:0;;125802:611;-1:-1:-1;126397:4:0;125630:790;;;;;;:::o;146330:107::-;146390:13;146420:12;146413:19;;;;;:::i;25130:723::-;25186:13;25407:10;25403:53;;-1:-1:-1;;25434:10:0;;;;;;;;;;;;-1:-1:-1;;;25434:10:0;;;;;25130:723::o;25403:53::-;25481:5;25466:12;25522:78;25529:9;;25522:78;;25555:8;;;;:::i;:::-;;-1:-1:-1;25578:10:0;;-1:-1:-1;25586:2:0;25578:10;;:::i;:::-;;;25522:78;;;25610:19;25642:6;-1:-1:-1;;;;;25632:17:0;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;25632:17:0;;25610:39;;25660:154;25667:10;;25660:154;;25694:11;25704:1;25694:11;;:::i;:::-;;-1:-1:-1;25763:10:0;25771:2;25763:5;:10;:::i;:::-;25750:24;;:2;:24;:::i;:::-;25737:39;;25720:6;25727;25720:14;;;;;;;;:::i;:::-;;;;:56;-1:-1:-1;;;;;25720:56:0;;;;;;;;-1:-1:-1;25791:11:0;25800:2;25791:11;;:::i;:::-;;;25660:154;;31291:231;31369:7;31390:17;31409:18;31431:27;31442:4;31448:9;31431:10;:27::i;:::-;31389:69;;;;31469:18;31481:5;31469:11;:18::i;:::-;-1:-1:-1;31505:9:0;31291:231;-1:-1:-1;;;31291:231:0:o;118272:163::-;118395:32;118401:2;118405:8;118415:5;118422:4;118395:5;:32::i;24042:716::-;24466:23;24492:69;24520:4;24492:69;;;;;;;;;;;;;;;;;24500:5;-1:-1:-1;;;;;24492:27:0;;;:69;;;;;:::i;:::-;24576:17;;24466:95;;-1:-1:-1;24576:21:0;24572:179;;24673:10;24662:30;;;;;;;;;;;;:::i;:::-;24654:85;;;;-1:-1:-1;;;24654:85:0;;23345:2:1;24654:85:0;;;23327:21:1;23384:2;23364:18;;;23357:30;23423:34;23403:18;;;23396:62;-1:-1:-1;;;23474:18:1;;;23467:40;23524:19;;24654:85:0;23143:406:1;29181:1308:0;29262:7;29271:12;29496:9;:16;29516:2;29496:22;29492:990;;;29792:4;29777:20;;29771:27;29842:4;29827:20;;29821:27;29900:4;29885:20;;29879:27;29535:9;29871:36;29943:25;29954:4;29871:36;29771:27;29821;29943:10;:25::i;:::-;29936:32;;;;;;;;;29492:990;29990:9;:16;30010:2;29990:22;29986:496;;;30265:4;30250:20;;30244:27;30316:4;30301:20;;30295:27;30358:23;30369:4;30244:27;30295;30358:10;:23::i;:::-;30351:30;;;;;;;;29986:496;-1:-1:-1;30430:1:0;;-1:-1:-1;30434:35:0;29986:496;29181:1308;;;;;:::o;27452:643::-;27530:20;27521:5;:29;;;;;;;;:::i;:::-;;27517:571;;;27452:643;:::o;27517:571::-;27628:29;27619:5;:38;;;;;;;;:::i;:::-;;27615:473;;;27674:34;;-1:-1:-1;;;27674:34:0;;13097:2:1;27674:34:0;;;13079:21:1;13136:2;13116:18;;;13109:30;13175:26;13155:18;;;13148:54;13219:18;;27674:34:0;12895:348:1;27615:473:0;27739:35;27730:5;:44;;;;;;;;:::i;:::-;;27726:362;;;27791:41;;-1:-1:-1;;;27791:41:0;;14647:2:1;27791:41:0;;;14629:21:1;14686:2;14666:18;;;14659:30;14725:33;14705:18;;;14698:61;14776:18;;27791:41:0;14445:355:1;27726:362:0;27863:30;27854:5;:39;;;;;;;;:::i;:::-;;27850:238;;;27910:44;;-1:-1:-1;;;27910:44:0;;17711:2:1;27910:44:0;;;17693:21:1;17750:2;17730:18;;;17723:30;17789:34;17769:18;;;17762:62;-1:-1:-1;;;17840:18:1;;;17833:32;17882:19;;27910:44:0;17509:398:1;27850:238:0;27985:30;27976:5;:39;;;;;;;;:::i;:::-;;27972:116;;;28032:44;;-1:-1:-1;;;28032:44:0;;19641:2:1;28032:44:0;;;19623:21:1;19680:2;19660:18;;;19653:30;19719:34;19699:18;;;19692:62;-1:-1:-1;;;19770:18:1;;;19763:32;19812:19;;28032:44:0;19439:398:1;118694:1422:0;118856:13;;-1:-1:-1;;;;;118856:13:0;-1:-1:-1;;;;;118884:16:0;;118880:48;;118909:19;;-1:-1:-1;;;118909:19:0;;;;;;;;;;;118880:48;118943:13;118939:44;;118965:18;;-1:-1:-1;;;118965:18:0;;;;;;;;;;;118939:44;-1:-1:-1;;;;;119335:16:0;;;;;;:12;:16;;;;;;;;:44;;-1:-1:-1;;;;;;119394:49:0;;-1:-1:-1;;;;;119335:44:0;;;;;;;119394:49;;;;-1:-1:-1;;119335:44:0;;;;;;119394:49;;;;;;;;;;;;;;;;119460:25;;;119394:29;119460:25;;;;;:35;;-1:-1:-1;;;;;;119510:66:0;;;;-1:-1:-1;;;119560:15:0;119510:66;;;;;;;;;;;119460:25;;119645:328;119665:8;119661:1;:12;119645:328;;;119704:38;;119729:12;;-1:-1:-1;;;;;119704:38:0;;;119721:1;;119704:38;;119721:1;;119704:38;119765:4;:68;;;;;119774:59;119805:1;119809:2;119813:12;119827:5;119774:22;:59::i;:::-;119773:60;119765:68;119761:164;;;119865:40;;-1:-1:-1;;;119865:40:0;;;;;;;;;;;119761:164;119943:14;;;;;119675:3;119645:328;;;-1:-1:-1;119989:13:0;:37;;-1:-1:-1;;;;;;119989:37:0;-1:-1:-1;;;;;119989:37:0;;;;;;;;;;120048:60;143726:1040;13351:229;13488:12;13520:52;13542:6;13550:4;13556:1;13559:12;13520:21;:52::i;32790:1632::-;32921:7;;33855:66;33842:79;;33838:163;;;-1:-1:-1;33954:1:0;;-1:-1:-1;33958:30:0;33938:51;;33838:163;34015:1;:7;;34020:2;34015:7;;:18;;;;;34026:1;:7;;34031:2;34026:7;;34015:18;34011:102;;;-1:-1:-1;34066:1:0;;-1:-1:-1;34070:30:0;34050:51;;34011:102;34227:24;;;34210:14;34227:24;;;;;;;;;12495:25:1;;;12568:4;12556:17;;12536:18;;;12529:45;;;;12590:18;;;12583:34;;;12633:18;;;12626:34;;;34227:24:0;;12467:19:1;;34227:24:0;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;34227:24:0;;-1:-1:-1;;34227:24:0;;;-1:-1:-1;;;;;;;34266:20:0;;34262:103;;34319:1;34323:29;34303:50;;;;;;;34262:103;34385:6;-1:-1:-1;34393:20:0;;-1:-1:-1;32790:1632:0;;;;;;;;:::o;31785:391::-;31899:7;;-1:-1:-1;;;;;32000:75:0;;32102:3;32098:12;;;32112:2;32094:21;32143:25;32154:4;32094:21;32163:1;32000:75;32143:10;:25::i;:::-;32136:32;;;;;;31785:391;;;;;;:::o;14471:510::-;14641:12;14699:5;14674:21;:30;;14666:81;;;;-1:-1:-1;;;14666:81:0;;18472:2:1;14666:81:0;;;18454:21:1;18511:2;18491:18;;;18484:30;18550:34;18530:18;;;18523:62;-1:-1:-1;;;18601:18:1;;;18594:36;18647:19;;14666:81:0;18270:402:1;14666:81:0;10868:20;;14758:60;;;;-1:-1:-1;;;14758:60:0;;22987:2:1;14758:60:0;;;22969:21:1;23026:2;23006:18;;;22999:30;23065:31;23045:18;;;23038:59;23114:18;;14758:60:0;22785:353:1;14758:60:0;14832:12;14846:23;14873:6;-1:-1:-1;;;;;14873:11:0;14892:5;14899:4;14873:31;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14831:73;;;;14922:51;14939:7;14948:10;14960:12;14922:16;:51::i;:::-;14915:58;14471:510;-1:-1:-1;;;;;;;14471:510:0:o;17157:712::-;17307:12;17336:7;17332:530;;;-1:-1:-1;17367:10:0;17360:17;;17332:530;17481:17;;:21;17477:374;;17679:10;17673:17;17740:15;17727:10;17723:2;17719:19;17712:44;17477:374;17822:12;17815:20;;-1:-1:-1;;;17815:20:0;;;;;;;;:::i;-1:-1:-1:-;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;:::o;:::-;;;;;;;;;;;;;;;14:631:1;78:5;-1:-1:-1;;;;;149:2:1;141:6;138:14;135:40;;;155:18;;:::i;:::-;230:2;224:9;198:2;284:15;;-1:-1:-1;;280:24:1;;;306:2;276:33;272:42;260:55;;;330:18;;;350:22;;;327:46;324:72;;;376:18;;:::i;:::-;416:10;412:2;405:22;445:6;436:15;;475:6;467;460:22;515:3;506:6;501:3;497:16;494:25;491:45;;;532:1;529;522:12;491:45;582:6;577:3;570:4;562:6;558:17;545:44;637:1;630:4;621:6;613;609:19;605:30;598:41;;;;14:631;;;;;:::o;650:220::-;692:5;745:3;738:4;730:6;726:17;722:27;712:55;;763:1;760;753:12;712:55;785:79;860:3;851:6;838:20;831:4;823:6;819:17;785:79;:::i;875:247::-;934:6;987:2;975:9;966:7;962:23;958:32;955:52;;;1003:1;1000;993:12;955:52;1042:9;1029:23;1061:31;1086:5;1061:31;:::i;1387:388::-;1455:6;1463;1516:2;1504:9;1495:7;1491:23;1487:32;1484:52;;;1532:1;1529;1522:12;1484:52;1571:9;1558:23;1590:31;1615:5;1590:31;:::i;:::-;1640:5;-1:-1:-1;1697:2:1;1682:18;;1669:32;1710:33;1669:32;1710:33;:::i;:::-;1762:7;1752:17;;;1387:388;;;;;:::o;1780:456::-;1857:6;1865;1873;1926:2;1914:9;1905:7;1901:23;1897:32;1894:52;;;1942:1;1939;1932:12;1894:52;1981:9;1968:23;2000:31;2025:5;2000:31;:::i;:::-;2050:5;-1:-1:-1;2107:2:1;2092:18;;2079:32;2120:33;2079:32;2120:33;:::i;:::-;1780:456;;2172:7;;-1:-1:-1;;;2226:2:1;2211:18;;;;2198:32;;1780:456::o;2241:665::-;2336:6;2344;2352;2360;2413:3;2401:9;2392:7;2388:23;2384:33;2381:53;;;2430:1;2427;2420:12;2381:53;2469:9;2456:23;2488:31;2513:5;2488:31;:::i;:::-;2538:5;-1:-1:-1;2595:2:1;2580:18;;2567:32;2608:33;2567:32;2608:33;:::i;:::-;2660:7;-1:-1:-1;2714:2:1;2699:18;;2686:32;;-1:-1:-1;2769:2:1;2754:18;;2741:32;-1:-1:-1;;;;;2785:30:1;;2782:50;;;2828:1;2825;2818:12;2782:50;2851:49;2892:7;2883:6;2872:9;2868:22;2851:49;:::i;:::-;2841:59;;;2241:665;;;;;;;:::o;2911:382::-;2976:6;2984;3037:2;3025:9;3016:7;3012:23;3008:32;3005:52;;;3053:1;3050;3043:12;3005:52;3092:9;3079:23;3111:31;3136:5;3111:31;:::i;:::-;3161:5;-1:-1:-1;3218:2:1;3203:18;;3190:32;3231:30;3190:32;3231:30;:::i;3298:455::-;3375:6;3383;3436:2;3424:9;3415:7;3411:23;3407:32;3404:52;;;3452:1;3449;3442:12;3404:52;3491:9;3478:23;3510:31;3535:5;3510:31;:::i;:::-;3560:5;-1:-1:-1;3616:2:1;3601:18;;3588:32;-1:-1:-1;;;;;3632:30:1;;3629:50;;;3675:1;3672;3665:12;3629:50;3698:49;3739:7;3730:6;3719:9;3715:22;3698:49;:::i;:::-;3688:59;;;3298:455;;;;;:::o;3758:315::-;3826:6;3834;3887:2;3875:9;3866:7;3862:23;3858:32;3855:52;;;3903:1;3900;3893:12;3855:52;3942:9;3929:23;3961:31;3986:5;3961:31;:::i;:::-;4011:5;4063:2;4048:18;;;;4035:32;;-1:-1:-1;;;3758:315:1:o;4078:615::-;4164:6;4172;4225:2;4213:9;4204:7;4200:23;4196:32;4193:52;;;4241:1;4238;4231:12;4193:52;4281:9;4268:23;-1:-1:-1;;;;;4351:2:1;4343:6;4340:14;4337:34;;;4367:1;4364;4357:12;4337:34;4405:6;4394:9;4390:22;4380:32;;4450:7;4443:4;4439:2;4435:13;4431:27;4421:55;;4472:1;4469;4462:12;4421:55;4512:2;4499:16;4538:2;4530:6;4527:14;4524:34;;;4554:1;4551;4544:12;4524:34;4607:7;4602:2;4592:6;4589:1;4585:14;4581:2;4577:23;4573:32;4570:45;4567:65;;;4628:1;4625;4618:12;4567:65;4659:2;4651:11;;;;;4681:6;;-1:-1:-1;4078:615:1;;-1:-1:-1;;;;4078:615:1:o;4698:241::-;4754:6;4807:2;4795:9;4786:7;4782:23;4778:32;4775:52;;;4823:1;4820;4813:12;4775:52;4862:9;4849:23;4881:28;4903:5;4881:28;:::i;4944:245::-;5011:6;5064:2;5052:9;5043:7;5039:23;5035:32;5032:52;;;5080:1;5077;5070:12;5032:52;5112:9;5106:16;5131:28;5153:5;5131:28;:::i;5194:245::-;5252:6;5305:2;5293:9;5284:7;5280:23;5276:32;5273:52;;;5321:1;5318;5311:12;5273:52;5360:9;5347:23;5379:30;5403:5;5379:30;:::i;5444:249::-;5513:6;5566:2;5554:9;5545:7;5541:23;5537:32;5534:52;;;5582:1;5579;5572:12;5534:52;5614:9;5608:16;5633:30;5657:5;5633:30;:::i;6371:450::-;6440:6;6493:2;6481:9;6472:7;6468:23;6464:32;6461:52;;;6509:1;6506;6499:12;6461:52;6549:9;6536:23;-1:-1:-1;;;;;6574:6:1;6571:30;6568:50;;;6614:1;6611;6604:12;6568:50;6637:22;;6690:4;6682:13;;6678:27;-1:-1:-1;6668:55:1;;6719:1;6716;6709:12;6668:55;6742:73;6807:7;6802:2;6789:16;6784:2;6780;6776:11;6742:73;:::i;6826:180::-;6885:6;6938:2;6926:9;6917:7;6913:23;6909:32;6906:52;;;6954:1;6951;6944:12;6906:52;-1:-1:-1;6977:23:1;;6826:180;-1:-1:-1;6826:180:1:o;7011:184::-;7081:6;7134:2;7122:9;7113:7;7109:23;7105:32;7102:52;;;7150:1;7147;7140:12;7102:52;-1:-1:-1;7173:16:1;;7011:184;-1:-1:-1;7011:184:1:o;7200:388::-;7277:6;7285;7338:2;7326:9;7317:7;7313:23;7309:32;7306:52;;;7354:1;7351;7344:12;7306:52;7390:9;7377:23;7367:33;;7451:2;7440:9;7436:18;7423:32;-1:-1:-1;;;;;7470:6:1;7467:30;7464:50;;;7510:1;7507;7500:12;7593:248;7661:6;7669;7722:2;7710:9;7701:7;7697:23;7693:32;7690:52;;;7738:1;7735;7728:12;7690:52;-1:-1:-1;;7761:23:1;;;7831:2;7816:18;;;7803:32;;-1:-1:-1;7593:248:1:o;7846:257::-;7887:3;7925:5;7919:12;7952:6;7947:3;7940:19;7968:63;8024:6;8017:4;8012:3;8008:14;8001:4;7994:5;7990:16;7968:63;:::i;:::-;8085:2;8064:15;-1:-1:-1;;8060:29:1;8051:39;;;;8092:4;8047:50;;7846:257;-1:-1:-1;;7846:257:1:o;8108:274::-;8237:3;8275:6;8269:13;8291:53;8337:6;8332:3;8325:4;8317:6;8313:17;8291:53;:::i;:::-;8360:16;;;;;8108:274;-1:-1:-1;;8108:274:1:o;8387:470::-;8566:3;8604:6;8598:13;8620:53;8666:6;8661:3;8654:4;8646:6;8642:17;8620:53;:::i;:::-;8736:13;;8695:16;;;;8758:57;8736:13;8695:16;8792:4;8780:17;;8758:57;:::i;:::-;8831:20;;8387:470;-1:-1:-1;;;;8387:470:1:o;10349:488::-;-1:-1:-1;;;;;10618:15:1;;;10600:34;;10670:15;;10665:2;10650:18;;10643:43;10717:2;10702:18;;10695:34;;;10765:3;10760:2;10745:18;;10738:31;;;10543:4;;10786:45;;10811:19;;10803:6;10786:45;:::i;:::-;10778:53;10349:488;-1:-1:-1;;;;;;10349:488:1:o;12671:219::-;12820:2;12809:9;12802:21;12783:4;12840:44;12880:2;12869:9;12865:18;12857:6;12840:44;:::i;16675:402::-;16877:2;16859:21;;;16916:2;16896:18;;;16889:30;16955:34;16950:2;16935:18;;16928:62;-1:-1:-1;;;17021:2:1;17006:18;;16999:36;17067:3;17052:19;;16675:402::o;18677:407::-;18879:2;18861:21;;;18918:2;18898:18;;;18891:30;18957:34;18952:2;18937:18;;18930:62;-1:-1:-1;;;19023:2:1;19008:18;;19001:41;19074:3;19059:19;;18677:407::o;20193:356::-;20395:2;20377:21;;;20414:18;;;20407:30;20473:34;20468:2;20453:18;;20446:62;20540:2;20525:18;;20193:356::o;23736:128::-;23776:3;23807:1;23803:6;23800:1;23797:13;23794:39;;;23813:18;;:::i;:::-;-1:-1:-1;23849:9:1;;23736:128::o;23869:120::-;23909:1;23935;23925:35;;23940:18;;:::i;:::-;-1:-1:-1;23974:9:1;;23869:120::o;23994:168::-;24034:7;24100:1;24096;24092:6;24088:14;24085:1;24082:21;24077:1;24070:9;24063:17;24059:45;24056:71;;;24107:18;;:::i;:::-;-1:-1:-1;24147:9:1;;23994:168::o;24167:125::-;24207:4;24235:1;24232;24229:8;24226:34;;;24240:18;;:::i;:::-;-1:-1:-1;24277:9:1;;24167:125::o;24297:258::-;24369:1;24379:113;24393:6;24390:1;24387:13;24379:113;;;24469:11;;;24463:18;24450:11;;;24443:39;24415:2;24408:10;24379:113;;;24510:6;24507:1;24504:13;24501:48;;;-1:-1:-1;;24545:1:1;24527:16;;24520:27;24297:258::o;24560:380::-;24639:1;24635:12;;;;24682;;;24703:61;;24757:4;24749:6;24745:17;24735:27;;24703:61;24810:2;24802:6;24799:14;24779:18;24776:38;24773:161;;;24856:10;24851:3;24847:20;24844:1;24837:31;24891:4;24888:1;24881:15;24919:4;24916:1;24909:15;24773:161;;24560:380;;;:::o;24945:135::-;24984:3;-1:-1:-1;;25005:17:1;;25002:43;;;25025:18;;:::i;:::-;-1:-1:-1;25072:1:1;25061:13;;24945:135::o;25085:112::-;25117:1;25143;25133:35;;25148:18;;:::i;:::-;-1:-1:-1;25182:9:1;;25085:112::o;25202:127::-;25263:10;25258:3;25254:20;25251:1;25244:31;25294:4;25291:1;25284:15;25318:4;25315:1;25308:15;25334:127;25395:10;25390:3;25386:20;25383:1;25376:31;25426:4;25423:1;25416:15;25450:4;25447:1;25440:15;25466:127;25527:10;25522:3;25518:20;25515:1;25508:31;25558:4;25555:1;25548:15;25582:4;25579:1;25572:15;25598:127;25659:10;25654:3;25650:20;25647:1;25640:31;25690:4;25687:1;25680:15;25714:4;25711:1;25704:15;25730:127;25791:10;25786:3;25782:20;25779:1;25772:31;25822:4;25819:1;25812:15;25846:4;25843:1;25836:15;25862:131;-1:-1:-1;;;;;25937:31:1;;25927:42;;25917:70;;25983:1;25980;25973:12;25998:118;26084:5;26077:13;26070:21;26063:5;26060:32;26050:60;;26106:1;26103;26096:12;26121:131;-1:-1:-1;;;;;;26195:32:1;;26185:43;;26175:71;;26242:1;26239;26232:12

Swarm Source

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