--- loncom/interface/lonerrorhandler.pm 2001/12/19 17:17:46 1.3 +++ loncom/interface/lonerrorhandler.pm 2006/04/13 19:07:11 1.11 @@ -1,7 +1,7 @@ # The LearningOnline Network # Internal Server Error Handler # -# $Id: lonerrorhandler.pm,v 1.3 2001/12/19 17:17:46 albertel Exp $ +# $Id: lonerrorhandler.pm,v 1.11 2006/04/13 19:07:11 albertel Exp $ # # Copyright Michigan State University Board of Trustees # @@ -25,72 +25,114 @@ # # http://www.lon-capa.org/ # -# (Login Screen -# 5/21/99,5/22,5/25,5/26,5/31,6/2,6/10,7/12,7/14, -# 1/14/00,5/29,5/30,6/1,6/29,7/1,11/9 Gerd Kortemeyer) -# -# 3/1/1 Gerd Kortemeyer -# + package Apache::lonerrorhandler; use strict; use Apache::Constants qw(:common); +use Apache::loncommon(); +use Apache::lonnet; +use Apache::lonmsg(); +use Apache::lonacc(); sub handler { my $r = shift; - $r->content_type('text/html'); + &Apache::loncommon::content_type($r,'text/html'); $r->send_http_header; return OK if $r->header_only; + &Apache::lonacc::get_posted_cgi($r); + + my $title = $env{'form.sendinfo'} ? 'Sending Error Report' + : 'Could Not Process Request'; + $r->print(&Apache::loncommon::start_page($title)); + + if ($env{'form.sendinfo'}) { + my $repro='no'; +# ------------------------------------------------------------------ Mail stuff + if ($env{'form.reproducible'}) { + $repro='yes'; + } + my $message=(<<ENDMESSAGE); +LON-CAPA Error Message +Reproducible: $repro +Version: $env{'form.version'} +Syllabus: +$env{'form.syllabus'} + +Prior Action: +$env{'form.prioraction'} + +Guesses: +$env{'form.guesses'} + +Environment: +$env{'form.environment'} +ENDMESSAGE + my $recipients=$r->dir_config('lonAdmEMail').','. + $r->dir_config('lonSysEMail'); + + &Apache::lonmsg::sendemail($recipients,'ERROR REPORT',$message); + $r->print('<h2>Report submitted</h2>Thank you!'); + } else { # ------------------------------------------------------------- Get environment - my $envkey; - my $env=''; - - foreach $envkey (sort keys %ENV) { - $env.="$envkey: $ENV{$envkey}\n"; - } - - $env=~s/\"/\'\'/g; - my $recipients=$r->dir_config('lonAdmEMail').','. - $r->dir_config('lonSysEMail'); - - my $req=$r->as_string(); - $req=~s/\"/\'\'/g; - -# --------------------------------------------------- Print login screen header - $r->print(<<ENDDOCUMENT); -<html> -<head> -<title>The LearningOnline Network with CAPA</title> -</head> -<body bgcolor="#FFFFFF"> -<img src="/adm/lonKaputt/lonlogo_broken.gif" align=left> -<h1>Sorry!</h1> + my $envkey; + my $env=''; + my $syllabus=''; + + foreach $envkey (sort(keys(%env))) { + $env.="$envkey: $env{$envkey}\n"; + } + foreach $envkey (sort(keys(%ENV))) { + $env.="$envkey: $ENV{$envkey}\n"; + if ($envkey=~/REDIRECT\_(REQUEST_URI|SCRIPT|ERROR)/) { + $syllabus.="\n$1:\n$ENV{$envkey}"; + } + } + + $env=~s/\"/\'\'/g; + + my $version=$r->dir_config('lonVersion'); + +# ----------------------------------------------------------- Print error form + $r->print(<<ENDDOCUMENT); <h2>Somewhere something went wrong - please help us to find out what.</h2> Please take a moment to fill out the form below. Your information, together with internal debugging information, will be emailed to the system and server administrators. -<form action="mailto:$recipients" method=get enctype="text/plain"> -<input type=submit value="Send Information"> +<form action="/adm/errorhandler" method="post"> +<input type="submit" value="Send Information"> <h3>Please describe what you did just before this screen came up</h3> -<input type=hidden name=req value="$req"> -<textarea name=prioraction cols=50 rows=5> +<textarea name="prioraction" cols="50" rows="5"> </textarea> <h3>Is this problem reproducible?</h3> -<input type=checkbox name=reproducible value=yes> Yes! +<label> +<input type="checkbox" name="reproducible" value="yes"> Yes! +</label> <h3>Do you have any guesses why this might have happened?</h3> -<textarea name=guesses cols=50 rows=5> +<textarea name="guesses" cols="50" rows="5"> </textarea> -<input type=hidden name=environment value="$env"><p> -<input type=submit value="Send Information"> +<input type="hidden" name="version" value="$version" /> +<input type="hidden" name="environment" value="$env" /> +<input type="hidden" name="syllabus" value="$syllabus" /> +<input type="hidden" name="sendinfo" value="1" /> +<p> +<input type="submit" value="Send Information"> +</p> </form> <h1>Thank you for your help!</h1> -</body> -</html> +<font size="-1"> +<pre> +Internal info: +$syllabus +</pre> +</font> ENDDOCUMENT # -------------------------- Better terminate this in case something was sticky - $r->child_terminate(); + $r->child_terminate(); + } + $r->print(&Apache::loncommon::end_page()); return OK; }