fi
# split args of ethdevice=eth0,eth1 into "eth0 eth1"
- for device in $(echo $ETHDEVICE | sed 's/,/ /g')
+ for device in $(echo "$ETHDEVICE" | sed 's/,/ /g')
do
devlist="$devlist $device"
done
for dev in $devlist
do
echo "Executing ipconfig -t $ETHDEV_TIMEOUT $dev"
- ipconfig -t "$ETHDEV_TIMEOUT" $dev | tee -a /netboot.config
+ ipconfig -t "$ETHDEV_TIMEOUT" "$dev" | tee -a /netboot.config
# if configuration of device worked we should have an assigned
# IP address, if so let's use the device as $DEVICE for later usage.
# simple and primitive approach which seems to work fine
- if ifconfig $dev | grep -q -E 'inet.*addr:|inet [0-9][0-9]*.[0-9][0-9]*.[0-9][0-9]*.[0-9][0-9]*'
+ if ifconfig "$dev" | grep -q -E 'inet.*addr:|inet [0-9][0-9]*.[0-9][0-9]*.[0-9][0-9]*.[0-9][0-9]*'
then
export DEVICE="$dev"
break
done
else
for interface in ${DEVICE}; do
- ipconfig -t "$ETHDEV_TIMEOUT" ${interface} | tee /netboot-${interface}.config
+ ipconfig -t "$ETHDEV_TIMEOUT" "${interface}" | tee "/netboot-${interface}.config"
- [ -e /run/net-${interface}.conf ] && . /run/net-${interface}.conf
+ [ -e "/run/net-${interface}.conf" ] && . "/run/net-${interface}.conf"
if [ "$IPV4ADDR" != "0.0.0.0" ]
then
# source relevant ipconfig output
OLDHOSTNAME=${HOSTNAME}
- [ -e /run/net-${interface}.conf ] && . /run/net-${interface}.conf
+ [ -e "/run/net-${interface}.conf" ] && . "/run/net-${interface}.conf"
- [ -z ${HOSTNAME} ] && HOSTNAME=${OLDHOSTNAME}
+ [ -z "${HOSTNAME}" ] && HOSTNAME="${OLDHOSTNAME}"
export HOSTNAME
if [ -n "${interface}" ]
then
- HWADDR="$(cat /sys/class/net/${interface}/address)"
+ # HWADDR used by do_iscsi from 9990-mount-iscsi.sh
+ # shellcheck disable=SC2034
+ HWADDR="$(cat "/sys/class/net/${interface}/address")"
+ fi
+
+ if [ ! -e "/etc/hostname" ] && [ -n "${HOSTNAME}" ]
+ then
+ echo "Creating /etc/hostname"
+ echo "${HOSTNAME}" > /etc/hostname
+ fi
+
+ # Only create /etc/hosts if FQDN is known (to let 'hostname -f' query
+ # this file). Otherwise DNS will be queried to determine the FQDN.
+ if [ ! -e "/etc/hosts" ] && [ -n "${DNSDOMAIN}" ]
+ then
+ echo "Creating /etc/hosts"
+ cat > /etc/hosts <<EOF
+127.0.0.1 localhost
+127.0.1.1 ${HOSTNAME}.${DNSDOMAIN} ${HOSTNAME}
+
+# The following lines are desirable for IPv6 capable hosts
+::1 localhost ip6-localhost ip6-loopback
+ff02::1 ip6-allnodes
+ff02::2 ip6-allrouters
+EOF
fi
if [ ! -e "/etc/resolv.conf" ]
if [ -n "${DNSDOMAIN}" ]
then
echo "domain ${DNSDOMAIN}" > /etc/resolv.conf
- echo "search ${DNSDOMAIN}" >> /etc/resolv.conf
fi
for i in ${IPV4DNS0} ${IPV4DNS1} ${IPV4DNS1} ${DNSSERVERS}
echo "nameserver $i" >> /etc/resolv.conf
fi
done
+
+ if [ -n "${DOMAINSEARCH}" ]
+ then
+ echo "search ${DOMAINSEARCH}" >> /etc/resolv.conf
+ elif [ -n "${DNSDOMAIN}" ]
+ then
+ echo "search ${DNSDOMAIN}" >> /etc/resolv.conf
+ fi
fi
# Check if we have a network device at all