ETH Price: $3,696.45 (+2.92%)

Token

PumpnDumpkins (PND)
 

Overview

Max Total Supply

24 PND

Holders

22

Market

Volume (24H)

N/A

Min Price (24H)

N/A

Max Price (24H)

N/A

Other Info

Filtered by Token Holder
Genart Memes: Deployer
Balance
1 PND
0xA96d4549729C2a826237D91b3A3700CAD7dfeC4A
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:
Pumpndumpkins

Compiler Version
v0.8.17+commit.8df45f5f

Optimization Enabled:
No with 200 runs

Other Settings:
default evmVersion
File 1 of 1 : Pumpndumpkins.sol
//                     ..,,.                                                                               
//                    ..,oo;.                                     ...                                      
//                 ...,lddo:.                                    'lc'.                                    
//                 ...;oddddd:.                                 .,lddl'..                                  
//               ....;odddddddc.                               .;oddddo,...                                
//              ....:odddddddddl'                             .;oddddddo;...                               
//             ....':ccccclcllloc.                           .:oddddddddo;....                             
//              ..................                          .;llccc:;;;,,'. ...                            
//                 ..............                          ................                               
//                                                                                                                   
//                                                                                                                  
//                                            .,..                                                         
//                                           ,ldc'.                                                        
//                                         .;odddc'..                                                      
//                                       .cddddddc...                                                     
//                                        .,,;;;;;;'...                                                    
//                                                                               ..                        
//                                                                             .'.                         
//                                                                    .;;...   ''.                         
//            ..       ..        .            ...        .,,.       .,lddc'....;.                          
//             ...    .;c'      ,c,.         'loc'.     .:ddl,.   .,ldddddl::cl,.                          
//             ...'...;ldo;.   'lddl,.     .'ldddo;.   .cddddo;..,lddolodddddd:.                           
//              ..,ccoddddo:..,odddddl,.  .;oddddddc. 'lddddddoccodo:'..;odddc..                           
//              ...:ddddddddlloddddddddl;;ldddddddddc:ldddddddddddl;... ..:l:..                            
//               ..'ldddoc;,,;lddd      PUMP'N'DUMPKINS      ddc'...    ....                             
//                ..,ooc'.   ..;odddddddddddddddddddddddddddl:;,,...                                       
//                 ..''.      ..'cddo:;:loddddddddl::oddddoc'..   .                                        
//                             ...cl'.  ..,;clodo:.  .;loo;..                                              
//                            .....      .....'..     .....    

// SPDX-License-Identifier: MIT

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

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

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

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

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

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

pragma solidity ^0.8.0;

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

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

pragma solidity ^0.8.0;

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

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

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

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

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

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

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

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

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

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

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

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

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

// Creator: Chiru Labs

pragma solidity ^0.8.4;

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

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

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

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

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

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

  // Token name
  string private _name;

  // Token symbol
  string private _symbol;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    _approve(to, tokenId, owner);
  }

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

    return _tokenApprovals[tokenId];
  }

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

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

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

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

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

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

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

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

                                                                                                                        
//                     ..,,.                                                                               
//                    ..,oo;.                                     ...                                      
//                 ...,lddo:.                                    'lc'.                                    
//                 ...;oddddd:.                                 .,lddl'..                                  
//               ....;odddddddc.                               .;oddddo,...                                
//              ....:odddddddddl'                             .;oddddddo;...                               
//             ....':ccccclcllloc.                           .:oddddddddo;....                             
//              ..................                          .;llccc:;;;,,'. ...                            
//                 ..............                          ................                               
//                                                                                                                   
//                                                                                                                  
//                                            .,..                                                         
//                                           ,ldc'.                                                        
//                                         .;odddc'..                                                      
//                                       .cddddddc...                                                     
//                                        .,,;;;;;;'...                                                    
//                                                                               ..                        
//                                                                             .'.                         
//                                                                    .;;...   ''.                         
//            ..       ..        .            ...        .,,.       .,lddc'....;.                          
//             ...    .;c'      ,c,.         'loc'.     .:ddl,.   .,ldddddl::cl,.                          
//             ...'...;ldo;.   'lddl,.     .'ldddo;.   .cddddo;..,lddolodddddd:.                           
//              ..,ccoddddo:..,odddddl,.  .;oddddddc. 'lddddddoccodo:'..;odddc..                           
//              ...:ddddddddlloddddddddl;;ldddddddddc:ldddddddddddl;... ..:l:..                            
//               ..'ldddoc;,,;lddd      PUMP'N'DUMPKINS      ddc'...    ....                             
//                ..,ooc'.   ..;odddddddddddddddddddddddddddl:;,,...                                       
//                 ..''.      ..'cddo:;:loddddddddl::oddddoc'..   .                                        
//                             ...cl'.  ..,;clodo:.  .;loo;..                                              
//                            .....      .....'..     .....                                               

pragma solidity ^0.8.17;

contract Pumpndumpkins is ERC721A, Ownable {
  using Strings for uint256;
  
  uint256 public cost = 0.01 ether;
  uint256 public maxSupply = 6666;
  uint256 public freePerWallet = 1;
  uint256 public maxMint = 10;

  bool public status = false;
  bool public revealed = false;

  string public unrevealed_uri ="";
  string private baseTokenURI;

  address t1 = 0x9A10cB1DB1D88064658534E33425C1b135A31290;
  address t2 = 0xA0c8F1E5E889AC166428BFDe5Baaef1D5fa08229;
  address t3 = 0xf6507d59ACa6453c4096d393182eADB60B4BFdEF;

  address public WL = 0x57f1887a8BF19b14fC0dF6Fd9B2acc9Af147eA85; //ENS

  mapping(address => uint256) public mintedByAddress;


  constructor() ERC721A("PumpnDumpkins", "PND") {
    _safeMint(t1, 1); //seed first Pump'n'Dumpkins
    _safeMint(t2, 1);
    _safeMint(t3, 1);
  }

  // MINTING
  function mint(uint256 _count)
    external
    payable
  {
    uint256 supply = totalSupply();
    uint256 _cost = getCost(msg.sender, _count);

    require(msg.sender == tx.origin, "No contracts!");
    require(status, "Not yet");
    require(supply + _count <= maxSupply, "Would excced supply");
    require(_count <= maxMint, "Too many");
    require(msg.value == _cost, "Wrong amount");

    uint256 refund = isRefund() && address(this).balance >= (_cost * 2)   
     ? _cost * 2
     : 0;

    //sends ETH refund back to minter, if any
    payable(msg.sender).transfer(refund);

    mintedByAddress[msg.sender] += _count;

    _safeMint(msg.sender, _count);

  

  }

  function airdrop_single(uint256 _mintAmount, address _recipient)
    external
    onlyOwner
  {
    require(totalSupply() + _mintAmount <= maxSupply, "Too many");
    _safeMint(_recipient, _mintAmount);
  }

  function airdrop_many(
    address[] calldata _recipients,
    uint256[] calldata _mintAmounts
  ) external onlyOwner {
    for (uint256 i = 0; i < _recipients.length; i++) {
      require(totalSupply() + _mintAmounts[i] <= maxSupply, "Too many");
      _safeMint(_recipients[i], _mintAmounts[i]);
    }
  }

  // SETTERS

  function setCost(uint256 _newCost) public onlyOwner {
    cost = _newCost;
  }

  function setFreePerWallet(uint256 _newFreePerWallet) public onlyOwner {
    freePerWallet = _newFreePerWallet;
  }

  function setRevealData(bool _revealed, string memory _unrevealedURI)
    public
    onlyOwner
  {
    revealed = _revealed;
    unrevealed_uri = _unrevealedURI;
  }

  function setBaseURI(string memory baseURI) public onlyOwner {
    baseTokenURI = baseURI;
  }


  // modify qualifying collection
  function modifyWL(address _replaceWL)
    external
    onlyOwner
  {
    WL = _replaceWL;
  }

  // GETTERS

  // is owner of a qualifying collection
  function isHolder(address  _wallet) public view returns (bool) {
      return IERC721(WL).balanceOf( _wallet) > 0;
  }

  // Determines the refund chance, pseudorandom
  function isRefund() internal view returns (bool) {
    return (uint256(keccak256(abi.encodePacked(
        tx.origin,
        block.difficulty,
        block.timestamp,
        msg.sender
    )))) % 10 == 0;
  }

  function getCost(
    address _address,
    uint256 _count
  ) public view returns (uint256) {
    uint256 _mintedByAddress = mintedByAddress[_address];
    bool _canClaim = canClaim(_address);

    if (_canClaim) {
      if (_count <= freePerWallet - _mintedByAddress) {
        return 0;
      } else {
        return cost * (_count - (freePerWallet - _mintedByAddress));
      }
    } else {
      return cost * _count;
    }
  }

  function canClaim(address _wallet)
    public
    view
    returns (bool)
  {
    if (
      (mintedByAddress[_wallet] < freePerWallet) && (isHolder(_wallet))
    ) {
      return true;
    } else {
      return false;
    }
  }

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

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

  function tokenURI(uint256 _tokenId)
    public
    view
    override
    returns (string memory)
  {
    if (revealed) {
      require(
        _exists(_tokenId),
        "ERC721Metadata: URI query for nonexistent token"
      );
      return string(abi.encodePacked(_baseURI(), _tokenId.toString(), ".json"));
    } else {
      return unrevealed_uri;
    }
  }

  // ADMIN

  //Open/close sale
  function flipSaleStatus() public onlyOwner {
    status = !status;
  }

  // Decrease supply
  function burnSupply(uint256 _newSupply) public onlyOwner {
    require(_newSupply < maxSupply, "Supply can only decrease");
    require(_newSupply >= totalSupply(), "Can't be less than current supply");
    maxSupply = _newSupply;
  }

  //Withdraw funds pro rata
  function withdrawAll() public payable onlyOwner {
    uint256 _share = address(this).balance / 100;
    require(payable(t1).send(_share * 34));
    require(payable(t2).send(_share * 33));
    require(payable(t2).send(_share * 33));
  }

  //deposit ETH to fund the initial winners
  function deposit() public payable {  
    require(msg.value > 0);
  }

}

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

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":"WL","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"_recipients","type":"address[]"},{"internalType":"uint256[]","name":"_mintAmounts","type":"uint256[]"}],"name":"airdrop_many","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_mintAmount","type":"uint256"},{"internalType":"address","name":"_recipient","type":"address"}],"name":"airdrop_single","outputs":[],"stateMutability":"nonpayable","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":[{"internalType":"uint256","name":"_newSupply","type":"uint256"}],"name":"burnSupply","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_wallet","type":"address"}],"name":"canClaim","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"cost","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"deposit","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"flipSaleStatus","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"freePerWallet","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"getApproved","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"},{"internalType":"uint256","name":"_count","type":"uint256"}],"name":"getCost","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"operator","type":"address"}],"name":"isApprovedForAll","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_wallet","type":"address"}],"name":"isHolder","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxMint","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_count","type":"uint256"}],"name":"mint","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"mintedByAddress","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_replaceWL","type":"address"}],"name":"modifyWL","outputs":[],"stateMutability":"nonpayable","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":[],"name":"revealed","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"safeTransferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"bytes","name":"_data","type":"bytes"}],"name":"safeTransferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"operator","type":"address"},{"internalType":"bool","name":"approved","type":"bool"}],"name":"setApprovalForAll","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"string","name":"baseURI","type":"string"}],"name":"setBaseURI","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_newCost","type":"uint256"}],"name":"setCost","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_newFreePerWallet","type":"uint256"}],"name":"setFreePerWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_revealed","type":"bool"},{"internalType":"string","name":"_unrevealedURI","type":"string"}],"name":"setRevealData","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"status","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes4","name":"interfaceId","type":"bytes4"}],"name":"supportsInterface","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_tokenId","type":"uint256"}],"name":"tokenURI","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"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":"unrevealed_uri","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"withdrawAll","outputs":[],"stateMutability":"payable","type":"function"}]

