| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513 | 
							- #!/bin/bash
 - #
 - # .---.                  .              .
 - # |                      |              |
 - # |--- .--. .-.  .-.  .-.|  .-. .--.--. |.-.  .-. .--.  .-.
 - # |    |   (.-' (.-' (   | (   )|  |  | |   )(   )|  | (.-'
 - # '    '     --'  --'  -' -  -' '  '   -' -'   -' '   -  --'
 - #
 - #                    Freedom in the Cloud
 - #
 - # Wifi configuration tools
 - 
 - # License
 - # =======
 - #
 - # Copyright (C) 2016 Bob Mottram <bob@robotics.uk.to>
 - #
 - # This program is free software: you can redistribute it and/or modify
 - # it under the terms of the GNU Affero General Public License as published by
 - # the Free Software Foundation, either version 3 of the License, or
 - # (at your option) any later version.
 - #
 - # This program is distributed in the hope that it will be useful,
 - # but WITHOUT ANY WARRANTY; without even the implied warranty of
 - # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 - # GNU Affero General Public License for more details.
 - #
 - # You should have received a copy of the GNU Affero General Public License
 - # along with this program.  If not, see <http://www.gnu.org/licenses/>.
 - 
 - PROJECT_NAME='freedombone'
 - 
 - export TEXTDOMAIN=${PROJECT_NAME}-wifi
 - export TEXTDOMAINDIR="/usr/share/locale"
 - 
 - CONFIGURATION_FILE=$HOME/${PROJECT_NAME}.cfg
 - COMPLETION_FILE=$HOME/${PROJECT_NAME}-completed.txt
 - 
 - WIFI_INTERFACE=wlan0
 - wifi_interface_specified=
 - WIFI_TYPE='wpa2-psk'
 - WIFI_SSID=
 - WIFI_PASSPHRASE=
 - WIFI_HOTSPOT='no'
 - WIFI_CONFIG=/etc/wpa_supplicant/wpa_supplicant.conf
 - WIFI_NETWORKS_FILE=~/${PROJECT_NAME}-wifi.cfg
 - NETWORKS_INTERACTIVE=
 - WIFI_DISABLE=
 - 
 - IFACE=
 - IFACE_SECONDARY=
 - 
 - function update_wifi_adaptors {
 -     IFACE=
 -     IFACE_SECONDARY=
 - 
 -     for i in $(seq 10 -1 0); do
 -         if grep -q "wlan${i}" /proc/net/dev; then
 -             if [ ! $IFACE ]; then
 -                 IFACE="wlan${i}"
 -             else
 -                 IFACE_SECONDARY="wlan${i}"
 -                 return
 -             fi
 -         fi
 -     done
 - }
 - 
 - function wifi_get_psk {
 -     ssid=$1
 -     passphrase=$2
 - 
 -     psk=$(wpa_passphrase "$ssid" "$passphrase" | grep 'psk=' | sed -n 2p | awk -F '=' '{print $2}')
 -     echo $psk
 - }
 - 
 - function hotspot_off {
 -     if [ ! -f /etc/hostapd/hostapd.conf ]; then
 -         return
 -     fi
 -     systemctl stop hostapd
 - 
 -     rm /etc/hostapd/hostapd.conf
 - 
 -     if [ -f /etc/network/interfaces_original ]; then
 -         cp /etc/network/interfaces_original /etc/network/interfaces
 -     else
 -         echo '# interfaces(5) file used by ifup(8) and ifdown(8)' > /etc/network/interfaces
 -         echo '# Include files from /etc/network/interfaces.d:' >> /etc/network/interfaces
 -         echo 'source-directory /etc/network/interfaces.d' >> /etc/network/interfaces
 -     fi
 - 
 -     systemctl restart network-manager
 -     ifdown $WIFI_INTERFACE
 - }
 - 
 - function hotspot_on {
 -     if [ ! -f /etc/default/hostapd ]; then
 -         echo $'/etc/default/hostapd was not found'
 -         exit 67241
 -     fi
 -     if [ ${#WIFI_PASSPHRASE} -lt 8 ]; then
 -         echo $'Wifi hotspot passphrase is too short'
 -         exit 25719
 -     fi
 - 
 -     sed -i 's|#DAEMON_CONF=.*|DAEMON_CONF="/etc/hostapd/hostapd.conf"|g' /etc/default/hostapd
 - 
 -     echo '### Wireless network name ###' > /etc/hostapd/hostapd.conf
 -     echo "interface=$WIFI_INTERFACE" >> /etc/hostapd/hostapd.conf
 -     echo '' >> /etc/hostapd/hostapd.conf
 -     echo '### Set your bridge name ###' >> /etc/hostapd/hostapd.conf
 -     echo 'bridge=br0' >> /etc/hostapd/hostapd.conf
 -     echo '' >> /etc/hostapd/hostapd.conf
 -     echo 'driver=nl80211' >> /etc/hostapd/hostapd.conf
 -     echo "country_code=UK" >> /etc/hostapd/hostapd.conf
 -     echo "ssid=$WIFI_SSID" >> /etc/hostapd/hostapd.conf
 -     echo 'hw_mode=g' >> /etc/hostapd/hostapd.conf
 -     echo 'channel=6' >> /etc/hostapd/hostapd.conf
 -     echo 'wpa=2' >> /etc/hostapd/hostapd.conf
 -     echo "wpa_passphrase=$WIFI_PASSPHRASE" >> /etc/hostapd/hostapd.conf
 -     echo '' >> /etc/hostapd/hostapd.conf
 -     echo '## Key management algorithms ##' >> /etc/hostapd/hostapd.conf
 -     echo 'wpa_key_mgmt=WPA-PSK' >> /etc/hostapd/hostapd.conf
 -     echo '' >> /etc/hostapd/hostapd.conf
 -     echo '## Set cipher suites (encryption algorithms) ##' >> /etc/hostapd/hostapd.conf
 -     echo '## TKIP = Temporal Key Integrity Protocol' >> /etc/hostapd/hostapd.conf
 -     echo '## CCMP = AES in Counter mode with CBC-MAC' >> /etc/hostapd/hostapd.conf
 -     echo 'wpa_pairwise=TKIP' >> /etc/hostapd/hostapd.conf
 -     echo 'rsn_pairwise=CCMP' >> /etc/hostapd/hostapd.conf
 -     echo '' >> /etc/hostapd/hostapd.conf
 -     echo '## Shared Key Authentication ##'
 -     echo 'auth_algs=1' >> /etc/hostapd/hostapd.conf
 -     echo '' >> /etc/hostapd/hostapd.conf
 -     echo '## Accept all MAC address ###' >> /etc/hostapd/hostapd.conf
 -     echo 'macaddr_acl=0' >> /etc/hostapd/hostapd.conf
 - 
 -     if [ ! -f /etc/network/interfaces_original ]; then
 -         if ! grep -q "# wifi enabled" /etc/network/interfaces; then
 -             cp /etc/network/interfaces /etc/network/interfaces_original
 -         fi
 -     fi
 - 
 -     echo '# wifi enabled' > /etc/network/interfaces
 -     echo 'auto lo br0' >> /etc/network/interfaces
 -     echo 'iface lo inet loopback' >> /etc/network/interfaces
 -     echo '' >> /etc/network/interfaces
 -     echo "# wireless $WIFI_INTERFACE" >> /etc/network/interfaces
 -     echo "allow-hotplug $WIFI_INTERFACE" >> /etc/network/interfaces
 -     echo "iface $WIFI_INTERFACE inet manual" >> /etc/network/interfaces
 -     echo '' >> /etc/network/interfaces
 -     echo '# eth0 connected to the ISP router' >> /etc/network/interfaces
 -     echo 'allow-hotplug eth0' >> /etc/network/interfaces
 -     echo 'iface eth0 inet manual' >> /etc/network/interfaces
 -     echo '' >> /etc/network/interfaces
 -     echo '# Setup bridge' >> /etc/network/interfaces
 -     echo 'iface br0 inet static' >> /etc/network/interfaces
 -     echo "    bridge_ports $WIFI_INTERFACE eth0" >> /etc/network/interfaces
 - 
 -     systemctl restart network-manager
 -     ifup $WIFI_INTERFACE
 -     systemctl restart hostapd
 - }
 - 
 - function wifi_wpa2_psk {
 -     ssid=$1
 -     passphrase=$2
 - 
 -     if [ ! -f /etc/network/interfaces_original ]; then
 -         if ! grep -q "# wifi enabled" /etc/network/interfaces; then
 -             cp /etc/network/interfaces /etc/network/interfaces_original
 -         fi
 -     fi
 - 
 -     echo '# wifi enabled' > /etc/network/interfaces
 -     echo 'auto lo' >> /etc/network/interfaces
 -     echo 'iface lo inet loopback' >> /etc/network/interfaces
 -     echo '' >> /etc/network/interfaces
 -     echo 'allow-hotplug eth0' >> /etc/network/interfaces
 -     echo 'iface eth0 inet dhcp' >> /etc/network/interfaces
 -     echo '' >> /etc/network/interfaces
 -     echo "allow-hotplug ${WIFI_INTERFACE}" >> /etc/network/interfaces
 -     echo "iface ${WIFI_INTERFACE} inet manual" >> /etc/network/interfaces
 -     echo "  wpa-roam $WIFI_CONFIG" >> /etc/network/interfaces
 -     echo '' >> /etc/network/interfaces
 -     echo 'iface default inet dhcp' >> /etc/network/interfaces
 - 
 -     wpa_passphrase "$ssid" "$passphrase" > $WIFI_CONFIG
 - 
 -     systemctl restart network-manager
 -     ifup ${WIFI_INTERFACE}
 - }
 - 
 - function wifi_none {
 -     ssid=$1
 - 
 -     if [ ! -f /etc/network/interfaces_original ]; then
 -         if ! grep -q "# wifi enabled" /etc/network/interfaces; then
 -             cp /etc/network/interfaces /etc/network/interfaces_original
 -         fi
 -     fi
 - 
 -     echo '# wifi enabled' > /etc/network/interfaces
 -     echo 'auto lo' >> /etc/network/interfaces
 -     echo 'iface lo inet loopback' >> /etc/network/interfaces
 -     echo '' >> /etc/network/interfaces
 -     echo 'allow-hotplug eth0' >> /etc/network/interfaces
 -     echo 'iface eth0 inet dhcp' >> /etc/network/interfaces
 -     echo '' >> /etc/network/interfaces
 -     echo "allow-hotplug ${WIFI_INTERFACE}" >> /etc/network/interfaces
 -     echo "iface ${WIFI_INTERFACE} inet manual" >> /etc/network/interfaces
 -     echo "  wpa-roam $WIFI_CONFIG" >> /etc/network/interfaces
 -     echo '' >> /etc/network/interfaces
 -     echo 'iface default inet dhcp' >> /etc/network/interfaces
 - 
 -     echo 'network={' > $WIFI_CONFIG
 -     echo "  ssid=\"${ssid}\"" >> $WIFI_CONFIG
 -     echo '  key_mgmt=NONE' >> $WIFI_CONFIG
 -     echo '}' >> $WIFI_CONFIG
 - 
 -     systemctl restart network-manager
 -     ifup ${WIFI_INTERFACE}
 - }
 - 
 - function networks_from_file {
 -     if [ ! -f $WIFI_NETWORKS_FILE ]; then
 -         exit 4
 -     fi
 - 
 -     if [ ! -f /etc/network/interfaces_original ]; then
 -         if ! grep -q "# wifi enabled" /etc/network/interfaces; then
 -             cp /etc/network/interfaces /etc/network/interfaces_original
 -         fi
 -     fi
 - 
 -     echo '# wifi enabled' > /etc/network/interfaces
 -     echo 'auto lo' >> /etc/network/interfaces
 -     echo 'iface lo inet loopback' >> /etc/network/interfaces
 -     echo '' >> /etc/network/interfaces
 -     echo 'allow-hotplug eth0' >> /etc/network/interfaces
 -     echo 'iface eth0 inet dhcp' >> /etc/network/interfaces
 -     echo '' >> /etc/network/interfaces
 -     echo "allow-hotplug ${WIFI_INTERFACE}" >> /etc/network/interfaces
 -     echo "iface ${WIFI_INTERFACE} inet manual" >> /etc/network/interfaces
 -     echo "  wpa-roam $WIFI_CONFIG" >> /etc/network/interfaces
 -     echo '' >> /etc/network/interfaces
 -     echo 'iface default inet dhcp' >> /etc/network/interfaces
 - 
 -     # remove wpa_supplicant.conf if it exists
 -     if [ -f $WIFI_CONFIG ]; then
 -         rm -f $WIFI_CONFIG
 -     fi
 - 
 -     ctr=0
 -     while read -r line
 -     do
 -         if [ ${#line} -gt 1 ]; then
 -             if [[ "$line" != '#'* ]]; then
 -                 if [ $ctr -eq 0 ]; then
 -                     WIFI_SSID="$line"
 -                 fi
 -                 if [ $ctr -eq 1 ]; then
 -                     WIFI_TYPE="$line"
 -                     if [[ $WIFI_TYPE == $'none' || $WIFI_TYPE == $'open' ]]; then
 -                         echo 'network={' >> $WIFI_CONFIG
 -                         echo "  ssid=\"${WIFI_SSID}\"" >> $WIFI_CONFIG
 -                         echo '  key_mgmt=NONE' >> $WIFI_CONFIG
 -                         echo '}' >> $WIFI_CONFIG
 -                         ctr=0
 -                         continue
 -                     fi
 -                 fi
 -                 if [ $ctr -eq 2 ]; then
 -                     WIFI_PASSPHRASE="$line"
 -                     wpa_passphrase "$WIFI_SSID" "$WIFI_PASSPHRASE" >> $WIFI_CONFIG
 -                     ctr=0
 -                     continue
 -                 fi
 - 
 -                 ctr=$((ctr + 1))
 -             fi
 -         fi
 -     done < $WIFI_NETWORKS_FILE
 - 
 -     systemctl restart network-manager
 -     ifup ${WIFI_INTERFACE}
 - }
 - 
 - function create_networks_interactive {
 -     update_wifi_adaptors
 -     if [ ! $IFACE ]; then
 -         # Don't try to configure wifi if there are no adaptors
 -         return
 -     fi
 - 
 -     if [ -f $WIFI_NETWORKS_FILE ]; then
 -         rm $WIFI_NETWORKS_FILE
 -     fi
 - 
 -     echo $'# Add wifi networks as follows:' > $WIFI_NETWORKS_FILE
 -     echo '#' >> $WIFI_NETWORKS_FILE
 -     echo $'# MySSID' >> $WIFI_NETWORKS_FILE
 -     echo $'# wpa2-psk' >> $WIFI_NETWORKS_FILE
 -     echo $'# myWifiPassphrase' >> $WIFI_NETWORKS_FILE
 -     echo '#' >> $WIFI_NETWORKS_FILE
 -     echo $'# AnotherSSID' >> $WIFI_NETWORKS_FILE
 -     echo $'# none' >> $WIFI_NETWORKS_FILE
 -     echo '#' >> $WIFI_NETWORKS_FILE
 - 
 -     wifi_ctr=0
 -     wifi_networks_done=
 -     while [ ! $wifi_networks_done ]
 -     do
 -         data=$(tempfile 2>/dev/null)
 -         trap "rm -f $data" 0 1 2 5 15
 -         dialog --backtitle $"Freedombone Configuration" \
 -                --title $"Wifi Settings ${wifi_ctr}" \
 -                --form $"\nIf you wish to use wifi and have a Free Software compatible adapter (eg. Atheros) rather than wired ethernet then enter the details below, otherwise just select Ok:" 15 55 4 \
 -                $"SSID:" 1 1 "$WIFI_SSID" 1 16 30 30 \
 -                $"Type:" 2 1 "$WIFI_TYPE" 2 16 10 10 \
 -                $"Passphrase:" 3 1 "$WIFI_PASSPHRASE" 3 16 30 30 \
 -                2> $data
 -         sel=$?
 -         case $sel in
 -             1) return;;
 -             255) return;;
 -         esac
 -         WIFI_SSID=$(cat $data | sed -n 1p)
 -         WIFI_TYPE=$(cat $data | sed -n 2p)
 -         WIFI_PASSPHRASE=$(cat $data | sed -n 3p)
 - 
 -         # if these fields are empty then there are no more wifi networks
 -         if [ ${#WIFI_SSID} -lt 2 ]; then
 -             wifi_networks_done='yes'
 -             continue
 -         fi
 -         if [ ${#WIFI_TYPE} -lt 2 ]; then
 -             wifi_networks_done='yes'
 -             continue
 -         fi
 - 
 -         # update the wifi networks file
 -         echo '' >> $WIFI_NETWORKS_FILE
 -         echo "$WIFI_SSID" >> $WIFI_NETWORKS_FILE
 -         echo "$WIFI_TYPE" >> $WIFI_NETWORKS_FILE
 -         if [ ${#WIFI_PASSPHRASE} -gt 1 ]; then
 -             echo "$WIFI_PASSPHRASE" >> $WIFI_NETWORKS_FILE
 -         fi
 - 
 -         if [ ${#WIFI_SSID} -gt 1 ]; then
 -             if [ ${#WIFI_TYPE} -gt 1 ]; then
 -                 if [[ "${WIFI_TYPE}" == $'none' || "${WIFI_TYPE}" == $'open' ]]; then
 -                     return
 -                 else
 -                     if [ ${#WIFI_PASSPHRASE} -gt 1 ]; then
 -                         return
 -                     fi
 -                 fi
 -             fi
 -         fi
 - 
 -         # clear values
 -         WIFI_SSID=
 -         WIFI_PASSPHRASE=
 - 
 -         wifi_ctr=$((wifi_ctr + 1))
 -     done
 - }
 - 
 - function disable_wifi {
 -     if [[ ${1} == 'yes' || ${1} == 'y' ]]; then
 -         hotspot_off
 -         echo '# interfaces(5) file used by ifup(8) and ifdown(8)' > /etc/network/interfaces
 -         echo '# Include files from /etc/network/interfaces.d:' >> /etc/network/interfaces
 -         echo 'source-directory /etc/network/interfaces.d' >> /etc/network/interfaces
 -         systemctl restart network-manager
 -         ifdown ${WIFI_INTERFACE}
 -     else
 -         networks_from_file
 -     fi
 - }
 - 
 - function show_help {
 -     echo ''
 -     echo $"${PROJECT_NAME}-wifi -i [interface] -t [type] -s [ssid] -p [passphrase]"
 -     echo ''
 -     echo $'Wifi configuration tool'
 -     echo ''
 -     echo $'     --help                        Show help'
 -     echo $'  -i --interface [wlan0|wlan1...]  Device name'
 -     echo $'  -t --type [wpa2-psk|none|open]   Security type'
 -     echo $'  -s --ssid [id]                   Set SSID'
 -     echo $'  -p --passphrase [text]           Set passphrase'
 -     echo $'     --hotspot [yes|no]            Create a hotspot'
 -     echo $'     --networks [filename]         File containing wifi networks'
 -     echo $'     --createnetworks [filename]   Create file containing wifi networks'
 -     echo $'     --disable [yes/no]            Disable wifi'
 -     echo ''
 -     exit 0
 - }
 - 
 - while [[ $# > 1 ]]
 - do
 -     key="$1"
 - 
 -     case $key in
 -         --help)
 -             show_help
 -             ;;
 -         -i|--if|--interface)
 -             shift
 -             WIFI_INTERFACE=${1}
 -             wifi_interface_specified=1
 -             ;;
 -         -t|--type)
 -             shift
 -             WIFI_TYPE=${1}
 -             ;;
 -         -s|--ssid)
 -             shift
 -             WIFI_SSID=${1}
 -             ;;
 -         -p|--pass|--passphrase)
 -             shift
 -             WIFI_PASSPHRASE=${1}
 -             ;;
 -         --hotspot)
 -             shift
 -             WIFI_HOTSPOT=${1}
 -             ;;
 -         --networks)
 -             shift
 -             WIFI_NETWORKS_FILE=${1}
 -             ;;
 -         --networksinteractive)
 -             shift
 -             NETWORKS_INTERACTIVE='yes'
 -             WIFI_NETWORKS_FILE=${1}
 -             ;;
 -         --disable)
 -             shift
 -             WIFI_DISABLE=${1}
 -             if [[ $WIFI_DISABLE == $'yes' || $WIFI_DISABLE == $'y' ]]; then
 -                 WIFI_DISABLE='yes'
 -             else
 -                 WIFI_DISABLE='no'
 -             fi
 -             ;;
 -         *)
 -             # unknown option
 -             ;;
 -     esac
 -     shift
 - done
 - 
 - if [ $NETWORKS_INTERACTIVE ]; then
 -     create_networks_interactive
 -     exit 0
 - fi
 - 
 - if [ $WIFI_DISABLE ]; then
 -     disable_wifi $WIFI_DISABLE
 -     exit 0
 - fi
 - 
 - if [ ! $wifi_interface_specified= ]; then
 -     update_wifi_adaptors
 -     if [ ! $IFACE ]; then
 -         echo $'No wifi adaptors were found'
 -         exit 872356
 -     fi
 -     WIFI_INTERFACE=$IFACE
 - fi
 - 
 - if [ -f $WIFI_NETWORKS_FILE ]; then
 -     networks_from_file
 -     exit 0
 - fi
 - 
 - if [ ! $WIFI_SSID ]; then
 -     echo $'No SSID given'
 -     exit 1
 - fi
 - 
 - if [[ $WIFI_HOTSPOT != 'no' ]]; then
 -     hotspot_on
 -     exit 0
 - else
 -     hotspot_off
 - fi
 - 
 - if [[ "$WIFI_TYPE" != 'none' && "$WIFI_TYPE" != 'open' ]]; then
 -     if [ ! $WIFI_PASSPHRASE ]; then
 -         echo $'No wifi passphrase was given'
 -         exit 2
 -     fi
 - fi
 - 
 - if [[ $WIFI_TYPE == 'wpa2-psk' ]]; then
 -     if [ ! -d /etc/wpa_supplicant ]; then
 -         echo $'wpasupplicant package is not installed'
 -         exit 3
 -     fi
 -     wifi_wpa2_psk "$WIFI_SSID" "$WIFI_PASSPHRASE"
 -     exit 0
 - fi
 - 
 - if [[ "$WIFI_TYPE" == 'none' || "$WIFI_TYPE" == 'open' ]]; then
 -     wifi_none "$WIFI_SSID"
 -     exit 0
 - fi
 - 
 - exit 0
 
 
  |