ETH Price: $3,392.26 (+1.72%)

Token

Zoozooos (ZOZOS)
 

Overview

Max Total Supply

880 ZOZOS

Holders

235

Market

Volume (24H)

N/A

Min Price (24H)

N/A

Max Price (24H)

N/A
Filtered by Token Holder
ssdd.eth
Balance
3 ZOZOS
0x70144e5b5bbf464cff98d689254dc7c7223e01ab
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:
Zoozooos

Compiler Version
v0.8.17+commit.8df45f5f

Optimization Enabled:
No with 200 runs

Other Settings:
default evmVersion
File 1 of 1 : ZooZooos.sol
// SPDX-License-Identifier: MIT                                                                                        
//         ,----,                          ,----,                                         
//       .'   .`|                        .'   .`|                                         
//    .'   .'   ;                     .'   .'   ;                                         
//  ,---, '    .' ,---.     ,---.   ,---, '    .' ,---.     ,---.     ,---.               
//  |   :     ./ '   ,'\   '   ,'\  |   :     ./ '   ,'\   '   ,'\   '   ,'\   .--.--.    
//  ;   | .'  / /   /   | /   /   | ;   | .'  / /   /   | /   /   | /   /   | /  /    '   
//  `---' /  ; .   ; ,. :.   ; ,. : `---' /  ; .   ; ,. :.   ; ,. :.   ; ,. :|  :  /`./   
//    /  ;  /  '   | |: :'   | |: :   /  ;  /  '   | |: :'   | |: :'   | |: :|  :  ;_     
//   ;  /  /--,'   | .; :'   | .; :  ;  /  /--,'   | .; :'   | .; :'   | .; : \  \    `.  
//  /  /  / .`||   :    ||   :    | /  /  / .`||   :    ||   :    ||   :    |  `----.   \ 
//./__;       : \   \  /  \   \  /./__;       : \   \  /  \   \  /  \   \  /  /  /`--'  / 
//|   :     .'   `----'    `----' |   :     .'   `----'    `----'    `----'  '--'.     /  
//;   |  .'                       ;   |  .'                                    `--'---'   
//`---'                           `---'                                                   
//                                                                                        
//                                                                                                                                                               
// 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/Address.sol


// OpenZeppelin Contracts (last updated v4.5.0) (utils/Address.sol)

pragma solidity ^0.8.1;

/**
 * @dev Collection of functions related to the address type
 */
library Address {
 /**
 * @dev Returns true if `account` is a contract.
 *
 * [IMPORTANT]
 * ====
 * It is unsafe to assume that an address for which this function returns
 * false is an externally-owned account (EOA) and not a contract.
 *
 * Among others, `isContract` will return false for the following
 * types of addresses:
 *
 * - an externally-owned account
 * - a contract in construction
 * - an address where a contract will be created
 * - an address where a contract lived, but was destroyed
 * ====
 *
 * [IMPORTANT]
 * ====
 * You shouldn't rely on `isContract` to protect against flash loan attacks!
 *
 * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets
 * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract
 * constructor.
 * ====
 */
 function isContract(address account) internal view returns (bool) {
 // This method relies on extcodesize/address.code.length, which returns 0
 // for contracts in construction, since the code is only stored at the end
 // of the constructor execution.

 return account.code.length > 0;
 }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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


// OpenZeppelin Contracts (last updated v4.6.0) (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 `IERC721Receiver.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 (last updated v4.6.0) (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`.
 *
 * 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;

 /**
 * @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 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 the account approved for `tokenId` token.
 *
 * Requirements:
 *
 * - `tokenId` must exist.
 */
 function getApproved(uint256 tokenId) external view returns (address operator);

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

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


// Creator: Chiru Labs

pragma solidity ^0.8.7;

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

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

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

 // Compiler will pack this into a single 256bit word.
 struct AddressData {
 // Realistically, 2**64-1 is more than enough.
 uint64 balance;
 // Keeps track of mint count with minimal overhead for tokenomics.
 uint64 numberMinted;
 // Keeps track of burn count with minimal overhead for tokenomics.
 uint64 numberBurned;
 // For miscellaneous variable(s) pertaining to the address
 // (e.g. number of whitelist mint slots used).
 // If there are multiple variables, please pack them into a uint64.
 uint64 aux;
 }

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

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

 // Token name
 string private _name;

 // Token symbol
 string private _symbol;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

 _approve(to, tokenId, owner);
 }

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

 return _tokenApprovals[tokenId];
 }

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

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

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

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

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

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

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

 /**
 * @dev Equivalent to `_safeMint(to, quantity, '')`.
 */
 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 {
 uint256 startTokenId = _currentIndex;
 if (to == address(0)) revert MintToZeroAddress();
 if (quantity == 0) revert MintZeroQuantity();

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

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

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

 uint256 updatedIndex = startTokenId;
 uint256 end = updatedIndex + quantity;

 if (to.isContract()) {
 do {
 emit Transfer(address(0), to, updatedIndex);
 if (!_checkContractOnERC721Received(address(0), to, updatedIndex++, _data)) {
 revert TransferToNonERC721ReceiverImplementer();
 }
 } while (updatedIndex != end);
 // Reentrancy protection
 if (_currentIndex != startTokenId) revert();
 } else {
 do {
 emit Transfer(address(0), to, updatedIndex++);
 } while (updatedIndex != end);
 }
 _currentIndex = updatedIndex;
 }
 _afterTokenTransfers(address(0), to, startTokenId, quantity);
 }

 /**
 * @dev 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) internal {
 uint256 startTokenId = _currentIndex;
 if (to == address(0)) revert MintToZeroAddress();
 if (quantity == 0) revert MintZeroQuantity();

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

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

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

 uint256 updatedIndex = startTokenId;
 uint256 end = updatedIndex + quantity;

 do {
 emit Transfer(address(0), to, updatedIndex++);
 } while (updatedIndex != end);

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

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

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

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

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

 _beforeTokenTransfers(from, to, tokenId, 1);

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

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

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

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

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

 /**
 * @dev Equivalent to `_burn(tokenId, false)`.
 */
 function _burn(uint256 tokenId) internal virtual {
 _burn(tokenId, false);
 }

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

 address from = prevOwnership.addr;

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

 if (!isApprovedOrOwner) revert TransferCallerNotOwnerNorApproved();
 }

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

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

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

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

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

 emit Transfer(from, address(0), tokenId);
 _afterTokenTransfers(from, address(0), tokenId, 1);

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

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

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

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

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


pragma solidity ^0.8.7;


// File @openzeppelin/contracts/interfaces/[email protected]


// OpenZeppelin Contracts (last updated v4.6.0) (interfaces/IERC2981.sol)

pragma solidity ^0.8.0;

/**
 * @dev Interface for the NFT Royalty Standard.
 *
 * A standardized way to retrieve royalty payment information for non-fungible tokens (NFTs) to enable universal
 * support for royalty payments across all NFT marketplaces and ecosystem participants.
 *
 * _Available since v4.5._
 */
interface IERC2981 is IERC165 {
 /**
 * @dev Returns how much royalty is owed and to whom, based on a sale price that may be denominated in any unit of
 * exchange. The royalty amount is denominated and should be paid in that same unit of exchange.
 */
 function royaltyInfo(uint256 tokenId, uint256 salePrice)
 external
 view
 returns (address receiver, uint256 royaltyAmount);
}


// File @openzeppelin/contracts/token/common/[email protected]


// OpenZeppelin Contracts (last updated v4.7.0) (token/common/ERC2981.sol)

pragma solidity ^0.8.0;


/**
 * @dev Implementation of the NFT Royalty Standard, a standardized way to retrieve royalty payment information.
 *
 * Royalty information can be specified globally for all token ids via {_setDefaultRoyalty}, and/or individually for
 * specific token ids via {_setTokenRoyalty}. The latter takes precedence over the first.
 *
 * Royalty is specified as a fraction of sale price. {_feeDenominator} is overridable but defaults to 10000, meaning the
 * fee is specified in basis points by default.
 *
 * IMPORTANT: ERC-2981 only specifies a way to signal royalty information and does not enforce its payment. See
 * https://eips.ethereum.org/EIPS/eip-2981#optional-royalty-payments[Rationale] in the EIP. Marketplaces are expected to
 * voluntarily pay royalties together with sales, but note that this standard is not yet widely supported.
 *
 * _Available since v4.5._
 */
abstract contract ERC2981 is IERC2981, ERC165 {
 struct RoyaltyInfo {
 address receiver;
 uint96 royaltyFraction;
 }

 RoyaltyInfo private _defaultRoyaltyInfo;
 mapping(uint256 => RoyaltyInfo) private _tokenRoyaltyInfo;

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

 /**
 * @inheritdoc IERC2981
 */
 function royaltyInfo(uint256 _tokenId, uint256 _salePrice) public view virtual override returns (address, uint256) {
 RoyaltyInfo memory royalty = _tokenRoyaltyInfo[_tokenId];

 if (royalty.receiver == address(0)) {
 royalty = _defaultRoyaltyInfo;
 }

 uint256 royaltyAmount = (_salePrice * royalty.royaltyFraction) / _feeDenominator();

 return (royalty.receiver, royaltyAmount);
 }

 /**
 * @dev The denominator with which to interpret the fee set in {_setTokenRoyalty} and {_setDefaultRoyalty} as a
 * fraction of the sale price. Defaults to 10000 so fees are expressed in basis points, but may be customized by an
 * override.
 */
 function _feeDenominator() internal pure virtual returns (uint96) {
 return 10000;
 }

 /**
 * @dev Sets the royalty information that all ids in this contract will default to.
 *
 * Requirements:
 *
 * - `receiver` cannot be the zero address.
 * - `feeNumerator` cannot be greater than the fee denominator.
 */
 function _setDefaultRoyalty(address receiver, uint96 feeNumerator) internal virtual {
 require(feeNumerator <= _feeDenominator(), "ERC2981: royalty fee will exceed salePrice");
 require(receiver != address(0), "ERC2981: invalid receiver");

 _defaultRoyaltyInfo = RoyaltyInfo(receiver, feeNumerator);
 }

 /**
 * @dev Removes default royalty information.
 */
 function _deleteDefaultRoyalty() internal virtual {
 delete _defaultRoyaltyInfo;
 }

 /**
 * @dev Sets the royalty information for a specific token id, overriding the global default.
 *
 * Requirements:
 *
 * - `receiver` cannot be the zero address.
 * - `feeNumerator` cannot be greater than the fee denominator.
 */
 function _setTokenRoyalty(
 uint256 tokenId,
 address receiver,
 uint96 feeNumerator
 ) internal virtual {
 require(feeNumerator <= _feeDenominator(), "ERC2981: royalty fee will exceed salePrice");
 require(receiver != address(0), "ERC2981: Invalid parameters");

 _tokenRoyaltyInfo[tokenId] = RoyaltyInfo(receiver, feeNumerator);
 }

 /**
 * @dev Resets royalty information for the token id back to the global default.
 */
 function _resetTokenRoyalty(uint256 tokenId) internal virtual {
 delete _tokenRoyaltyInfo[tokenId];
 }
}


