--- loncom/interface/lonerrorhandler.pm 2005/04/07 06:56:23 1.7 +++ loncom/interface/lonerrorhandler.pm 2005/07/08 21:21:56 1.8 @@ -1,7 +1,7 @@ # The LearningOnline Network # Internal Server Error Handler # -# $Id: lonerrorhandler.pm,v 1.7 2005/04/07 06:56:23 albertel Exp $ +# $Id: lonerrorhandler.pm,v 1.8 2005/07/08 21:21:56 www Exp $ # # Copyright Michigan State University Board of Trustees # @@ -32,6 +32,7 @@ use strict; use Apache::Constants qw(:common); use Apache::loncommon; use Apache::lonnet; +use Apache::lonmsg; sub handler { my $r = shift; @@ -39,61 +40,104 @@ sub handler { $r->send_http_header; return OK if $r->header_only; -# ------------------------------------------------------------- Get environment - my $envkey; - my $env=''; - - foreach $envkey (sort(keys(%env))) { - $env.="$envkey: $env{$envkey}\n"; - } - foreach $envkey (sort(keys(%ENV))) { - $env.="$envkey: $ENV{$envkey}\n"; - } - - $env=~s/\"/\'\'/g; - my $recipients=$r->dir_config('lonAdmEMail').','. - $r->dir_config('lonSysEMail'); - - my $version=$r->dir_config('lonVersion'); - - my $req=$r->as_string(); - $req=~s/\"/\'\'/g; + &Apache::loncommon::get_posted_cgi($r); my $html=&Apache::lonxml::xmlbegin(); - my $bodytag=&Apache::loncommon::bodytag('Could Not Process Request'); -# --------------------------------------------------- Print login screen header - $r->print(<print(< The LearningOnline Network with CAPA $bodytag +ENDHEADER + + if ($env{'form.sendinfo'}) { + my $repro='no'; +# ------------------------------------------------------------------ Mail stuff + if ($env{'form.reproducible'}) { + $repro='yes'; + } + my $message=(<dir_config('lonAdmEMail').','. + $r->dir_config('lonSysEMail'); + + &Apache::lonmsg::sendemail($recipients,'ERROR REPORT',$message); + $r->print('

Report submitted

Thank you!'); + } else { +# ------------------------------------------------------------- Get environment + 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(<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. -
- + +

Please describe what you did just before this screen came up

- -

Is this problem reproducible?

- Yes! +

Do you have any guesses why this might have happened?

- - -

- + + + + +

+ +

Thank you for your help!

+ +
+Internal info:
+$syllabus
+
+
ENDDOCUMENT # -------------------------- Better terminate this in case something was sticky - $r->child_terminate(); - + $r->child_terminate(); + } return OK; }