A website for temporary file- or text hosting https://trash.ctdo.de/
Go to file
neri 24c4307ce5 fix: payload too large, failed binary content type detection 2023-02-02 20:58:34 +01:00
snippet remove wrong lang=javascript attributes from script tags 2022-05-09 11:20:17 +02:00
src fix: payload too large, failed binary content type detection 2023-02-02 20:58:34 +01:00
static feat: larger textarea on textview 2023-01-05 20:43:50 +01:00
template add button to view text content as raw file 2022-10-07 14:59:57 +02:00
.dockerignore add dockerignore 2020-08-07 02:11:56 +02:00
.gitignore chore: update dependencies 2022-04-24 00:37:20 +02:00
Cargo.lock fix: payload too large, failed binary content type detection 2023-02-02 20:58:34 +01:00
Cargo.toml fix: payload too large, failed binary content type detection 2023-02-02 20:58:34 +01:00
Dockerfile version 1.2.0 2022-10-07 16:10:05 +02:00
LICENSE license as agpl 2021-10-16 00:22:54 +02:00
README.md update/fix rate limit environment variables 2022-10-15 14:32:20 +02:00
docker-compose.yml.sample add FILES_DIR to sample docker-compose environment 2022-04-11 00:01:19 +02:00
init-db.sql fix db migration 2022-09-30 15:27:35 +02:00
mime.types determine corrext file extension for text uploads 2022-10-07 15:51:38 +02:00
screenshot.png update screenshot 2022-01-29 13:21:00 +01:00

README.md

datatrash

A file and text uploading service with configurable time limit

Application screenshot

running

For running on docker, use the provided docker-compose.yml.sample and adapt it to your needs. To run the software directly, use the compiling instructions below.

config

  • The static files directory needs to be next to the binary.
  • The static directory sadly needs to be writable
    • On startup the index.html will be generated based on the config
  • The maximum filename length is 255

General configuration

environment variable default value description
STATIC_DIR ./static directory to generate "static" files into
FILES_DIR ./files directory to save uploaded files into
UPLOAD_MAX_BYTES 8388608 (8MiB) maximum size for uploaded files
BIND_ADDRESS 0.0.0.0:8000 address to bind the server to
RATE_LIMIT true whether download rate should be limited
RATE_LIMIT_PROXIED false whether rate limit should read x-forwarded-for
RATE_LIMIT_REPLENISH_SECONDS 60 seconds to wait between requests
RATE_LIMIT_BURST 480 allowed request burst

Database configuration

environment variable default value
DATABASE_URL
DATABASE_USER
DATABASE_PASS
DATABASE_HOST localhost
DATABASE_NAME datatrash

No auth limits configuration

Require authentication for certain uploads

  • The password is provided as plain text
  • Uploads with longer validity than NO_AUTH_MAX_TIME require authentication
  • Uploads larger than NO_AUTH_LARGE_FILE_SIZE require auth when they are valid for longer than NO_AUTH_LARGE_FILE_MAX_TIME
  • All times are in seconds, the size is in bytes
environment variable default value
AUTH_PASSWORD
NO_AUTH_MAX_TIME
NO_AUTH_LARGE_FILE_MAX_TIME
NO_AUTH_LARGE_FILE_SIZE

compiling

cargo build --release

or

docker build -t datatrash .
docker cp datatrash:/home/rust/.cargo/bin/datatrash datatrash