[open-ils-commits] r7996 - in trunk/Open-ILS: examples/apache src/perlmods/OpenILS/WWW

svn at svn.open-ils.org svn at svn.open-ils.org
Sun Nov 4 17:45:20 EST 2007


Author: erickson
Date: 2007-11-04 17:30:00 -0500 (Sun, 04 Nov 2007)
New Revision: 7996

Modified:
   trunk/Open-ILS/examples/apache/startup.pl
   trunk/Open-ILS/src/perlmods/OpenILS/WWW/Redirect.pm
Log:
Removed any assumptions about the structure of the org hierarchy from the
IP range handling code.

Moved the parsing code into the redirector and added a commented-out 
incantation to startup.pl



Modified: trunk/Open-ILS/examples/apache/startup.pl
===================================================================
--- trunk/Open-ILS/examples/apache/startup.pl	2007-11-04 20:04:04 UTC (rev 7995)
+++ trunk/Open-ILS/examples/apache/startup.pl	2007-11-04 22:30:00 UTC (rev 7996)
@@ -6,6 +6,15 @@
 use OpenILS::WWW::Proxy ('/openils/conf/opensrf_core.xml');
 
 
+# - Uncoment the following 2 lines to make use of the IP redirection code
+# - The IP file should to contain a map with the following format:
+# - actor.org_unit.shortname <start_ip> <end_ip>
+# - e.g.  LIB123 10.0.0.1 10.0.0.254
 
+#use OpenILS::WWW::Redirect qw(/openils/conf/opensrf_core.xml);
+#OpenILS::WWW::Redirect->parse_ips_file('/openils/conf/lib_ips.txt');
+
+
+
 1;
 

Modified: trunk/Open-ILS/src/perlmods/OpenILS/WWW/Redirect.pm
===================================================================
--- trunk/Open-ILS/src/perlmods/OpenILS/WWW/Redirect.pm	2007-11-04 20:04:04 UTC (rev 7995)
+++ trunk/Open-ILS/src/perlmods/OpenILS/WWW/Redirect.pm	2007-11-04 22:30:00 UTC (rev 7996)
@@ -1,21 +1,20 @@
 package OpenILS::WWW::Redirect;
 use strict; use warnings;
+
 use Socket;
-
 use Apache2::Log;
 use Apache2::Const -compile => qw(OK REDIRECT :log);
 use APR::Const    -compile => qw(:error SUCCESS);
-use Template;
 use Apache2::RequestRec ();
 use Apache2::RequestIO ();
 use CGI ();
 
 use OpenSRF::AppSession;
 use OpenSRF::System;
-use OpenILS::Utils::Fieldmapper;
 use OpenSRF::Utils::Logger qw/$logger/;
 
 use vars '$lib_ips_hash';
+my $lib_ips_hash;
 
 my $bootstrap_config_file;
 sub import {
@@ -27,7 +26,30 @@
 	OpenSRF::System->bootstrap_client( config_file => $bootstrap_config_file );
 }
 
+sub parse_ips_file {
+    my $class = shift;
+    my $ips_file = shift;
 
+    if( open(F, $ips_file) ) {
+
+       while( my $data = <F> ) {
+         chomp($data);
+
+         my( $shortname, $ip1, $ip2 ) = split(/\s+/, $data);
+         next unless ($shortname and $ip1 and $ip2);
+
+         $lib_ips_hash->{$shortname} = [] unless $lib_ips_hash->{$shortname};
+         push( @{$lib_ips_hash->{$shortname}}, [ $ip1, $ip2 ] );
+       }
+
+       close(F);
+
+    } else {
+        $logger->error("Unable to open lib IP redirector file $ips_file");
+    }
+}
+
+
 sub handler {
 
 	my $user_ip = $ENV{REMOTE_ADDR};
@@ -46,20 +68,16 @@
 
 	$logger->debug("Apache client connecting from $user_ip");
 
-	if( my $lib_data = redirect_libs( $user_ip ) ) {
-		my $region = $lib_data->[0];
-		my $library = $lib_data->[1];
+	if(my $shortname = redirect_libs($user_ip)) {
 
-		$logger->info("Apache redirecting $user_ip to $region / $library");
+		$logger->info("Apache redirecting $user_ip to $shortname");
 		my $session = OpenSRF::AppSession->create("open-ils.storage");
-		my $shortname = "$region-$library";
 
 		my $org = $session->request(
 			"open-ils.storage.direct.actor.org_unit.search.shortname",
 			 $shortname)->gather(1);
 
 		if($org) { $url .= "?ol=" . $org->id; }
-
 	}
 
 	print "Location: $url\n\n"; 
@@ -72,26 +90,23 @@
 	my $source_ip = shift;
 	my $aton_binary = inet_aton( $source_ip );
 
-	if( ! $aton_binary ) { return 0; }
+    return 0 unless $aton_binary;
 
 	# do this the linear way for now...
-	for my $reg (keys %$lib_ips_hash) {
+	for my $shortname (keys %$lib_ips_hash) {
 
-		for my $lib( keys %{$lib_ips_hash->{$reg}} ) {
+        for my $block (@{$lib_ips_hash->{$shortname}}) {
 
-			for my $block (@{$lib_ips_hash->{$reg}->{$lib}}) {
-
-				if(defined($block->[0]) && defined($block->[1]) ) {
-					my $start_binary	= inet_aton( $block->[0] );
-					my $end_binary		= inet_aton( $block->[1] );
-					unless( $start_binary and $end_binary ) { next; }
-					if( $start_binary le $aton_binary and
-							$end_binary ge $aton_binary ) {
-						return [ $reg, $lib ];
-					}
-				}
-			}
-		}
+            if(defined($block->[0]) && defined($block->[1]) ) {
+                my $start_binary	= inet_aton( $block->[0] );
+                my $end_binary		= inet_aton( $block->[1] );
+                next unless( $start_binary and $end_binary );
+                if( $start_binary le $aton_binary and
+                        $end_binary ge $aton_binary ) {
+                    return $shortname;
+                }
+            }
+        }
 	}
 	return 0;
 }



More information about the open-ils-commits mailing list