Diff for /loncom/lonnet/perl/lonrep.pm between versions 1.7 and 1.15

version 1.7, 2005/03/02 22:26:36 version 1.15, 2020/09/03 13:40:50
Line 25 Line 25
 #  #
 # http://www.lon-capa.org/  # http://www.lon-capa.org/
 #  #
 # (Access Handler for File Transfers  
 # (lonacc: Cookie Based Access Handler  
 # 5/21/99,5/22,5/29,5/31,6/15 Gerd Kortemeyer)  
 # 6/16,6/18 Gerd Kortemeyer)  
 # 6/18,6/21,6/26,6/28,6/29,6/30,  
 # 7/2,7/3,7/9,7/10,7/12,  
 # 01/06,01/14,10/5,  
 # 06/14/01 Gerd Kortemeyer  
   
 package Apache::lonrep;  package Apache::lonrep;
   
 use strict;  use strict;
 use Apache::Constants qw(:common :http);  use Apache::Constants qw(:common :http);
 use Apache::lonnet();  use Apache::lonnet;
 use Apache::File();  use Apache::File();
 use CGI::Cookie();  
   sub update_filename {
       my ($r,$filename) = @_;
       my $oldfile = $r->filename($filename);
       if ($ENV{'MOD_PERL_API_VERSION'} == 2
    && -e $filename) {
    eval {
       require APR::Finfo;
       require APR::Const;
       $r->finfo(APR::Finfo::stat($filename, 
          &APR::Const::FINFO_NORM(),
          $r->pool));
    };
    if ($@) {
       return $@;
    }
       }
       return;
   }
   
 sub handler {  sub handler {
     my $r = shift;      my $r = shift;
Line 49  sub handler { Line 59  sub handler {
     } else {      } else {
       my $filename=$r->filename.$r->path_info;        my $filename=$r->filename.$r->path_info;
       if ($filename=~/\/$/) { return OK; }        if ($filename=~/\/$/) { return OK; }
         if ($filename eq '/home/httpd/html/res/lib/templates/simpleproblem.problem/smpedit') { return OK; }
       if (-e "$filename.in.transfer") {        if (-e "$filename.in.transfer") {
  sleep 10;   sleep 10;
         $r->filename($filename);          if (-e $filename) {
         if (-e $r->finfo) {      my $error = &update_filename($r,$filename);
    return OK;      if ($error) {
    $r->log_reason('Update filename failed '.$error);
    return HTTP_SERVICE_UNAVAILABLE;
       }
       return OK;
         } else {          } else {
    $r->log_reason("Waiting for file transfer timed out",$filename);      $r->log_reason("Waiting for file transfer timed out",$filename);
    return HTTP_SERVICE_UNAVAILABLE;      return HTTP_SERVICE_UNAVAILABLE;
         }          }
       } else {        } else {
           my $response=Apache::lonnet::repcopy($filename);            my $response=&Apache::lonnet::repcopy($filename);
           if ($response eq 'OK') {            if ($response eq 'ok' && -e $filename) {
       $r->filename($filename);        $r->path_info('');
         my $error = &update_filename($r,$filename);
         if ($error) {
     $r->log_reason('Update filename failed after replication '.$error);
     return HTTP_SERVICE_UNAVAILABLE;
         }
               return OK;                return OK;
           }            }
           my %cookies=CGI::Cookie->parse($r->header_in('Cookie'));            my $handle = &Apache::lonnet::check_for_valid_session($r);
           my $lonid=$cookies{'lonID'};            if ($handle) {
           if ($lonid) {       $r->log_reason('Replication failed for '.$handle);
      $r->log_reason('Replication failed for '.$lonid->value);  
              return $response;               return $response;
   } else {    } else {
      $r->log_reason('Replication failed for unknown user');        $r->log_reason('Replication failed for unknown user'); 

Removed from v.1.7  
changed lines
  Added in v.1.15


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