A website for temporary file- or text hosting https://trash.ctdo.de/
Go to file
neri 7f6db2de40 chore: version 2.3.6 2023-05-24 10:53:56 +02:00
snippet feat: add abuse mail link to footer 2023-02-11 00:16:51 +01:00
src refactor: use results for deletion failures 2023-05-24 10:53:07 +02:00
static fix: increase upload button contrast 2023-04-25 11:30:57 +02:00
template fix: remove unnecessary label links, update dependencies 2023-04-26 20:28:48 +02:00
.dockerignore add dockerignore 2020-08-07 02:11:56 +02:00
.gitignore feat: update styling and layout 2023-02-08 12:34:24 +01:00
Cargo.lock chore: version 2.3.6 2023-05-24 10:53:56 +02:00
Cargo.toml chore: version 2.3.6 2023-05-24 10:53:56 +02: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 feat: add abuse mail link to footer 2023-02-11 00:16:51 +01: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 showing the web form for file or text upload

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
ABUSE_MAIL email address to report abuse to

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