Diff for /loncom/auth/lonshibauth.pm between versions 1.1 and 1.10

version 1.1, 2012/03/05 20:51:29 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::Constants qw(:common);  use Apache::lonnet;
   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;

Removed from v.1.1  
changed lines
  Added in v.1.10


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