version 1.1, 1999/10/13 17:48:51
|
version 1.5, 2001/06/14 17:54:04
|
Line 5
|
Line 5
|
# 5/21/99,5/22,5/29,5/31,6/15 Gerd Kortemeyer) |
# 5/21/99,5/22,5/29,5/31,6/15 Gerd Kortemeyer) |
# 6/16,6/18 Gerd Kortemeyer) |
# 6/16,6/18 Gerd Kortemeyer) |
# 6/18,6/21,6/26,6/28,6/29,6/30, |
# 6/18,6/21,6/26,6/28,6/29,6/30, |
# 7/2,7/3,7/9,7/10,7/12 Gerd Kortemeyer |
# 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 LWP::UserAgent(); |
|
use Apache::lonnet(); |
use Apache::lonnet(); |
use Apache::File(); |
use Apache::File(); |
|
use CGI::Cookie(); |
|
|
sub handler { |
sub handler { |
my $r = shift; |
my $r = shift; |
Line 21 sub handler {
|
Line 23 sub handler {
|
return OK; |
return OK; |
} else { |
} else { |
my $filename=$r->filename.$r->path_info; |
my $filename=$r->filename.$r->path_info; |
my $transname="$filename.in.transfer"; |
if ($filename=~/\/$/) { return OK; } |
if (-e $transname) { |
if (-e "$filename.in.transfer") { |
sleep 10; |
sleep 10; |
$r->filename($filename); |
$r->filename($filename); |
if (-e $r->finfo) { |
if (-e $r->finfo) { |
Line 32 sub handler {
|
Line 34 sub handler {
|
return HTTP_SERVICE_UNAVAILABLE; |
return HTTP_SERVICE_UNAVAILABLE; |
} |
} |
} else { |
} else { |
my $remoteurl=Apache::lonnet::subscribe($filename); |
my $response=Apache::lonnet::repcopy($filename); |
if ($remoteurl eq 'con_lost') { |
if ($response==OK) { |
$r->log_reason("Subscribe returned con_lost",$filename); |
$r->filename($filename); |
return HTTP_SERVICE_UNAVAILABLE; |
return OK; |
} elsif ($remoteurl eq 'not_found') { |
} |
$r->log_reason("Subscribe returned not_found",$filename); |
my %cookies=CGI::Cookie->parse($r->header_in('Cookie')); |
return HTTP_NOT_FOUND; |
my $lonid=$cookies{'lonID'}; |
} elsif ($remoteurl eq 'forbidden') { |
if ($lonid) { |
$r->log_reason("Subscribe returned forbidden",$filename); |
$r->log_reason('Replication failed for '.$lonid->value); |
return FORBIDDEN; |
return $response; |
} else { |
} else { |
my @parts=split(/\//,$filename); |
$r->log_reason('Replication failed for unknown user'); |
my $path="/$parts[1]/$parts[2]/$parts[3]/$parts[4]"; |
return FORBIDDEN; |
my $count; |
} |
for ($count=5;$count<$#parts;$count++) { |
|
$path.="/$parts[$count]"; |
|
if ((-e $path)!=1) { |
|
mkdir($path,0777); |
|
} |
|
} |
|
my $ua=new LWP::UserAgent; |
|
my $request=new HTTP::Request('GET',"$remoteurl"); |
|
my $response=$ua->request($request,$transname); |
|
if ($response->is_error()) { |
|
unlink($transname); |
|
my $message=$response->status_line; |
|
$r->log_reason("LWP GET: $message",$filename); |
|
return HTTP_SERVICE_UNAVAILABLE; |
|
} else { |
|
rename($transname,$filename); |
|
$r->filename($filename); |
|
return OK; |
|
} |
|
} |
|
} |
} |
} |
} |
} |
} |
|
|
1; |
1; |