Skip to content

Latest commit

 

History

History
225 lines (172 loc) · 8.72 KB

README.md

File metadata and controls

225 lines (172 loc) · 8.72 KB

Smyik - Banking application

codecov GitHub last commit GitHub language count GitHub top language GitHub Actions Workflow Status

This project is a banking application built using Go + PostgreSQL + Docker. I have used Go as the backend language, PostgreSQL as the database, SQLC for generating type-safe SQL queries, and go-playground/validator for input validation. The project also includes comprehensive unit tests written with testify and GoMock for mocking dependencies. The project also includes CI tests written using GitHub workflows and code coverage is also tracked and uploaded to Codecov (find it here). Build automation and commands are managed using Makefile.

⭐ Star us on GitHub — it motivates me a lot!

Share Share Share Share Share

📚Tech Stack

  • Backend Language: Go (Golang)
  • Database: PostgreSQL
  • ORM/SQL Generator: SQLC
  • Validation: go-playground/validator
  • Testing: Comprehensive unit tests with GoMock for mocking
  • CI Pipeline: GitHub Actions for CI tests and code coverage uploading,
  • Code Coverage: Tracking test coverage of the project using Codecov. (find it here)
  • Build and Commands: Managed using Makefile

CodeCov

📝 How to Build

To build the packages, follow these steps:

# Open a terminal (Command Prompt or PowerShell for Windows, Terminal for macOS or Linux)

# Ensure Git and make is installed
# Visit https://git-scm.com to download and install console Git if not already installed

# Clone the repository
git clone https://github.com/1Shubham7/Banking-application.git

# Navigate to the project directory
cd Banking-application

make postgres

make createdb

make start_prod

# If you want to run it through local image:
# Install `go-migrate` with root previliges
sudo go install -tags 'postgres' github.com/golang-migrate/migrate/v4/cmd/[email protected]

make migrateup1

make migrateup

make server

🙋‍♂️ User Journey

  1. Create a User/SignIn:
curl -i -X POST http://localhost:8080/users -H "Content-Type: application/json" \
-d '{"username": "Shubham", "password": "secret", "full_name": "Shubham Singh", "email": "[email protected]"}'
  1. Login User:
curl -i -X POST http://localhost:8080/users/login -H "Content-Type application/json" \
-d '{"username": "Shubham", "password": "secret"}'

This will return you a JWT token:

{
  "session_id": "932680d9-a170-4e3d-8f1a-ed9aa090d21b",
  "access_token": "v2.local.nqUejIG_-A0-YKfedgDIjfFH9AyLr-idGE5e3QvduogV3hRsO0d1HTu3MoaXjHTfixDPjy7ZImbJZU_6S-LNZG3OqWtNZlQA0ta-UBg5vnnaGjzvahOT4CxwaBXOeZdxMjiZ0eRMB3yf4Kb8X0dYdjk0830h7b6b95gnmWfs85DfUUvh5JxuHaUwdT1SSiAf2r5-hh2d3qX1nFRnyeT0T0P3jOVrFd-Citqgz-ASCGMdtbJ1Dne6xjZ1SXsMlNt5zswiEkfTx5wOBshWV6oj.bnVsbA",
  "access_token_expires_at": "2024-12-13T12:15:43.050587204+05:30",
  "user": {
    "username": "Shubham",
    "full_name": "Shubham Singh",
    "email": "[email protected]",
    "password_changed_at": "0001-01-01T05:53:28+05:53",
    "created_at": "2024-12-13T11:36:20.819497+05:30"
  },
  "refresh_token": "v2.local.aWZ1xqaQ6KZfgwmN-uPrwKgfu2uqzXILAA006JbGvIHdfmpAgWkj_vJ5bjPhUi8KDT1qGyzSYMTG1PD8tOTisGWVz__VYLKzjr7aPBkIB_Nj0yHBInYPXF27G1MK5E_DPi_GOYKiGjITW76CYN-ob7cM8p5ruCwxAB_Mz8Sr4XLlzGGSuRnuEaBVZkBd2rIQil2m5FjidkvyXtwztonC5wT93CxEeVCH7Nnx05zp_tKzUtAZV0vQU4xf_Z0S5ynPvrf0azYrHsyG_Jh2_t9s.bnVsbA",
  "refresh_token_expires_at": "2024-12-15T11:45:43.056058261+05:30"
}
  1. Create an account for the user:
curl -X POST http://localhost:8080/accounts \
-H "Authorization: Bearer <Token> \
-H "Content-Type: application/json" \
-d '{"balance": 10000, "currency": "USD"}'
  1. Now you can perform actions on the account, for example, get a user account (under authentication):
curl -X GET http://localhost:8080/accounts -H "Authorization: Bearer <Token>"

This will return a response:

{"id":1,"owner":"Shubham","balance":10000,"currency":"USD","created_at":"2024-12-13T12:01:09.869101+05:30"}
  1. Perform Money Tansfer:

For that we will have to create another user:

curl -i -X POST http://localhost:8080/users \
-H "Content-Type: application/json" \
-d '{
  "username": "Elon", 
  "password": "secret", 
  "full_name": "Elon Musk", 
  "email": "[email protected]"
}'

And then login the new user:

curl -i -X POST http://localhost:8080/users/login \
-H "Content-Type: application/json" \
-d '{
  "username": "Elon", 
  "password": "secret"
}'

This will return this result including the JWT/Paesto Token:

{
  "session_id": "0f48c550-16fc-418c-9e99-d5b378fcd53d",
  "access_token": "<Token>",
  "access_token_expires_at": "2024-12-13T13:23:37.434517608+05:30",
  "user": {
    "username": "Elon",
    "full_name": "Elon Musk",
    "email": "[email protected]",
    "password_changed_at": "0001-01-01T05:53:28+05:53",
    "created_at": "2024-12-13T12:52:38.271222+05:30"
  },
  "refresh_token": "<Token>",
  "refresh_token_expires_at": "2024-12-15T12:53:37.435101986+05:30"
}

Then create new account for this new user:

curl -X POST http://localhost:8080/accounts \
-H "Authorization: Bearer <Token>" \
-H "Content-Type: application/json" \
-d '{
  "balance": 100, 
  "currency": "USD"
}'

And then perform transfer:

curl -X POST http://localhost:8080/transfers \
-H "Authorization: Bearer <Token>" \
-d '{
  "from_account_id": 1, 
  "to_account_id": 2, 
  "amount": 100, 
  "currency": "USD"
}'
  1. For Refreshing Token:
curl -X POST http://localhost:8080/tokens/renew_access \
-H "Authorization: Bearer <Token>" \
-d '{
  "refresh_token": "<Token>"
}'

This will return a new access token:

{
  "access_token": "<Token>",
  "access_token_expires_at": "2024-12-13T13:41:10.668632532+05:30"
}

🤝 Contributing

GitHub Issues or Pull Requests GitHub Issues or Pull Requests GitHub Issues or Pull Requests GitHub Issues or Pull Requests

Whether you have feedback on features, have encountered any bugs, or have suggestions for enhancements, we're eager to hear from you. Your insights help us make our application more robust and user-friendly. Please feel free to contribute by submitting an issue. Each contribution helps us grow and improve. If you would like to contribute to this project, please read the Contribution guidelines and make sure to follow the Code Of Conduct.

We appreciate your support and look forward to making our product even better with your help!

📃 License

GitHub License

This product is distributed under a Apache License Version 2.0, January 2004. You can review the full license agreement at LICENSE