version 1.9, 2006/03/19 22:34:30
|
version 1.14, 2007/12/04 04:43:21
|
Line 30 package Apache::lonerrorhandler;
|
Line 30 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::lonnet; |
use Apache::lonmsg; |
use Apache::lonmsg(); |
|
use Apache::lonacc(); |
|
use Apache::lonlocal; |
|
|
sub handler { |
sub handler { |
my $r = shift; |
my $r = shift; |
Line 40 sub handler {
|
Line 42 sub handler {
|
$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); |
&Apache::lonacc::get_posted_cgi($r); |
|
|
my $title = $env{'form.sendinfo'} ? 'Sending Error Report' |
my $title = $env{'form.sendinfo'} ? 'Sending Error Report' |
: 'Could Not Process Request'; |
: 'Could Not Process Request'; |
Line 52 sub handler {
|
Line 54 sub handler {
|
if ($env{'form.reproducible'}) { |
if ($env{'form.reproducible'}) { |
$repro='yes'; |
$repro='yes'; |
} |
} |
|
my %lt = &Apache::lonlocal::texthash ( |
|
msg => 'LON-CAPA Error Message', |
|
rep => 'Reproducible', |
|
ver => 'Version', |
|
syl => 'Syllabus', |
|
pri => 'Prior Action', |
|
gue => 'Guesses', |
|
env => 'Environment', |
|
); |
my $message=(<<ENDMESSAGE); |
my $message=(<<ENDMESSAGE); |
LON-CAPA Error Message |
$lt{'msg'} |
Reproducible: $repro |
$lt{'rep'}: $repro |
Version: $env{'form.version'} |
$lt{'ver'}: $env{'form.version'} |
Syllabus: |
$lt{'syl'}: |
$env{'form.syllabus'} |
$env{'form.syllabus'} |
|
|
Prior Action: |
$lt{'pri'}: |
$env{'form.prioraction'} |
$env{'form.prioraction'} |
|
|
Guesses: |
$lt{'gue'}: |
$env{'form.guesses'} |
$env{'form.guesses'} |
|
|
Environment: |
$lt{'env'}: |
$env{'form.environment'} |
$env{'form.environment'} |
ENDMESSAGE |
ENDMESSAGE |
my $recipients=$r->dir_config('lonAdmEMail').','. |
my $sysmail = $r->dir_config('lonSysEMail'); |
$r->dir_config('lonSysEMail'); |
my $defdom = $r->dir_config('lonDefDomain'); |
|
my $origmail = $r->dir_config('lonAdmEMail'); |
&Apache::lonmsg::sendemail($recipients,'ERROR REPORT',$message); |
my $recipients = &Apache::loncommon::build_recipient_list($sysmail, |
$r->print('<h2>Report submitted</h2>Thank you!</body></html>'); |
'errormail',$defdom,$origmail); |
|
if ($recipients ne '') { |
|
&Apache::lonmsg::sendemail($recipients,'ERROR REPORT',$message); |
|
$r->print('<h2>'.&mt('Report submitted').'</h2>'.&mt('Thank you!')); |
|
} else { |
|
$r->print('<h2>'.&mt('Warning: Report not submitted').'</h2>'. |
|
'<span class="LC_error">'.&mt("The administrators of |
|
the domain ($defdom) have not set any e-mail addresses |
|
for receipt of your error report.").'</span>'); |
|
} |
} else { |
} else { |
# ------------------------------------------------------------- Get environment |
# ------------------------------------------------------------- Get environment |
my $envkey; |
my $envkey; |
Line 94 ENDMESSAGE
|
Line 114 ENDMESSAGE
|
my $version=$r->dir_config('lonVersion'); |
my $version=$r->dir_config('lonVersion'); |
|
|
# ----------------------------------------------------------- Print error form |
# ----------------------------------------------------------- Print error form |
$r->print(<<ENDDOCUMENT); |
$r->print('<h2>'. |
<h2>Somewhere something went wrong - please help us to find out what.</h2> |
&mt('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 |
&mt('Please take a moment to fill out the form below.').' '.&mt('Your information, |
with internal debugging information, will be emailed to the system and server |
together with internal debugging information, will be emailed to the system and |
administrators. |
server administrators.').' |
<form action="/adm/errorhandler" method="post"> |
<form action="/adm/errorhandler" method="post"> |
<input type="submit" value="Send Information"> |
<input type="submit" value="'.&mt('Send Information').'" /> |
<h3>Please describe what you did just before this screen came up</h3> |
<h3>'.&mt('Please describe what you did just before this screen came up').'</h3> |
<textarea name="prioraction" cols="50" rows="5"> |
<textarea name="prioraction" cols="50" rows="5"> |
</textarea> |
</textarea> |
<h3>Is this problem reproducible?</h3> |
<h3>'.&mt('Is this problem reproducible?').'</h3> |
<label> |
<label> |
<input type="checkbox" name="reproducible" value="yes"> Yes! |
<input type="checkbox" name="reproducible" value="yes" /> '.&mt('Yes!').' |
</label> |
</label> |
<h3>Do you have any guesses why this might have happened?</h3> |
<h3>'.&mt('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" /> |
<input type="hidden" name="environment" value="'.$env.'" /> |
<input type="hidden" name="syllabus" value="$syllabus" /> |
<input type="hidden" name="syllabus" value="'.$syllabus.'" /> |
<input type="hidden" name="sendinfo" value="1" /> |
<input type="hidden" name="sendinfo" value="1" /> |
<p> |
<p> |
<input type="submit" value="Send Information"> |
<input type="submit" value="'.&mt('Send Information').'" /> |
</p> |
</p> |
</form> |
</form> |
<h1>Thank you for your help!</h1> |
<h1>'.&mt('Thank you for your help!').'</h1> |
<font size="-1"> |
<font size="-1"> |
<pre> |
<pre> |
Internal info: |
'.&mt('Internal info:'). |
$syllabus |
$syllabus.' |
</pre> |
</pre> |
</font> |
</font> |
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(); |
} |
} |
|
$r->print(&Apache::loncommon::end_page()); |
return OK; |
return OK; |
} |
} |
|
|
1; |
1; |
__END__ |
__END__ |