[LON-CAPA-cvs] cvs: loncom / CrGenerate.pl
foxr
lon-capa-cvs@mail.lon-capa.org
Tue, 29 Jun 2004 10:47:46 -0000
foxr Tue Jun 29 06:47:46 2004 EDT
Added files:
/loncom CrGenerate.pl
Log:
Major flow of control of the script to:
- Generate certificate requests.
- Install the host key
- Email the certificate request to the loncapa certificate administrator.
Index: loncom/CrGenerate.pl
+++ loncom/CrGenerate.pl
#!/usr/bin/perl
# The LearningOnline Network
# CrGenerate - Generate a loncapa certificate request.
#
# $Id: CrGenerate.pl,v 1.1 2004/06/29 10:47:46 foxr Exp $
#
# Copyright Michigan State University Board of Trustees
#
# This file is part of the LearningOnline Network with CAPA (LON-CAPA).
#
# LON-CAPA 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; either version 2 of the License, or
# (at your option) any later version.
#
# LON-CAPA 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 LON-CAPA; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#
# /home/httpd/html/adm/gpl.txt
#
# http://www.lon-capa.org/
#
#
# This script:
# 1. Generates a private host key and certificate request/
# 2. Decodes the private host key
# 3. Installs the private host key with appropriate permissions
# in the appropriate directory (sorry to be vague about this, but
# the installation directory is determined by external configuration
# info).
# 4. Constructs an email to the loncapa cluster administrator
# consisting of a generic heading and the certificate request as a MIME
# attachment.
# 5. Sends the email and
# 6. Cleans up after itself by removing any temp files generated.
#
#
# Import section:
use strict;
use MIME::Entity;
use Mail::Mailer;
use LONCAPA::Configuration;
# Global variable declarations:
$SSLCommand; # Full path to openssl command.
$CertificateDirectory; # LONCAPA Certificate directory.
$KeyFilename; # Key filename (within CertificateDirectory).
$Passphrase="loncapawhatever"; # Initial passphrase for keyfile
$RequestEmail; # Email address of loncapa cert admin.
# Debug/log support:
#
$DEBUG = 1; # 1 for on, 0 for off.
# Send debugging to stderr.
# Parameters:
# msg - Message to send to stderr.
# Implicit Inputs:
# $DEBUG - message is only written if this is true.
#
sub Debug {
$msg = shift;
if($DEBUG) {
print STDERR "$msg\n";
}
}
sub ReadConfig {}
sub GenerateRequest {}
sub InstallKey {}
sub MailRequest {}
sub Cleanup {}
# Entry point:
Debug("Starting program");
ReadConfig; # Read loncapa apache config file.
GenerateRequest; # Generate certificate request.
InstallKey; # Install the user's key.
MailRequest; # Mail certificate request to loncapa
Cleanup; # Cleanup temp files created.
Debug("Done");