| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662 | #!/bin/bashLATEST="testing"# check_version - make sure current version is 0.17.1 before continuingcheck_version() {  IMG_TAG=$(yq -r '.services.netmaker.image' docker-compose.yml)  if [[ "$IMG_TAG" == *"v0.17.1"* ]]; then      echo "version is $IMG_TAG"  else      echo "error, current version is $IMG_TAG"      echo "please upgrade to v0.17.1 in order to use the upgrade script"      exit 1  fi}# wait_seconds - wait a number of seconds, print a logwait_seconds() {  for ((a=1; a <= $1; a++))  do    echo ". . ."    sleep 1  done}# confirm - confirm a choice, or exit scriptconfirm() {  while true; do      read -p 'Does everything look right? [y/n]: ' yn      case $yn in          [Yy]* ) override="true"; break;;          [Nn]* ) echo "exiting..."; exit 1;;          * ) echo "Please answer yes or no.";;      esac  done}# install_dependencies - install system dependencies necessary for script to runinstall_dependencies() {  OS=$(uname)  if [ -f /etc/debian_version ]; then    dependencies="jq wireguard jq docker.io docker-compose"    update_cmd='apt update'    install_cmd='apt install -y'  elif [ -f /etc/centos-release ]; then    dependencies="wireguard jq docker.io docker-compose"    update_cmd='yum update'    install_cmd='yum install -y'  elif [ -f /etc/fedora-release ]; then    dependencies="wireguard jq docker.io docker-compose"    update_cmd='dnf update'    install_cmd='dnf install -y'  elif [ -f /etc/redhat-release ]; then    dependencies="wireguard jq docker.io docker-compose"    update_cmd='yum update'    install_cmd='yum install -y'  elif [ -f /etc/arch-release ]; then        dependecies="wireguard-tools jq docker.io docker-compose netclient"    update_cmd='pacman -Sy'    install_cmd='pacman -S --noconfirm'  else    echo "OS not supported for automatic install"      exit 1  fi  set -- $dependencies  ${update_cmd}  set +e  while [ -n "$1" ]; do      is_installed=$(dpkg-query -W --showformat='${Status}\n' $1 | grep "install ok installed")      if [ "${is_installed}" != "" ]; then          echo "    " $1 is installed      else          echo "    " $1 is not installed. Attempting install.          ${install_cmd} $1          sleep 5          if [ "${OS}" = "OpenWRT" ] || [ "${OS}" = "TurrisOS" ]; then              is_installed=$(opkg list-installed $1 | grep $1)          else              is_installed=$(dpkg-query -W --showformat='${Status}\n' $1 | grep "install ok installed")          fi          if [ "${is_installed}" != "" ]; then              echo "    " $1 is installed          elif [ -x "$(command -v $1)" ]; then              echo "  " $1 is installed          else              echo "  " FAILED TO INSTALL $1              echo "  " This may break functionality.          fi      fi    shift  done  set -e    echo "-----------------------------------------------------"  echo "dependency install complete"  echo "-----------------------------------------------------"}# install_yq - install yq if not presentinstall_yq() {	if ! command -v yq &> /dev/null; then		wget -O /usr/bin/yq https://github.com/mikefarah/yq/releases/download/v4.31.1/yq_linux_$(dpkg --print-architecture)		chmod +x /usr/bin/yq	fi	set +e	if ! command -v yq &> /dev/null; then		set -e		wget -O /usr/bin/yq https://github.com/mikefarah/yq/releases/download/v4.31.1/yq_linux_amd64		chmod +x /usr/bin/yq	fi	set -e	if ! command -v yq &> /dev/null; then		echo "failed to install yq. Please install yq and try again."		echo "https://github.com/mikefarah/yq/#install"		exit 1	fi	}# collect_server_settings - retrieve server settings from existing compose filecollect_server_settings() {  MASTER_KEY=$(yq -r .services.netmaker.environment.MASTER_KEY docker-compose.yml)  echo "-----------------------------------------------------"  echo "Is $MASTER_KEY the correct master key for your Netmaker installation?"  echo "-----------------------------------------------------"  select mkey_option in "yes" "no (enter manually)"; do    case $REPLY in      1)        echo "using $MASTER_KEY for master key"      break        ;;            2)        read -p "Enter Master Key: " mkey        MASTER_KEY=$mkey        echo "using $MASTER_KEY"        break        ;;      *) echo "invalid option $REPLY, choose 1 or 2";;    esac  done  SERVER_HTTP_HOST=$(yq -r .services.netmaker.environment.SERVER_HTTP_HOST docker-compose.yml)  echo "-----------------------------------------------------"  echo "Is $SERVER_HTTP_HOST the correct api endpoint for your Netmaker installation?"  echo "-----------------------------------------------------"  select endpoint_option in "yes" "no (enter manually)"; do    case $REPLY in      1)        echo "using $SERVER_HTTP_HOST for api endpoint"      break        ;;            2)        read -p "Enter API Endpoint: " endpoint        SERVER_HTTP_HOST=$endpoint        echo "using $SERVER_HTTP_HOST"        break        ;;      *) echo "invalid option $REPLY";;    esac  done  BROKER_NAME=$(yq -r .services.netmaker.environment.SERVER_NAME docker-compose.yml)  echo "-----------------------------------------------------"  echo "Is $BROKER_NAME the correct domain for your MQ broker?"  echo "-----------------------------------------------------"  select broker_option in "yes" "no (enter manually)"; do    case $REPLY in      1)        echo "using $BROKER_NAME for endpoint"      break        ;;            2)        read -p "Enter Broker Domain: " broker        BROKER_NAME=$broker        echo "using $BROKER_NAME"        break        ;;      *) echo "invalid option $REPLY";;    esac  done  SERVER_NAME=${BROKER_NAME#"broker."}  echo "-----------------------------------------------------"  echo "Is $SERVER_NAME the correct base domain for your installation?"  echo "-----------------------------------------------------"  select domain_option in "yes" "no (enter manually)"; do    case $REPLY in      1)        echo "using $SERVER_NAME for domain"      break        ;;            2)        read -p "Enter Server Domain: " broker        SERVER_NAME=$server        echo "using $SERVER_NAME"        break        ;;      *) echo "invalid option $REPLY";;    esac  done  STUN_DOMAIN="stun.$SERVER_NAME"  echo "-----------------------------------------------------"  echo "Netmaker v0.18 requires a new DNS entry for $STUN_DOMAIN."  echo "Please confirm this is added to your DNS provider before continuing"  echo "(note: this is not required if using an nip.io address)"  echo "-----------------------------------------------------"  confirm}# collect_node_settings - get existing server node configurationcollect_node_settings() {  curl -s -H "Authorization: Bearer $MASTER_KEY" -H 'Content-Type: application/json' https://$SERVER_HTTP_HOST/api/nodes | jq -c '[ .[] | select(.isserver=="yes") ]' > nodejson.tmp  NODE_LEN=$(jq length nodejson.tmp)  HAS_INGRESS="no"  HAS_RELAY="no"  if [ "$NODE_LEN" -gt 0 ]; then      echo "===SERVER NODES==="      for i in $(seq 1 $NODE_LEN); do          NUM=$(($i-1))          echo "  SERVER NODE $NUM:"          echo "    network: $(jq -r ".[$NUM].network" ./nodejson.tmp)"          echo "      name: $(jq -r ".[$NUM].name" ./nodejson.tmp)"          echo "      private ipv4: $(jq -r ".[$NUM].address" ./nodejson.tmp)"          echo "      private ipv6: $(jq -r ".[$NUM].address6" ./nodejson.tmp)"          echo "      is egress: $(jq -r ".[$NUM].isegressgateway" ./nodejson.tmp)"          if [[ $(jq -r ".[$NUM].isegressgateway" ./nodejson.tmp) == "yes" ]]; then              echo "          egress range: $(jq -r ".[$NUM].egressgatewayranges" ./nodejson.tmp)"          fi          echo "      is ingress: $(jq -r ".[$NUM].isingressgateway" ./nodejson.tmp)"          if [[ $(jq -r ".[$NUM].isingressgateway" ./nodejson.tmp) == "yes" ]]; then              HAS_INGRESS="yes"          fi          echo "      is relay: $(jq -r ".[$NUM].isrelay" ./nodejson.tmp)"          if [[ $(jq -r ".[$NUM].isrelay" ./nodejson.tmp) == "yes" ]]; then              HAS_RELAY="yes"              echo "          relay addrs: $(jq -r ".[$NUM].relayaddrs" ./nodejson.tmp | tr -d '[]\n"[:space:]')"          fi          echo "      is failover: $(jq -r ".[$NUM].failover" ./nodejson.tmp)"          echo "  ------------"      done      echo "=================="  else      echo "no nodes to parse"  fi  echo "Please confirm that the above output matches the server nodes in your Netmaker server."  confirm  if [[ $HAS_INGRESS == "yes" ]]; then      echo "WARNING: Your server contains an Ingress Gateway. After upgrading, existing Ext Clients will be lost and must be recreated. Please confirm that you would like to continue."      confirm  fi  if [[ $HAS_RELAY == "yes" ]]; then      echo "WARNING: Your server contains a Relay. After upgrading, relay will be unset. Relay functionality has been moved to the 'host' level, and must be reconfigured once all machines are upgraded."      confirm  fi}# setup_caddy - updates Caddy with new infosetup_caddy() {  echo "backing up Caddyfile to /root/Caddyfile.backup"  cp /root/Caddyfile /root/Caddyfile.backup  if grep -wq "acme.zerossl.com/v2/DV90" Caddyfile; then       echo "zerossl already set, continuing"   else     echo "editing Caddyfile"    sed -i '0,/email/{s~email~acme_ca https://acme.zerossl.com/v2/DV90\n\t&~}' /root/Caddyfile  ficat <<EOT >> /root/Caddyfile# STUNhttps://$STUN_DOMAIN {  reverse_proxy netmaker:3478}EOT}# set_mq_credentials - sets mq credentialsset_mq_credentials() {  unset GET_MQ_USERNAME  unset GET_MQ_PASSWORD  unset CONFIRM_MQ_PASSWORD  echo "Enter Credentials For MQ..."  read -p "MQ Username (click 'enter' to use 'netmaker'): " GET_MQ_USERNAME  if [ -z "$GET_MQ_USERNAME" ]; then    echo "using default username for mq"    MQ_USERNAME="netmaker"  else    MQ_USERNAME="$GET_MQ_USERNAME"  fi  select domain_option in "Auto Generated Password" "Input Your Own Password"; do    case $REPLY in    1)    echo "generating random password for mq"    MQ_PASSWORD=$(tr -dc A-Za-z0-9 </dev/urandom | head -c 30 ; echo '')    break    ;;            2)    while true      do          echo "Enter your Password For MQ: "           read -s GET_MQ_PASSWORD          echo "Enter your password again to confirm: "          read -s CONFIRM_MQ_PASSWORD          if [ ${GET_MQ_PASSWORD} != ${CONFIRM_MQ_PASSWORD} ]; then              echo "wrong password entered, try again..."              continue          fi      MQ_PASSWORD="$GET_MQ_PASSWORD"          echo "MQ Password Saved Successfully!!"          break      done        break        ;;      *) echo "invalid option $REPLY";;    esac  done}# set_compose - set compose file with proper valuesset_compose() {  set_mq_credentials  echo "retrieving updated wait script and mosquitto conf"    rm /root/wait.sh  rm /root/mosquitto.conf  # DEV_TEMP  wget -O /root/wait.sh https://raw.githubusercontent.com/gravitl/netmaker/develop/docker/wait.sh   # RELEASE_REPLACE - Use this once release is ready  # wget -O /root/wait.sh https://raw.githubusercontent.com/gravitl/netmaker/master/docker/wait.sh  chmod +x /root/wait.sh  # DEV_TEMP  wget -O /root/mosquitto.conf https://raw.githubusercontent.com/gravitl/netmaker/develop/docker/mosquitto.conf  # RELEASE_REPLACE - Use this once release is ready  # wget -O /root/wait.sh https://raw.githubusercontent.com/gravitl/netmaker/master/docker/wait.sh  chmod +x /root/mosquitto.conf  # DEV_TEMP  sed -i "s/v0.17.1/$LATEST/g" /root/docker-compose.yml  STUN_PORT=3478  # RELEASE_REPLACE - Use this once release is ready  #sed -i "s/v0.17.1/v0.18.4/g" /root/docker-compose.yml  yq ".services.netmaker.environment.SERVER_NAME = \"$SERVER_NAME\"" -i /root/docker-compose.yml  yq ".services.netmaker.environment += {\"BROKER_ENDPOINT\": \"wss://$BROKER_NAME\"}" -i /root/docker-compose.yml    yq ".services.netmaker.environment += {\"SERVER_BROKER_ENDPOINT\": \"ws://mq:1883\"}" -i /root/docker-compose.yml    yq ".services.netmaker.environment += {\"STUN_LIST\": \"$STUN_DOMAIN:$STUN_PORT,stun1.netmaker.io:3478,stun2.netmaker.io:3478,stun1.l.google.com:19302,stun2.l.google.com:19302\"}" -i /root/docker-compose.yml    yq ".services.netmaker.environment += {\"MQ_PASSWORD\": \"$MQ_PASSWORD\"}" -i /root/docker-compose.yml    yq ".services.netmaker.environment += {\"MQ_USERNAME\": \"$MQ_USERNAME\"}" -i /root/docker-compose.yml    yq ".services.netmaker.environment += {\"STUN_PORT\": \"$STUN_PORT\"}" -i /root/docker-compose.yml    yq ".services.netmaker.ports += \"3478:3478/udp\"" -i /root/docker-compose.yml  yq ".services.mq.environment += {\"MQ_PASSWORD\": \"$MQ_PASSWORD\"}" -i /root/docker-compose.yml    yq ".services.mq.environment += {\"MQ_USERNAME\": \"$MQ_USERNAME\"}" -i /root/docker-compose.yml    #remove unnecessary ports  yq eval 'del( .services.netmaker.ports[] | select(. == "51821*") )' -i /root/docker-compose.yml  yq eval 'del( .services.mq.ports[] | select(. == "8883*") )' -i /root/docker-compose.yml  yq eval 'del( .services.mq.ports[] | select(. == "1883*") )' -i /root/docker-compose.yml  yq eval 'del( .services.mq.expose[] | select(. == "8883*") )' -i /root/docker-compose.yml  yq eval 'del( .services.mq.expose[] | select(. == "1883*") )' -i /root/docker-compose.yml  # delete unnecessary compose sections  yq eval 'del(.services.netmaker.cap_add)' -i /root/docker-compose.yml  yq eval 'del(.services.netmaker.sysctls)' -i /root/docker-compose.yml  yq eval 'del(.services.netmaker.environment.MQ_ADMIN_PASSWORD)' -i /root/docker-compose.yml  yq eval 'del(.services.netmaker.environment.MQ_HOST)' -i /root/docker-compose.yml  yq eval 'del(.services.netmaker.environment.MQ_PORT)' -i /root/docker-compose.yml  yq eval 'del(.services.netmaker.environment.MQ_SERVER_PORT)' -i /root/docker-compose.yml  yq eval 'del(.services.netmaker.environment.PORT_FORWARD_SERVICES)' -i /root/docker-compose.yml  yq eval 'del(.services.netmaker.environment.CLIENT_MODE)' -i /root/docker-compose.yml  yq eval 'del(.services.netmaker.environment.HOST_NETWORK)' -i /root/docker-compose.yml  yq eval 'del(.services.mq.environment.NETMAKER_SERVER_HOST)' -i /root/docker-compose.yml  yq eval 'del( .services.netmaker.volumes[] | select(. == "mosquitto_data*") )' -i /root/docker-compose.yml  yq eval 'del( .services.mq.volumes[] | select(. == "mosquitto_data*") )' -i /root/docker-compose.yml  yq eval 'del( .volumes.mosquitto_data )' -i /root/docker-compose.yml}# start_containers - run docker-compose up -dstart_containers() {  docker-compose -f /root/docker-compose.yml up -d}# test_caddy - make sure caddy is workingtest_caddy() {  echo "Testing Caddy setup (please be patient, this may take 1-2 minutes)"  for i in 1 2 3 4 5 6 7 8  do  curlresponse=$(curl -vIs https://${SERVER_HTTP_HOST} 2>&1)  if [[ "$i" == 8 ]]; then    echo "    Caddy is having an issue setting up certificates, please investigate (docker logs caddy)"    echo "    Exiting..."    exit 1  elif [[ "$curlresponse" == *"failed to verify the legitimacy of the server"* ]]; then    echo "    Certificates not yet configured, retrying..."  elif [[ "$curlresponse" == *"left intact"* ]]; then    echo "    Certificates ok"    break  else    secs=$(($i*5+10))    echo "    Issue establishing connection...retrying in $secs seconds..."         fi  sleep $secs  done}# setup_netclient - adds netclient to docker-composesetup_netclient() {  # yq ".services.netclient += {\"container_name\": \"netclient\"}" -i /root/docker-compose.yml  # yq ".services.netclient += {\"image\": \"gravitl/netclient:testing\"}" -i /root/docker-compose.yml  # yq ".services.netclient += {\"hostname\": \"netmaker-1\"}" -i /root/docker-compose.yml  # yq ".services.netclient += {\"network_mode\": \"host\"}" -i /root/docker-compose.yml  # yq ".services.netclient.depends_on += [\"netmaker\"]" -i /root/docker-compose.yml  # yq ".services.netclient += {\"restart\": \"always\"}" -i /root/docker-compose.yml  # yq ".services.netclient.environment += {\"TOKEN\": \"$KEY\"}" -i /root/docker-compose.yml  # yq ".services.netclient.volumes += [\"/etc/netclient:/etc/netclient\"]" -i /root/docker-compose.yml  # yq ".services.netclient.cap_add += [\"NET_ADMIN\"]" -i /root/docker-compose.yml  # yq ".services.netclient.cap_add += [\"NET_RAW\"]" -i /root/docker-compose.yml  # yq ".services.netclient.cap_add += [\"SYS_MODULE\"]" -i /root/docker-compose.yml  # docker-compose up -d	set +e	netclient uninstall	set -e  wget -O /tmp/netclient https://fileserver.netmaker.org/$LATEST/netclient 	chmod +x /tmp/netclient	/tmp/netclient install	netclient join -t $KEY	echo "waiting for client to become available"	wait_seconds 10 }# setup_nmctl - pulls nmctl and makes it executablesetup_nmctl() {  # DEV_TEMP - Temporary instructions for testing  wget https://fileserver.netmaker.org/testing/nmctl   # RELEASE_REPLACE - Use this once release is ready  # wget https://github.com/gravitl/netmaker/releases/download/v0.17.1/nmctl    chmod +x nmctl    echo "using server $SERVER_HTTP_HOST"    echo "using master key $MASTER_KEY"    ./nmctl context set default --endpoint="https://$SERVER_HTTP_HOST" --master_key="$MASTER_KEY"    ./nmctl context use default    RESP=$(./nmctl network list)    if [[ $RESP == *"unauthorized"* ]]; then        echo "Unable to properly configure NMCTL, exiting..."        exit 1    fi}# join_networks - joins netclient into the networks using old settingsjoin_networks() {  NODE_LEN=$(jq length nodejson.tmp)    if [ "$NODE_LEN" -gt 0 ]; then      for i in $(seq 1 $NODE_LEN); do          HAS_INGRESS="no"          HAS_EGRESS="no"          EGRESS_RANGES=""          HAS_RELAY="no"          RELAY_ADDRS=""          HAS_FAILOVER="no"          NUM=$(($i-1))          NETWORK=$(jq -r ".[$NUM].network" ./nodejson.tmp)          echo "  joining network $NETWORK with following settings. Please confirm:"          echo "         network: $(jq -r ".[$NUM].network" ./nodejson.tmp)"          echo "            name: $(jq -r ".[$NUM].name" ./nodejson.tmp)"          echo "    private ipv4: $(jq -r ".[$NUM].address" ./nodejson.tmp)"          echo "    private ipv6: $(jq -r ".[$NUM].address6" ./nodejson.tmp)"          echo "       is egress: $(jq -r ".[$NUM].isegressgateway" ./nodejson.tmp)"          if [[ $(jq -r ".[$NUM].isegressgateway" ./nodejson.tmp) == "yes" ]]; then              HAS_EGRESS="yes"              echo "          egress ranges: $(jq -r ".[$NUM].egressgatewayranges" ./nodejson.tmp | tr -d '[]\n"[:space:]')"              EGRESS_RANGES=$(jq -r ".[$NUM].egressgatewayranges" ./nodejson.tmp | tr -d '[]\n"[:space:]')          fi          echo "      is ingress: $(jq -r ".[$NUM].isingressgateway" ./nodejson.tmp)"          if [[ $(jq -r ".[$NUM].isingressgateway" ./nodejson.tmp) == "yes" ]]; then              HAS_INGRESS="yes"          fi          echo "        is relay: $(jq -r ".[$NUM].isrelay" ./nodejson.tmp)"          if [[ $(jq -r ".[$NUM].isrelay" ./nodejson.tmp) == "yes" ]]; then              HAS_RELAY="yes"              RELAY_ADDRS=$(jq -r ".[$NUM].relayaddrs" ./nodejson.tmp | tr -d '[]\n"[:space:]')          fi          echo "     is failover: $(jq -r ".[$NUM].failover" ./nodejson.tmp)"          if [[ $(jq -r ".[$NUM].failover" ./nodejson.tmp) == "yes" ]]; then              HAS_FAILOVER="yes"          fi          echo "  ------------"          confirm          if [[ $NUM -eq 0 ]]; then             echo "running command: ./nmctl keys create $NETWORK 1"            KEY_JSON=$(./nmctl keys create $NETWORK 1)                      KEY=$(echo $KEY_JSON | jq -r .accessstring)            echo "join key created: $KEY"            setup_netclient          else            HOST_ID=$(sudo cat /etc/netclient/netclient.yml | yq -r .host.id)            ./nmctl host add_network $HOST_ID $NETWORK          fi          NAME=$(jq -r ".[$NUM].name" ./nodejson.tmp)          ADDRESS=$(jq -r ".[$NUM].address" ./nodejson.tmp)          ADDRESS6=$(jq -r ".[$NUM].address6" ./nodejson.tmp)          echo "wait 10 seconds for netclient to be ready"          sleep 10          NODE_ID=$(sudo cat /etc/netclient/nodes.yml | yq -r .$NETWORK.commonnode.id)          echo "join complete. New node ID: $NODE_ID"          if [[ $NUM -eq 0 ]]; then            HOST_ID=$(sudo cat /etc/netclient/netclient.yml | yq -r .host.id)            echo "For first join, making host a default"            echo "Host ID: $HOST_ID"            # set as a default host            set +e            ./nmctl host update $HOST_ID --default            sleep 2            set -e                      fi          # create an egress if necessary          if [[ $HAS_EGRESS == "yes" ]]; then            echo "creating egress"                        ./nmctl node create_egress $NETWORK $NODE_ID $EGRESS_RANGES            sleep 2          fi          echo "HAS INGRESS: $HAS_INGRESS"          # create an ingress if necessary          if [[ $HAS_INGRESS == "yes" ]]; then            if [[ $HAS_FAILOVER == "yes" ]]; then              echo "creating ingress and failover..."              ./nmctl node create_ingress $NETWORK $NODE_ID --failover              sleep 2            else              echo "creating ingress..."              ./nmctl node create_ingress $NETWORK $NODE_ID              sleep 2            fi          fi          # relay          if [[ $HAS_RELAY == "yes" ]]; then            echo "cannot recreate relay; relay functionality moved to host"            # ./nmctl node create_relay $NETWORK $NODE_ID $RELAY_ADDRS            # sleep 2          fi      done      echo "=================="  else      echo "no networks to join"  fi}cat << "EOF"- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - The Netmaker Upgrade Script: Upgrading to v0.18 so you don't have to!- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - EOFset -e if [ $(id -u) -ne 0 ]; then   echo "This script must be run as root"   exit 1fiset +eecho "...installing dependencies for script"install_dependenciesecho "...installing yq if necessary"install_yqset -eecho "...confirming version is correct"check_versionecho "...collecting necessary server settings"collect_server_settingsecho "...setup nmctl"setup_nmctlecho "...retrieving current server node settings"collect_node_settingsecho "...backing up docker compose to docker-compose.yml.backup"cp /root/docker-compose.yml /root/docker-compose.yml.backupecho "...setting Caddyfile values"setup_caddyecho "...setting docker-compose values"set_composeecho "...starting containers"start_containersecho "...remove old mosquitto data"# TODO - yq is not removing volume from docker compose# docker volume rm root_mosquitto_datawait_seconds 3echo "..testing Caddy proxy"test_caddyecho "..testing Netmaker health"# TODO, implement health check# netmaker_health_check# wait_seconds 2wait_seconds 2echo "...setup netclient"join_networksecho "-----------------------------------------------------------------"echo "-----------------------------------------------------------------"echo "Netmaker setup is now complete. You are ready to begin using Netmaker."echo "Visit dashboard.$SERVER_NAME to log in"echo "-----------------------------------------------------------------"echo "-----------------------------------------------------------------"
 |