File:  [LON-CAPA] / loncom / lonnet / perl / lonrep.pm
Revision 1.12: download - view: text, annotated - select for diffs
Mon Jan 29 22:07:12 2007 UTC (17 years, 5 months ago) by albertel
Branches: MAIN
CVS tags: HEAD
- only update the finfo if the file exists

# The LearningOnline Network
# Replication Manager
#
# $Id: lonrep.pm,v 1.12 2007/01/29 22:07:12 albertel Exp $
#
# Copyright Michigan State University Board of Trustees
#
# This file is part of the LearningOnline Network with CAPA (LON-CAPA).
#
# LON-CAPA is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# LON-CAPA is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with LON-CAPA; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
#
# /home/httpd/html/adm/gpl.txt
#
# http://www.lon-capa.org/
#

package Apache::lonrep;

use strict;
use Apache::Constants qw(:common :http);
use Apache::lonnet;
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) {
	require APR::Finfo;
	require APR::Const;
	$r->finfo(APR::Finfo::stat($filename, 
				   &APR::Const::FINFO_NORM(),
				   $r->pool));
    }
    return $oldfile;
}

sub handler {
    my $r = shift;
    if (-e $r->finfo) {
      return OK;
    } else {
      my $filename=$r->filename.$r->path_info;
      if ($filename=~/\/$/) { return OK; }
      if (-e "$filename.in.transfer") {
	sleep 10;
        if (-e $filename) {
	    &update_filename($r,$filename);
	    return OK;
        } else {
	    $r->log_reason("Waiting for file transfer timed out",$filename);
	    return HTTP_SERVICE_UNAVAILABLE;
        }
      } else {
          my $response=Apache::lonnet::repcopy($filename);
          if ($response eq 'ok' && -e $filename) {
	      $r->path_info('');
	      &update_filename($r,$filename);
              return OK;
          }
          my %cookies=CGI::Cookie->parse($r->header_in('Cookie'));
          my $lonid=$cookies{'lonID'};
          if ($lonid) {
	     $r->log_reason('Replication failed for '.$lonid->value);
             return $response;
	  } else {
	     $r->log_reason('Replication failed for unknown user'); 
             return FORBIDDEN;
          } 
      }
    }
}

1;
__END__









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