Diff for /loncom/auth/lonlogout.pm between versions 1.16 and 1.25

version 1.16, 2006/04/05 22:25:44 version 1.25, 2007/03/01 23:14:12
Line 39  use Apache::lonlocal; Line 39  use Apache::lonlocal;
 sub handler {  sub handler {
     my $r = shift;      my $r = shift;
   
       #Check for cookie
     my $requrl=$r->uri;      my $requrl=$r->uri;
     my %cookies=CGI::Cookie->parse($r->header_in('Cookie'));      my %cookies=CGI::Cookie->parse($r->header_in('Cookie'));
     my $lonid=$cookies{'lonID'};      my $lonid=$cookies{'lonID'};
     my $cookie;      my $cookie;
     if ($lonid) {      if (!$lonid) {
  my $handle=$lonid->value;   return FORBIDDEN;
         $handle=~s/\W//g;      }
         my $lonidsdir=$r->dir_config('lonIDsDir');  
         if ((-e "$lonidsdir/$handle.id") && ($handle ne '')) {      #check if cookie still valid
            my @profile;      my $handle=&LONCAPA::clean_handle($lonid->value);
            my %sessionhash;      my $lonidsdir=$r->dir_config('lonIDsDir');
     {      if ((!-e "$lonidsdir/$handle.id") || ($handle eq '')) {
              my $idf=Apache::File->new("$lonidsdir/$handle.id");   $r->log_reason("Cookie $handle not valid", $r->filename); 
              @profile=<$idf>;   return FORBIDDEN;
     }      }
             my $envi;  
             for ($envi=0;$envi<=$#profile;$envi++) {      #we've got a valid user
  chomp($profile[$envi]);      my @profile;
  my ($envname,$envvalue)=split(/=/,$profile[$envi]);      &Apache::lonnet::transfer_profile_to_env($lonidsdir,$handle);
                 $sessionhash{$envname}=$envvalue;      unlink("$lonidsdir/$handle.id");
             }      my %temp=('logout' => time);
             unlink("$lonidsdir/$handle.id");      &Apache::lonnet::put('email_status',\%temp);
     my %temp=('logout' => time);      &Apache::lonnet::log($env{'user.domain'},
     &Apache::lonnet::put('email_status',\%temp);   $env{'user.name'},
     &Apache::lonnet::log($sessionhash{'user.domain'},   $env{'user.home'},
                                  $sessionhash{'user.name'},   "Logout $ENV{'REMOTE_ADDR'}");
                                  $sessionhash{'user.home'},  
                                  "Logout $ENV{'REMOTE_ADDR'}");      &Apache::loncommon::content_type($r,'text/html');
             &Apache::loncommon::content_type($r,'text/html');  
             $r->send_http_header;      #expire the cookie
             return OK if $r->header_only;      my $c = new CGI::Cookie(-name    => 'lonID',
       -value   => '',
       -expires => '-10y',);
       $r->header_out('Set-cookie' => $c);
   
       $r->send_http_header;
       return OK if $r->header_only;
 # -------------------------------------------------------- Menu script and info  # -------------------------------------------------------- Menu script and info
   
     my $windowinfo=&Apache::lonmenu::close();      my $windowinfo=&Apache::lonmenu::close();
Line 77  sub handler { Line 84  sub handler {
 # ---------------------------------------------------------------- Get handover  # ---------------------------------------------------------------- Get handover
     &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['handover']);      &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['handover']);
     my $switch='';      my $switch='';
     my $bodytag='';      my $start_page='';
     my $relogmessage='';      my $relogmessage='';
     if ($env{'form.handover'}) {      if ($env{'form.handover'}) {
        $switch='<meta HTTP-EQUIV="Refresh" CONTENT="0.5; url='.   $switch='<meta HTTP-EQUIV="Refresh" CONTENT="0.5; url='.
    $env{'form.handover'}.'">';      $env{'form.handover'}.'">';
        $start_page=&Apache::loncommon::start_page('Switching Server ...',   $start_page=&Apache::loncommon::start_page('Switching Server ...',
   $switch);     $switch);
    } else {      } else {
        $start_page=&Apache::loncommon::start_page('Logged Out');   $start_page=&Apache::loncommon::start_page('Logged Out',undef,
        my %lt=&Apache::lonlocal::texthash('gb' => 'Goodbye',     {'no_inline_link' => 1,});
                                           'cw' => 'close this window',   my %lt=&Apache::lonlocal::texthash('gb' => 'Goodbye',
                                           'li' => 'log in again',     'cw' => 'close this window',
                                           'pe' => 'Please either',     'li' => 'log in again',
                                           'or' => 'or');     'pe' => 'Please either',
        $relogmessage=(<<ENDRELOG);     'or' => 'or');
 <h1>$lt{'gb'}!</h1>          my $relogin_server;
     $lt{'pe'} <a href="javascript:self.close();">$lt{'cw'}</a> $lt{'or'}          if ($env{'request.sso.reloginserver'}) {
 <a href="/adm/login?domain=$sessionhash{'user.domain'}">$lt{'li'}</a>.              $relogin_server = $env{'request.sso.reloginserver'};
           }
    my $login_url = $relogin_server.'/adm/'.
                           ($env{'request.sso.login'} ? 'roles': 'login');
    
    $relogmessage=(<<ENDRELOG);
    <h1>$lt{'gb'}!</h1>
       $lt{'pe'} <a href="javascript:self.close();">$lt{'cw'}</a> $lt{'or'}
    <a href="$login_url?domain=$env{'user.domain'}">$lt{'li'}</a>.
 ENDRELOG  ENDRELOG
    }  
    $end_page=&Apache::loncommon::end_page();          if ($env{'request.sso.login'}
       && defined($r->dir_config('lonSSOUserLogoutMessageFile'))) {
       open(my $fh,$r->dir_config('lonSSOUserLogoutMessageFile'));
       $relogmessage.= join('',<$fh>);
    }
   
       }
       my $end_page=&Apache::loncommon::end_page();
 # --------------------------------------------------------------- Screen Output  # --------------------------------------------------------------- Screen Output
             $r->print(<<ENDDOCUMENT);      $r->print(<<ENDDOCUMENT);
 $start_page  $start_page
 $windowinfo  $windowinfo
 $relogmessage  $relogmessage
 $end_page  $end_page
 ENDDOCUMENT  ENDDOCUMENT
             &Apache::lonnet::flushcourselogs();      &Apache::lonnet::flushcourselogs();
             return OK;       return OK; 
         } else {   
             $r->log_reason("Cookie $handle not valid", $r->filename);   
         }  
     }  
     return FORBIDDEN;  
 }  }
   
 1;  1;

Removed from v.1.16  
changed lines
  Added in v.1.25


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