From 27ca7f490efe67611492d9df25851209b71f803c Mon Sep 17 00:00:00 2001 From: abhishek9686 Date: Fri, 20 Dec 2024 14:28:22 +0400 Subject: [PATCH] listen on ipv6 if available --- compose/docker-compose.yml | 3 +++ scripts/netmaker.default.env | 4 +++- scripts/nm-quick.sh | 12 +++++++----- 3 files changed, 13 insertions(+), 6 deletions(-) diff --git a/compose/docker-compose.yml b/compose/docker-compose.yml index 879b38ded..c3c3379a2 100644 --- a/compose/docker-compose.yml +++ b/compose/docker-compose.yml @@ -54,6 +54,9 @@ services: ports: - "$SERVER_HOST:80:80" - "$SERVER_HOST:443:443" + #uncomment to enable IPv6 communication + # - "$SERVER_HOST6:80:80" + # - "$SERVER_HOST6:443:443" coredns: #network_mode: host diff --git a/scripts/netmaker.default.env b/scripts/netmaker.default.env index 9cab2a82b..806c3765d 100644 --- a/scripts/netmaker.default.env +++ b/scripts/netmaker.default.env @@ -2,8 +2,10 @@ NM_EMAIL= # The base domain of netmaker NM_DOMAIN= -# Public IP of machine +# Public IPv4 endpoint of machine SERVER_HOST= +# Public IPv6 endpoint of machine +SERVER_HOST6= # The admin master key for accessing the API. Change this in any production installation. MASTER_KEY= # The username to set for MQ access diff --git a/scripts/nm-quick.sh b/scripts/nm-quick.sh index dcd6398ef..9f1c99cd3 100755 --- a/scripts/nm-quick.sh +++ b/scripts/nm-quick.sh @@ -260,7 +260,7 @@ save_config() { ( save_config_item SERVER_IMAGE_TAG "$IMAGE_TAG" fi # copy entries from the previous config - local toCopy=("SERVER_HOST" "MASTER_KEY" "MQ_USERNAME" "MQ_PASSWORD" "LICENSE_KEY" "NETMAKER_TENANT_ID" + local toCopy=("SERVER_HOST" "SERVER_HOST6" "MASTER_KEY" "MQ_USERNAME" "MQ_PASSWORD" "LICENSE_KEY" "NETMAKER_TENANT_ID" "INSTALL_TYPE" "NODE_ID" "DNS_MODE" "NETCLIENT_AUTO_UPDATE" "API_PORT" "CORS_ALLOWED_ORIGIN" "DISPLAY_KEYS" "DATABASE" "SERVER_BROKER_ENDPOINT" "VERBOSITY" "DEBUG_MODE" "REST_BACKEND" "DISABLE_REMOTE_IP_CHECK" "TELEMETRY" "ALLOWED_EMAIL_DOMAINS" "AUTH_PROVIDER" "CLIENT_ID" "CLIENT_SECRET" @@ -509,14 +509,16 @@ set -e # set_install_vars - sets the variables that will be used throughout installation set_install_vars() { - IP_ADDR=$(dig -4 myip.opendns.com @resolver1.opendns.com +short) - if [ "$IP_ADDR" = "" ]; then - IP_ADDR=$(curl -s ifconfig.me) - fi + IP_ADDR=$(curl -s -4 ifconfig.me) + IP6_ADDR=$(curl -s -6 ifconfig.me) if [ "$NETMAKER_BASE_DOMAIN" = "" ]; then NETMAKER_BASE_DOMAIN=nm.$(echo $IP_ADDR | tr . -).nip.io fi SERVER_HOST=$IP_ADDR + SERVER_HOST6=$IP6_ADDR + if [ "$IP_ADDR" = "" ]; then + SERVER_HOST=$IP6_ADDR + fi if test -z "$MASTER_KEY"; then MASTER_KEY=$( tr -dc A-Za-z0-9