Diff for /loncom/interface/lontiny.pm between versions 1.8.2.6 and 1.10

version 1.8.2.6, 2024/02/10 14:24:46 version 1.10, 2022/05/25 18:03:43
Line 68  sub handler { Line 68  sub handler {
                         my $chome = &Apache::lonnet::homeserver($cnum,$cdom);                          my $chome = &Apache::lonnet::homeserver($cnum,$cdom);
                         if ($chome ne 'no_host') {                          if ($chome ne 'no_host') {
                             &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['ttoken']);                              &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['ttoken']);
                             my ($linkprot,$linkprotuser,$linkprotexit,$ltoken,$linkprotpbid,$linkprotpburl);  
                             if ($env{'form.ttoken'}) {  
                                 my %link_info = &Apache::lonnet::tmpget($env{'form.ttoken'});  
                                 if ($link_info{'origurl'} eq $r->uri) {  
                                     if ($link_info{'ltoken'}) {  
                                         $ltoken = $link_info{'ltoken'};  
                                         my %ltoken_info = &Apache::lonnet::tmpget($link_info{'ltoken'});  
                                         $linkprot = $ltoken_info{'linkprot'};  
                                         $linkprotuser = $ltoken_info{'linkprotuser'};  
                                         $linkprotexit = $ltoken_info{'linkprotexit'};  
                                         $linkprotpbid = $ltoken_info{'linkprotpbid'};  
                                         $linkprotpburl = $ltoken_info{'linkprotpburl'};  
                                     } elsif ($link_info{'linkprot'}) {  
                                         $linkprot = $link_info{'linkprot'};  
                                         if ($link_info{'linkprotuser'}) {  
                                             $linkprotuser = $link_info{'linkprotuser'};  
                                         }  
                                         if ($link_info{'linkprotexit'}) {  
                                             $linkprotexit = $link_info{'linkprotexit'};  
                                         }  
                                         if ($link_info{'linkprotpbid'}) {  
                                             $linkprotpbid = $link_info{'linkprotpbid'};  
                                         }  
                                         if ($link_info{'linkprotpburl'}) {  
                                             $linkprotpburl = $link_info{'linkprotpburl'};  
                                         }  
                                     }  
                                 }  
                             }  
                             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);                                  my $newlauncher = &launch_check($r->uri,$symb);
Line 126  sub handler { Line 97  sub handler {
                                             $realuri .= '?symb='.$symb;                                              $realuri .= '?symb='.$symb;
                                         }                                          }
                                     }                                      }
                                     my ($update,$reinitresult);                                      my $update;
                                     # 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');
                                         ($reinitresult,my @reinit) = &Apache::loncommon::needs_coursereinit($loncaparev);                                          my ($result,@reinit) = &Apache::loncommon::needs_coursereinit($loncaparev);
                                         if (($reinitresult eq 'main') || ($reinitresult eq 'both')) {                                          if ($result eq 'update') {
                                             $update = 1;                                              $update = 1;
                                         } elsif (!-e $env{'request.course.fn'}.'.db') {                                          } elsif (!-e $env{'request.course.fn'}.'.db') {
                                             $update = 1;                                              $update = 1;
Line 163  sub handler { Line 134  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::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');                                      my $host = $r->headers_in->get('Host');
                                     if (!$host) {                                      if (!$host) {
                                         $r->internal_redirect($realuri);                                          $r->internal_redirect($realuri);
Line 195  sub handler { Line 156  sub handler {
                                 } else {                                  } else {
                                     unshift(@possroles,'cc');                                      unshift(@possroles,'cc');
                                 }                                  }
                                 my %roleshash =                                  my %roleshash = &Apache::lonnet::get_my_roles($env{'user.uname'},
                                     &Apache::lonnet::get_my_roles($env{'user.uname'},$env{'user.domain'},                                                                                $env{'user.domain'},
                                                                   'userroles',['previous','active','future'],                                                                                'userroles',undef,
                                                                   \@possroles,[$cdom],1);                                                                                \@possroles,[$cdom],1);
                                 my (%possroles,$hassection,%active,%expired,%future);                                  my (%possroles,$hassection);
                                 if (keys(%roleshash)) {                                  if (keys(%roleshash)) {
                                     my $now = time;  
                                     foreach my $entry (keys(%roleshash)) {                                      foreach my $entry (keys(%roleshash)) {
                                         if ($entry =~ /^\Q$cnum:$cdom:\E([^:]+):([^:]*)$/) {                                          if ($entry =~ /^\Q$cnum:$cdom:\E([^:]+):([^:]*)$/) {
                                             my ($role,$sec) = ($1,$2);                                              $possroles{$1} = $2;
                                             $possroles{$role} = $sec;                                              if ($2 ne '') {
                                             if ($sec ne '') {  
                                                 $hassection = 1;                                                  $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;  
                                             }  
                                         }                                          }
                                     }                                      }
                                 }                                  }
                                 my @allposs = keys(%active);                                  my @allposs = keys(%possroles);
                                 if ($env{'request.lti.login'}) {                                  if ($env{'request.lti.login'}) {
                                     &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'});                                      &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'});
                                     if ($env{'request.lti.target'} eq '') {                                      if ($env{'request.lti.target'} eq '') {
Line 244  sub handler { Line 188  sub handler {
                                             }                                              }
                                             if ($env{"form.$newrole"}) {                                              if ($env{"form.$newrole"}) {
                                                 my $destination .= '/adm/roles?selectrole=1&'.$newrole.'=1'.                                                  my $destination .= '/adm/roles?selectrole=1&'.$newrole.'=1'.
                                                                    '&destinationurl='.&HTML::Entities::encode($r->uri,'&<>"');                                                                     '&destinationurl='.&HTML::Entities::encode($r->uri);
                                                 if ($env{'form.ltitarget'} eq 'iframe') {                                                  if ($env{'form.ltitarget'} eq 'iframe') {
                                                     $destination .= '&ltitarget=iframe';                                                      $destination .= '&ltitarget=iframe';
                                                 }                                                  }
Line 255  sub handler { Line 199  sub handler {
                                     }                                      }
                                 }                                  }
                                 if (@allposs == 0) {                                  if (@allposs == 0) {
                                     &show_roles($r,\%crsenv,\%active,'','',\%future,\%expired,$linkprot,$linkprotuser,                                      &show_roles($r,\%crsenv,\%possroles);
                                                 $linkprotexit,$linkprotpbid,$linkprotpburl,$ltoken);  
                                 } elsif (@allposs == 1) {                                  } elsif (@allposs == 1) {
                                     my $newrole = "$allposs[0]./$cdom/$cnum";                                      my $newrole = "$allposs[0]./$cdom/$cnum";
                                     $newrole = "$allposs[0]./$cdom/$cnum";                                      $newrole = "$allposs[0]./$cdom/$cnum";
                                     if ($possroles{$allposs[0]} ne '') {                                      if ($possroles{$allposs[0]} ne '') {
                                         $newrole .= "/$possroles{$allposs[0]}";                                          $newrole .= "/$possroles{$allposs[0]}"; 
                                     }                                      }
                                     my $destination .= '/adm/roles?selectrole=1&'.$newrole.'=1'.                                      my $destination .= '/adm/roles?selectrole=1&'.$newrole.'=1'.
                                                        '&destinationurl='.&HTML::Entities::encode($r->uri,'&<>"');                                                         '&destinationurl='.&HTML::Entities::encode($r->uri);
                                     if ($env{'form.ttoken'}) {                                      if ($env{'form.ttoken'}) {
                                         $destination .= '&ttoken='.$env{'form.ttoken'};                                          $destination .= '&ttoken='.$env{'form.ttoken'};
                                     }                                      }
                                     &do_redirect($r,$destination,$linkprot);                                      &do_redirect($r,$destination);
                                 } elsif (@allposs > 1) {                                  } elsif (keys(%possroles) > 1) {
                                     if (grep(/^(cc|co)$/,@allposs)) {                                      if (grep(/^(cc|co)$/,@allposs)) {
                                         my $newrole;                                          my $newrole;
                                         if (exists($possroles{'cc'})) {                                          if (exists($possroles{'cc'})) {
Line 279  sub handler { Line 222  sub handler {
                                         }                                          }
                                         $newrole .= "./$cdom/$cnum";                                          $newrole .= "./$cdom/$cnum";
                                         my $destination .= '/adm/roles?selectrole=1&'.$newrole.'=1'.                                          my $destination .= '/adm/roles?selectrole=1&'.$newrole.'=1'.
                                                            '&destinationurl='.&HTML::Entities::encode($r->uri,'&<>"');                                                             '&destinationurl='.&HTML::Entities::encode($r->uri);
                                         if ($env{'form.ttoken'}) {                                          if ($env{'form.ttoken'}) {
                                             $destination .= '&ttoken='.$env{'form.ttoken'};                                              $destination .= '&ttoken='.$env{'form.ttoken'};
                                         }                                          }
                                         &do_redirect($r,$destination,$linkprot);                                          &do_redirect($r,$destination);
                                     } else {                                      } else {
                                         my $hascustom;                                          my $hascustom;
                                         if (grep(/^cr\//,@allposs)) {                                          if (grep(/^cr\//,@allposs)) {
                                             $hascustom = 1;                                              $hascustom = 1;
                                         }                                          }
                                         &show_roles($r,\%crsenv,\%active,$hassection,$hascustom);                                          &show_roles($r,\%crsenv,\%possroles,$hassection,$hascustom);
                                     }                                      }
                                 }                                  }
                                 return OK;                                  return OK;
Line 308  sub handler { Line 251  sub handler {
   
 sub launch_check {  sub launch_check {
     my ($linkuri,$symb) = @_;      my ($linkuri,$symb) = @_;
     my ($linkprotector,$linkproturi,$linkprotexit,$linkprotpbid,$linkprotpburl,      my ($linkprotector,$linkproturi,$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 323  sub launch_check { Line 265  sub launch_check {
                     $link_info{'linkkey'} = $ltoken_info{'linkkey'};                      $link_info{'linkkey'} = $ltoken_info{'linkkey'};
                 }                  }
             }              }
             &Apache::lonnet::tmpdel($link_info{'ltoken'});              &Apache::lonnet::tmpdel($env{'form.ltoken'});
               delete($env{'form.ltoken'});
         }          }
         if ($link_info{'linkprot'}) {          if ($link_info{'linkprot'}) {
             ($linkprotector,$linkproturi) = split(/:/,$link_info{'linkprot'},2);              ($linkprotector,$linkproturi) = split(/:/,$link_info{'linkprot'},2);
Line 347  sub launch_check { Line 290  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'};  
             }  
             if ($link_info{'linkprotpbid'}) {  
                 $linkprotpbid = $link_info{'linkprotpbid'};  
             }  
             if ($link_info{'linkprotpburl'}) {  
                 $linkprotpburl = $link_info{'linkprotpburl'};  
             }  
         } 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 381  sub launch_check { Line 315  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 398  sub launch_check { Line 329  sub launch_check {
     }      }
     if ($deeplink ne '') {      if ($deeplink ne '') {
         my $disallow;          my $disallow;
         my ($state,$others,$listed,$scope,$protect,$display,$target,$exit) = split(/,/,$deeplink);          my ($state,$others,$listed,$scope,$protect,$display,$target) = 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 426  sub launch_check { Line 357  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');  
                 }  
                 if ($env{'request.linkprotpbid'} ne '') {  
                     &Apache::lonnet::delenv('request.linkprotpbid');  
                 }  
                 if ($env{'request.linkprotpburl'} ne '') {  
                     &Apache::lonnet::delenv('request.linkprotpburl');  
                 }  
             }              }
         } 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});  
             } 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 ($linkkey ne '') {
                 if ($linkprotpbid ne $env{'request.linkprotpbid'}) {                          &Apache::lonnet::appenv({'request.linkkey' => $linkkey});
                     if ($linkprotpbid) {                      } elsif ($env{'request.linkkey'} ne '') {
                         &Apache::lonnet::appenv({'request.linkprotpbid' => $linkprotpbid});                          &Apache::lonnet::delenv({'request.linkkey'});
                     } 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");  
                     }                      }
                       $newlauncher = 1;
                 }                  }
             }              }
             &Apache::lonnet::appenv({'request.deeplink.login' => $linkuri});              &Apache::lonnet::appenv({'request.deeplink.login' => $linkuri});
Line 495  sub launch_check { Line 385  sub launch_check {
         if ($linkprotector) {          if ($linkprotector) {
             &Apache::lonnet::appenv({'request.linkprot' => $linkprotector.':'.$linkproturi});              &Apache::lonnet::appenv({'request.linkprot' => $linkprotector.':'.$linkproturi});
         } 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 ($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 '') {          if ($linkkey ne '') {
             &Apache::lonnet::appenv({'request.linkkey' => $linkkey});              &Apache::lonnet::appenv({'request.linkkey' => $linkkey});
         } else {          } else {
             &Apache::lonnet::delenv('request.linkkey');              &Apache::lonnet::delenv({'request.linkkey'});
         }          }
         &Apache::lonnet::appenv({'request.deeplink.login' => $linkuri});          &Apache::lonnet::appenv({'request.deeplink.login' => $linkuri});
         if ($env{'request.deeplink.target'} ne '') {          if ($env{'request.deeplink.target'} ne '') {
Line 526  sub launch_check { Line 401  sub launch_check {
 }  }
   
 sub do_redirect {  sub do_redirect {
     my ($r,$destination,$linkprot) = @_;      my ($r,$destination) = @_;
     my $windowname = 'loncapaclient';      my $windowname = 'loncapaclient';
     if ($env{'request.lti.login'}) {      if ($env{'request.lti.login'}) {
         $windowname .= 'lti';          $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;
     if ($linkprot) {      $r->print(&Apache::loncommon::start_page('Valid link',$header,$args).
         $r->print(&Apache::loncommon::start_page('Valid link','',$args).                &Apache::lonhtmlcommon::scripttag('self.name="'.$windowname.'";').
                   &Apache::loncommon::end_page());                '<h1>'.&mt('Welcome').'</h1>'.
     } else {                '<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>'.
         $r->print(&Apache::loncommon::start_page('Valid link',$header,$args).                '<a href="'.$destination.'">'.&mt('Continue').'</a></p>'.
                   &Apache::lonhtmlcommon::scripttag('self.name="'.$windowname.'";').                &Apache::loncommon::end_page());
                   '<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,$futureroles,$expiredroles,      my ($r,$crsenv,$possroles,$hassection,$hascustom) = @_;
         $linkprot,$linkprotuser,$linkprotexit,$linkprotpbid,$linkprotpburl,$ltoken) = @_;      &Apache::loncommon::content_type($r,'text/html');
       $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 574  sub show_roles { Line 441  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 586  sub show_roles { Line 450  sub show_roles {
             $datatable = '<form name="" action="/adm/roles">'.              $datatable = '<form name="" action="/adm/roles">'.
                          '<input type="hidden" name="newrole" value="" />'."\n".                           '<input type="hidden" name="newrole" value="" />'."\n".
                          '<input type="hidden" name="selectrole" value="1" />'."\n".                           '<input type="hidden" name="selectrole" value="1" />'."\n".
                          '<input type="hidden" name="destinationurl" value="'.&HTML::Entities::encode($r->uri,'&<>"').'" />'."\n";                           '<input type="hidden" name="destinationurl" value="'.$r->uri.'" />'."\n";
             if ($env{'form.ttoken'}) {              if ($env{'form.ttoken'}) {
                 $datatable .= '<input type="hidden" name="ttoken" value="'.$env{'form.ttoken'}.'" />'."\n";                  $datatable .= '<input type="hidden" name="ttoken" value="'.$env{'form.ttoken'}.'" />'."\n";
             }              }
Line 668  function enterrole (thisform,rolecode,bu Line 532  function enterrole (thisform,rolecode,bu
 </script>  </script>
 ENDJS  ENDJS
         } else {          } else {
             if ($linkprot) {              $title = 'No active role';
                 $title = 'No access';              $preamble = &mt("You have no active roles in this $lc_crstype so the page is currently unavailable to you.");
                 $preamble = '<p>'.&mt('Access unavailable for this LON-CAPA content.').'</p>';              $args = {'bread_crumbs' => [{'href' => '','text' => 'Role status'},],};
                 $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');

Removed from v.1.8.2.6  
changed lines
  Added in v.1.10


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