Contract 0xa305F7078c8b2F9F95205e272aa680a86F003C34

Contract Overview

Balance:
0 Ether
Txn Hash
Method
Block
From
To
Value
0x0b95f76d5caea11b900b2460693c672c9df240931e885048d4cc3ab5d8cb418aMint Reserved Go...99518462022-01-07 21:19:19178 days 2 hrs ago0x0eefa7e7877aeb0ce0ffced291f492458aae19eb IN  0xa305f7078c8b2f9f95205e272aa680a86f003c340 Ether0.00002425 1.00000001
0x0af11988c80cda223624c19501561c019219089579d35019958f1ff6b449bcc90x6080604099518142022-01-07 21:11:19178 days 3 hrs ago0x1e3918dd44f427f056be6c8e132cf1b5f42de59e IN  Create: Genesis0 Ether0.01161167 2.5
[ Download CSV Export 
Parent Txn Hash Block From To Value
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
Genesis

Compiler Version
v0.8.7+commit.e28d00a7

Optimization Enabled:
No with 200 runs

Other Settings:
default evmVersion
File 1 of 16 : Genesis.sol
//SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
import "@openzeppelin/contracts/access/Ownable.sol";
import "@openzeppelin/contracts/utils/Strings.sol";
import "@openzeppelin/contracts/token/ERC721/extensions/ERC721Pausable.sol";
import "@openzeppelin/contracts/utils/cryptography/MerkleProof.sol";
import "./interfaces/GenesisSupplyInterface.sol";
import "./interfaces/State.sol";

contract OwnableDelegateProxy {}

/**
 * Used to delegate ownership of a contract to another address, to save on unneeded transactions to approve contract use for users
 */
contract ProxyRegistry {
    mapping(address => OwnableDelegateProxy) public proxies;
}

contract Genesis is ERC721Pausable, Ownable, State {
    struct Airdrop {
        address to;
        uint256 count;
    }

    /**
     * Mint parameters
     */
    uint256 public constant WHITELIST_MINT_COUNT = 1;
    uint256 public price;
    string public baseTokenURI;
    mapping(address => bool) private addressToMint;

    /**
     * Merkle tree properties
     */
    bytes32 private whiteListMerkleTreeRoot;

    DeployedSupply private supply;
    address private proxyRegistryAddress;

    constructor(
        address _genesisSupplyAddress,
        string memory unrevealedURI,
        uint256 _price,
        address _proxyRegistryAddress
    ) ERC721("Mythics Genesis", "MGEN") {
        supply = DeployedSupply(_genesisSupplyAddress);
        baseTokenURI = unrevealedURI;
        price = _price;
        proxyRegistryAddress = _proxyRegistryAddress;
        _pause();
    }

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

    function contractURI() public pure returns (string memory) {
        return
            "https://ipfs.io/ipfs/QmbZwPZgKS6YJkT2U4Vmp87udA6Cfy4Tu63KKDv4QnncU2";
    }

    function totalSupply() external view returns (uint256) {
        return supply.currentIndex();
    }

    /**
     * Setters
     */
    function setBaseURI(string memory _baseTokenURI) external onlyOwner {
        require(mintState == MintState.Maintenance, "Mint not maintenance");
        // Set in Supply contract for the `getMetadataForTokenId` function
        supply.setIsRevealed(true);
        baseTokenURI = _baseTokenURI;
    }

    function setWhiteListMerkleTreeRoot(bytes32 _whiteListMerkleTreeRoot)
        external
        onlyOwner
    {
        whiteListMerkleTreeRoot = _whiteListMerkleTreeRoot;
    }

    function setMintState(MintState _mintState) external onlyOwner {
        this._setMintState(_mintState);
        supply._setMintState(_mintState);
    }

    function tokenURI(uint256 tokenId)
        public
        view
        override
        returns (string memory)
    {
        return
            string(abi.encodePacked(baseTokenURI, Strings.toString(tokenId)));
    }

    /**
     * Pause contract
     */
    function pause() external onlyOwner {
        _pause();
    }

    /**
     * Unpause contract
     */
    function unpause() external onlyOwner {
        _unpause();
    }

    /**
     * Airdrop tokens to an array of address
     * @param airdrops list of people to airdrop to
     */
    function airdrop(Airdrop[] calldata airdrops)
        external
        onlyOwner
        whenNotPaused
        closed
    {
        for (uint256 index = 0; index < airdrops.length; index++) {
            (uint256 startIndex, uint256 endIndex) = supply.mint(
                airdrops[index].count
            );
            for (uint256 i = startIndex; i < endIndex; i++) {
                _mint(airdrops[index].to, i);
            }
        }
    }

    /**
     * Whitelist mint
     * @param nonce nonce used to verify that the caller is allowed to mint
     * @param proof Proof to verify that the caller is allowed to mint
     */
    function mintWhitelist(uint256 nonce, bytes32[] calldata proof)
        external
        payable
        whenNotPaused
        active
    {
        require(
            verifyProof(nonce, whiteListMerkleTreeRoot, proof),
            "Address is not in the whitelist"
        );
        require(addressToMint[msg.sender] == false, "Already minted");
        require(msg.value == price, "Not enough ETH");
        addressToMint[msg.sender] = true;
        (uint256 startIndex, ) = supply.mint(1);
        _mint(msg.sender, startIndex);
    }

    /**
     * Function to mint the reserved gods
     * @param count number of gods to mint from the reserved pool
     */
    function mintReservedGods(uint256 count)
        external
        onlyOwner
        whenNotPaused
        closed
    {
        (uint256 startingIndex, uint256 maxSupply) = supply
            .reservedGodsCurrentIndexAndSupply();
        require(
            startingIndex + count <= maxSupply,
            "Not enough reserved gods left"
        );
        supply.mintReservedGods(count);
        // We use the current index if the reserved is done in multiple parts
        for (uint256 i = startingIndex; i < count + startingIndex; i++) {
            _mint(msg.sender, i);
        }
    }

    /**
     * Generate a leaf of the Merkle tree with a nonce and the address of the sender
     * @param nonce nonce to be used
     * @param addr id of the token
     * @return leaf generated
     */
    function generateLeaf(uint256 nonce, address addr)
        internal
        pure
        returns (bytes32 leaf)
    {
        return keccak256(abi.encodePacked(nonce, addr));
    }

    /**
     * Verifies the proof of the sender to confirm they are in given list
     * @param nonce nonce to be used
     * @param root Merkle tree root
     * @param proof proof
     * @return valid TRUE if the proof is valid, FALSE otherwise
     */
    function verifyProof(
        uint256 nonce,
        bytes32 root,
        bytes32[] memory proof
    ) internal view returns (bool valid) {
        return MerkleProof.verify(proof, root, generateLeaf(nonce, msg.sender));
    }

    /**
     * Withdraw balance from the contract
     */
    function withdrawAll() external payable onlyOwner {
        uint256 balance = address(this).balance;
        require(balance > 0, "No ether left to withdraw");
        (bool success, ) = (msg.sender).call{value: balance}("");
        require(success, "Transfer failed.");
    }

    /**
     * Override isApprovedForAll to whitelist user's ProxyRegistry proxy accounts to
     * enable gas-less listings.
     */
    function isApprovedForAll(address owner, address operator)
        public
        view
        override
        returns (bool)
    {
        // Whitelist OpenSea proxy contract for easy trading.
        ProxyRegistry proxyRegistry = ProxyRegistry(proxyRegistryAddress);
        if (address(proxyRegistry.proxies(owner)) == operator) {
            return true;
        }

        return super.isApprovedForAll(owner, operator);
    }
}

File 2 of 16 : Ownable.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.0 (access/Ownable.sol)

pragma solidity ^0.8.0;

import "../utils/Context.sol";

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

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

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

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

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

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

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

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

File 3 of 16 : Strings.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.0 (utils/Strings.sol)

pragma solidity ^0.8.0;

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

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

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

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

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

File 4 of 16 : ERC721Pausable.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.0 (token/ERC721/extensions/ERC721Pausable.sol)

pragma solidity ^0.8.0;

import "../ERC721.sol";
import "../../../security/Pausable.sol";

/**
 * @dev ERC721 token with pausable token transfers, minting and burning.
 *
 * Useful for scenarios such as preventing trades until the end of an evaluation
 * period, or having an emergency switch for freezing all token transfers in the
 * event of a large bug.
 */
abstract contract ERC721Pausable is ERC721, Pausable {
    /**
     * @dev See {ERC721-_beforeTokenTransfer}.
     *
     * Requirements:
     *
     * - the contract must not be paused.
     */
    function _beforeTokenTransfer(
        address from,
        address to,
        uint256 tokenId
    ) internal virtual override {
        super._beforeTokenTransfer(from, to, tokenId);

        require(!paused(), "ERC721Pausable: token transfer while paused");
    }
}

File 5 of 16 : MerkleProof.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.0 (utils/cryptography/MerkleProof.sol)

pragma solidity ^0.8.0;

/**
 * @dev These functions deal with verification of Merkle Trees proofs.
 *
 * The proofs can be generated using the JavaScript library
 * https://github.com/miguelmota/merkletreejs[merkletreejs].
 * Note: the hashing algorithm should be keccak256 and pair sorting should be enabled.
 *
 * See `test/utils/cryptography/MerkleProof.test.js` for some examples.
 */
library MerkleProof {
    /**
     * @dev Returns true if a `leaf` can be proved to be a part of a Merkle tree
     * defined by `root`. For this, a `proof` must be provided, containing
     * sibling hashes on the branch from the leaf to the root of the tree. Each
     * pair of leaves and each pair of pre-images are assumed to be sorted.
     */
    function verify(
        bytes32[] memory proof,
        bytes32 root,
        bytes32 leaf
    ) internal pure returns (bool) {
        return processProof(proof, leaf) == root;
    }

    /**
     * @dev Returns the rebuilt hash obtained by traversing a Merklee tree up
     * from `leaf` using `proof`. A `proof` is valid if and only if the rebuilt
     * hash matches the root of the tree. When processing the proof, the pairs
     * of leafs & pre-images are assumed to be sorted.
     *
     * _Available since v4.4._
     */
    function processProof(bytes32[] memory proof, bytes32 leaf) internal pure returns (bytes32) {
        bytes32 computedHash = leaf;
        for (uint256 i = 0; i < proof.length; i++) {
            bytes32 proofElement = proof[i];
            if (computedHash <= proofElement) {
                // Hash(current computed hash + current element of the proof)
                computedHash = keccak256(abi.encodePacked(computedHash, proofElement));
            } else {
                // Hash(current element of the proof + current computed hash)
                computedHash = keccak256(abi.encodePacked(proofElement, computedHash));
            }
        }
        return computedHash;
    }
}

File 6 of 16 : GenesisSupplyInterface.sol
//SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
import "./State.sol";

// Supply ABI needed from Genesis Contract
contract DeployedSupply is State {
    function setIsRevealed(bool _isRevealed) external {}

    function currentIndex() public view returns (uint256 index) {}

    function reservedGodsCurrentIndexAndSupply()
        public
        view
        returns (uint256 index, uint256 supply)
    {}

    function mint(uint256 count)
        public
        returns (uint256 startIndex, uint256 endIndex)
    {}

    function mintReservedGods(uint256 count) public {}
}

File 7 of 16 : State.sol
//SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

abstract contract State {
    enum MintState {
        Closed,
        Active,
        Maintenance,
        Finalized
    }
    MintState public mintState = MintState.Closed;

    function _setMintState(MintState _mintState) external {
        require(mintState != MintState.Finalized, "Mint finalized");
        mintState = _mintState;
    }

    /**
     * Modifier that checks mint state to be closed
     */
    modifier closed() {
        require(mintState == MintState.Closed, "Mint not closed");
        _;
    }

    /**
     * Modifier that checks mint state to be active
     */
    modifier active() {
        require(mintState == MintState.Active, "Mint not active");
        _;
    }
}

File 8 of 16 : Context.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.0 (utils/Context.sol)

pragma solidity ^0.8.0;

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

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

File 9 of 16 : ERC721.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.0 (token/ERC721/ERC721.sol)

pragma solidity ^0.8.0;

import "./IERC721.sol";
import "./IERC721Receiver.sol";
import "./extensions/IERC721Metadata.sol";
import "../../utils/Address.sol";
import "../../utils/Context.sol";
import "../../utils/Strings.sol";
import "../../utils/introspection/ERC165.sol";

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

File 10 of 16 : Pausable.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.0 (security/Pausable.sol)

pragma solidity ^0.8.0;

import "../utils/Context.sol";

/**
 * @dev Contract module which allows children to implement an emergency stop
 * mechanism that can be triggered by an authorized account.
 *
 * This module is used through inheritance. It will make available the
 * modifiers `whenNotPaused` and `whenPaused`, which can be applied to
 * the functions of your contract. Note that they will not be pausable by
 * simply including this module, only once the modifiers are put in place.
 */
abstract contract Pausable is Context {
    /**
     * @dev Emitted when the pause is triggered by `account`.
     */
    event Paused(address account);

    /**
     * @dev Emitted when the pause is lifted by `account`.
     */
    event Unpaused(address account);

    bool private _paused;

    /**
     * @dev Initializes the contract in unpaused state.
     */
    constructor() {
        _paused = false;
    }

    /**
     * @dev Returns true if the contract is paused, and false otherwise.
     */
    function paused() public view virtual returns (bool) {
        return _paused;
    }

    /**
     * @dev Modifier to make a function callable only when the contract is not paused.
     *
     * Requirements:
     *
     * - The contract must not be paused.
     */
    modifier whenNotPaused() {
        require(!paused(), "Pausable: paused");
        _;
    }

    /**
     * @dev Modifier to make a function callable only when the contract is paused.
     *
     * Requirements:
     *
     * - The contract must be paused.
     */
    modifier whenPaused() {
        require(paused(), "Pausable: not paused");
        _;
    }

    /**
     * @dev Triggers stopped state.
     *
     * Requirements:
     *
     * - The contract must not be paused.
     */
    function _pause() internal virtual whenNotPaused {
        _paused = true;
        emit Paused(_msgSender());
    }

    /**
     * @dev Returns to normal state.
     *
     * Requirements:
     *
     * - The contract must be paused.
     */
    function _unpause() internal virtual whenPaused {
        _paused = false;
        emit Unpaused(_msgSender());
    }
}

File 11 of 16 : IERC721.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.0 (token/ERC721/IERC721.sol)

pragma solidity ^0.8.0;

import "../../utils/introspection/IERC165.sol";

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

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

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

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

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

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

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

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

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

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

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

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

File 12 of 16 : IERC721Receiver.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.0 (token/ERC721/IERC721Receiver.sol)

pragma solidity ^0.8.0;

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

File 13 of 16 : IERC721Metadata.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.0 (token/ERC721/extensions/IERC721Metadata.sol)

pragma solidity ^0.8.0;

import "../IERC721.sol";

/**
 * @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 14 of 16 : Address.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.0 (utils/Address.sol)

pragma solidity ^0.8.0;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

File 15 of 16 : ERC165.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.0 (utils/introspection/ERC165.sol)

pragma solidity ^0.8.0;

import "./IERC165.sol";

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

File 16 of 16 : IERC165.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.0 (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);
}

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

Contract ABI

[{"inputs":[{"internalType":"address","name":"_genesisSupplyAddress","type":"address"},{"internalType":"string","name":"unrevealedURI","type":"string"},{"internalType":"uint256","name":"_price","type":"uint256"},{"internalType":"address","name":"_proxyRegistryAddress","type":"address"}],"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":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"}],"name":"Paused","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"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"}],"name":"Unpaused","type":"event"},{"inputs":[],"name":"WHITELIST_MINT_COUNT","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"enum State.MintState","name":"_mintState","type":"uint8"}],"name":"_setMintState","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"components":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"count","type":"uint256"}],"internalType":"struct Genesis.Airdrop[]","name":"airdrops","type":"tuple[]"}],"name":"airdrop","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":[],"name":"baseTokenURI","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"contractURI","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","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":[{"internalType":"uint256","name":"count","type":"uint256"}],"name":"mintReservedGods","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"mintState","outputs":[{"internalType":"enum State.MintState","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"nonce","type":"uint256"},{"internalType":"bytes32[]","name":"proof","type":"bytes32[]"}],"name":"mintWhitelist","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"ownerOf","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pause","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"paused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"price","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"safeTransferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"bytes","name":"_data","type":"bytes"}],"name":"safeTransferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"operator","type":"address"},{"internalType":"bool","name":"approved","type":"bool"}],"name":"setApprovalForAll","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"string","name":"_baseTokenURI","type":"string"}],"name":"setBaseURI","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"enum State.MintState","name":"_mintState","type":"uint8"}],"name":"setMintState","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"_whiteListMerkleTreeRoot","type":"bytes32"}],"name":"setWhiteListMerkleTreeRoot","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":"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":"unpause","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"withdrawAll","outputs":[],"stateMutability":"payable","type":"function"}]

60806040526000600660156101000a81548160ff021916908360038111156200002d576200002c6200074d565b5b02179055503480156200003f57600080fd5b5060405162005796380380620057968339818101604052810190620000659190620004f5565b6040518060400160405280600f81526020017f4d7974686963732047656e6573697300000000000000000000000000000000008152506040518060400160405280600481526020017f4d47454e000000000000000000000000000000000000000000000000000000008152508160009080519060200190620000e992919062000399565b5080600190805190602001906200010292919062000399565b5050506000600660006101000a81548160ff0219169083151502179055506200014062000134620001fc60201b60201c565b6200020460201b60201c565b83600b60006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555082600890805190602001906200019992919062000399565b508160078190555080600c60006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550620001f2620002ca60201b60201c565b505050506200085c565b600033905090565b6000600660019054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905081600660016101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b620002da6200038260201b60201c565b156200031d576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016200031490620005db565b60405180910390fd5b6001600660006101000a81548160ff0219169083151502179055507f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a25862000369620001fc60201b60201c565b604051620003789190620005be565b60405180910390a1565b6000600660009054906101000a900460ff16905090565b828054620003a790620006e1565b90600052602060002090601f016020900481019282620003cb576000855562000417565b82601f10620003e657805160ff191683800117855562000417565b8280016001018555821562000417579182015b8281111562000416578251825591602001919060010190620003f9565b5b5090506200042691906200042a565b5090565b5b80821115620004455760008160009055506001016200042b565b5090565b6000620004606200045a8462000626565b620005fd565b9050828152602081018484840111156200047f576200047e620007df565b5b6200048c848285620006ab565b509392505050565b600081519050620004a58162000828565b92915050565b600082601f830112620004c357620004c2620007da565b5b8151620004d584826020860162000449565b91505092915050565b600081519050620004ef8162000842565b92915050565b60008060008060808587031215620005125762000511620007e9565b5b6000620005228782880162000494565b945050602085015167ffffffffffffffff811115620005465762000545620007e4565b5b6200055487828801620004ab565b93505060406200056787828801620004de565b92505060606200057a8782880162000494565b91505092959194509250565b62000591816200066d565b82525050565b6000620005a66010836200065c565b9150620005b382620007ff565b602082019050919050565b6000602082019050620005d5600083018462000586565b92915050565b60006020820190508181036000830152620005f68162000597565b9050919050565b6000620006096200061c565b905062000617828262000717565b919050565b6000604051905090565b600067ffffffffffffffff821115620006445762000643620007ab565b5b6200064f82620007ee565b9050602081019050919050565b600082825260208201905092915050565b60006200067a8262000681565b9050919050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000819050919050565b60005b83811015620006cb578082015181840152602081019050620006ae565b83811115620006db576000848401525b50505050565b60006002820490506001821680620006fa57607f821691505b602082108114156200071157620007106200077c565b5b50919050565b6200072282620007ee565b810181811067ffffffffffffffff82111715620007445762000743620007ab565b5b80604052505050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b600080fd5b600080fd5b600080fd5b600080fd5b6000601f19601f8301169050919050565b7f5061757361626c653a2070617573656400000000000000000000000000000000600082015250565b62000833816200066d565b81146200083f57600080fd5b50565b6200084d81620006a1565b81146200085957600080fd5b50565b614f2a806200086c6000396000f3fe6080604052600436106101ee5760003560e01c8063853828b61161010d578063c87b56dd116100a0578063e985e9c51161006f578063e985e9c514610683578063ea50e78c146106c0578063f11cb0af146106e9578063f28ba28314610712578063f2fde38b1461073d576101ee565b8063c87b56dd146105c7578063d547cfb714610604578063e0c9ffc61461062f578063e8a3d48514610658576101ee565b8063a22cb465116100dc578063a22cb46514610521578063b88d4fde1461054a578063bb1ee47b14610573578063c051e38a1461059c576101ee565b8063853828b6146104965780638da5cb5b146104a057806395d89b41146104cb578063a035b1fe146104f6576101ee565b806342842e0e116101855780636352211e116101545780636352211e146103ee57806370a082311461042b578063715018a6146104685780638456cb591461047f576101ee565b806342842e0e146103485780634ce847471461037157806355f804b31461039a5780635c975abb146103c3576101ee565b8063095ea7b3116101c1578063095ea7b3146102b457806318160ddd146102dd57806323b872dd146103085780633f4ba83a14610331576101ee565b806301ffc9a7146101f3578063061431a81461023057806306fdde031461024c578063081812fc14610277575b600080fd5b3480156101ff57600080fd5b5061021a600480360381019061021591906135fd565b610766565b6040516102279190613e95565b60405180910390f35b61024a60048036038101906102459190613754565b610848565b005b34801561025857600080fd5b50610261610b84565b60405161026e9190613ee6565b60405180910390f35b34801561028357600080fd5b5061029e600480360381019061029991906136fa565b610c16565b6040516102ab9190613e2e565b60405180910390f35b3480156102c057600080fd5b506102db60048036038101906102d69190613543565b610c9b565b005b3480156102e957600080fd5b506102f2610db3565b6040516102ff9190614288565b60405180910390f35b34801561031457600080fd5b5061032f600480360381019061032a919061342d565b610e5a565b005b34801561033d57600080fd5b50610346610eba565b005b34801561035457600080fd5b5061036f600480360381019061036a919061342d565b610f40565b005b34801561037d57600080fd5b5061039860048036038101906103939190613684565b610f60565b005b3480156103a657600080fd5b506103c160048036038101906103bc91906136b1565b611003565b005b3480156103cf57600080fd5b506103d861119d565b6040516103e59190613e95565b60405180910390f35b3480156103fa57600080fd5b50610415600480360381019061041091906136fa565b6111b4565b6040516104229190613e2e565b60405180910390f35b34801561043757600080fd5b50610452600480360381019061044d91906133c0565b611266565b60405161045f9190614288565b60405180910390f35b34801561047457600080fd5b5061047d61131e565b005b34801561048b57600080fd5b506104946113a6565b005b61049e61142c565b005b3480156104ac57600080fd5b506104b56115a0565b6040516104c29190613e2e565b60405180910390f35b3480156104d757600080fd5b506104e06115ca565b6040516104ed9190613ee6565b60405180910390f35b34801561050257600080fd5b5061050b61165c565b6040516105189190614288565b60405180910390f35b34801561052d57600080fd5b5061054860048036038101906105439190613503565b611662565b005b34801561055657600080fd5b50610571600480360381019061056c9190613480565b611678565b005b34801561057f57600080fd5b5061059a600480360381019061059591906135d0565b6116da565b005b3480156105a857600080fd5b506105b1611760565b6040516105be9190613eb0565b60405180910390f35b3480156105d357600080fd5b506105ee60048036038101906105e991906136fa565b611773565b6040516105fb9190613ee6565b60405180910390f35b34801561061057600080fd5b506106196117a7565b6040516106269190613ee6565b60405180910390f35b34801561063b57600080fd5b5061065660048036038101906106519190613583565b611835565b005b34801561066457600080fd5b5061066d611abc565b60405161067a9190613ee6565b60405180910390f35b34801561068f57600080fd5b506106aa60048036038101906106a591906133ed565b611adc565b6040516106b79190613e95565b60405180910390f35b3480156106cc57600080fd5b506106e760048036038101906106e291906136fa565b611bde565b005b3480156106f557600080fd5b50610710600480360381019061070b9190613684565b611ed5565b005b34801561071e57600080fd5b5061072761204c565b6040516107349190614288565b60405180910390f35b34801561074957600080fd5b50610764600480360381019061075f91906133c0565b612051565b005b60007f80ac58cd000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916148061083157507f5b5e139f000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916145b80610841575061084082612149565b5b9050919050565b61085061119d565b15610890576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610887906140a8565b60405180910390fd5b600160038111156108a4576108a36146c4565b5b600660159054906101000a900460ff1660038111156108c6576108c56146c4565b5b14610906576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016108fd90613fe8565b60405180910390fd5b61095483600a54848480806020026020016040519081016040528093929190818152602001838360200280828437600081840152601f19601f820116905080830192505050505050506121b3565b610993576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161098a90614088565b60405180910390fd5b60001515600960003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16151514610a26576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a1d90613f28565b60405180910390fd5b6007543414610a6a576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a6190614188565b60405180910390fd5b6001600960003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055506000600b60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663a0712d6860016040518263ffffffff1660e01b8152600401610b209190613ecb565b6040805180830381600087803b158015610b3957600080fd5b505af1158015610b4d573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610b7191906137b4565b509050610b7e33826121d2565b50505050565b606060008054610b9390614551565b80601f0160208091040260200160405190810160405280929190818152602001828054610bbf90614551565b8015610c0c5780601f10610be157610100808354040283529160200191610c0c565b820191906000526020600020905b815481529060010190602001808311610bef57829003601f168201915b5050505050905090565b6000610c21826123a0565b610c60576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c57906141a8565b60405180910390fd5b6004600083815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050919050565b6000610ca6826111b4565b90508073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff161415610d17576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d0e90614208565b60405180910390fd5b8073ffffffffffffffffffffffffffffffffffffffff16610d3661240c565b73ffffffffffffffffffffffffffffffffffffffff161480610d655750610d6481610d5f61240c565b611adc565b5b610da4576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d9b906140c8565b60405180910390fd5b610dae8383612414565b505050565b6000600b60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166326987b606040518163ffffffff1660e01b815260040160206040518083038186803b158015610e1d57600080fd5b505afa158015610e31573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e559190613727565b905090565b610e6b610e6561240c565b826124cd565b610eaa576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610ea190614248565b60405180910390fd5b610eb58383836125ab565b505050565b610ec261240c565b73ffffffffffffffffffffffffffffffffffffffff16610ee06115a0565b73ffffffffffffffffffffffffffffffffffffffff1614610f36576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610f2d906141c8565b60405180910390fd5b610f3e612807565b565b610f5b83838360405180602001604052806000815250611678565b505050565b600380811115610f7357610f726146c4565b5b600660159054906101000a900460ff166003811115610f9557610f946146c4565b5b1415610fd6576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610fcd90613f08565b60405180910390fd5b80600660156101000a81548160ff02191690836003811115610ffb57610ffa6146c4565b5b021790555050565b61100b61240c565b73ffffffffffffffffffffffffffffffffffffffff166110296115a0565b73ffffffffffffffffffffffffffffffffffffffff161461107f576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611076906141c8565b60405180910390fd5b60026003811115611093576110926146c4565b5b600660159054906101000a900460ff1660038111156110b5576110b46146c4565b5b146110f5576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016110ec90614008565b60405180910390fd5b600b60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166349a5980a60016040518263ffffffff1660e01b81526004016111519190613e95565b600060405180830381600087803b15801561116b57600080fd5b505af115801561117f573d6000803e3d6000fd5b5050505080600890805190602001906111999291906130d4565b5050565b6000600660009054906101000a900460ff16905090565b6000806002600084815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff16141561125d576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161125490614108565b60405180910390fd5b80915050919050565b60008073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1614156112d7576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016112ce906140e8565b60405180910390fd5b600360008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050919050565b61132661240c565b73ffffffffffffffffffffffffffffffffffffffff166113446115a0565b73ffffffffffffffffffffffffffffffffffffffff161461139a576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611391906141c8565b60405180910390fd5b6113a460006128a9565b565b6113ae61240c565b73ffffffffffffffffffffffffffffffffffffffff166113cc6115a0565b73ffffffffffffffffffffffffffffffffffffffff1614611422576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611419906141c8565b60405180910390fd5b61142a61296f565b565b61143461240c565b73ffffffffffffffffffffffffffffffffffffffff166114526115a0565b73ffffffffffffffffffffffffffffffffffffffff16146114a8576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161149f906141c8565b60405180910390fd5b6000479050600081116114f0576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016114e790614168565b60405180910390fd5b60003373ffffffffffffffffffffffffffffffffffffffff168260405161151690613ded565b60006040518083038185875af1925050503d8060008114611553576040519150601f19603f3d011682016040523d82523d6000602084013e611558565b606091505b505090508061159c576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161159390614228565b60405180910390fd5b5050565b6000600660019054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b6060600180546115d990614551565b80601f016020809104026020016040519081016040528092919081815260200182805461160590614551565b80156116525780601f1061162757610100808354040283529160200191611652565b820191906000526020600020905b81548152906001019060200180831161163557829003601f168201915b5050505050905090565b60075481565b61167461166d61240c565b8383612a12565b5050565b61168961168361240c565b836124cd565b6116c8576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116bf90614248565b60405180910390fd5b6116d484848484612b7f565b50505050565b6116e261240c565b73ffffffffffffffffffffffffffffffffffffffff166117006115a0565b73ffffffffffffffffffffffffffffffffffffffff1614611756576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161174d906141c8565b60405180910390fd5b80600a8190555050565b600660159054906101000a900460ff1681565b6060600861178083612bdb565b604051602001611791929190613dc9565b6040516020818303038152906040529050919050565b600880546117b490614551565b80601f01602080910402602001604051908101604052809291908181526020018280546117e090614551565b801561182d5780601f106118025761010080835404028352916020019161182d565b820191906000526020600020905b81548152906001019060200180831161181057829003601f168201915b505050505081565b61183d61240c565b73ffffffffffffffffffffffffffffffffffffffff1661185b6115a0565b73ffffffffffffffffffffffffffffffffffffffff16146118b1576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016118a8906141c8565b60405180910390fd5b6118b961119d565b156118f9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016118f0906140a8565b60405180910390fd5b6000600381111561190d5761190c6146c4565b5b600660159054906101000a900460ff16600381111561192f5761192e6146c4565b5b1461196f576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161196690614128565b60405180910390fd5b60005b82829050811015611ab757600080600b60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663a0712d688686868181106119d1576119d0614722565b5b905060400201602001356040518263ffffffff1660e01b81526004016119f79190614288565b6040805180830381600087803b158015611a1057600080fd5b505af1158015611a24573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611a4891906137b4565b9150915060008290505b81811015611aa157611a8e868686818110611a7057611a6f614722565b5b9050604002016000016020810190611a8891906133c0565b826121d2565b8080611a99906145b4565b915050611a52565b5050508080611aaf906145b4565b915050611972565b505050565b6060604051806080016040528060438152602001614eb260439139905090565b600080600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1690508273ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1663c4552791866040518263ffffffff1660e01b8152600401611b549190613e2e565b60206040518083038186803b158015611b6c57600080fd5b505afa158015611b80573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611ba49190613657565b73ffffffffffffffffffffffffffffffffffffffff161415611bca576001915050611bd8565b611bd48484612d3c565b9150505b92915050565b611be661240c565b73ffffffffffffffffffffffffffffffffffffffff16611c046115a0565b73ffffffffffffffffffffffffffffffffffffffff1614611c5a576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611c51906141c8565b60405180910390fd5b611c6261119d565b15611ca2576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611c99906140a8565b60405180910390fd5b60006003811115611cb657611cb56146c4565b5b600660159054906101000a900460ff166003811115611cd857611cd76146c4565b5b14611d18576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611d0f90614128565b60405180910390fd5b600080600b60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f3df656d6040518163ffffffff1660e01b8152600401604080518083038186803b158015611d8257600080fd5b505afa158015611d96573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611dba91906137b4565b91509150808383611dcb919061438d565b1115611e0c576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611e0390614268565b60405180910390fd5b600b60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ea50e78c846040518263ffffffff1660e01b8152600401611e679190614288565b600060405180830381600087803b158015611e8157600080fd5b505af1158015611e95573d6000803e3d6000fd5b5050505060008290505b8284611eab919061438d565b811015611ecf57611ebc33826121d2565b8080611ec7906145b4565b915050611e9f565b50505050565b611edd61240c565b73ffffffffffffffffffffffffffffffffffffffff16611efb6115a0565b73ffffffffffffffffffffffffffffffffffffffff1614611f51576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611f48906141c8565b60405180910390fd5b3073ffffffffffffffffffffffffffffffffffffffff16634ce84747826040518263ffffffff1660e01b8152600401611f8a9190613eb0565b600060405180830381600087803b158015611fa457600080fd5b505af1158015611fb8573d6000803e3d6000fd5b50505050600b60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16634ce84747826040518263ffffffff1660e01b81526004016120179190613eb0565b600060405180830381600087803b15801561203157600080fd5b505af1158015612045573d6000803e3d6000fd5b5050505050565b600181565b61205961240c565b73ffffffffffffffffffffffffffffffffffffffff166120776115a0565b73ffffffffffffffffffffffffffffffffffffffff16146120cd576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016120c4906141c8565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff16141561213d576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161213490613fa8565b60405180910390fd5b612146816128a9565b50565b60007f01ffc9a7000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916149050919050565b60006121c982846121c48733612dd0565b612e03565b90509392505050565b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415612242576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161223990614148565b60405180910390fd5b61224b816123a0565b1561228b576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161228290613fc8565b60405180910390fd5b61229760008383612e1a565b6001600360008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008282546122e7919061438d565b92505081905550816002600083815260200190815260200160002060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550808273ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a45050565b60008073ffffffffffffffffffffffffffffffffffffffff166002600084815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614159050919050565b600033905090565b816004600083815260200190815260200160002060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550808273ffffffffffffffffffffffffffffffffffffffff16612487836111b4565b73ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a45050565b60006124d8826123a0565b612517576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161250e90614068565b60405180910390fd5b6000612522836111b4565b90508073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16148061259157508373ffffffffffffffffffffffffffffffffffffffff1661257984610c16565b73ffffffffffffffffffffffffffffffffffffffff16145b806125a257506125a18185611adc565b5b91505092915050565b8273ffffffffffffffffffffffffffffffffffffffff166125cb826111b4565b73ffffffffffffffffffffffffffffffffffffffff1614612621576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612618906141e8565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415612691576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161268890614028565b60405180910390fd5b61269c838383612e1a565b6126a7600082612414565b6001600360008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008282546126f79190614414565b925050819055506001600360008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600082825461274e919061438d565b92505081905550816002600083815260200190815260200160002060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550808273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a4505050565b61280f61119d565b61284e576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161284590613f68565b60405180910390fd5b6000600660006101000a81548160ff0219169083151502179055507f5db9ee0a495bf2e6ff9c91a7834c1ba4fdd244a5e8aa4e537bd38aeae4b073aa61289261240c565b60405161289f9190613e2e565b60405180910390a1565b6000600660019054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905081600660016101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b61297761119d565b156129b7576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016129ae906140a8565b60405180910390fd5b6001600660006101000a81548160ff0219169083151502179055507f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a2586129fb61240c565b604051612a089190613e2e565b60405180910390a1565b8173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff161415612a81576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612a7890614048565b60405180910390fd5b80600560008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c3183604051612b729190613e95565b60405180910390a3505050565b612b8a8484846125ab565b612b9684848484612e72565b612bd5576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612bcc90613f88565b60405180910390fd5b50505050565b60606000821415612c23576040518060400160405280600181526020017f30000000000000000000000000000000000000000000000000000000000000008152509050612d37565b600082905060005b60008214612c55578080612c3e906145b4565b915050600a82612c4e91906143e3565b9150612c2b565b60008167ffffffffffffffff811115612c7157612c70614751565b5b6040519080825280601f01601f191660200182016040528015612ca35781602001600182028036833780820191505090505b5090505b60008514612d3057600182612cbc9190614414565b9150600a85612ccb9190614635565b6030612cd7919061438d565b60f81b818381518110612ced57612cec614722565b5b60200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a905350600a85612d2991906143e3565b9450612ca7565b8093505050505b919050565b6000600560008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16905092915050565b60008282604051602001612de5929190613e02565b60405160208183030381529060405280519060200120905092915050565b600082612e108584613009565b1490509392505050565b612e258383836130bc565b612e2d61119d565b15612e6d576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612e6490613f48565b60405180910390fd5b505050565b6000612e938473ffffffffffffffffffffffffffffffffffffffff166130c1565b15612ffc578373ffffffffffffffffffffffffffffffffffffffff1663150b7a02612ebc61240c565b8786866040518563ffffffff1660e01b8152600401612ede9493929190613e49565b602060405180830381600087803b158015612ef857600080fd5b505af1925050508015612f2957506040513d601f19601f82011682018060405250810190612f26919061362a565b60015b612fac573d8060008114612f59576040519150601f19603f3d011682016040523d82523d6000602084013e612f5e565b606091505b50600081511415612fa4576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612f9b90613f88565b60405180910390fd5b805181602001fd5b63150b7a0260e01b7bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916817bffffffffffffffffffffffffffffffffffffffffffffffffffffffff191614915050613001565b600190505b949350505050565b60008082905060005b84518110156130b15760008582815181106130305761302f614722565b5b60200260200101519050808311613071578281604051602001613054929190613d9d565b60405160208183030381529060405280519060200120925061309d565b8083604051602001613084929190613d9d565b6040516020818303038152906040528051906020012092505b5080806130a9906145b4565b915050613012565b508091505092915050565b505050565b600080823b905060008111915050919050565b8280546130e090614551565b90600052602060002090601f0160209004810192826131025760008555613149565b82601f1061311b57805160ff1916838001178555613149565b82800160010185558215613149579182015b8281111561314857825182559160200191906001019061312d565b5b509050613156919061315a565b5090565b5b8082111561317357600081600090555060010161315b565b5090565b600061318a613185846142c8565b6142a3565b9050828152602081018484840111156131a6576131a561478f565b5b6131b184828561450f565b509392505050565b60006131cc6131c7846142f9565b6142a3565b9050828152602081018484840111156131e8576131e761478f565b5b6131f384828561450f565b509392505050565b60008135905061320a81614e17565b92915050565b60008083601f84011261322657613225614785565b5b8235905067ffffffffffffffff81111561324357613242614780565b5b60208301915083602082028301111561325f5761325e61478a565b5b9250929050565b60008083601f84011261327c5761327b614785565b5b8235905067ffffffffffffffff81111561329957613298614780565b5b6020830191508360408202830111156132b5576132b461478a565b5b9250929050565b6000813590506132cb81614e2e565b92915050565b6000813590506132e081614e45565b92915050565b6000813590506132f581614e5c565b92915050565b60008151905061330a81614e5c565b92915050565b600082601f83011261332557613324614785565b5b8135613335848260208601613177565b91505092915050565b60008151905061334d81614e73565b92915050565b60008135905061336281614e8a565b92915050565b600082601f83011261337d5761337c614785565b5b813561338d8482602086016131b9565b91505092915050565b6000813590506133a581614e9a565b92915050565b6000815190506133ba81614e9a565b92915050565b6000602082840312156133d6576133d5614799565b5b60006133e4848285016131fb565b91505092915050565b6000806040838503121561340457613403614799565b5b6000613412858286016131fb565b9250506020613423858286016131fb565b9150509250929050565b60008060006060848603121561344657613445614799565b5b6000613454868287016131fb565b9350506020613465868287016131fb565b925050604061347686828701613396565b9150509250925092565b6000806000806080858703121561349a57613499614799565b5b60006134a8878288016131fb565b94505060206134b9878288016131fb565b93505060406134ca87828801613396565b925050606085013567ffffffffffffffff8111156134eb576134ea614794565b5b6134f787828801613310565b91505092959194509250565b6000806040838503121561351a57613519614799565b5b6000613528858286016131fb565b9250506020613539858286016132bc565b9150509250929050565b6000806040838503121561355a57613559614799565b5b6000613568858286016131fb565b925050602061357985828601613396565b9150509250929050565b6000806020838503121561359a57613599614799565b5b600083013567ffffffffffffffff8111156135b8576135b7614794565b5b6135c485828601613266565b92509250509250929050565b6000602082840312156135e6576135e5614799565b5b60006135f4848285016132d1565b91505092915050565b60006020828403121561361357613612614799565b5b6000613621848285016132e6565b91505092915050565b6000602082840312156136405761363f614799565b5b600061364e848285016132fb565b91505092915050565b60006020828403121561366d5761366c614799565b5b600061367b8482850161333e565b91505092915050565b60006020828403121561369a57613699614799565b5b60006136a884828501613353565b91505092915050565b6000602082840312156136c7576136c6614799565b5b600082013567ffffffffffffffff8111156136e5576136e4614794565b5b6136f184828501613368565b91505092915050565b6000602082840312156137105761370f614799565b5b600061371e84828501613396565b91505092915050565b60006020828403121561373d5761373c614799565b5b600061374b848285016133ab565b91505092915050565b60008060006040848603121561376d5761376c614799565b5b600061377b86828701613396565b935050602084013567ffffffffffffffff81111561379c5761379b614794565b5b6137a886828701613210565b92509250509250925092565b600080604083850312156137cb576137ca614799565b5b60006137d9858286016133ab565b92505060206137ea858286016133ab565b9150509250929050565b6137fd81614448565b82525050565b61381461380f82614448565b6145fd565b82525050565b6138238161445a565b82525050565b61383a61383582614466565b61460f565b82525050565b600061384b8261433f565b6138558185614355565b935061386581856020860161451e565b61386e8161479e565b840191505092915050565b613882816144eb565b82525050565b613891816144fd565b82525050565b60006138a28261434a565b6138ac8185614371565b93506138bc81856020860161451e565b6138c58161479e565b840191505092915050565b60006138db8261434a565b6138e58185614382565b93506138f581856020860161451e565b80840191505092915050565b6000815461390e81614551565b6139188186614382565b94506001821660008114613933576001811461394457613977565b60ff19831686528186019350613977565b61394d8561432a565b60005b8381101561396f57815481890152600182019150602081019050613950565b838801955050505b50505092915050565b600061398d600e83614371565b9150613998826147bc565b602082019050919050565b60006139b0600e83614371565b91506139bb826147e5565b602082019050919050565b60006139d3602b83614371565b91506139de8261480e565b604082019050919050565b60006139f6601483614371565b9150613a018261485d565b602082019050919050565b6000613a19603283614371565b9150613a2482614886565b604082019050919050565b6000613a3c602683614371565b9150613a47826148d5565b604082019050919050565b6000613a5f601c83614371565b9150613a6a82614924565b602082019050919050565b6000613a82600f83614371565b9150613a8d8261494d565b602082019050919050565b6000613aa5601483614371565b9150613ab082614976565b602082019050919050565b6000613ac8602483614371565b9150613ad38261499f565b604082019050919050565b6000613aeb601983614371565b9150613af6826149ee565b602082019050919050565b6000613b0e602c83614371565b9150613b1982614a17565b604082019050919050565b6000613b31601f83614371565b9150613b3c82614a66565b602082019050919050565b6000613b54601083614371565b9150613b5f82614a8f565b602082019050919050565b6000613b77603883614371565b9150613b8282614ab8565b604082019050919050565b6000613b9a602a83614371565b9150613ba582614b07565b604082019050919050565b6000613bbd602983614371565b9150613bc882614b56565b604082019050919050565b6000613be0600f83614371565b9150613beb82614ba5565b602082019050919050565b6000613c03602083614371565b9150613c0e82614bce565b602082019050919050565b6000613c26601983614371565b9150613c3182614bf7565b602082019050919050565b6000613c49600e83614371565b9150613c5482614c20565b602082019050919050565b6000613c6c602c83614371565b9150613c7782614c49565b604082019050919050565b6000613c8f602083614371565b9150613c9a82614c98565b602082019050919050565b6000613cb2602983614371565b9150613cbd82614cc1565b604082019050919050565b6000613cd5602183614371565b9150613ce082614d10565b604082019050919050565b6000613cf8600083614366565b9150613d0382614d5f565b600082019050919050565b6000613d1b601083614371565b9150613d2682614d62565b602082019050919050565b6000613d3e603183614371565b9150613d4982614d8b565b604082019050919050565b6000613d61601d83614371565b9150613d6c82614dda565b602082019050919050565b613d80816144e1565b82525050565b613d97613d92826144e1565b61462b565b82525050565b6000613da98285613829565b602082019150613db98284613829565b6020820191508190509392505050565b6000613dd58285613901565b9150613de182846138d0565b91508190509392505050565b6000613df882613ceb565b9150819050919050565b6000613e0e8285613d86565b602082019150613e1e8284613803565b6014820191508190509392505050565b6000602082019050613e4360008301846137f4565b92915050565b6000608082019050613e5e60008301876137f4565b613e6b60208301866137f4565b613e786040830185613d77565b8181036060830152613e8a8184613840565b905095945050505050565b6000602082019050613eaa600083018461381a565b92915050565b6000602082019050613ec56000830184613879565b92915050565b6000602082019050613ee06000830184613888565b92915050565b60006020820190508181036000830152613f008184613897565b905092915050565b60006020820190508181036000830152613f2181613980565b9050919050565b60006020820190508181036000830152613f41816139a3565b9050919050565b60006020820190508181036000830152613f61816139c6565b9050919050565b60006020820190508181036000830152613f81816139e9565b9050919050565b60006020820190508181036000830152613fa181613a0c565b9050919050565b60006020820190508181036000830152613fc181613a2f565b9050919050565b60006020820190508181036000830152613fe181613a52565b9050919050565b6000602082019050818103600083015261400181613a75565b9050919050565b6000602082019050818103600083015261402181613a98565b9050919050565b6000602082019050818103600083015261404181613abb565b9050919050565b6000602082019050818103600083015261406181613ade565b9050919050565b6000602082019050818103600083015261408181613b01565b9050919050565b600060208201905081810360008301526140a181613b24565b9050919050565b600060208201905081810360008301526140c181613b47565b9050919050565b600060208201905081810360008301526140e181613b6a565b9050919050565b6000602082019050818103600083015261410181613b8d565b9050919050565b6000602082019050818103600083015261412181613bb0565b9050919050565b6000602082019050818103600083015261414181613bd3565b9050919050565b6000602082019050818103600083015261416181613bf6565b9050919050565b6000602082019050818103600083015261418181613c19565b9050919050565b600060208201905081810360008301526141a181613c3c565b9050919050565b600060208201905081810360008301526141c181613c5f565b9050919050565b600060208201905081810360008301526141e181613c82565b9050919050565b6000602082019050818103600083015261420181613ca5565b9050919050565b6000602082019050818103600083015261422181613cc8565b9050919050565b6000602082019050818103600083015261424181613d0e565b9050919050565b6000602082019050818103600083015261426181613d31565b9050919050565b6000602082019050818103600083015261428181613d54565b9050919050565b600060208201905061429d6000830184613d77565b92915050565b60006142ad6142be565b90506142b98282614583565b919050565b6000604051905090565b600067ffffffffffffffff8211156142e3576142e2614751565b5b6142ec8261479e565b9050602081019050919050565b600067ffffffffffffffff82111561431457614313614751565b5b61431d8261479e565b9050602081019050919050565b60008190508160005260206000209050919050565b600081519050919050565b600081519050919050565b600082825260208201905092915050565b600081905092915050565b600082825260208201905092915050565b600081905092915050565b6000614398826144e1565b91506143a3836144e1565b9250827fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff038211156143d8576143d7614666565b5b828201905092915050565b60006143ee826144e1565b91506143f9836144e1565b92508261440957614408614695565b5b828204905092915050565b600061441f826144e1565b915061442a836144e1565b92508282101561443d5761443c614666565b5b828203905092915050565b6000614453826144c1565b9050919050565b60008115159050919050565b6000819050919050565b60007fffffffff0000000000000000000000000000000000000000000000000000000082169050919050565b60006144a782614448565b9050919050565b60008190506144bc82614e03565b919050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000819050919050565b60006144f6826144ae565b9050919050565b6000614508826144e1565b9050919050565b82818337600083830152505050565b60005b8381101561453c578082015181840152602081019050614521565b8381111561454b576000848401525b50505050565b6000600282049050600182168061456957607f821691505b6020821081141561457d5761457c6146f3565b5b50919050565b61458c8261479e565b810181811067ffffffffffffffff821117156145ab576145aa614751565b5b80604052505050565b60006145bf826144e1565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8214156145f2576145f1614666565b5b600182019050919050565b600061460882614619565b9050919050565b6000819050919050565b6000614624826147af565b9050919050565b6000819050919050565b6000614640826144e1565b915061464b836144e1565b92508261465b5761465a614695565b5b828206905092915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b600080fd5b600080fd5b600080fd5b600080fd5b600080fd5b600080fd5b6000601f19601f8301169050919050565b60008160601b9050919050565b7f4d696e742066696e616c697a6564000000000000000000000000000000000000600082015250565b7f416c7265616479206d696e746564000000000000000000000000000000000000600082015250565b7f4552433732315061757361626c653a20746f6b656e207472616e73666572207760008201527f68696c6520706175736564000000000000000000000000000000000000000000602082015250565b7f5061757361626c653a206e6f7420706175736564000000000000000000000000600082015250565b7f4552433732313a207472616e7366657220746f206e6f6e20455243373231526560008201527f63656976657220696d706c656d656e7465720000000000000000000000000000602082015250565b7f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160008201527f6464726573730000000000000000000000000000000000000000000000000000602082015250565b7f4552433732313a20746f6b656e20616c7265616479206d696e74656400000000600082015250565b7f4d696e74206e6f74206163746976650000000000000000000000000000000000600082015250565b7f4d696e74206e6f74206d61696e74656e616e6365000000000000000000000000600082015250565b7f4552433732313a207472616e7366657220746f20746865207a65726f2061646460008201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b7f4552433732313a20617070726f766520746f2063616c6c657200000000000000600082015250565b7f4552433732313a206f70657261746f7220717565727920666f72206e6f6e657860008201527f697374656e7420746f6b656e0000000000000000000000000000000000000000602082015250565b7f41646472657373206973206e6f7420696e207468652077686974656c69737400600082015250565b7f5061757361626c653a2070617573656400000000000000000000000000000000600082015250565b7f4552433732313a20617070726f76652063616c6c6572206973206e6f74206f7760008201527f6e6572206e6f7220617070726f76656420666f7220616c6c0000000000000000602082015250565b7f4552433732313a2062616c616e636520717565727920666f7220746865207a6560008201527f726f206164647265737300000000000000000000000000000000000000000000602082015250565b7f4552433732313a206f776e657220717565727920666f72206e6f6e657869737460008201527f656e7420746f6b656e0000000000000000000000000000000000000000000000602082015250565b7f4d696e74206e6f7420636c6f7365640000000000000000000000000000000000600082015250565b7f4552433732313a206d696e7420746f20746865207a65726f2061646472657373600082015250565b7f4e6f206574686572206c65667420746f20776974686472617700000000000000600082015250565b7f4e6f7420656e6f75676820455448000000000000000000000000000000000000600082015250565b7f4552433732313a20617070726f76656420717565727920666f72206e6f6e657860008201527f697374656e7420746f6b656e0000000000000000000000000000000000000000602082015250565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572600082015250565b7f4552433732313a207472616e73666572206f6620746f6b656e2074686174206960008201527f73206e6f74206f776e0000000000000000000000000000000000000000000000602082015250565b7f4552433732313a20617070726f76616c20746f2063757272656e74206f776e6560008201527f7200000000000000000000000000000000000000000000000000000000000000602082015250565b50565b7f5472616e73666572206661696c65642e00000000000000000000000000000000600082015250565b7f4552433732313a207472616e736665722063616c6c6572206973206e6f74206f60008201527f776e6572206e6f7220617070726f766564000000000000000000000000000000602082015250565b7f4e6f7420656e6f75676820726573657276656420676f6473206c656674000000600082015250565b60048110614e1457614e136146c4565b5b50565b614e2081614448565b8114614e2b57600080fd5b50565b614e378161445a565b8114614e4257600080fd5b50565b614e4e81614466565b8114614e5957600080fd5b50565b614e6581614470565b8114614e7057600080fd5b50565b614e7c8161449c565b8114614e8757600080fd5b50565b60048110614e9757600080fd5b50565b614ea3816144e1565b8114614eae57600080fd5b5056fe68747470733a2f2f697066732e696f2f697066732f516d625a77505a674b5336594a6b54325534566d7038377564413643667934547536334b4b447634516e6e635532a2646970667358221220241dca9c08ed4b490c34f109a2a1fce12be1a9a08bc5026372d4b41b8ab80b6964736f6c6343000807003300000000000000000000000081360edef3b9f3639fa60639729881aba9fe29b1000000000000000000000000000000000000000000000000000000000000008000000000000000000000000000000000000000000000000001118f178fb48000000000000000000000000000f57b2c51ded3a29e6891aba85459d600256cf3170000000000000000000000000000000000000000000000000000000000000036697066733a2f2f516d655a397a477446737a7039713366634b374d536f7573736a6d346e42715238786251317a386f4463474459612f00000000000000000000

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

00000000000000000000000081360edef3b9f3639fa60639729881aba9fe29b1000000000000000000000000000000000000000000000000000000000000008000000000000000000000000000000000000000000000000001118f178fb48000000000000000000000000000f57b2c51ded3a29e6891aba85459d600256cf3170000000000000000000000000000000000000000000000000000000000000036697066733a2f2f516d655a397a477446737a7039713366634b374d536f7573736a6d346e42715238786251317a386f4463474459612f00000000000000000000

-----Decoded View---------------
Arg [0] : _genesisSupplyAddress (address): 0x81360edef3b9f3639fa60639729881aba9fe29b1
Arg [1] : unrevealedURI (string): ipfs://QmeZ9zGtFszp9q3fcK7MSoussjm4nBqR8xbQ1z8oDcGDYa/
Arg [2] : _price (uint256): 77000000000000000
Arg [3] : _proxyRegistryAddress (address): 0xf57b2c51ded3a29e6891aba85459d600256cf317

-----Encoded View---------------
7 Constructor Arguments found :
Arg [0] : 00000000000000000000000081360edef3b9f3639fa60639729881aba9fe29b1
Arg [1] : 0000000000000000000000000000000000000000000000000000000000000080
Arg [2] : 00000000000000000000000000000000000000000000000001118f178fb48000
Arg [3] : 000000000000000000000000f57b2c51ded3a29e6891aba85459d600256cf317
Arg [4] : 0000000000000000000000000000000000000000000000000000000000000036
Arg [5] : 697066733a2f2f516d655a397a477446737a7039713366634b374d536f757373
Arg [6] : 6a6d346e42715238786251317a386f4463474459612f00000000000000000000


Block Transaction Difficulty Gas Used Reward
Block Uncle Number Difficulty Gas Used Reward
Loading

A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.