Current File : //usr/share/webmin/iscsi-target/save_auth.cgi |
#!/usr/bin/perl
# Save global authentication options
use strict;
use warnings;
no warnings 'redefine';
no warnings 'uninitialized';
require './iscsi-target-lib.pl';
our (%text, %in, %config);
&ReadParse();
&error_setup($text{'auth_err'});
&lock_file($config{'config_file'});
my $pconf = &get_iscsi_config_parent();
my $conf = $pconf->{'members'};
# Validate incoming user(s)
my @iusers;
if (!$in{"iuser_def"}) {
for(my $i=0; defined($in{"uname_$i"}); $i++) {
next if (!$in{"uname_$i"});
$in{"uname_$i"} =~ /^\S+$/ ||
&error(&text('target_eiuser', $i+1));
$in{"upass_$i"} =~ /^\S+$/ ||
&error(&text('target_eipass', $i+1));
push(@iusers, $in{"uname_$i"}." ".$in{"upass_$i"});
}
@iusers || &error($text{'target_eiusernone'});
}
&save_directive($conf, $pconf, "IncomingUser", \@iusers);
# Validate outgoing user
if ($in{"ouser_def"}) {
&save_directive($conf, $pconf, "OutgoingUser", [ ]);
}
else {
$in{"ouser"} =~ /^\S+$/ || &error($text{'target_eouser'});
$in{"opass"} =~ /^\S+$/ || &error($text{'target_eopass'});
&save_directive($conf, $pconf, "OutgoingUser",
[ $in{"ouser"}." ".$in{"opass"} ]);
}
&flush_file_lines($config{'config_file'});
&unlock_file($config{'config_file'});
&webmin_log('auth');
&redirect("");