Nekr Profile picture
Dec 12, 2022 26 tweets 9 min read Read on X
[#CALENDRIER DE L'AVENT 12/25]

25 jours pour apprendre à développer des Smart Contracts en #Solidity 🔥

Jour 12 / 25 :

Création #ERC721 : Mise en place de la whitelist ! C'est l'une des plus grosses journées de notre calendrier 💪

🧵
Aujourd'hui nous attaquons une des parties les plus complexes de notre contrat... la gestion de la whitelist !

Nous allons utiliser un des composants de base de la blockchain (et indispensable) de la blockchain, les arbres de Merkle !

Nous allons voir pourquoi !
Petit rappel de ce qu'est une whitelist pour notre projet :

C'est une liste qui permet de définir si une personne a le droit de mint pendant une certaine phase.

Dans notre cas, la whitelist permet de mint avant la phase ouverte au public et à un prix avantageux !
Mais alors, ne suffirait-il pas d'utiliser un "mapping" qui lie une adresse à un booléen afin de déclarer qu'une adresse est sur la whitelist ?

Avec une fonction accessible au propriétaire pour gérer qui est whitelist ou non, comme ceci ?

🔽 Image
Et si vous avez répondu oui, vous avez raison !

C'est en effet une très bonne solution pour identifier des adresses ayant le droit de mint en avance !

Sauf si vous avez 500/1000 adresses à renseigner, ça serait très long et surtout très très cher...
Même si notre projet ne comporte que 20 NFTs, nous allons quand même utiliser une solution plus robuste et moins cher :

Celle de l'arbre de Merkle.

Mais qu'est-ce que c'est ?

🔽
C'est un sujet très technique.

Vous pouvez mettre en place cette solution sans connaitre tous ses recoins, mais il faut comprendre le principe de base.

Heureusement, @0xKaelSensei a fait un super thread sur ce sujet, vous devez le lire avant la suite !

Et vous abonnez à lui !
Comme d'habitude, si vous avez manqué le jour d'hier ou que vous souhaitez repartir au propre, vous pouvez repartir du code présent dans le répertoire "Jour12/NekrIsERC721_Jour12.sol" Image
Vous pouvez stocker vos adresses comme vous le souhaitez pour la whitelist, le but est juste de pouvoir itérer dessus grâce à un script Java.

Personnellement, j'utilise du ".json" et j'ai mis un template à disposition dans le dossier "assets/whitelist.json". Image
À partir de cette liste, nous allons devoir générer :

- La racine de Merkle qui sera stocké sur le contrat.
- La preuve de Merkle que nous devrons passer en argument de la fonction de mint.

Dans un premier temps, nous allons apprendre à générer la racine de Merkle

🔽
Le script pour générer la racine de Merkle est disponible dans le répertoire "scripts/GenerateMerkle.ts".

Le script parcourt les adresses pour les ajouter dans un tableau, puis grâce à "MerkleTreeJs" & "keccak256" il va générer les feuilles de l'arbre de Merkle et sa racine. Image
C'est cette racine que nous passerons dans l'argument "_merkleRoot" dans le constructeur créé hier !

Très important à savoir, il faut régénérer une racine de Merkle à chaque ajout/retrait d'adresse dans la liste, car la racine changera du tout au tout ! Image
Il faut rajouter deux lignes à notre script pour récupérer la preuve de Merkle pour une adresse.

Pour se faire, il faut repartir de l'arbre et passer une adresse pour générer la preuve 🔽

C'est l'exercice que devra faire la dApp pour permettre aux utilisateurs de mint ! Image
Voici le résultat lorsque je lance le script via la commande :

"node .scripts/GenerateMerkle.ts"

Nous récupérons la racine de Merkle qui sera stocké sur le contrat dans la variable "merkleRoot".

Nous récupérons aussi la preuve qui devra être passé à la fonction de mint ! Image
Important :

Votre application qui permet à vos utilisateurs de mint doit avoir la même liste que celle qui a permis de générer la racine de Merkle sur le contrat !

Si ce n'est pas le cas, les preuves qu'elle va générer ne seront pas bonnes !
Pour information, voici ce qu'est la "preuve" si l'adresse n'est pas sur la liste : un tableau vide !

Nous avons vu ce qui était à faire off-chain pour la whitelist, c'est dense, si vous n'avez pas tout compris, pas de panique !

Lisez les scripts, ça va venir vite en utilisant! Image
Revenons sur Solidity, nous allons pouvoir implémenter tout ce qui est en rapport avec la whitelist sur notre contrat.

On commence avec une fonction simple, comme celles pour modifier les prix que nous avons fait hier.

Celle-ci permet de mettre à jour notre racine de Merkle ! Image
Nous allons devoir implémenter trois fonctions afin de vérifier si une adresse est whitelist grâce à une preuve de Merkle.

Nous pourrions tout faire dans une seule fonction, mais il est plus simple de comprendre le fonctionnement en découpant la logique en trois parties. Image
La première fonction à implémenter est la fonction "_leaf()".

C'est une fonction "internal" donc interne au contrat.

Elle est de type "pure" car elle ne manipule pas de donnée inscrite sur la blockchain.

Elle renvoie le hash de l'adresse passé en paramètre au format "bytes32". Image
La fonction "_verify" est aussi une vue "internal".

Elle prend en paramètre la feuille précédemment créée et une preuve.

Elle se sert de la librairie "MerkleProof" d'OpenZeppelin afin de vérifier la preuve et renvoie "true" ou "false" si l'utilisateur est whitelist ou non. Image
On fini par mettre en place une vue "public" qui :

- Appelle la fonction "_leaf()" avec une adresse spécifique
- Appelle la fonction "_verify()" avec le retour de "_leaf()"
- Retourne le résultat de "_verify()" : "true" ou "false"

Et nous saurons si l'utilisateur est whitelist! Image
Et c'est fini pour les fonctions en rapport avec la whitelist dans notre contrat.

Lorsque nous souhaitons savoir si un utilisateur est whitelist, il nous suffira d'appeler la fonction "isWhitelisted()" avec l'adresse de la personne et la preuve envoyé à la fonction.
Pour rappel, cette preuve sera généré par l'application qui possède la liste exacte !

Côté frais de gas, il nous suffit de stocker une variable "merkleRoot" pour gérer toute la whitelist, nous n'avons pas à stocker x adresses, ce qui serait bien trop couteux !
C'était une des journées les plus denses du calendrier !

Si vous avez des questions, les commentaires sont là pour échanger.

Il existe aussi beaucoup de vidéos sur internet pour expliquer plus en profondeur le principe d'arbre de Merkle si vous avez soif de savoir !
On se retrouve dès demain pour parler métadonnées !

Si l'initiative vous plait, vous pouvez me soutenir avec un j'aime et un retweet sur le tweet principal.

N'hésitez pas à vous abonner pour ne pas rater les prochains jours ! 🔥

• • •

Missing some Tweet in this thread? You can try to force a refresh
 

Keep Current with Nekr

Nekr Profile picture

Stay in touch and get notified when new unrolls are available from this author!

Read all threads

This Thread may be Removed Anytime!

PDF

Twitter may remove this content at anytime! Save it as PDF for later use!

Try unrolling a thread yourself!

how to unroll video
  1. Follow @ThreadReaderApp to mention us!

  2. From a Twitter thread mention us with a keyword "unroll"
@threadreaderapp unroll

Practice here first or read more on our help page!

More from @0xNekr

Jul 26, 2023
[APPRENDRE]

Expliquer la #Blockchain à un enfant de 10 ans.

L'objectif, comprendre les grands concepts de la blockchain en 5 minutes comme si vous étiez un enfant.

C'est LE guide à partager à qui tu souhaites expliquer la décentralisation.

🧵 Image
Avant de commencer, le contenu de ce thread existe de manière plus complète et détaillée sur mon blog "explorations blockchain".

Tu peux retrouver l'article en cliquant sur ce lien :

explorations-blockchain.com/2023/07/26/la-…
Est-ce que tu peux m'expliquer ce que c'est concrètement la blockchain ?

C'est une question que mon entourage m'a beaucoup posé, il est difficile de le faire sans utiliser des mots techniques et complexes.

Alors voici ma manière d'expliquer la blockchain, même à un enfant.

🔽
Read 16 tweets
Mar 15, 2023
[#THREAD]

👋

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...

Les #stablecoins !

Des tokens indexés au cours de l'USD qui (en théorie) ne varient pas.

Mais est-ce possible de mint des NFTs en échange de stablecoins ?
Read 16 tweets
Dec 25, 2022
[#GIVEAWAY DE NOËL]

On a passé 24 jours à apprendre Solidity, merci de m'avoir suivi ! Aujourd'hui, c'est moi qui vous offre quelque chose :

Un free mint du projet @Marmottoshis 🎁 (77.7$) :

- Retweet & Like (ce tweet et le thread cité)
- Follow @Marmottoshis & @0xNekr

🧵
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 !
D'ailleurs, maintenant que vous avez bien suivi mon calendrier, vous pouvez vous exercer en lisant mon code pour le projet et me faire vos retours !

Un code 100% transparent avant le déploiement c'est l'assurance d'un projet sérieux !

github.com/Marmottoshis/S…
Read 4 tweets
Dec 25, 2022
[#CALENDRIER DE L'AVENT 25/25]

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 !
Read 31 tweets
Dec 24, 2022
[#CALENDRIER DE L'AVENT 24/25]

25 jours pour apprendre à développer des Smart Contracts en #Solidity 🔥

Jour 24 / 25 :

Déploiement de tous nos contrats, nous allons pouvoir déployer l'ensemble de notre travail sur la blockchain ! 🎊

🧵
Avant de commencer, vous pouvez récupérer l'ensemble des trois contrats dans le répertoire "solutions" ainsi que le script de déploiement.

Si vous ne les avez pas dans votre projet : git pull.
Read 24 tweets
Dec 23, 2022
[#CALENDRIER DE L'AVENT 23/25]

25 jours pour apprendre à développer des Smart Contracts en #Solidity 🔥

Jour 23 / 25 :

Staking : Comment récupérer la liste des tokens stakés par un utilisateur ? C'est ce que nous allons mettre en place aujourd'hui 💪

🧵
Avant de commencer, vous pouvez repartir du code développé hier.

Il est présent dans le répertoire "Jour23/Staking_Jour23.sol".

N’oubliez pas de modifier les noms et les imports.

Si vous n'avez pas ce répertoire : git pull.
Read 18 tweets

Did Thread Reader help you today?

Support us! We are indie developers!


This site is made by just two indie developers on a laptop doing marketing, support and development! Read more about the story.

Become a Premium Member ($3/month or $30/year) and get exclusive features!

Become Premium

Don't want to be a Premium member but still want to support us?

Make a small donation by buying us coffee ($5) or help with server cost ($10)

Donate via Paypal

Or Donate anonymously using crypto!

Ethereum

0xfe58350B80634f60Fa6Dc149a72b4DFbc17D341E copy

Bitcoin

3ATGMxNzCUFzxpMCHL5sWSt4DVtS8UqXpi copy

Thank you for your support!

Follow Us!

:(