diff options
author | makefu <github@syntax-fehler.de> | 2013-05-26 11:20:17 +0200 |
---|---|---|
committer | makefu <github@syntax-fehler.de> | 2013-05-26 11:20:17 +0200 |
commit | 9bee05500405e0418876406d3dc64beca044667e (patch) | |
tree | dca4063b9026e4827142670715d783499b3ead71 /usr/lib | |
parent | 7b378cab9f8c201b2646d1112867225b47645e4e (diff) |
add wps, nonworking
Diffstat (limited to 'usr/lib')
-rw-r--r-- | usr/lib/autowifi/lib/wps | 44 |
1 files changed, 40 insertions, 4 deletions
diff --git a/usr/lib/autowifi/lib/wps b/usr/lib/autowifi/lib/wps index 0fdba0f5..7fd38a26 100644 --- a/usr/lib/autowifi/lib/wps +++ b/usr/lib/autowifi/lib/wps @@ -13,9 +13,45 @@ try_wps_pin(){ PIN="$7" [ "$ENC" == off ] && return 2 + WPA_CONF=/tmp/wpa.conf + WPA_LOG=/tmp/wpa.log + rm $WPA_LOG + #mkfifo $WPA_LOG + killall wpa_supplicant && sleep 1 + + cat > $WPA_CONF <<EOF +ctrl_interface=/var/run/wpa_supplicant +ctrl_interface_group=0 +update_config=1 +EOF + wpa_supplicant -Dwext -iwlan0 -c $WPA_CONF -f $WPA_LOG & + sleep 2 + if !(sudo wpa_cli wps_reg $MAC $PIN | grep -q OK) ;then + echo "wpa_cli wps_reg failed, bailing out!" + return 1 + fi + + WPA_PID=$! + #*"WPA: Key negotiation completed"*) + # association failed + # exit 1 ;; + if ( tail -f $WPA_LOG & echo "TAILPID: $!" )| while read line ; do + case "$line" in + TAILPID:*)IFS=" " set -- $line; TAILPID=$2;; + *CTRL-EVENT-DISCONNECTED*):;; + *CTRL-EVENT-CONNECTED*) + kill -HUP $TAILPID + exit 0;; + + esac + done ; then + echo "Connected!" + sed -n 's/[ \t]*psk="\(.*\)"$/\1/p' $WPA_CONF + return 0 + else + echo "failed!" + return 1 + fi + kill $WPA_PID - airmon-ng start ${WIFI:-wlan0} $CHANNEL - sleep 1 - reaver -i mon0 -b $MAC -vv -p "$PIN" -f -c $CHANNEL || : - airmon-ng stop mon0 } |