QuickDrop is an easy-to-use file sharing application that allows users to upload files without an account, generate download links, and manage file availability, file encryption and optional password protection.
This project is made with the self-hosting community in mind as a self-hosted file-sharing application.
- File Upload: Users can upload files without needing to create an account.
- Adjustable file size limit: The maximum file size can be ajusted in the settings.
- Download Links: Generate download links for easy sharing.
- File Management: Manage file availability with options to keep files indefinitely or delete them.
- Password Protection: Optionally protect files with a password.
- File Encryption: Encrypt files to ensure privacy.
- Whole app password protection: Optionally protect the entire app with a password.
- Java
- SQLite
- Spring Framework
- Spring Security
- Spring Data JPA (Hibernate)
- Spring Web
- Spring Boot
- Thymeleaf
- Bootstrap
- Maven
Installation with Docker
- Pull the Docker image:
docker pull roastslav/quickdrop:latest
- Run the Docker container:
docker run -d -p 8080:8080 roastslav/quickdrop:latest
Optional: Use volumes to persist the uploaded files when you update the container:
docker run -d -p 8080:8080 \
-v /path/to/db:/app/db \
-v /path/to/log:/app/log \
-v /path/to/files:/app/files \
quickdrop
Installation without Docker
Prerequisites
- Java 21 or higher
- Maven
- SQLite
- Clone the repository:
git clone https://github.com/RoastSlav/quickdrop.git
cd quickdrop
- Build the application:
mvn clean package
- Run the application:
java -jar target/quickdrop-0.0.1-SNAPSHOT.jar
To update the app, you need to:
- Stop and remove the old container.
- Pull the new image.
- Start the updated container.
If you want to ensure file and database persistence between updates, you can use Docker volumes. (Check docker instalation above)
This project is licensed under the MIT License. See the LICENSE
file for details.