#!/bin/bash # Etherpad Installer for Jitsi Meet # SwITNet Ltd © - 2024, https://switnet.net/ # # GPLv3 or later. while getopts m: option do case "${option}" in m) MODE=${OPTARG};; \?) echo "Usage: sudo bash ./$0 [-m debug]" && exit;; esac done if [ "$MODE" = "debug" ]; then set -x fi if ! [ "$(id -u)" = 0 ]; then echo "You need to be root or have sudo privileges!" exit 0 fi clear echo ' ######################################################################## Etherpad Docker addon ######################################################################## by Software, IT & Networks Ltd ' FORGE_REPO="https://forge.switnet.net/switnet/quick-jibri-installer" check_apt_policy() { apt-cache policy 2>/dev/null| \ awk "/$1/{print \$3}" | \ awk -F '/' 'NR==1{print$2}' } install_ifnot() { if [ "$(dpkg-query -W -f='${Status}' "$1" 2>/dev/null | grep -c "ok installed")" == "1" ]; then echo " $1 is installed, skipping..." else echo -e "\n---- Installing $1 ----" apt-get -yq2 install "$1" fi } # Test for matches test_match() { if grep -q "$1" "$2" ; then echo "$(basename "$2") - OK..." else echo "$(basename "$2"), FAIL..." echo "Please report this to $FORGE_REPO" exit fi } DOMAIN="$(find /etc/prosody/conf.d/ -name \*.lua|awk -F'.cfg' '!/localhost/{print $1}'|xargs basename)" MEET_CONF="/etc/jitsi/meet/$DOMAIN-config.js" WS_CONF="/etc/nginx/sites-available/$DOMAIN.conf" PSGVER="$(apt-cache madison postgresql|tr -d '[:blank:]'|awk -F'[|+]' 'NR==1{print $2}')" 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" read -p "Set your etherpad docker admin password: " -r ETHERPAD_ADMIN_PASS # Make sure we can rely on the match strings. printf "> Testing match strings on config files.\n" test_match "$WS_MATCH1" "$WS_CONF" # Install required packages install_ifnot docker.io install_ifnot docker-compose install_ifnot postgresql-"$PSGVER" # Create DB echo -e "> Creating postgresql database for container...\n" sudo -u postgres psql < /opt/etherpat/.env DOCKER_COMPOSE_APP_ADMIN_PASSWORD="$ETHERPAD_ADMIN_PASS" DOCKER_COMPOSE_APP_DB_CHARSET="utf8mb4" DOCKER_COMPOSE_POSTGRES_HOST="localhost" DOCKER_COMPOSE_POSTGRES_USER="$ETHERPAD_DB_USER" DOCKER_COMPOSE_POSTGRES_DATABASE="$ETHERPAD_DB_NAME" DOCKER_COMPOSE_POSTGRES_PASSWORD="$ETHERPAD_DB_PASS" DOCKER_COMPOSE_POSTGRES_PORT="5432" #DOCKER_COMPOSE_APP_DEFAULT_PAD_TEXT= DOCKER_COMPOSE_APP_DISABLE_IP_LOGGING="false" DOCKER_COMPOSE_APP_SOFFICE="null" DOCKER_COMPOSE_APP_TRUST_PROXY="true" EOF chmod 600 /opt/etherpat/.env cp files/etherpad/docker-compose.yml /opt/etherpat/ chmod 644 /opt/etherpat/docker-compose.yml docker-compose -f /opt/etherpat/docker-compose.yml up -d # Tune webserver for Jitsi App control if [ "$(grep -c etherpad "$WS_CONF")" != 0 ]; then echo "> Webserver seems configured, skipping..." elif [ -f "$WS_CONF" ]; then 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" sed -i "/$WS_CONF_MATCH1/i \ \ \ \ \ \ \ \ proxy_http_version 1.1;" "$WS_CONF" sed -i "/$WS_CONF_MATCH1/i \ \ \ \ \ \ \ \ proxy_set_header Upgrade \$http_upgrade;" "$WS_CONF" sed -i "/$WS_CONF_MATCH1/i \ \ \ \ \ \ \ \ proxy_set_header Connection \$connection_upgrade;" "$WS_CONF" sed -i "/$WS_CONF_MATCH1/i \ \ \ \ \ \ \ \ proxy_set_header X-Forwarded-For \$remote_addr;" "$WS_CONF" sed -i "/$WS_CONF_MATCH1/i \ \ \ \ \ \ \ \ proxy_buffering off;" "$WS_CONF" sed -i "/$WS_CONF_MATCH1/i \ \ \ \ \ \ \ \ proxy_redirect off;" "$WS_CONF" sed -i "/$WS_CONF_MATCH1/i \ \ \ \ \ \ \ \ proxy_set_header Host \$host;" "$WS_CONF" sed -i "/$WS_CONF_MATCH1/i \ \ \ \ \ \ \ \ proxy_pass http:\/\/localhost:9001\/;" "$WS_CONF" sed -i "/$WS_CONF_MATCH1/i \ \ \ \ }" "$WS_CONF" sed -i "/$WS_CONF_MATCH1/i \\\n" "$WS_CONF" else echo "> No etherpad config done to server file, please report to:" echo " -> https://forge.switnet.net/switnet/quick-jibri-installer/issues" fi # Configure config.js if [ "$(grep -c "etherpad_base" "$WS_CONF")" != 0 ]; then echo -e "> $MEET_CONF seems configured, skipping...\n" else echo -e "> Setting etherpad domain at $MEET_CONF...\n" sed -i "s|// etherpad_base: .*|etherpad_base: \'https://$DOMAIN/etherpad/p/\',|" "$MEET_CONF" fi echo "> Checking nginx configuration..." if nginx -t 2>/dev/null ; then echo -e " -- Docker configuration seems fine, enabling it." # systemctl reload nginx else echo "Please check your configuration, something may be wrong." echo "Will not try to enable etherpad nginx configuration, please report to:" echo " -> https://forge.switnet.net/switnet/quick-jibri-installer/issues" fi