blob: 55cd51737014b969c4c6663a5c721f4534c7995a [file] [log] [blame]
#!/system/bin/sh
# HotSpot2.0 Release 2 action script - hs20-action.sh
# Supports the testing of wpa_supplicant and wlan driver
# support for HotSpot2.0 Release 2 on Android.
# It assumes that busybox is installed.
# Copyright (c) 2014, Qualcomm Atheros, Inc.
# All Rights Reserved.
# Licensed under the Clear BSD license. See README for more details.
BASEDIR=$(busybox dirname $0)
date >> $BASEDIR/Logs/hs20-action.log
echo "$*" >> $BASEDIR/Logs/hs20-action.log
if [ -e $BASEDIR/summary ]; then
echo "$*" >> $BASEDIR/summary
fi
IFNAME=$1
CMD=$2
echo "CMD=$CMD"
echo "CMD=$CMD" >> $BASEDIR/Logs/hs20-action.log
if [ -e /data/vendor/wifi/wpa/sockets/$IFNAME ]; then
IFACE_DIR=/data/vendor/wifi/wpa/sockets/
else
IFACE_DIR=/data/misc/wifi/sockets/
fi
run_eloop_cmd()
{
rm -f $BASEDIR/Logs/e_loop.log
echo "$1" > $BASEDIR/tag_file
# Read back the status of the command issued to e_loop
i=1
while [ ! -e $BASEDIR/Logs/e_loop.log ]
do
sleep 1
echo "Waiting $i second(s) for result..." >> $BASEDIR/Logs/hs20-action.log
if [ "$i" = "30" ] ; then
echo "Something went wrong with e_loop, exiting" >> $BASEDIR/Logs/hs20-action.log
exit 0
fi
i=$(($i + 1))
done
cmd=$(grep "ELOOP_CMD :" $BASEDIR/Logs/e_loop.log)
status=$(grep "ELOOP_CMD_STATUS :" $BASEDIR/Logs/e_loop.log)
echo "Eloop: $cmd ; $status" >> $BASEDIR/Logs/hs20-action.log
}
# generated cleanup url for system() command
cleanup_url()
{
sp_str="&"
mod_str="\\\\&"
URL="${1//$sp_str/$mod_str}"
}
if [ "$CMD" = "HS20-SUBSCRIPTION-REMEDIATION" ]; then
METHOD="$3"
cleanup_url "$4"
cd $BASEDIR
date >> Logs/hs20-osu-client.txt
echo "METHOD=$METHOD" >> Logs/hs20-osu-client.txt
echo "URL=$URL" >> Logs/hs20-osu-client.txt
if [ -e $BASEDIR/SP/wi-fi.org/pps.xml ]; then
run_eloop_cmd "nohup hs20-osu-client -w $IFACE_DIR -r hs20-osu-client.res -s summary -dddKt -f Logs/hs20-osu-client.txt sub_rem $URL SP/wi-fi.org/pps.xml SP/wi-fi.org/ca.pem >> Logs/browser.txt 2>&1 &"
else
if [ "$METHOD" = "0" ]; then
run_eloop_cmd "hs20-osu-client -w $IFACE_DIR -r hs20-osu-client.res -s summary -dddKt -f Logs/hs20-osu-client.txt oma_dm_sim_prov $URL osu-ca.pem"
else
run_eloop_cmd "hs20-osu-client -w $IFACE_DIR -r hs20-osu-client.res -s summary -dddKt -f Logs/hs20-osu-client.txt sim_prov $URL osu-ca.pem"
fi
fi
RES=$?
if [ -r hs20-osu-client.res ]; then
# notify-send "'cat hs20-osu-client.res'"
echo "hs20-osu-client: 'cat hs20-osu-client.res'" >> summary
elif [ "$RES" = "0" ]; then
echo "hs20-osu-client success" >> summary
else
echo "hs20-osu-client error" >> summary
fi
date >> Logs/hs20-osu-client.txt
fi
if [ "$CMD" = "CONNECTED" ]; then
if [ -e $BASEDIR/static-ip ]; then
if read ver addr mask gw < $BASEDIR/static-ip; then
echo "ver=$ver addr=$addr mask=$mask gw=$gw" >> $BASEDIR/Logs/hs20-action.log
if [ "$ver" = "6" ]; then
run_eloop_cmd "busybox sysctl -w net.ipv6.conf.$IFNAME.accept_dad=2 net.ipv6.conf.$IFNAME.dad_transmits=4 net.ipv6.conf.$IFNAME.autoconf=0 net.ipv6.conf.$IFNAME.ndisc_notify=1"
run_eloop_cmd "ip -6 addr del $addr/$mask dev $IFNAME"
run_eloop_cmd "busybox sysctl -w net.ipv6.conf.$IFNAME.disable_ipv6=0"
run_eloop_cmd "ip -6 addr add $addr/$mask dev $IFNAME"
sleep 4
run_eloop_cmd "ip addr show dev $IFNAME"
if [[ ! -z $(busybox grep -i $addr $BASEDIR/Logs/e_loop.log | grep -i dadfailed ) ]] ; then
echo "Duplicate IPv6 address $addr found on $IFNAME" >> $BASEDIR/Logs/hs20-action.log
#I need a version of the "notify-send" command that works in Android
#notify-send "Duplicate IPv6 address $addr found on $IFNAME"
exit 0
fi
if [[ -z $(grep -i $addr $BASEDIR/Logs/e_loop.log) ]] ; then
echo "Could not assign the requested IPv6 address $addr on $IFNAME" >> $BASEDIR/Logs/hs20-action.log
#notify-send "Could not assign the requested IPv6 address $addr on $IFNAME"
exit 0
fi
else
echo "Cleaning up and Sleeping 4 seconds..." >> $BASEDIR/Logs/hs20-action.log
rm -f $BASEDIR/Logs/e_loop.log
sleep 4
echo "Waking up..." >> $BASEDIR/Logs/hs20-action.log
run_eloop_cmd "busybox arping -c 4 -D -I $IFNAME -s 0.0.0.0 $addr"
#Search for the string "Unicast reply". Then you know you have a duplicate IP address...
if [[ ! -z $(grep Unicast $BASEDIR/Logs/e_loop.log) ]] ; then
echo "Duplicate IPv4 address $addr found on $IFNAME" >> $BASEDIR/Logs/hs20-action.log
#notify-send "Duplicate IPv4 address $addr found on $IFNAME"
exit 0
else
echo "Duplicate IPv4 address $addr NOT found on $IFNAME. Configuring address." >> $BASEDIR/Logs/hs20-action.log
fi
ifconfig $IFNAME $addr netmask $mask
run_eloop_cmd "busybox arping -c 4 -I $IFNAME -s $addr $addr"
if [ "$gw" != "N/A" ]; then
route add default gw "$gw"
ip ro re default via "$gw"
fi
fi
else
echo "Could not parse static-ip" >> $BASEDIR/Logs/hs20-action.log
fi
exit
fi
run_eloop_cmd "busybox sysctl -w net.ipv6.conf.$IFNAME.disable_ipv6=1 net.ipv6.conf.$IFNAME.autoconf=1 net.ipv6.conf.$IFNAME.accept_ra=1 net.ipv6.conf.$IFNAME.ndisc_notify=1 net.ipv6.conf.$IFNAME.disable_ipv6=0"
# Do not run dhcpcd from here as sigma_dut is already starting appropriate
# dhcp binary on CTRL-EVENT-CONNECTED.
fi
if [ "$CMD" = "ESS-DISASSOC-IMMINENT" ]; then
cd $BASEDIR
PMF="$3"
TIME_IN_MS="$4"
cleanup_url "$5"
count=1
if [ "$PMF" = "0" ]; then
echo "Disassociation imminent notification received without PMF - ignored" >> summary
exit 0
fi
echo "Disassociation imminent notification received - URL: $URL" >> summary
case "$URL" in
http*)
while [ $count -le 10 ]
do
sleep 1
addr=$(busybox ip addr show dev $IFNAME | grep "inet ")
if [ -n "$addr" ]; then
if ! busybox pidof hs20-osu-client; then
run_eloop_cmd "nohup hs20-osu-client -w $IFACE_DIR -f Logs/hs20-osu-client.txt browser $URL > Logs/browser.txt 2>&1 &"
fi
break
else
echo "waiting $count seconds"
fi
count=$(($count + 1))
done
;;
esac
# notify-send "Disassociation imminent"
fi
if [ "$CMD" = "HS20-DEAUTH-IMMINENT-NOTICE" ]; then
cd $BASEDIR
CODE="$3"
DELAY="$4"
cleanup_url "$5"
count=1
echo "HS 2.0 Deauthentication Imminent notification received - code=$CODE reauth_delay=$DELAY URL: $URL" >> summary
case "$URL" in
http*)
while [ $count -le 10 ]
do
sleep 1
addr=$(busybox ip addr show dev $IFNAME | grep "inet ")
if [ -n "$addr" ]; then
if ! busybox pidof hs20-osu-client; then
run_eloop_cmd "nohup hs20-osu-client -w $IFACE_DIR -f Logs/hs20-osu-client.txt browser $URL > Logs/browser.txt 2>&1 &"
fi
break
else
echo "waiting $count seconds"
fi
count=$(($count + 1))
done
;;
esac
# notify-send "HS 2.0 Deauthentication imminent"
fi
if [ "$CMD" = "HS20-T-C-ACCEPTANCE" ]; then
cd $BASEDIR
cleanup_url "$3"
count=1
echo "HS 2.0 Terms and Conditions notification received - URL: $URL" >> summary
case "$URL" in
http*)
while [ $count -le 10 ]
do
sleep 1
addr=$(busybox ip addr show dev $IFNAME | grep "inet ")
if [ -n "$addr" ]; then
if ! busybox pidof hs20-osu-client; then
run_eloop_cmd "nohup hs20-osu-client -w $IFACE_DIR -f Logs/hs20-osu-client.txt browser $URL > Logs/browser.txt 2>&1 &"
fi
break
else
echo "waiting $count seconds"
fi
count=$(($count + 1))
done
;;
esac
fi