From 919f52e9d0c36ee17921c50d9248f396df4ba637 Mon Sep 17 00:00:00 2001 From: Ark74 Date: Tue, 21 Jan 2025 03:27:18 -0600 Subject: [PATCH] set mapping for nginx connection upgrade --- etherpad-docker.sh | 9 +++++++++ grafana.sh | 13 ++++++++----- 2 files changed, 17 insertions(+), 5 deletions(-) diff --git a/etherpad-docker.sh b/etherpad-docker.sh index fe38da3..186c5b8 100644 --- a/etherpad-docker.sh +++ b/etherpad-docker.sh @@ -61,6 +61,7 @@ ETHERPAD_DB_USER="dockerpad" ETHERPAD_DB_NAME="etherpad" ETHERPAD_DB_PASS="$(tr -dc "a-zA-Z0-9#*=" < /dev/urandom | fold -w 10 | head -n1)" WS_CONF_MATCH1="# ensure all static content can always be found first" +WS_MATCH2="upstream prosody {" read -p "Set your etherpad docker admin password: " -r ETHERPAD_ADMIN_PASS @@ -75,6 +76,7 @@ EOF # Make sure we can rely on the match strings. printf "> Testing match strings on config files.\n" test_match "$WS_MATCH1" "$WS_CONF" +test_match "$WS_MATCH2" "$WS_CONF" # Install required packages install_ifnot docker.io @@ -120,6 +122,13 @@ fi if [ "$(grep -c etherpad "$WS_CONF")" != 0 ]; then echo "> Webserver seems configured, skipping..." elif [ -f "$WS_CONF" ]; then + if ! grep -q 'map $http_upgrade $connection_upgrade' "$WS_CONF"; then + sed -i "/$WS_MATCH2/i # This is required to proxy Grafana Live WebSocket connections or Etherpad" "$WS_CONF" + sed -i "/$WS_MATCH2/i map \$http_upgrade \$connection_upgrade {" "$WS_CONF" + sed -i "/$WS_MATCH2/i \ \ default upgrade;" "$WS_CONF" + sed -i "/$WS_MATCH2/i \ \ '' close;" "$WS_CONF" + sed -i "/$WS_MATCH2/i }" "$WS_CONF" + fi echo "> Setting up webserver configuration file..." sed -i "/$WS_CONF_MATCH1/i \ \ \ \ #Etherpad block" "$WS_CONF" sed -i "/$WS_CONF_MATCH1/i \ \ \ \ location \^\~\ \/etherpad\/ {" "$WS_CONF" diff --git a/grafana.sh b/grafana.sh index 76e9ede..8e18001 100644 --- a/grafana.sh +++ b/grafana.sh @@ -194,11 +194,14 @@ if [ -f "$WS_CONF" ]; then sed -i "/$WS_MATCH1/i \ \ \ \ \ \ proxy_pass http://grafana;" "$WS_CONF" sed -i "/$WS_MATCH1/i \ \ \ \ }" "$WS_CONF" - sed -i "/$WS_MATCH2/i # This is required to proxy Grafana Live WebSocket connections." "$WS_CONF" - sed -i "/$WS_MATCH2/i map \$http_upgrade \$connection_upgrade {" "$WS_CONF" - sed -i "/$WS_MATCH2/i \ \ default upgrade;" "$WS_CONF" - sed -i "/$WS_MATCH2/i \ \ '' close;" "$WS_CONF" - sed -i "/$WS_MATCH2/i }" "$WS_CONF" + if ! grep -q 'map $http_upgrade $connection_upgrade' "$WS_CONF"; then + sed -i "/$WS_MATCH2/i # This is required to proxy Grafana Live WebSocket connections or Etherpad" "$WS_CONF" + sed -i "/$WS_MATCH2/i map \$http_upgrade \$connection_upgrade {" "$WS_CONF" + sed -i "/$WS_MATCH2/i \ \ default upgrade;" "$WS_CONF" + sed -i "/$WS_MATCH2/i \ \ '' close;" "$WS_CONF" + sed -i "/$WS_MATCH2/i }" "$WS_CONF" + fi + sed -i "/$WS_MATCH1/i \\\n" "$WS_CONF" sed -i "/$WS_MATCH2/i upstream grafana {" "$WS_CONF" sed -i "/$WS_MATCH2/i \ \ server localhost:3000;" "$WS_CONF"