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'; |
|
|
|
} |
} |
|
|