ETH Price: $2,718.37 (-1.70%)

Token

noheroes (NHRO)
 

Overview

Max Total Supply

191 NHRO

Holders

79

Market

Volume (24H)

N/A

Min Price (24H)

N/A

Max Price (24H)

N/A
Filtered by Token Holder
aziely.eth
Balance
1 NHRO
0x7cd55b4641b08091ff6576bf319c57fe367f497e
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:
noheroes

Compiler Version
v0.8.16+commit.07a7930e

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, GNU GPLv3 license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2022-09-08
*/

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

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

pragma solidity ^0.8.0;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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


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


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

pragma solidity ^0.8.0;


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

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

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

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


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

pragma solidity ^0.8.0;

/**
 * @dev Implementation of https://eips.ethereum.org/EIPS/eip-721[ERC721] Non-Fungible Token Standard, including
 * the Metadata extension, but not including the Enumerable extension, which is available separately as
 * {ERC721Enumerable}.
 */
contract ERC721 is Context, ERC165, IERC721, IERC721Metadata {
    using Address for address;
    using Strings for uint256;

    // Token name
    string private _name;

    // Token symbol
    string private _symbol;

    // Mapping from token ID to owner address
    mapping(uint256 => address) private _owners;

    // Mapping owner address to token count
    mapping(address => uint256) private _balances;

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

    /**
     * @dev Initializes the contract by setting a `name` and a `symbol` to the token collection.
     */
    constructor(string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
    }

    /**
     * @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 virtual override returns (uint256) {
        require(owner != address(0), "ERC721: balance query for the zero address");
        return _balances[owner];
    }

    /**
     * @dev See {IERC721-ownerOf}.
     */
    function ownerOf(uint256 tokenId) public view virtual override returns (address) {
        address owner = _owners[tokenId];
        require(owner != address(0), "ERC721: owner query for nonexistent token");
        return owner;
    }

    /**
     * @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) {
        require(_exists(tokenId), "ERC721Metadata: URI query for nonexistent token");

        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 virtual override {
        address owner = ERC721.ownerOf(tokenId);
        require(to != owner, "ERC721: approval to current owner");

        require(
            _msgSender() == owner || isApprovedForAll(owner, _msgSender()),
            "ERC721: approve caller is not owner nor approved for all"
        );

        _approve(to, tokenId);
    }

    /**
     * @dev See {IERC721-getApproved}.
     */
    function getApproved(uint256 tokenId) public view virtual override returns (address) {
        require(_exists(tokenId), "ERC721: approved query for nonexistent token");

        return _tokenApprovals[tokenId];
    }

    /**
     * @dev See {IERC721-setApprovalForAll}.
     */
    function setApprovalForAll(address operator, bool approved) public virtual override {
        _setApprovalForAll(_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 {
        //solhint-disable-next-line max-line-length
        require(_isApprovedOrOwner(_msgSender(), tokenId), "ERC721: transfer caller is not owner nor approved");

        _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 {
        require(_isApprovedOrOwner(_msgSender(), tokenId), "ERC721: transfer caller is not owner nor approved");
        _safeTransfer(from, to, tokenId, _data);
    }

    /**
     * @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.
     *
     * `_data` is additional data, it has no specified format and it is sent in call to `to`.
     *
     * This internal function is equivalent to {safeTransferFrom}, and can be used to e.g.
     * implement alternative mechanisms to perform token transfer, such as signature-based.
     *
     * Requirements:
     *
     * - `from` cannot be the zero address.
     * - `to` cannot be the zero address.
     * - `tokenId` token must exist and be owned by `from`.
     * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.
     *
     * Emits a {Transfer} event.
     */
    function _safeTransfer(
        address from,
        address to,
        uint256 tokenId,
        bytes memory _data
    ) internal virtual {
        _transfer(from, to, tokenId);
        require(_checkOnERC721Received(from, to, tokenId, _data), "ERC721: transfer to non ERC721Receiver implementer");
    }

    /**
     * @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`),
     * and stop existing when they are burned (`_burn`).
     */
    function _exists(uint256 tokenId) internal view virtual returns (bool) {
        return _owners[tokenId] != address(0);
    }

    /**
     * @dev Returns whether `spender` is allowed to manage `tokenId`.
     *
     * Requirements:
     *
     * - `tokenId` must exist.
     */
    function _isApprovedOrOwner(address spender, uint256 tokenId) internal view virtual returns (bool) {
        require(_exists(tokenId), "ERC721: operator query for nonexistent token");
        address owner = ERC721.ownerOf(tokenId);
        return (spender == owner || getApproved(tokenId) == spender || isApprovedForAll(owner, spender));
    }

    /**
     * @dev Safely mints `tokenId` and transfers it to `to`.
     *
     * Requirements:
     *
     * - `tokenId` must not exist.
     * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.
     *
     * Emits a {Transfer} event.
     */
    function _safeMint(address to, uint256 tokenId) internal virtual {
        _safeMint(to, tokenId, "");
    }

    /**
     * @dev Same as {xref-ERC721-_safeMint-address-uint256-}[`_safeMint`], with an additional `data` parameter which is
     * forwarded in {IERC721Receiver-onERC721Received} to contract recipients.
     */
    function _safeMint(
        address to,
        uint256 tokenId,
        bytes memory _data
    ) internal virtual {
        _mint(to, tokenId);
        require(
            _checkOnERC721Received(address(0), to, tokenId, _data),
            "ERC721: transfer to non ERC721Receiver implementer"
        );
    }

    /**
     * @dev Mints `tokenId` and transfers it to `to`.
     *
     * WARNING: Usage of this method is discouraged, use {_safeMint} whenever possible
     *
     * Requirements:
     *
     * - `tokenId` must not exist.
     * - `to` cannot be the zero address.
     *
     * Emits a {Transfer} event.
     */
    function _mint(address to, uint256 tokenId) internal virtual {
        require(to != address(0), "ERC721: mint to the zero address");
        require(!_exists(tokenId), "ERC721: token already minted");

        _beforeTokenTransfer(address(0), to, tokenId);

        _balances[to] += 1;
        _owners[tokenId] = to;

        emit Transfer(address(0), to, tokenId);
    }

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

        _beforeTokenTransfer(owner, address(0), tokenId);

        // Clear approvals
        _approve(address(0), tokenId);

        _balances[owner] -= 1;
        delete _owners[tokenId];

        emit Transfer(owner, address(0), tokenId);
    }

    /**
     * @dev Transfers `tokenId` from `from` to `to`.
     *  As opposed to {transferFrom}, this imposes no restrictions on msg.sender.
     *
     * 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
    ) internal virtual {
        require(ERC721.ownerOf(tokenId) == from, "ERC721: transfer of token that is not own");
        require(to != address(0), "ERC721: transfer to the zero address");

        _beforeTokenTransfer(from, to, tokenId);

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

        _balances[from] -= 1;
        _balances[to] += 1;
        _owners[tokenId] = to;

        emit Transfer(from, to, tokenId);
    }

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

    /**
     * @dev Approve `operator` to operate on all of `owner` tokens
     *
     * Emits a {ApprovalForAll} event.
     */
    function _setApprovalForAll(
        address owner,
        address operator,
        bool approved
    ) internal virtual {
        require(owner != operator, "ERC721: approve to caller");
        _operatorApprovals[owner][operator] = approved;
        emit ApprovalForAll(owner, operator, approved);
    }

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

    /**
     * @dev Hook that is called before any token transfer. This includes minting
     * and burning.
     *
     * 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, ``from``'s `tokenId` will be burned.
     * - `from` and `to` are never both zero.
     *
     * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
     */
    function _beforeTokenTransfer(
        address from,
        address to,
        uint256 tokenId
    ) internal virtual {}
}

/*
          _____                  _______                  _____                   _____                   _____                  _______                  _____                   _____          
         /\    \                /::\    \                /\    \                 /\    \                 /\    \                /::\    \                /\    \                 /\    \         
        /::\____\              /::::\    \              /::\____\               /::\    \               /::\    \              /::::\    \              /::\    \               /::\    \        
       /::::|   |             /::::::\    \            /:::/    /              /::::\    \             /::::\    \            /::::::\    \            /::::\    \             /::::\    \       
      /:::::|   |            /::::::::\    \          /:::/    /              /::::::\    \           /::::::\    \          /::::::::\    \          /::::::\    \           /::::::\    \      
     /::::::|   |           /:::/~~\:::\    \        /:::/    /              /:::/\:::\    \         /:::/\:::\    \        /:::/~~\:::\    \        /:::/\:::\    \         /:::/\:::\    \     
    /:::/|::|   |          /:::/    \:::\    \      /:::/____/              /:::/__\:::\    \       /:::/__\:::\    \      /:::/    \:::\    \      /:::/__\:::\    \       /:::/__\:::\    \    
   /:::/ |::|   |         /:::/    / \:::\    \    /::::\    \             /::::\   \:::\    \     /::::\   \:::\    \    /:::/    / \:::\    \    /::::\   \:::\    \      \:::\   \:::\    \   
  /:::/  |::|   | _____  /:::/____/   \:::\____\  /::::::\    \   _____   /::::::\   \:::\    \   /::::::\   \:::\    \  /:::/____/   \:::\____\  /::::::\   \:::\    \   ___\:::\   \:::\    \  
 /:::/   |::|   |/\    \|:::|    |     |:::|    |/:::/\:::\    \ /\    \ /:::/\:::\   \:::\    \ /:::/\:::\   \:::\____\|:::|    |     |:::|    |/:::/\:::\   \:::\    \ /\   \:::\   \:::\    \ 
/:: /    |::|   /::\____|:::|____|     |:::|    /:::/  \:::\    /::\____/:::/__\:::\   \:::\____/:::/  \:::\   \:::|    |:::|____|     |:::|    /:::/__\:::\   \:::\____/::\   \:::\   \:::\____\
\::/    /|::|  /:::/    /\:::\    \   /:::/    /\::/    \:::\  /:::/    \:::\   \:::\   \::/    \::/   |::::\  /:::|____|\:::\    \   /:::/    /\:::\   \:::\   \::/    \:::\   \:::\   \::/    /
 \/____/ |::| /:::/    /  \:::\    \ /:::/    /  \/____/ \:::\/:::/    / \:::\   \:::\   \/____/ \/____|:::::\/:::/    /  \:::\    \ /:::/    /  \:::\   \:::\   \/____/ \:::\   \:::\   \/____/ 
         |::|/:::/    /    \:::\    /:::/    /            \::::::/    /   \:::\   \:::\    \           |:::::::::/    /    \:::\    /:::/    /    \:::\   \:::\    \      \:::\   \:::\    \     
         |::::::/    /      \:::\__/:::/    /              \::::/    /     \:::\   \:::\____\          |::|\::::/    /      \:::\__/:::/    /      \:::\   \:::\____\      \:::\   \:::\____\    
         |:::::/    /        \::::::::/    /               /:::/    /       \:::\   \::/    /          |::| \::/____/        \::::::::/    /        \:::\   \::/    /       \:::\  /:::/    /    
         |::::/    /          \::::::/    /               /:::/    /         \:::\   \/____/           |::|  ~|               \::::::/    /          \:::\   \/____/         \:::\/:::/    /     
         /:::/    /            \::::/    /               /:::/    /           \:::\    \               |::|   |                \::::/    /            \:::\    \              \::::::/    /      
        /:::/    /              \::/____/               /:::/    /             \:::\____\              \::|   |                 \::/____/              \:::\____\              \::::/    /       
        \::/    /                ~~                     \::/    /               \::/    /               \:|   |                  ~~                     \::/    /               \::/    /        
         \/____/                                         \/____/                 \/____/                 \|___|                                          \/____/                 \/____/         
                                                                                                                                                                                                
*/

pragma solidity >=0.8.13;



contract noheroes is ERC721 {
    uint public constant maxSupply = 10000;
    uint public totalSupply;

    constructor() ERC721("noheroes", "NHRO") {
        for (uint i = 0; i < 10; ++i) {
            mint();
        }
    }

    function mint() public {
        require(totalSupply < maxSupply, "noheroes no more");        
        totalSupply += 1;
        _mint(msg.sender, totalSupply);
    }

    function tokenURI(uint token) public pure override(ERC721) returns(string memory) {
        return string(abi.encodePacked("ipfs://QmRFXGrcUGy5CeAeodFvK36qc2jRWEeVtkSvxjWuw5KGuj/", Strings.toString(token)));
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"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":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"Transfer","type":"event"},{"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":"tokenId","type":"uint256"}],"name":"getApproved","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"operator","type":"address"}],"name":"isApprovedForAll","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"mint","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"ownerOf","outputs":[{"internalType":"address","name":"","type":"address"}],"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":"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":"token","type":"uint256"}],"name":"tokenURI","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","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"}]

60806040523480156200001157600080fd5b50604051806040016040528060088152602001676e6f6865726f657360c01b815250604051806040016040528060048152602001634e48524f60e01b81525081600090816200006191906200030d565b5060016200007082826200030d565b50505060005b600a8110156200009d576200008a620000a4565b6200009581620003ef565b905062000076565b5062000427565b61271060065410620000f05760405162461bcd60e51b815260206004820152601060248201526f6e6f6865726f6573206e6f206d6f726560801b60448201526064015b60405180910390fd5b6001600660008282546200010591906200040b565b90915550506006546200011a9033906200011c565b565b6001600160a01b038216620001745760405162461bcd60e51b815260206004820181905260248201527f4552433732313a206d696e7420746f20746865207a65726f20616464726573736044820152606401620000e7565b6000818152600260205260409020546001600160a01b031615620001db5760405162461bcd60e51b815260206004820152601c60248201527f4552433732313a20746f6b656e20616c7265616479206d696e746564000000006044820152606401620000e7565b6001600160a01b0382166000908152600360205260408120805460019290620002069084906200040b565b909155505060008181526002602052604080822080546001600160a01b0319166001600160a01b03861690811790915590518392907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a45050565b505050565b634e487b7160e01b600052604160045260246000fd5b600181811c908216806200029457607f821691505b602082108103620002b557634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156200026457600081815260208120601f850160051c81016020861015620002e45750805b601f850160051c820191505b818110156200030557828155600101620002f0565b505050505050565b81516001600160401b0381111562000329576200032962000269565b62000341816200033a84546200027f565b84620002bb565b602080601f831160018114620003795760008415620003605750858301515b600019600386901b1c1916600185901b17855562000305565b600085815260208120601f198616915b82811015620003aa5788860151825594840194600190910190840162000389565b5085821015620003c95787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b634e487b7160e01b600052601160045260246000fd5b600060018201620004045762000404620003d9565b5060010190565b80820180821115620004215762000421620003d9565b92915050565b6113a580620004376000396000f3fe608060405234801561001057600080fd5b50600436106101005760003560e01c80636352211e11610097578063b88d4fde11610066578063b88d4fde14610208578063c87b56dd1461021b578063d5abeb011461022e578063e985e9c51461023757600080fd5b80636352211e146101c757806370a08231146101da57806395d89b41146101ed578063a22cb465146101f557600080fd5b80631249c58b116100d35780631249c58b1461018257806318160ddd1461018a57806323b872dd146101a157806342842e0e146101b457600080fd5b806301ffc9a71461010557806306fdde031461012d578063081812fc14610142578063095ea7b31461016d575b600080fd5b610118610113366004610e8d565b61024a565b60405190151581526020015b60405180910390f35b61013561029c565b6040516101249190610f01565b610155610150366004610f14565b61032e565b6040516001600160a01b039091168152602001610124565b61018061017b366004610f49565b6103c8565b005b6101806104dd565b61019360065481565b604051908152602001610124565b6101806101af366004610f73565b61054b565b6101806101c2366004610f73565b61057c565b6101556101d5366004610f14565b610597565b6101936101e8366004610faf565b61060e565b610135610695565b610180610203366004610fca565b6106a4565b61018061021636600461101c565b6106b3565b610135610229366004610f14565b6106eb565b61019361271081565b6101186102453660046110f8565b61071c565b60006001600160e01b031982166380ac58cd60e01b148061027b57506001600160e01b03198216635b5e139f60e01b145b8061029657506301ffc9a760e01b6001600160e01b03198316145b92915050565b6060600080546102ab9061112b565b80601f01602080910402602001604051908101604052809291908181526020018280546102d79061112b565b80156103245780601f106102f957610100808354040283529160200191610324565b820191906000526020600020905b81548152906001019060200180831161030757829003601f168201915b5050505050905090565b6000818152600260205260408120546001600160a01b03166103ac5760405162461bcd60e51b815260206004820152602c60248201527f4552433732313a20617070726f76656420717565727920666f72206e6f6e657860448201526b34b9ba32b73a103a37b5b2b760a11b60648201526084015b60405180910390fd5b506000908152600460205260409020546001600160a01b031690565b60006103d382610597565b9050806001600160a01b0316836001600160a01b0316036104405760405162461bcd60e51b815260206004820152602160248201527f4552433732313a20617070726f76616c20746f2063757272656e74206f776e656044820152603960f91b60648201526084016103a3565b336001600160a01b038216148061045c575061045c813361071c565b6104ce5760405162461bcd60e51b815260206004820152603860248201527f4552433732313a20617070726f76652063616c6c6572206973206e6f74206f7760448201527f6e6572206e6f7220617070726f76656420666f7220616c6c000000000000000060648201526084016103a3565b6104d8838361074a565b505050565b612710600654106105235760405162461bcd60e51b815260206004820152601060248201526f6e6f6865726f6573206e6f206d6f726560801b60448201526064016103a3565b600160066000828254610536919061117b565b92505081905550610549336006546107b8565b565b61055533826108fa565b6105715760405162461bcd60e51b81526004016103a39061118e565b6104d88383836109d1565b6104d8838383604051806020016040528060008152506106b3565b6000818152600260205260408120546001600160a01b0316806102965760405162461bcd60e51b815260206004820152602960248201527f4552433732313a206f776e657220717565727920666f72206e6f6e657869737460448201526832b73a103a37b5b2b760b91b60648201526084016103a3565b60006001600160a01b0382166106795760405162461bcd60e51b815260206004820152602a60248201527f4552433732313a2062616c616e636520717565727920666f7220746865207a65604482015269726f206164647265737360b01b60648201526084016103a3565b506001600160a01b031660009081526003602052604090205490565b6060600180546102ab9061112b565b6106af338383610b71565b5050565b6106bd33836108fa565b6106d95760405162461bcd60e51b81526004016103a39061118e565b6106e584848484610c3f565b50505050565b60606106f682610c72565b60405160200161070691906111df565b6040516020818303038152906040529050919050565b6001600160a01b03918216600090815260056020908152604080832093909416825291909152205460ff1690565b600081815260046020526040902080546001600160a01b0319166001600160a01b038416908117909155819061077f82610597565b6001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a45050565b6001600160a01b03821661080e5760405162461bcd60e51b815260206004820181905260248201527f4552433732313a206d696e7420746f20746865207a65726f206164647265737360448201526064016103a3565b6000818152600260205260409020546001600160a01b0316156108735760405162461bcd60e51b815260206004820152601c60248201527f4552433732313a20746f6b656e20616c7265616479206d696e7465640000000060448201526064016103a3565b6001600160a01b038216600090815260036020526040812080546001929061089c90849061117b565b909155505060008181526002602052604080822080546001600160a01b0319166001600160a01b03861690811790915590518392907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a45050565b6000818152600260205260408120546001600160a01b03166109735760405162461bcd60e51b815260206004820152602c60248201527f4552433732313a206f70657261746f7220717565727920666f72206e6f6e657860448201526b34b9ba32b73a103a37b5b2b760a11b60648201526084016103a3565b600061097e83610597565b9050806001600160a01b0316846001600160a01b031614806109b95750836001600160a01b03166109ae8461032e565b6001600160a01b0316145b806109c957506109c9818561071c565b949350505050565b826001600160a01b03166109e482610597565b6001600160a01b031614610a4c5760405162461bcd60e51b815260206004820152602960248201527f4552433732313a207472616e73666572206f6620746f6b656e2074686174206960448201526839903737ba1037bbb760b91b60648201526084016103a3565b6001600160a01b038216610aae5760405162461bcd60e51b8152602060048201526024808201527f4552433732313a207472616e7366657220746f20746865207a65726f206164646044820152637265737360e01b60648201526084016103a3565b610ab960008261074a565b6001600160a01b0383166000908152600360205260408120805460019290610ae2908490611243565b90915550506001600160a01b0382166000908152600360205260408120805460019290610b1090849061117b565b909155505060008181526002602052604080822080546001600160a01b0319166001600160a01b0386811691821790925591518493918716917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91a4505050565b816001600160a01b0316836001600160a01b031603610bd25760405162461bcd60e51b815260206004820152601960248201527f4552433732313a20617070726f766520746f2063616c6c65720000000000000060448201526064016103a3565b6001600160a01b03838116600081815260056020908152604080832094871680845294825291829020805460ff191686151590811790915591519182527f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a3505050565b610c4a8484846109d1565b610c5684848484610d73565b6106e55760405162461bcd60e51b81526004016103a390611256565b606081600003610c995750506040805180820190915260018152600360fc1b602082015290565b8160005b8115610cc35780610cad816112a8565b9150610cbc9050600a836112d7565b9150610c9d565b60008167ffffffffffffffff811115610cde57610cde611006565b6040519080825280601f01601f191660200182016040528015610d08576020820181803683370190505b5090505b84156109c957610d1d600183611243565b9150610d2a600a866112eb565b610d3590603061117b565b60f81b818381518110610d4a57610d4a6112ff565b60200101906001600160f81b031916908160001a905350610d6c600a866112d7565b9450610d0c565b60006001600160a01b0384163b15610e6957604051630a85bd0160e11b81526001600160a01b0385169063150b7a0290610db7903390899088908890600401611315565b6020604051808303816000875af1925050508015610df2575060408051601f3d908101601f19168201909252610def91810190611352565b60015b610e4f573d808015610e20576040519150601f19603f3d011682016040523d82523d6000602084013e610e25565b606091505b508051600003610e475760405162461bcd60e51b81526004016103a390611256565b805181602001fd5b6001600160e01b031916630a85bd0160e11b1490506109c9565b506001949350505050565b6001600160e01b031981168114610e8a57600080fd5b50565b600060208284031215610e9f57600080fd5b8135610eaa81610e74565b9392505050565b60005b83811015610ecc578181015183820152602001610eb4565b50506000910152565b60008151808452610eed816020860160208601610eb1565b601f01601f19169290920160200192915050565b602081526000610eaa6020830184610ed5565b600060208284031215610f2657600080fd5b5035919050565b80356001600160a01b0381168114610f4457600080fd5b919050565b60008060408385031215610f5c57600080fd5b610f6583610f2d565b946020939093013593505050565b600080600060608486031215610f8857600080fd5b610f9184610f2d565b9250610f9f60208501610f2d565b9150604084013590509250925092565b600060208284031215610fc157600080fd5b610eaa82610f2d565b60008060408385031215610fdd57600080fd5b610fe683610f2d565b915060208301358015158114610ffb57600080fd5b809150509250929050565b634e487b7160e01b600052604160045260246000fd5b6000806000806080858703121561103257600080fd5b61103b85610f2d565b935061104960208601610f2d565b925060408501359150606085013567ffffffffffffffff8082111561106d57600080fd5b818701915087601f83011261108157600080fd5b81358181111561109357611093611006565b604051601f8201601f19908116603f011681019083821181831017156110bb576110bb611006565b816040528281528a60208487010111156110d457600080fd5b82602086016020830137600060208483010152809550505050505092959194509250565b6000806040838503121561110b57600080fd5b61111483610f2d565b915061112260208401610f2d565b90509250929050565b600181811c9082168061113f57607f821691505b60208210810361115f57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b8082018082111561029657610296611165565b60208082526031908201527f4552433732313a207472616e736665722063616c6c6572206973206e6f74206f6040820152701ddb995c881b9bdc88185c1c1c9bdd9959607a1b606082015260800190565b7f697066733a2f2f516d52465847726355477935436541656f6446764b33367163815275326a5257456556746b5376786a577577354b47756a2f60501b602082015260008251611236816036850160208701610eb1565b9190910160360192915050565b8181038181111561029657610296611165565b60208082526032908201527f4552433732313a207472616e7366657220746f206e6f6e20455243373231526560408201527131b2b4bb32b91034b6b83632b6b2b73a32b960711b606082015260800190565b6000600182016112ba576112ba611165565b5060010190565b634e487b7160e01b600052601260045260246000fd5b6000826112e6576112e66112c1565b500490565b6000826112fa576112fa6112c1565b500690565b634e487b7160e01b600052603260045260246000fd5b6001600160a01b038581168252841660208201526040810183905260806060820181905260009061134890830184610ed5565b9695505050505050565b60006020828403121561136457600080fd5b8151610eaa81610e7456fea26469706673582212202756df577d8ac8b03305e4b682e44f048e3c9b2ecceb7cc4c9591190a34f136764736f6c63430008100033

Deployed Bytecode

0x608060405234801561001057600080fd5b50600436106101005760003560e01c80636352211e11610097578063b88d4fde11610066578063b88d4fde14610208578063c87b56dd1461021b578063d5abeb011461022e578063e985e9c51461023757600080fd5b80636352211e146101c757806370a08231146101da57806395d89b41146101ed578063a22cb465146101f557600080fd5b80631249c58b116100d35780631249c58b1461018257806318160ddd1461018a57806323b872dd146101a157806342842e0e146101b457600080fd5b806301ffc9a71461010557806306fdde031461012d578063081812fc14610142578063095ea7b31461016d575b600080fd5b610118610113366004610e8d565b61024a565b60405190151581526020015b60405180910390f35b61013561029c565b6040516101249190610f01565b610155610150366004610f14565b61032e565b6040516001600160a01b039091168152602001610124565b61018061017b366004610f49565b6103c8565b005b6101806104dd565b61019360065481565b604051908152602001610124565b6101806101af366004610f73565b61054b565b6101806101c2366004610f73565b61057c565b6101556101d5366004610f14565b610597565b6101936101e8366004610faf565b61060e565b610135610695565b610180610203366004610fca565b6106a4565b61018061021636600461101c565b6106b3565b610135610229366004610f14565b6106eb565b61019361271081565b6101186102453660046110f8565b61071c565b60006001600160e01b031982166380ac58cd60e01b148061027b57506001600160e01b03198216635b5e139f60e01b145b8061029657506301ffc9a760e01b6001600160e01b03198316145b92915050565b6060600080546102ab9061112b565b80601f01602080910402602001604051908101604052809291908181526020018280546102d79061112b565b80156103245780601f106102f957610100808354040283529160200191610324565b820191906000526020600020905b81548152906001019060200180831161030757829003601f168201915b5050505050905090565b6000818152600260205260408120546001600160a01b03166103ac5760405162461bcd60e51b815260206004820152602c60248201527f4552433732313a20617070726f76656420717565727920666f72206e6f6e657860448201526b34b9ba32b73a103a37b5b2b760a11b60648201526084015b60405180910390fd5b506000908152600460205260409020546001600160a01b031690565b60006103d382610597565b9050806001600160a01b0316836001600160a01b0316036104405760405162461bcd60e51b815260206004820152602160248201527f4552433732313a20617070726f76616c20746f2063757272656e74206f776e656044820152603960f91b60648201526084016103a3565b336001600160a01b038216148061045c575061045c813361071c565b6104ce5760405162461bcd60e51b815260206004820152603860248201527f4552433732313a20617070726f76652063616c6c6572206973206e6f74206f7760448201527f6e6572206e6f7220617070726f76656420666f7220616c6c000000000000000060648201526084016103a3565b6104d8838361074a565b505050565b612710600654106105235760405162461bcd60e51b815260206004820152601060248201526f6e6f6865726f6573206e6f206d6f726560801b60448201526064016103a3565b600160066000828254610536919061117b565b92505081905550610549336006546107b8565b565b61055533826108fa565b6105715760405162461bcd60e51b81526004016103a39061118e565b6104d88383836109d1565b6104d8838383604051806020016040528060008152506106b3565b6000818152600260205260408120546001600160a01b0316806102965760405162461bcd60e51b815260206004820152602960248201527f4552433732313a206f776e657220717565727920666f72206e6f6e657869737460448201526832b73a103a37b5b2b760b91b60648201526084016103a3565b60006001600160a01b0382166106795760405162461bcd60e51b815260206004820152602a60248201527f4552433732313a2062616c616e636520717565727920666f7220746865207a65604482015269726f206164647265737360b01b60648201526084016103a3565b506001600160a01b031660009081526003602052604090205490565b6060600180546102ab9061112b565b6106af338383610b71565b5050565b6106bd33836108fa565b6106d95760405162461bcd60e51b81526004016103a39061118e565b6106e584848484610c3f565b50505050565b60606106f682610c72565b60405160200161070691906111df565b6040516020818303038152906040529050919050565b6001600160a01b03918216600090815260056020908152604080832093909416825291909152205460ff1690565b600081815260046020526040902080546001600160a01b0319166001600160a01b038416908117909155819061077f82610597565b6001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a45050565b6001600160a01b03821661080e5760405162461bcd60e51b815260206004820181905260248201527f4552433732313a206d696e7420746f20746865207a65726f206164647265737360448201526064016103a3565b6000818152600260205260409020546001600160a01b0316156108735760405162461bcd60e51b815260206004820152601c60248201527f4552433732313a20746f6b656e20616c7265616479206d696e7465640000000060448201526064016103a3565b6001600160a01b038216600090815260036020526040812080546001929061089c90849061117b565b909155505060008181526002602052604080822080546001600160a01b0319166001600160a01b03861690811790915590518392907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a45050565b6000818152600260205260408120546001600160a01b03166109735760405162461bcd60e51b815260206004820152602c60248201527f4552433732313a206f70657261746f7220717565727920666f72206e6f6e657860448201526b34b9ba32b73a103a37b5b2b760a11b60648201526084016103a3565b600061097e83610597565b9050806001600160a01b0316846001600160a01b031614806109b95750836001600160a01b03166109ae8461032e565b6001600160a01b0316145b806109c957506109c9818561071c565b949350505050565b826001600160a01b03166109e482610597565b6001600160a01b031614610a4c5760405162461bcd60e51b815260206004820152602960248201527f4552433732313a207472616e73666572206f6620746f6b656e2074686174206960448201526839903737ba1037bbb760b91b60648201526084016103a3565b6001600160a01b038216610aae5760405162461bcd60e51b8152602060048201526024808201527f4552433732313a207472616e7366657220746f20746865207a65726f206164646044820152637265737360e01b60648201526084016103a3565b610ab960008261074a565b6001600160a01b0383166000908152600360205260408120805460019290610ae2908490611243565b90915550506001600160a01b0382166000908152600360205260408120805460019290610b1090849061117b565b909155505060008181526002602052604080822080546001600160a01b0319166001600160a01b0386811691821790925591518493918716917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91a4505050565b816001600160a01b0316836001600160a01b031603610bd25760405162461bcd60e51b815260206004820152601960248201527f4552433732313a20617070726f766520746f2063616c6c65720000000000000060448201526064016103a3565b6001600160a01b03838116600081815260056020908152604080832094871680845294825291829020805460ff191686151590811790915591519182527f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a3505050565b610c4a8484846109d1565b610c5684848484610d73565b6106e55760405162461bcd60e51b81526004016103a390611256565b606081600003610c995750506040805180820190915260018152600360fc1b602082015290565b8160005b8115610cc35780610cad816112a8565b9150610cbc9050600a836112d7565b9150610c9d565b60008167ffffffffffffffff811115610cde57610cde611006565b6040519080825280601f01601f191660200182016040528015610d08576020820181803683370190505b5090505b84156109c957610d1d600183611243565b9150610d2a600a866112eb565b610d3590603061117b565b60f81b818381518110610d4a57610d4a6112ff565b60200101906001600160f81b031916908160001a905350610d6c600a866112d7565b9450610d0c565b60006001600160a01b0384163b15610e6957604051630a85bd0160e11b81526001600160a01b0385169063150b7a0290610db7903390899088908890600401611315565b6020604051808303816000875af1925050508015610df2575060408051601f3d908101601f19168201909252610def91810190611352565b60015b610e4f573d808015610e20576040519150601f19603f3d011682016040523d82523d6000602084013e610e25565b606091505b508051600003610e475760405162461bcd60e51b81526004016103a390611256565b805181602001fd5b6001600160e01b031916630a85bd0160e11b1490506109c9565b506001949350505050565b6001600160e01b031981168114610e8a57600080fd5b50565b600060208284031215610e9f57600080fd5b8135610eaa81610e74565b9392505050565b60005b83811015610ecc578181015183820152602001610eb4565b50506000910152565b60008151808452610eed816020860160208601610eb1565b601f01601f19169290920160200192915050565b602081526000610eaa6020830184610ed5565b600060208284031215610f2657600080fd5b5035919050565b80356001600160a01b0381168114610f4457600080fd5b919050565b60008060408385031215610f5c57600080fd5b610f6583610f2d565b946020939093013593505050565b600080600060608486031215610f8857600080fd5b610f9184610f2d565b9250610f9f60208501610f2d565b9150604084013590509250925092565b600060208284031215610fc157600080fd5b610eaa82610f2d565b60008060408385031215610fdd57600080fd5b610fe683610f2d565b915060208301358015158114610ffb57600080fd5b809150509250929050565b634e487b7160e01b600052604160045260246000fd5b6000806000806080858703121561103257600080fd5b61103b85610f2d565b935061104960208601610f2d565b925060408501359150606085013567ffffffffffffffff8082111561106d57600080fd5b818701915087601f83011261108157600080fd5b81358181111561109357611093611006565b604051601f8201601f19908116603f011681019083821181831017156110bb576110bb611006565b816040528281528a60208487010111156110d457600080fd5b82602086016020830137600060208483010152809550505050505092959194509250565b6000806040838503121561110b57600080fd5b61111483610f2d565b915061112260208401610f2d565b90509250929050565b600181811c9082168061113f57607f821691505b60208210810361115f57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b8082018082111561029657610296611165565b60208082526031908201527f4552433732313a207472616e736665722063616c6c6572206973206e6f74206f6040820152701ddb995c881b9bdc88185c1c1c9bdd9959607a1b606082015260800190565b7f697066733a2f2f516d52465847726355477935436541656f6446764b33367163815275326a5257456556746b5376786a577577354b47756a2f60501b602082015260008251611236816036850160208701610eb1565b9190910160360192915050565b8181038181111561029657610296611165565b60208082526032908201527f4552433732313a207472616e7366657220746f206e6f6e20455243373231526560408201527131b2b4bb32b91034b6b83632b6b2b73a32b960711b606082015260800190565b6000600182016112ba576112ba611165565b5060010190565b634e487b7160e01b600052601260045260246000fd5b6000826112e6576112e66112c1565b500490565b6000826112fa576112fa6112c1565b500690565b634e487b7160e01b600052603260045260246000fd5b6001600160a01b038581168252841660208201526040810183905260806060820181905260009061134890830184610ed5565b9695505050505050565b60006020828403121561136457600080fd5b8151610eaa81610e7456fea26469706673582212202756df577d8ac8b03305e4b682e44f048e3c9b2ecceb7cc4c9591190a34f136764736f6c63430008100033

Deployed Bytecode Sourcemap

36928:638:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;20156:305;;;;;;:::i;:::-;;:::i;:::-;;;565:14:1;;558:22;540:41;;528:2;513:18;20156:305:0;;;;;;;;21101:100;;;:::i;:::-;;;;;;;:::i;22660:221::-;;;;;;:::i;:::-;;:::i;:::-;;;-1:-1:-1;;;;;1697:32:1;;;1679:51;;1667:2;1652:18;22660:221:0;1533:203:1;22183:411:0;;;;;;:::i;:::-;;:::i;:::-;;37170:170;;;:::i;37008:23::-;;;;;;;;;2324:25:1;;;2312:2;2297:18;37008:23:0;2178:177:1;23410:339:0;;;;;;:::i;:::-;;:::i;23820:185::-;;;;;;:::i;:::-;;:::i;20795:239::-;;;;;;:::i;:::-;;:::i;20525:208::-;;;;;;:::i;:::-;;:::i;21270:104::-;;;:::i;22953:155::-;;;;;;:::i;:::-;;:::i;24076:328::-;;;;;;:::i;:::-;;:::i;37348:215::-;;;;;;:::i;:::-;;:::i;36963:38::-;;36996:5;36963:38;;23179:164;;;;;;:::i;:::-;;:::i;20156:305::-;20258:4;-1:-1:-1;;;;;;20295:40:0;;-1:-1:-1;;;20295:40:0;;:105;;-1:-1:-1;;;;;;;20352:48:0;;-1:-1:-1;;;20352:48:0;20295:105;:158;;;-1:-1:-1;;;;;;;;;;13336:40:0;;;20417:36;20275:178;20156:305;-1:-1:-1;;20156:305:0:o;21101:100::-;21155:13;21188:5;21181:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;21101:100;:::o;22660:221::-;22736:7;26003:16;;;:7;:16;;;;;;-1:-1:-1;;;;;26003:16:0;22756:73;;;;-1:-1:-1;;;22756:73:0;;5363:2:1;22756:73:0;;;5345:21:1;5402:2;5382:18;;;5375:30;5441:34;5421:18;;;5414:62;-1:-1:-1;;;5492:18:1;;;5485:42;5544:19;;22756:73:0;;;;;;;;;-1:-1:-1;22849:24:0;;;;:15;:24;;;;;;-1:-1:-1;;;;;22849:24:0;;22660:221::o;22183:411::-;22264:13;22280:23;22295:7;22280:14;:23::i;:::-;22264:39;;22328:5;-1:-1:-1;;;;;22322:11:0;:2;-1:-1:-1;;;;;22322:11:0;;22314:57;;;;-1:-1:-1;;;22314:57:0;;5776:2:1;22314:57:0;;;5758:21:1;5815:2;5795:18;;;5788:30;5854:34;5834:18;;;5827:62;-1:-1:-1;;;5905:18:1;;;5898:31;5946:19;;22314:57:0;5574:397:1;22314:57:0;2659:10;-1:-1:-1;;;;;22406:21:0;;;;:62;;-1:-1:-1;22431:37:0;22448:5;2659:10;23179:164;:::i;22431:37::-;22384:168;;;;-1:-1:-1;;;22384:168:0;;6178:2:1;22384:168:0;;;6160:21:1;6217:2;6197:18;;;6190:30;6256:34;6236:18;;;6229:62;6327:26;6307:18;;;6300:54;6371:19;;22384:168:0;5976:420:1;22384:168:0;22565:21;22574:2;22578:7;22565:8;:21::i;:::-;22253:341;22183:411;;:::o;37170:170::-;36996:5;37212:11;;:23;37204:52;;;;-1:-1:-1;;;37204:52:0;;6603:2:1;37204:52:0;;;6585:21:1;6642:2;6622:18;;;6615:30;-1:-1:-1;;;6661:18:1;;;6654:46;6717:18;;37204:52:0;6401:340:1;37204:52:0;37290:1;37275:11;;:16;;;;;;;:::i;:::-;;;;;;;;37302:30;37308:10;37320:11;;37302:5;:30::i;:::-;37170:170::o;23410:339::-;23605:41;2659:10;23638:7;23605:18;:41::i;:::-;23597:103;;;;-1:-1:-1;;;23597:103:0;;;;;;;:::i;:::-;23713:28;23723:4;23729:2;23733:7;23713:9;:28::i;23820:185::-;23958:39;23975:4;23981:2;23985:7;23958:39;;;;;;;;;;;;:16;:39::i;20795:239::-;20867:7;20903:16;;;:7;:16;;;;;;-1:-1:-1;;;;;20903:16:0;;20930:73;;;;-1:-1:-1;;;20930:73:0;;7628:2:1;20930:73:0;;;7610:21:1;7667:2;7647:18;;;7640:30;7706:34;7686:18;;;7679:62;-1:-1:-1;;;7757:18:1;;;7750:39;7806:19;;20930:73:0;7426:405:1;20525:208:0;20597:7;-1:-1:-1;;;;;20625:19:0;;20617:74;;;;-1:-1:-1;;;20617:74:0;;8038:2:1;20617:74:0;;;8020:21:1;8077:2;8057:18;;;8050:30;8116:34;8096:18;;;8089:62;-1:-1:-1;;;8167:18:1;;;8160:40;8217:19;;20617:74:0;7836:406:1;20617:74:0;-1:-1:-1;;;;;;20709:16:0;;;;;:9;:16;;;;;;;20525:208::o;21270:104::-;21326:13;21359:7;21352:14;;;;;:::i;22953:155::-;23048:52;2659:10;23081:8;23091;23048:18;:52::i;:::-;22953:155;;:::o;24076:328::-;24251:41;2659:10;24284:7;24251:18;:41::i;:::-;24243:103;;;;-1:-1:-1;;;24243:103:0;;;;;;;:::i;:::-;24357:39;24371:4;24377:2;24381:7;24390:5;24357:13;:39::i;:::-;24076:328;;;;:::o;37348:215::-;37415:13;37530:23;37547:5;37530:16;:23::i;:::-;37455:99;;;;;;;;:::i;:::-;;;;;;;;;;;;;37441:114;;37348:215;;;:::o;23179:164::-;-1:-1:-1;;;;;23300:25:0;;;23276:4;23300:25;;;:18;:25;;;;;;;;:35;;;;;;;;;;;;;;;23179:164::o;29896:174::-;29971:24;;;;:15;:24;;;;;:29;;-1:-1:-1;;;;;;29971:29:0;-1:-1:-1;;;;;29971:29:0;;;;;;;;:24;;30025:23;29971:24;30025:14;:23::i;:::-;-1:-1:-1;;;;;30016:46:0;;;;;;;;;;;29896:174;;:::o;27892:382::-;-1:-1:-1;;;;;27972:16:0;;27964:61;;;;-1:-1:-1;;;27964:61:0;;8971:2:1;27964:61:0;;;8953:21:1;;;8990:18;;;8983:30;9049:34;9029:18;;;9022:62;9101:18;;27964:61:0;8769:356:1;27964:61:0;25979:4;26003:16;;;:7;:16;;;;;;-1:-1:-1;;;;;26003:16:0;:30;28036:58;;;;-1:-1:-1;;;28036:58:0;;9332:2:1;28036:58:0;;;9314:21:1;9371:2;9351:18;;;9344:30;9410;9390:18;;;9383:58;9458:18;;28036:58:0;9130:352:1;28036:58:0;-1:-1:-1;;;;;28165:13:0;;;;;;:9;:13;;;;;:18;;28182:1;;28165:13;:18;;28182:1;;28165:18;:::i;:::-;;;;-1:-1:-1;;28194:16:0;;;;:7;:16;;;;;;:21;;-1:-1:-1;;;;;;28194:21:0;-1:-1:-1;;;;;28194:21:0;;;;;;;;28233:33;;28194:16;;;28233:33;;28194:16;;28233:33;27892:382;;:::o;26208:348::-;26301:4;26003:16;;;:7;:16;;;;;;-1:-1:-1;;;;;26003:16:0;26318:73;;;;-1:-1:-1;;;26318:73:0;;9689:2:1;26318:73:0;;;9671:21:1;9728:2;9708:18;;;9701:30;9767:34;9747:18;;;9740:62;-1:-1:-1;;;9818:18:1;;;9811:42;9870:19;;26318:73:0;9487:408:1;26318:73:0;26402:13;26418:23;26433:7;26418:14;:23::i;:::-;26402:39;;26471:5;-1:-1:-1;;;;;26460:16:0;:7;-1:-1:-1;;;;;26460:16:0;;:51;;;;26504:7;-1:-1:-1;;;;;26480:31:0;:20;26492:7;26480:11;:20::i;:::-;-1:-1:-1;;;;;26480:31:0;;26460:51;:87;;;;26515:32;26532:5;26539:7;26515:16;:32::i;:::-;26452:96;26208:348;-1:-1:-1;;;;26208:348:0:o;29200:578::-;29359:4;-1:-1:-1;;;;;29332:31:0;:23;29347:7;29332:14;:23::i;:::-;-1:-1:-1;;;;;29332:31:0;;29324:85;;;;-1:-1:-1;;;29324:85:0;;10102:2:1;29324:85:0;;;10084:21:1;10141:2;10121:18;;;10114:30;10180:34;10160:18;;;10153:62;-1:-1:-1;;;10231:18:1;;;10224:39;10280:19;;29324:85:0;9900:405:1;29324:85:0;-1:-1:-1;;;;;29428:16:0;;29420:65;;;;-1:-1:-1;;;29420:65:0;;10512:2:1;29420:65:0;;;10494:21:1;10551:2;10531:18;;;10524:30;10590:34;10570:18;;;10563:62;-1:-1:-1;;;10641:18:1;;;10634:34;10685:19;;29420:65:0;10310:400:1;29420:65:0;29602:29;29619:1;29623:7;29602:8;:29::i;:::-;-1:-1:-1;;;;;29644:15:0;;;;;;:9;:15;;;;;:20;;29663:1;;29644:15;:20;;29663:1;;29644:20;:::i;:::-;;;;-1:-1:-1;;;;;;;29675:13:0;;;;;;:9;:13;;;;;:18;;29692:1;;29675:13;:18;;29692:1;;29675:18;:::i;:::-;;;;-1:-1:-1;;29704:16:0;;;;:7;:16;;;;;;:21;;-1:-1:-1;;;;;;29704:21:0;-1:-1:-1;;;;;29704:21:0;;;;;;;;;29743:27;;29704:16;;29743:27;;;;;;;29200:578;;;:::o;30212:315::-;30367:8;-1:-1:-1;;;;;30358:17:0;:5;-1:-1:-1;;;;;30358:17:0;;30350:55;;;;-1:-1:-1;;;30350:55:0;;11050:2:1;30350:55:0;;;11032:21:1;11089:2;11069:18;;;11062:30;11128:27;11108:18;;;11101:55;11173:18;;30350:55:0;10848:349:1;30350:55:0;-1:-1:-1;;;;;30416:25:0;;;;;;;:18;:25;;;;;;;;:35;;;;;;;;;;;;;:46;;-1:-1:-1;;30416:46:0;;;;;;;;;;30478:41;;540::1;;;30478::0;;513:18:1;30478:41:0;;;;;;;30212:315;;;:::o;25286:::-;25443:28;25453:4;25459:2;25463:7;25443:9;:28::i;:::-;25490:48;25513:4;25519:2;25523:7;25532:5;25490:22;:48::i;:::-;25482:111;;;;-1:-1:-1;;;25482:111:0;;;;;;;:::i;253:723::-;309:13;530:5;539:1;530:10;526:53;;-1:-1:-1;;557:10:0;;;;;;;;;;;;-1:-1:-1;;;557:10:0;;;;;253:723::o;526:53::-;604:5;589:12;645:78;652:9;;645:78;;678:8;;;;:::i;:::-;;-1:-1:-1;701:10:0;;-1:-1:-1;709:2:0;701:10;;:::i;:::-;;;645:78;;;733:19;765:6;755:17;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;755:17:0;;733:39;;783:154;790:10;;783:154;;817:11;827:1;817:11;;:::i;:::-;;-1:-1:-1;886:10:0;894:2;886:5;:10;:::i;:::-;873:24;;:2;:24;:::i;:::-;860:39;;843:6;850;843:14;;;;;;;;:::i;:::-;;;;:56;-1:-1:-1;;;;;843:56:0;;;;;;;;-1:-1:-1;914:11:0;923:2;914:11;;:::i;:::-;;;783:154;;31092:799;31247:4;-1:-1:-1;;;;;31268:13:0;;3824:20;3872:8;31264:620;;31304:72;;-1:-1:-1;;;31304:72:0;;-1:-1:-1;;;;;31304:36:0;;;;;:72;;2659:10;;31355:4;;31361:7;;31370:5;;31304:72;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;-1:-1:-1;31304:72:0;;;;;;;;-1:-1:-1;;31304:72:0;;;;;;;;;;;;:::i;:::-;;;31300:529;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;31546:6;:13;31563:1;31546:18;31542:272;;31589:60;;-1:-1:-1;;;31589:60:0;;;;;;;:::i;31542:272::-;31764:6;31758:13;31749:6;31745:2;31741:15;31734:38;31300:529;-1:-1:-1;;;;;;31427:51:0;-1:-1:-1;;;31427:51:0;;-1:-1:-1;31420:58:0;;31264:620;-1:-1:-1;31868:4:0;31092:799;;;;;;:::o;14:131:1:-;-1:-1:-1;;;;;;88:32:1;;78:43;;68:71;;135:1;132;125:12;68:71;14:131;:::o;150:245::-;208:6;261:2;249:9;240:7;236:23;232:32;229:52;;;277:1;274;267:12;229:52;316:9;303:23;335:30;359:5;335:30;:::i;:::-;384:5;150:245;-1:-1:-1;;;150:245:1:o;592:250::-;677:1;687:113;701:6;698:1;695:13;687:113;;;777:11;;;771:18;758:11;;;751:39;723:2;716:10;687:113;;;-1:-1:-1;;834:1:1;816:16;;809:27;592:250::o;847:271::-;889:3;927:5;921:12;954:6;949:3;942:19;970:76;1039:6;1032:4;1027:3;1023:14;1016:4;1009:5;1005:16;970:76;:::i;:::-;1100:2;1079:15;-1:-1:-1;;1075:29:1;1066:39;;;;1107:4;1062:50;;847:271;-1:-1:-1;;847:271:1:o;1123:220::-;1272:2;1261:9;1254:21;1235:4;1292:45;1333:2;1322:9;1318:18;1310:6;1292:45;:::i;1348:180::-;1407:6;1460:2;1448:9;1439:7;1435:23;1431:32;1428:52;;;1476:1;1473;1466:12;1428:52;-1:-1:-1;1499:23:1;;1348:180;-1:-1:-1;1348:180:1:o;1741:173::-;1809:20;;-1:-1:-1;;;;;1858:31:1;;1848:42;;1838:70;;1904:1;1901;1894:12;1838:70;1741:173;;;:::o;1919:254::-;1987:6;1995;2048:2;2036:9;2027:7;2023:23;2019:32;2016:52;;;2064:1;2061;2054:12;2016:52;2087:29;2106:9;2087:29;:::i;:::-;2077:39;2163:2;2148:18;;;;2135:32;;-1:-1:-1;;;1919:254:1:o;2360:328::-;2437:6;2445;2453;2506:2;2494:9;2485:7;2481:23;2477:32;2474:52;;;2522:1;2519;2512:12;2474:52;2545:29;2564:9;2545:29;:::i;:::-;2535:39;;2593:38;2627:2;2616:9;2612:18;2593:38;:::i;:::-;2583:48;;2678:2;2667:9;2663:18;2650:32;2640:42;;2360:328;;;;;:::o;2693:186::-;2752:6;2805:2;2793:9;2784:7;2780:23;2776:32;2773:52;;;2821:1;2818;2811:12;2773:52;2844:29;2863:9;2844:29;:::i;2884:347::-;2949:6;2957;3010:2;2998:9;2989:7;2985:23;2981:32;2978:52;;;3026:1;3023;3016:12;2978:52;3049:29;3068:9;3049:29;:::i;:::-;3039:39;;3128:2;3117:9;3113:18;3100:32;3175:5;3168:13;3161:21;3154:5;3151:32;3141:60;;3197:1;3194;3187:12;3141:60;3220:5;3210:15;;;2884:347;;;;;:::o;3236:127::-;3297:10;3292:3;3288:20;3285:1;3278:31;3328:4;3325:1;3318:15;3352:4;3349:1;3342:15;3368:1138;3463:6;3471;3479;3487;3540:3;3528:9;3519:7;3515:23;3511:33;3508:53;;;3557:1;3554;3547:12;3508:53;3580:29;3599:9;3580:29;:::i;:::-;3570:39;;3628:38;3662:2;3651:9;3647:18;3628:38;:::i;:::-;3618:48;;3713:2;3702:9;3698:18;3685:32;3675:42;;3768:2;3757:9;3753:18;3740:32;3791:18;3832:2;3824:6;3821:14;3818:34;;;3848:1;3845;3838:12;3818:34;3886:6;3875:9;3871:22;3861:32;;3931:7;3924:4;3920:2;3916:13;3912:27;3902:55;;3953:1;3950;3943:12;3902:55;3989:2;3976:16;4011:2;4007;4004:10;4001:36;;;4017:18;;:::i;:::-;4092:2;4086:9;4060:2;4146:13;;-1:-1:-1;;4142:22:1;;;4166:2;4138:31;4134:40;4122:53;;;4190:18;;;4210:22;;;4187:46;4184:72;;;4236:18;;:::i;:::-;4276:10;4272:2;4265:22;4311:2;4303:6;4296:18;4351:7;4346:2;4341;4337;4333:11;4329:20;4326:33;4323:53;;;4372:1;4369;4362:12;4323:53;4428:2;4423;4419;4415:11;4410:2;4402:6;4398:15;4385:46;4473:1;4468:2;4463;4455:6;4451:15;4447:24;4440:35;4494:6;4484:16;;;;;;;3368:1138;;;;;;;:::o;4511:260::-;4579:6;4587;4640:2;4628:9;4619:7;4615:23;4611:32;4608:52;;;4656:1;4653;4646:12;4608:52;4679:29;4698:9;4679:29;:::i;:::-;4669:39;;4727:38;4761:2;4750:9;4746:18;4727:38;:::i;:::-;4717:48;;4511:260;;;;;:::o;4776:380::-;4855:1;4851:12;;;;4898;;;4919:61;;4973:4;4965:6;4961:17;4951:27;;4919:61;5026:2;5018:6;5015:14;4995:18;4992:38;4989:161;;5072:10;5067:3;5063:20;5060:1;5053:31;5107:4;5104:1;5097:15;5135:4;5132:1;5125:15;4989:161;;4776:380;;;:::o;6746:127::-;6807:10;6802:3;6798:20;6795:1;6788:31;6838:4;6835:1;6828:15;6862:4;6859:1;6852:15;6878:125;6943:9;;;6964:10;;;6961:36;;;6977:18;;:::i;7008:413::-;7210:2;7192:21;;;7249:2;7229:18;;;7222:30;7288:34;7283:2;7268:18;;7261:62;-1:-1:-1;;;7354:2:1;7339:18;;7332:47;7411:3;7396:19;;7008:413::o;8247:517::-;8509:34;8504:3;8497:47;-1:-1:-1;;;8569:2:1;8564:3;8560:12;8553:46;8479:3;8628:6;8622:13;8644:73;8710:6;8705:2;8700:3;8696:12;8691:2;8683:6;8679:15;8644:73;:::i;:::-;8737:16;;;;8755:2;8733:25;;8247:517;-1:-1:-1;;8247:517:1:o;10715:128::-;10782:9;;;10803:11;;;10800:37;;;10817:18;;:::i;11202:414::-;11404:2;11386:21;;;11443:2;11423:18;;;11416:30;11482:34;11477:2;11462:18;;11455:62;-1:-1:-1;;;11548:2:1;11533:18;;11526:48;11606:3;11591:19;;11202:414::o;11621:135::-;11660:3;11681:17;;;11678:43;;11701:18;;:::i;:::-;-1:-1:-1;11748:1:1;11737:13;;11621:135::o;11761:127::-;11822:10;11817:3;11813:20;11810:1;11803:31;11853:4;11850:1;11843:15;11877:4;11874:1;11867:15;11893:120;11933:1;11959;11949:35;;11964:18;;:::i;:::-;-1:-1:-1;11998:9:1;;11893:120::o;12018:112::-;12050:1;12076;12066:35;;12081:18;;:::i;:::-;-1:-1:-1;12115:9:1;;12018:112::o;12135:127::-;12196:10;12191:3;12187:20;12184:1;12177:31;12227:4;12224:1;12217:15;12251:4;12248:1;12241:15;12267:489;-1:-1:-1;;;;;12536:15:1;;;12518:34;;12588:15;;12583:2;12568:18;;12561:43;12635:2;12620:18;;12613:34;;;12683:3;12678:2;12663:18;;12656:31;;;12461:4;;12704:46;;12730:19;;12722:6;12704:46;:::i;:::-;12696:54;12267:489;-1:-1:-1;;;;;;12267:489:1:o;12761:249::-;12830:6;12883:2;12871:9;12862:7;12858:23;12854:32;12851:52;;;12899:1;12896;12889:12;12851:52;12931:9;12925:16;12950:30;12974:5;12950:30;:::i

Swarm Source

ipfs://2756df577d8ac8b03305e4b682e44f048e3c9b2ecceb7cc4c9591190a34f1367
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.