diff --git a/p2p/9.Tangem_ERC-20/README.md b/p2p/9.Tangem_ERC-20/README.md new file mode 100644 index 00000000..b4745f90 --- /dev/null +++ b/p2p/9.Tangem_ERC-20/README.md @@ -0,0 +1,173 @@ +# Workshop Krypto Tour - Créer sa cryptomonnaie (ERC-20) + +✔ Découverte de la norme ERC-20 + +✔ Coder sa cryptomonnaie + +✔ Déployer sa cryptomonnaie sur la blockchain Polygon + +## Introduction en quelques lignes + +### Qu'est-ce qu'un ERC-20 ? + +**ERC-20**, qui signifie « Ethereum Request for Comments 20 », est une **norme technique** utilisée pour **créer** et **gérer** des jetons basés sur la **blockchain Ethereum**. Les tokens ERC-20 sont des **actifs numériques** qui peuvent représenter **plusieurs formes** de valeur, telles que des actifs financiers, des points de fidélité, des biens numériques, etc. + +### Pourquoi mettre en place une norme ? + +Le **premier avantage** de l'ERC-20 réside dans sa facilité d'**adoption** et d'**interopérabilité**. Cette norme **définit un ensemble de règles** et de fonctions qui permettent aux développeurs de **créer des tokens compatibles avec le réseau Ethereum** et les portefeuilles Ethereum existants. Cela signifie que les utilisateurs peuvent stocker, transférer et échanger différents types de tokens ERC-20 **en utilisant les mêmes portefeuilles et interfaces**. + +### Avec quelle technologie ? + +**Solidity** est un **langage de programmation** spécifiquement **conçu pour développer des contrats intelligents sur la blockchain Ethereum**. Il permet aux développeurs de **créer des contrats auto-exécutables, autonomes et vérifiables** qui définissent des règles et des interactions dans un **environnement décentralisé**. + +## Étape 0 - Initialisation + +Toute les informations nécéssaires à la mise en place de votre environment de développement sont à retrouver dans [SETUP.md](./SETUP.md) + +## Étape 1 - Création et personnalisation de son token + +### 📑 **Description** : + +Pour créer notre token, nous allons devoir coder un smart contract. Nous utiliserons le language [Solidity](https://fr.wikipedia.org/wiki/Solidity). + +>💡 *Un smart contract est un programme informatique autonome qui s'exécute automatiquement sur une blockchain lorsque des conditions prédéfinies sont remplies. Il permet d'automatiser et de sécuriser des accords sans intermédiaire, de manière transparente et immuable.* + +### 📌 **Tâches** : + +Premièrement, vous aller avoir besoin d'utiliser la bibliothèque de smart contrats d'OpenZeppelin: OpenZeppelin est une organisation qui fournit des smart contracts sécurisés et reconnus pour la blockchain Ethereum. Pour l'installer, entrez cette commande dans votre terminal: + +```sh +forge install OpenZeppelin/openzeppelin-contracts +``` + +C'est le moment de coder ! +- Ouvrez votre projet foundry `krypto-tour` dans VScode. +- Supprimez les fichiers `script/Counter.s.sol`, `test/Counter.t.sol` et `src/Counter.sol`. +- Créez un fichier `erc20.sol` dans le dossier `src/` et écrivez ces lignes: + +**Version et import** +```js +// SPDX-License-Identifier: UNLICENSED +pragma solidity ^0.8.20; + +import {ERC20} from "lib/openzeppelin-contracts/contracts/token/ERC20/ERC20.sol"; +``` + +La directive `SPDX-License-Identifier` est une convention pour spécifier la licence du code source.\ +Les mots-clés `pragma solidity` permettent de spécifier la version de Solidity à utiliser. Ici, nous utilisons la version 0.8.20.\ +`import` est une fonctionnalité qui vous permet d'utiliser du code depuis d'autres fichiers dans votre programme actuel. Ici on importe le contrat ERC20 d'OpenZeppelin. + +**Contract** +```js +contract Token is ERC20 { +} +``` + +`contract` en Solidity est un conteneur pour le code (ses fonctions) et les données (son état) qui résident à une adresse spécifique sur la blockchain. +Le mot-clé `is` en Solidity indique l'héritage. C'est à dire que notre contrat `Token` va pouvoir utiliser toutes les fonctions et événements définis dans le contrat `ERC20`. + +```js +constructor() ERC20("KRYPTO-POC", "POC") { + _mint(msg.sender, 100000 * 10 ** decimals()); +} +``` + +- `constructor()` : C'est le constructeur du contrat, c'est lui qui est en charge de créer le smart contract. Il est appelé une seule fois, lors du déploiement du contrat sur la blockchain. +- `ERC20("KRYPTO-POC", "POC")` : + - Ceci appelle le constructeur du contrat parent ERC20. + - "KRYPTO-POC" est le nom complet du token: **vous pouvez le personnaliser !** + - "POC" est le symbole du token (comme "BTC" pour Bitcoin): **vous pouvez le personnaliser !** +- `_mint(msg.sender, 100000 * 10 ** decimals());` : + - `_mint` est une fonction interne de ERC20 qui crée de nouveaux tokens. + - `msg.sender` est l'adresse qui déploie le contrat. Les nouveaux tokens seront envoyés à cette adresse. + - `100000 * 10 ** decimals()` calcule le nombre total de tokens à créer : + - `100000` est le nombre de tokens entiers. + - `10 ** decimals()` ajoute les décimales. Par défaut, `decimals()` renvoie 18 pour la plupart des tokens ERC20. + - Donc, si `decimals()` est 18, cela créera 100000 * 10^18 unités de base du token. + +## Étape 2 - Déploiement + +### 📑 **Description** : + +Maintenant que vous avez codé et personnalisé votre token, vous allez pouvoir déployer votre smart contract sur la blockchain [Polygon](https://polygon.technology/). + +### 📌 **Tâches** : + +Commençons par créer un wallet temporaire qui va nous permettre de déployer notre token sur la blockchain Polygon. Pour cela, entrez cette commande dans votre terminal : + +```sh +cast wallet new +``` + +Mettez de côté l'adresse et la clé privée du wallet généré, vous allez en avoir besoin. + +Remplissez le formulaire suivant avec votre adresse email et l'`address` générée par la commande précédente : [https://forms.gle/ZXDvPHJwP4TN7aWeA](https://forms.gle/ZXDvPHJwP4TN7aWeA). Cela nous permettra de vous envoyer des tokens `MATIC` afin de payer les frais de déploiement. + +C'est le grand moment ! Entrez cette commande, et votre token devrait se déployer ! Pensez simplement à remplacer `PRIVATE_KEY` par la clé privée de votre wallet temporaire. + +```sh +forge create src/erc20.sol --rpc-url https://polygon-mainnet.g.alchemy.com/v2/m1TWeG_zxjMLlLQD1Y1ldDhoBXE_vO2H --private-key PRIVATE_KEY +``` + +La commande `forge create` permet de déployer un smart contract, ici notre token ERC20. + +Le paramètre `--rpc-url` correspond à l'URL d'un noeud RPC de la blockchain Polygon. Un noeud RPC est un serveur qui permet de communiquer avec la blockchain. + +La private key est une clé secrète qui permet de signer les transactions. Elle est nécessaire pour déployer un smart contract sur la blockchain. + +## Étape 3 - Transfert des tokens sur son wallet Tangem + +### 📑 **Description** : + +Maintenant que votre token est déployé sur la blockchain Polygon, vous allez pouvoir le transférer sur votre wallet Tangem. + +### 📌 **Tâches** : + +Avant de transférer vos tokens, assurez-vous d'avoir configurer votre wallet Tangem et de l'avoir connecté à l'application. Vous pouvez ensuite récupérer l'adresse de votre wallet, vous en aurez besoin pour transférer vos tokens. + +Entrez cette commande pour transférer vos tokens sur votre wallet Tangem. Pensez à remplacer `AMOUNT` par le nombre de tokens que vous souhaitez transférer, `ADDRESS` par l'adresse de votre wallet Tangem et `PRIVATE_KEY` par la clé privée de votre wallet temporaire. + +```sh +cast send "transfer(address,uint256)" ADDRESS $(cast to-wei AMOUNT) --rpc-url https://polygon-mainnet.g.alchemy.com/v2/m1TWeG_zxjMLlLQD1Y1ldDhoBXE_vO2H --private-key PRIVATE_KEY +``` + +La commande `cast send` permet de déclencher une fonction d'un smart contract. Ici, nous utilisons la fonction `transfer` du contrat ERC20 pour envoyer des tokens à une adresse spécifique. + +Enfin, rendez-vous sur l'application de votre carte Tangem, vous devriez y aperçevoir votre token ! + +## Conclusion + +Vous venez de créer votre propre ERC-20, bravo ! Au cours de ce workshop, vous avez appris ce qu'était un ERC-20, mais vous avez également créé votre propre token et l'avez déployé sur la blockchain Polygon. Vous avez également pu découvrir les wallets Tangem et apprendre à utiliser l'application associée. + +J'espère que vous avez apprécié ce workshop ! + +## Authors + +| [
Sacha Dujardin](https://github.com/Sacharbon) | +| :-----------------------------------------------------------------------------------------------------------------: | +

+Organization +

+ +

+ + LinkedIn logo + + + Instagram logo + + + Twitter logo + + + Discord logo + +

+

+ + Website logo + +

+ +> 🚀 Don't hesitate to follow us on our different networks, and put a star 🌟 on `PoC's` repositories. diff --git a/p2p/9.Tangem_ERC-20/SETUP.md b/p2p/9.Tangem_ERC-20/SETUP.md new file mode 100644 index 00000000..413550ad --- /dev/null +++ b/p2p/9.Tangem_ERC-20/SETUP.md @@ -0,0 +1,54 @@ +# Setup - Foundry + +Foundry est une chaîne d'outils de développement de smarts contracts. Il gère vos dépendances, compile votre projet, exécute des tests, déploie et vous permet d'interagir avec la blockchain à partir de la ligne de commande et via des scripts Solidity. + +## Installer Foundry + +### Linux et MacOS +- Ouvrez votre terminal et tapez + +```sh +curl -L https://foundry.paradigm.xyz | bash +``` + +### Windows +- Téléchargez [Git pour windows](https://git-scm.com/downloads/win) puis lancer le programme Git Bash. +- Tapez + +```sh +curl -L https://foundry.paradigm.xyz | bash +``` + +Cela va télécharger foundryup. + +- Ensuite, vous pouvez installer foundry en tapant `foundryup` +- Si tout s'est bien passé vous devriez être capable d'utiliser `forge`, `anvil`, `chisel` et `cast` +- Si vous êtes sur macos vous devez installer `libusb` en tapant + +```sh +brew install libusb +``` + +Après l'installation, lancer cette commande pour vérifier que tout est bien installé sur votre ordinateur: + +```sh +forge --version +``` + +Cela devrait afficher la version actuelle de forge. + +Si vous avez des soucis d'installation n'hésitez pas à demander de l'aide aux organisateur de ce workshop. + +## Créer un projet Foundry + +Une fois que l'installation est faite, vous pouvez créer un nouveau projet en tapant + +```sh +forge init krypto-tour +``` + +Cela devrait créer un nouveau dossier contenant un tout nouveau projet foundry. + +Tout est bon, vous pouvez maintenant attaquer le workshop ! + +[Retour au workshop !](./README.md)