blob: e778627b05a3750210b8d1e39d527a3b5ae435b2 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
|
# Uses wireless_tools, to check for association to a network.
# wep_check interface [timeout]
wep_check()
{
local INTERFACE="$1" TIMEOUT="${2:-15}" timeout=0 bssid
while [[ $timeout -lt "$TIMEOUT" ]]; do
bssid=$(iwgetid "$INTERFACE" -ra)
[[ -n "$bssid" && "$bssid" != "00:00:00:00:00:00" ]] && return 0
sleep 1
let timeout++
done
return 1
}
# Check if a particular network is within range
# find_essid interface essid connection (we treat ESSID as regexp when CONNECTION=wireless-dbus)
find_essid() {
local INTERFACE="$1" ESSID="$2" CONNECTION="$3" RETRIES=10 try=0 res scanned
while [[ "$try" -lt "$RETRIES" ]]; do
sleep 0.5
let try++
if [[ "$CONNECTION" == wireless-dbus ]]; then
# JP: ESSID is a regexp
found=$(
res=$(iwlist "$INTERFACE" scan 2>/dev/null)
[[ -z "$res" ]] && exit 1
# if results were non-null, process them and exit 0
echo "$res" | sed -nr 's/^\s+ESSID:"([^"]*)"$/\1/p' | egrep -xm1 "$ESSID"
)
else
found=$(
res=$(iwlist "$INTERFACE" scan 2>/dev/null)
[[ -z "$res" ]] && exit 1
# if results were non-null, process them and exit 0
echo "$res" | sed -nr 's/^\s+ESSID:"([^"]*)"$/\1/p' | fgrep -xm1 "$ESSID"
)
fi && {
scanned=1
report_debug find_essid "\"$found\""
# we only bother with at most 5 successful scans
if (( try < RETRIES-4 )); then try=$((RETRIES-4)); fi
}
if [[ -n "$found" ]]; then
echo "$found" # JP: echo literal ESSID
return 0 # network found
fi
done
if [[ "$scanned" -ne 1 ]]; then
report_debug find_essid "unable to scan"
fi
return 1
}
# Check if a particular network is within range
# find_ap interface ap
find_ap() {
local INTERFACE="$1" ap=$(echo "$2" | tr 'abcdef' 'ABCDEF') RETRIES=10 try=0 res scanned
while [[ "$try" -lt "$RETRIES" ]]; do
sleep 0.5
let try++
found=$(
res=$(iwlist "$INTERFACE" scan 2> /dev/null)
[[ -z "$res" ]] && exit 1
# if results were non-null, process them and exit 0
echo "$res" | sed -nr '/^\s+Cell .. - Address: ([[:xdigit:]:]+)$/ { s//\1/; N; s/(.*)\n\s+ESSID:"([^"]*)"$/\1\t\2/p }' \
| egrep -m1 "^$ap\t"
) && {
scanned=1
report_debug find_ap "\"$found\""
# we only bother with at most 5 successful scans
if (( try < RETRIES-4 )); then try=$((RETRIES-4)); fi
}
if [[ -n "$found" ]]; then
echo "$found" | cut -f2 # JP: echo literal ESSID
return 0
fi
done
if [[ "$scanned" -ne 1 ]]; then
report_debug find_ap "unable to scan"
fi
return 1
}
# Return a filename containing a list of network APs and ESSIDs found (sorted by decreasing signal strength)
# list_networks interface
list_networks()
{
local INTERFACE="$1" essids try=0 RETRIES=20 res scanned
# temp file used, as keeping ESSID's with spaces in their name in arrays
# is hard, obscure and kinda nasty. This is simpler and clearer.
[[ -z "$INTERFACE" ]] && return 1
essids=$(mktemp --tmpdir essid.XXXXXXXX)
wpa_supplicant -B -i$INTERFACE -Dwext -C/var/run/wpa_supplicant -P/var/run/wpa_supplicant.pid
wpa_cli -i "$INTERFACE" scan &> /dev/null
sleep 2.5
wpa_cli -i "$INTERFACE" scan_results |
grep -v "^Selected" |
grep -v "^bssid" |
sort -rn -k3 |
sort -u -k5 |
sort -rn -k3 |
cut -f1,5 > "$essids"
# Fields are tab delimited
# Remove extraneous output from wpa_cli
# Sort by strength
# Remove duplicates
# Re-sort by strength as the removal disorders the list
# Cut to the AP/essid fields only
kill $(cat /var/run/wpa_supplicant.pid)
# File of 0 length, ie. no ssid's.
if [[ ! -s "$essids" ]]; then
rm -f "$essids"
return 1
fi
echo $essids
return 0
}
# vim: set ts=4 et sw=4 ft=sh:
|