#!/bin/bash # # Wireguard / VPN Service PATH=$HOME/.docker/cli-plugins:/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin config_wireguard() { echo -ne "\n* Configuring /federated/apps/wireguard container.." spin & SPINPID=$! if [ ! -d "/federated/apps/wireguard" ]; then mkdir -p /federated/apps/wireguard/data/config fi DOMAIN_ARRAY=(${DOMAIN//./ }) DOMAIN_FIRST=${DOMAIN_ARRAY[0]} DOMAIN_LAST=${DOMAIN_ARRAY[1]} cat > /federated/apps/wireguard/docker-compose.yml < /federated/apps/wireguard/.env < /dev/null echo -ne "done." } start_wireguard() { # Start /federated/apps/wireguard with output to /dev/null echo -ne "\n* Starting /federated/apps/wireguard service.." spin & SPINPID=$! if [ $DEBUG ]; then # Start /federated/apps/wireguard with output to console for debug docker-compose -f /federated/apps/wireguard/docker-compose.yml -p wireguard up [ $? -eq 0 ] && echo -ne "done.\n" || fail "There was a problem starting service /federated/apps/wireguard" else docker-compose -f /federated/apps/wireguard/docker-compose.yml -p wireguard up -d &> /dev/null # Keep trying wireguard port 80 to make sure it's up # before we proceed RETRY="30" while [ $RETRY -gt 0 ]; do nc -uvz 172.99.0.22 51820 &> /dev/null if [ $? -eq 0 ]; then break else if [ "$RETRY" == 1 ]; then docker-compose -f /federated/apps/wireguard/docker-compose.yml -p wireguard down &> /dev/null kill -9 $SPINPID &> /dev/null fail "There was a problem starting service /federated/apps/wireguard\nCheck the output of 'docker logs wireguard' or turn on\ndebug with -d" fi ((RETRY--)) sleep 7 fi done fi kill -9 $SPINPID &> /dev/null echo -ne "done." }