Diff for /loncom/misc/refresh_courseids_db.pl between versions 1.8 and 1.11

version 1.8, 2010/08/22 21:14:54 version 1.11, 2012/03/31 22:10:16
Line 61  use LONCAPA qw(:DEFAULT :match); Line 61  use LONCAPA qw(:DEFAULT :match);
   
 exit if ($Apache::lonnet::perlvar{'lonRole'} ne 'library');  exit if ($Apache::lonnet::perlvar{'lonRole'} ne 'library');
   
 use vars qw( %checkparms %checkresponsetypes %checkcrstypes %anonsurvey );  use vars qw( %checkparms %checkresponsetypes %checkcrstypes %anonsurvey %randomizetry );
   
 #  Make sure this process is running from user=www  #  Make sure this process is running from user=www
 my $wwwid=getpwnam('www');  my $wwwid=getpwnam('www');
Line 80  print $fh "==== refresh_courseids_db.pl Line 80  print $fh "==== refresh_courseids_db.pl
 my @domains = sort(&Apache::lonnet::current_machine_domains());  my @domains = sort(&Apache::lonnet::current_machine_domains());
 my @ids=&Apache::lonnet::current_machine_ids();  my @ids=&Apache::lonnet::current_machine_ids();
   
 &build_release_hashes();  &Apache::loncommon::build_release_hashes(\%checkparms,\%checkresponsetypes,
                                            \%checkcrstypes,\%anonsurvey,\%randomizetry);
 $env{'allowed.bre'} = 'F';  $env{'allowed.bre'} = 'F';
   
 foreach my $dom (@domains) {  foreach my $dom (@domains) {
Line 226  sub recurse_courses { Line 227  sub recurse_courses {
                     ($reqdmajor,$reqdminor) = &coursetype_constraints($cnum,$cdom,$crstype,                      ($reqdmajor,$reqdminor) = &coursetype_constraints($cnum,$cdom,$crstype,
                                                                       $reqdmajor,                                                                        $reqdmajor,
                                                                       $reqdminor);                                                                        $reqdminor);
                       # check communication blocks 
                       ($reqdmajor,$reqdminor) = &commblock_constraints($cnum,$cdom,
                                                                        $reqdmajor,
                                                                        $reqdminor);
                     # check course contents                      # check course contents
                     ($reqdmajor,$reqdminor) = &coursecontent_constraints($cnum,$cdom,                      ($reqdmajor,$reqdminor) = &coursecontent_constraints($cnum,$cdom,
                                                                          $reqdmajor,                                                                           $reqdmajor,
Line 376  sub coursetype_constraints { Line 381  sub coursetype_constraints {
     return ($reqdmajor,$reqdminor);      return ($reqdmajor,$reqdminor);
 }  }
   
   sub commblock_constraints {
       my ($cnum,$cdom,$reqdmajor,$reqdminor) = @_;
       my %comm_blocks =  &Apache::lonnet::dump('commblock',$cdom,$cnum);
       my $now = time;
       if (keys(%comm_blocks) > 0) {
           foreach my $block (keys(%comm_blocks)) {
               if ($block =~ /^firstaccess____(.+)$/) {
                   my ($major,$minor) = split(/\./,$Apache::lonnet::needsrelease{'course.commblock.timer'});
                   ($reqdmajor,$reqdminor) = &update_reqd_loncaparev($major,$minor,$reqdmajor,$reqdminor);
                   last;
               } elsif ($block =~ /^(\d+)____(\d+)$) {
                   my ($start,$end) = ($1,$2);
                   next if ($end < $now); 
               }
               if (ref($comm_blocks{$block}) eq 'HASH') {
                   if (ref($comm_blocks{$block}{'blocks'}) eq 'HASH') {
                       if (ref($comm_blocks{$block}{'blocks'}{'docs'}) eq 'HASH') {
                           if (keys(%{$comm_blocks{$block}{'blocks'}{'docs'}} > 0) {
                               my ($major,$minor) = split(/\./,$Apache::lonnet::needsrelease{'course.commblock.docs'});
                               ($reqdmajor,$reqdminor) = &update_reqd_loncaparev($major,$minor,$reqdmajor,$reqdminor);
                               last;
                           }
                       }
                   }
               }
           }
       }
       return;
   }
   
 sub coursecontent_constraints {  sub coursecontent_constraints {
     my ($cnum,$cdom,$reqdmajor,$reqdminor) = @_;      my ($cnum,$cdom,$reqdmajor,$reqdminor) = @_;
     my $navmap = Apache::lonnavmaps::navmap->new();      my $navmap = Apache::lonnavmaps::navmap->new();
     if (defined($navmap)) {      if (defined($navmap)) {
         my %anonsubmissions =  &Apache::lonnet::dump('nohist_anonsurveys',          my %anonsubmissions =  &Apache::lonnet::dump('nohist_anonsurveys',
                                                      $cdom,$cnum);                                                       $cdom,$cnum);
           my %randomizetrysubm = &Apache::lonnet::dump('nohist_randomizetry',
                                                        $cdom,$cnum);
         my %allresponses;          my %allresponses;
         my $anonsurv_subm;          my ($anonsurv_subm,$randbytry_subm);
         foreach my $res ($navmap->retrieveResources(undef,sub { $_[0]->is_problem() },1,0)) {          foreach my $res ($navmap->retrieveResources(undef,sub { $_[0]->is_problem() },1,0)) {
             my %responses = $res->responseTypes();              my %responses = $res->responseTypes();
             foreach my $key (keys(%responses)) {              foreach my $key (keys(%responses)) {
Line 396  sub coursecontent_constraints { Line 433  sub coursecontent_constraints {
                 if (exists($anonsubmissions{$symb."\0".$part})) {                  if (exists($anonsubmissions{$symb."\0".$part})) {
                     $anonsurv_subm = 1;                      $anonsurv_subm = 1;
                 }                  }
                   if (exists($randomizetrysubm{$symb."\0".$part})) {
                       $randbytry_subm = 1;
                   }
             }              }
         }          }
         foreach my $key (keys(%allresponses)) {          foreach my $key (keys(%allresponses)) {
Line 406  sub coursecontent_constraints { Line 446  sub coursecontent_constraints {
             ($reqdmajor,$reqdminor) = &update_reqd_loncaparev($anonsurvey{major},              ($reqdmajor,$reqdminor) = &update_reqd_loncaparev($anonsurvey{major},
                                           $anonsurvey{minor},$reqdmajor,$reqdminor);                                            $anonsurvey{minor},$reqdmajor,$reqdminor);
         }          }
           if ($randbytry_subm) {
               ($reqdmajor,$reqdminor) = &update_reqd_loncaparev($randomizetry{major},
                                             $randomizetry{minor},$reqdmajor,$reqdminor);
           }
     }      }
     return ($reqdmajor,$reqdminor);      return ($reqdmajor,$reqdminor);
 }  }
Line 445  sub read_paramdata { Line 489  sub read_paramdata {
     return $resourcedata;      return $resourcedata;
 }  }
   
 sub build_release_hashes {  
     foreach my $key (keys(%Apache::lonnet::needsrelease)) {  
         my ($item,$name,$value) = split(/:/,$key);  
         if ($item eq 'parameter') {  
             if (ref($checkparms{$name}) eq 'ARRAY') {  
                 unless(grep(/^\Q$name\E$/,@{$checkparms{$name}})) {  
                     push(@{$checkparms{$name}},$value);  
                 }  
             } else {  
                 push(@{$checkparms{$name}},$value);  
             }  
         } elsif ($item eq 'resourcetag') {  
             if ($name eq 'responsetype') {  
                 $checkresponsetypes{$value} = $Apache::lonnet::needsrelease{$key}  
             }  
         } elsif ($item eq 'course') {  
             if ($name eq 'crstype') {  
                 $checkcrstypes{$value} = $Apache::lonnet::needsrelease{$key};  
             }  
         }  
     }  
     ($anonsurvey{major},$anonsurvey{minor}) = split(/\./,$Apache::lonnet::needsrelease{'parameter:type:anonsurvey'});  
     return;  
 }  
   

Removed from v.1.8  
changed lines
  Added in v.1.11


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