编译器
0.8.21+commit.d9974bed
文件 1 的 23:Context.sol
pragma solidity ^0.8.20;
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
function _msgData() internal view virtual returns (bytes calldata) {
return msg.data;
}
function _contextSuffixLength() internal view virtual returns (uint256) {
return 0;
}
}
文件 2 的 23:DistributorBase.sol
pragma solidity ^0.8.13;
import { IDistributorBase } from "./interfaces/IDistributorBase.sol";
import {ECDSA} from "@openzeppelin/contracts/utils/cryptography/ECDSA.sol";
import { EIP712 } from '@openzeppelin/contracts/utils/cryptography/EIP712.sol';
import { Nonces } from '@openzeppelin/contracts/utils/Nonces.sol';
contract DistributorBase is IDistributorBase, EIP712, Nonces {
constructor(string memory name) EIP712(name, '1') {}
function _checkSignature(bytes32 typeHash, address owner, address user, uint256 deadline, uint8 v, bytes32 r, bytes32 s) internal {
if (block.timestamp > deadline) {
revert ExpiredSignature(address(this), deadline);
}
bytes32 structHash = keccak256(abi.encode(typeHash, user, _useNonce(user), deadline));
bytes32 hash = _hashTypedDataV4(structHash);
address signer = ECDSA.recover(hash, v, r, s);
if(signer != owner) {
revert InvalidSigner(address(this), signer, owner);
}
}
function nonces(address owner) public view virtual override(IDistributorBase, Nonces) returns(uint256) {
return super.nonces(owner);
}
function DOMAIN_SEPARATOR() public view virtual override returns(bytes32) {
return _domainSeparatorV4();
}
}
文件 3 的 23:DragonDistributor.sol
pragma solidity ^0.8.13;
import { IDragonDistributor } from './interfaces/IDragonDistributor.sol';
import { IDragonOG } from './interfaces/IDragonOG.sol';
import { DistributorBase } from './DistributorBase.sol';
import { SimpleInitializable } from './SimpleInitializable.sol';
import { IWETH} from './interfaces/IWETH.sol';
import { IERC721Metadata } from '@openzeppelin/contracts/token/ERC721/extensions/IERC721Metadata.sol';
import { Ownable, Ownable2Step } from '@openzeppelin/contracts/access/Ownable2Step.sol';
import { Math } from '@openzeppelin/contracts/utils/math/Math.sol';
contract DragonDistributor is IDragonDistributor, SimpleInitializable, Ownable2Step, DistributorBase{
bytes32 private constant MINT_A_TYPEHASH =
keccak256('MintA(address user,uint256 nonce,uint256 deadline)');
bytes32 private constant MINT_B_TYPEHASH =
keccak256('MintB(address user,uint256 nonce,uint256 deadline)');
bytes32 private constant PUBLIC_MINT_TYPEHASH =
keccak256('PublicMint(address user,uint256 nonce,uint256 deadline)');
uint256 private constant B_PRICE = 15 ether / 1000;
uint256 private constant PUBLIC_PRICE = 50 ether / 1000;
uint256 private constant MAX_PUBLIC_SUPPLY = 800;
uint256 private constant MAX_A_SUPPLY = 1500;
uint256 private constant MAX_B_SUPPLY = 1500;
address private _dragon;
address private _weth;
uint256 private _startTimeA;
uint256 private _startTimeB;
uint256 private _startTimePublic;
uint256 private _endTimeA;
uint256 private _endTimeB;
uint256 private _endTimePublic;
uint256 private _remainingPublicSupply = MAX_PUBLIC_SUPPLY;
uint256 private _remainingASupply = MAX_A_SUPPLY;
uint256 private _remainingBSupply = MAX_B_SUPPLY;
mapping(address => uint256) private _whiteListA;
mapping(address => uint256) private _whiteListB;
mapping(address => uint256) private _mintedA;
mapping(address => uint256) private _mintedB;
mapping(address => bool) private _mintedPublic;
constructor(address dragonAddress, address wethAddress) Ownable(msg.sender)
DistributorBase(IERC721Metadata(dragonAddress).name()) {
if(dragonAddress == address(0)) {
revert ZeroNFTAddress(address(this));
}
if(wethAddress == address(0)) {
revert ZeroWETHAddress(address(this));
}
_dragon = dragonAddress;
_weth = wethAddress;
}
function initialize(uint256 startA, uint256 endA, uint256 startB, uint256 endB, uint256 startPublic, uint256 endPublic) public onlyOwner initializer {
_startTimeA = startA;
_endTimeA = endA;
_startTimeB = startB;
_endTimeB = endB;
_startTimePublic = startPublic;
_endTimePublic = endPublic;
Ownable2Step(_dragon).acceptOwnership();
emit Initialize(_dragon, _startTimeA, _endTimeA, _startTimeB, _endTimeB, _startTimePublic, _endTimePublic);
}
function setStartTimeA(uint256 start) public onlyOwner {
_startTimeA = start;
emit StartTimeAChanged(_startTimeA);
}
function setEndTimeA(uint256 end) public onlyOwner {
_endTimeA = end;
emit EndTimeAChanged(_endTimeA);
}
function setStartTimeB(uint256 start) public onlyOwner {
_startTimeB = start;
emit StartTimeBChanged(_startTimeB);
}
function setEndTimeB(uint256 end) public onlyOwner {
_endTimeB = end;
emit EndTimeBChanged(_endTimeB);
}
function setStartTimePublic(uint256 start) public onlyOwner {
_startTimePublic = start;
emit StartTimePublicChanged(_startTimePublic);
}
function setEndTimePublic(uint256 end) public onlyOwner {
_endTimePublic = end;
emit EndTimePublicChanged(_endTimePublic);
}
function setWhiteListABatch(address [] memory users, uint256 [] memory counts) public onlyOwner {
if(users.length != counts.length) {
revert LengthNotMatch(address(this), users.length, counts.length);
}
for(uint256 i = 0; i < users.length; ++i) {
_whiteListA[users[i]] = counts[i];
if(counts[i] > 0){
emit WhiteListAAdded(users[i], counts[i]);
}
else{
emit WhiteListARemoved(users[i]);
}
}
}
function setWhiteListBBatch(address [] memory users, uint256[] memory counts) public onlyOwner {
if(users.length != counts.length) {
revert LengthNotMatch(address(this), users.length, counts.length);
}
for(uint256 i = 0; i < users.length; ++i) {
_whiteListB[users[i]] = counts[i];
if(counts[i] > 0){
emit WhiteListBAdded(users[i], counts[i]);
}
else{
emit WhiteListBRemoved(users[i]);
}
}
}
function mintA(address user, uint256 deadline, uint8 v, bytes32 r, bytes32 s) public override {
if(block.timestamp < _startTimeA) {
revert NotStartedYet(address(this), _startTimeA);
}
if(block.timestamp > _endTimeA) {
revert AlreadyEnded(address(this), _endTimeA);
}
if(_remainingASupply == 0) {
revert NoMoreMintA(address(this));
}
_checkSignature(MINT_A_TYPEHASH, owner(), user, deadline, v, r, s);
if(_whiteListA[user] == 0) {
revert NotInWhiteListA(address(this), user);
}
if(_mintedA[user] >= _whiteListA[user]) {
revert AlreadyMinted(address(this), user, _whiteListA[user]);
}
_mintedA[user] = _mintedA[user] + 1;
_remainingASupply = _remainingASupply - 1;
uint256 tokenId = IDragonOG(_dragon).mint(user);
emit MintA(user, tokenId);
}
function mintB(address user, uint256 price, uint256 deadline, uint8 v, bytes32 r, bytes32 s) public override {
if(block.timestamp < _startTimeB) {
revert NotStartedYet(address(this), _startTimeB);
}
if(block.timestamp > _endTimeB) {
revert AlreadyEnded(address(this), _endTimeB);
}
if(_remainingBSupply == 0){
revert NoMoreMintB(address(this));
}
_checkSignature(MINT_B_TYPEHASH, owner(), user, deadline, v, r, s);
if(_whiteListB[user] == 0) {
revert NotInWhiteListB(address(this), user);
}
if(_mintedB[user] >= _whiteListB[user]) {
revert AlreadyMinted(address(this), user, _whiteListB[user]);
}
if(price < B_PRICE) {
revert NotEnoughETH(address(this), price);
}
_mintedB[user] = _mintedB[user] + 1;
_remainingBSupply = _remainingBSupply - 1;
IWETH(_weth).transferFrom(msg.sender, address(this), price);
uint256 tokenId = IDragonOG(_dragon).mint(user);
emit MintB(user, tokenId);
}
function publicMint(address user, uint256 price, uint256 deadline, uint8 v, bytes32 r, bytes32 s) public override {
if(block.timestamp < _startTimePublic) {
revert NotStartedYet(address(this), _startTimePublic);
}
if(block.timestamp > _endTimePublic) {
revert AlreadyEnded(address(this), _endTimePublic);
}
if(_remainingPublicSupply == 0) {
revert NoMorePublicMint(address(this));
}
_checkSignature(PUBLIC_MINT_TYPEHASH, owner(), user, deadline, v, r, s);
if(_mintedPublic[user]) {
revert AlreadyMinted(address(this), user, 1);
}
if(price < PUBLIC_PRICE) {
revert NotEnoughETH(address(this), price);
}
_mintedPublic[user] = true;
_remainingPublicSupply = _remainingPublicSupply - 1;
IWETH(_weth).transferFrom(msg.sender, address(this), price);
uint256 tokenId = IDragonOG(_dragon).mint(user);
emit PublicMint(user, tokenId);
}
function transferDragonOwner(address newOwner) public override onlyOwner {
if(newOwner == address(0)) {
revert ZeroOwnerAddress(address(this));
}
Ownable2Step(_dragon).transferOwnership(newOwner);
}
function timeWindows() public view override returns(uint256, uint256, uint256, uint256, uint256, uint256) {
return (_startTimeA, _endTimeA, _startTimeB, _endTimeB, _startTimePublic, _endTimePublic);
}
function remainingPublicSupply() public view override returns(uint256) {
return _remainingPublicSupply;
}
function remainingASupply() public view override returns(uint256) {
return _remainingASupply;
}
function remainingBSupply() public view override returns(uint256) {
return _remainingBSupply;
}
function mintableDragons(address user) public view override returns(uint256, uint256, uint256) {
return ( (_whiteListA[user] > _mintedA[user]) ? (_whiteListA[user] - _mintedA[user]) : 0,
(_whiteListB[user] > _mintedB[user]) ? (_whiteListB[user] - _mintedB[user]) : 0,
_mintedPublic[user] ? 0 : 1);
}
function withdraw(address receiver) public onlyOwner {
uint256 balance = IWETH(_weth).balanceOf(address(this));
IWETH(_weth).transferFrom(address(this), receiver, balance);
}
function setBaseURI(string memory baseURI) public onlyOwner {
IDragonOG(_dragon).setBaseURI(baseURI);
}
}
文件 4 的 23:ECDSA.sol
pragma solidity ^0.8.20;
library ECDSA {
enum RecoverError {
NoError,
InvalidSignature,
InvalidSignatureLength,
InvalidSignatureS
}
error ECDSAInvalidSignature();
error ECDSAInvalidSignatureLength(uint256 length);
error ECDSAInvalidSignatureS(bytes32 s);
function tryRecover(bytes32 hash, bytes memory signature) internal pure returns (address, RecoverError, bytes32) {
if (signature.length == 65) {
bytes32 r;
bytes32 s;
uint8 v;
assembly {
r := mload(add(signature, 0x20))
s := mload(add(signature, 0x40))
v := byte(0, mload(add(signature, 0x60)))
}
return tryRecover(hash, v, r, s);
} else {
return (address(0), RecoverError.InvalidSignatureLength, bytes32(signature.length));
}
}
function recover(bytes32 hash, bytes memory signature) internal pure returns (address) {
(address recovered, RecoverError error, bytes32 errorArg) = tryRecover(hash, signature);
_throwError(error, errorArg);
return recovered;
}
function tryRecover(bytes32 hash, bytes32 r, bytes32 vs) internal pure returns (address, RecoverError, bytes32) {
unchecked {
bytes32 s = vs & bytes32(0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff);
uint8 v = uint8((uint256(vs) >> 255) + 27);
return tryRecover(hash, v, r, s);
}
}
function recover(bytes32 hash, bytes32 r, bytes32 vs) internal pure returns (address) {
(address recovered, RecoverError error, bytes32 errorArg) = tryRecover(hash, r, vs);
_throwError(error, errorArg);
return recovered;
}
function tryRecover(
bytes32 hash,
uint8 v,
bytes32 r,
bytes32 s
) internal pure returns (address, RecoverError, bytes32) {
if (uint256(s) > 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0) {
return (address(0), RecoverError.InvalidSignatureS, s);
}
address signer = ecrecover(hash, v, r, s);
if (signer == address(0)) {
return (address(0), RecoverError.InvalidSignature, bytes32(0));
}
return (signer, RecoverError.NoError, bytes32(0));
}
function recover(bytes32 hash, uint8 v, bytes32 r, bytes32 s) internal pure returns (address) {
(address recovered, RecoverError error, bytes32 errorArg) = tryRecover(hash, v, r, s);
_throwError(error, errorArg);
return recovered;
}
function _throwError(RecoverError error, bytes32 errorArg) private pure {
if (error == RecoverError.NoError) {
return;
} else if (error == RecoverError.InvalidSignature) {
revert ECDSAInvalidSignature();
} else if (error == RecoverError.InvalidSignatureLength) {
revert ECDSAInvalidSignatureLength(uint256(errorArg));
} else if (error == RecoverError.InvalidSignatureS) {
revert ECDSAInvalidSignatureS(errorArg);
}
}
}
文件 5 的 23:EIP712.sol
pragma solidity ^0.8.20;
import {MessageHashUtils} from "./MessageHashUtils.sol";
import {ShortStrings, ShortString} from "../ShortStrings.sol";
import {IERC5267} from "../../interfaces/IERC5267.sol";
abstract contract EIP712 is IERC5267 {
using ShortStrings for *;
bytes32 private constant TYPE_HASH =
keccak256("EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)");
bytes32 private immutable _cachedDomainSeparator;
uint256 private immutable _cachedChainId;
address private immutable _cachedThis;
bytes32 private immutable _hashedName;
bytes32 private immutable _hashedVersion;
ShortString private immutable _name;
ShortString private immutable _version;
string private _nameFallback;
string private _versionFallback;
constructor(string memory name, string memory version) {
_name = name.toShortStringWithFallback(_nameFallback);
_version = version.toShortStringWithFallback(_versionFallback);
_hashedName = keccak256(bytes(name));
_hashedVersion = keccak256(bytes(version));
_cachedChainId = block.chainid;
_cachedDomainSeparator = _buildDomainSeparator();
_cachedThis = address(this);
}
function _domainSeparatorV4() internal view returns (bytes32) {
if (address(this) == _cachedThis && block.chainid == _cachedChainId) {
return _cachedDomainSeparator;
} else {
return _buildDomainSeparator();
}
}
function _buildDomainSeparator() private view returns (bytes32) {
return keccak256(abi.encode(TYPE_HASH, _hashedName, _hashedVersion, block.chainid, address(this)));
}
function _hashTypedDataV4(bytes32 structHash) internal view virtual returns (bytes32) {
return MessageHashUtils.toTypedDataHash(_domainSeparatorV4(), structHash);
}
function eip712Domain()
public
view
virtual
returns (
bytes1 fields,
string memory name,
string memory version,
uint256 chainId,
address verifyingContract,
bytes32 salt,
uint256[] memory extensions
)
{
return (
hex"0f",
_EIP712Name(),
_EIP712Version(),
block.chainid,
address(this),
bytes32(0),
new uint256[](0)
);
}
function _EIP712Name() internal view returns (string memory) {
return _name.toStringWithFallback(_nameFallback);
}
function _EIP712Version() internal view returns (string memory) {
return _version.toStringWithFallback(_versionFallback);
}
}
文件 6 的 23:IDistributorBase.sol
pragma solidity ^0.8.13;
interface IDistributorBase {
function nonces(address owner) external view returns (uint256);
function DOMAIN_SEPARATOR() external view returns (bytes32);
error NotStartedYet(address thrower, uint256 startTimestamp);
error ZeroNFTAddress(address thrower);
error ZeroOwnerAddress(address thrower);
error ExpiredSignature(address thrower, uint256 deadline);
error InvalidSigner(address thrower, address signer, address owner);
error LengthNotMatch(address thrower, uint256 lengthA, uint256 lengthB);
}
文件 7 的 23:IDragonDistributor.sol
pragma solidity ^0.8.13;
interface IDragonDistributor {
event Initialize(address indexed dragonOG, uint256 startTimeA, uint256 endTimeA,
uint256 startTimeB, uint256 endTimeB, uint256 startTimePublic, uint256 endTimePublic);
event UpdateBaseURI(string baseURI);
event WhiteListAAdded(address indexed user, uint256 count);
event WhiteListARemoved(address indexed user);
event WhiteListBAdded(address indexed user, uint256 count);
event WhiteListBRemoved(address indexed user);
event MintA(address indexed user, uint256 indexed id);
event MintB(address indexed user, uint256 indexed id);
event PublicMint(address indexed user, uint256 indexed id);
event StartTimeAChanged(uint256 startTimeA);
event EndTimeAChanged(uint256 endTimeA);
event StartTimeBChanged(uint256 startTimeB);
event EndTimeBChanged(uint256 endTimeB);
event StartTimePublicChanged(uint256 startTimePublic);
event EndTimePublicChanged(uint256 endTimePublic);
function mintA(address receiver, uint256 deadline, uint8 v, bytes32 r, bytes32 s) external;
function mintB(address receiver, uint256 price, uint256 deadline, uint8 v, bytes32 r, bytes32 s) external;
function publicMint(address receiver, uint256 price, uint256 deadline, uint8 v, bytes32 r, bytes32 s) external;
function transferDragonOwner(address newOwner) external;
function mintableDragons(address user) external view returns(uint256, uint256, uint256);
function timeWindows() external view returns(uint256, uint256, uint256, uint256, uint256, uint256);
function remainingPublicSupply() external view returns(uint256);
function remainingASupply() external view returns(uint256);
function remainingBSupply() external view returns(uint256);
error ZeroWETHAddress(address thrower);
error NotInWhiteListA(address thrower, address user);
error NotInWhiteListB(address thrower, address user);
error AlreadyMinted(address thrower, address user, uint256 count);
error NoMorePublicMint(address thrower);
error NoMoreMintA(address thrower);
error NoMoreMintB(address thrower);
error AlreadyEnded(address thrower, uint256 endTime);
error NotEnoughETH(address thrower, uint256 amount);
}
文件 8 的 23:IDragonOG.sol
pragma solidity ^0.8.17;
interface IDragonOG {
event UpdateBaseURI(string baseURI);
function setBaseURI(string memory baseURI) external;
function mint(address receiver) external returns(uint256);
error OutOfStock(address thrower);
}
文件 9 的 23:IERC165.sol
pragma solidity ^0.8.20;
interface IERC165 {
function supportsInterface(bytes4 interfaceId) external view returns (bool);
}
文件 10 的 23:IERC5267.sol
pragma solidity ^0.8.20;
interface IERC5267 {
event EIP712DomainChanged();
function eip712Domain()
external
view
returns (
bytes1 fields,
string memory name,
string memory version,
uint256 chainId,
address verifyingContract,
bytes32 salt,
uint256[] memory extensions
);
}
文件 11 的 23:IERC721.sol
pragma solidity ^0.8.20;
import {IERC165} from "../../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);
}
文件 12 的 23:IERC721Metadata.sol
pragma solidity ^0.8.20;
import {IERC721} from "../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);
}
文件 13 的 23:IWETH.sol
pragma solidity ^0.8.11;
interface IWETH {
function deposit() external payable;
function withdraw(uint256) external;
function approve(address guy, uint256 wad) external returns (bool);
function balanceOf(address user) external returns (uint256);
function transferFrom(
address src,
address dst,
uint256 wad
) external returns (bool);
}
文件 14 的 23:Math.sol
pragma solidity ^0.8.20;
library Math {
error MathOverflowedMulDiv();
enum Rounding {
Floor,
Ceil,
Trunc,
Expand
}
function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) {
unchecked {
uint256 c = a + b;
if (c < a) return (false, 0);
return (true, c);
}
}
function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) {
unchecked {
if (b > a) return (false, 0);
return (true, a - b);
}
}
function tryMul(uint256 a, uint256 b) internal pure returns (bool, uint256) {
unchecked {
if (a == 0) return (true, 0);
uint256 c = a * b;
if (c / a != b) return (false, 0);
return (true, c);
}
}
function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) {
unchecked {
if (b == 0) return (false, 0);
return (true, a / b);
}
}
function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) {
unchecked {
if (b == 0) return (false, 0);
return (true, a % b);
}
}
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) {
if (b == 0) {
return a / b;
}
return a == 0 ? 0 : (a - 1) / b + 1;
}
function mulDiv(uint256 x, uint256 y, uint256 denominator) internal pure returns (uint256 result) {
unchecked {
uint256 prod0 = x * y;
uint256 prod1;
assembly {
let mm := mulmod(x, y, not(0))
prod1 := sub(sub(mm, prod0), lt(mm, prod0))
}
if (prod1 == 0) {
return prod0 / denominator;
}
if (denominator <= prod1) {
revert MathOverflowedMulDiv();
}
uint256 remainder;
assembly {
remainder := mulmod(x, y, denominator)
prod1 := sub(prod1, gt(remainder, prod0))
prod0 := sub(prod0, remainder)
}
uint256 twos = denominator & (0 - denominator);
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 (unsignedRoundsUp(rounding) && 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 + (unsignedRoundsUp(rounding) && 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 + (unsignedRoundsUp(rounding) && 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 + (unsignedRoundsUp(rounding) && 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 + (unsignedRoundsUp(rounding) && 1 << (result << 3) < value ? 1 : 0);
}
}
function unsignedRoundsUp(Rounding rounding) internal pure returns (bool) {
return uint8(rounding) % 2 == 1;
}
}
文件 15 的 23:MessageHashUtils.sol
pragma solidity ^0.8.20;
import {Strings} from "../Strings.sol";
library MessageHashUtils {
function toEthSignedMessageHash(bytes32 messageHash) internal pure returns (bytes32 digest) {
assembly {
mstore(0x00, "\x19Ethereum Signed Message:\n32")
mstore(0x1c, messageHash)
digest := keccak256(0x00, 0x3c)
}
}
function toEthSignedMessageHash(bytes memory message) internal pure returns (bytes32) {
return
keccak256(bytes.concat("\x19Ethereum Signed Message:\n", bytes(Strings.toString(message.length)), message));
}
function toDataWithIntendedValidatorHash(address validator, bytes memory data) internal pure returns (bytes32) {
return keccak256(abi.encodePacked(hex"19_00", validator, data));
}
function toTypedDataHash(bytes32 domainSeparator, bytes32 structHash) internal pure returns (bytes32 digest) {
assembly {
let ptr := mload(0x40)
mstore(ptr, hex"19_01")
mstore(add(ptr, 0x02), domainSeparator)
mstore(add(ptr, 0x22), structHash)
digest := keccak256(ptr, 0x42)
}
}
}
文件 16 的 23:Nonces.sol
pragma solidity ^0.8.20;
abstract contract Nonces {
error InvalidAccountNonce(address account, uint256 currentNonce);
mapping(address account => uint256) private _nonces;
function nonces(address owner) public view virtual returns (uint256) {
return _nonces[owner];
}
function _useNonce(address owner) internal virtual returns (uint256) {
unchecked {
return _nonces[owner]++;
}
}
function _useCheckedNonce(address owner, uint256 nonce) internal virtual {
uint256 current = _useNonce(owner);
if (nonce != current) {
revert InvalidAccountNonce(owner, current);
}
}
}
文件 17 的 23:Ownable.sol
pragma solidity ^0.8.20;
import {Context} from "../utils/Context.sol";
abstract contract Ownable is Context {
address private _owner;
error OwnableUnauthorizedAccount(address account);
error OwnableInvalidOwner(address owner);
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
constructor(address initialOwner) {
if (initialOwner == address(0)) {
revert OwnableInvalidOwner(address(0));
}
_transferOwnership(initialOwner);
}
modifier onlyOwner() {
_checkOwner();
_;
}
function owner() public view virtual returns (address) {
return _owner;
}
function _checkOwner() internal view virtual {
if (owner() != _msgSender()) {
revert OwnableUnauthorizedAccount(_msgSender());
}
}
function renounceOwnership() public virtual onlyOwner {
_transferOwnership(address(0));
}
function transferOwnership(address newOwner) public virtual onlyOwner {
if (newOwner == address(0)) {
revert OwnableInvalidOwner(address(0));
}
_transferOwnership(newOwner);
}
function _transferOwnership(address newOwner) internal virtual {
address oldOwner = _owner;
_owner = newOwner;
emit OwnershipTransferred(oldOwner, newOwner);
}
}
文件 18 的 23:Ownable2Step.sol
pragma solidity ^0.8.20;
import {Ownable} from "./Ownable.sol";
abstract contract Ownable2Step is Ownable {
address private _pendingOwner;
event OwnershipTransferStarted(address indexed previousOwner, address indexed newOwner);
function pendingOwner() public view virtual returns (address) {
return _pendingOwner;
}
function transferOwnership(address newOwner) public virtual override onlyOwner {
_pendingOwner = newOwner;
emit OwnershipTransferStarted(owner(), newOwner);
}
function _transferOwnership(address newOwner) internal virtual override {
delete _pendingOwner;
super._transferOwnership(newOwner);
}
function acceptOwnership() public virtual {
address sender = _msgSender();
if (pendingOwner() != sender) {
revert OwnableUnauthorizedAccount(sender);
}
_transferOwnership(sender);
}
}
文件 19 的 23:ShortStrings.sol
pragma solidity ^0.8.20;
import {StorageSlot} from "./StorageSlot.sol";
type ShortString is bytes32;
library ShortStrings {
bytes32 private constant FALLBACK_SENTINEL = 0x00000000000000000000000000000000000000000000000000000000000000FF;
error StringTooLong(string str);
error InvalidShortString();
function toShortString(string memory str) internal pure returns (ShortString) {
bytes memory bstr = bytes(str);
if (bstr.length > 31) {
revert StringTooLong(str);
}
return ShortString.wrap(bytes32(uint256(bytes32(bstr)) | bstr.length));
}
function toString(ShortString sstr) internal pure returns (string memory) {
uint256 len = byteLength(sstr);
string memory str = new string(32);
assembly {
mstore(str, len)
mstore(add(str, 0x20), sstr)
}
return str;
}
function byteLength(ShortString sstr) internal pure returns (uint256) {
uint256 result = uint256(ShortString.unwrap(sstr)) & 0xFF;
if (result > 31) {
revert InvalidShortString();
}
return result;
}
function toShortStringWithFallback(string memory value, string storage store) internal returns (ShortString) {
if (bytes(value).length < 32) {
return toShortString(value);
} else {
StorageSlot.getStringSlot(store).value = value;
return ShortString.wrap(FALLBACK_SENTINEL);
}
}
function toStringWithFallback(ShortString value, string storage store) internal pure returns (string memory) {
if (ShortString.unwrap(value) != FALLBACK_SENTINEL) {
return toString(value);
} else {
return store;
}
}
function byteLengthWithFallback(ShortString value, string storage store) internal view returns (uint256) {
if (ShortString.unwrap(value) != FALLBACK_SENTINEL) {
return byteLength(value);
} else {
return bytes(store).length;
}
}
}
文件 20 的 23:SignedMath.sol
pragma solidity ^0.8.20;
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);
}
}
}
文件 21 的 23:SimpleInitializable.sol
pragma solidity ^0.8.4;
abstract contract SimpleInitializable {
bool internal _initialized = false;
modifier initializer() {
if (_initialized) {
revert AlreadyInitialised(address(this));
}
_initialized = true;
_;
}
error AlreadyInitialised(address target);
}
文件 22 的 23:StorageSlot.sol
pragma solidity ^0.8.20;
library StorageSlot {
struct AddressSlot {
address value;
}
struct BooleanSlot {
bool value;
}
struct Bytes32Slot {
bytes32 value;
}
struct Uint256Slot {
uint256 value;
}
struct StringSlot {
string value;
}
struct BytesSlot {
bytes value;
}
function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {
assembly {
r.slot := slot
}
}
function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {
assembly {
r.slot := slot
}
}
function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {
assembly {
r.slot := slot
}
}
function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {
assembly {
r.slot := slot
}
}
function getStringSlot(bytes32 slot) internal pure returns (StringSlot storage r) {
assembly {
r.slot := slot
}
}
function getStringSlot(string storage store) internal pure returns (StringSlot storage r) {
assembly {
r.slot := store.slot
}
}
function getBytesSlot(bytes32 slot) internal pure returns (BytesSlot storage r) {
assembly {
r.slot := slot
}
}
function getBytesSlot(bytes storage store) internal pure returns (BytesSlot storage r) {
assembly {
r.slot := store.slot
}
}
}
文件 23 的 23:Strings.sol
pragma solidity ^0.8.20;
import {Math} from "./math/Math.sol";
import {SignedMath} from "./math/SignedMath.sol";
library Strings {
bytes16 private constant HEX_DIGITS = "0123456789abcdef";
uint8 private constant ADDRESS_LENGTH = 20;
error StringsInsufficientHexLength(uint256 value, uint256 length);
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), HEX_DIGITS))
}
value /= 10;
if (value == 0) break;
}
return buffer;
}
}
function toStringSigned(int256 value) internal pure returns (string memory) {
return string.concat(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) {
uint256 localValue = value;
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_DIGITS[localValue & 0xf];
localValue >>= 4;
}
if (localValue != 0) {
revert StringsInsufficientHexLength(value, length);
}
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 bytes(a).length == bytes(b).length && keccak256(bytes(a)) == keccak256(bytes(b));
}
}
{
"compilationTarget": {
"src/DragonDistributor.sol": "DragonDistributor"
},
"evmVersion": "paris",
"libraries": {},
"metadata": {
"bytecodeHash": "ipfs"
},
"optimizer": {
"enabled": true,
"runs": 200
},
"remappings": [
":@openzeppelin/contracts/=lib/openzeppelin-contracts/contracts/",
":ds-test/=lib/forge-std/lib/ds-test/src/",
":erc4626-tests/=lib/openzeppelin-contracts/lib/erc4626-tests/",
":forge-std/=lib/forge-std/src/",
":openzeppelin-contracts/=lib/openzeppelin-contracts/"
]
}
[{"inputs":[{"internalType":"address","name":"dragonAddress","type":"address"},{"internalType":"address","name":"wethAddress","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[{"internalType":"address","name":"thrower","type":"address"},{"internalType":"uint256","name":"endTime","type":"uint256"}],"name":"AlreadyEnded","type":"error"},{"inputs":[{"internalType":"address","name":"target","type":"address"}],"name":"AlreadyInitialised","type":"error"},{"inputs":[{"internalType":"address","name":"thrower","type":"address"},{"internalType":"address","name":"user","type":"address"},{"internalType":"uint256","name":"count","type":"uint256"}],"name":"AlreadyMinted","type":"error"},{"inputs":[],"name":"ECDSAInvalidSignature","type":"error"},{"inputs":[{"internalType":"uint256","name":"length","type":"uint256"}],"name":"ECDSAInvalidSignatureLength","type":"error"},{"inputs":[{"internalType":"bytes32","name":"s","type":"bytes32"}],"name":"ECDSAInvalidSignatureS","type":"error"},{"inputs":[{"internalType":"address","name":"thrower","type":"address"},{"internalType":"uint256","name":"deadline","type":"uint256"}],"name":"ExpiredSignature","type":"error"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"uint256","name":"currentNonce","type":"uint256"}],"name":"InvalidAccountNonce","type":"error"},{"inputs":[],"name":"InvalidShortString","type":"error"},{"inputs":[{"internalType":"address","name":"thrower","type":"address"},{"internalType":"address","name":"signer","type":"address"},{"internalType":"address","name":"owner","type":"address"}],"name":"InvalidSigner","type":"error"},{"inputs":[{"internalType":"address","name":"thrower","type":"address"},{"internalType":"uint256","name":"lengthA","type":"uint256"},{"internalType":"uint256","name":"lengthB","type":"uint256"}],"name":"LengthNotMatch","type":"error"},{"inputs":[{"internalType":"address","name":"thrower","type":"address"}],"name":"NoMoreMintA","type":"error"},{"inputs":[{"internalType":"address","name":"thrower","type":"address"}],"name":"NoMoreMintB","type":"error"},{"inputs":[{"internalType":"address","name":"thrower","type":"address"}],"name":"NoMorePublicMint","type":"error"},{"inputs":[{"internalType":"address","name":"thrower","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"NotEnoughETH","type":"error"},{"inputs":[{"internalType":"address","name":"thrower","type":"address"},{"internalType":"address","name":"user","type":"address"}],"name":"NotInWhiteListA","type":"error"},{"inputs":[{"internalType":"address","name":"thrower","type":"address"},{"internalType":"address","name":"user","type":"address"}],"name":"NotInWhiteListB","type":"error"},{"inputs":[{"internalType":"address","name":"thrower","type":"address"},{"internalType":"uint256","name":"startTimestamp","type":"uint256"}],"name":"NotStartedYet","type":"error"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"OwnableInvalidOwner","type":"error"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"OwnableUnauthorizedAccount","type":"error"},{"inputs":[{"internalType":"string","name":"str","type":"string"}],"name":"StringTooLong","type":"error"},{"inputs":[{"internalType":"address","name":"thrower","type":"address"}],"name":"ZeroNFTAddress","type":"error"},{"inputs":[{"internalType":"address","name":"thrower","type":"address"}],"name":"ZeroOwnerAddress","type":"error"},{"inputs":[{"internalType":"address","name":"thrower","type":"address"}],"name":"ZeroWETHAddress","type":"error"},{"anonymous":false,"inputs":[],"name":"EIP712DomainChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"endTimeA","type":"uint256"}],"name":"EndTimeAChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"endTimeB","type":"uint256"}],"name":"EndTimeBChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"endTimePublic","type":"uint256"}],"name":"EndTimePublicChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"dragonOG","type":"address"},{"indexed":false,"internalType":"uint256","name":"startTimeA","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"endTimeA","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"startTimeB","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"endTimeB","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"startTimePublic","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"endTimePublic","type":"uint256"}],"name":"Initialize","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":true,"internalType":"uint256","name":"id","type":"uint256"}],"name":"MintA","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":true,"internalType":"uint256","name":"id","type":"uint256"}],"name":"MintB","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferStarted","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":"user","type":"address"},{"indexed":true,"internalType":"uint256","name":"id","type":"uint256"}],"name":"PublicMint","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"startTimeA","type":"uint256"}],"name":"StartTimeAChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"startTimeB","type":"uint256"}],"name":"StartTimeBChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"startTimePublic","type":"uint256"}],"name":"StartTimePublicChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"string","name":"baseURI","type":"string"}],"name":"UpdateBaseURI","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":false,"internalType":"uint256","name":"count","type":"uint256"}],"name":"WhiteListAAdded","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"}],"name":"WhiteListARemoved","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":false,"internalType":"uint256","name":"count","type":"uint256"}],"name":"WhiteListBAdded","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"}],"name":"WhiteListBRemoved","type":"event"},{"inputs":[],"name":"DOMAIN_SEPARATOR","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"acceptOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"eip712Domain","outputs":[{"internalType":"bytes1","name":"fields","type":"bytes1"},{"internalType":"string","name":"name","type":"string"},{"internalType":"string","name":"version","type":"string"},{"internalType":"uint256","name":"chainId","type":"uint256"},{"internalType":"address","name":"verifyingContract","type":"address"},{"internalType":"bytes32","name":"salt","type":"bytes32"},{"internalType":"uint256[]","name":"extensions","type":"uint256[]"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"startA","type":"uint256"},{"internalType":"uint256","name":"endA","type":"uint256"},{"internalType":"uint256","name":"startB","type":"uint256"},{"internalType":"uint256","name":"endB","type":"uint256"},{"internalType":"uint256","name":"startPublic","type":"uint256"},{"internalType":"uint256","name":"endPublic","type":"uint256"}],"name":"initialize","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"user","type":"address"},{"internalType":"uint256","name":"deadline","type":"uint256"},{"internalType":"uint8","name":"v","type":"uint8"},{"internalType":"bytes32","name":"r","type":"bytes32"},{"internalType":"bytes32","name":"s","type":"bytes32"}],"name":"mintA","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"user","type":"address"},{"internalType":"uint256","name":"price","type":"uint256"},{"internalType":"uint256","name":"deadline","type":"uint256"},{"internalType":"uint8","name":"v","type":"uint8"},{"internalType":"bytes32","name":"r","type":"bytes32"},{"internalType":"bytes32","name":"s","type":"bytes32"}],"name":"mintB","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"user","type":"address"}],"name":"mintableDragons","outputs":[{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"nonces","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pendingOwner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"user","type":"address"},{"internalType":"uint256","name":"price","type":"uint256"},{"internalType":"uint256","name":"deadline","type":"uint256"},{"internalType":"uint8","name":"v","type":"uint8"},{"internalType":"bytes32","name":"r","type":"bytes32"},{"internalType":"bytes32","name":"s","type":"bytes32"}],"name":"publicMint","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"remainingASupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"remainingBSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"remainingPublicSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"string","name":"baseURI","type":"string"}],"name":"setBaseURI","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"end","type":"uint256"}],"name":"setEndTimeA","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"end","type":"uint256"}],"name":"setEndTimeB","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"end","type":"uint256"}],"name":"setEndTimePublic","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"start","type":"uint256"}],"name":"setStartTimeA","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"start","type":"uint256"}],"name":"setStartTimeB","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"start","type":"uint256"}],"name":"setStartTimePublic","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"users","type":"address[]"},{"internalType":"uint256[]","name":"counts","type":"uint256[]"}],"name":"setWhiteListABatch","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"users","type":"address[]"},{"internalType":"uint256[]","name":"counts","type":"uint256[]"}],"name":"setWhiteListBBatch","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"timeWindows","outputs":[{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferDragonOwner","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"receiver","type":"address"}],"name":"withdraw","outputs":[],"stateMutability":"nonpayable","type":"function"}]