]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - make/opensslcert.pm
Merge pull request #1157 from SaberUK/insp20+fix-cron-restart
[user/henk/code/inspircd.git] / make / opensslcert.pm
index cb94869f9974d18b6c692d7a4635aa9d5891f622..20da704f72434f3d8230c8489f7990a1bbfc372f 100644 (file)
@@ -1 +1,66 @@
-package make::opensslcert;\r\ruse Exporter 'import';\ruse make::configure;\r@EXPORT = qw(make_openssl_cert);\r\r\rsub make_openssl_cert()\r{\r  open (FH, ">openssl.template");\r        my $org = promptstring_s("Please enter the organization name", "My IRC Network");\r      my $unit = promptstring_s("Please enter the unit Name", "Server Admins");\r      my $country = promptstring_s("Please enter your country (two letter code)", "US");\r     my $state = promptstring_s("Please enter your state or locality name", "Alaska");\r      my $city = promptstring_s("Please enter your city", "Factory Town");\r   my $email = promptstring_s("Please enter a contact email address", "oompa\@loompa.com");\r       my $commonname = promptstring_s("Please enter the common name (domain name) of the irc server", "example.inspircd.org");\r       print FH <<__END__;\r$country\r$state\r$city\r$org\r$unit\r$commonname\r$email\r__END__\rclose(FH);\r\rmy $time = promptstring_s("Please enter the number of days that this certificate is valid for","365");\r     \rsystem("cat openssl.template | openssl req -x509 -nodes -newkey rsa:1024 -keyout key.pem -out cert.pem -days $time 2>/dev/null");\rsystem("openssl dhparam -out dhparams.pem 1024");\runlink("openssl.template");\r}\r\r1;\r
\ No newline at end of file
+#
+# InspIRCd -- Internet Relay Chat Daemon
+#
+#   Copyright (C) 2007 Dennis Friis <peavey@inspircd.org>
+#   Copyright (C) 2007 Craig Edwards <craigedwards@brainbox.cc>
+#
+# This file is part of InspIRCd.  InspIRCd is free software: you can
+# redistribute it and/or modify it under the terms of the GNU General Public
+# License as published by the Free Software Foundation, version 2.
+#
+# This program is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
+# FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
+# details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program.  If not, see <http://www.gnu.org/licenses/>.
+#
+
+
+package make::opensslcert;
+
+require 5.8.0;
+
+use strict;
+use warnings FATAL => qw(all);
+
+use Exporter 'import';
+use make::configure;
+our @EXPORT = qw(make_openssl_cert);
+
+
+sub make_openssl_cert()
+{
+       if (system 'openssl version >/dev/null 2>&1')
+       {
+               print "\e[1;31mCertificate generation failed:\e[0m unable to find 'openssl' in the PATH!\n";
+               return;
+       }
+       open (FH, ">openssl.template");
+       my $commonname = promptstring_s('What is the hostname of your server?', 'irc.example.com');
+       my $email = promptstring_s('What email address can you be contacted at?', 'example@example.com');
+       my $unit = promptstring_s('What is the name of your unit?', 'Server Admins');
+       my $org = promptstring_s('What is the name of your organization?', 'Example IRC Network');
+       my $city = promptstring_s('What city are you located in?', 'Example City');
+       my $state = promptstring_s('What state are you located in?', 'Example State');
+       my $country = promptstring_s('What is the ISO 3166-1 code for the country you are located in?', 'XZ');
+       my $time = promptstring_s('How many days do you want your certificate to be valid for?', '365');
+       my $use_1024 = promptstring_s('Do you want to generate less secure dhparams which are compatible with old versions of Java?', 'n');
+       print FH <<__END__;
+$country
+$state
+$city
+$org
+$unit
+$commonname
+$email
+__END__
+close(FH);
+my $dhbits = $use_1024 =~ /^(1|on|true|yes|y)$/ ? 1024 : 2048;
+system("cat openssl.template | openssl req -x509 -nodes -newkey rsa:2048 -keyout key.pem -out cert.pem -days $time 2>/dev/null");
+system("openssl dhparam -out dhparams.pem $dhbits");
+unlink("openssl.template");
+}
+
+1;