Add Docker Secrets Support
Documentation Update Add more examples to the compose
This commit is contained in:
parent
f0e15b5c7c
commit
6abd0adb42
3 changed files with 73 additions and 1 deletions
|
|
@ -89,6 +89,12 @@ Available options/variables and their default values:
|
||||||
|
|
||||||
See `config.js` for all options.
|
See `config.js` for all options.
|
||||||
|
|
||||||
|
#### Using Secrets for Docker
|
||||||
|
|
||||||
|
You can set any options/variables via [docker secrets](https://docs.docker.com/compose/use-secrets/) by appending `_FILE` to the variable/option name, e.g. to set `EG_PASSWORD` as secret replace it with `EG_PASSWORD_FILE` and setup secret as described in a docker documentation. You can find example in `docker-compose.yml`.
|
||||||
|
|
||||||
|
If you set same options as variables and as secret, secret value will override variable.
|
||||||
|
|
||||||
#### How to set options
|
#### How to set options
|
||||||
You can add options directly in the command or put them in a file to load.
|
You can add options directly in the command or put them in a file to load.
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,9 +1,20 @@
|
||||||
# start with `docker compose up`
|
# start with `docker compose up`
|
||||||
|
version: "3.7"
|
||||||
|
|
||||||
|
secrets:
|
||||||
|
vnc_password:
|
||||||
|
file: .secrets/vnc_password_common
|
||||||
|
epic_user:
|
||||||
|
file: .secrets/epic_user
|
||||||
|
epic_password:
|
||||||
|
file: .secrets/epic_password
|
||||||
|
epic_otp:
|
||||||
|
file: .secrets/epic_otp
|
||||||
|
|
||||||
services:
|
services:
|
||||||
free-games-claimer:
|
free-games-claimer:
|
||||||
container_name: fgc # is printed in front of every output line
|
container_name: fgc # is printed in front of every output line
|
||||||
image: ghcr.io/vogler/free-games-claimer # otherwise image name will be free-games-claimer-free-games-claimer
|
image: ghcr.io/vogler/free-games-claimer # otherwise image name will be free-games-claimer-free-games-claimer
|
||||||
build: .
|
|
||||||
ports:
|
ports:
|
||||||
# - "5900:5900" # VNC server
|
# - "5900:5900" # VNC server
|
||||||
- "6080:6080" # noVNC (browser-based VNC client)
|
- "6080:6080" # noVNC (browser-based VNC client)
|
||||||
|
|
@ -13,3 +24,30 @@ services:
|
||||||
environment:
|
environment:
|
||||||
# - EMAIL=foo@bar.org
|
# - EMAIL=foo@bar.org
|
||||||
# - NOTIFY='tgram://...'
|
# - NOTIFY='tgram://...'
|
||||||
|
# - NOTIFY_TITLE="Optional title for notifications"
|
||||||
|
# - VNC_PASSWORD="VNC Password"
|
||||||
|
- VNC_PASSWORD_FILE=/run/secrets/vnc_password
|
||||||
|
# - BROWSER_DIR="data/browser"
|
||||||
|
# - TIMEOUT="60"
|
||||||
|
# - LOGIN_TIMEOUT="80"
|
||||||
|
# - EMAIL="Default email for any login"
|
||||||
|
# - PASSWORD="Default password for any login"
|
||||||
|
# - EG_EMAIL="Epic Games email for login"
|
||||||
|
# - EG_PASSWORD="Epic Games password for login"
|
||||||
|
# - EG_OTPKEY="Epic Games MFA OTP key"
|
||||||
|
- EG_EMAIL_FILE=/run/secrets/epic_user
|
||||||
|
- EG_PASSWORD_FILE=/run/secrets/epic_password
|
||||||
|
- EG_OTPKEY_FILE=/run/secrets/epic_otp
|
||||||
|
# - EG_PARENTALPIN="Epic Games Parental Controls PIN"
|
||||||
|
# - PG_EMAIL="Prime Gaming email for login"
|
||||||
|
# - PG_PASSWORD="Prime Gaming password for login"
|
||||||
|
# - PG_OTPKEY="Prime Gaming MFA OTP key"
|
||||||
|
# - PG_REDEEM="0"
|
||||||
|
# - PG_CLAIMDLC="0"
|
||||||
|
# - GOG_EMAIL="GOG email for login"
|
||||||
|
# - GOG_PASSWORD="GOG Password"
|
||||||
|
secrets:
|
||||||
|
- epic_user
|
||||||
|
- epic_password
|
||||||
|
- epic_otp
|
||||||
|
- vnc_password
|
||||||
|
|
|
||||||
|
|
@ -13,6 +13,34 @@ rm -f /fgc/data/browser/SingletonLock
|
||||||
# ls -l /tmp/.X11-unix/
|
# ls -l /tmp/.X11-unix/
|
||||||
rm -f /tmp/.X1-lock
|
rm -f /tmp/.X1-lock
|
||||||
|
|
||||||
|
# Check and export secrets to variables if exist
|
||||||
|
# Get list of VARIABLES with "_FILE" at the end
|
||||||
|
SECRETS_LIST=$(env | grep "_FILE")
|
||||||
|
if [ ! -z "$SECRETS_LIST" ]; then
|
||||||
|
|
||||||
|
echo "Secrets were found, will try to convert them into the Variables..."
|
||||||
|
|
||||||
|
# Will read one by one, remove "_FILE" from the end and get value from the file
|
||||||
|
# Known bug: if you set "=" in the variable value, it will be converted to the space
|
||||||
|
while read SECRETS; do
|
||||||
|
SECRET_VALUE=$(echo $SECRETS | awk -F'[=]' '{ $1=""; print $0 }')
|
||||||
|
# Remove unneeded space at the begging
|
||||||
|
SECRET_VALUE=${SECRET_VALUE:1}
|
||||||
|
SECRET_NAME=$(echo $SECRETS | awk -F'[=]' '{ print $1 }')
|
||||||
|
# Remove "_FILE" at the end of the Variable Name
|
||||||
|
SECRET_NAME=${SECRET_NAME::-5}
|
||||||
|
|
||||||
|
# If file with value readable, use it to fetch value and export variable
|
||||||
|
if [ -r "$SECRET_VALUE" ]; then
|
||||||
|
echo "Setting $SECRET_NAME with value from $SECRET_VALUE"
|
||||||
|
export "$SECRET_NAME"="$(cat "$SECRET_VALUE")"
|
||||||
|
else
|
||||||
|
echo "ERROR - $SECRETS is configured, but file not exist or not readable."
|
||||||
|
fi
|
||||||
|
done <<< $SECRETS_LIST
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
# 6000+SERVERNUM is the TCP port Xvfb is listening on:
|
# 6000+SERVERNUM is the TCP port Xvfb is listening on:
|
||||||
# SERVERNUM=$(echo "$DISPLAY" | sed 's/:\([0-9][0-9]*\).*/\1/')
|
# SERVERNUM=$(echo "$DISPLAY" | sed 's/:\([0-9][0-9]*\).*/\1/')
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue