version 1.8, 2005/03/16 21:35:17
|
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'); |