--- loncom/auth/lontokacc.pm 2002/08/01 22:36:11 1.4 +++ loncom/auth/lontokacc.pm 2003/08/01 15:46:10 1.8 @@ -1,7 +1,7 @@ # The LearningOnline Network # Access Handler for User File Transfers # -# $Id: lontokacc.pm,v 1.4 2002/08/01 22:36:11 www Exp $ +# $Id: lontokacc.pm,v 1.8 2003/08/01 15:46:10 www Exp $ # # Copyright Michigan State University Board of Trustees # @@ -33,12 +33,20 @@ use Apache::Constants qw(:common :remote use Apache::lonnet(); use Apache::File(); + sub handler { my $r = shift; - my $reqhost; - unless ($reqhost=$r->get_remote_host(REMOTE_DOUBLE_REV)) { - $r->log_reason("Spoof request"); - return FORBIDDEN; + my $reqhost = $r->get_remote_host(REMOTE_DOUBLE_REV); + if (!$reqhost && $r->get_remote_host(REMOTE_NOLOOKUP) eq $r->get_server_name()) { + $reqhost = $r->get_server_name(); + } + unless ($reqhost) { + $r->log_reason("Spoof request from ". $reqhost); + return FORBIDDEN; + } + if ($reqhost eq 'localhost.localdomain') { + $r->register_cleanup(\&removefile); + return OK; } my $readline; my $lontabdir=$r->dir_config('lonTabDir'); @@ -50,7 +58,10 @@ sub handler { } while ($readline=<$fh>) { my ($id,$domain,$role,$name,$ip)=split(/:/,$readline); - if ($name =~ /$reqhost/i) { return OK; } + if ($name =~ /$reqhost/i) { + $r->register_cleanup(\&removefile); + return OK; + } } } @@ -59,6 +70,15 @@ sub handler { return FORBIDDEN; } +sub removefile { + my $r=shift; + if ($r->status==200) { + unlink($r->filename); + &Apache::lonnet::logthis('Unlinking '.$r->filename); + } else { + &Apache::lonnet::logthis('Failed to transfer '.$r->filename); + } +} 1; __END__