--- loncom/lonnet/perl/lonrep.pm	2000/01/14 21:12:40	1.3
+++ loncom/lonnet/perl/lonrep.pm	2005/03/16 21:35:17	1.8
@@ -1,12 +1,38 @@
 # The LearningOnline Network
 # Replication Manager
+#
+# $Id: lonrep.pm,v 1.8 2005/03/16 21:35:17 raeburn 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/
+#
 # (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 Gerd Kortemeyer
+# 01/06,01/14,10/5,
+# 06/14/01 Gerd Kortemeyer
 
 package Apache::lonrep;
 
@@ -14,6 +40,7 @@ use strict;
 use Apache::Constants qw(:common :http);
 use Apache::lonnet();
 use Apache::File();
+use CGI::Cookie();
 
 sub handler {
     my $r = shift;
@@ -21,6 +48,7 @@ sub handler {
       return OK;
     } else {
       my $filename=$r->filename.$r->path_info;
+      if ($filename=~/\/$/) { return OK; }
       if (-e "$filename.in.transfer") {
 	sleep 10;
         $r->filename($filename);
@@ -32,10 +60,19 @@ sub handler {
         }
       } else {
           my $response=Apache::lonnet::repcopy($filename);
-          if ($response==OK) {
+          if ($response eq 'ok') {
 	      $r->filename($filename);
+              return OK;
           }
-          return $response;
+          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;
+          } 
       }
     }
 }