--- loncom/interface/lonerrorhandler.pm 2006/09/02 20:49:20 1.12 +++ loncom/interface/lonerrorhandler.pm 2009/01/04 19:49:19 1.22 @@ -1,7 +1,7 @@ # The LearningOnline Network # Internal Server Error Handler # -# $Id: lonerrorhandler.pm,v 1.12 2006/09/02 20:49:20 albertel Exp $ +# $Id: lonerrorhandler.pm,v 1.22 2009/01/04 19:49:19 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -26,6 +26,8 @@ # http://www.lon-capa.org/ # + + package Apache::lonerrorhandler; use strict; @@ -34,6 +36,7 @@ use Apache::loncommon(); use Apache::lonnet; use Apache::lonmsg(); use Apache::lonacc(); +use Apache::lonlocal; sub handler { my $r = shift; @@ -42,7 +45,9 @@ sub handler { return OK if $r->header_only; &Apache::lonacc::get_posted_cgi($r); - + if (!$Apache::lonlocal::lh) { + &Apache::lonlocal::get_language_handle($r); + } my $title = $env{'form.sendinfo'} ? 'Sending Error Report' : 'Could Not Process Request'; $r->print(&Apache::loncommon::start_page($title)); @@ -53,33 +58,65 @@ sub handler { if ($env{'form.reproducible'}) { $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=(<dir_config('lonAdmEMail').','. - $r->dir_config('lonSysEMail'); - - &Apache::lonmsg::sendemail($recipients,'ERROR REPORT',$message); - $r->print('

Report submitted

Thank you!'); + my $sysmail = $r->dir_config('lonSysEMail'); + my $defdom = $r->dir_config('lonDefDomain'); + my $origmail = $r->dir_config('lonAdmEMail'); + my $recipients = &Apache::loncommon::build_recipient_list($sysmail, + 'errormail',$defdom,$origmail); + if ($recipients ne '') { + &Apache::lonmsg::sendemail($recipients,'ERROR REPORT',$message); + $r->print('

'.&mt('Report submitted').'

'.&mt('Thank you!')); + } else { + $r->print('

'.&mt('Warning: Report not submitted').'

'. + '' + .&mt('The administrators of the domain [_1] have not set' + .' any e-mail addresses for receipt of your error report.' + ,''.$defdom.'') + .''); + } } else { # ------------------------------------------------------------- Get environment my $envkey; my $env=''; my $syllabus=''; + foreach $envkey (keys(%env)) { + if ($envkey =~ /^form\.(.+)\.filename$/) { + my $item = $1; + if (exists($env{'form.'.$item.'.mimetype'})) { + if (exists($env{'form.'.$item})) { + my $size = (length($env{'form.'.$item}))/(1024.0 * 1024.0); + $env{'form.'.$item} = &mt('File (contents not shown) - size was [_1] MB.',sprintf("%.4f",$size)); + } + } + } + } + foreach $envkey (sort(keys(%env))) { $env.="$envkey: $env{$envkey}\n"; } @@ -95,46 +132,68 @@ ENDMESSAGE my $version=$r->dir_config('lonVersion'); # ----------------------------------------------------------- Print error form - $r->print(<Somewhere something went wrong - please help us to find out what. -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. + $r->print('

' +.&mt('Somewhere something went wrong') +.'

' +.'

'.&mt('Please help us to find out what.').'

' +.'

'.&mt('Please take a moment to fill out the form below.').' ' +.&mt('Your information, together with internal debugging information, ' + .'will be emailed to the system and server administrators.') +.'

- -

Please describe what you did just before this screen came up

+

'.&mt('Please describe what you did just before this screen came up').'

-

Is this problem reproducible?

+

'.&mt('Is this problem reproducible?').'

-

Do you have any guesses why this might have happened?

+

'.&mt('Do you have any guesses why this might have happened?').'

- - - + + +

- +

-

Thank you for your help!

- -
-Internal info:
-$syllabus
+

'.&mt('Thank you for your help!').'

+
+'.&mt('Internal info:'). +'
'.
+$syllabus.'
 
-
-ENDDOCUMENT +
+'); # -------------------------- Better terminate this in case something was sticky $r->child_terminate(); } $r->print(&Apache::loncommon::end_page()); return OK; -} +} 1; __END__ + + +=pod + +=head1 NAME + +Apache::lonerrorhandler.pm + +=head1 SYNOPSIS + +Handles errors. + +This is part of the LearningOnline Network with CAPA project +described at http://www.lon-capa.org. + +=head1 OVERVIEW + +None + +=cut