Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rapter1990/simplebanking
Simple Banking App (Spring Boot, Gradle, JUnit, Integration Test, Postgresql, Prometheus, Grafana, Github Actions, Postman)
https://github.com/rapter1990/simplebanking
ci-cd continuous-deployment continuous-integration docker docker-compose github-actions gradle grafana integration-test java junit monolith openapi postgresql postman prometheus spring-boot swagger
Last synced: 2 months ago
JSON representation
Simple Banking App (Spring Boot, Gradle, JUnit, Integration Test, Postgresql, Prometheus, Grafana, Github Actions, Postman)
- Host: GitHub
- URL: https://github.com/rapter1990/simplebanking
- Owner: Rapter1990
- Created: 2023-10-28T22:06:03.000Z (about 1 year ago)
- Default Branch: master
- Last Pushed: 2023-11-03T18:36:17.000Z (about 1 year ago)
- Last Synced: 2024-04-24T06:34:04.438Z (9 months ago)
- Topics: ci-cd, continuous-deployment, continuous-integration, docker, docker-compose, github-actions, gradle, grafana, integration-test, java, junit, monolith, openapi, postgresql, postman, prometheus, spring-boot, swagger
- Language: Java
- Homepage:
- Size: 3.5 MB
- Stars: 30
- Watchers: 0
- Forks: 6
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Case Study - Simple Banking API
In this assignment you will build a banking service that can handle any number of transactions for bank accounts. The service is part of a larger collection of services that model the inner workings of a bank. The services for the "bank account" provide a simple model of how bank accounts might work in an overly simplified world.
For this assignment, the bank account is exclusively interested in maintaining the name of the account owner, the number of the account and the account’s balance. The endpoints will be limited to methods that provide a means of crediting and debiting the account.
Your data model for the bank account object must have fields owner where the field type is java.lang.String, fields to hold the account number (String) and balance (double). the credit() service as specified above adds the supplied amount to the receiving BankAccounts balance and the the debit() service subtracts the supplied amount from the receiving BankAccounts balance.
The object model for our banking system must include transaction objects. A transaction object keeps track of the kind of transaction (deposit, withdrawal, payments etc.) as well as the date and amount of the transaction. Each transaction type will require its own parameters. The following diagram shows how BankAccounts and Transactions are related. An instance of DepositTransaction represents a deposit; a WithdrawalTransaction represents a withdrawal (the triangle on the diagram indicates inheritance). Inheritance for the PhoneBillPaymentTransaction, CheckTransaction etc. is not shown - you must decide where to put this class. All transactions must have have the fields date and amount at a minimum. The date field should contain the time of the transaction and should be automatically calculated.
![model](images/model.png)
## You can use provided project template as a start
The template project (gradle Java) is available under the src folder. We recommend that you use Quarkus or Spring(boot), Junit, JPA as the primary choices for your implementation.## Task 1: Implement and test the model
These transaction objects will be used both to make financial requests of a BankAccount and to keep a record of those requests. The following Unit test segment indicates how transactions will be used on the service side:BankAccount account = new BankAccount("Jim", 12345);
account.post(new DepositTransaction(1000));
account.post(new WithdrawalTransaction(200));
account.post(new PhoneBillPaymentTransaction("Vodafone", "5423345566", 96.50));
assertEquals(account.getBalance(), 703.50, 0.0001)### BONUS Task 1: Find a better implementation alternative
The bank account post method must do something special for each Transaction type. e.g. post(DepositTransaction) and post(WithdrawalTransaction. This solution will work but creating families of overloaded methods is discouraged as it causes problems with maintenance. Consider, if we added more Transaction subclasses we would need to keep changing the BankAccount class, overloading even more post methods. It is considered bad form in OO to write case statements based on the type of objects. It also has the same maintenance problems as the first solution. Adding more Transaction subclasses would require changes. Find a solution to delegate the operation using polymorphism so that the Bank account is never changed by introducing new transaction types. At a öinimum you shoudl make the provided uni test to run:## Task 2: Provide a REST API using Spring Rest Controllers and TEST
Provide a REST API to the banking system as follows. The following code demonstrates how BankAccounts might be used. Use services and repositories to persist your model above into a Database using JPA. Please provide tests (MOCK or othrewise) for your code:To deposit money into an account, one would use:
curl --location --request POST 'http://localhost:8080/account/v1/credit/669-7788' \
--header 'Content-Type: application/json' \
--header 'Accept: application/json' \
--data-raw ' {
"amount": 1000.0
}'response would be (200):
{
"status": "OK",
"approvalCode": "67f1aada-637d-4469-a650-3fb6352527ba"
}To withdraw money:
curl --location --request POST 'http://localhost:8080/account/v1/debit/669-7788' \
--header 'Content-Type: application/json' \
--header 'Accept: application/json' \
--data-raw ' {
"amount": 50.0
}'response would be (200):
{
"status": "OK",
"approvalCode": "a66cce54-335b-4e46-9b49-05017c4b38dd"
}To get the current account data, one would use:
curl --location --request GET 'http://localhost:8080/account/v1/669-7788'
response would be:
{
"accountNumber": "669-7788",
"owner": "Kerem Karaca",
"balance": 950.0,
"createDate": "2020-03-26T06:15:50.550+0000",
"transactions": [
{
"date": "2020-03-26T06:16:03.563+0000",
"amount": 1000.0,
"type": "DepositTransaction",
"approvalCode": "67f1aada-637d-4469-a650-3fb6352527ba"
},
{
"date": "2020-03-26T06:16:35.047+0000",
"amount": 50.0,
"type": "WithdrawalTransaction",
"approvalCode": "a66cce54-335b-4e46-9b49-05017c4b38dd"
}
]
}### Explore Rest APIs
Method
Url
Description
Request Body
Header
Valid Path Variable
No Path Variable
POST
/api/v1/account/createAccount
Create Account
CreatedAccountRequest
GET
/api/v1/account/account-number/{accountNumber}
Get Account Details
accountNumber
POST
/api/v1/account/credit
Deposit Money to Account
CreateCreditRequest
POST
/api/v1/account/debit
Withdraw Money from Account
CreateWithdrawalRequest
POST
/api/v1/account/payment
Payment of Phone Bill from Account
CreatePhoneBillPaymentRequest
### Technologies
---
- Java 11
- Spring Boot 2.5.5
- Restful API
- Lombok
- Gradle
- Junit5
- Mockito
- Integration Tests
- Docker
- Docker Compose
- CI/CD (Github Actions)
- Prometheus and Grafana
- Postman
- Actuator
- Swagger 3
- PostgreSQL### Swagger
```
http://localhost:1222/swagger-ui/index.html
```### Prerequisites
#### Define Variable in .env file
```
DATABASE_USERNAME={DATABASE_USERNAME}
DATABASE_PASSWORD={DATABASE_PASSWORD}
```---
- Gradle or Docker
---### Docker Run
The application can be built and run by the `Docker` engine. The `Dockerfile` has multistage build, so you do not need to build and run separately.Please follow directions shown below in order to build and run the application with Docker Compose file;
```sh
$ cd simplebanking
$ docker-compose up -d
```If you change anything in the project and run it on Docker, you can also use this command shown below
```sh
$ cd simplebanking
$ docker-compose up --build
```---
### Gradle Run
To build and run the application with `Gradle`, please follow the directions shown below;```sh
$ cd simplebanking
$ gradle clean build
$ gradle bootRun
```## Reference Documentation
For further reference, please consider the following sections:* [Official Gradle documentation](https://docs.gradle.org)
* [Spring Boot Gradle Plugin Reference Guide](https://docs.spring.io/spring-boot/docs/2.2.5.RELEASE/gradle-plugin/reference/html/)
* [Spring Boot DevTools](https://docs.spring.io/spring-boot/docs/2.2.5.RELEASE/reference/htmlsingle/#using-boot-devtools)### Guides
The following guides illustrate how to use some features concretely:* [Building REST services with Spring](https://spring.io/guides/tutorials/bookmarks/)
### Additional Links
These additional references should also help you:
* [Gradle Build Scans – insights for your project's build](https://scans.gradle.com#gradle)### Screenshots
Click here to show the screenshots of project
Figure 1
Figure 2
Figure 3
Figure 4
Figure 5
Figure 6
Figure 7
Figure 8
Figure 9
Figure 10
Figure 11
Figure 12
Figure 13
Figure 14
Figure 15
Figure 16
### Contributors
- [Sercan Noyan Germiyanoğlu](https://github.com/Rapter1990)