Current File : //usr/share/webmin/pptp-server/save_secret.cgi |
#!/usr/bin/perl
# save_secret.cgi
# Update the secrets file to add or change a secret
require './pptp-server-lib.pl';
$access{'secrets'} || &error($text{'secrets_ecannot'});
&ReadParse();
&error_setup($text{'save_secret_esave'});
&lock_file($config{'pap_file'});
if (defined($in{'idx'})) {
$host = &get_ppp_hostname();
@seclist = grep { $_->{'server'} eq $host } &list_secrets();
%sec = %{$seclist[$in{'idx'}]};
if ($in{'delete'}) {
&delete_secret(\%sec);
&unlock_file($config{'pap_file'});
&webmin_log("delete", "secret", $sec{'client'}, \%sec);
&redirect("list_secrets.cgi");
exit;
}
}
if ($in{'client_def'}) { $sec{'client'} = ""; }
else { $sec{'client'} = $in{'client'}; }
$sec{'server'} = &get_ppp_hostname();
if ($in{'pass_mode'} == 0) { $sec{'secret'} = ""; }
elsif ($in{'pass_mode'} == 1) { $sec{'secret'} = "\@$in{'pass_file'}"; }
elsif ($in{'pass_mode'} == 3) { $sec{'secret'} = &opt_crypt($in{'pass_text'}); }
if ($in{'ips_mode'} == 0) { $sec{'ips'} = [ "*" ]; }
elsif ($in{'ips_mode'} == 1) { $sec{'ips'} = [ "-" ]; }
elsif ($in{'ips_mode'} == 2) {
@ips = split(/\s+/, $in{'ips'});
foreach $ip (@ips) {
if (!&to_ipaddress($ip)) {
&error(&text('save_secret_enoip', $ip));
}
}
$sec{'ips'} = \@ips;
}
if (defined($in{'idx'})) { &change_secret(\%sec); }
else { &create_secret(\%sec); }
&unlock_file($config{'pap_file'});
delete($sec{'secret'});
&webmin_log(defined($in{'idx'}) ? "modify" : "create",
"secret", $sec{'client'}, \%sec);
&redirect("list_secrets.cgi");