编译器
0.8.19+commit.7dd6d404
文件 1 的 15: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 的 15:AdminAccessControl.sol
pragma solidity ^0.8.19;
import '@openzeppelin/contracts/access/AccessControl.sol';
import '@openzeppelin/contracts/access/Ownable.sol';
contract AdminAccessControl is AccessControl, Ownable {
bytes32 public constant ADMIN = "ADMIN";
modifier onlyAdmin() {
require(hasRole(ADMIN, _msgSender()), 'Caller is not a admin');
_;
}
function grantAdmin(address account)
public
onlyOwner
{
_grantRole(ADMIN, account);
}
function revokeAdmin(address account)
public
onlyOwner
{
_revokeRole(ADMIN, account);
}
}
文件 3 的 15:CNCCSeller.sol
pragma solidity ^0.8.19;
import '@openzeppelin/contracts/security/ReentrancyGuard.sol';
import '@openzeppelin/contracts/token/ERC721/IERC721.sol';
import '@openzeppelin/contracts/utils/cryptography/MerkleProof.sol';
import "./AdminAccessControl.sol";
import "./interface/ICryptNinjaChildrenCoin.sol";
import "./interface/ICryptNinjaChildren.sol";
contract CNCCSeller is AdminAccessControl, ReentrancyGuard {
event exchangeCoinToMakimonoEvent(address indexed user, uint256 afterTokenId, uint256 amount);
event exchangeMakimonoToCharacterEvent(address indexed user, uint256 beforeTokenId, uint256 afterTokenId, uint256 amount);
event burninEvent(address indexed user, uint256 burnTokenId, uint256 mintTokenId);
struct phaseStruct {
uint256 totalSupply;
uint256 maxSupply;
uint256 cost;
uint256 maxMintAmountPerTransaction;
bytes32 merkleRoot;
mapping(address => uint256) userMintedAmount;
}
struct pauseStruct {
bool coinMint;
bool exchangeCoinToMakimono;
bool exchangeMakimonoToCharacter;
bool exchangeCoinToKatasiro;
bool burnin;
}
uint256 public phaseId;
pauseStruct public pauseData;
mapping(uint256 => phaseStruct) public phaseStructMap;
mapping(uint256 => uint256) public exchangeTokenIdMap;
ICryptNinjaChildren public immutable cnc;
ICryptNinjaChildrenCoin public immutable cncc;
uint256 public cncNextTokenId = 11111;
uint256 public constant COIN_TOKEN_ID = 1;
uint256 public constant MAKIMONO_TEN_TOKEN_ID = 2;
uint256 public constant MAKIMONO_KAI_TOKEN_ID = 3;
uint256 public constant MAKIMONO_CHI_TOKEN_ID = 4;
uint256 public constant CHARACTER_KANEKO_TOKEN_ID = 5;
uint256 public constant CHARACTER_SATORU_TOKEN_ID = 6;
uint256 public constant CHARACTER_SARAO_TOKEN_ID = 7;
uint256 public constant KATASIRO_TOKEN_ID = 8;
constructor(ICryptNinjaChildrenCoin _cncc, ICryptNinjaChildren _cnc) {
grantAdmin(_msgSender());
cnc = ICryptNinjaChildren(_cnc);
cncc = ICryptNinjaChildrenCoin(_cncc);
setPhaseId(1);
setExchangeTokenIdMap(MAKIMONO_TEN_TOKEN_ID, CHARACTER_KANEKO_TOKEN_ID);
setExchangeTokenIdMap(MAKIMONO_KAI_TOKEN_ID, CHARACTER_SATORU_TOKEN_ID);
setExchangeTokenIdMap(MAKIMONO_CHI_TOKEN_ID, CHARACTER_SARAO_TOKEN_ID);
setPauseCoinMint(true);
setPauseExchangeCoinToMakimono(true);
setPauseExchangeMakimonoToCharacter(true);
setPauseExchangeCoinToKatasiro(true);
setPauseBurnin(true);
}
modifier amountCheck(uint256 _mintAmount, uint256 _wlCount) {
require(_mintAmount > 0, 'Mint amount cannot be zero');
require(_mintAmount <= phaseStructMap[phaseId].maxMintAmountPerTransaction, "max mint amount per session exceeded");
require(phaseStructMap[phaseId].totalSupply + _mintAmount <= phaseStructMap[phaseId].maxSupply, "max NFT limit exceeded");
require(
phaseStructMap[phaseId].userMintedAmount[msg.sender] + _mintAmount <= _wlCount,
'Address already claimed max amount'
);
_;
}
modifier senderCheck(address _sender, uint248 _wlCount, bytes32[] calldata _merkleProof) {
bytes32 leaf = keccak256(abi.encodePacked(_sender, _wlCount));
require(MerkleProof.verifyCalldata(_merkleProof, phaseStructMap[phaseId].merkleRoot, leaf), 'Invalid Merkle Proof');
_;
}
modifier callerIsUser() {
require(tx.origin == msg.sender, "The caller is another contract.");
_;
}
modifier enouthEth(uint256 _amount) {
require(msg.value >= phaseStructMap[phaseId].cost * _amount, "not enough eth.");
_;
}
function setPauseCoinMint(bool _isPause) public onlyAdmin { pauseData.coinMint = _isPause; }
function setPauseExchangeCoinToMakimono(bool _isPause) public onlyAdmin { pauseData.exchangeCoinToMakimono = _isPause; }
function setPauseExchangeMakimonoToCharacter(bool _isPause) public onlyAdmin { pauseData.exchangeMakimonoToCharacter = _isPause; }
function setPauseExchangeCoinToKatasiro(bool _isPause) public onlyAdmin { pauseData.exchangeCoinToKatasiro = _isPause; }
function setPauseBurnin(bool _isPause) public onlyAdmin { pauseData.burnin = _isPause; }
function mint(
uint256 _mintAmount,
uint248 _wlCount,
bytes32[] calldata _merkleProof
) external payable amountCheck(_mintAmount, _wlCount) senderCheck(msg.sender, _wlCount, _merkleProof) nonReentrant callerIsUser enouthEth(_mintAmount) {
require(!pauseData.coinMint, 'is not active.');
phaseStructMap[phaseId].userMintedAmount[msg.sender] += _mintAmount;
phaseStructMap[phaseId].totalSupply += _mintAmount;
cncc.mint(msg.sender, COIN_TOKEN_ID, _mintAmount, "");
}
function exchangeCoinToMakimono(uint256 _amount) external nonReentrant callerIsUser {
require(!pauseData.exchangeCoinToMakimono, 'is not active.');
require(0 < _amount && _amount <= cncc.balanceOf(msg.sender, COIN_TOKEN_ID), 'amount cannot be zero');
cncc.burn(msg.sender, COIN_TOKEN_ID, _amount);
uint256[] memory randCounts = new uint256[](3);
for (uint256 i = 0; i < _amount; i++) {
uint256 rand = uint256(keccak256(abi.encodePacked(blockhash(block.number - 1), i))) % 3;
randCounts[rand] += 1;
}
uint256[] memory tokenIds;
uint256[] memory amounts;
(tokenIds, amounts) = _forBatchMint(randCounts);
cncc.mintBatch(msg.sender, tokenIds, amounts, "");
}
function _forBatchMint(uint256[] memory _randCounts) private returns (uint256[] memory tokenIds, uint256[] memory amounts) {
tokenIds = new uint256[](_randCounts.length);
amounts = new uint256[](_randCounts.length);
uint256 tokenAmountIndex = 0;
for(uint256 i = 0; i < 3; i++) {
if (_randCounts[i] > 0) {
tokenIds[tokenAmountIndex] = MAKIMONO_TEN_TOKEN_ID + i;
amounts[tokenAmountIndex] = _randCounts[i];
emit exchangeCoinToMakimonoEvent(msg.sender, tokenIds[tokenAmountIndex], amounts[tokenAmountIndex]);
tokenAmountIndex += 1;
}
}
return (tokenIds, amounts);
}
function setExchangeTokenIdMap(uint256 _beforeTokenId, uint256 _afterTokenId) public onlyAdmin {
require(_beforeTokenId != _afterTokenId, 'beforeTokenId and afterTokenId cannot be same');
exchangeTokenIdMap[_beforeTokenId] = _afterTokenId;
}
function exchangeMakimonoToCharacter(uint256[] calldata _burnTokenIds, uint256[] calldata _amounts) external nonReentrant {
require(!pauseData.exchangeMakimonoToCharacter, 'is not active.');
require(_burnTokenIds.length > 0, 'length cannot be zero');
require(_burnTokenIds.length == _amounts.length, 'lengths are not equal');
uint256[] memory mintTokenIds = new uint256[](_burnTokenIds.length);
for(uint256 i = 0; i < _burnTokenIds.length; i++) {
require(_amounts[i] > 0, 'amount cannot be zero');
require(cncc.balanceOf(msg.sender, _burnTokenIds[i]) >= _amounts[i], 'Insufficient balance');
uint256 mintTokenId = exchangeTokenIdMap[_burnTokenIds[i]];
require(mintTokenId > 0, 'Invalid burn token id');
mintTokenIds[i] = mintTokenId;
emit exchangeMakimonoToCharacterEvent(msg.sender, _burnTokenIds[i], mintTokenId, _amounts[i]);
}
cncc.burnBatch(msg.sender, _burnTokenIds, _amounts);
cncc.mintBatch(msg.sender, mintTokenIds, _amounts, "");
}
function exchangeCoinToKatasiro(uint256 _amount) external nonReentrant callerIsUser {
require(!pauseData.exchangeCoinToKatasiro, 'is not active.');
require(0 < _amount && _amount <= cncc.balanceOf(msg.sender, COIN_TOKEN_ID), 'amount cannot be zero');
cncc.burn(msg.sender, COIN_TOKEN_ID, _amount);
cncc.mint(msg.sender, KATASIRO_TOKEN_ID, _amount, "");
}
function burnin(uint256[] calldata _CNCTokenIds) external nonReentrant {
require(!pauseData.burnin, 'is not active.');
uint256 tokenLength = _CNCTokenIds.length;
require(tokenLength > 0, 'length cannot be zero');
require(cncc.balanceOf(msg.sender, KATASIRO_TOKEN_ID) >= tokenLength, "Insufficient Katasiro balance");
for(uint256 i = 0; i < tokenLength; ++i) {
require(cnc.ownerOf(_CNCTokenIds[i]) == msg.sender, 'Not CNC owner');
}
cncc.burn(msg.sender, KATASIRO_TOKEN_ID, _CNCTokenIds.length);
bytes32[] memory merkleProof = new bytes32[](0);
cnc.exchange(_CNCTokenIds, 11111, merkleProof);
uint256 baseTokenId = cncNextTokenId;
for(uint256 i = 0; i < tokenLength; ++i) {
uint256 mintTokenId = baseTokenId + i;
cnc.safeTransferFrom(address(this), msg.sender, mintTokenId);
emit burninEvent(msg.sender, _CNCTokenIds[i], mintTokenId);
}
cncNextTokenId += tokenLength;
}
function adminMint(uint256 _tokenId, uint256 _mintAmount, address _to) external onlyAdmin {
require(_mintAmount > 0, 'Mint amount cannot be zero');
phaseStructMap[phaseId].totalSupply += _mintAmount;
cncc.mint(_to, _tokenId, _mintAmount, "");
}
function airdropMint(address[] calldata _airdropAddresses , uint256 _tokenId, uint256[] memory _userMintAmount) external onlyAdmin {
require(_airdropAddresses.length == _userMintAmount.length , "Array lengths are different");
require(_tokenId > 0, "Token ID cannot be zero");
uint256 mintAmount = 0;
for (uint256 i = 0; i < _userMintAmount.length; ++i) {
mintAmount += _userMintAmount[i];
}
require(mintAmount > 0, "need to mint at least 1 NFT");
require(phaseStructMap[phaseId].totalSupply + mintAmount <= phaseStructMap[phaseId].maxSupply, "max NFT limit exceeded");
for(uint256 i = 0; i < _userMintAmount.length; ++i) {
phaseStructMap[phaseId].totalSupply += _userMintAmount[i];
cncc.mint(_airdropAddresses[i], _tokenId, _userMintAmount[i], "");
}
}
function setPhaseData(
uint256 _id,
uint256 _maxSupply,
uint256 _cost,
uint256 _maxMintAmountPerTransaction,
bytes32 _merkleRoot
) external onlyAdmin {
phaseStructMap[_id].maxSupply = _maxSupply;
phaseStructMap[_id].cost = _cost;
phaseStructMap[_id].maxMintAmountPerTransaction = _maxMintAmountPerTransaction;
phaseStructMap[_id].merkleRoot = _merkleRoot;
}
function setPhaseId(uint256 _id) public onlyAdmin {
phaseId = _id;
}
function setMaxSupply(uint256 _maxSupply) external onlyAdmin {
phaseStructMap[phaseId].maxSupply = _maxSupply;
}
function setCost(uint256 _newCost) external onlyAdmin {
phaseStructMap[phaseId].cost = _newCost;
}
function setMaxMintAmountPerTransaction(uint256 _maxMintAmountPerTransaction) external onlyAdmin {
phaseStructMap[phaseId].maxMintAmountPerTransaction = _maxMintAmountPerTransaction;
}
function setMerkleRoot(bytes32 _merkleRoot) external onlyAdmin {
phaseStructMap[phaseId].merkleRoot = _merkleRoot;
}
function getUserMintedAmount(address _address) external view returns(uint256){
return phaseStructMap[phaseId].userMintedAmount[_address];
}
function onERC721Received(
address,
address,
uint256,
bytes calldata
) external pure returns (bytes4) {
return this.onERC721Received.selector;
}
}
文件 4 的 15: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 的 15: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;
}
}
文件 6 的 15: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;
}
文件 7 的 15:ICryptNinjaChildren.sol
pragma solidity ^0.8.19;
interface ICryptNinjaChildren {
function exchange(
uint256[] calldata burnTokenIds,
uint248 allowedAmount,
bytes32[] calldata merkleProof
) external;
function isApprovedForAll(address owner, address operator) external view returns(bool);
function claim(
uint248 amount,
uint248 allowedAmount,
bytes32[] calldata merkleProof
) external payable;
function safeTransferFrom(
address from,
address to,
uint256 tokenId
) external;
function ownerOf(uint256 tokenId) external view returns (address);
}
文件 8 的 15:ICryptNinjaChildrenCoin.sol
pragma solidity ^0.8.19;
interface ICryptNinjaChildrenCoin {
function mint(
address to,
uint256 id,
uint256 amount,
bytes memory data
) external;
function mintBatch(
address to,
uint256[] memory ids,
uint256[] memory amounts,
bytes memory data
) external;
function burn(
address account,
uint256 id,
uint256 value
) external;
function burnBatch(
address account,
uint256[] memory ids,
uint256[] memory values
) external;
function balanceOf(address account, uint256 id) external view returns (uint256);
}
文件 9 的 15:IERC165.sol
pragma solidity ^0.8.0;
interface IERC165 {
function supportsInterface(bytes4 interfaceId) external view returns (bool);
}
文件 10 的 15:IERC721.sol
pragma solidity ^0.8.0;
import "../../utils/introspection/IERC165.sol";
interface IERC721 is IERC165 {
event Transfer(address indexed from, address indexed to, uint256 indexed tokenId);
event Approval(address indexed owner, address indexed approved, uint256 indexed tokenId);
event ApprovalForAll(address indexed owner, address indexed operator, bool approved);
function balanceOf(address owner) external view returns (uint256 balance);
function ownerOf(uint256 tokenId) external view returns (address owner);
function safeTransferFrom(
address from,
address to,
uint256 tokenId,
bytes calldata data
) external;
function safeTransferFrom(
address from,
address to,
uint256 tokenId
) external;
function transferFrom(
address from,
address to,
uint256 tokenId
) external;
function approve(address to, uint256 tokenId) external;
function setApprovalForAll(address operator, bool _approved) external;
function getApproved(uint256 tokenId) external view returns (address operator);
function isApprovedForAll(address owner, address operator) external view returns (bool);
}
文件 11 的 15: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);
}
}
}
文件 12 的 15: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)
}
}
}
文件 13 的 15:Ownable.sol
pragma solidity ^0.8.0;
import "../utils/Context.sol";
abstract contract Ownable is Context {
address private _owner;
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
constructor() {
_transferOwnership(_msgSender());
}
modifier onlyOwner() {
_checkOwner();
_;
}
function owner() public view virtual returns (address) {
return _owner;
}
function _checkOwner() internal view virtual {
require(owner() == _msgSender(), "Ownable: caller is not the owner");
}
function renounceOwnership() public virtual onlyOwner {
_transferOwnership(address(0));
}
function transferOwnership(address newOwner) public virtual onlyOwner {
require(newOwner != address(0), "Ownable: new owner is the zero address");
_transferOwnership(newOwner);
}
function _transferOwnership(address newOwner) internal virtual {
address oldOwner = _owner;
_owner = newOwner;
emit OwnershipTransferred(oldOwner, newOwner);
}
}
文件 14 的 15:ReentrancyGuard.sol
pragma solidity ^0.8.0;
abstract contract ReentrancyGuard {
uint256 private constant _NOT_ENTERED = 1;
uint256 private constant _ENTERED = 2;
uint256 private _status;
constructor() {
_status = _NOT_ENTERED;
}
modifier nonReentrant() {
_nonReentrantBefore();
_;
_nonReentrantAfter();
}
function _nonReentrantBefore() private {
require(_status != _ENTERED, "ReentrancyGuard: reentrant call");
_status = _ENTERED;
}
function _nonReentrantAfter() private {
_status = _NOT_ENTERED;
}
}
文件 15 的 15: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);
}
}
{
"compilationTarget": {
"contracts/CNCCSeller.sol": "CNCCSeller"
},
"evmVersion": "paris",
"libraries": {},
"metadata": {
"bytecodeHash": "ipfs"
},
"optimizer": {
"enabled": true,
"runs": 100
},
"remappings": []
}
[{"inputs":[{"internalType":"contract ICryptNinjaChildrenCoin","name":"_cncc","type":"address"},{"internalType":"contract ICryptNinjaChildren","name":"_cnc","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"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":"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":true,"internalType":"address","name":"user","type":"address"},{"indexed":false,"internalType":"uint256","name":"burnTokenId","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"mintTokenId","type":"uint256"}],"name":"burninEvent","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":false,"internalType":"uint256","name":"afterTokenId","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"exchangeCoinToMakimonoEvent","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":false,"internalType":"uint256","name":"beforeTokenId","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"afterTokenId","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"exchangeMakimonoToCharacterEvent","type":"event"},{"inputs":[],"name":"ADMIN","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"CHARACTER_KANEKO_TOKEN_ID","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"CHARACTER_SARAO_TOKEN_ID","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"CHARACTER_SATORU_TOKEN_ID","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"COIN_TOKEN_ID","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"DEFAULT_ADMIN_ROLE","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"KATASIRO_TOKEN_ID","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MAKIMONO_CHI_TOKEN_ID","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MAKIMONO_KAI_TOKEN_ID","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MAKIMONO_TEN_TOKEN_ID","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_tokenId","type":"uint256"},{"internalType":"uint256","name":"_mintAmount","type":"uint256"},{"internalType":"address","name":"_to","type":"address"}],"name":"adminMint","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"_airdropAddresses","type":"address[]"},{"internalType":"uint256","name":"_tokenId","type":"uint256"},{"internalType":"uint256[]","name":"_userMintAmount","type":"uint256[]"}],"name":"airdropMint","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256[]","name":"_CNCTokenIds","type":"uint256[]"}],"name":"burnin","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"cnc","outputs":[{"internalType":"contract ICryptNinjaChildren","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"cncNextTokenId","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"cncc","outputs":[{"internalType":"contract ICryptNinjaChildrenCoin","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"exchangeCoinToKatasiro","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"exchangeCoinToMakimono","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256[]","name":"_burnTokenIds","type":"uint256[]"},{"internalType":"uint256[]","name":"_amounts","type":"uint256[]"}],"name":"exchangeMakimonoToCharacter","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"exchangeTokenIdMap","outputs":[{"internalType":"uint256","name":"","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":"_address","type":"address"}],"name":"getUserMintedAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"grantAdmin","outputs":[],"stateMutability":"nonpayable","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":"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":"_mintAmount","type":"uint256"},{"internalType":"uint248","name":"_wlCount","type":"uint248"},{"internalType":"bytes32[]","name":"_merkleProof","type":"bytes32[]"}],"name":"mint","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"","type":"address"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"bytes","name":"","type":"bytes"}],"name":"onERC721Received","outputs":[{"internalType":"bytes4","name":"","type":"bytes4"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pauseData","outputs":[{"internalType":"bool","name":"coinMint","type":"bool"},{"internalType":"bool","name":"exchangeCoinToMakimono","type":"bool"},{"internalType":"bool","name":"exchangeMakimonoToCharacter","type":"bool"},{"internalType":"bool","name":"exchangeCoinToKatasiro","type":"bool"},{"internalType":"bool","name":"burnin","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"phaseId","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"phaseStructMap","outputs":[{"internalType":"uint256","name":"totalSupply","type":"uint256"},{"internalType":"uint256","name":"maxSupply","type":"uint256"},{"internalType":"uint256","name":"cost","type":"uint256"},{"internalType":"uint256","name":"maxMintAmountPerTransaction","type":"uint256"},{"internalType":"bytes32","name":"merkleRoot","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"renounceRole","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"revokeAdmin","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":"_newCost","type":"uint256"}],"name":"setCost","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_beforeTokenId","type":"uint256"},{"internalType":"uint256","name":"_afterTokenId","type":"uint256"}],"name":"setExchangeTokenIdMap","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_maxMintAmountPerTransaction","type":"uint256"}],"name":"setMaxMintAmountPerTransaction","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_maxSupply","type":"uint256"}],"name":"setMaxSupply","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"_merkleRoot","type":"bytes32"}],"name":"setMerkleRoot","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_isPause","type":"bool"}],"name":"setPauseBurnin","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_isPause","type":"bool"}],"name":"setPauseCoinMint","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_isPause","type":"bool"}],"name":"setPauseExchangeCoinToKatasiro","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_isPause","type":"bool"}],"name":"setPauseExchangeCoinToMakimono","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_isPause","type":"bool"}],"name":"setPauseExchangeMakimonoToCharacter","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"},{"internalType":"uint256","name":"_maxSupply","type":"uint256"},{"internalType":"uint256","name":"_cost","type":"uint256"},{"internalType":"uint256","name":"_maxMintAmountPerTransaction","type":"uint256"},{"internalType":"bytes32","name":"_merkleRoot","type":"bytes32"}],"name":"setPhaseData","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"setPhaseId","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":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"}]