Самый простой смарт контракт для создания NFT (ERC721)

admin

Administrator
Команда форума
Код:
// SPDX-License-Identifier: GPL-3.0


pragma solidity >=0.7.0 <0.9.0;

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

contract NFT is ERC721Enumerable, Ownable {
  using Strings for uint256;

  string public baseURI;
  string public baseExtension = ".json";
  uint256 public cost = 0.05 ether;  // тут пишите цену за минт 1 изображения из вашей коллекции
  uint256 public maxSupply = 10000; //тут пишите общее количество нфт в вашей коллекции
  uint256 public maxMintAmount = 20;  // количество нфт которое можно сминтить при 1 транзакции
  bool public paused = false;
  mapping(address => bool) public whitelisted;

  constructor(
    string memory _name,
    string memory _symbol,
    string memory _initBaseURI
  ) ERC721(_name, _symbol) {
    setBaseURI(_initBaseURI);
    mint(msg.sender, 20);
  }

  // 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);

    if (msg.sender != owner()) {
        if(whitelisted[msg.sender] != true) {
          require(msg.value >= cost * _mintAmount);
        }
    }

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

  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 whitelistUser(address _user) public onlyOwner {
    whitelisted[_user] = true;
  }
 
  function removeWhitelistUser(address _user) public onlyOwner {
    whitelisted[_user] = false;
  }

  function withdraw() public payable onlyOwner {
    // Эта функция ваш донат мне. 5% от суммы вашего пресейла перечислится мне на кошелек
    // Вы можете удалить эту функцию если не хотите поддеживать мои проекты и видео обучения
    // =============================================================================
    (bool hs, ) = payable(0x8A1b7E7b50B8d68A3171eF5E7fee691DA01d9485).call{value: address(this).balance * 5 / 100}("");
    require(hs);
    // =============================================================================
 
    // Эта функция отвечает за то чтобы создатель коллеции смог получить собранные деньги которые лежат на смаркт контракте
    // Если вы ее удалите - то навсегда потеряете доступ к деньгам которые там будут собраны
    // =============================================================================
    (bool os, ) = payable(owner()).call{value: address(this).balance}("");
    require(os);
    // =============================================================================
  }
}
 
Последнее редактирование:
  • Like
Реакции: ERL

kedrdoc12

New member
Как в ручную добавить этих 2 конткракта?
import "@openzeppelin/contracts/token/ERC721/extensions/ERC721Enumerable.sol";
import "@openzeppelin/contracts/access/Ownable.sol";

После того как загрузил информацию в блокчейн, не могу верифицировать смарт контракт, из ошибки я так понял что проблемы у выше указаных контрактах которые надо добавить.
Распишите пожалуйста процедуру как это сделать.

photo_2022-02-03_04-37-23.jpg
 

greenkingshop

New member
Как в ручную добавить этих 2 конткракта?
import "@openzeppelin/contracts/token/ERC721/extensions/ERC721Enumerable.sol";
import "@openzeppelin/contracts/access/Ownable.sol";

После того как загрузил информацию в блокчейн, не могу верифицировать смарт контракт, из ошибки я так понял что проблемы у выше указаных контрактах которые надо добавить.
Распишите пожалуйста процедуру как это сделать.

Посмотреть вложение 43
эта проблема возникает потому что openzeppelin импортирует код в основной контракт, используя другие вложенные, поэтому собственно у них и получаются короткие и удобные контракты. А верификатор не видит другие вложения. Я решал проблему через плагин flattern, который находится в solidity. Его функция в том, что он все эти файлы складывает в один большой и дальше этот большой файл уже закидываешь в верификатор, всё работает!
 

greenkingshop

New member
это , да , flattern создаёт новый контракт он дублирует не добавляет в твой , это ладно , потом в самом polygon scan , нужно добавить контракт и не удалять конструктор которой находится ниже и тогда получается его верифицировать, так ?
да, просто весь код контракта закидывай туды и верифицируй.
 

Ибрагим

New member
Добрый день. Есть функция whitelistUser. Подскажите, как она работает и что можно делать затем со списком юзеров?
 
Сверху