Diff for /loncom/auth/loncacc.pm between versions 1.1.1.1 and 1.10

version 1.1.1.1, 1999/10/13 17:48:52 version 1.10, 2000/09/28 17:01:17
Line 1 Line 1
 # The LearningOnline Network  # The LearningOnline Network
 # Cookie Based Access Handler for Construction Area  # Cookie Based Access Handler for Construction Area
 # (lonacc: 5/21/99,5/22,5/29,5/31 Gerd Kortemeyer)  # (lonacc: 5/21/99,5/22,5/29,5/31 Gerd Kortemeyer)
 # 6/15 Gerd Kortemeyer  # 6/15,16/11,22/11,
   # 01/06,01/11,6/1,9/25,9/28 Gerd Kortemeyer
   
 package Apache::loncacc;  package Apache::loncacc;
   
 use strict;  use strict;
 use Apache::Constants qw(:common :http);  use Apache::Constants qw(:common :http :methods);
   use Apache::File;
 use CGI::Cookie();  use CGI::Cookie();
   
 sub handler {  sub handler {
Line 31  sub handler { Line 33  sub handler {
                    ("$username at $domain not authorized", $r->filename);                      ("$username at $domain not authorized", $r->filename); 
         return HTTP_NOT_ACCEPTABLE;          return HTTP_NOT_ACCEPTABLE;
             }              }
               my @profile;
       {
                my $idf=Apache::File->new("$lonidsdir/$handle.id");
                @profile=<$idf>;
       }
               my $envi;
               for ($envi=0;$envi<=$#profile;$envi++) {
    chomp($profile[$envi]);
    my ($envname,$envvalue)=split(/=/,$profile[$envi]);
                   $ENV{$envname} = $envvalue;
               }
               $ENV{'user.environment'} = "$lonidsdir/$handle.id";
               $ENV{'request.state'}    = "construct";
               $ENV{'request.filename'} = $r->filename;
   
   # -------------------------------------------------------- Load POST parameters
   
   
               my $buffer;
   
               $r->read($buffer,$r->header_in('Content-length'));
               my @pairs=split(/&/,$buffer);
               my $pair;
               foreach $pair (@pairs) {
                  my ($name,$value) = split(/=/,$pair);
                  $value =~ tr/+/ /;
                  $value =~ s/%([a-fA-F0-9][a-fA-F0-9])/pack("C",hex($1))/eg;
                  $name  =~ tr/+/ /;
                  $name  =~ s/%([a-fA-F0-9][a-fA-F0-9])/pack("C",hex($1))/eg;
                  $ENV{"form.$name"}=$value;
               } 
   
               $r->method_number(M_GET);
       $r->method('GET');
               $r->headers_in->unset('Content-length');
   
             return OK;               return OK; 
         } else {           } else { 
             $r->log_reason("Cookie $handle not valid", $r->filename)               $r->log_reason("Cookie $handle not valid", $r->filename) 
         };          };
     }      }
     $cookie=CGI::Cookie->new(-name  => 'lonURL',  
                              -value => $requrl,   # ----------------------------------------------- Store where they wanted to go
                              -path  => '/');  
     $r->err_headers_out->add('Set-Cookie' => $cookie);      $ENV{'request.firsturl'}=$requrl;
     return FORBIDDEN;      return FORBIDDEN;
 }  }
   

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


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