contract Zoozooos is ERC721A, ERC2981, Ownable {

 string public baseURI = "ipfs://QmcU73y4THg1yuLRFponPMUQkkXPDRAzCky5WGqi1A6KCy/";
 uint256 public constant MAX_SUPPLY = 4444;
 uint256 public MINT_PRICE = 0.004 ether;
 uint256 public MAX_PER_TX = 5;
 uint256 public MAX_PER_TX_FREE = 1;
 uint96 public _rAm = 500;
 bool public isPublicSale = false;
 mapping(address => uint256) public _mintedFreeAmount;
 mapping(address => uint256) public _totalMintedAmount;
 uint public totalFreeMinted = 0;

 constructor() ERC721A("Zoozooos", "ZOZOS") {
 _setDefaultRoyalty(0x640280c039C5b993F902147360C784eA1E5f826C, _rAm);
 }

 function tokenURI(uint256 _tokenId) public view override returns (string memory) {
 require(_exists(_tokenId), "Token does not exist.");
 return string(abi.encodePacked(baseURI, Strings.toString(_tokenId), ".json"));
 }

 function setBaseURI(string memory _baseURI) external onlyOwner {
 baseURI = _baseURI;
 }

 function setFreeSupply(uint256 _freeSupply) public onlyOwner {
 MAX_PER_TX_FREE = _freeSupply;
 }

 function setMintPrice(uint256 _price) external onlyOwner {
 MINT_PRICE = _price;
 }

 function _startTokenId() internal view virtual override returns (uint256) {
 return 1;
 }

 function togglePublicSale(bool _isPublicSale) external onlyOwner {
 isPublicSale = _isPublicSale;
 }

 function setRoyaltyInfo(address receiver, uint96 feeBasisPoints)
 external
 onlyOwner
 {
 _setDefaultRoyalty(receiver, feeBasisPoints);
 }

 function supportsInterface(bytes4 interfaceId)
 public
 view
 override(ERC721A, ERC2981)
 returns (bool)
 {
 return super.supportsInterface(interfaceId);
 }

 function mint(uint256 count) external payable {
 require(isPublicSale, "Mint is not live yet");
 require(totalSupply() + count <= MAX_SUPPLY, "No more");
 require(count <= MAX_PER_TX, "Max per txn reached.");
 if(count >= (MAX_PER_TX_FREE - _mintedFreeAmount[msg.sender]))
 {
 require(msg.value >= (count * MINT_PRICE) - ((MAX_PER_TX_FREE - _mintedFreeAmount[msg.sender]) * MINT_PRICE), "You've already minted max free allocation or incorrect ETH sent");
 _mintedFreeAmount[msg.sender] = MAX_PER_TX_FREE;
 totalFreeMinted += MAX_PER_TX_FREE;
 }
 else if(count < (MAX_PER_TX_FREE - _mintedFreeAmount[msg.sender]))
 {
 require(msg.value >= 0, "Please send the exact ETH amount");
 _mintedFreeAmount[msg.sender] += count;
 totalFreeMinted += count;
 }
 // }
 else{
 require(isPublicSale, "Mint is not live yet");
 require(msg.value >= count * MINT_PRICE, "Please send the exact ETH amount");
 require(totalSupply() + count <= MAX_SUPPLY, "No more");
 require(count <= MAX_PER_TX, "Max per txn reached.");
 }
 _totalMintedAmount[msg.sender] += count;
 _safeMint(msg.sender, count);
 }

 function devMint(uint256 count) external onlyOwner {
 _safeMint(_msgSender(), count);
 }

 function withdrawMoney() external onlyOwner {
 (bool success, ) = _msgSender().call{value: address(this).balance}("");
 require(success, "Transfer failed.");
 }
}

Settings
{
  "optimizer": {
    "enabled": false,
    "runs": 200
  },
  "outputSelection": {
    "*": {
      "*": [
        "evm.bytecode",
        "evm.deployedBytecode",
        "devdoc",
        "userdoc",
        "metadata",
        "abi"
      ]
    }
  },
  "libraries": {}
}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[],"name":"ApprovalCallerNotOwnerNorApproved","type":"error"},{"inputs":[],"name":"ApprovalQueryForNonexistentToken","type":"error"},{"inputs":[],"name":"ApprovalToCurrentOwner","type":"error"},{"inputs":[],"name":"ApproveToCaller","type":"error"},{"inputs":[],"name":"BalanceQueryForZeroAddress","type":"error"},{"inputs":[],"name":"MintToZeroAddress","type":"error"},{"inputs":[],"name":"MintZeroQuantity","type":"error"},{"inputs":[],"name":"OwnerQueryForNonexistentToken","type":"error"},{"inputs":[],"name":"TransferCallerNotOwnerNorApproved","type":"error"},{"inputs":[],"name":"TransferFromIncorrectOwner","type":"error"},{"inputs":[],"name":"TransferToNonERC721ReceiverImplementer","type":"error"},{"inputs":[],"name":"TransferToZeroAddress","type":"error"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"approved","type":"address"},{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"operator","type":"address"},{"indexed":false,"internalType":"bool","name":"approved","type":"bool"}],"name":"ApprovalForAll","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"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":"MAX_PER_TX","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MAX_PER_TX_FREE","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MAX_SUPPLY","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MINT_PRICE","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"_mintedFreeAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_rAm","outputs":[{"internalType":"uint96","name":"","type":"uint96"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"_totalMintedAmount","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":"baseURI","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"count","type":"uint256"}],"name":"devMint","outputs":[],"stateMutability":"nonpayable","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":"owner","type":"address"},{"internalType":"address","name":"operator","type":"address"}],"name":"isApprovedForAll","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"isPublicSale","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"count","type":"uint256"}],"name":"mint","outputs":[],"stateMutability":"payable","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":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_tokenId","type":"uint256"},{"internalType":"uint256","name":"_salePrice","type":"uint256"}],"name":"royaltyInfo","outputs":[{"internalType":"address","name":"","type":"address"},{"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":"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":"_baseURI","type":"string"}],"name":"setBaseURI","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_freeSupply","type":"uint256"}],"name":"setFreeSupply","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_price","type":"uint256"}],"name":"setMintPrice","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"receiver","type":"address"},{"internalType":"uint96","name":"feeBasisPoints","type":"uint96"}],"name":"setRoyaltyInfo","outputs":[],"stateMutability":"nonpayable","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":"bool","name":"_isPublicSale","type":"bool"}],"name":"togglePublicSale","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_tokenId","type":"uint256"}],"name":"tokenURI","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalFreeMinted","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":"withdrawMoney","outputs":[],"stateMutability":"nonpayable","type":"function"}]

