diff options
author | Eugeni Dodonov <eugeni@mandriva.org> | 2009-06-19 20:21:57 +0000 |
---|---|---|
committer | Eugeni Dodonov <eugeni@mandriva.org> | 2009-06-19 20:21:57 +0000 |
commit | 5bb0a6be631a0a76463d42e160d8c103326f660f (patch) | |
tree | 3c410774320554222016de3b49cd376d884913b0 | |
parent | b1fc187b0f4b90ef48b36cf355e3b1bccbf4f6fe (diff) | |
download | drakx-net-5bb0a6be631a0a76463d42e160d8c103326f660f.tar drakx-net-5bb0a6be631a0a76463d42e160d8c103326f660f.tar.gz drakx-net-5bb0a6be631a0a76463d42e160d8c103326f660f.tar.bz2 drakx-net-5bb0a6be631a0a76463d42e160d8c103326f660f.tar.xz drakx-net-5bb0a6be631a0a76463d42e160d8c103326f660f.zip |
Supporting extra wpa_supplicant variables with non-EAP networks.
-rw-r--r-- | lib/network/connection/wireless.pm | 49 |
1 files changed, 33 insertions, 16 deletions
diff --git a/lib/network/connection/wireless.pm b/lib/network/connection/wireless.pm index 5c1c396..522a8cd 100644 --- a/lib/network/connection/wireless.pm +++ b/lib/network/connection/wireless.pm @@ -570,8 +570,7 @@ the authentication server certificate. If this string is set, the server sertificate is only accepted if it contains this string in the subject. The subject string is in following format: /C=US/ST=CA/L=San Francisco/CN=Test AS/emailAddress=as\@example.com") }, - { label => N("EAP extra directives"), val => \$self->{access}{network}{eapextra}, advanced => 1, - disabled => sub { $self->{access}{network}{encryption} ne 'wpa-eap' }, + { label => N("EAP extra directives"), val => \$self->{access}{network}{extra}, advanced => 1, help => N("Here one can pass extra settings to wpa_supplicant The expected format is a string field=value pair. Multiple values maybe specified, separating each value with the # character. @@ -682,7 +681,7 @@ sub add_network_to_wpa_supplicant { if ($self->{access}{network}{encryption} eq 'wpa-eap') { wpa_supplicant_add_eap_network($self->{access}{network}); } else { - wpa_supplicant_add_network($self->{access}{network}{essid}, $self->{access}{network}{bssid}, $self->{access}{network}{encryption}, $self->{access}{network}{key}, $self->{access}{network}{force_ascii_key}, $self->{access}{network}{mode}); + wpa_supplicant_add_network($self->{access}{network}); } #- this should be handled by the monitoring daemon instead run_program::run('/usr/sbin/wpa_cli', 'reconfigure'); @@ -883,8 +882,17 @@ sub wpa_supplicant_get_driver { } sub wpa_supplicant_add_network { - my ($essid, $bssid, $enc_mode, $key, $force_ascii, $mode) = @_; + my ($ui_input) = @_; my $conf = wpa_supplicant_read_conf(); + + # use shorter variables + my $essid = $ui_input->{essid}; + my $bssid = $ui_input->{bssid}; + my $enc_mode = $ui_input->{encryption}; + my $key = $ui_input->{key}; + my $force_ascii = $ui_input->{force_ascii_key}; + my $mode = $ui_input->{mode}; + my $network = { ssid => qq("$essid"), scan_ssid => to_bool($bssid), #- hidden or non-broadcasted SSIDs @@ -906,6 +914,9 @@ sub wpa_supplicant_add_network { } } + #- handle extra variables as final overides + handle_extra_params($network, $ui_input->{extra}); + @$conf = difference2($conf, [ wpa_supplicant_find_similar($conf, $network) ]); push @$conf, $network; wpa_supplicant_write_conf($conf); @@ -1013,16 +1024,16 @@ sub wpa_supplicant_load_eap_settings { my $conf = wpa_supplicant_read_conf(); foreach my $old_net (@$conf) { if ($old_net->{ssid} eq $network->{essid} || $old_net->{ssid} eq $quoted_essid) { - $network->{eapextra} = ''; + $network->{extra} = ''; foreach my $eap_var (keys %eap_vars) { next if $eap_var eq 'ssid'; my $ui_var = join('_', "eap", $eap_var); if (defined $old_net->{$eap_var}) { if ($eap_vars{$eap_var} == 0) { - if ($network->{eapextra} eq "") { - $network->{eapextra} = "$eap_var=$old_net->{$eap_var}"; + if ($network->{extra} eq "") { + $network->{extra} = "$eap_var=$old_net->{$eap_var}"; } else { - $network->{eapextra} = join('#', $network->{eapextra}, "$eap_var=$old_net->{$eap_var}"); + $network->{extra} = join('#', $network->{extra}, "$eap_var=$old_net->{$eap_var}"); } } else { $network->{$ui_var} = $old_net->{$eap_var}; @@ -1040,6 +1051,17 @@ sub wpa_supplicant_load_eap_settings { } } +sub handle_extra_params { + my ($network, $extra) = @_; + #- handle extra variables as final overides + if (defined $extra && $extra ne "") { + #- FIXME: should split it on what the # sign? + foreach my $extra_var (split('#', $extra)) { + my ($key, $val) = split('=', $extra_var, 2); + $network->{$key} = $val; + } + } +} sub wpa_supplicant_add_eap_network { my ($ui_input) = @_; @@ -1075,14 +1097,9 @@ sub wpa_supplicant_add_eap_network { $network->{$eap_var} = $eap_vars{$eap_var} == 2 ? qq("$ui_input->{$key}") : $ui_input->{$key}; } } - #- handle eapextra as final overides - if (defined $ui_input->{eapextra} && $ui_input->{eapextra} ne "") { - #- FIXME: should split it on what the # sign? - foreach my $eap_var (split('#', $ui_input->{eapextra})) { - my ($key, $val) = split('=', $eap_var, 2); - $network->{$key} = $val; - } - } + #- handle extra variables as final overides + handle_extra_params($network, $ui_input->{extra}); + $network->{mode} = to_bool($ui_input->{mode} eq 'Ad-Hoc'); @$conf = difference2($conf, [ wpa_supplicant_find_similar($conf, $network) ]); |