| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136 | // SPDX-License-Identifier: MITpragma 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);    }}
 |