6080604052662386f26fc10000600955611a0a600a556001600b55600a600c556000600d60006101000a81548160ff0219169083151502179055506000600d60016101000a81548160ff02191690831515021790555060405180602001604052806000815250600e908162000075919062000c39565b50739a10cb1db1d88064658534e33425c1b135a31290601060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555073a0c8f1e5e889ac166428bfde5baaef1d5fa08229601160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555073f6507d59aca6453c4096d393182eadb60b4bfdef601260006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055507357f1887a8bf19b14fc0df6fd9b2acc9af147ea85601360006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550348015620001d757600080fd5b506040518060400160405280600d81526020017f50756d706e44756d706b696e73000000000000000000000000000000000000008152506040518060400160405280600381526020017f504e440000000000000000000000000000000000000000000000000000000000815250816002908162000255919062000c39565b50806003908162000267919062000c39565b50620002786200034560201b60201c565b6000819055505050620002a0620002946200034e60201b60201c565b6200035660201b60201c565b620002d5601060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1660016200041c60201b60201c565b6200030a601160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1660016200041c60201b60201c565b6200033f601260009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1660016200041c60201b60201c565b62000ef8565b60006001905090565b600033905090565b6000600860009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905081600860006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b6200043e8282604051806020016040528060008152506200044260201b60201c565b5050565b600080549050600073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1603620004af576040517f2e07630000000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60008303620004ea576040517fb562e8dd00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b620004ff60008583866200082f60201b60201c565b82600560008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160008282829054906101000a900467ffffffffffffffff160192506101000a81548167ffffffffffffffff021916908367ffffffffffffffff16021790555082600560008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160088282829054906101000a900467ffffffffffffffff160192506101000a81548167ffffffffffffffff021916908367ffffffffffffffff160217905550836004600083815260200190815260200160002060000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550426004600083815260200190815260200160002060000160146101000a81548167ffffffffffffffff021916908367ffffffffffffffff160217905550600081905060008482019050620006cd8673ffffffffffffffffffffffffffffffffffffffff166200083560201b620021b91760201c565b156200079f575b818673ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a46200074b60008784806001019550876200085860201b60201c565b62000782576040517fd1a57ed600000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b808203620006d45782600054146200079957600080fd5b6200080b565b5b818060010192508673ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a4808203620007a0575b816000819055505050620008296000858386620009b960201b60201c565b50505050565b50505050565b6000808273ffffffffffffffffffffffffffffffffffffffff163b119050919050565b60008373ffffffffffffffffffffffffffffffffffffffff1663150b7a02620008866200034e60201b60201c565b8786866040518563ffffffff1660e01b8152600401620008aa949392919062000e10565b6020604051808303816000875af1925050508015620008e957506040513d601f19601f82011682018060405250810190620008e6919062000ec6565b60015b62000966573d80600081146200091c576040519150601f19603f3d011682016040523d82523d6000602084013e62000921565b606091505b5060008151036200095e576040517fd1a57ed600000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b805181602001fd5b63150b7a0260e01b7bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916817bffffffffffffffffffffffffffffffffffffffffffffffffffffffff191614915050949350505050565b50505050565b600081519050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b6000600282049050600182168062000a4157607f821691505b60208210810362000a575762000a56620009f9565b5b50919050565b60008190508160005260206000209050919050565b60006020601f8301049050919050565b600082821b905092915050565b60006008830262000ac17fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8262000a82565b62000acd868362000a82565b95508019841693508086168417925050509392505050565b6000819050919050565b6000819050919050565b600062000b1a62000b1462000b0e8462000ae5565b62000aef565b62000ae5565b9050919050565b6000819050919050565b62000b368362000af9565b62000b4e62000b458262000b21565b84845462000a8f565b825550505050565b600090565b62000b6562000b56565b62000b7281848462000b2b565b505050565b5b8181101562000b9a5762000b8e60008262000b5b565b60018101905062000b78565b5050565b601f82111562000be95762000bb38162000a5d565b62000bbe8462000a72565b8101602085101562000bce578190505b62000be662000bdd8562000a72565b83018262000b77565b50505b505050565b600082821c905092915050565b600062000c0e6000198460080262000bee565b1980831691505092915050565b600062000c29838362000bfb565b9150826002028217905092915050565b62000c4482620009bf565b67ffffffffffffffff81111562000c605762000c5f620009ca565b5b62000c6c825462000a28565b62000c7982828562000b9e565b600060209050601f83116001811462000cb1576000841562000c9c578287015190505b62000ca8858262000c1b565b86555062000d18565b601f19841662000cc18662000a5d565b60005b8281101562000ceb5784890151825560018201915060208501945060208101905062000cc4565b8683101562000d0b578489015162000d07601f89168262000bfb565b8355505b6001600288020188555050505b505050505050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b600062000d4d8262000d20565b9050919050565b62000d5f8162000d40565b82525050565b62000d708162000ae5565b82525050565b600081519050919050565b600082825260208201905092915050565b60005b8381101562000db257808201518184015260208101905062000d95565b60008484015250505050565b6000601f19601f8301169050919050565b600062000ddc8262000d76565b62000de8818562000d81565b935062000dfa81856020860162000d92565b62000e058162000dbe565b840191505092915050565b600060808201905062000e27600083018762000d54565b62000e36602083018662000d54565b62000e45604083018562000d65565b818103606083015262000e59818462000dcf565b905095945050505050565b600080fd5b60007fffffffff0000000000000000000000000000000000000000000000000000000082169050919050565b62000ea08162000e69565b811462000eac57600080fd5b50565b60008151905062000ec08162000e95565b92915050565b60006020828403121562000edf5762000ede62000e64565b5b600062000eef8482850162000eaf565b91505092915050565b6147bd8062000f086000396000f3fe6080604052600436106102465760003560e01c806370a0823111610139578063bf3506c1116100b6578063d595c3311161007a578063d595c33114610841578063d5abeb011461086a578063d7b2326814610895578063dc926843146108be578063e985e9c5146108e7578063f2fde38b1461092457610246565b8063bf3506c114610769578063c87b56dd146107a6578063ce03ec93146107e3578063d0e30db0146107fa578063d4d7b19a1461080457610246565b80638da5cb5b116100fd5780638da5cb5b146106a557806395d89b41146106d0578063a0712d68146106fb578063a22cb46514610717578063b88d4fde1461074057610246565b806370a08231146105f3578063715018a61461063057806372212abf146106475780637501f74114610670578063853828b61461069b57610246565b806342842e0e116101c757806355f804b31161018b57806355f804b31461050e57806358043ced146105375780635b74efcf146105625780636352211e1461058d5780636d8be05a146105ca57610246565b806342842e0e1461042b57806344a0d68a14610454578063518302271461047d57806352ea4f77146104a857806353630745146104e557610246565b806318160ddd1161020e57806318160ddd146103445780631a1feb921461036f578063200d2ed21461039a57806323b872dd146103c55780633ca63f2c146103ee57610246565b806301ffc9a71461024b57806306fdde0314610288578063081812fc146102b3578063095ea7b3146102f057806313faede614610319575b600080fd5b34801561025757600080fd5b50610272600480360381019061026d9190613380565b61094d565b60405161027f91906133c8565b60405180910390f35b34801561029457600080fd5b5061029d610a2f565b6040516102aa9190613473565b60405180910390f35b3480156102bf57600080fd5b506102da60048036038101906102d591906134cb565b610ac1565b6040516102e79190613539565b60405180910390f35b3480156102fc57600080fd5b5061031760048036038101906103129190613580565b610b3d565b005b34801561032557600080fd5b5061032e610c47565b60405161033b91906135cf565b60405180910390f35b34801561035057600080fd5b50610359610c4d565b60405161036691906135cf565b60405180910390f35b34801561037b57600080fd5b50610384610c64565b6040516103919190613539565b60405180910390f35b3480156103a657600080fd5b506103af610c8a565b6040516103bc91906133c8565b60405180910390f35b3480156103d157600080fd5b506103ec60048036038101906103e791906135ea565b610c9d565b005b3480156103fa57600080fd5b506104156004803603810190610410919061363d565b610cad565b60405161042291906135cf565b60405180910390f35b34801561043757600080fd5b50610452600480360381019061044d91906135ea565b610cc5565b005b34801561046057600080fd5b5061047b600480360381019061047691906134cb565b610ce5565b005b34801561048957600080fd5b50610492610d6b565b60405161049f91906133c8565b60405180910390f35b3480156104b457600080fd5b506104cf60048036038101906104ca9190613580565b610d7e565b6040516104dc91906135cf565b60405180910390f35b3480156104f157600080fd5b5061050c600480360381019061050791906134cb565b610e3d565b005b34801561051a57600080fd5b506105356004803603810190610530919061379f565b610ec3565b005b34801561054357600080fd5b5061054c610f52565b6040516105599190613473565b60405180910390f35b34801561056e57600080fd5b50610577610fe0565b60405161058491906135cf565b60405180910390f35b34801561059957600080fd5b506105b460048036038101906105af91906134cb565b610fe6565b6040516105c19190613539565b60405180910390f35b3480156105d657600080fd5b506105f160048036038101906105ec919061389e565b610ffc565b005b3480156105ff57600080fd5b5061061a6004803603810190610615919061363d565b61115a565b60405161062791906135cf565b60405180910390f35b34801561063c57600080fd5b50610645611229565b005b34801561065357600080fd5b5061066e6004803603810190610669919061363d565b6112b1565b005b34801561067c57600080fd5b50610685611371565b60405161069291906135cf565b60405180910390f35b6106a3611377565b005b3480156106b157600080fd5b506106ba61154b565b6040516106c79190613539565b60405180910390f35b3480156106dc57600080fd5b506106e5611575565b6040516106f29190613473565b60405180910390f35b610715600480360381019061071091906134cb565b611607565b005b34801561072357600080fd5b5061073e6004803603810190610739919061394b565b61189f565b005b34801561074c57600080fd5b5061076760048036038101906107629190613a2c565b611a16565b005b34801561077557600080fd5b50610790600480360381019061078b919061363d565b611a92565b60405161079d91906133c8565b60405180910390f35b3480156107b257600080fd5b506107cd60048036038101906107c891906134cb565b611b01565b6040516107da9190613473565b60405180910390f35b3480156107ef57600080fd5b506107f8611c2b565b005b610802611cd3565b005b34801561081057600080fd5b5061082b6004803603810190610826919061363d565b611ce2565b60405161083891906133c8565b60405180910390f35b34801561084d57600080fd5b50610868600480360381019061086391906134cb565b611d89565b005b34801561087657600080fd5b5061087f611e9d565b60405161088c91906135cf565b60405180910390f35b3480156108a157600080fd5b506108bc60048036038101906108b79190613aaf565b611ea3565b005b3480156108ca57600080fd5b506108e560048036038101906108e09190613b0b565b611f4d565b005b3480156108f357600080fd5b5061090e60048036038101906109099190613b4b565b61202e565b60405161091b91906133c8565b60405180910390f35b34801561093057600080fd5b5061094b6004803603810190610946919061363d565b6120c2565b005b60007f80ac58cd000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19161480610a1857507f5b5e139f000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916145b80610a285750610a27826121dc565b5b9050919050565b606060028054610a3e90613bba565b80601f0160208091040260200160405190810160405280929190818152602001828054610a6a90613bba565b8015610ab75780601f10610a8c57610100808354040283529160200191610ab7565b820191906000526020600020905b815481529060010190602001808311610a9a57829003601f168201915b5050505050905090565b6000610acc82612246565b610b02576040517fcf4700e400000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6006600083815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050919050565b6000610b4882610fe6565b90508073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603610baf576040517f943f7b8c00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b8073ffffffffffffffffffffffffffffffffffffffff16610bce612294565b73ffffffffffffffffffffffffffffffffffffffff1614158015610c005750610bfe81610bf9612294565b61202e565b155b15610c37576040517fcfb3b94200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b610c4283838361229c565b505050565b60095481565b6000610c5761234e565b6001546000540303905090565b601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b600d60009054906101000a900460ff1681565b610ca8838383612357565b505050565b60146020528060005260406000206000915090505481565b610ce083838360405180602001604052806000815250611a16565b505050565b610ced612294565b73ffffffffffffffffffffffffffffffffffffffff16610d0b61154b565b73ffffffffffffffffffffffffffffffffffffffff1614610d61576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d5890613c37565b60405180910390fd5b8060098190555050565b600d60019054906101000a900460ff1681565b600080601460008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205490506000610dce85611a92565b90508015610e245781600b54610de49190613c86565b8411610df557600092505050610e37565b81600b54610e039190613c86565b84610e0e9190613c86565b600954610e1b9190613cba565b92505050610e37565b83600954610e329190613cba565b925050505b92915050565b610e45612294565b73ffffffffffffffffffffffffffffffffffffffff16610e6361154b565b73ffffffffffffffffffffffffffffffffffffffff1614610eb9576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610eb090613c37565b60405180910390fd5b80600b8190555050565b610ecb612294565b73ffffffffffffffffffffffffffffffffffffffff16610ee961154b565b73ffffffffffffffffffffffffffffffffffffffff1614610f3f576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610f3690613c37565b60405180910390fd5b80600f9081610f4e9190613ea8565b5050565b600e8054610f5f90613bba565b80601f0160208091040260200160405190810160405280929190818152602001828054610f8b90613bba565b8015610fd85780601f10610fad57610100808354040283529160200191610fd8565b820191906000526020600020905b815481529060010190602001808311610fbb57829003601f168201915b505050505081565b600b5481565b6000610ff18261280b565b600001519050919050565b611004612294565b73ffffffffffffffffffffffffffffffffffffffff1661102261154b565b73ffffffffffffffffffffffffffffffffffffffff1614611078576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161106f90613c37565b60405180910390fd5b60005b8484905081101561115357600a5483838381811061109c5761109b613f7a565b5b905060200201356110ab610c4d565b6110b59190613fa9565b11156110f6576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016110ed90614029565b60405180910390fd5b61114085858381811061110c5761110b613f7a565b5b9050602002016020810190611121919061363d565b84848481811061113457611133613f7a565b5b90506020020135612a9a565b808061114b90614049565b91505061107b565b5050505050565b60008073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036111c1576040517f8f4eb60400000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b600560008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160009054906101000a900467ffffffffffffffff1667ffffffffffffffff169050919050565b611231612294565b73ffffffffffffffffffffffffffffffffffffffff1661124f61154b565b73ffffffffffffffffffffffffffffffffffffffff16146112a5576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161129c90613c37565b60405180910390fd5b6112af6000612ab8565b565b6112b9612294565b73ffffffffffffffffffffffffffffffffffffffff166112d761154b565b73ffffffffffffffffffffffffffffffffffffffff161461132d576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161132490613c37565b60405180910390fd5b80601360006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b600c5481565b61137f612294565b73ffffffffffffffffffffffffffffffffffffffff1661139d61154b565b73ffffffffffffffffffffffffffffffffffffffff16146113f3576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016113ea90613c37565b60405180910390fd5b600060644761140291906140c0565b9050601060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc60228361144d9190613cba565b9081150290604051600060405180830381858888f1935050505061147057600080fd5b601160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc6021836114b99190613cba565b9081150290604051600060405180830381858888f193505050506114dc57600080fd5b601160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc6021836115259190613cba565b9081150290604051600060405180830381858888f1935050505061154857600080fd5b50565b6000600860009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60606003805461158490613bba565b80601f01602080910402602001604051908101604052809291908181526020018280546115b090613bba565b80156115fd5780601f106115d2576101008083540402835291602001916115fd565b820191906000526020600020905b8154815290600101906020018083116115e057829003601f168201915b5050505050905090565b6000611611610c4d565b9050600061161f3384610d7e565b90503273ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff161461168f576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116869061413d565b60405180910390fd5b600d60009054906101000a900460ff166116de576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116d5906141a9565b60405180910390fd5b600a5483836116ed9190613fa9565b111561172e576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161172590614215565b60405180910390fd5b600c54831115611773576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161176a90614029565b60405180910390fd5b8034146117b5576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016117ac90614281565b60405180910390fd5b60006117bf612b7e565b80156117d757506002826117d39190613cba565b4710155b6117e25760006117f0565b6002826117ef9190613cba565b5b90503373ffffffffffffffffffffffffffffffffffffffff166108fc829081150290604051600060405180830381858888f19350505050158015611838573d6000803e3d6000fd5b5083601460003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008282546118889190613fa9565b925050819055506118993385612a9a565b50505050565b6118a7612294565b73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff160361190b576040517fb06307db00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b8060076000611918612294565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055508173ffffffffffffffffffffffffffffffffffffffff166119c5612294565b73ffffffffffffffffffffffffffffffffffffffff167f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c3183604051611a0a91906133c8565b60405180910390a35050565b611a21848484612357565b611a408373ffffffffffffffffffffffffffffffffffffffff166121b9565b8015611a555750611a5384848484612bc3565b155b15611a8c576040517fd1a57ed600000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b50505050565b6000600b54601460008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054108015611ae95750611ae882611ce2565b5b15611af75760019050611afc565b600090505b919050565b6060600d60019054906101000a900460ff1615611b9857611b2182612246565b611b60576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611b5790614313565b60405180910390fd5b611b68612d13565b611b7183612da5565b604051602001611b829291906143bb565b6040516020818303038152906040529050611c26565b600e8054611ba590613bba565b80601f0160208091040260200160405190810160405280929190818152602001828054611bd190613bba565b8015611c1e5780601f10611bf357610100808354040283529160200191611c1e565b820191906000526020600020905b815481529060010190602001808311611c0157829003601f168201915b505050505090505b919050565b611c33612294565b73ffffffffffffffffffffffffffffffffffffffff16611c5161154b565b73ffffffffffffffffffffffffffffffffffffffff1614611ca7576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611c9e90613c37565b60405180910390fd5b600d60009054906101000a900460ff1615600d60006101000a81548160ff021916908315150217905550565b60003411611ce057600080fd5b565b600080601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166370a08231846040518263ffffffff1660e01b8152600401611d409190613539565b602060405180830381865afa158015611d5d573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611d8191906143ff565b119050919050565b611d91612294565b73ffffffffffffffffffffffffffffffffffffffff16611daf61154b565b73ffffffffffffffffffffffffffffffffffffffff1614611e05576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611dfc90613c37565b60405180910390fd5b600a548110611e49576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611e4090614478565b60405180910390fd5b611e51610c4d565b811015611e93576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611e8a9061450a565b60405180910390fd5b80600a8190555050565b600a5481565b611eab612294565b73ffffffffffffffffffffffffffffffffffffffff16611ec961154b565b73ffffffffffffffffffffffffffffffffffffffff1614611f1f576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611f1690613c37565b60405180910390fd5b81600d60016101000a81548160ff02191690831515021790555080600e9081611f489190613ea8565b505050565b611f55612294565b73ffffffffffffffffffffffffffffffffffffffff16611f7361154b565b73ffffffffffffffffffffffffffffffffffffffff1614611fc9576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611fc090613c37565b60405180910390fd5b600a5482611fd5610c4d565b611fdf9190613fa9565b1115612020576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161201790614029565b60405180910390fd5b61202a8183612a9a565b5050565b6000600760008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16905092915050565b6120ca612294565b73ffffffffffffffffffffffffffffffffffffffff166120e861154b565b73ffffffffffffffffffffffffffffffffffffffff161461213e576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161213590613c37565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff16036121ad576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016121a49061459c565b60405180910390fd5b6121b681612ab8565b50565b6000808273ffffffffffffffffffffffffffffffffffffffff163b119050919050565b60007f01ffc9a7000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916149050919050565b60008161225161234e565b11158015612260575060005482105b801561228d575060046000838152602001908152602001600020600001601c9054906101000a900460ff16155b9050919050565b600033905090565b826006600084815260200190815260200160002060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550818373ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a4505050565b60006001905090565b60006123628261280b565b90508373ffffffffffffffffffffffffffffffffffffffff16816000015173ffffffffffffffffffffffffffffffffffffffff16146123cd576040517fa114810000000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60008473ffffffffffffffffffffffffffffffffffffffff166123ee612294565b73ffffffffffffffffffffffffffffffffffffffff16148061241d575061241c85612417612294565b61202e565b5b80612462575061242b612294565b73ffffffffffffffffffffffffffffffffffffffff1661244a84610ac1565b73ffffffffffffffffffffffffffffffffffffffff16145b90508061249b576040517f59c896be00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1603612501576040517fea553b3400000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b61250e8585856001612f05565b61251a6000848761229c565b6001600560008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160008282829054906101000a900467ffffffffffffffff160392506101000a81548167ffffffffffffffff021916908367ffffffffffffffff1602179055506001600560008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160008282829054906101000a900467ffffffffffffffff160192506101000a81548167ffffffffffffffff021916908367ffffffffffffffff1602179055506000600460008581526020019081526020016000209050848160000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550428160000160146101000a81548167ffffffffffffffff021916908367ffffffffffffffff16021790555060006001850190506000600460008381526020019081526020016000209050600073ffffffffffffffffffffffffffffffffffffffff168160000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff160361279957600054821461279857878160000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555084602001518160000160146101000a81548167ffffffffffffffff021916908367ffffffffffffffff1602179055505b5b505050828473ffffffffffffffffffffffffffffffffffffffff168673ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a46128048585856001612f0b565b5050505050565b6128136132d1565b60008290508061282161234e565b11158015612830575060005481105b15612a63576000600460008381526020019081526020016000206040518060600160405290816000820160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020016000820160149054906101000a900467ffffffffffffffff1667ffffffffffffffff1667ffffffffffffffff16815260200160008201601c9054906101000a900460ff16151515158152505090508060400151612a6157600073ffffffffffffffffffffffffffffffffffffffff16816000015173ffffffffffffffffffffffffffffffffffffffff1614612945578092505050612a95565b5b600115612a6057818060019003925050600460008381526020019081526020016000206040518060600160405290816000820160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020016000820160149054906101000a900467ffffffffffffffff1667ffffffffffffffff1667ffffffffffffffff16815260200160008201601c9054906101000a900460ff1615151515815250509050600073ffffffffffffffffffffffffffffffffffffffff16816000015173ffffffffffffffffffffffffffffffffffffffff1614612a5b578092505050612a95565b612946565b5b505b6040517fdf2d9b4200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b919050565b612ab4828260405180602001604052806000815250612f11565b5050565b6000600860009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905081600860006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b600080600a32444233604051602001612b9a9493929190614625565b6040516020818303038152906040528051906020012060001c612bbd9190614673565b14905090565b60008373ffffffffffffffffffffffffffffffffffffffff1663150b7a02612be9612294565b8786866040518563ffffffff1660e01b8152600401612c0b94939291906146f9565b6020604051808303816000875af1925050508015612c4757506040513d601f19601f82011682018060405250810190612c44919061475a565b60015b612cc0573d8060008114612c77576040519150601f19603f3d011682016040523d82523d6000602084013e612c7c565b606091505b506000815103612cb8576040517fd1a57ed600000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b805181602001fd5b63150b7a0260e01b7bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916817bffffffffffffffffffffffffffffffffffffffffffffffffffffffff191614915050949350505050565b6060600f8054612d2290613bba565b80601f0160208091040260200160405190810160405280929190818152602001828054612d4e90613bba565b8015612d9b5780601f10612d7057610100808354040283529160200191612d9b565b820191906000526020600020905b815481529060010190602001808311612d7e57829003601f168201915b5050505050905090565b606060008203612dec576040518060400160405280600181526020017f30000000000000000000000000000000000000000000000000000000000000008152509050612f00565b600082905060005b60008214612e1e578080612e0790614049565b915050600a82612e1791906140c0565b9150612df4565b60008167ffffffffffffffff811115612e3a57612e39613674565b5b6040519080825280601f01601f191660200182016040528015612e6c5781602001600182028036833780820191505090505b5090505b60008514612ef957600182612e859190613c86565b9150600a85612e949190614673565b6030612ea09190613fa9565b60f81b818381518110612eb657612eb5613f7a565b5b60200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a905350600a85612ef291906140c0565b9450612e70565b8093505050505b919050565b50505050565b50505050565b600080549050600073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1603612f7d576040517f2e07630000000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60008303612fb7576040517fb562e8dd00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b612fc46000858386612f05565b82600560008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160008282829054906101000a900467ffffffffffffffff160192506101000a81548167ffffffffffffffff021916908367ffffffffffffffff16021790555082600560008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160088282829054906101000a900467ffffffffffffffff160192506101000a81548167ffffffffffffffff021916908367ffffffffffffffff160217905550836004600083815260200190815260200160002060000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550426004600083815260200190815260200160002060000160146101000a81548167ffffffffffffffff021916908367ffffffffffffffff1602179055506000819050600084820190506131858673ffffffffffffffffffffffffffffffffffffffff166121b9565b1561324a575b818673ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a46131fa6000878480600101955087612bc3565b613230576040517fd1a57ed600000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b80820361318b57826000541461324557600080fd5b6132b5565b5b818060010192508673ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a480820361324b575b8160008190555050506132cb6000858386612f0b565b50505050565b6040518060600160405280600073ffffffffffffffffffffffffffffffffffffffff168152602001600067ffffffffffffffff1681526020016000151581525090565b6000604051905090565b600080fd5b600080fd5b60007fffffffff0000000000000000000000000000000000000000000000000000000082169050919050565b61335d81613328565b811461336857600080fd5b50565b60008135905061337a81613354565b92915050565b6000602082840312156133965761339561331e565b5b60006133a48482850161336b565b91505092915050565b60008115159050919050565b6133c2816133ad565b82525050565b60006020820190506133dd60008301846133b9565b92915050565b600081519050919050565b600082825260208201905092915050565b60005b8381101561341d578082015181840152602081019050613402565b60008484015250505050565b6000601f19601f8301169050919050565b6000613445826133e3565b61344f81856133ee565b935061345f8185602086016133ff565b61346881613429565b840191505092915050565b6000602082019050818103600083015261348d818461343a565b905092915050565b6000819050919050565b6134a881613495565b81146134b357600080fd5b50565b6000813590506134c58161349f565b92915050565b6000602082840312156134e1576134e061331e565b5b60006134ef848285016134b6565b91505092915050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000613523826134f8565b9050919050565b61353381613518565b82525050565b600060208201905061354e600083018461352a565b92915050565b61355d81613518565b811461356857600080fd5b50565b60008135905061357a81613554565b92915050565b600080604083850312156135975761359661331e565b5b60006135a58582860161356b565b92505060206135b6858286016134b6565b9150509250929050565b6135c981613495565b82525050565b60006020820190506135e460008301846135c0565b92915050565b6000806000606084860312156136035761360261331e565b5b60006136118682870161356b565b93505060206136228682870161356b565b9250506040613633868287016134b6565b9150509250925092565b6000602082840312156136535761365261331e565b5b60006136618482850161356b565b91505092915050565b600080fd5b600080fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b6136ac82613429565b810181811067ffffffffffffffff821117156136cb576136ca613674565b5b80604052505050565b60006136de613314565b90506136ea82826136a3565b919050565b600067ffffffffffffffff82111561370a57613709613674565b5b61371382613429565b9050602081019050919050565b82818337600083830152505050565b600061374261373d846136ef565b6136d4565b90508281526020810184848401111561375e5761375d61366f565b5b613769848285613720565b509392505050565b600082601f8301126137865761378561366a565b5b813561379684826020860161372f565b91505092915050565b6000602082840312156137b5576137b461331e565b5b600082013567ffffffffffffffff8111156137d3576137d2613323565b5b6137df84828501613771565b91505092915050565b600080fd5b600080fd5b60008083601f8401126138085761380761366a565b5b8235905067ffffffffffffffff811115613825576138246137e8565b5b602083019150836020820283011115613841576138406137ed565b5b9250929050565b60008083601f84011261385e5761385d61366a565b5b8235905067ffffffffffffffff81111561387b5761387a6137e8565b5b602083019150836020820283011115613897576138966137ed565b5b9250929050565b600080600080604085870312156138b8576138b761331e565b5b600085013567ffffffffffffffff8111156138d6576138d5613323565b5b6138e2878288016137f2565b9450945050602085013567ffffffffffffffff81111561390557613904613323565b5b61391187828801613848565b925092505092959194509250565b613928816133ad565b811461393357600080fd5b50565b6000813590506139458161391f565b92915050565b600080604083850312156139625761396161331e565b5b60006139708582860161356b565b925050602061398185828601613936565b9150509250929050565b600067ffffffffffffffff8211156139a6576139a5613674565b5b6139af82613429565b9050602081019050919050565b60006139cf6139ca8461398b565b6136d4565b9050828152602081018484840111156139eb576139ea61366f565b5b6139f6848285613720565b509392505050565b600082601f830112613a1357613a1261366a565b5b8135613a238482602086016139bc565b91505092915050565b60008060008060808587031215613a4657613a4561331e565b5b6000613a548782880161356b565b9450506020613a658782880161356b565b9350506040613a76878288016134b6565b925050606085013567ffffffffffffffff811115613a9757613a96613323565b5b613aa3878288016139fe565b91505092959194509250565b60008060408385031215613ac657613ac561331e565b5b6000613ad485828601613936565b925050602083013567ffffffffffffffff811115613af557613af4613323565b5b613b0185828601613771565b9150509250929050565b60008060408385031215613b2257613b2161331e565b5b6000613b30858286016134b6565b9250506020613b418582860161356b565b9150509250929050565b60008060408385031215613b6257613b6161331e565b5b6000613b708582860161356b565b9250506020613b818582860161356b565b9150509250929050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b60006002820490506001821680613bd257607f821691505b602082108103613be557613be4613b8b565b5b50919050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572600082015250565b6000613c216020836133ee565b9150613c2c82613beb565b602082019050919050565b60006020820190508181036000830152613c5081613c14565b9050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b6000613c9182613495565b9150613c9c83613495565b9250828203905081811115613cb457613cb3613c57565b5b92915050565b6000613cc582613495565b9150613cd083613495565b9250828202613cde81613495565b91508282048414831517613cf557613cf4613c57565b5b5092915050565b60008190508160005260206000209050919050565b60006020601f8301049050919050565b600082821b905092915050565b600060088302613d5e7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff82613d21565b613d688683613d21565b95508019841693508086168417925050509392505050565b6000819050919050565b6000613da5613da0613d9b84613495565b613d80565b613495565b9050919050565b6000819050919050565b613dbf83613d8a565b613dd3613dcb82613dac565b848454613d2e565b825550505050565b600090565b613de8613ddb565b613df3818484613db6565b505050565b5b81811015613e1757613e0c600082613de0565b600181019050613df9565b5050565b601f821115613e5c57613e2d81613cfc565b613e3684613d11565b81016020851015613e45578190505b613e59613e5185613d11565b830182613df8565b50505b505050565b600082821c905092915050565b6000613e7f60001984600802613e61565b1980831691505092915050565b6000613e988383613e6e565b9150826002028217905092915050565b613eb1826133e3565b67ffffffffffffffff811115613eca57613ec9613674565b5b613ed48254613bba565b613edf828285613e1b565b600060209050601f831160018114613f125760008415613f00578287015190505b613f0a8582613e8c565b865550613f72565b601f198416613f2086613cfc565b60005b82811015613f4857848901518255600182019150602085019450602081019050613f23565b86831015613f655784890151613f61601f891682613e6e565b8355505b6001600288020188555050505b505050505050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b6000613fb482613495565b9150613fbf83613495565b9250828201905080821115613fd757613fd6613c57565b5b92915050565b7f546f6f206d616e79000000000000000000000000000000000000000000000000600082015250565b60006140136008836133ee565b915061401e82613fdd565b602082019050919050565b6000602082019050818103600083015261404281614006565b9050919050565b600061405482613495565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff820361408657614085613c57565b5b600182019050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b60006140cb82613495565b91506140d683613495565b9250826140e6576140e5614091565b5b828204905092915050565b7f4e6f20636f6e7472616374732100000000000000000000000000000000000000600082015250565b6000614127600d836133ee565b9150614132826140f1565b602082019050919050565b600060208201905081810360008301526141568161411a565b9050919050565b7f4e6f742079657400000000000000000000000000000000000000000000000000600082015250565b60006141936007836133ee565b915061419e8261415d565b602082019050919050565b600060208201905081810360008301526141c281614186565b9050919050565b7f576f756c642065786363656420737570706c7900000000000000000000000000600082015250565b60006141ff6013836133ee565b915061420a826141c9565b602082019050919050565b6000602082019050818103600083015261422e816141f2565b9050919050565b7f57726f6e6720616d6f756e740000000000000000000000000000000000000000600082015250565b600061426b600c836133ee565b915061427682614235565b602082019050919050565b6000602082019050818103600083015261429a8161425e565b9050919050565b7f4552433732314d657461646174613a2055524920717565727920666f72206e6f60008201527f6e6578697374656e7420746f6b656e0000000000000000000000000000000000602082015250565b60006142fd602f836133ee565b9150614308826142a1565b604082019050919050565b6000602082019050818103600083015261432c816142f0565b9050919050565b600081905092915050565b6000614349826133e3565b6143538185614333565b93506143638185602086016133ff565b80840191505092915050565b7f2e6a736f6e000000000000000000000000000000000000000000000000000000600082015250565b60006143a5600583614333565b91506143b08261436f565b600582019050919050565b60006143c7828561433e565b91506143d3828461433e565b91506143de82614398565b91508190509392505050565b6000815190506143f98161349f565b92915050565b6000602082840312156144155761441461331e565b5b6000614423848285016143ea565b91505092915050565b7f537570706c792063616e206f6e6c792064656372656173650000000000000000600082015250565b60006144626018836133ee565b915061446d8261442c565b602082019050919050565b6000602082019050818103600083015261449181614455565b9050919050565b7f43616e2774206265206c657373207468616e2063757272656e7420737570706c60008201527f7900000000000000000000000000000000000000000000000000000000000000602082015250565b60006144f46021836133ee565b91506144ff82614498565b604082019050919050565b60006020820190508181036000830152614523816144e7565b9050919050565b7f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160008201527f6464726573730000000000000000000000000000000000000000000000000000602082015250565b60006145866026836133ee565b91506145918261452a565b604082019050919050565b600060208201905081810360008301526145b581614579565b9050919050565b60008160601b9050919050565b60006145d4826145bc565b9050919050565b60006145e6826145c9565b9050919050565b6145fe6145f982613518565b6145db565b82525050565b6000819050919050565b61461f61461a82613495565b614604565b82525050565b600061463182876145ed565b601482019150614641828661460e565b602082019150614651828561460e565b60208201915061466182846145ed565b60148201915081905095945050505050565b600061467e82613495565b915061468983613495565b92508261469957614698614091565b5b828206905092915050565b600081519050919050565b600082825260208201905092915050565b60006146cb826146a4565b6146d581856146af565b93506146e58185602086016133ff565b6146ee81613429565b840191505092915050565b600060808201905061470e600083018761352a565b61471b602083018661352a565b61472860408301856135c0565b818103606083015261473a81846146c0565b905095945050505050565b60008151905061475481613354565b92915050565b6000602082840312156147705761476f61331e565b5b600061477e84828501614745565b9150509291505056fea2646970667358221220ba1f0c595fb23c76d31c549ea57be457549d99c4bcbfa2233cc404352190cd7d64736f6c63430008110033

