--- loncom/lonnet/perl/lonrep.pm 2005/03/16 21:35:17 1.8 +++ loncom/lonnet/perl/lonrep.pm 2007/01/29 22:07:12 1.12 @@ -1,7 +1,7 @@ # The LearningOnline Network # Replication Manager # -# $Id: lonrep.pm,v 1.8 2005/03/16 21:35:17 raeburn Exp $ +# $Id: lonrep.pm,v 1.12 2007/01/29 22:07:12 albertel Exp $ # # Copyright Michigan State University Board of Trustees # @@ -25,23 +25,29 @@ # # 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; use strict; use Apache::Constants qw(:common :http); -use Apache::lonnet(); +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) { @@ -51,17 +57,18 @@ sub handler { if ($filename=~/\/$/) { return OK; } if (-e "$filename.in.transfer") { sleep 10; - $r->filename($filename); - if (-e $r->finfo) { - return OK; + if (-e $filename) { + &update_filename($r,$filename); + return OK; } else { - $r->log_reason("Waiting for file transfer timed out",$filename); - return HTTP_SERVICE_UNAVAILABLE; + $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') { - $r->filename($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'));