123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137 |
- // SPDX-License-Identifier: MIT
- // OpenZeppelin Contracts v4.4.1 (token/ERC721/presets/ERC721PresetMinterPauserAutoId.sol)
- pragma solidity ^0.8.0;
- import "../ERC721.sol";
- import "../extensions/ERC721Enumerable.sol";
- import "../extensions/ERC721Burnable.sol";
- import "../extensions/ERC721Pausable.sol";
- import "../../../access/AccessControlEnumerable.sol";
- import "../../../utils/Context.sol";
- import "../../../utils/Counters.sol";
- /**
- * @dev {ERC721} token, including:
- *
- * - ability for holders to burn (destroy) their tokens
- * - a minter role that allows for token minting (creation)
- * - a pauser role that allows to stop all token transfers
- * - token ID and URI autogeneration
- *
- * This contract uses {AccessControl} to lock permissioned functions using the
- * different roles - head to its documentation for details.
- *
- * The account that deploys the contract will be granted the minter and pauser
- * roles, as well as the default admin role, which will let it grant both minter
- * and pauser roles to other accounts.
- */
- contract ERC721PresetMinterPauserAutoId is
- Context,
- AccessControlEnumerable,
- ERC721Enumerable,
- ERC721Burnable,
- ERC721Pausable
- {
- using Counters for Counters.Counter;
- bytes32 public constant MINTER_ROLE = keccak256("MINTER_ROLE");
- bytes32 public constant PAUSER_ROLE = keccak256("PAUSER_ROLE");
- Counters.Counter private _tokenIdTracker;
- string private _baseTokenURI;
- /**
- * @dev Grants `DEFAULT_ADMIN_ROLE`, `MINTER_ROLE` and `PAUSER_ROLE` to the
- * account that deploys the contract.
- *
- * Token URIs will be autogenerated based on `baseURI` and their token IDs.
- * See {ERC721-tokenURI}.
- */
- constructor(
- string memory name,
- string memory symbol,
- string memory baseTokenURI
- ) ERC721(name, symbol) {
- _baseTokenURI = baseTokenURI;
- _setupRole(DEFAULT_ADMIN_ROLE, _msgSender());
- _setupRole(MINTER_ROLE, _msgSender());
- _setupRole(PAUSER_ROLE, _msgSender());
- }
- function _baseURI() internal view virtual override returns (string memory) {
- return _baseTokenURI;
- }
- /**
- * @dev Creates a new token for `to`. Its token ID will be automatically
- * assigned (and available on the emitted {IERC721-Transfer} event), and the token
- * URI autogenerated based on the base URI passed at construction.
- *
- * See {ERC721-_mint}.
- *
- * Requirements:
- *
- * - the caller must have the `MINTER_ROLE`.
- */
- function mint(address to) public virtual {
- require(hasRole(MINTER_ROLE, _msgSender()), "ERC721PresetMinterPauserAutoId: must have minter role to mint");
- // We cannot just use balanceOf to create the new tokenId because tokens
- // can be burned (destroyed), so we need a separate counter.
- _mint(to, _tokenIdTracker.current());
- _tokenIdTracker.increment();
- }
- /**
- * @dev Pauses all token transfers.
- *
- * See {ERC721Pausable} and {Pausable-_pause}.
- *
- * Requirements:
- *
- * - the caller must have the `PAUSER_ROLE`.
- */
- function pause() public virtual {
- require(hasRole(PAUSER_ROLE, _msgSender()), "ERC721PresetMinterPauserAutoId: must have pauser role to pause");
- _pause();
- }
- /**
- * @dev Unpauses all token transfers.
- *
- * See {ERC721Pausable} and {Pausable-_unpause}.
- *
- * Requirements:
- *
- * - the caller must have the `PAUSER_ROLE`.
- */
- function unpause() public virtual {
- require(hasRole(PAUSER_ROLE, _msgSender()), "ERC721PresetMinterPauserAutoId: must have pauser role to unpause");
- _unpause();
- }
- function _beforeTokenTransfer(
- address from,
- address to,
- uint256 tokenId
- ) internal virtual override(ERC721, ERC721Enumerable, ERC721Pausable) {
- super._beforeTokenTransfer(from, to, tokenId);
- }
- /**
- * @dev See {IERC165-supportsInterface}.
- */
- function supportsInterface(bytes4 interfaceId)
- public
- view
- virtual
- override(AccessControlEnumerable, ERC721, ERC721Enumerable)
- returns (bool)
- {
- return super.supportsInterface(interfaceId);
- }
- }
|