#!/usr/local/bin/perl # newkey.cgi # Create a new SSL key for Usermin require './usermin-lib.pl'; $access{'ssl'} || &error($text{'acl_ecannot'}); &ReadParse(); # Validate inputs &error_setup($text{'newkey_err'}); $in{'commonName_def'} || $in{'commonName'} =~ /^[A-Za-z0-9\.\-\*]+$/ || &error($text{'newkey_ecn'}); $in{'newfile'} || &error($text{'newkey_efile'}); $in{'size_def'} || $in{'size'} =~ /^\d+$/ || &error($text{'newkey_esize'}); $in{'days'} =~ /^\d+$/ || &error($text{'newkey_edays'}); &ui_print_header(undef, $text{'newkey_title'}, ""); %aclconfig = &foreign_config('acl'); &foreign_require("acl", "acl-lib.pl"); if (!($cmd = &acl::get_ssleay())) { print "

",&text('newkey_ecmd', "$aclconfig{'ssleay'}", "$gconfig{'webprefix'}/config.cgi?acl"),"

\n"; &ui_print_footer("", $text{'index_return'}); exit; } # Create key file $ctemp = &transname(); $ktemp = &transname(); $outtemp = &transname(); $size = $in{'size_def'} ? $default_key_size : $in{'size'}; &open_execute_command(CA, "$cmd req -newkey rsa:$size -x509 -nodes -out $ctemp -keyout $ktemp -days $in{'days'} >$outtemp 2>&1", 0); print CA ($in{'countryName'} || "."),"\n"; print CA ($in{'stateOrProvinceName'} || "."),"\n"; print CA ($in{'cityName'} || "."),"\n"; print CA ($in{'organizationName'} || "."),"\n"; print CA ($in{'organizationalUnitName'} || "."),"\n"; print CA ($in{'commonName_def'} ? "*" : $in{'commonName'}),"\n"; print CA ($in{'emailAddress'} || "."),"\n"; close(CA); $rv = $?; $out = `cat $outtemp`; &unlink_file($outtemp); if (!-r $ctemp || !-r $ktemp || $?) { print "

$text{'newkey_essl'}
\n"; print "

$out
\n"; &ui_print_footer("", $text{'index_return'}); exit; } &lock_file($in{'newfile'}); &execute_command("cat $ctemp $ktemp 2>&1 >'$in{'newfile'}'", undef, \$catout); &unlink_file($ctemp); &unlink_file($ktemp); if ($catout || $?) { print "

$text{'newkey_ecat'}
\n"; print "

$catout
\n"; &ui_print_footer("", $text{'index_return'}); exit; } &set_ownership_permissions(0, 0, 0600, $in{'newfile'}); &unlock_file($in{'newfile'}); print "

$text{'newkey_ok'}
\n"; $key = `cat '$in{'newfile'}'`; print "

$key
"; &ui_print_footer("", $text{'index_return'}); # Configure usermin to use the new file if ($in{'usenew'}) { &lock_file($usermin_miniserv_config); &get_usermin_miniserv_config(\%miniserv); $miniserv{'keyfile'} = $in{'newfile'}; delete($miniserv{'certfile'}); &put_usermin_miniserv_config(\%miniserv); &unlock_file($usermin_miniserv_config); &restart_usermin_miniserv(); &webmin_log("newkey", undef, undef, \%in); }