Nekr Profile picture
Dec 24, 2022 24 tweets 8 min read Read on X
[#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.
Mais avant tout, même si j'ai développé le script de déploiement pour vous, il est super important de comprendre les étapes et l'ordre de déploiement.

Nous allons détailler tout cela ensemble en reprenant le script pas à pas !
Il faut absolument respecter ces étapes :

1 - Déploiement du contrat ERC721 et ERC20.

2 - Déploiement du contrat Staking avec les adresses des deux précédents en arguments.

3 - Ajout de l'adresse du contrat de Staking avec "addAdmin" du token ERC20.
Je vais commencer par créer une mini-script qui permet de retourner une racine de Merkle comme nous l'avons déjà fait avec le script "GenerateMerkle.ts".

Mais le but ici est de simplement retourner la racine et rien d'autre.

Ce script sera : "GetMerkleRoot.ts".
Nous allons détailler pas à pas les étapes pour le déploiement.

Je ne vais pas parler des logs indicatifs dans le thread, mais tout sera logué dans le script final.

On commence par importer "run" de hardhat ainsi que notre script, et on définit notre fonction "FullContract()".
Notre script va déployer les contrats et les vérifier.

Le souci est que parfois, si on tente de vérifier juste après avoir déployé, alors on a une erreur, car l'explorateur n'a pas le temps de prendre en compte le contrat.

On définit alors une fonction qui permet d'attendre.
L'étape d'après est de récupérer tous les contrats pour être prêt à les déployer.

Pensez à modifier les nommages de vos contrats afin que vous puissiez les récupérer.

On utilise la méthode "getContractFactory" de hardhat qui va récupérer les contrats dans nos contrats compilés.
On définit une constante qui contient l'URI.

Comme nous allons l'utiliser à plusieurs endroits, il est intéressant de la définir dans une variable, nous n'aurons plus qu'à la modifier au besoin.

L'URI que j'ai pris est celui des NFTs BAYC.
On passe ensuite au déploiement du contrat ERC20 (on aurait pu commencer par ERC721, pas d'importance).

Pour cela, on utilise la fonction "deploy()" de hardhat, puis on va utiliser "await" pour attendre que notre contrat soit correctement déployé sur la blockchain.
On attend 5 secondes grâce à "delay" avant de vérifier notre contrat.

Il est dans un "try/catch", car il peut y avoir une erreur si le contrat est déjà vérifié.

C'est possible si vous le déployez deux fois, l'explorateur vérifie un contrat si un identique a déjà été vérifié.
Note :

La vérification demande l'adresse du contrat, ainsi que le "constructorArguments".

Ici, nous n'en avons aucun car le constructeur ne nécessite pas d'argument, ça sera le cas pour le contrat ERC721 et de Staking !
On passe au déploiement ERC721. Pour cela, on commence par récupérer la racine de Merkle grâce à notre script.

Pour rappel, il génère la route avec la whitelist présente dans "assets/whitelist.json".

On déploie ensuite le contrat avec en argument l'URI et la racine de Merkle.
Même combat que pour le contrat ERC20, on attend 5 secondes puis on tente de vérifier le contrat.

Cette fois-ci, nous devons peupler le tableau "constructorArguments" avec l'URI et la racine de Merkle.

Attention, l'ordre a son importance dans le processus !
Vous commencez à comprendre, on passe au déploiement du contrat de Staking.

Cette fois-ci, nous passons en arguments les adresses des deux précédents contrats, que nous pouvons récupérer directement via le ".address".

Attention à l'ordre encore une fois !
Dernière fois, promis !

On attend 5 secondes, puis on vérifie le contrat avec les mêmes arguments du constructeur.

Tout ceci dans un "try/catch" pour éviter que le script s'arrête en cas d'erreur.

Et voilà, tout est déployé !
Dernière étape, super importante !

On utilise notre contrat ERC20 pour ajouter l'adresse de notre contrat de Staking fraichement déployé en tant d'admin via la fonction "addAdmin".

Ceci permettra à notre contrat de Staking de pouvoir "mint" les récompenses des utilisateurs.
Vous le verrez dans mon script dans "FullContract.deploy.ts", il y a beaucoup plus de logs que j'ai rajotué.

Je ne les ai pas spécifiés ici pour gagner de la place.

Mais il y a trois logs que je fais à la fin, c'est afficher les adresses des trois contrats !
Il ne vous reste qu'une étape à faire... déclencher la commande suivante :

yarn hardhat run .\scripts\FullContract.deploy.ts --network polygonMumbai

et attendre le déploiement de tous vos contrats...
Dès que vous avez vos adresses, vous pouvez aller tester tous vos contrats !

N'oubliez pas d'utiliser, avant de staker vos NFTs sur votre contrat, la fonction "setApprovalForAll" du contrat ERC721 à l'adresse du contrat de Staking, sinon, la transaction risque d’échouer !
Et voilà ! Vous avez développé trois contrats, et vous avez pu les déployer sur la blockchain et les vérifier !

Je vous laisse le soin de les tester par vous-même !

Un super exercice serait de développer tous les tests unitaires en reprenant les scripts de test du calendrier.
J'espère que tout cela vous a plu, j'ai donné tout le temps que j'avais afin de vous écrire tous ces threads afin de partager mes connaissances.

Il vous reste énormément à apprendre, mais si vous avez compris ce qu'on a fait ces derniers jours, alors vous avez fait un beau pas!
On se retrouve demain pour la liste de tous les threads qui ont été faits dans un thread de threads, ainsi qu'un petit cadeau de Noël de ma part ! 🎁

À demain, et comme nous sommes le 24 décembre :
joyeux Noël à tous, profitez bien! ❤️

• • •

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 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
Dec 22, 2022
[#CALENDRIER DE L'AVENT 22/25]

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

Jour 22 / 25 :

Staking : Nous savons staker, récupérer les récompenses, il est temps de pouvoir récupérer les NFTs stakés ! 🖼️

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

Il est présent dans le répertoire "Jour22/Staking_Jour22.sol".

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

Si vous n'avez pas ce répertoire : git pull.
Read 17 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!

:(