ETH Price: $2,873.29 (-10.82%)
Gas: 20 Gwei

Token

Women Warriors Club (WWC)
 

Overview

Max Total Supply

51 WWC

Holders

31

Market

Volume (24H)

N/A

Min Price (24H)

N/A

Max Price (24H)

N/A

Other Info

Balance
2 WWC
0x3c6a2eca6ff647d4cc9b5b4ebc6ccd1229019370
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:
WomenWarriorsClub

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-05-02
*/

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

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


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

pragma solidity ^0.8.0;

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

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


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

pragma solidity ^0.8.0;

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

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


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

pragma solidity ^0.8.0;


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

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


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

pragma solidity ^0.8.0;


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

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

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

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

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

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

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

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

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

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

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

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

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


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

pragma solidity ^0.8.0;


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

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

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

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


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

pragma solidity ^0.8.0;


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

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

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

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


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

pragma solidity ^0.8.0;

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

        uint256 size;
        assembly {
            size := extcodesize(account)
        }
        return size > 0;
    }

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

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

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

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

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

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

        (bool success, bytes memory returndata) = target.call{value : value}(data);
        return verifyCallResult(success, returndata, errorMessage);
    }

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

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

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

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

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

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

    /**
     * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the
     * revert reason using the provided one.
     *
     * _Available since v4.3._
     */
    function verifyCallResult(
        bool success,
        bytes memory returndata,
        string memory errorMessage
    ) internal pure returns (bytes memory) {
        if (success) {
            return returndata;
        } else {
            // Look for revert reason and bubble it up if present
            if (returndata.length > 0) {
                // The easiest way to bubble the revert reason is using memory via assembly

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

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


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

pragma solidity ^0.8.0;

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

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

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

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

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

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

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

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

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


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

pragma solidity ^0.8.0;



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

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

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

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

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

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

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

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

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


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

pragma solidity ^0.8.0;

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

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

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

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

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

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


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

pragma solidity ^0.8.0;


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

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

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

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

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

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

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

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

        return (signer, RecoverError.NoError);
    }

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

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

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

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

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


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

pragma solidity ^0.8.0;


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

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

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

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

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

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

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

// File: hardhat/console.sol


pragma solidity >= 0.4.22 <0.9.0;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

}

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


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

pragma solidity ^0.8.0;

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

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

// File: erc721a/contracts/ERC721A.sol


// Creator: Chiru Labs

pragma solidity ^0.8.4;









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

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

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

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

    // Compiler will pack the following
    // _currentIndex and _burnCounter into a single 256bit word.

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

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

    // Token name
    string private _name;

    // Token symbol
    string private _symbol;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

        _approve(to, tokenId, owner);
    }

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

        return _tokenApprovals[tokenId];
    }

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

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

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

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

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

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

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

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

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

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

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

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

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

        uint256 updatedIndex = startTokenId;

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

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

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

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

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

        _beforeTokenTransfers(from, to, tokenId, 1);

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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


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

pragma solidity ^0.8.0;




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

    uint256 private _totalShares;
    uint256 private _totalReleased;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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


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

pragma solidity ^0.8.0;


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

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

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

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

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

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

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

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

// File: contracts/WhiteList.sol

pragma solidity ^0.8.0;


contract WhiteList is Ownable, EIP712 {

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

    address public whitelistSigner;

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

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

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

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

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

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

pragma solidity ^0.8.0;


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

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

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

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

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

pragma solidity ^0.8.0;


contract PublicSales is Ownable {
    uint256 public publicSalesStartTime;

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

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

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

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

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


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

    //FOR PRODUCTION
    uint256 public constant TOTAL_MAX_QTY = 2222;
    uint256 public constant GIFT_MAX_QTY = 122;
    uint256 public constant SALES_MAX_QTY = TOTAL_MAX_QTY - GIFT_MAX_QTY;
    uint256 public constant PRESALES_MAX_QTY = 2100;
    uint256 public constant PRE_SALES_PRICE = 0.06 ether;
    uint256 public constant PUBLIC_SALES_PRICE = 0.065 ether;
    uint256 public constant MAX_QTY_PER_MINTER = 4;
    uint256 public constant MAX_QTY_PER_MINT = 4;
    uint256 public constant MAX_QTY_PER_MINTER_PRE_SALES = 4;

    address[] private addressList = [0xb862E637a679AbF63aB82729486BD6a1E4A98e46];

    uint256[] private shareList = [100];

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

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

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

    string private baseTokenURI;
    string private notRevealedUri;

    constructor(string memory _notRevealedUri) ERC721A("Women Warriors Club", "WWC") PaymentSplitter(addressList, shareList) {
        notRevealedUri = _notRevealedUri;
    }

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

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

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

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

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

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

        require(msg.value >= _mintQty * getPrice(), "Incorrect ETH");

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

        _safeMint(msg.sender, _mintQty);
    }

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

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

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

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

        require(msg.value >= _mintQty * getPrice(), "Incorrect ETH");

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

        _safeMint(msg.sender, _mintQty);
    }

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

        giftedQty += receivers.length;

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

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

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

    function _baseURI() internal view override virtual returns (string memory) {
        return baseTokenURI;
    }

    function setRevealed(bool _state) external onlyOwner {
        revealed = _state;
    }

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

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

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

        if (!revealed) {
            return notRevealedUri;
        }

        string memory currentBaseURI = _baseURI();

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

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

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

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

}

Contract Security Audit

Contract ABI

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

