From 571aebf02732eb09436de5d05d0dfb8e769f0887 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Todor=20Bogosavljevi=C4=87?= Date: Fri, 23 Aug 2024 16:26:14 +0200 Subject: [PATCH] added README.md and more documentation --- README.md | 72 +++++++++++++++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 70 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index dd0b0d1..da070f0 100644 --- a/README.md +++ b/README.md @@ -1,3 +1,71 @@ -# upload.x1b.dev +# x1b / upload -A simple one file upload script to push images to the cloud. +A very minimal script to host a fully-fledged file upload & URL shortening service. It is under a 100 lines of Python code, and is fully customizable with an external configuration file. + +It features: +- File upload +- URL shortening +- Size limits +- Time limits +- A landing page +- Customizable with an external file + +## Usage + +You can push files to it using the following command: +`curl -F file=@your_file up.x1b.dev.com` + +You can shorten URL's by using this command and providing the target URL: +`curl -d "url=https://example.com" up.x1b.dev` + +After any action you will get a URL with a 6-character key like: +`https://up.x1b.dev.com/xg29a6` + +## Requirements + +To run this you will need the following packages: + +- Default Python packages (os, requests, etc.) +- Flask +- SQlite3 + +## Setup + +After installing the required packages, you can configure your instance, and run the main python script with: +`python3 main.py` + +Everything will be set up automatically for a first-time run. + +## Configuration + +The example configuration file looks like this: +```json +{ + "upload_folder": "./uploads", + "max_file_size": 104857600, + "expiration_time": 604800, + "data_file": "data.db", + "base_url": "http://localhost:5000/", + "name": "up.x1b.dev" +}``` + +And here is what the fields mean: + +upload_folder - the folder where the uploads will be stored +max_file_size - maximum upload file size in bytes +expiration_time - how long files take to expire in seconds +data_file - sqlite3 database file +base_url - your domain url +name - what your website is called (doesn't have to be same as domain name) + +#### Reverse proxy + +You may want to set this up on a domain name, and not using the server IP. You can do this with a reverse proxy. + +You can find documentation on how to set up a [reverse proxy with nginx here](https://docs.nginx.com/nginx/admin-guide/web-server/reverse-proxy/). + +## Contribution + +Feel free to open pull requests to implement features, or issues to request features / report problems. The only rule is to keep the `main.py` file under 100 lines of code. + +Thanks for reading, and happy uploading! \ No newline at end of file