Architecture
Project Structure
The project is organized into the following directories:
.github
: Contains the GitHub Actions workflows, issue and pull request templates, linter configuration files, and other GitHub-specific files.CLI
: Maven child module containing the source code for the Drifty CLI.GUI
: Maven child module containing the source code for the Drifty GUI.Core
: Maven child module containing the shared code between the CLI and GUI.Website
: Contains the source code for the Drifty website (A Next.js application).website_redirection
: Contains the source code for the redirection page for the old Drifty website .config
: Contains the configuration files for building the native installers and executables.Docker
: Contains the Dockerfile to build and run the Drifty application in a Docker container.dev
: Contains the Dockerfiles to build and run the Drifty application in a Docker container for development purposes.CLI
: Contains the Dockerfile to build and run the Drifty CLI executable in a Docker container for development purposes.GUI
: Contains the Dockerfile to build and run the Drifty GUI executable in a Docker container for development purposes.commons
: Contains the Dockerfiles for the base images used by the Drifty CLI and GUI Dockerfiles.
prod
: Contains the Dockerfile to build and run the Drifty application in a Docker container for production purposes.
Technologies Used
The Drifty project uses the following technologies:
- Java: The project is written in Java, which is a high-level, class-based, object-oriented programming language.
- JavaFX: The project uses JavaFX as the GUI toolkit for Drifty GUI.
- Maven: The project uses Maven as the build automation and project management tool.
- GraalVM: The project uses GraalVM to build native executables for the Drifty CLI and GUI.
- GluonFX Maven Plugin: The project uses the GluonFX Maven Plugin (which uses GraalVM under the hood) to build native executables for the Drifty GUI.
- Next.js: The project uses Next.js to build the Drifty website.
- Tailwind CSS: The project uses Tailwind CSS as the main CSS framework for the Drifty website.
- Docker: The project uses Docker to containerize the Drifty application for development and production purposes.
- GitHub Actions: The project uses GitHub Actions for CI/CD workflows.