61016060405273b862e637a679abf63ab82729486bd6a1e4a98e466101409081526200003090601390600162000668565b5060408051602081019091526064815262000050906014906001620006d2565b50600060158190556016819055601755601a805462ffffff19166101001790553480156200007d57600080fd5b506040516200456938038062004569833981016040819052620000a091620007a9565b6013805480602002602001604051908101604052809291908181526020018280548015620000f857602002820191906000526020600020905b81546001600160a01b03168152600190910190602001808311620000d9575b505050505060148054806020026020016040519081016040528092919081815260200182805480156200014b57602002820191906000526020600020905b81548152602001906001019080831162000136575b50505050506040518060400160405280601381526020017f576f6d656e2057617272696f727320436c7562000000000000000000000000008152506040518060400160405280600381526020016257574360e81b8152506040518060400160405280600c81526020016b15d5d0d5da1a5d19531a5cdd60a21b815250604051806040016040528060018152602001603160f81b815250620001fb620001f56200042660201b60201c565b6200042a565b636212f2206001556362124960600255636212f21f600355815160208084019190912082518383012060e08290526101008190524660a0818152604080517f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f81880181905281830187905260608201869052608082019490945230818401528151808203909301835260c00190528051940193909320919290916080523060601b60c0526101205250508351620002bc925060069150602085019062000715565b508051620002d290600790602084019062000715565b5050508051825114620003475760405162461bcd60e51b815260206004820152603260248201527f5061796d656e7453706c69747465723a2070617965657320616e6420736861726044820152710cae640d8cadccee8d040dad2e6dac2e8c6d60731b60648201526084015b60405180910390fd5b60008251116200039a5760405162461bcd60e51b815260206004820152601a60248201527f5061796d656e7453706c69747465723a206e6f2070617965657300000000000060448201526064016200033e565b60005b82518110156200040657620003f1838281518110620003c057620003c062000911565b6020026020010151838381518110620003dd57620003dd62000911565b60200260200101516200047a60201b60201c565b80620003fd81620008dd565b9150506200039d565b505081516200041e9150601c90602084019062000715565b50506200093d565b3390565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6001600160a01b038216620004e75760405162461bcd60e51b815260206004820152602c60248201527f5061796d656e7453706c69747465723a206163636f756e74206973207468652060448201526b7a65726f206164647265737360a01b60648201526084016200033e565b60008111620005395760405162461bcd60e51b815260206004820152601d60248201527f5061796d656e7453706c69747465723a2073686172657320617265203000000060448201526064016200033e565b6001600160a01b0382166000908152600e602052604090205415620005b55760405162461bcd60e51b815260206004820152602b60248201527f5061796d656e7453706c69747465723a206163636f756e7420616c726561647960448201526a206861732073686172657360a81b60648201526084016200033e565b60108054600181019091557f1b6847dc741a1b0cd08d278845f9d819d87b734759afb55fe2de5cb82a9ae6720180546001600160a01b0319166001600160a01b0384169081179091556000908152600e60205260409020819055600c546200061f90829062000885565b600c55604080516001600160a01b0384168152602081018390527f40c340f65e17194d14ddddb073d3c9f888e3cb52b5aae0c6c7706b4fbc905fac910160405180910390a15050565b828054828255906000526020600020908101928215620006c0579160200282015b82811115620006c057825182546001600160a01b0319166001600160a01b0390911617825560209092019160019091019062000689565b50620006ce92915062000792565b5090565b828054828255906000526020600020908101928215620006c0579160200282015b82811115620006c0578251829060ff16905591602001919060010190620006f3565b8280546200072390620008a0565b90600052602060002090601f016020900481019282620007475760008555620006c0565b82601f106200076257805160ff1916838001178555620006c0565b82800160010185558215620006c0579182015b82811115620006c057825182559160200191906001019062000775565b5b80821115620006ce576000815560010162000793565b60006020808385031215620007bd57600080fd5b82516001600160401b0380821115620007d557600080fd5b818501915085601f830112620007ea57600080fd5b815181811115620007ff57620007ff62000927565b604051601f8201601f19908116603f011681019083821181831017156200082a576200082a62000927565b8160405282815288868487010111156200084357600080fd5b600093505b8284101562000867578484018601518185018701529285019262000848565b82841115620008795760008684830101525b98975050505050505050565b600082198211156200089b576200089b620008fb565b500190565b600181811c90821680620008b557607f821691505b60208210811415620008d757634e487b7160e01b600052602260045260246000fd5b50919050565b6000600019821415620008f457620008f4620008fb565b5060010190565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b60805160a05160c05160601c60e0516101005161012051613bd9620009906000396000612495015260006124e4015260006124bf01526000612418015260006124420152600061246c0152613bd96000f3fe6080604052600436106103fd5760003560e01c80637b2ca38611610213578063bd34fc5711610123578063e0a80853116100ab578063e985e9c51161007a578063e985e9c514610bd6578063ed39039b14610c1f578063ef81b4d414610c3f578063f2c4ce1e14610c5f578063f2fde38b14610c7f57600080fd5b8063e0a8085314610b6b578063e33b7de314610b8b578063e53e3a0414610ba0578063e6c3819c14610bc057600080fd5b8063d1ca131f116100f2578063d1ca131f14610ac4578063d338143814610ae4578063d6eec46a14610b04578063d79779b214610b1f578063dee816e614610b5557600080fd5b8063bd34fc5714610a24578063c688387f14610a3a578063c87b56dd14610a6e578063ce7c2ac214610a8e57600080fd5b80639c123661116101a6578063a78a673f11610175578063a78a673f146109c4578063ac501c4114610535578063ae4384f1146109da578063b7329d2b146109ef578063b88d4fde14610a0457600080fd5b80639c123661146109665780639e47efb81461097c578063a22cb4651461098f578063a50e89ff146109af57600080fd5b80638f7be8f2116101e25780638f7be8f2146108d957806395d89b41146109065780639852595c1461091b57806398d5fdca1461095157600080fd5b80637b2ca3861461086657806382afe550146108805780638b83209b1461089b5780638da5cb5b146108bb57600080fd5b8063397d0c0c1161030e5780634def4d1a116102a157806360869d9b1161027057806360869d9b146107c45780636352211e146107e457806370a0823114610804578063715018a614610824578063791eef071461083957600080fd5b80634def4d1a146107455780634f6ccce71461076557806351830227146107855780635c975abb146107a557600080fd5b806342842e0e116102dd57806342842e0e146106dc57806347fc6e76146106fc57806348b75044146107125780634d192b831461073257600080fd5b8063397d0c0c146106635780633a98ef39146106795780633ccfd60b1461068e578063406072a91461069657600080fd5b8063163e1e6111610391578063191655871161036057806319165587146105ce57806323b872dd146105ee5780632f745c591461060e57806330176e131461062e5780633354fe341461064e57600080fd5b8063163e1e611461055f578063167877581461053557806316c38b3c1461057f57806318160ddd1461059f57600080fd5b8063081812fc116103cd578063081812fc146104db578063095ea7b314610513578063122be4a31461053557806313c65a6e1461054a57600080fd5b806226275e1461044b57806301e3b4361461047357806301ffc9a71461048957806306fdde03146104b957600080fd5b36610446577f6ef95f06320e7a25a04a175ca677b7052bdd97131872c2192525a629f51be77033604080516001600160a01b0390921682523460208301520160405180910390a1005b600080fd5b34801561045757600080fd5b50610460610c9f565b6040519081526020015b60405180910390f35b34801561047f57600080fd5b5061046060155481565b34801561049557600080fd5b506104a96104a4366004613771565b610caf565b604051901515815260200161046a565b3480156104c557600080fd5b506104ce610d1c565b60405161046a919061392b565b3480156104e757600080fd5b506104fb6104f63660046137f3565b610dae565b6040516001600160a01b03909116815260200161046a565b34801561051f57600080fd5b5061053361052e366004613697565b610df2565b005b34801561054157600080fd5b50610460600481565b34801561055657600080fd5b50610460610e80565b34801561056b57600080fd5b5061053361057a3660046136c3565b610ec1565b34801561058b57600080fd5b5061053361059a366004613737565b610fab565b3480156105ab57600080fd5b506104606005546001600160801b03600160801b82048116918116919091031690565b3480156105da57600080fd5b506105336105e9366004613518565b610fef565b3480156105fa57600080fd5b5061053361060936600461356e565b61111d565b34801561061a57600080fd5b50610460610629366004613697565b611128565b34801561063a57600080fd5b506105336106493660046137ab565b611224565b34801561065a57600080fd5b50610460607a81565b34801561066f57600080fd5b5061046060025481565b34801561068557600080fd5b50600c54610460565b610533611265565b3480156106a257600080fd5b506104606106b1366004613535565b6001600160a01b03918216600090815260126020908152604080832093909416825291909152205490565b3480156106e857600080fd5b506105336106f736600461356e565b6112e7565b34801561070857600080fd5b5061046061083481565b34801561071e57600080fd5b5061053361072d366004613535565b611302565b6105336107403660046137f3565b6114ea565b34801561075157600080fd5b50610533610760366004613737565b6117b9565b34801561077157600080fd5b506104606107803660046137f3565b6117f6565b34801561079157600080fd5b50601a546104a99062010000900460ff1681565b3480156107b157600080fd5b50601a546104a990610100900460ff1681565b3480156107d057600080fd5b506105336107df3660046137f3565b6118a2565b3480156107f057600080fd5b506104fb6107ff3660046137f3565b6118d1565b34801561081057600080fd5b5061046061081f366004613518565b6118e3565b34801561083057600080fd5b50610533611931565b34801561084557600080fd5b50610460610854366004613518565b60186020526000908152604090205481565b34801561087257600080fd5b50601a546104a99060ff1681565b34801561088c57600080fd5b5061046066d529ae9e86000081565b3480156108a757600080fd5b506104fb6108b63660046137f3565b6119c4565b3480156108c757600080fd5b506000546001600160a01b03166104fb565b3480156108e557600080fd5b506104606108f4366004613518565b60196020526000908152604090205481565b34801561091257600080fd5b506104ce6119f4565b34801561092757600080fd5b50610460610936366004613518565b6001600160a01b03166000908152600f602052604090205490565b34801561095d57600080fd5b50610460611a03565b34801561097257600080fd5b5061046060165481565b61053361098a366004613825565b611a2a565b34801561099b57600080fd5b506105336109aa36600461361a565b611d69565b3480156109bb57600080fd5b50610533611dff565b3480156109d057600080fd5b5061046060035481565b3480156109e657600080fd5b506104a9611e7e565b3480156109fb57600080fd5b506104a9611e96565b348015610a1057600080fd5b50610533610a1f3660046135af565b611eca565b348015610a3057600080fd5b5061046060175481565b348015610a4657600080fd5b506104607ff59780ff8f4ba89ed09d6c9fc5aec79093994c7234326cb09aafc9bf724f074181565b348015610a7a57600080fd5b506104ce610a893660046137f3565b611efe565b348015610a9a57600080fd5b50610460610aa9366004613518565b6001600160a01b03166000908152600e602052604090205490565b348015610ad057600080fd5b50610460610adf366004613518565b61206b565b348015610af057600080fd5b50610533610aff366004613518565b612153565b348015610b1057600080fd5b5061046066e6ed27d666800081565b348015610b2b57600080fd5b50610460610b3a366004613518565b6001600160a01b031660009081526011602052604090205490565b348015610b6157600080fd5b506104606108ae81565b348015610b7757600080fd5b50610533610b86366004613737565b61219f565b348015610b9757600080fd5b50600d54610460565b348015610bac57600080fd5b506104fb610bbb366004613648565b6121e5565b348015610bcc57600080fd5b5061046060015481565b348015610be257600080fd5b506104a9610bf1366004613535565b6001600160a01b039182166000908152600b6020908152604080832093909416825291909152205460ff1690565b348015610c2b57600080fd5b50610533610c3a366004613855565b6121f9565b348015610c4b57600080fd5b506004546104fb906001600160a01b031681565b348015610c6b57600080fd5b50610533610c7a3660046137ab565b6122a4565b348015610c8b57600080fd5b50610533610c9a366004613518565b6122e1565b610cac607a6108ae613a4f565b81565b60006001600160e01b031982166380ac58cd60e01b1480610ce057506001600160e01b03198216635b5e139f60e01b145b80610cfb57506001600160e01b0319821663780e9d6360e01b145b80610d1657506301ffc9a760e01b6001600160e01b03198316145b92915050565b606060068054610d2b90613a92565b80601f0160208091040260200160405190810160405280929190818152602001828054610d5790613a92565b8015610da45780601f10610d7957610100808354040283529160200191610da4565b820191906000526020600020905b815481529060010190602001808311610d8757829003601f168201915b5050505050905090565b6000610db982612379565b610dd6576040516333d1c03960e21b815260040160405180910390fd5b506000908152600a60205260409020546001600160a01b031690565b6000610dfd826118d1565b9050806001600160a01b0316836001600160a01b03161415610e325760405163250fdee360e21b815260040160405180910390fd5b336001600160a01b03821614801590610e525750610e508133610bf1565b155b15610e70576040516367d9dca160e11b815260040160405180910390fd5b610e7b8383836123af565b505050565b600080546001600160a01b03163314610eb45760405162461bcd60e51b8152600401610eab906139cf565b60405180910390fd5b610ebc61240b565b905090565b6000546001600160a01b03163314610eeb5760405162461bcd60e51b8152600401610eab906139cf565b601754607a90610efc908390613a04565b1115610f425760405162461bcd60e51b8152602060048201526015602482015274115e18d959590819da599d081b585e081b1a5b5a5d605a1b6044820152606401610eab565b8181905060176000828254610f579190613a04565b90915550600090505b81811015610e7b57610f99838383818110610f7d57610f7d613b3e565b9050602002016020810190610f929190613518565b6001612532565b80610fa381613acd565b915050610f60565b6000546001600160a01b03163314610fd55760405162461bcd60e51b8152600401610eab906139cf565b601a80549115156101000261ff0019909216919091179055565b6001600160a01b0381166000908152600e60205260409020546110245760405162461bcd60e51b8152600401610eab9061393e565b600061102f600d5490565b6110399047613a04565b905060006110668383611061866001600160a01b03166000908152600f602052604090205490565b61254c565b9050806110855760405162461bcd60e51b8152600401610eab90613984565b6001600160a01b0383166000908152600f6020526040812080548392906110ad908490613a04565b9250508190555080600d60008282546110c69190613a04565b909155506110d690508382612592565b604080516001600160a01b0385168152602081018390527fdf20fd1e76bc69d672e4814fafb2c449bba3a5369d8359adf9e05e6fde87b056910160405180910390a1505050565b610e7b8383836126ab565b6000611133836118e3565b8210611152576040516306ed618760e11b815260040160405180910390fd5b6005546001600160801b0316600080805b8381101561121e57600081815260086020908152604091829020825160608101845290546001600160a01b0381168252600160a01b81046001600160401b031692820192909252600160e01b90910460ff1615801592820192909252906111ca5750611216565b80516001600160a01b0316156111df57805192505b876001600160a01b0316836001600160a01b03161415611214578684141561120d57509350610d1692505050565b6001909301925b505b600101611163565b50600080fd5b6000546001600160a01b0316331461124e5760405162461bcd60e51b8152600401610eab906139cf565b805161126190601b9060208401906133ea565b5050565b6000546001600160a01b0316331461128f5760405162461bcd60e51b8152600401610eab906139cf565b604051600090339047908381818185875af1925050503d80600081146112d1576040519150601f19603f3d011682016040523d82523d6000602084013e6112d6565b606091505b50509050806112e457600080fd5b50565b610e7b83838360405180602001604052806000815250611eca565b6001600160a01b0381166000908152600e60205260409020546113375760405162461bcd60e51b8152600401610eab9061393e565b6001600160a01b0382166000908152601160205260408120546040516370a0823160e01b81523060048201526001600160a01b038516906370a082319060240160206040518083038186803b15801561138f57600080fd5b505afa1580156113a3573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906113c7919061380c565b6113d19190613a04565b9050600061140a838361106187876001600160a01b03918216600090815260126020908152604080832093909416825291909152205490565b9050806114295760405162461bcd60e51b8152600401610eab90613984565b6001600160a01b03808516600090815260126020908152604080832093871683529290529081208054839290611460908490613a04565b90915550506001600160a01b0384166000908152601160205260408120805483929061148d908490613a04565b9091555061149e90508484836128c8565b604080516001600160a01b038581168252602082018490528616917f3be5b7a71e84ed12875d241991c70855ac5817d847039e17a9d895c1ceb0f18a910160405180910390a250505050565b6114f2611e7e565b6115535760405162461bcd60e51b815260206004820152602c60248201527f5075626c696353616c657341637469766174696f6e3a2053616c65206973206e60448201526b1bdd081858dd1a5d985d195960a21b6064820152608401610eab565b611560607a6108ae613a4f565b816016546015546115719190613a04565b61157b9190613a04565b11156115c25760405162461bcd60e51b8152602060048201526016602482015275115e18d95959081cd85b195cc81b585e081b1a5b5a5d60521b6044820152606401610eab565b60048111156116135760405162461bcd60e51b815260206004820152601960248201527f457863656564206d6178206d696e7420706572206d696e742e000000000000006044820152606401610eab565b33600090815260196020526040902054600490611631908390613a04565b111561167f5760405162461bcd60e51b815260206004820152601a60248201527f457863656564206d6178206d696e7420706572206d696e7465720000000000006044820152606401610eab565b3233146116ce5760405162461bcd60e51b815260206004820152601d60248201527f434f4e5452414354535f4e4f545f414c4c4f5745445f544f5f4d494e540000006044820152606401610eab565b601a54610100900460ff16156117205760405162461bcd60e51b815260206004820152601760248201527654686520636f6e7472616374206973207061757365642160481b6044820152606401610eab565b611728611a03565b6117329082613a30565b3410156117715760405162461bcd60e51b815260206004820152600d60248201526c092dcc6dee4e4cac6e8408aa89609b1b6044820152606401610eab565b3360009081526019602052604081208054839290611790908490613a04565b9250508190555080601660008282546117a99190613a04565b909155506112e490503382612532565b6000546001600160a01b031633146117e35760405162461bcd60e51b8152600401610eab906139cf565b601a805460ff1916911515919091179055565b6005546000906001600160801b031681805b8281101561188857600081815260086020908152604091829020825160608101845290546001600160a01b0381168252600160a01b81046001600160401b031692820192909252600160e01b90910460ff1615159181018290529061187f57858314156118785750949350505050565b6001909201915b50600101611808565b506040516329c8c00760e21b815260040160405180910390fd5b6000546001600160a01b031633146118cc5760405162461bcd60e51b8152600401610eab906139cf565b600155565b60006118dc8261291a565b5192915050565b60006001600160a01b03821661190c576040516323d3ad8160e21b815260040160405180910390fd5b506001600160a01b03166000908152600960205260409020546001600160401b031690565b6000546001600160a01b0316331461195b5760405162461bcd60e51b8152600401610eab906139cf565b601a5460ff166119b85760405162461bcd60e51b815260206004820152602260248201527f4e6f74207468652074696d6520746f2052656e6f756e6365204f776e65727368604482015261069760f41b6064820152608401610eab565b6119c26000612a3e565b565b6000601082815481106119d9576119d9613b3e565b6000918252602090912001546001600160a01b031692915050565b606060078054610d2b90613a92565b6000611a0d611e7e565b15611a1e575066e6ed27d666800090565b5066d529ae9e86000090565b611a32611e96565b611a905760405162461bcd60e51b815260206004820152602960248201527f50726553616c657341637469766174696f6e3a2053616c65206973206e6f74206044820152681858dd1a5d985d195960ba1b6064820152608401610eab565b600454339082906001600160a01b0316611aaa83836121e5565b6001600160a01b031614611b005760405162461bcd60e51b815260206004820152601860248201527f55736572206973206e6f74206f6e2077686974656c69737400000000000000006044820152606401610eab565b6108ae84601654601554611b149190613a04565b611b1e9190613a04565b1115611b655760405162461bcd60e51b8152602060048201526016602482015275115e18d95959081cd85b195cc81b585e081b1a5b5a5d60521b6044820152606401610eab565b61083484601554611b769190613a04565b1115611bc45760405162461bcd60e51b815260206004820152601a60248201527f457863656564207072652d73616c6573206d6178206c696d69740000000000006044820152606401610eab565b33600090815260186020526040902054600490611be2908690613a04565b1115611c295760405162461bcd60e51b8152602060048201526016602482015275457863656564207369676e6564207175616e7469747960501b6044820152606401610eab565b323314611c785760405162461bcd60e51b815260206004820152601d60248201527f434f4e5452414354535f4e4f545f414c4c4f5745445f544f5f4d494e540000006044820152606401610eab565b601a54610100900460ff1615611cca5760405162461bcd60e51b815260206004820152601760248201527654686520636f6e7472616374206973207061757365642160481b6044820152606401610eab565b611cd2611a03565b611cdc9085613a30565b341015611d1b5760405162461bcd60e51b815260206004820152600d60248201526c092dcc6dee4e4cac6e8408aa89609b1b6044820152606401610eab565b3360009081526018602052604081208054869290611d3a908490613a04565b925050819055508360156000828254611d539190613a04565b90915550611d6390503385612532565b50505050565b6001600160a01b038216331415611d935760405163b06307db60e01b815260040160405180910390fd5b336000818152600b602090815260408083206001600160a01b03871680855290835292819020805460ff191686151590811790915590519081529192917f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a35050565b6000546001600160a01b03163314611e295760405162461bcd60e51b8152600401610eab906139cf565b60005b6013548110156112e457600060138281548110611e4b57611e4b613b3e565b6000918252602090912001546001600160a01b03169050611e6b81610fef565b5080611e7681613acd565b915050611e2c565b600080600154118015610ebc57505060015442101590565b600080600254118015611eab57506000600354115b8015611eb957506002544210155b8015610ebc57505060035442111590565b611ed58484846126ab565b611ee184848484612a8e565b611d63576040516368d2bf6b60e11b815260040160405180910390fd5b6060611f0982612379565b611f6d5760405162461bcd60e51b815260206004820152602f60248201527f4552433732314d657461646174613a2055524920717565727920666f72206e6f60448201526e3732bc34b9ba32b73a103a37b5b2b760891b6064820152608401610eab565b601a5462010000900460ff1661200f57601c8054611f8a90613a92565b80601f0160208091040260200160405190810160405280929190818152602001828054611fb690613a92565b80156120035780601f10611fd857610100808354040283529160200191612003565b820191906000526020600020905b815481529060010190602001808311611fe657829003601f168201915b50505050509050919050565b6000612019612b9c565b905060008151116120395760405180602001604052806000815250612064565b8061204384612bab565b6040516020016120549291906138bf565b6040516020818303038152906040525b9392505050565b60008061210061207961240b565b604080517ff59780ff8f4ba89ed09d6c9fc5aec79093994c7234326cb09aafc9bf724f07416020808301919091526001600160a01b0388168284015282518083038401815260608301845280519082012061190160f01b6080840152608283019490945260a2808301949094528251808303909401845260c2909101909152815191012090565b6040517f19457468657265756d205369676e6564204d6573736167653a0a3332000000006020820152603c810191909152605c0160408051601f1981840301815291905280516020909101209392505050565b6000546001600160a01b0316331461217d5760405162461bcd60e51b8152600401610eab906139cf565b600480546001600160a01b0319166001600160a01b0392909216919091179055565b6000546001600160a01b031633146121c95760405162461bcd60e51b8152600401610eab906139cf565b601a8054911515620100000262ff000019909216919091179055565b60006120646121f38461206b565b83612ca8565b6000546001600160a01b031633146122235760405162461bcd60e51b8152600401610eab906139cf565b818110156122995760405162461bcd60e51b815260206004820152603c60248201527f50726553616c657341637469766174696f6e3a20456e642074696d652073686f60448201527f756c64206265206c61746572207468616e2073746172742074696d65000000006064820152608401610eab565b600291909155600355565b6000546001600160a01b031633146122ce5760405162461bcd60e51b8152600401610eab906139cf565b805161126190601c9060208401906133ea565b6000546001600160a01b0316331461230b5760405162461bcd60e51b8152600401610eab906139cf565b6001600160a01b0381166123705760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610eab565b6112e481612a3e565b6005546000906001600160801b031682108015610d16575050600090815260086020526040902054600160e01b900460ff161590565b6000828152600a602052604080822080546001600160a01b0319166001600160a01b0387811691821790925591518593918516917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591a4505050565b6000306001600160a01b037f00000000000000000000000000000000000000000000000000000000000000001614801561246457507f000000000000000000000000000000000000000000000000000000000000000046145b1561248e57507f000000000000000000000000000000000000000000000000000000000000000090565b50604080517f00000000000000000000000000000000000000000000000000000000000000006020808301919091527f0000000000000000000000000000000000000000000000000000000000000000828401527f000000000000000000000000000000000000000000000000000000000000000060608301524660808301523060a0808401919091528351808403909101815260c0909201909252805191012090565b611261828260405180602001604052806000815250612ccc565b600c546001600160a01b0384166000908152600e6020526040812054909183916125769086613a30565b6125809190613a1c565b61258a9190613a4f565b949350505050565b804710156125e25760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a20696e73756666696369656e742062616c616e63650000006044820152606401610eab565b6000826001600160a01b03168260405160006040518083038185875af1925050503d806000811461262f576040519150601f19603f3d011682016040523d82523d6000602084013e612634565b606091505b5050905080610e7b5760405162461bcd60e51b815260206004820152603a60248201527f416464726573733a20756e61626c6520746f2073656e642076616c75652c207260448201527f6563697069656e74206d617920686176652072657665727465640000000000006064820152608401610eab565b60006126b68261291a565b80519091506000906001600160a01b0316336001600160a01b031614806126e4575081516126e49033610bf1565b806126ff5750336126f484610dae565b6001600160a01b0316145b90508061271f57604051632ce44b5f60e11b815260040160405180910390fd5b846001600160a01b031682600001516001600160a01b0316146127545760405162a1148160e81b815260040160405180910390fd5b6001600160a01b03841661277b57604051633a954ecd60e21b815260040160405180910390fd5b61278b60008484600001516123af565b6001600160a01b038581166000908152600960209081526040808320805467ffffffffffffffff198082166001600160401b0392831660001901831617909255898616808652838620805493841693831660019081018416949094179055898652600890945282852080546001600160e01b031916909417600160a01b42909216919091021790925590860180835291205490911661287e576005546001600160801b031681101561287e57825160008281526008602090815260409091208054918601516001600160401b0316600160a01b026001600160e01b03199092166001600160a01b03909316929092171790555b5082846001600160a01b0316866001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a45b5050505050565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b179052610e7b908490612cd9565b604080516060810182526000808252602082018190529181019190915260055482906001600160801b0316811015612a2557600081815260086020908152604091829020825160608101845290546001600160a01b0381168252600160a01b81046001600160401b031692820192909252600160e01b90910460ff16151591810182905290612a235780516001600160a01b0316156129ba579392505050565b5060001901600081815260086020908152604091829020825160608101845290546001600160a01b038116808352600160a01b82046001600160401b031693830193909352600160e01b900460ff1615159281019290925215612a1e579392505050565b6129ba565b505b604051636f96cda160e11b815260040160405180910390fd5b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b60006001600160a01b0384163b15612b9157604051630a85bd0160e11b81526001600160a01b0385169063150b7a0290612ad29033908990889088906004016138ee565b602060405180830381600087803b158015612aec57600080fd5b505af1925050508015612b1c575060408051601f3d908101601f19168201909252612b199181019061378e565b60015b612b77573d808015612b4a576040519150601f19603f3d011682016040523d82523d6000602084013e612b4f565b606091505b508051612b6f576040516368d2bf6b60e11b815260040160405180910390fd5b805181602001fd5b6001600160e01b031916630a85bd0160e11b14905061258a565b506001949350505050565b6060601b8054610d2b90613a92565b606081612bcf5750506040805180820190915260018152600360fc1b602082015290565b8160005b8115612bf95780612be381613acd565b9150612bf29050600a83613a1c565b9150612bd3565b6000816001600160401b03811115612c1357612c13613b54565b6040519080825280601f01601f191660200182016040528015612c3d576020820181803683370190505b5090505b841561258a57612c52600183613a4f565b9150612c5f600a86613ae8565b612c6a906030613a04565b60f81b818381518110612c7f57612c7f613b3e565b60200101906001600160f81b031916908160001a905350612ca1600a86613a1c565b9450612c41565b6000806000612cb78585612dab565b91509150612cc481612e1b565b509392505050565b610e7b8383836001612fd6565b6000612d2e826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b031661315e9092919063ffffffff16565b805190915015610e7b5780806020019051810190612d4c9190613754565b610e7b5760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6044820152691bdd081cdd58d8d9595960b21b6064820152608401610eab565b600080825160411415612de25760208301516040840151606085015160001a612dd68782858561316d565b94509450505050612e14565b825160401415612e0c5760208301516040840151612e0186838361325a565b935093505050612e14565b506000905060025b9250929050565b6000816004811115612e2f57612e2f613b28565b1415612e385750565b6001816004811115612e4c57612e4c613b28565b1415612e9a5760405162461bcd60e51b815260206004820152601860248201527f45434453413a20696e76616c6964207369676e617475726500000000000000006044820152606401610eab565b6002816004811115612eae57612eae613b28565b1415612efc5760405162461bcd60e51b815260206004820152601f60248201527f45434453413a20696e76616c6964207369676e6174757265206c656e677468006044820152606401610eab565b6003816004811115612f1057612f10613b28565b1415612f695760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202773272076616c604482015261756560f01b6064820152608401610eab565b6004816004811115612f7d57612f7d613b28565b14156112e45760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202776272076616c604482015261756560f01b6064820152608401610eab565b6005546001600160801b03166001600160a01b03851661300857604051622e076360e81b815260040160405180910390fd5b836130265760405163b562e8dd60e01b815260040160405180910390fd5b6001600160a01b038516600081815260096020908152604080832080546001600160801b031981166001600160401b038083168c0181169182176801000000000000000067ffffffffffffffff1990941690921783900481168c018116909202179091558584526008909252822080546001600160e01b031916909317600160a01b42909216919091021790915581905b858110156131385760405182906001600160a01b038916906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a483801561310e575061310c6000888488612a8e565b155b1561312c576040516368d2bf6b60e11b815260040160405180910390fd5b600191820191016130b7565b50600580546001600160801b0319166001600160801b03929092169190911790556128c1565b606061258a8484600085613289565b6000807f7fffffffffffffffffffffffffffffff5d576e7357a4501ddfe92f46681b20a08311156131a45750600090506003613251565b8460ff16601b141580156131bc57508460ff16601c14155b156131cd5750600090506004613251565b6040805160008082526020820180845289905260ff881692820192909252606081018690526080810185905260019060a0016020604051602081039080840390855afa158015613221573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b03811661324a57600060019250925050613251565b9150600090505b94509492505050565b6000806001600160ff1b03831660ff84901c601b0161327b8782888561316d565b935093505050935093915050565b6060824710156132ea5760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f6044820152651c8818d85b1b60d21b6064820152608401610eab565b843b6133385760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610eab565b600080866001600160a01b0316858760405161335491906138a3565b60006040518083038185875af1925050503d8060008114613391576040519150601f19603f3d011682016040523d82523d6000602084013e613396565b606091505b50915091506133a68282866133b1565b979650505050505050565b606083156133c0575081612064565b8251156133d05782518084602001fd5b8160405162461bcd60e51b8152600401610eab919061392b565b8280546133f690613a92565b90600052602060002090601f016020900481019282613418576000855561345e565b82601f1061343157805160ff191683800117855561345e565b8280016001018555821561345e579182015b8281111561345e578251825591602001919060010190613443565b5061346a92915061346e565b5090565b5b8082111561346a576000815560010161346f565b60006001600160401b038084111561349d5761349d613b54565b604051601f8501601f19908116603f011681019082821181831017156134c5576134c5613b54565b816040528093508581528686860111156134de57600080fd5b858560208301376000602087830101525050509392505050565b600082601f83011261350957600080fd5b61206483833560208501613483565b60006020828403121561352a57600080fd5b813561206481613b6a565b6000806040838503121561354857600080fd5b823561355381613b6a565b9150602083013561356381613b6a565b809150509250929050565b60008060006060848603121561358357600080fd5b833561358e81613b6a565b9250602084013561359e81613b6a565b929592945050506040919091013590565b600080600080608085870312156135c557600080fd5b84356135d081613b6a565b935060208501356135e081613b6a565b92506040850135915060608501356001600160401b0381111561360257600080fd5b61360e878288016134f8565b91505092959194509250565b6000806040838503121561362d57600080fd5b823561363881613b6a565b9150602083013561356381613b7f565b6000806040838503121561365b57600080fd5b823561366681613b6a565b915060208301356001600160401b0381111561368157600080fd5b61368d858286016134f8565b9150509250929050565b600080604083850312156136aa57600080fd5b82356136b581613b6a565b946020939093013593505050565b600080602083850312156136d657600080fd5b82356001600160401b03808211156136ed57600080fd5b818501915085601f83011261370157600080fd5b81358181111561371057600080fd5b8660208260051b850101111561372557600080fd5b60209290920196919550909350505050565b60006020828403121561374957600080fd5b813561206481613b7f565b60006020828403121561376657600080fd5b815161206481613b7f565b60006020828403121561378357600080fd5b813561206481613b8d565b6000602082840312156137a057600080fd5b815161206481613b8d565b6000602082840312156137bd57600080fd5b81356001600160401b038111156137d357600080fd5b8201601f810184136137e457600080fd5b61258a84823560208401613483565b60006020828403121561380557600080fd5b5035919050565b60006020828403121561381e57600080fd5b5051919050565b6000806040838503121561383857600080fd5b8235915060208301356001600160401b0381111561368157600080fd5b6000806040838503121561386857600080fd5b50508035926020909101359150565b6000815180845261388f816020860160208601613a66565b601f01601f19169290920160200192915050565b600082516138b5818460208701613a66565b9190910192915050565b600083516138d1818460208801613a66565b8351908301906138e5818360208801613a66565b01949350505050565b6001600160a01b038581168252841660208201526040810183905260806060820181905260009061392190830184613877565b9695505050505050565b6020815260006120646020830184613877565b60208082526026908201527f5061796d656e7453706c69747465723a206163636f756e7420686173206e6f2060408201526573686172657360d01b606082015260800190565b6020808252602b908201527f5061796d656e7453706c69747465723a206163636f756e74206973206e6f742060408201526a191d59481c185e5b595b9d60aa1b606082015260800190565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60008219821115613a1757613a17613afc565b500190565b600082613a2b57613a2b613b12565b500490565b6000816000190483118215151615613a4a57613a4a613afc565b500290565b600082821015613a6157613a61613afc565b500390565b60005b83811015613a81578181015183820152602001613a69565b83811115611d635750506000910152565b600181811c90821680613aa657607f821691505b60208210811415613ac757634e487b7160e01b600052602260045260246000fd5b50919050565b6000600019821415613ae157613ae1613afc565b5060010190565b600082613af757613af7613b12565b500690565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052601260045260246000fd5b634e487b7160e01b600052602160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b6001600160a01b03811681146112e457600080fd5b80151581146112e457600080fd5b6001600160e01b0319811681146112e457600080fdfea264697066735822122054d58b66bc356807e80f98237a943b06f85e973d3a8d27934796ae89fb623e0a64736f6c6343000807003300000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000041697066733a2f2f516d65385844503131544664375a356a547779597a767633656a4b676f6353365067614a546a6a385247537839792f68696464656e2e6a736f6e00000000000000000000000000000000000000000000000000000000000000

