version 1.2, 2013/01/04 01:37:02
|
version 1.10, 2021/10/10 23:59:19
|
Line 67 package Apache::lonshibauth;
|
Line 67 package Apache::lonshibauth;
|
|
|
use strict; |
use strict; |
use lib '/home/httpd/lib/perl/'; |
use lib '/home/httpd/lib/perl/'; |
|
use Apache::lonnet; |
use Apache::Constants qw(:common REDIRECT); |
use Apache::Constants qw(:common REDIRECT); |
use LONCAPA qw(:DEFAULT); |
use LONCAPA qw(:DEFAULT); |
|
|
sub handler { |
sub handler { |
my $r = shift; |
my $r = shift; |
my $target = '/adm/sso'; |
my $target = '/adm/sso'; |
if (($r->user eq '') && ($r->uri() ne $target)) { |
if (&Apache::lonnet::get_saml_landing()) { |
my $dest = &Apache::lonnet::absolute_url($r->hostname()).$target; |
$target = '/adm/login'; |
$r->subprocess_env; |
} |
if ($ENV{'QUERY_STRING'} ne '') { |
my $uri = $r->uri; |
$dest .= '?'.$ENV{'QUERY_STRING'}; |
if (($r->user eq '') && ($uri ne $target) && ($uri ne '/adm/sso')) { |
|
my $lonhost = $Apache::lonnet::perlvar{'lonHostID'}; |
|
my $hostname = &Apache::lonnet::hostname($lonhost); |
|
if (!$hostname) { $hostname = $r->hostname(); } |
|
my $protocol = $Apache::lonnet::protocol{$lonhost}; |
|
unless ($protocol eq 'https') { $protocol = 'http'; } |
|
my $alias = &Apache::lonnet::use_proxy_alias($r,$lonhost); |
|
if (($alias ne '') && |
|
(&Apache::lonnet::alias_shibboleth($lonhost))) { |
|
$hostname = $alias; |
|
} |
|
my $dest = $protocol.'://'.$hostname.$target; |
|
if ($r->args ne '') { |
|
$dest .= (($dest=~/\?/)?'&':'?').$r->args; |
|
} |
|
unless (($uri eq '/adm/roles') || ($uri eq '/adm/logout')) { |
|
if ($target eq '/adm/login') { |
|
unless ($ENV{'QUERY_STRING'} =~ /firsturl=/) { |
|
$dest.=(($dest=~/\?/)?'&':'?').'firsturl='.$uri; |
|
} |
|
} else { |
|
unless ($ENV{'QUERY_STRING'} =~ /origurl=/) { |
|
$dest.=(($dest=~/\?/)?'&':'?').'origurl='.$uri; |
|
} |
|
} |
} |
} |
$r->header_out(Location => $dest); |
$r->header_out(Location => $dest); |
return REDIRECT; |
return REDIRECT; |