Diff for /loncom/homework/lonhomework.pm between versions 1.17 and 1.32

version 1.17, 2000/11/30 16:20:49 version 1.32, 2001/01/11 15:25:46
Line 1 Line 1
 # The LON-CAPA Homework handler  # The LON-CAPA Homework handler
 # Guy Albertelli  # Guy Albertelli
 # 11/30 Gerd Kortemeyer  # 11/30 Gerd Kortemeyer
   # 6/1 Gerd Kortemeyer
   
 package Apache::lonhomework;  package Apache::lonhomework;
 use strict;  use strict;
Line 10  use Apache::lonnet; Line 11  use Apache::lonnet;
 use Apache::inputtags;  use Apache::inputtags;
 use Apache::structuretags;  use Apache::structuretags;
 use Apache::response;  use Apache::response;
   use Apache::hint;
   use Apache::outputtags;
 sub subhandler {  use Apache::Constants qw(:common);
   my ($target,$problem)=@_;  
   my %mystyle;  
   my $result = '';  
   &Apache::inputtags::initialize_inputtags;  
   %Apache::lonhomework::results=();  
   %Apache::lonhomework::history=&Apache::lonnet::restore;  
   #ignore error conditions  
   my ($temp)=keys %Apache::lonhomework::history ;  
   if ($temp =~ m/^error:.*/) { %Apache::lonhomework::history=(); }   
   
   my $resultkey;  
   foreach $resultkey (sort keys %Apache::lonhomework::history) {  
     &Apache::lonxml::debug("$resultkey ---- $Apache::lonhomework::history{$resultkey}");  
   }  
   &Apache::lonxml::debug("\n<br>restored values^</br>\n");  
   my $default=&Apache::lonnet::getfile('/home/httpd/html/res/adm/includes/default_homework.lcpm');  
   if ($default == -1) {  
     &Apache::lonxml::error("<b>Unable to find <i>default_homework.lcpm</i></b>");  
     $default='';  
   }  
   
   return Apache::lonxml::xmlparse($target, $problem,  
      $default.&setup_vars($target),%mystyle);  
 }  
   
 sub get_target {  sub get_target {
   if ( $ENV{'request.state'} eq "published") {    if ( $ENV{'request.state'} eq "published") {
     return 'web';      if ( defined $ENV{'form.submit'}) {
         return ('grade', 'web');
       } else {
         return ('web');
       }
   } elsif ($ENV{'request.state'} eq "construct") {    } elsif ($ENV{'request.state'} eq "construct") {
     if ( defined $ENV{'form.preview'}) {      if ( defined $ENV{'form.preview'}) {
       return 'web';        if ( defined $ENV{'form.submit'}) {
    return ('grade', 'web');
         } else {
    return ('web');
         }
     } else {      } else {
       return 'edit';        #return ('edit');
         #edit is currently broken
         return ('web');
     }      }
   }    }
     return ();
 }  }
   
 sub setup_vars {  sub setup_vars {
Line 69  sub send_footer { Line 57  sub send_footer {
   $request->print(&Apache::lontexconvert::footer());    $request->print(&Apache::lontexconvert::footer());
 }  }
   
 sub getfilenothere {  #@Apache::lonhomework::date_status=();
   my ($filename) = @_;  #@Apache::lonhomework::date_msg=();
   my $a="";  sub check_date {
   if (! -e $filename ) {    my ($id) = @_;
     &Apache::lonnet::subscribe($filename);    my $date ='';
     &Apache::lonnet::repcopy($filename);    my $status = '';
   }    my $datemsg = '';
   {    my $lastdate = '';
     my $fh=Apache::File->new($filename);    my $temp;
     my $type;
     while (<$fh>) {    my $passed;
       $a .=$_;    &Apache::lonxml::debug("checking for part :$id:");
     foreach $temp ("opendate","duedate","answerdate") {
       $lastdate = $date;
       $date = &Apache::lonnet::EXT("resource.$id.$temp");
       &Apache::lonxml::debug("found :$date: for :$temp:");
       if ($date eq '') {
         $date = "an unknown date"; $passed = 0;
       } elsif ($date eq 'con_lost') {
         $date = "an indeterminate date"; $passed = 0;
       } else {
         if (time < $date) { $passed = 0; } else { $passed = 1; }
         $date = localtime $date;
     }      }
       if (!$passed) { $type=$temp; last; }
     }
     &Apache::lonxml::debug("have :$type:$passed:");
     if ($passed) {
       $status='SHOW_ANSWER';
       $datemsg=$date;
     } elsif ($type eq 'opendate') {
       $status='CLOSED';
       $datemsg = "will open on $date";
     } elsif ($type eq 'duedate') {
       $status='CAN_ANSWER';
       $datemsg = "is due at $date";
     } elsif ($type eq 'answerdate') {
       $status='CLOSED';
       $datemsg = "was due on $lastdate, and answers will be available on $date";
     }
     if ($status eq 'CAN_ANSWER') {
       #check #tries
       my $tries = $Apache::lonhomework::history{"resource.$id.tries"};
       my $maxtries = &Apache::lonnet::EXT("resource.$id.maxtries");
       if ( $tries eq '' ) { $tries = '0'; }
       if ( $maxtries eq '' ) { $maxtries = '2'; } 
       if ($tries >= $maxtries) { $status = 'CANNOT_ANSWER'; } 
     }
     &Apache::lonxml::debug("sending back :$status:$datemsg:");
     if ($ENV{'request.state'} eq "construct") {
       &Apache::lonxml::debug("in construction ignoring dates");
       $status='CAN_ANSWER';
       $datemsg='is in under construction';
   }    }
   return $a    return ($status,$datemsg);
 }  }
   
 sub handler {  sub handler {
   my $request=shift;    my $request=$_[0];
   
     if ( $ENV{'user.name'} eq 'albertel' ) { $Apache::lonxml::debug=1; }
     
     my (@targets) = &get_target();
   
   $Apache::lonxml::debug=1;  
   if ($ENV{'browser.mathml'}) {    if ($ENV{'browser.mathml'}) {
     $request->content_type('text/xml');      $request->content_type('text/xml');
   } else {    } else {
     $request->content_type('text/html');      $request->content_type('text/html');
   }    }
   $request->send_http_header;    $request->send_http_header;
   return 'OK' if $request->header_only;    return OK if $request->header_only;
     
   &Apache::lonhomework::send_header($request);    &Apache::lonhomework::send_header($request);
   my $file=&Apache::lonnet::filelocation("",$request->uri);    
   my $problem=&Apache::lonnet::getfile($file);    #check if allowed to see
   if ($problem == -1) {    
     &Apache::lonxml::error("<b> Unable to find <i>$file</i></b>");    foreach my $target (@targets) {
     $problem='';      my $file=&Apache::lonnet::filelocation("",$request->uri);
   }      my $problem=&Apache::lonnet::getfile($file);
       if ($problem == -1) {
   my $result=&subhandler(&get_target(),$problem);        &Apache::lonxml::error("<b> Unable to find <i>$file</i></b>");
         $problem='';
   #$request->print("Result follows:");      }
   $request->print($result);      
   #$request->print(":Result ends");      my %mystyle;
       my $result = '';
       &Apache::inputtags::initialize_inputtags;
       %Apache::lonhomework::results=();
       %Apache::lonhomework::history=&Apache::lonnet::restore;
       #ignore error conditions
       my ($temp)=keys %Apache::lonhomework::history ;
       if ($temp =~ m/^error:.*/) { %Apache::lonhomework::history=(); } 
       if ($target eq 'web' && &Apache::lonnet::symbread() eq '') {
         $request->print("Vieiwing this problem as not a student, submissions will be ignored.");
       }
       if ($target eq 'grade') {
         my $resultkey;
         foreach $resultkey (sort keys %Apache::lonhomework::history) {
    &Apache::lonxml::debug("$resultkey ---- $Apache::lonhomework::history{$resultkey}");
         }
         &Apache::lonxml::debug("\n<br>restored values^</br>\n");
       }
       my $default=&Apache::lonnet::getfile('/home/httpd/html/res/adm/includes/default_homework.lcpm');
       if ($default == -1) {
         &Apache::lonxml::error("<b>Unable to find <i>default_homework.lcpm</i></b>");
         $default='';
       }
       $result = &Apache::lonxml::xmlparse($target, $problem,
    $default.&setup_vars($target),%mystyle);
   
   my $temp;      #$request->print("Result follows:");
   my $resultkey;      $request->print($result);
   foreach $resultkey (sort keys %Apache::lonhomework::results) {      #$request->print(":Result ends");
     &Apache::lonxml::debug("$resultkey ---- $Apache::lonhomework::results{$resultkey}");      if ($target eq 'grade') {
   
         my $resultkey;
         foreach $resultkey (sort keys %Apache::lonhomework::results) {
    &Apache::lonxml::debug("$resultkey ---- $Apache::lonhomework::results{$resultkey}");
         }
         &Apache::lonxml::debug("\n<br>storing values^</br>\n");
       }
       
       my ($temp) = keys %Apache::lonhomework::results;
       if ( $temp ne '' ) {
         &Apache::lonxml::debug("Store return message:".&Apache::lonnet::cstore(%Apache::lonhomework::results));
       }
   }    }
   &Apache::lonxml::debug("\n<br>storing values^</br>\n");  
   
   &Apache::lonhomework::send_footer($request);    &Apache::lonhomework::send_footer($request);
   ($temp) = keys %Apache::lonhomework::results;    
   if ( $temp ne '' ) {    return OK;
     &Apache::lonxml::debug("Store return message:".&Apache::lonnet::cstore(%Apache::lonhomework::results));  
   }  
   return 'OK';  
   
 }  }
   

Removed from v.1.17  
changed lines
  Added in v.1.32


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