befit is a revolutionary new fitness tracking application that will help you unlock your potential and take your fitness to the next level. Do you want to have the perfect beach body? Do you want all your friends to envy you? Do you want to reach the peak of human form? Then this app is for you!
This app helps users to track their fitness. There are three main functionalities.
-
A user can create workout plans. Each plan consists of one or more exercises and there are four different types of exercises. Depending on the type, the plan also contains an "amount" of the exercise to be done. There can be exercises such as squats which have a certain number of repetitions, exercises like a plank which are performed for a specific time duration, exercises like running which have a distance associated with them and finally one can also specify the number of steps, for example for walking.
-
It is possible to create a record that a user has performed a workout plan on a given day. These records can then be retrieved and filtered so that the users can see and track their progress.
-
Users can subscribe to notifications, to be reminded that they are supposed to exercise. The notifications are delivered via email.
There are four microservices: the main one is workout-service
and the remaining are notification-service
, record-service
and stats-service
. Only workout-service
and notification-service
are "front-facing", meaning they can be used directly through the swagger-ui. record-service
has swagger-ui as well, but it is harder to use. As it is a "backend" service it doesn't redirect the user to a login screen and one must first obtain an access token through another service and paste into the swagger-ui. Unlike the other services the stats-service
is implemented in haskell so it doesn't provide any swagger-ui. It is used for creating a simple bar graph to visualize the exercise records.
- url: http://localhost:8080/
- Swagger-ui: http://localhost:8080/q/swagger-ui/
- url: http://localhost:8082/
- Swagger-ui: http://localhost:8082/q/swagger-ui/
- url: http://localhost:8082/
- Swagger-ui: http://localhost:8082/q/swagger-ui/
- url: http://localhost:8084/
- REST-API: README.md
To use the swagger-ui, one most provide it with an access token. To do that start the workout-service
service in dev mode and perform these steps:
TODO
- Prometheus: http://localhost:9090/
- Grafana: http://localhost:3000/
- Jaeger: http://localhost:16686/
- Keycloak administration: http://localhost:8180/
For managing users we use keycloak. There are three user accounts that can be used. It is also possible to register as a new user on the login screen.
Username | Password | Roles |
---|---|---|
alice | alice | user |
jdoe | jdoe | user |
admin | admin | user, admin |
To logout use one of the following URLs:
cd befit
mvn clean package
docker-compose -f docker-compose.yml build
docker-compose -f docker-compose.yml up
Or to use the services in dev mode, first start the supporting services
docker-compose -f docker-compose-dev.yml up
And then enter the root directory of each service and run
./mvnw clean compile quarkus:dev
On windows it is not possible to run the main services in docker containers. The only option is to run the supporting services using docker-compose-dev-win.yml
and then run each service individually either in dev mode or start it from the target folder (but they shouldn't be started in a container).
Additionally, if one wants to use Grafana, the url for Prometheus should be set to host.docker.internal:9090
.
-
Description of the project: ...
-
Story/scenario of usage:
-
User creates a workout plan “Workout Routine 1” consisting of exercises “Running, Planking, Pushups” and daily frequency
-
On Monday, User records that they have run for
3km
, planked for74s
and done30
pushups -
On Tuesday, User records that they have run for
0km
, planked for20s
and done10
pushups -
On Wednesday, User forgets to workout and doesn't record any exercise
-
Next day, User sets up optional daily notifications at 17:05 in order not to forget again
-
On Friday, User receives an e-mail from
[email protected]
that they should do their “Workout Routine 1”
-
-
Why you think a microservice architecture can be appropriate:
- Because there doesn't need to be much interaction between users, that makes the whole system easier to split into multiple closed units. Each feature of the system can be represented as a standalone microservice calling other microservices when needed. User then accesses the microservice that gives them the functionality they currently need.
-
Benefits of the using microservices in this project:
- Ease of development: each student can take care of their own microservice and not be bothered with others intervening on their work.
-
Drawbacks of microservices in this case:
- For some parts of the system it would be more intuitive to make them
as a monolith – namely
workout service
andrecord service
, because these two have to communicate frequently to provide the desired functionality.
- For some parts of the system it would be more intuitive to make them
as a monolith – namely
-
Responsiveness: ...
-
Resiliency:
-
record-service
crashes or the network fails -
User tries to record through the
workout-service
that they did a workout plan -
workout-service
is unable to reach therecord-service
-
workout-service
retries several times and ifrecord-service
service comes back it it successfully processes the request -
if
record-service
is still unreachableworkout-service
fails gracefully and informs user of the error using a fallback implementation
-
-
Elasticity: ...
-
Message-driveness: ...