Diff for /loncom/auth/switchserver.pm between versions 1.42 and 1.46

version 1.42, 2018/11/24 16:19:04 version 1.46, 2018/12/08 15:16:03
Line 31  package Apache::switchserver; Line 31  package Apache::switchserver;
 use strict;  use strict;
 use Apache::Constants qw(:common);  use Apache::Constants qw(:common);
 use Apache::lonnet;  use Apache::lonnet;
 use Apache::lonmenu;  
 use Digest::MD5 qw(md5_hex);  use Digest::MD5 qw(md5_hex);
 use CGI::Cookie();  use CGI::Cookie();
 use Apache::lonlocal;  use Apache::lonlocal;
Line 69  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 117  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 132  sub handler { Line 149  sub handler {
             } elsif ($env{'form.role'} =~ m{^[ac]a\./($match_domain)/($match_username)$}) {              } elsif ($env{'form.role'} =~ m{^[ac]a\./($match_domain)/($match_username)$}) {
                 my ($audom,$auname) = ($1,$2);                  my ($audom,$auname) = ($1,$2);
                 if (&Apache::lonnet::homeserver($auname,$audom) eq $env{'form.otherserver'}) {                  if (&Apache::lonnet::homeserver($auname,$audom) eq $env{'form.otherserver'}) {
                     if ((&Apache::lonnet::will_trust('othcoau',$audom,$env{'user.domain'})) &&                      if ((&Apache::lonnet::will_trust('othcoau',$env{'user.domain'},$audom)) &&
                         (&Apache::lonnet::will_trust('coremau',$env{'user.domain'},$audom))) {                                                       (&Apache::lonnet::will_trust('coaurem',$audom,$env{'user.domain'}))) {                             
                         $skip_canhost_check = 1;                          $skip_canhost_check = 1;
                     }                      }
                 }                  }
Line 177  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 215  sub handler { Line 231  sub handler {
 # ---------------------------------------------------------------- Get handover  # ---------------------------------------------------------------- Get handover
   
     my $newcookieid;      my $newcookieid;
     (my $is_balancer,undef,my $setcookie) =      my ($is_balancer,$posshost,$setcookie,$offloadto,$dom_balancers) =
         &Apache::lonnet::check_loadbalancing($env{'user.name'},$env{'user.domain'});          &Apache::lonnet::check_loadbalancing($env{'user.name'},$env{'user.domain'});
     if ($is_balancer && $setcookie && $env{'form.otherserver'}) {      if ($is_balancer && $setcookie && $env{'form.otherserver'}) {
   
Line 225  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);  
             }  
         }          }
     }      }
   
     my %info=('ip'       => $ENV{'REMOTE_ADDR'},      my %info=('ip'            => $ENV{'REMOTE_ADDR'},
       'domain'   => $env{'user.domain'},                'domain'        => $env{'user.domain'},
       'username' => $env{'user.name'},                'username'      => $env{'user.name'},
       'role'     => $env{'form.role'},                'home'          => $env{'user.home'},
       'server'   => $r->dir_config('lonHostID'),                'role'          => $env{'form.role'},
       'balancer' => $is_balancer);                'server'        => $r->dir_config('lonHostID'),
                 'balancer'      => $is_balancer,
                 'dom_balancers' => $dom_balancers,
                 'offloadto'     => '');
       if (ref($offloadto) eq 'HASH') {
           foreach my $key (keys(%{$offloadto})) {
               if (ref($offloadto->{$key}) eq 'ARRAY') {
                   $info{'offloadto'} .= $key.'='.join(',',@{$offloadto->{$key}}).'&';
               }
           }
           $info{'offloadto'} =~ s/\&$//;
       } elsif (ref($offloadto) eq 'ARRAY') {
           $info{'offloadto'} = join(',',@{$offloadto});
       }
     if ($newcookieid) {      if ($newcookieid) {
         $info{'balcookie'} = $newcookieid;          $info{'balcookie'} = $newcookieid;
     }      }

Removed from v.1.42  
changed lines
  Added in v.1.46


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