From 921f208b25f9560388df79d2593e85a501e15412 Mon Sep 17 00:00:00 2001 From: Thomas Dickson Date: Sat, 23 Nov 2024 14:23:41 +1300 Subject: [PATCH] feat: additional docker-compose and readme formatting --- README.md | 49 +++++++++++++++++++++++++++++++-------- deploy.docker-compose.yml | 14 +++++++++++ 2 files changed, 53 insertions(+), 10 deletions(-) create mode 100644 deploy.docker-compose.yml diff --git a/README.md b/README.md index ea47408..e8a9bf8 100644 --- a/README.md +++ b/README.md @@ -10,26 +10,55 @@ A very lightweight URL shortener. ### Standalone -You can use ssurlss standalone by manually compiling & installing it in a directory. Running it for the first time will generate the `ssurlss.toml` config file, which can be edited, and the changes will take affect once ssurlss is restarted. +You can use ssurlss standalone by manually compiling & installing it +in a directory. Running it for the first time will generate the +`ssurlss.toml` config file, which can be edited, and the changes +will take affect once ssurlss is restarted. ### Docker -You can build the docker image using supplied `docker-compose.yml` using `docker-compose up` in a clone of this repo. +#### Using GitHub Packages -To use a specific release, change the `build: .` to `build: https://github.com/Hoverth/ssurlss.git#v1.1.0` (just change the `v1.1.0` to whatever [release](https://github.com/Hoverth/ssurlss/releases) you want to target). +Use the supplied +[deploy.docker-compose.yml](https://github.com/Hoverth/ssurlss/blob/main/deploy.docker-compose.yml) +, or simply run + +```sh +docker run -p 8000:8000 \ + -v ./ssurlss.toml:/ssurlss.toml \ + ghcr.io/hoverth/ssurlss:main +``` + +#### Build yourself + +You can build the docker image using supplied `docker-compose.yml` +using `docker-compose up` in a clone of this repo. + +To use a specific release, change the `build: .` to +`build: https://github.com/Hoverth/ssurlss.git#v1.1.0` +(just change the `v1.1.0` to whatever +[release](https://github.com/Hoverth/ssurlss/releases) you want to target). ## Configuration -There are several options to configure ssurlss, which can both be controlled via changes in the config, or set via environment variables (which override the config file configuration). +There are several options to configure ssurlss, which can both be +controlled via changes in the config, or set via environment +variables (which override the config file configuration). The following list is formatted as: `- toml_name (ENVNAME, default value) Notes` -- host (HOST, `"http://localhost:8000"`) This is only really needed if allowing new entries -- url_path (URLPATH, `""`) The path that the application should use, e.g. `/ssurlss/` -- link_path (LINKPATH, `"links"`) The subpath that links should use, e.g. `/link/` -- port (PORT, `8000`) The port for the server to listen on, if using in docker just set the mapped port in the `docker-compose.yml` -- allow_new (ALLOWNEW/DISALLOWNEW, `true`) Setting either envvar to 1 will set the relevant value in the config. -- entries_len (no envvar, `0`) A helpful tracking value for admin purposes, no environment variable and not used anywhere (write-only). +- host (HOST, `"http://localhost:8000"`) This is only really needed +if allowing new entries +- url_path (URLPATH, `""`) The path that the application should use, +e.g. `/ssurlss/` +- link_path (LINKPATH, `"links"`) The subpath that links should use, +e.g. `/link/` +- port (PORT, `8000`) The port for the server to listen on, if using +in docker just set the mapped port in the `docker-compose.yml` +- allow_new (ALLOWNEW/DISALLOWNEW, `true`) Setting either envvar to +1 will set the relevant value in the config. +- entries_len (no envvar, `0`) A helpful tracking value for admin +purposes, no environment variable and not used anywhere (write-only). ## License diff --git a/deploy.docker-compose.yml b/deploy.docker-compose.yml new file mode 100644 index 0000000..43ce0d7 --- /dev/null +++ b/deploy.docker-compose.yml @@ -0,0 +1,14 @@ +services: + ssurlss: + image: ghcr.io/hoverth/ssurlss:main + ports: + - "8000:8000" + volumes: + - "${PWD}/ssurlss.toml:/ssurlss.toml" + environment: + HOST: http://localhost:8000 + #URLPATH: "" + LINKPATH: "links" + PORT: 8000 + ALLOWNEW: 1 + #DISALLOWNEW: 1