update readme, add docker-compose installation

This commit is contained in:
lyx0 2023-09-04 18:41:51 +02:00
parent 293a47e7b0
commit 1d73f17d46

View file

@ -2,10 +2,20 @@
jaf is a simple Go program to handle file uploads. jaf is a simple Go program to handle file uploads.
If you also want to serve the uploaded files, consider a web server like [nginx](https://nginx.org/en/). If you also want to serve the uploaded files, consider a web server like [nginx](https://nginx.org/en/).
## Installation ## Installation with docker-compose and local build
**Clone** the directory: **Clone** the directory:
```bash ```bash
git clone https://github.com/leon-richardt/jaf.git git clone https://github.com/lyx0/yaf.git
```
Run **tests** (optional):
```bash
go test
```
## Installation without docker-compose
**Clone** the directory:
```bash
git clone https://github.com/lyx0/yaf.git
``` ```
**Build** the executable: **Build** the executable:
```bash ```bash
@ -16,23 +26,24 @@ Run **tests** (optional):
go test go test
``` ```
If you plan on using a systemd service or another init system, you might want to move the `jaf` executable to a different directory (e.g. `/opt`) at this point; you know your setup best. If you plan on using a systemd service or another init system, you might want to move the `yaf` executable to a different directory (e.g. `/opt`) at this point; you know your setup best.
## Configuration ## Configuration
### jaf ### yaf
There are just a few parameters that need to be configured for jaf. There are just a few parameters that need to be configured for jaf.
Refer to the `example.conf` file: Refer to the `example.conf` file:
``` ```
Port: 4711 Port: 4711
# a comment # a comment
LinkPrefix: https://jaf.example.com/ LinkPrefix: https://yaf.example.com/
FileDir: /var/www/jaf/ FileDir: /var/www/yaf/
LinkLength: 5 LinkLength: 5
ScrubExif: true ScrubExif: true
# Both IDs also refer to the "Orientation" tag, included for illustrative purposes only # Both IDs also refer to the "Orientation" tag, included for illustrative purposes only
ExifAllowedIds: 0x0112 274 ExifAllowedIds: 0x0112 274
ExifAllowedPaths: IFD/Orientation ExifAllowedPaths: IFD/Orientation
ExifAbortOnError: true ExifAbortOnError: true
FileExpiration: false
``` ```
Option | Use Option | Use
@ -45,9 +56,10 @@ Option | Use
`ExifAllowedIds` | a space-separated list of EXIF tag IDs that should be preserved through EXIF scrubbing (only relevant if `ScrubExif` is `true`) `ExifAllowedIds` | a space-separated list of EXIF tag IDs that should be preserved through EXIF scrubbing (only relevant if `ScrubExif` is `true`)
`ExifAllowedPaths` | a space-separated list of EXIF tag paths that should be preserved through EXIF scrubbing (only relevant if `ScrubExif` is `true`) `ExifAllowedPaths` | a space-separated list of EXIF tag paths that should be preserved through EXIF scrubbing (only relevant if `ScrubExif` is `true`)
`ExifAbortOnError` | whether to abort JPEG and PNG uploads if an error occurs during EXIF scrubbing (only relevant if `ScrubExif` is `true`) `ExifAbortOnError` | whether to abort JPEG and PNG uploads if an error occurs during EXIF scrubbing (only relevant if `ScrubExif` is `true`)
`FileExpiration` | whether to automatically remove files after a given time or not (`true` or `false`)
Make sure the user running jaf has suitable permissions to read, and write to, `FileDir`. Make sure the user running yaf has suitable permissions to read, and write to, `FileDir`.
Also note that `LinkLength` directly relates to the number of files that can be saved. Also note that `LinkLength` directly relates to the number of files that can be saved.
Since jaf only uses alphanumeric characters for file name generation, a maximum of `(26 + 26 + 10)^LinkLength` names can be generated. Since jaf only uses alphanumeric characters for file name generation, a maximum of `(26 + 26 + 10)^LinkLength` names can be generated.
@ -80,17 +92,37 @@ For nginx, this is achieved via the `proxy_pass_request_headers on;` option.
If you want to limit access to jaf (e.g. require basic authentication), you will also need to do this via your reverse-proxy. If you want to limit access to jaf (e.g. require basic authentication), you will also need to do this via your reverse-proxy.
## Running ## Running
### Manually
After adjusting the configuration file to your needs, run: After adjusting the configuration file to your needs, run:
```bash ```bash
jaf -configFile example.conf jaf -configFile example.conf
``` ```
Of course, you can also write a init system script to handle this for you. Of course, you can also write a init system script to handle this for you.
### Running from docker-compose
**Copy** configuration file and fill it in:
```bash
cp example.conf yaf.conf
```
**Configure** the `docker-compose.yml` volume paths:
```bash
vim docker-compose.yml
```
**Build** the local docker file:
```bash
make build
```
**Run** the local docker file with docker-compose:
```bash
make run
```
### Running from Docker ### Running from Docker
Running it from the GitHub Container Registry Running it from the GitHub Container Registry
```bash ```bash
docker run \ docker run \
-p 4712:4711 \ -p 4711:4711 \
-v /path/to/your/config.conf:/app/jaf.conf \ -v /path/to/your/config.conf:/app/jaf.conf \
-v /path/to/local/filedir:/var/www/jaf \ -v /path/to/local/filedir:/var/www/jaf \
ghcr.io/leon-richardt/jaf:latest ghcr.io/leon-richardt/jaf:latest
@ -100,21 +132,21 @@ Building the Docker image and running it locally
```bash ```bash
docker build -t jaf . docker build -t jaf .
docker run \ docker run \
-p 4712:4711 \ -p 4711:4711 \
-v /path/to/your/config.conf:/app/jaf.conf \ -v /path/to/your/config.conf:/app/jaf.conf \
-v /path/to/local/filedir:/var/www/jaf \ -v /path/to/local/filedir:/var/www/jaf \
jaf jaf
``` ```
Port 4711 is the default port for the server in `example.conf`, if you've changed this in your config you'll need to change this in the `docker run` invocations above too. Port 4711 is the default port for the server in `example.conf`, if you've changed this in your config you'll need to change this in the `docker run` invocations above too.
The above runs forwards the jaf port from 4711 in the container to 4712 on your local system. The above runs forwards the jaf port from 4711 in the container to 4711 on your local system.
## Usage ## Usage
You can use jaf with any application that can send POST requests (e.g. ShareX/ShareNix or just `curl`). You can use jaf with any application that can send POST requests (e.g. ShareX/ShareNix or just `curl`).
Make sure the file you want to upload is attached as a `multipart/form-data` field named `file`. Make sure the file you want to upload is attached as a `multipart/form-data` field named `file`.
In `curl`, a request to upload the file `/home/alice/foo.txt` could look like this: In `curl`, a request to upload the file `/home/alice/foo.txt` could look like this:
```bash ```bash
curl -L -F "file=@/home/alice/foo.txt" jaf.example.com/upload curl -L -F "file=@/home/alice/foo.txt" yaf.example.com/upload
``` ```
The response will include a link to the newly uploaded content. The response will include a link to the newly uploaded content.
Note that you may have to add additional header fields to the request, e.g. if you have basic authentication enabled. Note that you may have to add additional header fields to the request, e.g. if you have basic authentication enabled.