608060405260405180606001604052806036815260200162004e1b60369139600b90816200002e9190620006b1565b50660e35fa931a0000600c556005600d556001600e556101f4600f60006101000a8154816bffffffffffffffffffffffff02191690836bffffffffffffffffffffffff1602179055506000600f600c6101000a81548160ff0219169083151502179055506000601255348015620000a457600080fd5b506040518060400160405280600881526020017f5a6f6f7a6f6f6f730000000000000000000000000000000000000000000000008152506040518060400160405280600581526020017f5a4f5a4f530000000000000000000000000000000000000000000000000000008152508160029081620001229190620006b1565b508060039081620001349190620006b1565b5062000145620001b360201b60201c565b60008190555050506200016d62000161620001bc60201b60201c565b620001c460201b60201c565b620001ad73640280c039c5b993f902147360c784ea1e5f826c600f60009054906101000a90046bffffffffffffffffffffffff166200028a60201b60201c565b620008b3565b60006001905090565b600033905090565b6000600a60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905081600a60006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b6200029a6200042d60201b60201c565b6bffffffffffffffffffffffff16816bffffffffffffffffffffffff161115620002fb576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401620002f2906200081f565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036200036d576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401620003649062000891565b60405180910390fd5b60405180604001604052808373ffffffffffffffffffffffffffffffffffffffff168152602001826bffffffffffffffffffffffff16815250600860008201518160000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555060208201518160000160146101000a8154816bffffffffffffffffffffffff02191690836bffffffffffffffffffffffff1602179055509050505050565b6000612710905090565b600081519050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b60006002820490506001821680620004b957607f821691505b602082108103620004cf57620004ce62000471565b5b50919050565b60008190508160005260206000209050919050565b60006020601f8301049050919050565b600082821b905092915050565b600060088302620005397fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff82620004fa565b620005458683620004fa565b95508019841693508086168417925050509392505050565b6000819050919050565b6000819050919050565b6000620005926200058c62000586846200055d565b62000567565b6200055d565b9050919050565b6000819050919050565b620005ae8362000571565b620005c6620005bd8262000599565b84845462000507565b825550505050565b600090565b620005dd620005ce565b620005ea818484620005a3565b505050565b5b81811015620006125762000606600082620005d3565b600181019050620005f0565b5050565b601f82111562000661576200062b81620004d5565b6200063684620004ea565b8101602085101562000646578190505b6200065e6200065585620004ea565b830182620005ef565b50505b505050565b600082821c905092915050565b6000620006866000198460080262000666565b1980831691505092915050565b6000620006a1838362000673565b9150826002028217905092915050565b620006bc8262000437565b67ffffffffffffffff811115620006d857620006d762000442565b5b620006e48254620004a0565b620006f182828562000616565b600060209050601f83116001811462000729576000841562000714578287015190505b62000720858262000693565b86555062000790565b601f1984166200073986620004d5565b60005b8281101562000763578489015182556001820191506020850194506020810190506200073c565b868310156200078357848901516200077f601f89168262000673565b8355505b6001600288020188555050505b505050505050565b600082825260208201905092915050565b7f455243323938313a20726f79616c7479206665652077696c6c2065786365656460008201527f2073616c65507269636500000000000000000000000000000000000000000000602082015250565b600062000807602a8362000798565b91506200081482620007a9565b604082019050919050565b600060208201905081810360008301526200083a81620007f8565b9050919050565b7f455243323938313a20696e76616c696420726563656976657200000000000000600082015250565b60006200087960198362000798565b9150620008868262000841565b602082019050919050565b60006020820190508181036000830152620008ac816200086a565b9050919050565b61455880620008c36000396000f3fe60806040526004361061020f5760003560e01c8063715018a611610118578063c002d23d116100a0578063f2fde38b1161006f578063f2fde38b14610791578063f43a22dc146107ba578063f4a0a528146107e5578063f4db2acb1461080e578063f676308a1461084b5761020f565b8063c002d23d146106c1578063c87b56dd146106ec578063dad7b5c914610729578063e985e9c5146107545761020f565b8063a0712d68116100e7578063a0712d6814610611578063a22cb4651461062d578063a5a865dc14610656578063ac44600214610681578063b88d4fde146106985761020f565b8063715018a61461057b5780638c3cefa3146105925780638da5cb5b146105bb57806395d89b41146105e65761020f565b806332cb6b0c1161019b57806355f804b31161016a57806355f804b31461048257806358c87f72146104ab5780636352211e146104d65780636c0360eb1461051357806370a082311461053e5761020f565b806332cb6b0c146103da578063375a069a1461040557806342842e0e1461042e578063463fff79146104575761020f565b8063095ea7b3116101e2578063095ea7b3146102e257806311b01a321461030b57806318160ddd1461034857806323b872dd146103735780632a55205a1461039c5761020f565b806301ffc9a71461021457806302fa7c471461025157806306fdde031461027a578063081812fc146102a5575b600080fd5b34801561022057600080fd5b5061023b6004803603810190610236919061316e565b610874565b60405161024891906131b6565b60405180910390f35b34801561025d57600080fd5b5061027860048036038101906102739190613273565b610886565b005b34801561028657600080fd5b5061028f610910565b60405161029c9190613343565b60405180910390f35b3480156102b157600080fd5b506102cc60048036038101906102c7919061339b565b6109a2565b6040516102d991906133d7565b60405180910390f35b3480156102ee57600080fd5b50610309600480360381019061030491906133f2565b610a1e565b005b34801561031757600080fd5b50610332600480360381019061032d9190613432565b610b28565b60405161033f919061346e565b60405180910390f35b34801561035457600080fd5b5061035d610b40565b60405161036a919061346e565b60405180910390f35b34801561037f57600080fd5b5061039a60048036038101906103959190613489565b610b57565b005b3480156103a857600080fd5b506103c360048036038101906103be91906134dc565b610b67565b6040516103d192919061351c565b60405180910390f35b3480156103e657600080fd5b506103ef610d51565b6040516103fc919061346e565b60405180910390f35b34801561041157600080fd5b5061042c6004803603810190610427919061339b565b610d57565b005b34801561043a57600080fd5b5061045560048036038101906104509190613489565b610de7565b005b34801561046357600080fd5b5061046c610e07565b604051610479919061346e565b60405180910390f35b34801561048e57600080fd5b506104a960048036038101906104a4919061367a565b610e0d565b005b3480156104b757600080fd5b506104c0610e9c565b6040516104cd91906136d2565b60405180910390f35b3480156104e257600080fd5b506104fd60048036038101906104f8919061339b565b610eba565b60405161050a91906133d7565b60405180910390f35b34801561051f57600080fd5b50610528610ed0565b6040516105359190613343565b60405180910390f35b34801561054a57600080fd5b5061056560048036038101906105609190613432565b610f5e565b604051610572919061346e565b60405180910390f35b34801561058757600080fd5b5061059061102d565b005b34801561059e57600080fd5b506105b960048036038101906105b49190613719565b6110b5565b005b3480156105c757600080fd5b506105d061114e565b6040516105dd91906133d7565b60405180910390f35b3480156105f257600080fd5b506105fb611178565b6040516106089190613343565b60405180910390f35b61062b6004803603810190610626919061339b565b61120a565b005b34801561063957600080fd5b50610654600480360381019061064f9190613746565b61170e565b005b34801561066257600080fd5b5061066b611885565b60405161067891906131b6565b60405180910390f35b34801561068d57600080fd5b50610696611898565b005b3480156106a457600080fd5b506106bf60048036038101906106ba9190613827565b6119ca565b005b3480156106cd57600080fd5b506106d6611a46565b6040516106e3919061346e565b60405180910390f35b3480156106f857600080fd5b50610713600480360381019061070e919061339b565b611a4c565b6040516107209190613343565b60405180910390f35b34801561073557600080fd5b5061073e611ac8565b60405161074b919061346e565b60405180910390f35b34801561076057600080fd5b5061077b600480360381019061077691906138aa565b611ace565b60405161078891906131b6565b60405180910390f35b34801561079d57600080fd5b506107b860048036038101906107b39190613432565b611b62565b005b3480156107c657600080fd5b506107cf611c59565b6040516107dc919061346e565b60405180910390f35b3480156107f157600080fd5b5061080c6004803603810190610807919061339b565b611c5f565b005b34801561081a57600080fd5b5061083560048036038101906108309190613432565b611ce5565b604051610842919061346e565b60405180910390f35b34801561085757600080fd5b50610872600480360381019061086d919061339b565b611cfd565b005b600061087f82611d83565b9050919050565b61088e611dfd565b73ffffffffffffffffffffffffffffffffffffffff166108ac61114e565b73ffffffffffffffffffffffffffffffffffffffff1614610902576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016108f990613936565b60405180910390fd5b61090c8282611e05565b5050565b60606002805461091f90613985565b80601f016020809104026020016040519081016040528092919081815260200182805461094b90613985565b80156109985780601f1061096d57610100808354040283529160200191610998565b820191906000526020600020905b81548152906001019060200180831161097b57829003601f168201915b5050505050905090565b60006109ad82611f9a565b6109e3576040517fcf4700e400000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6006600083815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050919050565b6000610a2982610eba565b90508073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603610a90576040517f943f7b8c00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b8073ffffffffffffffffffffffffffffffffffffffff16610aaf611dfd565b73ffffffffffffffffffffffffffffffffffffffff1614158015610ae15750610adf81610ada611dfd565b611ace565b155b15610b18576040517fcfb3b94200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b610b23838383611fe8565b505050565b60116020528060005260406000206000915090505481565b6000610b4a61209a565b6001546000540303905090565b610b628383836120a3565b505050565b6000806000600960008681526020019081526020016000206040518060400160405290816000820160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020016000820160149054906101000a90046bffffffffffffffffffffffff166bffffffffffffffffffffffff166bffffffffffffffffffffffff16815250509050600073ffffffffffffffffffffffffffffffffffffffff16816000015173ffffffffffffffffffffffffffffffffffffffff1603610cfc5760086040518060400160405290816000820160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020016000820160149054906101000a90046bffffffffffffffffffffffff166bffffffffffffffffffffffff166bffffffffffffffffffffffff168152505090505b6000610d06612557565b6bffffffffffffffffffffffff1682602001516bffffffffffffffffffffffff1686610d3291906139e5565b610d3c9190613a56565b90508160000151819350935050509250929050565b61115c81565b610d5f611dfd565b73ffffffffffffffffffffffffffffffffffffffff16610d7d61114e565b73ffffffffffffffffffffffffffffffffffffffff1614610dd3576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610dca90613936565b60405180910390fd5b610de4610dde611dfd565b82612561565b50565b610e02838383604051806020016040528060008152506119ca565b505050565b600e5481565b610e15611dfd565b73ffffffffffffffffffffffffffffffffffffffff16610e3361114e565b73ffffffffffffffffffffffffffffffffffffffff1614610e89576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610e8090613936565b60405180910390fd5b80600b9081610e989190613c33565b5050565b600f60009054906101000a90046bffffffffffffffffffffffff1681565b6000610ec58261257f565b600001519050919050565b600b8054610edd90613985565b80601f0160208091040260200160405190810160405280929190818152602001828054610f0990613985565b8015610f565780601f10610f2b57610100808354040283529160200191610f56565b820191906000526020600020905b815481529060010190602001808311610f3957829003601f168201915b505050505081565b60008073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603610fc5576040517f8f4eb60400000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b600560008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160009054906101000a900467ffffffffffffffff1667ffffffffffffffff169050919050565b611035611dfd565b73ffffffffffffffffffffffffffffffffffffffff1661105361114e565b73ffffffffffffffffffffffffffffffffffffffff16146110a9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016110a090613936565b60405180910390fd5b6110b3600061280e565b565b6110bd611dfd565b73ffffffffffffffffffffffffffffffffffffffff166110db61114e565b73ffffffffffffffffffffffffffffffffffffffff1614611131576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161112890613936565b60405180910390fd5b80600f600c6101000a81548160ff02191690831515021790555050565b6000600a60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60606003805461118790613985565b80601f01602080910402602001604051908101604052809291908181526020018280546111b390613985565b80156112005780601f106111d557610100808354040283529160200191611200565b820191906000526020600020905b8154815290600101906020018083116111e357829003601f168201915b5050505050905090565b600f600c9054906101000a900460ff16611259576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161125090613d51565b60405180910390fd5b61115c81611265610b40565b61126f9190613d71565b11156112b0576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016112a790613df1565b60405180910390fd5b600d548111156112f5576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016112ec90613e5d565b60405180910390fd5b601060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054600e546113429190613e7d565b811061146257600c54601060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054600e546113989190613e7d565b6113a291906139e5565b600c54826113b091906139e5565b6113ba9190613e7d565b3410156113fc576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016113f390613f23565b60405180910390fd5b600e54601060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550600e54601260008282546114569190613d71565b925050819055506116ab565b601060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054600e546114af9190613e7d565b81101561156e5760003410156114fa576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016114f190613f8f565b60405180910390fd5b80601060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008282546115499190613d71565b9250508190555080601260008282546115629190613d71565b925050819055506116aa565b600f600c9054906101000a900460ff166115bd576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016115b490613d51565b60405180910390fd5b600c54816115cb91906139e5565b34101561160d576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161160490613f8f565b60405180910390fd5b61115c81611619610b40565b6116239190613d71565b1115611664576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161165b90613df1565b60405180910390fd5b600d548111156116a9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116a090613e5d565b60405180910390fd5b5b5b80601160003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008282546116fa9190613d71565b9250508190555061170b3382612561565b50565b611716611dfd565b73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff160361177a576040517fb06307db00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b8060076000611787611dfd565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055508173ffffffffffffffffffffffffffffffffffffffff16611834611dfd565b73ffffffffffffffffffffffffffffffffffffffff167f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c318360405161187991906131b6565b60405180910390a35050565b600f600c9054906101000a900460ff1681565b6118a0611dfd565b73ffffffffffffffffffffffffffffffffffffffff166118be61114e565b73ffffffffffffffffffffffffffffffffffffffff1614611914576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161190b90613936565b60405180910390fd5b600061191e611dfd565b73ffffffffffffffffffffffffffffffffffffffff164760405161194190613fe0565b60006040518083038185875af1925050503d806000811461197e576040519150601f19603f3d011682016040523d82523d6000602084013e611983565b606091505b50509050806119c7576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016119be90614041565b60405180910390fd5b50565b6119d58484846120a3565b6119f48373ffffffffffffffffffffffffffffffffffffffff166128d4565b8015611a095750611a07848484846128f7565b155b15611a40576040517fd1a57ed600000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b50505050565b600c5481565b6060611a5782611f9a565b611a96576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611a8d906140ad565b60405180910390fd5b600b611aa183612a47565b604051602001611ab29291906141d8565b6040516020818303038152906040529050919050565b60125481565b6000600760008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16905092915050565b611b6a611dfd565b73ffffffffffffffffffffffffffffffffffffffff16611b8861114e565b73ffffffffffffffffffffffffffffffffffffffff1614611bde576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611bd590613936565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1603611c4d576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611c4490614279565b60405180910390fd5b611c568161280e565b50565b600d5481565b611c67611dfd565b73ffffffffffffffffffffffffffffffffffffffff16611c8561114e565b73ffffffffffffffffffffffffffffffffffffffff1614611cdb576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611cd290613936565b60405180910390fd5b80600c8190555050565b60106020528060005260406000206000915090505481565b611d05611dfd565b73ffffffffffffffffffffffffffffffffffffffff16611d2361114e565b73ffffffffffffffffffffffffffffffffffffffff1614611d79576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611d7090613936565b60405180910390fd5b80600e8190555050565b60007f2a55205a000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19161480611df65750611df582612ba7565b5b9050919050565b600033905090565b611e0d612557565b6bffffffffffffffffffffffff16816bffffffffffffffffffffffff161115611e6b576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611e629061430b565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603611eda576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611ed190614377565b60405180910390fd5b60405180604001604052808373ffffffffffffffffffffffffffffffffffffffff168152602001826bffffffffffffffffffffffff16815250600860008201518160000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555060208201518160000160146101000a8154816bffffffffffffffffffffffff02191690836bffffffffffffffffffffffff1602179055509050505050565b600081611fa561209a565b11158015611fb4575060005482105b8015611fe1575060046000838152602001908152602001600020600001601c9054906101000a900460ff16155b9050919050565b826006600084815260200190815260200160002060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550818373ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a4505050565b60006001905090565b60006120ae8261257f565b90508373ffffffffffffffffffffffffffffffffffffffff16816000015173ffffffffffffffffffffffffffffffffffffffff1614612119576040517fa114810000000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60008473ffffffffffffffffffffffffffffffffffffffff1661213a611dfd565b73ffffffffffffffffffffffffffffffffffffffff161480612169575061216885612163611dfd565b611ace565b5b806121ae5750612177611dfd565b73ffffffffffffffffffffffffffffffffffffffff16612196846109a2565b73ffffffffffffffffffffffffffffffffffffffff16145b9050806121e7576040517f59c896be00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff160361224d576040517fea553b3400000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b61225a8585856001612c89565b61226660008487611fe8565b6001600560008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160008282829054906101000a900467ffffffffffffffff160392506101000a81548167ffffffffffffffff021916908367ffffffffffffffff1602179055506001600560008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160008282829054906101000a900467ffffffffffffffff160192506101000a81548167ffffffffffffffff021916908367ffffffffffffffff1602179055506000600460008581526020019081526020016000209050848160000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550428160000160146101000a81548167ffffffffffffffff021916908367ffffffffffffffff16021790555060006001850190506000600460008381526020019081526020016000209050600073ffffffffffffffffffffffffffffffffffffffff168160000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16036124e55760005482146124e457878160000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555084602001518160000160146101000a81548167ffffffffffffffff021916908367ffffffffffffffff1602179055505b5b505050828473ffffffffffffffffffffffffffffffffffffffff168673ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a46125508585856001612c8f565b5050505050565b6000612710905090565b61257b828260405180602001604052806000815250612c95565b5050565b6125876130bf565b60008290508061259561209a565b111580156125a4575060005481105b156127d7576000600460008381526020019081526020016000206040518060600160405290816000820160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020016000820160149054906101000a900467ffffffffffffffff1667ffffffffffffffff1667ffffffffffffffff16815260200160008201601c9054906101000a900460ff161515151581525050905080604001516127d557600073ffffffffffffffffffffffffffffffffffffffff16816000015173ffffffffffffffffffffffffffffffffffffffff16146126b9578092505050612809565b5b6001156127d457818060019003925050600460008381526020019081526020016000206040518060600160405290816000820160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020016000820160149054906101000a900467ffffffffffffffff1667ffffffffffffffff1667ffffffffffffffff16815260200160008201601c9054906101000a900460ff1615151515815250509050600073ffffffffffffffffffffffffffffffffffffffff16816000015173ffffffffffffffffffffffffffffffffffffffff16146127cf578092505050612809565b6126ba565b5b505b6040517fdf2d9b4200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b919050565b6000600a60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905081600a60006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b6000808273ffffffffffffffffffffffffffffffffffffffff163b119050919050565b60008373ffffffffffffffffffffffffffffffffffffffff1663150b7a0261291d611dfd565b8786866040518563ffffffff1660e01b815260040161293f94939291906143ec565b6020604051808303816000875af192505050801561297b57506040513d601f19601f82011682018060405250810190612978919061444d565b60015b6129f4573d80600081146129ab576040519150601f19603f3d011682016040523d82523d6000602084013e6129b0565b606091505b5060008151036129ec576040517fd1a57ed600000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b805181602001fd5b63150b7a0260e01b7bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916817bffffffffffffffffffffffffffffffffffffffffffffffffffffffff191614915050949350505050565b606060008203612a8e576040518060400160405280600181526020017f30000000000000000000000000000000000000000000000000000000000000008152509050612ba2565b600082905060005b60008214612ac0578080612aa99061447a565b915050600a82612ab99190613a56565b9150612a96565b60008167ffffffffffffffff811115612adc57612adb61354f565b5b6040519080825280601f01601f191660200182016040528015612b0e5781602001600182028036833780820191505090505b5090505b60008514612b9b57600182612b279190613e7d565b9150600a85612b3691906144c2565b6030612b429190613d71565b60f81b818381518110612b5857612b576144f3565b5b60200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a905350600a85612b949190613a56565b9450612b12565b8093505050505b919050565b60007f80ac58cd000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19161480612c7257507f5b5e139f000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916145b80612c825750612c8182613055565b5b9050919050565b50505050565b50505050565b600080549050600073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1603612d01576040517f2e07630000000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60008303612d3b576040517fb562e8dd00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b612d486000858386612c89565b82600560008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160008282829054906101000a900467ffffffffffffffff160192506101000a81548167ffffffffffffffff021916908367ffffffffffffffff16021790555082600560008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160088282829054906101000a900467ffffffffffffffff160192506101000a81548167ffffffffffffffff021916908367ffffffffffffffff160217905550836004600083815260200190815260200160002060000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550426004600083815260200190815260200160002060000160146101000a81548167ffffffffffffffff021916908367ffffffffffffffff160217905550600081905060008482019050612f098673ffffffffffffffffffffffffffffffffffffffff166128d4565b15612fce575b818673ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a4612f7e60008784806001019550876128f7565b612fb4576040517fd1a57ed600000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b808203612f0f578260005414612fc957600080fd5b613039565b5b818060010192508673ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a4808203612fcf575b81600081905550505061304f6000858386612c8f565b50505050565b60007f01ffc9a7000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916149050919050565b6040518060600160405280600073ffffffffffffffffffffffffffffffffffffffff168152602001600067ffffffffffffffff1681526020016000151581525090565b6000604051905090565b600080fd5b600080fd5b60007fffffffff0000000000000000000000000000000000000000000000000000000082169050919050565b61314b81613116565b811461315657600080fd5b50565b60008135905061316881613142565b92915050565b6000602082840312156131845761318361310c565b5b600061319284828501613159565b91505092915050565b60008115159050919050565b6131b08161319b565b82525050565b60006020820190506131cb60008301846131a7565b92915050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b60006131fc826131d1565b9050919050565b61320c816131f1565b811461321757600080fd5b50565b60008135905061322981613203565b92915050565b60006bffffffffffffffffffffffff82169050919050565b6132508161322f565b811461325b57600080fd5b50565b60008135905061326d81613247565b92915050565b6000806040838503121561328a5761328961310c565b5b60006132988582860161321a565b92505060206132a98582860161325e565b9150509250929050565b600081519050919050565b600082825260208201905092915050565b60005b838110156132ed5780820151818401526020810190506132d2565b60008484015250505050565b6000601f19601f8301169050919050565b6000613315826132b3565b61331f81856132be565b935061332f8185602086016132cf565b613338816132f9565b840191505092915050565b6000602082019050818103600083015261335d818461330a565b905092915050565b6000819050919050565b61337881613365565b811461338357600080fd5b50565b6000813590506133958161336f565b92915050565b6000602082840312156133b1576133b061310c565b5b60006133bf84828501613386565b91505092915050565b6133d1816131f1565b82525050565b60006020820190506133ec60008301846133c8565b92915050565b600080604083850312156134095761340861310c565b5b60006134178582860161321a565b925050602061342885828601613386565b9150509250929050565b6000602082840312156134485761344761310c565b5b60006134568482850161321a565b91505092915050565b61346881613365565b82525050565b6000602082019050613483600083018461345f565b92915050565b6000806000606084860312156134a2576134a161310c565b5b60006134b08682870161321a565b93505060206134c18682870161321a565b92505060406134d286828701613386565b9150509250925092565b600080604083850312156134f3576134f261310c565b5b600061350185828601613386565b925050602061351285828601613386565b9150509250929050565b600060408201905061353160008301856133c8565b61353e602083018461345f565b9392505050565b600080fd5b600080fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b613587826132f9565b810181811067ffffffffffffffff821117156135a6576135a561354f565b5b80604052505050565b60006135b9613102565b90506135c5828261357e565b919050565b600067ffffffffffffffff8211156135e5576135e461354f565b5b6135ee826132f9565b9050602081019050919050565b82818337600083830152505050565b600061361d613618846135ca565b6135af565b9050828152602081018484840111156136395761363861354a565b5b6136448482856135fb565b509392505050565b600082601f83011261366157613660613545565b5b813561367184826020860161360a565b91505092915050565b6000602082840312156136905761368f61310c565b5b600082013567ffffffffffffffff8111156136ae576136ad613111565b5b6136ba8482850161364c565b91505092915050565b6136cc8161322f565b82525050565b60006020820190506136e760008301846136c3565b92915050565b6136f68161319b565b811461370157600080fd5b50565b600081359050613713816136ed565b92915050565b60006020828403121561372f5761372e61310c565b5b600061373d84828501613704565b91505092915050565b6000806040838503121561375d5761375c61310c565b5b600061376b8582860161321a565b925050602061377c85828601613704565b9150509250929050565b600067ffffffffffffffff8211156137a1576137a061354f565b5b6137aa826132f9565b9050602081019050919050565b60006137ca6137c584613786565b6135af565b9050828152602081018484840111156137e6576137e561354a565b5b6137f18482856135fb565b509392505050565b600082601f83011261380e5761380d613545565b5b813561381e8482602086016137b7565b91505092915050565b600080600080608085870312156138415761384061310c565b5b600061384f8782880161321a565b94505060206138608782880161321a565b935050604061387187828801613386565b925050606085013567ffffffffffffffff81111561389257613891613111565b5b61389e878288016137f9565b91505092959194509250565b600080604083850312156138c1576138c061310c565b5b60006138cf8582860161321a565b92505060206138e08582860161321a565b9150509250929050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572600082015250565b60006139206020836132be565b915061392b826138ea565b602082019050919050565b6000602082019050818103600083015261394f81613913565b9050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b6000600282049050600182168061399d57607f821691505b6020821081036139b0576139af613956565b5b50919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b60006139f082613365565b91506139fb83613365565b9250828202613a0981613365565b91508282048414831517613a2057613a1f6139b6565b5b5092915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b6000613a6182613365565b9150613a6c83613365565b925082613a7c57613a7b613a27565b5b828204905092915050565b60008190508160005260206000209050919050565b60006020601f8301049050919050565b600082821b905092915050565b600060088302613ae97fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff82613aac565b613af38683613aac565b95508019841693508086168417925050509392505050565b6000819050919050565b6000613b30613b2b613b2684613365565b613b0b565b613365565b9050919050565b6000819050919050565b613b4a83613b15565b613b5e613b5682613b37565b848454613ab9565b825550505050565b600090565b613b73613b66565b613b7e818484613b41565b505050565b5b81811015613ba257613b97600082613b6b565b600181019050613b84565b5050565b601f821115613be757613bb881613a87565b613bc184613a9c565b81016020851015613bd0578190505b613be4613bdc85613a9c565b830182613b83565b50505b505050565b600082821c905092915050565b6000613c0a60001984600802613bec565b1980831691505092915050565b6000613c238383613bf9565b9150826002028217905092915050565b613c3c826132b3565b67ffffffffffffffff811115613c5557613c5461354f565b5b613c5f8254613985565b613c6a828285613ba6565b600060209050601f831160018114613c9d5760008415613c8b578287015190505b613c958582613c17565b865550613cfd565b601f198416613cab86613a87565b60005b82811015613cd357848901518255600182019150602085019450602081019050613cae565b86831015613cf05784890151613cec601f891682613bf9565b8355505b6001600288020188555050505b505050505050565b7f4d696e74206973206e6f74206c69766520796574000000000000000000000000600082015250565b6000613d3b6014836132be565b9150613d4682613d05565b602082019050919050565b60006020820190508181036000830152613d6a81613d2e565b9050919050565b6000613d7c82613365565b9150613d8783613365565b9250828201905080821115613d9f57613d9e6139b6565b5b92915050565b7f4e6f206d6f726500000000000000000000000000000000000000000000000000600082015250565b6000613ddb6007836132be565b9150613de682613da5565b602082019050919050565b60006020820190508181036000830152613e0a81613dce565b9050919050565b7f4d6178207065722074786e20726561636865642e000000000000000000000000600082015250565b6000613e476014836132be565b9150613e5282613e11565b602082019050919050565b60006020820190508181036000830152613e7681613e3a565b9050919050565b6000613e8882613365565b9150613e9383613365565b9250828203905081811115613eab57613eaa6139b6565b5b92915050565b7f596f7527766520616c7265616479206d696e746564206d61782066726565206160008201527f6c6c6f636174696f6e206f7220696e636f7272656374204554482073656e7400602082015250565b6000613f0d603f836132be565b9150613f1882613eb1565b604082019050919050565b60006020820190508181036000830152613f3c81613f00565b9050919050565b7f506c656173652073656e64207468652065786163742045544820616d6f756e74600082015250565b6000613f796020836132be565b9150613f8482613f43565b602082019050919050565b60006020820190508181036000830152613fa881613f6c565b9050919050565b600081905092915050565b50565b6000613fca600083613faf565b9150613fd582613fba565b600082019050919050565b6000613feb82613fbd565b9150819050919050565b7f5472616e73666572206661696c65642e00000000000000000000000000000000600082015250565b600061402b6010836132be565b915061403682613ff5565b602082019050919050565b6000602082019050818103600083015261405a8161401e565b9050919050565b7f546f6b656e20646f6573206e6f742065786973742e0000000000000000000000600082015250565b60006140976015836132be565b91506140a282614061565b602082019050919050565b600060208201905081810360008301526140c68161408a565b9050919050565b600081905092915050565b600081546140e581613985565b6140ef81866140cd565b9450600182166000811461410a576001811461411f57614152565b60ff1983168652811515820286019350614152565b61412885613a87565b60005b8381101561414a5781548189015260018201915060208101905061412b565b838801955050505b50505092915050565b6000614166826132b3565b61417081856140cd565b93506141808185602086016132cf565b80840191505092915050565b7f2e6a736f6e000000000000000000000000000000000000000000000000000000600082015250565b60006141c26005836140cd565b91506141cd8261418c565b600582019050919050565b60006141e482856140d8565b91506141f0828461415b565b91506141fb826141b5565b91508190509392505050565b7f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160008201527f6464726573730000000000000000000000000000000000000000000000000000602082015250565b60006142636026836132be565b915061426e82614207565b604082019050919050565b6000602082019050818103600083015261429281614256565b9050919050565b7f455243323938313a20726f79616c7479206665652077696c6c2065786365656460008201527f2073616c65507269636500000000000000000000000000000000000000000000602082015250565b60006142f5602a836132be565b915061430082614299565b604082019050919050565b60006020820190508181036000830152614324816142e8565b9050919050565b7f455243323938313a20696e76616c696420726563656976657200000000000000600082015250565b60006143616019836132be565b915061436c8261432b565b602082019050919050565b6000602082019050818103600083015261439081614354565b9050919050565b600081519050919050565b600082825260208201905092915050565b60006143be82614397565b6143c881856143a2565b93506143d88185602086016132cf565b6143e1816132f9565b840191505092915050565b600060808201905061440160008301876133c8565b61440e60208301866133c8565b61441b604083018561345f565b818103606083015261442d81846143b3565b905095945050505050565b60008151905061444781613142565b92915050565b6000602082840312156144635761446261310c565b5b600061447184828501614438565b91505092915050565b600061448582613365565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff82036144b7576144b66139b6565b5b600182019050919050565b60006144cd82613365565b91506144d883613365565b9250826144e8576144e7613a27565b5b828206905092915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fdfea2646970667358221220498e5fddbcd4848ed6b44eaed62917ac9ed4131f836f8f45ba3bd6d7d016759464736f6c63430008110033697066733a2f2f516d6355373379345448673179754c5246706f6e504d55516b6b58504452417a436b7935574771693141364b43792f

