首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >合同只适用于业主

合同只适用于业主
EN

Stack Overflow用户
提问于 2022-08-31 17:23:26
回答 1查看 152关注 0票数 -1

我有一份合同我已经查过了。然而,当我试图从所有人以外的人那里铸币时,它失败了,我哪里出错了?

代码语言:javascript
复制
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.2;

import "@openzeppelin/contracts@4.4.2/token/ERC721/ERC721.sol";
import "@openzeppelin/contracts@4.4.2/token/ERC721/extensions/ERC721Enumerable.sol";
import "@openzeppelin/contracts@4.4.2/access/Ownable.sol";
import "@openzeppelin/contracts/utils/Counters.sol";


contract MyToken is ERC721, ERC721Enumerable, Ownable {
    
    using Strings for uint256;

        using Counters for Counters.Counter;

        Counters.Counter private _tokenIds;

        string public baseURI;
        string public baseExtension = ".json";
        uint256 public cost = 0.03 ether;
        uint256 public maxSupply = 1000;
        uint256 public maxMintAmount = 5;
        bool public paused = false;
    

    string public contractURI;
    uint96 royaltyFeesInBips;
    address royaltyAddress;

    constructor(string memory _name,
            string memory _symbol,
            string memory _initBaseURI,
            uint96 _royaltyFeesInBips
             ) ERC721(_name, _symbol) {
            setBaseURI(_initBaseURI);
            mint(msg.sender, 1);
        royaltyFeesInBips = _royaltyFeesInBips;
        royaltyAddress = owner();
        contractURI = _initBaseURI;
       
    }

    // internal
        function _baseURI() internal view virtual override returns (string memory) {
            return baseURI;
        }

        // public
        function mint(address _to, uint256 _mintAmount) public payable {
            uint256 supply = totalSupply();
            require(!paused);
            require(_mintAmount > 0);
            require(_mintAmount <= maxMintAmount);
            require(supply + _mintAmount <= maxSupply);

            

            for (uint256 i = 1; i <= _mintAmount; i++) {
            _safeMint(_to, supply + i);
            _tokenIds.increment();
            }
        }


        function count() public view returns (uint256){
            return _tokenIds.current();
        }

        function walletOfOwner(address _owner)
            public
            view
            returns (uint256[] memory)
        {
            uint256 ownerTokenCount = balanceOf(_owner);
            uint256[] memory tokenIds = new uint256[](ownerTokenCount);
            for (uint256 i; i < ownerTokenCount; i++) {
            tokenIds[i] = tokenOfOwnerByIndex(_owner, i);
            }
            return tokenIds;
        }

        function tokenURI(uint256 tokenId)
            public
            view
            virtual
            override
            returns (string memory)
        {
            require(
            _exists(tokenId),
            "ERC721Metadata: URI query for nonexistent token"
            );

            string memory currentBaseURI = _baseURI();
            return bytes(currentBaseURI).length > 0
                ? string(abi.encodePacked(currentBaseURI, tokenId.toString(), baseExtension))
                : "";
        }


    //only owner
        function setCost(uint256 _newCost) public onlyOwner() {
            cost = _newCost;
        }

        function setmaxMintAmount(uint256 _newmaxMintAmount) public onlyOwner() {
            maxMintAmount = _newmaxMintAmount;
        }

        function setBaseURI(string memory _newBaseURI) public onlyOwner {
            baseURI = _newBaseURI;
        }

        function setBaseExtension(string memory _newBaseExtension) public onlyOwner {
            baseExtension = _newBaseExtension;
        }

        function pause(bool _state) public onlyOwner {
            paused = _state;
        }


        function withdraw() public payable onlyOwner {
            require(payable(msg.sender).send(address(this).balance));
        }

        
    function safeMint(address to, uint256 tokenId) public onlyOwner {
        _safeMint(to, tokenId);
    }

    function setRoyaltyInfo(address _receiver, uint96 _royaltyFeesInBips) public onlyOwner {
        royaltyAddress = _receiver;
        royaltyFeesInBips = _royaltyFeesInBips;
    }

    function setContractURI(string calldata _contractURI) public onlyOwner {
        contractURI = _contractURI;
    }

    // The following functions are overrides required by Solidity.
    function _beforeTokenTransfer(address from, address to, uint256 tokenId)
        internal
        override(ERC721, ERC721Enumerable)
    {
        super._beforeTokenTransfer(from, to, tokenId);
    }

    function royaltyInfo( uint256 _salePrice)
        external
        view
        virtual
        
        returns (address, uint256)
    {
        return (royaltyAddress, calculateRoyalty(_salePrice));
    }

    function calculateRoyalty(uint256 _salePrice) view public returns (uint256) {
        return (_salePrice / 10000) * royaltyFeesInBips;
    }

    function supportsInterface(bytes4 interfaceId)
            public
            view
            override(ERC721, ERC721Enumerable)
            returns (bool)
    {
        return interfaceId == 0x2a55205a || super.supportsInterface(interfaceId);
    }
}
EN

回答 1

Stack Overflow用户

发布于 2022-08-31 18:40:25

首先,您需要在智能契约中存储所有者地址。

您可以访问全局变量msg.sender;

谁是精明的合同部署者,在其他意义上是所有者;

代码语言:javascript
复制
constructor(){
  owner = msg.sender;
}

在mint函数中检查此要求。

代码语言:javascript
复制
require(owner == address(msg.sender);

或者,您可以将修饰符函数用于调用方是否是所有者。

或者您可以使用OpenZeppelin Ownable.sol

Cick 这里

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73559689

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档