A comprehensive web app for scheduling and tracking flights in a flight simulator environment. Designed for virtual aviation enthusiasts, it enables seamless management of flights, aircraft, airports, crews, and passengers.
With this app, you can:
- Plan & manage flights with detailed flight plans
- Track flights step-by-step from departure to arrival
- Generate timesheets & loadsheets for accurate record-keeping
- Monitor aircraft status and optimize resource allocation
Take full control of your virtual airline operations with a realistic and structured workflow for flight simulation
This is server part of the project. For client part, please visit this repository.
Repository contains server code for Flight Tracker app.
Project is using Node.js and TypeScript in versions listed below:
| Technology | Version |
|---|---|
| Node.js | 24 |
| TypeScript | ^5.8 |
Main dependencies are Nest.js and Prisma ORM in versions listed below.
| Vendor | Version |
|---|---|
| Nest.js | ^11.1 |
| Prisma | ^6.11.0 |
This app uses docker-based virtualization to run. In order to set up project, follow these steps:
- Clone project by running:
git@github.com:oskarbarcz/flight-tracker-api.git- Prepare environment variable file by copying
.env.exampleto.envand fill it with your data.
cd flight-tracker-api
cp .env.dist .env- Use docker compose to set up the environment
docker compose up -d --buildPackages, database schema, seed data will be configured automatically.
- Your project should be up and running. Open browser and go to http://localhost/api to see the api documentation.
Default credentials for the API are:
| Role | Username | Password |
|---|---|---|
| Cabin crew | cabin-crew@example.com | P@$$w0rd |
| Operations | operations@example.com | P@$$w0rd |
| Admin | admin@example.com | P@$$w0rd |
Application has by default configured EC certificates. However, if you want to create custom ones, use the command below:
openssl ecparam -genkey -name prime256v1 -noout -out private.key
openssl ec -in private.key -pubout -out public.keyThis project uses semantic versioning.
This project has configured continuous integration and continuous deployment pipelines. It uses GitHub Actions to
automatically build, test and deploy the app to the DigitalOcean. You can find the configuration in .github/workflows
directory.
This projects adapts UNLICENSE. For more information, please visit UNLICENSE file.
I am experienced software engineer, but I am not connected anyhow with airline industry. This project is created for educational purposes only and should not be used for real-world aviation operations.