0xNekr.eth Profile picture
Dec 10 17 tweets 6 min read
[#CALENDRIER DE L'AVENT 10/25]

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

Jour 10 / 25 :

Création #ERC721 : Les variables 💻

🧵
Bonjour à tous ! Nouveau sujet du jour : les variables de notre contrat ERC721 !

Mais avant ça, il est temps de définir notre objectif avec ce contrat…
Ce que je propose (vous pouvez adapter en fonction de ce que vous souhaitez) :

- Une supply de 20 NFTs
- Une vente en whitelist au prix de 0.5 MATIC (max 10 NFTs)
- Une vente en public au prix de 1 MATIC
- Pas plus de 1 mint par whitelist
Une fois que tout cela sera mis en place, vous aurez les clefs principales pour faire un contrat ERC721 standard ! Commençons à rajouter nos variables.

Si vous avez raté le jour précédent, vous pouvez repartir du code présent dans le dossier “contracts/Jour10” !
Aujourd’hui nous allons commencer par déclarer l’utilisation de “Counters” et “Strings”.

“Counters” s’initialise pour son propre type, “Counter”.

"Strings" s'utilise avec le type “uint” pour convertir des entiers. Image
Nous allons déclarer le compteur qui servira à incrémenter les IDs de NFT.

Il s’agit d’une variable nommée “_tokenIds” qui est du type “Counter” de la librairie.

On va le définir de type “private” car inutile de laisser cette variable accessible depuis une fonction publique. Image
Note : par définition, on essaie de nommer les variables privées grâce à un underscore en début de nom, d'où le "_tokenIds".
Nous allons maintenant déclarer une variable “Step” de type “enum”, ceci permet de créer un type de variable avec plusieurs états prédéfini.

Nous définissons les étapes de vente avec

0 : “SaleNotStarted”,
1 : “WhitelistSale”,
etc.

Tout ceci sera stocké dans une autre variable. Image
Cette autre variable c’est la variable “currentStep” de type “Step”.

Cette est “public” car on souhaite que notre application et nos utilisateurs puissent avoir accès à l’état d’avancement de la vente.

Elle contient donc la valeur (0/1/2/3) de l’étape en cours. Image
On passe rapidement sur la variable d’après, c’est une variable “public” pour que notre dApp puisse la lire facilement (et les utilisateurs).

Il s’agit du stockage de la route de Merkle.

Pour le moment c’est un peu flou, nous en reparlerons au moment de parler des whitelists ! Image
Étape suivante, la définition du nombre max de NFTs et le nombre max disponible pendant la phase de whitelist.

Ces deux variables sont des entiers constants, car nous ne souhaitons jamais les modifier.

Elles sont aussi “public”, encore pour des appelles de la potentielle dApp. Image
Nous devons définir un prix pour la vente “whitelist” et un pour la “public”.

Ce sont aussi des entiers, mais pas des constantes, car nous pourrions avoir envie de les changer en cas de forte variation du prix le jour du mint par exemple.

Pour rappel, 0.5 ether = 0.5 MATIC. Image
La variable suivante est un mapping qui permet d’associer un nombre à une adresse.

Le but ici est d’enregistrer le nombre de mint qu’effectue une adresse pendant la whitelist pour être sur qu’il ne puisse mint qu’une seule fois.

Encore une fois, il est de type “public”. Image
Dernière variable et dernière étape pour aujourd’hui, il s’agit de la variable qui va stocker la base de notre URI (lien IPFS) vers les métadonnées.

Nous reparlerons de cette variable quand nous aborderons le sujet des “metadatas” de nos NFTs ! Image
Vous avez initialisé l'ensemble des variables nécessaires pour notre contrat de NFT !

Demain, nous passerons au constructeur et aux premières fonctions !

N'hésitez pas à vous abonner pour ne pas rater les jours qui arrivent 🔥

Passez une bonne journée, à demain !👋

• • •

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!

:(