Deployed Bytecode

0x6080604052600436106103fd5760003560e01c80637b2ca38611610213578063bd34fc5711610123578063e0a80853116100ab578063e985e9c51161007a578063e985e9c514610bd6578063ed39039b14610c1f578063ef81b4d414610c3f578063f2c4ce1e14610c5f578063f2fde38b14610c7f57600080fd5b8063e0a8085314610b6b578063e33b7de314610b8b578063e53e3a0414610ba0578063e6c3819c14610bc057600080fd5b8063d1ca131f116100f2578063d1ca131f14610ac4578063d338143814610ae4578063d6eec46a14610b04578063d79779b214610b1f578063dee816e614610b5557600080fd5b8063bd34fc5714610a24578063c688387f14610a3a578063c87b56dd14610a6e578063ce7c2ac214610a8e57600080fd5b80639c123661116101a6578063a78a673f11610175578063a78a673f146109c4578063ac501c4114610535578063ae4384f1146109da578063b7329d2b146109ef578063b88d4fde14610a0457600080fd5b80639c123661146109665780639e47efb81461097c578063a22cb4651461098f578063a50e89ff146109af57600080fd5b80638f7be8f2116101e25780638f7be8f2146108d957806395d89b41146109065780639852595c1461091b57806398d5fdca1461095157600080fd5b80637b2ca3861461086657806382afe550146108805780638b83209b1461089b5780638da5cb5b146108bb57600080fd5b8063397d0c0c1161030e5780634def4d1a116102a157806360869d9b1161027057806360869d9b146107c45780636352211e146107e457806370a0823114610804578063715018a614610824578063791eef071461083957600080fd5b80634def4d1a146107455780634f6ccce71461076557806351830227146107855780635c975abb146107a557600080fd5b806342842e0e116102dd57806342842e0e146106dc57806347fc6e76146106fc57806348b75044146107125780634d192b831461073257600080fd5b8063397d0c0c146106635780633a98ef39146106795780633ccfd60b1461068e578063406072a91461069657600080fd5b8063163e1e6111610391578063191655871161036057806319165587146105ce57806323b872dd146105ee5780632f745c591461060e57806330176e131461062e5780633354fe341461064e57600080fd5b8063163e1e611461055f578063167877581461053557806316c38b3c1461057f57806318160ddd1461059f57600080fd5b8063081812fc116103cd578063081812fc146104db578063095ea7b314610513578063122be4a31461053557806313c65a6e1461054a57600080fd5b806226275e1461044b57806301e3b4361461047357806301ffc9a71461048957806306fdde03146104b957600080fd5b36610446577f6ef95f06320e7a25a04a175ca677b7052bdd97131872c2192525a629f51be77033604080516001600160a01b0390921682523460208301520160405180910390a1005b600080fd5b34801561045757600080fd5b50610460610c9f565b6040519081526020015b60405180910390f35b34801561047f57600080fd5b5061046060155481565b34801561049557600080fd5b506104a96104a4366004613771565b610caf565b604051901515815260200161046a565b3480156104c557600080fd5b506104ce610d1c565b60405161046a919061392b565b3480156104e757600080fd5b506104fb6104f63660046137f3565b610dae565b6040516001600160a01b03909116815260200161046a565b34801561051f57600080fd5b5061053361052e366004613697565b610df2565b005b34801561054157600080fd5b50610460600481565b34801561055657600080fd5b50610460610e80565b34801561056b57600080fd5b5061053361057a3660046136c3565b610ec1565b34801561058b57600080fd5b5061053361059a366004613737565b610fab565b3480156105ab57600080fd5b506104606005546001600160801b03600160801b82048116918116919091031690565b3480156105da57600080fd5b506105336105e9366004613518565b610fef565b3480156105fa57600080fd5b5061053361060936600461356e565b61111d565b34801561061a57600080fd5b50610460610629366004613697565b611128565b34801561063a57600080fd5b506105336106493660046137ab565b611224565b34801561065a57600080fd5b50610460607a81565b34801561066f57600080fd5b5061046060025481565b34801561068557600080fd5b50600c54610460565b610533611265565b3480156106a257600080fd5b506104606106b1366004613535565b6001600160a01b03918216600090815260126020908152604080832093909416825291909152205490565b3480156106e857600080fd5b506105336106f736600461356e565b6112e7565b34801561070857600080fd5b5061046061083481565b34801561071e57600080fd5b5061053361072d366004613535565b611302565b6105336107403660046137f3565b6114ea565b34801561075157600080fd5b50610533610760366004613737565b6117b9565b34801561077157600080fd5b506104606107803660046137f3565b6117f6565b34801561079157600080fd5b50601a546104a99062010000900460ff1681565b3480156107b157600080fd5b50601a546104a990610100900460ff1681565b3480156107d057600080fd5b506105336107df3660046137f3565b6118a2565b3480156107f057600080fd5b506104fb6107ff3660046137f3565b6118d1565b34801561081057600080fd5b5061046061081f366004613518565b6118e3565b34801561083057600080fd5b50610533611931565b34801561084557600080fd5b50610460610854366004613518565b60186020526000908152604090205481565b34801561087257600080fd5b50601a546104a99060ff1681565b34801561088c57600080fd5b5061046066d529ae9e86000081565b3480156108a757600080fd5b506104fb6108b63660046137f3565b6119c4565b3480156108c757600080fd5b506000546001600160a01b03166104fb565b3480156108e557600080fd5b506104606108f4366004613518565b60196020526000908152604090205481565b34801561091257600080fd5b506104ce6119f4565b34801561092757600080fd5b50610460610936366004613518565b6001600160a01b03166000908152600f602052604090205490565b34801561095d57600080fd5b50610460611a03565b34801561097257600080fd5b5061046060165481565b61053361098a366004613825565b611a2a565b34801561099b57600080fd5b506105336109aa36600461361a565b611d69565b3480156109bb57600080fd5b50610533611dff565b3480156109d057600080fd5b5061046060035481565b3480156109e657600080fd5b506104a9611e7e565b3480156109fb57600080fd5b506104a9611e96565b348015610a1057600080fd5b50610533610a1f3660046135af565b611eca565b348015610a3057600080fd5b5061046060175481565b348015610a4657600080fd5b506104607ff59780ff8f4ba89ed09d6c9fc5aec79093994c7234326cb09aafc9bf724f074181565b348015610a7a57600080fd5b506104ce610a893660046137f3565b611efe565b348015610a9a57600080fd5b50610460610aa9366004613518565b6001600160a01b03166000908152600e602052604090205490565b348015610ad057600080fd5b50610460610adf366004613518565b61206b565b348015610af057600080fd5b50610533610aff366004613518565b612153565b348015610b1057600080fd5b5061046066e6ed27d666800081565b348015610b2b57600080fd5b50610460610b3a366004613518565b6001600160a01b031660009081526011602052604090205490565b348015610b6157600080fd5b506104606108ae81565b348015610b7757600080fd5b50610533610b86366004613737565b61219f565b348015610b9757600080fd5b50600d54610460565b348015610bac57600080fd5b506104fb610bbb366004613648565b6121e5565b348015610bcc57600080fd5b5061046060015481565b348015610be257600080fd5b506104a9610bf1366004613535565b6001600160a01b039182166000908152600b6020908152604080832093909416825291909152205460ff1690565b348015610c2b57600080fd5b50610533610c3a366004613855565b6121f9565b348015610c4b57600080fd5b506004546104fb906001600160a01b031681565b348015610c6b57600080fd5b50610533610c7a3660046137ab565b6122a4565b348015610c8b57600080fd5b50610533610c9a366004613518565b6122e1565b610cac607a6108ae613a4f565b81565b60006001600160e01b031982166380ac58cd60e01b1480610ce057506001600160e01b03198216635b5e139f60e01b145b80610cfb57506001600160e01b0319821663780e9d6360e01b145b80610d1657506301ffc9a760e01b6001600160e01b03198316145b92915050565b606060068054610d2b90613a92565b80601f0160208091040260200160405190810160405280929190818152602001828054610d5790613a92565b8015610da45780601f10610d7957610100808354040283529160200191610da4565b820191906000526020600020905b815481529060010190602001808311610d8757829003601f168201915b5050505050905090565b6000610db982612379565b610dd6576040516333d1c03960e21b815260040160405180910390fd5b506000908152600a60205260409020546001600160a01b031690565b6000610dfd826118d1565b9050806001600160a01b0316836001600160a01b03161415610e325760405163250fdee360e21b815260040160405180910390fd5b336001600160a01b03821614801590610e525750610e508133610bf1565b155b15610e70576040516367d9dca160e11b815260040160405180910390fd5b610e7b8383836123af565b505050565b600080546001600160a01b03163314610eb45760405162461bcd60e51b8152600401610eab906139cf565b60405180910390fd5b610ebc61240b565b905090565b6000546001600160a01b03163314610eeb5760405162461bcd60e51b8152600401610eab906139cf565b601754607a90610efc908390613a04565b1115610f425760405162461bcd60e51b8152602060048201526015602482015274115e18d959590819da599d081b585e081b1a5b5a5d605a1b6044820152606401610eab565b8181905060176000828254610f579190613a04565b90915550600090505b81811015610e7b57610f99838383818110610f7d57610f7d613b3e565b9050602002016020810190610f929190613518565b6001612532565b80610fa381613acd565b915050610f60565b6000546001600160a01b03163314610fd55760405162461bcd60e51b8152600401610eab906139cf565b601a80549115156101000261ff0019909216919091179055565b6001600160a01b0381166000908152600e60205260409020546110245760405162461bcd60e51b8152600401610eab9061393e565b600061102f600d5490565b6110399047613a04565b905060006110668383611061866001600160a01b03166000908152600f602052604090205490565b61254c565b9050806110855760405162461bcd60e51b8152600401610eab90613984565b6001600160a01b0383166000908152600f6020526040812080548392906110ad908490613a04565b9250508190555080600d60008282546110c69190613a04565b909155506110d690508382612592565b604080516001600160a01b0385168152602081018390527fdf20fd1e76bc69d672e4814fafb2c449bba3a5369d8359adf9e05e6fde87b056910160405180910390a1505050565b610e7b8383836126ab565b6000611133836118e3565b8210611152576040516306ed618760e11b815260040160405180910390fd5b6005546001600160801b0316600080805b8381101561121e57600081815260086020908152604091829020825160608101845290546001600160a01b0381168252600160a01b81046001600160401b031692820192909252600160e01b90910460ff1615801592820192909252906111ca5750611216565b80516001600160a01b0316156111df57805192505b876001600160a01b0316836001600160a01b03161415611214578684141561120d57509350610d1692505050565b6001909301925b505b600101611163565b50600080fd5b6000546001600160a01b0316331461124e5760405162461bcd60e51b8152600401610eab906139cf565b805161126190601b9060208401906133ea565b5050565b6000546001600160a01b0316331461128f5760405162461bcd60e51b8152600401610eab906139cf565b604051600090339047908381818185875af1925050503d80600081146112d1576040519150601f19603f3d011682016040523d82523d6000602084013e6112d6565b606091505b50509050806112e457600080fd5b50565b610e7b83838360405180602001604052806000815250611eca565b6001600160a01b0381166000908152600e60205260409020546113375760405162461bcd60e51b8152600401610eab9061393e565b6001600160a01b0382166000908152601160205260408120546040516370a0823160e01b81523060048201526001600160a01b038516906370a082319060240160206040518083038186803b15801561138f57600080fd5b505afa1580156113a3573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906113c7919061380c565b6113d19190613a04565b9050600061140a838361106187876001600160a01b03918216600090815260126020908152604080832093909416825291909152205490565b9050806114295760405162461bcd60e51b8152600401610eab90613984565b6001600160a01b03808516600090815260126020908152604080832093871683529290529081208054839290611460908490613a04565b90915550506001600160a01b0384166000908152601160205260408120805483929061148d908490613a04565b9091555061149e90508484836128c8565b604080516001600160a01b038581168252602082018490528616917f3be5b7a71e84ed12875d241991c70855ac5817d847039e17a9d895c1ceb0f18a910160405180910390a250505050565b6114f2611e7e565b6115535760405162461bcd60e51b815260206004820152602c60248201527f5075626c696353616c657341637469766174696f6e3a2053616c65206973206e60448201526b1bdd081858dd1a5d985d195960a21b6064820152608401610eab565b611560607a6108ae613a4f565b816016546015546115719190613a04565b61157b9190613a04565b11156115c25760405162461bcd60e51b8152602060048201526016602482015275115e18d95959081cd85b195cc81b585e081b1a5b5a5d60521b6044820152606401610eab565b60048111156116135760405162461bcd60e51b815260206004820152601960248201527f457863656564206d6178206d696e7420706572206d696e742e000000000000006044820152606401610eab565b33600090815260196020526040902054600490611631908390613a04565b111561167f5760405162461bcd60e51b815260206004820152601a60248201527f457863656564206d6178206d696e7420706572206d696e7465720000000000006044820152606401610eab565b3233146116ce5760405162461bcd60e51b815260206004820152601d60248201527f434f4e5452414354535f4e4f545f414c4c4f5745445f544f5f4d494e540000006044820152606401610eab565b601a54610100900460ff16156117205760405162461bcd60e51b815260206004820152601760248201527654686520636f6e7472616374206973207061757365642160481b6044820152606401610eab565b611728611a03565b6117329082613a30565b3410156117715760405162461bcd60e51b815260206004820152600d60248201526c092dcc6dee4e4cac6e8408aa89609b1b6044820152606401610eab565b3360009081526019602052604081208054839290611790908490613a04565b9250508190555080601660008282546117a99190613a04565b909155506112e490503382612532565b6000546001600160a01b031633146117e35760405162461bcd60e51b8152600401610eab906139cf565b601a805460ff1916911515919091179055565b6005546000906001600160801b031681805b8281101561188857600081815260086020908152604091829020825160608101845290546001600160a01b0381168252600160a01b81046001600160401b031692820192909252600160e01b90910460ff1615159181018290529061187f57858314156118785750949350505050565b6001909201915b50600101611808565b506040516329c8c00760e21b815260040160405180910390fd5b6000546001600160a01b031633146118cc5760405162461bcd60e51b8152600401610eab906139cf565b600155565b60006118dc8261291a565b5192915050565b60006001600160a01b03821661190c576040516323d3ad8160e21b815260040160405180910390fd5b506001600160a01b03166000908152600960205260409020546001600160401b031690565b6000546001600160a01b0316331461195b5760405162461bcd60e51b8152600401610eab906139cf565b601a5460ff166119b85760405162461bcd60e51b815260206004820152602260248201527f4e6f74207468652074696d6520746f2052656e6f756e6365204f776e65727368604482015261069760f41b6064820152608401610eab565b6119c26000612a3e565b565b6000601082815481106119d9576119d9613b3e565b6000918252602090912001546001600160a01b031692915050565b606060078054610d2b90613a92565b6000611a0d611e7e565b15611a1e575066e6ed27d666800090565b5066d529ae9e86000090565b611a32611e96565b611a905760405162461bcd60e51b815260206004820152602960248201527f50726553616c657341637469766174696f6e3a2053616c65206973206e6f74206044820152681858dd1a5d985d195960ba1b6064820152608401610eab565b600454339082906001600160a01b0316611aaa83836121e5565b6001600160a01b031614611b005760405162461bcd60e51b815260206004820152601860248201527f55736572206973206e6f74206f6e2077686974656c69737400000000000000006044820152606401610eab565b6108ae84601654601554611b149190613a04565b611b1e9190613a04565b1115611b655760405162461bcd60e51b8152602060048201526016602482015275115e18d95959081cd85b195cc81b585e081b1a5b5a5d60521b6044820152606401610eab565b61083484601554611b769190613a04565b1115611bc45760405162461bcd60e51b815260206004820152601a60248201527f457863656564207072652d73616c6573206d6178206c696d69740000000000006044820152606401610eab565b33600090815260186020526040902054600490611be2908690613a04565b1115611c295760405162461bcd60e51b8152602060048201526016602482015275457863656564207369676e6564207175616e7469747960501b6044820152606401610eab565b323314611c785760405162461bcd60e51b815260206004820152601d60248201527f434f4e5452414354535f4e4f545f414c4c4f5745445f544f5f4d494e540000006044820152606401610eab565b601a54610100900460ff1615611cca5760405162461bcd60e51b815260206004820152601760248201527654686520636f6e7472616374206973207061757365642160481b6044820152606401610eab565b611cd2611a03565b611cdc9085613a30565b341015611d1b5760405162461bcd60e51b815260206004820152600d60248201526c092dcc6dee4e4cac6e8408aa89609b1b6044820152606401610eab565b3360009081526018602052604081208054869290611d3a908490613a04565b925050819055508360156000828254611d539190613a04565b90915550611d6390503385612532565b50505050565b6001600160a01b038216331415611d935760405163b06307db60e01b815260040160405180910390fd5b336000818152600b602090815260408083206001600160a01b03871680855290835292819020805460ff191686151590811790915590519081529192917f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a35050565b6000546001600160a01b03163314611e295760405162461bcd60e51b8152600401610eab906139cf565b60005b6013548110156112e457600060138281548110611e4b57611e4b613b3e565b6000918252602090912001546001600160a01b03169050611e6b81610fef565b5080611e7681613acd565b915050611e2c565b600080600154118015610ebc57505060015442101590565b600080600254118015611eab57506000600354115b8015611eb957506002544210155b8015610ebc57505060035442111590565b611ed58484846126ab565b611ee184848484612a8e565b611d63576040516368d2bf6b60e11b815260040160405180910390fd5b6060611f0982612379565b611f6d5760405162461bcd60e51b815260206004820152602f60248201527f4552433732314d657461646174613a2055524920717565727920666f72206e6f60448201526e3732bc34b9ba32b73a103a37b5b2b760891b6064820152608401610eab565b601a5462010000900460ff1661200f57601c8054611f8a90613a92565b80601f0160208091040260200160405190810160405280929190818152602001828054611fb690613a92565b80156120035780601f10611fd857610100808354040283529160200191612003565b820191906000526020600020905b815481529060010190602001808311611fe657829003601f168201915b50505050509050919050565b6000612019612b9c565b905060008151116120395760405180602001604052806000815250612064565b8061204384612bab565b6040516020016120549291906138bf565b6040516020818303038152906040525b9392505050565b60008061210061207961240b565b604080517ff59780ff8f4ba89ed09d6c9fc5aec79093994c7234326cb09aafc9bf724f07416020808301919091526001600160a01b0388168284015282518083038401815260608301845280519082012061190160f01b6080840152608283019490945260a2808301949094528251808303909401845260c2909101909152815191012090565b6040517f19457468657265756d205369676e6564204d6573736167653a0a3332000000006020820152603c810191909152605c0160408051601f1981840301815291905280516020909101209392505050565b6000546001600160a01b0316331461217d5760405162461bcd60e51b8152600401610eab906139cf565b600480546001600160a01b0319166001600160a01b0392909216919091179055565b6000546001600160a01b031633146121c95760405162461bcd60e51b8152600401610eab906139cf565b601a8054911515620100000262ff000019909216919091179055565b60006120646121f38461206b565b83612ca8565b6000546001600160a01b031633146122235760405162461bcd60e51b8152600401610eab906139cf565b818110156122995760405162461bcd60e51b815260206004820152603c60248201527f50726553616c657341637469766174696f6e3a20456e642074696d652073686f60448201527f756c64206265206c61746572207468616e2073746172742074696d65000000006064820152608401610eab565b600291909155600355565b6000546001600160a01b031633146122ce5760405162461bcd60e51b8152600401610eab906139cf565b805161126190601c9060208401906133ea565b6000546001600160a01b0316331461230b5760405162461bcd60e51b8152600401610eab906139cf565b6001600160a01b0381166123705760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610eab565b6112e481612a3e565b6005546000906001600160801b031682108015610d16575050600090815260086020526040902054600160e01b900460ff161590565b6000828152600a602052604080822080546001600160a01b0319166001600160a01b0387811691821790925591518593918516917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591a4505050565b6000306001600160a01b037f00000000000000000000000084813607763fe3e0b06b5218d91c9c909ded9f681614801561246457507f000000000000000000000000000000000000000000000000000000000000000146145b1561248e57507fed83aeb1dd842ff62cfc5239b7894e52281546bf08f65dd4d0c58735cb0ecac090565b50604080517f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f6020808301919091527fd70a5e61c3f9ce3bafeb8e235f6f8edd3bada9790dac2715eebc3dd1040aa74c828401527fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc660608301524660808301523060a0808401919091528351808403909101815260c0909201909252805191012090565b611261828260405180602001604052806000815250612ccc565b600c546001600160a01b0384166000908152600e6020526040812054909183916125769086613a30565b6125809190613a1c565b61258a9190613a4f565b949350505050565b804710156125e25760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a20696e73756666696369656e742062616c616e63650000006044820152606401610eab565b6000826001600160a01b03168260405160006040518083038185875af1925050503d806000811461262f576040519150601f19603f3d011682016040523d82523d6000602084013e612634565b606091505b5050905080610e7b5760405162461bcd60e51b815260206004820152603a60248201527f416464726573733a20756e61626c6520746f2073656e642076616c75652c207260448201527f6563697069656e74206d617920686176652072657665727465640000000000006064820152608401610eab565b60006126b68261291a565b80519091506000906001600160a01b0316336001600160a01b031614806126e4575081516126e49033610bf1565b806126ff5750336126f484610dae565b6001600160a01b0316145b90508061271f57604051632ce44b5f60e11b815260040160405180910390fd5b846001600160a01b031682600001516001600160a01b0316146127545760405162a1148160e81b815260040160405180910390fd5b6001600160a01b03841661277b57604051633a954ecd60e21b815260040160405180910390fd5b61278b60008484600001516123af565b6001600160a01b038581166000908152600960209081526040808320805467ffffffffffffffff198082166001600160401b0392831660001901831617909255898616808652838620805493841693831660019081018416949094179055898652600890945282852080546001600160e01b031916909417600160a01b42909216919091021790925590860180835291205490911661287e576005546001600160801b031681101561287e57825160008281526008602090815260409091208054918601516001600160401b0316600160a01b026001600160e01b03199092166001600160a01b03909316929092171790555b5082846001600160a01b0316866001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a45b5050505050565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b179052610e7b908490612cd9565b604080516060810182526000808252602082018190529181019190915260055482906001600160801b0316811015612a2557600081815260086020908152604091829020825160608101845290546001600160a01b0381168252600160a01b81046001600160401b031692820192909252600160e01b90910460ff16151591810182905290612a235780516001600160a01b0316156129ba579392505050565b5060001901600081815260086020908152604091829020825160608101845290546001600160a01b038116808352600160a01b82046001600160401b031693830193909352600160e01b900460ff1615159281019290925215612a1e579392505050565b6129ba565b505b604051636f96cda160e11b815260040160405180910390fd5b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b60006001600160a01b0384163b15612b9157604051630a85bd0160e11b81526001600160a01b0385169063150b7a0290612ad29033908990889088906004016138ee565b602060405180830381600087803b158015612aec57600080fd5b505af1925050508015612b1c575060408051601f3d908101601f19168201909252612b199181019061378e565b60015b612b77573d808015612b4a576040519150601f19603f3d011682016040523d82523d6000602084013e612b4f565b606091505b508051612b6f576040516368d2bf6b60e11b815260040160405180910390fd5b805181602001fd5b6001600160e01b031916630a85bd0160e11b14905061258a565b506001949350505050565b6060601b8054610d2b90613a92565b606081612bcf5750506040805180820190915260018152600360fc1b602082015290565b8160005b8115612bf95780612be381613acd565b9150612bf29050600a83613a1c565b9150612bd3565b6000816001600160401b03811115612c1357612c13613b54565b6040519080825280601f01601f191660200182016040528015612c3d576020820181803683370190505b5090505b841561258a57612c52600183613a4f565b9150612c5f600a86613ae8565b612c6a906030613a04565b60f81b818381518110612c7f57612c7f613b3e565b60200101906001600160f81b031916908160001a905350612ca1600a86613a1c565b9450612c41565b6000806000612cb78585612dab565b91509150612cc481612e1b565b509392505050565b610e7b8383836001612fd6565b6000612d2e826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b031661315e9092919063ffffffff16565b805190915015610e7b5780806020019051810190612d4c9190613754565b610e7b5760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6044820152691bdd081cdd58d8d9595960b21b6064820152608401610eab565b600080825160411415612de25760208301516040840151606085015160001a612dd68782858561316d565b94509450505050612e14565b825160401415612e0c5760208301516040840151612e0186838361325a565b935093505050612e14565b506000905060025b9250929050565b6000816004811115612e2f57612e2f613b28565b1415612e385750565b6001816004811115612e4c57612e4c613b28565b1415612e9a5760405162461bcd60e51b815260206004820152601860248201527f45434453413a20696e76616c6964207369676e617475726500000000000000006044820152606401610eab565b6002816004811115612eae57612eae613b28565b1415612efc5760405162461bcd60e51b815260206004820152601f60248201527f45434453413a20696e76616c6964207369676e6174757265206c656e677468006044820152606401610eab565b6003816004811115612f1057612f10613b28565b1415612f695760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202773272076616c604482015261756560f01b6064820152608401610eab565b6004816004811115612f7d57612f7d613b28565b14156112e45760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202776272076616c604482015261756560f01b6064820152608401610eab565b6005546001600160801b03166001600160a01b03851661300857604051622e076360e81b815260040160405180910390fd5b836130265760405163b562e8dd60e01b815260040160405180910390fd5b6001600160a01b038516600081815260096020908152604080832080546001600160801b031981166001600160401b038083168c0181169182176801000000000000000067ffffffffffffffff1990941690921783900481168c018116909202179091558584526008909252822080546001600160e01b031916909317600160a01b42909216919091021790915581905b858110156131385760405182906001600160a01b038916906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a483801561310e575061310c6000888488612a8e565b155b1561312c576040516368d2bf6b60e11b815260040160405180910390fd5b600191820191016130b7565b50600580546001600160801b0319166001600160801b03929092169190911790556128c1565b606061258a8484600085613289565b6000807f7fffffffffffffffffffffffffffffff5d576e7357a4501ddfe92f46681b20a08311156131a45750600090506003613251565b8460ff16601b141580156131bc57508460ff16601c14155b156131cd5750600090506004613251565b6040805160008082526020820180845289905260ff881692820192909252606081018690526080810185905260019060a0016020604051602081039080840390855afa158015613221573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b03811661324a57600060019250925050613251565b9150600090505b94509492505050565b6000806001600160ff1b03831660ff84901c601b0161327b8782888561316d565b935093505050935093915050565b6060824710156132ea5760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f6044820152651c8818d85b1b60d21b6064820152608401610eab565b843b6133385760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610eab565b600080866001600160a01b0316858760405161335491906138a3565b60006040518083038185875af1925050503d8060008114613391576040519150601f19603f3d011682016040523d82523d6000602084013e613396565b606091505b50915091506133a68282866133b1565b979650505050505050565b606083156133c0575081612064565b8251156133d05782518084602001fd5b8160405162461bcd60e51b8152600401610eab919061392b565b8280546133f690613a92565b90600052602060002090601f016020900481019282613418576000855561345e565b82601f1061343157805160ff191683800117855561345e565b8280016001018555821561345e579182015b8281111561345e578251825591602001919060010190613443565b5061346a92915061346e565b5090565b5b8082111561346a576000815560010161346f565b60006001600160401b038084111561349d5761349d613b54565b604051601f8501601f19908116603f011681019082821181831017156134c5576134c5613b54565b816040528093508581528686860111156134de57600080fd5b858560208301376000602087830101525050509392505050565b600082601f83011261350957600080fd5b61206483833560208501613483565b60006020828403121561352a57600080fd5b813561206481613b6a565b6000806040838503121561354857600080fd5b823561355381613b6a565b9150602083013561356381613b6a565b809150509250929050565b60008060006060848603121561358357600080fd5b833561358e81613b6a565b9250602084013561359e81613b6a565b929592945050506040919091013590565b600080600080608085870312156135c557600080fd5b84356135d081613b6a565b935060208501356135e081613b6a565b92506040850135915060608501356001600160401b0381111561360257600080fd5b61360e878288016134f8565b91505092959194509250565b6000806040838503121561362d57600080fd5b823561363881613b6a565b9150602083013561356381613b7f565b6000806040838503121561365b57600080fd5b823561366681613b6a565b915060208301356001600160401b0381111561368157600080fd5b61368d858286016134f8565b9150509250929050565b600080604083850312156136aa57600080fd5b82356136b581613b6a565b946020939093013593505050565b600080602083850312156136d657600080fd5b82356001600160401b03808211156136ed57600080fd5b818501915085601f83011261370157600080fd5b81358181111561371057600080fd5b8660208260051b850101111561372557600080fd5b60209290920196919550909350505050565b60006020828403121561374957600080fd5b813561206481613b7f565b60006020828403121561376657600080fd5b815161206481613b7f565b60006020828403121561378357600080fd5b813561206481613b8d565b6000602082840312156137a057600080fd5b815161206481613b8d565b6000602082840312156137bd57600080fd5b81356001600160401b038111156137d357600080fd5b8201601f810184136137e457600080fd5b61258a84823560208401613483565b60006020828403121561380557600080fd5b5035919050565b60006020828403121561381e57600080fd5b5051919050565b6000806040838503121561383857600080fd5b8235915060208301356001600160401b0381111561368157600080fd5b6000806040838503121561386857600080fd5b50508035926020909101359150565b6000815180845261388f816020860160208601613a66565b601f01601f19169290920160200192915050565b600082516138b5818460208701613a66565b9190910192915050565b600083516138d1818460208801613a66565b8351908301906138e5818360208801613a66565b01949350505050565b6001600160a01b038581168252841660208201526040810183905260806060820181905260009061392190830184613877565b9695505050505050565b6020815260006120646020830184613877565b60208082526026908201527f5061796d656e7453706c69747465723a206163636f756e7420686173206e6f2060408201526573686172657360d01b606082015260800190565b6020808252602b908201527f5061796d656e7453706c69747465723a206163636f756e74206973206e6f742060408201526a191d59481c185e5b595b9d60aa1b606082015260800190565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60008219821115613a1757613a17613afc565b500190565b600082613a2b57613a2b613b12565b500490565b6000816000190483118215151615613a4a57613a4a613afc565b500290565b600082821015613a6157613a61613afc565b500390565b60005b83811015613a81578181015183820152602001613a69565b83811115611d635750506000910152565b600181811c90821680613aa657607f821691505b60208210811415613ac757634e487b7160e01b600052602260045260246000fd5b50919050565b6000600019821415613ae157613ae1613afc565b5060010190565b600082613af757613af7613b12565b500690565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052601260045260246000fd5b634e487b7160e01b600052602160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b6001600160a01b03811681146112e457600080fd5b80151581146112e457600080fd5b6001600160e01b0319811681146112e457600080fdfea264697066735822122054d58b66bc356807e80f98237a943b06f85e973d3a8d27934796ae89fb623e0a64736f6c63430008070033

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

