version 1.49, 2020/12/18 15:23:03
|
version 1.51, 2021/08/07 20:49:10
|
Line 30 package Apache::migrateuser;
|
Line 30 package Apache::migrateuser;
|
|
|
use strict; |
use strict; |
use LONCAPA qw(:DEFAULT :match); |
use LONCAPA qw(:DEFAULT :match); |
use Apache::Constants qw(:common :http :methods); |
use Apache::Constants qw(:common :http :methods :remotehost); |
use Apache::lonauth; |
use Apache::lonauth; |
use Apache::lonnet; |
use Apache::lonnet; |
use Apache::loncommon; |
use Apache::loncommon; |
Line 253 sub ip_changed {
|
Line 253 sub ip_changed {
|
if ($hostname) { |
if ($hostname) { |
my $protocol = $Apache::lonnet::protocol{$switchto}; |
my $protocol = $Apache::lonnet::protocol{$switchto}; |
$protocol = 'http' if ($protocol ne 'https'); |
$protocol = 'http' if ($protocol ne 'https'); |
|
my $alias = &Apache::lonnet::use_proxy_alias($r,$switchto); |
|
$hostname = $alias if ($alias ne ''); |
$url = $protocol.'://'.$hostname; |
$url = $protocol.'://'.$hostname; |
if ($rule_in_effect eq 'balancer') { |
if ($rule_in_effect eq 'balancer') { |
$message .= '<br />'. |
$message .= '<br />'. |
Line 308 sub ip_changed {
|
Line 310 sub ip_changed {
|
} |
} |
|
|
sub logout { |
sub logout { |
my ($r,$handle,$data,$lti_env) = @_; |
my ($r,$ip,$handle,$data,$lti_env) = @_; |
my $lonidsdir=$r->dir_config('lonIDsDir'); |
my $lonidsdir=$r->dir_config('lonIDsDir'); |
if (unlink("$lonidsdir/$handle.id")) { |
if (unlink("$lonidsdir/$handle.id")) { |
if (($env{'user.linkedenv'} =~ /^[a-f0-9]+_linked$/) && |
if (($env{'user.linkedenv'} =~ /^[a-f0-9]+_linked$/) && |
Line 319 sub logout {
|
Line 321 sub logout {
|
} |
} |
my %temp=('logout' => time); |
my %temp=('logout' => time); |
&Apache::lonnet::put('email_status',\%temp); |
&Apache::lonnet::put('email_status',\%temp); |
my $ip = &Apache::lonnet::get_requestor_ip(); |
|
&Apache::lonnet::log($env{'user.domain'}, |
&Apache::lonnet::log($env{'user.domain'}, |
$env{'user.name'}, |
$env{'user.name'}, |
$env{'user.home'}, |
$env{'user.home'}, |
Line 588 sub handler {
|
Line 589 sub handler {
|
} |
} |
my ($home,@ids); |
my ($home,@ids); |
@ids=&Apache::lonnet::current_machine_ids(); |
@ids=&Apache::lonnet::current_machine_ids(); |
my $ip = &Apache::lonnet::get_requestor_ip(); |
my $ip = &Apache::lonnet::get_requestor_ip($r,REMOTE_NOLOOKUP); |
if ($data{'ip'} ne $ip) { |
if ($data{'ip'} ne $ip) { |
&Apache::lonnet::logthis('IP change when session migration requested -- was: '. |
&Apache::lonnet::logthis('IP change when session migration requested -- was: '. |
$data{'ip'}.'; now: '.$ip.' for '.$data{'username'}.':'.$data{'domain'}); |
$data{'ip'}.'; now: '.$ip.' for '.$data{'username'}.':'.$data{'domain'}); |
Line 710 sub handler {
|
Line 711 sub handler {
|
$handle); |
$handle); |
if ($data{'linkprot'} ne '') { |
if ($data{'linkprot'} ne '') { |
my ($linkprotector,$deeplink) = split(/:/,$data{'linkprot'},2); |
my ($linkprotector,$deeplink) = split(/:/,$data{'linkprot'},2); |
if ($deeplink ne '') { |
|
&Apache::lonnet::appenv({'request.deeplink.login' => $deeplink}); |
|
} |
|
if ($env{'user.linkprotector'}) { |
if ($env{'user.linkprotector'}) { |
my @protectors = split(/,/,$env{'user.linkprotector'}); |
my @protectors = split(/,/,$env{'user.linkprotector'}); |
unless (grep(/^\Q$linkprotector\E$/,@protectors)) { |
unless (grep(/^\Q$linkprotector\E$/,@protectors)) { |
Line 733 sub handler {
|
Line 731 sub handler {
|
} else { |
} else { |
&Apache::lonnet::appenv({'user.linkproturi' => $deeplink}); |
&Apache::lonnet::appenv({'user.linkproturi' => $deeplink}); |
} |
} |
} elsif ($data{'deeplink.login'}) { |
} elsif ($data{'linkkey'}) { |
my $deeplink = $data{'deeplink.login'}; |
my $deeplink = $data{'deeplink.login'}; |
if ($data{'linkkey'}) { |
my $linkkey = $data{'linkkey'}; |
my $linkkey = $data{'linkkey'}; |
if ($env{'user.deeplinkkey'}) { |
if ($env{'user.deeplinkkey'}) { |
my @linkkeys = split(/,/,$env{'user.deeplinkkey'}); |
my @linkkeys = split(/,/,$env{'user.deeplinkkey'}); |
unless (grep(/^\Q$linkkey\E$/,@linkkeys)) { |
unless (grep(/^\Q$linkkey\E$/,@linkkeys)) { |
push(@linkkeys,$linkkey); |
push(@linkkeys,$linkkey); |
&Apache::lonnet::appenv({'user.deeplinkkey' => join(',',sort(@linkkeys))}); |
&Apache::lonnet::appenv({'user.deeplinkkey' => join(',',sort(@linkkeys))}); |
|
} |
|
} else { |
|
&Apache::lonnet::appenv({'user.deeplinkkey' => $linkkey}); |
|
} |
} |
|
} else { |
|
&Apache::lonnet::appenv({'user.deeplinkkey' => $linkkey}); |
|
} |
|
if ($deeplink) { |
if ($env{'user.keyedlinkuri'}) { |
if ($env{'user.keyedlinkuri'}) { |
my @keyeduris = split(/,/,$env{'user.keyedlinkuri'}); |
my @keyeduris = split(/,/,$env{'user.keyedlinkuri'}); |
unless (grep(/^\Q$deeplink\E$/,@keyeduris)) { |
unless (grep(/^\Q$deeplink\E$/,@keyeduris)) { |
Line 756 sub handler {
|
Line 754 sub handler {
|
&Apache::lonnet::appenv({'user.keyedlinkuri' => $deeplink}); |
&Apache::lonnet::appenv({'user.keyedlinkuri' => $deeplink}); |
} |
} |
} |
} |
|
} |
|
if ($data{'deeplink.login'}) { |
&Apache::lonnet::appenv({'request.deeplink.login' => $data{'deeplink.login'}}); |
&Apache::lonnet::appenv({'request.deeplink.login' => $data{'deeplink.login'}}); |
} |
} |
if ($data{'lti.login'}) { |
if ($data{'lti.login'}) { |
Line 772 sub handler {
|
Line 772 sub handler {
|
# (and session) or has an LTI session cookie for a different username, |
# (and session) or has an LTI session cookie for a different username, |
# logout the existing session, and start a new one |
# logout the existing session, and start a new one |
if ($needslogout) { |
if ($needslogout) { |
&logout($r,$handle,\%data,$lti_env); |
&logout($r,$ip,$handle,\%data,$lti_env); |
} elsif (($data{'lti.reqcrs'}) && ($data{'lti.reqrole'} eq 'cc')) { |
} elsif (($data{'lti.reqcrs'}) && ($data{'lti.reqrole'} eq 'cc')) { |
$form{'lti.reqcrs'} = $data{'lti.reqcrs'}; |
$form{'lti.reqcrs'} = $data{'lti.reqcrs'}; |
$form{'lti.reqrole'} = $data{'lti.reqrole'}; |
$form{'lti.reqrole'} = $data{'lti.reqrole'}; |
Line 918 sub handler {
|
Line 918 sub handler {
|
$needslogout = 1; |
$needslogout = 1; |
} |
} |
if ($needslogout) { |
if ($needslogout) { |
&logout($r,$handle,\%data,$lti_env); |
&logout($r,$ip,$handle,\%data,$lti_env); |
return OK; |
return OK; |
} |
} |
} |
} |