This is a proof-of-concept smart contracts built using solidity to show the automation on study loan/scholarship disbursement using blockchain. The smart contract is separated into 3 parts, student, loan/scholarship provider and university staff. A decentralised web application (dApp) has been created using ethers.js to connect with the smart contracts and metamask. The dApp allows higher education staff, loan/scholarship institutions and students to interact with the private Ethereum network and transfer the money disbursement automatically once the disbursement requirements are met.
I am using web wallet - Metamask for this project. For this particular project version, I am using Goerli Testnet (However Goerli is yet to have the pricefeed chainlink on USD/GBP, so I can only do the USD to ETH conversion for now with Goerli) for the deployment and testing. There are 2 more versions using different testnets in other repository folders (Ganache and Rinkeby).
For more information
- Metamask refer to this link: https://metamask.io/
There are 4 smart contracts on this project and all of them are deployed to Goerli Testnet via Remix IDE, you can use the "priceConvertGoerli.sol" and "ScholarshipDisbursementGoerli.sol" and the addresses below on remix IDE to look at the functions.
- PriceConvert Smart Contract Addrress:
0xb1003b72B1cCc8b98bD7072d312A6445369402A6
- Student Smart Contract Addrress:
0xaa31d34920fCBA7933Ce03cbDe59b46ff6f3b56C
- Scholarship Provider Smart Contract Addrress:
0x34f251aC03E7896cF7377FF531a3c392d8EF60dB
- University Staff Smart Contract Addrress:
0xbf9eaf4Cb7dCA0C688CF171C29e6E6b429fae971
I use Visual Studio Code to create and edit my project. You need also need Visual Studio Code to run the local web server. You can find the latest version here: https://code.visualstudio.com/
Then download all the files in this repository and put them into a single folder in your local drive. Remember to unzip any zip file.
Open the folder using visual studio code.
You need to have Node.js and NPM, which come together.
NB: Check if Node and NPM are already installed by inputting the following commands in the terminal:
node --version
npm --version
If they are installed, you will see something like this
Else go to https://nodejs.org/en/ if you need to install it.
To execute the local web server. Type the below in the terminal:
node server.js
In your browser, go to the link below to access the frontend
If the local web server is set up correctly, you will see the landing page below
Each of the button in the landing page give you accesss as if to 3 different parties (Student, Scholarship Provider and University Staff)
Student Page allows the student to enter their student code (numeric only) and their details. The smart contract will store the wallet ID to the student record when execute the transaction, this will be used later on the scholarship payment to pay student directly to their wallet.
Error message will show if try to store a student code that already exists in the blockchain
Scholarship Provider Page allows the scholarship provider to add scholarship to the student. If the provider tries to add scholarship to the student code that is not exists in the blockchain, it will create an error message.
When the provider add the scholarship, the wallet address of the provider will be stored to the scholarship record and the price convert function will convert the USD amount entered to Wei and then metamask will be executed to transfer the Wei amount (you could refer the Rinkeby version for GBP amount unit or Ganache version with no price conversion involved in other repository folders) to the Staff smart contract for disbursement later.
The provider can also cancel the scholarship if they decide not to sponsor by using the cancel scholarship function. The amount will not be return immediately to the provider, instead the university staff will need to process the refund.
University Staff Page allows the staff to enter the attendance percentage and average result of the student, if the attendance and result meet the required percentage entered by the provider when add the scholarship, the student will be disbursed the scholarship amount directly to their wallet address. Else the scholarship will mark as failed.
For those scholarships that have been cancelled by provider, staff can perform the refund to refund back the money of the provider from the smart contract. The money will be send to the provider wallet.
For those failed scholarship due to not meeting the attendance and result criteria, staff can reactivate them to reinsert new result or attendance for the payment to be disbursed.