Anthony Gourraud - anthonyg.eth@ethereum.email
Topics :
- Blockchain
- Ethereum, Polygon
- Solidity, ERC20
- Hardhat, Open Zepellin, Thirdweb
- IPFS, Fleek
A blockchain is a distributed database, with data publicly available. Multiple servers, called nodes, store and synchronize a copy of a global set of records. Write operations are also open to anyone, as long as modifications are accepted by the majority of nodes. The process of validation, called consensus, is what makes a blockchain a real innovation, by its principles that participating in the well-being of the network is more profitable than acting maliciously.
Bitcoin is considered as the first project to use a blockchain, to provide a peer-to-peer electronic cash system, a way to send and receive monetary value without relying on a trusted party.
Whereas Bitcoin is mainly developed as an alternative to banks, Ethereum purposes to store and execute code within its blockchain. It allows the emerging of unstoppable applications, open source protocols relying on no central entities to work. Every interaction with "dApps" that modify the state should be submitted as a transaction to the network. It costs fees (paid in ETH, the Ethereum coin), sent to nodes as validation incentives.
For various reasons, using Ethereum can be really expensive. Different solutions are on tracks to solve the problem. For now, you can use a "sidechain" like Polygon PoS to experiment decentralized applications at a lower cost. On Polygon, fees are paid in a coin called MATIC.
Code deployed on Ethereum is compatible with Polygon PoS.
📝 What are the main use cases of the following dApps, and why the use of a blockchain like Ethereum is relevant ?
- Aave :
- PoolTogether :
- Sablier :
- Uniswap :
We call programs executed on a blockchain "smart contracts". To interact with smart contracts, you need a digital wallet, represented by an address.
For smart contracts to work well together, standards are needed. ERC20 is the standard for tokens (to create your own cryto asset), ERC721 the one for NFT (used to prove a digital property). All contracts are deployed at a specific address.
Testing environments, "testnets", allow any developer to get a staging environment at no cost. Polygon Mumbai is a testnet of Polygon.
👉 Get your own wallet, and interact with smart contracts deployed on Mumbai.
- Install Metamask
- Add the Polygon Mumbai testnet network to Metamask with Chainlist
- Get test tokens : MATIC and DERC20 (Test ERC20 PoS) on Mumbai, thanks to the official Polygon faucet.
- Copy the address of the DERC20 contract. Use it to get your DERC20 balance with Metamask
- Transfer 0.01 DERC20 to someone next to you, with Metamask
- Exchange ("swap") 0.02 DERC20 to get MATIC with Uniswap
- Transfer 0.03 DERC20 to someone next to you, with the
transfer
write function via the block explorer Polygonscan
📝 Write down what you get from the described actions above
- Wallet address :
- DERC20 contract address :
- Hash of the DERC20 transfer transaction with Metamask:
- Hash of the swap transaction :
- Hash of the DERC20 transfer transaction with Polygonscan :
📝 Go deeper with the ERC20 standard
- Check the input data from the transaction details of the transfer you executed with Metamask ("Click to see more", "Decode Input Data"). Why is the argument
amount
different from what you set on Metamask ? - Why did you have to "approve" DERC20 spending before performing a swap ?
- What are "events" ? Why is it useful ? Which event(s) are emitted when you transfer DERC20 tokens ?
Solidity is the main language to conceive smart contracts. "Solidity By Example" is a great website to learn Solidity easily.
Hardhat is a famous framework that helps developers to code, test and deploy Solidity code. To build faster and for secure smart contract development, you can use libraries like Open Zeppelin contracts.
👉 Build your first contract : a token called "EPICOIN", following ERC20 standard. This contract should have a custom implementation, with a public address variable called lastUser
and a updateLastUser()
function too. When a user calls the updateLastUser
function, lastUser
should be updated with its wallet address, and an event AddressUpdated(address wallet)
should be emitted. The updateLastUser
function should not have any argument.
- Install NodeJS, VSCode and the Solidity extension from Nomic Foundation.
- Set up a new Hardhat project
- Create your contract EPICOIN.sol contract and code what is necessary to get a ERC20 token named "EPICOIN" (tip : import
ERC20.sol
from Open Zeppelin). - Write a
mint(address wallet, uint256 amount)
function to allow any wallet to create and send EPICOINS tokens to an address. - Write the
updateLastUser()
function. - Write down the tests. You can use Foundry (Solidity), or Mocha (Javascript), as you want. Ensure
lastUser
is correctly updated whenupdateLastUser
is executed (test with two different wallets), and an eventAddressUpdated
is emitted. Ensure EPICOIN balance changed for a wallet when themint
function is executed. - Once tested, deploy the contract on Mumbai with the wallet you created with Metamask. You may have to export your private key.
- Use your deployed contract with Polygonscan : call the
mint
andupdateLastUser
functions, and transfer some EPICOIN tokens to someone next to you. Write functions are unavailable ? It's because you need to verify your contract.
📝 Write down what you get from the described actions above
- Deployed EPICOIN contract address :
- Hash of the contract creation transaction :
- Hashes of mint and transfer transactions with the EPICOIN contract :
- Hash of a transaction where
lastUser
variable is modified (we should seeAddressUpdated
event in "Logs") :
Once you have developed your logic with smart contracts, you need an interface to facilitate people to use the implemented features.
React is a good frontend framework, with several libraries to integrate wallet connection and blockchain transactions easier. Thirdweb provides several React hooks, UI components and templates to get started.
But if you deploy a React app on a server (with Vercel for example), the application is not really "decentralized", because you rely on the hosting provider. A solution is a to use Fleek, and deploy on IPFS, a P2P data storing protocol.
👉 Build a web app that allows any user to mint EPICOIN tokens. The interface should offer to modify the lastUser
variable of the contract you deployed too. You may need the Web3 Button from Thirdweb. Deploy on IPFS.
📝 Write down what you get from the described actions above
- IPFS link to the web app :