ETH Price: $3,336.44 (-0.37%)
 

Overview

Max Total Supply

3,002 DGV

Holders

1,329

Market

Volume (24H)

N/A

Min Price (24H)

N/A

Max Price (24H)

N/A
Balance
1 DGV
0xe46f313aee954b140cf95509b0cfb5b4b9938b41
Loading...
Loading
Loading...
Loading
Loading...
Loading

OVERVIEW

DragonVerse is a collection of 3000 Dragons, programmatically and randomly generated on the Ethereum Blockchain. Each dragon is unique, made from a combination of more than 200 attributes drawn by hand. A dragon is both a NFT collectible and a key to enter the DragonVerse Pl...

# Exchange Pair Price  24H Volume % Volume

Contract Source Code Verified (Exact Match)

Contract Name:
DragonVerse

Compiler Version
v0.8.7+commit.e28d00a7

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, None license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2021-11-12
*/

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



pragma solidity ^0.8.0;

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

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

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

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

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

// File: @openzeppelin/contracts/utils/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: @openzeppelin/contracts/security/Pausable.sol



pragma solidity ^0.8.0;


/**
 * @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: @openzeppelin/contracts/access/Ownable.sol



pragma solidity ^0.8.0;


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

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

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() {
        _setOwner(_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 {
        _setOwner(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");
        _setOwner(newOwner);
    }

    function _setOwner(address newOwner) private {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}

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



pragma solidity ^0.8.0;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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



pragma solidity ^0.8.0;

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

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



pragma solidity ^0.8.0;

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

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



pragma solidity ^0.8.0;


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

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



pragma solidity ^0.8.0;


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

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

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

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

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

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

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

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

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

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

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

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

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



pragma solidity ^0.8.0;


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

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

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

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



pragma solidity ^0.8.0;








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

    // Token name
    string private _name;

    // Token symbol
    string private _symbol;

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

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

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

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

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

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

    /**
     * @dev See {IERC721-balanceOf}.
     */
    function balanceOf(address owner) public view virtual override returns (uint256) {
        require(owner != address(0), "ERC721: balance query for the zero address");
        return _balances[owner];
    }

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

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

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

    /**
     * @dev See {IERC721Metadata-tokenURI}.
     */
    function tokenURI(uint256 tokenId) public view virtual override returns (string memory) {
        require(_exists(tokenId), "ERC721Metadata: URI query for nonexistent token");

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

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

    /**
     * @dev See {IERC721-approve}.
     */
    function approve(address to, uint256 tokenId) public virtual override {
        address owner = ERC721.ownerOf(tokenId);
        require(to != owner, "ERC721: approval to current owner");

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

        _approve(to, tokenId);
    }

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

        return _tokenApprovals[tokenId];
    }

    /**
     * @dev See {IERC721-setApprovalForAll}.
     */
    function setApprovalForAll(address operator, bool approved) public virtual override {
        require(operator != _msgSender(), "ERC721: approve to caller");

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

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

    /**
     * @dev See {IERC721-transferFrom}.
     */
    function transferFrom(
        address from,
        address to,
        uint256 tokenId
    ) public virtual override {
        //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 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: @openzeppelin/contracts/token/ERC721/extensions/ERC721URIStorage.sol



pragma solidity ^0.8.0;


/**
 * @dev ERC721 token with storage based token URI management.
 */
abstract contract ERC721URIStorage is ERC721 {
    using Strings for uint256;

    // Optional mapping for token URIs
    mapping(uint256 => string) private _tokenURIs;

    /**
     * @dev See {IERC721Metadata-tokenURI}.
     */
    function tokenURI(uint256 tokenId) public view virtual override returns (string memory) {
        require(_exists(tokenId), "ERC721URIStorage: URI query for nonexistent token");

        string memory _tokenURI = _tokenURIs[tokenId];
        string memory base = _baseURI();

        // If there is no base URI, return the token URI.
        if (bytes(base).length == 0) {
            return _tokenURI;
        }
        // If both are set, concatenate the baseURI and tokenURI (via abi.encodePacked).
        if (bytes(_tokenURI).length > 0) {
            return string(abi.encodePacked(base, _tokenURI));
        }

        return super.tokenURI(tokenId);
    }

    /**
     * @dev Sets `_tokenURI` as the tokenURI of `tokenId`.
     *
     * Requirements:
     *
     * - `tokenId` must exist.
     */
    function _setTokenURI(uint256 tokenId, string memory _tokenURI) internal virtual {
        require(_exists(tokenId), "ERC721URIStorage: URI set of nonexistent token");
        _tokenURIs[tokenId] = _tokenURI;
    }

    /**
     * @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 override {
        super._burn(tokenId);

        if (bytes(_tokenURIs[tokenId]).length != 0) {
            delete _tokenURIs[tokenId];
        }
    }
}

// File: contracts/DragonVerse.sol

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



/**
 * @dev Implementation of Non-Fungible Token Standard (ERC-721)
 * This contract is designed to be ready-to-use and versatile.
 */
contract DragonVerse is ERC721URIStorage, Ownable, Pausable {
    
    // general constants and immutable variables
    uint256 public maxItems                         = 9999; // maximum number of items in the collection
    uint256 public maxMintsPerTx                    = 5;    // maximum number of mints per transaction
    uint256 public maxMintPreSale                   = 2;    // maximum number of mint per wallet for the presale
    uint256 public startingTimePreSale              = 1636743600; // UTC timestamp when minting starts for presale
    uint256 public startingTimePublicSale           = 1636830000; // UTC timestamp when minting starts for public sale
    uint256 public pricePreSale                     = 0.08 ether; // price for minting one NFT
    uint256 public pricePublicSale                  = 0.1 ether;  // price for minting one NFT
    uint256 public totalSupply;                             // number of NFTs minted thus far
    bool public specialMintLocked;                          // when `true`, `specialMint` cannot longer be called
    string public contractUri;
    mapping(address => uint256) public amountMintedWhitelist; // Keep track of the amount mint by the whitelist
    
    mapping(address => uint256[]) internal _ownerToIds;     // mapping from owner to list of owned NFT IDs.
    mapping(uint256 => uint256) internal _idToOwnerIndex;
    address internal __wallet; // Address of the treasuary wallet
    string internal __baseURI;
    string internal _extensionURI;
    
    constructor(string memory name_,
                string memory symbol_,
                address wallet_,
                string memory _baseURI_,
                string memory _extensionURI_) ERC721(name_, symbol_) {
                    
        __baseURI = _baseURI_;
        _extensionURI = _extensionURI_;
        __wallet = wallet_;
    }
    
    function setMaxMintsPerTx(uint256 _newMax) external onlyOwner {
        maxMintsPerTx = _newMax;
    }
    
    function setMaxMintsPreSale(uint256 _newMax) external onlyOwner {
        maxMintPreSale = _newMax;
    }
    
    function setStartingTimePreSale(uint256 _startingTime) external onlyOwner {
        startingTimePreSale = _startingTime;
    }
    
    function setStartingTimePublicSale(uint256 _startingTime) external onlyOwner {
        startingTimePublicSale = _startingTime;
    }
    
    function setPricePreSale(uint256 _newPrice) public onlyOwner {
        require(_newPrice > 0, "price must be positive");
        pricePreSale = _newPrice;
    }
    
    function setPricePublicSale(uint256 _newPrice) public onlyOwner {
        require(_newPrice > 0, "price must be positive");
        pricePublicSale = _newPrice;
    }
    
    function setWallet(address _wallet) external onlyOwner {
        __wallet = _wallet;
    }
    
    function setBaseURI(string memory _newBaseURI) external onlyOwner {
        __baseURI = _newBaseURI;
    }
    
    function setExtensionURI(string memory _newExtensionURI) external onlyOwner {
        _extensionURI = _newExtensionURI;
    }
    
    
    function tokenURI(uint256 tokenId) public view virtual override returns (string memory) {
        if(bytes(_extensionURI).length == 0){
            return super.tokenURI(tokenId);
        }
        
        return string(abi.encodePacked(super.tokenURI(tokenId), _extensionURI));
    }
    
    function contractURI() public view returns (string memory) {
        return string(abi.encodePacked(__baseURI, "contract/default.json"));
    }
    
    function getOwnerNFTs(address owner) public view returns (uint256[] memory){
        return _ownerToIds[owner];
    }
    
    function mint(uint256 _numToMint) external payable whenNotPaused {
        require(block.timestamp > startingTimePublicSale, "minting not open yet");
        require(msg.value >= pricePublicSale * _numToMint, 'not enough eth');
        require(_numToMint > 0, "not enough mint");
        require((_numToMint + totalSupply) <= maxItems, "would exceed max supply");
        require(_numToMint <= maxMintsPerTx, "limit on minting too many at a time");
        
        for(uint256 i=totalSupply; i < (totalSupply + _numToMint); i++){
            _mint(msg.sender, i);
        }
        
        totalSupply += _numToMint;
    }
    
    function mintWhitelist(uint256 _numToMint, bytes memory signature) external payable {
        require(verify(signature, msg.sender)); // We check if the user has provided the correct data and if he's whitelisted
        require(msg.value >= pricePreSale * _numToMint, 'not enough eth');
        require(_numToMint > 0, "not enough");
        require((_numToMint + totalSupply) <= maxItems, "would exceed max supply");
        require(_numToMint <= maxMintsPerTx, "limit on minting too many at a time");
        require(amountMintedWhitelist[msg.sender] + _numToMint <= maxMintPreSale, "limit on minting too many while whitelisted");
        
        for(uint256 i=totalSupply; i < (totalSupply + _numToMint); i++){
            _mint(msg.sender, i);
        }
        
        amountMintedWhitelist[msg.sender] = amountMintedWhitelist[msg.sender] + _numToMint;
        totalSupply += _numToMint;
    } 
    
    function mintSpecial(address[] memory recipients, uint256[] memory amounts) external onlyOwner {
        require(!specialMintLocked, "special mint permanently locked");
        require(recipients.length == amounts.length, "arrays have different lengths");
        
        for (uint256 i=0; i < recipients.length; i++){
            for(uint256 j=totalSupply; j < (totalSupply + amounts[i]); j++){
                _mint(recipients[i], j);
            }
            
            totalSupply += amounts[i];
        }
    }
    
    
    function verify(bytes memory signature, address target) public view returns (bool) {
        uint8 v;
        bytes32 r;
        bytes32 s;
        (v, r, s) = splitSignature(signature);
        bytes32 senderHash = keccak256(abi.encodePacked(target));
        
        return (owner() == address(ecrecover(senderHash, v, r, s)));
    }
    
    function splitSignature(bytes memory sig) public pure returns (uint8, bytes32, bytes32) {
       require(sig.length == 65);
       
       bytes32 r;
       bytes32 s;
       uint8 v;
       assembly {
           // first 32 bytes, after the length prefix
           r := mload(add(sig, 32))
           // second 32 bytes
           s := mload(add(sig, 64))
           // final byte (first byte of the next 32 bytes)
           v := byte(0, mload(add(sig, 96)))
       }
       return (v, r, s);
   }
   
    /**
     * @dev Burns `tokenId`. See {ERC721-_burn}.
     *
     * Requirements:
     *
     * - The caller must own `tokenId` or be an approved operator.
     */
    function burn(uint256 tokenId) public virtual {
        require(_isApprovedOrOwner(_msgSender(), tokenId), "ERC721Burnable: caller is not owner nor approved");
        _burn(tokenId);
    }
    
    // permanently prevent dev from calling `specialMint`.
    function lockSpecialMint() external onlyOwner
    {
        specialMintLocked = true;
    }
    
    function withdraw() external payable onlyOwner returns (bool success) {
        (success,) = payable(__wallet).call{value: address(this).balance}("");
    }
    
    function _beforeTokenTransfer(address from, address to, uint256 tokenId) internal override {
        if(from != address(0)){
            require(from == ownerOf(tokenId), "not owner");
        }
        
        if(from == to){
            return;
        }
        
        uint256 _idToPreviousOwnerIndex = _idToOwnerIndex[tokenId];
        // adding token to array of new owner
        
        if(to != address(0)){
            _ownerToIds[to].push(tokenId);
            _idToOwnerIndex[tokenId] = _ownerToIds[to].length - 1;
        }
        
        // remove token from array of previous owner
        if(from != address(0)){
            uint256 _len = _ownerToIds[from].length;
            if(_idToPreviousOwnerIndex < (_len - 1)){
                _ownerToIds[from][_idToPreviousOwnerIndex] = _ownerToIds[from][_len - 1];
            }
            _ownerToIds[from].pop();
        }
    }
    
    function _baseURI() internal view override returns (string memory) {
        return __baseURI;
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"string","name":"name_","type":"string"},{"internalType":"string","name":"symbol_","type":"string"},{"internalType":"address","name":"wallet_","type":"address"},{"internalType":"string","name":"_baseURI_","type":"string"},{"internalType":"string","name":"_extensionURI_","type":"string"}],"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":[{"internalType":"address","name":"","type":"address"}],"name":"amountMintedWhitelist","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"approve","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"burn","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"contractURI","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"contractUri","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"getApproved","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"getOwnerNFTs","outputs":[{"internalType":"uint256[]","name":"","type":"uint256[]"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"operator","type":"address"}],"name":"isApprovedForAll","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"lockSpecialMint","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"maxItems","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxMintPreSale","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxMintsPerTx","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_numToMint","type":"uint256"}],"name":"mint","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address[]","name":"recipients","type":"address[]"},{"internalType":"uint256[]","name":"amounts","type":"uint256[]"}],"name":"mintSpecial","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_numToMint","type":"uint256"},{"internalType":"bytes","name":"signature","type":"bytes"}],"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":"paused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pricePreSale","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pricePublicSale","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":"_newBaseURI","type":"string"}],"name":"setBaseURI","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"string","name":"_newExtensionURI","type":"string"}],"name":"setExtensionURI","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_newMax","type":"uint256"}],"name":"setMaxMintsPerTx","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_newMax","type":"uint256"}],"name":"setMaxMintsPreSale","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_newPrice","type":"uint256"}],"name":"setPricePreSale","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_newPrice","type":"uint256"}],"name":"setPricePublicSale","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_startingTime","type":"uint256"}],"name":"setStartingTimePreSale","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_startingTime","type":"uint256"}],"name":"setStartingTimePublicSale","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_wallet","type":"address"}],"name":"setWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"specialMintLocked","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes","name":"sig","type":"bytes"}],"name":"splitSignature","outputs":[{"internalType":"uint8","name":"","type":"uint8"},{"internalType":"bytes32","name":"","type":"bytes32"},{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"startingTimePreSale","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"startingTimePublicSale","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes4","name":"interfaceId","type":"bytes4"}],"name":"supportsInterface","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"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":[{"internalType":"bytes","name":"signature","type":"bytes"},{"internalType":"address","name":"target","type":"address"}],"name":"verify","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"withdraw","outputs":[{"internalType":"bool","name":"success","type":"bool"}],"stateMutability":"payable","type":"function"}]

608060405261270f60085560056009556002600a5563618eb9b0600b556361900b30600c5567011c37937e080000600d5567016345785d8a0000600e553480156200004957600080fd5b5060405162003434380380620034348339810160408190526200006c91620002d0565b8451859085906200008590600090602085019062000173565b5080516200009b90600190602084019062000173565b505050620000b8620000b26200011d60201b60201c565b62000121565b6007805460ff60a01b191690558151620000da90601690602085019062000173565b508051620000f090601790602084019062000173565b5050601580546001600160a01b0319166001600160a01b03939093169290921790915550620003fe915050565b3390565b600780546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b8280546200018190620003ab565b90600052602060002090601f016020900481019282620001a55760008555620001f0565b82601f10620001c057805160ff1916838001178555620001f0565b82800160010185558215620001f0579182015b82811115620001f0578251825591602001919060010190620001d3565b50620001fe92915062000202565b5090565b5b80821115620001fe576000815560010162000203565b600082601f8301126200022b57600080fd5b81516001600160401b0380821115620002485762000248620003e8565b604051601f8301601f19908116603f01168101908282118183101715620002735762000273620003e8565b816040528381526020925086838588010111156200029057600080fd5b600091505b83821015620002b4578582018301518183018401529082019062000295565b83821115620002c65760008385830101525b9695505050505050565b600080600080600060a08688031215620002e957600080fd5b85516001600160401b03808211156200030157600080fd5b6200030f89838a0162000219565b965060208801519150808211156200032657600080fd5b6200033489838a0162000219565b604089015190965091506001600160a01b03821682146200035457600080fd5b6060880151919450808211156200036a57600080fd5b6200037889838a0162000219565b935060808801519150808211156200038f57600080fd5b506200039e8882890162000219565b9150509295509295909350565b600181811c90821680620003c057607f821691505b60208210811415620003e257634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052604160045260246000fd5b613026806200040e6000396000f3fe6080604052600436106102885760003560e01c80638da5cb5b1161015a578063c3bb8c64116100c1578063deaa59df1161007a578063deaa59df1461076e578063e20346691461078e578063e8a3d485146107ae578063e985e9c5146107c3578063f29efaeb1461080c578063f2fde38b1461082c57600080fd5b8063c3bb8c64146106cc578063c4165653146106ec578063c87b56dd1461070c578063cd08c0461461072c578063d8d1038c14610742578063dc30158b1461075857600080fd5b8063a7bb580311610113578063a7bb580314610602578063b32142c414610641578063b843b09014610661578063b88d4fde14610681578063c0cf3f41146106a1578063c0e24d5e146106b757600080fd5b80638da5cb5b1461056f5780638ede9e4d1461058d57806395d89b41146105a75780639f41554a146105bc578063a0712d68146105cf578063a22cb465146105e257600080fd5b80633641d544116101fe57806355f804b3116101b757806355f804b3146104ae5780635c975abb146104ce5780636352211e146104ed57806370a082311461050d578063715018a61461052d5780638c0175721461054257600080fd5b80633641d5441461041a5780633c010a3e146104305780633ccfd60b146104465780633d3ac1b51461044e57806342842e0e1461046e57806342966c681461048e57600080fd5b806311b92aaf1161025057806311b92aaf14610362578063174da4a21461037757806318160ddd1461039757806323b872dd146103ad578063279ad417146103cd5780632e257676146103ed57600080fd5b806301ffc9a71461028d57806306fdde03146102c2578063081812fc146102e4578063095ea7b31461031c5780630fae42cd1461033e575b600080fd5b34801561029957600080fd5b506102ad6102a83660046129d0565b61084c565b60405190151581526020015b60405180910390f35b3480156102ce57600080fd5b506102d761089e565b6040516102b99190612cf1565b3480156102f057600080fd5b506103046102ff366004612acd565b610930565b6040516001600160a01b0390911681526020016102b9565b34801561032857600080fd5b5061033c6103373660046128df565b6109ca565b005b34801561034a57600080fd5b50610354600d5481565b6040519081526020016102b9565b34801561036e57600080fd5b5061033c610ae0565b34801561038357600080fd5b5061033c610392366004612acd565b610b19565b3480156103a357600080fd5b50610354600f5481565b3480156103b957600080fd5b5061033c6103c83660046127ff565b610b48565b3480156103d957600080fd5b5061033c6103e8366004612acd565b610b7a565b3480156103f957600080fd5b506103546104083660046127b1565b60126020526000908152604090205481565b34801561042657600080fd5b50610354600c5481565b34801561043c57600080fd5b5061035460085481565b6102ad610bf2565b34801561045a57600080fd5b506102ad610469366004612a3f565b610c79565b34801561047a57600080fd5b5061033c6104893660046127ff565b610d54565b34801561049a57600080fd5b5061033c6104a9366004612acd565b610d6f565b3480156104ba57600080fd5b5061033c6104c9366004612a84565b610de9565b3480156104da57600080fd5b50600754600160a01b900460ff166102ad565b3480156104f957600080fd5b50610304610508366004612acd565b610e2a565b34801561051957600080fd5b506103546105283660046127b1565b610ea1565b34801561053957600080fd5b5061033c610f28565b34801561054e57600080fd5b5061056261055d3660046127b1565b610f5e565b6040516102b99190612cad565b34801561057b57600080fd5b506007546001600160a01b0316610304565b34801561059957600080fd5b506010546102ad9060ff1681565b3480156105b357600080fd5b506102d7610fca565b61033c6105ca366004612ae6565b610fd9565b61033c6105dd366004612acd565b6111f0565b3480156105ee57600080fd5b5061033c6105fd3660046128a3565b6113df565b34801561060e57600080fd5b5061062261061d366004612a0a565b6114a4565b6040805160ff90941684526020840192909252908201526060016102b9565b34801561064d57600080fd5b5061033c61065c366004612acd565b6114d3565b34801561066d57600080fd5b5061033c61067c366004612909565b611502565b34801561068d57600080fd5b5061033c61069c36600461283b565b611687565b3480156106ad57600080fd5b50610354600a5481565b3480156106c357600080fd5b506102d76116bf565b3480156106d857600080fd5b5061033c6106e7366004612a84565b61174d565b3480156106f857600080fd5b5061033c610707366004612acd565b61178a565b34801561071857600080fd5b506102d7610727366004612acd565b6117b9565b34801561073857600080fd5b50610354600e5481565b34801561074e57600080fd5b50610354600b5481565b34801561076457600080fd5b5061035460095481565b34801561077a57600080fd5b5061033c6107893660046127b1565b61180b565b34801561079a57600080fd5b5061033c6107a9366004612acd565b611857565b3480156107ba57600080fd5b506102d76118cf565b3480156107cf57600080fd5b506102ad6107de3660046127cc565b6001600160a01b03918216600090815260056020908152604080832093909416825291909152205460ff1690565b34801561081857600080fd5b5061033c610827366004612acd565b6118f7565b34801561083857600080fd5b5061033c6108473660046127b1565b611926565b60006001600160e01b031982166380ac58cd60e01b148061087d57506001600160e01b03198216635b5e139f60e01b145b8061089857506301ffc9a760e01b6001600160e01b03198316145b92915050565b6060600080546108ad90612f02565b80601f01602080910402602001604051908101604052809291908181526020018280546108d990612f02565b80156109265780601f106108fb57610100808354040283529160200191610926565b820191906000526020600020905b81548152906001019060200180831161090957829003601f168201915b5050505050905090565b6000818152600260205260408120546001600160a01b03166109ae5760405162461bcd60e51b815260206004820152602c60248201527f4552433732313a20617070726f76656420717565727920666f72206e6f6e657860448201526b34b9ba32b73a103a37b5b2b760a11b60648201526084015b60405180910390fd5b506000908152600460205260409020546001600160a01b031690565b60006109d582610e2a565b9050806001600160a01b0316836001600160a01b03161415610a435760405162461bcd60e51b815260206004820152602160248201527f4552433732313a20617070726f76616c20746f2063757272656e74206f776e656044820152603960f91b60648201526084016109a5565b336001600160a01b0382161480610a5f5750610a5f81336107de565b610ad15760405162461bcd60e51b815260206004820152603860248201527f4552433732313a20617070726f76652063616c6c6572206973206e6f74206f7760448201527f6e6572206e6f7220617070726f76656420666f7220616c6c000000000000000060648201526084016109a5565b610adb83836119be565b505050565b6007546001600160a01b03163314610b0a5760405162461bcd60e51b81526004016109a590612d99565b6010805460ff19166001179055565b6007546001600160a01b03163314610b435760405162461bcd60e51b81526004016109a590612d99565b600955565b610b53335b82611a2c565b610b6f5760405162461bcd60e51b81526004016109a590612dce565b610adb838383611b23565b6007546001600160a01b03163314610ba45760405162461bcd60e51b81526004016109a590612d99565b60008111610bed5760405162461bcd60e51b81526020600482015260166024820152757072696365206d75737420626520706f73697469766560501b60448201526064016109a5565b600e55565b6007546000906001600160a01b03163314610c1f5760405162461bcd60e51b81526004016109a590612d99565b6015546040516001600160a01b03909116904790600081818185875af1925050503d8060008114610c6c576040519150601f19603f3d011682016040523d82523d6000602084013e610c71565b606091505b509092915050565b600080600080610c88866114a4565b6040516bffffffffffffffffffffffff1960608a901b166020820152929550909350915060009060340160408051601f1981840301815282825280516020918201206000845290830180835281905260ff8716918301919091526060820185905260808201849052915060019060a0016020604051602081039080840390855afa158015610d1a573d6000803e3d6000fd5b505050602060405103516001600160a01b0316610d3f6007546001600160a01b031690565b6001600160a01b031614979650505050505050565b610adb83838360405180602001604052806000815250611687565b610d7833610b4d565b610ddd5760405162461bcd60e51b815260206004820152603060248201527f4552433732314275726e61626c653a2063616c6c6572206973206e6f74206f7760448201526f1b995c881b9bdc88185c1c1c9bdd995960821b60648201526084016109a5565b610de681611cce565b50565b6007546001600160a01b03163314610e135760405162461bcd60e51b81526004016109a590612d99565b8051610e269060169060208401906125dc565b5050565b6000818152600260205260408120546001600160a01b0316806108985760405162461bcd60e51b815260206004820152602960248201527f4552433732313a206f776e657220717565727920666f72206e6f6e657869737460448201526832b73a103a37b5b2b760b91b60648201526084016109a5565b60006001600160a01b038216610f0c5760405162461bcd60e51b815260206004820152602a60248201527f4552433732313a2062616c616e636520717565727920666f7220746865207a65604482015269726f206164647265737360b01b60648201526084016109a5565b506001600160a01b031660009081526003602052604090205490565b6007546001600160a01b03163314610f525760405162461bcd60e51b81526004016109a590612d99565b610f5c6000611d0e565b565b6001600160a01b038116600090815260136020908152604091829020805483518184028101840190945280845260609392830182828015610fbe57602002820191906000526020600020905b815481526020019060010190808311610faa575b50505050509050919050565b6060600180546108ad90612f02565b610fe38133610c79565b610fec57600080fd5b81600d54610ffa9190612ea0565b34101561103a5760405162461bcd60e51b815260206004820152600e60248201526d0dcdee840cadcdeeaced040cae8d60931b60448201526064016109a5565b600082116110775760405162461bcd60e51b815260206004820152600a6024820152690dcdee840cadcdeeaced60b31b60448201526064016109a5565b600854600f546110879084612e74565b11156110cf5760405162461bcd60e51b8152602060048201526017602482015276776f756c6420657863656564206d617820737570706c7960481b60448201526064016109a5565b6009548211156110f15760405162461bcd60e51b81526004016109a590612d56565b600a543360009081526012602052604090205461110f908490612e74565b11156111715760405162461bcd60e51b815260206004820152602b60248201527f6c696d6974206f6e206d696e74696e6720746f6f206d616e79207768696c652060448201526a1dda1a5d195b1a5cdd195960aa1b60648201526084016109a5565b600f545b82600f546111839190612e74565b8110156111a6576111943382611d60565b8061119e81612f3d565b915050611175565b50336000908152601260205260409020546111c2908390612e74565b33600090815260126020526040812091909155600f80548492906111e7908490612e74565b90915550505050565b600754600160a01b900460ff161561123d5760405162461bcd60e51b815260206004820152601060248201526f14185d5cd8589b194e881c185d5cd95960821b60448201526064016109a5565b600c5442116112855760405162461bcd60e51b81526020600482015260146024820152731b5a5b9d1a5b99c81b9bdd081bdc195b881e595d60621b60448201526064016109a5565b80600e546112939190612ea0565b3410156112d35760405162461bcd60e51b815260206004820152600e60248201526d0dcdee840cadcdeeaced040cae8d60931b60448201526064016109a5565b600081116113155760405162461bcd60e51b815260206004820152600f60248201526e1b9bdd08195b9bdd59da081b5a5b9d608a1b60448201526064016109a5565b600854600f546113259083612e74565b111561136d5760405162461bcd60e51b8152602060048201526017602482015276776f756c6420657863656564206d617820737570706c7960481b60448201526064016109a5565b60095481111561138f5760405162461bcd60e51b81526004016109a590612d56565b600f545b81600f546113a19190612e74565b8110156113c4576113b23382611d60565b806113bc81612f3d565b915050611393565b5080600f60008282546113d79190612e74565b909155505050565b6001600160a01b0382163314156114385760405162461bcd60e51b815260206004820152601960248201527f4552433732313a20617070726f766520746f2063616c6c65720000000000000060448201526064016109a5565b3360008181526005602090815260408083206001600160a01b03871680855290835292819020805460ff191686151590811790915590519081529192917f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a35050565b600080600083516041146114b757600080fd5b5050506020810151604082015160609092015160001a92909190565b6007546001600160a01b031633146114fd5760405162461bcd60e51b81526004016109a590612d99565b600a55565b6007546001600160a01b0316331461152c5760405162461bcd60e51b81526004016109a590612d99565b60105460ff161561157f5760405162461bcd60e51b815260206004820152601f60248201527f7370656369616c206d696e74207065726d616e656e746c79206c6f636b65640060448201526064016109a5565b80518251146115d05760405162461bcd60e51b815260206004820152601d60248201527f617272617973206861766520646966666572656e74206c656e6774687300000060448201526064016109a5565b60005b8251811015610adb57600f545b8282815181106115f2576115f2612fae565b6020026020010151600f546116079190612e74565b8110156116435761163184838151811061162357611623612fae565b602002602001015182611d60565b8061163b81612f3d565b9150506115e0565b5081818151811061165657611656612fae565b6020026020010151600f600082825461166f9190612e74565b9091555081905061167f81612f3d565b9150506115d3565b6116913383611a2c565b6116ad5760405162461bcd60e51b81526004016109a590612dce565b6116b984848484611eae565b50505050565b601180546116cc90612f02565b80601f01602080910402602001604051908101604052809291908181526020018280546116f890612f02565b80156117455780601f1061171a57610100808354040283529160200191611745565b820191906000526020600020905b81548152906001019060200180831161172857829003601f168201915b505050505081565b6007546001600160a01b031633146117775760405162461bcd60e51b81526004016109a590612d99565b8051610e269060179060208401906125dc565b6007546001600160a01b031633146117b45760405162461bcd60e51b81526004016109a590612d99565b600c55565b6060601780546117c890612f02565b151590506117d95761089882611ee1565b6117e282611ee1565b60176040516020016117f5929190612c18565b6040516020818303038152906040529050919050565b6007546001600160a01b031633146118355760405162461bcd60e51b81526004016109a590612d99565b601580546001600160a01b0319166001600160a01b0392909216919091179055565b6007546001600160a01b031633146118815760405162461bcd60e51b81526004016109a590612d99565b600081116118ca5760405162461bcd60e51b81526020600482015260166024820152757072696365206d75737420626520706f73697469766560501b60448201526064016109a5565b600d55565b606060166040516020016118e39190612c3f565b604051602081830303815290604052905090565b6007546001600160a01b031633146119215760405162461bcd60e51b81526004016109a590612d99565b600b55565b6007546001600160a01b031633146119505760405162461bcd60e51b81526004016109a590612d99565b6001600160a01b0381166119b55760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016109a5565b610de681611d0e565b600081815260046020526040902080546001600160a01b0319166001600160a01b03841690811790915581906119f382610e2a565b6001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a45050565b6000818152600260205260408120546001600160a01b0316611aa55760405162461bcd60e51b815260206004820152602c60248201527f4552433732313a206f70657261746f7220717565727920666f72206e6f6e657860448201526b34b9ba32b73a103a37b5b2b760a11b60648201526084016109a5565b6000611ab083610e2a565b9050806001600160a01b0316846001600160a01b03161480611aeb5750836001600160a01b0316611ae084610930565b6001600160a01b0316145b80611b1b57506001600160a01b0380821660009081526005602090815260408083209388168352929052205460ff165b949350505050565b826001600160a01b0316611b3682610e2a565b6001600160a01b031614611b9e5760405162461bcd60e51b815260206004820152602960248201527f4552433732313a207472616e73666572206f6620746f6b656e2074686174206960448201526839903737ba1037bbb760b91b60648201526084016109a5565b6001600160a01b038216611c005760405162461bcd60e51b8152602060048201526024808201527f4552433732313a207472616e7366657220746f20746865207a65726f206164646044820152637265737360e01b60648201526084016109a5565b611c0b838383612053565b611c166000826119be565b6001600160a01b0383166000908152600360205260408120805460019290611c3f908490612ebf565b90915550506001600160a01b0382166000908152600360205260408120805460019290611c6d908490612e74565b909155505060008181526002602052604080822080546001600160a01b0319166001600160a01b0386811691821790925591518493918716917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91a4505050565b611cd781612240565b60008181526006602052604090208054611cf090612f02565b159050610de6576000818152600660205260408120610de691612660565b600780546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b038216611db65760405162461bcd60e51b815260206004820181905260248201527f4552433732313a206d696e7420746f20746865207a65726f206164647265737360448201526064016109a5565b6000818152600260205260409020546001600160a01b031615611e1b5760405162461bcd60e51b815260206004820152601c60248201527f4552433732313a20746f6b656e20616c7265616479206d696e7465640000000060448201526064016109a5565b611e2760008383612053565b6001600160a01b0382166000908152600360205260408120805460019290611e50908490612e74565b909155505060008181526002602052604080822080546001600160a01b0319166001600160a01b03861690811790915590518392907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a45050565b611eb9848484611b23565b611ec5848484846122e7565b6116b95760405162461bcd60e51b81526004016109a590612d04565b6000818152600260205260409020546060906001600160a01b0316611f625760405162461bcd60e51b815260206004820152603160248201527f45524337323155524953746f726167653a2055524920717565727920666f72206044820152703737b732bc34b9ba32b73a103a37b5b2b760791b60648201526084016109a5565b60008281526006602052604081208054611f7b90612f02565b80601f0160208091040260200160405190810160405280929190818152602001828054611fa790612f02565b8015611ff45780601f10611fc957610100808354040283529160200191611ff4565b820191906000526020600020905b815481529060010190602001808311611fd757829003601f168201915b5050505050905060006120056123f4565b9050805160001415612018575092915050565b81511561204a578082604051602001612032929190612be9565b60405160208183030381529060405292505050919050565b611b1b84612403565b6001600160a01b038316156120b75761206b81610e2a565b6001600160a01b0316836001600160a01b0316146120b75760405162461bcd60e51b81526020600482015260096024820152683737ba1037bbb732b960b91b60448201526064016109a5565b816001600160a01b0316836001600160a01b031614156120d657505050565b6000818152601460205260409020546001600160a01b03831615612141576001600160a01b03831660008181526013602090815260408220805460018181018355828552928420018690559290915290546121319190612ebf565b6000838152601460205260409020555b6001600160a01b038416156116b9576001600160a01b038416600090815260136020526040902054612174600182612ebf565b8210156121fc576001600160a01b038516600090815260136020526040902061219e600183612ebf565b815481106121ae576121ae612fae565b906000526020600020015460136000876001600160a01b03166001600160a01b0316815260200190815260200160002083815481106121ef576121ef612fae565b6000918252602090912001555b6001600160a01b038516600090815260136020526040902080548061222357612223612f98565b600190038181906000526020600020016000905590555050505050565b600061224b82610e2a565b905061225981600084612053565b6122646000836119be565b6001600160a01b038116600090815260036020526040812080546001929061228d908490612ebf565b909155505060008281526002602052604080822080546001600160a01b0319169055518391906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908390a45050565b60006001600160a01b0384163b156123e957604051630a85bd0160e11b81526001600160a01b0385169063150b7a029061232b903390899088908890600401612c70565b602060405180830381600087803b15801561234557600080fd5b505af1925050508015612375575060408051601f3d908101601f19168201909252612372918101906129ed565b60015b6123cf573d8080156123a3576040519150601f19603f3d011682016040523d82523d6000602084013e6123a8565b606091505b5080516123c75760405162461bcd60e51b81526004016109a590612d04565b805181602001fd5b6001600160e01b031916630a85bd0160e11b149050611b1b565b506001949350505050565b6060601680546108ad90612f02565b6000818152600260205260409020546060906001600160a01b03166124825760405162461bcd60e51b815260206004820152602f60248201527f4552433732314d657461646174613a2055524920717565727920666f72206e6f60448201526e3732bc34b9ba32b73a103a37b5b2b760891b60648201526084016109a5565b600061248c6123f4565b905060008151116124ac57604051806020016040528060008152506124d7565b806124b6846124de565b6040516020016124c7929190612be9565b6040516020818303038152906040525b9392505050565b6060816125025750506040805180820190915260018152600360fc1b602082015290565b8160005b811561252c578061251681612f3d565b91506125259050600a83612e8c565b9150612506565b60008167ffffffffffffffff81111561254757612547612fc4565b6040519080825280601f01601f191660200182016040528015612571576020820181803683370190505b5090505b8415611b1b57612586600183612ebf565b9150612593600a86612f58565b61259e906030612e74565b60f81b8183815181106125b3576125b3612fae565b60200101906001600160f81b031916908160001a9053506125d5600a86612e8c565b9450612575565b8280546125e890612f02565b90600052602060002090601f01602090048101928261260a5760008555612650565b82601f1061262357805160ff1916838001178555612650565b82800160010185558215612650579182015b82811115612650578251825591602001919060010190612635565b5061265c929150612696565b5090565b50805461266c90612f02565b6000825580601f1061267c575050565b601f016020900490600052602060002090810190610de691905b5b8082111561265c5760008155600101612697565b600067ffffffffffffffff8311156126c5576126c5612fc4565b6126d8601f8401601f1916602001612e1f565b90508281528383830111156126ec57600080fd5b828260208301376000602084830101529392505050565b80356001600160a01b038116811461271a57600080fd5b919050565b600082601f83011261273057600080fd5b8135602061274561274083612e50565b612e1f565b80838252828201915082860187848660051b890101111561276557600080fd5b60005b8581101561278457813584529284019290840190600101612768565b5090979650505050505050565b600082601f8301126127a257600080fd5b6124d7838335602085016126ab565b6000602082840312156127c357600080fd5b6124d782612703565b600080604083850312156127df57600080fd5b6127e883612703565b91506127f660208401612703565b90509250929050565b60008060006060848603121561281457600080fd5b61281d84612703565b925061282b60208501612703565b9150604084013590509250925092565b6000806000806080858703121561285157600080fd5b61285a85612703565b935061286860208601612703565b925060408501359150606085013567ffffffffffffffff81111561288b57600080fd5b61289787828801612791565b91505092959194509250565b600080604083850312156128b657600080fd5b6128bf83612703565b9150602083013580151581146128d457600080fd5b809150509250929050565b600080604083850312156128f257600080fd5b6128fb83612703565b946020939093013593505050565b6000806040838503121561291c57600080fd5b823567ffffffffffffffff8082111561293457600080fd5b818501915085601f83011261294857600080fd5b8135602061295861274083612e50565b8083825282820191508286018a848660051b890101111561297857600080fd5b600096505b848710156129a25761298e81612703565b83526001969096019591830191830161297d565b50965050860135925050808211156129b957600080fd5b506129c68582860161271f565b9150509250929050565b6000602082840312156129e257600080fd5b81356124d781612fda565b6000602082840312156129ff57600080fd5b81516124d781612fda565b600060208284031215612a1c57600080fd5b813567ffffffffffffffff811115612a3357600080fd5b611b1b84828501612791565b60008060408385031215612a5257600080fd5b823567ffffffffffffffff811115612a6957600080fd5b612a7585828601612791565b9250506127f660208401612703565b600060208284031215612a9657600080fd5b813567ffffffffffffffff811115612aad57600080fd5b8201601f81018413612abe57600080fd5b611b1b848235602084016126ab565b600060208284031215612adf57600080fd5b5035919050565b60008060408385031215612af957600080fd5b82359150602083013567ffffffffffffffff811115612b1757600080fd5b6129c685828601612791565b60008151808452612b3b816020860160208601612ed6565b601f01601f19169290920160200192915050565b8054600090600181811c9080831680612b6957607f831692505b6020808410821415612b8b57634e487b7160e01b600052602260045260246000fd5b818015612b9f5760018114612bb057612bdd565b60ff19861689528489019650612bdd565b60008881526020902060005b86811015612bd55781548b820152908501908301612bbc565b505084890196505b50505050505092915050565b60008351612bfb818460208801612ed6565b835190830190612c0f818360208801612ed6565b01949350505050565b60008351612c2a818460208801612ed6565b612c3681840185612b4f565b95945050505050565b6000612c4b8284612b4f565b7431b7b73a3930b1ba17b232b330bab63a173539b7b760591b81526015019392505050565b6001600160a01b0385811682528416602082015260408101839052608060608201819052600090612ca390830184612b23565b9695505050505050565b6020808252825182820181905260009190848201906040850190845b81811015612ce557835183529284019291840191600101612cc9565b50909695505050505050565b6020815260006124d76020830184612b23565b60208082526032908201527f4552433732313a207472616e7366657220746f206e6f6e20455243373231526560408201527131b2b4bb32b91034b6b83632b6b2b73a32b960711b606082015260800190565b60208082526023908201527f6c696d6974206f6e206d696e74696e6720746f6f206d616e7920617420612074604082015262696d6560e81b606082015260800190565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60208082526031908201527f4552433732313a207472616e736665722063616c6c6572206973206e6f74206f6040820152701ddb995c881b9bdc88185c1c1c9bdd9959607a1b606082015260800190565b604051601f8201601f1916810167ffffffffffffffff81118282101715612e4857612e48612fc4565b604052919050565b600067ffffffffffffffff821115612e6a57612e6a612fc4565b5060051b60200190565b60008219821115612e8757612e87612f6c565b500190565b600082612e9b57612e9b612f82565b500490565b6000816000190483118215151615612eba57612eba612f6c565b500290565b600082821015612ed157612ed1612f6c565b500390565b60005b83811015612ef1578181015183820152602001612ed9565b838111156116b95750506000910152565b600181811c90821680612f1657607f821691505b60208210811415612f3757634e487b7160e01b600052602260045260246000fd5b50919050565b6000600019821415612f5157612f51612f6c565b5060010190565b600082612f6757612f67612f82565b500690565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052601260045260246000fd5b634e487b7160e01b600052603160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b6001600160e01b031981168114610de657600080fdfea26469706673582212202f7bf2be806fa9eb45d31066e9f006f2745b5720c0447527b8523641d8adeb5664736f6c6343000807003300000000000000000000000000000000000000000000000000000000000000a000000000000000000000000000000000000000000000000000000000000000e000000000000000000000000014bbcd028822aae01f4b0093b5b42052fd1093b700000000000000000000000000000000000000000000000000000000000001200000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000b447261676f6e566572736500000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000034447560000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000002068747470733a2f2f6d657461646174612e647261676f6e76657273652e696f2f00000000000000000000000000000000000000000000000000000000000000052e6a736f6e000000000000000000000000000000000000000000000000000000

Deployed Bytecode

0x6080604052600436106102885760003560e01c80638da5cb5b1161015a578063c3bb8c64116100c1578063deaa59df1161007a578063deaa59df1461076e578063e20346691461078e578063e8a3d485146107ae578063e985e9c5146107c3578063f29efaeb1461080c578063f2fde38b1461082c57600080fd5b8063c3bb8c64146106cc578063c4165653146106ec578063c87b56dd1461070c578063cd08c0461461072c578063d8d1038c14610742578063dc30158b1461075857600080fd5b8063a7bb580311610113578063a7bb580314610602578063b32142c414610641578063b843b09014610661578063b88d4fde14610681578063c0cf3f41146106a1578063c0e24d5e146106b757600080fd5b80638da5cb5b1461056f5780638ede9e4d1461058d57806395d89b41146105a75780639f41554a146105bc578063a0712d68146105cf578063a22cb465146105e257600080fd5b80633641d544116101fe57806355f804b3116101b757806355f804b3146104ae5780635c975abb146104ce5780636352211e146104ed57806370a082311461050d578063715018a61461052d5780638c0175721461054257600080fd5b80633641d5441461041a5780633c010a3e146104305780633ccfd60b146104465780633d3ac1b51461044e57806342842e0e1461046e57806342966c681461048e57600080fd5b806311b92aaf1161025057806311b92aaf14610362578063174da4a21461037757806318160ddd1461039757806323b872dd146103ad578063279ad417146103cd5780632e257676146103ed57600080fd5b806301ffc9a71461028d57806306fdde03146102c2578063081812fc146102e4578063095ea7b31461031c5780630fae42cd1461033e575b600080fd5b34801561029957600080fd5b506102ad6102a83660046129d0565b61084c565b60405190151581526020015b60405180910390f35b3480156102ce57600080fd5b506102d761089e565b6040516102b99190612cf1565b3480156102f057600080fd5b506103046102ff366004612acd565b610930565b6040516001600160a01b0390911681526020016102b9565b34801561032857600080fd5b5061033c6103373660046128df565b6109ca565b005b34801561034a57600080fd5b50610354600d5481565b6040519081526020016102b9565b34801561036e57600080fd5b5061033c610ae0565b34801561038357600080fd5b5061033c610392366004612acd565b610b19565b3480156103a357600080fd5b50610354600f5481565b3480156103b957600080fd5b5061033c6103c83660046127ff565b610b48565b3480156103d957600080fd5b5061033c6103e8366004612acd565b610b7a565b3480156103f957600080fd5b506103546104083660046127b1565b60126020526000908152604090205481565b34801561042657600080fd5b50610354600c5481565b34801561043c57600080fd5b5061035460085481565b6102ad610bf2565b34801561045a57600080fd5b506102ad610469366004612a3f565b610c79565b34801561047a57600080fd5b5061033c6104893660046127ff565b610d54565b34801561049a57600080fd5b5061033c6104a9366004612acd565b610d6f565b3480156104ba57600080fd5b5061033c6104c9366004612a84565b610de9565b3480156104da57600080fd5b50600754600160a01b900460ff166102ad565b3480156104f957600080fd5b50610304610508366004612acd565b610e2a565b34801561051957600080fd5b506103546105283660046127b1565b610ea1565b34801561053957600080fd5b5061033c610f28565b34801561054e57600080fd5b5061056261055d3660046127b1565b610f5e565b6040516102b99190612cad565b34801561057b57600080fd5b506007546001600160a01b0316610304565b34801561059957600080fd5b506010546102ad9060ff1681565b3480156105b357600080fd5b506102d7610fca565b61033c6105ca366004612ae6565b610fd9565b61033c6105dd366004612acd565b6111f0565b3480156105ee57600080fd5b5061033c6105fd3660046128a3565b6113df565b34801561060e57600080fd5b5061062261061d366004612a0a565b6114a4565b6040805160ff90941684526020840192909252908201526060016102b9565b34801561064d57600080fd5b5061033c61065c366004612acd565b6114d3565b34801561066d57600080fd5b5061033c61067c366004612909565b611502565b34801561068d57600080fd5b5061033c61069c36600461283b565b611687565b3480156106ad57600080fd5b50610354600a5481565b3480156106c357600080fd5b506102d76116bf565b3480156106d857600080fd5b5061033c6106e7366004612a84565b61174d565b3480156106f857600080fd5b5061033c610707366004612acd565b61178a565b34801561071857600080fd5b506102d7610727366004612acd565b6117b9565b34801561073857600080fd5b50610354600e5481565b34801561074e57600080fd5b50610354600b5481565b34801561076457600080fd5b5061035460095481565b34801561077a57600080fd5b5061033c6107893660046127b1565b61180b565b34801561079a57600080fd5b5061033c6107a9366004612acd565b611857565b3480156107ba57600080fd5b506102d76118cf565b3480156107cf57600080fd5b506102ad6107de3660046127cc565b6001600160a01b03918216600090815260056020908152604080832093909416825291909152205460ff1690565b34801561081857600080fd5b5061033c610827366004612acd565b6118f7565b34801561083857600080fd5b5061033c6108473660046127b1565b611926565b60006001600160e01b031982166380ac58cd60e01b148061087d57506001600160e01b03198216635b5e139f60e01b145b8061089857506301ffc9a760e01b6001600160e01b03198316145b92915050565b6060600080546108ad90612f02565b80601f01602080910402602001604051908101604052809291908181526020018280546108d990612f02565b80156109265780601f106108fb57610100808354040283529160200191610926565b820191906000526020600020905b81548152906001019060200180831161090957829003601f168201915b5050505050905090565b6000818152600260205260408120546001600160a01b03166109ae5760405162461bcd60e51b815260206004820152602c60248201527f4552433732313a20617070726f76656420717565727920666f72206e6f6e657860448201526b34b9ba32b73a103a37b5b2b760a11b60648201526084015b60405180910390fd5b506000908152600460205260409020546001600160a01b031690565b60006109d582610e2a565b9050806001600160a01b0316836001600160a01b03161415610a435760405162461bcd60e51b815260206004820152602160248201527f4552433732313a20617070726f76616c20746f2063757272656e74206f776e656044820152603960f91b60648201526084016109a5565b336001600160a01b0382161480610a5f5750610a5f81336107de565b610ad15760405162461bcd60e51b815260206004820152603860248201527f4552433732313a20617070726f76652063616c6c6572206973206e6f74206f7760448201527f6e6572206e6f7220617070726f76656420666f7220616c6c000000000000000060648201526084016109a5565b610adb83836119be565b505050565b6007546001600160a01b03163314610b0a5760405162461bcd60e51b81526004016109a590612d99565b6010805460ff19166001179055565b6007546001600160a01b03163314610b435760405162461bcd60e51b81526004016109a590612d99565b600955565b610b53335b82611a2c565b610b6f5760405162461bcd60e51b81526004016109a590612dce565b610adb838383611b23565b6007546001600160a01b03163314610ba45760405162461bcd60e51b81526004016109a590612d99565b60008111610bed5760405162461bcd60e51b81526020600482015260166024820152757072696365206d75737420626520706f73697469766560501b60448201526064016109a5565b600e55565b6007546000906001600160a01b03163314610c1f5760405162461bcd60e51b81526004016109a590612d99565b6015546040516001600160a01b03909116904790600081818185875af1925050503d8060008114610c6c576040519150601f19603f3d011682016040523d82523d6000602084013e610c71565b606091505b509092915050565b600080600080610c88866114a4565b6040516bffffffffffffffffffffffff1960608a901b166020820152929550909350915060009060340160408051601f1981840301815282825280516020918201206000845290830180835281905260ff8716918301919091526060820185905260808201849052915060019060a0016020604051602081039080840390855afa158015610d1a573d6000803e3d6000fd5b505050602060405103516001600160a01b0316610d3f6007546001600160a01b031690565b6001600160a01b031614979650505050505050565b610adb83838360405180602001604052806000815250611687565b610d7833610b4d565b610ddd5760405162461bcd60e51b815260206004820152603060248201527f4552433732314275726e61626c653a2063616c6c6572206973206e6f74206f7760448201526f1b995c881b9bdc88185c1c1c9bdd995960821b60648201526084016109a5565b610de681611cce565b50565b6007546001600160a01b03163314610e135760405162461bcd60e51b81526004016109a590612d99565b8051610e269060169060208401906125dc565b5050565b6000818152600260205260408120546001600160a01b0316806108985760405162461bcd60e51b815260206004820152602960248201527f4552433732313a206f776e657220717565727920666f72206e6f6e657869737460448201526832b73a103a37b5b2b760b91b60648201526084016109a5565b60006001600160a01b038216610f0c5760405162461bcd60e51b815260206004820152602a60248201527f4552433732313a2062616c616e636520717565727920666f7220746865207a65604482015269726f206164647265737360b01b60648201526084016109a5565b506001600160a01b031660009081526003602052604090205490565b6007546001600160a01b03163314610f525760405162461bcd60e51b81526004016109a590612d99565b610f5c6000611d0e565b565b6001600160a01b038116600090815260136020908152604091829020805483518184028101840190945280845260609392830182828015610fbe57602002820191906000526020600020905b815481526020019060010190808311610faa575b50505050509050919050565b6060600180546108ad90612f02565b610fe38133610c79565b610fec57600080fd5b81600d54610ffa9190612ea0565b34101561103a5760405162461bcd60e51b815260206004820152600e60248201526d0dcdee840cadcdeeaced040cae8d60931b60448201526064016109a5565b600082116110775760405162461bcd60e51b815260206004820152600a6024820152690dcdee840cadcdeeaced60b31b60448201526064016109a5565b600854600f546110879084612e74565b11156110cf5760405162461bcd60e51b8152602060048201526017602482015276776f756c6420657863656564206d617820737570706c7960481b60448201526064016109a5565b6009548211156110f15760405162461bcd60e51b81526004016109a590612d56565b600a543360009081526012602052604090205461110f908490612e74565b11156111715760405162461bcd60e51b815260206004820152602b60248201527f6c696d6974206f6e206d696e74696e6720746f6f206d616e79207768696c652060448201526a1dda1a5d195b1a5cdd195960aa1b60648201526084016109a5565b600f545b82600f546111839190612e74565b8110156111a6576111943382611d60565b8061119e81612f3d565b915050611175565b50336000908152601260205260409020546111c2908390612e74565b33600090815260126020526040812091909155600f80548492906111e7908490612e74565b90915550505050565b600754600160a01b900460ff161561123d5760405162461bcd60e51b815260206004820152601060248201526f14185d5cd8589b194e881c185d5cd95960821b60448201526064016109a5565b600c5442116112855760405162461bcd60e51b81526020600482015260146024820152731b5a5b9d1a5b99c81b9bdd081bdc195b881e595d60621b60448201526064016109a5565b80600e546112939190612ea0565b3410156112d35760405162461bcd60e51b815260206004820152600e60248201526d0dcdee840cadcdeeaced040cae8d60931b60448201526064016109a5565b600081116113155760405162461bcd60e51b815260206004820152600f60248201526e1b9bdd08195b9bdd59da081b5a5b9d608a1b60448201526064016109a5565b600854600f546113259083612e74565b111561136d5760405162461bcd60e51b8152602060048201526017602482015276776f756c6420657863656564206d617820737570706c7960481b60448201526064016109a5565b60095481111561138f5760405162461bcd60e51b81526004016109a590612d56565b600f545b81600f546113a19190612e74565b8110156113c4576113b23382611d60565b806113bc81612f3d565b915050611393565b5080600f60008282546113d79190612e74565b909155505050565b6001600160a01b0382163314156114385760405162461bcd60e51b815260206004820152601960248201527f4552433732313a20617070726f766520746f2063616c6c65720000000000000060448201526064016109a5565b3360008181526005602090815260408083206001600160a01b03871680855290835292819020805460ff191686151590811790915590519081529192917f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a35050565b600080600083516041146114b757600080fd5b5050506020810151604082015160609092015160001a92909190565b6007546001600160a01b031633146114fd5760405162461bcd60e51b81526004016109a590612d99565b600a55565b6007546001600160a01b0316331461152c5760405162461bcd60e51b81526004016109a590612d99565b60105460ff161561157f5760405162461bcd60e51b815260206004820152601f60248201527f7370656369616c206d696e74207065726d616e656e746c79206c6f636b65640060448201526064016109a5565b80518251146115d05760405162461bcd60e51b815260206004820152601d60248201527f617272617973206861766520646966666572656e74206c656e6774687300000060448201526064016109a5565b60005b8251811015610adb57600f545b8282815181106115f2576115f2612fae565b6020026020010151600f546116079190612e74565b8110156116435761163184838151811061162357611623612fae565b602002602001015182611d60565b8061163b81612f3d565b9150506115e0565b5081818151811061165657611656612fae565b6020026020010151600f600082825461166f9190612e74565b9091555081905061167f81612f3d565b9150506115d3565b6116913383611a2c565b6116ad5760405162461bcd60e51b81526004016109a590612dce565b6116b984848484611eae565b50505050565b601180546116cc90612f02565b80601f01602080910402602001604051908101604052809291908181526020018280546116f890612f02565b80156117455780601f1061171a57610100808354040283529160200191611745565b820191906000526020600020905b81548152906001019060200180831161172857829003601f168201915b505050505081565b6007546001600160a01b031633146117775760405162461bcd60e51b81526004016109a590612d99565b8051610e269060179060208401906125dc565b6007546001600160a01b031633146117b45760405162461bcd60e51b81526004016109a590612d99565b600c55565b6060601780546117c890612f02565b151590506117d95761089882611ee1565b6117e282611ee1565b60176040516020016117f5929190612c18565b6040516020818303038152906040529050919050565b6007546001600160a01b031633146118355760405162461bcd60e51b81526004016109a590612d99565b601580546001600160a01b0319166001600160a01b0392909216919091179055565b6007546001600160a01b031633146118815760405162461bcd60e51b81526004016109a590612d99565b600081116118ca5760405162461bcd60e51b81526020600482015260166024820152757072696365206d75737420626520706f73697469766560501b60448201526064016109a5565b600d55565b606060166040516020016118e39190612c3f565b604051602081830303815290604052905090565b6007546001600160a01b031633146119215760405162461bcd60e51b81526004016109a590612d99565b600b55565b6007546001600160a01b031633146119505760405162461bcd60e51b81526004016109a590612d99565b6001600160a01b0381166119b55760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016109a5565b610de681611d0e565b600081815260046020526040902080546001600160a01b0319166001600160a01b03841690811790915581906119f382610e2a565b6001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a45050565b6000818152600260205260408120546001600160a01b0316611aa55760405162461bcd60e51b815260206004820152602c60248201527f4552433732313a206f70657261746f7220717565727920666f72206e6f6e657860448201526b34b9ba32b73a103a37b5b2b760a11b60648201526084016109a5565b6000611ab083610e2a565b9050806001600160a01b0316846001600160a01b03161480611aeb5750836001600160a01b0316611ae084610930565b6001600160a01b0316145b80611b1b57506001600160a01b0380821660009081526005602090815260408083209388168352929052205460ff165b949350505050565b826001600160a01b0316611b3682610e2a565b6001600160a01b031614611b9e5760405162461bcd60e51b815260206004820152602960248201527f4552433732313a207472616e73666572206f6620746f6b656e2074686174206960448201526839903737ba1037bbb760b91b60648201526084016109a5565b6001600160a01b038216611c005760405162461bcd60e51b8152602060048201526024808201527f4552433732313a207472616e7366657220746f20746865207a65726f206164646044820152637265737360e01b60648201526084016109a5565b611c0b838383612053565b611c166000826119be565b6001600160a01b0383166000908152600360205260408120805460019290611c3f908490612ebf565b90915550506001600160a01b0382166000908152600360205260408120805460019290611c6d908490612e74565b909155505060008181526002602052604080822080546001600160a01b0319166001600160a01b0386811691821790925591518493918716917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91a4505050565b611cd781612240565b60008181526006602052604090208054611cf090612f02565b159050610de6576000818152600660205260408120610de691612660565b600780546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b038216611db65760405162461bcd60e51b815260206004820181905260248201527f4552433732313a206d696e7420746f20746865207a65726f206164647265737360448201526064016109a5565b6000818152600260205260409020546001600160a01b031615611e1b5760405162461bcd60e51b815260206004820152601c60248201527f4552433732313a20746f6b656e20616c7265616479206d696e7465640000000060448201526064016109a5565b611e2760008383612053565b6001600160a01b0382166000908152600360205260408120805460019290611e50908490612e74565b909155505060008181526002602052604080822080546001600160a01b0319166001600160a01b03861690811790915590518392907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a45050565b611eb9848484611b23565b611ec5848484846122e7565b6116b95760405162461bcd60e51b81526004016109a590612d04565b6000818152600260205260409020546060906001600160a01b0316611f625760405162461bcd60e51b815260206004820152603160248201527f45524337323155524953746f726167653a2055524920717565727920666f72206044820152703737b732bc34b9ba32b73a103a37b5b2b760791b60648201526084016109a5565b60008281526006602052604081208054611f7b90612f02565b80601f0160208091040260200160405190810160405280929190818152602001828054611fa790612f02565b8015611ff45780601f10611fc957610100808354040283529160200191611ff4565b820191906000526020600020905b815481529060010190602001808311611fd757829003601f168201915b5050505050905060006120056123f4565b9050805160001415612018575092915050565b81511561204a578082604051602001612032929190612be9565b60405160208183030381529060405292505050919050565b611b1b84612403565b6001600160a01b038316156120b75761206b81610e2a565b6001600160a01b0316836001600160a01b0316146120b75760405162461bcd60e51b81526020600482015260096024820152683737ba1037bbb732b960b91b60448201526064016109a5565b816001600160a01b0316836001600160a01b031614156120d657505050565b6000818152601460205260409020546001600160a01b03831615612141576001600160a01b03831660008181526013602090815260408220805460018181018355828552928420018690559290915290546121319190612ebf565b6000838152601460205260409020555b6001600160a01b038416156116b9576001600160a01b038416600090815260136020526040902054612174600182612ebf565b8210156121fc576001600160a01b038516600090815260136020526040902061219e600183612ebf565b815481106121ae576121ae612fae565b906000526020600020015460136000876001600160a01b03166001600160a01b0316815260200190815260200160002083815481106121ef576121ef612fae565b6000918252602090912001555b6001600160a01b038516600090815260136020526040902080548061222357612223612f98565b600190038181906000526020600020016000905590555050505050565b600061224b82610e2a565b905061225981600084612053565b6122646000836119be565b6001600160a01b038116600090815260036020526040812080546001929061228d908490612ebf565b909155505060008281526002602052604080822080546001600160a01b0319169055518391906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908390a45050565b60006001600160a01b0384163b156123e957604051630a85bd0160e11b81526001600160a01b0385169063150b7a029061232b903390899088908890600401612c70565b602060405180830381600087803b15801561234557600080fd5b505af1925050508015612375575060408051601f3d908101601f19168201909252612372918101906129ed565b60015b6123cf573d8080156123a3576040519150601f19603f3d011682016040523d82523d6000602084013e6123a8565b606091505b5080516123c75760405162461bcd60e51b81526004016109a590612d04565b805181602001fd5b6001600160e01b031916630a85bd0160e11b149050611b1b565b506001949350505050565b6060601680546108ad90612f02565b6000818152600260205260409020546060906001600160a01b03166124825760405162461bcd60e51b815260206004820152602f60248201527f4552433732314d657461646174613a2055524920717565727920666f72206e6f60448201526e3732bc34b9ba32b73a103a37b5b2b760891b60648201526084016109a5565b600061248c6123f4565b905060008151116124ac57604051806020016040528060008152506124d7565b806124b6846124de565b6040516020016124c7929190612be9565b6040516020818303038152906040525b9392505050565b6060816125025750506040805180820190915260018152600360fc1b602082015290565b8160005b811561252c578061251681612f3d565b91506125259050600a83612e8c565b9150612506565b60008167ffffffffffffffff81111561254757612547612fc4565b6040519080825280601f01601f191660200182016040528015612571576020820181803683370190505b5090505b8415611b1b57612586600183612ebf565b9150612593600a86612f58565b61259e906030612e74565b60f81b8183815181106125b3576125b3612fae565b60200101906001600160f81b031916908160001a9053506125d5600a86612e8c565b9450612575565b8280546125e890612f02565b90600052602060002090601f01602090048101928261260a5760008555612650565b82601f1061262357805160ff1916838001178555612650565b82800160010185558215612650579182015b82811115612650578251825591602001919060010190612635565b5061265c929150612696565b5090565b50805461266c90612f02565b6000825580601f1061267c575050565b601f016020900490600052602060002090810190610de691905b5b8082111561265c5760008155600101612697565b600067ffffffffffffffff8311156126c5576126c5612fc4565b6126d8601f8401601f1916602001612e1f565b90508281528383830111156126ec57600080fd5b828260208301376000602084830101529392505050565b80356001600160a01b038116811461271a57600080fd5b919050565b600082601f83011261273057600080fd5b8135602061274561274083612e50565b612e1f565b80838252828201915082860187848660051b890101111561276557600080fd5b60005b8581101561278457813584529284019290840190600101612768565b5090979650505050505050565b600082601f8301126127a257600080fd5b6124d7838335602085016126ab565b6000602082840312156127c357600080fd5b6124d782612703565b600080604083850312156127df57600080fd5b6127e883612703565b91506127f660208401612703565b90509250929050565b60008060006060848603121561281457600080fd5b61281d84612703565b925061282b60208501612703565b9150604084013590509250925092565b6000806000806080858703121561285157600080fd5b61285a85612703565b935061286860208601612703565b925060408501359150606085013567ffffffffffffffff81111561288b57600080fd5b61289787828801612791565b91505092959194509250565b600080604083850312156128b657600080fd5b6128bf83612703565b9150602083013580151581146128d457600080fd5b809150509250929050565b600080604083850312156128f257600080fd5b6128fb83612703565b946020939093013593505050565b6000806040838503121561291c57600080fd5b823567ffffffffffffffff8082111561293457600080fd5b818501915085601f83011261294857600080fd5b8135602061295861274083612e50565b8083825282820191508286018a848660051b890101111561297857600080fd5b600096505b848710156129a25761298e81612703565b83526001969096019591830191830161297d565b50965050860135925050808211156129b957600080fd5b506129c68582860161271f565b9150509250929050565b6000602082840312156129e257600080fd5b81356124d781612fda565b6000602082840312156129ff57600080fd5b81516124d781612fda565b600060208284031215612a1c57600080fd5b813567ffffffffffffffff811115612a3357600080fd5b611b1b84828501612791565b60008060408385031215612a5257600080fd5b823567ffffffffffffffff811115612a6957600080fd5b612a7585828601612791565b9250506127f660208401612703565b600060208284031215612a9657600080fd5b813567ffffffffffffffff811115612aad57600080fd5b8201601f81018413612abe57600080fd5b611b1b848235602084016126ab565b600060208284031215612adf57600080fd5b5035919050565b60008060408385031215612af957600080fd5b82359150602083013567ffffffffffffffff811115612b1757600080fd5b6129c685828601612791565b60008151808452612b3b816020860160208601612ed6565b601f01601f19169290920160200192915050565b8054600090600181811c9080831680612b6957607f831692505b6020808410821415612b8b57634e487b7160e01b600052602260045260246000fd5b818015612b9f5760018114612bb057612bdd565b60ff19861689528489019650612bdd565b60008881526020902060005b86811015612bd55781548b820152908501908301612bbc565b505084890196505b50505050505092915050565b60008351612bfb818460208801612ed6565b835190830190612c0f818360208801612ed6565b01949350505050565b60008351612c2a818460208801612ed6565b612c3681840185612b4f565b95945050505050565b6000612c4b8284612b4f565b7431b7b73a3930b1ba17b232b330bab63a173539b7b760591b81526015019392505050565b6001600160a01b0385811682528416602082015260408101839052608060608201819052600090612ca390830184612b23565b9695505050505050565b6020808252825182820181905260009190848201906040850190845b81811015612ce557835183529284019291840191600101612cc9565b50909695505050505050565b6020815260006124d76020830184612b23565b60208082526032908201527f4552433732313a207472616e7366657220746f206e6f6e20455243373231526560408201527131b2b4bb32b91034b6b83632b6b2b73a32b960711b606082015260800190565b60208082526023908201527f6c696d6974206f6e206d696e74696e6720746f6f206d616e7920617420612074604082015262696d6560e81b606082015260800190565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60208082526031908201527f4552433732313a207472616e736665722063616c6c6572206973206e6f74206f6040820152701ddb995c881b9bdc88185c1c1c9bdd9959607a1b606082015260800190565b604051601f8201601f1916810167ffffffffffffffff81118282101715612e4857612e48612fc4565b604052919050565b600067ffffffffffffffff821115612e6a57612e6a612fc4565b5060051b60200190565b60008219821115612e8757612e87612f6c565b500190565b600082612e9b57612e9b612f82565b500490565b6000816000190483118215151615612eba57612eba612f6c565b500290565b600082821015612ed157612ed1612f6c565b500390565b60005b83811015612ef1578181015183820152602001612ed9565b838111156116b95750506000910152565b600181811c90821680612f1657607f821691505b60208210811415612f3757634e487b7160e01b600052602260045260246000fd5b50919050565b6000600019821415612f5157612f51612f6c565b5060010190565b600082612f6757612f67612f82565b500690565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052601260045260246000fd5b634e487b7160e01b600052603160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b6001600160e01b031981168114610de657600080fdfea26469706673582212202f7bf2be806fa9eb45d31066e9f006f2745b5720c0447527b8523641d8adeb5664736f6c63430008070033

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

00000000000000000000000000000000000000000000000000000000000000a000000000000000000000000000000000000000000000000000000000000000e000000000000000000000000014bbcd028822aae01f4b0093b5b42052fd1093b700000000000000000000000000000000000000000000000000000000000001200000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000b447261676f6e566572736500000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000034447560000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000002068747470733a2f2f6d657461646174612e647261676f6e76657273652e696f2f00000000000000000000000000000000000000000000000000000000000000052e6a736f6e000000000000000000000000000000000000000000000000000000

-----Decoded View---------------
Arg [0] : name_ (string): DragonVerse
Arg [1] : symbol_ (string): DGV
Arg [2] : wallet_ (address): 0x14bBcd028822Aae01f4b0093b5b42052fd1093B7
Arg [3] : _baseURI_ (string): https://metadata.dragonverse.io/
Arg [4] : _extensionURI_ (string): .json

-----Encoded View---------------
13 Constructor Arguments found :
Arg [0] : 00000000000000000000000000000000000000000000000000000000000000a0
Arg [1] : 00000000000000000000000000000000000000000000000000000000000000e0
Arg [2] : 00000000000000000000000014bbcd028822aae01f4b0093b5b42052fd1093b7
Arg [3] : 0000000000000000000000000000000000000000000000000000000000000120
Arg [4] : 0000000000000000000000000000000000000000000000000000000000000160
Arg [5] : 000000000000000000000000000000000000000000000000000000000000000b
Arg [6] : 447261676f6e5665727365000000000000000000000000000000000000000000
Arg [7] : 0000000000000000000000000000000000000000000000000000000000000003
Arg [8] : 4447560000000000000000000000000000000000000000000000000000000000
Arg [9] : 0000000000000000000000000000000000000000000000000000000000000020
Arg [10] : 68747470733a2f2f6d657461646174612e647261676f6e76657273652e696f2f
Arg [11] : 0000000000000000000000000000000000000000000000000000000000000005
Arg [12] : 2e6a736f6e000000000000000000000000000000000000000000000000000000


Deployed Bytecode Sourcemap

39477:8503:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;25183:305;;;;;;;;;;-1:-1:-1;25183:305:0;;;;;:::i;:::-;;:::i;:::-;;;11271:14:1;;11264:22;11246:41;;11234:2;11219:18;25183:305:0;;;;;;;;26128:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;27687:221::-;;;;;;;;;;-1:-1:-1;27687:221:0;;;;;:::i;:::-;;:::i;:::-;;;-1:-1:-1;;;;;9932:32:1;;;9914:51;;9902:2;9887:18;27687:221:0;9768:203:1;27210:411:0;;;;;;;;;;-1:-1:-1;27210:411:0;;;;;:::i;:::-;;:::i;:::-;;40160:60;;;;;;;;;;;;;;;;;;;23582:25:1;;;23570:2;23555:18;40160:60:0;23436:177:1;46665:94:0;;;;;;;;;;;;;:::i;41385:104::-;;;;;;;;;;-1:-1:-1;41385:104:0;;;;;:::i;:::-;;:::i;40352:26::-;;;;;;;;;;;;;;;;28577:339;;;;;;;;;;-1:-1:-1;28577:339:0;;;;;:::i;:::-;;:::i;42081:169::-;;;;;;;;;;-1:-1:-1;42081:169:0;;;;;:::i;:::-;;:::i;40594:56::-;;;;;;;;;;-1:-1:-1;40594:56:0;;;;;:::i;:::-;;;;;;;;;;;;;;40040:60;;;;;;;;;;;;;;;;39600:54;;;;;;;;;;;;;;;;46771:158;;;:::i;45345:344::-;;;;;;;;;;-1:-1:-1;45345:344:0;;;;;:::i;:::-;;:::i;28987:185::-;;;;;;;;;;-1:-1:-1;28987:185:0;;;;;:::i;:::-;;:::i;46401:192::-;;;;;;;;;;-1:-1:-1;46401:192:0;;;;;:::i;:::-;;:::i;42366:108::-;;;;;;;;;;-1:-1:-1;42366:108:0;;;;;:::i;:::-;;:::i;3983:86::-;;;;;;;;;;-1:-1:-1;4054:7:0;;-1:-1:-1;;;4054:7:0;;;;3983:86;;25822:239;;;;;;;;;;-1:-1:-1;25822:239:0;;;;;:::i;:::-;;:::i;25552:208::-;;;;;;;;;;-1:-1:-1;25552:208:0;;;;;:::i;:::-;;:::i;6818:94::-;;;;;;;;;;;;;:::i;43091:119::-;;;;;;;;;;-1:-1:-1;43091:119:0;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;6167:87::-;;;;;;;;;;-1:-1:-1;6240:6:0;;-1:-1:-1;;;;;6240:6:0;6167:87;;40447:29;;;;;;;;;;-1:-1:-1;40447:29:0;;;;;;;;26297:104;;;;;;;;;;;;;:::i;43870:914::-;;;;;;:::i;:::-;;:::i;43222:636::-;;;;;;:::i;:::-;;:::i;27980:295::-;;;;;;;;;;-1:-1:-1;27980:295:0;;;;;:::i;:::-;;:::i;45701:515::-;;;;;;;;;;-1:-1:-1;45701:515:0;;;;;:::i;:::-;;:::i;:::-;;;;23846:4:1;23834:17;;;23816:36;;23883:2;23868:18;;23861:34;;;;23911:18;;;23904:34;23804:2;23789:18;45701:515:0;23618:326:1;41501:107:0;;;;;;;;;;-1:-1:-1;41501:107:0;;;;;:::i;:::-;;:::i;44797:530::-;;;;;;;;;;-1:-1:-1;44797:530:0;;;;;:::i;:::-;;:::i;29243:328::-;;;;;;;;;;-1:-1:-1;29243:328:0;;;;;:::i;:::-;;:::i;39810:51::-;;;;;;;;;;;;;;;;40562:25;;;;;;;;;;;;;:::i;42486:127::-;;;;;;;;;;-1:-1:-1;42486:127:0;;;;;:::i;:::-;;:::i;41760:134::-;;;;;;;;;;-1:-1:-1;41760:134:0;;;;;:::i;:::-;;:::i;42631:291::-;;;;;;;;;;-1:-1:-1;42631:291:0;;;;;:::i;:::-;;:::i;40256:59::-;;;;;;;;;;;;;;;;39924:60;;;;;;;;;;;;;;;;39706:51;;;;;;;;;;;;;;;;42262:92;;;;;;;;;;-1:-1:-1;42262:92:0;;;;;:::i;:::-;;:::i;41906:163::-;;;;;;;;;;-1:-1:-1;41906:163:0;;;;;:::i;:::-;;:::i;42934:145::-;;;;;;;;;;;;;:::i;28346:164::-;;;;;;;;;;-1:-1:-1;28346:164:0;;;;;:::i;:::-;-1:-1:-1;;;;;28467:25:0;;;28443:4;28467:25;;;:18;:25;;;;;;;;:35;;;;;;;;;;;;;;;28346:164;41620:128;;;;;;;;;;-1:-1:-1;41620:128:0;;;;;:::i;:::-;;:::i;7067:192::-;;;;;;;;;;-1:-1:-1;7067:192:0;;;;;:::i;:::-;;:::i;25183:305::-;25285:4;-1:-1:-1;;;;;;25322:40:0;;-1:-1:-1;;;25322:40:0;;:105;;-1:-1:-1;;;;;;;25379:48:0;;-1:-1:-1;;;25379:48:0;25322:105;:158;;;-1:-1:-1;;;;;;;;;;18262:40:0;;;25444:36;25302:178;25183:305;-1:-1:-1;;25183:305:0:o;26128:100::-;26182:13;26215:5;26208:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;26128:100;:::o;27687:221::-;27763:7;31170:16;;;:7;:16;;;;;;-1:-1:-1;;;;;31170:16:0;27783:73;;;;-1:-1:-1;;;27783:73:0;;19419:2:1;27783:73:0;;;19401:21:1;19458:2;19438:18;;;19431:30;19497:34;19477:18;;;19470:62;-1:-1:-1;;;19548:18:1;;;19541:42;19600:19;;27783:73:0;;;;;;;;;-1:-1:-1;27876:24:0;;;;:15;:24;;;;;;-1:-1:-1;;;;;27876:24:0;;27687:221::o;27210:411::-;27291:13;27307:23;27322:7;27307:14;:23::i;:::-;27291:39;;27355:5;-1:-1:-1;;;;;27349:11:0;:2;-1:-1:-1;;;;;27349:11:0;;;27341:57;;;;-1:-1:-1;;;27341:57:0;;21377:2:1;27341:57:0;;;21359:21:1;21416:2;21396:18;;;21389:30;21455:34;21435:18;;;21428:62;-1:-1:-1;;;21506:18:1;;;21499:31;21547:19;;27341:57:0;21175:397:1;27341:57:0;2775:10;-1:-1:-1;;;;;27433:21:0;;;;:62;;-1:-1:-1;27458:37:0;27475:5;2775:10;28346:164;:::i;27458:37::-;27411:168;;;;-1:-1:-1;;;27411:168:0;;17394:2:1;27411:168:0;;;17376:21:1;17433:2;17413:18;;;17406:30;17472:34;17452:18;;;17445:62;17543:26;17523:18;;;17516:54;17587:19;;27411:168:0;17192:420:1;27411:168:0;27592:21;27601:2;27605:7;27592:8;:21::i;:::-;27280:341;27210:411;;:::o;46665:94::-;6240:6;;-1:-1:-1;;;;;6240:6:0;2775:10;6387:23;6379:68;;;;-1:-1:-1;;;6379:68:0;;;;;;;:::i;:::-;46727:17:::1;:24:::0;;-1:-1:-1;;46727:24:0::1;46747:4;46727:24;::::0;;46665:94::o;41385:104::-;6240:6;;-1:-1:-1;;;;;6240:6:0;2775:10;6387:23;6379:68;;;;-1:-1:-1;;;6379:68:0;;;;;;;:::i;:::-;41458:13:::1;:23:::0;41385:104::o;28577:339::-;28772:41;2775:10;28791:12;28805:7;28772:18;:41::i;:::-;28764:103;;;;-1:-1:-1;;;28764:103:0;;;;;;;:::i;:::-;28880:28;28890:4;28896:2;28900:7;28880:9;:28::i;42081:169::-;6240:6;;-1:-1:-1;;;;;6240:6:0;2775:10;6387:23;6379:68;;;;-1:-1:-1;;;6379:68:0;;;;;;;:::i;:::-;42176:1:::1;42164:9;:13;42156:48;;;::::0;-1:-1:-1;;;42156:48:0;;14762:2:1;42156:48:0::1;::::0;::::1;14744:21:1::0;14801:2;14781:18;;;14774:30;-1:-1:-1;;;14820:18:1;;;14813:52;14882:18;;42156:48:0::1;14560:346:1::0;42156:48:0::1;42215:15;:27:::0;42081:169::o;46771:158::-;6240:6;;46827:12;;-1:-1:-1;;;;;6240:6:0;2775:10;6387:23;6379:68;;;;-1:-1:-1;;;6379:68:0;;;;;;;:::i;:::-;46873:8:::1;::::0;46865:56:::1;::::0;-1:-1:-1;;;;;46873:8:0;;::::1;::::0;46895:21:::1;::::0;46865:56:::1;::::0;;;46895:21;46873:8;46865:56:::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1::0;46852:69:0;;46771:158;-1:-1:-1;;46771:158:0:o;45345:344::-;45422:4;45439:7;45457:9;45477;45509:25;45524:9;45509:14;:25::i;:::-;45576:24;;-1:-1:-1;;8260:2:1;8256:15;;;8252:53;45576:24:0;;;8240:66:1;45497:37:0;;-1:-1:-1;45497:37:0;;-1:-1:-1;45497:37:0;-1:-1:-1;45545:18:0;;8322:12:1;;45576:24:0;;;-1:-1:-1;;45576:24:0;;;;;;;;;45566:35;;45576:24;45566:35;;;;45649:30;;;;;;;;;11525:25:1;;;11598:4;11586:17;;11566:18;;;11559:45;;;;11620:18;;;11613:34;;;11663:18;;;11656:34;;;45566:35:0;-1:-1:-1;45649:30:0;;11497:19:1;;45649:30:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;45630:50:0;:7;6240:6;;-1:-1:-1;;;;;6240:6:0;;6167:87;45630:7;-1:-1:-1;;;;;45630:50:0;;;45345:344;-1:-1:-1;;;;;;;45345:344:0:o;28987:185::-;29125:39;29142:4;29148:2;29152:7;29125:39;;;;;;;;;;;;:16;:39::i;46401:192::-;46466:41;2775:10;46485:12;2695:98;46466:41;46458:102;;;;-1:-1:-1;;;46458:102:0;;22541:2:1;46458:102:0;;;22523:21:1;22580:2;22560:18;;;22553:30;22619:34;22599:18;;;22592:62;-1:-1:-1;;;22670:18:1;;;22663:46;22726:19;;46458:102:0;22339:412:1;46458:102:0;46571:14;46577:7;46571:5;:14::i;:::-;46401:192;:::o;42366:108::-;6240:6;;-1:-1:-1;;;;;6240:6:0;2775:10;6387:23;6379:68;;;;-1:-1:-1;;;6379:68:0;;;;;;;:::i;:::-;42443:23;;::::1;::::0;:9:::1;::::0;:23:::1;::::0;::::1;::::0;::::1;:::i;:::-;;42366:108:::0;:::o;25822:239::-;25894:7;25930:16;;;:7;:16;;;;;;-1:-1:-1;;;;;25930:16:0;25965:19;25957:73;;;;-1:-1:-1;;;25957:73:0;;18230:2:1;25957:73:0;;;18212:21:1;18269:2;18249:18;;;18242:30;18308:34;18288:18;;;18281:62;-1:-1:-1;;;18359:18:1;;;18352:39;18408:19;;25957:73:0;18028:405:1;25552:208:0;25624:7;-1:-1:-1;;;;;25652:19:0;;25644:74;;;;-1:-1:-1;;;25644:74:0;;17819:2:1;25644:74:0;;;17801:21:1;17858:2;17838:18;;;17831:30;17897:34;17877:18;;;17870:62;-1:-1:-1;;;17948:18:1;;;17941:40;17998:19;;25644:74:0;17617:406:1;25644:74:0;-1:-1:-1;;;;;;25736:16:0;;;;;:9;:16;;;;;;;25552:208::o;6818:94::-;6240:6;;-1:-1:-1;;;;;6240:6:0;2775:10;6387:23;6379:68;;;;-1:-1:-1;;;6379:68:0;;;;;;;:::i;:::-;6883:21:::1;6901:1;6883:9;:21::i;:::-;6818:94::o:0;43091:119::-;-1:-1:-1;;;;;43184:18:0;;;;;;:11;:18;;;;;;;;;43177:25;;;;;;;;;;;;;;;;;43149:16;;43177:25;;;43184:18;43177:25;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;43091:119;;;:::o;26297:104::-;26353:13;26386:7;26379:14;;;;;:::i;43870:914::-;43973:29;43980:9;43991:10;43973:6;:29::i;:::-;43965:38;;;;;;44128:10;44113:12;;:25;;;;:::i;:::-;44100:9;:38;;44092:65;;;;-1:-1:-1;;;44092:65:0;;23295:2:1;44092:65:0;;;23277:21:1;23334:2;23314:18;;;23307:30;-1:-1:-1;;;23353:18:1;;;23346:44;23407:18;;44092:65:0;23093:338:1;44092:65:0;44189:1;44176:10;:14;44168:37;;;;-1:-1:-1;;;44168:37:0;;14423:2:1;44168:37:0;;;14405:21:1;14462:2;14442:18;;;14435:30;-1:-1:-1;;;14481:18:1;;;14474:40;14531:18;;44168:37:0;14221:334:1;44168:37:0;44254:8;;44238:11;;44225:24;;:10;:24;:::i;:::-;44224:38;;44216:74;;;;-1:-1:-1;;;44216:74:0;;15113:2:1;44216:74:0;;;15095:21:1;15152:2;15132:18;;;15125:30;-1:-1:-1;;;15171:18:1;;;15164:53;15234:18;;44216:74:0;14911:347:1;44216:74:0;44323:13;;44309:10;:27;;44301:75;;;;-1:-1:-1;;;44301:75:0;;;;;;;:::i;:::-;44445:14;;44417:10;44395:33;;;;:21;:33;;;;;;:46;;44431:10;;44395:46;:::i;:::-;:64;;44387:120;;;;-1:-1:-1;;;44387:120:0;;16224:2:1;44387:120:0;;;16206:21:1;16263:2;16243:18;;;16236:30;16302:34;16282:18;;;16275:62;-1:-1:-1;;;16353:18:1;;;16346:41;16404:19;;44387:120:0;16022:407:1;44387:120:0;44542:11;;44528:110;44574:10;44560:11;;:24;;;;:::i;:::-;44555:1;:30;44528:110;;;44606:20;44612:10;44624:1;44606:5;:20::i;:::-;44587:3;;;;:::i;:::-;;;;44528:110;;;-1:-1:-1;44716:10:0;44694:33;;;;:21;:33;;;;;;:46;;44730:10;;44694:46;:::i;:::-;44680:10;44658:33;;;;:21;:33;;;;;:82;;;;44751:11;:25;;44766:10;;44658:33;44751:25;;44766:10;;44751:25;:::i;:::-;;;;-1:-1:-1;;;;43870:914:0:o;43222:636::-;4054:7;;-1:-1:-1;;;4054:7:0;;;;4308:9;4300:38;;;;-1:-1:-1;;;4300:38:0;;17049:2:1;4300:38:0;;;17031:21:1;17088:2;17068:18;;;17061:30;-1:-1:-1;;;17107:18:1;;;17100:46;17163:18;;4300:38:0;16847:340:1;4300:38:0;43324:22:::1;;43306:15;:40;43298:73;;;::::0;-1:-1:-1;;;43298:73:0;;12127:2:1;43298:73:0::1;::::0;::::1;12109:21:1::0;12166:2;12146:18;;;12139:30;-1:-1:-1;;;12185:18:1;;;12178:50;12245:18;;43298:73:0::1;11925:344:1::0;43298:73:0::1;43421:10;43403:15;;:28;;;;:::i;:::-;43390:9;:41;;43382:68;;;::::0;-1:-1:-1;;;43382:68:0;;23295:2:1;43382:68:0::1;::::0;::::1;23277:21:1::0;23334:2;23314:18;;;23307:30;-1:-1:-1;;;23353:18:1;;;23346:44;23407:18;;43382:68:0::1;23093:338:1::0;43382:68:0::1;43482:1;43469:10;:14;43461:42;;;::::0;-1:-1:-1;;;43461:42:0;;22197:2:1;43461:42:0::1;::::0;::::1;22179:21:1::0;22236:2;22216:18;;;22209:30;-1:-1:-1;;;22255:18:1;;;22248:45;22310:18;;43461:42:0::1;21995:339:1::0;43461:42:0::1;43552:8;::::0;43536:11:::1;::::0;43523:24:::1;::::0;:10;:24:::1;:::i;:::-;43522:38;;43514:74;;;::::0;-1:-1:-1;;;43514:74:0;;15113:2:1;43514:74:0::1;::::0;::::1;15095:21:1::0;15152:2;15132:18;;;15125:30;-1:-1:-1;;;15171:18:1;;;15164:53;15234:18;;43514:74:0::1;14911:347:1::0;43514:74:0::1;43621:13;;43607:10;:27;;43599:75;;;;-1:-1:-1::0;;;43599:75:0::1;;;;;;;:::i;:::-;43709:11;::::0;43695:110:::1;43741:10;43727:11;;:24;;;;:::i;:::-;43722:1;:30;43695:110;;;43773:20;43779:10;43791:1;43773:5;:20::i;:::-;43754:3:::0;::::1;::::0;::::1;:::i;:::-;;;;43695:110;;;;43840:10;43825:11;;:25;;;;;;;:::i;:::-;::::0;;;-1:-1:-1;;;43222:636:0:o;27980:295::-;-1:-1:-1;;;;;28083:24:0;;2775:10;28083:24;;28075:62;;;;-1:-1:-1;;;28075:62:0;;15870:2:1;28075:62:0;;;15852:21:1;15909:2;15889:18;;;15882:30;15948:27;15928:18;;;15921:55;15993:18;;28075:62:0;15668:349:1;28075:62:0;2775:10;28150:32;;;;:18;:32;;;;;;;;-1:-1:-1;;;;;28150:42:0;;;;;;;;;;;;:53;;-1:-1:-1;;28150:53:0;;;;;;;;;;28219:48;;11246:41:1;;;28150:42:0;;2775:10;28219:48;;11219:18:1;28219:48:0;;;;;;;27980:295;;:::o;45701:515::-;45764:5;45771:7;45780;45807:3;:10;45821:2;45807:16;45799:25;;;;;;-1:-1:-1;;;45996:2:0;45987:12;;45981:19;46064:2;46055:12;;46049:19;46169:2;46160:12;;;46154:19;45843:9;46146:28;;45981:19;;46049;45701:515::o;41501:107::-;6240:6;;-1:-1:-1;;;;;6240:6:0;2775:10;6387:23;6379:68;;;;-1:-1:-1;;;6379:68:0;;;;;;;:::i;:::-;41576:14:::1;:24:::0;41501:107::o;44797:530::-;6240:6;;-1:-1:-1;;;;;6240:6:0;2775:10;6387:23;6379:68;;;;-1:-1:-1;;;6379:68:0;;;;;;;:::i;:::-;44912:17:::1;::::0;::::1;;44911:18;44903:62;;;::::0;-1:-1:-1;;;44903:62:0;;12476:2:1;44903:62:0::1;::::0;::::1;12458:21:1::0;12515:2;12495:18;;;12488:30;12554:33;12534:18;;;12527:61;12605:18;;44903:62:0::1;12274:355:1::0;44903:62:0::1;45005:7;:14;44984:10;:17;:35;44976:77;;;::::0;-1:-1:-1;;;44976:77:0;;19832:2:1;44976:77:0::1;::::0;::::1;19814:21:1::0;19871:2;19851:18;;;19844:30;19910:31;19890:18;;;19883:59;19959:18;;44976:77:0::1;19630:353:1::0;44976:77:0::1;45079:9;45074:246;45096:10;:17;45092:1;:21;45074:246;;;45148:11;::::0;45134:121:::1;45180:7;45188:1;45180:10;;;;;;;;:::i;:::-;;;;;;;45166:11;;:24;;;;:::i;:::-;45161:1;:30;45134:121;;;45216:23;45222:10;45233:1;45222:13;;;;;;;;:::i;:::-;;;;;;;45237:1;45216:5;:23::i;:::-;45193:3:::0;::::1;::::0;::::1;:::i;:::-;;;;45134:121;;;;45298:7;45306:1;45298:10;;;;;;;;:::i;:::-;;;;;;;45283:11;;:25;;;;;;;:::i;:::-;::::0;;;-1:-1:-1;45115:3:0;;-1:-1:-1;45115:3:0::1;::::0;::::1;:::i;:::-;;;;45074:246;;29243:328:::0;29418:41;2775:10;29451:7;29418:18;:41::i;:::-;29410:103;;;;-1:-1:-1;;;29410:103:0;;;;;;;:::i;:::-;29524:39;29538:4;29544:2;29548:7;29557:5;29524:13;:39::i;:::-;29243:328;;;;:::o;40562:25::-;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;42486:127::-;6240:6;;-1:-1:-1;;;;;6240:6:0;2775:10;6387:23;6379:68;;;;-1:-1:-1;;;6379:68:0;;;;;;;:::i;:::-;42573:32;;::::1;::::0;:13:::1;::::0;:32:::1;::::0;::::1;::::0;::::1;:::i;41760:134::-:0;6240:6;;-1:-1:-1;;;;;6240:6:0;2775:10;6387:23;6379:68;;;;-1:-1:-1;;;6379:68:0;;;;;;;:::i;:::-;41848:22:::1;:38:::0;41760:134::o;42631:291::-;42704:13;42739;42733:27;;;;;:::i;:::-;:32;42730:93;;-1:-1:-1;42730:93:0;;42788:23;42803:7;42788:14;:23::i;42730:93::-;42874:23;42889:7;42874:14;:23::i;:::-;42899:13;42857:56;;;;;;;;;:::i;:::-;;;;;;;;;;;;;42843:71;;42631:291;;;:::o;42262:92::-;6240:6;;-1:-1:-1;;;;;6240:6:0;2775:10;6387:23;6379:68;;;;-1:-1:-1;;;6379:68:0;;;;;;;:::i;:::-;42328:8:::1;:18:::0;;-1:-1:-1;;;;;;42328:18:0::1;-1:-1:-1::0;;;;;42328:18:0;;;::::1;::::0;;;::::1;::::0;;42262:92::o;41906:163::-;6240:6;;-1:-1:-1;;;;;6240:6:0;2775:10;6387:23;6379:68;;;;-1:-1:-1;;;6379:68:0;;;;;;;:::i;:::-;41998:1:::1;41986:9;:13;41978:48;;;::::0;-1:-1:-1;;;41978:48:0;;14762:2:1;41978:48:0::1;::::0;::::1;14744:21:1::0;14801:2;14781:18;;;14774:30;-1:-1:-1;;;14820:18:1;;;14813:52;14882:18;;41978:48:0::1;14560:346:1::0;41978:48:0::1;42037:12;:24:::0;41906:163::o;42934:145::-;42978:13;43035:9;43018:52;;;;;;;;:::i;:::-;;;;;;;;;;;;;43004:67;;42934:145;:::o;41620:128::-;6240:6;;-1:-1:-1;;;;;6240:6:0;2775:10;6387:23;6379:68;;;;-1:-1:-1;;;6379:68:0;;;;;;;:::i;:::-;41705:19:::1;:35:::0;41620:128::o;7067:192::-;6240:6;;-1:-1:-1;;;;;6240:6:0;2775:10;6387:23;6379:68;;;;-1:-1:-1;;;6379:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;7156:22:0;::::1;7148:73;;;::::0;-1:-1:-1;;;7148:73:0;;13255:2:1;7148:73:0::1;::::0;::::1;13237:21:1::0;13294:2;13274:18;;;13267:30;13333:34;13313:18;;;13306:62;-1:-1:-1;;;13384:18:1;;;13377:36;13430:19;;7148:73:0::1;13053:402:1::0;7148:73:0::1;7232:19;7242:8;7232:9;:19::i;35063:174::-:0;35138:24;;;;:15;:24;;;;;:29;;-1:-1:-1;;;;;;35138:29:0;-1:-1:-1;;;;;35138:29:0;;;;;;;;:24;;35192:23;35138:24;35192:14;:23::i;:::-;-1:-1:-1;;;;;35183:46:0;;;;;;;;;;;35063:174;;:::o;31375:348::-;31468:4;31170:16;;;:7;:16;;;;;;-1:-1:-1;;;;;31170:16:0;31485:73;;;;-1:-1:-1;;;31485:73:0;;16636:2:1;31485:73:0;;;16618:21:1;16675:2;16655:18;;;16648:30;16714:34;16694:18;;;16687:62;-1:-1:-1;;;16765:18:1;;;16758:42;16817:19;;31485:73:0;16434:408:1;31485:73:0;31569:13;31585:23;31600:7;31585:14;:23::i;:::-;31569:39;;31638:5;-1:-1:-1;;;;;31627:16:0;:7;-1:-1:-1;;;;;31627:16:0;;:51;;;;31671:7;-1:-1:-1;;;;;31647:31:0;:20;31659:7;31647:11;:20::i;:::-;-1:-1:-1;;;;;31647:31:0;;31627:51;:87;;;-1:-1:-1;;;;;;28467:25:0;;;28443:4;28467:25;;;:18;:25;;;;;;;;:35;;;;;;;;;;;;31682:32;31619:96;31375:348;-1:-1:-1;;;;31375:348:0:o;34367:578::-;34526:4;-1:-1:-1;;;;;34499:31:0;:23;34514:7;34499:14;:23::i;:::-;-1:-1:-1;;;;;34499:31:0;;34491:85;;;;-1:-1:-1;;;34491:85:0;;20551:2:1;34491:85:0;;;20533:21:1;20590:2;20570:18;;;20563:30;20629:34;20609:18;;;20602:62;-1:-1:-1;;;20680:18:1;;;20673:39;20729:19;;34491:85:0;20349:405:1;34491:85:0;-1:-1:-1;;;;;34595:16:0;;34587:65;;;;-1:-1:-1;;;34587:65:0;;15465:2:1;34587:65:0;;;15447:21:1;15504:2;15484:18;;;15477:30;15543:34;15523:18;;;15516:62;-1:-1:-1;;;15594:18:1;;;15587:34;15638:19;;34587:65:0;15263:400:1;34587:65:0;34665:39;34686:4;34692:2;34696:7;34665:20;:39::i;:::-;34769:29;34786:1;34790:7;34769:8;:29::i;:::-;-1:-1:-1;;;;;34811:15:0;;;;;;:9;:15;;;;;:20;;34830:1;;34811:15;:20;;34830:1;;34811:20;:::i;:::-;;;;-1:-1:-1;;;;;;;34842:13:0;;;;;;:9;:13;;;;;:18;;34859:1;;34842:13;:18;;34859:1;;34842:18;:::i;:::-;;;;-1:-1:-1;;34871:16:0;;;;:7;:16;;;;;;:21;;-1:-1:-1;;;;;;34871:21:0;-1:-1:-1;;;;;34871:21:0;;;;;;;;;34910:27;;34871:16;;34910:27;;;;;;;34367:578;;;:::o;39017:206::-;39086:20;39098:7;39086:11;:20::i;:::-;39129:19;;;;:10;:19;;;;;39123:33;;;;;:::i;:::-;:38;;-1:-1:-1;39119:97:0;;39185:19;;;;:10;:19;;;;;39178:26;;;:::i;7267:173::-;7342:6;;;-1:-1:-1;;;;;7359:17:0;;;-1:-1:-1;;;;;;7359:17:0;;;;;;;7392:40;;7342:6;;;7359:17;7342:6;;7392:40;;7323:16;;7392:40;7312:128;7267:173;:::o;33059:382::-;-1:-1:-1;;;;;33139:16:0;;33131:61;;;;-1:-1:-1;;;33131:61:0;;18640:2:1;33131:61:0;;;18622:21:1;;;18659:18;;;18652:30;18718:34;18698:18;;;18691:62;18770:18;;33131:61:0;18438:356:1;33131:61:0;31146:4;31170:16;;;:7;:16;;;;;;-1:-1:-1;;;;;31170:16:0;:30;33203:58;;;;-1:-1:-1;;;33203:58:0;;13662:2:1;33203:58:0;;;13644:21:1;13701:2;13681:18;;;13674:30;13740;13720:18;;;13713:58;13788:18;;33203:58:0;13460:352:1;33203:58:0;33274:45;33303:1;33307:2;33311:7;33274:20;:45::i;:::-;-1:-1:-1;;;;;33332:13:0;;;;;;:9;:13;;;;;:18;;33349:1;;33332:13;:18;;33349:1;;33332:18;:::i;:::-;;;;-1:-1:-1;;33361:16:0;;;;:7;:16;;;;;;:21;;-1:-1:-1;;;;;;33361:21:0;-1:-1:-1;;;;;33361:21:0;;;;;;;;33400:33;;33361:16;;;33400:33;;33361:16;;33400:33;33059:382;;:::o;30453:315::-;30610:28;30620:4;30626:2;30630:7;30610:9;:28::i;:::-;30657:48;30680:4;30686:2;30690:7;30699:5;30657:22;:48::i;:::-;30649:111;;;;-1:-1:-1;;;30649:111:0;;;;;;;:::i;37736:679::-;31146:4;31170:16;;;:7;:16;;;;;;37809:13;;-1:-1:-1;;;;;31170:16:0;37835:78;;;;-1:-1:-1;;;37835:78:0;;19001:2:1;37835:78:0;;;18983:21:1;19040:2;19020:18;;;19013:30;19079:34;19059:18;;;19052:62;-1:-1:-1;;;19130:18:1;;;19123:47;19187:19;;37835:78:0;18799:413:1;37835:78:0;37926:23;37952:19;;;:10;:19;;;;;37926:45;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;37982:18;38003:10;:8;:10::i;:::-;37982:31;;38095:4;38089:18;38111:1;38089:23;38085:72;;;-1:-1:-1;38136:9:0;37736:679;-1:-1:-1;;37736:679:0:o;38085:72::-;38261:23;;:27;38257:108;;38336:4;38342:9;38319:33;;;;;;;;;:::i;:::-;;;;;;;;;;;;;38305:48;;;;37736:679;;;:::o;38257:108::-;38384:23;38399:7;38384:14;:23::i;46941:922::-;-1:-1:-1;;;;;47046:18:0;;;47043:95;;47096:16;47104:7;47096;:16::i;:::-;-1:-1:-1;;;;;47088:24:0;:4;-1:-1:-1;;;;;47088:24:0;;47080:46;;;;-1:-1:-1;;;47080:46:0;;22958:2:1;47080:46:0;;;22940:21:1;22997:1;22977:18;;;22970:29;-1:-1:-1;;;23015:18:1;;;23008:39;23064:18;;47080:46:0;22756:332:1;47080:46:0;47169:2;-1:-1:-1;;;;;47161:10:0;:4;-1:-1:-1;;;;;47161:10:0;;47158:47;;;46941:922;;;:::o;47158:47::-;47225:31;47259:24;;;:15;:24;;;;;;-1:-1:-1;;;;;47354:16:0;;;47351:144;;-1:-1:-1;;;;;47386:15:0;;;;;;:11;:15;;;;;;;:29;;;;;;;;;;;;;;;;;;47457:15;;;;:22;;:26;;47386:29;47457:26;:::i;:::-;47430:24;;;;:15;:24;;;;;:53;47351:144;-1:-1:-1;;;;;47572:18:0;;;47569:287;;-1:-1:-1;;;;;47621:17:0;;47606:12;47621:17;;;:11;:17;;;;;:24;47690:8;47697:1;47621:24;47690:8;:::i;:::-;47663:23;:36;47660:147;;;-1:-1:-1;;;;;47764:17:0;;;;;;:11;:17;;;;;47782:8;47789:1;47782:4;:8;:::i;:::-;47764:27;;;;;;;;:::i;:::-;;;;;;;;;47719:11;:17;47731:4;-1:-1:-1;;;;;47719:17:0;-1:-1:-1;;;;;47719:17:0;;;;;;;;;;;;47737:23;47719:42;;;;;;;;:::i;:::-;;;;;;;;;;:72;47660:147;-1:-1:-1;;;;;47821:17:0;;;;;;:11;:17;;;;;:23;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;47591:265;47032:831;46941:922;;;:::o;33670:360::-;33730:13;33746:23;33761:7;33746:14;:23::i;:::-;33730:39;;33782:48;33803:5;33818:1;33822:7;33782:20;:48::i;:::-;33871:29;33888:1;33892:7;33871:8;:29::i;:::-;-1:-1:-1;;;;;33913:16:0;;;;;;:9;:16;;;;;:21;;33933:1;;33913:16;:21;;33933:1;;33913:21;:::i;:::-;;;;-1:-1:-1;;33952:16:0;;;;:7;:16;;;;;;33945:23;;-1:-1:-1;;;;;;33945:23:0;;;33986:36;33960:7;;33952:16;-1:-1:-1;;;;;33986:36:0;;;;;33952:16;;33986:36;33719:311;33670:360;:::o;35802:799::-;35957:4;-1:-1:-1;;;;;35978:13:0;;8536:20;8584:8;35974:620;;36014:72;;-1:-1:-1;;;36014:72:0;;-1:-1:-1;;;;;36014:36:0;;;;;:72;;2775:10;;36065:4;;36071:7;;36080:5;;36014:72;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;36014:72:0;;;;;;;;-1:-1:-1;;36014:72:0;;;;;;;;;;;;:::i;:::-;;;36010:529;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;36256:13:0;;36252:272;;36299:60;;-1:-1:-1;;;36299:60:0;;;;;;;:::i;36252:272::-;36474:6;36468:13;36459:6;36455:2;36451:15;36444:38;36010:529;-1:-1:-1;;;;;;36137:51:0;-1:-1:-1;;;36137:51:0;;-1:-1:-1;36130:58:0;;35974:620;-1:-1:-1;36578:4:0;35802:799;;;;;;:::o;47875:102::-;47927:13;47960:9;47953:16;;;;;:::i;26472:334::-;31146:4;31170:16;;;:7;:16;;;;;;26545:13;;-1:-1:-1;;;;;31170:16:0;26571:76;;;;-1:-1:-1;;;26571:76:0;;20961:2:1;26571:76:0;;;20943:21:1;21000:2;20980:18;;;20973:30;21039:34;21019:18;;;21012:62;-1:-1:-1;;;21090:18:1;;;21083:45;21145:19;;26571:76:0;20759:411:1;26571:76:0;26660:21;26684:10;:8;:10::i;:::-;26660:34;;26736:1;26718:7;26712:21;:25;:86;;;;;;;;;;;;;;;;;26764:7;26773:18;:7;:16;:18::i;:::-;26747:45;;;;;;;;;:::i;:::-;;;;;;;;;;;;;26712:86;26705:93;26472:334;-1:-1:-1;;;26472:334:0:o;311:723::-;367:13;588:10;584:53;;-1:-1:-1;;615:10:0;;;;;;;;;;;;-1:-1:-1;;;615:10:0;;;;;311:723::o;584:53::-;662:5;647:12;703:78;710:9;;703:78;;736:8;;;;:::i;:::-;;-1:-1:-1;759:10:0;;-1:-1:-1;767:2:0;759:10;;:::i;:::-;;;703:78;;;791:19;823:6;813:17;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;813:17:0;;791:39;;841:154;848:10;;841:154;;875:11;885:1;875:11;;:::i;:::-;;-1:-1:-1;944:10:0;952:2;944:5;:10;:::i;:::-;931:24;;:2;:24;:::i;:::-;918:39;;901:6;908;901:14;;;;;;;;:::i;:::-;;;;:56;-1:-1:-1;;;;;901:56:0;;;;;;;;-1:-1:-1;972:11:0;981:2;972:11;;:::i;:::-;;;841:154;;-1:-1:-1;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;:::o;:::-;;;;;;;:::i;:::-;;;;;;;;;;;:::o;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14:406:1;78:5;112:18;104:6;101:30;98:56;;;134:18;;:::i;:::-;172:57;217:2;196:15;;-1:-1:-1;;192:29:1;223:4;188:40;172:57;:::i;:::-;163:66;;252:6;245:5;238:21;292:3;283:6;278:3;274:16;271:25;268:45;;;309:1;306;299:12;268:45;358:6;353:3;346:4;339:5;335:16;322:43;412:1;405:4;396:6;389:5;385:18;381:29;374:40;14:406;;;;;:::o;425:173::-;493:20;;-1:-1:-1;;;;;542:31:1;;532:42;;522:70;;588:1;585;578:12;522:70;425:173;;;:::o;603:673::-;657:5;710:3;703:4;695:6;691:17;687:27;677:55;;728:1;725;718:12;677:55;764:6;751:20;790:4;814:60;830:43;870:2;830:43;:::i;:::-;814:60;:::i;:::-;896:3;920:2;915:3;908:15;948:2;943:3;939:12;932:19;;983:2;975:6;971:15;1035:3;1030:2;1024;1021:1;1017:10;1009:6;1005:23;1001:32;998:41;995:61;;;1052:1;1049;1042:12;995:61;1074:1;1084:163;1098:2;1095:1;1092:9;1084:163;;;1155:17;;1143:30;;1193:12;;;;1225;;;;1116:1;1109:9;1084:163;;;-1:-1:-1;1265:5:1;;603:673;-1:-1:-1;;;;;;;603:673:1:o;1281:220::-;1323:5;1376:3;1369:4;1361:6;1357:17;1353:27;1343:55;;1394:1;1391;1384:12;1343:55;1416:79;1491:3;1482:6;1469:20;1462:4;1454:6;1450:17;1416:79;:::i;1506:186::-;1565:6;1618:2;1606:9;1597:7;1593:23;1589:32;1586:52;;;1634:1;1631;1624:12;1586:52;1657:29;1676:9;1657:29;:::i;1697:260::-;1765:6;1773;1826:2;1814:9;1805:7;1801:23;1797:32;1794:52;;;1842:1;1839;1832:12;1794:52;1865:29;1884:9;1865:29;:::i;:::-;1855:39;;1913:38;1947:2;1936:9;1932:18;1913:38;:::i;:::-;1903:48;;1697:260;;;;;:::o;1962:328::-;2039:6;2047;2055;2108:2;2096:9;2087:7;2083:23;2079:32;2076:52;;;2124:1;2121;2114:12;2076:52;2147:29;2166:9;2147:29;:::i;:::-;2137:39;;2195:38;2229:2;2218:9;2214:18;2195:38;:::i;:::-;2185:48;;2280:2;2269:9;2265:18;2252:32;2242:42;;1962:328;;;;;:::o;2295:537::-;2390:6;2398;2406;2414;2467:3;2455:9;2446:7;2442:23;2438:33;2435:53;;;2484:1;2481;2474:12;2435:53;2507:29;2526:9;2507:29;:::i;:::-;2497:39;;2555:38;2589:2;2578:9;2574:18;2555:38;:::i;:::-;2545:48;;2640:2;2629:9;2625:18;2612:32;2602:42;;2695:2;2684:9;2680:18;2667:32;2722:18;2714:6;2711:30;2708:50;;;2754:1;2751;2744:12;2708:50;2777:49;2818:7;2809:6;2798:9;2794:22;2777:49;:::i;:::-;2767:59;;;2295:537;;;;;;;:::o;2837:347::-;2902:6;2910;2963:2;2951:9;2942:7;2938:23;2934:32;2931:52;;;2979:1;2976;2969:12;2931:52;3002:29;3021:9;3002:29;:::i;:::-;2992:39;;3081:2;3070:9;3066:18;3053:32;3128:5;3121:13;3114:21;3107:5;3104:32;3094:60;;3150:1;3147;3140:12;3094:60;3173:5;3163:15;;;2837:347;;;;;:::o;3189:254::-;3257:6;3265;3318:2;3306:9;3297:7;3293:23;3289:32;3286:52;;;3334:1;3331;3324:12;3286:52;3357:29;3376:9;3357:29;:::i;:::-;3347:39;3433:2;3418:18;;;;3405:32;;-1:-1:-1;;;3189:254:1:o;3448:1157::-;3566:6;3574;3627:2;3615:9;3606:7;3602:23;3598:32;3595:52;;;3643:1;3640;3633:12;3595:52;3683:9;3670:23;3712:18;3753:2;3745:6;3742:14;3739:34;;;3769:1;3766;3759:12;3739:34;3807:6;3796:9;3792:22;3782:32;;3852:7;3845:4;3841:2;3837:13;3833:27;3823:55;;3874:1;3871;3864:12;3823:55;3910:2;3897:16;3932:4;3956:60;3972:43;4012:2;3972:43;:::i;3956:60::-;4038:3;4062:2;4057:3;4050:15;4090:2;4085:3;4081:12;4074:19;;4121:2;4117;4113:11;4169:7;4164:2;4158;4155:1;4151:10;4147:2;4143:19;4139:28;4136:41;4133:61;;;4190:1;4187;4180:12;4133:61;4212:1;4203:10;;4222:169;4236:2;4233:1;4230:9;4222:169;;;4293:23;4312:3;4293:23;:::i;:::-;4281:36;;4254:1;4247:9;;;;;4337:12;;;;4369;;4222:169;;;-1:-1:-1;4410:5:1;-1:-1:-1;;4453:18:1;;4440:32;;-1:-1:-1;;4484:16:1;;;4481:36;;;4513:1;4510;4503:12;4481:36;;4536:63;4591:7;4580:8;4569:9;4565:24;4536:63;:::i;:::-;4526:73;;;3448:1157;;;;;:::o;4610:245::-;4668:6;4721:2;4709:9;4700:7;4696:23;4692:32;4689:52;;;4737:1;4734;4727:12;4689:52;4776:9;4763:23;4795:30;4819:5;4795:30;:::i;4860:249::-;4929:6;4982:2;4970:9;4961:7;4957:23;4953:32;4950:52;;;4998:1;4995;4988:12;4950:52;5030:9;5024:16;5049:30;5073:5;5049:30;:::i;5114:320::-;5182:6;5235:2;5223:9;5214:7;5210:23;5206:32;5203:52;;;5251:1;5248;5241:12;5203:52;5291:9;5278:23;5324:18;5316:6;5313:30;5310:50;;;5356:1;5353;5346:12;5310:50;5379:49;5420:7;5411:6;5400:9;5396:22;5379:49;:::i;5439:394::-;5516:6;5524;5577:2;5565:9;5556:7;5552:23;5548:32;5545:52;;;5593:1;5590;5583:12;5545:52;5633:9;5620:23;5666:18;5658:6;5655:30;5652:50;;;5698:1;5695;5688:12;5652:50;5721:49;5762:7;5753:6;5742:9;5738:22;5721:49;:::i;:::-;5711:59;;;5789:38;5823:2;5812:9;5808:18;5789:38;:::i;5838:450::-;5907:6;5960:2;5948:9;5939:7;5935:23;5931:32;5928:52;;;5976:1;5973;5966:12;5928:52;6016:9;6003:23;6049:18;6041:6;6038:30;6035:50;;;6081:1;6078;6071:12;6035:50;6104:22;;6157:4;6149:13;;6145:27;-1:-1:-1;6135:55:1;;6186:1;6183;6176:12;6135:55;6209:73;6274:7;6269:2;6256:16;6251:2;6247;6243:11;6209:73;:::i;6293:180::-;6352:6;6405:2;6393:9;6384:7;6380:23;6376:32;6373:52;;;6421:1;6418;6411:12;6373:52;-1:-1:-1;6444:23:1;;6293:180;-1:-1:-1;6293:180:1:o;6478:388::-;6555:6;6563;6616:2;6604:9;6595:7;6591:23;6587:32;6584:52;;;6632:1;6629;6622:12;6584:52;6668:9;6655:23;6645:33;;6729:2;6718:9;6714:18;6701:32;6756:18;6748:6;6745:30;6742:50;;;6788:1;6785;6778:12;6742:50;6811:49;6852:7;6843:6;6832:9;6828:22;6811:49;:::i;6871:257::-;6912:3;6950:5;6944:12;6977:6;6972:3;6965:19;6993:63;7049:6;7042:4;7037:3;7033:14;7026:4;7019:5;7015:16;6993:63;:::i;:::-;7110:2;7089:15;-1:-1:-1;;7085:29:1;7076:39;;;;7117:4;7072:50;;6871:257;-1:-1:-1;;6871:257:1:o;7133:973::-;7218:12;;7183:3;;7273:1;7293:18;;;;7346;;;;7373:61;;7427:4;7419:6;7415:17;7405:27;;7373:61;7453:2;7501;7493:6;7490:14;7470:18;7467:38;7464:161;;;7547:10;7542:3;7538:20;7535:1;7528:31;7582:4;7579:1;7572:15;7610:4;7607:1;7600:15;7464:161;7641:18;7668:104;;;;7786:1;7781:319;;;;7634:466;;7668:104;-1:-1:-1;;7701:24:1;;7689:37;;7746:16;;;;-1:-1:-1;7668:104:1;;7781:319;24490:1;24483:14;;;24527:4;24514:18;;7875:1;7889:165;7903:6;7900:1;7897:13;7889:165;;;7981:14;;7968:11;;;7961:35;8024:16;;;;7918:10;;7889:165;;;7893:3;;8083:6;8078:3;8074:16;8067:23;;7634:466;;;;;;;7133:973;;;;:::o;8345:470::-;8524:3;8562:6;8556:13;8578:53;8624:6;8619:3;8612:4;8604:6;8600:17;8578:53;:::i;:::-;8694:13;;8653:16;;;;8716:57;8694:13;8653:16;8750:4;8738:17;;8716:57;:::i;:::-;8789:20;;8345:470;-1:-1:-1;;;;8345:470:1:o;8820:356::-;8996:3;9034:6;9028:13;9050:53;9096:6;9091:3;9084:4;9076:6;9072:17;9050:53;:::i;:::-;9119:51;9162:6;9157:3;9153:16;9145:6;9119:51;:::i;:::-;9112:58;8820:356;-1:-1:-1;;;;;8820:356:1:o;9181:372::-;9410:3;9438:38;9472:3;9464:6;9438:38;:::i;:::-;-1:-1:-1;;;9485:35:1;;9544:2;9536:11;;9181:372;-1:-1:-1;;;9181:372:1:o;9976:488::-;-1:-1:-1;;;;;10245:15:1;;;10227:34;;10297:15;;10292:2;10277:18;;10270:43;10344:2;10329:18;;10322:34;;;10392:3;10387:2;10372:18;;10365:31;;;10170:4;;10413:45;;10438:19;;10430:6;10413:45;:::i;:::-;10405:53;9976:488;-1:-1:-1;;;;;;9976:488:1:o;10469:632::-;10640:2;10692:21;;;10762:13;;10665:18;;;10784:22;;;10611:4;;10640:2;10863:15;;;;10837:2;10822:18;;;10611:4;10906:169;10920:6;10917:1;10914:13;10906:169;;;10981:13;;10969:26;;11050:15;;;;11015:12;;;;10942:1;10935:9;10906:169;;;-1:-1:-1;11092:3:1;;10469:632;-1:-1:-1;;;;;;10469:632:1:o;11701:219::-;11850:2;11839:9;11832:21;11813:4;11870:44;11910:2;11899:9;11895:18;11887:6;11870:44;:::i;12634:414::-;12836:2;12818:21;;;12875:2;12855:18;;;12848:30;12914:34;12909:2;12894:18;;12887:62;-1:-1:-1;;;12980:2:1;12965:18;;12958:48;13038:3;13023:19;;12634:414::o;13817:399::-;14019:2;14001:21;;;14058:2;14038:18;;;14031:30;14097:34;14092:2;14077:18;;14070:62;-1:-1:-1;;;14163:2:1;14148:18;;14141:33;14206:3;14191:19;;13817:399::o;19988:356::-;20190:2;20172:21;;;20209:18;;;20202:30;20268:34;20263:2;20248:18;;20241:62;20335:2;20320:18;;19988:356::o;21577:413::-;21779:2;21761:21;;;21818:2;21798:18;;;21791:30;21857:34;21852:2;21837:18;;21830:62;-1:-1:-1;;;21923:2:1;21908:18;;21901:47;21980:3;21965:19;;21577:413::o;23949:275::-;24020:2;24014:9;24085:2;24066:13;;-1:-1:-1;;24062:27:1;24050:40;;24120:18;24105:34;;24141:22;;;24102:62;24099:88;;;24167:18;;:::i;:::-;24203:2;24196:22;23949:275;;-1:-1:-1;23949:275:1:o;24229:183::-;24289:4;24322:18;24314:6;24311:30;24308:56;;;24344:18;;:::i;:::-;-1:-1:-1;24389:1:1;24385:14;24401:4;24381:25;;24229:183::o;24543:128::-;24583:3;24614:1;24610:6;24607:1;24604:13;24601:39;;;24620:18;;:::i;:::-;-1:-1:-1;24656:9:1;;24543:128::o;24676:120::-;24716:1;24742;24732:35;;24747:18;;:::i;:::-;-1:-1:-1;24781:9:1;;24676:120::o;24801:168::-;24841:7;24907:1;24903;24899:6;24895:14;24892:1;24889:21;24884:1;24877:9;24870:17;24866:45;24863:71;;;24914:18;;:::i;:::-;-1:-1:-1;24954:9:1;;24801:168::o;24974:125::-;25014:4;25042:1;25039;25036:8;25033:34;;;25047:18;;:::i;:::-;-1:-1:-1;25084:9:1;;24974:125::o;25104:258::-;25176:1;25186:113;25200:6;25197:1;25194:13;25186:113;;;25276:11;;;25270:18;25257:11;;;25250:39;25222:2;25215:10;25186:113;;;25317:6;25314:1;25311:13;25308:48;;;-1:-1:-1;;25352:1:1;25334:16;;25327:27;25104:258::o;25367:380::-;25446:1;25442:12;;;;25489;;;25510:61;;25564:4;25556:6;25552:17;25542:27;;25510:61;25617:2;25609:6;25606:14;25586:18;25583:38;25580:161;;;25663:10;25658:3;25654:20;25651:1;25644:31;25698:4;25695:1;25688:15;25726:4;25723:1;25716:15;25580:161;;25367:380;;;:::o;25752:135::-;25791:3;-1:-1:-1;;25812:17:1;;25809:43;;;25832:18;;:::i;:::-;-1:-1:-1;25879:1:1;25868:13;;25752:135::o;25892:112::-;25924:1;25950;25940:35;;25955:18;;:::i;:::-;-1:-1:-1;25989:9:1;;25892:112::o;26009:127::-;26070:10;26065:3;26061:20;26058:1;26051:31;26101:4;26098:1;26091:15;26125:4;26122:1;26115:15;26141:127;26202:10;26197:3;26193:20;26190:1;26183:31;26233:4;26230:1;26223:15;26257:4;26254:1;26247:15;26273:127;26334:10;26329:3;26325:20;26322:1;26315:31;26365:4;26362:1;26355:15;26389:4;26386:1;26379:15;26405:127;26466:10;26461:3;26457:20;26454:1;26447:31;26497:4;26494:1;26487:15;26521:4;26518:1;26511:15;26537:127;26598:10;26593:3;26589:20;26586:1;26579:31;26629:4;26626:1;26619:15;26653:4;26650:1;26643:15;26669:131;-1:-1:-1;;;;;;26743:32:1;;26733:43;;26723:71;;26790:1;26787;26780:12

Swarm Source

ipfs://2f7bf2be806fa9eb45d31066e9f006f2745b5720c0447527b8523641d8adeb56
Loading...
Loading
Loading...
Loading
[ Download: CSV Export  ]
[ Download: CSV Export  ]

A token is a representation of an on-chain or off-chain asset. The token page shows information such as price, total supply, holders, transfers and social links. Learn more about this page in our Knowledge Base.