File upload, pastebin, and URL shortening all in one app
File sharing, url shortener and pastebin all in one place with QR code and curl support. Uses stream based cryptography and data processing that can handle gigabytes of data with fixed memory and cpu usage. It can run on anything including PaaS like repl.it or Render and is very easy to customize.
Please star this project if you find it useful, thank you!
Why it's better than other similar apps โก
works in mobile browsers, can upload file / text with ctrl+v, drag and drop, browse file or through terminal
Extremely easy to set up, all you need is
go build .or use the docker-compose.yaml and it's doneVery easy for modificiations, don't like the style? pick a .css file from here and replace the
static/theme.css, don't like the layout? the html page is well commented and structuredCan run on any OS or deployment platforms like repl.it, render, fly.io, etc
Designed to run efficiently on any system, regardless of its CPU or memory resources
Can handle gigabytes of file upload and download with fixed memory and cpu usage
Encryption done right, all your data can be secured with AES & pbkdf2 for passwords
Decryption is done on the fly, the encrypted data is never decrypted to the disk
Short & unambiguous URL generation (with letters like ilI1 omitted) with collision detection
QR code support to quickly share files to / between mobile devices
URL shortener ๐
simply paste any valid url (must start with http:// or https://) to the textbox and upload
Dont like how it looks? ๐จ
pick a .css file from here and replace the static/theme.css, or search for "classless css"
How to build with docker ๐
Download / clone this repo
Make a folder called
uploadsRun
docker compose up
How to build without docker ๐
Download / clone this repo
Open terminal
Run
go build .
Settings โ๏ธ
You can modify the variables inside data/settings.json
fileSizeLimitMB= limit file size (in megabytes)textSizeLimitMB= limit text size (in megabytes)streamSizeLimitKB= limit file encryption, decryption, upload & download buffer stream size (in kb) to limit memory usagestreamThrottleMS= add throttle to the encryption, decryption, upload & download buffer to limit cpu usagepbkdf2Iterations= key derivation algorithm iteration, the higher the better, but 100000 should be enoughcmdUploadDefaultDurationMinute= default file duration if you upload file through curl if duration is not specified
You can modify CPU/memory usage by calculating the memory usage / sec with streamSizeLimitKB * (1000/streamThrottleMS), the default setting can handle 40 MB of data/second on file upload, download, encryption & decryption / second, you can tune this down if needed
Curl upload โฌ๏ธ
curl -F "file=@main.go" -F "duration=10" -F "pass=123" -F "burn=true" yoursite.com
Note that the duration, password, and burn is totally optional, you can just write curl -F "file=@file.txt" yoursite.com for quick upload
Security ๐
For maximum security, it is recommended to encrypt your file before uploading
Contribution ๐ค
The core features are complete & there will be no new major feature unless it's a really good idea. Any changes to the project will either be minor improvements or bugfix.