Welcome to the FlashLoanSimple-Pt-2
repository. This repository builds upon the basic implementation of a FlashLoan contract for Aave v3, utilizing the Hardhat framework. While the primary goal of the original project was to provide a simple example of how flash loans work within the Aave ecosystem, this part delves into more advanced topics, including deployment scripts and deploying the FlashLoan contract on testnets, including Layer 2 solutions.
- Introduction
- Verification and Security
- Commented Code
- Getting Started
- Smart Contract Deployment
- Contributions
- License
- Project Updates
- Additional Resources
- Donation
This repository is an extension of the FlashLoanSimple repository project, covering more advanced topics related to flash loans within the Aave ecosystem. It includes deployment scripts and instructions for deploying the FlashLoan contract on various testnets, including Layer 2 solutions.
Each modification to this project undergoes a meticulous verification process and subsequent signing. This stringent approach guarantees the authenticity and integrity of our codebase. In case you encounter any modifications that lack appropriate verification, we strongly advise against cloning or utilizing them, as they might harbor malicious code.
Please take note: Our codebase is meticulously documented with comprehensive comments, aimed at providing a clear understanding of the functionality of individual components.
To explore and interact with our FlashLoanSimple-Part-2
project, follow these steps:
-
Clone this repository to your local machine.
git clone https://github.com/Innovation-Web-3-0-Blockchain/FlashLoanSimple-Part-2.git
-
Ensure you have
node.js
andnpm
installed in your environment. -
Install the necessary dependencies by running the following command in your terminal:
npm install
We will be deploying the FlashLoan contract on Polygon Mumbai Testnet.
To deploy the FlashLoanSimplePt2.sol
contract, follow these steps:
-
Set your deployment environment by setting the hardhat.config.js file with the testnet you want to use with the Hardhat node. For guidance on what to include, please refer to our Hardhat Configuration File.
-
Set your RPC endpoint. We recommend using your own RPC URL for better reliability. You can create your own Web3 API keys on the Infura website: Infura.
-
Create a .env file and add the following:
YOUR_API_KEY="" // Paste your Web3 API key in between the quotation marks YOUR_PRIVATE_KEY="" // Paste your wallet private key in between the quotation marks
IMPORTANT NOTE: Make sure that your .env file is private, and that you never share its contents.
-
Get faucets MATIC for the gas fees:
- MATIC faucets: Mumbai Faucet
-
Get faucets USDC for the FlashLoan:
- USDC faucets: Aave Faucet
-
Deploy the deployment script by using the following command:
npx hardhat run --network mumbai scripts/1_deploy.js
-
(Optional) To use the Polygon Mainnet for forking purposes, use the following command:
npx hardhat node
-
(Optional) Deploy the deployment script by using the following command:
npx hardhat run 1_deploy.js --network fork
If the deployment is successful, this is what will show up in your command line console:
Deploying FlashLoan contract...
FlashLoan contract deployed at: 0x28b76D579f1B3b314098E99a543dF3bC3C2d9Ee6
View contract at: https://mumbai.polygonscan.com/address/0x28b76D579f1B3b314098E99a543dF3bC3C2d9Ee6
--------------------------------------------------------------------------------------------------------------------------
Transferring 5 USDC to the FlashLoan contract...
Transferred 5 USDC tokens to the FlashLoan contract
Waiting for 1 block to verify the transfer...
--------------------------------------------------------------------------------------------------------------------------
USDC balance of the FlashLoan contract is: 5 USDC
--------------------------------------------------------------------------------------------------------------------------
Requesting a flash loan of 1000 USDC...
Flash loan executed!
View transaction at: https://mumbai.polygonscan.com/tx/0x04bf0178a90535f95821925dcc00c12145b9db84de247222f59b6b91794bf0d8
--------------------------------------------------------------------------------------------------------------------------
Withdrawing 4.5 USDC from the FlashLoan contract...
Funds sent!
View transaction at: https://mumbai.polygonscan.com/tx/0xf59acb85d752fd50cb4b990b9a684e1eb0f25b930a9ad43df9faa7b996431f55
--------------------------------------------------------------------------------------------------------------------------
This code tutorial uses a testnet; however, the exact same instructions and sequence will work on the mainnet as well.
Contributions to this project are welcome and encouraged. If you identify any bugs, have feature requests, or would like to improve the project, please open an issue or submit a pull request. We appreciate your interest and contributions.
This project is licensed under the MIT License. For details, please refer to the LICENSE file.
As the DeFi ecosystem continues to evolve, we will monitor and update this project to align with the latest developments and best practices. Stay tuned for updates and improvements!
For more details on flash loans and how they work in Aave, please refer to the Aave Flash Loans Guide.
To verify any Aave V3 testnet addresses, please refer to the Docs for Aave V3 Testnet Adresses.
We do not use any form of social media or engage in marketing activities. Our principles are rooted in open source and privacy, and we do not receive compensation for our contributions to GitHub. Furthermore, we do not endorse or have affiliations with any other projects.
While we remain committed to providing valuable resources for aspiring blockchain developers, any donations are greatly appreciated. Your support will help us offset the time and effort we invest in these projects to facilitate access to accessible information.
We welcome contributions in Bitcoin and Monero, and you can send contributions by scanning one of the addresses in the QR codes at the following link: Donate to Innovation Web 3.0
Thank you for your support and for being part of our community!