56 lines
2.8 KiB
Bash
56 lines
2.8 KiB
Bash
#!/usr/bin/env bash
|
||
|
||
set -eo pipefail # exit on error, error on any fail in pipe (not just last cmd); add -x to print each cmd; see gist bash_strict_mode.md
|
||
|
||
echo "Version: https://github.com/vogler/free-games-claimer/tree/${COMMIT}"
|
||
[ ! -z $BRANCH ] && [ $BRANCH != "main" ] && echo "Branch: ${BRANCH}"
|
||
echo "Build: $NOW"
|
||
|
||
# Remove chromium profile lock.
|
||
# When running in docker and then killing it, on the next run chromium displayed a dialog to unlock the profile which made the script time out.
|
||
# Maybe due to changed hostname of container or due to how the docker container kills playwright - didn't check.
|
||
# https://bugs.chromium.org/p/chromium/issues/detail?id=367048
|
||
rm -f /fgc/data/browser/SingletonLock
|
||
|
||
# Firefox preferences are stored in $BROWSER_DIR/pref.js and can be overridden by a file user.js
|
||
# Since this file has to be in the volume (data/browser), we can't do this in Dockerfile.
|
||
mkdir -p /fgc/data/browser
|
||
# fix for 'Incorrect response' after solving a captcha correctly - https://github.com/vogler/free-games-claimer/issues/261#issuecomment-1868385830
|
||
# echo 'user_pref("privacy.resistFingerprinting", true);' > /fgc/data/browser/user.js
|
||
cat << EOT > /fgc/data/browser/user.js
|
||
user_pref("privacy.resistFingerprinting", true);
|
||
// user_pref("privacy.resistFingerprinting.letterboxing", true);
|
||
// user_pref("browser.contentblocking.category", "strict");
|
||
// user_pref("webgl.disabled", true);
|
||
EOT
|
||
# TODO disable session restore message?
|
||
|
||
# Remove X server display lock, fix for `docker compose up` which reuses container which made it fail after initial run, https://github.com/vogler/free-games-claimer/issues/31
|
||
# echo $DISPLAY
|
||
# ls -l /tmp/.X11-unix/
|
||
rm -f /tmp/.X1-lock
|
||
|
||
# 6000+SERVERNUM is the TCP port Xvfb is listening on:
|
||
# SERVERNUM=$(echo "$DISPLAY" | sed 's/:\([0-9][0-9]*\).*/\1/')
|
||
|
||
# Options passed directly to the Xvfb server:
|
||
# -ac disables host-based access control mechanisms
|
||
# −screen NUM WxHxD creates the screen and sets its width, height, and depth
|
||
|
||
export DISPLAY=:1 # need to export this, otherwise playwright complains with 'Looks like you launched a headed browser without having a XServer running.'
|
||
Xvfb $DISPLAY -ac -screen 0 "${WIDTH}x${HEIGHT}x${DEPTH}" &
|
||
echo "Xvfb display server created screen with resolution ${WIDTH}x${HEIGHT}"
|
||
if [ -z "$VNC_PASSWORD" ]; then
|
||
pw="-nopw"
|
||
pwt="no password!"
|
||
else
|
||
pw="-passwd $VNC_PASSWORD"
|
||
pwt="with password"
|
||
fi
|
||
x11vnc -display $DISPLAY -forever -shared -rfbport $VNC_PORT -bg $pw 2>/dev/null 1>&2
|
||
echo "VNC is running on port $VNC_PORT ($pwt)"
|
||
websockify -D --web "/usr/share/novnc/" $NOVNC_PORT "localhost:$VNC_PORT" 2>/dev/null 1>&2 &
|
||
echo "noVNC (VNC via browser) is running on http://localhost:$NOVNC_PORT"
|
||
echo
|
||
exec tini -g -- "$@" # https://github.com/krallin/tini/issues/8 node/playwright respond to signals like ctrl-c, but unsure about zombie processes
|