This repository contains the REST API which the weekplanner uses to connect with the database through, here the web-api, server and database make out the backend of the project.
The web-api is written as a .NET project and it is therefore written in C#. The current version of the project is .NET 8 and EF6, and it is not compatible with newer versions of these frameworks. The project consists of different controllers with endpoints for the requests made by the client, repositories for accessing the database through and models, which translates into the different entities/tables that are in the database.
An explination of the structure of the web-api can be found on the wiki, and a setup guide can be found here.
This repository uses the scaled trunkbased branching strategy, as explained here: GitHub setup. In this repository the "trunk" is named develop, and this is the branch that all developers should branch from when solving an issue. The naming convention for these branches are:
Issue type | Name | Example |
---|---|---|
User Story | feature/<issue-number> | feature/697 |
Task | task/<issue-number> | task/918 |
Bug fix | bug-fix/<issue-number> | bug-fix/299 |
Other than the branches being used for development and the trunk, there exists some release branches, where the newest release branch is running on the PROD-environment. The release branches can only be created by members of the release group in the organization, and they should adhere to the following naming convention:
- Naming is release-<release-version>, e.g. release-1.0
- A hot-fix on a release will increment the number after the dot (.)
- A new release will increment the number before the dot (.)
To run the wep-api with Docker:
- Install Docker Desktop or Docker + Docker Compose, and ensure that the Docker engine is running.
- Clone the repository and navigate into the web-api folder.
- In a terminal, write
docker compose up
, you can optionally use the-d
flag to run headless.
The Docker Compose will setup the database and seed it with sample data before starting the web-api.
The database can be accessed from port 5100. You can confirm the web-api is running by going to the swagger endpoint.
Note: If you want to run the web-api with a local instance of MySQL, then you must change the port in the Development appsettings from 5100 to 3306.
MIT License Copyright (c) 2018-present Aalborg University