Annotation of loncom/lonnet/perl/lonrep.pm, revision 1.15

1.1       albertel    1: # The LearningOnline Network
                      2: # Replication Manager
1.6       www         3: #
1.15    ! raeburn     4: # $Id: lonrep.pm,v 1.14 2007/10/02 01:09:53 albertel Exp $
1.6       www         5: #
                      6: # Copyright Michigan State University Board of Trustees
                      7: #
                      8: # This file is part of the LearningOnline Network with CAPA (LON-CAPA).
                      9: #
                     10: # LON-CAPA is free software; you can redistribute it and/or modify
                     11: # it under the terms of the GNU General Public License as published by
                     12: # the Free Software Foundation; either version 2 of the License, or
                     13: # (at your option) any later version.
                     14: #
                     15: # LON-CAPA is distributed in the hope that it will be useful,
                     16: # but WITHOUT ANY WARRANTY; without even the implied warranty of
                     17: # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
                     18: # GNU General Public License for more details.
                     19: #
                     20: # You should have received a copy of the GNU General Public License
                     21: # along with LON-CAPA; if not, write to the Free Software
                     22: # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
                     23: #
                     24: # /home/httpd/html/adm/gpl.txt
                     25: #
                     26: # http://www.lon-capa.org/
                     27: #
1.1       albertel   28: 
                     29: package Apache::lonrep;
                     30: 
                     31: use strict;
                     32: use Apache::Constants qw(:common :http);
1.9       albertel   33: use Apache::lonnet;
1.1       albertel   34: use Apache::File();
                     35: 
1.11      albertel   36: sub update_filename {
                     37:     my ($r,$filename) = @_;
                     38:     my $oldfile = $r->filename($filename);
1.12      albertel   39:     if ($ENV{'MOD_PERL_API_VERSION'} == 2
                     40: 	&& -e $filename) {
1.13      albertel   41: 	eval {
                     42: 	    require APR::Finfo;
                     43: 	    require APR::Const;
                     44: 	    $r->finfo(APR::Finfo::stat($filename, 
                     45: 				       &APR::Const::FINFO_NORM(),
                     46: 				       $r->pool));
                     47: 	};
                     48: 	if ($@) {
                     49: 	    return $@;
                     50: 	}
1.11      albertel   51:     }
1.13      albertel   52:     return;
1.11      albertel   53: }
                     54: 
1.1       albertel   55: sub handler {
                     56:     my $r = shift;
                     57:     if (-e $r->finfo) {
                     58:       return OK;
                     59:     } else {
                     60:       my $filename=$r->filename.$r->path_info;
1.5       www        61:       if ($filename=~/\/$/) { return OK; }
1.15    ! raeburn    62:       if ($filename eq '/home/httpd/html/res/lib/templates/simpleproblem.problem/smpedit') { return OK; }
1.2       www        63:       if (-e "$filename.in.transfer") {
1.1       albertel   64: 	sleep 10;
1.12      albertel   65:         if (-e $filename) {
1.13      albertel   66: 	    my $error = &update_filename($r,$filename);
                     67: 	    if ($error) {
                     68: 		$r->log_reason('Update filename failed '.$error);
                     69: 		return HTTP_SERVICE_UNAVAILABLE;
                     70: 	    }
1.12      albertel   71: 	    return OK;
1.1       albertel   72:         } else {
1.12      albertel   73: 	    $r->log_reason("Waiting for file transfer timed out",$filename);
                     74: 	    return HTTP_SERVICE_UNAVAILABLE;
1.1       albertel   75:         }
                     76:       } else {
1.13      albertel   77:           my $response=&Apache::lonnet::repcopy($filename);
1.12      albertel   78:           if ($response eq 'ok' && -e $filename) {
1.10      albertel   79: 	      $r->path_info('');
1.13      albertel   80: 	      my $error = &update_filename($r,$filename);
                     81: 	      if ($error) {
                     82: 		  $r->log_reason('Update filename failed after replication '.$error);
                     83: 		  return HTTP_SERVICE_UNAVAILABLE;
                     84: 	      }
1.4       www        85:               return OK;
1.3       www        86:           }
1.14      albertel   87:           my $handle = &Apache::lonnet::check_for_valid_session($r);
                     88:           if ($handle) {
                     89: 	     $r->log_reason('Replication failed for '.$handle);
1.4       www        90:              return $response;
                     91: 	  } else {
                     92: 	     $r->log_reason('Replication failed for unknown user'); 
                     93:              return FORBIDDEN;
                     94:           } 
1.1       albertel   95:       }
1.2       www        96:     }
1.1       albertel   97: }
                     98: 
                     99: 1;
                    100: __END__
                    101: 
                    102: 
                    103: 
                    104: 
                    105: 
                    106: 
                    107: 
                    108: 

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