-
Notifications
You must be signed in to change notification settings - Fork 5
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #25 from axieinfinity/implement-feature/adapt-oz-v…
…5/merge-with-release-0.2.0 feat: resolve conflicts caused by merging with release/v0.2.0 branch
- Loading branch information
Showing
18 changed files
with
576 additions
and
67 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,145 @@ | ||
// SPDX-License-Identifier: MIT | ||
// Compatible with OpenZeppelin Contracts ^5.0.0 | ||
pragma solidity ^0.8.20; | ||
|
||
import { AccessControlEnumerable } from "@openzeppelin/contracts/access/extensions/AccessControlEnumerable.sol"; | ||
import { IERC165 } from "@openzeppelin/contracts/interfaces/IERC165.sol"; | ||
import { ERC1155 } from "@openzeppelin/contracts/token/ERC1155/ERC1155.sol"; | ||
|
||
import { IERC1155Common } from "./interfaces/IERC1155Common.sol"; | ||
import { ERC1155Burnable } from "@openzeppelin/contracts/token/ERC1155/extensions/ERC1155Burnable.sol"; | ||
import { ERC1155Pausable } from "@openzeppelin/contracts/token/ERC1155/extensions/ERC1155Pausable.sol"; | ||
import { ERC1155Supply } from "@openzeppelin/contracts/token/ERC1155/extensions/ERC1155Supply.sol"; | ||
import { Strings } from "@openzeppelin/contracts/utils/Strings.sol"; | ||
|
||
contract ERC1155Common is | ||
ERC1155, | ||
AccessControlEnumerable, | ||
ERC1155Pausable, | ||
ERC1155Burnable, | ||
ERC1155Supply, | ||
IERC1155Common | ||
{ | ||
using Strings for uint256; | ||
|
||
bytes32 public constant URI_SETTER_ROLE = keccak256("URI_SETTER_ROLE"); | ||
bytes32 public constant PAUSER_ROLE = keccak256("PAUSER_ROLE"); | ||
bytes32 public constant MINTER_ROLE = keccak256("MINTER_ROLE"); | ||
|
||
string private _name; | ||
string private _symbol; | ||
|
||
constructor(address admin, string memory name_, string memory symbol_, string memory uri_) ERC1155(uri_) { | ||
_grantRole(DEFAULT_ADMIN_ROLE, admin); | ||
_grantRole(PAUSER_ROLE, admin); | ||
_grantRole(MINTER_ROLE, admin); | ||
_grantRole(URI_SETTER_ROLE, admin); | ||
|
||
_name = name_; | ||
_symbol = symbol_; | ||
} | ||
|
||
/** | ||
* @dev Set the URI for all token types. | ||
* Requirements: | ||
* - the caller must have the `URI_SETTER_ROLE`. | ||
*/ | ||
function setURI( | ||
string memory newURI | ||
) external onlyRole(URI_SETTER_ROLE) { | ||
_setURI(newURI); | ||
} | ||
|
||
/** | ||
* @dev Pauses all token transfers. | ||
* Requirements: | ||
* - the caller must have the `PAUSER_ROLE`. | ||
*/ | ||
function pause() external onlyRole(PAUSER_ROLE) { | ||
_pause(); | ||
} | ||
|
||
/** | ||
* @dev Unpauses all token transfers. | ||
* Requirements: | ||
* - the caller must have the `PAUSER_ROLE`. | ||
*/ | ||
function unpause() external onlyRole(PAUSER_ROLE) { | ||
_unpause(); | ||
} | ||
|
||
/// @inheritdoc IERC1155Common | ||
function mint(address account, uint256 id, uint256 amount, bytes calldata data) public virtual onlyRole(MINTER_ROLE) { | ||
_mint(account, id, amount, data); | ||
} | ||
|
||
/// @inheritdoc IERC1155Common | ||
function mintBatch( | ||
address to, | ||
uint256[] calldata ids, | ||
uint256[] calldata amounts, | ||
bytes calldata data | ||
) public virtual onlyRole(MINTER_ROLE) { | ||
_mintBatch(to, ids, amounts, data); | ||
} | ||
|
||
/** | ||
* @dev Mint single token to multiple addresses. | ||
* Requirements: | ||
* - the caller must have the `MINTER_ROLE`. | ||
*/ | ||
function bulkMint( | ||
uint256 id, | ||
address[] calldata tos, | ||
uint256[] calldata amounts, | ||
bytes[] calldata datas | ||
) public virtual onlyRole(MINTER_ROLE) { | ||
uint256 length = tos.length; | ||
require(length != 0 && length == amounts.length && length == datas.length, "ERC1155: invalid array lengths"); | ||
|
||
for (uint256 i; i < length; ++i) { | ||
_mint(tos[i], id, amounts[i], datas[i]); | ||
} | ||
} | ||
|
||
/** | ||
* @dev See {ERC1155-uri}. | ||
*/ | ||
function uri( | ||
uint256 tokenId | ||
) public view virtual override returns (string memory) { | ||
string memory uri_ = super.uri(tokenId); | ||
return string.concat(uri_, tokenId.toString()); | ||
} | ||
|
||
/// @inheritdoc IERC1155Common | ||
function name() public view virtual returns (string memory) { | ||
return _name; | ||
} | ||
|
||
/// @inheritdoc IERC1155Common | ||
function symbol() public view virtual returns (string memory) { | ||
return _symbol; | ||
} | ||
|
||
/** | ||
* @dev See {ERC165-supportsInterface}. | ||
*/ | ||
function supportsInterface( | ||
bytes4 interfaceId | ||
) public view virtual override(IERC165, ERC1155, AccessControlEnumerable) returns (bool) { | ||
return interfaceId == type(IERC1155Common).interfaceId || super.supportsInterface(interfaceId); | ||
} | ||
|
||
/** | ||
* @dev See {ERC1155-_update}. | ||
*/ | ||
function _update( | ||
address from, | ||
address to, | ||
uint256[] memory ids, | ||
uint256[] memory values | ||
) internal virtual override(ERC1155, ERC1155Supply, ERC1155Pausable) { | ||
super._update(from, to, ids, values); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,51 @@ | ||
// SPDX-License-Identifier: UNLICENSED | ||
pragma solidity ^0.8.0; | ||
|
||
import { IAccessControlEnumerable } from "@openzeppelin/contracts/access/extensions/IAccessControlEnumerable.sol"; | ||
import { IERC1155 } from "@openzeppelin/contracts/token/ERC1155/IERC1155.sol"; | ||
|
||
interface IERC1155Common is IAccessControlEnumerable, IERC1155 { | ||
/// @dev Return the name of the collection. | ||
function name() external view returns (string memory); | ||
|
||
/// @dev Return the symbol of the collection. | ||
function symbol() external view returns (string memory); | ||
|
||
/** | ||
* @dev Mints a single ERC1155 token and assigns it to the specified address. | ||
* | ||
* Requirements: | ||
* - the caller must have the `MINTER_ROLE`. | ||
* | ||
* @param to The address to which the minted token will be assigned. | ||
* @param id The ID of the token to mint. | ||
* @param amount The amount of tokens to mint. | ||
* @param data Additional data with no specified format. | ||
*/ | ||
function mint(address to, uint256 id, uint256 amount, bytes calldata data) external; | ||
|
||
/** | ||
* @dev Mints multiple ERC1155 tokens and assigns them to the specified address. | ||
* | ||
* Requirements: | ||
* - the caller must have the `MINTER_ROLE`. | ||
* | ||
* @param to The address to which the minted tokens will be assigned. | ||
* @param ids The IDs of the tokens to mint. | ||
* @param amounts The amounts of tokens to mint. | ||
* @param data Additional data with no specified format. | ||
*/ | ||
function mintBatch(address to, uint256[] calldata ids, uint256[] calldata amounts, bytes calldata data) external; | ||
|
||
/** | ||
* @dev Mint single token to multiple addresses. | ||
* Requirements: | ||
* - the caller must have the `MINTER_ROLE`. | ||
* | ||
* @param id The ID of the token to mint. | ||
* @param tos The addresses to which the minted tokens will be assigned. | ||
* @param amounts The amounts of tokens to mint. | ||
* @param datas Additional data with no specified format. | ||
*/ | ||
function bulkMint(uint256 id, address[] calldata tos, uint256[] calldata amounts, bytes[] calldata datas) external; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
// SPDX-License-Identifier: MIT | ||
pragma solidity ^0.8.19; | ||
|
||
/// @dev Interface for the NFT contract that compatible with the contract MavisPresale. | ||
/// MUST be included ERC165 interface to support the detection of the contract's capabilities. | ||
interface INFTPresale { | ||
/** | ||
* @dev Mint NFTs for the presale. | ||
* | ||
* Requirements: | ||
* - The mintedTokenIds and mintedAmounts should have the same length. | ||
* - The mintedTokenIds array should be unique. | ||
* - For ERC721 NFTs, each minted token's quantity should always be 1. | ||
* - For ERC1155 NFTs, each minted token's quantity should be actual minted amounts. | ||
* - The total of minted amounts can be different from the input `quantity`. | ||
* | ||
* Examples: | ||
* - ERC1155: If mintedTokenIds = [1, 2], then mintedAmounts = [10, 20] | ||
* - ERC721: If mintedTokenIds = [1, 2], then mintedAmounts = [1, 1] | ||
* | ||
* @param to The address to mint the NFTs to. | ||
* @param quantity The quantity of NFTs to mint. | ||
* @param extraData The extra data for further customization. | ||
* @return mintedTokenIds The token IDs of the minted NFTs. | ||
* @return mintedAmounts The minted amounts according to the `mintedTokenIds`. | ||
*/ | ||
function mintPresale(address to, uint256 quantity, bytes calldata extraData) | ||
external | ||
returns (uint256[] memory mintedTokenIds, uint256[] memory mintedAmounts); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
// SPDX-License-Identifier: MIT | ||
pragma solidity ^0.8.22; | ||
|
||
import { IERC165 } from "@openzeppelin/contracts/interfaces/IERC165.sol"; | ||
|
||
import { INFTPresale } from "../interfaces/launchpad/INFTPresale.sol"; | ||
|
||
abstract contract NFTPresaleCommon is IERC165, INFTPresale { | ||
/// @dev Returns whether the contract supports the NFT presale interface. | ||
function supportsInterface(bytes4 interfaceId) public view virtual returns (bool) { | ||
return interfaceId == type(INFTPresale).interfaceId || interfaceId == type(IERC165).interfaceId; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
// SPDX-License-Identifier: UNLICENSED | ||
pragma solidity ^0.8.0; | ||
|
||
import "../ERC1155Common.sol"; | ||
|
||
contract SampleERC1155 is ERC1155Common { | ||
constructor(address admin, string memory name, string memory symbol, string memory uri) | ||
ERC1155Common(admin, name, symbol, uri) | ||
{ } | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
// SPDX-License-Identifier: MIT | ||
pragma solidity ^0.8.19; | ||
|
||
import { NFTLaunchpadCommon } from "../../launchpad/NFTLaunchpadCommon.sol"; | ||
import { SampleERC1155, ERC1155Common } from "../SampleERC1155.sol"; | ||
|
||
contract SampleERC1155Launchpad is SampleERC1155, NFTLaunchpadCommon { | ||
constructor(address admin, string memory name, string memory symbol, string memory uri) | ||
SampleERC1155(admin, name, symbol, uri) | ||
{ } | ||
|
||
/// @dev Mint NFTs for the launchpad. | ||
function mintLaunchpad( | ||
address to, | ||
uint256 quantity, | ||
bytes calldata /* extraData */ | ||
) external onlyRole(MINTER_ROLE) returns (uint256[] memory tokenIds, uint256[] memory amounts) { | ||
_mint(to, 3, quantity, ""); | ||
_mint(to, 4, 1, ""); | ||
|
||
tokenIds = new uint256[](2); | ||
amounts = new uint256[](2); | ||
tokenIds[0] = 3; | ||
tokenIds[1] = 4; | ||
|
||
amounts[0] = quantity; | ||
amounts[1] = 1; | ||
} | ||
|
||
function supportsInterface(bytes4 interfaceId) | ||
public | ||
view | ||
virtual | ||
override(ERC1155Common, NFTLaunchpadCommon) | ||
returns (bool) | ||
{ | ||
return ERC1155Common.supportsInterface(interfaceId) || NFTLaunchpadCommon.supportsInterface(interfaceId); | ||
} | ||
} |
Oops, something went wrong.