Handle hostnames with upper-case letters
[webmin.git] / dovecot / save_ssl.cgi
1 #!/usr/local/bin/perl
2 # Update SSL options
3
4 require './dovecot-lib.pl';
5 &ReadParse();
6 &error_setup($text{'ssl_err'});
7 $conf = &get_config();
8 &lock_dovecot_files($conf);
9
10 # Save SSL cert and key
11 $in{'cert_def'} || -r $in{'cert'} || $in{'cert'} =~ /^[<>\|]/ ||
12         &error($text{'ssl_ecert'});
13 if (&find_value("ssl_cert", $conf, 2)) {
14         $in{'cert'} = "<".$in{'cert'} if ($in{'cert'} =~ /^\//);
15         &save_directive($conf, "ssl_cert",
16                         $in{'cert_def'} ? undef : $in{'cert'});
17         }
18 else {
19         &save_directive($conf, "ssl_cert_file",
20                         $in{'cert_def'} ? undef : $in{'cert'});
21         }
22 $in{'key_def'} || -r $in{'key'} || $in{'key'} =~ /^[<>\|]/ ||
23         &error($text{'ssl_ekey'});
24 if (&find_value("ssl_key", $conf, 2)) {
25         $in{'key'} = "<".$in{'key'} if ($in{'key'} =~ /^\//);
26         &save_directive($conf, "ssl_key",
27                         $in{'key_def'} ? undef : $in{'key'});
28         }
29 else {
30         &save_directive($conf, "ssl_key_file",
31                         $in{'key_def'} ? undef : $in{'key'});
32         }
33
34 # Save SSL CA cert
35 $in{'ca_def'} || -r $in{'ca'} || $in{'ca'} =~ /^[<>\|]/ ||
36         &error($text{'ssl_eca'});
37 if (&find_value("ssl_ca", $conf, 2)) {
38         $in{'ca'} = "<".$in{'ca'} if ($in{'ca'} =~ /^\//);
39         &save_directive($conf, "ssl_ca",
40                         $in{'ca_def'} ? undef : $in{'ca'});
41         }
42 else {
43         &save_directive($conf, "ssl_ca_file",
44                         $in{'ca_def'} ? undef : $in{'ca'});
45         }
46
47 # Save SSL key password
48 $in{'pass_def'} || $in{'pass'} =~ /\S/ || &error($text{'ssl_epass'});
49 &save_directive($conf, "ssl_key_password",
50                 $in{'pass_def'} ? undef : $in{'pass'});
51
52 $in{'regen_def'} || $in{'regen'} =~ /^\d+$/ || &error($text{'ssl_eregen'});
53 &save_directive($conf, "ssl_parameters_regenerate",
54                 $in{'regen_def'} ? undef : $in{'regen'});
55
56 &save_directive($conf, "disable_plaintext_auth",
57                 $in{'plain'} ? $in{'plain'} : undef);
58
59 &flush_file_lines();
60 &unlock_dovecot_files($conf);
61 &webmin_log("ssl");
62 &redirect("");
63