File:  [LON-CAPA] / loncom / auth / lontokacc.pm
Revision 1.4: download - view: text, annotated - select for diffs
Thu Aug 1 22:36:11 2002 UTC (21 years, 11 months ago) by www
Branches: MAIN
CVS tags: HEAD
Completely new version, derived from lonracc, to control access to
userfile temp storage to registered servers only.

    1: # The LearningOnline Network
    2: # Access Handler for User File Transfers
    3: #
    4: # $Id: lontokacc.pm,v 1.4 2002/08/01 22:36:11 www Exp $
    5: #
    6: # Copyright Michigan State University Board of Trustees
    7: #
    8: # This file is part of the LearningOnline Network with CAPA (LON-CAPA).
    9: #
   10: # LON-CAPA is free software; you can redistribute it and/or modify
   11: # it under the terms of the GNU General Public License as published by
   12: # the Free Software Foundation; either version 2 of the License, or
   13: # (at your option) any later version.
   14: #
   15: # LON-CAPA is distributed in the hope that it will be useful,
   16: # but WITHOUT ANY WARRANTY; without even the implied warranty of
   17: # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   18: # GNU General Public License for more details.
   19: #
   20: # You should have received a copy of the GNU General Public License
   21: # along with LON-CAPA; if not, write to the Free Software
   22: # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
   23: #
   24: # /home/httpd/html/adm/gpl.txt
   25: #
   26: # http://www.lon-capa.org/
   27: #
   28: 
   29: package Apache::lontokacc;
   30: 
   31: use strict;
   32: use Apache::Constants qw(:common :remotehost);
   33: use Apache::lonnet();
   34: use Apache::File();
   35: 
   36: sub handler {
   37:     my $r = shift;
   38:     my $reqhost;
   39:     unless ($reqhost=$r->get_remote_host(REMOTE_DOUBLE_REV)) {
   40:        $r->log_reason("Spoof request");
   41:        return FORBIDDEN;
   42:     }
   43:     my $readline;
   44:     my $lontabdir=$r->dir_config('lonTabDir');
   45:     {
   46:        my $fh;
   47:        unless ($fh=Apache::File->new("$lontabdir/hosts.tab")) {
   48:           $r->log_reason("Could not find host tab file");
   49:           return FORBIDDEN;
   50:        }
   51:        while ($readline=<$fh>) {
   52:           my ($id,$domain,$role,$name,$ip)=split(/:/,$readline);
   53:           if ($name =~ /$reqhost/i) { return OK; }
   54:        }
   55: 
   56:     }
   57:     $r->log_reason("Invalid request for user file transfer from $reqhost", 
   58:                    $r->filename); 
   59:     return FORBIDDEN;
   60: }
   61: 
   62: 1;
   63: __END__
   64: 
   65: 
   66: 
   67: 
   68: 
   69: 
   70: 

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