forked from quinncheong/IS213-driver-app
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathREADME.txt
109 lines (89 loc) · 4.5 KB
/
README.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
<!-- ABOUT THE PROJECT -->
## About The Project
NinjaTruck aims to be the last mile delivery management solution for delivery drivers.
The application covers the most essential features a delivery driver will need when
carrying out their day to day responsibilities of delivering a parcel to customers.
## Built With
### Frontend
* [Vue.js](https://vuejs.org/)
* [Quasar](https://quasar.dev/)
### API Gateway
* [KONG](https://konghq.com)
### Backend
* [Python](https://python.org/)
* [Node.js](https://nodejs.org/)
* [Java Spring Boot](https://spring.io/)
* [Docker](https://docker.com)
### Message Brokers
* [RabbitMQ](https://rabbitmq.com)
* [Apache Kafka](https://kafka.apache.com)
### External APIs used
* [Weather API](https://openweathermap.org/current)
* [Google Maps API](https://www.npmjs.com/package/vue2-google-maps)
* [Twilio API](https://www.twilio.com/docs/sms/api/message-resource)
* [Nodemailer API](https://nodemailer.com)
<!-- GETTING STARTED -->
## Getting Started
### Backend
Make sure you have a clean environment with no other containers as it can possibly conflict with this project’s ports mapping, image or container naming/labeling. Make sure that the Kong container and image is also deleted along with its network to set up a new kong configuration.
1. From the directory ./IS213-driver-app, open the terminal and enter `docker compose up`
2. Access [http://localhost:1337](http://localhost:1337) in a browser to create an admin user for Konga
```
Username: admin
Email: <your email address>
Password: adminadmin
```
3. Sign in to continue
4. Connect Konga to Kong by creating a new connection
```
Name: default
Kong Admin URL: http://kong:8001
```
5. Go to Snapshots located on bottom right of the sidebar
6. Select _IMPORT FROM FILE_ and import ./tools/kongSnapshot.json
7. Click on _DETAILS_ for the new snapshot created which ends with Ninjatruck
8. Select _RESTORE_, tick all of the boxes, and click on _IMPORT OBJECTS_
9. Repeat step 8 until there is only 1 failed item left being under _key-auths_
10. Select _CONSUMERS_ on the side bar and select driver
11. Click on _Credentials_ and select _API KEYS_
12. Select _CREATE API KEY_ and key in: _BtqGD0VZBhHgFiIm2fbfA5zdzXmN6Coz_ and _SUBMIT_
## Prerequisites
* Docker version 20.10.13, build a224086
* Node - v16.13.0
Ensure you are running the same version by running the packages with `--version` in the terminal
<!-- USAGE EXAMPLES -->
## Usage
1. Open folder in vscode, cd “Frontend Code”, and open terminal
2. Install required dependencies
```sh
$ npm install
```
3. Launch NinjaTruck Application
```sh
$ quasar dev
```
4. In browser, tap f12 to open console (as platform is only compatible for mobile)
## Scenario 1
Driver logs in and views his dashboard
### Beyond the Lab
1. KONG is used as our API Gateway mainly for security implementation. Kong keeps the internal microservices from being directly exposed to external clients. 3 Plugins was also used to configure Kong:
* Kong’s Bot detection and rate limiting was used to prevent any bot attacks, DoS attack, and limit login attempts in case an attacker tries to brute force through the login.
* Key-auth plugin was also used to add another layer of security by allowing only users with an api key belonging to Driver type consumer to access the microservices through kong.
2. Driver microservice is coded in Java SpringBoot. This is to highlight that the microservices are language agnostic.
3. To handle exceptions in business logic, Error handling is implemented if username or password is incorrect when logging in. User will be notified of the incorrect username or password
## Scenario 2
Driver views map of all his parcels for delivery
## Scenario 3
Driver completes a delivery of a parcel and marks it as either completed or failed
### Beyond the Lab
1. Used Kafka as our message broker between Update Parcel Status and SMS microservice. Kafka is designed for holding and distributing large volumes of messages. Considering how there are hundreds of thousands of parcels delivered daily, kafka would be a good choice to handle the large amount of messages.
2. Kafka uses their own custom kafka protocol.
3. SMS microservice is built with Node.js. This is to highlight that the microservices are language agnostic.
4. To handle exceptions in business logic, Error handling is implemented if delivery has not been fulfilled.
<!-- ACKNOWLEDGMENTS -->
## Acknowledgments
* [Greg G Tan Jun Kai]()
* [Hazel Ma Ruiqi]()
* [Ian Chia Chern Yi]()
* [Juan Sebastian]()
* [Quinn Cheong Shi Han]()