version 1.162, 2004/01/29 18:51:28
|
version 1.165, 2004/02/16 17:20:39
|
Line 201 sub check_access {
|
Line 201 sub check_access {
|
my $passed; |
my $passed; |
|
|
if ($ENV{'request.state'} eq "construct") { |
if ($ENV{'request.state'} eq "construct") { |
|
if (defined($ENV{'form.problemstatus'})) { |
|
if ($ENV{'form.problemstate'} =~ /^CANNOT_ANSWER/) { |
|
return ('CANNOT_ANSWER','is in this state by royal decree.'); |
|
} else { |
|
return ($ENV{'form.problemstate'}, |
|
'is in this state by royal decree.'); |
|
} |
|
} |
&Apache::lonxml::debug("in construction ignoring dates"); |
&Apache::lonxml::debug("in construction ignoring dates"); |
$status='CAN_ANSWER'; |
$status='CAN_ANSWER'; |
$datemsg=&mt('is in under construction'); |
$datemsg=&mt('is in under construction'); |
return ($status,$datemsg); |
# return ($status,$datemsg); |
} |
} |
|
|
&Apache::lonxml::debug("checking for part :$id:"); |
&Apache::lonxml::debug("checking for part :$id:"); |
&Apache::lonxml::debug("time:".time); |
&Apache::lonxml::debug("time:".time); |
|
|
my $allowed=&check_ip_acc(&Apache::lonnet::EXT("resource.$id.acc")); |
|
if (!$allowed && ($Apache::lonhomework::browse ne 'F')) { |
|
$status='INVALID_ACCESS'; |
|
$date=&mt("can not be accessed from your location."); |
|
return($status,$date); |
|
} |
|
|
|
foreach $temp ("opendate","duedate","answerdate") { |
if ($ENV{'request.state'} ne "construct") { |
$lastdate = $date; |
my $allowed=&check_ip_acc(&Apache::lonnet::EXT("resource.$id.acc")); |
$date = &Apache::lonnet::EXT("resource.$id.$temp"); |
if (!$allowed && ($Apache::lonhomework::browse ne 'F')) { |
my $thistype = &Apache::lonnet::EXT("resource.$id.$temp.type"); |
$status='INVALID_ACCESS'; |
if ($thistype =~ /^(con_lost|no_such_host)/ || |
$date=&mt("can not be accessed from your location."); |
$date =~ /^(con_lost|no_such_host)/) { |
|
$status='UNAVAILABLE'; |
|
$date=&mt("may open later."); |
|
return($status,$date); |
return($status,$date); |
} |
} |
if ($thistype eq 'date_interval') { |
|
if ($temp eq 'opendate') { |
foreach $temp ("opendate","duedate","answerdate") { |
$date=&Apache::lonnet::EXT("resource.$id.duedate")-$date; |
$lastdate = $date; |
|
$date = &Apache::lonnet::EXT("resource.$id.$temp"); |
|
my $thistype = &Apache::lonnet::EXT("resource.$id.$temp.type"); |
|
if ($thistype =~ /^(con_lost|no_such_host)/ || |
|
$date =~ /^(con_lost|no_such_host)/) { |
|
$status='UNAVAILABLE'; |
|
$date=&mt("may open later."); |
|
return($status,$date); |
} |
} |
if ($temp eq 'answerdate') { |
if ($thistype eq 'date_interval') { |
$date=&Apache::lonnet::EXT("resource.$id.duedate")+$date; |
if ($temp eq 'opendate') { |
|
$date=&Apache::lonnet::EXT("resource.$id.duedate")-$date; |
|
} |
|
if ($temp eq 'answerdate') { |
|
$date=&Apache::lonnet::EXT("resource.$id.duedate")+$date; |
|
} |
} |
} |
|
&Apache::lonxml::debug("found :$date: for :$temp:"); |
|
if ($date eq '') { |
|
$date = &mt("an unknown date"); $passed = 0; |
|
} elsif ($date eq 'con_lost') { |
|
$date = &mt("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("found :$date: for :$temp:"); |
&Apache::lonxml::debug("have :$type:$passed:"); |
if ($date eq '') { |
if ($passed) { |
$date = &mt("an unknown date"); $passed = 0; |
$status='SHOW_ANSWER'; |
} elsif ($date eq 'con_lost') { |
$datemsg=$date; |
$date = &mt("an indeterminate date"); $passed = 0; |
} elsif ($type eq 'opendate') { |
} else { |
$status='CLOSED'; |
if (time < $date) { $passed = 0; } else { $passed = 1; } |
$datemsg = &mt("will open on")." $date"; |
$date = localtime $date; |
} elsif ($type eq 'duedate') { |
|
$status='CAN_ANSWER'; |
|
$datemsg = &mt("is due at")." $date"; |
|
} elsif ($type eq 'answerdate') { |
|
$status='CLOSED'; |
|
$datemsg = &mt("was due on")." $lastdate".&mt(", and answers will be available on")." $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 = &mt("will open on")." $date"; |
|
} elsif ($type eq 'duedate') { |
|
$status='CAN_ANSWER'; |
|
$datemsg = &mt("is due at")." $date"; |
|
} elsif ($type eq 'answerdate') { |
|
$status='CLOSED'; |
|
$datemsg = &mt("was due on")." $lastdate".&mt(", and answers will be available on")." $date"; |
|
} |
} |
if ($status eq 'CAN_ANSWER') { |
if ($status eq 'CAN_ANSWER') { |
#check #tries, and if correct. |
#check #tries, and if correct. |
my $tries = $Apache::lonhomework::history{"resource.$id.tries"}; |
my $tries = $Apache::lonhomework::history{"resource.$id.tries"}; |
my $maxtries = &Apache::lonnet::EXT("resource.$id.maxtries"); |
my $maxtries = &Apache::lonnet::EXT("resource.$id.maxtries"); |
if ( $tries eq '' ) { $tries = '0'; } |
if ( $tries eq '' ) { $tries = '0'; } |
if ( $maxtries eq '' ) { $maxtries = '2'; } |
if ( $maxtries eq '' && |
if ($tries >= $maxtries) { $status = 'CANNOT_ANSWER'; } |
$ENV{'request.state'} ne 'construct') { $maxtries = '2'; } |
|
if ($maxtries && $tries >= $maxtries) { $status = 'CANNOT_ANSWER'; } |
# if (correct and show prob status) or excused then CANNOT_ANSWER |
# if (correct and show prob status) or excused then CANNOT_ANSWER |
if(($Apache::lonhomework::history{"resource.$id.solved"}=~/^correct/ |
if(($Apache::lonhomework::history{"resource.$id.solved"}=~/^correct/ |
&& |
&& |