File:  [LON-CAPA] / loncom / lonnet / perl / lonrep.pm
Revision 1.1: download - view: text, annotated - select for diffs
Wed Oct 13 17:48:51 1999 UTC (24 years, 7 months ago) by albertel
Branches: MAIN
CVS tags: HEAD
Initial revision

# The LearningOnline Network
# Replication Manager
# (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 Gerd Kortemeyer

package Apache::lonrep;

use strict;
use Apache::Constants qw(:common :http);
use LWP::UserAgent();
use Apache::lonnet();
use Apache::File();

sub handler {
    my $r = shift;
    if (-e $r->finfo) {
      return OK;
    } else {
      my $filename=$r->filename.$r->path_info;
      my $transname="$filename.in.transfer";
      if (-e $transname) {
	sleep 10;
        $r->filename($filename);
        if (-e $r->finfo) {
	   return OK;
        } else {
	   $r->log_reason("Waiting for file transfer timed out",$filename);
	   return HTTP_SERVICE_UNAVAILABLE;
        }
      } else {
        my $remoteurl=Apache::lonnet::subscribe($filename);
        if ($remoteurl eq 'con_lost') {
	   $r->log_reason("Subscribe returned con_lost",$filename);
           return HTTP_SERVICE_UNAVAILABLE;
	} elsif ($remoteurl eq 'not_found') {
	   $r->log_reason("Subscribe returned not_found",$filename);
	   return HTTP_NOT_FOUND;
        } elsif ($remoteurl eq 'forbidden') {
	   $r->log_reason("Subscribe returned forbidden",$filename);
           return FORBIDDEN;
        } else {
           my @parts=split(/\//,$filename);
           my $path="/$parts[1]/$parts[2]/$parts[3]/$parts[4]";
           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;
__END__









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