编译器
0.8.19+commit.7dd6d404
文件 1 的 19:Address.sol
pragma solidity ^0.8.1;
library Address {
function isContract(address account) internal view returns (bool) {
return account.code.length > 0;
}
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");
}
function functionCall(address target, bytes memory data) internal returns (bytes memory) {
return functionCallWithValue(target, data, 0, "Address: low-level call failed");
}
function functionCall(
address target,
bytes memory data,
string memory errorMessage
) internal returns (bytes memory) {
return functionCallWithValue(target, data, 0, errorMessage);
}
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");
}
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");
(bool success, bytes memory returndata) = target.call{value: value}(data);
return verifyCallResultFromTarget(target, success, returndata, errorMessage);
}
function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {
return functionStaticCall(target, data, "Address: low-level static call failed");
}
function functionStaticCall(
address target,
bytes memory data,
string memory errorMessage
) internal view returns (bytes memory) {
(bool success, bytes memory returndata) = target.staticcall(data);
return verifyCallResultFromTarget(target, success, returndata, errorMessage);
}
function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {
return functionDelegateCall(target, data, "Address: low-level delegate call failed");
}
function functionDelegateCall(
address target,
bytes memory data,
string memory errorMessage
) internal returns (bytes memory) {
(bool success, bytes memory returndata) = target.delegatecall(data);
return verifyCallResultFromTarget(target, success, returndata, errorMessage);
}
function verifyCallResultFromTarget(
address target,
bool success,
bytes memory returndata,
string memory errorMessage
) internal view returns (bytes memory) {
if (success) {
if (returndata.length == 0) {
require(isContract(target), "Address: call to non-contract");
}
return returndata;
} else {
_revert(returndata, errorMessage);
}
}
function verifyCallResult(
bool success,
bytes memory returndata,
string memory errorMessage
) internal pure returns (bytes memory) {
if (success) {
return returndata;
} else {
_revert(returndata, errorMessage);
}
}
function _revert(bytes memory returndata, string memory errorMessage) private pure {
if (returndata.length > 0) {
assembly {
let returndata_size := mload(returndata)
revert(add(32, returndata), returndata_size)
}
} else {
revert(errorMessage);
}
}
}
文件 2 的 19:Context.sol
pragma solidity ^0.8.0;
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
function _msgData() internal view virtual returns (bytes calldata) {
return msg.data;
}
}
文件 3 的 19:ERC165.sol
pragma solidity ^0.8.0;
import "./IERC165.sol";
abstract contract ERC165 is IERC165 {
function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {
return interfaceId == type(IERC165).interfaceId;
}
}
文件 4 的 19:ERC2981.sol
pragma solidity ^0.8.0;
import "../../interfaces/IERC2981.sol";
import "../../utils/introspection/ERC165.sol";
abstract contract ERC2981 is IERC2981, ERC165 {
struct RoyaltyInfo {
address receiver;
uint96 royaltyFraction;
}
RoyaltyInfo private _defaultRoyaltyInfo;
mapping(uint256 => RoyaltyInfo) private _tokenRoyaltyInfo;
function supportsInterface(bytes4 interfaceId) public view virtual override(IERC165, ERC165) returns (bool) {
return interfaceId == type(IERC2981).interfaceId || super.supportsInterface(interfaceId);
}
function royaltyInfo(uint256 tokenId, uint256 salePrice) public view virtual override returns (address, uint256) {
RoyaltyInfo memory royalty = _tokenRoyaltyInfo[tokenId];
if (royalty.receiver == address(0)) {
royalty = _defaultRoyaltyInfo;
}
uint256 royaltyAmount = (salePrice * royalty.royaltyFraction) / _feeDenominator();
return (royalty.receiver, royaltyAmount);
}
function _feeDenominator() internal pure virtual returns (uint96) {
return 10000;
}
function _setDefaultRoyalty(address receiver, uint96 feeNumerator) internal virtual {
require(feeNumerator <= _feeDenominator(), "ERC2981: royalty fee will exceed salePrice");
require(receiver != address(0), "ERC2981: invalid receiver");
_defaultRoyaltyInfo = RoyaltyInfo(receiver, feeNumerator);
}
function _deleteDefaultRoyalty() internal virtual {
delete _defaultRoyaltyInfo;
}
function _setTokenRoyalty(uint256 tokenId, address receiver, uint96 feeNumerator) internal virtual {
require(feeNumerator <= _feeDenominator(), "ERC2981: royalty fee will exceed salePrice");
require(receiver != address(0), "ERC2981: Invalid parameters");
_tokenRoyaltyInfo[tokenId] = RoyaltyInfo(receiver, feeNumerator);
}
function _resetTokenRoyalty(uint256 tokenId) internal virtual {
delete _tokenRoyaltyInfo[tokenId];
}
}
文件 5 的 19:ERC721.sol
pragma solidity ^0.8.0;
import "./IERC721.sol";
import "./IERC721Receiver.sol";
import "./extensions/IERC721Metadata.sol";
import "../../utils/Address.sol";
import "../../utils/Context.sol";
import "../../utils/Strings.sol";
import "../../utils/introspection/ERC165.sol";
contract ERC721 is Context, ERC165, IERC721, IERC721Metadata {
using Address for address;
using Strings for uint256;
string private _name;
string private _symbol;
mapping(uint256 => address) private _owners;
mapping(address => uint256) private _balances;
mapping(uint256 => address) private _tokenApprovals;
mapping(address => mapping(address => bool)) private _operatorApprovals;
constructor(string memory name_, string memory symbol_) {
_name = name_;
_symbol = symbol_;
}
function supportsInterface(bytes4 interfaceId) public view virtual override(ERC165, IERC165) returns (bool) {
return
interfaceId == type(IERC721).interfaceId ||
interfaceId == type(IERC721Metadata).interfaceId ||
super.supportsInterface(interfaceId);
}
function balanceOf(address owner) public view virtual override returns (uint256) {
require(owner != address(0), "ERC721: address zero is not a valid owner");
return _balances[owner];
}
function ownerOf(uint256 tokenId) public view virtual override returns (address) {
address owner = _ownerOf(tokenId);
require(owner != address(0), "ERC721: invalid token ID");
return owner;
}
function name() public view virtual override returns (string memory) {
return _name;
}
function symbol() public view virtual override returns (string memory) {
return _symbol;
}
function tokenURI(uint256 tokenId) public view virtual override returns (string memory) {
_requireMinted(tokenId);
string memory baseURI = _baseURI();
return bytes(baseURI).length > 0 ? string(abi.encodePacked(baseURI, tokenId.toString())) : "";
}
function _baseURI() internal view virtual returns (string memory) {
return "";
}
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 token owner or approved for all"
);
_approve(to, tokenId);
}
function getApproved(uint256 tokenId) public view virtual override returns (address) {
_requireMinted(tokenId);
return _tokenApprovals[tokenId];
}
function setApprovalForAll(address operator, bool approved) public virtual override {
_setApprovalForAll(_msgSender(), operator, approved);
}
function isApprovedForAll(address owner, address operator) public view virtual override returns (bool) {
return _operatorApprovals[owner][operator];
}
function transferFrom(address from, address to, uint256 tokenId) public virtual override {
require(_isApprovedOrOwner(_msgSender(), tokenId), "ERC721: caller is not token owner or approved");
_transfer(from, to, tokenId);
}
function safeTransferFrom(address from, address to, uint256 tokenId) public virtual override {
safeTransferFrom(from, to, tokenId, "");
}
function safeTransferFrom(address from, address to, uint256 tokenId, bytes memory data) public virtual override {
require(_isApprovedOrOwner(_msgSender(), tokenId), "ERC721: caller is not token owner or approved");
_safeTransfer(from, to, tokenId, data);
}
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");
}
function _ownerOf(uint256 tokenId) internal view virtual returns (address) {
return _owners[tokenId];
}
function _exists(uint256 tokenId) internal view virtual returns (bool) {
return _ownerOf(tokenId) != address(0);
}
function _isApprovedOrOwner(address spender, uint256 tokenId) internal view virtual returns (bool) {
address owner = ERC721.ownerOf(tokenId);
return (spender == owner || isApprovedForAll(owner, spender) || getApproved(tokenId) == spender);
}
function _safeMint(address to, uint256 tokenId) internal virtual {
_safeMint(to, tokenId, "");
}
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"
);
}
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, 1);
require(!_exists(tokenId), "ERC721: token already minted");
unchecked {
_balances[to] += 1;
}
_owners[tokenId] = to;
emit Transfer(address(0), to, tokenId);
_afterTokenTransfer(address(0), to, tokenId, 1);
}
function _burn(uint256 tokenId) internal virtual {
address owner = ERC721.ownerOf(tokenId);
_beforeTokenTransfer(owner, address(0), tokenId, 1);
owner = ERC721.ownerOf(tokenId);
delete _tokenApprovals[tokenId];
unchecked {
_balances[owner] -= 1;
}
delete _owners[tokenId];
emit Transfer(owner, address(0), tokenId);
_afterTokenTransfer(owner, address(0), tokenId, 1);
}
function _transfer(address from, address to, uint256 tokenId) internal virtual {
require(ERC721.ownerOf(tokenId) == from, "ERC721: transfer from incorrect owner");
require(to != address(0), "ERC721: transfer to the zero address");
_beforeTokenTransfer(from, to, tokenId, 1);
require(ERC721.ownerOf(tokenId) == from, "ERC721: transfer from incorrect owner");
delete _tokenApprovals[tokenId];
unchecked {
_balances[from] -= 1;
_balances[to] += 1;
}
_owners[tokenId] = to;
emit Transfer(from, to, tokenId);
_afterTokenTransfer(from, to, tokenId, 1);
}
function _approve(address to, uint256 tokenId) internal virtual {
_tokenApprovals[tokenId] = to;
emit Approval(ERC721.ownerOf(tokenId), to, tokenId);
}
function _setApprovalForAll(address owner, address operator, bool approved) internal virtual {
require(owner != operator, "ERC721: approve to caller");
_operatorApprovals[owner][operator] = approved;
emit ApprovalForAll(owner, operator, approved);
}
function _requireMinted(uint256 tokenId) internal view virtual {
require(_exists(tokenId), "ERC721: invalid token ID");
}
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;
}
}
function _beforeTokenTransfer(address from, address to, uint256 firstTokenId, uint256 batchSize) internal virtual {}
function _afterTokenTransfer(address from, address to, uint256 firstTokenId, uint256 batchSize) internal virtual {}
function __unsafe_increaseBalance(address account, uint256 amount) internal {
_balances[account] += amount;
}
}
文件 6 的 19:ERC721PermanentProof.sol
pragma solidity ^0.8.0;
import "lib/openzeppelin-contracts/contracts/token/ERC721/ERC721.sol";
abstract contract ERC721PermanentProof is ERC721 {
string private _permanentGlobalProof;
mapping(uint256 => string) private _permanentTokenProofs;
function tokenProofPermanent(uint256 tokenId) public view virtual returns (string memory) {
_requireMinted(tokenId);
string memory _tokenProof = _permanentTokenProofs[tokenId];
if (bytes(_tokenProof).length == 0) {
return _permanentGlobalProof;
}
return _tokenProof;
}
function _setPermanentGlobalProof(string memory _globalProof) internal virtual {
require(bytes(_permanentGlobalProof).length == 0, "ERC721PermanentProof: Proof already set");
_permanentGlobalProof = _globalProof;
}
function _setPermanentTokenProof(uint256 tokenId, string memory _tokenProof) internal virtual {
require(_exists(tokenId), "ERC721PermanentProof: Proof set of nonexistent token");
require(bytes(_permanentTokenProofs[tokenId]).length == 0, "ERC721PermanentProof: Proof already set");
_permanentTokenProofs[tokenId] = _tokenProof;
}
function _burn(uint256 tokenId) internal virtual override {
super._burn(tokenId);
if (bytes(_permanentTokenProofs[tokenId]).length != 0) {
delete _permanentTokenProofs[tokenId];
}
}
}
文件 7 的 19:ERC721PermanentURIs.sol
pragma solidity ^0.8.0;
import "lib/openzeppelin-contracts/contracts/token/ERC721/ERC721.sol";
abstract contract ERC721PermanentURIs is ERC721 {
using Strings for uint256;
string[] private _globalURIsPermanent;
mapping(uint256 => string[]) private _tokenURIsPermanent;
uint256 _baseURIsPermanentIndex = 0;
mapping(uint256 => string) private _prefixBaseURIsPermanent;
mapping(uint256 => string) private _suffixBaseURIsPermanent;
function tokenURIsPermanent(uint256 tokenId) public view virtual returns (string[] memory) {
_requireMinted(tokenId);
uint256 index = 0;
string[] memory uris = new string[](_globalURIsPermanent.length + _baseURIsPermanentIndex + _tokenURIsPermanent[tokenId].length);
for (uint256 i = 0; i < _globalURIsPermanent.length;) {
uris[index] = string(_globalURIsPermanent[i]);
unchecked {
index++;
i++;
}
}
for (uint256 i = 0; i < _baseURIsPermanentIndex;) {
uris[index] = string(abi.encodePacked(_prefixBaseURIsPermanent[i], tokenId.toString(), _suffixBaseURIsPermanent[i]));
unchecked {
index++;
i++;
}
}
for (uint256 i = 0; i < _tokenURIsPermanent[tokenId].length;) {
uris[index] = string(_tokenURIsPermanent[tokenId][i]);
unchecked {
index++;
i++;
}
}
return uris;
}
function _addPermanentBaseURI(string memory prefixURI_, string memory suffixURI_) internal virtual {
_prefixBaseURIsPermanent[_baseURIsPermanentIndex] = prefixURI_;
_suffixBaseURIsPermanent[_baseURIsPermanentIndex] = suffixURI_;
_baseURIsPermanentIndex++;
}
function _addPermanentTokenURI(uint256 tokenId, string memory tokenURI_) internal virtual {
require(_exists(tokenId), "ERC721PermanentURIs: PermanentURI set of nonexistent token");
_tokenURIsPermanent[tokenId].push(tokenURI_);
}
function _addPermanentGlobalURI(string memory tokenURI_) internal virtual {
_globalURIsPermanent.push(tokenURI_);
}
function _burn(uint256 tokenId) internal virtual override {
super._burn(tokenId);
if (_tokenURIsPermanent[tokenId].length != 0) {
delete _tokenURIsPermanent[tokenId];
}
}
}
文件 8 的 19:IERC165.sol
pragma solidity ^0.8.0;
interface IERC165 {
function supportsInterface(bytes4 interfaceId) external view returns (bool);
}
文件 9 的 19:IERC2981.sol
pragma solidity ^0.8.0;
import "../utils/introspection/IERC165.sol";
interface IERC2981 is IERC165 {
function royaltyInfo(
uint256 tokenId,
uint256 salePrice
) external view returns (address receiver, uint256 royaltyAmount);
}
文件 10 的 19:IERC721.sol
pragma solidity ^0.8.0;
import "../../utils/introspection/IERC165.sol";
interface IERC721 is IERC165 {
event Transfer(address indexed from, address indexed to, uint256 indexed tokenId);
event Approval(address indexed owner, address indexed approved, uint256 indexed tokenId);
event ApprovalForAll(address indexed owner, address indexed operator, bool approved);
function balanceOf(address owner) external view returns (uint256 balance);
function ownerOf(uint256 tokenId) external view returns (address owner);
function safeTransferFrom(address from, address to, uint256 tokenId, bytes calldata data) external;
function safeTransferFrom(address from, address to, uint256 tokenId) external;
function transferFrom(address from, address to, uint256 tokenId) external;
function approve(address to, uint256 tokenId) external;
function setApprovalForAll(address operator, bool approved) external;
function getApproved(uint256 tokenId) external view returns (address operator);
function isApprovedForAll(address owner, address operator) external view returns (bool);
}
文件 11 的 19:IERC721Metadata.sol
pragma solidity ^0.8.0;
import "../IERC721.sol";
interface IERC721Metadata is IERC721 {
function name() external view returns (string memory);
function symbol() external view returns (string memory);
function tokenURI(uint256 tokenId) external view returns (string memory);
}
文件 12 的 19:IERC721Receiver.sol
pragma solidity ^0.8.0;
interface IERC721Receiver {
function onERC721Received(
address operator,
address from,
uint256 tokenId,
bytes calldata data
) external returns (bytes4);
}
文件 13 的 19:IUNDOXXED.sol
pragma solidity ^0.8.19;
enum Status {
notInitialized,
allowlist,
whitelist,
publicMint,
finished,
paused,
privateWhitelist
}
error ZeroAddress();
error contractFreezed();
error onlyApprovedPaymentAddress();
error maxSupplyToken1Reach();
error maxSupplyToken2Reach();
error invalidAmountSend();
error maxMintWalletReachToken1();
error maxMintWalletReachToken2();
error invalidSaleStatus();
error PublicSaleNotStarted();
error invalidSignature();
error exceedAllowedToken1Mint();
error exceedAllowedToken2Mint();
error failWhithdraw();
error whithdrawZeroValue();
error privateWhitelistToken1SoldOut();
error privateWhitelistToken2SoldOut();
error NoReserveToken1();
error NoReserveToken2();
error noSupplyAvailableToken1();
error noSupplyAvailableToken2();
error AmountCanNotBeLowerThanCurrent(uint256);
error WihdrawToZeroAddress();
error MaxSupplyCanNotBeMoreThan500();
error MaxSupplyCanNotbeOdd();
error MaxSupplyCanNotBeLowerThanActual();
error FeeExceed10Percent();
error PercentCanNotBeMoreThan100Percent();
error SupplySealed();
文件 14 的 19:Math.sol
pragma solidity ^0.8.0;
library Math {
enum Rounding {
Down,
Up,
Zero
}
function max(uint256 a, uint256 b) internal pure returns (uint256) {
return a > b ? a : b;
}
function min(uint256 a, uint256 b) internal pure returns (uint256) {
return a < b ? a : b;
}
function average(uint256 a, uint256 b) internal pure returns (uint256) {
return (a & b) + (a ^ b) / 2;
}
function ceilDiv(uint256 a, uint256 b) internal pure returns (uint256) {
return a == 0 ? 0 : (a - 1) / b + 1;
}
function mulDiv(uint256 x, uint256 y, uint256 denominator) internal pure returns (uint256 result) {
unchecked {
uint256 prod0;
uint256 prod1;
assembly {
let mm := mulmod(x, y, not(0))
prod0 := mul(x, y)
prod1 := sub(sub(mm, prod0), lt(mm, prod0))
}
if (prod1 == 0) {
return prod0 / denominator;
}
require(denominator > prod1, "Math: mulDiv overflow");
uint256 remainder;
assembly {
remainder := mulmod(x, y, denominator)
prod1 := sub(prod1, gt(remainder, prod0))
prod0 := sub(prod0, remainder)
}
uint256 twos = denominator & (~denominator + 1);
assembly {
denominator := div(denominator, twos)
prod0 := div(prod0, twos)
twos := add(div(sub(0, twos), twos), 1)
}
prod0 |= prod1 * twos;
uint256 inverse = (3 * denominator) ^ 2;
inverse *= 2 - denominator * inverse;
inverse *= 2 - denominator * inverse;
inverse *= 2 - denominator * inverse;
inverse *= 2 - denominator * inverse;
inverse *= 2 - denominator * inverse;
inverse *= 2 - denominator * inverse;
result = prod0 * inverse;
return result;
}
}
function mulDiv(uint256 x, uint256 y, uint256 denominator, Rounding rounding) internal pure returns (uint256) {
uint256 result = mulDiv(x, y, denominator);
if (rounding == Rounding.Up && mulmod(x, y, denominator) > 0) {
result += 1;
}
return result;
}
function sqrt(uint256 a) internal pure returns (uint256) {
if (a == 0) {
return 0;
}
uint256 result = 1 << (log2(a) >> 1);
unchecked {
result = (result + a / result) >> 1;
result = (result + a / result) >> 1;
result = (result + a / result) >> 1;
result = (result + a / result) >> 1;
result = (result + a / result) >> 1;
result = (result + a / result) >> 1;
result = (result + a / result) >> 1;
return min(result, a / result);
}
}
function sqrt(uint256 a, Rounding rounding) internal pure returns (uint256) {
unchecked {
uint256 result = sqrt(a);
return result + (rounding == Rounding.Up && result * result < a ? 1 : 0);
}
}
function log2(uint256 value) internal pure returns (uint256) {
uint256 result = 0;
unchecked {
if (value >> 128 > 0) {
value >>= 128;
result += 128;
}
if (value >> 64 > 0) {
value >>= 64;
result += 64;
}
if (value >> 32 > 0) {
value >>= 32;
result += 32;
}
if (value >> 16 > 0) {
value >>= 16;
result += 16;
}
if (value >> 8 > 0) {
value >>= 8;
result += 8;
}
if (value >> 4 > 0) {
value >>= 4;
result += 4;
}
if (value >> 2 > 0) {
value >>= 2;
result += 2;
}
if (value >> 1 > 0) {
result += 1;
}
}
return result;
}
function log2(uint256 value, Rounding rounding) internal pure returns (uint256) {
unchecked {
uint256 result = log2(value);
return result + (rounding == Rounding.Up && 1 << result < value ? 1 : 0);
}
}
function log10(uint256 value) internal pure returns (uint256) {
uint256 result = 0;
unchecked {
if (value >= 10 ** 64) {
value /= 10 ** 64;
result += 64;
}
if (value >= 10 ** 32) {
value /= 10 ** 32;
result += 32;
}
if (value >= 10 ** 16) {
value /= 10 ** 16;
result += 16;
}
if (value >= 10 ** 8) {
value /= 10 ** 8;
result += 8;
}
if (value >= 10 ** 4) {
value /= 10 ** 4;
result += 4;
}
if (value >= 10 ** 2) {
value /= 10 ** 2;
result += 2;
}
if (value >= 10 ** 1) {
result += 1;
}
}
return result;
}
function log10(uint256 value, Rounding rounding) internal pure returns (uint256) {
unchecked {
uint256 result = log10(value);
return result + (rounding == Rounding.Up && 10 ** result < value ? 1 : 0);
}
}
function log256(uint256 value) internal pure returns (uint256) {
uint256 result = 0;
unchecked {
if (value >> 128 > 0) {
value >>= 128;
result += 16;
}
if (value >> 64 > 0) {
value >>= 64;
result += 8;
}
if (value >> 32 > 0) {
value >>= 32;
result += 4;
}
if (value >> 16 > 0) {
value >>= 16;
result += 2;
}
if (value >> 8 > 0) {
result += 1;
}
}
return result;
}
function log256(uint256 value, Rounding rounding) internal pure returns (uint256) {
unchecked {
uint256 result = log256(value);
return result + (rounding == Rounding.Up && 1 << (result << 3) < value ? 1 : 0);
}
}
}
文件 15 的 19:Ownable.sol
pragma solidity ^0.8.0;
import "../utils/Context.sol";
abstract contract Ownable is Context {
address private _owner;
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
constructor() {
_transferOwnership(_msgSender());
}
modifier onlyOwner() {
_checkOwner();
_;
}
function owner() public view virtual returns (address) {
return _owner;
}
function _checkOwner() internal view virtual {
require(owner() == _msgSender(), "Ownable: caller is not the owner");
}
function renounceOwnership() public virtual onlyOwner {
_transferOwnership(address(0));
}
function transferOwnership(address newOwner) public virtual onlyOwner {
require(newOwner != address(0), "Ownable: new owner is the zero address");
_transferOwnership(newOwner);
}
function _transferOwnership(address newOwner) internal virtual {
address oldOwner = _owner;
_owner = newOwner;
emit OwnershipTransferred(oldOwner, newOwner);
}
}
文件 16 的 19:SignedMath.sol
pragma solidity ^0.8.0;
library SignedMath {
function max(int256 a, int256 b) internal pure returns (int256) {
return a > b ? a : b;
}
function min(int256 a, int256 b) internal pure returns (int256) {
return a < b ? a : b;
}
function average(int256 a, int256 b) internal pure returns (int256) {
int256 x = (a & b) + ((a ^ b) >> 1);
return x + (int256(uint256(x) >> 255) & (a ^ b));
}
function abs(int256 n) internal pure returns (uint256) {
unchecked {
return uint256(n >= 0 ? n : -n);
}
}
}
文件 17 的 19:Strings.sol
pragma solidity ^0.8.0;
import "./math/Math.sol";
import "./math/SignedMath.sol";
library Strings {
bytes16 private constant _SYMBOLS = "0123456789abcdef";
uint8 private constant _ADDRESS_LENGTH = 20;
function toString(uint256 value) internal pure returns (string memory) {
unchecked {
uint256 length = Math.log10(value) + 1;
string memory buffer = new string(length);
uint256 ptr;
assembly {
ptr := add(buffer, add(32, length))
}
while (true) {
ptr--;
assembly {
mstore8(ptr, byte(mod(value, 10), _SYMBOLS))
}
value /= 10;
if (value == 0) break;
}
return buffer;
}
}
function toString(int256 value) internal pure returns (string memory) {
return string(abi.encodePacked(value < 0 ? "-" : "", toString(SignedMath.abs(value))));
}
function toHexString(uint256 value) internal pure returns (string memory) {
unchecked {
return toHexString(value, Math.log256(value) + 1);
}
}
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] = _SYMBOLS[value & 0xf];
value >>= 4;
}
require(value == 0, "Strings: hex length insufficient");
return string(buffer);
}
function toHexString(address addr) internal pure returns (string memory) {
return toHexString(uint256(uint160(addr)), _ADDRESS_LENGTH);
}
function equal(string memory a, string memory b) internal pure returns (bool) {
return keccak256(bytes(a)) == keccak256(bytes(b));
}
}
文件 18 的 19:UNDOXXED.sol
pragma solidity ^0.8.19;
import {Ownable} from "lib/openzeppelin-contracts/contracts/access/Ownable.sol";
import {ERC2981} from "lib/openzeppelin-contracts/contracts/token/common/ERC2981.sol";
import {ERC721} from "lib/openzeppelin-contracts/contracts/token/ERC721/ERC721.sol";
import {ERC721PermanentURIs} from "lib/opengem-contracts/token/ERC721/extensions/ERC721PermanentURIs.sol";
import {ERC721PermanentProof} from "lib/opengem-contracts/token/ERC721/extensions/ERC721PermanentProof.sol";
import "./IUNDOXXED.sol";
import "./verification/Verification.sol";
contract UNDOXXEDBOOK24 is ERC721, Ownable, ERC2981, ERC721PermanentProof {
string private cover1URI = "ipfs://Qmbo6MEp788EKWf3YGRkRxDVrbEL1L3Zj4c2C4W2EGDXnU";
string private cover2URI = "ipfs://QmPojiTQyZk7cpJ3LvbHroJJNptoX45ZLj1r5RUeWqdSyX";
string private baseMediaURICover = "ipfs://QmXSwaTSgMaiER1zKM6mdjjAD6YMXeEgQBBBFhd4vvtCVk";
string private baseMediaURICoverArweave = "ar://-bk2F28vmvghWo90grBHKbC12ATIjgKG3NL0G2t0G1c";
string private tokenProof1 = "8d39748984ce311a99f51fec1295f4e6c2c432e38617001e879a066150bb4f1c";
string private tokenProof2 = "003d43ec4ff0e42e297825e3c1ee0838a6191b44dfb3cb5aa11cb5653fc1dc9d";
uint256 private maxSupply = 300;
uint256 private token1 = 0;
uint256 private token2 = 0;
uint256 private whitelistPrice = 0.074 ether;
uint256 private publicPrice = 0.091 ether;
uint256 public cover1Reserved = 40;
uint256 public cover2Reserved = 35;
uint256 private withdrawPercent = 6000;
address private signer = 0x90D41fA17a8dF96E7dff80227b4FC7d208dFd026;
address[2] private fundsReceivers;
bool public isPublic;
bool public supplySealed;
mapping(bytes => uint256) private signatureCheckToken1;
mapping(bytes => uint256) private signatureCheckToken2;
modifier verify(
address _to,
uint256 _amount1,
uint256 _amount2,
Status _status,
bytes memory _sign
) {
if (!Verification.verifySignature(signer, _to, _amount1, _amount2, _status, _sign))
revert invalidSignature();
_;
}
constructor () ERC721("UNDOXXED BOOK Vol.1", "UNDXX24") {
fundsReceivers = [msg.sender, 0x19C013b64b7B2c7DaA59b96514662B687665E852];
_setDefaultRoyalty(msg.sender, 300);
}
function allowlistMint(
uint256 _amount1,
uint256 _amount2,
uint256 _amount1Sign,
uint256 _amount2Sign,
bytes memory _sign
)
external
verify(msg.sender, _amount1Sign, _amount2Sign, Status.allowlist, _sign)
{
address receiver = msg.sender;
uint256 maxTokenSupply = getMaxSupplyCover();
if (_amount1 + signatureCheckToken1[_sign] > _amount1Sign) revert exceedAllowedToken1Mint();
if (_amount2 + signatureCheckToken2[_sign] > _amount2Sign) revert exceedAllowedToken2Mint();
if (token1 + _amount1 > maxTokenSupply) revert maxSupplyToken1Reach();
if (token2 + _amount2 > maxTokenSupply) revert maxSupplyToken2Reach();
if (_amount1 > cover1Reserved) revert NoReserveToken1();
if (_amount2 > cover2Reserved) revert NoReserveToken2();
unchecked {
signatureCheckToken1[_sign] += _amount1;
signatureCheckToken2[_sign] += _amount2;
}
cover1Reserved -= _amount1;
cover2Reserved -= _amount2;
_mintToken1(receiver, _amount1);
_mintToken2(receiver, _amount2);
}
function whitelistMint(
uint256 _amount1,
uint256 _amount2,
uint256 _amount1Sign,
uint256 _amount2Sign,
bytes memory _sign
)
external
payable
verify(msg.sender, _amount1Sign, _amount2Sign, Status.whitelist, _sign)
{
address receiver = msg.sender;
uint256 maxTokenSupply = getMaxSupplyCover();
if (_amount1 + signatureCheckToken1[_sign] > _amount1Sign) revert exceedAllowedToken1Mint();
if (_amount2 + signatureCheckToken2[_sign] > _amount2Sign) revert exceedAllowedToken2Mint();
if (token1 + _amount1 + cover1Reserved > maxTokenSupply) revert maxSupplyToken1Reach();
if (token2 + _amount2 + cover2Reserved > maxTokenSupply) revert maxSupplyToken2Reach();
unchecked {
if ((_amount1 + _amount2) * whitelistPrice > msg.value) revert invalidAmountSend();
}
unchecked {
signatureCheckToken1[_sign] += _amount1;
signatureCheckToken2[_sign] += _amount2;
}
_mintToken1(receiver, _amount1);
_mintToken2(receiver, _amount2);
}
function privateWhitelistMint(
uint256 _amount1,
uint256 _amount2,
uint256 _amount1Sign,
uint256 _amount2Sign,
bytes memory _sign
)
external
payable
verify(msg.sender, _amount1Sign, _amount2Sign, Status.privateWhitelist, _sign)
{
address receiver = msg.sender;
uint256 maxTokenSupply = getMaxSupplyCover();
if (_amount1 + signatureCheckToken1[_sign] > _amount1Sign) revert exceedAllowedToken1Mint();
if (_amount2 + signatureCheckToken2[_sign] > _amount2Sign) revert exceedAllowedToken2Mint();
if (token1 + _amount1 > maxTokenSupply) revert maxSupplyToken1Reach();
if (token2 + _amount2 > maxTokenSupply) revert maxSupplyToken2Reach();
if (_amount1 > cover1Reserved) revert NoReserveToken1();
if (_amount2 > cover2Reserved) revert NoReserveToken2();
unchecked {
if ((_amount1 + _amount2) * whitelistPrice > msg.value) revert invalidAmountSend();
}
unchecked {
signatureCheckToken1[_sign] += _amount1;
signatureCheckToken2[_sign] += _amount2;
}
cover1Reserved -= _amount1;
cover2Reserved -= _amount2;
_mintToken1(receiver, _amount1);
_mintToken2(receiver, _amount2);
}
function mint(uint256 _amount1, uint256 _amount2)
external
payable
{
address receiver = msg.sender;
uint256 maxTokenSupply = getMaxSupplyCover();
if (!isPublic) revert PublicSaleNotStarted();
if (token1 + _amount1 + cover1Reserved > maxTokenSupply) revert maxSupplyToken1Reach();
if (token2 + _amount2 + cover2Reserved > maxTokenSupply) revert maxSupplyToken2Reach();
unchecked {
if ((_amount1 + _amount2) * publicPrice > msg.value) revert invalidAmountSend();
}
_mintToken1(receiver, _amount1);
_mintToken2(receiver, _amount2);
}
function withdraw() external onlyOwner {
if (fundsReceivers[0] == address(0) || fundsReceivers[1] == address(0)) revert WihdrawToZeroAddress();
uint256 totalValue = address(this).balance;
if (totalValue == 0) revert whithdrawZeroValue();
uint256 firstValue = totalValue * withdrawPercent / 10000;
(bool success, ) = address(fundsReceivers[0]).call{value: firstValue}("");
if (!success) revert failWhithdraw();
(success, ) = address(fundsReceivers[1]).call{value: totalValue - firstValue}("");
if (!success) revert failWhithdraw();
}
function emergencyWithdraw() external onlyOwner {
(bool success, ) = address(msg.sender).call{value: address(this).balance}("");
if (!success) revert failWhithdraw();
}
function setMaxSupply(uint256 _newMaxSupply) external onlyOwner {
if (_newMaxSupply > 500) revert MaxSupplyCanNotBeMoreThan500();
if (_newMaxSupply % 2 == 1) revert MaxSupplyCanNotbeOdd();
if (_newMaxSupply < getAllSupply() + getTotalReservedCover()) revert MaxSupplyCanNotBeLowerThanActual();
if (supplySealed) revert SupplySealed();
maxSupply = _newMaxSupply;
}
function setPublic(bool _public) external onlyOwner {
isPublic = _public;
}
function setSigner(address _newSigner) external onlyOwner {
signer = _newSigner;
}
function setWhitelistPrice(uint256 _newWhitelistPrice) external onlyOwner {
whitelistPrice = _newWhitelistPrice;
}
function setPublicPrice(uint256 _newPublicPrice) external onlyOwner {
publicPrice = _newPublicPrice;
}
function setReserveToken1(uint256 _amountToken1) external onlyOwner {
if (token1 + _amountToken1 > getMaxSupplyCover()) revert noSupplyAvailableToken1();
cover1Reserved = _amountToken1;
}
function setReserveToken2(uint256 _amountToken2) external onlyOwner {
if (token2 + _amountToken2 > getMaxSupplyCover()) revert noSupplyAvailableToken2();
cover2Reserved = _amountToken2;
}
function setDefaultRoyalties(address _recipient, uint96 _feeNumerator) external onlyOwner {
if (_feeNumerator > 1000) revert FeeExceed10Percent();
_setDefaultRoyalty(_recipient, _feeNumerator);
}
function setFundsReceivers(address _firstReceiver, address _secondReceiver) external onlyOwner {
if (_firstReceiver == address(0) || _secondReceiver == address(0)) revert ZeroAddress();
fundsReceivers[0] = _firstReceiver;
fundsReceivers[1] = _secondReceiver;
}
function setPercentReceiver(uint256 _percent) external onlyOwner {
if (_percent > 10000) revert PercentCanNotBeMoreThan100Percent();
withdrawPercent = _percent;
}
function sealSupply() external onlyOwner {
maxSupply = getAllSupply();
supplySealed = true;
}
function getMaxSupply() external view returns (uint256) {
return maxSupply;
}
function getMaxSupplyCover() public view returns (uint256) {
return maxSupply / 2;
}
function getToken1Supply() external view returns (uint256) {
return token1;
}
function getToken2Supply() external view returns (uint256) {
return token2;
}
function getAllSupply() public view returns (uint256) {
return token1 + token2;
}
function getWhitelistPrice() external view returns (uint256) {
return whitelistPrice;
}
function getPublicPrice() external view returns (uint256) {
return publicPrice;
}
function getBalanceMintBySign(bytes memory _sign) external view returns (uint256 cover1, uint256 cover2) {
cover1 = signatureCheckToken1[_sign];
cover2 = signatureCheckToken2[_sign];
}
function getTotalReservedCover() public view returns (uint256) {
return cover1Reserved + cover2Reserved;
}
function getDescription() external pure returns (string memory) {
return "UNDOXXED, the finest in digital lifestyle culture, is an annual hybrid book that merges street and lifestyle culture with the digital world. It focuses on fashion, sneakers, and streetwear, cataloging the best of phygital culture. This publication bridges the physical and digital realms within the evolving Web3 space. 3D by Ryan Owers, Art Direction and Music by XERAK.";
}
function getTokenName(uint256 _tokenId) external view returns (string memory) {
if (keccak256(bytes(tokenProofPermanent(_tokenId))) == keccak256(bytes(tokenProof1))) {
return string("UNDOXXED BOOK vol.1 Black");
}
return string("UNDOXXED BOOK vol.1 Purple");
}
function getTokenMediaPermanent() external view returns (string[2] memory) {
return [baseMediaURICover, baseMediaURICoverArweave];
}
function getMediaProofPermanent() external pure returns (string memory) {
return "ab57c888aa9d13029b64f563ec18941eca5054ad002a35fffd4a68022975dc45";
}
function supportsInterface(bytes4 interfaceId)
public
view
virtual
override(ERC2981, ERC721)
returns(bool)
{
return super.supportsInterface(interfaceId);
}
function tokenURI(uint256 tokenId) public view virtual override returns (string memory) {
if (!_exists(tokenId)) return "";
if (keccak256(bytes(tokenProofPermanent(tokenId))) == keccak256(bytes(tokenProof1))) {
return cover1URI;
}
return cover2URI;
}
function _burn(uint256 tokenId) internal override(ERC721, ERC721PermanentProof) {
super._burn(tokenId);
}
function _mintToken1(address _to, uint256 _amount) internal {
unchecked {
for (uint256 i = 0; i < _amount; ++i) {
uint256 nextId = getAllSupply() + 1;
_mint(_to, nextId);
_setPermanentTokenProof(nextId, tokenProof1);
++token1;
}
}
}
function _mintToken2(address _to, uint256 _amount) internal {
unchecked {
for (uint256 i = 0; i < _amount; ++i) {
uint256 nextId = getAllSupply() + 1;
_mint(_to, nextId);
_setPermanentTokenProof(nextId, tokenProof2);
++token2;
}
}
}
}
文件 19 的 19:Verification.sol
pragma solidity ^0.8.19;
import { Status } from "../IUNDOXXED.sol";
library Verification {
function getMessageHash(address _to, uint256 _amount1, uint256 _amount2, Status _status) internal pure returns (bytes32) {
return keccak256(
abi.encodePacked(
_to,
_amount1,
_amount2,
_status
)
);
}
function verifySignature(
address _signer,
address _to,
uint256 _amount1,
uint256 _amount2,
Status _status,
bytes memory _signature
)
internal
pure
returns (bool)
{
bytes32 messageHash = getMessageHash(_to, _amount1, _amount2, _status);
bytes32 ethSignedMessageHash = getEthSignedMessageHash(messageHash);
return recoverSigner(ethSignedMessageHash, _signature) == _signer;
}
function getEthSignedMessageHash(
bytes32 _messageHash
) internal pure returns (bytes32) {
return keccak256(
abi.encodePacked("\x19Ethereum Signed Message:\n32", _messageHash)
);
}
function recoverSigner(
bytes32 _ethSignedMessageHash,
bytes memory _signature
) public pure returns (address) {
(bytes32 r, bytes32 s, uint8 v) = splitSignature(_signature);
return ecrecover(_ethSignedMessageHash, v, r, s);
}
function splitSignature(
bytes memory _sig
) public pure returns (bytes32 r, bytes32 s, uint8 v) {
require(_sig.length == 65, "invalid signature length");
assembly {
r := mload(add(_sig, 32))
s := mload(add(_sig, 64))
v := byte(0, mload(add(_sig, 96)))
}
}
}
{
"compilationTarget": {
"src/ERC721/UNDOXXED.sol": "UNDOXXEDBOOK24"
},
"evmVersion": "paris",
"libraries": {},
"metadata": {
"bytecodeHash": "ipfs"
},
"optimizer": {
"enabled": true,
"runs": 200
},
"remappings": [
":Assembly/=lib/Assembly/",
":ds-test/=lib/forge-std/lib/ds-test/src/",
":erc4626-tests/=lib/openzeppelin-contracts/lib/erc4626-tests/",
":forge-std/=lib/forge-std/src/",
":opengem-contracts/=lib/opengem-contracts/",
":openzeppelin-contracts/=lib/openzeppelin-contracts/",
":openzeppelin/=lib/openzeppelin-contracts/contracts/"
]
}
[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[],"name":"FeeExceed10Percent","type":"error"},{"inputs":[],"name":"MaxSupplyCanNotBeLowerThanActual","type":"error"},{"inputs":[],"name":"MaxSupplyCanNotBeMoreThan500","type":"error"},{"inputs":[],"name":"MaxSupplyCanNotbeOdd","type":"error"},{"inputs":[],"name":"NoReserveToken1","type":"error"},{"inputs":[],"name":"NoReserveToken2","type":"error"},{"inputs":[],"name":"PercentCanNotBeMoreThan100Percent","type":"error"},{"inputs":[],"name":"PublicSaleNotStarted","type":"error"},{"inputs":[],"name":"SupplySealed","type":"error"},{"inputs":[],"name":"WihdrawToZeroAddress","type":"error"},{"inputs":[],"name":"ZeroAddress","type":"error"},{"inputs":[],"name":"exceedAllowedToken1Mint","type":"error"},{"inputs":[],"name":"exceedAllowedToken2Mint","type":"error"},{"inputs":[],"name":"failWhithdraw","type":"error"},{"inputs":[],"name":"invalidAmountSend","type":"error"},{"inputs":[],"name":"invalidSignature","type":"error"},{"inputs":[],"name":"maxSupplyToken1Reach","type":"error"},{"inputs":[],"name":"maxSupplyToken2Reach","type":"error"},{"inputs":[],"name":"noSupplyAvailableToken1","type":"error"},{"inputs":[],"name":"noSupplyAvailableToken2","type":"error"},{"inputs":[],"name":"whithdrawZeroValue","type":"error"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"approved","type":"address"},{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"operator","type":"address"},{"indexed":false,"internalType":"bool","name":"approved","type":"bool"}],"name":"ApprovalForAll","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[{"internalType":"uint256","name":"_amount1","type":"uint256"},{"internalType":"uint256","name":"_amount2","type":"uint256"},{"internalType":"uint256","name":"_amount1Sign","type":"uint256"},{"internalType":"uint256","name":"_amount2Sign","type":"uint256"},{"internalType":"bytes","name":"_sign","type":"bytes"}],"name":"allowlistMint","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"approve","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"cover1Reserved","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"cover2Reserved","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"emergencyWithdraw","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"getAllSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"getApproved","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes","name":"_sign","type":"bytes"}],"name":"getBalanceMintBySign","outputs":[{"internalType":"uint256","name":"cover1","type":"uint256"},{"internalType":"uint256","name":"cover2","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getDescription","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"getMaxSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getMaxSupplyCover","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getMediaProofPermanent","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"getPublicPrice","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getToken1Supply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getToken2Supply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getTokenMediaPermanent","outputs":[{"internalType":"string[2]","name":"","type":"string[2]"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_tokenId","type":"uint256"}],"name":"getTokenName","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getTotalReservedCover","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getWhitelistPrice","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":"isPublic","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount1","type":"uint256"},{"internalType":"uint256","name":"_amount2","type":"uint256"}],"name":"mint","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"ownerOf","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount1","type":"uint256"},{"internalType":"uint256","name":"_amount2","type":"uint256"},{"internalType":"uint256","name":"_amount1Sign","type":"uint256"},{"internalType":"uint256","name":"_amount2Sign","type":"uint256"},{"internalType":"bytes","name":"_sign","type":"bytes"}],"name":"privateWhitelistMint","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"uint256","name":"salePrice","type":"uint256"}],"name":"royaltyInfo","outputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"safeTransferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"bytes","name":"data","type":"bytes"}],"name":"safeTransferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"sealSupply","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":"address","name":"_recipient","type":"address"},{"internalType":"uint96","name":"_feeNumerator","type":"uint96"}],"name":"setDefaultRoyalties","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_firstReceiver","type":"address"},{"internalType":"address","name":"_secondReceiver","type":"address"}],"name":"setFundsReceivers","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_newMaxSupply","type":"uint256"}],"name":"setMaxSupply","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_percent","type":"uint256"}],"name":"setPercentReceiver","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_public","type":"bool"}],"name":"setPublic","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_newPublicPrice","type":"uint256"}],"name":"setPublicPrice","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amountToken1","type":"uint256"}],"name":"setReserveToken1","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amountToken2","type":"uint256"}],"name":"setReserveToken2","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_newSigner","type":"address"}],"name":"setSigner","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_newWhitelistPrice","type":"uint256"}],"name":"setWhitelistPrice","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"supplySealed","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes4","name":"interfaceId","type":"bytes4"}],"name":"supportsInterface","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"tokenProofPermanent","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":[{"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":"uint256","name":"_amount1","type":"uint256"},{"internalType":"uint256","name":"_amount2","type":"uint256"},{"internalType":"uint256","name":"_amount1Sign","type":"uint256"},{"internalType":"uint256","name":"_amount2Sign","type":"uint256"},{"internalType":"bytes","name":"_sign","type":"bytes"}],"name":"whitelistMint","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"withdraw","outputs":[],"stateMutability":"nonpayable","type":"function"}]