Diff for /loncom/auth/switchserver.pm between versions 1.35.2.1 and 1.35.2.2

version 1.35.2.1, 2019/08/01 15:20:06 version 1.35.2.2, 2019/08/03 23:27:39
Line 128  sub handler { Line 128  sub handler {
     if ($env{'user.name'} eq 'public'      if ($env{'user.name'} eq 'public'
  && $env{'user.domain'} eq 'public') {   && $env{'user.domain'} eq 'public') {
  my $url = $protocol.'://'.$switch_to.$r->uri;   my $url = $protocol.'://'.$switch_to.$r->uri;
           unlink($handle);
           #expire the cookie
           my $c = new CGI::Cookie(-name    => 'lonPubID',
                                   -value   => '',
                                   -expires => '-10y',);
           $r->header_out('Set-cookie' => $c);
  return &do_redirect($r,$url,1)   return &do_redirect($r,$url,1)
     }      }
   
Line 178  sub handler { Line 184  sub handler {
     }      }
   
     #remove session env, and log event      #remove session env, and log event
     unlink($handle);      if (unlink($handle)) {
           if ($env{'user.linkedenv'} ne '') {
               my $lonidsdir=$r->dir_config('lonIDsDir');
               if (($env{'user.linkedenv'} =~ /^[a-f0-9]+_linked$/) &&
                   (-l "$lonidsdir/$env{'user.linkedenv'}.id") &&
                   (readlink("$lonidsdir/$env{'user.linkedenv'}.id") eq $handle)) {
                   unlink("$lonidsdir/$env{'user.linkedenv'}.id");
               }
           }
       }
     my %temp=('switchserver' => $now.':'.$env{'form.otherserver'},      my %temp=('switchserver' => $now.':'.$env{'form.otherserver'},
       $env{'form.role'});        $env{'form.role'});
     &Apache::lonnet::put('email_status',\%temp);      &Apache::lonnet::put('email_status',\%temp);
Line 194  sub handler { Line 209  sub handler {
   
     &Apache::loncommon::content_type($r,'text/html');      &Apache::loncommon::content_type($r,'text/html');
   
     #expire the cookie      #expire the cookies
     my $c = new CGI::Cookie(-name    => 'lonID',      my %cookies=CGI::Cookie->parse($r->header_in('Cookie'));
     -value   => '',      foreach my $name (keys(%cookies)) {
     -expires => '-10y',);          next unless ($name =~ /^lon(|S|Link|Pub)ID$/);
     $r->header_out('Set-cookie' => $c);          my $c = new CGI::Cookie(-name    => $name,
                                   -value   => '',
                                   -expires => '-10y',);
           $r->headers_out->add('Set-cookie' => $c);
       }
     if ($r->header_only) {      if ($r->header_only) {
  $r->send_http_header;   $r->send_http_header;
  return OK;   return OK;

Removed from v.1.35.2.1  
changed lines
  Added in v.1.35.2.2


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