ETH Price: $3,002.81 (+3.01%)
Gas: 2 Gwei

Token

Thieves (THIEVES)
 

Overview

Max Total Supply

3,333 THIEVES

Holders

1,233

Market

Volume (24H)

N/A

Min Price (24H)

N/A

Max Price (24H)

N/A
Filtered by Token Holder
style01.eth
Balance
1 THIEVES
0xC13483B20E434a4Bd653FDe5F526b6e76c294809
Loading...
Loading
Loading...
Loading
Loading...
Loading

Click here to update the token information / general information
# Exchange Pair Price  24H Volume % Volume

Contract Source Code Verified (Exact Match)

Contract Name:
Thieves

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-06-12
*/

//SPDX-License-Identifier: MIT

// 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/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 (last updated v4.5.0) (utils/Address.sol)

pragma solidity ^0.8.1;

/**
 * @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
     * ====
     *
     * [IMPORTANT]
     * ====
     * You shouldn't rely on `isContract` to protect against flash loan attacks!
     *
     * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets
     * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract
     * constructor.
     * ====
     */
    function isContract(address account) internal view returns (bool) {
        // This method relies on extcodesize/address.code.length, which returns 0
        // for contracts in construction, since the code is only stored at the end
        // of the constructor execution.

        return account.code.length > 0;
    }

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

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

    /**
     * @dev Performs a Solidity function call using a low level `call`. A
     * plain `call` is an unsafe replacement for a function call: use this
     * function instead.
     *
     * If `target` reverts with a revert reason, it is bubbled up by this
     * function (like regular Solidity function calls).
     *
     * Returns the raw returned data. To convert to the expected return value,
     * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].
     *
     * Requirements:
     *
     * - `target` must be a contract.
     * - calling `target` with `data` must not revert.
     *
     * _Available since v3.1._
     */
    function functionCall(address target, bytes memory data) internal returns (bytes memory) {
        return 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 (last updated v4.5.0) (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 `to`.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transfer(address to, uint256 amount) external returns (bool);

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

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

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

    /**
     * @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 (last updated v4.5.0) (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 = vs & bytes32(0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff);
        uint8 v = uint8((uint256(vs) >> 255) + 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 MintToZeroAddress();
error MintZeroQuantity();
error OwnerQueryForNonexistentToken();
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 extension. Built to optimize for lower gas during batch mints.
 *
 * Assumes serials are sequentially minted starting at _startTokenId() (defaults to 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**256 - 1 (max value of uint256).
 */
contract ERC721A is Context, ERC165, IERC721, IERC721Metadata {
    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;
        // For miscellaneous variable(s) pertaining to the address
        // (e.g. number of whitelist mint slots used).
        // If there are multiple variables, please pack them into a uint64.
        uint64 aux;
    }

    // The tokenId of the next token to be minted.
    uint256 internal _currentIndex;

    // The number of tokens burned.
    uint256 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_;
        _currentIndex = _startTokenId();
    }

    /**
     * To change the starting tokenId, please override this function.
     */
    function _startTokenId() internal view virtual returns (uint256) {
        return 0;
    }

    /**
     * @dev Burned tokens are calculated here, use _totalMinted() if you want to count just minted tokens.
     */
    function totalSupply() public view returns (uint256) {
        // Counter underflow is impossible as _burnCounter cannot be incremented
        // more than _currentIndex - _startTokenId() times
        unchecked {
            return _currentIndex - _burnCounter - _startTokenId();
        }
    }

    /**
     * Returns the total amount of tokens minted in the contract.
     */
    function _totalMinted() internal view returns (uint256) {
        // Counter underflow is impossible as _currentIndex does not decrement,
        // and it is initialized to _startTokenId()
        unchecked {
            return _currentIndex - _startTokenId();
        }
    }

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

    /**
     * Returns the number of tokens minted by `owner`.
     */
    function _numberMinted(address owner) internal view returns (uint256) {
        return uint256(_addressData[owner].numberMinted);
    }

    /**
     * Returns the number of tokens burned by or on behalf of `owner`.
     */
    function _numberBurned(address owner) internal view returns (uint256) {
        return uint256(_addressData[owner].numberBurned);
    }

    /**
     * Returns the auxillary data for `owner`. (e.g. number of whitelist mint slots used).
     */
    function _getAux(address owner) internal view returns (uint64) {
        return _addressData[owner].aux;
    }

    /**
     * Sets the auxillary data for `owner`. (e.g. number of whitelist mint slots used).
     * If there are multiple variables, please pack them into a uint64.
     */
    function _setAux(address owner, uint64 aux) internal {
        _addressData[owner].aux = aux;
    }

    /**
     * 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 (_startTokenId() <= curr && 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 virtual 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 (to.isContract() && !_checkContractOnERC721Received(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 _startTokenId() <= tokenId && 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 > 1.8e19 (2**64) - 1
        // updatedIndex overflows if _currentIndex + quantity > 1.2e77 (2**256) - 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;
            uint256 end = updatedIndex + quantity;

            if (safe && to.isContract()) {
                do {
                    emit Transfer(address(0), to, updatedIndex);
                    if (!_checkContractOnERC721Received(address(0), to, updatedIndex++, _data)) {
                        revert TransferToNonERC721ReceiverImplementer();
                    }
                } while (updatedIndex != end);
                // Reentrancy protection
                if (_currentIndex != startTokenId) revert();
            } else {
                do {
                    emit Transfer(address(0), to, updatedIndex++);
                } while (updatedIndex != end);
            }
            _currentIndex = 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);

        if (prevOwnership.addr != from) revert TransferFromIncorrectOwner();

        bool isApprovedOrOwner = (_msgSender() == from ||
            isApprovedForAll(from, _msgSender()) ||
            getApproved(tokenId) == _msgSender());

        if (!isApprovedOrOwner) revert TransferCallerNotOwnerNorApproved();
        if (to == address(0)) revert TransferToZeroAddress();

        _beforeTokenTransfers(from, to, tokenId, 1);

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

        // 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**256.
        unchecked {
            _addressData[from].balance -= 1;
            _addressData[to].balance += 1;

            TokenOwnership storage currSlot = _ownerships[tokenId];
            currSlot.addr = to;
            currSlot.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;
            TokenOwnership storage nextSlot = _ownerships[nextTokenId];
            if (nextSlot.addr == address(0)) {
                // This will suffice for checking _exists(nextTokenId),
                // as a burned slot cannot contain the zero address.
                if (nextTokenId != _currentIndex) {
                    nextSlot.addr = from;
                    nextSlot.startTimestamp = prevOwnership.startTimestamp;
                }
            }
        }

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

    /**
     * @dev This is equivalent to _burn(tokenId, false)
     */
    function _burn(uint256 tokenId) internal virtual {
        _burn(tokenId, false);
    }

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

        address from = prevOwnership.addr;

        if (approvalCheck) {
            bool isApprovedOrOwner = (_msgSender() == from ||
                isApprovedForAll(from, _msgSender()) ||
                getApproved(tokenId) == _msgSender());

            if (!isApprovedOrOwner) revert TransferCallerNotOwnerNorApproved();
        }

        _beforeTokenTransfers(from, address(0), tokenId, 1);

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

        // 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**256.
        unchecked {
            AddressData storage addressData = _addressData[from];
            addressData.balance -= 1;
            addressData.numberBurned += 1;

            // Keep track of who burned the token, and the timestamp of burning.
            TokenOwnership storage currSlot = _ownerships[tokenId];
            currSlot.addr = from;
            currSlot.startTimestamp = uint64(block.timestamp);
            currSlot.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;
            TokenOwnership storage nextSlot = _ownerships[nextTokenId];
            if (nextSlot.addr == address(0)) {
                // This will suffice for checking _exists(nextTokenId),
                // as a burned slot cannot contain the zero address.
                if (nextTokenId != _currentIndex) {
                    nextSlot.addr = from;
                    nextSlot.startTimestamp = prevOwnership.startTimestamp;
                }
            }
        }

        emit Transfer(from, address(0), tokenId);
        _afterTokenTransfers(from, 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 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 _checkContractOnERC721Received(
        address from,
        address to,
        uint256 tokenId,
        bytes memory _data
    ) private returns (bool) {
        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))
                }
            }
        }
    }

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

    address public whitelistSignerFree;

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

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

    function setWhitelistSignerFree(address _address) external onlyOwner {
        whitelistSignerFree = _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"
        );
        _;
    }

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

    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() {
        //22-06-12 12:00:00 EST == 22-06-12 13:00:00 GMT-3 at this site https://www.epochconverter.com/
        preSalesStartTime = 1655049600;
        //22-06-12 14:00:00 EST == 22-06-12 15:00:00 GMT-3 at this site https://www.epochconverter.com/
        preSalesEndTime = 1655056799;
    }

    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() {
        //22-06-12 14:00:00 EST == 22-06-12 15:00:00 GMT-3 at this site https://www.epochconverter.com/
        publicSalesStartTime = 1655056800;
    }

    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/Thieves.sol


pragma solidity ^0.8.0;








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

