--- loncom/interface/slotrequest.pm 2005/05/31 17:42:11 1.1 +++ loncom/interface/slotrequest.pm 2005/10/07 20:00:20 1.20 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA # Handler for requesting to have slots added to a students record # -# $Id: slotrequest.pm,v 1.1 2005/05/31 17:42:11 albertel Exp $ +# $Id: slotrequest.pm,v 1.20 2005/10/07 20:00:20 albertel Exp $ # # Copyright Michigan State University Board of Trustees # @@ -34,10 +34,21 @@ use Apache::Constants qw(:common :http : use Apache::loncommon(); use Apache::lonlocal; use Apache::lonnet; +use Date::Manip; sub fail { my ($r,$code)=@_; - $r->print(); + if ($code eq 'not_valid') { + $r->print('

'.&mt('Unable to understand what resource you wanted to sign up for.').'

'); + + } elsif ($code eq 'not_allowed') { + $r->print('

'.&mt('Not allowed to sign up or change reservations at this time.').'

'); + } else { + $r->print('

'.&mt('Failed.').'

'); + } + + $r->print('

'. + &mt('Return to last resource').'

'); &end_page($r); } @@ -54,17 +65,757 @@ sub end_page { $r->print(&Apache::loncommon::endbodytag().''); } +=pod + + slot_reservations db + - keys are + - slotname\0id -> value is an hashref of + name -> user@domain of holder + timestamp -> timestamp of reservation + symb -> symb of resource that it is reserved for + +=cut + +sub get_course { + (undef,my $courseid)=&Apache::lonxml::whichuser(); + my $cdom=$env{'course.'.$courseid.'.domain'}; + my $cnum=$env{'course.'.$courseid.'.num'}; + return ($cnum,$cdom); +} + +sub get_reservation_ids { + my ($slot_name)=@_; + + my ($cnum,$cdom)=&get_course(); + + my %consumed=&Apache::lonnet::dump('slot_reservations',$cdom,$cnum, + "^$slot_name\0"); + + my ($tmp)=%consumed; + if ($tmp=~/^error: 2 / ) { + return 0; + } + return keys(%consumed); +} + +sub space_available { + my ($slot_name,$slot)=@_; + my $max=$slot->{'maxspace'}; + + if (!defined($max)) { return 1; } + + my $consumed=scalar(&get_reservation_ids($slot_name)); + if ($consumed < $max) { + return 1 + } + return 0; +} + +sub check_for_reservation { + my ($symb)=@_; + my $student = &Apache::lonnet::EXT("resource.0.availablestudent", $symb, + $env{'user.domain'}, $env{'user.name'}); + + my $course = &Apache::lonnet::EXT("resource.0.available", $symb, + $env{'user.domain'}, $env{'user.name'}); + my @slots = (split(/:/,$student), split(/:/, $course)); + + &Apache::lonxml::debug(" slot list is ".join(':',@slots)); + + my ($cnum,$cdom)=&get_course(); + my %slots=&Apache::lonnet::get('slots', [@slots], $cdom, $cnum); + + foreach my $slot_name (@slots) { + next if (!defined($slots{$slot_name}) || + !ref($slots{$slot_name})); + &Apache::lonxml::debug(time." $slot_name ". + $slots{$slot_name}->{'starttime'}." -- ". + $slots{$slot_name}->{'startreserve'}); + if ($slots{$slot_name}->{'endtime'} > time && + $slots{$slot_name}->{'startreserve'} < time) { + # between start of reservation times and end of slot + return($slot_name, $slots{$slot_name}); + } + } + return (undef,undef); +} + +sub check_for_conflict { + my ($symb,$new_slot_name)=@_; + my $student = &Apache::lonnet::EXT("resource.0.availablestudent", $symb, + $env{'user.domain'}, $env{'user.name'}); + my $course = &Apache::lonnet::EXT("resource.0.available", $symb, + $env{'user.domain'}, $env{'user.name'}); + my @slots = (split(/:/,$student), split(/:/, $course)); + my ($cnum,$cdom)=&get_course(); + my %slots=&Apache::lonnet::get('slots', [@slots], $cdom, $cnum); + foreach my $slot_name (@slots) { + next if (!defined($slots{$slot_name}) || + !ref($slots{$slot_name})); + + next if (!defined($slots{$slot_name}->{'uniqueperiod'}) || + !ref($slots{$slot_name}->{'uniqueperiod'})); + my ($start,$end)=@{$slots{$slot_name}->{'uniqueperiod'}}; + if ($start