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 !
Aujourd'hui, je vais vous montrer comment créer un contrat de NFT qui autorise le paiement en #stablecoin à la place de l'ether pour éviter la volatilité (👀).
Suivez ce thread pour apprendre comment mettre en place cette solution technique simplement.
🧵👇
Mise en situation :
Vous lancez une collection de NFT sur la blockchain #Ethereum... mais vous avez besoin d'un montant très précis, 100$ par NFT, pas plus, pas moins.
Et la se pose un problème, un mint en ether induit forcément la variation du cours...
Heureusement, il existe une solution à votre problème...
Avant tout, je vous conseille de lire le super thread de @TCryptomonnaies sur le projet.
Mais ce n'est pas tout, c'est moi qui ai développé le Smart Contrat, vous comprenez pourquoi je suis très heureux de pouvoir vous offrir ce free mint !
25 jours pour apprendre à développer des Smart Contracts en #Solidity 🔥
Jour 25 / 25 : Récap de l'aventure, et thread de mes 24 threads ! ❤️
Retweet et like ça t'a plu ! 💪
🧵
Avant tout, je tiens à re-remercier énormément @CryptoLidl pour les 25 vidéos illustratives du calendrier !
Il est disponible pour vous assister dans la création de contenu (support visuel, montage, etc.).
Si vous êtes intéressé, n'hésitez pas à le contacter via Twitter.
Je sais que le format Twitter n'est pas l'idéal pour beaucoup, ne vous inquiétez pas, je travaille à passer tout ceci en format article pour que cela soit bien plus simple à suivre/réaliser !