//FOR PRODUCTION
    uint256 public constant TOTAL_MAX_QTY = 3333;
    uint256 public constant GIFT_MAX_QTY = 30;
    uint256 public constant PRESALES_MAX_QTY = 3333;
    uint256 public constant PRE_SALES_PRICE = 0.04 ether;
    uint256 public constant PUBLIC_SALES_PRICE = 0.08 ether;
    uint256 public constant MAX_QTY_PER_MINTER = 3;
    uint256 public constant MAX_QTY_PER_MINT = 3;
    uint256 public constant MAX_QTY_PER_MINTER_PRE_SALES = 2;
    uint256 public constant MAX_QTY_PER_MINTER_PRE_SALES_FREE = 1;

    address[] private addressList = [
	0xa9c2291771272E49b077bE5637d0a06bbF4bb8e2
	];

	uint256[] private shareList = [100];

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

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

    bool public canRenounceOwnership = false;
    bool public paused = false;
    bool public revealed = false;
    bool public customPrice = false;
    uint256 public custom_price = 0.08 ether;

    string private baseTokenURI;
    string private notRevealedUri;

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

    function getPrice() public view returns (uint256) {
        if (isPublicSalesActivated()) {
            if(customPrice){
                return custom_price;
            }else{
                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 + giftedQty + _mintQty <=
                TOTAL_MAX_QTY,
            "Exceed sales max limit"
        );

        require(
            preSalesMintedQty + giftedQty + _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 preSalesMintFree(
        uint256 _mintQty,
        bytes memory signature
    )
        external
        payable
        isPreSalesActive
        isUserWhileListFree(msg.sender, signature )
    {
        require(
            preSalesMintedQty + publicSalesMintedQty + giftedQty + _mintQty <=
                TOTAL_MAX_QTY,
            "Exceed sales max limit"
        );

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

        require(
            preSalesFreeMinterToTokenQty[msg.sender] + _mintQty <= MAX_QTY_PER_MINTER_PRE_SALES_FREE,
            "Exceed signed gift quantity"
        );

        require(
            giftedQty + _mintQty <= GIFT_MAX_QTY,
            "Exceed signed gift max limit"
        );

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

        require(!paused, "The contract is paused!");

        giftedQty += _mintQty;
        preSalesFreeMinterToTokenQty[msg.sender] += _mintQty;

        _safeMint(msg.sender, _mintQty);
    }

    function publicSalesMint(uint256 _mintQty)
        external
        payable
        isPublicSalesActive
    {     
         require(
            preSalesMintedQty + publicSalesMintedQty + giftedQty + _mintQty <=
                TOTAL_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 setCustomPrice(bool isCustomPrice, uint256 price) external onlyOwner {
        customPrice = isCustomPrice;
        custom_price = price;
    }

    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":"OwnerQueryForNonexistentToken","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":"MAX_QTY_PER_MINTER_PRE_SALES_FREE","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":"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":[],"name":"customPrice","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"custom_price","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"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":"address","name":"","type":"address"}],"name":"preSalesFreeMinterToTokenQty","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":[{"internalType":"uint256","name":"_mintQty","type":"uint256"},{"internalType":"bytes","name":"signature","type":"bytes"}],"name":"preSalesMintFree","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":"bool","name":"isCustomPrice","type":"bool"},{"internalType":"uint256","name":"price","type":"uint256"}],"name":"setCustomPrice","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":"_address","type":"address"}],"name":"setWhitelistSignerFree","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":"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":"whitelistSignerFree","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"}]

61016060405273a9c2291771272e49b077be5637d0a06bbf4bb8e26101409081526200003090601590600162000667565b5060408051602081019091526064815262000050906016906001620006d1565b50600060178190556018819055601955601d805463ffffffff1916905567011c37937e080000601e553480156200008657600080fd5b506040516200478138038062004781833981016040819052620000a991620007a8565b60158054806020026020016040519081016040528092919081815260200182805480156200010157602002820191906000526020600020905b81546001600160a01b03168152600190910190602001808311620000e2575b505050505060168054806020026020016040519081016040528092919081815260200182805480156200015457602002820191906000526020600020905b8154815260200190600101908083116200013f575b5050505050604051806040016040528060078152602001665468696576657360c81b815250604051806040016040528060078152602001665448494556455360c81b8152506040518060400160405280601081526020016f151a1a595d995cd5da1a5d19531a5cdd60821b815250604051806040016040528060018152602001603160f81b815250620001f6620001f06200042560201b60201c565b62000429565b6362a629a06001556362a60d806002556362a6299f600355815160208084019190912082518383012060e08290526101008190524660a0818152604080517f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f81880181905281830187905260608201869052608082019490945230818401528151808203909301835260c00190528051940193909320919290916080523060601b60c0526101205250508351620002b7925060089150602085019062000714565b508051620002cd90600990602084019062000714565b50600060065550508051825114620003475760405162461bcd60e51b815260206004820152603260248201527f5061796d656e7453706c69747465723a2070617965657320616e6420736861726044820152710cae640d8cadccee8d040dad2e6dac2e8c6d60731b60648201526084015b60405180910390fd5b60008251116200039a5760405162461bcd60e51b815260206004820152601a60248201527f5061796d656e7453706c69747465723a206e6f2070617965657300000000000060448201526064016200033e565b60005b82518110156200040657620003f1838281518110620003c057620003c062000910565b6020026020010151838381518110620003dd57620003dd62000910565b60200260200101516200047960201b60201c565b80620003fd81620008dc565b9150506200039d565b505081516200041d91506020908184019062000714565b50506200093c565b3390565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6001600160a01b038216620004e65760405162461bcd60e51b815260206004820152602c60248201527f5061796d656e7453706c69747465723a206163636f756e74206973207468652060448201526b7a65726f206164647265737360a01b60648201526084016200033e565b60008111620005385760405162461bcd60e51b815260206004820152601d60248201527f5061796d656e7453706c69747465723a2073686172657320617265203000000060448201526064016200033e565b6001600160a01b03821660009081526010602052604090205415620005b45760405162461bcd60e51b815260206004820152602b60248201527f5061796d656e7453706c69747465723a206163636f756e7420616c726561647960448201526a206861732073686172657360a81b60648201526084016200033e565b60128054600181019091557fbb8a6a4669ba250d26cd7a459eca9d215f8307e33aebe50379bc5a3617ec34440180546001600160a01b0319166001600160a01b0384169081179091556000908152601060205260409020819055600e546200061e90829062000884565b600e55604080516001600160a01b0384168152602081018390527f40c340f65e17194d14ddddb073d3c9f888e3cb52b5aae0c6c7706b4fbc905fac910160405180910390a15050565b828054828255906000526020600020908101928215620006bf579160200282015b82811115620006bf57825182546001600160a01b0319166001600160a01b0390911617825560209092019160019091019062000688565b50620006cd92915062000791565b5090565b828054828255906000526020600020908101928215620006bf579160200282015b82811115620006bf578251829060ff16905591602001919060010190620006f2565b82805462000722906200089f565b90600052602060002090601f016020900481019282620007465760008555620006bf565b82601f106200076157805160ff1916838001178555620006bf565b82800160010185558215620006bf579182015b82811115620006bf57825182559160200191906001019062000774565b5b80821115620006cd576000815560010162000792565b60006020808385031215620007bc57600080fd5b82516001600160401b0380821115620007d457600080fd5b818501915085601f830112620007e957600080fd5b815181811115620007fe57620007fe62000926565b604051601f8201601f19908116603f0116810190838211818310171562000829576200082962000926565b8160405282815288868487010111156200084257600080fd5b600093505b8284101562000866578484018601518185018701529285019262000847565b82841115620008785760008684830101525b98975050505050505050565b600082198211156200089a576200089a620008fa565b500190565b600181811c90821680620008b457607f821691505b60208210811415620008d657634e487b7160e01b600052602260045260246000fd5b50919050565b6000600019821415620008f357620008f3620008fa565b5060010190565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b60805160a05160c05160601c60e0516101005161012051613df26200098f600039600061259e015260006125ed015260006125c8015260006125210152600061254b015260006125750152613df26000f3fe6080604052600436106104355760003560e01c8063951cddd011610229578063c87b56dd1161012e578063e33b7de3116100b6578063ef81b4d41161007a578063ef81b4d414610cc5578063f2c4ce1e14610ce5578063f2fde38b14610d05578063f6ffab9b14610d25578063ff7fb00114610d4557600080fd5b8063e33b7de314610c11578063e53e3a0414610c26578063e6c3819c14610c46578063e985e9c514610c5c578063ed39039b14610ca557600080fd5b8063d5069924116100fd578063d506992414610b7f578063d6eec46a14610b9f578063d79779b214610bbb578063dee816e614610714578063e0a8085314610bf157600080fd5b8063c87b56dd14610ae9578063ce7c2ac214610b09578063d1ca131f14610b3f578063d338143814610b5f57600080fd5b8063a78a673f116101b1578063b5cf0c2211610180578063b5cf0c2214610a4a578063b7329d2b14610a6a578063b88d4fde14610a7f578063bd34fc5714610a9f578063c688387f14610ab557600080fd5b8063a78a673f14610a0a578063a8c733ca14610a20578063ac501c4114610558578063ae4384f114610a3557600080fd5b80639c123661116101f85780639c1236611461098b5780639e47efb8146109a1578063a22cb465146109b4578063a43c6536146109d4578063a50e89ff146109f557600080fd5b8063951cddd0146108fe57806395d89b411461092b5780639852595c1461094057806398d5fdca1461097657600080fd5b80633ccfd60b1161033a57806360869d9b116102c25780637b2ca386116102865780637b2ca3861461085e57806382afe550146108785780638b83209b146108935780638da5cb5b146108b35780638f7be8f2146108d157600080fd5b806360869d9b146107bc5780636352211e146107dc57806370a08231146107fc578063715018a61461081c578063791eef071461083157600080fd5b806348b750441161030957806348b750441461072a5780634d192b831461074a5780634def4d1a1461075d578063518302271461077d5780635c975abb1461079d57600080fd5b80633ccfd60b146106a6578063406072a9146106ae57806342842e0e146106f457806347fc6e761461071457600080fd5b806316c38b3c116103bd57806330176e131161038c57806330176e13146106305780633354fe3414610650578063397d0c0c146106655780633a4087c71461067b5780633a98ef391461069157600080fd5b806316c38b3c146105b757806318160ddd146105d757806319165587146105f057806323b872dd1461061057600080fd5b8063095ea7b311610404578063095ea7b314610536578063122be4a31461055857806313c65a6e1461056d578063163e1e611461058257806316787758146105a257600080fd5b806301e3b4361461048357806301ffc9a7146104ac57806306fdde03146104dc578063081812fc146104fe57600080fd5b3661047e577f6ef95f06320e7a25a04a175ca677b7052bdd97131872c2192525a629f51be77033604080516001600160a01b0390921682523460208301520160405180910390a1005b600080fd5b34801561048f57600080fd5b5061049960175481565b6040519081526020015b60405180910390f35b3480156104b857600080fd5b506104cc6104c73660046138a3565b610d58565b60405190151581526020016104a3565b3480156104e857600080fd5b506104f1610daa565b6040516104a39190613a5d565b34801561050a57600080fd5b5061051e610519366004613925565b610e3c565b6040516001600160a01b0390911681526020016104a3565b34801561054257600080fd5b506105566105513660046137ab565b610e80565b005b34801561056457600080fd5b50610499600381565b34801561057957600080fd5b50610499610f0e565b34801561058e57600080fd5b5061055661059d3660046137d7565b610f4f565b3480156105ae57600080fd5b50610499600281565b3480156105c357600080fd5b506105566105d236600461384b565b611039565b3480156105e357600080fd5b5060075460065403610499565b3480156105fc57600080fd5b5061055661060b36600461362c565b61107d565b34801561061c57600080fd5b5061055661062b366004613682565b6111ab565b34801561063c57600080fd5b5061055661064b3660046138dd565b6111b6565b34801561065c57600080fd5b50610499601e81565b34801561067157600080fd5b5061049960025481565b34801561068757600080fd5b50610499601e5481565b34801561069d57600080fd5b50600e54610499565b6105566111f7565b3480156106ba57600080fd5b506104996106c9366004613649565b6001600160a01b03918216600090815260146020908152604080832093909416825291909152205490565b34801561070057600080fd5b5061055661070f366004613682565b611279565b34801561072057600080fd5b50610499610d0581565b34801561073657600080fd5b50610556610745366004613649565b611294565b610556610758366004613925565b61147c565b34801561076957600080fd5b5061055661077836600461384b565b6116cb565b34801561078957600080fd5b50601d546104cc9062010000900460ff1681565b3480156107a957600080fd5b50601d546104cc90610100900460ff1681565b3480156107c857600080fd5b506105566107d7366004613925565b611708565b3480156107e857600080fd5b5061051e6107f7366004613925565b611737565b34801561080857600080fd5b5061049961081736600461362c565b611749565b34801561082857600080fd5b50610556611797565b34801561083d57600080fd5b5061049961084c36600461362c565b601b6020526000908152604090205481565b34801561086a57600080fd5b50601d546104cc9060ff1681565b34801561088457600080fd5b50610499668e1bc9bf04000081565b34801561089f57600080fd5b5061051e6108ae366004613925565b61182a565b3480156108bf57600080fd5b506000546001600160a01b031661051e565b3480156108dd57600080fd5b506104996108ec36600461362c565b601c6020526000908152604090205481565b34801561090a57600080fd5b5061049961091936600461362c565b601a6020526000908152604090205481565b34801561093757600080fd5b506104f161185a565b34801561094c57600080fd5b5061049961095b36600461362c565b6001600160a01b031660009081526011602052604090205490565b34801561098257600080fd5b50610499611869565b34801561099757600080fd5b5061049960185481565b6105566109af366004613957565b6118aa565b3480156109c057600080fd5b506105566109cf36600461372e565b611b3e565b3480156109e057600080fd5b50601d546104cc906301000000900460ff1681565b348015610a0157600080fd5b50610556611bd4565b348015610a1657600080fd5b5061049960035481565b348015610a2c57600080fd5b50610499600181565b348015610a4157600080fd5b506104cc611c53565b348015610a5657600080fd5b5060055461051e906001600160a01b031681565b348015610a7657600080fd5b506104cc611c6b565b348015610a8b57600080fd5b50610556610a9a3660046136c3565b611c9f565b348015610aab57600080fd5b5061049960195481565b348015610ac157600080fd5b506104997ff59780ff8f4ba89ed09d6c9fc5aec79093994c7234326cb09aafc9bf724f074181565b348015610af557600080fd5b506104f1610b04366004613925565b611cea565b348015610b1557600080fd5b50610499610b2436600461362c565b6001600160a01b031660009081526010602052604090205490565b348015610b4b57600080fd5b50610499610b5a36600461362c565b611e57565b348015610b6b57600080fd5b50610556610b7a36600461362c565b611f3f565b348015610b8b57600080fd5b50610556610b9a366004613885565b611f8b565b348015610bab57600080fd5b5061049967011c37937e08000081565b348015610bc757600080fd5b50610499610bd636600461362c565b6001600160a01b031660009081526013602052604090205490565b348015610bfd57600080fd5b50610556610c0c36600461384b565b611fd7565b348015610c1d57600080fd5b50600f54610499565b348015610c3257600080fd5b5061051e610c4136600461375c565b61201d565b348015610c5257600080fd5b5061049960015481565b348015610c6857600080fd5b506104cc610c77366004613649565b6001600160a01b039182166000908152600d6020908152604080832093909416825291909152205460ff1690565b348015610cb157600080fd5b50610556610cc0366004613987565b612031565b348015610cd157600080fd5b5060045461051e906001600160a01b031681565b348015610cf157600080fd5b50610556610d003660046138dd565b6120dc565b348015610d1157600080fd5b50610556610d2036600461362c565b612118565b348015610d3157600080fd5b50610556610d4036600461362c565b6121b0565b610556610d53366004613957565b6121fc565b60006001600160e01b031982166380ac58cd60e01b1480610d8957506001600160e01b03198216635b5e139f60e01b145b80610da457506301ffc9a760e01b6001600160e01b03198316145b92915050565b606060088054610db990613cab565b80601f0160208091040260200160405190810160405280929190818152602001828054610de590613cab565b8015610e325780601f10610e0757610100808354040283529160200191610e32565b820191906000526020600020905b815481529060010190602001808311610e1557829003601f168201915b5050505050905090565b6000610e478261248c565b610e64576040516333d1c03960e21b815260040160405180910390fd5b506000908152600c60205260409020546001600160a01b031690565b6000610e8b82611737565b9050806001600160a01b0316836001600160a01b03161415610ec05760405163250fdee360e21b815260040160405180910390fd5b336001600160a01b03821614801590610ee05750610ede8133610c77565b155b15610efe576040516367d9dca160e11b815260040160405180910390fd5b610f098383836124b8565b505050565b600080546001600160a01b03163314610f425760405162461bcd60e51b8152600401610f3990613bb1565b60405180910390fd5b610f4a612514565b905090565b6000546001600160a01b03163314610f795760405162461bcd60e51b8152600401610f3990613bb1565b601954601e90610f8a908390613c1d565b1115610fd05760405162461bcd60e51b8152602060048201526015602482015274115e18d959590819da599d081b585e081b1a5b5a5d605a1b6044820152606401610f39565b8181905060196000828254610fe59190613c1d565b90915550600090505b81811015610f095761102783838381811061100b5761100b613d57565b9050602002016020810190611020919061362c565b600161263b565b8061103181613ce6565b915050610fee565b6000546001600160a01b031633146110635760405162461bcd60e51b8152600401610f3990613bb1565b601d80549115156101000261ff0019909216919091179055565b6001600160a01b0381166000908152601060205260409020546110b25760405162461bcd60e51b8152600401610f3990613af0565b60006110bd600f5490565b6110c79047613c1d565b905060006110f483836110ef866001600160a01b031660009081526011602052604090205490565b612655565b9050806111135760405162461bcd60e51b8152600401610f3990613b36565b6001600160a01b0383166000908152601160205260408120805483929061113b908490613c1d565b9250508190555080600f60008282546111549190613c1d565b909155506111649050838261269b565b604080516001600160a01b0385168152602081018390527fdf20fd1e76bc69d672e4814fafb2c449bba3a5369d8359adf9e05e6fde87b056910160405180910390a1505050565b610f098383836127b4565b6000546001600160a01b031633146111e05760405162461bcd60e51b8152600401610f3990613bb1565b80516111f390601f9060208401906134fe565b5050565b6000546001600160a01b031633146112215760405162461bcd60e51b8152600401610f3990613bb1565b604051600090339047908381818185875af1925050503d8060008114611263576040519150601f19603f3d011682016040523d82523d6000602084013e611268565b606091505b505090508061127657600080fd5b50565b610f0983838360405180602001604052806000815250611c9f565b6001600160a01b0381166000908152601060205260409020546112c95760405162461bcd60e51b8152600401610f3990613af0565b6001600160a01b0382166000908152601360205260408120546040516370a0823160e01b81523060048201526001600160a01b038516906370a082319060240160206040518083038186803b15801561132157600080fd5b505afa158015611335573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611359919061393e565b6113639190613c1d565b9050600061139c83836110ef87876001600160a01b03918216600090815260146020908152604080832093909416825291909152205490565b9050806113bb5760405162461bcd60e51b8152600401610f3990613b36565b6001600160a01b038085166000908152601460209081526040808320938716835292905290812080548392906113f2908490613c1d565b90915550506001600160a01b0384166000908152601360205260408120805483929061141f908490613c1d565b9091555061143090508484836129a2565b604080516001600160a01b038581168252602082018490528616917f3be5b7a71e84ed12875d241991c70855ac5817d847039e17a9d895c1ceb0f18a910160405180910390a250505050565b611484611c53565b6114e55760405162461bcd60e51b815260206004820152602c60248201527f5075626c696353616c657341637469766174696f6e3a2053616c65206973206e60448201526b1bdd081858dd1a5d985d195960a21b6064820152608401610f39565b610d05816019546018546017546114fc9190613c1d565b6115069190613c1d565b6115109190613c1d565b111561152e5760405162461bcd60e51b8152600401610f3990613b81565b600381111561157f5760405162461bcd60e51b815260206004820152601960248201527f457863656564206d6178206d696e7420706572206d696e742e000000000000006044820152606401610f39565b336000908152601c602052604090205460039061159d908390613c1d565b11156115eb5760405162461bcd60e51b815260206004820152601a60248201527f457863656564206d6178206d696e7420706572206d696e7465720000000000006044820152606401610f39565b32331461160a5760405162461bcd60e51b8152600401610f3990613ab9565b601d54610100900460ff16156116325760405162461bcd60e51b8152600401610f3990613be6565b61163a611869565b6116449082613c49565b3410156116835760405162461bcd60e51b815260206004820152600d60248201526c092dcc6dee4e4cac6e8408aa89609b1b6044820152606401610f39565b336000908152601c6020526040812080548392906116a2908490613c1d565b9250508190555080601860008282546116bb9190613c1d565b909155506112769050338261263b565b6000546001600160a01b031633146116f55760405162461bcd60e51b8152600401610f3990613bb1565b601d805460ff1916911515919091179055565b6000546001600160a01b031633146117325760405162461bcd60e51b8152600401610f3990613bb1565b600155565b6000611742826129f4565b5192915050565b60006001600160a01b038216611772576040516323d3ad8160e21b815260040160405180910390fd5b506001600160a01b03166000908152600b60205260409020546001600160401b031690565b6000546001600160a01b031633146117c15760405162461bcd60e51b8152600401610f3990613bb1565b601d5460ff1661181e5760405162461bcd60e51b815260206004820152602260248201527f4e6f74207468652074696d6520746f2052656e6f756e6365204f776e65727368604482015261069760f41b6064820152608401610f39565b6118286000612b0e565b565b60006012828154811061183f5761183f613d57565b6000918252602090912001546001600160a01b031692915050565b606060098054610db990613cab565b6000611873611c53565b1561189e57601d546301000000900460ff16156118915750601e5490565b5067011c37937e08000090565b50668e1bc9bf04000090565b6118b2611c6b565b6118ce5760405162461bcd60e51b8152600401610f3990613a70565b600454339082906001600160a01b03166118e8838361201d565b6001600160a01b03161461193e5760405162461bcd60e51b815260206004820152601860248201527f55736572206973206e6f74206f6e2077686974656c69737400000000000000006044820152606401610f39565b610d05846019546018546017546119559190613c1d565b61195f9190613c1d565b6119699190613c1d565b11156119875760405162461bcd60e51b8152600401610f3990613b81565b610d058460195460175461199b9190613c1d565b6119a59190613c1d565b11156119f35760405162461bcd60e51b815260206004820152601a60248201527f457863656564207072652d73616c6573206d6178206c696d69740000000000006044820152606401610f39565b336000908152601b6020526040902054600290611a11908690613c1d565b1115611a585760405162461bcd60e51b8152602060048201526016602482015275457863656564207369676e6564207175616e7469747960501b6044820152606401610f39565b323314611a775760405162461bcd60e51b8152600401610f3990613ab9565b601d54610100900460ff1615611a9f5760405162461bcd60e51b8152600401610f3990613be6565b611aa7611869565b611ab19085613c49565b341015611af05760405162461bcd60e51b815260206004820152600d60248201526c092dcc6dee4e4cac6e8408aa89609b1b6044820152606401610f39565b336000908152601b602052604081208054869290611b0f908490613c1d565b925050819055508360176000828254611b289190613c1d565b90915550611b389050338561263b565b50505050565b6001600160a01b038216331415611b685760405163b06307db60e01b815260040160405180910390fd5b336000818152600d602090815260408083206001600160a01b03871680855290835292819020805460ff191686151590811790915590519081529192917f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a35050565b6000546001600160a01b03163314611bfe5760405162461bcd60e51b8152600401610f3990613bb1565b60005b60155481101561127657600060158281548110611c2057611c20613d57565b6000918252602090912001546001600160a01b03169050611c408161107d565b5080611c4b81613ce6565b915050611c01565b600080600154118015610f4a57505060015442101590565b600080600254118015611c8057506000600354115b8015611c8e57506002544210155b8015610f4a57505060035442111590565b611caa8484846127b4565b6001600160a01b0383163b15158015611ccc5750611cca84848484612b5e565b155b15611b38576040516368d2bf6b60e11b815260040160405180910390fd5b6060611cf58261248c565b611d595760405162461bcd60e51b815260206004820152602f60248201527f4552433732314d657461646174613a2055524920717565727920666f72206e6f60448201526e3732bc34b9ba32b73a103a37b5b2b760891b6064820152608401610f39565b601d5462010000900460ff16611dfb5760208054611d7690613cab565b80601f0160208091040260200160405190810160405280929190818152602001828054611da290613cab565b8015611def5780601f10611dc457610100808354040283529160200191611def565b820191906000526020600020905b815481529060010190602001808311611dd257829003601f168201915b50505050509050919050565b6000611e05612c55565b90506000815111611e255760405180602001604052806000815250611e50565b80611e2f84612c64565b604051602001611e409291906139f1565b6040516020818303038152906040525b9392505050565b600080611eec611e65612514565b604080517ff59780ff8f4ba89ed09d6c9fc5aec79093994c7234326cb09aafc9bf724f07416020808301919091526001600160a01b0388168284015282518083038401815260608301845280519082012061190160f01b6080840152608283019490945260a2808301949094528251808303909401845260c2909101909152815191012090565b6040517f19457468657265756d205369676e6564204d6573736167653a0a3332000000006020820152603c810191909152605c0160408051601f1981840301815291905280516020909101209392505050565b6000546001600160a01b03163314611f695760405162461bcd60e51b8152600401610f3990613bb1565b600480546001600160a01b0319166001600160a01b0392909216919091179055565b6000546001600160a01b03163314611fb55760405162461bcd60e51b8152600401610f3990613bb1565b601d805492151563010000000263ff0000001990931692909217909155601e55565b6000546001600160a01b031633146120015760405162461bcd60e51b8152600401610f3990613bb1565b601d8054911515620100000262ff000019909216919091179055565b6000611e5061202b84611e57565b83612d61565b6000546001600160a01b0316331461205b5760405162461bcd60e51b8152600401610f3990613bb1565b818110156120d15760405162461bcd60e51b815260206004820152603c60248201527f50726553616c657341637469766174696f6e3a20456e642074696d652073686f60448201527f756c64206265206c61746572207468616e2073746172742074696d65000000006064820152608401610f39565b600291909155600355565b6000546001600160a01b031633146121065760405162461bcd60e51b8152600401610f3990613bb1565b80516111f390602090818401906134fe565b6000546001600160a01b031633146121425760405162461bcd60e51b8152600401610f3990613bb1565b6001600160a01b0381166121a75760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610f39565b61127681612b0e565b6000546001600160a01b031633146121da5760405162461bcd60e51b8152600401610f3990613bb1565b600580546001600160a01b0319166001600160a01b0392909216919091179055565b612204611c6b565b6122205760405162461bcd60e51b8152600401610f3990613a70565b600554339082906001600160a01b031661223a838361201d565b6001600160a01b0316146122905760405162461bcd60e51b815260206004820152601d60248201527f55736572206973206e6f74206f6e2077686974656c69737420467265650000006044820152606401610f39565b610d05846019546018546017546122a79190613c1d565b6122b19190613c1d565b6122bb9190613c1d565b11156122d95760405162461bcd60e51b8152600401610f3990613b81565b610d05846019546017546122ed9190613c1d565b6122f79190613c1d565b11156123455760405162461bcd60e51b815260206004820152601a60248201527f457863656564207072652d73616c6573206d6178206c696d69740000000000006044820152606401610f39565b336000908152601a6020526040902054600190612363908690613c1d565b11156123b15760405162461bcd60e51b815260206004820152601b60248201527f457863656564207369676e65642067696674207175616e7469747900000000006044820152606401610f39565b601e846019546123c19190613c1d565b111561240f5760405162461bcd60e51b815260206004820152601c60248201527f457863656564207369676e65642067696674206d6178206c696d6974000000006044820152606401610f39565b32331461242e5760405162461bcd60e51b8152600401610f3990613ab9565b601d54610100900460ff16156124565760405162461bcd60e51b8152600401610f3990613be6565b83601960008282546124689190613c1d565b9091555050336000908152601a602052604081208054869290611b28908490613c1d565b600060065482108015610da45750506000908152600a6020526040902054600160e01b900460ff161590565b6000828152600c602052604080822080546001600160a01b0319166001600160a01b0387811691821790925591518593918516917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591a4505050565b6000306001600160a01b037f00000000000000000000000000000000000000000000000000000000000000001614801561256d57507f000000000000000000000000000000000000000000000000000000000000000046145b1561259757507f000000000000000000000000000000000000000000000000000000000000000090565b50604080517f00000000000000000000000000000000000000000000000000000000000000006020808301919091527f0000000000000000000000000000000000000000000000000000000000000000828401527f000000000000000000000000000000000000000000000000000000000000000060608301524660808301523060a0808401919091528351808403909101815260c0909201909252805191012090565b6111f3828260405180602001604052806000815250612d85565b600e546001600160a01b0384166000908152601060205260408120549091839161267f9086613c49565b6126899190613c35565b6126939190613c68565b949350505050565b804710156126eb5760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a20696e73756666696369656e742062616c616e63650000006044820152606401610f39565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114612738576040519150601f19603f3d011682016040523d82523d6000602084013e61273d565b606091505b5050905080610f095760405162461bcd60e51b815260206004820152603a60248201527f416464726573733a20756e61626c6520746f2073656e642076616c75652c207260448201527f6563697069656e74206d617920686176652072657665727465640000000000006064820152608401610f39565b60006127bf826129f4565b9050836001600160a01b031681600001516001600160a01b0316146127f65760405162a1148160e81b815260040160405180910390fd5b6000336001600160a01b038616148061281457506128148533610c77565b8061282f57503361282484610e3c565b6001600160a01b0316145b90508061284f57604051632ce44b5f60e11b815260040160405180910390fd5b6001600160a01b03841661287657604051633a954ecd60e21b815260040160405180910390fd5b612882600084876124b8565b6001600160a01b038581166000908152600b60209081526040808320805467ffffffffffffffff198082166001600160401b0392831660001901831617909255898616808652838620805493841693831660019081018416949094179055898652600a90945282852080546001600160e01b031916909417600160a01b4290921691909102178355870180845292208054919390911661295657600654821461295657805460208601516001600160401b0316600160a01b026001600160e01b03199091166001600160a01b038a16171781555b50505082846001600160a01b0316866001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a45b5050505050565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b179052610f09908490612d92565b604080516060810182526000808252602082018190529181019190915281600654811015612af5576000818152600a6020908152604091829020825160608101845290546001600160a01b0381168252600160a01b81046001600160401b031692820192909252600160e01b90910460ff16151591810182905290612af35780516001600160a01b031615612a8a579392505050565b50600019016000818152600a6020908152604091829020825160608101845290546001600160a01b038116808352600160a01b82046001600160401b031693830193909352600160e01b900460ff1615159281019290925215612aee579392505050565b612a8a565b505b604051636f96cda160e11b815260040160405180910390fd5b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b604051630a85bd0160e11b81526000906001600160a01b0385169063150b7a0290612b93903390899088908890600401613a20565b602060405180830381600087803b158015612bad57600080fd5b505af1925050508015612bdd575060408051601f3d908101601f19168201909252612bda918101906138c0565b60015b612c38573d808015612c0b576040519150601f19603f3d011682016040523d82523d6000602084013e612c10565b606091505b508051612c30576040516368d2bf6b60e11b815260040160405180910390fd5b805181602001fd5b6001600160e01b031916630a85bd0160e11b149050949350505050565b6060601f8054610db990613cab565b606081612c885750506040805180820190915260018152600360fc1b602082015290565b8160005b8115612cb25780612c9c81613ce6565b9150612cab9050600a83613c35565b9150612c8c565b6000816001600160401b03811115612ccc57612ccc613d6d565b6040519080825280601f01601f191660200182016040528015612cf6576020820181803683370190505b5090505b841561269357612d0b600183613c68565b9150612d18600a86613d01565b612d23906030613c1d565b60f81b818381518110612d3857612d38613d57565b60200101906001600160f81b031916908160001a905350612d5a600a86613c35565b9450612cfa565b6000806000612d708585612e64565b91509150612d7d81612ed4565b509392505050565b610f09838383600161308f565b6000612de7826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b031661325f9092919063ffffffff16565b805190915015610f095780806020019051810190612e059190613868565b610f095760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6044820152691bdd081cdd58d8d9595960b21b6064820152608401610f39565b600080825160411415612e9b5760208301516040840151606085015160001a612e8f8782858561326e565b94509450505050612ecd565b825160401415612ec55760208301516040840151612eba86838361335b565b935093505050612ecd565b506000905060025b9250929050565b6000816004811115612ee857612ee8613d41565b1415612ef15750565b6001816004811115612f0557612f05613d41565b1415612f535760405162461bcd60e51b815260206004820152601860248201527f45434453413a20696e76616c6964207369676e617475726500000000000000006044820152606401610f39565b6002816004811115612f6757612f67613d41565b1415612fb55760405162461bcd60e51b815260206004820152601f60248201527f45434453413a20696e76616c6964207369676e6174757265206c656e677468006044820152606401610f39565b6003816004811115612fc957612fc9613d41565b14156130225760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202773272076616c604482015261756560f01b6064820152608401610f39565b600481600481111561303657613036613d41565b14156112765760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202776272076616c604482015261756560f01b6064820152608401610f39565b6006546001600160a01b0385166130b857604051622e076360e81b815260040160405180910390fd5b836130d65760405163b562e8dd60e01b815260040160405180910390fd5b6001600160a01b0385166000818152600b6020908152604080832080546fffffffffffffffffffffffffffffffff1981166001600160401b038083168c0181169182176801000000000000000067ffffffffffffffff1990941690921783900481168c01811690920217909155858452600a90925290912080546001600160e01b031916909217600160a01b42909216919091021790558080850183801561318757506001600160a01b0387163b15155b15613210575b60405182906001600160a01b038916906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a46131d86000888480600101955088612b5e565b6131f5576040516368d2bf6b60e11b815260040160405180910390fd5b8082141561318d57826006541461320b57600080fd5b613256565b5b6040516001830192906001600160a01b038916906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a480821415613211575b5060065561299b565b60606126938484600085613394565b6000807f7fffffffffffffffffffffffffffffff5d576e7357a4501ddfe92f46681b20a08311156132a55750600090506003613352565b8460ff16601b141580156132bd57508460ff16601c14155b156132ce5750600090506004613352565b6040805160008082526020820180845289905260ff881692820192909252606081018690526080810185905260019060a0016020604051602081039080840390855afa158015613322573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b03811661334b57600060019250925050613352565b9150600090505b94509492505050565b6000806001600160ff1b0383168161337860ff86901c601b613c1d565b90506133868782888561326e565b935093505050935093915050565b6060824710156133f55760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f6044820152651c8818d85b1b60d21b6064820152608401610f39565b6001600160a01b0385163b61344c5760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610f39565b600080866001600160a01b0316858760405161346891906139d5565b60006040518083038185875af1925050503d80600081146134a5576040519150601f19603f3d011682016040523d82523d6000602084013e6134aa565b606091505b50915091506134ba8282866134c5565b979650505050505050565b606083156134d4575081611e50565b8251156134e45782518084602001fd5b8160405162461bcd60e51b8152600401610f399190613a5d565b82805461350a90613cab565b90600052602060002090601f01602090048101928261352c5760008555613572565b82601f1061354557805160ff1916838001178555613572565b82800160010185558215613572579182015b82811115613572578251825591602001919060010190613557565b5061357e929150613582565b5090565b5b8082111561357e5760008155600101613583565b60006001600160401b03808411156135b1576135b1613d6d565b604051601f8501601f19908116603f011681019082821181831017156135d9576135d9613d6d565b816040528093508581528686860111156135f257600080fd5b858560208301376000602087830101525050509392505050565b600082601f83011261361d57600080fd5b611e5083833560208501613597565b60006020828403121561363e57600080fd5b8135611e5081613d83565b6000806040838503121561365c57600080fd5b823561366781613d83565b9150602083013561367781613d83565b809150509250929050565b60008060006060848603121561369757600080fd5b83356136a281613d83565b925060208401356136b281613d83565b929592945050506040919091013590565b600080600080608085870312156136d957600080fd5b84356136e481613d83565b935060208501356136f481613d83565b92506040850135915060608501356001600160401b0381111561371657600080fd5b6137228782880161360c565b91505092959194509250565b6000806040838503121561374157600080fd5b823561374c81613d83565b9150602083013561367781613d98565b6000806040838503121561376f57600080fd5b823561377a81613d83565b915060208301356001600160401b0381111561379557600080fd5b6137a18582860161360c565b9150509250929050565b600080604083850312156137be57600080fd5b82356137c981613d83565b946020939093013593505050565b600080602083850312156137ea57600080fd5b82356001600160401b038082111561380157600080fd5b818501915085601f83011261381557600080fd5b81358181111561382457600080fd5b8660208260051b850101111561383957600080fd5b60209290920196919550909350505050565b60006020828403121561385d57600080fd5b8135611e5081613d98565b60006020828403121561387a57600080fd5b8151611e5081613d98565b6000806040838503121561389857600080fd5b82356137c981613d98565b6000602082840312156138b557600080fd5b8135611e5081613da6565b6000602082840312156138d257600080fd5b8151611e5081613da6565b6000602082840312156138ef57600080fd5b81356001600160401b0381111561390557600080fd5b8201601f8101841361391657600080fd5b61269384823560208401613597565b60006020828403121561393757600080fd5b5035919050565b60006020828403121561395057600080fd5b5051919050565b6000806040838503121561396a57600080fd5b8235915060208301356001600160401b0381111561379557600080fd5b6000806040838503121561399a57600080fd5b50508035926020909101359150565b600081518084526139c1816020860160208601613c7f565b601f01601f19169290920160200192915050565b600082516139e7818460208701613c7f565b9190910192915050565b60008351613a03818460208801613c7f565b835190830190613a17818360208801613c7f565b01949350505050565b6001600160a01b0385811682528416602082015260408101839052608060608201819052600090613a53908301846139a9565b9695505050505050565b602081526000611e5060208301846139a9565b60208082526029908201527f50726553616c657341637469766174696f6e3a2053616c65206973206e6f74206040820152681858dd1a5d985d195960ba1b606082015260800190565b6020808252601d908201527f434f4e5452414354535f4e4f545f414c4c4f5745445f544f5f4d494e54000000604082015260600190565b60208082526026908201527f5061796d656e7453706c69747465723a206163636f756e7420686173206e6f2060408201526573686172657360d01b606082015260800190565b6020808252602b908201527f5061796d656e7453706c69747465723a206163636f756e74206973206e6f742060408201526a191d59481c185e5b595b9d60aa1b606082015260800190565b602080825260169082015275115e18d95959081cd85b195cc81b585e081b1a5b5a5d60521b604082015260600190565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60208082526017908201527f54686520636f6e74726163742069732070617573656421000000000000000000604082015260600190565b60008219821115613c3057613c30613d15565b500190565b600082613c4457613c44613d2b565b500490565b6000816000190483118215151615613c6357613c63613d15565b500290565b600082821015613c7a57613c7a613d15565b500390565b60005b83811015613c9a578181015183820152602001613c82565b83811115611b385750506000910152565b600181811c90821680613cbf57607f821691505b60208210811415613ce057634e487b7160e01b600052602260045260246000fd5b50919050565b6000600019821415613cfa57613cfa613d15565b5060010190565b600082613d1057613d10613d2b565b500690565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052601260045260246000fd5b634e487b7160e01b600052602160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b6001600160a01b038116811461127657600080fd5b801515811461127657600080fd5b6001600160e01b03198116811461127657600080fdfea26469706673582212206f47ca89132ddeaaa7fadfe2e79252b1c7db72ef4eab884e1daac61fcc4d4ae364736f6c6343000807003300000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000000

Deployed Bytecode

0x6080604052600436106104355760003560e01c8063951cddd011610229578063c87b56dd1161012e578063e33b7de3116100b6578063ef81b4d41161007a578063ef81b4d414610cc5578063f2c4ce1e14610ce5578063f2fde38b14610d05578063f6ffab9b14610d25578063ff7fb00114610d4557600080fd5b8063e33b7de314610c11578063e53e3a0414610c26578063e6c3819c14610c46578063e985e9c514610c5c578063ed39039b14610ca557600080fd5b8063d5069924116100fd578063d506992414610b7f578063d6eec46a14610b9f578063d79779b214610bbb578063dee816e614610714578063e0a8085314610bf157600080fd5b8063c87b56dd14610ae9578063ce7c2ac214610b09578063d1ca131f14610b3f578063d338143814610b5f57600080fd5b8063a78a673f116101b1578063b5cf0c2211610180578063b5cf0c2214610a4a578063b7329d2b14610a6a578063b88d4fde14610a7f578063bd34fc5714610a9f578063c688387f14610ab557600080fd5b8063a78a673f14610a0a578063a8c733ca14610a20578063ac501c4114610558578063ae4384f114610a3557600080fd5b80639c123661116101f85780639c1236611461098b5780639e47efb8146109a1578063a22cb465146109b4578063a43c6536146109d4578063a50e89ff146109f557600080fd5b8063951cddd0146108fe57806395d89b411461092b5780639852595c1461094057806398d5fdca1461097657600080fd5b80633ccfd60b1161033a57806360869d9b116102c25780637b2ca386116102865780637b2ca3861461085e57806382afe550146108785780638b83209b146108935780638da5cb5b146108b35780638f7be8f2146108d157600080fd5b806360869d9b146107bc5780636352211e146107dc57806370a08231146107fc578063715018a61461081c578063791eef071461083157600080fd5b806348b750441161030957806348b750441461072a5780634d192b831461074a5780634def4d1a1461075d578063518302271461077d5780635c975abb1461079d57600080fd5b80633ccfd60b146106a6578063406072a9146106ae57806342842e0e146106f457806347fc6e761461071457600080fd5b806316c38b3c116103bd57806330176e131161038c57806330176e13146106305780633354fe3414610650578063397d0c0c146106655780633a4087c71461067b5780633a98ef391461069157600080fd5b806316c38b3c146105b757806318160ddd146105d757806319165587146105f057806323b872dd1461061057600080fd5b8063095ea7b311610404578063095ea7b314610536578063122be4a31461055857806313c65a6e1461056d578063163e1e611461058257806316787758146105a257600080fd5b806301e3b4361461048357806301ffc9a7146104ac57806306fdde03146104dc578063081812fc146104fe57600080fd5b3661047e577f6ef95f06320e7a25a04a175ca677b7052bdd97131872c2192525a629f51be77033604080516001600160a01b0390921682523460208301520160405180910390a1005b600080fd5b34801561048f57600080fd5b5061049960175481565b6040519081526020015b60405180910390f35b3480156104b857600080fd5b506104cc6104c73660046138a3565b610d58565b60405190151581526020016104a3565b3480156104e857600080fd5b506104f1610daa565b6040516104a39190613a5d565b34801561050a57600080fd5b5061051e610519366004613925565b610e3c565b6040516001600160a01b0390911681526020016104a3565b34801561054257600080fd5b506105566105513660046137ab565b610e80565b005b34801561056457600080fd5b50610499600381565b34801561057957600080fd5b50610499610f0e565b34801561058e57600080fd5b5061055661059d3660046137d7565b610f4f565b3480156105ae57600080fd5b50610499600281565b3480156105c357600080fd5b506105566105d236600461384b565b611039565b3480156105e357600080fd5b5060075460065403610499565b3480156105fc57600080fd5b5061055661060b36600461362c565b61107d565b34801561061c57600080fd5b5061055661062b366004613682565b6111ab565b34801561063c57600080fd5b5061055661064b3660046138dd565b6111b6565b34801561065c57600080fd5b50610499601e81565b34801561067157600080fd5b5061049960025481565b34801561068757600080fd5b50610499601e5481565b34801561069d57600080fd5b50600e54610499565b6105566111f7565b3480156106ba57600080fd5b506104996106c9366004613649565b6001600160a01b03918216600090815260146020908152604080832093909416825291909152205490565b34801561070057600080fd5b5061055661070f366004613682565b611279565b34801561072057600080fd5b50610499610d0581565b34801561073657600080fd5b50610556610745366004613649565b611294565b610556610758366004613925565b61147c565b34801561076957600080fd5b5061055661077836600461384b565b6116cb565b34801561078957600080fd5b50601d546104cc9062010000900460ff1681565b3480156107a957600080fd5b50601d546104cc90610100900460ff1681565b3480156107c857600080fd5b506105566107d7366004613925565b611708565b3480156107e857600080fd5b5061051e6107f7366004613925565b611737565b34801561080857600080fd5b5061049961081736600461362c565b611749565b34801561082857600080fd5b50610556611797565b34801561083d57600080fd5b5061049961084c36600461362c565b601b6020526000908152604090205481565b34801561086a57600080fd5b50601d546104cc9060ff1681565b34801561088457600080fd5b50610499668e1bc9bf04000081565b34801561089f57600080fd5b5061051e6108ae366004613925565b61182a565b3480156108bf57600080fd5b506000546001600160a01b031661051e565b3480156108dd57600080fd5b506104996108ec36600461362c565b601c6020526000908152604090205481565b34801561090a57600080fd5b5061049961091936600461362c565b601a6020526000908152604090205481565b34801561093757600080fd5b506104f161185a565b34801561094c57600080fd5b5061049961095b36600461362c565b6001600160a01b031660009081526011602052604090205490565b34801561098257600080fd5b50610499611869565b34801561099757600080fd5b5061049960185481565b6105566109af366004613957565b6118aa565b3480156109c057600080fd5b506105566109cf36600461372e565b611b3e565b3480156109e057600080fd5b50601d546104cc906301000000900460ff1681565b348015610a0157600080fd5b50610556611bd4565b348015610a1657600080fd5b5061049960035481565b348015610a2c57600080fd5b50610499600181565b348015610a4157600080fd5b506104cc611c53565b348015610a5657600080fd5b5060055461051e906001600160a01b031681565b348015610a7657600080fd5b506104cc611c6b565b348015610a8b57600080fd5b50610556610a9a3660046136c3565b611c9f565b348015610aab57600080fd5b5061049960195481565b348015610ac157600080fd5b506104997ff59780ff8f4ba89ed09d6c9fc5aec79093994c7234326cb09aafc9bf724f074181565b348015610af557600080fd5b506104f1610b04366004613925565b611cea565b348015610b1557600080fd5b50610499610b2436600461362c565b6001600160a01b031660009081526010602052604090205490565b348015610b4b57600080fd5b50610499610b5a36600461362c565b611e57565b348015610b6b57600080fd5b50610556610b7a36600461362c565b611f3f565b348015610b8b57600080fd5b50610556610b9a366004613885565b611f8b565b348015610bab57600080fd5b5061049967011c37937e08000081565b348015610bc757600080fd5b50610499610bd636600461362c565b6001600160a01b031660009081526013602052604090205490565b348015610bfd57600080fd5b50610556610c0c36600461384b565b611fd7565b348015610c1d57600080fd5b50600f54610499565b348015610c3257600080fd5b5061051e610c4136600461375c565b61201d565b348015610c5257600080fd5b5061049960015481565b348015610c6857600080fd5b506104cc610c77366004613649565b6001600160a01b039182166000908152600d6020908152604080832093909416825291909152205460ff1690565b348015610cb157600080fd5b50610556610cc0366004613987565b612031565b348015610cd157600080fd5b5060045461051e906001600160a01b031681565b348015610cf157600080fd5b50610556610d003660046138dd565b6120dc565b348015610d1157600080fd5b50610556610d2036600461362c565b612118565b348015610d3157600080fd5b50610556610d4036600461362c565b6121b0565b610556610d53366004613957565b6121fc565b60006001600160e01b031982166380ac58cd60e01b1480610d8957506001600160e01b03198216635b5e139f60e01b145b80610da457506301ffc9a760e01b6001600160e01b03198316145b92915050565b606060088054610db990613cab565b80601f0160208091040260200160405190810160405280929190818152602001828054610de590613cab565b8015610e325780601f10610e0757610100808354040283529160200191610e32565b820191906000526020600020905b815481529060010190602001808311610e1557829003601f168201915b5050505050905090565b6000610e478261248c565b610e64576040516333d1c03960e21b815260040160405180910390fd5b506000908152600c60205260409020546001600160a01b031690565b6000610e8b82611737565b9050806001600160a01b0316836001600160a01b03161415610ec05760405163250fdee360e21b815260040160405180910390fd5b336001600160a01b03821614801590610ee05750610ede8133610c77565b155b15610efe576040516367d9dca160e11b815260040160405180910390fd5b610f098383836124b8565b505050565b600080546001600160a01b03163314610f425760405162461bcd60e51b8152600401610f3990613bb1565b60405180910390fd5b610f4a612514565b905090565b6000546001600160a01b03163314610f795760405162461bcd60e51b8152600401610f3990613bb1565b601954601e90610f8a908390613c1d565b1115610fd05760405162461bcd60e51b8152602060048201526015602482015274115e18d959590819da599d081b585e081b1a5b5a5d605a1b6044820152606401610f39565b8181905060196000828254610fe59190613c1d565b90915550600090505b81811015610f095761102783838381811061100b5761100b613d57565b9050602002016020810190611020919061362c565b600161263b565b8061103181613ce6565b915050610fee565b6000546001600160a01b031633146110635760405162461bcd60e51b8152600401610f3990613bb1565b601d80549115156101000261ff0019909216919091179055565b6001600160a01b0381166000908152601060205260409020546110b25760405162461bcd60e51b8152600401610f3990613af0565b60006110bd600f5490565b6110c79047613c1d565b905060006110f483836110ef866001600160a01b031660009081526011602052604090205490565b612655565b9050806111135760405162461bcd60e51b8152600401610f3990613b36565b6001600160a01b0383166000908152601160205260408120805483929061113b908490613c1d565b9250508190555080600f60008282546111549190613c1d565b909155506111649050838261269b565b604080516001600160a01b0385168152602081018390527fdf20fd1e76bc69d672e4814fafb2c449bba3a5369d8359adf9e05e6fde87b056910160405180910390a1505050565b610f098383836127b4565b6000546001600160a01b031633146111e05760405162461bcd60e51b8152600401610f3990613bb1565b80516111f390601f9060208401906134fe565b5050565b6000546001600160a01b031633146112215760405162461bcd60e51b8152600401610f3990613bb1565b604051600090339047908381818185875af1925050503d8060008114611263576040519150601f19603f3d011682016040523d82523d6000602084013e611268565b606091505b505090508061127657600080fd5b50565b610f0983838360405180602001604052806000815250611c9f565b6001600160a01b0381166000908152601060205260409020546112c95760405162461bcd60e51b8152600401610f3990613af0565b6001600160a01b0382166000908152601360205260408120546040516370a0823160e01b81523060048201526001600160a01b038516906370a082319060240160206040518083038186803b15801561132157600080fd5b505afa158015611335573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611359919061393e565b6113639190613c1d565b9050600061139c83836110ef87876001600160a01b03918216600090815260146020908152604080832093909416825291909152205490565b9050806113bb5760405162461bcd60e51b8152600401610f3990613b36565b6001600160a01b038085166000908152601460209081526040808320938716835292905290812080548392906113f2908490613c1d565b90915550506001600160a01b0384166000908152601360205260408120805483929061141f908490613c1d565b9091555061143090508484836129a2565b604080516001600160a01b038581168252602082018490528616917f3be5b7a71e84ed12875d241991c70855ac5817d847039e17a9d895c1ceb0f18a910160405180910390a250505050565b611484611c53565b6114e55760405162461bcd60e51b815260206004820152602c60248201527f5075626c696353616c657341637469766174696f6e3a2053616c65206973206e60448201526b1bdd081858dd1a5d985d195960a21b6064820152608401610f39565b610d05816019546018546017546114fc9190613c1d565b6115069190613c1d565b6115109190613c1d565b111561152e5760405162461bcd60e51b8152600401610f3990613b81565b600381111561157f5760405162461bcd60e51b815260206004820152601960248201527f457863656564206d6178206d696e7420706572206d696e742e000000000000006044820152606401610f39565b336000908152601c602052604090205460039061159d908390613c1d565b11156115eb5760405162461bcd60e51b815260206004820152601a60248201527f457863656564206d6178206d696e7420706572206d696e7465720000000000006044820152606401610f39565b32331461160a5760405162461bcd60e51b8152600401610f3990613ab9565b601d54610100900460ff16156116325760405162461bcd60e51b8152600401610f3990613be6565b61163a611869565b6116449082613c49565b3410156116835760405162461bcd60e51b815260206004820152600d60248201526c092dcc6dee4e4cac6e8408aa89609b1b6044820152606401610f39565b336000908152601c6020526040812080548392906116a2908490613c1d565b9250508190555080601860008282546116bb9190613c1d565b909155506112769050338261263b565b6000546001600160a01b031633146116f55760405162461bcd60e51b8152600401610f3990613bb1565b601d805460ff1916911515919091179055565b6000546001600160a01b031633146117325760405162461bcd60e51b8152600401610f3990613bb1565b600155565b6000611742826129f4565b5192915050565b60006001600160a01b038216611772576040516323d3ad8160e21b815260040160405180910390fd5b506001600160a01b03166000908152600b60205260409020546001600160401b031690565b6000546001600160a01b031633146117c15760405162461bcd60e51b8152600401610f3990613bb1565b601d5460ff1661181e5760405162461bcd60e51b815260206004820152602260248201527f4e6f74207468652074696d6520746f2052656e6f756e6365204f776e65727368604482015261069760f41b6064820152608401610f39565b6118286000612b0e565b565b60006012828154811061183f5761183f613d57565b6000918252602090912001546001600160a01b031692915050565b606060098054610db990613cab565b6000611873611c53565b1561189e57601d546301000000900460ff16156118915750601e5490565b5067011c37937e08000090565b50668e1bc9bf04000090565b6118b2611c6b565b6118ce5760405162461bcd60e51b8152600401610f3990613a70565b600454339082906001600160a01b03166118e8838361201d565b6001600160a01b03161461193e5760405162461bcd60e51b815260206004820152601860248201527f55736572206973206e6f74206f6e2077686974656c69737400000000000000006044820152606401610f39565b610d05846019546018546017546119559190613c1d565b61195f9190613c1d565b6119699190613c1d565b11156119875760405162461bcd60e51b8152600401610f3990613b81565b610d058460195460175461199b9190613c1d565b6119a59190613c1d565b11156119f35760405162461bcd60e51b815260206004820152601a60248201527f457863656564207072652d73616c6573206d6178206c696d69740000000000006044820152606401610f39565b336000908152601b6020526040902054600290611a11908690613c1d565b1115611a585760405162461bcd60e51b8152602060048201526016602482015275457863656564207369676e6564207175616e7469747960501b6044820152606401610f39565b323314611a775760405162461bcd60e51b8152600401610f3990613ab9565b601d54610100900460ff1615611a9f5760405162461bcd60e51b8152600401610f3990613be6565b611aa7611869565b611ab19085613c49565b341015611af05760405162461bcd60e51b815260206004820152600d60248201526c092dcc6dee4e4cac6e8408aa89609b1b6044820152606401610f39565b336000908152601b602052604081208054869290611b0f908490613c1d565b925050819055508360176000828254611b289190613c1d565b90915550611b389050338561263b565b50505050565b6001600160a01b038216331415611b685760405163b06307db60e01b815260040160405180910390fd5b336000818152600d602090815260408083206001600160a01b03871680855290835292819020805460ff191686151590811790915590519081529192917f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a35050565b6000546001600160a01b03163314611bfe5760405162461bcd60e51b8152600401610f3990613bb1565b60005b60155481101561127657600060158281548110611c2057611c20613d57565b6000918252602090912001546001600160a01b03169050611c408161107d565b5080611c4b81613ce6565b915050611c01565b600080600154118015610f4a57505060015442101590565b600080600254118015611c8057506000600354115b8015611c8e57506002544210155b8015610f4a57505060035442111590565b611caa8484846127b4565b6001600160a01b0383163b15158015611ccc5750611cca84848484612b5e565b155b15611b38576040516368d2bf6b60e11b815260040160405180910390fd5b6060611cf58261248c565b611d595760405162461bcd60e51b815260206004820152602f60248201527f4552433732314d657461646174613a2055524920717565727920666f72206e6f60448201526e3732bc34b9ba32b73a103a37b5b2b760891b6064820152608401610f39565b601d5462010000900460ff16611dfb5760208054611d7690613cab565b80601f0160208091040260200160405190810160405280929190818152602001828054611da290613cab565b8015611def5780601f10611dc457610100808354040283529160200191611def565b820191906000526020600020905b815481529060010190602001808311611dd257829003601f168201915b50505050509050919050565b6000611e05612c55565b90506000815111611e255760405180602001604052806000815250611e50565b80611e2f84612c64565b604051602001611e409291906139f1565b6040516020818303038152906040525b9392505050565b600080611eec611e65612514565b604080517ff59780ff8f4ba89ed09d6c9fc5aec79093994c7234326cb09aafc9bf724f07416020808301919091526001600160a01b0388168284015282518083038401815260608301845280519082012061190160f01b6080840152608283019490945260a2808301949094528251808303909401845260c2909101909152815191012090565b6040517f19457468657265756d205369676e6564204d6573736167653a0a3332000000006020820152603c810191909152605c0160408051601f1981840301815291905280516020909101209392505050565b6000546001600160a01b03163314611f695760405162461bcd60e51b8152600401610f3990613bb1565b600480546001600160a01b0319166001600160a01b0392909216919091179055565b6000546001600160a01b03163314611fb55760405162461bcd60e51b8152600401610f3990613bb1565b601d805492151563010000000263ff0000001990931692909217909155601e55565b6000546001600160a01b031633146120015760405162461bcd60e51b8152600401610f3990613bb1565b601d8054911515620100000262ff000019909216919091179055565b6000611e5061202b84611e57565b83612d61565b6000546001600160a01b0316331461205b5760405162461bcd60e51b8152600401610f3990613bb1565b818110156120d15760405162461bcd60e51b815260206004820152603c60248201527f50726553616c657341637469766174696f6e3a20456e642074696d652073686f60448201527f756c64206265206c61746572207468616e2073746172742074696d65000000006064820152608401610f39565b600291909155600355565b6000546001600160a01b031633146121065760405162461bcd60e51b8152600401610f3990613bb1565b80516111f390602090818401906134fe565b6000546001600160a01b031633146121425760405162461bcd60e51b8152600401610f3990613bb1565b6001600160a01b0381166121a75760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610f39565b61127681612b0e565b6000546001600160a01b031633146121da5760405162461bcd60e51b8152600401610f3990613bb1565b600580546001600160a01b0319166001600160a01b0392909216919091179055565b612204611c6b565b6122205760405162461bcd60e51b8152600401610f3990613a70565b600554339082906001600160a01b031661223a838361201d565b6001600160a01b0316146122905760405162461bcd60e51b815260206004820152601d60248201527f55736572206973206e6f74206f6e2077686974656c69737420467265650000006044820152606401610f39565b610d05846019546018546017546122a79190613c1d565b6122b19190613c1d565b6122bb9190613c1d565b11156122d95760405162461bcd60e51b8152600401610f3990613b81565b610d05846019546017546122ed9190613c1d565b6122f79190613c1d565b11156123455760405162461bcd60e51b815260206004820152601a60248201527f457863656564207072652d73616c6573206d6178206c696d69740000000000006044820152606401610f39565b336000908152601a6020526040902054600190612363908690613c1d565b11156123b15760405162461bcd60e51b815260206004820152601b60248201527f457863656564207369676e65642067696674207175616e7469747900000000006044820152606401610f39565b601e846019546123c19190613c1d565b111561240f5760405162461bcd60e51b815260206004820152601c60248201527f457863656564207369676e65642067696674206d6178206c696d6974000000006044820152606401610f39565b32331461242e5760405162461bcd60e51b8152600401610f3990613ab9565b601d54610100900460ff16156124565760405162461bcd60e51b8152600401610f3990613be6565b83601960008282546124689190613c1d565b9091555050336000908152601a602052604081208054869290611b28908490613c1d565b600060065482108015610da45750506000908152600a6020526040902054600160e01b900460ff161590565b6000828152600c602052604080822080546001600160a01b0319166001600160a01b0387811691821790925591518593918516917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591a4505050565b6000306001600160a01b037f000000000000000000000000c4f7fddf7ce4d60fdbaf2adb9db596549d78bb371614801561256d57507f000000000000000000000000000000000000000000000000000000000000000146145b1561259757507fce205c5bd7feb89c7023ff508d16c423c7db5cf2a9fafe4cd934eed8b00f4b8a90565b50604080517f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f6020808301919091527f7fc3c792eabad8fdf05f63c12644e1f02ee16b6de82c80474c7066cee41e3d16828401527fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc660608301524660808301523060a0808401919091528351808403909101815260c0909201909252805191012090565b6111f3828260405180602001604052806000815250612d85565b600e546001600160a01b0384166000908152601060205260408120549091839161267f9086613c49565b6126899190613c35565b6126939190613c68565b949350505050565b804710156126eb5760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a20696e73756666696369656e742062616c616e63650000006044820152606401610f39565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114612738576040519150601f19603f3d011682016040523d82523d6000602084013e61273d565b606091505b5050905080610f095760405162461bcd60e51b815260206004820152603a60248201527f416464726573733a20756e61626c6520746f2073656e642076616c75652c207260448201527f6563697069656e74206d617920686176652072657665727465640000000000006064820152608401610f39565b60006127bf826129f4565b9050836001600160a01b031681600001516001600160a01b0316146127f65760405162a1148160e81b815260040160405180910390fd5b6000336001600160a01b038616148061281457506128148533610c77565b8061282f57503361282484610e3c565b6001600160a01b0316145b90508061284f57604051632ce44b5f60e11b815260040160405180910390fd5b6001600160a01b03841661287657604051633a954ecd60e21b815260040160405180910390fd5b612882600084876124b8565b6001600160a01b038581166000908152600b60209081526040808320805467ffffffffffffffff198082166001600160401b0392831660001901831617909255898616808652838620805493841693831660019081018416949094179055898652600a90945282852080546001600160e01b031916909417600160a01b4290921691909102178355870180845292208054919390911661295657600654821461295657805460208601516001600160401b0316600160a01b026001600160e01b03199091166001600160a01b038a16171781555b50505082846001600160a01b0316866001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a45b5050505050565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b179052610f09908490612d92565b604080516060810182526000808252602082018190529181019190915281600654811015612af5576000818152600a6020908152604091829020825160608101845290546001600160a01b0381168252600160a01b81046001600160401b031692820192909252600160e01b90910460ff16151591810182905290612af35780516001600160a01b031615612a8a579392505050565b50600019016000818152600a6020908152604091829020825160608101845290546001600160a01b038116808352600160a01b82046001600160401b031693830193909352600160e01b900460ff1615159281019290925215612aee579392505050565b612a8a565b505b604051636f96cda160e11b815260040160405180910390fd5b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b604051630a85bd0160e11b81526000906001600160a01b0385169063150b7a0290612b93903390899088908890600401613a20565b602060405180830381600087803b158015612bad57600080fd5b505af1925050508015612bdd575060408051601f3d908101601f19168201909252612bda918101906138c0565b60015b612c38573d808015612c0b576040519150601f19603f3d011682016040523d82523d6000602084013e612c10565b606091505b508051612c30576040516368d2bf6b60e11b815260040160405180910390fd5b805181602001fd5b6001600160e01b031916630a85bd0160e11b149050949350505050565b6060601f8054610db990613cab565b606081612c885750506040805180820190915260018152600360fc1b602082015290565b8160005b8115612cb25780612c9c81613ce6565b9150612cab9050600a83613c35565b9150612c8c565b6000816001600160401b03811115612ccc57612ccc613d6d565b6040519080825280601f01601f191660200182016040528015612cf6576020820181803683370190505b5090505b841561269357612d0b600183613c68565b9150612d18600a86613d01565b612d23906030613c1d565b60f81b818381518110612d3857612d38613d57565b60200101906001600160f81b031916908160001a905350612d5a600a86613c35565b9450612cfa565b6000806000612d708585612e64565b91509150612d7d81612ed4565b509392505050565b610f09838383600161308f565b6000612de7826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b031661325f9092919063ffffffff16565b805190915015610f095780806020019051810190612e059190613868565b610f095760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6044820152691bdd081cdd58d8d9595960b21b6064820152608401610f39565b600080825160411415612e9b5760208301516040840151606085015160001a612e8f8782858561326e565b94509450505050612ecd565b825160401415612ec55760208301516040840151612eba86838361335b565b935093505050612ecd565b506000905060025b9250929050565b6000816004811115612ee857612ee8613d41565b1415612ef15750565b6001816004811115612f0557612f05613d41565b1415612f535760405162461bcd60e51b815260206004820152601860248201527f45434453413a20696e76616c6964207369676e617475726500000000000000006044820152606401610f39565b6002816004811115612f6757612f67613d41565b1415612fb55760405162461bcd60e51b815260206004820152601f60248201527f45434453413a20696e76616c6964207369676e6174757265206c656e677468006044820152606401610f39565b6003816004811115612fc957612fc9613d41565b14156130225760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202773272076616c604482015261756560f01b6064820152608401610f39565b600481600481111561303657613036613d41565b14156112765760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202776272076616c604482015261756560f01b6064820152608401610f39565b6006546001600160a01b0385166130b857604051622e076360e81b815260040160405180910390fd5b836130d65760405163b562e8dd60e01b815260040160405180910390fd5b6001600160a01b0385166000818152600b6020908152604080832080546fffffffffffffffffffffffffffffffff1981166001600160401b038083168c0181169182176801000000000000000067ffffffffffffffff1990941690921783900481168c01811690920217909155858452600a90925290912080546001600160e01b031916909217600160a01b42909216919091021790558080850183801561318757506001600160a01b0387163b15155b15613210575b60405182906001600160a01b038916906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a46131d86000888480600101955088612b5e565b6131f5576040516368d2bf6b60e11b815260040160405180910390fd5b8082141561318d57826006541461320b57600080fd5b613256565b5b6040516001830192906001600160a01b038916906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a480821415613211575b5060065561299b565b60606126938484600085613394565b6000807f7fffffffffffffffffffffffffffffff5d576e7357a4501ddfe92f46681b20a08311156132a55750600090506003613352565b8460ff16601b141580156132bd57508460ff16601c14155b156132ce5750600090506004613352565b6040805160008082526020820180845289905260ff881692820192909252606081018690526080810185905260019060a0016020604051602081039080840390855afa158015613322573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b03811661334b57600060019250925050613352565b9150600090505b94509492505050565b6000806001600160ff1b0383168161337860ff86901c601b613c1d565b90506133868782888561326e565b935093505050935093915050565b6060824710156133f55760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f6044820152651c8818d85b1b60d21b6064820152608401610f39565b6001600160a01b0385163b61344c5760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610f39565b600080866001600160a01b0316858760405161346891906139d5565b60006040518083038185875af1925050503d80600081146134a5576040519150601f19603f3d011682016040523d82523d6000602084013e6134aa565b606091505b50915091506134ba8282866134c5565b979650505050505050565b606083156134d4575081611e50565b8251156134e45782518084602001fd5b8160405162461bcd60e51b8152600401610f399190613a5d565b82805461350a90613cab565b90600052602060002090601f01602090048101928261352c5760008555613572565b82601f1061354557805160ff1916838001178555613572565b82800160010185558215613572579182015b82811115613572578251825591602001919060010190613557565b5061357e929150613582565b5090565b5b8082111561357e5760008155600101613583565b60006001600160401b03808411156135b1576135b1613d6d565b604051601f8501601f19908116603f011681019082821181831017156135d9576135d9613d6d565b816040528093508581528686860111156135f257600080fd5b858560208301376000602087830101525050509392505050565b600082601f83011261361d57600080fd5b611e5083833560208501613597565b60006020828403121561363e57600080fd5b8135611e5081613d83565b6000806040838503121561365c57600080fd5b823561366781613d83565b9150602083013561367781613d83565b809150509250929050565b60008060006060848603121561369757600080fd5b83356136a281613d83565b925060208401356136b281613d83565b929592945050506040919091013590565b600080600080608085870312156136d957600080fd5b84356136e481613d83565b935060208501356136f481613d83565b92506040850135915060608501356001600160401b0381111561371657600080fd5b6137228782880161360c565b91505092959194509250565b6000806040838503121561374157600080fd5b823561374c81613d83565b9150602083013561367781613d98565b6000806040838503121561376f57600080fd5b823561377a81613d83565b915060208301356001600160401b0381111561379557600080fd5b6137a18582860161360c565b9150509250929050565b600080604083850312156137be57600080fd5b82356137c981613d83565b946020939093013593505050565b600080602083850312156137ea57600080fd5b82356001600160401b038082111561380157600080fd5b818501915085601f83011261381557600080fd5b81358181111561382457600080fd5b8660208260051b850101111561383957600080fd5b60209290920196919550909350505050565b60006020828403121561385d57600080fd5b8135611e5081613d98565b60006020828403121561387a57600080fd5b8151611e5081613d98565b6000806040838503121561389857600080fd5b82356137c981613d98565b6000602082840312156138b557600080fd5b8135611e5081613da6565b6000602082840312156138d257600080fd5b8151611e5081613da6565b6000602082840312156138ef57600080fd5b81356001600160401b0381111561390557600080fd5b8201601f8101841361391657600080fd5b61269384823560208401613597565b60006020828403121561393757600080fd5b5035919050565b60006020828403121561395057600080fd5b5051919050565b6000806040838503121561396a57600080fd5b8235915060208301356001600160401b0381111561379557600080fd5b6000806040838503121561399a57600080fd5b50508035926020909101359150565b600081518084526139c1816020860160208601613c7f565b601f01601f19169290920160200192915050565b600082516139e7818460208701613c7f565b9190910192915050565b60008351613a03818460208801613c7f565b835190830190613a17818360208801613c7f565b01949350505050565b6001600160a01b0385811682528416602082015260408101839052608060608201819052600090613a53908301846139a9565b9695505050505050565b602081526000611e5060208301846139a9565b60208082526029908201527f50726553616c657341637469766174696f6e3a2053616c65206973206e6f74206040820152681858dd1a5d985d195960ba1b606082015260800190565b6020808252601d908201527f434f4e5452414354535f4e4f545f414c4c4f5745445f544f5f4d494e54000000604082015260600190565b60208082526026908201527f5061796d656e7453706c69747465723a206163636f756e7420686173206e6f2060408201526573686172657360d01b606082015260800190565b6020808252602b908201527f5061796d656e7453706c69747465723a206163636f756e74206973206e6f742060408201526a191d59481c185e5b595b9d60aa1b606082015260800190565b602080825260169082015275115e18d95959081cd85b195cc81b585e081b1a5b5a5d60521b604082015260600190565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60208082526017908201527f54686520636f6e74726163742069732070617573656421000000000000000000604082015260600190565b60008219821115613c3057613c30613d15565b500190565b600082613c4457613c44613d2b565b500490565b6000816000190483118215151615613c6357613c63613d15565b500290565b600082821015613c7a57613c7a613d15565b500390565b60005b83811015613c9a578181015183820152602001613c82565b83811115611b385750506000910152565b600181811c90821680613cbf57607f821691505b60208210811415613ce057634e487b7160e01b600052602260045260246000fd5b50919050565b6000600019821415613cfa57613cfa613d15565b5060010190565b600082613d1057613d10613d2b565b500690565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052601260045260246000fd5b634e487b7160e01b600052602160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b6001600160a01b038116811461127657600080fd5b801515811461127657600080fd5b6001600160e01b03198116811461127657600080fdfea26469706673582212206f47ca89132ddeaaa7fadfe2e79252b1c7db72ef4eab884e1daac61fcc4d4ae364736f6c63430008070033

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

00000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000000

-----Decoded View---------------
Arg [0] : _notRevealedUri (string):

-----Encoded View---------------
2 Constructor Arguments found :
Arg [0] : 0000000000000000000000000000000000000000000000000000000000000020
Arg [1] : 0000000000000000000000000000000000000000000000000000000000000000


Deployed Bytecode Sourcemap

141061:7347:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;130085:40;104692:10;130085:40;;;-1:-1:-1;;;;;10576:32:1;;;10558:51;;130115:9:0;10640:2:1;10625:18;;10618:34;10531:18;130085:40:0;;;;;;;141061:7347;;;;;141818:36;;;;;;;;;;;;;;;;;;;11773:25:1;;;11761:2;11746:18;141818:36:0;;;;;;;;109096:305;;;;;;;;;;-1:-1:-1;109096:305:0;;;;;:::i;:::-;;:::i;:::-;;;11600:14:1;;11593:22;11575:41;;11563:2;11548:18;109096:305:0;11435:187:1;112209:100:0;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;113712:204::-;;;;;;;;;;-1:-1:-1;113712:204:0;;;;;:::i;:::-;;:::i;:::-;;;-1:-1:-1;;;;;10332:32:1;;;10314:51;;10302:2;10287:18;113712:204:0;10168:203:1;113275:371:0;;;;;;;;;;-1:-1:-1;113275:371:0;;;;;:::i;:::-;;:::i;:::-;;141502:44;;;;;;;;;;;;141545:1;141502:44;;138548:121;;;;;;;;;;;;;:::i;146048:351::-;;;;;;;;;;-1:-1:-1;146048:351:0;;;;;:::i;:::-;;:::i;141553:56::-;;;;;;;;;;;;141608:1;141553:56;;147052:86;;;;;;;;;;-1:-1:-1;147052:86:0;;;;;:::i;:::-;;:::i;108345:303::-;;;;;;;;;;-1:-1:-1;108599:12:0;;108583:13;;:28;108345:303;;131871:566;;;;;;;;;;-1:-1:-1;131871:566:0;;;;;:::i;:::-;;:::i;114577:170::-;;;;;;;;;;-1:-1:-1;114577:170:0;;;;;:::i;:::-;;:::i;146706:120::-;;;;;;;;;;-1:-1:-1;146706:120:0;;;;;:::i;:::-;;:::i;141226:41::-;;;;;;;;;;;;141265:2;141226:41;;138776:32;;;;;;;;;;;;;;;;142304:40;;;;;;;;;;;;;;;;130216:91;;;;;;;;;;-1:-1:-1;130287:12:0;;130216:91;;148019:165;;;:::i;131345:135::-;;;;;;;;;;-1:-1:-1;131345:135:0;;;;;:::i;:::-;-1:-1:-1;;;;;131442:21:0;;;131415:7;131442:21;;;:14;:21;;;;;;;;:30;;;;;;;;;;;;;131345:135;114818:185;;;;;;;;;;-1:-1:-1;114818:185:0;;;;;:::i;:::-;;:::i;141274:47::-;;;;;;;;;;;;141317:4;141274:47;;132705:641;;;;;;;;;;-1:-1:-1;132705:641:0;;;;;:::i;:::-;;:::i;145104:936::-;;;;;;:::i;:::-;;:::i;147146:114::-;;;;;;;;;;-1:-1:-1;147146:114:0;;;;;:::i;:::-;;:::i;142231:28::-;;;;;;;;;;-1:-1:-1;142231:28:0;;;;;;;;;;;142198:26;;;;;;;;;;-1:-1:-1;142198:26:0;;;;;;;;;;;140860:119;;;;;;;;;;-1:-1:-1;140860:119:0;;;;;:::i;:::-;;:::i;112017:125::-;;;;;;;;;;-1:-1:-1;112017:125:0;;;;;:::i;:::-;;:::i;109465:206::-;;;;;;;;;;-1:-1:-1;109465:206:0;;;;;:::i;:::-;;:::i;147831:180::-;;;;;;;;;;;;;:::i;142014:59::-;;;;;;;;;;-1:-1:-1;142014:59:0;;;;;:::i;:::-;;;;;;;;;;;;;;142151:40;;;;;;;;;;-1:-1:-1;142151:40:0;;;;;;;;141328:52;;;;;;;;;;;;141370:10;141328:52;;131571:100;;;;;;;;;;-1:-1:-1;131571:100:0;;;;;:::i;:::-;;:::i;135506:87::-;;;;;;;;;;-1:-1:-1;135552:7:0;135579:6;-1:-1:-1;;;;;135579:6:0;135506:87;;142080:62;;;;;;;;;;-1:-1:-1;142080:62:0;;;;;:::i;:::-;;;;;;;;;;;;;;141944:63;;;;;;;;;;-1:-1:-1;141944:63:0;;;;;:::i;:::-;;;;;;;;;;;;;;112378:104;;;;;;;;;;;;;:::i;131067:109::-;;;;;;;;;;-1:-1:-1;131067:109:0;;;;;:::i;:::-;-1:-1:-1;;;;;131150:18:0;131123:7;131150:18;;;:9;:18;;;;;;;131067:109;142598:290;;;;;;;;;;;;;:::i;141861:39::-;;;;;;;;;;;;;;;;142896:1064;;;;;;:::i;:::-;;:::i;113988:287::-;;;;;;;;;;-1:-1:-1;113988:287:0;;;;;:::i;:::-;;:::i;142266:31::-;;;;;;;;;;-1:-1:-1;142266:31:0;;;;;;;;;;;148189:214;;;;;;;;;;;;;:::i;138815:30::-;;;;;;;;;;;;;;;;141616:61;;;;;;;;;;;;141676:1;141616:61;;140615:167;;;;;;;;;;;;;:::i;137223:34::-;;;;;;;;;;-1:-1:-1;137223:34:0;;;;-1:-1:-1;;;;;137223:34:0;;;139353:258;;;;;;;;;;;;;:::i;115074:369::-;;;;;;;;;;-1:-1:-1;115074:369:0;;;;;:::i;:::-;;:::i;141907:28::-;;;;;;;;;;;;;;;;137094:81;;;;;;;;;;;;137140:35;137094:81;;147272:551;;;;;;;;;;-1:-1:-1;147272:551:0;;;;;:::i;:::-;;:::i;130863:105::-;;;;;;;;;;-1:-1:-1;130863:105:0;;;;;:::i;:::-;-1:-1:-1;;;;;130944:16:0;130917:7;130944:16;;;:7;:16;;;;;;;130863:105;137736:333;;;;;;;;;;-1:-1:-1;137736:333:0;;;;;:::i;:::-;;:::i;137322:110::-;;;;;;;;;;-1:-1:-1;137322:110:0;;;;;:::i;:::-;;:::i;146407:155::-;;;;;;;;;;-1:-1:-1;146407:155:0;;;;;:::i;:::-;;:::i;141387:55::-;;;;;;;;;;;;141432:10;141387:55;;130653:119;;;;;;;;;;-1:-1:-1;130653:119:0;;;;;:::i;:::-;-1:-1:-1;;;;;130738:26:0;130711:7;130738:26;;;:19;:26;;;;;;;130653:119;146953:90;;;;;;;;;;-1:-1:-1;146953:90:0;;;;;:::i;:::-;;:::i;130401:95::-;;;;;;;;;;-1:-1:-1;130474:14:0;;130401:95;;137566:162;;;;;;;;;;-1:-1:-1;137566:162:0;;;;;:::i;:::-;;:::i;140204:35::-;;;;;;;;;;;;;;;;114346:164;;;;;;;;;;-1:-1:-1;114346:164:0;;;;;:::i;:::-;-1:-1:-1;;;;;114467:25:0;;;114443:4;114467:25;;;:18;:25;;;;;;;;:35;;;;;;;;;;;;;;;114346:164;139757:334;;;;;;;;;;-1:-1:-1;139757:334:0;;;;;:::i;:::-;;:::i;137184:30::-;;;;;;;;;;-1:-1:-1;137184:30:0;;;;-1:-1:-1;;;;;137184:30:0;;;146570:128;;;;;;;;;;-1:-1:-1;146570:128:0;;;;;:::i;:::-;;:::i;136415:201::-;;;;;;;;;;-1:-1:-1;136415:201:0;;;;;:::i;:::-;;:::i;137440:118::-;;;;;;;;;;-1:-1:-1;137440:118:0;;;;;:::i;:::-;;:::i;143968:1128::-;;;;;;:::i;:::-;;:::i;109096:305::-;109198:4;-1:-1:-1;;;;;;109235:40:0;;-1:-1:-1;;;109235:40:0;;:105;;-1:-1:-1;;;;;;;109292:48:0;;-1:-1:-1;;;109292:48:0;109235:105;:158;;;-1:-1:-1;;;;;;;;;;2956:40:0;;;109357:36;109215:178;109096:305;-1:-1:-1;;109096:305:0:o;112209:100::-;112263:13;112296:5;112289:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;112209:100;:::o;113712:204::-;113780:7;113805:16;113813:7;113805;:16::i;:::-;113800:64;;113830:34;;-1:-1:-1;;;113830:34:0;;;;;;;;;;;113800:64;-1:-1:-1;113884:24:0;;;;:15;:24;;;;;;-1:-1:-1;;;;;113884:24:0;;113712:204::o;113275:371::-;113348:13;113364:24;113380:7;113364:15;:24::i;:::-;113348:40;;113409:5;-1:-1:-1;;;;;113403:11:0;:2;-1:-1:-1;;;;;113403:11:0;;113399:48;;;113423:24;;-1:-1:-1;;;113423:24:0;;;;;;;;;;;113399:48;104692:10;-1:-1:-1;;;;;113464:21:0;;;;;;:63;;-1:-1:-1;113490:37:0;113507:5;104692:10;114346:164;:::i;113490:37::-;113489:38;113464:63;113460:138;;;113551:35;;-1:-1:-1;;;113551:35:0;;;;;;;;;;;113460:138;113610:28;113619:2;113623:7;113632:5;113610:8;:28::i;:::-;113337:309;113275:371;;:::o;138548:121::-;138614:7;135579:6;;-1:-1:-1;;;;;135579:6:0;104692:10;135726:23;135718:68;;;;-1:-1:-1;;;135718:68:0;;;;;;;:::i;:::-;;;;;;;;;138641:20:::1;:18;:20::i;:::-;138634:27;;138548:121:::0;:::o;146048:351::-;135552:7;135579:6;-1:-1:-1;;;;;135579:6:0;104692:10;135726:23;135718:68;;;;-1:-1:-1;;;135718:68:0;;;;;;;:::i;:::-;146144:9:::1;::::0;141265:2:::1;::::0;146144:28:::1;::::0;146156:9;;146144:28:::1;:::i;:::-;:44;;146122:115;;;::::0;-1:-1:-1;;;146122:115:0;;19963:2:1;146122:115:0::1;::::0;::::1;19945:21:1::0;20002:2;19982:18;;;19975:30;-1:-1:-1;;;20021:18:1;;;20014:51;20082:18;;146122:115:0::1;19761:345:1::0;146122:115:0::1;146263:9;;:16;;146250:9;;:29;;;;;;;:::i;:::-;::::0;;;-1:-1:-1;146297:9:0::1;::::0;-1:-1:-1;146292:100:0::1;146312:20:::0;;::::1;146292:100;;;146354:26;146364:9;;146374:1;146364:12;;;;;;;:::i;:::-;;;;;;;;;;;;;;:::i;:::-;146378:1;146354:9;:26::i;:::-;146334:3:::0;::::1;::::0;::::1;:::i;:::-;;;;146292:100;;147052:86:::0;135552:7;135579:6;-1:-1:-1;;;;;135579:6:0;104692:10;135726:23;135718:68;;;;-1:-1:-1;;;135718:68:0;;;;;;;:::i;:::-;147115:6:::1;:15:::0;;;::::1;;;;-1:-1:-1::0;;147115:15:0;;::::1;::::0;;;::::1;::::0;;147052:86::o;131871:566::-;-1:-1:-1;;;;;131947:16:0;;131966:1;131947:16;;;:7;:16;;;;;;131939:71;;;;-1:-1:-1;;;131939:71:0;;;;;;;:::i;:::-;132023:21;132071:15;130474:14;;;130401:95;132071:15;132047:39;;:21;:39;:::i;:::-;132023:63;;132097:15;132115:58;132131:7;132140:13;132155:17;132164:7;-1:-1:-1;;;;;131150:18:0;131123:7;131150:18;;;:9;:18;;;;;;;131067:109;132155:17;132115:15;:58::i;:::-;132097:76;-1:-1:-1;132194:12:0;132186:68;;;;-1:-1:-1;;;132186:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;132267:18:0;;;;;;:9;:18;;;;;:29;;132289:7;;132267:18;:29;;132289:7;;132267:29;:::i;:::-;;;;;;;;132325:7;132307:14;;:25;;;;;;;:::i;:::-;;;;-1:-1:-1;132345:35:0;;-1:-1:-1;132363:7:0;132372;132345:17;:35::i;:::-;132396:33;;;-1:-1:-1;;;;;10576:32:1;;10558:51;;10640:2;10625:18;;10618:34;;;132396:33:0;;10531:18:1;132396:33:0;;;;;;;131928:509;;131871:566;:::o;114577:170::-;114711:28;114721:4;114727:2;114731:7;114711:9;:28::i;146706:120::-;135552:7;135579:6;-1:-1:-1;;;;;135579:6:0;104692:10;135726:23;135718:68;;;;-1:-1:-1;;;135718:68:0;;;;;;;:::i;:::-;146790:28;;::::1;::::0;:12:::1;::::0;:28:::1;::::0;::::1;::::0;::::1;:::i;:::-;;146706:120:::0;:::o;148019:165::-;135552:7;135579:6;-1:-1:-1;;;;;135579:6:0;104692:10;135726:23;135718:68;;;;-1:-1:-1;;;135718:68:0;;;;;;;:::i;:::-;148094:58:::1;::::0;148076:12:::1;::::0;148102:10:::1;::::0;148126:21:::1;::::0;148076:12;148094:58;148076:12;148094:58;148126:21;148102:10;148094:58:::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;148075:77;;;148171:7;148163:16;;;::::0;::::1;;148064:120;148019:165::o:0;114818:185::-;114956:39;114973:4;114979:2;114983:7;114956:39;;;;;;;;;;;;:16;:39::i;132705:641::-;-1:-1:-1;;;;;132787:16:0;;132806:1;132787:16;;;:7;:16;;;;;;132779:71;;;;-1:-1:-1;;;132779:71:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;130738:26:0;;132863:21;130738:26;;;:19;:26;;;;;;132887:30;;-1:-1:-1;;;132887:30:0;;132911:4;132887:30;;;10314:51:1;-1:-1:-1;;;;;132887:15:0;;;;;10287:18:1;;132887:30:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;:53;;;;:::i;:::-;132863:77;;132951:15;132969:65;132985:7;132994:13;133009:24;133018:5;133025:7;-1:-1:-1;;;;;131442:21:0;;;131415:7;131442:21;;;:14;:21;;;;;;;;:30;;;;;;;;;;;;;131345:135;132969:65;132951:83;-1:-1:-1;133055:12:0;133047:68;;;;-1:-1:-1;;;133047:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;133128:21:0;;;;;;;:14;:21;;;;;;;;:30;;;;;;;;;;;:41;;133162:7;;133128:21;:41;;133162:7;;133128:41;:::i;:::-;;;;-1:-1:-1;;;;;;;133180:26:0;;;;;;:19;:26;;;;;:37;;133210:7;;133180:26;:37;;133210:7;;133180:37;:::i;:::-;;;;-1:-1:-1;133230:47:0;;-1:-1:-1;133253:5:0;133260:7;133269;133230:22;:47::i;:::-;133293:45;;;-1:-1:-1;;;;;10576:32:1;;;10558:51;;10640:2;10625:18;;10618:34;;;133293:45:0;;;;;10531:18:1;133293:45:0;;;;;;;132768:578;;132705:641;;:::o;145104:936::-;140312:24;:22;:24::i;:::-;140290:118;;;;-1:-1:-1;;;140290:118:0;;17136:2:1;140290:118:0;;;17118:21:1;17175:2;17155:18;;;17148:30;17214:34;17194:18;;;17187:62;-1:-1:-1;;;17265:18:1;;;17258:42;17317:19;;140290:118:0;16934:408:1;140290:118:0;141215:4:::1;145310:8;145298:9;;145275:20;;145255:17;;:40;;;;:::i;:::-;:52;;;;:::i;:::-;:63;;;;:::i;:::-;:97;;145233:169;;;;-1:-1:-1::0;;;145233:169:0::1;;;;;;;:::i;:::-;141545:1;145421:8;:28;;145413:76;;;::::0;-1:-1:-1;;;145413:76:0;;22902:2:1;145413:76:0::1;::::0;::::1;22884:21:1::0;22941:2;22921:18;;;22914:30;22980:27;22960:18;;;22953:55;23025:18;;145413:76:0::1;22700:349:1::0;145413:76:0::1;145552:10;145524:39;::::0;;;:27:::1;:39;::::0;;;;;141494:1:::1;::::0;145524:50:::1;::::0;145566:8;;145524:50:::1;:::i;:::-;:89;;145502:165;;;::::0;-1:-1:-1;;;145502:165:0;;21780:2:1;145502:165:0::1;::::0;::::1;21762:21:1::0;21819:2;21799:18;;;21792:30;21858:28;21838:18;;;21831:56;21904:18;;145502:165:0::1;21578:350:1::0;145502:165:0::1;145688:9;145701:10;145688:23;145680:64;;;;-1:-1:-1::0;;;145680:64:0::1;;;;;;;:::i;:::-;145766:6;::::0;::::1;::::0;::::1;;;145765:7;145757:43;;;;-1:-1:-1::0;;;145757:43:0::1;;;;;;;:::i;:::-;145853:10;:8;:10::i;:::-;145842:21;::::0;:8;:21:::1;:::i;:::-;145829:9;:34;;145821:60;;;::::0;-1:-1:-1;;;145821:60:0;;16441:2:1;145821:60:0::1;::::0;::::1;16423:21:1::0;16480:2;16460:18;;;16453:30;-1:-1:-1;;;16499:18:1;;;16492:43;16552:18;;145821:60:0::1;16239:337:1::0;145821:60:0::1;145922:10;145894:39;::::0;;;:27:::1;:39;::::0;;;;:51;;145937:8;;145894:39;:51:::1;::::0;145937:8;;145894:51:::1;:::i;:::-;;;;;;;;145980:8;145956:20;;:32;;;;;;;:::i;:::-;::::0;;;-1:-1:-1;146001:31:0::1;::::0;-1:-1:-1;146011:10:0::1;146023:8:::0;146001:9:::1;:31::i;147146:114::-:0;135552:7;135579:6;-1:-1:-1;;;;;135579:6:0;104692:10;135726:23;135718:68;;;;-1:-1:-1;;;135718:68:0;;;;;;;:::i;:::-;147223:20:::1;:29:::0;;-1:-1:-1;;147223:29:0::1;::::0;::::1;;::::0;;;::::1;::::0;;147146:114::o;140860:119::-;135552:7;135579:6;-1:-1:-1;;;;;135579:6:0;104692:10;135726:23;135718:68;;;;-1:-1:-1;;;135718:68:0;;;;;;;:::i;:::-;140938:20:::1;:33:::0;140860:119::o;112017:125::-;112081:7;112108:21;112121:7;112108:12;:21::i;:::-;:26;;112017:125;-1:-1:-1;;112017:125:0:o;109465:206::-;109529:7;-1:-1:-1;;;;;109553:19:0;;109549:60;;109581:28;;-1:-1:-1;;;109581:28:0;;;;;;;;;;;109549:60;-1:-1:-1;;;;;;109635:19:0;;;;;:12;:19;;;;;:27;-1:-1:-1;;;;;109635:27:0;;109465:206::o;147831:180::-;135552:7;135579:6;-1:-1:-1;;;;;135579:6:0;104692:10;135726:23;135718:68;;;;-1:-1:-1;;;135718:68:0;;;;;;;:::i;:::-;147904:20:::1;::::0;::::1;;147896:66;;;::::0;-1:-1:-1;;;147896:66:0;;23256:2:1;147896:66:0::1;::::0;::::1;23238:21:1::0;23295:2;23275:18;;;23268:30;23334:34;23314:18;;;23307:62;-1:-1:-1;;;23385:18:1;;;23378:32;23427:19;;147896:66:0::1;23054:398:1::0;147896:66:0::1;147973:30;148000:1;147973:18;:30::i;:::-;147831:180::o:0;131571:100::-;131622:7;131649;131657:5;131649:14;;;;;;;;:::i;:::-;;;;;;;;;;;-1:-1:-1;;;;;131649:14:0;;131571:100;-1:-1:-1;;131571:100:0:o;112378:104::-;112434:13;112467:7;112460:14;;;;;:::i;142598:290::-;142639:7;142663:24;:22;:24::i;:::-;142659:189;;;142707:11;;;;;;;142704:133;;;-1:-1:-1;142745:12:0;;;142598:290::o;142704:133::-;-1:-1:-1;141432:10:0;;142598:290::o;142704:133::-;-1:-1:-1;141370:10:0;;142598:290::o;142896:1064::-;138915:21;:19;:21::i;:::-;138893:112;;;;-1:-1:-1;;;138893:112:0;;;;;;;:::i;:::-;138197:15:::1;::::0;143071:10:::1;::::0;143083:9;;-1:-1:-1;;;;;138197:15:0::1;138161:32;143071:10:::0;143083:9;138161:13:::1;:32::i;:::-;-1:-1:-1::0;;;;;138161:51:0::1;;138153:125;;;::::0;-1:-1:-1;;;138153:125:0;;16783:2:1;138153:125:0::1;::::0;::::1;16765:21:1::0;16822:2;16802:18;;;16795:30;16861:26;16841:18;;;16834:54;16905:18;;138153:125:0::1;16581:348:1::0;138153:125:0::1;141215:4:::2;143188:8;143176:9;;143153:20;;143133:17;;:40;;;;:::i;:::-;:52;;;;:::i;:::-;:63;;;;:::i;:::-;:97;;143111:169;;;;-1:-1:-1::0;;;143111:169:0::2;;;;;;;:::i;:::-;141317:4;143347:8;143335:9;;143315:17;;:29;;;;:::i;:::-;:40;;;;:::i;:::-;:60;;143293:136;;;::::0;-1:-1:-1;;;143293:136:0;;15321:2:1;143293:136:0::2;::::0;::::2;15303:21:1::0;15360:2;15340:18;;;15333:30;15399:28;15379:18;;;15372:56;15445:18;;143293:136:0::2;15119:350:1::0;143293:136:0::2;143489:10;143464:36;::::0;;;:24:::2;:36;::::0;;;;;141608:1:::2;::::0;143464:47:::2;::::0;143503:8;;143464:47:::2;:::i;:::-;:79;;143442:151;;;::::0;-1:-1:-1;;;143442:151:0;;22135:2:1;143442:151:0::2;::::0;::::2;22117:21:1::0;22174:2;22154:18;;;22147:30;-1:-1:-1;;;22193:18:1;;;22186:52;22255:18;;143442:151:0::2;21933:346:1::0;143442:151:0::2;143614:9;143627:10;143614:23;143606:64;;;;-1:-1:-1::0;;;143606:64:0::2;;;;;;;:::i;:::-;143692:6;::::0;::::2;::::0;::::2;;;143691:7;143683:43;;;;-1:-1:-1::0;;;143683:43:0::2;;;;;;;:::i;:::-;143779:10;:8;:10::i;:::-;143768:21;::::0;:8;:21:::2;:::i;:::-;143755:9;:34;;143747:60;;;::::0;-1:-1:-1;;;143747:60:0;;16441:2:1;143747:60:0::2;::::0;::::2;16423:21:1::0;16480:2;16460:18;;;16453:30;-1:-1:-1;;;16499:18:1;;;16492:43;16552:18;;143747:60:0::2;16239:337:1::0;143747:60:0::2;143845:10;143820:36;::::0;;;:24:::2;:36;::::0;;;;:48;;143860:8;;143820:36;:48:::2;::::0;143860:8;;143820:48:::2;:::i;:::-;;;;;;;;143900:8;143879:17;;:29;;;;;;;:::i;:::-;::::0;;;-1:-1:-1;143921:31:0::2;::::0;-1:-1:-1;143931:10:0::2;143943:8:::0;143921:9:::2;:31::i;:::-;139016:1:::1;;142896:1064:::0;;:::o;113988:287::-;-1:-1:-1;;;;;114087:24:0;;104692:10;114087:24;114083:54;;;114120:17;;-1:-1:-1;;;114120:17:0;;;;;;;;;;;114083:54;104692:10;114150:32;;;;:18;:32;;;;;;;;-1:-1:-1;;;;;114150:42:0;;;;;;;;;;;;:53;;-1:-1:-1;;114150:53:0;;;;;;;;;;114219:48;;11575:41:1;;;114150:42:0;;104692:10;114219:48;;11548:18:1;114219:48:0;;;;;;;113988:287;;:::o;148189:214::-;135552:7;135579:6;-1:-1:-1;;;;;135579:6:0;104692:10;135726:23;135718:68;;;;-1:-1:-1;;;135718:68:0;;;;;;;:::i;:::-;148247:9:::1;148242:154;148266:11;:18:::0;148262:22;::::1;148242:154;;;148306:22;148339:11;148351:1;148339:14;;;;;;;;:::i;:::-;;::::0;;;::::1;::::0;;;::::1;::::0;-1:-1:-1;;;;;148339:14:0::1;::::0;-1:-1:-1;148369:15:0::1;148339:14:::0;148369:7:::1;:15::i;:::-;-1:-1:-1::0;148286:3:0;::::1;::::0;::::1;:::i;:::-;;;;148242:154;;140615:167:::0;140670:4;140730:1;140707:20;;:24;:67;;;;-1:-1:-1;;140754:20:0;;140735:15;:39;;;140615:167::o;139353:258::-;139405:4;139462:1;139442:17;;:21;:57;;;;;139498:1;139480:15;;:19;139442:57;:110;;;;;139535:17;;139516:15;:36;;139442:110;:161;;;;-1:-1:-1;;139588:15:0;;139569;:34;;;139353:258::o;115074:369::-;115241:28;115251:4;115257:2;115261:7;115241:9;:28::i;:::-;-1:-1:-1;;;;;115284:13:0;;10214:19;:23;;115284:76;;;;;115304:56;115335:4;115341:2;115345:7;115354:5;115304:30;:56::i;:::-;115303:57;115284:76;115280:156;;;115384:40;;-1:-1:-1;;;115384:40:0;;;;;;;;;;;147272:551;147390:13;147439:16;147447:7;147439;:16::i;:::-;147421:105;;;;-1:-1:-1;;;147421:105:0;;22486:2:1;147421:105:0;;;22468:21:1;22525:2;22505:18;;;22498:30;22564:34;22544:18;;;22537:62;-1:-1:-1;;;22615:18:1;;;22608:45;22670:19;;147421:105:0;22284:411:1;147421:105:0;147551:8;;;;;;;147547:62;;147583:14;147576:21;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;147272:551;;;:::o;147547:62::-;147621:28;147652:10;:8;:10::i;:::-;147621:41;;147713:1;147688:14;147682:28;:32;:133;;;;;;;;;;;;;;;;;147754:14;147770:25;147787:7;147770:16;:25::i;:::-;147737:59;;;;;;;;;:::i;:::-;;;;;;;;;;;;;147682:133;147675:140;147272:551;-1:-1:-1;;;147272:551:0:o;137736:333::-;137792:7;137811:21;137910:120;137932:20;:18;:20::i;:::-;137980:39;;;137140:35;137980:39;;;;11983:25:1;;;;-1:-1:-1;;;;;12044:32:1;;12024:18;;;12017:60;137980:39:0;;;;;;;;;11956:18:1;;;137980:39:0;;137970:50;;;;;;-1:-1:-1;;;35646:57:0;;;9819:27:1;9862:11;;;9855:27;;;;9898:12;;;;9891:28;;;;35646:57:0;;;;;;;;;;9935:12:1;;;;35646:57:0;;;35636:68;;;;;;35516:196;137910:120;137845:186;;9418:66:1;137845:186:0;;;9406:79:1;9501:12;;;9494:28;;;;9538:12;;137845:186:0;;;-1:-1:-1;;137845:186:0;;;;;;;;;137835:197;;137845:186;137835:197;;;;;137736:333;-1:-1:-1;;;137736:333:0:o;137322:110::-;135552:7;135579:6;-1:-1:-1;;;;;135579:6:0;104692:10;135726:23;135718:68;;;;-1:-1:-1;;;135718:68:0;;;;;;;:::i;:::-;137398:15:::1;:26:::0;;-1:-1:-1;;;;;;137398:26:0::1;-1:-1:-1::0;;;;;137398:26:0;;;::::1;::::0;;;::::1;::::0;;137322:110::o;146407:155::-;135552:7;135579:6;-1:-1:-1;;;;;135579:6:0;104692:10;135726:23;135718:68;;;;-1:-1:-1;;;135718:68:0;;;;;;;:::i;:::-;146496:11:::1;:27:::0;;;::::1;;::::0;::::1;-1:-1:-1::0;;146496:27:0;;::::1;::::0;;;::::1;::::0;;;146534:12:::1;:20:::0;146407:155::o;146953:90::-;135552:7;135579:6;-1:-1:-1;;;;;135579:6:0;104692:10;135726:23;135718:68;;;;-1:-1:-1;;;135718:68:0;;;;;;;:::i;:::-;147018:8:::1;:17:::0;;;::::1;;::::0;::::1;-1:-1:-1::0;;147018:17:0;;::::1;::::0;;;::::1;::::0;;146953:90::o;137566:162::-;137650:7;137677:43;137691:17;137701:6;137691:9;:17::i;:::-;137710:9;137677:13;:43::i;139757:334::-;135552:7;135579:6;-1:-1:-1;;;;;135579:6:0;104692:10;135726:23;135718:68;;;;-1:-1:-1;;;135718:68:0;;;;;;;:::i;:::-;139907:10:::1;139895:8;:22;;139873:132;;;::::0;-1:-1:-1;;;139873:132:0;;14174:2:1;139873:132:0::1;::::0;::::1;14156:21:1::0;14213:2;14193:18;;;14186:30;14252:34;14232:18;;;14225:62;14323:30;14303:18;;;14296:58;14371:19;;139873:132:0::1;13972:424:1::0;139873:132:0::1;140016:17;:30:::0;;;;140057:15:::1;:26:::0;139757:334::o;146570:128::-;135552:7;135579:6;-1:-1:-1;;;;;135579:6:0;104692:10;135726:23;135718:68;;;;-1:-1:-1;;;135718:68:0;;;;;;;:::i;:::-;146658:32;;::::1;::::0;:14:::1;::::0;:32;;::::1;::::0;::::1;:::i;136415:201::-:0;135552:7;135579:6;-1:-1:-1;;;;;135579:6:0;104692:10;135726:23;135718:68;;;;-1:-1:-1;;;135718:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;136504:22:0;::::1;136496:73;;;::::0;-1:-1:-1;;;136496:73:0;;16034:2:1;136496:73:0::1;::::0;::::1;16016:21:1::0;16073:2;16053:18;;;16046:30;16112:34;16092:18;;;16085:62;-1:-1:-1;;;16163:18:1;;;16156:36;16209:19;;136496:73:0::1;15832:402:1::0;136496:73:0::1;136580:28;136599:8;136580:18;:28::i;137440:118::-:0;135552:7;135579:6;-1:-1:-1;;;;;135579:6:0;104692:10;135726:23;135718:68;;;;-1:-1:-1;;;135718:68:0;;;;;;;:::i;:::-;137520:19:::1;:30:::0;;-1:-1:-1;;;;;;137520:30:0::1;-1:-1:-1::0;;;;;137520:30:0;;;::::1;::::0;;;::::1;::::0;;137440:118::o;143968:1128::-;138915:21;:19;:21::i;:::-;138893:112;;;;-1:-1:-1;;;138893:112:0;;;;;;;:::i;:::-;138430:19:::1;::::0;144151:10:::1;::::0;144163:9;;-1:-1:-1;;;;;138430:19:0::1;138394:32;144151:10:::0;144163:9;138394:13:::1;:32::i;:::-;-1:-1:-1::0;;;;;138394:55:0::1;;138386:134;;;::::0;-1:-1:-1;;;138386:134:0;;15676:2:1;138386:134:0::1;::::0;::::1;15658:21:1::0;15715:2;15695:18;;;15688:30;15754:31;15734:18;;;15727:59;15803:18;;138386:134:0::1;15474:353:1::0;138386:134:0::1;141215:4:::2;144268:8;144256:9;;144233:20;;144213:17;;:40;;;;:::i;:::-;:52;;;;:::i;:::-;:63;;;;:::i;:::-;:97;;144191:169;;;;-1:-1:-1::0;;;144191:169:0::2;;;;;;;:::i;:::-;141317:4;144427:8;144415:9;;144395:17;;:29;;;;:::i;:::-;:40;;;;:::i;:::-;:60;;144373:136;;;::::0;-1:-1:-1;;;144373:136:0;;15321:2:1;144373:136:0::2;::::0;::::2;15303:21:1::0;15360:2;15340:18;;;15333:30;15399:28;15379:18;;;15372:56;15445:18;;144373:136:0::2;15119:350:1::0;144373:136:0::2;144573:10;144544:40;::::0;;;:28:::2;:40;::::0;;;;;141676:1:::2;::::0;144544:51:::2;::::0;144587:8;;144544:51:::2;:::i;:::-;:88;;144522:165;;;::::0;-1:-1:-1;;;144522:165:0;;24785:2:1;144522:165:0::2;::::0;::::2;24767:21:1::0;24824:2;24804:18;;;24797:30;24863:29;24843:18;;;24836:57;24910:18;;144522:165:0::2;24583:351:1::0;144522:165:0::2;141265:2;144734:8;144722:9;;:20;;;;:::i;:::-;:36;;144700:114;;;::::0;-1:-1:-1;;;144700:114:0;;24017:2:1;144700:114:0::2;::::0;::::2;23999:21:1::0;24056:2;24036:18;;;24029:30;24095;24075:18;;;24068:58;24143:18;;144700:114:0::2;23815:352:1::0;144700:114:0::2;144835:9;144848:10;144835:23;144827:64;;;;-1:-1:-1::0;;;144827:64:0::2;;;;;;;:::i;:::-;144913:6;::::0;::::2;::::0;::::2;;;144912:7;144904:43;;;;-1:-1:-1::0;;;144904:43:0::2;;;;;;;:::i;:::-;144973:8;144960:9;;:21;;;;;;;:::i;:::-;::::0;;;-1:-1:-1;;145021:10:0::2;144992:40;::::0;;;:28:::2;:40;::::0;;;;:52;;145036:8;;144992:40;:52:::2;::::0;145036:8;;144992:52:::2;:::i;115698:174::-:0;115755:4;115819:13;;115809:7;:23;115779:85;;;;-1:-1:-1;;115837:20:0;;;;:11;:20;;;;;:27;-1:-1:-1;;;115837:27:0;;;;115836:28;;115698:174::o;123855:196::-;123970:24;;;;:15;:24;;;;;;:29;;-1:-1:-1;;;;;;123970:29:0;-1:-1:-1;;;;;123970:29:0;;;;;;;;;124015:28;;123970:24;;124015:28;;;;;;;123855:196;;;:::o;38949:314::-;39002:7;39034:4;-1:-1:-1;;;;;39043:12:0;39026:29;;:66;;;;;39076:16;39059:13;:33;39026:66;39022:234;;;-1:-1:-1;39116:24:0;;38949:314::o;39022:234::-;-1:-1:-1;39452:73:0;;;39202:10;39452:73;;;;12347:25:1;;;;39214:12:0;12388:18:1;;;12381:34;39228:15:0;12431:18:1;;;12424:34;39496:13:0;12474:18:1;;;12467:34;39519:4:0;12517:19:1;;;;12510:61;;;;39452:73:0;;;;;;;;;;12319:19:1;;;;39452:73:0;;;39442:84;;;;;;138548:121::o;115880:104::-;115949:27;115959:2;115963:8;115949:27;;;;;;;;;;;;:9;:27::i;133524:248::-;133734:12;;-1:-1:-1;;;;;133714:16:0;;133670:7;133714:16;;;:7;:16;;;;;;133670:7;;133749:15;;133698:32;;:13;:32;:::i;:::-;133697:49;;;;:::i;:::-;:67;;;;:::i;:::-;133690:74;133524:248;-1:-1:-1;;;;133524:248:0:o;11180:317::-;11295:6;11270:21;:31;;11262:73;;;;-1:-1:-1;;;11262:73:0;;18786:2:1;11262:73:0;;;18768:21:1;18825:2;18805:18;;;18798:30;18864:31;18844:18;;;18837:59;18913:18;;11262:73:0;18584:353:1;11262:73:0;11349:12;11367:9;-1:-1:-1;;;;;11367:14:0;11389:6;11367:33;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;11348:52;;;11419:7;11411:78;;;;-1:-1:-1;;;11411:78:0;;17956:2:1;11411:78:0;;;17938:21:1;17995:2;17975:18;;;17968:30;18034:34;18014:18;;;18007:62;18105:28;18085:18;;;18078:56;18151:19;;11411:78:0;17754:422:1;118798:2130:0;118913:35;118951:21;118964:7;118951:12;:21::i;:::-;118913:59;;119011:4;-1:-1:-1;;;;;118989:26:0;:13;:18;;;-1:-1:-1;;;;;118989:26:0;;118985:67;;119024:28;;-1:-1:-1;;;119024:28:0;;;;;;;;;;;118985:67;119065:22;104692:10;-1:-1:-1;;;;;119091:20:0;;;;:73;;-1:-1:-1;119128:36:0;119145:4;104692:10;114346:164;:::i;119128:36::-;119091:126;;;-1:-1:-1;104692:10:0;119181:20;119193:7;119181:11;:20::i;:::-;-1:-1:-1;;;;;119181:36:0;;119091:126;119065:153;;119236:17;119231:66;;119262:35;;-1:-1:-1;;;119262:35:0;;;;;;;;;;;119231:66;-1:-1:-1;;;;;119312:16:0;;119308:52;;119337:23;;-1:-1:-1;;;119337:23:0;;;;;;;;;;;119308:52;119481:35;119498:1;119502:7;119511:4;119481:8;:35::i;:::-;-1:-1:-1;;;;;119812:18:0;;;;;;;:12;:18;;;;;;;;:31;;-1:-1:-1;;119812:31:0;;;-1:-1:-1;;;;;119812:31:0;;;-1:-1:-1;;119812:31:0;;;;;;;119858:16;;;;;;;;;:29;;;;;;;;-1:-1:-1;119858:29:0;;;;;;;;;;;119938:20;;;:11;:20;;;;;;119973:18;;-1:-1:-1;;;;;;120006:49:0;;;;-1:-1:-1;;;120039:15:0;120006:49;;;;;;;;;;120329:11;;120389:24;;;;;120432:13;;119938:20;;120389:24;;120432:13;120428:384;;120642:13;;120627:11;:28;120623:174;;120680:20;;120749:28;;;;-1:-1:-1;;;;;120723:54:0;-1:-1:-1;;;120723:54:0;-1:-1:-1;;;;;;120723:54:0;;;-1:-1:-1;;;;;120680:20:0;;120723:54;;;;120623:174;119787:1036;;;120859:7;120855:2;-1:-1:-1;;;;;120840:27:0;120849:4;-1:-1:-1;;;;;120840:27:0;;;;;;;;;;;120878:42;118902:2026;;118798:2130;;;:::o;20765:211::-;20909:58;;;-1:-1:-1;;;;;10576:32:1;;20909:58:0;;;10558:51:1;10625:18;;;;10618:34;;;20909:58:0;;;;;;;;;;10531:18:1;;;;20909:58:0;;;;;;;;-1:-1:-1;;;;;20909:58:0;-1:-1:-1;;;20909:58:0;;;20882:86;;20902:5;;20882:19;:86::i;110846:1109::-;-1:-1:-1;;;;;;;;;;;;;;;;;;;;;;;;;110957:7:0;111040:13;;111033:4;:20;111002:886;;;111074:31;111108:17;;;:11;:17;;;;;;;;;111074:51;;;;;;;;;-1:-1:-1;;;;;111074:51:0;;;;-1:-1:-1;;;111074:51:0;;-1:-1:-1;;;;;111074:51:0;;;;;;;;-1:-1:-1;;;111074:51:0;;;;;;;;;;;;;;111144:729;;111194:14;;-1:-1:-1;;;;;111194:28:0;;111190:101;;111258:9;110846:1109;-1:-1:-1;;;110846:1109:0:o;111190:101::-;-1:-1:-1;;;111633:6:0;111678:17;;;;:11;:17;;;;;;;;;111666:29;;;;;;;;;-1:-1:-1;;;;;111666:29:0;;;;;-1:-1:-1;;;111666:29:0;;-1:-1:-1;;;;;111666:29:0;;;;;;;;-1:-1:-1;;;111666:29:0;;;;;;;;;;;;;111726:28;111722:109;;111794:9;110846:1109;-1:-1:-1;;;110846:1109:0:o;111722:109::-;111593:261;;;111055:833;111002:886;111916:31;;-1:-1:-1;;;111916:31:0;;;;;;;;;;;136776:191;136850:16;136869:6;;-1:-1:-1;;;;;136886:17:0;;;-1:-1:-1;;;;;;136886:17:0;;;;;;136919:40;;136869:6;;;;;;;136919:40;;136850:16;136919:40;136839:128;136776:191;:::o;124543:667::-;124727:72;;-1:-1:-1;;;124727:72:0;;124706:4;;-1:-1:-1;;;;;124727:36:0;;;;;:72;;104692:10;;124778:4;;124784:7;;124793:5;;124727:72;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;124727:72:0;;;;;;;;-1:-1:-1;;124727:72:0;;;;;;;;;;;;:::i;:::-;;;124723:480;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;124961:13:0;;124957:235;;125007:40;;-1:-1:-1;;;125007:40:0;;;;;;;;;;;124957:235;125150:6;125144:13;125135:6;125131:2;125127:15;125120:38;124723:480;-1:-1:-1;;;;;;124846:55:0;-1:-1:-1;;;124846:55:0;;-1:-1:-1;124543:667:0;;;;;;:::o;146835:107::-;146895:13;146925:12;146918:19;;;;;:::i;24426:723::-;24482:13;24703:10;24699:53;;-1:-1:-1;;24730:10:0;;;;;;;;;;;;-1:-1:-1;;;24730:10:0;;;;;24426:723::o;24699:53::-;24777:5;24762:12;24818:78;24825:9;;24818:78;;24851:8;;;;:::i;:::-;;-1:-1:-1;24874:10:0;;-1:-1:-1;24882:2:0;24874:10;;:::i;:::-;;;24818:78;;;24906:19;24938:6;-1:-1:-1;;;;;24928:17:0;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;24928:17:0;;24906:39;;24956:154;24963:10;;24956:154;;24990:11;25000:1;24990:11;;:::i;:::-;;-1:-1:-1;25059:10:0;25067:2;25059:5;:10;:::i;:::-;25046:24;;:2;:24;:::i;:::-;25033:39;;25016:6;25023;25016:14;;;;;;;;:::i;:::-;;;;:56;-1:-1:-1;;;;;25016:56:0;;;;;;;;-1:-1:-1;25087:11:0;25096:2;25087:11;;:::i;:::-;;;24956:154;;30602:231;30680:7;30701:17;30720:18;30742:27;30753:4;30759:9;30742:10;:27::i;:::-;30700:69;;;;30780:18;30792:5;30780:11;:18::i;:::-;-1:-1:-1;30816:9:0;30602:231;-1:-1:-1;;;30602:231:0:o;116347:163::-;116470:32;116476:2;116480:8;116490:5;116497:4;116470:5;:32::i;23338:716::-;23762:23;23788:69;23816:4;23788:69;;;;;;;;;;;;;;;;;23796:5;-1:-1:-1;;;;;23788:27:0;;;:69;;;;;:::i;:::-;23872:17;;23762:95;;-1:-1:-1;23872:21:0;23868:179;;23969:10;23958:30;;;;;;;;;;;;:::i;:::-;23950:85;;;;-1:-1:-1;;;23950:85:0;;24374:2:1;23950:85:0;;;24356:21:1;24413:2;24393:18;;;24386:30;24452:34;24432:18;;;24425:62;-1:-1:-1;;;24503:18:1;;;24496:40;24553:19;;23950:85:0;24172:406:1;28492:1308:0;28573:7;28582:12;28807:9;:16;28827:2;28807:22;28803:990;;;29103:4;29088:20;;29082:27;29153:4;29138:20;;29132:27;29211:4;29196:20;;29190:27;28846:9;29182:36;29254:25;29265:4;29182:36;29082:27;29132;29254:10;:25::i;:::-;29247:32;;;;;;;;;28803:990;29301:9;:16;29321:2;29301:22;29297:496;;;29576:4;29561:20;;29555:27;29627:4;29612:20;;29606:27;29669:23;29680:4;29555:27;29606;29669:10;:23::i;:::-;29662:30;;;;;;;;29297:496;-1:-1:-1;29741:1:0;;-1:-1:-1;29745:35:0;29297:496;28492:1308;;;;;:::o;26763:643::-;26841:20;26832:5;:29;;;;;;;;:::i;:::-;;26828:571;;;26763:643;:::o;26828:571::-;26939:29;26930:5;:38;;;;;;;;:::i;:::-;;26926:473;;;26985:34;;-1:-1:-1;;;26985:34:0;;13411:2:1;26985:34:0;;;13393:21:1;13450:2;13430:18;;;13423:30;13489:26;13469:18;;;13462:54;13533:18;;26985:34:0;13209:348:1;26926:473:0;27050:35;27041:5;:44;;;;;;;;:::i;:::-;;27037:362;;;27102:41;;-1:-1:-1;;;27102:41:0;;14961:2:1;27102:41:0;;;14943:21:1;15000:2;14980:18;;;14973:30;15039:33;15019:18;;;15012:61;15090:18;;27102:41:0;14759:355:1;27037:362:0;27174:30;27165:5;:39;;;;;;;;:::i;:::-;;27161:238;;;27221:44;;-1:-1:-1;;;27221:44:0;;18383:2:1;27221:44:0;;;18365:21:1;18422:2;18402:18;;;18395:30;18461:34;18441:18;;;18434:62;-1:-1:-1;;;18512:18:1;;;18505:32;18554:19;;27221:44:0;18181:398:1;27161:238:0;27296:30;27287:5;:39;;;;;;;;:::i;:::-;;27283:116;;;27343:44;;-1:-1:-1;;;27343:44:0;;20313:2:1;27343:44:0;;;20295:21:1;20352:2;20332:18;;;20325:30;20391:34;20371:18;;;20364:62;-1:-1:-1;;;20442:18:1;;;20435:32;20484:19;;27343:44:0;20111:398:1;116769:1775:0;116931:13;;-1:-1:-1;;;;;116959:16:0;;116955:48;;116984:19;;-1:-1:-1;;;116984:19:0;;;;;;;;;;;116955:48;117018:13;117014:44;;117040:18;;-1:-1:-1;;;117040:18:0;;;;;;;;;;;117014:44;-1:-1:-1;;;;;117409:16:0;;;;;;:12;:16;;;;;;;;:44;;-1:-1:-1;;117468:49:0;;-1:-1:-1;;;;;117409:44:0;;;;;;;117468:49;;;;-1:-1:-1;;117409:44:0;;;;;;117468:49;;;;;;;;;;;;;;;;117534:25;;;:11;:25;;;;;;:35;;-1:-1:-1;;;;;;117584:66:0;;;;-1:-1:-1;;;117634:15:0;117584:66;;;;;;;;;;117534:25;117731:23;;;117775:4;:23;;;;-1:-1:-1;;;;;;117783:13:0;;10214:19;:23;;117783:15;117771:641;;;117819:314;117850:38;;117875:12;;-1:-1:-1;;;;;117850:38:0;;;117867:1;;117850:38;;117867:1;;117850:38;117916:69;117955:1;117959:2;117963:14;;;;;;117979:5;117916:30;:69::i;:::-;117911:174;;118021:40;;-1:-1:-1;;;118021:40:0;;;;;;;;;;;117911:174;118128:3;118112:12;:19;;117819:314;;118214:12;118197:13;;:29;118193:43;;118228:8;;;118193:43;117771:641;;;118277:120;118308:40;;118333:14;;;;;-1:-1:-1;;;;;118308:40:0;;;118325:1;;118308:40;;118325:1;;118308:40;118392:3;118376:12;:19;;118277:120;;117771:641;-1:-1:-1;118426:13:0;:28;118476:60;142896:1064;12664:229;12801:12;12833:52;12855:6;12863:4;12869:1;12872:12;12833:21;:52::i;32054:1632::-;32185:7;;33119:66;33106:79;;33102:163;;;-1:-1:-1;33218:1:0;;-1:-1:-1;33222:30:0;33202:51;;33102:163;33279:1;:7;;33284:2;33279:7;;:18;;;;;33290:1;:7;;33295:2;33290:7;;33279:18;33275:102;;;-1:-1:-1;33330:1:0;;-1:-1:-1;33334:30:0;33314:51;;33275:102;33491:24;;;33474:14;33491:24;;;;;;;;;12809:25:1;;;12882:4;12870:17;;12850:18;;;12843:45;;;;12904:18;;;12897:34;;;12947:18;;;12940:34;;;33491:24:0;;12781:19:1;;33491:24:0;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;33491:24:0;;-1:-1:-1;;33491:24:0;;;-1:-1:-1;;;;;;;33530:20:0;;33526:103;;33583:1;33587:29;33567:50;;;;;;;33526:103;33649:6;-1:-1:-1;33657:20:0;;-1:-1:-1;32054:1632:0;;;;;;;;:::o;31096:344::-;31210:7;;-1:-1:-1;;;;;31256:80:0;;31210:7;31363:25;31379:3;31364:18;;;31386:2;31363:25;:::i;:::-;31347:42;;31407:25;31418:4;31424:1;31427;31430;31407:10;:25::i;:::-;31400:32;;;;;;31096:344;;;;;;:::o;13784:510::-;13954:12;14012:5;13987:21;:30;;13979:81;;;;-1:-1:-1;;;13979:81:0;;19144:2:1;13979:81:0;;;19126:21:1;19183:2;19163:18;;;19156:30;19222:34;19202:18;;;19195:62;-1:-1:-1;;;19273:18:1;;;19266:36;19319:19;;13979:81:0;18942:402:1;13979:81:0;-1:-1:-1;;;;;10214:19:0;;;14071:60;;;;-1:-1:-1;;;14071:60:0;;23659:2:1;14071:60:0;;;23641:21:1;23698:2;23678:18;;;23671:30;23737:31;23717:18;;;23710:59;23786:18;;14071:60:0;23457:353:1;14071:60:0;14145:12;14159:23;14186:6;-1:-1:-1;;;;;14186:11:0;14205:5;14212:4;14186:31;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14144:73;;;;14235:51;14252:7;14261:10;14273:12;14235:16;:51::i;:::-;14228:58;13784:510;-1:-1:-1;;;;;;;13784:510:0:o;16470:712::-;16620:12;16649:7;16645:530;;;-1:-1:-1;16680:10:0;16673:17;;16645:530;16794:17;;:21;16790:374;;16992:10;16986:17;17053:15;17040:10;17036:2;17032:19;17025:44;16790:374;17135:12;17128:20;;-1:-1:-1;;;17128: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:309::-;5259:6;5267;5320:2;5308:9;5299:7;5295:23;5291:32;5288:52;;;5336:1;5333;5326:12;5288:52;5375:9;5362:23;5394:28;5416:5;5394:28;:::i;5508:245::-;5566:6;5619:2;5607:9;5598:7;5594:23;5590:32;5587:52;;;5635:1;5632;5625:12;5587:52;5674:9;5661:23;5693:30;5717:5;5693:30;:::i;5758:249::-;5827:6;5880:2;5868:9;5859:7;5855:23;5851:32;5848:52;;;5896:1;5893;5886:12;5848:52;5928:9;5922:16;5947:30;5971:5;5947:30;:::i;6685:450::-;6754:6;6807:2;6795:9;6786:7;6782:23;6778:32;6775:52;;;6823:1;6820;6813:12;6775:52;6863:9;6850:23;-1:-1:-1;;;;;6888:6:1;6885:30;6882:50;;;6928:1;6925;6918:12;6882:50;6951:22;;7004:4;6996:13;;6992:27;-1:-1:-1;6982:55:1;;7033:1;7030;7023:12;6982:55;7056:73;7121:7;7116:2;7103:16;7098:2;7094;7090:11;7056:73;:::i;7140:180::-;7199:6;7252:2;7240:9;7231:7;7227:23;7223:32;7220:52;;;7268:1;7265;7258:12;7220:52;-1:-1:-1;7291:23:1;;7140:180;-1:-1:-1;7140:180:1:o;7325:184::-;7395:6;7448:2;7436:9;7427:7;7423:23;7419:32;7416:52;;;7464:1;7461;7454:12;7416:52;-1:-1:-1;7487:16:1;;7325:184;-1:-1:-1;7325:184:1:o;7514:388::-;7591:6;7599;7652:2;7640:9;7631:7;7627:23;7623:32;7620:52;;;7668:1;7665;7658:12;7620:52;7704:9;7691:23;7681:33;;7765:2;7754:9;7750:18;7737:32;-1:-1:-1;;;;;7784:6:1;7781:30;7778:50;;;7824:1;7821;7814:12;7907:248;7975:6;7983;8036:2;8024:9;8015:7;8011:23;8007:32;8004:52;;;8052:1;8049;8042:12;8004:52;-1:-1:-1;;8075:23:1;;;8145:2;8130:18;;;8117:32;;-1:-1:-1;7907:248:1:o;8160:257::-;8201:3;8239:5;8233:12;8266:6;8261:3;8254:19;8282:63;8338:6;8331:4;8326:3;8322:14;8315:4;8308:5;8304:16;8282:63;:::i;:::-;8399:2;8378:15;-1:-1:-1;;8374:29:1;8365:39;;;;8406:4;8361:50;;8160:257;-1:-1:-1;;8160:257:1:o;8422:274::-;8551:3;8589:6;8583:13;8605:53;8651:6;8646:3;8639:4;8631:6;8627:17;8605:53;:::i;:::-;8674:16;;;;;8422:274;-1:-1:-1;;8422:274:1:o;8701:470::-;8880:3;8918:6;8912:13;8934:53;8980:6;8975:3;8968:4;8960:6;8956:17;8934:53;:::i;:::-;9050:13;;9009:16;;;;9072:57;9050:13;9009:16;9106:4;9094:17;;9072:57;:::i;:::-;9145:20;;8701:470;-1:-1:-1;;;;8701:470:1:o;10663:488::-;-1:-1:-1;;;;;10932:15:1;;;10914:34;;10984:15;;10979:2;10964:18;;10957:43;11031:2;11016:18;;11009:34;;;11079:3;11074:2;11059:18;;11052:31;;;10857:4;;11100:45;;11125:19;;11117:6;11100:45;:::i;:::-;11092:53;10663:488;-1:-1:-1;;;;;;10663:488:1:o;12985:219::-;13134:2;13123:9;13116:21;13097:4;13154:44;13194:2;13183:9;13179:18;13171:6;13154:44;:::i;13562:405::-;13764:2;13746:21;;;13803:2;13783:18;;;13776:30;13842:34;13837:2;13822:18;;13815:62;-1:-1:-1;;;13908:2:1;13893:18;;13886:39;13957:3;13942:19;;13562:405::o;14401:353::-;14603:2;14585:21;;;14642:2;14622:18;;;14615:30;14681:31;14676:2;14661:18;;14654:59;14745:2;14730:18;;14401:353::o;17347:402::-;17549:2;17531:21;;;17588:2;17568:18;;;17561:30;17627:34;17622:2;17607:18;;17600:62;-1:-1:-1;;;17693:2:1;17678:18;;17671:36;17739:3;17724:19;;17347:402::o;19349:407::-;19551:2;19533:21;;;19590:2;19570:18;;;19563:30;19629:34;19624:2;19609:18;;19602:62;-1:-1:-1;;;19695:2:1;19680:18;;19673:41;19746:3;19731:19;;19349:407::o;20514:346::-;20716:2;20698:21;;;20755:2;20735:18;;;20728:30;-1:-1:-1;;;20789:2:1;20774:18;;20767:52;20851:2;20836:18;;20514:346::o;20865:356::-;21067:2;21049:21;;;21086:18;;;21079:30;21145:34;21140:2;21125:18;;21118:62;21212:2;21197:18;;20865:356::o;21226:347::-;21428:2;21410:21;;;21467:2;21447:18;;;21440:30;21506:25;21501:2;21486:18;;21479:53;21564:2;21549:18;;21226:347::o;25121:128::-;25161:3;25192:1;25188:6;25185:1;25182:13;25179:39;;;25198:18;;:::i;:::-;-1:-1:-1;25234:9:1;;25121:128::o;25254:120::-;25294:1;25320;25310:35;;25325:18;;:::i;:::-;-1:-1:-1;25359:9:1;;25254:120::o;25379:168::-;25419:7;25485:1;25481;25477:6;25473:14;25470:1;25467:21;25462:1;25455:9;25448:17;25444:45;25441:71;;;25492:18;;:::i;:::-;-1:-1:-1;25532:9:1;;25379:168::o;25552:125::-;25592:4;25620:1;25617;25614:8;25611:34;;;25625:18;;:::i;:::-;-1:-1:-1;25662:9:1;;25552:125::o;25682:258::-;25754:1;25764:113;25778:6;25775:1;25772:13;25764:113;;;25854:11;;;25848:18;25835:11;;;25828:39;25800:2;25793:10;25764:113;;;25895:6;25892:1;25889:13;25886:48;;;-1:-1:-1;;25930:1:1;25912:16;;25905:27;25682:258::o;25945:380::-;26024:1;26020:12;;;;26067;;;26088:61;;26142:4;26134:6;26130:17;26120:27;;26088:61;26195:2;26187:6;26184:14;26164:18;26161:38;26158:161;;;26241:10;26236:3;26232:20;26229:1;26222:31;26276:4;26273:1;26266:15;26304:4;26301:1;26294:15;26158:161;;25945:380;;;:::o;26330:135::-;26369:3;-1:-1:-1;;26390:17:1;;26387:43;;;26410:18;;:::i;:::-;-1:-1:-1;26457:1:1;26446:13;;26330:135::o;26470:112::-;26502:1;26528;26518:35;;26533:18;;:::i;:::-;-1:-1:-1;26567:9:1;;26470:112::o;26587:127::-;26648:10;26643:3;26639:20;26636:1;26629:31;26679:4;26676:1;26669:15;26703:4;26700:1;26693:15;26719:127;26780:10;26775:3;26771:20;26768:1;26761:31;26811:4;26808:1;26801:15;26835:4;26832:1;26825:15;26851:127;26912:10;26907:3;26903:20;26900:1;26893:31;26943:4;26940:1;26933:15;26967:4;26964:1;26957:15;26983:127;27044:10;27039:3;27035:20;27032:1;27025:31;27075:4;27072:1;27065:15;27099:4;27096:1;27089:15;27115:127;27176:10;27171:3;27167:20;27164:1;27157:31;27207:4;27204:1;27197:15;27231:4;27228:1;27221:15;27247:131;-1:-1:-1;;;;;27322:31:1;;27312:42;;27302:70;;27368:1;27365;27358:12;27383:118;27469:5;27462:13;27455:21;27448:5;27445:32;27435:60;;27491:1;27488;27481:12;27506:131;-1:-1:-1;;;;;;27580:32:1;;27570:43;;27560:71;;27627:1;27624;27617:12

Swarm Source

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