Diff for /loncom/auth/switchserver.pm between versions 1.44 and 1.45

version 1.44, 2018/12/02 13:52:56 version 1.45, 2018/12/02 13:56:10
Line 68  sub do_redirect { Line 68  sub do_redirect {
     return OK;      return OK;
 }  }
   
   sub balancer_cookieid {
       my ($r,$desthost,$uname,$udom) = @_;
       my @hosts = &Apache::lonnet::current_machine_ids();
       my $newcookieid;
       unless (grep(/^\Q$desthost\E$/,@hosts)) {
           my $balancedir=$r->dir_config('lonBalanceDir');
           $newcookieid = &md5_hex(&md5_hex(time.{}.rand().$$));
           my $cookie = $udom.'_'.$uname.'_'.$newcookieid;
           my $balcookie = "balanceID=$cookie; path=/; HttpOnly;";
           if (open(my $fh,'>',"$balancedir/$cookie.id")) {
               print $fh $desthost;
               close($fh);
               $r->headers_out->add('Set-cookie' => $balcookie);
           }
       }
       return $newcookieid;
   }
   
 sub flush_course_logs {  sub flush_course_logs {
     &Apache::lonnet::flushcourselogs();      &Apache::lonnet::flushcourselogs();
     return OK;      return OK;
Line 116  sub handler { Line 134  sub handler {
     }      }
   
     my $skip_canhost_check = '';      my $skip_canhost_check = '';
       my $now = time;
     if ($env{'form.role'}) {      if ($env{'form.role'}) {
         if (!exists($env{'user.role.'.$env{'form.role'}})) {          if (!exists($env{'user.role.'.$env{'form.role'}})) {
             delete($env{'form.role'});              delete($env{'form.role'});
         } else {          } else {
             my $now = time;  
             my ($start,$end) = split(/\./,$env{'user.role.'.$env{'form.role'}});              my ($start,$end) = split(/\./,$env{'user.role.'.$env{'form.role'}});
             if (($start && $start > $now) || ($end && $end < $now)) {              if (($start && $start > $now) || ($end && $end < $now)) {
                 delete($env{'form.role'});                  delete($env{'form.role'});
Line 176  sub handler { Line 194  sub handler {
             }              }
         }          }
     }      }
     my $now = time;  
     my %temp=('switchserver' => $now.':'.$env{'form.otherserver'},      my %temp=('switchserver' => $now.':'.$env{'form.otherserver'},
       $env{'form.role'});        $env{'form.role'});
     &Apache::lonnet::put('email_status',\%temp);      &Apache::lonnet::put('email_status',\%temp);
Line 224  sub handler { Line 241  sub handler {
   
         unless (($found_server eq $env{'form.otherserver'}) &&          unless (($found_server eq $env{'form.otherserver'}) &&
                 ($balancer_cookie =~ /^\Q$env{'user.domain'}\E_\Q$env{'user.name'}\E_/)) {                  ($balancer_cookie =~ /^\Q$env{'user.domain'}\E_\Q$env{'user.name'}\E_/)) {
             my @hosts = &Apache::lonnet::current_machine_ids();              $newcookieid = &balancer_cookieid($r,$env{'form.otherserver'},
             my $desthost = $env{'form.otherserver'};                                                $env{'user.name'},$env{'user.domain'});
             unless (grep(/^\Q$desthost\E$/,@hosts)) {  
                 my $balancedir=$r->dir_config('lonBalanceDir');  
                 $newcookieid = &md5_hex(&md5_hex($now.{}.rand().$$));  
                 my $cookie = $env{'user.domain'}.'_'.$env{'user.name'}.'_'.$newcookieid;  
                 my $balcookie = "balanceID=$cookie; path=/; HttpOnly;";  
                 if (open(my $fh,'>',"$balancedir/$cookie.id")) {  
                     print $fh $env{'form.otherserver'};  
                     close($fh);  
                 }  
                 $r->headers_out->add('Set-cookie' => $balcookie);  
             }  
         }          }
     }      }
   

Removed from v.1.44  
changed lines
  Added in v.1.45


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