Diff for /rat/lonpageflip.pm between versions 1.80.8.13.2.3 and 1.103

version 1.80.8.13.2.3, 2023/01/20 23:34:08 version 1.103, 2021/04/29 17:45:25
Line 99  sub hash_src { Line 99  sub hash_src {
 }  }
   
 sub move {  sub move {
     my ($next,$endupmap,$direction,$firstres) = @_;      my ($next,$endupmap,$direction) = @_;
     my $safecount=0;      my $safecount=0;
     my $allowed=0;      my $allowed=0;
     my $deeplinkonly=0;      my $deeplinkonly=0;
     my $deeplinkchecked;  
     my $deeplink_login_pc;  
     my $prev=$next;      my $prev=$next;
     my ($prevmapid)=split(/\./,$next);      my ($prevmapid)=split(/\./,$next);
     do {      do {
Line 117  sub move { Line 115  sub move {
  if ($url eq '' || $symb eq '') {   if ($url eq '' || $symb eq '') {
     $allowed = 0;      $allowed = 0;
  } else {   } else {
             my $nodeeplinkcheck = 0;      my $priv = &Apache::lonnet::allowed('bre',$url,$symb);
             if ($hash{'is_map_'.$next}) {      $allowed = (($priv eq 'F') || ($priv eq '2'));
                 $nodeeplinkcheck = 1;  
             }  
             my $priv = &Apache::lonnet::allowed('bre',$url,$symb,'','','','',$nodeeplinkcheck);  
             $allowed = (($priv eq 'F') || ($priv eq '2') || ($priv eq 'A'));  
  }   }
         $deeplinkonly = 0;          $deeplinkonly = 0;
         if ($hash{'deeplinkonly_'.$next}) {          if ($hash{'deeplinkonly_'.$next}) {
             my ($value,$level) = map { &unescape($_); } split(/:/,$hash{'deeplinkonly_'.$next});              my ($value,$level) = split(/:/,$hash{'deeplinkonly_'.$next});
             my ($state,$others,$listed,$scope,$protect) = split(/,/,$value);              if ($level eq 'resource') {
             unless (($state eq 'both') || ($hash{'is_map_'.$next})) {                  $deeplinkonly = 1;
                 if ($level eq 'resource') {              } elsif ($level eq 'map') {
                   if ($mapid != $prevmapid) {
                     $deeplinkonly = 1;                      $deeplinkonly = 1;
                 } elsif ($level eq 'map') {  
                     if ($scope eq 'rec') {  
                         unless ($mapid == $prevmapid) {  
                             unless ($deeplinkchecked) {  
                                 $deeplink_login_pc = &get_deeplink_login_pc();  
                                 $deeplinkchecked = 1;  
                             }  
                             if ($deeplink_login_pc) {  
                                 my $poss_map_pc;  
                                 if ($hash{'is_map_'.$next}) {  
                                     $poss_map_pc = $hash{'map_pc_'.$url};  
                                 } else {  
                                     $poss_map_pc = $hash{'map_pc_'.$hash{'map_id_'.$mapid}};  
                                 }  
                                 unless ($deeplink_login_pc == $poss_map_pc) {  
                                     unless (grep(/^$deeplink_login_pc$/,split(/,/,$hash{'map_hierarchy_'.$poss_map_pc}))) {  
                                         $deeplinkonly = 1;  
                                     }  
                                 }  
                             } else {  
                                 $deeplinkonly = 1;  
                             }  
                         }  
                     } elsif ($mapid != $prevmapid) {  
                         $deeplinkonly = 1;  
                     }  
                 }                  }
             }              }
         } elsif (($hash{'deeplinkonly_'.$prev}) && (!$firstres)) {          } elsif ($hash{'deeplinkonly_'.$prev}) {
             my ($value,$level) = map { &unescape($_); } split(/:/,$hash{'deeplinkonly_'.$prev});              my ($value,$level) = split(/:/,$hash{'deeplinkonly_'.$prev});
             my ($state,$others,$listed,$scope,$protect) = split(/,/,$value);              if ($level eq 'resource') {
             unless (($state eq 'both') || ($hash{'is_map_'.$prev})) {                  $deeplinkonly = 1;
                 if ($level eq 'resource') {              } elsif ($level eq 'map') {
                   if ($mapid != $prevmapid) {
                     $deeplinkonly = 1;                      $deeplinkonly = 1;
                 } elsif ($level eq 'map') {  
                     if ($scope eq 'rec') {  
                         unless ($mapid == $prevmapid) {  
                             unless ($deeplinkchecked) {  
                                 $deeplink_login_pc = &get_deeplink_login_pc();  
                                 $deeplinkchecked = 1;  
                             }  
                             if ($deeplink_login_pc) {  
                                 my $poss_map_pc;  
                                 if ($hash{'is_map_'.$prev}) {  
                                     $poss_map_pc = $hash{'map_pc_'.$url};  
                                 } else {  
                                     $poss_map_pc = $hash{'map_pc_'.$hash{'map_id_'.$mapid}};  
                                 }  
                                 unless ($deeplink_login_pc == $poss_map_pc) {  
                                     unless (grep(/^$deeplink_login_pc$/,split(/,/,$hash{'map_hierarchy_'.$poss_map_pc}))) {  
                                         $deeplinkonly = 1;  
                                     }  
                                 }  
                             }  
                         }  
                     } else {  
                         if ($mapid != $prevmapid) {  
                             $deeplinkonly = 1;  
                         }  
                     }  
                 }                  }
             }              }
         }          }
Line 200  sub move { Line 144  sub move {
      && (       && (
     (!$hash{'src_'.$next})      (!$hash{'src_'.$next})
  || (   || (
         (!$env{'request.role.adv'})                          (!$env{'request.role.adv'})
      && (($hash{'randomout_'.$next})                       && (($hash{'randomout_'.$next})
                      ||  ($deeplinkonly)                       ||  ($deeplinkonly))
                      ||  ($hash{'deeplinkout_'.$next}))  
     )      )
  || (!$allowed)   || (!$allowed)
  )   )
Line 238  sub get_next_possible_move { Line 181  sub get_next_possible_move {
           }            }
                           if ($thiscond>$mincond) { $mincond=$thiscond; }                            if ($thiscond>$mincond) { $mincond=$thiscond; }
               }                }
                   }                    } 
   foreach my $id (split(/\,/,$posnext))  {    foreach my $id (split(/\,/,$posnext))  {
                       my ($linkid,$condval)=split(/\:/,$id);                        my ($linkid,$condval)=split(/\:/,$id);
                       if ($condval>=$mincond) {                        if ($condval>=$mincond) {
Line 280  sub get_next_possible_move { Line 223  sub get_next_possible_move {
  }   }
  if ($thiscond>$mincond) { $mincond=$thiscond; }   if ($thiscond>$mincond) { $mincond=$thiscond; }
      }       }
  }   } 
  foreach my $id (split(/\,/,$posnext)) {   foreach my $id (split(/\,/,$posnext)) {
      my ($linkid,$condval)=split(/\:/,$id);       my ($linkid,$condval)=split(/\:/,$id);
      if ($condval>=$mincond) {       if ($condval>=$mincond) {
Line 313  sub first_accessible_resource { Line 256  sub first_accessible_resource {
     if (tie(%hash,'GDBM_File',$env{'request.course.fn'}.'.db',      if (tie(%hash,'GDBM_File',$env{'request.course.fn'}.'.db',
     &GDBM_READER(),0640)) {      &GDBM_READER(),0640)) {
  $furl=$hash{'first_url'};   $furl=$hash{'first_url'};
  my (%args,$url,$argstr);   my %args;
  if ($furl =~ m{^/enc/}) {   my ($url,$args) = split(/\?/,$furl);
     ($url,$argstr) = split(/\?/,&Apache::lonenc::unencrypted($furl));   foreach my $pair (split(/\&/,$args)) {
  } else {  
     ($url,$argstr) = split(/\?/,$furl);  
  }  
  foreach my $pair (split(/\&/,$argstr)) {  
     my ($name,$value) = split(/=/,$pair);      my ($name,$value) = split(/=/,$pair);
     $args{&unescape($name)} = &unescape($value);      $args{&unescape($name)} = &unescape($value);
  }   }
         my $priv = &Apache::lonnet::allowed('bre',$url,$args{'symb'});          if (!&Apache::lonnet::allowed('bre',$url,$args{'symb'})) {
         my $allowed = (($priv eq 'F') || ($priv eq '2') || ($priv eq 'A'));  
         if (!$allowed) {  
 # Wow, we cannot see this ... move forward to the next one that we can see  # Wow, we cannot see this ... move forward to the next one that we can see
     my ($newrid,$newmap)=&move($hash{'first_rid'},$hash{'first_mapurl'},'forward',1);      my ($newrid,$newmap)=&move($hash{'first_rid'},$hash{'first_mapurl'},'forward');
 # Build the new URL  # Build the new URL
             if ($newrid eq '') {      my ($newmapid,$newresid)=split(/\./,$newrid);
                 $furl = '/adm/navmaps';      my $symb=&Apache::lonnet::encode_symb($newmap,$newresid,$hash{'src_'.$newrid});
             } else {      $furl=&add_get_param($hash{'src_'.$newrid},{ 'symb' => $symb });
         my ($newmapid,$newresid)=split(/\./,$newrid);      if ($hash{'encrypted_'.$newrid}) {
         my $symb=&Apache::lonnet::encode_symb($newmap,$newresid,$hash{'src_'.$newrid});   $furl=&Apache::lonenc::encrypted($furl);
         $furl=&add_get_param($hash{'src_'.$newrid},{ 'symb' => $symb });      }
         if ($hash{'encrypted_'.$newrid}) {   }
     $furl=&Apache::lonenc::encrypted($furl);  
                 }  
             }  
         }  
  untie(%hash);   untie(%hash);
  return $furl;   return $furl;
     } else {      } else {
Line 347  sub first_accessible_resource { Line 280  sub first_accessible_resource {
     }      }
 }  }
   
   sub first_answerable_ressymb {
       my $navmap = Apache::lonnavmaps::navmap->new;
       return unless (ref($navmap));
       my $iterator = $navmap->getIterator(undef,undef,undef,1);
       return unless (ref($iterator));
       my ($curRes,$result);
       while ($curRes = $iterator->next()) {
           if (ref($curRes) && $curRes->is_problem()) {
               foreach my $part (@{$curRes->parts()}) {
                   if ($curRes->tries($part) < $curRes->maxtries($part)) {
                       $result = $curRes->link().'?symb='.$curRes->shown_symb();
                       last;
                   }    
               }
           }
       }
       if ($result) {
           return $result; 
       } else {
           return &first_accessible_resource(); 
       }
   }
   
 sub check_http_req {  sub check_http_req {
     my ($srcref,$hostname) = @_;      my ($srcref,$hostname) = @_;
     return unless (ref($srcref) eq 'SCALAR');      return unless (ref($srcref) eq 'SCALAR');
Line 367  sub check_http_req { Line 323  sub check_http_req {
             unless ((&Apache::lonnet::uses_sts()) ||              unless ((&Apache::lonnet::uses_sts()) ||
                     (&Apache::lonnet::waf_allssl($hostname))) {                      (&Apache::lonnet::waf_allssl($hostname))) {
                 my ($url,$anchor) = ($$srcref =~ /^([^\#]+)(?:|(\#[^\#]+))$/);                  my ($url,$anchor) = ($$srcref =~ /^([^\#]+)(?:|(\#[^\#]+))$/);
                 $$srcref = $url . (($$srcref =~/\?/)? '&':'?') . 'usehttp=1' .$anchor;                  $$srcref = $url . (($$srcref =~/\?/)? '&':'?') . 'usehttp=1' .$anchor; 
                 $usehttp = 1;                  $usehttp = 1;
             }              }
         }          }
Line 397  setTimeout(function() { Line 353  setTimeout(function() {
 END  END
 }  }
   
 sub get_deeplink_login_pc {  
     my $deeplink_login_pc;  
     if (($env{'request.deeplink.login'}) && ($env{'request.course.id'})) {  
         my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};  
         my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};  
         my $deeplink_symb = &Apache::loncommon::deeplink_login_symb($cnum,$cdom);  
         if ($deeplink_symb) {  
             my $loginmap;  
             if ($deeplink_symb =~ /\.(page|sequence)$/) {  
                 $loginmap = &Apache::lonnet::clutter((&Apache::lonnet::decode_symb($deeplink_symb))[2]);  
             } else {  
                 $loginmap = &Apache::lonnet::clutter((&Apache::lonnet::decode_symb($deeplink_symb))[0]);  
             }  
             $deeplink_login_pc = $hash{'map_pc_'.$loginmap};  
         }  
     }  
     return $deeplink_login_pc;  
 }  
   
 # ================================================================ Main Handler  # ================================================================ Main Handler
   
 sub handler {  sub handler {
Line 453  sub handler { Line 390  sub handler {
               $last=$hash{'last_known'};                $last=$hash{'last_known'};
               untie(%hash);                untie(%hash);
           }            }
         } elsif ($direction eq 'firstanswerable') {
             my $furl = &first_answerable_ressymb();
             my $usehttp = &check_http_req(\$furl,$hostname);
             if (($usehttp) && ($hostname ne '')) {
                 $furl='http://'.$hostname.$furl;
             } else {
                 $furl=&Apache::lonnet::absolute_url().$furl;
             }
             &Apache::loncommon::content_type($r,'text/html');
             $r->header_out(Location => $furl);
             return REDIRECT;
         } elsif ($direction eq 'endplacement') {
             &Apache::loncommon::content_type($r,'text/html');
             $r->send_http_header;
             $r->print(&Apache::lonplacementtest::showresult());
             return OK;
       }        }
       if ($env{'request.course.id'}) {        if ($env{'request.course.id'}) {
           # Check if course needs to be re-initialized            # Check if course needs to be re-initialized
Line 463  sub handler { Line 416  sub handler {
               $r->send_http_header;                $r->send_http_header;
               $r->print(&Apache::loncommon::check_release_result(@reinit));                $r->print(&Apache::loncommon::check_release_result(@reinit));
               return OK;                return OK;
           }            } elsif ($reinitcheck eq 'update') {
           my ($cnum,$cdom);                my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};
           if ($reinitcheck) {                my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};
               $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};  
               $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};  
           }  
           if (($reinitcheck eq 'main') || ($reinitcheck eq 'both')) {  
               $preupdatepos = &Apache::lonnet::symbread($currenturl);                $preupdatepos = &Apache::lonnet::symbread($currenturl);
               unless ($direction eq 'return') {                unless ($direction eq 'return') {
                   if (tie(%hash,'GDBM_File',$env{'request.course.fn'}.'_symb.db',                    if (tie(%hash,'GDBM_File',$env{'request.course.fn'}.'_symb.db',
Line 505  sub handler { Line 454  sub handler {
                   }                    }
               }                }
           }            }
           if (($reinitcheck eq 'both') || ($reinitcheck eq 'supp')) {  
               my $possdel;  
               if ($reinitcheck eq 'supp') {  
                   $possdel = 1;  
               }  
               my ($supplemental,$refs_updated) = &Apache::loncommon::get_supplemental($cnum,$cdom,'',$possdel);  
               unless ($refs_updated) {  
                   &Apache::loncommon::set_supp_httprefs($cnum,$cdom,$supplemental);  
               }  
           }  
       }        }
       if ($direction eq 'firstres') {        if ($direction eq 'firstres') {
   my $furl=&first_accessible_resource();    my $furl=&first_accessible_resource();
Line 545  sub handler { Line 484  sub handler {
     $newloc=$hash{'src_'.$id};      $newloc=$hash{'src_'.$id};
     if ($newloc) {      if ($newloc) {
                 $usehttp = &check_http_req(\$newloc,$hostname);                  $usehttp = &check_http_req(\$newloc,$hostname);
                 if ($hash{'encrypted_'.$id}) {   if ($hash{'encrypted_'.$id}) { 
                     $newloc=&Apache::lonenc::encrypted($newloc);                      $newloc=&Apache::lonenc::encrypted($newloc);
                 }                  }
                 if ($newloc =~ m{^(/adm/wrapper/ext/[^\#]+)(?:|(\#[^\#]+))$}) {                  if ($newloc =~ m{^(/adm/wrapper/ext/[^\#]+)(?:|(\#[^\#]+))$}) {
Line 571  sub handler { Line 510  sub handler {
              $r->print(&Apache::loncommon::end_page());               $r->print(&Apache::loncommon::end_page());
              return OK;               return OK;
          } else {           } else {
              &Apache::loncommon::content_type($r,'text/html');       &Apache::loncommon::content_type($r,'text/html');
              $r->header_out(Location => $newloc);       $r->header_out(Location => $newloc);
              return REDIRECT;       return REDIRECT;
          }           }
       }        }
 #  #
Line 592  sub handler { Line 531  sub handler {
      $currenturl=&Apache::lonnet::clutter((&Apache::lonnet::decode_symb($last))[2]);       $currenturl=&Apache::lonnet::clutter((&Apache::lonnet::decode_symb($last))[2]);
  } else {   } else {
              my $newloc = &Apache::lonnet::absolute_url().               my $newloc = &Apache::lonnet::absolute_url().
                           '/adm/navmaps';                            '/adm/navmaps'; 
              if ($reinitcheck eq 'update') {               if ($reinitcheck eq 'update') {
                  &Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state);                   &Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state);
                  $r->print(&reinited_js($newloc,$env{'request.course.id'},100));                   $r->print(&reinited_js($newloc,$env{'request.course.id'},100));
                  $r->print(&Apache::loncommon::end_page());                   $r->print(&Apache::loncommon::end_page());
                  return OK;                   return OK;
              } else {               } else {
                  &Apache::loncommon::content_type($r,'text/html');           &Apache::loncommon::content_type($r,'text/html');
          $r->header_out(Location => $newloc);           $r->header_out(Location => $newloc); 
          return REDIRECT;           return REDIRECT;
              }               }
          }           }
Line 660  sub handler { Line 599  sub handler {
       } else {        } else {
 # -------------------------------------------------------------- No place to go  # -------------------------------------------------------------- No place to go
                   $multichoice=-1;                    $multichoice=-1;
                   if ($position && $env{'request.deeplink.login'}) {                    if ($hash{'deeplinkonly_'.$rid}) {
                       my ($map,$resid,$url) = &Apache::lonnet::decode_symb($position);                        (my $value,$deeplinklevel) = split(/:/,$hash{'deeplinkonly_'.$rid});
                       my $mapid = $hash{'map_pc_'.&Apache::lonnet::clutter($map)};  
                       my $position_deeplink = $hash{'deeplinkonly_'.$mapid.'.'.$resid};  
                       if ($position_deeplink) {  
                           (my $value,$deeplinklevel) = map { &unescape($_); }  
                                                        split(/:/,$position_deeplink);  
                       }  
                   }                    }
               }                }
 # ----------------- The program must come past this point to untie the big hash  # ----------------- The program must come past this point to untie the big hash
Line 710  sub handler { Line 643  sub handler {
                   }                    }
                   if ($reinitcheck eq 'update') {                    if ($reinitcheck eq 'update') {
                       &Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state);                        &Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state);
                       $r->print(&reinited_js($url,$env{'request.course.id'},100));                        $r->print(&reinited_js($url,$env{'request.course.id'},100)); 
                       $r->print(&Apache::loncommon::end_page());                        $r->print(&Apache::loncommon::end_page());
                       return OK;                        return OK;
                   } else {                    } else {
Line 740  sub handler { Line 673  sub handler {
      'type' => 'Type',       'type' => 'Type',
                                                      'update' => 'Content updated',                                                       'update' => 'Content updated',
                                                      'expupdate' => 'As a result of a recent update to the sequence of materials, it is not possible to complete the page flip.',                                                       'expupdate' => 'As a result of a recent update to the sequence of materials, it is not possible to complete the page flip.',
                                                      'gonav' => 'Go to the Contents page to select a resource to display.');                                                       'gonav' => 'Go to the Contents page to select a resource to display.',
                                                        );
                   if (&Apache::loncommon::course_type() eq 'Community') {                    if (&Apache::loncommon::course_type() eq 'Community') {
                       $lt{'nav'} = &mt('Community Contents');                        $lt{'nav'} = &mt('Community Contents');
                   }                    }
Line 786  ENDSTART Line 720  ENDSTART
                                   .'<p>'.$lt{'expupdate'}.'<br />'                                    .'<p>'.$lt{'expupdate'}.'<br />'
                                   .$lt{'gonav'}.'</p>');                                    .$lt{'gonav'}.'</p>');
                       } else {                        } else {
                           $r->print(                            if (($env{'course.'.$env{'request.course.id'}.'.type'} eq 'Placement') && 
                               &Apache::loncommon::start_page('No Resource'));                                (!$env{'request.role.adv'})) {
                           if ($deeplinklevel eq 'resource') {                                my ($score,$incomplete) = &Apache::lonplacementtest::check_completion(undef,undef,1); 
                               $r->print('<h2>'.$lt{'deeplink'}.'</h2>'                                if ($incomplete) {
                                        .'<p>'.$lt{'deeplinkres'}.'</p>');                                    $r->print(&Apache::lonplacementtest::showincomplete($incomplete)); 
                           } elsif ($deeplinklevel eq 'map') {                                } else {
                               $r->print('<h2>'.$lt{'title'}.'</h2>'                                    $r->print(&Apache::lonplacementtest::showresult(1));
                                        .'<p>'.$lt{'deeplinkmap'}.'</p>');                                }
                           } else {                            } else {
                               $r->print('<h2>'.$lt{'title'}.'</h2>'                                $r->print(
                                        .'<p>'.$lt{'explain'}.'</p>');                                    &Apache::loncommon::start_page('No Resource'));
                                 if ($deeplinklevel eq 'resource') {
                                     $r->print('<h2>'.$lt{'deeplink'}.'</h2>'
                                              .'<p>'.$lt{'deeplinkres'}.'</p>');
                                 } elsif ($deeplinklevel eq 'map') {
                                     $r->print('<h2>'.$lt{'title'}.'</h2>'
                                              .'<p>'.$lt{'deeplinkmap'}.'</p>');
                                 } else {
                                     $r->print('<h2>'.$lt{'title'}.'</h2>'
                                              .'<p>'.$lt{'explain'}.'</p>');
                                 }
                           }                            }
                       }                        }
   }    }
                   if ($deeplinklevel) {                    unless (($env{'course.'.$env{'request.course.id'}.'.type'} eq 'Placement') ||
                       $r->print(                            ($env{'request.role.adv'})) {
                           &Apache::lonhtmlcommon::actionbox(                        if ($deeplinklevel) {
                               ['<a href="/adm/flip?postdata=return:">'.$lt{'back'}.'</a>']));                            $r->print(
                   } elsif ((!@possibilities) && ($reinitcheck))  {                                &Apache::lonhtmlcommon::actionbox(
                       $r->print(                                    ['<a href="/adm/flip?postdata=return:">'.$lt{'back'}.'</a>']));
                           &Apache::lonhtmlcommon::actionbox(                        } elsif ((!@possibilities) && ($reinitcheck))  {
                               ['<a href="/adm/navmaps">'.$lt{'nav'}.'</a></li>'                            $r->print(
                               ]));                                &Apache::lonhtmlcommon::actionbox(
                   } else {                                    ['<a href="/adm/navmaps">'.$lt{'nav'}.'</a></li>'
                       $r->print(                                    ]));
                           &Apache::lonhtmlcommon::actionbox(                        } else {
                               ['<a href="/adm/flip?postdata=return:">'.$lt{'back'}.'</a></li>',                            $r->print(
                                '<a href="/adm/navmaps">'.$lt{'nav'}.'</a></li>'                                &Apache::lonhtmlcommon::actionbox(
                               ]));                                    ['<a href="/adm/flip?postdata=return:">'.$lt{'back'}.'</a></li>',
                                      '<a href="/adm/navmaps">'.$lt{'nav'}.'</a></li>'
                                     ]));
                         }
   
                   }                    }
                   $r->print(&Apache::loncommon::end_page());                    $r->print(&Apache::loncommon::end_page());
               
Line 825  ENDSTART Line 773  ENDSTART
               if ($reinitcheck eq 'update') {                if ($reinitcheck eq 'update') {
                   &Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state);                    &Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state);
                   $r->print(&Apache::loncommon::end_page());                    $r->print(&Apache::loncommon::end_page());
               }                } 
               $env{'user.error.msg'}="/adm/flip:bre:0:1:Course Data Missing";                $env{'user.error.msg'}="/adm/flip:bre:0:1:Course Data Missing";
               return HTTP_NOT_ACCEPTABLE;                 return HTTP_NOT_ACCEPTABLE; 
           }            }

Removed from v.1.80.8.13.2.3  
changed lines
  Added in v.1.103


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