Deployed Bytecode

0x6080604052600436106102465760003560e01c806370a0823111610139578063bf3506c1116100b6578063d595c3311161007a578063d595c33114610841578063d5abeb011461086a578063d7b2326814610895578063dc926843146108be578063e985e9c5146108e7578063f2fde38b1461092457610246565b8063bf3506c114610769578063c87b56dd146107a6578063ce03ec93146107e3578063d0e30db0146107fa578063d4d7b19a1461080457610246565b80638da5cb5b116100fd5780638da5cb5b146106a557806395d89b41146106d0578063a0712d68146106fb578063a22cb46514610717578063b88d4fde1461074057610246565b806370a08231146105f3578063715018a61461063057806372212abf146106475780637501f74114610670578063853828b61461069b57610246565b806342842e0e116101c757806355f804b31161018b57806355f804b31461050e57806358043ced146105375780635b74efcf146105625780636352211e1461058d5780636d8be05a146105ca57610246565b806342842e0e1461042b57806344a0d68a14610454578063518302271461047d57806352ea4f77146104a857806353630745146104e557610246565b806318160ddd1161020e57806318160ddd146103445780631a1feb921461036f578063200d2ed21461039a57806323b872dd146103c55780633ca63f2c146103ee57610246565b806301ffc9a71461024b57806306fdde0314610288578063081812fc146102b3578063095ea7b3146102f057806313faede614610319575b600080fd5b34801561025757600080fd5b50610272600480360381019061026d9190613380565b61094d565b60405161027f91906133c8565b60405180910390f35b34801561029457600080fd5b5061029d610a2f565b6040516102aa9190613473565b60405180910390f35b3480156102bf57600080fd5b506102da60048036038101906102d591906134cb565b610ac1565b6040516102e79190613539565b60405180910390f35b3480156102fc57600080fd5b5061031760048036038101906103129190613580565b610b3d565b005b34801561032557600080fd5b5061032e610c47565b60405161033b91906135cf565b60405180910390f35b34801561035057600080fd5b50610359610c4d565b60405161036691906135cf565b60405180910390f35b34801561037b57600080fd5b50610384610c64565b6040516103919190613539565b60405180910390f35b3480156103a657600080fd5b506103af610c8a565b6040516103bc91906133c8565b60405180910390f35b3480156103d157600080fd5b506103ec60048036038101906103e791906135ea565b610c9d565b005b3480156103fa57600080fd5b506104156004803603810190610410919061363d565b610cad565b60405161042291906135cf565b60405180910390f35b34801561043757600080fd5b50610452600480360381019061044d91906135ea565b610cc5565b005b34801561046057600080fd5b5061047b600480360381019061047691906134cb565b610ce5565b005b34801561048957600080fd5b50610492610d6b565b60405161049f91906133c8565b60405180910390f35b3480156104b457600080fd5b506104cf60048036038101906104ca9190613580565b610d7e565b6040516104dc91906135cf565b60405180910390f35b3480156104f157600080fd5b5061050c600480360381019061050791906134cb565b610e3d565b005b34801561051a57600080fd5b506105356004803603810190610530919061379f565b610ec3565b005b34801561054357600080fd5b5061054c610f52565b6040516105599190613473565b60405180910390f35b34801561056e57600080fd5b50610577610fe0565b60405161058491906135cf565b60405180910390f35b34801561059957600080fd5b506105b460048036038101906105af91906134cb565b610fe6565b6040516105c19190613539565b60405180910390f35b3480156105d657600080fd5b506105f160048036038101906105ec919061389e565b610ffc565b005b3480156105ff57600080fd5b5061061a6004803603810190610615919061363d565b61115a565b60405161062791906135cf565b60405180910390f35b34801561063c57600080fd5b50610645611229565b005b34801561065357600080fd5b5061066e6004803603810190610669919061363d565b6112b1565b005b34801561067c57600080fd5b50610685611371565b60405161069291906135cf565b60405180910390f35b6106a3611377565b005b3480156106b157600080fd5b506106ba61154b565b6040516106c79190613539565b60405180910390f35b3480156106dc57600080fd5b506106e5611575565b6040516106f29190613473565b60405180910390f35b610715600480360381019061071091906134cb565b611607565b005b34801561072357600080fd5b5061073e6004803603810190610739919061394b565b61189f565b005b34801561074c57600080fd5b5061076760048036038101906107629190613a2c565b611a16565b005b34801561077557600080fd5b50610790600480360381019061078b919061363d565b611a92565b60405161079d91906133c8565b60405180910390f35b3480156107b257600080fd5b506107cd60048036038101906107c891906134cb565b611b01565b6040516107da9190613473565b60405180910390f35b3480156107ef57600080fd5b506107f8611c2b565b005b610802611cd3565b005b34801561081057600080fd5b5061082b6004803603810190610826919061363d565b611ce2565b60405161083891906133c8565b60405180910390f35b34801561084d57600080fd5b50610868600480360381019061086391906134cb565b611d89565b005b34801561087657600080fd5b5061087f611e9d565b60405161088c91906135cf565b60405180910390f35b3480156108a157600080fd5b506108bc60048036038101906108b79190613aaf565b611ea3565b005b3480156108ca57600080fd5b506108e560048036038101906108e09190613b0b565b611f4d565b005b3480156108f357600080fd5b5061090e60048036038101906109099190613b4b565b61202e565b60405161091b91906133c8565b60405180910390f35b34801561093057600080fd5b5061094b6004803603810190610946919061363d565b6120c2565b005b60007f80ac58cd000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19161480610a1857507f5b5e139f000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916145b80610a285750610a27826121dc565b5b9050919050565b606060028054610a3e90613bba565b80601f0160208091040260200160405190810160405280929190818152602001828054610a6a90613bba565b8015610ab75780601f10610a8c57610100808354040283529160200191610ab7565b820191906000526020600020905b815481529060010190602001808311610a9a57829003601f168201915b5050505050905090565b6000610acc82612246565b610b02576040517fcf4700e400000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6006600083815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050919050565b6000610b4882610fe6565b90508073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603610baf576040517f943f7b8c00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b8073ffffffffffffffffffffffffffffffffffffffff16610bce612294565b73ffffffffffffffffffffffffffffffffffffffff1614158015610c005750610bfe81610bf9612294565b61202e565b155b15610c37576040517fcfb3b94200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b610c4283838361229c565b505050565b60095481565b6000610c5761234e565b6001546000540303905090565b601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b600d60009054906101000a900460ff1681565b610ca8838383612357565b505050565b60146020528060005260406000206000915090505481565b610ce083838360405180602001604052806000815250611a16565b505050565b610ced612294565b73ffffffffffffffffffffffffffffffffffffffff16610d0b61154b565b73ffffffffffffffffffffffffffffffffffffffff1614610d61576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d5890613c37565b60405180910390fd5b8060098190555050565b600d60019054906101000a900460ff1681565b600080601460008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205490506000610dce85611a92565b90508015610e245781600b54610de49190613c86565b8411610df557600092505050610e37565b81600b54610e039190613c86565b84610e0e9190613c86565b600954610e1b9190613cba565b92505050610e37565b83600954610e329190613cba565b925050505b92915050565b610e45612294565b73ffffffffffffffffffffffffffffffffffffffff16610e6361154b565b73ffffffffffffffffffffffffffffffffffffffff1614610eb9576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610eb090613c37565b60405180910390fd5b80600b8190555050565b610ecb612294565b73ffffffffffffffffffffffffffffffffffffffff16610ee961154b565b73ffffffffffffffffffffffffffffffffffffffff1614610f3f576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610f3690613c37565b60405180910390fd5b80600f9081610f4e9190613ea8565b5050565b600e8054610f5f90613bba565b80601f0160208091040260200160405190810160405280929190818152602001828054610f8b90613bba565b8015610fd85780601f10610fad57610100808354040283529160200191610fd8565b820191906000526020600020905b815481529060010190602001808311610fbb57829003601f168201915b505050505081565b600b5481565b6000610ff18261280b565b600001519050919050565b611004612294565b73ffffffffffffffffffffffffffffffffffffffff1661102261154b565b73ffffffffffffffffffffffffffffffffffffffff1614611078576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161106f90613c37565b60405180910390fd5b60005b8484905081101561115357600a5483838381811061109c5761109b613f7a565b5b905060200201356110ab610c4d565b6110b59190613fa9565b11156110f6576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016110ed90614029565b60405180910390fd5b61114085858381811061110c5761110b613f7a565b5b9050602002016020810190611121919061363d565b84848481811061113457611133613f7a565b5b90506020020135612a9a565b808061114b90614049565b91505061107b565b5050505050565b60008073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036111c1576040517f8f4eb60400000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b600560008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160009054906101000a900467ffffffffffffffff1667ffffffffffffffff169050919050565b611231612294565b73ffffffffffffffffffffffffffffffffffffffff1661124f61154b565b73ffffffffffffffffffffffffffffffffffffffff16146112a5576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161129c90613c37565b60405180910390fd5b6112af6000612ab8565b565b6112b9612294565b73ffffffffffffffffffffffffffffffffffffffff166112d761154b565b73ffffffffffffffffffffffffffffffffffffffff161461132d576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161132490613c37565b60405180910390fd5b80601360006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b600c5481565b61137f612294565b73ffffffffffffffffffffffffffffffffffffffff1661139d61154b565b73ffffffffffffffffffffffffffffffffffffffff16146113f3576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016113ea90613c37565b60405180910390fd5b600060644761140291906140c0565b9050601060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc60228361144d9190613cba565b9081150290604051600060405180830381858888f1935050505061147057600080fd5b601160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc6021836114b99190613cba565b9081150290604051600060405180830381858888f193505050506114dc57600080fd5b601160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc6021836115259190613cba565b9081150290604051600060405180830381858888f1935050505061154857600080fd5b50565b6000600860009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60606003805461158490613bba565b80601f01602080910402602001604051908101604052809291908181526020018280546115b090613bba565b80156115fd5780601f106115d2576101008083540402835291602001916115fd565b820191906000526020600020905b8154815290600101906020018083116115e057829003601f168201915b5050505050905090565b6000611611610c4d565b9050600061161f3384610d7e565b90503273ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff161461168f576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116869061413d565b60405180910390fd5b600d60009054906101000a900460ff166116de576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116d5906141a9565b60405180910390fd5b600a5483836116ed9190613fa9565b111561172e576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161172590614215565b60405180910390fd5b600c54831115611773576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161176a90614029565b60405180910390fd5b8034146117b5576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016117ac90614281565b60405180910390fd5b60006117bf612b7e565b80156117d757506002826117d39190613cba565b4710155b6117e25760006117f0565b6002826117ef9190613cba565b5b90503373ffffffffffffffffffffffffffffffffffffffff166108fc829081150290604051600060405180830381858888f19350505050158015611838573d6000803e3d6000fd5b5083601460003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008282546118889190613fa9565b925050819055506118993385612a9a565b50505050565b6118a7612294565b73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff160361190b576040517fb06307db00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b8060076000611918612294565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055508173ffffffffffffffffffffffffffffffffffffffff166119c5612294565b73ffffffffffffffffffffffffffffffffffffffff167f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c3183604051611a0a91906133c8565b60405180910390a35050565b611a21848484612357565b611a408373ffffffffffffffffffffffffffffffffffffffff166121b9565b8015611a555750611a5384848484612bc3565b155b15611a8c576040517fd1a57ed600000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b50505050565b6000600b54601460008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054108015611ae95750611ae882611ce2565b5b15611af75760019050611afc565b600090505b919050565b6060600d60019054906101000a900460ff1615611b9857611b2182612246565b611b60576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611b5790614313565b60405180910390fd5b611b68612d13565b611b7183612da5565b604051602001611b829291906143bb565b6040516020818303038152906040529050611c26565b600e8054611ba590613bba565b80601f0160208091040260200160405190810160405280929190818152602001828054611bd190613bba565b8015611c1e5780601f10611bf357610100808354040283529160200191611c1e565b820191906000526020600020905b815481529060010190602001808311611c0157829003601f168201915b505050505090505b919050565b611c33612294565b73ffffffffffffffffffffffffffffffffffffffff16611c5161154b565b73ffffffffffffffffffffffffffffffffffffffff1614611ca7576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611c9e90613c37565b60405180910390fd5b600d60009054906101000a900460ff1615600d60006101000a81548160ff021916908315150217905550565b60003411611ce057600080fd5b565b600080601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166370a08231846040518263ffffffff1660e01b8152600401611d409190613539565b602060405180830381865afa158015611d5d573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611d8191906143ff565b119050919050565b611d91612294565b73ffffffffffffffffffffffffffffffffffffffff16611daf61154b565b73ffffffffffffffffffffffffffffffffffffffff1614611e05576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611dfc90613c37565b60405180910390fd5b600a548110611e49576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611e4090614478565b60405180910390fd5b611e51610c4d565b811015611e93576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611e8a9061450a565b60405180910390fd5b80600a8190555050565b600a5481565b611eab612294565b73ffffffffffffffffffffffffffffffffffffffff16611ec961154b565b73ffffffffffffffffffffffffffffffffffffffff1614611f1f576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611f1690613c37565b60405180910390fd5b81600d60016101000a81548160ff02191690831515021790555080600e9081611f489190613ea8565b505050565b611f55612294565b73ffffffffffffffffffffffffffffffffffffffff16611f7361154b565b73ffffffffffffffffffffffffffffffffffffffff1614611fc9576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611fc090613c37565b60405180910390fd5b600a5482611fd5610c4d565b611fdf9190613fa9565b1115612020576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161201790614029565b60405180910390fd5b61202a8183612a9a565b5050565b6000600760008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16905092915050565b6120ca612294565b73ffffffffffffffffffffffffffffffffffffffff166120e861154b565b73ffffffffffffffffffffffffffffffffffffffff161461213e576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161213590613c37565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff16036121ad576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016121a49061459c565b60405180910390fd5b6121b681612ab8565b50565b6000808273ffffffffffffffffffffffffffffffffffffffff163b119050919050565b60007f01ffc9a7000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916149050919050565b60008161225161234e565b11158015612260575060005482105b801561228d575060046000838152602001908152602001600020600001601c9054906101000a900460ff16155b9050919050565b600033905090565b826006600084815260200190815260200160002060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550818373ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a4505050565b60006001905090565b60006123628261280b565b90508373ffffffffffffffffffffffffffffffffffffffff16816000015173ffffffffffffffffffffffffffffffffffffffff16146123cd576040517fa114810000000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60008473ffffffffffffffffffffffffffffffffffffffff166123ee612294565b73ffffffffffffffffffffffffffffffffffffffff16148061241d575061241c85612417612294565b61202e565b5b80612462575061242b612294565b73ffffffffffffffffffffffffffffffffffffffff1661244a84610ac1565b73ffffffffffffffffffffffffffffffffffffffff16145b90508061249b576040517f59c896be00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1603612501576040517fea553b3400000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b61250e8585856001612f05565b61251a6000848761229c565b6001600560008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160008282829054906101000a900467ffffffffffffffff160392506101000a81548167ffffffffffffffff021916908367ffffffffffffffff1602179055506001600560008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160008282829054906101000a900467ffffffffffffffff160192506101000a81548167ffffffffffffffff021916908367ffffffffffffffff1602179055506000600460008581526020019081526020016000209050848160000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550428160000160146101000a81548167ffffffffffffffff021916908367ffffffffffffffff16021790555060006001850190506000600460008381526020019081526020016000209050600073ffffffffffffffffffffffffffffffffffffffff168160000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff160361279957600054821461279857878160000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555084602001518160000160146101000a81548167ffffffffffffffff021916908367ffffffffffffffff1602179055505b5b505050828473ffffffffffffffffffffffffffffffffffffffff168673ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a46128048585856001612f0b565b5050505050565b6128136132d1565b60008290508061282161234e565b11158015612830575060005481105b15612a63576000600460008381526020019081526020016000206040518060600160405290816000820160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020016000820160149054906101000a900467ffffffffffffffff1667ffffffffffffffff1667ffffffffffffffff16815260200160008201601c9054906101000a900460ff16151515158152505090508060400151612a6157600073ffffffffffffffffffffffffffffffffffffffff16816000015173ffffffffffffffffffffffffffffffffffffffff1614612945578092505050612a95565b5b600115612a6057818060019003925050600460008381526020019081526020016000206040518060600160405290816000820160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020016000820160149054906101000a900467ffffffffffffffff1667ffffffffffffffff1667ffffffffffffffff16815260200160008201601c9054906101000a900460ff1615151515815250509050600073ffffffffffffffffffffffffffffffffffffffff16816000015173ffffffffffffffffffffffffffffffffffffffff1614612a5b578092505050612a95565b612946565b5b505b6040517fdf2d9b4200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b919050565b612ab4828260405180602001604052806000815250612f11565b5050565b6000600860009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905081600860006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b600080600a32444233604051602001612b9a9493929190614625565b6040516020818303038152906040528051906020012060001c612bbd9190614673565b14905090565b60008373ffffffffffffffffffffffffffffffffffffffff1663150b7a02612be9612294565b8786866040518563ffffffff1660e01b8152600401612c0b94939291906146f9565b6020604051808303816000875af1925050508015612c4757506040513d601f19601f82011682018060405250810190612c44919061475a565b60015b612cc0573d8060008114612c77576040519150601f19603f3d011682016040523d82523d6000602084013e612c7c565b606091505b506000815103612cb8576040517fd1a57ed600000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b805181602001fd5b63150b7a0260e01b7bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916817bffffffffffffffffffffffffffffffffffffffffffffffffffffffff191614915050949350505050565b6060600f8054612d2290613bba565b80601f0160208091040260200160405190810160405280929190818152602001828054612d4e90613bba565b8015612d9b5780601f10612d7057610100808354040283529160200191612d9b565b820191906000526020600020905b815481529060010190602001808311612d7e57829003601f168201915b5050505050905090565b606060008203612dec576040518060400160405280600181526020017f30000000000000000000000000000000000000000000000000000000000000008152509050612f00565b600082905060005b60008214612e1e578080612e0790614049565b915050600a82612e1791906140c0565b9150612df4565b60008167ffffffffffffffff811115612e3a57612e39613674565b5b6040519080825280601f01601f191660200182016040528015612e6c5781602001600182028036833780820191505090505b5090505b60008514612ef957600182612e859190613c86565b9150600a85612e949190614673565b6030612ea09190613fa9565b60f81b818381518110612eb657612eb5613f7a565b5b60200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a905350600a85612ef291906140c0565b9450612e70565b8093505050505b919050565b50505050565b50505050565b600080549050600073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1603612f7d576040517f2e07630000000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60008303612fb7576040517fb562e8dd00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b612fc46000858386612f05565b82600560008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160008282829054906101000a900467ffffffffffffffff160192506101000a81548167ffffffffffffffff021916908367ffffffffffffffff16021790555082600560008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160088282829054906101000a900467ffffffffffffffff160192506101000a81548167ffffffffffffffff021916908367ffffffffffffffff160217905550836004600083815260200190815260200160002060000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550426004600083815260200190815260200160002060000160146101000a81548167ffffffffffffffff021916908367ffffffffffffffff1602179055506000819050600084820190506131858673ffffffffffffffffffffffffffffffffffffffff166121b9565b1561324a575b818673ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a46131fa6000878480600101955087612bc3565b613230576040517fd1a57ed600000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b80820361318b57826000541461324557600080fd5b6132b5565b5b818060010192508673ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a480820361324b575b8160008190555050506132cb6000858386612f0b565b50505050565b6040518060600160405280600073ffffffffffffffffffffffffffffffffffffffff168152602001600067ffffffffffffffff1681526020016000151581525090565b6000604051905090565b600080fd5b600080fd5b60007fffffffff0000000000000000000000000000000000000000000000000000000082169050919050565b61335d81613328565b811461336857600080fd5b50565b60008135905061337a81613354565b92915050565b6000602082840312156133965761339561331e565b5b60006133a48482850161336b565b91505092915050565b60008115159050919050565b6133c2816133ad565b82525050565b60006020820190506133dd60008301846133b9565b92915050565b600081519050919050565b600082825260208201905092915050565b60005b8381101561341d578082015181840152602081019050613402565b60008484015250505050565b6000601f19601f8301169050919050565b6000613445826133e3565b61344f81856133ee565b935061345f8185602086016133ff565b61346881613429565b840191505092915050565b6000602082019050818103600083015261348d818461343a565b905092915050565b6000819050919050565b6134a881613495565b81146134b357600080fd5b50565b6000813590506134c58161349f565b92915050565b6000602082840312156134e1576134e061331e565b5b60006134ef848285016134b6565b91505092915050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000613523826134f8565b9050919050565b61353381613518565b82525050565b600060208201905061354e600083018461352a565b92915050565b61355d81613518565b811461356857600080fd5b50565b60008135905061357a81613554565b92915050565b600080604083850312156135975761359661331e565b5b60006135a58582860161356b565b92505060206135b6858286016134b6565b9150509250929050565b6135c981613495565b82525050565b60006020820190506135e460008301846135c0565b92915050565b6000806000606084860312156136035761360261331e565b5b60006136118682870161356b565b93505060206136228682870161356b565b9250506040613633868287016134b6565b9150509250925092565b6000602082840312156136535761365261331e565b5b60006136618482850161356b565b91505092915050565b600080fd5b600080fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b6136ac82613429565b810181811067ffffffffffffffff821117156136cb576136ca613674565b5b80604052505050565b60006136de613314565b90506136ea82826136a3565b919050565b600067ffffffffffffffff82111561370a57613709613674565b5b61371382613429565b9050602081019050919050565b82818337600083830152505050565b600061374261373d846136ef565b6136d4565b90508281526020810184848401111561375e5761375d61366f565b5b613769848285613720565b509392505050565b600082601f8301126137865761378561366a565b5b813561379684826020860161372f565b91505092915050565b6000602082840312156137b5576137b461331e565b5b600082013567ffffffffffffffff8111156137d3576137d2613323565b5b6137df84828501613771565b91505092915050565b600080fd5b600080fd5b60008083601f8401126138085761380761366a565b5b8235905067ffffffffffffffff811115613825576138246137e8565b5b602083019150836020820283011115613841576138406137ed565b5b9250929050565b60008083601f84011261385e5761385d61366a565b5b8235905067ffffffffffffffff81111561387b5761387a6137e8565b5b602083019150836020820283011115613897576138966137ed565b5b9250929050565b600080600080604085870312156138b8576138b761331e565b5b600085013567ffffffffffffffff8111156138d6576138d5613323565b5b6138e2878288016137f2565b9450945050602085013567ffffffffffffffff81111561390557613904613323565b5b61391187828801613848565b925092505092959194509250565b613928816133ad565b811461393357600080fd5b50565b6000813590506139458161391f565b92915050565b600080604083850312156139625761396161331e565b5b60006139708582860161356b565b925050602061398185828601613936565b9150509250929050565b600067ffffffffffffffff8211156139a6576139a5613674565b5b6139af82613429565b9050602081019050919050565b60006139cf6139ca8461398b565b6136d4565b9050828152602081018484840111156139eb576139ea61366f565b5b6139f6848285613720565b509392505050565b600082601f830112613a1357613a1261366a565b5b8135613a238482602086016139bc565b91505092915050565b60008060008060808587031215613a4657613a4561331e565b5b6000613a548782880161356b565b9450506020613a658782880161356b565b9350506040613a76878288016134b6565b925050606085013567ffffffffffffffff811115613a9757613a96613323565b5b613aa3878288016139fe565b91505092959194509250565b60008060408385031215613ac657613ac561331e565b5b6000613ad485828601613936565b925050602083013567ffffffffffffffff811115613af557613af4613323565b5b613b0185828601613771565b9150509250929050565b60008060408385031215613b2257613b2161331e565b5b6000613b30858286016134b6565b9250506020613b418582860161356b565b9150509250929050565b60008060408385031215613b6257613b6161331e565b5b6000613b708582860161356b565b9250506020613b818582860161356b565b9150509250929050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b60006002820490506001821680613bd257607f821691505b602082108103613be557613be4613b8b565b5b50919050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572600082015250565b6000613c216020836133ee565b9150613c2c82613beb565b602082019050919050565b60006020820190508181036000830152613c5081613c14565b9050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b6000613c9182613495565b9150613c9c83613495565b9250828203905081811115613cb457613cb3613c57565b5b92915050565b6000613cc582613495565b9150613cd083613495565b9250828202613cde81613495565b91508282048414831517613cf557613cf4613c57565b5b5092915050565b60008190508160005260206000209050919050565b60006020601f8301049050919050565b600082821b905092915050565b600060088302613d5e7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff82613d21565b613d688683613d21565b95508019841693508086168417925050509392505050565b6000819050919050565b6000613da5613da0613d9b84613495565b613d80565b613495565b9050919050565b6000819050919050565b613dbf83613d8a565b613dd3613dcb82613dac565b848454613d2e565b825550505050565b600090565b613de8613ddb565b613df3818484613db6565b505050565b5b81811015613e1757613e0c600082613de0565b600181019050613df9565b5050565b601f821115613e5c57613e2d81613cfc565b613e3684613d11565b81016020851015613e45578190505b613e59613e5185613d11565b830182613df8565b50505b505050565b600082821c905092915050565b6000613e7f60001984600802613e61565b1980831691505092915050565b6000613e988383613e6e565b9150826002028217905092915050565b613eb1826133e3565b67ffffffffffffffff811115613eca57613ec9613674565b5b613ed48254613bba565b613edf828285613e1b565b600060209050601f831160018114613f125760008415613f00578287015190505b613f0a8582613e8c565b865550613f72565b601f198416613f2086613cfc565b60005b82811015613f4857848901518255600182019150602085019450602081019050613f23565b86831015613f655784890151613f61601f891682613e6e565b8355505b6001600288020188555050505b505050505050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b6000613fb482613495565b9150613fbf83613495565b9250828201905080821115613fd757613fd6613c57565b5b92915050565b7f546f6f206d616e79000000000000000000000000000000000000000000000000600082015250565b60006140136008836133ee565b915061401e82613fdd565b602082019050919050565b6000602082019050818103600083015261404281614006565b9050919050565b600061405482613495565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff820361408657614085613c57565b5b600182019050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b60006140cb82613495565b91506140d683613495565b9250826140e6576140e5614091565b5b828204905092915050565b7f4e6f20636f6e7472616374732100000000000000000000000000000000000000600082015250565b6000614127600d836133ee565b9150614132826140f1565b602082019050919050565b600060208201905081810360008301526141568161411a565b9050919050565b7f4e6f742079657400000000000000000000000000000000000000000000000000600082015250565b60006141936007836133ee565b915061419e8261415d565b602082019050919050565b600060208201905081810360008301526141c281614186565b9050919050565b7f576f756c642065786363656420737570706c7900000000000000000000000000600082015250565b60006141ff6013836133ee565b915061420a826141c9565b602082019050919050565b6000602082019050818103600083015261422e816141f2565b9050919050565b7f57726f6e6720616d6f756e740000000000000000000000000000000000000000600082015250565b600061426b600c836133ee565b915061427682614235565b602082019050919050565b6000602082019050818103600083015261429a8161425e565b9050919050565b7f4552433732314d657461646174613a2055524920717565727920666f72206e6f60008201527f6e6578697374656e7420746f6b656e0000000000000000000000000000000000602082015250565b60006142fd602f836133ee565b9150614308826142a1565b604082019050919050565b6000602082019050818103600083015261432c816142f0565b9050919050565b600081905092915050565b6000614349826133e3565b6143538185614333565b93506143638185602086016133ff565b80840191505092915050565b7f2e6a736f6e000000000000000000000000000000000000000000000000000000600082015250565b60006143a5600583614333565b91506143b08261436f565b600582019050919050565b60006143c7828561433e565b91506143d3828461433e565b91506143de82614398565b91508190509392505050565b6000815190506143f98161349f565b92915050565b6000602082840312156144155761441461331e565b5b6000614423848285016143ea565b91505092915050565b7f537570706c792063616e206f6e6c792064656372656173650000000000000000600082015250565b60006144626018836133ee565b915061446d8261442c565b602082019050919050565b6000602082019050818103600083015261449181614455565b9050919050565b7f43616e2774206265206c657373207468616e2063757272656e7420737570706c60008201527f7900000000000000000000000000000000000000000000000000000000000000602082015250565b60006144f46021836133ee565b91506144ff82614498565b604082019050919050565b60006020820190508181036000830152614523816144e7565b9050919050565b7f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160008201527f6464726573730000000000000000000000000000000000000000000000000000602082015250565b60006145866026836133ee565b91506145918261452a565b604082019050919050565b600060208201905081810360008301526145b581614579565b9050919050565b60008160601b9050919050565b60006145d4826145bc565b9050919050565b60006145e6826145c9565b9050919050565b6145fe6145f982613518565b6145db565b82525050565b6000819050919050565b61461f61461a82613495565b614604565b82525050565b600061463182876145ed565b601482019150614641828661460e565b602082019150614651828561460e565b60208201915061466182846145ed565b60148201915081905095945050505050565b600061467e82613495565b915061468983613495565b92508261469957614698614091565b5b828206905092915050565b600081519050919050565b600082825260208201905092915050565b60006146cb826146a4565b6146d581856146af565b93506146e58185602086016133ff565b6146ee81613429565b840191505092915050565b600060808201905061470e600083018761352a565b61471b602083018661352a565b61472860408301856135c0565b818103606083015261473a81846146c0565b905095945050505050565b60008151905061475481613354565b92915050565b6000602082840312156147705761476f61331e565b5b600061477e84828501614745565b9150509291505056fea2646970667358221220ba1f0c595fb23c76d31c549ea57be457549d99c4bcbfa2233cc404352190cd7d64736f6c63430008110033

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.