编译器
0.8.13+commit.abaa5c0e
文件 1 的 18:AccessControl.sol
pragma solidity ^0.8.0;
import "./IAccessControl.sol";
import "../utils/Context.sol";
import "../utils/Strings.sol";
import "../utils/introspection/ERC165.sol";
abstract contract AccessControl is Context, IAccessControl, ERC165 {
struct RoleData {
mapping(address => bool) members;
bytes32 adminRole;
}
mapping(bytes32 => RoleData) private _roles;
bytes32 public constant DEFAULT_ADMIN_ROLE = 0x00;
modifier onlyRole(bytes32 role) {
_checkRole(role);
_;
}
function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {
return interfaceId == type(IAccessControl).interfaceId || super.supportsInterface(interfaceId);
}
function hasRole(bytes32 role, address account) public view virtual override returns (bool) {
return _roles[role].members[account];
}
function _checkRole(bytes32 role) internal view virtual {
_checkRole(role, _msgSender());
}
function _checkRole(bytes32 role, address account) internal view virtual {
if (!hasRole(role, account)) {
revert(
string(
abi.encodePacked(
"AccessControl: account ",
Strings.toHexString(account),
" is missing role ",
Strings.toHexString(uint256(role), 32)
)
)
);
}
}
function getRoleAdmin(bytes32 role) public view virtual override returns (bytes32) {
return _roles[role].adminRole;
}
function grantRole(bytes32 role, address account) public virtual override onlyRole(getRoleAdmin(role)) {
_grantRole(role, account);
}
function revokeRole(bytes32 role, address account) public virtual override onlyRole(getRoleAdmin(role)) {
_revokeRole(role, account);
}
function renounceRole(bytes32 role, address account) public virtual override {
require(account == _msgSender(), "AccessControl: can only renounce roles for self");
_revokeRole(role, account);
}
function _setupRole(bytes32 role, address account) internal virtual {
_grantRole(role, account);
}
function _setRoleAdmin(bytes32 role, bytes32 adminRole) internal virtual {
bytes32 previousAdminRole = getRoleAdmin(role);
_roles[role].adminRole = adminRole;
emit RoleAdminChanged(role, previousAdminRole, adminRole);
}
function _grantRole(bytes32 role, address account) internal virtual {
if (!hasRole(role, account)) {
_roles[role].members[account] = true;
emit RoleGranted(role, account, _msgSender());
}
}
function _revokeRole(bytes32 role, address account) internal virtual {
if (hasRole(role, account)) {
_roles[role].members[account] = false;
emit RoleRevoked(role, account, _msgSender());
}
}
}
文件 2 的 18:Administration.sol
pragma solidity ^0.8.0;
import "@openzeppelin/contracts/access/AccessControl.sol";
import "@openzeppelin/contracts/security/Pausable.sol";
error InsufficientAccess();
error InvalidOwner();
abstract contract Administration is AccessControl, Pausable {
address private _owner;
bytes32 public constant ADMIN = keccak256("ADMIN");
bytes32 public constant MINTER = keccak256("MINTER");
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
modifier isAdmin() {
if (!hasRole(ADMIN, _msgSender())) {
revert InsufficientAccess();
}
_;
}
modifier isMinter() {
if (!hasRole(MINTER, _msgSender())) {
revert InsufficientAccess();
}
_;
}
modifier isGlobalAdmin() {
if (!hasRole(DEFAULT_ADMIN_ROLE, _msgSender())) {
revert InsufficientAccess();
}
_;
}
constructor(address globalAdmin) {
_setupRole(MINTER, _msgSender());
_setupRole(ADMIN, _msgSender());
_setupRole(DEFAULT_ADMIN_ROLE, globalAdmin);
_setupRole(ADMIN, globalAdmin);
_setOwner(globalAdmin);
}
function pause() public isAdmin {
_pause();
}
function unpause() public isAdmin {
_unpause();
}
function owner() public view returns (address) {
return _owner;
}
function transferOwnership(address newOwner) public virtual isAdmin {
if (newOwner == address(0)) revert InvalidOwner();
_setOwner(newOwner);
}
function _setOwner(address newOwner) private {
address oldOwner = _owner;
_owner = newOwner;
emit OwnershipTransferred(oldOwner, newOwner);
}
function supportsInterface(bytes4 interfaceId) public view virtual override(AccessControl) returns (bool) {
return
interfaceId == type(AccessControl).interfaceId ||
interfaceId == type(Pausable).interfaceId ||
super.supportsInterface(interfaceId);
}
}
文件 3 的 18:AllowList.sol
pragma solidity ^0.8.4;
import "@openzeppelin/contracts/utils/cryptography/MerkleProof.sol";
contract AllowList {
error NotOnAllowList(address);
struct AllowListData {
bytes32 merkleRoot;
string uri;
}
mapping(bytes32 => AllowListData) private _allowListMerkleRoots;
function verifyProof(
bytes32 list,
address from,
bytes memory data,
bytes32[] calldata merkleProof
) public view returns (bool) {
AllowListData memory d = _allowListMerkleRoots[list];
if (d.merkleRoot == 0) return false;
return MerkleProof.verify(merkleProof, d.merkleRoot, _formatLeaf(from, data));
}
function _formatLeaf(address from, bytes memory data) internal pure returns (bytes32) {
return keccak256(abi.encodePacked(from, data));
}
function _verifyProofOrRevert(
bytes32 list,
address from,
bytes memory data,
bytes32[] calldata merkleProof
) internal view returns (bool) {
if (verifyProof(list, from, data, merkleProof) != true) {
revert NotOnAllowList(from);
}
return true;
}
function _returnAllowList(bytes32 list) internal view returns (AllowListData memory) {
return _allowListMerkleRoots[list];
}
function _updateAllowList(bytes32 id, AllowListData calldata allowListData) internal virtual {
_allowListMerkleRoots[id] = allowListData;
}
}
文件 4 的 18: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;
}
}
文件 5 的 18:ERC1155Receiver.sol
pragma solidity ^0.8.0;
import "../IERC1155Receiver.sol";
import "../../../utils/introspection/ERC165.sol";
abstract contract ERC1155Receiver is ERC165, IERC1155Receiver {
function supportsInterface(bytes4 interfaceId) public view virtual override(ERC165, IERC165) returns (bool) {
return interfaceId == type(IERC1155Receiver).interfaceId || super.supportsInterface(interfaceId);
}
}
文件 6 的 18: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;
}
}
文件 7 的 18:IAccessControl.sol
pragma solidity ^0.8.0;
interface IAccessControl {
event RoleAdminChanged(bytes32 indexed role, bytes32 indexed previousAdminRole, bytes32 indexed newAdminRole);
event RoleGranted(bytes32 indexed role, address indexed account, address indexed sender);
event RoleRevoked(bytes32 indexed role, address indexed account, address indexed sender);
function hasRole(bytes32 role, address account) external view returns (bool);
function getRoleAdmin(bytes32 role) external view returns (bytes32);
function grantRole(bytes32 role, address account) external;
function revokeRole(bytes32 role, address account) external;
function renounceRole(bytes32 role, address account) external;
}
文件 8 的 18:IERC1155.sol
pragma solidity ^0.8.0;
import "../../utils/introspection/IERC165.sol";
interface IERC1155 is IERC165 {
event TransferSingle(address indexed operator, address indexed from, address indexed to, uint256 id, uint256 value);
event TransferBatch(
address indexed operator,
address indexed from,
address indexed to,
uint256[] ids,
uint256[] values
);
event ApprovalForAll(address indexed account, address indexed operator, bool approved);
event URI(string value, uint256 indexed id);
function balanceOf(address account, uint256 id) external view returns (uint256);
function balanceOfBatch(address[] calldata accounts, uint256[] calldata ids)
external
view
returns (uint256[] memory);
function setApprovalForAll(address operator, bool approved) external;
function isApprovedForAll(address account, address operator) external view returns (bool);
function safeTransferFrom(
address from,
address to,
uint256 id,
uint256 amount,
bytes calldata data
) external;
function safeBatchTransferFrom(
address from,
address to,
uint256[] calldata ids,
uint256[] calldata amounts,
bytes calldata data
) external;
}
文件 9 的 18:IERC1155Receiver.sol
pragma solidity ^0.8.0;
import "../../utils/introspection/IERC165.sol";
interface IERC1155Receiver is IERC165 {
function onERC1155Received(
address operator,
address from,
uint256 id,
uint256 value,
bytes calldata data
) external returns (bytes4);
function onERC1155BatchReceived(
address operator,
address from,
uint256[] calldata ids,
uint256[] calldata values,
bytes calldata data
) external returns (bytes4);
}
文件 10 的 18:IERC165.sol
pragma solidity ^0.8.0;
interface IERC165 {
function supportsInterface(bytes4 interfaceId) external view returns (bool);
}
文件 11 的 18:IERC20.sol
pragma solidity ^0.8.0;
interface IERC20 {
event Transfer(address indexed from, address indexed to, uint256 value);
event Approval(address indexed owner, address indexed spender, uint256 value);
function totalSupply() external view returns (uint256);
function balanceOf(address account) external view returns (uint256);
function transfer(address to, uint256 amount) external returns (bool);
function allowance(address owner, address spender) external view returns (uint256);
function approve(address spender, uint256 amount) external returns (bool);
function transferFrom(
address from,
address to,
uint256 amount
) external returns (bool);
}
文件 12 的 18: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);
}
文件 13 的 18: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);
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 * 8) < value ? 1 : 0);
}
}
}
文件 14 的 18:MerkleProof.sol
pragma solidity ^0.8.0;
library MerkleProof {
function verify(
bytes32[] memory proof,
bytes32 root,
bytes32 leaf
) internal pure returns (bool) {
return processProof(proof, leaf) == root;
}
function verifyCalldata(
bytes32[] calldata proof,
bytes32 root,
bytes32 leaf
) internal pure returns (bool) {
return processProofCalldata(proof, leaf) == root;
}
function processProof(bytes32[] memory proof, bytes32 leaf) internal pure returns (bytes32) {
bytes32 computedHash = leaf;
for (uint256 i = 0; i < proof.length; i++) {
computedHash = _hashPair(computedHash, proof[i]);
}
return computedHash;
}
function processProofCalldata(bytes32[] calldata proof, bytes32 leaf) internal pure returns (bytes32) {
bytes32 computedHash = leaf;
for (uint256 i = 0; i < proof.length; i++) {
computedHash = _hashPair(computedHash, proof[i]);
}
return computedHash;
}
function multiProofVerify(
bytes32[] memory proof,
bool[] memory proofFlags,
bytes32 root,
bytes32[] memory leaves
) internal pure returns (bool) {
return processMultiProof(proof, proofFlags, leaves) == root;
}
function multiProofVerifyCalldata(
bytes32[] calldata proof,
bool[] calldata proofFlags,
bytes32 root,
bytes32[] memory leaves
) internal pure returns (bool) {
return processMultiProofCalldata(proof, proofFlags, leaves) == root;
}
function processMultiProof(
bytes32[] memory proof,
bool[] memory proofFlags,
bytes32[] memory leaves
) internal pure returns (bytes32 merkleRoot) {
uint256 leavesLen = leaves.length;
uint256 totalHashes = proofFlags.length;
require(leavesLen + proof.length - 1 == totalHashes, "MerkleProof: invalid multiproof");
bytes32[] memory hashes = new bytes32[](totalHashes);
uint256 leafPos = 0;
uint256 hashPos = 0;
uint256 proofPos = 0;
for (uint256 i = 0; i < totalHashes; i++) {
bytes32 a = leafPos < leavesLen ? leaves[leafPos++] : hashes[hashPos++];
bytes32 b = proofFlags[i] ? leafPos < leavesLen ? leaves[leafPos++] : hashes[hashPos++] : proof[proofPos++];
hashes[i] = _hashPair(a, b);
}
if (totalHashes > 0) {
return hashes[totalHashes - 1];
} else if (leavesLen > 0) {
return leaves[0];
} else {
return proof[0];
}
}
function processMultiProofCalldata(
bytes32[] calldata proof,
bool[] calldata proofFlags,
bytes32[] memory leaves
) internal pure returns (bytes32 merkleRoot) {
uint256 leavesLen = leaves.length;
uint256 totalHashes = proofFlags.length;
require(leavesLen + proof.length - 1 == totalHashes, "MerkleProof: invalid multiproof");
bytes32[] memory hashes = new bytes32[](totalHashes);
uint256 leafPos = 0;
uint256 hashPos = 0;
uint256 proofPos = 0;
for (uint256 i = 0; i < totalHashes; i++) {
bytes32 a = leafPos < leavesLen ? leaves[leafPos++] : hashes[hashPos++];
bytes32 b = proofFlags[i] ? leafPos < leavesLen ? leaves[leafPos++] : hashes[hashPos++] : proof[proofPos++];
hashes[i] = _hashPair(a, b);
}
if (totalHashes > 0) {
return hashes[totalHashes - 1];
} else if (leavesLen > 0) {
return leaves[0];
} else {
return proof[0];
}
}
function _hashPair(bytes32 a, bytes32 b) private pure returns (bytes32) {
return a < b ? _efficientHash(a, b) : _efficientHash(b, a);
}
function _efficientHash(bytes32 a, bytes32 b) private pure returns (bytes32 value) {
assembly {
mstore(0x00, a)
mstore(0x20, b)
value := keccak256(0x00, 0x40)
}
}
}
文件 15 的 18:Pausable.sol
pragma solidity ^0.8.0;
import "../utils/Context.sol";
abstract contract Pausable is Context {
event Paused(address account);
event Unpaused(address account);
bool private _paused;
constructor() {
_paused = false;
}
modifier whenNotPaused() {
_requireNotPaused();
_;
}
modifier whenPaused() {
_requirePaused();
_;
}
function paused() public view virtual returns (bool) {
return _paused;
}
function _requireNotPaused() internal view virtual {
require(!paused(), "Pausable: paused");
}
function _requirePaused() internal view virtual {
require(paused(), "Pausable: not paused");
}
function _pause() internal virtual whenNotPaused {
_paused = true;
emit Paused(_msgSender());
}
function _unpause() internal virtual whenPaused {
_paused = false;
emit Unpaused(_msgSender());
}
}
文件 16 的 18:RelicsDrop.sol
pragma solidity ^0.8.4;
import "../utils/Administration.sol";
import "../utils/Treasury.sol";
import "../utils/AllowList.sol";
import "@openzeppelin/contracts/token/ERC1155/utils/ERC1155Receiver.sol";
contract RelicsDrop is ERC1155Receiver, AllowList, Administration, Treasury {
address private _relicsContract;
uint256 private _maxPerTxn = 25;
struct Presale {
uint32 startTime;
uint32 endTime;
uint128 price;
uint64 limit;
bytes32 nonce;
}
struct Sale {
uint128 quantity;
uint128 minted;
uint32 activeFrom;
uint32 startTime;
uint32 endTime;
uint96 price;
uint24 tickets;
uint24 redeemed;
uint8 limit;
bool paused;
}
struct Ticket {
uint256 tokenId;
uint256 saleId;
}
mapping(uint256 => Sale) private _sales;
mapping(address => Ticket) private _tickets;
mapping(bytes32 => bool) private _participated;
mapping(address => mapping(uint256 => uint256)) private _mints;
constructor(address relicsContract, address treasuryAddress) Administration(treasuryAddress) {
_relicsContract = relicsContract;
_treasury = treasuryAddress;
}
function hasParticipatedInPresale(bytes32 nonce) public view returns (bool participated) {
participated = _participated[nonce];
}
function getMaxPerTransaction() public view returns (uint256 max) {
max = _maxPerTxn;
}
function getDrop(uint256 id) public view returns (Sale memory sale) {
sale = _sales[id];
}
function getAllowList(uint256 id) public view returns (AllowListData memory allowlist) {
allowlist = _returnAllowList(bytes32(id));
}
function getTicket(address ticketAddress) public view returns (Ticket memory ticket) {
ticket = _tickets[ticketAddress];
}
function getAvailable(uint256 id)
public
view
returns (
uint256 total,
uint256 tickets,
uint256 purchasable
)
{
Sale memory sale = _sales[id];
unchecked {
total = maxSupply(id) - totalMinted(id);
tickets = sale.tickets - sale.redeemed;
purchasable = total - tickets;
}
}
function allowListStatus(
uint256 id,
address from,
Presale calldata presale,
bytes32[] calldata merkleProof
) public view returns (bool allowed, bool participated) {
participated = _participated[presale.nonce];
allowed = verifyProof(bytes32(id), from, _hashPresaleData(presale), merkleProof);
}
function maxSupply(uint256 id) public view returns (uint256 supply) {
supply = _sales[id].quantity;
}
function totalMinted(uint256 id) public view returns (uint256 minted) {
minted = _sales[id].minted;
}
function ownerMinted(address owner, uint256 id) public view returns (uint256 minted) {
minted = _mints[owner][id];
}
function setMaxPerTransaction(uint256 max) external isAdmin {
_maxPerTxn = max;
}
function pauseSaleToggle(uint256 id) external isAdmin {
Sale storage sale = _sales[id];
sale.paused = !sale.paused;
}
function createDrop(
uint256 id,
uint32 activeFrom,
uint32 startTime,
uint32 endTime,
uint64 quantity,
uint96 price,
uint8 limit,
uint8 premint,
string calldata proof
) external isAdmin {
Sale storage _sale = _sales[id];
if (_sale.startTime != 0) revert DropExists();
if (startTime > endTime) revert InvalidDropConfig();
(uint256 startIndex, uint256 endIndex) = IRelic721(_relicsContract).registerRange(id, quantity, proof);
if (startIndex == 0 || endIndex == 0) revert InvalidDropConfig();
_sale.quantity = quantity;
_sale.activeFrom = activeFrom;
_sale.startTime = startTime;
_sale.endTime = endTime;
_sale.price = price;
_sale.limit = limit;
if (premint > 0) {
IRelic721(_relicsContract).mintRange(id, getTreasuryAddress(), premint);
}
}
function updateDrop(
uint256 id,
uint32 activeFrom,
uint32 startTime,
uint32 endTime,
uint96 price,
uint8 limit
) external isAdmin {
Sale storage _sale = _sales[id];
if (_sale.startTime == 0) revert DropDoesNotExist();
if (startTime > endTime) revert InvalidDropConfig();
_sale.activeFrom = activeFrom;
_sale.startTime = startTime;
_sale.endTime = endTime;
_sale.price = price;
_sale.limit = limit;
}
function updateDropAllowList(uint256 id, AllowListData calldata allowListData) external isAdmin {
Sale memory _sale = _sales[id];
if (_sale.quantity == 0) revert InvalidDropConfig();
_updateAllowList(bytes32(id), allowListData);
}
function updateDropTicket(
uint256 id,
uint24 tickets,
address ticketAddress,
uint256 tokenId
) external isAdmin {
Sale storage _sale = _sales[id];
Ticket storage _ticket = _tickets[ticketAddress];
if (tickets > _sale.quantity) revert InvalidDropConfig();
_sale.tickets = tickets;
_ticket.saleId = id;
_ticket.tokenId = tokenId;
}
function presaleMint(
uint256 id,
uint128 quantity,
Presale calldata presale,
bytes32[] calldata merkleProof
) external payable whenNotPaused {
Sale storage sale = _sales[id];
uint256 userMints = _mints[_msgSender()][id];
if (sale.quantity == 0) revert InvalidDropConfig();
uint256 price = presale.price;
_verifyIsActive(presale.startTime, presale.endTime, sale.paused);
_verifyPayment(quantity, price);
_verifyPresale(quantity, presale);
_verifyProofOrRevert(bytes32(id), _msgSender(), _hashPresaleData(presale), merkleProof);
_verifyQuantity(quantity, sale.quantity, sale.minted, sale.tickets);
_verifyUserLimit(userMints, quantity, sale.limit);
unchecked {
_mints[_msgSender()][id] = userMints + quantity;
sale.minted += quantity;
}
IRelic721(_relicsContract).mintRange(id, _msgSender(), quantity);
}
function publicMint(uint256 id, uint128 quantity) external payable whenNotPaused {
Sale storage sale = _sales[id];
uint256 price = sale.price;
uint256 userMints = _mints[_msgSender()][id];
_verifyIsActive(sale.startTime, sale.endTime, sale.paused);
_verifyPayment(quantity, price);
_verifyQuantity(quantity, sale.quantity, sale.minted, sale.tickets);
_verifyUserLimit(userMints, quantity, sale.limit);
unchecked {
_mints[_msgSender()][id] = userMints + quantity;
sale.minted += quantity;
}
IRelic721(_relicsContract).mintRange(id, _msgSender(), quantity);
}
function onERC721Received(
address,
address from,
uint256 tokenId,
bytes calldata
) public virtual whenNotPaused returns (bytes4) {
address tokenAddress = msg.sender;
Ticket memory ticket = _tickets[tokenAddress];
Sale storage sale = _sales[ticket.saleId];
_verifyIsActive(sale.activeFrom, sale.endTime, sale.paused);
_verifyQuantity(1, sale.quantity, sale.minted, 0);
_verifyTicketsRedeemed(sale, 1);
IRelic721(msg.sender).burn(tokenId);
unchecked {
sale.minted += 1;
}
IRelic721(_relicsContract).mintRange(ticket.saleId, from, 1);
return this.onERC721Received.selector;
}
function onERC1155Received(
address,
address from,
uint256 id,
uint256 value,
bytes memory
) public override whenNotPaused returns (bytes4) {
address tokenAddress = msg.sender;
Ticket memory ticket = _tickets[tokenAddress];
Sale storage sale = _sales[ticket.saleId];
if (id != ticket.tokenId) revert InvalidTicket(id, ticket.tokenId);
_verifyIsActive(sale.activeFrom, sale.endTime, sale.paused);
_verifyQuantity(1, sale.quantity, sale.minted, 0);
_verifyTicketsRedeemed(sale, uint24(value));
IERC1155Burn(msg.sender).burn(address(this), id, value);
unchecked {
sale.minted += uint128(value);
}
IRelic721(_relicsContract).mintRange(ticket.saleId, from, value);
return this.onERC1155Received.selector;
}
function onERC1155BatchReceived(
address operator,
address from,
uint256[] memory id,
uint256[] memory value,
bytes memory
) public override whenNotPaused returns (bytes4) {
for (uint256 i = 0; i < id.length; ) {
onERC1155Received(operator, from, id[i], value[i], "");
unchecked {
i++;
}
}
return this.onERC1155BatchReceived.selector;
}
function _hashPresaleData(Presale memory presale) internal pure returns (bytes memory) {
return
abi.encodePacked(
keccak256(
abi.encodePacked(presale.startTime, presale.endTime, presale.price, presale.limit, presale.nonce)
)
);
}
function _verifyPresale(uint256 quantity, Presale calldata presale) internal {
if (quantity > presale.limit) revert InvalidQuantity(quantity, presale.limit);
if (_participated[presale.nonce] == true) revert AlreadyParticipated();
_participated[presale.nonce] = true;
}
function _verifyTicketsRedeemed(Sale storage sale, uint24 value) internal {
unchecked {
uint24 redeemed = sale.redeemed + value;
if (redeemed > sale.tickets) revert TicketQuantityExceeded(sale.tickets);
sale.redeemed = redeemed;
}
}
function _verifyIsActive(
uint32 startTime,
uint32 endTime,
bool paused
) internal view {
uint32 blockTimestamp = uint32(block.timestamp % 2**32);
if (paused) {
revert NotActive(blockTimestamp, startTime, endTime, true);
}
if (blockTimestamp < startTime || blockTimestamp > endTime) {
revert NotActive(blockTimestamp, startTime, endTime, false);
}
}
function _verifyPayment(uint256 quantity, uint256 mintPrice) internal view {
unchecked {
if (msg.value != quantity * mintPrice) {
revert InvalidPayment(msg.value, quantity * mintPrice);
}
}
}
function _verifyQuantity(
uint256 quantity,
uint256 supply,
uint256 minted,
uint256 tickets
) internal view {
if (quantity > _maxPerTxn) {
revert InvalidQuantity(quantity, _maxPerTxn);
}
unchecked {
uint256 newSupply = (minted + quantity + tickets);
if (newSupply > supply) {
revert RequestExceedsMaxSupply(quantity, minted, supply);
}
}
}
function _verifyUserLimit(
uint256 minted,
uint256 requested,
uint256 limit
) internal pure {
unchecked {
uint256 total = minted + requested;
if (total > limit) {
revert InvalidQuantity(total, limit);
}
}
}
function supportsInterface(bytes4 interfaceId)
public
view
override(Administration, ERC1155Receiver)
returns (bool)
{
return super.supportsInterface(interfaceId);
}
receive() external payable {}
error NotActive(uint32 currentTimestamp, uint32 startTimestamp, uint32 endTimestamp, bool paused);
error InvalidPayment(uint256 received, uint256 required);
error InvalidQuantity(uint256 requested, uint256 max);
error RequestExceedsMaxSupply(uint256 requested, uint256 current, uint256 max);
error InvalidTicketQuantity(uint256 requested, uint256 owned);
error InvalidTicket(uint256 received, uint256 required);
error TicketQuantityExceeded(uint256 tickets);
error TicketApprovalRequired();
error AlreadyParticipated();
error InvalidDropConfig();
error DropDoesNotExist();
error DropExists();
}
interface IRelic721 {
function burn(uint256 tokenId) external;
function mint(address to, uint256 tokenId) external;
function mintRange(
uint256 range,
address to,
uint256 quantity
) external;
function registerRange(
uint256 range,
uint64 quantity,
string calldata proof
) external returns (uint64, uint64);
}
interface IERC1155Burn {
function burn(
address account,
uint256 id,
uint256 value
) external;
}
文件 17 的 18:Strings.sol
pragma solidity ^0.8.0;
import "./math/Math.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 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);
}
}
文件 18 的 18:Treasury.sol
pragma solidity ^0.8.4;
import "./Administration.sol";
import "@openzeppelin/contracts/token/ERC20/IERC20.sol";
import "@openzeppelin/contracts/token/ERC1155/IERC1155.sol";
import "@openzeppelin/contracts/token/ERC721/IERC721.sol";
abstract contract Treasury is Administration {
address internal _treasury;
modifier isTreasuryOrGlobalAdmin() {
if (!hasRole(DEFAULT_ADMIN_ROLE, _msgSender()) && _msgSender() != _treasury) {
revert InsufficientAccess();
}
_;
}
function setTreasury(address treasury) external isGlobalAdmin {
_treasury = treasury;
}
function getTreasuryAddress() public view returns (address) {
return _treasury;
}
function withdraw() external isTreasuryOrGlobalAdmin {
if (_treasury == address(0)) revert MustSetTreasury();
(bool success, ) = payable(_treasury).call{value: address(this).balance}("");
if (!success) revert WithdrawFailed();
}
function withdrawToken(address token) external isTreasuryOrGlobalAdmin {
if (_treasury == address(0)) revert MustSetTreasury();
IERC20 t = IERC20(token);
t.transfer(_treasury, t.balanceOf(address(this)));
}
function withdraw1155(address token, uint256 tokenId) external isTreasuryOrGlobalAdmin {
if (_treasury == address(0)) revert MustSetTreasury();
IERC1155 erc1155 = IERC1155(token);
erc1155.safeTransferFrom(address(this), _treasury, tokenId, erc1155.balanceOf(address(this), tokenId), "");
}
function withdraw721(address token, uint256 tokenId) external isTreasuryOrGlobalAdmin {
if (_treasury == address(0)) revert MustSetTreasury();
IERC721 erc721 = IERC721(token);
erc721.transferFrom(address(this), _treasury, tokenId);
}
error WithdrawFailed();
error MustSetTreasury();
}
{
"compilationTarget": {
"contracts/relics/RelicsDrop.sol": "RelicsDrop"
},
"evmVersion": "london",
"libraries": {},
"metadata": {
"bytecodeHash": "ipfs"
},
"optimizer": {
"enabled": true,
"runs": 200
},
"remappings": []
}
[{"inputs":[{"internalType":"address","name":"relicsContract","type":"address"},{"internalType":"address","name":"treasuryAddress","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[],"name":"AlreadyParticipated","type":"error"},{"inputs":[],"name":"DropDoesNotExist","type":"error"},{"inputs":[],"name":"DropExists","type":"error"},{"inputs":[],"name":"InsufficientAccess","type":"error"},{"inputs":[],"name":"InvalidDropConfig","type":"error"},{"inputs":[],"name":"InvalidOwner","type":"error"},{"inputs":[{"internalType":"uint256","name":"received","type":"uint256"},{"internalType":"uint256","name":"required","type":"uint256"}],"name":"InvalidPayment","type":"error"},{"inputs":[{"internalType":"uint256","name":"requested","type":"uint256"},{"internalType":"uint256","name":"max","type":"uint256"}],"name":"InvalidQuantity","type":"error"},{"inputs":[{"internalType":"uint256","name":"received","type":"uint256"},{"internalType":"uint256","name":"required","type":"uint256"}],"name":"InvalidTicket","type":"error"},{"inputs":[{"internalType":"uint256","name":"requested","type":"uint256"},{"internalType":"uint256","name":"owned","type":"uint256"}],"name":"InvalidTicketQuantity","type":"error"},{"inputs":[],"name":"MustSetTreasury","type":"error"},{"inputs":[{"internalType":"uint32","name":"currentTimestamp","type":"uint32"},{"internalType":"uint32","name":"startTimestamp","type":"uint32"},{"internalType":"uint32","name":"endTimestamp","type":"uint32"},{"internalType":"bool","name":"paused","type":"bool"}],"name":"NotActive","type":"error"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"NotOnAllowList","type":"error"},{"inputs":[{"internalType":"uint256","name":"requested","type":"uint256"},{"internalType":"uint256","name":"current","type":"uint256"},{"internalType":"uint256","name":"max","type":"uint256"}],"name":"RequestExceedsMaxSupply","type":"error"},{"inputs":[],"name":"TicketApprovalRequired","type":"error"},{"inputs":[{"internalType":"uint256","name":"tickets","type":"uint256"}],"name":"TicketQuantityExceeded","type":"error"},{"inputs":[],"name":"WithdrawFailed","type":"error"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"}],"name":"Paused","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"role","type":"bytes32"},{"indexed":true,"internalType":"bytes32","name":"previousAdminRole","type":"bytes32"},{"indexed":true,"internalType":"bytes32","name":"newAdminRole","type":"bytes32"}],"name":"RoleAdminChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"role","type":"bytes32"},{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":true,"internalType":"address","name":"sender","type":"address"}],"name":"RoleGranted","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"role","type":"bytes32"},{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":true,"internalType":"address","name":"sender","type":"address"}],"name":"RoleRevoked","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"}],"name":"Unpaused","type":"event"},{"inputs":[],"name":"ADMIN","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"DEFAULT_ADMIN_ROLE","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MINTER","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"id","type":"uint256"},{"internalType":"address","name":"from","type":"address"},{"components":[{"internalType":"uint32","name":"startTime","type":"uint32"},{"internalType":"uint32","name":"endTime","type":"uint32"},{"internalType":"uint128","name":"price","type":"uint128"},{"internalType":"uint64","name":"limit","type":"uint64"},{"internalType":"bytes32","name":"nonce","type":"bytes32"}],"internalType":"struct RelicsDrop.Presale","name":"presale","type":"tuple"},{"internalType":"bytes32[]","name":"merkleProof","type":"bytes32[]"}],"name":"allowListStatus","outputs":[{"internalType":"bool","name":"allowed","type":"bool"},{"internalType":"bool","name":"participated","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"id","type":"uint256"},{"internalType":"uint32","name":"activeFrom","type":"uint32"},{"internalType":"uint32","name":"startTime","type":"uint32"},{"internalType":"uint32","name":"endTime","type":"uint32"},{"internalType":"uint64","name":"quantity","type":"uint64"},{"internalType":"uint96","name":"price","type":"uint96"},{"internalType":"uint8","name":"limit","type":"uint8"},{"internalType":"uint8","name":"premint","type":"uint8"},{"internalType":"string","name":"proof","type":"string"}],"name":"createDrop","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"id","type":"uint256"}],"name":"getAllowList","outputs":[{"components":[{"internalType":"bytes32","name":"merkleRoot","type":"bytes32"},{"internalType":"string","name":"uri","type":"string"}],"internalType":"struct AllowList.AllowListData","name":"allowlist","type":"tuple"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"id","type":"uint256"}],"name":"getAvailable","outputs":[{"internalType":"uint256","name":"total","type":"uint256"},{"internalType":"uint256","name":"tickets","type":"uint256"},{"internalType":"uint256","name":"purchasable","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"id","type":"uint256"}],"name":"getDrop","outputs":[{"components":[{"internalType":"uint128","name":"quantity","type":"uint128"},{"internalType":"uint128","name":"minted","type":"uint128"},{"internalType":"uint32","name":"activeFrom","type":"uint32"},{"internalType":"uint32","name":"startTime","type":"uint32"},{"internalType":"uint32","name":"endTime","type":"uint32"},{"internalType":"uint96","name":"price","type":"uint96"},{"internalType":"uint24","name":"tickets","type":"uint24"},{"internalType":"uint24","name":"redeemed","type":"uint24"},{"internalType":"uint8","name":"limit","type":"uint8"},{"internalType":"bool","name":"paused","type":"bool"}],"internalType":"struct RelicsDrop.Sale","name":"sale","type":"tuple"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getMaxPerTransaction","outputs":[{"internalType":"uint256","name":"max","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"}],"name":"getRoleAdmin","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"ticketAddress","type":"address"}],"name":"getTicket","outputs":[{"components":[{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"uint256","name":"saleId","type":"uint256"}],"internalType":"struct RelicsDrop.Ticket","name":"ticket","type":"tuple"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getTreasuryAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"grantRole","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"nonce","type":"bytes32"}],"name":"hasParticipatedInPresale","outputs":[{"internalType":"bool","name":"participated","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"hasRole","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"id","type":"uint256"}],"name":"maxSupply","outputs":[{"internalType":"uint256","name":"supply","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"operator","type":"address"},{"internalType":"address","name":"from","type":"address"},{"internalType":"uint256[]","name":"id","type":"uint256[]"},{"internalType":"uint256[]","name":"value","type":"uint256[]"},{"internalType":"bytes","name":"","type":"bytes"}],"name":"onERC1155BatchReceived","outputs":[{"internalType":"bytes4","name":"","type":"bytes4"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"from","type":"address"},{"internalType":"uint256","name":"id","type":"uint256"},{"internalType":"uint256","name":"value","type":"uint256"},{"internalType":"bytes","name":"","type":"bytes"}],"name":"onERC1155Received","outputs":[{"internalType":"bytes4","name":"","type":"bytes4"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"from","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"bytes","name":"","type":"bytes"}],"name":"onERC721Received","outputs":[{"internalType":"bytes4","name":"","type":"bytes4"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"uint256","name":"id","type":"uint256"}],"name":"ownerMinted","outputs":[{"internalType":"uint256","name":"minted","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pause","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"id","type":"uint256"}],"name":"pauseSaleToggle","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"paused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"id","type":"uint256"},{"internalType":"uint128","name":"quantity","type":"uint128"},{"components":[{"internalType":"uint32","name":"startTime","type":"uint32"},{"internalType":"uint32","name":"endTime","type":"uint32"},{"internalType":"uint128","name":"price","type":"uint128"},{"internalType":"uint64","name":"limit","type":"uint64"},{"internalType":"bytes32","name":"nonce","type":"bytes32"}],"internalType":"struct RelicsDrop.Presale","name":"presale","type":"tuple"},{"internalType":"bytes32[]","name":"merkleProof","type":"bytes32[]"}],"name":"presaleMint","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"uint256","name":"id","type":"uint256"},{"internalType":"uint128","name":"quantity","type":"uint128"}],"name":"publicMint","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"renounceRole","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"revokeRole","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"max","type":"uint256"}],"name":"setMaxPerTransaction","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"treasury","type":"address"}],"name":"setTreasury","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes4","name":"interfaceId","type":"bytes4"}],"name":"supportsInterface","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"id","type":"uint256"}],"name":"totalMinted","outputs":[{"internalType":"uint256","name":"minted","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"unpause","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"id","type":"uint256"},{"internalType":"uint32","name":"activeFrom","type":"uint32"},{"internalType":"uint32","name":"startTime","type":"uint32"},{"internalType":"uint32","name":"endTime","type":"uint32"},{"internalType":"uint96","name":"price","type":"uint96"},{"internalType":"uint8","name":"limit","type":"uint8"}],"name":"updateDrop","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"id","type":"uint256"},{"components":[{"internalType":"bytes32","name":"merkleRoot","type":"bytes32"},{"internalType":"string","name":"uri","type":"string"}],"internalType":"struct AllowList.AllowListData","name":"allowListData","type":"tuple"}],"name":"updateDropAllowList","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"id","type":"uint256"},{"internalType":"uint24","name":"tickets","type":"uint24"},{"internalType":"address","name":"ticketAddress","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"updateDropTicket","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"list","type":"bytes32"},{"internalType":"address","name":"from","type":"address"},{"internalType":"bytes","name":"data","type":"bytes"},{"internalType":"bytes32[]","name":"merkleProof","type":"bytes32[]"}],"name":"verifyProof","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"withdraw","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"withdraw1155","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"withdraw721","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"}],"name":"withdrawToken","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]