diff --git a/functions/fn_autoip b/functions/fn_autoip index 4af782c2b..6f38ec317 100644 --- a/functions/fn_autoip +++ b/functions/fn_autoip @@ -12,8 +12,17 @@ if [ ! -f /bin/ip ]; then else ipcommand="ip" fi -getip=$(hostname -I) +getip=$(${ipcommand} -o -4 addr|awk '{print $4 }'|grep -oe '\([0-9]\{1,3\}\.\?\)\{4\}'|grep -v 127.0.0) +getipwc=$(${ipcommand} -o -4 addr|awk '{print $4 }'|grep -oe '\([0-9]\{1,3\}\.\?\)\{4\}'|grep -vc 127.0.0) if [ "${ip}" == "0.0.0.0" ]||[ "${ip}" == "" ]; then - ip=${getip} -fi + if [ "${getipwc}" -ge "2" ]; then + fn_printwarn "Multiple active network interfaces found.\n\n" + echo -en "Manually specify the IP you want to use within the ${selfname} script.\n" + echo -en "Set ip=\"0.0.0.0\" to one of the following:\n" + echo -en "${getip}\n" + exit + else + ip=${getip} + fi +fi \ No newline at end of file diff --git a/functions/fn_check_ip b/functions/fn_check_ip index e5b2755c9..f0ec52970 100644 --- a/functions/fn_check_ip +++ b/functions/fn_check_ip @@ -7,9 +7,22 @@ # Description: Automatically identifies the server interface IP. # If multiple interfaces are detected the user will need to manualy set using ip="0.0.0.0". -getip=$(hostname -I) - -if [ "${ip}" == "0.0.0.0" ]||[ "${ip}" == "" ]; then - ip=${getip} +if [ ! -f /bin/ip ]; then + ipcommand="/sbin/ip" +else + ipcommand="ip" fi +getip=$(${ipcommand} -o -4 addr|awk '{print $4 }'|grep -oe '\([0-9]\{1,3\}\.\?\)\{4\}'|grep -v 127.0.0) +getipwc=$(${ipcommand} -o -4 addr|awk '{print $4 }'|grep -oe '\([0-9]\{1,3\}\.\?\)\{4\}'|grep -vc 127.0.0) +if [ "${ip}" == "0.0.0.0" ]||[ "${ip}" == "" ]; then + if [ "${getipwc}" -ge "2" ]; then + fn_printwarn "Multiple active network interfaces found.\n\n" + echo -en "Manually specify the IP you want to use within the ${selfname} script.\n" + echo -en "Set ip=\"0.0.0.0\" to one of the following:\n" + echo -en "${getip}\n" + exit + else + ip=${getip} + fi +fi \ No newline at end of file