Skip to content
Snippets Groups Projects
Commit 995190da authored by rubo77's avatar rubo77
Browse files

Read all options from config and add option to use mac as offline suffix instead of nodename

parent 9cd44be8
No related branches found
No related tags found
No related merge requests found
#!/bin/sh #!/bin/sh
MINUTES=1440 # only once every timeframe the SSID will change to OFFLINE (set to 1 minute to change every time the router gets offline) # only once every timeframe the SSID will change to OFFLINE (set to 1 minute to change every time the router gets offline)
FIRST=5 # the first few minutes directly after reboot within which an Offline-SSID always may be activated MINUTES="$(uci get ssid-changer.settings.switch_timeframe -q)"
OFFLINE_PREFIX='FF_OFFLINE_' # use something short to leave space for the nodename (no '~' allowed!) # the first few minutes directly after reboot within which an Offline-SSID always may be activated
: ${MINUTES:=1}
FIRST="$(uci get ssid-changer.settings.first -q)"
# use something short to leave space for the nodename (no '~' allowed!)
: ${FIRST:=5}
PREFIX="$(uci get ssid-changer.settings.prefix -q)"
# generate the ssid with either 'nodename', 'mac' or to use only the prefix: 'none'
: ${PREFIX:='FF_OFFLINE_'}
if [ "$(uci get ssid-changer.settings.enabled -q)" = '0' ]; then if [ "$(uci get ssid-changer.settings.enabled -q)" = '0' ]; then
DISABLED='1' DISABLED='1'
...@@ -10,20 +19,28 @@ else ...@@ -10,20 +19,28 @@ else
DISABLED='0' DISABLED='0'
fi fi
ONLINE_SSID="$(uci get wireless.client_radio0.ssid -q)" SETTINGS_SUFFIX="$(uci get ssid-changer.settings.suffix -q)"
: ${ONLINE_SSID:="FREIFUNK"} # if for whatever reason ONLINE_SSID is NULL
# generate an Offline SSID with the first and last part of the nodename to allow owner to recognise wich node is down if [ $SETTINGS_SUFFIX = 'nodename' ]; then
NODENAME="$(uname -n)" SUFFIX="$(uname -n)"
if [ ${#NODENAME} -gt $((30 - ${#OFFLINE_PREFIX})) ]; then # 32 would be possible as well if [ ${#SUFFIX} -gt $((30 - ${#PREFIX})) ]; then # 32 would be possible as well
HALF=$(( (28 - ${#OFFLINE_PREFIX} ) / 2 )) # calculate the length of the first part of the node identifier in the offline-ssid HALF=$(( (28 - ${#PREFIX} ) / 2 )) # calculate the length of the first part of the node identifier in the offline-ssid
SKIP=$(( ${#NODENAME} - $HALF )) # jump to this charakter for the last part of the name SKIP=$(( ${#SUFFIX} - $HALF )) # jump to this charakter for the last part of the name
OFFLINE_SSID=$OFFLINE_PREFIX${NODENAME:0:$HALF}...${NODENAME:$SKIP:${#NODENAME}} # use the first and last part of the nodename for nodes with long name SUFFIX=${SUFFIX:0:$HALF}...${SUFFIX:$SKIP:${#SUFFIX}} # use the first and last part of the nodename for nodes with long name
else fi
OFFLINE_SSID="$OFFLINE_PREFIX$NODENAME" # great! we are able to use the full nodename in the offline ssid elif [ $SETTINGS_SUFFIX = 'mac' ]; then
SUFFIX="$(uci get network.bat0.macaddr -q)"
else # 'none'
SUFFIX=''
fi fi
# maximum simplified, no more ttvn rating OFFLINE_SSID="$PREFIX$SUFFIX"
# TODO: ffac tq limits has to be implemented here if enabled
ONLINE_SSID="$(uci get wireless.client_radio0.ssid -q)"
: ${ONLINE_SSID:="FREIFUNK"} # if for whatever reason ONLINE_SSID is NULL
CHECK="$(batctl gwl -H|grep -v "gateways in range"|wc -l)" CHECK="$(batctl gwl -H|grep -v "gateways in range"|wc -l)"
HUP_NEEDED=0 HUP_NEEDED=0
if [ "$CHECK" -gt 0 ] || [ "$DISABLED" = '1' ]; then if [ "$CHECK" -gt 0 ] || [ "$DISABLED" = '1' ]; then
...@@ -37,11 +54,11 @@ if [ "$CHECK" -gt 0 ] || [ "$DISABLED" = '1' ]; then ...@@ -37,11 +54,11 @@ if [ "$CHECK" -gt 0 ] || [ "$DISABLED" = '1' ]; then
fi fi
CURRENT_SSID="$(grep "^ssid=$OFFLINE_SSID" $HOSTAPD | cut -d"=" -f2)" CURRENT_SSID="$(grep "^ssid=$OFFLINE_SSID" $HOSTAPD | cut -d"=" -f2)"
if [ "$CURRENT_SSID" = "$OFFLINE_SSID" ]; then if [ "$CURRENT_SSID" = "$OFFLINE_SSID" ]; then
logger -s -t "gluon-offline-ssid" -p 5 "SSID is $CURRENT_SSID, change to $ONLINE_SSID" logger -s -t "gluon-ssid-changer" -p 5 "SSID is $CURRENT_SSID, change to $ONLINE_SSID"
sed -i "s~^ssid=$CURRENT_SSID~ssid=$ONLINE_SSID~" $HOSTAPD sed -i "s~^ssid=$CURRENT_SSID~ssid=$ONLINE_SSID~" $HOSTAPD
HUP_NEEDED=1 # HUP here would be to early for dualband devices HUP_NEEDED=1 # HUP here would be to early for dualband devices
else else
echo "There is something wrong, did not find SSID $ONLINE_SSID or $OFFLINE_SSID" logger -s -t "gluon-ssid-changer" -p 5 "could not set to online state: did neither find SSID '$ONLINE_SSID' nor '$OFFLINE_SSID'. Please reboot"
fi fi
done done
elif [ "$CHECK" -eq 0 ]; then elif [ "$CHECK" -eq 0 ]; then
...@@ -56,11 +73,11 @@ elif [ "$CHECK" -eq 0 ]; then ...@@ -56,11 +73,11 @@ elif [ "$CHECK" -eq 0 ]; then
fi fi
CURRENT_SSID="$(grep "^ssid=$ONLINE_SSID" $HOSTAPD | cut -d"=" -f2)" CURRENT_SSID="$(grep "^ssid=$ONLINE_SSID" $HOSTAPD | cut -d"=" -f2)"
if [ "$CURRENT_SSID" = "$ONLINE_SSID" ]; then if [ "$CURRENT_SSID" = "$ONLINE_SSID" ]; then
logger -s -t "gluon-offline-ssid" -p 5 "SSID is $CURRENT_SSID, change to $OFFLINE_SSID" logger -s -t "gluon-ssid-changer" -p 5 "SSID is $CURRENT_SSID, change to $OFFLINE_SSID"
sed -i "s~^ssid=$ONLINE_SSID~ssid=$OFFLINE_SSID~" $HOSTAPD sed -i "s~^ssid=$ONLINE_SSID~ssid=$OFFLINE_SSID~" $HOSTAPD
HUP_NEEDED=1 HUP_NEEDED=1
else else
echo "There is something wrong: did neither find SSID '$ONLINE_SSID' nor '$OFFLINE_SSID'" logger -s -t "gluon-ssid-changer" -p 5 "could not set to offline state: did neither find SSID '$ONLINE_SSID' nor '$OFFLINE_SSID'. Please reboot"
fi fi
done done
fi fi
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment