Diff for /loncom/interface/lontiny.pm between versions 1.8.2.8 and 1.19

version 1.8.2.8, 2025/02/07 21:42:42 version 1.19, 2023/06/02 01:20:26
Line 79  sub handler { Line 79  sub handler {
                                         $linkprotuser = $ltoken_info{'linkprotuser'};                                          $linkprotuser = $ltoken_info{'linkprotuser'};
                                         $linkprotexit = $ltoken_info{'linkprotexit'};                                          $linkprotexit = $ltoken_info{'linkprotexit'};
                                         $linkprotpbid = $ltoken_info{'linkprotpbid'};                                          $linkprotpbid = $ltoken_info{'linkprotpbid'};
                                         $linkprotpburl = $ltoken_info{'linkprotpburl'};                                          $linkprotpbid = $ltoken_info{'linkprotpburl'};
                                     } elsif ($link_info{'linkprot'}) {                                      } elsif ($link_info{'linkprot'}) {
                                         $linkprot = $link_info{'linkprot'};                                          $linkprot = $link_info{'linkprot'};
                                         if ($link_info{'linkprotuser'}) {                                          if ($link_info{'linkprotuser'}) {
Line 99  sub handler { Line 99  sub handler {
                             }                              }
                             if ($env{'request.course.id'} eq $cdom.'_'.$cnum) {                              if ($env{'request.course.id'} eq $cdom.'_'.$cnum) {
                                 # Check for ttoken                                  # Check for ttoken
                                 my $newlauncher = &launch_check($r->uri,$symb,$cdom,$cnum);                                  my $newlauncher = &launch_check($r->uri,$symb);
                                 my ($map,$resid,$url) = &Apache::lonnet::decode_symb($symb);                                  my ($map,$resid,$url) = &Apache::lonnet::decode_symb($symb);
                                 if (&Apache::lonnet::is_on_map($url)) {                                  if (&Apache::lonnet::is_on_map($url)) {
                                     my ($realuri,$reinitresult,$reinitchecked);                                      my $realuri;
                                     if ((&Apache::lonnet::EXT('resource.0.hiddenresource',$symb) =~ /^yes$/i) &&                                      if ((&Apache::lonnet::EXT('resource.0.hiddenresource',$symb) =~ /^yes$/i) &&
                                         (!$env{'request.role.adv'})) {                                          (!$env{'request.role.adv'})) {
                                         my $loncaparev = $r->dir_config('lonVersion');                                          $env{'user.error.msg'}=$r->uri.':bre:1:1:Access to resource denied';
                                         ($reinitresult,my @reinit) = &Apache::loncommon::needs_coursereinit($loncaparev);                                          return HTTP_NOT_ACCEPTABLE;
                                         $reinitchecked = 1;  
                                         unless (($reinitresult eq 'main') || ($reinitresult eq 'both')) {  
                                             $env{'user.error.msg'}=$r->uri.':bre:1:1:Access to resource denied';  
                                             return HTTP_NOT_ACCEPTABLE;  
                                         }  
                                     }                                      }
                                     if ((&Apache::lonnet::EXT('resource.0.encrypturl',$symb) =~ /^yes$/i) &&                                      if ((&Apache::lonnet::EXT('resource.0.encrypturl',$symb) =~ /^yes$/i) &&
                                         (!$env{'request.role.adv'})) {                                          (!$env{'request.role.adv'})) {
Line 131  sub handler { Line 126  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;
                                     } elsif (($reinitresult eq 'main') || ($reinitresult eq 'both')) {  
                                         $update = 1;  
                                     } else {                                      } else {
                                         if (!$reinitchecked) {                                          my $loncaparev = $r->dir_config('lonVersion');
                                             my $loncaparev = $r->dir_config('lonVersion');                                          ($reinitresult,my @reinit) = &Apache::loncommon::needs_coursereinit($loncaparev);
                                             ($reinitresult,my @reinit) = &Apache::loncommon::needs_coursereinit($loncaparev);  
                                         }  
                                         if (($reinitresult eq 'main') || ($reinitresult eq 'both')) {                                          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') {
Line 170  sub handler { Line 161  sub handler {
                                             $env{'user.error.msg'}=$r->uri.':bre:0:0:Course not initialized';                                              $env{'user.error.msg'}=$r->uri.':bre:0:0:Course not initialized';
                                             $env{'user.reinit'} = 1;                                              $env{'user.reinit'} = 1;
                                             return HTTP_NOT_ACCEPTABLE;                                              return HTTP_NOT_ACCEPTABLE;
                                         } elsif ((&Apache::lonnet::EXT('resource.0.hiddenresource',$symb) =~ /^yes$/i) &&  
                                                  (!$env{'request.role.adv'})) {  
                                             $env{'user.error.msg'}=$r->uri.':bre:1:1:Access to resource denied';  
                                             return HTTP_NOT_ACCEPTABLE;  
                                         }                                          }
                                     }                                      }
                                     if (($reinitresult eq 'both') || ($reinitresult eq 'supp')) {                                      if (($reinitresult eq 'both') || ($reinitresult eq 'supp')) {
Line 320  sub handler { Line 307  sub handler {
 }  }
   
 sub launch_check {  sub launch_check {
     my ($linkuri,$symb,$cdom,$cnum) = @_;      my ($linkuri,$symb) = @_;
     my ($linkprotector,$linkproturi,$linkprotexit,$linkprotpbid,$linkprotpburl,      my ($linkprotector,$linkproturi,$linkprotexit,$linkprotpbid,$linkprotpburl,$linkkey,$newlauncher);
         $linkkey,$newlauncher,$prevlaunch);  
     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 394  sub launch_check { Line 380  sub launch_check {
         if ($link_info{'checklaunch'}) {          if ($link_info{'checklaunch'}) {
             $newlauncher = 1;              $newlauncher = 1;
         }          }
         if ($link_info{'prevlaunch'} ne '') {  
             $prevlaunch = $link_info{'prevlaunch'};  
         }  
     }      }
     my $currdeeplinklogin = $env{'request.deeplink.login'};      my $currdeeplinklogin = $env{'request.deeplink.login'};
     my $deeplink;      my $deeplink;
Line 455  sub launch_check { Line 438  sub launch_check {
         } else {          } else {
             unless ($currdeeplinklogin eq $linkuri) {              unless ($currdeeplinklogin eq $linkuri) {
                 if (($linkprotector) || ($linkkey ne '')) {                  if (($linkprotector) || ($linkkey ne '')) {
                     $newlauncher = 1;                      if ($linkprotector) {
                 }                          &Apache::lonnet::appenv({'request.linkprot' => $linkprotector.':'.$linkproturi});
             }                      } elsif ($env{'request.linkprot'}) {
             if ($linkprotector) {                          &Apache::lonnet::delenv('request.linkprot');
                 &Apache::lonnet::appenv({'request.linkprot' => $linkprotector.':'.$linkproturi});                      }
                 if ($linkprotpburl && $linkprotpbid) {  
                     my ($res,$error) = &store_passback_info($cdom,$cnum,$linkuri,$linkprotector,  
                                                         $scope,$symb,$linkprotpbid,$linkprotpburl,  
                                                         $currdeeplinklogin);  
                 }  
             } elsif ($env{'request.linkprot'}) {  
                 &Apache::lonnet::delenv('request.linkprot');  
             }  
             if ($linkkey ne '') {  
                 &Apache::lonnet::appenv({'request.linkkey' => $linkkey});  
             } elsif ($env{'request.linkkey'} ne '') {  
                 &Apache::lonnet::delenv('request.linkkey');  
             }  
             if (($linkprotector) || ($linkkey ne '')) {  
                 if ($linkprotexit ne $env{'request.linkprotexit'}) {  
                     if ($linkprotexit) {                      if ($linkprotexit) {
                         &Apache::lonnet::appenv({'request.linkprotexit' => $linkprotexit});                          &Apache::lonnet::appenv({'request.linkprotexit' => $linkprotexit});
                     } elsif ($env{'request.linkprotexit'}) {                      } elsif ($env{'request.linkprotexit'}) {
                         &Apache::lonnet::delenv('request.linkprotexit');                          &Apache::lonnet::delenv('request.linkprotexit');
                     }                      }
                 }  
                 if ($linkprotpbid ne $env{'request.linkprotpbid'}) {  
                     if ($linkprotpbid) {                      if ($linkprotpbid) {
                         &Apache::lonnet::appenv({'request.linkprotpbid' => $linkprotpbid});                          &Apache::lonnet::appenv({'request.linkprotpbid' => $linkprotpbid});
                     } elsif ($env{'request.linkprotpbid'}) {                      } elsif ($env{'request.linkprotpbid'}) {
                         &Apache::lonnet::delenv('request.linkprotpbid');                          &Apache::lonnet::delenv('request.linkprotpbid');
                     }                      }
                 }  
                 if ($linkprotpburl ne $env{'request.linkprotpburl'}) {  
                     if ($linkprotpburl) {                      if ($linkprotpburl) {
                         &Apache::lonnet::appenv({'request.linkprotpburl' => $linkprotpburl});                          &Apache::lonnet::appenv({'request.linkprotpburl' => $linkprotpburl});
                     } elsif ($env{'request.linkprotpburl'}) {                      } elsif ($env{'request.linkprotpburl'}) {
                         &Apache::lonnet::delenv('request.linkprotpburl');                          &Apache::lonnet::delenv('request.linkprotpburl');
                     }                      }
                 }                      if ($linkkey ne '') {
             } elsif ($prevlaunch) {                          &Apache::lonnet::appenv({'request.linkkey' => $linkkey});
                 foreach my $requestkey ('linkprotpbid','linkprotpburl','linkprotexit') {                      } elsif ($env{'request.linkkey'} ne '') {
                     if ($env{"request.$requestkey"}) {                          &Apache::lonnet::delenv('request.linkkey');
                         &Apache::lonnet::delenv("request.$requestkey");  
                     }                      }
                       $newlauncher = 1;
                 }                  }
             }              }
             &Apache::lonnet::appenv({'request.deeplink.login' => $linkuri});              &Apache::lonnet::appenv({'request.deeplink.login' => $linkuri});
Line 543  sub launch_check { Line 507  sub launch_check {
     return $newlauncher;      return $newlauncher;
 }  }
   
 #  
 # Store linkprotpburl and linkprotpbid in user's nohist_$cid_linkprot_pb.db  
 # $linkuri\0$linkprotector\0$scope = [$linkprotpbid,$linkprotpburl]  
 # Separately store $symb in course's nohist_linkprot_passback.db  
 # which should trigger passback:  
 # $symb => {$linkuri\0$linkprotector\0$scope => 1};  
 #  
   
 sub store_passback_info {  
     my ($cdom,$cnum,$linkuri,$linkprotector,$scope,$symb,  
         $linkprotpbid,$linkprotpburl,$currdeeplinklogin) = @_;  
     my $key = join("\0",($linkuri,$linkprotector,$scope));  
     my $namespace = 'nohist_'.$cdom.'_'.$cnum.'_linkprot_pb';  
     if ($linkuri eq $currdeeplinklogin) {  
         my %pbinfo = &Apache::lonnet::get($namespace,[$key]);  
         if (ref($pbinfo{$key}) eq 'ARRAY') {  
             if (($pbinfo{$key}[0] eq $linkprotpbid) &&  
                 ($pbinfo{$key}[1] eq $linkprotpburl)) {  
                 return ('ok');  
             }  
         }  
     }  
     my $now = time;  
     my $result = &Apache::lonnet::cput($namespace,{$key => [$linkprotpbid,$linkprotpburl]});  
     my $error;  
     if (($result eq 'ok') || ($result eq 'con_delayed')) {  
         $namespace = 'nohist_linkprot_passback';  
         my %triggers = &Apache::lonnet::get($namespace,[$symb],$cdom,$cnum);  
         my $newtrigger;  
         if ((exists($triggers{$symb})) && (ref($triggers{$symb}) eq 'HASH')) {  
             unless (exists($triggers{$symb}{$key})) {  
                 $newtrigger = 1;  
             }  
         } else {  
             $newtrigger = 1;  
         }  
         if ($newtrigger) {  
             my ($lockhash,$tries,$gotlock);  
             $lockhash = {  
                           lock => $env{'user.name'}.  
                                   ':'.$env{'user.domain'},  
                         };  
             $tries = 0;  
             $gotlock = &Apache::lonnet::newput($namespace,$lockhash,$cdom,$cnum);  
             while (($gotlock ne 'ok') && ($tries<10)) {  
                 $tries ++;  
                 sleep (0.1);  
                 $gotlock = &Apache::lonnet::newput($namespace,$lockhash,$cdom,$cnum);  
             }  
             if ($gotlock eq 'ok') {  
                 %triggers = &Apache::lonnet::get($namespace,[$symb],$cdom,$cnum);  
                 $triggers{$symb}{$key} = 1;  
                 $result = &Apache::lonnet::cput($namespace,{$symb => $triggers{$symb}},$cdom,$cnum);  
                 my $dellockoutcome = &Apache::lonnet::del($namespace,['lock'],$cdom,$cnum);  
             } else {  
                 $error = 'nolock';  
             }  
         }  
     }  
     return ($result,$error);  
 }  
   
 sub do_redirect {  sub do_redirect {
     my ($r,$destination,$linkprot) = @_;      my ($r,$destination,$linkprot) = @_;
     my $windowname = 'loncapaclient';      my $windowname = 'loncapaclient';

Removed from v.1.8.2.8  
changed lines
  Added in v.1.19


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