Deployed Bytecode

0x60806040526004361061020f5760003560e01c8063715018a611610118578063c002d23d116100a0578063f2fde38b1161006f578063f2fde38b14610791578063f43a22dc146107ba578063f4a0a528146107e5578063f4db2acb1461080e578063f676308a1461084b5761020f565b8063c002d23d146106c1578063c87b56dd146106ec578063dad7b5c914610729578063e985e9c5146107545761020f565b8063a0712d68116100e7578063a0712d6814610611578063a22cb4651461062d578063a5a865dc14610656578063ac44600214610681578063b88d4fde146106985761020f565b8063715018a61461057b5780638c3cefa3146105925780638da5cb5b146105bb57806395d89b41146105e65761020f565b806332cb6b0c1161019b57806355f804b31161016a57806355f804b31461048257806358c87f72146104ab5780636352211e146104d65780636c0360eb1461051357806370a082311461053e5761020f565b806332cb6b0c146103da578063375a069a1461040557806342842e0e1461042e578063463fff79146104575761020f565b8063095ea7b3116101e2578063095ea7b3146102e257806311b01a321461030b57806318160ddd1461034857806323b872dd146103735780632a55205a1461039c5761020f565b806301ffc9a71461021457806302fa7c471461025157806306fdde031461027a578063081812fc146102a5575b600080fd5b34801561022057600080fd5b5061023b6004803603810190610236919061316e565b610874565b60405161024891906131b6565b60405180910390f35b34801561025d57600080fd5b5061027860048036038101906102739190613273565b610886565b005b34801561028657600080fd5b5061028f610910565b60405161029c9190613343565b60405180910390f35b3480156102b157600080fd5b506102cc60048036038101906102c7919061339b565b6109a2565b6040516102d991906133d7565b60405180910390f35b3480156102ee57600080fd5b50610309600480360381019061030491906133f2565b610a1e565b005b34801561031757600080fd5b50610332600480360381019061032d9190613432565b610b28565b60405161033f919061346e565b60405180910390f35b34801561035457600080fd5b5061035d610b40565b60405161036a919061346e565b60405180910390f35b34801561037f57600080fd5b5061039a60048036038101906103959190613489565b610b57565b005b3480156103a857600080fd5b506103c360048036038101906103be91906134dc565b610b67565b6040516103d192919061351c565b60405180910390f35b3480156103e657600080fd5b506103ef610d51565b6040516103fc919061346e565b60405180910390f35b34801561041157600080fd5b5061042c6004803603810190610427919061339b565b610d57565b005b34801561043a57600080fd5b5061045560048036038101906104509190613489565b610de7565b005b34801561046357600080fd5b5061046c610e07565b604051610479919061346e565b60405180910390f35b34801561048e57600080fd5b506104a960048036038101906104a4919061367a565b610e0d565b005b3480156104b757600080fd5b506104c0610e9c565b6040516104cd91906136d2565b60405180910390f35b3480156104e257600080fd5b506104fd60048036038101906104f8919061339b565b610eba565b60405161050a91906133d7565b60405180910390f35b34801561051f57600080fd5b50610528610ed0565b6040516105359190613343565b60405180910390f35b34801561054a57600080fd5b5061056560048036038101906105609190613432565b610f5e565b604051610572919061346e565b60405180910390f35b34801561058757600080fd5b5061059061102d565b005b34801561059e57600080fd5b506105b960048036038101906105b49190613719565b6110b5565b005b3480156105c757600080fd5b506105d061114e565b6040516105dd91906133d7565b60405180910390f35b3480156105f257600080fd5b506105fb611178565b6040516106089190613343565b60405180910390f35b61062b6004803603810190610626919061339b565b61120a565b005b34801561063957600080fd5b50610654600480360381019061064f9190613746565b61170e565b005b34801561066257600080fd5b5061066b611885565b60405161067891906131b6565b60405180910390f35b34801561068d57600080fd5b50610696611898565b005b3480156106a457600080fd5b506106bf60048036038101906106ba9190613827565b6119ca565b005b3480156106cd57600080fd5b506106d6611a46565b6040516106e3919061346e565b60405180910390f35b3480156106f857600080fd5b50610713600480360381019061070e919061339b565b611a4c565b6040516107209190613343565b60405180910390f35b34801561073557600080fd5b5061073e611ac8565b60405161074b919061346e565b60405180910390f35b34801561076057600080fd5b5061077b600480360381019061077691906138aa565b611ace565b60405161078891906131b6565b60405180910390f35b34801561079d57600080fd5b506107b860048036038101906107b39190613432565b611b62565b005b3480156107c657600080fd5b506107cf611c59565b6040516107dc919061346e565b60405180910390f35b3480156107f157600080fd5b5061080c6004803603810190610807919061339b565b611c5f565b005b34801561081a57600080fd5b5061083560048036038101906108309190613432565b611ce5565b604051610842919061346e565b60405180910390f35b34801561085757600080fd5b50610872600480360381019061086d919061339b565b611cfd565b005b600061087f82611d83565b9050919050565b61088e611dfd565b73ffffffffffffffffffffffffffffffffffffffff166108ac61114e565b73ffffffffffffffffffffffffffffffffffffffff1614610902576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016108f990613936565b60405180910390fd5b61090c8282611e05565b5050565b60606002805461091f90613985565b80601f016020809104026020016040519081016040528092919081815260200182805461094b90613985565b80156109985780601f1061096d57610100808354040283529160200191610998565b820191906000526020600020905b81548152906001019060200180831161097b57829003601f168201915b5050505050905090565b60006109ad82611f9a565b6109e3576040517fcf4700e400000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6006600083815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050919050565b6000610a2982610eba565b90508073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603610a90576040517f943f7b8c00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b8073ffffffffffffffffffffffffffffffffffffffff16610aaf611dfd565b73ffffffffffffffffffffffffffffffffffffffff1614158015610ae15750610adf81610ada611dfd565b611ace565b155b15610b18576040517fcfb3b94200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b610b23838383611fe8565b505050565b60116020528060005260406000206000915090505481565b6000610b4a61209a565b6001546000540303905090565b610b628383836120a3565b505050565b6000806000600960008681526020019081526020016000206040518060400160405290816000820160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020016000820160149054906101000a90046bffffffffffffffffffffffff166bffffffffffffffffffffffff166bffffffffffffffffffffffff16815250509050600073ffffffffffffffffffffffffffffffffffffffff16816000015173ffffffffffffffffffffffffffffffffffffffff1603610cfc5760086040518060400160405290816000820160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020016000820160149054906101000a90046bffffffffffffffffffffffff166bffffffffffffffffffffffff166bffffffffffffffffffffffff168152505090505b6000610d06612557565b6bffffffffffffffffffffffff1682602001516bffffffffffffffffffffffff1686610d3291906139e5565b610d3c9190613a56565b90508160000151819350935050509250929050565b61115c81565b610d5f611dfd565b73ffffffffffffffffffffffffffffffffffffffff16610d7d61114e565b73ffffffffffffffffffffffffffffffffffffffff1614610dd3576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610dca90613936565b60405180910390fd5b610de4610dde611dfd565b82612561565b50565b610e02838383604051806020016040528060008152506119ca565b505050565b600e5481565b610e15611dfd565b73ffffffffffffffffffffffffffffffffffffffff16610e3361114e565b73ffffffffffffffffffffffffffffffffffffffff1614610e89576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610e8090613936565b60405180910390fd5b80600b9081610e989190613c33565b5050565b600f60009054906101000a90046bffffffffffffffffffffffff1681565b6000610ec58261257f565b600001519050919050565b600b8054610edd90613985565b80601f0160208091040260200160405190810160405280929190818152602001828054610f0990613985565b8015610f565780601f10610f2b57610100808354040283529160200191610f56565b820191906000526020600020905b815481529060010190602001808311610f3957829003601f168201915b505050505081565b60008073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603610fc5576040517f8f4eb60400000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b600560008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160009054906101000a900467ffffffffffffffff1667ffffffffffffffff169050919050565b611035611dfd565b73ffffffffffffffffffffffffffffffffffffffff1661105361114e565b73ffffffffffffffffffffffffffffffffffffffff16146110a9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016110a090613936565b60405180910390fd5b6110b3600061280e565b565b6110bd611dfd565b73ffffffffffffffffffffffffffffffffffffffff166110db61114e565b73ffffffffffffffffffffffffffffffffffffffff1614611131576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161112890613936565b60405180910390fd5b80600f600c6101000a81548160ff02191690831515021790555050565b6000600a60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60606003805461118790613985565b80601f01602080910402602001604051908101604052809291908181526020018280546111b390613985565b80156112005780601f106111d557610100808354040283529160200191611200565b820191906000526020600020905b8154815290600101906020018083116111e357829003601f168201915b5050505050905090565b600f600c9054906101000a900460ff16611259576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161125090613d51565b60405180910390fd5b61115c81611265610b40565b61126f9190613d71565b11156112b0576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016112a790613df1565b60405180910390fd5b600d548111156112f5576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016112ec90613e5d565b60405180910390fd5b601060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054600e546113429190613e7d565b811061146257600c54601060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054600e546113989190613e7d565b6113a291906139e5565b600c54826113b091906139e5565b6113ba9190613e7d565b3410156113fc576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016113f390613f23565b60405180910390fd5b600e54601060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550600e54601260008282546114569190613d71565b925050819055506116ab565b601060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054600e546114af9190613e7d565b81101561156e5760003410156114fa576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016114f190613f8f565b60405180910390fd5b80601060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008282546115499190613d71565b9250508190555080601260008282546115629190613d71565b925050819055506116aa565b600f600c9054906101000a900460ff166115bd576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016115b490613d51565b60405180910390fd5b600c54816115cb91906139e5565b34101561160d576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161160490613f8f565b60405180910390fd5b61115c81611619610b40565b6116239190613d71565b1115611664576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161165b90613df1565b60405180910390fd5b600d548111156116a9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116a090613e5d565b60405180910390fd5b5b5b80601160003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008282546116fa9190613d71565b9250508190555061170b3382612561565b50565b611716611dfd565b73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff160361177a576040517fb06307db00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b8060076000611787611dfd565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055508173ffffffffffffffffffffffffffffffffffffffff16611834611dfd565b73ffffffffffffffffffffffffffffffffffffffff167f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c318360405161187991906131b6565b60405180910390a35050565b600f600c9054906101000a900460ff1681565b6118a0611dfd565b73ffffffffffffffffffffffffffffffffffffffff166118be61114e565b73ffffffffffffffffffffffffffffffffffffffff1614611914576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161190b90613936565b60405180910390fd5b600061191e611dfd565b73ffffffffffffffffffffffffffffffffffffffff164760405161194190613fe0565b60006040518083038185875af1925050503d806000811461197e576040519150601f19603f3d011682016040523d82523d6000602084013e611983565b606091505b50509050806119c7576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016119be90614041565b60405180910390fd5b50565b6119d58484846120a3565b6119f48373ffffffffffffffffffffffffffffffffffffffff166128d4565b8015611a095750611a07848484846128f7565b155b15611a40576040517fd1a57ed600000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b50505050565b600c5481565b6060611a5782611f9a565b611a96576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611a8d906140ad565b60405180910390fd5b600b611aa183612a47565b604051602001611ab29291906141d8565b6040516020818303038152906040529050919050565b60125481565b6000600760008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16905092915050565b611b6a611dfd565b73ffffffffffffffffffffffffffffffffffffffff16611b8861114e565b73ffffffffffffffffffffffffffffffffffffffff1614611bde576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611bd590613936565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1603611c4d576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611c4490614279565b60405180910390fd5b611c568161280e565b50565b600d5481565b611c67611dfd565b73ffffffffffffffffffffffffffffffffffffffff16611c8561114e565b73ffffffffffffffffffffffffffffffffffffffff1614611cdb576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611cd290613936565b60405180910390fd5b80600c8190555050565b60106020528060005260406000206000915090505481565b611d05611dfd565b73ffffffffffffffffffffffffffffffffffffffff16611d2361114e565b73ffffffffffffffffffffffffffffffffffffffff1614611d79576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611d7090613936565b60405180910390fd5b80600e8190555050565b60007f2a55205a000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19161480611df65750611df582612ba7565b5b9050919050565b600033905090565b611e0d612557565b6bffffffffffffffffffffffff16816bffffffffffffffffffffffff161115611e6b576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611e629061430b565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603611eda576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611ed190614377565b60405180910390fd5b60405180604001604052808373ffffffffffffffffffffffffffffffffffffffff168152602001826bffffffffffffffffffffffff16815250600860008201518160000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555060208201518160000160146101000a8154816bffffffffffffffffffffffff02191690836bffffffffffffffffffffffff1602179055509050505050565b600081611fa561209a565b11158015611fb4575060005482105b8015611fe1575060046000838152602001908152602001600020600001601c9054906101000a900460ff16155b9050919050565b826006600084815260200190815260200160002060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550818373ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a4505050565b60006001905090565b60006120ae8261257f565b90508373ffffffffffffffffffffffffffffffffffffffff16816000015173ffffffffffffffffffffffffffffffffffffffff1614612119576040517fa114810000000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60008473ffffffffffffffffffffffffffffffffffffffff1661213a611dfd565b73ffffffffffffffffffffffffffffffffffffffff161480612169575061216885612163611dfd565b611ace565b5b806121ae5750612177611dfd565b73ffffffffffffffffffffffffffffffffffffffff16612196846109a2565b73ffffffffffffffffffffffffffffffffffffffff16145b9050806121e7576040517f59c896be00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff160361224d576040517fea553b3400000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b61225a8585856001612c89565b61226660008487611fe8565b6001600560008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160008282829054906101000a900467ffffffffffffffff160392506101000a81548167ffffffffffffffff021916908367ffffffffffffffff1602179055506001600560008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160008282829054906101000a900467ffffffffffffffff160192506101000a81548167ffffffffffffffff021916908367ffffffffffffffff1602179055506000600460008581526020019081526020016000209050848160000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550428160000160146101000a81548167ffffffffffffffff021916908367ffffffffffffffff16021790555060006001850190506000600460008381526020019081526020016000209050600073ffffffffffffffffffffffffffffffffffffffff168160000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16036124e55760005482146124e457878160000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555084602001518160000160146101000a81548167ffffffffffffffff021916908367ffffffffffffffff1602179055505b5b505050828473ffffffffffffffffffffffffffffffffffffffff168673ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a46125508585856001612c8f565b5050505050565b6000612710905090565b61257b828260405180602001604052806000815250612c95565b5050565b6125876130bf565b60008290508061259561209a565b111580156125a4575060005481105b156127d7576000600460008381526020019081526020016000206040518060600160405290816000820160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020016000820160149054906101000a900467ffffffffffffffff1667ffffffffffffffff1667ffffffffffffffff16815260200160008201601c9054906101000a900460ff161515151581525050905080604001516127d557600073ffffffffffffffffffffffffffffffffffffffff16816000015173ffffffffffffffffffffffffffffffffffffffff16146126b9578092505050612809565b5b6001156127d457818060019003925050600460008381526020019081526020016000206040518060600160405290816000820160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020016000820160149054906101000a900467ffffffffffffffff1667ffffffffffffffff1667ffffffffffffffff16815260200160008201601c9054906101000a900460ff1615151515815250509050600073ffffffffffffffffffffffffffffffffffffffff16816000015173ffffffffffffffffffffffffffffffffffffffff16146127cf578092505050612809565b6126ba565b5b505b6040517fdf2d9b4200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b919050565b6000600a60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905081600a60006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b6000808273ffffffffffffffffffffffffffffffffffffffff163b119050919050565b60008373ffffffffffffffffffffffffffffffffffffffff1663150b7a0261291d611dfd565b8786866040518563ffffffff1660e01b815260040161293f94939291906143ec565b6020604051808303816000875af192505050801561297b57506040513d601f19601f82011682018060405250810190612978919061444d565b60015b6129f4573d80600081146129ab576040519150601f19603f3d011682016040523d82523d6000602084013e6129b0565b606091505b5060008151036129ec576040517fd1a57ed600000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b805181602001fd5b63150b7a0260e01b7bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916817bffffffffffffffffffffffffffffffffffffffffffffffffffffffff191614915050949350505050565b606060008203612a8e576040518060400160405280600181526020017f30000000000000000000000000000000000000000000000000000000000000008152509050612ba2565b600082905060005b60008214612ac0578080612aa99061447a565b915050600a82612ab99190613a56565b9150612a96565b60008167ffffffffffffffff811115612adc57612adb61354f565b5b6040519080825280601f01601f191660200182016040528015612b0e5781602001600182028036833780820191505090505b5090505b60008514612b9b57600182612b279190613e7d565b9150600a85612b3691906144c2565b6030612b429190613d71565b60f81b818381518110612b5857612b576144f3565b5b60200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a905350600a85612b949190613a56565b9450612b12565b8093505050505b919050565b60007f80ac58cd000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19161480612c7257507f5b5e139f000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916145b80612c825750612c8182613055565b5b9050919050565b50505050565b50505050565b600080549050600073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1603612d01576040517f2e07630000000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60008303612d3b576040517fb562e8dd00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b612d486000858386612c89565b82600560008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160008282829054906101000a900467ffffffffffffffff160192506101000a81548167ffffffffffffffff021916908367ffffffffffffffff16021790555082600560008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160088282829054906101000a900467ffffffffffffffff160192506101000a81548167ffffffffffffffff021916908367ffffffffffffffff160217905550836004600083815260200190815260200160002060000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550426004600083815260200190815260200160002060000160146101000a81548167ffffffffffffffff021916908367ffffffffffffffff160217905550600081905060008482019050612f098673ffffffffffffffffffffffffffffffffffffffff166128d4565b15612fce575b818673ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a4612f7e60008784806001019550876128f7565b612fb4576040517fd1a57ed600000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b808203612f0f578260005414612fc957600080fd5b613039565b5b818060010192508673ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a4808203612fcf575b81600081905550505061304f6000858386612c8f565b50505050565b60007f01ffc9a7000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916149050919050565b6040518060600160405280600073ffffffffffffffffffffffffffffffffffffffff168152602001600067ffffffffffffffff1681526020016000151581525090565b6000604051905090565b600080fd5b600080fd5b60007fffffffff0000000000000000000000000000000000000000000000000000000082169050919050565b61314b81613116565b811461315657600080fd5b50565b60008135905061316881613142565b92915050565b6000602082840312156131845761318361310c565b5b600061319284828501613159565b91505092915050565b60008115159050919050565b6131b08161319b565b82525050565b60006020820190506131cb60008301846131a7565b92915050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b60006131fc826131d1565b9050919050565b61320c816131f1565b811461321757600080fd5b50565b60008135905061322981613203565b92915050565b60006bffffffffffffffffffffffff82169050919050565b6132508161322f565b811461325b57600080fd5b50565b60008135905061326d81613247565b92915050565b6000806040838503121561328a5761328961310c565b5b60006132988582860161321a565b92505060206132a98582860161325e565b9150509250929050565b600081519050919050565b600082825260208201905092915050565b60005b838110156132ed5780820151818401526020810190506132d2565b60008484015250505050565b6000601f19601f8301169050919050565b6000613315826132b3565b61331f81856132be565b935061332f8185602086016132cf565b613338816132f9565b840191505092915050565b6000602082019050818103600083015261335d818461330a565b905092915050565b6000819050919050565b61337881613365565b811461338357600080fd5b50565b6000813590506133958161336f565b92915050565b6000602082840312156133b1576133b061310c565b5b60006133bf84828501613386565b91505092915050565b6133d1816131f1565b82525050565b60006020820190506133ec60008301846133c8565b92915050565b600080604083850312156134095761340861310c565b5b60006134178582860161321a565b925050602061342885828601613386565b9150509250929050565b6000602082840312156134485761344761310c565b5b60006134568482850161321a565b91505092915050565b61346881613365565b82525050565b6000602082019050613483600083018461345f565b92915050565b6000806000606084860312156134a2576134a161310c565b5b60006134b08682870161321a565b93505060206134c18682870161321a565b92505060406134d286828701613386565b9150509250925092565b600080604083850312156134f3576134f261310c565b5b600061350185828601613386565b925050602061351285828601613386565b9150509250929050565b600060408201905061353160008301856133c8565b61353e602083018461345f565b9392505050565b600080fd5b600080fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b613587826132f9565b810181811067ffffffffffffffff821117156135a6576135a561354f565b5b80604052505050565b60006135b9613102565b90506135c5828261357e565b919050565b600067ffffffffffffffff8211156135e5576135e461354f565b5b6135ee826132f9565b9050602081019050919050565b82818337600083830152505050565b600061361d613618846135ca565b6135af565b9050828152602081018484840111156136395761363861354a565b5b6136448482856135fb565b509392505050565b600082601f83011261366157613660613545565b5b813561367184826020860161360a565b91505092915050565b6000602082840312156136905761368f61310c565b5b600082013567ffffffffffffffff8111156136ae576136ad613111565b5b6136ba8482850161364c565b91505092915050565b6136cc8161322f565b82525050565b60006020820190506136e760008301846136c3565b92915050565b6136f68161319b565b811461370157600080fd5b50565b600081359050613713816136ed565b92915050565b60006020828403121561372f5761372e61310c565b5b600061373d84828501613704565b91505092915050565b6000806040838503121561375d5761375c61310c565b5b600061376b8582860161321a565b925050602061377c85828601613704565b9150509250929050565b600067ffffffffffffffff8211156137a1576137a061354f565b5b6137aa826132f9565b9050602081019050919050565b60006137ca6137c584613786565b6135af565b9050828152602081018484840111156137e6576137e561354a565b5b6137f18482856135fb565b509392505050565b600082601f83011261380e5761380d613545565b5b813561381e8482602086016137b7565b91505092915050565b600080600080608085870312156138415761384061310c565b5b600061384f8782880161321a565b94505060206138608782880161321a565b935050604061387187828801613386565b925050606085013567ffffffffffffffff81111561389257613891613111565b5b61389e878288016137f9565b91505092959194509250565b600080604083850312156138c1576138c061310c565b5b60006138cf8582860161321a565b92505060206138e08582860161321a565b9150509250929050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572600082015250565b60006139206020836132be565b915061392b826138ea565b602082019050919050565b6000602082019050818103600083015261394f81613913565b9050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b6000600282049050600182168061399d57607f821691505b6020821081036139b0576139af613956565b5b50919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b60006139f082613365565b91506139fb83613365565b9250828202613a0981613365565b91508282048414831517613a2057613a1f6139b6565b5b5092915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b6000613a6182613365565b9150613a6c83613365565b925082613a7c57613a7b613a27565b5b828204905092915050565b60008190508160005260206000209050919050565b60006020601f8301049050919050565b600082821b905092915050565b600060088302613ae97fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff82613aac565b613af38683613aac565b95508019841693508086168417925050509392505050565b6000819050919050565b6000613b30613b2b613b2684613365565b613b0b565b613365565b9050919050565b6000819050919050565b613b4a83613b15565b613b5e613b5682613b37565b848454613ab9565b825550505050565b600090565b613b73613b66565b613b7e818484613b41565b505050565b5b81811015613ba257613b97600082613b6b565b600181019050613b84565b5050565b601f821115613be757613bb881613a87565b613bc184613a9c565b81016020851015613bd0578190505b613be4613bdc85613a9c565b830182613b83565b50505b505050565b600082821c905092915050565b6000613c0a60001984600802613bec565b1980831691505092915050565b6000613c238383613bf9565b9150826002028217905092915050565b613c3c826132b3565b67ffffffffffffffff811115613c5557613c5461354f565b5b613c5f8254613985565b613c6a828285613ba6565b600060209050601f831160018114613c9d5760008415613c8b578287015190505b613c958582613c17565b865550613cfd565b601f198416613cab86613a87565b60005b82811015613cd357848901518255600182019150602085019450602081019050613cae565b86831015613cf05784890151613cec601f891682613bf9565b8355505b6001600288020188555050505b505050505050565b7f4d696e74206973206e6f74206c69766520796574000000000000000000000000600082015250565b6000613d3b6014836132be565b9150613d4682613d05565b602082019050919050565b60006020820190508181036000830152613d6a81613d2e565b9050919050565b6000613d7c82613365565b9150613d8783613365565b9250828201905080821115613d9f57613d9e6139b6565b5b92915050565b7f4e6f206d6f726500000000000000000000000000000000000000000000000000600082015250565b6000613ddb6007836132be565b9150613de682613da5565b602082019050919050565b60006020820190508181036000830152613e0a81613dce565b9050919050565b7f4d6178207065722074786e20726561636865642e000000000000000000000000600082015250565b6000613e476014836132be565b9150613e5282613e11565b602082019050919050565b60006020820190508181036000830152613e7681613e3a565b9050919050565b6000613e8882613365565b9150613e9383613365565b9250828203905081811115613eab57613eaa6139b6565b5b92915050565b7f596f7527766520616c7265616479206d696e746564206d61782066726565206160008201527f6c6c6f636174696f6e206f7220696e636f7272656374204554482073656e7400602082015250565b6000613f0d603f836132be565b9150613f1882613eb1565b604082019050919050565b60006020820190508181036000830152613f3c81613f00565b9050919050565b7f506c656173652073656e64207468652065786163742045544820616d6f756e74600082015250565b6000613f796020836132be565b9150613f8482613f43565b602082019050919050565b60006020820190508181036000830152613fa881613f6c565b9050919050565b600081905092915050565b50565b6000613fca600083613faf565b9150613fd582613fba565b600082019050919050565b6000613feb82613fbd565b9150819050919050565b7f5472616e73666572206661696c65642e00000000000000000000000000000000600082015250565b600061402b6010836132be565b915061403682613ff5565b602082019050919050565b6000602082019050818103600083015261405a8161401e565b9050919050565b7f546f6b656e20646f6573206e6f742065786973742e0000000000000000000000600082015250565b60006140976015836132be565b91506140a282614061565b602082019050919050565b600060208201905081810360008301526140c68161408a565b9050919050565b600081905092915050565b600081546140e581613985565b6140ef81866140cd565b9450600182166000811461410a576001811461411f57614152565b60ff1983168652811515820286019350614152565b61412885613a87565b60005b8381101561414a5781548189015260018201915060208101905061412b565b838801955050505b50505092915050565b6000614166826132b3565b61417081856140cd565b93506141808185602086016132cf565b80840191505092915050565b7f2e6a736f6e000000000000000000000000000000000000000000000000000000600082015250565b60006141c26005836140cd565b91506141cd8261418c565b600582019050919050565b60006141e482856140d8565b91506141f0828461415b565b91506141fb826141b5565b91508190509392505050565b7f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160008201527f6464726573730000000000000000000000000000000000000000000000000000602082015250565b60006142636026836132be565b915061426e82614207565b604082019050919050565b6000602082019050818103600083015261429281614256565b9050919050565b7f455243323938313a20726f79616c7479206665652077696c6c2065786365656460008201527f2073616c65507269636500000000000000000000000000000000000000000000602082015250565b60006142f5602a836132be565b915061430082614299565b604082019050919050565b60006020820190508181036000830152614324816142e8565b9050919050565b7f455243323938313a20696e76616c696420726563656976657200000000000000600082015250565b60006143616019836132be565b915061436c8261432b565b602082019050919050565b6000602082019050818103600083015261439081614354565b9050919050565b600081519050919050565b600082825260208201905092915050565b60006143be82614397565b6143c881856143a2565b93506143d88185602086016132cf565b6143e1816132f9565b840191505092915050565b600060808201905061440160008301876133c8565b61440e60208301866133c8565b61441b604083018561345f565b818103606083015261442d81846143b3565b905095945050505050565b60008151905061444781613142565b92915050565b6000602082840312156144635761446261310c565b5b600061447184828501614438565b91505092915050565b600061448582613365565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff82036144b7576144b66139b6565b5b600182019050919050565b60006144cd82613365565b91506144d883613365565b9250826144e8576144e7613a27565b5b828206905092915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fdfea2646970667358221220498e5fddbcd4848ed6b44eaed62917ac9ed4131f836f8f45ba3bd6d7d016759464736f6c63430008110033

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.