File:  [LON-CAPA] / loncom / homework / lonhomework.pm
Revision 1.30: download - view: text, annotated - select for diffs
Wed Jan 10 21:49:43 2001 UTC (23 years, 3 months ago) by albertel
Branches: MAIN
CVS tags: HEAD
- need to check for EXT sending back a con_lost

    1: # The LON-CAPA Homework handler
    2: # Guy Albertelli
    3: # 11/30 Gerd Kortemeyer
    4: # 6/1 Gerd Kortemeyer
    5: 
    6: package Apache::lonhomework;
    7: use strict;
    8: use Apache::style;
    9: use Apache::lonxml;
   10: use Apache::lonnet;
   11: use Apache::inputtags;
   12: use Apache::structuretags;
   13: use Apache::response;
   14: use Apache::hint;
   15: use Apache::Constants qw(:common);
   16: 
   17: sub get_target {
   18:   if ( $ENV{'request.state'} eq "published") {
   19:     if ( defined $ENV{'form.submit'}) {
   20:       return ('grade', 'web');
   21:     } else {
   22:       return ('web');
   23:     }
   24:   } elsif ($ENV{'request.state'} eq "construct") {
   25:     if ( defined $ENV{'form.preview'}) {
   26:       if ( defined $ENV{'form.submit'}) {
   27: 	return ('grade', 'web');
   28:       } else {
   29: 	return ('web');
   30:       }
   31:     } else {
   32:       #return ('edit');
   33:       #edit is currently broken
   34:       return ('web');
   35:     }
   36:   }
   37:   return ();
   38: }
   39: 
   40: sub setup_vars {
   41:   my ($target) = @_;
   42:   return ';'
   43: #  return ';$external::target='.$target.';';
   44: }
   45: 
   46: sub send_header {
   47:   my ($request)= @_;
   48:   $request->print(&Apache::lontexconvert::header());
   49:   $ENV{'request.uri'}=$request->uri;
   50: #  $request->print('<form name='.$ENV{'form.request.prefix'}.'lonhomework method="POST" action="'.$request->uri.'">');
   51: }
   52: 
   53: sub send_footer {
   54:   my ($request)= @_;
   55: #  $request->print('</form>');
   56:   $request->print(&Apache::lontexconvert::footer());
   57: }
   58: 
   59: #@Apache::lonhomework::date_status=();
   60: #@Apache::lonhomework::date_msg=();
   61: sub check_date {
   62:   my ($id) = @_;
   63:   my $date ='';
   64:   my $status = '';
   65:   my $datemsg = '';
   66:   my $lastdate = '';
   67:   my $temp;
   68:   my $type;
   69:   my $passed;
   70:   &Apache::lonxml::debug("checking for part :$id:");
   71:   foreach $temp ("opendate","duedate","answerdate") {
   72:     $lastdate = $date;
   73:     $date = &Apache::lonnet::EXT("resource.$id.$temp");
   74:     &Apache::lonxml::debug("found :$date: for :$temp:");
   75:     if ($date eq '') {
   76:       $date = "an unknown date"; $passed = 0;
   77:     } elsif ($date eq 'con_lost') {
   78:       $date = "an indeterminate date"; $passed = 0;
   79:     } else {
   80:       if (time < $date) { $passed = 0; } else { $passed = 1; }
   81:       $date = localtime $date;
   82:     }
   83:     if (!$passed) { $type=$temp; last; }
   84:   }
   85:   &Apache::lonxml::debug("have :$type:$passed:");
   86:   if ($passed) {
   87:     $status='SHOW_ANSWER';
   88:     $datemsg=$date;
   89:   } elsif ($type eq 'opendate') {
   90:     $status='CLOSED';
   91:     $datemsg = "will open on $date";
   92:   } elsif ($type eq 'duedate') {
   93:     $status='CAN_ANSWER';
   94:     $datemsg = "is due at $date";
   95:   } elsif ($type eq 'answerdate') {
   96:     $status='CLOSED';
   97:     $datemsg = "was due as $lastdate, and answers will be available at $date";
   98:   }
   99:   if ($status eq 'CAN_ANSWER') {
  100:     #check #tries
  101:     my $tries = $Apache::lonhomework::history{"resource.$id.tries"};
  102:     my $maxtries = &Apache::lonnet::EXT("resource.$id.maxtries");
  103:     if ( $tries eq '' ) { $tries = '0'; }
  104:     if ( $maxtries eq '' ) { $maxtries = '2'; } 
  105:     if ($tries >= $maxtries) { $status = 'CANNOT_ANSWER'; } 
  106:   }
  107:   &Apache::lonxml::debug("sending back :$status:$datemsg:");
  108:   if ($ENV{'request.state'} eq "construct") {
  109:     &Apache::lonxml::debug("in construction ignoring dates");
  110:     $status='CAN_ANSWER';
  111:     $datemsg='is in under construction';
  112:   }
  113:   return ($status,$datemsg);
  114: }
  115: 
  116: sub handler {
  117:   my $request=$_[0];
  118: 
  119:   if ( $ENV{'user.name'} eq 'albertel' ) { $Apache::lonxml::debug=1; }
  120:   
  121:   my (@targets) = &get_target();
  122: 
  123:   if ($ENV{'browser.mathml'}) {
  124:     $request->content_type('text/xml');
  125:   } else {
  126:     $request->content_type('text/html');
  127:   }
  128:   $request->send_http_header;
  129:   return OK if $request->header_only;
  130:   
  131:   &Apache::lonhomework::send_header($request);
  132:   
  133:   #check if allowed to see
  134:   
  135:   foreach my $target (@targets) {
  136:     my $file=&Apache::lonnet::filelocation("",$request->uri);
  137:     my $problem=&Apache::lonnet::getfile($file);
  138:     if ($problem == -1) {
  139:       &Apache::lonxml::error("<b> Unable to find <i>$file</i></b>");
  140:       $problem='';
  141:     }
  142:     
  143:     my %mystyle;
  144:     my $result = '';
  145:     &Apache::inputtags::initialize_inputtags;
  146:     %Apache::lonhomework::results=();
  147:     %Apache::lonhomework::history=&Apache::lonnet::restore;
  148:     #ignore error conditions
  149:     my ($temp)=keys %Apache::lonhomework::history ;
  150:     if ($temp =~ m/^error:.*/) { %Apache::lonhomework::history=(); } 
  151:     if ($target eq 'web' && &Apache::lonnet::symbread() eq '') {
  152:       $request->print("Vieiwing this problem as not a student, submissions will be ignored.");
  153:     }
  154:     if ($target eq 'grade') {
  155:       my $resultkey;
  156:       foreach $resultkey (sort keys %Apache::lonhomework::history) {
  157: 	&Apache::lonxml::debug("$resultkey ---- $Apache::lonhomework::history{$resultkey}");
  158:       }
  159:       &Apache::lonxml::debug("\n<br>restored values^</br>\n");
  160:     }
  161:     my $default=&Apache::lonnet::getfile('/home/httpd/html/res/adm/includes/default_homework.lcpm');
  162:     if ($default == -1) {
  163:       &Apache::lonxml::error("<b>Unable to find <i>default_homework.lcpm</i></b>");
  164:       $default='';
  165:     }
  166:     $result = &Apache::lonxml::xmlparse($target, $problem,
  167: 			$default.&setup_vars($target),%mystyle);
  168: 
  169:     #$request->print("Result follows:");
  170:     $request->print($result);
  171:     #$request->print(":Result ends");
  172:     if ($target eq 'grade') {
  173: 
  174:       my $resultkey;
  175:       foreach $resultkey (sort keys %Apache::lonhomework::results) {
  176: 	&Apache::lonxml::debug("$resultkey ---- $Apache::lonhomework::results{$resultkey}");
  177:       }
  178:       &Apache::lonxml::debug("\n<br>storing values^</br>\n");
  179:     }
  180:     
  181:     my ($temp) = keys %Apache::lonhomework::results;
  182:     if ( $temp ne '' ) {
  183:       &Apache::lonxml::debug("Store return message:".&Apache::lonnet::cstore(%Apache::lonhomework::results));
  184:     }
  185:   }
  186:   &Apache::lonhomework::send_footer($request);
  187:   
  188:   return OK;
  189: 
  190: }
  191: 
  192: 1;
  193: __END__

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>