From bfdbe82097d80671e248ba341c2dd6151adf1645 Mon Sep 17 00:00:00 2001 From: MrMM <mm@freifunk-aachen.de> Date: Mon, 5 Oct 2015 22:19:13 +0200 Subject: [PATCH] Set the online and offline SSID at the top of the script --- files/lib/gluon/ssid-changer/ssid-changer.sh | 27 +++++++++++++------- 1 file changed, 18 insertions(+), 9 deletions(-) diff --git a/files/lib/gluon/ssid-changer/ssid-changer.sh b/files/lib/gluon/ssid-changer/ssid-changer.sh index 19ee9e9..a637efd 100755 --- a/files/lib/gluon/ssid-changer/ssid-changer.sh +++ b/files/lib/gluon/ssid-changer/ssid-changer.sh @@ -1,20 +1,25 @@ + #!/bin/sh +# At first some Definitions: + +ONLINE_SSID='Freifunk' +OFFLINE_PREFIX='FF_OFFLINE_' # Use something short to leave space for the nodename #Is there an active Gateway GATEWAY_TQ=`batctl gwl | grep "^=>" | cut -d" " -f3 | tr -d "()"` -if [ $GATEWAY_TQ > 50 ]; +if [ $GATEWAY_TQ -gt 50 ]; then echo "Gateway TQ is $GATEWAY_TQ node is online" for RADIO in $(iw dev | grep client | cut -d" " -f2); do - CURRENT_SSID=`iw dev $RADIO info | grep ssid | cut -d" " -f2` - # Use Freifunk for now, get it from /lib/gluon/site.conf in future version - if [ $CURRENT_SSID == 'Freifunk' ] + CURRENT_SSID=`iw dev $RADIO info | grep ssid | cut -d" " -f2` # Is there a better way to fetch the SSID wich is active? + if [ $CURRENT_SSID == $ONLINE_SSID ] then echo "SSID $CURRENT_SSID is correct, noting to do" else + echo "SSID is $CURRENT_SSID, change to $ONLINE_SSID" NUM=`echo $RADIO | tail -c 2` - `uci set wireless.client_radio$NUM.ssid="Freifunk"` + `uci set wireless.client_radio$NUM.ssid=$ONLINE_SSID` wifi fi done @@ -22,15 +27,20 @@ then else echo "Gateway TQ is $GATEWAY_TQ node is considered offline" NODENAME=`uname -n` - #There is a limit auf 32 charakters for the ssid + 'FF_OFFLINE_' leves us 21 maximum SSID length - if [ ${#NODENAME} > 20 ] ; then - OFFLINE_SSID=`echo "FF_OFFLINE_${STRING:0:9}...${STRING:(-9)}"` # use the first and last part of the nodename for nodes with long prefix + if [ ${#NODENAME} > 30-${#OFFLINE_PREFIX} ] ; then #32 would be possible as well + HALF=$(( (28 - ${#OFFLINE_PREFIX} ) / 2 )) + SKIP=$(( ${#NODENAME} - $HALF )) + OFFLINE_SSID=$OFFLINE_PREFIX${NODENAME:0:$HALF}...${NODENAME:$SKIP:${#NODENAME}} # use the first and last part of the nodename for nodes with long name + else + OFFLINE_SSID=`$OFFLINE_PREFIX$NODENAME` + fi for RADIO in $(iw dev | grep client | cut -d" " -f2); do CURRENT_SSID=`iw dev $RADIO info | grep ssid | cut -d" " -f2` if [ $CURRENT_SSID == $OFFLINE_SSID ] then echo "SSID $CURRENT_SSID is correct, noting to do" else + echo "SSID is $CURRENT_SSID, change to $OFFLINE_SSID" NUM=`echo $RADIO | tail -c 2` `uci set wireless.client_radio$NUM.ssid="$OFFLINE_SSID"` wifi @@ -38,4 +48,3 @@ else done fi - -- GitLab