Diff for /loncom/auth/lonacc.pm between versions 1.5 and 1.6

version 1.5, 2000/01/14 21:12:40 version 1.6, 2000/06/05 20:28:17
Line 1 Line 1
 # The LearningOnline Network  # The LearningOnline Network
 # Cookie Based Access Handler  # Cookie Based Access Handler
 # 5/21/99,5/22,5/29,5/31,6/15,16/11,22/11,  # 5/21/99,5/22,5/29,5/31,6/15,16/11,22/11,
 # 01/06,01/13 Gerd Kortemeyer  # 01/06,01/13,05/31,06/01 Gerd Kortemeyer
   
 package Apache::lonacc;  package Apache::lonacc;
   
 use strict;  use strict;
 use Apache::Constants qw(:common);  use Apache::Constants qw(:common :http);
 use Apache::File;  use Apache::File;
   use Apache::lonnet;
 use CGI::Cookie();  use CGI::Cookie();
   
 sub handler {  sub handler {
Line 21  sub handler { Line 22  sub handler {
         $handle=~s/\W//g;          $handle=~s/\W//g;
         my $lonidsdir=$r->dir_config('lonIDsDir');          my $lonidsdir=$r->dir_config('lonIDsDir');
         if ((-e "$lonidsdir/$handle.id") && ($handle ne '')) {          if ((-e "$lonidsdir/$handle.id") && ($handle ne '')) {
   
   # ------------------------------------------- Transfer profile into environment
   
             my @profile;              my @profile;
     {      {
              my $idf=Apache::File->new("$lonidsdir/$handle.id");               my $idf=Apache::File->new("$lonidsdir/$handle.id");
Line 31  sub handler { Line 35  sub handler {
  chomp($profile[$envi]);   chomp($profile[$envi]);
  my ($envname,$envvalue)=split(/=/,$profile[$envi]);   my ($envname,$envvalue)=split(/=/,$profile[$envi]);
                 $r->subprocess_env("$envname" => "$envvalue");                  $r->subprocess_env("$envname" => "$envvalue");
                   $ENV{$envname}=$envvalue;
             }              }
             $r->subprocess_env("user.environment" => "$lonidsdir/$handle.id",              $r->subprocess_env("user.environment" => "$lonidsdir/$handle.id",
                                "request.state"    => "published",                                 "request.state"    => "published",
                                "request.filename" => $r->filename);                                 "request.filename" => $r->filename);
   
   # -------------------------------------------------------- Load POST parameters
   
             my $buffer;              my $buffer;
   
             $r->read($buffer,$r->header_in('Content-length'));              $r->read($buffer,$r->header_in('Content-length'));
             my @pairs=split(/&/,$buffer);              my @pairs=split(/&/,$buffer);
             my $pair; my $name; my $value;              my $pair;
             foreach $pair (@pairs) {              foreach $pair (@pairs) {
                ($name,$value) = split(/=/,$pair);                 my ($name,$value) = split(/=/,$pair);
                  $value =~ tr/+/ /;
                  $value =~ s/%([a-fA-F0-9][a-fA-F0-9])/pack("C",hex($1))/eg;
                $r->subprocess_env("form.$name" => $value);                 $r->subprocess_env("form.$name" => $value);
               }
   
   
   # ---------------------------------------------------------------- Check access
   
               if ($requrl!~/^\/adm\//) {
                  if (&Apache::lonnet::allowed('bre',$requrl) eq '') {
     $ENV{'user.error.msg'}="$requrl:bre:1:1:Access denied";
                     return HTTP_NOT_ACCEPTABLE; 
                  }
             }               } 
             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;
 }  }
   
 1;  1;
 __END__  __END__
   
   
   
   
   
   
   
   

Removed from v.1.5  
changed lines
  Added in v.1.6


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