Diff for /loncom/interface/lontiny.pm between versions 1.1 and 1.23

version 1.1, 2018/01/12 13:33:38 version 1.23, 2024/11/17 04:48:15
Line 35  use Apache::lonnet; Line 35  use Apache::lonnet;
 use Apache::loncommon;  use Apache::loncommon;
 use Apache::lonhtmlcommon;  use Apache::lonhtmlcommon;
 use Apache::lonroles;  use Apache::lonroles;
   use Apache::lonuserstate;
   use Apache::lonnavmaps;
 use Apache::lonlocal;  use Apache::lonlocal;
 use LONCAPA qw(:DEFAULT :match);  use LONCAPA qw(:DEFAULT :match);
   
Line 42  sub handler { Line 44  sub handler {
     my $r = shift;      my $r = shift;
     my %user;      my %user;
     my $handle = &Apache::lonnet::check_for_valid_session($r,undef,\%user);      my $handle = &Apache::lonnet::check_for_valid_session($r,undef,\%user);
     if ($handle ne '') {       if ($handle ne '') {
           my $lonidsdir=$r->dir_config('lonIDsDir');
           &Apache::lonnet::transfer_profile_to_env($lonidsdir,$handle);
         if ($r->uri =~ m{^/tiny/($match_domain)/(\w+)$}) {          if ($r->uri =~ m{^/tiny/($match_domain)/(\w+)$}) {
             my ($cdom,$key) = ($1,$2);              my ($cdom,$key) = ($1,$2);
             if (&Apache::lonnet::domain($cdom) ne '') {              if (&Apache::lonnet::domain($cdom) ne '') {
Line 63  sub handler { Line 67  sub handler {
                     if ($cnum =~ /^$match_courseid$/) {                      if ($cnum =~ /^$match_courseid$/) {
                         my $chome = &Apache::lonnet::homeserver($cnum,$cdom);                          my $chome = &Apache::lonnet::homeserver($cnum,$cdom);
                         if ($chome ne 'no_host') {                          if ($chome ne 'no_host') {
                             my %crsenv = &Apache::lonnet::coursedescription("$cdom/$cnum");                              &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['ttoken']);
                             my @possroles = ('in','ta','ep','st','cr','ad');                              my ($linkprot,$linkprotuser,$linkprotexit,$ltoken,$linkprotpbid,$linkprotpburl);
                             if ($crsenv{'type'} eq 'Community') {                              if ($env{'form.ttoken'}) {
                                 unshift(@possroles,'co');                                  my %link_info = &Apache::lonnet::tmpget($env{'form.ttoken'});
                             } else {                                  if ($link_info{'origurl'} eq $r->uri) {
                                 unshift(@possroles,'cc');                                      if ($link_info{'ltoken'}) {
                             }                                          $ltoken = $link_info{'ltoken'};
                             my %roleshash = &Apache::lonnet::get_my_roles($env{'user.uname'},                                          my %ltoken_info = &Apache::lonnet::tmpget($link_info{'ltoken'});
                                                                           $env{'user.domain'},                                          $linkprot = $ltoken_info{'linkprot'};
                                                                           'userroles',undef,                                          $linkprotuser = $ltoken_info{'linkprotuser'};
                                                                           \@possroles,[$cdom],1);                                          $linkprotexit = $ltoken_info{'linkprotexit'};
                             my (%possroles,$hassection);                                          $linkprotpbid = $ltoken_info{'linkprotpbid'};
                             if (keys(%roleshash)) {                                          $linkprotpburl = $ltoken_info{'linkprotpburl'};
                                 foreach my $entry (keys(%roleshash)) {                                      } elsif ($link_info{'linkprot'}) {
                                     if ($entry =~ /^\Q$cnum:$cdom:\E([^:]+):([^:]*)$/) {                                          $linkprot = $link_info{'linkprot'};
                                         $possroles{$1} = $2;                                          if ($link_info{'linkprotuser'}) {
                                         if ($2 ne '') {                                              $linkprotuser = $link_info{'linkprotuser'};
                                             $hassection = 1;                                          }
                                           if ($link_info{'linkprotexit'}) {
                                               $linkprotexit = $link_info{'linkprotexit'};
                                           }
                                           if ($link_info{'linkprotpbid'}) {
                                               $linkprotpbid = $link_info{'linkprotpbid'};
                                           }
                                           if ($link_info{'linkprotpburl'}) {
                                               $linkprotpburl = $link_info{'linkprotpburl'};
                                         }                                          }
                                     }                                      }
                                 }                                  }
                             }                              }
                             my @allposs = keys(%possroles);                              if ($env{'request.course.id'} eq $cdom.'_'.$cnum) {
                             if (@allposs == 0) {                                  # Check for ttoken
                                 &show_roles($r,\%crsenv,\%possroles)                                  my $newlauncher = &launch_check($r->uri,$symb,$cdom,$cnum);
                             } elsif (@allposs == 1) {                                  my ($map,$resid,$url) = &Apache::lonnet::decode_symb($symb);
                                 my $newrole = "$allposs[0]./$cdom/$cnum";                                  if (&Apache::lonnet::is_on_map($url)) {
                                 $newrole = "$allposs[0]./$cdom/$cnum";                                      my $realuri;
                                 if ($possroles{$allposs[0]} ne '') {                                      if ((&Apache::lonnet::EXT('resource.0.hiddenresource',$symb) =~ /^yes$/i) &&
                                     $newrole .= "/$possroles{$allposs[0]}";                                           (!$env{'request.role.adv'})) {
                                 }                                          $env{'user.error.msg'}=$r->uri.':bre:1:1:Access to resource denied';
                                 my $destination .= '/adm/roles?selectrole=1&'.$newrole.'=1'.                                          return HTTP_NOT_ACCEPTABLE;
                                                    '&destinationurl='.&HTML::Entities::encode($r->uri);                                      }
                                 &do_redirect($r,$destination);                                      if ((&Apache::lonnet::EXT('resource.0.encrypturl',$symb) =~ /^yes$/i) &&
                             } elsif (keys(%possroles) > 1) {                                          (!$env{'request.role.adv'})) {
                                 if (grep(/^(cc|co)$/,@allposs)) {                                          $realuri = &Apache::lonenc::encrypted(&Apache::lonnet::clutter($url));
                                     my $newrole;                                          if (($url =~ /\.sequence$/) &&
                                     if (exists($possroles{'cc'})) {                                              ($env{'course.'.$env{'request.course.id'}.'.type'} ne 'Placement')) {
                                         $newrole = 'cc';                                              $realuri .= '?navmap=1';
                                           } else {
                                               $realuri .= '?symb='.&Apache::lonenc::encrypted($symb);
                                           }
                                     } else {                                      } else {
                                         $newrole = 'co';                                          $realuri = &Apache::lonnet::clutter($url);
                                           if (($url =~ /\.sequence$/) &&
                                               ($env{'course.'.$env{'request.course.id'}.'.type'} ne 'Placement')) {
                                               $realuri .= '?navmap=1';
                                           } else {
                                               $realuri .= '?symb='.$symb;
                                           }
                                     }                                      }
                                     $newrole .= "./$cdom/$cnum";                                      my ($update,$reinitresult);
                                     my $destination .= '/adm/roles?selectrole=1&'.$newrole.'=1'.                                      # Check if course needs to be re-initialized
                                                        '&destinationurl='.&HTML::Entities::encode($r->uri);                                      if ($newlauncher) {
                                     &do_redirect($r,$destination);                                          $update = 1;
                                       } else {
                                           my $loncaparev = $r->dir_config('lonVersion');
                                           ($reinitresult,my @reinit) = &Apache::loncommon::needs_coursereinit($loncaparev);
                                           if (($reinitresult eq 'main') || ($reinitresult eq 'both')) {
                                               $update = 1;
                                           } elsif (!-e $env{'request.course.fn'}.'.db') {
                                               $update = 1;
                                           } elsif (!$env{'request.role.adv'}) {
                                               my $navmap = Apache::lonnavmaps::navmap->new();
                                               if (ref($navmap)) {
                                                   my $res = $navmap->getBySymb($symb);
                                                   if (ref($res)) {
                                                       my ($enc_in_bighash,$enc_in_parm);
                                                       $enc_in_bighash = $res->encrypted();
                                                       if (&Apache::lonnet::EXT('resource.0.encrypturl',$symb) =~ /^yes$/i) {
                                                           $enc_in_parm = 1;
                                                       }
                                                       if ($enc_in_bighash ne $enc_in_parm) {
                                                           $update = 1;
                                                       }
                                                   }
                                               }
                                           }
                                       }
                                       if ($update) {
                                           my ($furl,$ferr)=
                                               &Apache::lonuserstate::readmap($cdom.'/'.$cnum);
                                           if ($ferr) {
                                               $env{'user.error.msg'}=$r->uri.':bre:0:0:Course not initialized';
                                               $env{'user.reinit'} = 1;
                                               return HTTP_NOT_ACCEPTABLE;
                                           }
                                       }
                                       if (($reinitresult eq 'both') || ($reinitresult eq 'supp')) {
                                           my $possdel;
                                           if ($reinitresult 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,$possdel);
                                           }
                                       }
                                       my $host = $r->headers_in->get('Host');
                                       if (!$host) {
                                           $r->internal_redirect($realuri);
                                           return OK;
                                       } else {
                                           my $protocol = 'http';
                                           if ($r->get_server_port == 443) {
                                               $protocol = 'https';
                                           }
                                           my $location = $protocol.'://'.$host.$realuri;
                                           $r->headers_out->set(Location => $location);
                                           return REDIRECT;
                                       }
                                   }
                               } else {
                                   my %crsenv = &Apache::lonnet::coursedescription("$cdom/$cnum");
                                   my @possroles = ('in','ta','ep','st','cr','ad');
                                   if ($crsenv{'type'} eq 'Community') {
                                       unshift(@possroles,'co');
                                 } else {                                  } else {
                                     my $hascustom;                                      unshift(@possroles,'cc');
                                     if (grep(/^cr\//,@allposs)) {                                  }
                                         $hascustom = 1;                                  my %roleshash =
                                       &Apache::lonnet::get_my_roles($env{'user.uname'},$env{'user.domain'},
                                                                     'userroles',['previous','active','future'],
                                                                     \@possroles,[$cdom],1);
                                   my (%possroles,$hassection,%active,%expired,%future);
                                   if (keys(%roleshash)) {
                                       my $now = time;
                                       foreach my $entry (keys(%roleshash)) {
                                           if ($entry =~ /^\Q$cnum:$cdom:\E([^:]+):([^:]*)$/) {
                                               my ($role,$sec) = ($1,$2);
                                               $possroles{$role} = $sec;
                                               if ($sec ne '') {
                                                   $hassection = 1;
                                               }
                                               my ($tstart,$tend)=split(/\:/,$roleshash{$entry});
                                               my $status = 'active';
                                               if (($tend) && ($tend<=$now)) {
                                                   $status = 'previous';
                                               }
                                               if (($tstart) && ($now<$tstart)) {
                                                   $status = 'future';
                                               }
                                               if ($status eq 'active') {
                                                   $active{$role} = $sec;
                                               } elsif ($status eq 'previous') {
                                                   $expired{$tend} = $role.':'.$sec;
                                               } elsif ($status eq 'future') {
                                                   $future{$tstart} = $role.':'.$sec;
                                               }
                                           }
                                     }                                      }
                                     &show_roles($r,\%crsenv,\%possroles,$hassection,$hascustom);  
                                 }                                  }
                                   my @allposs = keys(%active);
                                   if ($env{'request.lti.login'}) {
                                       &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'});
                                       if ($env{'request.lti.target'} eq '') {
                                           if ($env{'form.ltitarget'} eq 'iframe') {
                                               &Apache::lonnet::appenv({'request.lti.target' => 'iframe'});
                                               delete($env{'form.ltitarget'});
                                           }
                                       }
                                       if ($env{'form.selectrole'}) {
                                           foreach my $role (@allposs) {
                                               my $newrole = "$role./$cdom/$cnum";
                                               if ($possroles{$allposs[0]} ne '') {
                                                   $newrole .= "/$possroles{$role}";
                                               }
                                               if ($env{"form.$newrole"}) {
                                                   my $destination .= '/adm/roles?selectrole=1&'.$newrole.'=1'.
                                                                      '&destinationurl='.&HTML::Entities::encode($r->uri,'&<>"');
                                                   if ($env{'form.ltitarget'} eq 'iframe') {
                                                       $destination .= '&ltitarget=iframe';
                                                   }
                                                   &do_redirect($r,$destination);
                                                   return OK;
                                               }
                                           }
                                       }
                                   }
                                   if (@allposs == 0) {
                                       &show_roles($r,\%crsenv,\%active,'','',\%future,\%expired,$linkprot,$linkprotuser,
                                                   $linkprotexit,$linkprotpbid,$linkprotpburl,$ltoken);
                                   } elsif (@allposs == 1) {
                                       my $newrole = "$allposs[0]./$cdom/$cnum";
                                       $newrole = "$allposs[0]./$cdom/$cnum";
                                       if ($possroles{$allposs[0]} ne '') {
                                           $newrole .= "/$possroles{$allposs[0]}";
                                       }
                                       my $destination .= '/adm/roles?selectrole=1&'.$newrole.'=1'.
                                                          '&destinationurl='.&HTML::Entities::encode($r->uri,'&<>"');
                                       if ($env{'form.ttoken'}) {
                                           $destination .= '&ttoken='.$env{'form.ttoken'};
                                       }
                                       &do_redirect($r,$destination,$linkprot);
                                   } elsif (@allposs > 1) {
                                       if (grep(/^(cc|co)$/,@allposs)) {
                                           my $newrole;
                                           if (exists($possroles{'cc'})) {
                                               $newrole = 'cc';
                                           } else {
                                               $newrole = 'co';
                                           }
                                           $newrole .= "./$cdom/$cnum";
                                           my $destination .= '/adm/roles?selectrole=1&'.$newrole.'=1'.
                                                              '&destinationurl='.&HTML::Entities::encode($r->uri,'&<>"');
                                           if ($env{'form.ttoken'}) {
                                               $destination .= '&ttoken='.$env{'form.ttoken'};
                                           }
                                           &do_redirect($r,$destination,$linkprot);
                                       } else {
                                           my $hascustom;
                                           if (grep(/^cr\//,@allposs)) {
                                               $hascustom = 1;
                                           }
                                           &show_roles($r,\%crsenv,\%active,$hassection,$hascustom);
                                       }
                                   }
                                   return OK;
                             }                              }
                             return OK;  
                         }                          }
                     }                      }
                 }                  }
Line 130  sub handler { Line 306  sub handler {
     }      }
 }  }
   
   sub launch_check {
       my ($linkuri,$symb,$cdom,$cnum) = @_;
       my ($linkprotector,$linkproturi,$linkprotexit,$linkprotpbid,$linkprotpburl,
           $linkkey,$newlauncher,$prevlaunch);
       if ($env{'form.ttoken'}) {
           my %link_info = &Apache::lonnet::tmpget($env{'form.ttoken'});
           &Apache::lonnet::tmpdel($env{'form.ttoken'});
           delete($env{'form.ttoken'});
           if ($link_info{'ltoken'}) {
               unless (($link_info{'linkprot'}) || ($link_info{'linkkey'} ne '')) {
                   my %ltoken_info = &Apache::lonnet::tmpget($link_info{'ltoken'});
                   if ($ltoken_info{'linkprot'}) {
                       $link_info{'linkprot'} = $ltoken_info{'linkprot'};
                   } elsif ($ltoken_info{'linkkey'} ne '') {
                       $link_info{'linkkey'} = $ltoken_info{'linkkey'};
                   }
               }
               &Apache::lonnet::tmpdel($link_info{'ltoken'});
           }
           if ($link_info{'linkprot'}) {
               ($linkprotector,$linkproturi) = split(/:/,$link_info{'linkprot'},2);
               if ($env{'user.linkprotector'}) {
                   my @protectors = split(/,/,$env{'user.linkprotector'});
                   unless (grep(/^\Q$linkprotector\E$/,@protectors)) {
                       push(@protectors,$linkprotector);
                       @protectors = sort { $a <=> $b } @protectors;
                       &Apache::lonnet::appenv({'user.linkprotector' => join(',',@protectors)});
                   }
               } else {
                   &Apache::lonnet::appenv({'user.linkprotector' => $linkprotector });
               }
               if ($env{'user.linkproturi'}) {
                   my @proturis = split(/,/,$env{'user.linkproturi'});
                   unless(grep(/^\Q$linkproturi\E$/,@proturis)) {
                       push(@proturis,$linkproturi);
                       @proturis = sort(@proturis);
                       &Apache::lonnet::appenv({'user.linkproturi' => join(',',@proturis)});
                   }
               } else {
                   &Apache::lonnet::appenv({'user.linkproturi' => $linkproturi});
               }
               if ($link_info{'linkprotexit'}) {
                   $linkprotexit = $link_info{'linkprotexit'};
               }
               if ($link_info{'linkprotpbid'}) {
                   $linkprotpbid = $link_info{'linkprotpbid'};
               }
               if ($link_info{'linkprotpburl'}) {
                   $linkprotpburl = $link_info{'linkprotpburl'};
               }
           } elsif ($link_info{'linkkey'} ne '') {
               $linkkey = $link_info{'linkkey'};
               my $keyedlinkuri = $linkuri;
               if ($env{'user.deeplinkkey'} ne '') {
                   my @linkkeys = split(/,/,$env{'user.deeplinkkey'});
                   unless (grep(/^\Q$linkkey\E$/,@linkkeys)) {
                       push(@linkkeys,$linkkey);
                       &Apache::lonnet::appenv({'user.deeplinkkey' => join(',',sort(@linkkeys))});
                   }
               } else {
                   &Apache::lonnet::appenv({'user.deeplinkkey' => $linkkey});
               }
               if ($env{'user.keyedlinkuri'}) {
                   my @keyeduris = split(/,/,$env{'user.keyedlinkuri'});
                   unless (grep(/^\Q$keyedlinkuri\E$/,@keyeduris)) {
                       push(@keyeduris,$keyedlinkuri);
                       &Apache::lonnet::appenv({'user.keyedlinkuri' => join(',',sort(@keyeduris))});
                   }
               } else {
                   &Apache::lonnet::appenv({'user.keyedlinkuri' => $keyedlinkuri});
               }
           }
           if ($link_info{'checklaunch'}) {
               $newlauncher = 1;
           }
           if ($link_info{'prevlaunch'} ne '') {
               $prevlaunch = $link_info{'prevlaunch'};
           }
       }
       my $currdeeplinklogin = $env{'request.deeplink.login'};
       my $deeplink;
       if ($symb =~ /\.(page|sequence)$/) {
           my $mapname = &Apache::lonnet::deversion((&Apache::lonnet::decode_symb($symb))[2]);
           my $navmap = Apache::lonnavmaps::navmap->new();
           if (ref($navmap)) {
               $deeplink = $navmap->get_mapparam(undef,$mapname,'0.deeplink');
           }
       } else {
           $deeplink = &Apache::lonnet::EXT('resource.0.deeplink',$symb);
       }
       if ($deeplink ne '') {
           my $disallow;
           my ($state,$others,$listed,$scope,$protect,$display,$target,$exit) = split(/,/,$deeplink);
           if (($protect ne 'none') && ($protect ne '')) {
               my ($acctype,$item) = split(/:/,$protect);
               if ($acctype =~ /lti(c|d)$/) {
                   my $ltitype = $1;
                   if ($linkprotector) {
                       unless ($linkprotector.':'.$linkproturi eq $item.$ltitype.':'.$linkuri) {
                           $disallow = 1;
                       }
                   } else {
                       $disallow = 1;
                   }
               } elsif ($acctype eq 'key') {
                   if ($linkkey ne '') {
                       unless ($linkkey eq $item) {
                           $disallow = 1;
                       }
                   } else {
                       $disallow = 1;
                   }
               }
           }
           if ($disallow) {
               if ($currdeeplinklogin eq $linkuri) {
                   &Apache::lonnet::delenv('request.deeplink.login');
                   if ($env{'request.deeplink.target'} ne '') {
                       &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');
                   }
                   if ($env{'request.linkprotpbid'} ne '') {
                       &Apache::lonnet::delenv('request.linkprotpbid');
                   }
                   if ($env{'request.linkprotpburl'} ne '') {
                       &Apache::lonnet::delenv('request.linkprotpburl');
                   }
               }
           } else {
               unless ($currdeeplinklogin eq $linkuri) {
                   if (($linkprotector) || ($linkkey ne '')) {
                       $newlauncher = 1;
                   }
               }
               if ($linkprotector) {
                   &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) {
                           &Apache::lonnet::appenv({'request.linkprotexit' => $linkprotexit});
                       } elsif ($env{'request.linkprotexit'}) {
                           &Apache::lonnet::delenv('request.linkprotexit');
                       }
                   }
                   if ($linkprotpbid ne $env{'request.linkprotpbid'}) {
                       if ($linkprotpbid) {
                           &Apache::lonnet::appenv({'request.linkprotpbid' => $linkprotpbid});
                       } elsif ($env{'request.linkprotpbid'}) {
                           &Apache::lonnet::delenv('request.linkprotpbid');
                       }
                   }
                   if ($linkprotpburl ne $env{'request.linkprotpburl'}) {
                       if ($linkprotpburl) {
                           &Apache::lonnet::appenv({'request.linkprotpburl' => $linkprotpburl});
                       } elsif ($env{'request.linkprotpburl'}) {
                           &Apache::lonnet::delenv('request.linkprotpburl');
                       }
                   }
               } elsif ($prevlaunch) {
                   foreach my $requestkey ('linkprotpbid','linkprotpburl','linkprotexit') {
                       if ($env{"request.$requestkey"}) {
                           &Apache::lonnet::delenv("request.$requestkey");
                       }
                   }
               }
               &Apache::lonnet::appenv({'request.deeplink.login' => $linkuri});
               if ($target ne '') {
                   &Apache::lonnet::appenv({'request.deeplink.target' => $target});
               } elsif ($env{'request.deeplink.target'} ne '') {
                   &Apache::lonnet::delenv('request.deeplink.target');
               }
           }
       } else {
           if ($linkprotector) {
               &Apache::lonnet::appenv({'request.linkprot' => $linkprotector.':'.$linkproturi});
           } elsif ($env{'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 ($linkprotpbid) {
               &Apache::lonnet::appenv({'request.linkprotpbid' => $linkprotpbid});
           } elsif ($env{'request.linkprotpbid'}) {
               &Apache::lonnet::delenv('request.linkprotpbid');
           }
           if ($linkprotpburl) {
               &Apache::lonnet::appenv({'request.linkprotpburl' => $linkprotpburl});
           } elsif ($env{'request.linkprotpburl'}) {
               &Apache::lonnet::delenv('request.linkprotpburl');
           }
           if ($linkkey ne '') {
               &Apache::lonnet::appenv({'request.linkkey' => $linkkey});
           } else {
               &Apache::lonnet::delenv('request.linkkey');
           }
           &Apache::lonnet::appenv({'request.deeplink.login' => $linkuri});
           if ($env{'request.deeplink.target'} ne '') {
               &Apache::lonnet::delenv('request.deeplink.target');
           }
       }
       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) = @_;      my ($r,$destination,$linkprot) = @_;
     my $windowinfo = Apache::lonhtmlcommon::scripttag('self.name="loncapaclient";');      my $windowname = 'loncapaclient';
       if ($env{'request.lti.login'}) {
           $windowname .= 'lti';
       }
     my $header = '<meta HTTP-EQUIV="Refresh" CONTENT="0; url='.$destination.'" />';      my $header = '<meta HTTP-EQUIV="Refresh" CONTENT="0; url='.$destination.'" />';
     my $args = {'bread_crumbs' => [{'href' => '','text' => 'Role initialization'},],};      my $args = {'bread_crumbs' => [{'href' => '','text' => 'Role initialization'},],};
       if ($linkprot) {
           $args = {'only_body' => 1,
                    'redirect'  => [0,$destination],};
       }
     &Apache::loncommon::content_type($r,'text/html');      &Apache::loncommon::content_type($r,'text/html');
     $r->send_http_header;      $r->send_http_header;
     $r->print(&Apache::loncommon::start_page('Valid link',$header,$args).      if ($linkprot) {
               &Apache::lonhtmlcommon::scripttag('self.name="loncapaclient";').          $r->print(&Apache::loncommon::start_page('Valid link','',$args).
               '<h1>'.&mt('Welcome').'</h1>'.                    &Apache::loncommon::end_page());
               '<p>'.&mt('Welcome to the Learning[_1]Online[_2] Network with CAPA. Please wait while your session is being set up.','<i>','</i>').'</p><p>'.      } else {
               '<a href="'.$destination.'">'.&mt('Continue').'</a></p>'.          $r->print(&Apache::loncommon::start_page('Valid link',$header,$args).
               &Apache::loncommon::end_page());                    &Apache::lonhtmlcommon::scripttag('self.name="'.$windowname.'";').
                     '<h1>'.&mt('Welcome').'</h1>'.
                     '<p>'.&mt('Welcome to the Learning[_1]Online[_2] Network with CAPA. Please wait while your session is being set up.','<i>','</i>').'</p><p>'.
                     '<a href="'.$destination.'">'.&mt('Continue').'</a></p>'.
                     &Apache::loncommon::end_page());
       }
     return;      return;
 }  }
   
 sub show_roles {  sub show_roles {
     my ($r,$crsenv,$possroles,$hassection,$hascustom) = @_;      my ($r,$crsenv,$possroles,$hassection,$hascustom,$futureroles,$expiredroles,
     &Apache::loncommon::content_type($r,'text/html');          $linkprot,$linkprotuser,$linkprotexit,$linkprotpbid,$linkprotpburl,$ltoken) = @_;
     $r->send_http_header;  
     my ($crsdesc,$crstype,$cdom,$cnum,$header,$title,$preamble,$datatable,$js,$args);      my ($crsdesc,$crstype,$cdom,$cnum,$header,$title,$preamble,$datatable,$js,$args);
     if (ref($crsenv) eq 'HASH') {      if (ref($crsenv) eq 'HASH') {
         $crsdesc = $crsenv->{'description'};          $crsdesc = $crsenv->{'description'};
Line 168  sub show_roles { Line 641  sub show_roles {
     if (ref($possroles) eq 'HASH') {      if (ref($possroles) eq 'HASH') {
         if (keys(%{$possroles}) > 0) {          if (keys(%{$possroles}) > 0) {
             $args = {'bread_crumbs' => [{'href' => '','text' => "Choose role in $lc_crstype"},],};              $args = {'bread_crumbs' => [{'href' => '','text' => "Choose role in $lc_crstype"},],};
               if ($linkprot) {
                   $args = {'only_body' => 1};
               }
             $title = 'Choose a role'; #Do not localize.              $title = 'Choose a role'; #Do not localize.
             if ($crstype eq 'Community') {              if ($crstype eq 'Community') {
                 $preamble = &mt('You have the following active roles in this community:');                  $preamble = &mt('You have the following active roles in this community:');
Line 175  sub show_roles { Line 651  sub show_roles {
                 $preamble = &mt('You have the following active roles in this course:');                  $preamble = &mt('You have the following active roles in this course:');
             }              }
             $datatable = '<form name="" action="/adm/roles">'.              $datatable = '<form name="" action="/adm/roles">'.
                          '<input type="hidden" name="newrole" value="" />'.                           '<input type="hidden" name="newrole" value="" />'."\n".
                          '<input type="hidden" name="selectrole" value="1" />'.                           '<input type="hidden" name="selectrole" value="1" />'."\n".
                          '<input type="hidden" name="destinationurl" value="'.$r->uri.'" />'.                           '<input type="hidden" name="destinationurl" value="'.&HTML::Entities::encode($r->uri,'&<>"').'" />'."\n";
                          &Apache::loncommon::start_data_table().              if ($env{'form.ttoken'}) {
                          &Apache::loncommon::start_data_table_header_row().                  $datatable .= '<input type="hidden" name="ttoken" value="'.$env{'form.ttoken'}.'" />'."\n";
                          '<th></th><th>'.&mt('User role').'</th>';              }
               $datatable .= &Apache::loncommon::start_data_table().
                             &Apache::loncommon::start_data_table_header_row().
                             '<th></th><th>'.&mt('User role').'</th>';
             if ($hassection) {              if ($hassection) {
                 $datatable .= '<th>'.&mt('Section').'</th>';                  $datatable .= '<th>'.&mt('Section').'</th>';
             }              }
Line 256  function enterrole (thisform,rolecode,bu Line 735  function enterrole (thisform,rolecode,bu
 </script>  </script>
 ENDJS  ENDJS
         } else {          } else {
             $title = 'No active role';              if ($linkprot) {
             $preamble = &mt("You have no active roles in this $lc_crstype so the page is currently unavailable to you.");                  $title = 'No access';
             $args = {'bread_crumbs' => [{'href' => '','text' => 'Role status'},],};                  $preamble = '<p>'.&mt('Access unavailable for this LON-CAPA content.').'</p>';
                   $args->{'only_body'} = 1;
               } else {
                   $title = 'No active role';
                   $preamble = '<p>'.&mt("You have no active roles in this $lc_crstype so the page is currently unavailable to you.").'</p>';
                   $args = {'bread_crumbs' => [{'href' => '','text' => 'Role status'},],};
               }
               $header = &mt('No access for: [_1]','<b>'.&Apache::loncommon::plainname($env{'user.name'},
                                                                                       $env{'user.domain'}).'</b>');
               if ((ref($futureroles) eq 'HASH') && (keys(%{$futureroles}) > 0)) {
                   my @future = sort { $a <=> $b } (keys(%{$futureroles}));
                   $preamble .= '<p>'.&mt('Access will begin: [_1].',&Apache::lonlocal::locallocaltime($future[0])).
                                ' '.&mt('Please try again then.').'</p>';
               } elsif ((ref($expiredroles) eq 'HASH') && (keys(%{$expiredroles}) > 0)) {
                   my @expired = sort { $b <=> $a } (keys(%{$expiredroles}));
                   $preamble .= '<p>'.&mt('Access ended: [_1].',&Apache::lonlocal::locallocaltime($expired[0])).'</p>';
               } elsif ($linkprot) {
                   if ($linkprotuser) {
                       my ($uname,$udom) = split(/:/,$linkprotuser,2);
                       $preamble .= '<p>'.&mt('As you followed a link from another system, while logged into that other system with the username: [_1], it is recommended that you contact your instructor.','<i>'.$uname.'</i>').'</p>';
                   } else {
                       my $relogin;
                       my %data = (
                                   origurl => $r->uri,
                                   linkprot => $linkprot,
                                   linkprotexit => $linkprotexit,
                                   linkprotpbid => $linkprotpbid,
                                   linkprotpburl => $linkprotpburl,
                       );
                       my $token =
                           &Apache::lonnet::tmpput(\%data,$r->dir_config('lonHostID'),'retry');
                       unless (($token eq 'con_lost') || ($token eq 'refused') || ($token =~ /^error:/) ||
                               ($token eq 'unknown_cmd') || ($token eq 'no_such_host')) {
                               $relogin = '/adm/relaunch?rtoken='.$token;
                       }
                       $preamble .= '<p>'.&mt('You might try logging in with a different username and/or domain.').' '.
                                          &mt('You are currently logged in as: [_1] in domain: [_2]',
                                              '<i>'.$env{'user.name'}.'</i>','<i>'.$env{'user.domain'}.'</i>').'</p>';
                       if ($relogin) {
                           $preamble .= '<p>'.&mt('[_1]Log-in again[_2]','<a href="'.$relogin.'" target="_self">','</a>').'</p>';
                       }
                   }
               }
               if ($env{'form.ttoken'}) {
                   &Apache::lonnet::tmpdel($env{'form.ttoken'});
               }
               if ($ltoken) {
                   &Apache::lonnet::tmpdel($ltoken);
               }
         }          }
     }      }
     &Apache::loncommon::content_type($r,'text/html');      &Apache::loncommon::content_type($r,'text/html');
Line 273  ENDJS Line 800  ENDJS
   
 sub generic_error {  sub generic_error {
     my ($r) = @_;      my ($r) = @_;
     my $linktext;      my $continuelink;
     if ($env{'user.adv'}) {      unless ($env{'request.lti.login'}) {
         $linktext = &mt('Continue to your roles page');          my $linktext;
     } else {          if ($env{'user.adv'}) {
         $linktext = &mt('Continue to your courses page');              $linktext = &mt('Continue to your roles page');
           } else {
               $linktext = &mt('Continue to your courses page');
           }
           $continuelink='<a href="/adm/roles">'.$linktext.'</a>';
     }      }
     my $continuelink='<a href="/adm/roles">'.$linktext.'</a>';  
     my $msg = &mt('The page you requested does not exist.');      my $msg = &mt('The page you requested does not exist.');
     &Apache::loncommon::content_type($r,'text/html');      &Apache::loncommon::content_type($r,'text/html');
     $r->send_http_header;      $r->send_http_header;

Removed from v.1.1  
changed lines
  Added in v.1.23


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