Kreditpay is a minimal loan management system build using MERN stack. It's an online platform where you as a customer can take a loan with ease.
https://kreditpay.netlify.app/
From developer perspective this project is build using 3 tier structure that allow you to easily deploy frontend and backend code on different platform. For example the current demo project frontend is served on netlify and backend api is served by heroku server.
Following are the design patterns used in this project to make code modular.
- 3 tier structure - Decouple your frontend and backend code.
- Router config array - Seperate module for creating and adding routes.
- RBAC(Role Based Access Control) - To limit the resource access for each type of user which are
[admin,customer,agent]
-
- List,view and edit users.
-
- Create a loan request on behalf of the user - This can only be done by "agent" role. Inputs would be tenure selected (in months) and interest to be charged every month. Loan can have 3 states - "NEW", "REJECTED", "APPROVED".
-
- Approval of loan request - This can only be done by an "admin" role.
-
- Edit a loan (but not after it has been approved) - This can be done only by "agent" role. But cannot be done if loan is in "Approved" state. IMPORTANT: Can we save previous history ? In an extreme situation, can we "rollback" the changes ? Hint: the best designs here use "double safety" - logic in the code as well as database constraints.
-
- Ability to list and view loans (approved) or loan requests based on the filter applied - By "filter" we mean - select by date of creation, date of update, state of loan (NEW, REJECTED, APPROVED), etc. This action can be done by all : "customer", "agent" and "admin" roles. HOWEVER - "customer" can only see his own loans...while "agent" and "admin" can see everyone's loans. The way we design our data model above will allow us to do this. Make sure there are no security loopholes here.
-
- Writing the test cases.
Using MERN stack i.e.
- Frontend: React, Tailwind CSS.
- Backend: Nodejs, Express, MongoDB.
- VSCode: If you want to take advantage of dev plugins.
- Node v12.x.x
To prevent bugs project is locked to run only on Node v10.0+.
Recommended to use NVM
Run these commands in terminal.
$ git clone --recurse-submodules https://github.com/CoderOO7/kreditpay.git
$ cd kreditpay
$ npm run install-all
This will install dependencies for both client and server. The next step is to set environment
variables. For this checkout client and server directory.
And then run this command from root directory.
$ npm start
It serve the project on http://localhost:8080
- Fork it!
- Create your feature branch:
git checkout -b my-new-feature
- Commit your changes:
git commit -am 'Add some feature'
- Push to the branch:
git push origin my-new-feature
- Submit a pull request :D