version 1.158.2.6, 2016/08/13 20:11:58
|
version 1.158.2.6.2.1, 2017/10/14 20:59:35
|
Line 38 use Apache::lonlocal;
|
Line 38 use Apache::lonlocal;
|
use Apache::migrateuser(); |
use Apache::migrateuser(); |
use lib '/home/httpd/lib/perl/'; |
use lib '/home/httpd/lib/perl/'; |
use LONCAPA; |
use LONCAPA; |
|
use CGI::Cookie(); |
|
|
sub handler { |
sub handler { |
my $r = shift; |
my $r = shift; |
Line 56 sub handler {
|
Line 57 sub handler {
|
return &Apache::migrateuser::handler($r); |
return &Apache::migrateuser::handler($r); |
} |
} |
|
|
|
# For "public user" - remove any exising "public" cookie, as user really wants to log-in |
|
my ($handle,$lonidsdir,$expirepub,$userdom); |
|
unless ($r->header_only) { |
|
$handle = &Apache::lonnet::check_for_valid_session($r,'lonID',undef,\$userdom); |
|
if ($handle ne '') { |
|
$lonidsdir=$r->dir_config('lonIDsDir'); |
|
if ($handle=~/^publicuser\_/) { |
|
unlink($r->dir_config('lonIDsDir')."/$handle.id"); |
|
undef($handle); |
|
undef($userdom); |
|
$expirepub = 1; |
|
} |
|
} |
|
} |
|
|
&Apache::loncommon::no_cache($r); |
&Apache::loncommon::no_cache($r); |
&Apache::lonlocal::get_language_handle($r); |
&Apache::lonlocal::get_language_handle($r); |
&Apache::loncommon::content_type($r,'text/html'); |
&Apache::loncommon::content_type($r,'text/html'); |
|
if ($expirepub) { |
|
my $c = new CGI::Cookie(-name => 'lonID', |
|
-value => '', |
|
-expires => '-10y',); |
|
$r->header_out('Set-cookie' => $c); |
|
} elsif (($handle eq '') && ($userdom ne '')) { |
|
my $c = new CGI::Cookie(-name => 'lonID', |
|
-value => '', |
|
-expires => '-10y',); |
|
$r->headers_out->add('Set-cookie' => $c); |
|
} |
$r->send_http_header; |
$r->send_http_header; |
return OK if $r->header_only; |
return OK if $r->header_only; |
|
|
Line 70 sub handler {
|
Line 97 sub handler {
|
return OK; |
return OK; |
} |
} |
|
|
|
# |
|
# If browser sent an old cookie for which the session file had been removed |
|
# check if configuration for user's domain has a portal URL set. If so |
|
# switch user's log-in to the portal. |
|
# |
|
|
|
if (($handle eq '') && ($userdom ne '')) { |
|
my %domdefaults = &Apache::lonnet::get_domain_defaults($userdom); |
|
if ($domdefaults{'portal_def'} =~ /^https?\:/) { |
|
my $start_page = &Apache::loncommon::start_page('Switching Server ...',undef, |
|
{'redirect' => [0,$domdefaults{'portal_def'}],}); |
|
my $end_page = &Apache::loncommon::end_page(); |
|
$r->print($start_page.$end_page); |
|
return OK; |
|
} |
|
} |
|
|
$env{'form.firsturl'} =~ s/(`)/'/g; |
$env{'form.firsturl'} =~ s/(`)/'/g; |
|
|
# -------------------------------- Prevent users from attempting to login twice |
# -------------------------------- Prevent users from attempting to login twice |