C’est le grand jour, nous allons attaquer la construction de notre contrat NFT 🔥.
La création de notre contrat va se faire sur plusieurs jours de calendrier, le but est de bien détailler chaque partie !
On se rend directement sur notre IDE préféré, dans le répertoire “contracts” nous allons créer un nouveau fichier Solidity.
Je vous laisse libre du nom de base, mais par habitude, j’aime bien que son nom finisse par la norme qu’il met en place.
Mon contrat : “NekrIsERC721.sol”
Pour la licence du contrat, je vous laisserai vous renseigner si vous avez des besoins spécifiques.
Pour nos contrats nous allons utiliser la licence “MIT” qui correspond à la licence de logiciel pour logiciels libres et open source.
Concernant la version, nous allons prendre la dernière en date. Pour finir, il faut définir le contrat via l’identifieur “contract” suivi du nom que vous lui aurez donné.
⬇️
Nous allons passer aux imports.
Les imports c’est faire appel à du code déjà fait, ici grâce à une librairie très utile dont j’ai déjà parlé régulièrement :
OpenZeppelin.
C’est la librairie pour les développeurs Web3.
Je vous vous détailler à quoi correspond chaque import.
Le premier import est celui d’ERC721.
Comme expliqué hier, ERC721 est la norme qui définit les NFTs. Elle va nous permettre d’avoir accès directement aux fonctions de mint, de transfert, les variables de balance, etc...
Le deuxième import est tout aussi important, il s’agit de “Ownable”.
C’est une librairie qui va vous permettre de gérer la propriété du contrat.
Elle est super utile pour limiter l’accès à certaines fonctions qu’au propriétaire.
Le troisième import est celui de la librairie “Counters”.
Il s’agit d’un compteur qui va nous permettre d’incrémenter une variable qui sera l’ID du NFT que l’on doit “mint”, il s’incrémente et permet de mint les IDs en partant de 0 jusqu’où nous souhaitons.
Vous devez ensuite rajouter la librairie “Strings”.
Son utilité est simple, elle permet de transformer un entier (le numéro du NFT) en chaine de caractères afin de retourner le bon lien vers les métadonnées du NFT, nous y reviendrons bientôt.
Pour finir, il faut rajouter la librairie “MerkleProof”, elle nous permettra de gérer une whitelist à faible coût pour notre collection !
Dernière étape du jour, certaines librairies ont besoin d’être définies sur le contrat, c’est le cas de ERC721 et Ownable.
Il faut donc les rajouter après le nom de votre contrat grâce à l’identifieur “is” comme ceci :
🔽
Et c’est déjà fini pour aujourd’hui !
Mais nous avons déjà bien avancé sur le début de notre contrat. Votre exercice, s’il vous reste du temps aujourd’hui, c’est de bien lire la page Openzeppelin de ces quatre librairies que vous croiserez souvent !
Hier nous avons créé notre premier contrat ERC20. Aujourd'hui le challenge est simple : le déployer sur Mumbai, mint des tokens et l'ajouter à notre wallet pour pouvoir le voir !