echo -n "$MS_DNS1" > /var/ipfire/red/dns1
echo -n "$MS_DNS2" > /var/ipfire/red/dns2
else
- echo -n "$PRIMARY_DNS" > /var/ipfire/red/dns1
- echo -n "$SECONDARY_DNS" > /var/ipfire/red/dns2
+ if [ "$PRIMARY_DNS" == "10.11.12.13" ]; then
+ echo -n "$DNS1" > /var/ipfire/red/dns1
+ else
+ echo -n "$PRIMARY_DNS" > /var/ipfire/red/dns1
+ fi
+ if [ "$SECONDARY_DNS" == "10.11.12.14" ]; then
+ echo -n "$DNS2" > /var/ipfire/red/dns2
+ else
+ echo -n "$SECONDARY_DNS" > /var/ipfire/red/dns2
+ fi
fi
else
echo -n "$DNS1" > /var/ipfire/red/dns1
echo -n "$DNS2" > /var/ipfire/red/dns2
fi
-
+7
echo -n "$1" > /var/ipfire/red/iface
echo -n "$4" > /var/ipfire/red/local-ipaddress
echo -n "$5" > /var/ipfire/red/remote-ipaddress
+touch /var/ipfire/red/active
run_subdir ${rc_base}/init.d/networking/red.up/
#Check if gateway has answerd to ping, if not replace with ping.ipfire.org
TEST=`/usr/bin/ping -c 2 $5 2>/dev/null | tail -2 | head -1 | cut -d"," -f2`;
-grep -v "gateway" /etc/hosts > /tmp/hosts
+grep -v -E "\<gateway\>" /etc/hosts > /tmp/hosts
-if [ "$TEST" == " 2 packets received" ]; then
+if [ "$TEST" == " 2 received" ]; then
#ping the ppp-gateway
echo "$5 gateway" >> /tmp/hosts
else
#no answer
- FIRE=`nslookup ping.ipfire.org | tail -2 | head -1 | cut -d" " -f2`;
- if [ "$FIRE" == "server" ]; then
- #DNS lookup failed use direct ip
- echo "85.88.28.124 gateway" >> /tmp/hosts
- else
+ HOST=`host ping.ipfire.org`;
+ FIRE=`echo $HOST | cut -d" " -f4`;
+ CHK=`echo $HOST | cut -d" " -f3`;
+ if [ "$CHK" == "address" ]; then
#use ping.ipfire.org
echo "$FIRE gateway" >> /tmp/hosts
+ else
+ #DNS lookup failed use direct ip
+ echo "85.88.28.125 gateway" >> /tmp/hosts
fi
fi
mv /tmp/hosts /etc/hosts
[ -e "/var/ipfire/ppp/nobeeps" ] || /etc/rc.d/init.d/beep up
+
+/sbin/ip route replace default via ${IPREMOTE}