Diff for /loncom/interface/lontiny.pm between versions 1.14 and 1.17

version 1.14, 2022/07/02 17:23:02 version 1.17, 2022/10/19 18:09:04
Line 118  sub handler { Line 118  sub handler {
                                             $realuri .= '?symb='.$symb;                                              $realuri .= '?symb='.$symb;
                                         }                                          }
                                     }                                      }
                                     my $update;                                      my ($update,$reinitresult);
                                     # Check if course needs to be re-initialized                                      # Check if course needs to be re-initialized
                                     if ($newlauncher) {                                      if ($newlauncher) {
                                         $update = 1;                                          $update = 1;
                                     } else {                                      } else {
                                         my $loncaparev = $r->dir_config('lonVersion');                                          my $loncaparev = $r->dir_config('lonVersion');
                                         my ($result,@reinit) = &Apache::loncommon::needs_coursereinit($loncaparev);                                          ($reinitresult,my @reinit) = &Apache::loncommon::needs_coursereinit($loncaparev);
                                         if ($result eq 'update') {                                          if (($reinitresult eq 'main') || ($reinitresult eq 'both')) {
                                             $update = 1;                                              $update = 1;
                                         } elsif (!-e $env{'request.course.fn'}.'.db') {                                          } elsif (!-e $env{'request.course.fn'}.'.db') {
                                             $update = 1;                                              $update = 1;
Line 155  sub handler { Line 155  sub handler {
                                             return HTTP_NOT_ACCEPTABLE;                                              return HTTP_NOT_ACCEPTABLE;
                                         }                                          }
                                     }                                      }
                                       if (($reinitresult eq 'both') || ($reinitresult eq 'supp')) {
                                           my $possdel;
                                           if ($reinitresult eq 'supp') {
                                               $possdel = 1;
                                           }
                                           my ($supplemental,$refs_updated) = &Apache::lonnet::get_supplemental($cnum,$cdom,'',$possdel);
                                           unless ($refs_updated) {
                                               &Apache::loncommon::set_supp_httprefs($cnum,$cdom,$supplemental,$possdel);
                                           }
                                       }
                                     my $host = $r->headers_in->get('Host');                                      my $host = $r->headers_in->get('Host');
                                     if (!$host) {                                      if (!$host) {
                                         $r->internal_redirect($realuri);                                          $r->internal_redirect($realuri);
Line 250  sub handler { Line 260  sub handler {
                                         $destination .= '&ttoken='.$env{'form.ttoken'};                                          $destination .= '&ttoken='.$env{'form.ttoken'};
                                     }                                      }
                                     &do_redirect($r,$destination,$linkprot);                                      &do_redirect($r,$destination,$linkprot);
                                 } elsif (keys(%possroles) > 1) {                                  } elsif (@allposs > 1) {
                                     if (grep(/^(cc|co)$/,@allposs)) {                                      if (grep(/^(cc|co)$/,@allposs)) {
                                         my $newrole;                                          my $newrole;
                                         if (exists($possroles{'cc'})) {                                          if (exists($possroles{'cc'})) {
Line 270  sub handler { Line 280  sub handler {
                                         if (grep(/^cr\//,@allposs)) {                                          if (grep(/^cr\//,@allposs)) {
                                             $hascustom = 1;                                              $hascustom = 1;
                                         }                                          }
                                         &show_roles($r,\%crsenv,\%possroles,$hassection,$hascustom);                                          &show_roles($r,\%crsenv,\%active,$hassection,$hascustom);
                                     }                                      }
                                 }                                  }
                                 return OK;                                  return OK;
Line 289  sub handler { Line 299  sub handler {
   
 sub launch_check {  sub launch_check {
     my ($linkuri,$symb) = @_;      my ($linkuri,$symb) = @_;
     my ($linkprotector,$linkproturi,$linkkey,$newlauncher);      my ($linkprotector,$linkproturi,$linkprotexit,$linkkey,$newlauncher);
     if ($env{'form.ttoken'}) {      if ($env{'form.ttoken'}) {
         my %link_info = &Apache::lonnet::tmpget($env{'form.ttoken'});          my %link_info = &Apache::lonnet::tmpget($env{'form.ttoken'});
         &Apache::lonnet::tmpdel($env{'form.ttoken'});          &Apache::lonnet::tmpdel($env{'form.ttoken'});
Line 327  sub launch_check { Line 337  sub launch_check {
             } else {              } else {
                 &Apache::lonnet::appenv({'user.linkproturi' => $linkproturi});                  &Apache::lonnet::appenv({'user.linkproturi' => $linkproturi});
             }              }
               if ($link_info{'linkprotexit'}) {
                   $linkprotexit = $link_info{'linkprotexit'};
               }
         } elsif ($link_info{'linkkey'} ne '') {          } elsif ($link_info{'linkkey'} ne '') {
             $linkkey = $link_info{'linkkey'};              $linkkey = $link_info{'linkkey'};
             my $keyedlinkuri = $linkuri;              my $keyedlinkuri = $linkuri;
Line 366  sub launch_check { Line 379  sub launch_check {
     }      }
     if ($deeplink ne '') {      if ($deeplink ne '') {
         my $disallow;          my $disallow;
         my ($state,$others,$listed,$scope,$protect,$display,$target) = split(/,/,$deeplink);          my ($state,$others,$listed,$scope,$protect,$display,$target,$exit) = split(/,/,$deeplink);
         if (($protect ne 'none') && ($protect ne '')) {          if (($protect ne 'none') && ($protect ne '')) {
             my ($acctype,$item) = split(/:/,$protect);              my ($acctype,$item) = split(/:/,$protect);
             if ($acctype =~ /lti(c|d)$/) {              if ($acctype =~ /lti(c|d)$/) {
Line 394  sub launch_check { Line 407  sub launch_check {
                 if ($env{'request.deeplink.target'} ne '') {                  if ($env{'request.deeplink.target'} ne '') {
                     &Apache::lonnet::delenv('request.deeplink.target');                      &Apache::lonnet::delenv('request.deeplink.target');
                 }                  }
                   if ($env{'request.linkprot'} ne '') {
                       &Apache::lonnet::delenv('request.linkprot');
                   }
                   if ($env{'request.linkprotexit'} ne '') {
                       &Apache::lonnet::delenv('request.linkprotexit');
                   }
             }              }
         } else {          } else {
             unless ($currdeeplinklogin eq $linkuri) {              unless ($currdeeplinklogin eq $linkuri) {
Line 403  sub launch_check { Line 422  sub launch_check {
                     } elsif ($env{'request.linkprot'}) {                      } elsif ($env{'request.linkprot'}) {
                         &Apache::lonnet::delenv('request.linkprot');                          &Apache::lonnet::delenv('request.linkprot');
                     }                      }
                       if ($linkprotexit) {
                           &Apache::lonnet::appenv({'request.linkprotexit' => $linkprotexit});
                       } elsif ($env{'request.linkprotexit'}) {
                           &Apache::lonnet::delenv('request.linkprotexit');
                       }
                     if ($linkkey ne '') {                      if ($linkkey ne '') {
                         &Apache::lonnet::appenv({'request.linkkey' => $linkkey});                          &Apache::lonnet::appenv({'request.linkkey' => $linkkey});
                     } elsif ($env{'request.linkkey'} ne '') {                      } elsif ($env{'request.linkkey'} ne '') {
Line 424  sub launch_check { Line 448  sub launch_check {
         } elsif ($env{'request.linkprot'}) {          } elsif ($env{'request.linkprot'}) {
             &Apache::lonnet::delenv('request.linkprot');              &Apache::lonnet::delenv('request.linkprot');
         }          }
           if ($linkprotexit) {
               &Apache::lonnet::appenv({'request.linkprotexit' => $linkprotexit});
           } elsif ($env{'request.linkprotexit'}) {
               &Apache::lonnet::delenv('request.linkprotexit');
           }
         if ($linkkey ne '') {          if ($linkkey ne '') {
             &Apache::lonnet::appenv({'request.linkkey' => $linkkey});              &Apache::lonnet::appenv({'request.linkkey' => $linkkey});
         } else {          } else {

Removed from v.1.14  
changed lines
  Added in v.1.17


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