Backend
This repository contains the backend code for the application. It utilizes FastAPI to quickly create a RESTful API that exposes the endpoints of the route optimizer.
Getting Started
Directory Structure
- The code for the Python application is located in the
src
directory. - Package management is handled with pipenv, and the dependencies are listed in the
Pipfile
. - Since the application is designed to be deployed in a container, the
Dockerfile
is provided to build the image.
Setting Up the Development Environment
To set up your development environment using pipenv, follow these steps:
-
Install
pipenv
by running:sudo apt install pipenv
-
Create and activate a virtual environment:
pipenv shell
-
Install the dependencies listed in the
Pipfile
:pipenv install
-
The virtual environment will be created under:
~/.local/share/virtualenvs/...
Deployment
To deploy the backend docker container, we use kubernetes. Modifications to the backend are automatically pushed to a two-stage environment through the CI pipeline. See [deployment/README](deployment/README.md] for further information.
The deployment configuration is included as a submodule in the deployment
directory. The standalone repository is under https://git.kluster.moll.re/anydev/anyway-backend-deployment/.
Development
The backend application is structured around the src
directory, which contains the core components for handling route optimization and API logic. Development generally involves working with key modules such as the optimization engine, Overpass API integration, and utilities for managing landmarks and trip data.
Key Areas:
- API Endpoints: The main interaction with the backend is through the endpoints defined in
src/main.py
. FastAPI simplifies the creation of RESTful services that manage trip and landmark data. - Optimization Logic: The trip optimization and refinement are handled in the
src/optimization
module. This is where the core algorithms are implemented. - Landmark Management: Fetching and prioritizing points of interest (POIs) based on user preferences happens in
src/utils/LandmarkManager
. - Testing: The
src/tests
directory includes tests in various scenarii, ensuring that the logic works as expected.
For detailed information, refer to the src README.
Running the Application:
To run the backend locally, ensure that the virtual environment is activated and all dependencies are installed as outlined in the "Getting Started" section. You can start the FastAPI server with:
uvicorn src.main:app --reload