X-Git-Url: http://git.grml.org/?a=blobdiff_plain;f=sbin%2Fnetcardconfig;h=d9440e6096f34ee1e533e8c77b134347d1ae3d53;hb=f512c908edc331ca6a87bb83a8ae06e630d2e040;hp=3a8036621a080c76da3d60c4744ebc10fb5cbe18;hpb=0129d4078b03e9f0919ad24368c4e88189b9702c;p=grml-network.git diff --git a/sbin/netcardconfig b/sbin/netcardconfig index 3a80366..d9440e6 100755 --- a/sbin/netcardconfig +++ b/sbin/netcardconfig @@ -28,58 +28,58 @@ bailout() { writeiwline() { IWOURLINE="" if [ -n "$NWID" ]; then - IWOURLINE="$IWOURLINE wireless-nwid $NWID\n" + IWOURLINE="$IWOURLINE\twireless-nwid $NWID\n" fi if [ -n "$MODE" ]; then - IWOURLINE="$IWOURLINE wireless-mode $MODE\n" + IWOURLINE="$IWOURLINE\twireless-mode $MODE\n" fi if [ -n "$CHANNEL" ]; then - IWOURLINE="$IWOURLINE wireless-channel $CHANNEL\n" + IWOURLINE="$IWOURLINE\twireless-channel $CHANNEL\n" fi if [ -n "$FREQ" ]; then - IWOURLINE="$IWOURLINE wireless-freq $FREQ\n" + IWOURLINE="$IWOURLINE\twireless-freq $FREQ\n" fi if [ -n "$KEY" ]; then if [ "$PUBKEY" -eq 1 ]; then # Store the key in interfaces in wireless-key - IWOURLINE="$IWOURLINE wireless-key $KEY\n" + IWOURLINE="$IWOURLINE\twireless-key $KEY\n" else # Store the key in /etc/network/wep.$DV which is root readable only # Use pre-up in interfaces to read and set it - echo "$KEY" > "/etc/network/wep.$DV" && chmod 600 "/etc/network/wep.$DV" && IWOURLINE="$IWOURLINE pre-up KEY=\$(cat /etc/network/wep.$DV) && iwconfig $DV key \$KEY\n" + echo "$KEY" > "/etc/network/wep.$DV" && chmod 600 "/etc/network/wep.$DV" && IWOURLINE="$IWOURLINE\tpre-up KEY=\$(cat /etc/network/wep.$DV) && iwconfig $DV key \$KEY\n" fi fi for mod in /sys/module/rt2??0/ ; do if [ -d "$mod" ]; then - IWPREUPLINE="$IWPREUPLINE pre-up /sbin/ip link set $DV up\n" + IWPREUPLINE="$IWPREUPLINE\tpre-up /sbin/ip link set $DV up\n" break fi done if [ -n "$IWCONFIG" ]; then - IWPREUPLINE="$IWPREUPLINE iwconfig $IWCONFIG\n" + IWPREUPLINE="$IWPREUPLINE\tiwconfig $IWCONFIG\n" fi if [ -n "$IWSPY" ]; then - IWPREUPLINE="$IWPREUPLINE iwspy $IWSPY\n" + IWPREUPLINE="$IWPREUPLINE\tiwspy $IWSPY\n" fi if [ -n "$IWPRIV" ]; then - IWPREUPLINE="$IWPREUPLINE iwpriv $IWPRIV\n" + IWPREUPLINE="$IWPREUPLINE\tiwpriv $IWPRIV\n" fi # execute ESSID last, but make sure that it is written as first option if [ -n "$ESSID" ]; then - IWOURLINE="$IWOURLINE wireless-essid $ESSID\n" + IWOURLINE="$IWOURLINE\twireless-essid $ESSID\n" fi if [ "$WPAON" -gt 0 ]; then - IWOURLINE="$IWOURLINE wpa-ssid $ESSID\n wpa-psk $WPASECRET\n" + IWOURLINE="$IWOURLINE\twpa-ssid $ESSID\n\twpa-psk $WPASECRET\n" fi IWOURLINE="$IWOURLINE $IWPREUPLINE" @@ -169,268 +169,292 @@ scanwlan(){ } configiface() { + local METHOD + METHOD="${1,,}" + if [[ -n "${METHOD}" ]] && [[ "${METHOD}" != 'dhcp' ]]; then + local IP + IP="${2}" + local NM + NM="${3}" + local DG + DG="${4}" + local NS + NS="${5}" + local BC + BC="${IP%.*}.255" + fi + [ ! -r /etc/network/interfaces ] && touch /etc/network/interfaces DEVICE=${NETDEVICES[$DV]} device2props DV=$DEVICENAME - ifdown "$DV" + ifdown "${DV}" --force sleep 3 - # wireless config - WLDEVICECOUNT="$(LANG=C LC_MESSAGEWS=C iwconfig "$DV" 2>/dev/null | wc -l)" - if [ $iswireless -gt 0 ] && $DIALOG --yesno "$MESSAGE13" 8 45; then - ESSID="" - NWID="" - MODE="" - CHANNEL="" - FREQ="" - SENS="" - RATE="" - KEY="" - RTS="" - FRAG="" - IWCONFIG="" - IWSPY="" - IWPRIV="" - - if [ -f /etc/network/interfaces ]; then - awk '/iface/{if(/'"$DV"'/){found=1}else{found=0}} - /essid/{if(found){for(i=NF;i>=2;i--)essid=$i "~" essid}} - /nwid/{if(found){nwid=$NF}} - /mode/{if(found){mode=$NF}} - /channel/{if(found){channel=$NF}} - /freq/{if(found){freq=$NF}} - /sens/{if(found){sens=$NF}} - /rate/{if(found){rate=$NF}} - /rts/{if(found){rts=$NF}} - /frag/{if(found){frag=$NF}} - /iwconfig/{if(!/KEY/){if(found){iwconfig=$NF}}} - /iwspy/{if(found){iwspy=$NF}} - /iwpriv/{if(found){iwpriv=$NF}} - /wireless[-_]key/{if(found){gsub(/^\W*wireless[-_]key\W*/,"");key=$0}} - END{ - if (!(length(essid))){essid="~~~"} - if (!(length(nwid))){nwid="~~~"} - if (!(length(mode))){mode="~~~"} - if (!(length(channel))){channel="~~~"} - if (!(length(freq))){freq="~~~"} - if (!(length(sens))){sens="~~~"} - if (!(length(rate))){rate="~~~"} - if (!(length(rts))){rts="~~~"} - if (!(length(frag))){frag="~~~"} - if (!(length(iwconfig))){iwconfig="~~~"} - if (!(length(iwspy))){iwspy="~~~"} - if (!(length(iwpriv))){iwpriv="~~~"} - if (!(length(key))){key="~~~"} - print essid" "nwid" "mode" "channel" "freq" "sens" "rate" "rts" "frag" "iwconfig" "iwspy" "iwpriv" "key - }' /etc/network/interfaces >"$TMP" - - read -r ESSID NWID MODE CHANNEL FREQ SENS RATE RTS FRAG IWCONFIG IWSPY IWPRIV KEY<"$TMP" - - [[ "$ESSID" =~ ^~~~$ ]] && ESSID="" - [[ "$NWID" =~ ^~~~$ ]] && NWID="" - [[ "$MODE" =~ ^~~~$ ]] && MODE="" - [[ "$CHANNEL" =~ ^~~~$ ]] && CHANNEL="" - [[ "$FREQ" =~ ^~~~$ ]] && FREQ="" - [[ "$SENS" =~ ^~~~$ ]] && SENS="" - [[ "$RATE" =~ ^~~~$ ]] && RATE="" - [[ "$RTS" =~ ^~~~$ ]] && RTS="" - [[ "$FRAG" =~ ^~~~$ ]] && FRAG="" - [[ "$IWCONFIG" =~ ^~~~$ ]] && IWCONFIG="" - [[ "$IWSPY" =~ ^~~~$ ]] && IWSPY="" - [[ "$IWPRIV" =~ ^~~~$ ]] && IWPRIV="" - [[ "$KEY" =~ ^~~~$ ]] && KEY="" - - # shellcheck disable=SC2088 - ESSID=$(echo $ESSID | tr '~' " " | sed 's/ *$//') - - if [ -z "$KEY" ]; then - KEY=$(cat "/etc/network/wep.$DV" 2>/dev/null) + # INTERACTIVE=true + if "${INTERACTIVE}" ; then + # Setup wireless options? + if [ $iswireless -gt 0 ] && $DIALOG --yesno "$MESSAGE13" 8 45; then + WLDEVICECOUNT="$(LANG=C LC_MESSAGEWS=C iwconfig "$DV" 2>/dev/null | wc -l)" + ESSID="" + NWID="" + MODE="" + CHANNEL="" + FREQ="" + SENS="" + RATE="" + KEY="" + RTS="" + FRAG="" + IWCONFIG="" + IWSPY="" + IWPRIV="" + + if [ -f /etc/network/interfaces ]; then + awk '/iface/{if(/'"$DV"'/){found=1}else{found=0}} + /essid/{if(found){for(i=NF;i>=2;i--)essid=$i "~" essid}} + /nwid/{if(found){nwid=$NF}} + /mode/{if(found){mode=$NF}} + /channel/{if(found){channel=$NF}} + /freq/{if(found){freq=$NF}} + /sens/{if(found){sens=$NF}} + /rate/{if(found){rate=$NF}} + /rts/{if(found){rts=$NF}} + /frag/{if(found){frag=$NF}} + /iwconfig/{if(!/KEY/){if(found){iwconfig=$NF}}} + /iwspy/{if(found){iwspy=$NF}} + /iwpriv/{if(found){iwpriv=$NF}} + /wireless[-_]key/{if(found){gsub(/^\W*wireless[-_]key\W*/,"");key=$0}} + END{ + if (!(length(essid))){essid="~~~"} + if (!(length(nwid))){nwid="~~~"} + if (!(length(mode))){mode="~~~"} + if (!(length(channel))){channel="~~~"} + if (!(length(freq))){freq="~~~"} + if (!(length(sens))){sens="~~~"} + if (!(length(rate))){rate="~~~"} + if (!(length(rts))){rts="~~~"} + if (!(length(frag))){frag="~~~"} + if (!(length(iwconfig))){iwconfig="~~~"} + if (!(length(iwspy))){iwspy="~~~"} + if (!(length(iwpriv))){iwpriv="~~~"} + if (!(length(key))){key="~~~"} + print essid" "nwid" "mode" "channel" "freq" "sens" "rate" "rts" "frag" "iwconfig" "iwspy" "iwpriv" "key + }' /etc/network/interfaces >"$TMP" + + read -r ESSID NWID MODE CHANNEL FREQ SENS RATE RTS FRAG IWCONFIG IWSPY IWPRIV KEY<"$TMP" + + [[ "$ESSID" =~ ^~~~$ ]] && ESSID="" + [[ "$NWID" =~ ^~~~$ ]] && NWID="" + [[ "$MODE" =~ ^~~~$ ]] && MODE="" + [[ "$CHANNEL" =~ ^~~~$ ]] && CHANNEL="" + [[ "$FREQ" =~ ^~~~$ ]] && FREQ="" + [[ "$SENS" =~ ^~~~$ ]] && SENS="" + [[ "$RATE" =~ ^~~~$ ]] && RATE="" + [[ "$RTS" =~ ^~~~$ ]] && RTS="" + [[ "$FRAG" =~ ^~~~$ ]] && FRAG="" + [[ "$IWCONFIG" =~ ^~~~$ ]] && IWCONFIG="" + [[ "$IWSPY" =~ ^~~~$ ]] && IWSPY="" + [[ "$IWPRIV" =~ ^~~~$ ]] && IWPRIV="" + [[ "$KEY" =~ ^~~~$ ]] && KEY="" + + # shellcheck disable=SC2088 + ESSID=$(echo $ESSID | tr '~' " " | sed 's/ *$//') if [ -z "$KEY" ]; then - PUBKEY=0 + KEY=$(cat "/etc/network/wep.$DV" 2>/dev/null) + + if [ -z "$KEY" ]; then + PUBKEY=0 + else + PUBKEY=-1 + fi else - PUBKEY=-1 + PUBKEY=1 fi - else - PUBKEY=1 + + #echo "DEBUG:E:$ESSID N:$NWID M:$MODE C:$CHANNEL F:$FREQ S:$SENS R:$RATE K:$KEY R:$RTS F:$FRAG I:$IWCONFIG I:$IWSPY I:$IWPRIV" + rm -f "$TMP" fi - #echo "DEBUG:E:$ESSID N:$NWID M:$MODE C:$CHANNEL F:$FREQ S:$SENS R:$RATE K:$KEY R:$RTS F:$FRAG I:$IWCONFIG I:$IWSPY I:$IWPRIV" - rm -f "$TMP" - fi + # ask to scan or manually set wireless network + if $DIALOG --yesno "$MESSAGEWSCAN1" 8 45 ; then + RESCAN=1 + + while [ $RESCAN -eq 1 ] + do + scanwlan + $DIALOG --extra-button --extra-label "Rescan" --menu "$MESSAGEWSCAN2" 20 70 15 "${WARRAY[@]}" 2>"$TMP" + case $? in + 0) + RESCAN=0 + ;; + 3) + ;; + *) + bailout 1 + ;; + esac + done - # ask to scan or manually set wireless network - if $DIALOG --yesno "$MESSAGEWSCAN1" 8 45 ; then - RESCAN=1 - - while [ $RESCAN -eq 1 ] - do - scanwlan - $DIALOG --extra-button --extra-label "Rescan" --menu "$MESSAGEWSCAN2" 20 70 15 "${WARRAY[@]}" 2>"$TMP" - case $? in - 0) - RESCAN=0 - ;; - 3) - ;; - *) - bailout 1 - ;; - esac - done + read -r ESSID <"$TMP" ; rm -f "$TMP" + [ -z "$MODE" ] && MODE="Managed" - read -r ESSID <"$TMP" ; rm -f "$TMP" - [ -z "$MODE" ] && MODE="Managed" + else - else + $DIALOG --inputbox "$MESSAGEW4 $DEVICENAME $MESSAGEW5" 15 50 "$ESSID" 2>"$TMP" || bailout 1 + read -r ESSID <"$TMP" ; rm -f "$TMP" + [ -z "$ESSID" ] && ESSID="any" - $DIALOG --inputbox "$MESSAGEW4 $DEVICENAME $MESSAGEW5" 15 50 "$ESSID" 2>"$TMP" || bailout 1 - read -r ESSID <"$TMP" ; rm -f "$TMP" - [ -z "$ESSID" ] && ESSID="any" + $DIALOG --inputbox "$MESSAGEW6 $DEVICENAME $MESSAGEW7" 15 50 "$NWID" 2>"$TMP" || bailout 1 + read -r NWID <"$TMP" ; rm -f "$TMP" - $DIALOG --inputbox "$MESSAGEW6 $DEVICENAME $MESSAGEW7" 15 50 "$NWID" 2>"$TMP" || bailout 1 - read -r NWID <"$TMP" ; rm -f "$TMP" + $DIALOG --inputbox "$MESSAGEW8 $DEVICENAME $MESSAGEW9" 15 50 "$MODE" 2>"$TMP" || bailout 1 + read -r MODE <"$TMP" ; rm -f "$TMP" + [ -z "$MODE" ] && MODE="Managed" - $DIALOG --inputbox "$MESSAGEW8 $DEVICENAME $MESSAGEW9" 15 50 "$MODE" 2>"$TMP" || bailout 1 - read -r MODE <"$TMP" ; rm -f "$TMP" - [ -z "$MODE" ] && MODE="Managed" + $DIALOG --inputbox "$MESSAGEW10 $DEVICENAME $MESSAGEW11" 15 50 "$CHANNEL" 2>"$TMP" || bailout 1 + read -r CHANNEL <"$TMP" ; rm -f "$TMP" - $DIALOG --inputbox "$MESSAGEW10 $DEVICENAME $MESSAGEW11" 15 50 "$CHANNEL" 2>"$TMP" || bailout 1 - read -r CHANNEL <"$TMP" ; rm -f "$TMP" + if [ -z "$CHANNEL" ]; then + $DIALOG --inputbox "$MESSAGEW12 $DEVICENAME $MESSAGEW13" 15 50 "$FREQ" 2>"$TMP" || bailout 1 + read -r FREQ <"$TMP" ; rm -f "$TMP" + fi - if [ -z "$CHANNEL" ]; then - $DIALOG --inputbox "$MESSAGEW12 $DEVICENAME $MESSAGEW13" 15 50 "$FREQ" 2>"$TMP" || bailout 1 - read -r FREQ <"$TMP" ; rm -f "$TMP" fi - fi - - WPAON=0 - IWDRIVER=$driver - - case $IWDRIVER in - ath_pci) - WPA_DEV="madwifi" - ;; - ipw2200|ipw2100|ipw3945) - WPA_DEV="wext" - ;; - hostap) - WPA_DEV="hostap" - ;; - *) - WPA_DEV="wext" - ;; - esac - - if [ -z "$WPA_DEV" ]; then - if [ -d "/proc/net/ndiswrapper/$DV" ]; then - WPA_DEV=ndiswrapper - elif [ -d "/proc/net/hostap/$DV" ]; then - WPA_DEV=hostap - elif [ "$WLDEVICECOUNT" -eq 1 ]; then - if [ -e /proc/driver/atmel ]; then - WPA_DEV=atmel + WPAON=0 + IWDRIVER=$driver + + case $IWDRIVER in + ath_pci) + WPA_DEV="madwifi" + ;; + ipw2200|ipw2100|ipw3945) + WPA_DEV="wext" + ;; + hostap) + WPA_DEV="hostap" + ;; + *) + WPA_DEV="wext" + ;; + esac + + if [ -z "$WPA_DEV" ]; then + if [ -d "/proc/net/ndiswrapper/$DV" ]; then + WPA_DEV=ndiswrapper + elif [ -d "/proc/net/hostap/$DV" ]; then + WPA_DEV=hostap + elif [ "$WLDEVICECOUNT" -eq 1 ]; then + if [ -e /proc/driver/atmel ]; then + WPA_DEV=atmel + fi fi fi - fi - WPAON=-1 - - if [ -n "$WPA_DEV" ]; then - if $DIALOG --yesno "$MESSAGEW22" 15 50; then - # Other wpa options - # scan_ssid [0]|1 - # bssid 00:11:22:33:44:55 - # priority [0]|Integer - # proto [WPA RSN] WPA|RSN - # key_mgmt [WPA-PSK WPA-EAP]|NONE|WPA-PSK|WPA-EAP|IEEE8021X - # pairwise [CCMP TKIP]|CCMP|TKIP|NONE - # group [CCMP TKIP WEP105 WEP40]|CCMP|TKIP|WEP105|WEP40 - # eapol_flags [3]|1|2 - - WPAON=1 - KEY="" - WPASECRET=$(awk ' - /iface/{ - if(found){ - found=0 - } - else if (/'"$DV"'/){ - found=1 - } - } - /wpa-psk/{ - if(found){ - gsub(/\W*#.*$/,""); - if (gsub(/^\W*wpa-psk\W*/,"")){ - gsub(/\W.*$/,""); - print; - exit; - } - } - } - ' /etc/network/interfaces) - FIRST_RUN=0 # show the wpasecret input box at least once - while ( [ -z "$WPASECRET" ] || [ "$FIRST_RUN" ] ) ; do - $DIALOG --inputbox "$MESSAGEW23 $ESSID" 15 50 "$WPASECRET" 2>"$TMP" || bailout 1 - read -r WPASECRET <"$TMP" - if [ -z "$WPASECRET" ] ; then - $DIALOG --msgbox "Sorry, empty password not allowed, please retry." 0 0 || bailout 1 - fi - FIRST_RUN="" - done + WPAON=-1 + + if [ -n "$WPA_DEV" ]; then + if $DIALOG --yesno "$MESSAGEW22" 15 50; then + # Other wpa options + # scan_ssid [0]|1 + # bssid 00:11:22:33:44:55 + # priority [0]|Integer + # proto [WPA RSN] WPA|RSN + # key_mgmt [WPA-PSK WPA-EAP]|NONE|WPA-PSK|WPA-EAP|IEEE8021X + # pairwise [CCMP TKIP]|CCMP|TKIP|NONE + # group [CCMP TKIP WEP105 WEP40]|CCMP|TKIP|WEP105|WEP40 + # eapol_flags [3]|1|2 + + WPAON=1 + KEY="" + WPASECRET=$(awk ' + /iface/{ + if(found){ + found=0 + } + else if (/'"$DV"'/){ + found=1 + } + } + /wpa-psk/{ + if(found){ + gsub(/\W*#.*$/,""); + if (gsub(/^\W*wpa-psk\W*/,"")){ + gsub(/\W.*$/,""); + print; + exit; + } + } + } + ' /etc/network/interfaces) + FIRST_RUN=0 # show the wpasecret input box at least once + while ( [ -z "$WPASECRET" ] || [ "$FIRST_RUN" ] ) ; do + $DIALOG --inputbox "$MESSAGEW23 $ESSID" 15 50 "$WPASECRET" 2>"$TMP" || bailout 1 + read -r WPASECRET <"$TMP" + if [ -z "$WPASECRET" ] ; then + $DIALOG --msgbox "Sorry, empty password not allowed, please retry." 0 0 || bailout 1 + fi + FIRST_RUN="" + done + + rm -f "$TMP" + + case $WPA_DEV in + hostap) + MODE="Managed" + ;; + esac + else + WPASECRET="" + fi + else + WPASECRET="" + fi - rm -f "$TMP" + # No need for a wep key if we are using wpa + if [ ! $WPAON -eq 1 ]; then + $DIALOG --inputbox "$MESSAGEW14 $DEVICENAME $MESSAGEW15" 15 50 "$KEY" 2>"$TMP" || bailout 1 + read -r KEY <"$TMP" ; rm -f "$TMP" - case $WPA_DEV in - hostap) - MODE="Managed" - ;; - esac - else - WPASECRET="" - fi - else - WPASECRET="" - fi + if [ -n "$KEY" ] && [ "$PUBKEY" -eq 0 ]; then + if ! $DIALOG --yesno "$MESSAGEW25 $DEVICENAME $MESSAGEW26" 15 50; then + PUBKEY=1 + fi + fi + fi - # No need for a wep key if we are using wpa - if [ ! $WPAON -eq 1 ]; then - $DIALOG --inputbox "$MESSAGEW14 $DEVICENAME $MESSAGEW15" 15 50 "$KEY" 2>"$TMP" || bailout 1 - read -r KEY <"$TMP" ; rm -f "$TMP" + $DIALOG --inputbox "$MESSAGEW16 $DEVICENAME $MESSAGEW17" 15 50 "$IWCONFIG" 2>"$TMP" || bailout 1 + read -r IWCONFIG <"$TMP" ; rm -f "$TMP" - if [ -n "$KEY" ] && [ "$PUBKEY" -eq 0 ]; then - if ! $DIALOG --yesno "$MESSAGEW25 $DEVICENAME $MESSAGEW26" 15 50; then - PUBKEY=1 - fi - fi - fi + $DIALOG --inputbox "$MESSAGEW18 $DEVICENAME $MESSAGEW19" 15 50 "$IWSPY" 2>"$TMP" || bailout 1 + read -r IWSPY <"$TMP" ; rm -f "$TMP" - $DIALOG --inputbox "$MESSAGEW16 $DEVICENAME $MESSAGEW17" 15 50 "$IWCONFIG" 2>"$TMP" || bailout 1 - read -r IWCONFIG <"$TMP" ; rm -f "$TMP" + $DIALOG --inputbox "$MESSAGEW20 $DEVICENAME $MESSAGEW21" 15 50 "$IWPRIV" 2>"$TMP" || bailout 1 + read -r IWPRIV <"$TMP" ; rm -f "$TMP" - $DIALOG --inputbox "$MESSAGEW18 $DEVICENAME $MESSAGEW19" 15 50 "$IWSPY" 2>"$TMP" || bailout 1 - read -r IWSPY <"$TMP" ; rm -f "$TMP" - - $DIALOG --inputbox "$MESSAGEW20 $DEVICENAME $MESSAGEW21" 15 50 "$IWPRIV" 2>"$TMP" || bailout 1 - read -r IWPRIV <"$TMP" ; rm -f "$TMP" + unset IWOURLINE + if [ "$iswireless" = "1" ] ; then + writeiwline + fi - writeiwline - fi + fi # Setup wireless options? - # Configure VLAN on this interface? - if $DIALOG --defaultno --yesno "$MESSAGE16" 8 45; then - $DIALOG --inputbox "$MESSAGE17 $DV" 10 45 2>"$TMP" || bailout 1 - read -r VLAN <"$TMP" ; rm -f "$TMP" - if [ -n "$VLAN" ]; then - modprobe 8021q # avoid warning that VLAN support isn't present yet - PDV=$DV - DV="vlan$VLAN" + # Configure VLAN on this interface? + if $DIALOG --defaultno --yesno "$MESSAGE16" 8 45; then + $DIALOG --inputbox "$MESSAGE17 $DV" 10 45 2>"$TMP" || bailout 1 + read -r VLAN <"$TMP" ; rm -f "$TMP" + if [ -n "$VLAN" ]; then + modprobe 8021q # avoid warning that VLAN support isn't present yet + PDV=$DV + DV="vlan$VLAN" + fi fi - fi + fi # INTERACTIVE=true - if $DIALOG --yesno "$MESSAGE2" 8 45; then + # Use DHCP broadcast? + if ("${INTERACTIVE}" && "${DIALOG}" --yesno "${MESSAGE2}" 8 45) || \ + (! "${INTERACTIVE}" && [[ "${METHOD}" == 'dhcp' ]]) ; then if [ -w /etc/network/interfaces ]; then rm -f "$TMP" awk '/iface/{if(/'"$DV"'/){found=1}else{found=0}} @@ -439,7 +463,14 @@ configiface() { {if(!(found+lastblank)){print}} END{print "iface '"$DV"' inet dhcp";if("'"$PDV"'"!=""){print "\tvlan-raw-device '"$PDV"'"}}' \ /etc/network/interfaces >"$TMP" - echo -e "$IWOURLINE" >> "$TMP" + case "$DV" in + "$WLAN") + # write wireless configuration only when we are dealing with a wireless device, + # it might be set from a previous configuration run of a wireless device + # while the currently configured network device isn't a wireless device + echo -e "$IWOURLINE" >> "$TMP" + ;; + esac #echo -e "\n\n" >> $TMP cat "$TMP" >/etc/network/interfaces rm -f "$TMP" @@ -447,38 +478,51 @@ configiface() { #addauto fi else - if [ -f /etc/network/interfaces ]; then - awk '/iface/{if(/'"$DV"'/){found=1}else{found=0}} - /address/{if(found){address=$NF}} - /netmask/{if(found){netmask=$NF}} - /broadcast/{if(found){broadcast=$NF}} - /gateway/{if(found){gateway=$NF}} - /dns-nameservers/{if(found){dnsnameservers=$NF}} - END{print address" "netmask" "broadcast" "gateway" "dnsnameservers}' /etc/network/interfaces >"$TMP" - read -r IP NM BC DG NS <"$TMP" - rm -f "$TMP" - fi + if "${INTERACTIVE}" ; then + if [ -f /etc/network/interfaces ]; then + awk '/iface/{if(/'"$DV"'/){found=1}else{found=0}} + /address/{if(found){address=$NF}} + /netmask/{if(found){netmask=$NF}} + /broadcast/{if(found){broadcast=$NF}} + /gateway/{if(found){gateway=$NF}} + /dns-nameservers/{if(found){dnsnameservers=$NF}} + END{print address" "netmask" "broadcast" "gateway" "dnsnameservers}' /etc/network/interfaces >"$TMP" + read -r IP NM BC DG NS <"$TMP" + rm -f "$TMP" + fi - $DIALOG --inputbox "$MESSAGE6 $DV" 10 45 "${IP:-192.168.0.1}" 2>"$TMP" || bailout 1 - read -r IP <"$TMP" ; rm -f "$TMP" + $DIALOG --inputbox "$MESSAGE6 $DV" 10 45 "${IP:-192.168.0.1}" 2>"$TMP" || bailout 1 + read -r IP <"$TMP" ; rm -f "$TMP" - $DIALOG --inputbox "$MESSAGE7 $DV" 10 45 "${NM:-255.255.255.0}" 2>"$TMP" || bailout 1 - read -r NM <"$TMP" ; rm -f "$TMP" + $DIALOG --inputbox "$MESSAGE7 $DV" 10 45 "${NM:-255.255.255.0}" 2>"$TMP" || bailout 1 + read -r NM <"$TMP" ; rm -f "$TMP" - $DIALOG --inputbox "$MESSAGE8 $DV" 10 45 "${BC:-${IP%.*}.255}" 2>"$TMP" || bailout 1 - read -r BC <"$TMP" ; rm -f "$TMP" + $DIALOG --inputbox "$MESSAGE8 $DV" 10 45 "${BC:-${IP%.*}.255}" 2>"$TMP" || bailout 1 + read -r BC <"$TMP" ; rm -f "$TMP" - $DIALOG --inputbox "$MESSAGE9" 10 45 "${DG:-${IP%.*}.1}" 2>"$TMP" - read -r DG <"$TMP" ; rm -f "$TMP" + $DIALOG --inputbox "$MESSAGE9" 10 45 "${DG:-${IP%.*}.1}" 2>"$TMP" + read -r DG <"$TMP" ; rm -f "$TMP" - if [ -f "/etc/resolv.conf" ]; then - NS="$(awk '/^nameserver/{printf "%s ",$2}' /etc/resolv.conf)" - fi + if [ -f "/etc/resolv.conf" ]; then + NS="$(awk '/^nameserver/{printf "%s ",$2}' /etc/resolv.conf)" + fi - $DIALOG --inputbox "$MESSAGE10" 10 45 "${NS:-$DG}" 2>"$TMP" - read -r NS <"$TMP" ; rm -f "$TMP" + $DIALOG --inputbox "$MESSAGE10" 10 45 "${NS:-$DG}" 2>"$TMP" + read -r NS <"$TMP" ; rm -f "$TMP" + fi if [ -w /etc/network/interfaces ]; then + case "$DV" in + "$WLAN") + ;; + *) + # ensure we don't leak the IWOURLINE into the + # following awk command line, if we are configuring + # a device without wireless capabilities + unset IWOURLINE + ;; + esac + awk '/iface/{if(/'"$DV"'/){found=1}else{found=0}} {if(!found){print}} END{print "\niface '"$DV"' inet static\n\taddress '"$IP"'\n\tnetmask '"$NM"'\n\tnetwork '"${IP%.*}.0"'";if("'"$BC"'"!=""){print "\tbroadcast '"$BC"'"};if("'"$DG"'"!=""){print "\tgateway '"$DG"'"};if("'"$NS"'"!=""){print "\tdns-nameservers '"$NS"'"};if("'"$PDV"'"!=""){print "\tvlan-raw-device '"$PDV"'"};if("'"$IWOURLINE"'"!=""){print "'"$IWOURLINE"'"};print "\n"}' \ @@ -491,10 +535,18 @@ configiface() { #addauto fi - fi + fi # Use DHCP broadcast? echo "Done." } +enable_auto_if () { + addauto + # get persistent interface names across reboots + generate_udev_entry + # make sure we don't run the dhcp stuff when using /etc/network/interfaces + disable_config_dhcp +} + DIALOG="dialog" NET_DEVICE_NAME="Network_device" @@ -539,6 +591,14 @@ MESSAGEW26=")? If you say no, your wep key will be stored in /etc/network/inte MESSAGEWSCAN1="Scan for available wireless networks?" MESSAGEWSCAN2="Please choose a wireless network from below:" +NET_DEV="${NET_DEV:-}" +METHOD="${METHOD,,:-}" +IPADDR="${IPADDR:-}" +NETMASK="${NETMASK:-}" +GATEWAY="${GATEWAY:-}" +DNS="${DNS:-}" +INTERACTIVE=true + NETDEVICESCOUNT=0 if [ -r /proc/net/dev ] ; then LAN=$(tail -n +3 /proc/net/dev | awk -F: '{print $1}'| sed "s/\s*//" | grep -v -e ^lo -e ^vmnet | sort) @@ -546,13 +606,34 @@ else LAN="" fi +if [[ -n "${NET_DEV}" ]] && [[ -n "${METHOD}" ]]; then + if [[ "${METHOD}" != 'dhcp' ]]; then + missed=0 + if [[ -z "${IPADDR}" ]]; then + echo "Mandatory parameter IPADDR for method ${METHOD} missing" >&2 + ((missed++)) + fi + if [[ -z "${NETMASK}" ]]; then + echo "Mandatory parameter NETMASK for method ${METHOD} missing" >&2 + ((missed++)) + fi + if [[ "${missed}" -gt 0 ]]; then + echo "Can not proceed, exiting..." >&2 + bailout 1 + fi + unset missed + fi + LAN="${NET_DEV}" + INTERACTIVE=false +fi + if [ -z "${WLAN[*]}" ] ; then WLAN_OLD=( $(tail -n +3 /proc/net/wireless 2>/dev/null|awk -F: '{print $1}') ) # /proc/net/wireless does not work e.g. with iwl3945 on kernel 2.6.33 anymore WLAN_NEW=( $(for i in /sys/class/net/* ; do ( [ -d "$i/wireless" ] || [ -d "$i/phy80211" ] ) && basename "$i" ; done) ) set -a WLAN_IWCONFIG for DEV in $LAN ; do - iwconfig $DEV 2>/dev/null 1>&2 && WLAN_IWCONFIG+=($DEV) + iwconfig "${DEV}" 2>/dev/null 1>&2 && WLAN_IWCONFIG+=("${DEV}") done WLAN=( $(echo "${WLAN_OLD[@]}" "${WLAN_NEW[@]}" "${WLAN_IWCONFIG[@]}" | tr ' ' '\n' | sort -u) ) fi @@ -582,10 +663,10 @@ while read -r dev mac; do ((NETDEVICESCOUNT++)) done < <(ip link show | awk ' !/^\s/{sub(/:/,"",$2);IFACE=$2} /link.ether/{if (IFACE !~/^vmnet/) print IFACE" "$2}') for dev in $LAN; do - if [ "$(ethtool -i $dev 2>/dev/null|awk '/^bus-info:/{print $2}')" == "ieee1394" ]; then + if [ "$(ethtool -i "${dev}" 2>/dev/null|awk '/^bus-info:/{print $2}')" == "ieee1394" ]; then isauto="0" - grep auto /etc/network/interfaces | grep -q $dev && isauto="1" - NETDEVICES[$NETDEVICESCOUNT]="$dev A::$isauto D::$(ethtool -i $dev 2>/dev/null|awk '/^driver:/{print $2}') W::0 F::1" + grep auto /etc/network/interfaces | grep -q "${dev}" && isauto="1" + NETDEVICES[$NETDEVICESCOUNT]="${dev} A::${isauto} D::$(ethtool -i "${dev}" 2>/dev/null|awk '/^driver:/{print $2}') W::0 F::1" ((NETDEVICESCOUNT++)) fi done @@ -621,9 +702,27 @@ EXITMENU=( $EXITKEY Exit ) while (true); do # first get the device if [ "$count" -gt 1 ]; then - rm -f "$TMP" - $DIALOG --menu "$MESSAGE1" 18 60 12 "${DEVICELIST[@]}" "${EXITMENU[@]}" 2>"$TMP" || bailout - read -r DV <"$TMP" ; rm -f "$TMP" + if "${INTERACTIVE}" ; then + rm -f "$TMP" + $DIALOG --menu "$MESSAGE1" 18 60 12 "${DEVICELIST[@]}" "${EXITMENU[@]}" 2>"$TMP" || bailout + read -r DV <"$TMP" ; rm -f "$TMP" + else + # we have interface name so we need to find its number in NETDEVICES + DV=0 + found=false + for DV in "${!NETDEVICES[@]}"; do + if [[ "${NETDEVICES[$DV]}" =~ ^"${NET_DEV} " ]]; then + found=true + break + fi + done + if ! "${found}"; then + echo "There is no interface ${NET_DEV} in the system" >&2 + bailout 1 + fi + + [[ -z "${IFACEDONE}" ]] || bailout + fi [ "$DV" = "$EXITKEY" ] && bailout else # Only one device @@ -634,18 +733,23 @@ while (true); do # device config loop IFACEDONE="" while [ -n "$DV" ] && [ -z "$IFACEDONE" ]; do - configiface + configiface "${METHOD}" "${IPADDR}" "${NETMASK}" "${GATEWAY}" "${DNS}" if ! ifup $DV; then - $DIALOG --yesno "$MESSAGE14" 15 50 || IFACEDONE="DONE" + if "${INTERACTIVE}" ; then + $DIALOG --yesno "$MESSAGE14" 15 50 || IFACEDONE="DONE" + else + echo "${MESSAGE14}" >&2 + bailout 1 + fi else - if $DIALOG --yesno "$MESSAGE15" 12 50 ; then - addauto - # get persistent interface names across reboots - generate_udev_entry - # make sure we don't run the dhcp stuff when using /etc/network/interfaces - disable_config_dhcp + if "${INTERACTIVE}" ; then + if $DIALOG --yesno "$MESSAGE15" 12 50 ; then + enable_auto_if + else + remauto + fi else - remauto + enable_auto_if fi IFACEDONE="DONE" fi