2024-07-31 18:25:30 -04:00
# file-uploader
Simple file uploader made on Crystal.
2024-08-06 18:42:53 -04:00
~~I'm making this to replace my current File uploader hosted on https://ayaya.beauty which uses https://github.com/nokonoko/uguu~~
Already replaced lol.
2024-07-31 18:25:30 -04:00
2024-08-04 15:33:49 -04:00
## Features
2024-08-06 18:42:53 -04:00
- Temporary file uploads like Uguu
2024-08-04 15:33:49 -04:00
- File deletion link (not available in frontend for now)
- Chatterino and ShareX support
2024-08-10 00:58:31 -04:00
- Video Thumbnails for Chatterino and FrankerFaceZ (Requires `ffmpeg` to be installed, can be disabled.)
2024-08-10 03:09:38 -04:00
- [Small Admin API ](./src/handling/admin.cr ) that allows you to delete files. (Needs to be enabled in the configuration)
2024-08-05 16:01:10 -04:00
- Unix socket support if you don't want to deal with all the TCP overhead
2024-08-06 18:42:53 -04:00
- Automatic protocol detection (HTTPS or HTTP)
- Low memory usage: Between 6MB at idle and 25MB if a file is being uploaded or retrieved. It will depend of your traffic.
## Usage
- Clone this repository, compile it using `shards build --release` and execute the server using `./bin/file-uploader` .
- Change the settings file `./config/config.yml` acording to what you need.
## NGINX Server block
Assuming you are already using NGINX and you know how to use it, you can use this example server block.
```
server {
# You can keep the domain prefixed with `~.` if you want
# to allow users to use any domain to upload and retrieve
# files. Like xdxd.example.com or lolol.example.com .
# This will only work if you have a wildcard domain.
server_name ~.example.com example.com;
location / {
proxy_pass http://127.0.0.1:8080;
# This if you want to use a UNIX socket instead
#proxy_pass http://unix:/tmp/file-uploader.sock;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header X-Forwarded-Host $host;
proxy_pass_request_headers on;
}
# This should be the size_limit value (from config.yml)
client_max_body_size 512M;
listen 443 ssl;
http2 on;
}
```
## Systemd user service example
```
[Unit]
Description=file-uploader-crystal
After=network.target
[Service]
Type=simple
Restart=always
RestartSec=2
LimitNOFILE=4096
Environment="KEMAL_ENV=production"
ExecStart=%h/file-uploader-crystal/bin/file-uploader
WorkingDirectory=%h/file-uploader-crystal/
[Install]
WantedBy=default.target
```
2024-08-04 15:33:49 -04:00
2024-08-01 03:08:30 -04:00
## TODO
2024-08-04 03:32:30 -04:00
- ~~Add file size limit~~ ADDED
2024-08-06 18:42:53 -04:00
- ~~Fix error when accessing `http://127.0.0.1:8080` with an empty DB.~~ Fixed somehow.
2024-08-04 15:33:49 -04:00
- Better frontend...
2024-08-10 21:13:37 -04:00
- ~~Disable file deletion if `deleteFilesCheck` or `deleteFilesAfter` is set to `0` ~~ DONE
- ~~Disable delete key if `deleteKeyLength` is `0` ~~ DONE (But I think there is a better way to do it)
- ~~Exit if `fileameLength` is `0` ~~ DONE
2024-08-05 12:11:38 -04:00
- ~~Disable file limit if `size_limit` is `0` ~~ DONE
- ~~Prevent files from being overwritten in the event of a name collision~~ DONE
- Dockerfile and Docker image (Crystal doesn't has dependency hell like other languages so is not really necessary to do, but useful for people that want instant deploy)
2024-08-10 21:13:37 -04:00
- Custom file expiration using headers (Like rustypaste)
- Small CLI to upload files (like `rpaste` from rustypaste)