version 1.4, 2003/08/05 12:52:23
|
version 1.9, 2006/03/19 22:34:30
|
Line 31 package Apache::lonerrorhandler;
|
Line 31 package Apache::lonerrorhandler;
|
use strict; |
use strict; |
use Apache::Constants qw(:common); |
use Apache::Constants qw(:common); |
use Apache::loncommon; |
use Apache::loncommon; |
|
use Apache::lonnet; |
|
use Apache::lonmsg; |
|
|
sub handler { |
sub handler { |
my $r = shift; |
my $r = shift; |
$r->content_type('text/html'); |
&Apache::loncommon::content_type($r,'text/html'); |
$r->send_http_header; |
$r->send_http_header; |
return OK if $r->header_only; |
return OK if $r->header_only; |
|
|
|
&Apache::loncommon::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!</body></html>'); |
|
} else { |
# ------------------------------------------------------------- Get environment |
# ------------------------------------------------------------- Get environment |
my $envkey; |
my $envkey; |
my $env=''; |
my $env=''; |
|
my $syllabus=''; |
foreach $envkey (sort keys %ENV) { |
|
$env.="$envkey: $ENV{$envkey}\n"; |
foreach $envkey (sort(keys(%env))) { |
} |
$env.="$envkey: $env{$envkey}\n"; |
|
} |
$env=~s/\"/\'\'/g; |
foreach $envkey (sort(keys(%ENV))) { |
my $recipients=$r->dir_config('lonAdmEMail').','. |
$env.="$envkey: $ENV{$envkey}\n"; |
$r->dir_config('lonSysEMail'); |
if ($envkey=~/REDIRECT\_(REQUEST_URI|SCRIPT|ERROR)/) { |
|
$syllabus.="\n$1:\n$ENV{$envkey}"; |
my $version=$r->dir_config('lonVersion'); |
} |
|
} |
my $req=$r->as_string(); |
|
$req=~s/\"/\'\'/g; |
$env=~s/\"/\'\'/g; |
|
|
my $bodytag=&Apache::loncommon::bodytag('Could Not Process Request'); |
my $version=$r->dir_config('lonVersion'); |
# --------------------------------------------------- Print login screen header |
|
$r->print(<<ENDDOCUMENT); |
# ----------------------------------------------------------- Print error form |
<html> |
$r->print(<<ENDDOCUMENT); |
<head> |
|
<title>The LearningOnline Network with CAPA</title> |
|
</head> |
|
$bodytag |
|
<h2>Somewhere something went wrong - please help us to find out what.</h2> |
<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 |
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 |
with internal debugging information, will be emailed to the system and server |
administrators. |
administrators. |
<form action="mailto:$recipients" method=get enctype="text/plain"> |
<form action="/adm/errorhandler" method="post"> |
<input type=submit value="Send Information"> |
<input type="submit" value="Send Information"> |
<h3>Please describe what you did just before this screen came up</h3> |
<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> |
</textarea> |
<h3>Is this problem reproducible?</h3> |
<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> |
<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> |
</textarea> |
<input type=hidden name=version value="$version"> |
<input type="hidden" name="version" value="$version" /> |
<input type=hidden name=environment value="$env"><p> |
<input type="hidden" name="environment" value="$env" /> |
<input type=submit value="Send Information"> |
<input type="hidden" name="syllabus" value="$syllabus" /> |
|
<input type="hidden" name="sendinfo" value="1" /> |
|
<p> |
|
<input type="submit" value="Send Information"> |
|
</p> |
</form> |
</form> |
<h1>Thank you for your help!</h1> |
<h1>Thank you for your help!</h1> |
</body> |
<font size="-1"> |
</html> |
<pre> |
|
Internal info: |
|
$syllabus |
|
</pre> |
|
</font> |
ENDDOCUMENT |
ENDDOCUMENT |
|
$r->print(&Apache::loncommon::end_page()); |
# -------------------------- Better terminate this in case something was sticky |
# -------------------------- Better terminate this in case something was sticky |
$r->child_terminate(); |
|
|
|
|
$r->child_terminate(); |
|
} |
return OK; |
return OK; |
} |
} |
|
|