File path with clickable GitHub link | Purpose (1 line description) |
---|---|
UserServiceImpl.java | Contains the business logic for creating, retrieving, and validation user data |
UserController.java | Handles HTTP requests for user operations |
KeycloakApiClient.java | Manages user accounts and handles Keycloak authentication in the project |
GlobalExceptionHandler.java | Manages and returns error responses for various exceptions in the user service |
AxiosInstance.tsx | Handle the API requests with error handling |
Test file path with clickable GitHub link | Purpose (1 line description) |
---|---|
MogoConfigTest.java | Ensures correct MongoDB client configuration and custom conversions |
UserServiceTest.java | Tests user creation, error handling for duplicates, and user retrieval |
UserServiceTest.java | Validates the business logic for user creation, retrieval, validation, and error handling |
frontend-ci-cd.yml | Runs Jest tests on frontend code for pull requests and pushes to main, dev, and release branches |
axiosInstance.test.ts | Perform tests on the axiosInstance.tsx to ensure proper error handling |
Sporta connects users who are passionate about playing sports, enabling them to create and join public events for games like soccer, basketball, tennis, and more. Users can register, create profiles with their skill levels, and browse events based on location and availability. The app allows for real-time updates on event participation, skill-based filtering, and in-app messaging to coordinate with others. Sporta enables users to post photos and rate fellow players to foster engagement.
Name | Student ID | GitHub ID | Email Address |
---|---|---|---|
Daniel Duguay | 40202775 | DanDuguay | Duguay9@gmail.com |
Nicolas Chelico | 40156158 | NicolasChelico | nicolas.chelico@outlook.com |
Wadeh Hamati | 40216893 | wade3hamati | wade3_hamati@outlook.com |
Walid Achlaf | 40210355 | walidoow | walidachlaf@gmail.com |
Monika Moanes | 40188452 | MonikaaMoanes | monicanasser6@gmail.com |
Khalil Garaali | 40226310 | KhalilGarali | garalikhalil@gmail.com |
Youssef Alsheghri | 40108014 | yousfino | youssef.alsheghri@gmail.com |
Ziad Elsharkawi | 40213438 | Ziadsharkos | ziadelsharkawi@outlook.com |
Patrick MacEachen | 40209790 | patrickmac3 | patrickmaceachen9@gmail.com |
Joud Babik | 40031039 | JRB958 | j_babik@live.concordia.ca |
Jean-Nicolas Sabatini-Ouellet | 40207926 | wolfie7679 | je_sabat@live.concordia.ca |
This guide provides all the steps needed to set up, build, and run this project, including Docker containerization and Gradle configuration. It is important to note that this is the main setup for the backend. In order to setup the frontend, please consult the following README.md to understand more about the Expo app.
Before starting, ensure you have the following installed:
- Git: for cloning the repository.
- Docker: for containerizing the application.
- Java Development Kit (JDK): version 21.
- Gradle: or use the Gradle wrapper (
./gradlew
) included in the project.
First, clone the repository to your local machine:
git clone <repository-url>
cd <repository-directory>
Use Gradle to build the project and run tests.
./gradlew build
This command will compile the project, package it, and run unit tests.
This project uses a Dockerfile to package the application for containerized deployment.
The Dockerfile sets up the container with an OpenJDK base image, configures environment variables, copies the JAR file, and exposes port 8080.
./gradlew build
The generated JAR file will be located in build/libs
as project-name-0.0.1-SNAPSHOT.jar
.
docker build --build-arg JAR_FILE=build/libs/project-name-0.0.1-SNAPSHOT.jar -t project-image .
To run the container, map port 8080 and use an .env
file to provide the environment variables:
docker run -p 8080:8080 --env-file .env project-image
Replace .env
with the path to your environment variable file or set the variables directly in the command.
The build.gradle
file specifies dependencies, configurations, and build tasks. Key sections include:
This project relies on several microservices, each with its own Docker setup. All microservices depend on the services defined in a shared docker-compose.yml
file, which includes services such as MongoDB, MySQL (for Keycloak), and Keycloak itself. These services must be running for the microservices to function properly.
The docker-compose.yml
file configures and manages the required services. You will need to ensure that the services are up and running before starting any microservice.
-
Navigate to the directory of the microservice you want to run.
-
Make sure the
docker-compose.yml
file is present and configured. -
Run the following command to start all the required services for that microservice:
docker-compose up --build
Once the services are up and running, the microservice will be able to interact with MongoDB, Keycloak, and other dependencies.
The project consists of several microservices, each located in its respective folder under Microservices/<service-name>
. The README assumes the backend is located at the root of the project directory, but since we have multiple microservices, each microservice has its own folder and configuration.
To run a specific microservice, you need to follow the setup steps (including using Docker Compose) inside each microservice directory:
- Navigate to the corresponding microservice directory under
Microservices/
:
cd Microservices/<service-name>
- Run Docker Compose for that microservice:
docker-compose up --build
This ensures that each microservice runs with its own set of services (like databases or authentication), and you can independently manage and deploy them as needed.
After building the project and Docker image, you can access the application at http://localhost:8080