0xNekr Profile picture
Jul 19 23 tweets 11 min read
[#THREAD] Vos NFTs peuvent-ils disparaître ?

Spoiler : OUI

Mais pourquoi et comment ? 🧵

#Web3 #Solidity #NFT #Crypto #ETH #Ethereum #JavaScript

⬇️ Image
> Prélude

Rassurez-vous, le token en lui-même ne peut pas disparaître, il est ancré sur la blockchain (Vous pouvez vous le faire scam/voler mais ce n'est pas le sujet). ouf...

MAIS...

2/22
Si vous pensez que votre #JPEG lié à votre token est immuable... Là c'est parfois moins vrai.

Imaginez qu'un matin vous arriviez pour contempler votre beau #BAYC sur #OpenSea et là...

96 #ETH pour un carré noir !

Est-ce possible ? Comment ?

⬇️

3/22 Image
> Est-ce possible ?

Oui & non... c'est possible pour beaucoup de projets, mais il est possible de s'assurer que ça ne le soit pas !

Je vais prendre l'exemple du contrat des BAYC pour illustrer mes propos.

Voyons comment cela pourrait arriver.

4/22
> Les metadatas

Si votre token, lui, est bien stocké sur la blockchain, les métadonnées qui le définissent (images, attributs, nom, desc, etc...) sont majoritairement stockées off-chain.

En effet, le coût d'un tel stockage sur une blockchain seraient bien trop élevé.

5/22
Voici les métadonnées du BAYC #6409

C'est un fichier JSON qui contient les informations importantes telles que les attributs mais surtout l'image. Ceci permet aux marketplaces tel que #OpenSea de pouvoir afficher tout cela.

Comment les marketplaces récupèrent ces données?

6/22 Image
Et bien il existe une fonction #ERC721 standard nommée "tokenURI" qui permet de retourner une URI contenant les métadonnées pour un ID de NFT.

C'est donc cette fonction qui permet à OpenSea de récupérer les images, attributs, etc.

Regardons celle des BAYC...

7/22 Image
Cette fonction peut être "override".

Ici le contrat à trois possibilités :

• Si pas de baseURI renvoyer tokenURI.
• Si baseURI + tokenURI alors renvoyer la concaténation.
• Si baseURI et pas de tokenURI renvoyer baseURI + l'ID du token.

8/22 Image
tokenURI est une valeur stockée dans un mapping, pour chaque ID de NFT il est possible de définir une URI spécifique.

baseURI est l'URI de base qui pointe vers les métadonnées.

Dans nos trois cas c'est le dernier qui est le cas classique et qui nous intéresse.

9/22 Image
On a donc une fonction qui permet à OpenSea de récupérer toutes les métadonnées qui permettent à notre token d'être un BAYC !

Pour notre exemple le BAYC #6409 a comme retour de fonction le "baseURI" + son numéro de token.

Mais peut-on modifier la baseURI ?

Résumons ⬇️

10/22 Image
On a :

• Une fonction qui permet aux marketplaces de récupérer les métadonnées
• Des métadonnées qui sont stockées hors blockchain
• Des métadonnées qui dépendent d'une baseURI

Donc si on modifie cette baseURI on peut tout simplement modifier les BAYC ! Flippant non ?

11/22
Mais la baseURI est-elle modifiable ?

Et bien ça dépend des contrats... mais en général, oui.

Et les BAYC ne dérogent pas à la règle d'après leur contrat.

Heureusement, cette fonction ne peut être appelée que par le propriétaire du contrat.

12/22 Image
Vos NFTs peuvent-ils disparaître ? Et bien oui !

Cette fonction permet au propriétaire du contrat de modifier l'URI de vos métadonnées et il peut les rediriger vers absolument tout ce qu'il veut.

Imaginez si quelqu'un met la main sur sa clé privée ?

13/22 Image
Alors que faire ?

Pour commencer un projet sérieux n'a aucun intéret à remplacer ses NFTs par du vide. Pour éviter le vol de clé, mettre un contrat multi-sig en propriétaire semble être une bonne idée.

Pour le reste ⬇️

14/22
Il est parfois utile pour un projet de garder la main sur la modification pour réaliser des NFTs évolutifs, corriger des erreurs, etc...

Les cas d'usage sont nombreux.

Comment être sûr que mon NFT ne sera jamais modifié ?

Regardons nos BAYC de plus près !

15/22
Il existe bien une fonction qui permet au propriétaire du contrat de modifier l'URI de base.

Mais le contrat implémente la librairie "Ownable" d'OpenZeppelin qui permet de... renoncer aux droits du contrat !

Si on regarde au niveau du contrat des BAYC...

16/22 Image
On peut voir que le propriétaire du contrat est l'adresse 0.

Il est donc complétement impossible que quelqu'un modifie les images/traits des BAYC, même pas les créateurs.

C'est rassurant non ?

17/22 Image
Du côté de #Azuki le constat est tout autre...

Je vous laisse analyser par vous même, mais le propriétaire est toujours là et la fonction de modification d'URI aussi !

etherscan.io/token/0xed5af3…

Mais ceci n'est pas forcèment un problème tant qu'on a confiance en la team.

18/22 Image
Je n'ai pas parlé du fait d'utiliser des services centralisés pour stocker ces métadonnées... services qui peuvent disparaître !

C'est pour ça que la majorité des projets utilse IPFS. Mais c'est un tout autre sujet que j'aborderai un autre jour.

19/22 Image
Vous comprenez maintenant un peu mieux comment sont gérés vos NFTs favoris.

Je trouve important de comprendre que vos tokens sont bien inscrits dans la blockchain et sont immuables. Mais leurs métadonnées ne le sont pas forcément !

20/22
Vous pouvez vous abonner pour ne pas rater la suite.

Je poste régulierement des threads autour de la tech Web3 !

Et je vous souhaite une très bonne journée/soirée à tous, et à très bientôt 🔥

21/22
Encore merci à ceux qui m'aident, S/0 @CryptoLidl pour l'illu et @CrypToma8 pour les retours !

Sans oublier tous les singes de @CryptApeDAO

Rejoignez-nous dans notre antre afin de build pendant ce bear !

discord.gg/KwcuH6ycar
Merci d'avoir lu ce thread !

J'espère qu'il vous permettra de mieux comprendre comment fonctionne notre univers.

Si ça vous a plu, le meilleur moyen de me soutenir est d'aimer et retweet ce thread. Merci d'avance !

⬇️

• • •

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

Keep Current with 0xNekr

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

Jun 22
[#THREAD] Intéragir directement avec un Smart Contract

Difficulté technique : ★☆☆☆☆

Mint sans passer par une dApp, transférer un NFT, on a plein de raisons de vouloir intéragir avec un Smart Contract.

Mais comment faire ?

#Web3 #SmartContracts #NFT #Crypto

⬇️ Image
Interagir en direct avec un contrat a beaucoup d'avantages.

Notamment lorsqu'une #dApp ne fonctionne pas ou ne propose pas certaines fonctionnalités comme le transfert par exemple.

Cela va nous permettre d'avoir accès à toutes les fonctions publiques et externes !

1/22
> Le scope

Aujourd'hui je ne parle que des contrats qui sont déployés sur Ethereum et toutes les EVMs (AVAX, BSC, Fantom, Polygon, etc..)

Ce qui couvre déjà une belle partie de notre écosystème !

On est parti

⬇️

2/22
Read 24 tweets
Jun 17
[#THREAD] Les outils du développeur Web3

Difficulté technique : ★☆☆☆☆

Je vous livre sur un petit plateau tous les outils qui vont vous permettre d'avancer dans le monde du dev !

#Web3 #Solidity #SmartContracts #NFT #Crypto #Tools

⬇️

1/15 Image
> Organisation / Documentation

L'OUTIL INCONTOURNABLE : notion.so

@NotionHQ

C'est ce qui me permet de TOUT gérer :

- ToDo List
- Planning
- Gestion des prestations
- Documentation

Je fais tout là-bas et tout est centralisé ! C'est le TOP !

2/15
@NotionHQ > Organisation / Documentation

Le deuxième outil que TOUT dev doit gérer et maîtriser :

@github

Plus besoin de le présenter, le gestionnaire de code où je stocke tout ce que je fais, vous pouvez me suivre là-bas pour voir mon code :

github.com/0xNekr

3/15
Read 16 tweets
Jun 14
[#THREAD] On créé un contrat ERC721 pas à pas v.2

Difficulté technique : ★★★★☆

On améliore notre dernier contrat : il est temps de rajouter des étapes de vente et surtout... une whitelist !

#Web3 #Solidity #SmartContracts #NFT #Crypto #Whitelist

⬇️

1/21 Image
Notre objectif est de rajouter et modifier certaines caractéristiques :

• Ajouter des étapes de vente.
• Ajouter une vente en whitelist avec un arbre de Merkle.
• Un prix de vente de 0.01 ether en vente publique.
• Un prix de vente de 0.005 ether en whitelist.

2/21
Avant de continuer, si ce n'est pas déjà le cas, je vous conseille fortement de suivre mon premier thread sur la première étape de développement du contrat.

Il permet de poser les bases nécessaires pour comprendre ce qui suit !



3/21
Read 22 tweets
Jun 7
[#THREAD DE MES THREADS💻]

Histoire de facilement tout retrouver, voici mes threads dans l'ordre de publication ! 🥳

Design by @CryptoLidl 🔥

#ERC721 #Solidity #EVM #Eth #Crypto #Dev Image
Read 8 tweets
Jun 6
[#THREAD] Comment devenir développeur Solidity ?

C'est la question qu'on me pose le plus régulièrement !

Je ne suis pas sûr d'avoir la réponse, mais mon parcours est le suivant...

#Web3 #Solidity #SmartContract #NFT #Crypto #ETH

⬇️ 1/20 Image
[Prélude]

Je suis développeur de formation, j'ai des appétences pour le développement et ça m'a aidé à aller beaucoup plus vite !

Mais rien n'est impossible même si vous n'avez pas les bases (avec du temps et de l'envie on peut tout faire).

2/20
Je vais aborder exclusivement mon parcours entre mon apprentissage de Solidity jusqu'à mes premiers projets.

Mais si vous partez de 0, il est important selon moi de comprendre et maîtriser au moins les points qui suivent :

• HTML/CSS/JS
• Un framework JS
• La POO

3/20
Read 21 tweets
May 31
[#THREAD] Déployer et tester son premier smart contract

Difficulté technique : ★☆☆☆☆

La dernière fois on a développé notre premier smart contrat…

Aujourd'hui on va faire en sorte de le déployer sur la blockchain !

#Web3 #Solidity #SmartContract #NFT #Crypto #ETH
⬇️
1/19
[INTRO]

Pour commencer, n'oubliez pas d'aller lire / appliquer tout ce qu'on a apprit dans le dernier thread sur comment développer un smart contract ERC721, vous pouvez le retrouver ici :



2/19
[INTRO]

Si vous voulez tester par vous même je vous conseille de repartir du code présent sur mon #Github :

github.com/0xNekr/HowToCr…

3/19
Read 20 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!

:(