00000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000041697066733a2f2f516d65385844503131544664375a356a547779597a767633656a4b676f6353365067614a546a6a385247537839792f68696464656e2e6a736f6e00000000000000000000000000000000000000000000000000000000000000

-----Decoded View---------------
Arg [0] : _notRevealedUri (string): ipfs://Qme8XDP11TFd7Z5jTwyYzvv3ejKgocS6PgaJTjj8RGSx9y/hidden.json

-----Encoded View---------------
5 Constructor Arguments found :
Arg [0] : 0000000000000000000000000000000000000000000000000000000000000020
Arg [1] : 0000000000000000000000000000000000000000000000000000000000000041
Arg [2] : 697066733a2f2f516d65385844503131544664375a356a547779597a76763365
Arg [3] : 6a4b676f6353365067614a546a6a385247537839792f68696464656e2e6a736f
Arg [4] : 6e00000000000000000000000000000000000000000000000000000000000000


Deployed Bytecode Sourcemap

146125:5694:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;135563:40;110088:10;135563:40;;;-1:-1:-1;;;;;10262:32:1;;;10244:51;;135593:9:0;10326:2:1;10311:18;;10304:34;10217:18;135563:40:0;;;;;;;146125:5694;;;;;146354:68;;;;;;;;;;;;;:::i;:::-;;;11459:25:1;;;11447:2;11432:18;146354:68:0;;;;;;;;146903:36;;;;;;;;;;;;;;;;116184:356;;;;;;;;;;-1:-1:-1;116184:356:0;;;;;:::i;:::-;;:::i;:::-;;;11286:14:1;;11279:22;11261:41;;11249:2;11234:18;116184:356:0;11121:187:1;118692:100:0;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;120195:204::-;;;;;;;;;;-1:-1:-1;120195:204:0;;;;;:::i;:::-;;:::i;:::-;;;-1:-1:-1;;;;;10018:32:1;;;10000:51;;9988:2;9973:18;120195:204:0;9854:203:1;119758:371:0;;;;;;;;;;-1:-1:-1;119758:371:0;;;;;:::i;:::-;;:::i;:::-;;146658:44;;;;;;;;;;;;146701:1;146658:44;;143605:120;;;;;;;;;;;;;:::i;149647:351::-;;;;;;;;;;-1:-1:-1;149647:351:0;;;;;:::i;:::-;;:::i;150488:85::-;;;;;;;;;;-1:-1:-1;150488:85:0;;;;;:::i;:::-;;:::i;113549:264::-;;;;;;;;;;;;113786:12;;-1:-1:-1;;;;;;;;113786:12:0;;;;113770:13;;;:28;;;;113763:35;;113549:264;137349:566;;;;;;;;;;-1:-1:-1;137349:566:0;;;;;:::i;:::-;;:::i;121052:170::-;;;;;;;;;;-1:-1:-1;121052:170:0;;;;;:::i;:::-;;:::i;115075:1037::-;;;;;;;;;;-1:-1:-1;115075:1037:0;;;;;:::i;:::-;;:::i;150142:120::-;;;;;;;;;;-1:-1:-1;150142:120:0;;;;;:::i;:::-;;:::i;146305:42::-;;;;;;;;;;;;146344:3;146305:42;;143830:32;;;;;;;;;;;;;;;;135694:91;;;;;;;;;;-1:-1:-1;135765:12:0;;135694:91;;151424:168;;;:::i;136823:135::-;;;;;;;;;;-1:-1:-1;136823:135:0;;;;;:::i;:::-;-1:-1:-1;;;;;136920:21:0;;;136893:7;136920:21;;;:14;:21;;;;;;;;:30;;;;;;;;;;;;;136823:135;121293:185;;;;;;;;;;-1:-1:-1;121293:185:0;;;;;:::i;:::-;;:::i;146429:47::-;;;;;;;;;;;;146472:4;146429:47;;138183:641;;;;;;;;;;-1:-1:-1;138183:641:0;;;;;:::i;:::-;;:::i;148745:894::-;;;;;;:::i;:::-;;:::i;150581:113::-;;;;;;;;;;-1:-1:-1;150581:113:0;;;;;:::i;:::-;;:::i;114106:669::-;;;;;;;;;;-1:-1:-1;114106:669:0;;;;;:::i;:::-;;:::i;147245:28::-;;;;;;;;;;-1:-1:-1;147245:28:0;;;;;;;;;;;147213:25;;;;;;;;;;-1:-1:-1;147213:25:0;;;;;;;;;;;145896:119;;;;;;;;;;-1:-1:-1;145896:119:0;;;;;:::i;:::-;;:::i;118501:124::-;;;;;;;;;;-1:-1:-1;118501:124:0;;;;;:::i;:::-;;:::i;116604:206::-;;;;;;;;;;-1:-1:-1;116604:206:0;;;;;:::i;:::-;;:::i;151234:182::-;;;;;;;;;;;;;:::i;147029:59::-;;;;;;;;;;-1:-1:-1;147029:59:0;;;;;:::i;:::-;;;;;;;;;;;;;;147166:40;;;;;;;;;;-1:-1:-1;147166:40:0;;;;;;;;146483:52;;;;;;;;;;;;146525:10;146483:52;;137049:100;;;;;;;;;;-1:-1:-1;137049:100:0;;;;;:::i;:::-;;:::i;140984:87::-;;;;;;;;;;-1:-1:-1;141030:7:0;141057:6;-1:-1:-1;;;;;141057:6:0;140984:87;;147095:62;;;;;;;;;;-1:-1:-1;147095:62:0;;;;;:::i;:::-;;;;;;;;;;;;;;118861:104;;;;;;;;;;;;;:::i;136545:109::-;;;;;;;;;;-1:-1:-1;136545:109:0;;;;;:::i;:::-;-1:-1:-1;;;;;136628:18:0;136601:7;136628:18;;;:9;:18;;;;;;;136545:109;147534:183;;;;;;;;;;;;;:::i;146946:39::-;;;;;;;;;;;;;;;;147725:1012;;;;;;:::i;:::-;;:::i;120471:279::-;;;;;;;;;;-1:-1:-1;120471:279:0;;;;;:::i;:::-;;:::i;151600:214::-;;;;;;;;;;;;;:::i;143869:30::-;;;;;;;;;;;;;;;;145655:163;;;;;;;;;;;;;:::i;144415:242::-;;;;;;;;;;;;;:::i;121549:342::-;;;;;;;;;;-1:-1:-1;121549:342:0;;;;;:::i;:::-;;:::i;146992:28::-;;;;;;;;;;;;;;;;142564:81;;;;;;;;;;;;142610:35;142564:81;;150702:524;;;;;;;;;;-1:-1:-1;150702:524:0;;;;;:::i;:::-;;:::i;136341:105::-;;;;;;;;;;-1:-1:-1;136341:105:0;;;;;:::i;:::-;-1:-1:-1;;;;;136422:16:0;136395:7;136422:16;;;:7;:16;;;;;;;136341:105;143033:339;;;;;;;;;;-1:-1:-1;143033:339:0;;;;;:::i;:::-;;:::i;142745:110::-;;;;;;;;;;-1:-1:-1;142745:110:0;;;;;:::i;:::-;;:::i;146542:56::-;;;;;;;;;;;;146587:11;146542:56;;136131:119;;;;;;;;;;-1:-1:-1;136131:119:0;;;;;:::i;:::-;-1:-1:-1;;;;;136216:26:0;136189:7;136216:26;;;:19;:26;;;;;;;136131:119;146254:44;;;;;;;;;;;;146294:4;146254:44;;150391:89;;;;;;;;;;-1:-1:-1;150391:89:0;;;;;:::i;:::-;;:::i;135879:95::-;;;;;;;;;;-1:-1:-1;135952:14:0;;135879:95;;142863:162;;;;;;;;;;-1:-1:-1;142863:162:0;;;;;:::i;:::-;;:::i;145240:35::-;;;;;;;;;;;;;;;;120821:164;;;;;;;;;;-1:-1:-1;120821:164:0;;;;;:::i;:::-;-1:-1:-1;;;;;120942:25:0;;;120918:4;120942:25;;;:18;:25;;;;;;;;:35;;;;;;;;;;;;;;;120821:164;144803:326;;;;;;;;;;-1:-1:-1;144803:326:0;;;;;:::i;:::-;;:::i;142654:30::-;;;;;;;;;;-1:-1:-1;142654:30:0;;;;-1:-1:-1;;;;;142654:30:0;;;150006:128;;;;;;;;;;-1:-1:-1;150006:128:0;;;;;:::i;:::-;;:::i;141893:201::-;;;;;;;;;;-1:-1:-1;141893:201:0;;;;;:::i;:::-;;:::i;146354:68::-;146394:28;146344:3;146294:4;146394:28;:::i;:::-;146354:68;:::o;116184:356::-;116286:4;-1:-1:-1;;;;;;116319:40:0;;-1:-1:-1;;;116319:40:0;;:101;;-1:-1:-1;;;;;;;116372:48:0;;-1:-1:-1;;;116372:48:0;116319:101;:164;;;-1:-1:-1;;;;;;;116433:50:0;;-1:-1:-1;;;116433:50:0;116319:164;:213;;;-1:-1:-1;;;;;;;;;;2993:40:0;;;116496:36;116303:229;116184:356;-1:-1:-1;;116184:356:0:o;118692:100::-;118746:13;118779:5;118772:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;118692:100;:::o;120195:204::-;120263:7;120288:16;120296:7;120288;:16::i;:::-;120283:64;;120313:34;;-1:-1:-1;;;120313:34:0;;;;;;;;;;;120283:64;-1:-1:-1;120367:24:0;;;;:15;:24;;;;;;-1:-1:-1;;;;;120367:24:0;;120195:204::o;119758:371::-;119831:13;119847:24;119863:7;119847:15;:24::i;:::-;119831:40;;119892:5;-1:-1:-1;;;;;119886:11:0;:2;-1:-1:-1;;;;;119886:11:0;;119882:48;;;119906:24;;-1:-1:-1;;;119906:24:0;;;;;;;;;;;119882:48;110088:10;-1:-1:-1;;;;;119947:21:0;;;;;;:63;;-1:-1:-1;119973:37:0;119990:5;110088:10;120821:164;:::i;119973:37::-;119972:38;119947:63;119943:138;;;120034:35;;-1:-1:-1;;;120034:35:0;;;;;;;;;;;119943:138;120093:28;120102:2;120106:7;120115:5;120093:8;:28::i;:::-;119820:309;119758:371;;:::o;143605:120::-;143670:7;141057:6;;-1:-1:-1;;;;;141057:6:0;110088:10;141204:23;141196:68;;;;-1:-1:-1;;;141196:68:0;;;;;;;:::i;:::-;;;;;;;;;143697:20:::1;:18;:20::i;:::-;143690:27;;143605:120:::0;:::o;149647:351::-;141030:7;141057:6;-1:-1:-1;;;;;141057:6:0;110088:10;141204:23;141196:68;;;;-1:-1:-1;;;141196:68:0;;;;;;;:::i;:::-;149743:9:::1;::::0;146344:3:::1;::::0;149743:28:::1;::::0;149755:9;;149743:28:::1;:::i;:::-;:44;;149721:115;;;::::0;-1:-1:-1;;;149721:115:0;;19291:2:1;149721:115:0::1;::::0;::::1;19273:21:1::0;19330:2;19310:18;;;19303:30;-1:-1:-1;;;19349:18:1;;;19342:51;19410:18;;149721:115:0::1;19089:345:1::0;149721:115:0::1;149862:9;;:16;;149849:9;;:29;;;;;;;:::i;:::-;::::0;;;-1:-1:-1;149896:9:0::1;::::0;-1:-1:-1;149891:100:0::1;149911:20:::0;;::::1;149891:100;;;149953:26;149963:9;;149973:1;149963:12;;;;;;;:::i;:::-;;;;;;;;;;;;;;:::i;:::-;149977:1;149953:9;:26::i;:::-;149933:3:::0;::::1;::::0;::::1;:::i;:::-;;;;149891:100;;150488:85:::0;141030:7;141057:6;-1:-1:-1;;;;;141057:6:0;110088:10;141204:23;141196:68;;;;-1:-1:-1;;;141196:68:0;;;;;;;:::i;:::-;150550:6:::1;:15:::0;;;::::1;;;;-1:-1:-1::0;;150550:15:0;;::::1;::::0;;;::::1;::::0;;150488:85::o;137349:566::-;-1:-1:-1;;;;;137425:16:0;;137444:1;137425:16;;;:7;:16;;;;;;137417:71;;;;-1:-1:-1;;;137417:71:0;;;;;;;:::i;:::-;137501:21;137549:15;135952:14;;;135879:95;137549:15;137525:39;;:21;:39;:::i;:::-;137501:63;;137575:15;137593:58;137609:7;137618:13;137633:17;137642:7;-1:-1:-1;;;;;136628:18:0;136601:7;136628:18;;;:9;:18;;;;;;;136545:109;137633:17;137593:15;:58::i;:::-;137575:76;-1:-1:-1;137672:12:0;137664:68;;;;-1:-1:-1;;;137664:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;137745:18:0;;;;;;:9;:18;;;;;:29;;137767:7;;137745:18;:29;;137767:7;;137745:29;:::i;:::-;;;;;;;;137803:7;137785:14;;:25;;;;;;;:::i;:::-;;;;-1:-1:-1;137823:35:0;;-1:-1:-1;137841:7:0;137850;137823:17;:35::i;:::-;137874:33;;;-1:-1:-1;;;;;10262:32:1;;10244:51;;10326:2;10311:18;;10304:34;;;137874:33:0;;10217:18:1;137874:33:0;;;;;;;137406:509;;137349:566;:::o;121052:170::-;121186:28;121196:4;121202:2;121206:7;121186:9;:28::i;115075:1037::-;115164:7;115197:16;115207:5;115197:9;:16::i;:::-;115188:5;:25;115184:61;;115222:23;;-1:-1:-1;;;115222:23:0;;;;;;;;;;;115184:61;115281:13;;-1:-1:-1;;;;;115281:13:0;115256:22;;;115523:501;115543:14;115539:1;:18;115523:501;;;115579:31;115613:14;;;:11;:14;;;;;;;;;115579:48;;;;;;;;;-1:-1:-1;;;;;115579:48:0;;;;-1:-1:-1;;;115579:48:0;;-1:-1:-1;;;;;115579:48:0;;;;;;;;-1:-1:-1;;;115579:48:0;;;;;;;;;;;;;;;;115642:65;;115683:8;;;115642:65;115725:14;;-1:-1:-1;;;;;115725:28:0;;115721:103;;115794:14;;;-1:-1:-1;115721:103:0;115863:5;-1:-1:-1;;;;;115842:26:0;:17;-1:-1:-1;;;;;115842:26:0;;115838:175;;;115908:5;115893:11;:20;115889:77;;;-1:-1:-1;115945:1:0;-1:-1:-1;115938:8:0;;-1:-1:-1;;;115938:8:0;115889:77;115984:13;;;;;115838:175;115564:460;115523:501;115559:3;;115523:501;;;;116096:8;;;150142:120;141030:7;141057:6;-1:-1:-1;;;;;141057:6:0;110088:10;141204:23;141196:68;;;;-1:-1:-1;;;141196:68:0;;;;;;;:::i;:::-;150226:28;;::::1;::::0;:12:::1;::::0;:28:::1;::::0;::::1;::::0;::::1;:::i;:::-;;150142:120:::0;:::o;151424:168::-;141030:7;141057:6;-1:-1:-1;;;;;141057:6:0;110088:10;141204:23;141196:68;;;;-1:-1:-1;;;141196:68:0;;;;;;;:::i;:::-;151498:59:::1;::::0;151481:12:::1;::::0;151506:10:::1;::::0;151531:21:::1;::::0;151481:12;151498:59;151481:12;151498:59;151531:21;151506:10;151498:59:::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;151480:77;;;151576:7;151568:16;;;::::0;::::1;;151469:123;151424:168::o:0;121293:185::-;121431:39;121448:4;121454:2;121458:7;121431:39;;;;;;;;;;;;:16;:39::i;138183:641::-;-1:-1:-1;;;;;138265:16:0;;138284:1;138265:16;;;:7;:16;;;;;;138257:71;;;;-1:-1:-1;;;138257:71:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;136216:26:0;;138341:21;136216:26;;;:19;:26;;;;;;138365:30;;-1:-1:-1;;;138365:30:0;;138389:4;138365:30;;;10000:51:1;-1:-1:-1;;;;;138365:15:0;;;;;9973:18:1;;138365:30:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;:53;;;;:::i;:::-;138341:77;;138429:15;138447:65;138463:7;138472:13;138487:24;138496:5;138503:7;-1:-1:-1;;;;;136920:21:0;;;136893:7;136920:21;;;:14;:21;;;;;;;;:30;;;;;;;;;;;;;136823:135;138447:65;138429:83;-1:-1:-1;138533:12:0;138525:68;;;;-1:-1:-1;;;138525:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;138606:21:0;;;;;;;:14;:21;;;;;;;;:30;;;;;;;;;;;:41;;138640:7;;138606:21;:41;;138640:7;;138606:41;:::i;:::-;;;;-1:-1:-1;;;;;;;138658:26:0;;;;;;:19;:26;;;;;:37;;138688:7;;138658:26;:37;;138688:7;;138658:37;:::i;:::-;;;;-1:-1:-1;138708:47:0;;-1:-1:-1;138731:5:0;138738:7;138747;138708:22;:47::i;:::-;138771:45;;;-1:-1:-1;;;;;10262:32:1;;;10244:51;;10326:2;10311:18;;10304:34;;;138771:45:0;;;;;10217:18:1;138771:45:0;;;;;;;138246:578;;138183:641;;:::o;148745:894::-;145348:24;:22;:24::i;:::-;145326:118;;;;-1:-1:-1;;;145326:118:0;;16464:2:1;145326:118:0;;;16446:21:1;16503:2;16483:18;;;16476:30;16542:34;16522:18;;;16515:62;-1:-1:-1;;;16593:18:1;;;16586:42;16645:19;;145326:118:0;16262:408:1;145326:118:0;146394:28:::1;146344:3;146294:4;146394:28;:::i;:::-;148921:8;148898:20;;148878:17;;:40;;;;:::i;:::-;:51;;;;:::i;:::-;:81;;148856:153;;;::::0;-1:-1:-1;;;148856:153:0;;20044:2:1;148856:153:0::1;::::0;::::1;20026:21:1::0;20083:2;20063:18;;;20056:30;-1:-1:-1;;;20102:18:1;;;20095:52;20164:18;;148856:153:0::1;19842:346:1::0;148856:153:0::1;146701:1;149028:8;:28;;149020:79;;;::::0;-1:-1:-1;;;149020:79:0;;22230:2:1;149020:79:0::1;::::0;::::1;22212:21:1::0;22269:2;22249:18;;;22242:30;22308:27;22288:18;;;22281:55;22353:18;;149020:79:0::1;22028:349:1::0;149020:79:0::1;149162:10;149134:39;::::0;;;:27:::1;:39;::::0;;;;;146650:1:::1;::::0;149134:50:::1;::::0;149176:8;;149134:50:::1;:::i;:::-;:85;;149112:161;;;::::0;-1:-1:-1;;;149112:161:0;;21108:2:1;149112:161:0::1;::::0;::::1;21090:21:1::0;21147:2;21127:18;;;21120:30;21186:28;21166:18;;;21159:56;21232:18;;149112:161:0::1;20906:350:1::0;149112:161:0::1;149294:9;149307:10;149294:23;149286:65;;;::::0;-1:-1:-1;;;149286:65:0;;14289:2:1;149286:65:0::1;::::0;::::1;14271:21:1::0;14328:2;14308:18;;;14301:30;14367:31;14347:18;;;14340:59;14416:18;;149286:65:0::1;14087:353:1::0;149286:65:0::1;149373:6;::::0;::::1;::::0;::::1;;;149372:7;149364:43;;;::::0;-1:-1:-1;;;149364:43:0;;20756:2:1;149364:43:0::1;::::0;::::1;20738:21:1::0;20795:2;20775:18;;;20768:30;-1:-1:-1;;;20814:18:1;;;20807:53;20877:18;;149364:43:0::1;20554:347:1::0;149364:43:0::1;149452:10;:8;:10::i;:::-;149441:21;::::0;:8;:21:::1;:::i;:::-;149428:9;:34;;149420:60;;;::::0;-1:-1:-1;;;149420:60:0;;15769:2:1;149420:60:0::1;::::0;::::1;15751:21:1::0;15808:2;15788:18;;;15781:30;-1:-1:-1;;;15827:18:1;;;15820:43;15880:18;;149420:60:0::1;15567:337:1::0;149420:60:0::1;149521:10;149493:39;::::0;;;:27:::1;:39;::::0;;;;:51;;149536:8;;149493:39;:51:::1;::::0;149536:8;;149493:51:::1;:::i;:::-;;;;;;;;149579:8;149555:20;;:32;;;;;;;:::i;:::-;::::0;;;-1:-1:-1;149600:31:0::1;::::0;-1:-1:-1;149610:10:0::1;149622:8:::0;149600:9:::1;:31::i;150581:113::-:0;141030:7;141057:6;-1:-1:-1;;;;;141057:6:0;110088:10;141204:23;141196:68;;;;-1:-1:-1;;;141196:68:0;;;;;;;:::i;:::-;150657:20:::1;:29:::0;;-1:-1:-1;;150657:29:0::1;::::0;::::1;;::::0;;;::::1;::::0;;150581:113::o;114106:669::-;114218:13;;114173:7;;-1:-1:-1;;;;;114218:13:0;114173:7;;114424:296;114444:14;114440:1;:18;114424:296;;;114480:31;114514:14;;;:11;:14;;;;;;;;;114480:48;;;;;;;;;-1:-1:-1;;;;;114480:48:0;;;;-1:-1:-1;;;114480:48:0;;-1:-1:-1;;;;;114480:48:0;;;;;;;;-1:-1:-1;;;114480:48:0;;;;;;;;;;;;;;114543:166;;114604:5;114589:11;:20;114585:77;;;-1:-1:-1;114641:1:0;114106:669;-1:-1:-1;;;;114106:669:0:o;114585:77::-;114680:13;;;;;114543:166;-1:-1:-1;114460:3:0;;114424:296;;;;114744:23;;-1:-1:-1;;;114744:23:0;;;;;;;;;;;145896:119;141030:7;141057:6;-1:-1:-1;;;;;141057:6:0;110088:10;141204:23;141196:68;;;;-1:-1:-1;;;141196:68:0;;;;;;;:::i;:::-;145974:20:::1;:33:::0;145896:119::o;118501:124::-;118565:7;118592:20;118604:7;118592:11;:20::i;:::-;:25;;118501:124;-1:-1:-1;;118501:124:0:o;116604:206::-;116668:7;-1:-1:-1;;;;;116692:19:0;;116688:60;;116720:28;;-1:-1:-1;;;116720:28:0;;;;;;;;;;;116688:60;-1:-1:-1;;;;;;116774:19:0;;;;;:12;:19;;;;;:27;-1:-1:-1;;;;;116774:27:0;;116604:206::o;151234:182::-;141030:7;141057:6;-1:-1:-1;;;;;141057:6:0;110088:10;141204:23;141196:68;;;;-1:-1:-1;;;141196:68:0;;;;;;;:::i;:::-;151308:20:::1;::::0;::::1;;151300:67;;;::::0;-1:-1:-1;;;151300:67:0;;22584:2:1;151300:67:0::1;::::0;::::1;22566:21:1::0;22623:2;22603:18;;;22596:30;22662:34;22642:18;;;22635:62;-1:-1:-1;;;22713:18:1;;;22706:32;22755:19;;151300:67:0::1;22382:398:1::0;151300:67:0::1;151378:30;151405:1;151378:18;:30::i;:::-;151234:182::o:0;137049:100::-;137100:7;137127;137135:5;137127:14;;;;;;;;:::i;:::-;;;;;;;;;;;-1:-1:-1;;;;;137127:14:0;;137049:100;-1:-1:-1;;137049:100:0:o;118861:104::-;118917:13;118950:7;118943:14;;;;;:::i;147534:183::-;147575:7;147599:24;:22;:24::i;:::-;147595:82;;;-1:-1:-1;146587:11:0;;147534:183::o;147595:82::-;-1:-1:-1;146525:10:0;;147534:183::o;147725:1012::-;143969:21;:19;:21::i;:::-;143947:112;;;;-1:-1:-1;;;143947:112:0;;13450:2:1;143947:112:0;;;13432:21:1;13489:2;13469:18;;;13462:30;13528:34;13508:18;;;13501:62;-1:-1:-1;;;13579:18:1;;;13572:39;13628:19;;143947:112:0;13248:405:1;143947:112:0;143500:15:::1;::::0;147884:10:::1;::::0;147896:9;;-1:-1:-1;;;;;143500:15:0::1;143464:32;147884:10:::0;147896:9;143464:13:::1;:32::i;:::-;-1:-1:-1::0;;;;;143464:51:0::1;;143456:121;;;::::0;-1:-1:-1;;;143456:121:0;;16111:2:1;143456:121:0::1;::::0;::::1;16093:21:1::0;16150:2;16130:18;;;16123:30;16189:26;16169:18;;;16162:54;16233:18;;143456:121:0::1;15909:348:1::0;143456:121:0::1;146294:4:::2;147988:8;147965:20;;147945:17;;:40;;;;:::i;:::-;:51;;;;:::i;:::-;:81;;147923:153;;;::::0;-1:-1:-1;;;147923:153:0;;20044:2:1;147923:153:0::2;::::0;::::2;20026:21:1::0;20083:2;20063:18;;;20056:30;-1:-1:-1;;;20102:18:1;;;20095:52;20164:18;;147923:153:0::2;19842:346:1::0;147923:153:0::2;146472:4;148131:8;148111:17;;:28;;;;:::i;:::-;:48;;148089:124;;;::::0;-1:-1:-1;;;148089:124:0;;15007:2:1;148089:124:0::2;::::0;::::2;14989:21:1::0;15046:2;15026:18;;;15019:30;15085:28;15065:18;;;15058:56;15131:18;;148089:124:0::2;14805:350:1::0;148089:124:0::2;148273:10;148248:36;::::0;;;:24:::2;:36;::::0;;;;;146764:1:::2;::::0;148248:47:::2;::::0;148287:8;;148248:47:::2;:::i;:::-;:79;;148226:151;;;::::0;-1:-1:-1;;;148226:151:0;;21463:2:1;148226:151:0::2;::::0;::::2;21445:21:1::0;21502:2;21482:18;;;21475:30;-1:-1:-1;;;21521:18:1;;;21514:52;21583:18;;148226:151:0::2;21261:346:1::0;148226:151:0::2;148398:9;148411:10;148398:23;148390:65;;;::::0;-1:-1:-1;;;148390:65:0;;14289:2:1;148390:65:0::2;::::0;::::2;14271:21:1::0;14328:2;14308:18;;;14301:30;14367:31;14347:18;;;14340:59;14416:18;;148390:65:0::2;14087:353:1::0;148390:65:0::2;148477:6;::::0;::::2;::::0;::::2;;;148476:7;148468:43;;;::::0;-1:-1:-1;;;148468:43:0;;20756:2:1;148468:43:0::2;::::0;::::2;20738:21:1::0;20795:2;20775:18;;;20768:30;-1:-1:-1;;;20814:18:1;;;20807:53;20877:18;;148468:43:0::2;20554:347:1::0;148468:43:0::2;148556:10;:8;:10::i;:::-;148545:21;::::0;:8;:21:::2;:::i;:::-;148532:9;:34;;148524:60;;;::::0;-1:-1:-1;;;148524:60:0;;15769:2:1;148524:60:0::2;::::0;::::2;15751:21:1::0;15808:2;15788:18;;;15781:30;-1:-1:-1;;;15827:18:1;;;15820:43;15880:18;;148524:60:0::2;15567:337:1::0;148524:60:0::2;148622:10;148597:36;::::0;;;:24:::2;:36;::::0;;;;:48;;148637:8;;148597:36;:48:::2;::::0;148637:8;;148597:48:::2;:::i;:::-;;;;;;;;148677:8;148656:17;;:29;;;;;;;:::i;:::-;::::0;;;-1:-1:-1;148698:31:0::2;::::0;-1:-1:-1;148708:10:0::2;148720:8:::0;148698:9:::2;:31::i;:::-;144070:1:::1;;147725:1012:::0;;:::o;120471:279::-;-1:-1:-1;;;;;120562:24:0;;110088:10;120562:24;120558:54;;;120595:17;;-1:-1:-1;;;120595:17:0;;;;;;;;;;;120558:54;110088:10;120625:32;;;;:18;:32;;;;;;;;-1:-1:-1;;;;;120625:42:0;;;;;;;;;;;;:53;;-1:-1:-1;;120625:53:0;;;;;;;;;;120694:48;;11261:41:1;;;120625:42:0;;110088:10;120694:48;;11234:18:1;120694:48:0;;;;;;;120471:279;;:::o;151600:214::-;141030:7;141057:6;-1:-1:-1;;;;;141057:6:0;110088:10;141204:23;141196:68;;;;-1:-1:-1;;;141196:68:0;;;;;;;:::i;:::-;151658:9:::1;151653:154;151677:11;:18:::0;151673:22;::::1;151653:154;;;151717:22;151750:11;151762:1;151750:14;;;;;;;;:::i;:::-;;::::0;;;::::1;::::0;;;::::1;::::0;-1:-1:-1;;;;;151750:14:0::1;::::0;-1:-1:-1;151780:15:0::1;151750:14:::0;151780:7:::1;:15::i;:::-;-1:-1:-1::0;151697:3:0;::::1;::::0;::::1;:::i;:::-;;;;151653:154;;145655:163:::0;145710:4;145766:1;145743:20;;:24;:67;;;;-1:-1:-1;;145790:20:0;;145771:15;:39;;;145655:163::o;144415:242::-;144467:4;144520:1;144500:17;;:21;:53;;;;;144552:1;144534:15;;:19;144500:53;:102;;;;;144585:17;;144566:15;:36;;144500:102;:149;;;;-1:-1:-1;;144634:15:0;;144615;:34;;;144415:242::o;121549:342::-;121716:28;121726:4;121732:2;121736:7;121716:9;:28::i;:::-;121760:48;121783:4;121789:2;121793:7;121802:5;121760:22;:48::i;:::-;121755:129;;121832:40;;-1:-1:-1;;;121832:40:0;;;;;;;;;;;150702:524;150800:13;150853:16;150861:7;150853;:16::i;:::-;150831:113;;;;-1:-1:-1;;;150831:113:0;;21814:2:1;150831:113:0;;;21796:21:1;21853:2;21833:18;;;21826:30;21892:34;21872:18;;;21865:62;-1:-1:-1;;;21943:18:1;;;21936:45;21998:19;;150831:113:0;21612:411:1;150831:113:0;150962:8;;;;;;;150957:63;;150994:14;150987:21;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;150702:524;;;:::o;150957:63::-;151032:28;151063:10;:8;:10::i;:::-;151032:41;;151124:1;151099:14;151093:28;:32;:125;;;;;;;;;;;;;;;;;151161:14;151177:25;151194:7;151177:16;:25::i;:::-;151144:59;;;;;;;;;:::i;:::-;;;;;;;;;;;;;151093:125;151086:132;150702:524;-1:-1:-1;;;150702:524:0:o;143033:339::-;143089:7;143109:21;143209:122;143231:20;:18;:20::i;:::-;143276:39;;;142610:35;143276:39;;;;11669:25:1;;;;-1:-1:-1;;;;;11730:32:1;;11710:18;;;11703:60;143276:39:0;;;;;;;;;11642:18:1;;;143276:39:0;;143266:50;;;;;;-1:-1:-1;;;36443:57:0;;;9505:27:1;9548:11;;;9541:27;;;;9584:12;;;;9577:28;;;;36443:57:0;;;;;;;;;;9621:12:1;;;;36443:57:0;;;36433:68;;;;;;36313:196;143209:122;143143:189;;9104:66:1;143143:189:0;;;9092:79:1;9187:12;;;9180:28;;;;9224:12;;143143:189:0;;;-1:-1:-1;;143143:189:0;;;;;;;;;143133:200;;143143:189;143133:200;;;;;143033:339;-1:-1:-1;;;143033:339:0:o;142745:110::-;141030:7;141057:6;-1:-1:-1;;;;;141057:6:0;110088:10;141204:23;141196:68;;;;-1:-1:-1;;;141196:68:0;;;;;;;:::i;:::-;142821:15:::1;:26:::0;;-1:-1:-1;;;;;;142821:26:0::1;-1:-1:-1::0;;;;;142821:26:0;;;::::1;::::0;;;::::1;::::0;;142745:110::o;150391:89::-;141030:7;141057:6;-1:-1:-1;;;;;141057:6:0;110088:10;141204:23;141196:68;;;;-1:-1:-1;;;141196:68:0;;;;;;;:::i;:::-;150455:8:::1;:17:::0;;;::::1;;::::0;::::1;-1:-1:-1::0;;150455:17:0;;::::1;::::0;;;::::1;::::0;;150391:89::o;142863:162::-;142947:7;142974:43;142988:17;142998:6;142988:9;:17::i;:::-;143007:9;142974:13;:43::i;144803:326::-;141030:7;141057:6;-1:-1:-1;;;;;141057:6:0;110088:10;141204:23;141196:68;;;;-1:-1:-1;;;141196:68:0;;;;;;;:::i;:::-;144945:10:::1;144933:8;:22;;144911:132;;;::::0;-1:-1:-1;;;144911:132:0;;13860:2:1;144911:132:0::1;::::0;::::1;13842:21:1::0;13899:2;13879:18;;;13872:30;13938:34;13918:18;;;13911:62;14009:30;13989:18;;;13982:58;14057:19;;144911:132:0::1;13658:424:1::0;144911:132:0::1;145054:17;:30:::0;;;;145095:15:::1;:26:::0;144803:326::o;150006:128::-;141030:7;141057:6;-1:-1:-1;;;;;141057:6:0;110088:10;141204:23;141196:68;;;;-1:-1:-1;;;141196:68:0;;;;;;;:::i;:::-;150094:32;;::::1;::::0;:14:::1;::::0;:32:::1;::::0;::::1;::::0;::::1;:::i;141893:201::-:0;141030:7;141057:6;-1:-1:-1;;;;;141057:6:0;110088:10;141204:23;141196:68;;;;-1:-1:-1;;;141196:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;141982:22:0;::::1;141974:73;;;::::0;-1:-1:-1;;;141974:73:0;;15362:2:1;141974:73:0::1;::::0;::::1;15344:21:1::0;15401:2;15381:18;;;15374:30;15440:34;15420:18;;;15413:62;-1:-1:-1;;;15491:18:1;;;15484:36;15537:19;;141974:73:0::1;15160:402:1::0;141974:73:0::1;142058:28;142077:8;142058:18;:28::i;122146:144::-:0;122237:13;;122203:4;;-1:-1:-1;;;;;122237:13:0;122227:23;;:55;;;;-1:-1:-1;;122255:20:0;;;;:11;:20;;;;;:27;-1:-1:-1;;;122255:27:0;;;;122254:28;;122146:144::o;129137:196::-;129252:24;;;;:15;:24;;;;;;:29;;-1:-1:-1;;;;;;129252:29:0;-1:-1:-1;;;;;129252:29:0;;;;;;;;;129297:28;;129252:24;;129297:28;;;;;;;129137:196;;;:::o;39746:314::-;39799:7;39831:4;-1:-1:-1;;;;;39840:12:0;39823:29;;:66;;;;;39873:16;39856:13;:33;39823:66;39819:234;;;-1:-1:-1;39913:24:0;;39746:314::o;39819:234::-;-1:-1:-1;40249:73:0;;;39999:10;40249:73;;;;12033:25:1;;;;40011:12:0;12074:18:1;;;12067:34;40025:15:0;12117:18:1;;;12110:34;40293:13:0;12160:18:1;;;12153:34;40316:4:0;12203:19:1;;;;12196:61;;;;40249:73:0;;;;;;;;;;12005:19:1;;;;40249:73:0;;;40239:84;;;;;;143605:120::o;122298:104::-;122367:27;122377:2;122381:8;122367:27;;;;;;;;;;;;:9;:27::i;139002:248::-;139212:12;;-1:-1:-1;;;;;139192:16:0;;139148:7;139192:16;;;:7;:16;;;;;;139148:7;;139227:15;;139176:32;;:13;:32;:::i;:::-;139175:49;;;;:::i;:::-;:67;;;;:::i;:::-;139168:74;139002:248;-1:-1:-1;;;;139002:248:0:o;11938:317::-;12053:6;12028:21;:31;;12020:73;;;;-1:-1:-1;;;12020:73:0;;18114:2:1;12020:73:0;;;18096:21:1;18153:2;18133:18;;;18126:30;18192:31;18172:18;;;18165:59;18241:18;;12020:73:0;17912:353:1;12020:73:0;12107:12;12124:9;-1:-1:-1;;;;;12124:14:0;12147:6;12124:34;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;12106:52;;;12177:7;12169:78;;;;-1:-1:-1;;;12169:78:0;;17284:2:1;12169:78:0;;;17266:21:1;17323:2;17303:18;;;17296:30;17362:34;17342:18;;;17335:62;17433:28;17413:18;;;17406:56;17479:19;;12169:78:0;17082:422:1;124803:2036:0;124918:35;124956:20;124968:7;124956:11;:20::i;:::-;125031:18;;124918:58;;-1:-1:-1;124989:22:0;;-1:-1:-1;;;;;125015:34:0;110088:10;-1:-1:-1;;;;;125015:34:0;;:97;;;-1:-1:-1;125079:18:0;;125062:50;;110088:10;120821:164;:::i;125062:50::-;125015:146;;;-1:-1:-1;110088:10:0;125125:20;125137:7;125125:11;:20::i;:::-;-1:-1:-1;;;;;125125:36:0;;125015:146;124989:173;;125180:17;125175:66;;125206:35;;-1:-1:-1;;;125206:35:0;;;;;;;;;;;125175:66;125278:4;-1:-1:-1;;;;;125256:26:0;:13;:18;;;-1:-1:-1;;;;;125256:26:0;;125252:67;;125291:28;;-1:-1:-1;;;125291:28:0;;;;;;;;;;;125252:67;-1:-1:-1;;;;;125334:16:0;;125330:52;;125359:23;;-1:-1:-1;;;125359:23:0;;;;;;;;;;;125330:52;125503:49;125520:1;125524:7;125533:13;:18;;;125503:8;:49::i;:::-;-1:-1:-1;;;;;125840:18:0;;;;;;;:12;:18;;;;;;;;:31;;-1:-1:-1;;125840:31:0;;;-1:-1:-1;;;;;125840:31:0;;;-1:-1:-1;;125840:31:0;;;;;;;125882:16;;;;;;;;;:29;;;;;;;;-1:-1:-1;125882:29:0;;;;;;;;;;;125924:20;;;:11;:20;;;;;;:30;;-1:-1:-1;;;;;;125965:61:0;;;;-1:-1:-1;;;126010:15:0;125965:61;;;;;;;;;;;126288:11;;;126314:24;;;;;:29;126288:11;;126314:29;126310:417;;126527:13;;-1:-1:-1;;;;;126527:13:0;126513:27;;126509:207;;;126593:18;;;126561:24;;;:11;:24;;;;;;;;:50;;126672:28;;;;-1:-1:-1;;;;;126630:70:0;-1:-1:-1;;;126630:70:0;-1:-1:-1;;;;;;126630:70:0;;;-1:-1:-1;;;;;126561:50:0;;;126630:70;;;;;;;126509:207;125819:915;126770:7;126766:2;-1:-1:-1;;;;;126751:27:0;126760:4;-1:-1:-1;;;;;126751:27:0;;;;;;;;;;;126789:42;124907:1932;;124803:2036;;;:::o;21541:211::-;21685:58;;;-1:-1:-1;;;;;10262:32:1;;21685:58:0;;;10244:51:1;10311:18;;;;10304:34;;;21685:58:0;;;;;;;;;;10217:18:1;;;;21685:58:0;;;;;;;;-1:-1:-1;;;;;21685:58:0;-1:-1:-1;;;21685:58:0;;;21658:86;;21678:5;;21658:19;:86::i;117442:997::-;-1:-1:-1;;;;;;;;;;;;;;;;;;;;;;;;;117600:13:0;;117552:7;;-1:-1:-1;;;;;117600:13:0;117593:20;;117589:787;;;117630:31;117664:17;;;:11;:17;;;;;;;;;117630:51;;;;;;;;;-1:-1:-1;;;;;117630:51:0;;;;-1:-1:-1;;;117630:51:0;;-1:-1:-1;;;;;117630:51:0;;;;;;;;-1:-1:-1;;;117630:51:0;;;;;;;;;;;;;;117696:669;;117742:14;;-1:-1:-1;;;;;117742:28:0;;117738:93;;117802:9;117442:997;-1:-1:-1;;;117442:997:0:o;117738:93::-;-1:-1:-1;;;118149:6:0;118190:17;;;;:11;:17;;;;;;;;;118178:29;;;;;;;;;-1:-1:-1;;;;;118178:29:0;;;;;-1:-1:-1;;;118178:29:0;;-1:-1:-1;;;;;118178:29:0;;;;;;;;-1:-1:-1;;;118178:29:0;;;;;;;;;;;;;118234:28;118230:101;;118298:9;117442:997;-1:-1:-1;;;117442:997:0:o;118230:101::-;118113:237;;;117615:761;117589:787;118400:31;;-1:-1:-1;;;118400:31:0;;;;;;;;;;;142254:191;142328:16;142347:6;;-1:-1:-1;;;;;142364:17:0;;;-1:-1:-1;;;;;;142364:17:0;;;;;;142397:40;;142347:6;;;;;;;142397:40;;142328:16;142397:40;142317:128;142254:191;:::o;129898:790::-;130053:4;-1:-1:-1;;;;;130074:13:0;;10939:20;10987:8;130070:611;;130110:72;;-1:-1:-1;;;130110:72:0;;-1:-1:-1;;;;;130110:36:0;;;;;:72;;110088:10;;130161:4;;130167:7;;130176:5;;130110:72;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;130110:72:0;;;;;;;;-1:-1:-1;;130110:72:0;;;;;;;;;;;;:::i;:::-;;;130106:520;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;130356:13:0;;130352:259;;130406:40;;-1:-1:-1;;;130406:40:0;;;;;;;;;;;130352:259;130561:6;130555:13;130546:6;130542:2;130538:15;130531:38;130106:520;-1:-1:-1;;;;;;130233:55:0;-1:-1:-1;;;130233:55:0;;-1:-1:-1;130226:62:0;;130070:611;-1:-1:-1;130665:4:0;129898:790;;;;;;:::o;150270:113::-;150330:13;150363:12;150356:19;;;;;:::i;25178:723::-;25234:13;25455:10;25451:53;;-1:-1:-1;;25482:10:0;;;;;;;;;;;;-1:-1:-1;;;25482:10:0;;;;;25178:723::o;25451:53::-;25529:5;25514:12;25570:78;25577:9;;25570:78;;25603:8;;;;:::i;:::-;;-1:-1:-1;25626:10:0;;-1:-1:-1;25634:2:0;25626:10;;:::i;:::-;;;25570:78;;;25658:19;25690:6;-1:-1:-1;;;;;25680:17:0;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;25680:17:0;;25658:39;;25708:154;25715:10;;25708:154;;25742:11;25752:1;25742:11;;:::i;:::-;;-1:-1:-1;25811:10:0;25819:2;25811:5;:10;:::i;:::-;25798:24;;:2;:24;:::i;:::-;25785:39;;25768:6;25775;25768:14;;;;;;;;:::i;:::-;;;;:56;-1:-1:-1;;;;;25768:56:0;;;;;;;;-1:-1:-1;25839:11:0;25848:2;25839:11;;:::i;:::-;;;25708:154;;31352:231;31430:7;31451:17;31470:18;31492:27;31503:4;31509:9;31492:10;:27::i;:::-;31450:69;;;;31530:18;31542:5;31530:11;:18::i;:::-;-1:-1:-1;31566:9:0;31352:231;-1:-1:-1;;;31352:231:0:o;122765:163::-;122888:32;122894:2;122898:8;122908:5;122915:4;122888:5;:32::i;24090:716::-;24514:23;24540:69;24568:4;24540:69;;;;;;;;;;;;;;;;;24548:5;-1:-1:-1;;;;;24540:27:0;;;:69;;;;;:::i;:::-;24624:17;;24514:95;;-1:-1:-1;24624:21:0;24620:179;;24721:10;24710:30;;;;;;;;;;;;:::i;:::-;24702:85;;;;-1:-1:-1;;;24702:85:0;;23345:2:1;24702:85:0;;;23327:21:1;23384:2;23364:18;;;23357:30;23423:34;23403:18;;;23396:62;-1:-1:-1;;;23474:18:1;;;23467:40;23524:19;;24702:85:0;23143:406:1;29242:1308:0;29323:7;29332:12;29557:9;:16;29577:2;29557:22;29553:990;;;29853:4;29838:20;;29832:27;29903:4;29888:20;;29882:27;29961:4;29946:20;;29940:27;29596:9;29932:36;30004:25;30015:4;29932:36;29832:27;29882;30004:10;:25::i;:::-;29997:32;;;;;;;;;29553:990;30051:9;:16;30071:2;30051:22;30047:496;;;30326:4;30311:20;;30305:27;30377:4;30362:20;;30356:27;30419:23;30430:4;30305:27;30356;30419:10;:23::i;:::-;30412:30;;;;;;;;30047:496;-1:-1:-1;30491:1:0;;-1:-1:-1;30495:35:0;30047:496;29242:1308;;;;;:::o;27500:656::-;27578:20;27569:5;:29;;;;;;;;:::i;:::-;;27565:584;;;27500:656;:::o;27565:584::-;27689:29;27680:5;:38;;;;;;;;:::i;:::-;;27676:473;;;27735:34;;-1:-1:-1;;;27735:34:0;;13097:2:1;27735:34:0;;;13079:21:1;13136:2;13116:18;;;13109:30;13175:26;13155:18;;;13148:54;13219:18;;27735:34:0;12895:348:1;27676:473:0;27800:35;27791:5;:44;;;;;;;;:::i;:::-;;27787:362;;;27852:41;;-1:-1:-1;;;27852:41:0;;14647:2:1;27852:41:0;;;14629:21:1;14686:2;14666:18;;;14659:30;14725:33;14705:18;;;14698:61;14776:18;;27852:41:0;14445:355:1;27787:362:0;27924:30;27915:5;:39;;;;;;;;:::i;:::-;;27911:238;;;27971:44;;-1:-1:-1;;;27971:44:0;;17711:2:1;27971:44:0;;;17693:21:1;17750:2;17730:18;;;17723:30;17789:34;17769:18;;;17762:62;-1:-1:-1;;;17840:18:1;;;17833:32;17882:19;;27971:44:0;17509:398:1;27911:238:0;28046:30;28037:5;:39;;;;;;;;:::i;:::-;;28033:116;;;28093:44;;-1:-1:-1;;;28093:44:0;;19641:2:1;28093:44:0;;;19623:21:1;19680:2;19660:18;;;19653:30;19719:34;19699:18;;;19692:62;-1:-1:-1;;;19770:18:1;;;19763:32;19812:19;;28093:44:0;19439:398:1;123187:1362:0;123349:13;;-1:-1:-1;;;;;123349:13:0;-1:-1:-1;;;;;123377:16:0;;123373:48;;123402:19;;-1:-1:-1;;;123402:19:0;;;;;;;;;;;123373:48;123436:13;123432:44;;123458:18;;-1:-1:-1;;;123458:18:0;;;;;;;;;;;123432:44;-1:-1:-1;;;;;123820:16:0;;;;;;:12;:16;;;;;;;;:44;;-1:-1:-1;;;;;;123875:49:0;;-1:-1:-1;;;;;123820:44:0;;;;;;;123875:49;;;;-1:-1:-1;;123820:44:0;;;;;;123875:49;;;;;;;;;;;;;;;;123937:25;;;123875:29;123937:25;;;;;:35;;-1:-1:-1;;;;;;123983:66:0;;;;-1:-1:-1;;;124033:15:0;123983:66;;;;;;;;;;;123937:25;;124110:304;124130:8;124126:1;:12;124110:304;;;124165:38;;124190:12;;-1:-1:-1;;;;;124165:38:0;;;124182:1;;124165:38;;124182:1;;124165:38;124222:4;:68;;;;;124231:59;124262:1;124266:2;124270:12;124284:5;124231:22;:59::i;:::-;124230:60;124222:68;124218:156;;;124318:40;;-1:-1:-1;;;124318:40:0;;;;;;;;;;;124218:156;124388:14;;;;;124140:3;124110:304;;;-1:-1:-1;124426:13:0;:37;;-1:-1:-1;;;;;;124426:37:0;-1:-1:-1;;;;;124426:37:0;;;;;;;;;;124481:60;147725:1012;13422:229;13559:12;13591:52;13613:6;13621:4;13627:1;13630:12;13591:21;:52::i;32851:1632::-;32982:7;;33916:66;33903:79;;33899:163;;;-1:-1:-1;34015:1:0;;-1:-1:-1;34019:30:0;33999:51;;33899:163;34076:1;:7;;34081:2;34076:7;;:18;;;;;34087:1;:7;;34092:2;34087:7;;34076:18;34072:102;;;-1:-1:-1;34127:1:0;;-1:-1:-1;34131:30:0;34111:51;;34072:102;34288:24;;;34271:14;34288:24;;;;;;;;;12495:25:1;;;12568:4;12556:17;;12536:18;;;12529:45;;;;12590:18;;;12583:34;;;12633:18;;;12626:34;;;34288:24:0;;12467:19:1;;34288:24:0;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;34288:24:0;;-1:-1:-1;;34288:24:0;;;-1:-1:-1;;;;;;;34327:20:0;;34323:103;;34380:1;34384:29;34364:50;;;;;;;34323:103;34446:6;-1:-1:-1;34454:20:0;;-1:-1:-1;32851:1632:0;;;;;;;;:::o;31846:391::-;31960:7;;-1:-1:-1;;;;;32061:75:0;;32163:3;32159:12;;;32173:2;32155:21;32204:25;32215:4;32155:21;32224:1;32061:75;32204:10;:25::i;:::-;32197:32;;;;;;31846:391;;;;;;:::o;14542:511::-;14712:12;14770:5;14745:21;:30;;14737:81;;;;-1:-1:-1;;;14737:81:0;;18472:2:1;14737:81:0;;;18454:21:1;18511:2;18491:18;;;18484:30;18550:34;18530:18;;;18523:62;-1:-1:-1;;;18601:18:1;;;18594:36;18647:19;;14737:81:0;18270:402:1;14737:81:0;10939:20;;14829:60;;;;-1:-1:-1;;;14829:60:0;;22987:2:1;14829:60:0;;;22969:21:1;23026:2;23006:18;;;22999:30;23065:31;23045:18;;;23038:59;23114:18;;14829:60:0;22785:353:1;14829:60:0;14903:12;14917:23;14944:6;-1:-1:-1;;;;;14944:11:0;14964:5;14971:4;14944:32;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14902:74;;;;14994:51;15011:7;15020:10;15032:12;14994:16;:51::i;:::-;14987:58;14542:511;-1:-1:-1;;;;;;;14542:511:0:o;17229:712::-;17379:12;17408:7;17404:530;;;-1:-1:-1;17439:10:0;17432:17;;17404:530;17553:17;;:21;17549:374;;17751:10;17745:17;17812:15;17799:10;17795:2;17791:19;17784:44;17549:374;17894:12;17887:20;;-1:-1:-1;;;17887:20:0;;;;;;;;:::i;-1:-1:-1:-;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;:::o;:::-;;;;;;;;;;;;;;;14:631:1;78:5;-1:-1:-1;;;;;149:2:1;141:6;138:14;135:40;;;155:18;;:::i;:::-;230:2;224:9;198:2;284:15;;-1:-1:-1;;280:24:1;;;306:2;276:33;272:42;260:55;;;330:18;;;350:22;;;327:46;324:72;;;376:18;;:::i;:::-;416:10;412:2;405:22;445:6;436:15;;475:6;467;460:22;515:3;506:6;501:3;497:16;494:25;491:45;;;532:1;529;522:12;491:45;582:6;577:3;570:4;562:6;558:17;545:44;637:1;630:4;621:6;613;609:19;605:30;598:41;;;;14:631;;;;;:::o;650:220::-;692:5;745:3;738:4;730:6;726:17;722:27;712:55;;763:1;760;753:12;712:55;785:79;860:3;851:6;838:20;831:4;823:6;819:17;785:79;:::i;875:247::-;934:6;987:2;975:9;966:7;962:23;958:32;955:52;;;1003:1;1000;993:12;955:52;1042:9;1029:23;1061:31;1086:5;1061:31;:::i;1387:388::-;1455:6;1463;1516:2;1504:9;1495:7;1491:23;1487:32;1484:52;;;1532:1;1529;1522:12;1484:52;1571:9;1558:23;1590:31;1615:5;1590:31;:::i;:::-;1640:5;-1:-1:-1;1697:2:1;1682:18;;1669:32;1710:33;1669:32;1710:33;:::i;:::-;1762:7;1752:17;;;1387:388;;;;;:::o;1780:456::-;1857:6;1865;1873;1926:2;1914:9;1905:7;1901:23;1897:32;1894:52;;;1942:1;1939;1932:12;1894:52;1981:9;1968:23;2000:31;2025:5;2000:31;:::i;:::-;2050:5;-1:-1:-1;2107:2:1;2092:18;;2079:32;2120:33;2079:32;2120:33;:::i;:::-;1780:456;;2172:7;;-1:-1:-1;;;2226:2:1;2211:18;;;;2198:32;;1780:456::o;2241:665::-;2336:6;2344;2352;2360;2413:3;2401:9;2392:7;2388:23;2384:33;2381:53;;;2430:1;2427;2420:12;2381:53;2469:9;2456:23;2488:31;2513:5;2488:31;:::i;:::-;2538:5;-1:-1:-1;2595:2:1;2580:18;;2567:32;2608:33;2567:32;2608:33;:::i;:::-;2660:7;-1:-1:-1;2714:2:1;2699:18;;2686:32;;-1:-1:-1;2769:2:1;2754:18;;2741:32;-1:-1:-1;;;;;2785:30:1;;2782:50;;;2828:1;2825;2818:12;2782:50;2851:49;2892:7;2883:6;2872:9;2868:22;2851:49;:::i;:::-;2841:59;;;2241:665;;;;;;;:::o;2911:382::-;2976:6;2984;3037:2;3025:9;3016:7;3012:23;3008:32;3005:52;;;3053:1;3050;3043:12;3005:52;3092:9;3079:23;3111:31;3136:5;3111:31;:::i;:::-;3161:5;-1:-1:-1;3218:2:1;3203:18;;3190:32;3231:30;3190:32;3231:30;:::i;3298:455::-;3375:6;3383;3436:2;3424:9;3415:7;3411:23;3407:32;3404:52;;;3452:1;3449;3442:12;3404:52;3491:9;3478:23;3510:31;3535:5;3510:31;:::i;:::-;3560:5;-1:-1:-1;3616:2:1;3601:18;;3588:32;-1:-1:-1;;;;;3632:30:1;;3629:50;;;3675:1;3672;3665:12;3629:50;3698:49;3739:7;3730:6;3719:9;3715:22;3698:49;:::i;:::-;3688:59;;;3298:455;;;;;:::o;3758:315::-;3826:6;3834;3887:2;3875:9;3866:7;3862:23;3858:32;3855:52;;;3903:1;3900;3893:12;3855:52;3942:9;3929:23;3961:31;3986:5;3961:31;:::i;:::-;4011:5;4063:2;4048:18;;;;4035:32;;-1:-1:-1;;;3758:315:1:o;4078:615::-;4164:6;4172;4225:2;4213:9;4204:7;4200:23;4196:32;4193:52;;;4241:1;4238;4231:12;4193:52;4281:9;4268:23;-1:-1:-1;;;;;4351:2:1;4343:6;4340:14;4337:34;;;4367:1;4364;4357:12;4337:34;4405:6;4394:9;4390:22;4380:32;;4450:7;4443:4;4439:2;4435:13;4431:27;4421:55;;4472:1;4469;4462:12;4421:55;4512:2;4499:16;4538:2;4530:6;4527:14;4524:34;;;4554:1;4551;4544:12;4524:34;4607:7;4602:2;4592:6;4589:1;4585:14;4581:2;4577:23;4573:32;4570:45;4567:65;;;4628:1;4625;4618:12;4567:65;4659:2;4651:11;;;;;4681:6;;-1:-1:-1;4078:615:1;;-1:-1:-1;;;;4078:615:1:o;4698:241::-;4754:6;4807:2;4795:9;4786:7;4782:23;4778:32;4775:52;;;4823:1;4820;4813:12;4775:52;4862:9;4849:23;4881:28;4903:5;4881:28;:::i;4944:245::-;5011:6;5064:2;5052:9;5043:7;5039:23;5035:32;5032:52;;;5080:1;5077;5070:12;5032:52;5112:9;5106:16;5131:28;5153:5;5131:28;:::i;5194:245::-;5252:6;5305:2;5293:9;5284:7;5280:23;5276:32;5273:52;;;5321:1;5318;5311:12;5273:52;5360:9;5347:23;5379:30;5403:5;5379:30;:::i;5444:249::-;5513:6;5566:2;5554:9;5545:7;5541:23;5537:32;5534:52;;;5582:1;5579;5572:12;5534:52;5614:9;5608:16;5633:30;5657:5;5633:30;:::i;6371:450::-;6440:6;6493:2;6481:9;6472:7;6468:23;6464:32;6461:52;;;6509:1;6506;6499:12;6461:52;6549:9;6536:23;-1:-1:-1;;;;;6574:6:1;6571:30;6568:50;;;6614:1;6611;6604:12;6568:50;6637:22;;6690:4;6682:13;;6678:27;-1:-1:-1;6668:55:1;;6719:1;6716;6709:12;6668:55;6742:73;6807:7;6802:2;6789:16;6784:2;6780;6776:11;6742:73;:::i;6826:180::-;6885:6;6938:2;6926:9;6917:7;6913:23;6909:32;6906:52;;;6954:1;6951;6944:12;6906:52;-1:-1:-1;6977:23:1;;6826:180;-1:-1:-1;6826:180:1:o;7011:184::-;7081:6;7134:2;7122:9;7113:7;7109:23;7105:32;7102:52;;;7150:1;7147;7140:12;7102:52;-1:-1:-1;7173:16:1;;7011:184;-1:-1:-1;7011:184:1:o;7200:388::-;7277:6;7285;7338:2;7326:9;7317:7;7313:23;7309:32;7306:52;;;7354:1;7351;7344:12;7306:52;7390:9;7377:23;7367:33;;7451:2;7440:9;7436:18;7423:32;-1:-1:-1;;;;;7470:6:1;7467:30;7464:50;;;7510:1;7507;7500:12;7593:248;7661:6;7669;7722:2;7710:9;7701:7;7697:23;7693:32;7690:52;;;7738:1;7735;7728:12;7690:52;-1:-1:-1;;7761:23:1;;;7831:2;7816:18;;;7803:32;;-1:-1:-1;7593:248:1:o;7846:257::-;7887:3;7925:5;7919:12;7952:6;7947:3;7940:19;7968:63;8024:6;8017:4;8012:3;8008:14;8001:4;7994:5;7990:16;7968:63;:::i;:::-;8085:2;8064:15;-1:-1:-1;;8060:29:1;8051:39;;;;8092:4;8047:50;;7846:257;-1:-1:-1;;7846:257:1:o;8108:274::-;8237:3;8275:6;8269:13;8291:53;8337:6;8332:3;8325:4;8317:6;8313:17;8291:53;:::i;:::-;8360:16;;;;;8108:274;-1:-1:-1;;8108:274:1:o;8387:470::-;8566:3;8604:6;8598:13;8620:53;8666:6;8661:3;8654:4;8646:6;8642:17;8620:53;:::i;:::-;8736:13;;8695:16;;;;8758:57;8736:13;8695:16;8792:4;8780:17;;8758:57;:::i;:::-;8831:20;;8387:470;-1:-1:-1;;;;8387:470:1:o;10349:488::-;-1:-1:-1;;;;;10618:15:1;;;10600:34;;10670:15;;10665:2;10650:18;;10643:43;10717:2;10702:18;;10695:34;;;10765:3;10760:2;10745:18;;10738:31;;;10543:4;;10786:45;;10811:19;;10803:6;10786:45;:::i;:::-;10778:53;10349:488;-1:-1:-1;;;;;;10349:488:1:o;12671:219::-;12820:2;12809:9;12802:21;12783:4;12840:44;12880:2;12869:9;12865:18;12857:6;12840:44;:::i;16675:402::-;16877:2;16859:21;;;16916:2;16896:18;;;16889:30;16955:34;16950:2;16935:18;;16928:62;-1:-1:-1;;;17021:2:1;17006:18;;16999:36;17067:3;17052:19;;16675:402::o;18677:407::-;18879:2;18861:21;;;18918:2;18898:18;;;18891:30;18957:34;18952:2;18937:18;;18930:62;-1:-1:-1;;;19023:2:1;19008:18;;19001:41;19074:3;19059:19;;18677:407::o;20193:356::-;20395:2;20377:21;;;20414:18;;;20407:30;20473:34;20468:2;20453:18;;20446:62;20540:2;20525:18;;20193:356::o;23736:128::-;23776:3;23807:1;23803:6;23800:1;23797:13;23794:39;;;23813:18;;:::i;:::-;-1:-1:-1;23849:9:1;;23736:128::o;23869:120::-;23909:1;23935;23925:35;;23940:18;;:::i;:::-;-1:-1:-1;23974:9:1;;23869:120::o;23994:168::-;24034:7;24100:1;24096;24092:6;24088:14;24085:1;24082:21;24077:1;24070:9;24063:17;24059:45;24056:71;;;24107:18;;:::i;:::-;-1:-1:-1;24147:9:1;;23994:168::o;24167:125::-;24207:4;24235:1;24232;24229:8;24226:34;;;24240:18;;:::i;:::-;-1:-1:-1;24277:9:1;;24167:125::o;24297:258::-;24369:1;24379:113;24393:6;24390:1;24387:13;24379:113;;;24469:11;;;24463:18;24450:11;;;24443:39;24415:2;24408:10;24379:113;;;24510:6;24507:1;24504:13;24501:48;;;-1:-1:-1;;24545:1:1;24527:16;;24520:27;24297:258::o;24560:380::-;24639:1;24635:12;;;;24682;;;24703:61;;24757:4;24749:6;24745:17;24735:27;;24703:61;24810:2;24802:6;24799:14;24779:18;24776:38;24773:161;;;24856:10;24851:3;24847:20;24844:1;24837:31;24891:4;24888:1;24881:15;24919:4;24916:1;24909:15;24773:161;;24560:380;;;:::o;24945:135::-;24984:3;-1:-1:-1;;25005:17:1;;25002:43;;;25025:18;;:::i;:::-;-1:-1:-1;25072:1:1;25061:13;;24945:135::o;25085:112::-;25117:1;25143;25133:35;;25148:18;;:::i;:::-;-1:-1:-1;25182:9:1;;25085:112::o;25202:127::-;25263:10;25258:3;25254:20;25251:1;25244:31;25294:4;25291:1;25284:15;25318:4;25315:1;25308:15;25334:127;25395:10;25390:3;25386:20;25383:1;25376:31;25426:4;25423:1;25416:15;25450:4;25447:1;25440:15;25466:127;25527:10;25522:3;25518:20;25515:1;25508:31;25558:4;25555:1;25548:15;25582:4;25579:1;25572:15;25598:127;25659:10;25654:3;25650:20;25647:1;25640:31;25690:4;25687:1;25680:15;25714:4;25711:1;25704:15;25730:127;25791:10;25786:3;25782:20;25779:1;25772:31;25822:4;25819:1;25812:15;25846:4;25843:1;25836:15;25862:131;-1:-1:-1;;;;;25937:31:1;;25927:42;;25917:70;;25983:1;25980;25973:12;25998:118;26084:5;26077:13;26070:21;26063:5;26060:32;26050:60;;26106:1;26103;26096:12;26121:131;-1:-1:-1;;;;;;26195:32:1;;26185:43;;26175:71;;26242:1;26239;26232:12

Swarm Source

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