--- loncom/auth/lontokacc.pm 2002/07/27 19:06:41 1.2 +++ loncom/auth/lontokacc.pm 2020/12/18 15:23:03 1.20 @@ -1,8 +1,7 @@ # The LearningOnline Network -# Low security Access Handler for Token-based access -# (clearance given by other loncapa host) +# Access Handler for User File Transfers # -# $Id: lontokacc.pm,v 1.2 2002/07/27 19:06:41 www Exp $ +# $Id: lontokacc.pm,v 1.20 2020/12/18 15:23:03 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -30,29 +29,42 @@ package Apache::lontokacc; use strict; -use Apache::Constants qw(:common); +use Apache::Constants qw(:common :remotehost); use Apache::lonnet(); -use Apache::loncommon(); +use Apache::File(); +use IO::Socket; sub handler { my $r = shift; - &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, - ['token','server']); - my $tmpinfo='no_token'; - if (($ENV{'form.token'}) || ($ENV{'form.server'})) { - $tmpinfo=&Apache::lonnet::unescape( - &Apache::lonnet::reply('tmpget:'.$ENV{'form.token'}, - $ENV{'form.server'})); - if ($tmpinfo eq $r->uri) { - return OK; - } + my $reqhost = &Apache::lonnet::get_requestor_ip($r,REMOTE_NOLOOKUP,1); + my @hostids= &Apache::lonnet::get_hosts_from_ip($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; } - $r->log_reason("Invalid token-based access ".$r->uri.' '.$tmpinfo, - $r->filename); - return FORBIDDEN; + if ($reqhost eq '127.0.0.1') { + return OK; + } + return OK; } +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); + } + return OK; +} 1; __END__ + + + + +