[open-ils-commits] r15508 - trunk/Open-ILS/src/support-scripts (erickson)
svn at svn.open-ils.org
svn at svn.open-ils.org
Fri Feb 12 08:29:28 EST 2010
Author: erickson
Date: 2010-02-12 08:29:27 -0500 (Fri, 12 Feb 2010)
New Revision: 15508
Modified:
trunk/Open-ILS/src/support-scripts/offline-blocked-list.pl
Log:
Patch from Joe Atzberger to add getop support for defininging the call style, hostname, etc. and a fix to bypass some extraneous oils_requestor output that was dying during json parsing
Modified: trunk/Open-ILS/src/support-scripts/offline-blocked-list.pl
===================================================================
--- trunk/Open-ILS/src/support-scripts/offline-blocked-list.pl 2010-02-11 20:19:18 UTC (rev 15507)
+++ trunk/Open-ILS/src/support-scripts/offline-blocked-list.pl 2010-02-12 13:29:27 UTC (rev 15508)
@@ -1,93 +1,180 @@
#!/usr/bin/perl
+#
+
use strict; use warnings;
-my $config = shift || die "Please specify a config file\n";
-my $context = shift || 'opensrf';
+use Getopt::Long;
-my $oils_reqr = 'BINDIR/oils_requestor'; # XXX command line param
+use OpenSRF::Utils::JSON; # for the oils_requestor approach
+use IPC::Open2 qw/open2/; # for the oils_requestor approach
+use Net::Domain qw/hostfqdn/; # for the oils_requestor approach
-if(1) { # XXX command line param
+# use OpenSRF::EX qw(:try); # for traditional approach
+use OpenSRF::System; # for traditional approach
+use OpenSRF::AppSession; # for traditional approach
+### USAGE
+
+sub usage {
+ my $defhost = hostfqdn();
+ return <<END_OF_USAGE
+
+$0
+
+Generate a file of blocked barcodes for offline use. There are two styles of
+invocation, old and new (using oils_requestor). See WARNING.
+
+By default, all known blocked barcodes are output. Override with --barcodes option.
+
+OPTIONS:
+
+--oldstyle Use traditional OpenSRF calls default: OFF.
+--verbose give feedback on STDERR, including number of barcodes fetched
+--help print this message
+
+--config =[file] core config file default: /openils/conf/opensrf_core.xml
+--requestor=[/path/to/requstor] default: /openils/bin/oils_requestor
+--hostname =[my.fqdn.com] default: hostfqdn()
+ (Only used by new style.)
+ May be necessary if hostfqdn does not match router configs.
+ Currently your hostfqdn is '$defhost'.
+
+--barcodes [key=eg_code] default: ALL
+ Specify what kind of barcodes to fetch and how to tag them in the output.
+ The key is the (one letter) tag used in the offline file,
+ and the eg_code is the component of the SRF call that targets the barcodes
+ (like "lost"). NOTE: This option can be specified multiple times.
+
+
+EXAMPLES:
+
+# Use the old style with a custom config
+$0 --config /openils/conf/test_core.xml --oldstyle
+
+# Append just lost and barred barcodes to file, showing feedback on STDERR
+$0 --verbose --barcodes L=lost --barcodes B=barred >>file
+
+WARNING:
+The new style offers performance benefits but seems to lose one line of data per call.
+
+END_OF_USAGE
+}
+
+### DEFAULTS
+
+my $config = '/openils/conf/opensrf_core.xml';
+my $oils_reqr = '/openils/bin/oils_requestor';
+my $context = 'opensrf';
+my $hostname = hostfqdn();
+my $help = 0;
+my $verbose = 0;
+my $approach = 0;
+my %types = ();
+
+GetOptions(
+ "barcodes=s" => \%types,
+ "config" => \$config,
+ "oldstyle" => \$approach,
+ "hostname" => \$hostname,
+ "requestor" => \$oils_reqr,
+ "verbose" => \$verbose,
+ "help" => \$help,
+);
+
+### SANITY CHECK
+
+print usage() and exit if $help;
+
+(-r $config) or die "Cannot read config file\n";
+
+%types or %types = ( # If you don't specify, you get'm all.
+ L => 'lost',
+ E => 'expired', # Possibly too many, making the file too large for download
+ B => 'barred',
+ D => 'penalized',
+);
+
+my %counts = ();
+foreach (keys %types) {
+ $counts{$_} = 0; # initialize count
+}
+
+### FEEDBACK
+
+if ($verbose) {
+ print STDERR "verbose feedback is ON\n";
+ print STDERR "hostname: $hostname\n";
+ print STDERR "barcodes types:\n";
+ foreach (sort keys %types) {
+ print STDERR " $_ ==> $types{$_}\n";
+ }
+ print STDERR "Using the ", ($approach ? 'traditional' : 'new oils'), " approach\n";
+}
+
+### Engine of the new style piped approach
+### Note, this appears to LOSE DATA, specifically one barcode value from each call.
+
+sub runmethod {
+ my $method = shift;
+ my $key = shift;
+ my $command = "echo \"open-ils.storage $method\" | $oils_reqr -f $config -c $context -h $hostname";
+ $verbose and print STDERR "\nCOMMAND:\n-> $command\n";
+
+ my ($child_stdout, $child_stdin);
+ my $pid = open2($child_stdout, $child_stdin, $command);
+ for my $barcode (<$child_stdout>) {
+ next if $barcode =~ /^oils/o; # hack to chop out the oils_requestor prompt
+ next if $barcode =~ /^Connected to OpenSRF/o;
+ chomp $barcode;
+ $barcode = OpenSRF::Utils::JSON->JSON2perl($barcode);
+ print "$barcode $key\n" if $barcode;
+ $counts{$key}++;
+ }
+ close($child_stdout);
+ close($child_stdin);
+ waitpid($pid, 0); # don't leave any zombies (see ipc::open2)
+}
+
+### MAIN
+
+if (! $approach) {
# ------------------------------------------------------------
# This sends the method calls to storage via oils_requestor,
# which is able to process the results much faster
# Make this the default for now.
# ------------------------------------------------------------
- use OpenSRF::Utils::JSON;
- use IPC::Open2 qw/open2/;
- use Net::Domain qw/hostfqdn/;
-
- sub runmethod {
- my $method = shift;
- my $flag = shift;
- my $hostname = hostfqdn();
- my $command = "echo \"open-ils.storage $method\" | $oils_reqr -f $config -c $context -h $hostname";
- warn "-> $command\n";
-
- my ($child_stdout, $child_stdin);
- my $pid = open2($child_stdout, $child_stdin, $command);
- my $x = 0;
- for my $barcode (<$child_stdout>) {
- next if $barcode =~ /^oils/o; # hack to chop out the oils_requestor prompt
- chomp $barcode;
- $barcode = OpenSRF::Utils::JSON->JSON2perl($barcode);
- print "$barcode $flag\n" if $barcode;
- }
- close($child_stdout);
- close($child_stdin);
- waitpid($pid, 0); # don't leave any zombies (see ipc::open2)
+ foreach my $key (keys %types) {
+ runmethod('open-ils.storage.actor.user.' . $types{$key} . '_barcodes', $key);
}
- runmethod('open-ils.storage.actor.user.lost_barcodes', 'L');
- runmethod('open-ils.storage.actor.user.barred_barcodes', 'B');
- runmethod('open-ils.storage.actor.user.penalized_barcodes', 'D');
- # too many, makes the file too large for download
- #runmethod('open-ils.storage.actor.user.expired_barcodes', 'E');
-
} else {
-
-
# ------------------------------------------------------------
# Uses the traditional opensrf Perl API approach
# ------------------------------------------------------------
- use OpenSRF::EX qw(:try);
- use OpenSRF::System;
- use OpenSRF::AppSession;
-
OpenSRF::System->bootstrap_client( config_file => $config );
my $ses = OpenSRF::AppSession->connect( 'open-ils.storage' );
- my $lost = $ses->request( 'open-ils.storage.actor.user.lost_barcodes' );
- while (my $resp = $lost->recv ) {
- print $resp->content . " L\n";
- }
- $lost->finish;
-
- if(0) { # XXX just too many... arg
- my $expired = $ses->request( 'open-ils.storage.actor.user.expired_barcodes' );
- while (my $resp = $expired->recv ) {
- print $resp->content . " E\n";
+ foreach my $key (keys %types) {
+ my $req = $ses->request( 'open-ils.storage.actor.user.' . $types{$key} . '_barcodes' );
+ while (my $resp = $req->recv) {
+ print $resp->content, " $key\n";
+ $counts{$key}++;
}
- $expired->finish;
+ $req->finish;
}
- my $barred = $ses->request( 'open-ils.storage.actor.user.barred_barcodes' );
- while (my $resp = $barred->recv ) {
- print $resp->content . " B\n";
- }
- $barred->finish;
-
- my $penalized = $ses->request( 'open-ils.storage.actor.user.penalized_barcodes' );
- while (my $resp = $penalized->recv ) {
- print $resp->content . " D\n";
- }
- $penalized->finish;
-
$ses->disconnect;
$ses->finish;
+}
+if ($verbose) {
+ print STDERR "\nBarcodes retrieved:\n";
+ foreach (sort keys %types) {
+ printf STDERR " %s ==> %9s ==> %d\n", $_, $types{$_}, $counts{$_};
+ }
+ print STDERR "\ndone\n";
}
More information about the open-ils-commits
mailing list