version 1.182, 2020/10/06 17:26:15
|
version 1.183, 2020/10/20 01:38:12
|
Line 582 sub handler {
|
Line 582 sub handler {
|
if ($env{'user.noloadbalance'} eq $r->dir_config('lonHostID')) { |
if ($env{'user.noloadbalance'} eq $r->dir_config('lonHostID')) { |
$checkexempt = 1; |
$checkexempt = 1; |
} |
} |
unless ($checkexempt) { |
unless (($checkexempt) || (($requrl eq '/adm/switchserver') && (!$r->is_initial_req()))) { |
($is_balancer,$otherserver) = |
($is_balancer,$otherserver) = |
&Apache::lonnet::check_loadbalancing($env{'user.name'}, |
&Apache::lonnet::check_loadbalancing($env{'user.name'}, |
$env{'user.domain'}); |
$env{'user.domain'}); |
if ($is_balancer) { |
if ($is_balancer) { |
unless (($requrl eq '/adm/switchserver') && (!$r->is_initial_req())) { |
# Check if browser sent a LON-CAPA load balancer cookie (and this is a balancer) |
# Check if browser sent a LON-CAPA load balancer cookie (and this is a balancer) |
my ($found_server,$balancer_cookie) = &Apache::lonnet::check_for_balancer_cookie($r); |
my ($found_server,$balancer_cookie) = &Apache::lonnet::check_for_balancer_cookie($r); |
if (($found_server) && ($balancer_cookie =~ /^\Q$env{'user.domain'}\E_\Q$env{'user.name'}\E_/)) { |
if (($found_server) && ($balancer_cookie =~ /^\Q$env{'user.domain'}\E_\Q$env{'user.name'}\E_/)) { |
$otherserver = $found_server; |
$otherserver = $found_server; |
} |
} |
unless ($requrl eq '/adm/switchserver') { |
|
$r->set_handlers('PerlResponseHandler'=> |
|
[\&Apache::switchserver::handler]); |
} |
} |
} |
|
} |
|
if ($is_balancer) { |
|
unless (($requrl eq '/adm/switchserver') && (!$r->is_initial_req())) { |
|
$r->set_handlers('PerlResponseHandler'=> |
|
[\&Apache::switchserver::handler]); |
|
if ($otherserver ne '') { |
if ($otherserver ne '') { |
$env{'form.otherserver'} = $otherserver; |
$env{'form.otherserver'} = $otherserver; |
} |
} |
} |
unless (($env{'form.origurl'}) || ($r->uri eq '/adm/roles') || |
unless (($env{'form.origurl'}) || ($r->uri eq '/adm/roles') || |
($r->uri eq '/adm/switchserver') || ($r->uri eq '/adm/sso')) { |
($r->uri eq '/adm/switchserver') || ($r->uri eq '/adm/sso')) { |
$env{'form.origurl'} = $r->uri; |
$env{'form.origurl'} = $r->uri; |
} |
} |
} |
} |
} |
if ($requrl=~m{^/+tiny/+$match_domain/+\w+$}) { |
if ($requrl=~m{^/+tiny/+$match_domain/+\w+$}) { |