Annotation of loncom/configuration/Configuration.pm, revision 1.9

1.1       harris41    1: # The LearningOnline Network with CAPA
                      2: # Configuration file reader
                      3: #
1.9     ! foxr        4: # $Id: Configuration.pm,v 1.8 2003/02/03 18:03:52 harris41 Exp $
1.1       harris41    5: #
                      6: #
                      7: # Copyright Michigan State University Board of Trustees
                      8: #
                      9: # This file is part of the LearningOnline Network with CAPA (LON-CAPA).
                     10: #
                     11: # LON-CAPA is free software; you can redistribute it and/or modify
                     12: # it under the terms of the GNU General Public License as published by
                     13: # the Free Software Foundation; either version 2 of the License, or
                     14: # (at your option) any later version.
                     15: #
                     16: # LON-CAPA is distributed in the hope that it will be useful,
                     17: # but WITHOUT ANY WARRANTY; without even the implied warranty of
                     18: # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
                     19: # GNU General Public License for more details.
                     20: #
                     21: # You should have received a copy of the GNU General Public License
                     22: # along with LON-CAPA; if not, write to the Free Software
                     23: # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
                     24: #
                     25: # /home/httpd/html/adm/gpl.txt
                     26: #
                     27: # http://www.lon-capa.org/
                     28: #
                     29: # YEAR=2002
                     30: #
                     31: ###
                     32: 
1.7       harris41   33: # POD documentation is at the end of this short module.
                     34: 
1.1       harris41   35: package LONCAPA::Configuration;
                     36: 
1.9     ! foxr       37: $VERSION = sprintf("%d.%02d", q$Revision: 1.8 $ =~ /(\d+)\.(\d+)/);
1.1       harris41   38: 
                     39: use strict;
                     40: 
                     41: my $confdir='/etc/httpd/conf/';
                     42: 
