--- loncom/auth/lonracc.pm 2005/02/06 07:23:40 1.15 +++ loncom/auth/lonracc.pm 2007/02/01 06:20:34 1.18 @@ -1,7 +1,7 @@ # The LearningOnline Network # Access Handler for File Transfers # -# $Id: lonracc.pm,v 1.15 2005/02/06 07:23:40 albertel Exp $ +# $Id: lonracc.pm,v 1.18 2007/02/01 06:20:34 albertel Exp $ # # Copyright Michigan State University Board of Trustees # @@ -30,20 +30,26 @@ package Apache::lonracc; use strict; use Apache::Constants qw(:common :remotehost); -use Apache::lonnet(); +use Apache::lonnet; use Apache::File(); use IO::Socket; sub subscribed { my ($filename,$id) = @_; - my $found=0; + + return 0 if (-e "$filename.subscription"); + my $hostname=$Apache::lonnet::hostname{$id}; my (undef,undef,undef,undef,$ip) = gethostbyname($hostname); + + return 0 if (length($ip) != 4); + $ip=inet_ntoa($ip); - my $expr='^'.$id.':'.$ip.':'; - $expr =~ s/\./\\\./g; - my $sh; - if ($sh=Apache::File->new("$filename.subscription")) { + + my $expr='^'.quotemeta($id).':'.quotemeta($ip).':'; + + my $found=0; + if (my $sh=Apache::File->new("$filename.subscription")) { while (my $subline=<$sh>) { if ($subline =~ /$expr/) { $found=1; } } $sh->close(); } @@ -53,31 +59,30 @@ sub subscribed { sub handler { my $r = shift; my $reqhost = $r->get_remote_host(REMOTE_NOLOOKUP); - my $netaddr=inet_aton($reqhost); - ($reqhost) = gethostbyaddr($netaddr,AF_INET); - if (!$reqhost) { - $r->log_reason("Unable to do hostname $reqhost lookup for ".$r->get_remote_host(REMOTE_NOLOOKUP)); + my %iphost=&Apache::lonnet::get_iphost(); + my $hostids=$iphost{$reqhost}; + if (!$hostids && $reqhost ne '127.0.0.1' ) { + $r->log_reason("Unable to find a host for ". + $r->get_remote_host(REMOTE_NOLOOKUP)); return FORBIDDEN; } - if ($reqhost eq 'localhost.localdomain') { + if ($reqhost eq '127.0.0.1') { return OK; } my $return; - my @ids=(); - my $id; - foreach $id (keys %Apache::lonnet::hostname) { - if ($Apache::lonnet::hostname{$id} =~ /^\Q$reqhost\E$/i) { - my $filename=$r->filename; - my $uri =$r->uri; - if ((-e "$filename.$id") || - &subscribed($filename,$id) || - ($filename=~/\.meta$/) || - ($uri=~m|^/raw/uploaded|)) { - return OK; - } else { - $return=FORBIDDEN; - push(@ids,$id); - } + my @ids; + + foreach my $id (@{$hostids}) { + my $filename=$r->filename; + my $uri =$r->uri; + if (($filename=~/\.meta$/) || + ($uri=~m|^/raw/uploaded|) || + (-e "$filename.$id") || + &subscribed($filename,$id) ) { + return OK; + } else { + $return=FORBIDDEN; + push(@ids,$id); } } if ($return == FORBIDDEN) {