0xNekr.eth Profile picture
Dec 11 20 tweets 7 min read
[#CALENDRIER DE L'AVENT 11/25]

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

Jour 11 / 25 :

Création #ERC721 : Le constructeur, les événements, la récupération de la monnaie et plus !

🧵
Bonjour à tous !

On continue l'avancement de notre contrat ERC721 !

Aujourd'hui, nous allons développer le constructeur, initialiser les événements et ajouter une fonction pour retirer les fonds du contrat !
Si vous avez raté le calendrier d'hier, ou que vous souhaitez commencer à ce stade, vous pouvez repartir du code qui est dans le répertoire "Jour11/NekrIsERC721_Jour11.sol".

N'oubliez pas de tout renommer à votre guise avant de continuer. Image
Passons au constructeur !

Dans notre cas, il est nécessaire de d'initialiser le constructeur de la librairie ERC721 en même temps.

Pour se faire, il faut initialiser le contrat avec le nom et le symbol qu'on souhaite donner à la collection. Image
Ensuite, nous allons passer deux arguments à notre constructeur, l'URI de nos métadonnées et la route de Merkle.

Il est important de typer les arguments des fonctions, nous avons donc "string" et un "bytes32".

Je vous explique bientôt comment générer ces deux arguments ! Image
Je ne sais pas si vous avez remarqué, mais j'ai dû rajouter un identifieur après le type "string".

Cet identifieur est "memory", il signale que cette variable n'est définie que dans la portée de la fonction. Image
Il existe deux autres identifieurs, "calldata" et "storage", voici un article que vous devriez lire à ce sujet :

medium.com/coinmonks/soli…
Et c'est déjà terminé pour notre constructeur 🎉

Nous voulons initialiser deux événements maintenant, un quand un nouveau mint a lieu (pour incrémenter un compteur sur une application par exemple) et un quand on passe à une nouvelle étape de vente (encore pour notre application)
Comment fonctionne un événement ?

C'est assez simple, on le définit sous les variables, au-dessus du constructeur, et on les émet quand on le souhaite dans les fonctions.

Il faut savoir qu'ERC721 implémente beaucoup d'événements, comme les transferts par exemple ! Image
Pour les événement, on précède le nom par l'identifieur "event".

On définit aussi les informations à embarquer.

"newMint" intègre l'adresse de la personne qui mint et le nombre de mint.

"stepUpdated" prend en compte le nouveau step.

On n'oublie pas de typer ses variables ! Image
Une fois déclaré, il ne manquera plus qu'à déclencher l'événement via "emit" au moment voulu.

Nous verrons ça dans la suite du contrat ! Image
Étape suivante, récupérer l'argent présent sur le contrat après le mint.

Pour ça, on va se servir du fait que nous utilisons la librairie "Ownable" pour restreindre l'appelle.

Ensuite on transfère la balance à notre adresse, comme on l'a déjà vu plus tôt dans le calendrier !
🔽
Cette fonction est donc "external", car elle ne sera appelée que de l'extérieur du contrat.

Et "onlyOwner", c'est un "modifier" de la librairie "Ownable" qui s'assure que nous sommes bien le propriétaire.

Et avant le transfert, on vérifie que le contrat possède bien des fonds ! Image
La prochaine fonction servira pour la fonction de mint et pour une potentielle dApp :

Une fonction qui retourne le prix que doit payer l'utilisateur en fonction de l'étape à laquelle nous sommes !

Cette fonction est donc une vue publique qui retourne un entier (le prix). Image
Vous commencez à comprendre, elle est publique, car notre fonction de mint va l'utiliser.

Mais aussi par ce qu'il serait super utile pour notre application de savoir en temps réel combien elle doit faire payer à l'utilisateur sans le renseigner en dur dans le code de l'app.
La condition est :

Si notre étape de vente actuelle "currentStep" est égale à la valeur prédéfinie pour la whitelist de notre "enum" Step alors on renvoie la variable "whitelistPrice" qui correspond au prix en whitelist.

Si ce n'est pas le cas, on renvoie le prix "publicPrice". Image
Nous allons aussi créer deux fonctions permettant de modifier les prix des NFTs.

Il est utile de les mettre dans le cas où une très forte variation du prix a lieu le jour du mint par exemple.

Ou en cas de non sold-out.

C'est une porte ouverte en cas de problème !
Ces deux fonctions sont bien évidemment restreintes au propriétaire du contrat grâce au "modifier" "onlyOwner".

Ce sont des fonctions "external" on ne les appelle que depuis l'extérieur et elles prennent en paramètre le nouveau prix pour écraser l'ancien ! Image
C'est fini pour aujourd'hui !

On avance super vite sur notre contrat ERC721, il reste de moins en moins de fonctions à faire même si les étapes qui arrivent sont les plus complexes !

On se retrouve demain, même heure pour la suite de notre apprentissage ! 👋

• • •

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

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

Jour 17 / 25 :

Création #ERC20 : Nous allons déployer notre contrat ERC20, le vérifier, et l'ajouter à notre wallet 🔥

🧵
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 !

En route 🔥
Read 18 tweets
Dec 16
[#CALENDRIER DE L'AVENT 16/25]

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

Jour 16 / 25 :

Création #ERC20 : Nous allons créer notre premier token ERC20 ! Et tout ceci en une seule journée 🔥

🧵
Il est possible de faire des contrats de token ERC20 plus ou moins complexe !

Comme nous réalisons un token utilitaire qui sert de récompense de staking, il va être extrêmement simple à mettre en place !

On pourrait imaginer qu'il serve dans une marketplace de jeu par exemple.
Read 13 tweets
Dec 15
[#CALENDRIER DE L'AVENT 15/25]

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

Jour 15 / 25 :

La norme #ERC20 : Qu'est-ce que la norme ERC20 ? À quoi sert-elle ? C'est ce que nous allons voir aujourd'hui 💸

🧵
La norme ERC20 est une norme pour définir les contrats intelligents des jetons fongibles.

À l'inverse d'un NFT (ERC721), ERC20 permet de créer des jetons qui sont échangeables en 1:1 car ils ont exactement tous la même valeur !
À titre d'exemple, le "stable coin" #USDT est un token fongible dont le contrat est disponible sur plusieurs blockchain.

etherscan.io/token/0xdac17f…

Il est impossible de différencier 1 USDT d'un autre sur le même contrat, c'est pour ça qu'on les appelle des jetons fongibles !
Read 11 tweets
Dec 14
[#CALENDRIER DE L'AVENT 14/25]

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

Jour 14 / 25 :

Création #ERC721 : Finalisation du contrat ERC721... le mint ! 🔥

🧵
Dernière étape de notre contrat ERC721 ! Mais pas des moindres... la fonction de mint !

Elle doit regrouper pas mal de mécanismes pour gérer toutes les phases, nous allons la décortiquer !
Read 15 tweets
Dec 13
[#CALENDRIER DE L'AVENT 13/25]

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

Jour 13 / 25 :

Création #ERC721 : Comment gérer les métadonnées ? Est-ce que les métadonnées sont immuables ? Développons ça !

🧵
Dans le thread précédent, nous avons appréhendé le système d'Arbre de Merkle, c'est un gros sujet quand on parle de cryptomonnaie.

Le deuxième gros sujet, plus spécifique aux NFTs, ce sont les métadonnées... mais qu'est-ce que c'est ?
Read 24 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!

:(