0xNekr.eth Profile picture
Dec 24 24 tweets 8 min read
[#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 0xNekr.eth

0xNekr.eth 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

Dec 23
[#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
[#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
Dec 21
[#CALENDRIER DE L'AVENT 21/25]

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

Jour 21 / 25 :

Staking : Aujourd'hui nous allons gérer les récompenses du staking, ainsi que le claim de ces récompenses ! 💸

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

Il est présent dans le répertoire "Jour21/Staking_Jour21.sol".

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

Si vous n'avez pas ce répertoire : git pull.
Read 20 tweets
Dec 20
[#CALENDRIER DE L'AVENT 20/25]

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

Jour 20 / 25 :

Staking : Le staking des NFTs ! Comment faire pour que le contrat permette de staker un NFT ? C'est ce que nous allons développer aujourd'hui. 🔥

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

Il est présent dans le répertoire "Jour20/Staking_Jour20.sol".

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

Si vous n'avez pas ce répertoire : git pull.
Read 19 tweets
Dec 19
[#CALENDRIER DE L'AVENT 19/25]

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

Jour 19 / 25 :

Staking : Nous allons entamer notre contrat de staking ! Parlons imports, initialisations et variables.

🧵
Vous savez comment va fonctionner globalement notre contrat de staking, il est temps de le développer !

Allons-y 🔥
Read 12 tweets
Dec 18
[#CALENDRIER DE L'AVENT 18/25]

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

Jour 18 / 25 :

Staking : Comment ça fonctionne ? Qu'est-ce que c'est ? C'est ce que nous allons voir aujourd'hui ! 🔥

🧵
Hier nous avons déployé notre premier contrat ERC20.

Aujourd'hui, nous allons parler staking ! Mais avant tout, nous allons refaire un point sur la globalité de notre projet !

En route 🔥
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 on Twitter!

:(