1.7       harris41   43: # ------------------- Subroutine read_conf: read LON-CAPA server configuration.
                     44: # This subroutine reads PerlSetVar values out of specified web server
                     45: # configuration files.
                     46: sub read_conf
                     47:   {
1.1       harris41   48:     my (@conf_files)=@_;
                     49:     my %perlvar;
1.7       harris41   50:     foreach my $filename (@conf_files,'loncapa_apache.conf')
                     51:       {
                     52: 	open(CONFIG,'<'.$confdir.$filename) or
                     53: 	    die("Can't read $confdir$filename");
                     54: 	while (my $configline=<CONFIG>)
                     55: 	  {
                     56: 	    if ($configline =~ /^[^\#]*PerlSetVar/)
                     57: 	      {
1.1       harris41   58: 		my ($unused,$varname,$varvalue)=split(/\s+/,$configline);
                     59: 		chomp($varvalue);
                     60: 		$perlvar{$varname}=$varvalue;
1.7       harris41   61: 	      }
                     62: 	  }
1.1       harris41   63: 	close(CONFIG);
1.7       harris41   64:       }
1.1       harris41   65:     my $perlvarref=\%perlvar;
                     66:     return ($perlvarref);
1.7       harris41   67:   }
1.1       harris41   68: 
1.9     ! foxr       69: #---------------------- Subroutine read_hosts: Read a LON-CAPA hosts.tab
        !            70: # formatted configuration file.
        !            71: #
        !            72: my $RequiredCount = 5;		# Required item count in hosts.tab.
        !            73: my $DefaultMaxCon = 5;		# Default value for maximum connections.
        !            74: my $DefaultIdle   = 1000;       # Default connection idle time in seconds.
        !            75: my $DefaultMinCon = 0;          # Default value for minimum connections.
        !            76: sub read_hosts {
        !            77:     my $Filename = shift;
        !            78:     my %HostsTab;
        !            79:     
        !            80:     open(CONFIG,'<'.$Filename) or die("Can't read $Filename");
        !            81:     while (my $line = <CONFIG>) {
        !            82: 	my @items = split(/:/, $line);
        !            83: 	if (scalar @items == $RequiredCount) {	# Have only all required items:
        !            84: 	    $items[$RequiredCount] = $DefaultMaxCon;
        !            85: 	}
        !            86: 	if(scalar @items == $RequiredCount + 1) { # Have up through maxcon.
        !            87: 	    $items[$RequiredCount+1] = $DefaultIdle;
        !            88: 	}
        !            89: 	if(scalar @items == $RequiredCount + 2) { # Have up through idle.
        !            90: 	    $items[$RequiredCount+2] = $DefaultMinCon;
        !            91: 	}
        !            92: 	{
        !            93: 	    my @list = @items;	# probably not needed but I'm unsure of 
        !            94: 				# about the scope of item so...
        !            95: 	    $HostsTab{@list[0]} = \@list; 
        !            96: 	}
        !            97:     }
        !            98:     close(CONFIG);
        !            99:     my $hostref = \%HostsTab;
        !           100:     return ($hostref);
        !           101: }
        !           102: 
        !           103: 1;
1.1       harris41  104: __END__
                    105: 
                    106: =pod
                    107: 
                    108: =head1 NAME
                    109: 
                    110: B<LONCAPA::Configuration> - configuration file reader
                    111: 
                    112: =head1 SYNOPSIS
                    113: 
                    114:  use lib '/home/httpd/lib/perl/';
                    115:  use LONCAPA::Configuration;
                    116: 
1.7       harris41  117:  LONCAPA::Configuration::read_conf('loncapa.conf');
1.9     ! foxr      118:  LONCAPA::Configuration::read_hosts(filename);
1.1       harris41  119: 
                    120: =head1 DESCRIPTION
                    121: 
1.9     ! foxr      122: Many different parts of the LON-CAPA software need to reads in the
1.4       harris41  123: machine-specific configuration information.  These included scripts
                    124: controlling the TCP/IP layer (e.g. F<lonc> and F<lond>), testing scripts
                    125: (e.g. test_weblayer.pl and sqltest.pl), and utility scripts
                    126: (e.g. clusterstatus.pl and metadata_keywords.pl).
1.1       harris41  127: 
                    128: The following methods are available:
                    129: 
                    130: =over 4
                    131: 
                    132: =item $perlvarref = LONCAPA::Configuration::read_conf( @filename_list );
                    133: 
                    134: On a typical LON-CAPA server, the filename list argument will consist of
                    135: just one element, "loncapa.conf".
                    136: 
                    137: If there are multiple elements within the filename list, then these
                    138: filenames are processed consecutively.
                    139: 
                    140: A hash reference is returned and consists of those values which
                    141: have been initialized from the configuration filenames indicated
                    142: in the arguments.
                    143: 
                    144: If multiple file names define the same hash key, then priority is
1.4       harris41  145: given toward the B<last> file name processed.
1.1       harris41  146: 
                    147: =back
1.9     ! foxr      148: 
        !           149: =over 4
        !           150: =item $hostinfo = LONCAPA::Configuration::read_hosts(filename);
        !           151: 
        !           152:   The parameter is the name of a file in hosts.tab form.  The file is read and
        !           153: parsed.  The return value is a reference to a hash.   The hash is indexed by
        !           154: host and each element of the has is in turn a reference to an anonymous list
        !           155: containing:
        !           156: 
        !           157: =over 4
        !           158: =item host
        !           159:    The loncapa hostname of the system. (This may be different than the 
        !           160:    network hostname, see below).
        !           161: =item domain
        !           162:    The loncapa domain in which the host lives.
        !           163: =item role
        !           164:     The role of the system, currently allowed values are access for an
        !           165:     access server and library for a library server.
        !           166: =item dns
        !           167:     The DNS hostname of the system. 
        !           168: =item ip
        !           169:     The IP address corresponding to the dns hostname of the system.
        !           170: =item maxconn 
        !           171:     The maximum number of connections this system should hold to the
        !           172:     target system's lond.  If the file has no value, a default is supplied
        !           173:     here by the function.
        !           174: =item idle
        !           175:     The number of seconds the oldest idle connection can be idle before it
        !           176:     should be adaptively dropped.  If the file has no value, a default
        !           177:     is supplied by the function.
        !           178: =item mincon
        !           179:     The minimum number of connections this system should hold to the
        !           180:     target system's lond.  If the file has no value, a default is supplied by
        !           181:     the funciton.
        !           182: 
        !           183: =back
        !           184: 
        !           185: =back
        !           186: 
        !           187: 
1.1       harris41  188: 
                    189: =head1 AUTHORS
                    190: 
                    191: This library is free software; you can redistribute it and/or
                    192: modify it under the same terms as LON-CAPA itself.
                    193: 
                    194: =cut

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