for firing up the network: no longer rely on ifconfig
[bootcd.git] / initscripts / pl_netinit
index 2363cea..15de8b3 100755 (executable)
@@ -194,7 +194,8 @@ function find-node-config() {
 
 
 verbose-message "pl_netinit: bringing loopback network device up"
-/sbin/ifconfig lo 127.0.0.1 up
+ip address add dev lo 127.0.0.1/8
+ip link set lo up
 
 find-node-config
 if [ $? -eq 0 ]; then
@@ -283,20 +284,18 @@ fi
 # tmp: Thierry June 2015
 # on fedora 21 nodes we see this running in a context where eth0 is not known to the system
 # could be related to a dependency that we poorly describe to systemd
-# I am increasing this timeout to 2 minutes in order to check that conjecture
-ALLOW=60
+# I am increasing this timeout to 1 minute in order to check that conjecture
+ALLOW=10
 COUNTER=0
 while true; do
-    if /sbin/ifconfig $ETH_DEVICE >& /dev/null; then
-       verbose-message "pl_netinit: device present $ETH_DEVICE, proceeding (${COUNTER}s/${ALLOW}s)"
-       break
+    ### check if the interface is known
+    # instead of using ifconfig, check the kernel area
+    if [ -e /sys/class/net/$ETH_DEVICE ]; then
+        verbose-message "pl_netinit: device present $ETH_DEVICE"
+        break
     fi
     verbose-message "pl_netinit: waiting for device $ETH_DEVICE - ${COUNTER}s/${ALLOW}s"
-    set -x
-    /sbin/ifconfig
-    journalctl -b | egrep 'eth|bnx|udev'
-    systemctl list-unit-files | grep -i network
-    set +x 
+    sleep 1
     COUNTER=$(($COUNTER+1))
     [ $COUNTER -ge $ALLOW ] && net-init-failed
     sleep 1
@@ -305,7 +304,7 @@ done
 
 # actually check to make sure ifconfig <device> succeeds
 
-/sbin/ifconfig $ETH_DEVICE up 2>&1 > /dev/null || {
+/usr/libexec/nm-ifup $ETH_DEVICE >& /dev/null || {
     verbose-message "pl_netinit: device $ETH_DEVICE does not exist, most likely"
     verbose-message "pl_netinit: this CD does not have hardware support for your"
     verbose-message "pl_netinit: network adapter. please send the following lines"
@@ -321,30 +320,36 @@ verbose-message "pl_netinit: attempting to start networking"
 
 verbose-message "pl_netinit: network online"
 
-# patch for f22 - if /etc/resolv.conf is empty in static mode
+# patch for f22 and above - if /etc/resolv.conf is empty or missing
 function pl-netinit-patch-resolv-conf () {
-    file=/etc/resolv.conf
+    file="$1"; shift
     needed=""
     # missing file : patch needed
     if ! [ -f $file ]; then
        needed=true
     # empty file : patch needed
-    elif cmp $file /dev/null; then
-       needed=true
-    fi
-    if [ -n "$needed" ]; then
-       verbose-message "pl_netinit: patching $file"
-       source /etc/sysconfig/network-scripts/ifcfg-${ETH_DEVICE}
-       # delete because it's a symlink to /run/systemd/resolve/resolv.conf
-       # which looks really weird (ls -lL /etc/resolv.conf does not show anything)
-       rm $file
-       ( [ -n "$DNS1" ] && echo nameserver $DNS1; \
-         [ -n "$DNS2" ] && echo nameserver $DNS2 ) > $file
     else
+       contents=$(grep -v '^#' $file)
+       contents=$(echo $contents)
+       [ -z "$contents" ] && needed=true
+    fi
+    if [ -z "$needed" ]; then
        echo pl_netinit has no need to patch $file
+       return
     fi
+
+    verbose-message "pl_netinit: patching $file"
+    source /etc/sysconfig/network-scripts/ifcfg-${ETH_DEVICE}
+    # delete because it may be a symlink to /run/systemd/resolve/resolv.conf
+    # which looks really weird (ls -lL /etc/resolv.conf does not show anything)
+    rm -f $file
+    # mention the DNS servers defined in the config - if any
+    [ -n "$DNS1" ] && echo nameserver $DNS1 >> $file
+    [ -n "$DNS2" ] && echo nameserver $DNS2 >> $file
+    # also add landmark for good measure
+    echo "nameserver 8.8.8.8" >> $file
 }
 
-pl-netinit-patch-resolv-conf
+pl-netinit-patch-resolv-conf /etc/resolv.conf
 
 verbose-forensics "pl_netinit epilogue"