mirror of
git://projects.qi-hardware.com/openwrt-xburst.git
synced 2025-01-12 11:00:15 +02:00
[package] wpa_supplicant: add WEP key handling to conform with documented behaviour in mac80211.sh (#6493)
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@19119 3c298f89-4303-0410-b956-a3cf2f4a3e73
This commit is contained in:
parent
505a102cb3
commit
65c8a9c39a
@ -12,12 +12,33 @@ wpa_supplicant_setup_vif() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
case "$enc" in
|
case "$enc" in
|
||||||
|
*wep*)
|
||||||
|
key_mgmt='NONE'
|
||||||
|
config_get key "$vif" key
|
||||||
|
key="${key:-1}"
|
||||||
|
case "$key" in
|
||||||
|
[1234])
|
||||||
|
for idx in 1 2 3 4; do
|
||||||
|
local zidx
|
||||||
|
zidx=$(($idx - 1))
|
||||||
|
config_get ckey "$vif" "key${idx}"
|
||||||
|
if [ -n "$ckey" ] && \
|
||||||
|
append "wep_key${zidx}" "wep_key${zidx}=$(prepare_key_wep "$ckey")"
|
||||||
|
done
|
||||||
|
wep_tx_keyidx="wep_tx_keyidx=$((key - 1))"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
wep_key0="wep_key0=$(prepare_key_wep "$key")"
|
||||||
|
wep_tx_keyidx="wep_tx_keyidx=0"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
;;
|
||||||
*psk*)
|
*psk*)
|
||||||
key_mgmt='WPA-PSK'
|
key_mgmt='WPA-PSK'
|
||||||
config_get_bool usepassphrase "$vif" passphrase 1
|
config_get_bool usepassphrase "$vif" passphrase 1
|
||||||
case "$enc" in
|
case "$enc" in
|
||||||
*psk2*)
|
*psk2*)
|
||||||
proto='RSN'
|
proto='proto=RSN'
|
||||||
if [ "$usepassphrase" = "1" ]; then
|
if [ "$usepassphrase" = "1" ]; then
|
||||||
passphrase="psk=\"${key}\""
|
passphrase="psk=\"${key}\""
|
||||||
else
|
else
|
||||||
@ -25,7 +46,7 @@ wpa_supplicant_setup_vif() {
|
|||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
*psk*)
|
*psk*)
|
||||||
proto='WPA'
|
proto='proto=WPA'
|
||||||
if [ "$usepassphrase" = "1" ]; then
|
if [ "$usepassphrase" = "1" ]; then
|
||||||
passphrase="psk=\"${key}\""
|
passphrase="psk=\"${key}\""
|
||||||
else
|
else
|
||||||
@ -35,7 +56,7 @@ wpa_supplicant_setup_vif() {
|
|||||||
esac
|
esac
|
||||||
;;
|
;;
|
||||||
*wpa*|*8021x*)
|
*wpa*|*8021x*)
|
||||||
proto='WPA2'
|
proto='proto=WPA2'
|
||||||
key_mgmt='WPA-EAP'
|
key_mgmt='WPA-EAP'
|
||||||
config_get ca_cert "$vif" ca_cert
|
config_get ca_cert "$vif" ca_cert
|
||||||
ca_cert=${ca_cert:+"ca_cert=\"$ca_cert\""}
|
ca_cert=${ca_cert:+"ca_cert=\"$ca_cert\""}
|
||||||
@ -72,7 +93,7 @@ network={
|
|||||||
ssid="$ssid"
|
ssid="$ssid"
|
||||||
$bssid
|
$bssid
|
||||||
key_mgmt=$key_mgmt
|
key_mgmt=$key_mgmt
|
||||||
proto=$proto
|
$proto
|
||||||
$passphrase
|
$passphrase
|
||||||
$pairwise
|
$pairwise
|
||||||
$group
|
$group
|
||||||
@ -83,7 +104,13 @@ network={
|
|||||||
$phase2
|
$phase2
|
||||||
$identity
|
$identity
|
||||||
$password
|
$password
|
||||||
|
$wep_key0
|
||||||
|
$wep_key1
|
||||||
|
$wep_key2
|
||||||
|
$wep_key3
|
||||||
|
$wep_tx_keyidx
|
||||||
}
|
}
|
||||||
EOF
|
EOF
|
||||||
[ -z "$proto" ] || wpa_supplicant ${bridge:+ -b $bridge} -B -P "/var/run/wifi-${ifname}.pid" -D ${driver:-wext} -i "$ifname" -c /var/run/wpa_supplicant-$ifname.conf
|
[ -z "$proto" -a "$key_mgmt" != "NONE" ] ||
|
||||||
|
wpa_supplicant ${bridge:+ -b $bridge} -B -P "/var/run/wifi-${ifname}.pid" -D ${driver:-wext} -i "$ifname" -c /var/run/wpa_supplicant-$ifname.conf
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user