3660bc647a
Removed unused global variables. Added POD. Added some explanatory comments. Added some FIXME comments.
312 lines
8.2 KiB
Perl
Executable file
312 lines
8.2 KiB
Perl
Executable file
package C4::Z3950;
|
|
|
|
# $Id$
|
|
|
|
# Routines for handling Z39.50 lookups
|
|
|
|
# Koha library project www.koha.org
|
|
|
|
# Licensed under the GPL
|
|
|
|
|
|
# Copyright 2000-2002 Katipo Communications
|
|
#
|
|
# This file is part of Koha.
|
|
#
|
|
# Koha is free software; you can redistribute it and/or modify it under the
|
|
# terms of the GNU General Public License as published by the Free Software
|
|
# Foundation; either version 2 of the License, or (at your option) any later
|
|
# version.
|
|
#
|
|
# Koha is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
|
# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License along with
|
|
# Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place,
|
|
# Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
use strict;
|
|
|
|
# standard or CPAN modules used
|
|
use DBI;
|
|
|
|
# Koha modules used
|
|
use C4::Database;
|
|
use C4::Input;
|
|
use C4::Biblio;
|
|
|
|
#------------------
|
|
|
|
require Exporter;
|
|
|
|
use vars qw($VERSION @ISA @EXPORT);
|
|
|
|
# set the version for version checking
|
|
$VERSION = 0.01;
|
|
|
|
=head1 NAME
|
|
|
|
C4::Z3950 - Functions dealing with Z39.50 queries
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
use C4::Z3950;
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
This module contains functions for looking up Z39.50 servers, and for
|
|
entering Z39.50 lookup requests.
|
|
|
|
=head1 FUNCTIONS
|
|
|
|
=over 2
|
|
|
|
=cut
|
|
|
|
@ISA = qw(Exporter);
|
|
@EXPORT = qw(
|
|
&z3950servername
|
|
&addz3950queue
|
|
);
|
|
|
|
#------------------------------------------------
|
|
|
|
=item z3950servername
|
|
|
|
$name = &z3950servername($dbh, $server_id, $default_name);
|
|
|
|
Looks up a Z39.50 server by ID number, and returns its full name. If
|
|
the server is not found, returns C<$default_name>.
|
|
|
|
C<$server_id> is the Z39.50 server ID to look up.
|
|
|
|
C<$dbh> is ignored.
|
|
|
|
=cut
|
|
#'
|
|
sub z3950servername {
|
|
# inputs
|
|
my (
|
|
$dbh, # FIXME - Unused argument
|
|
$srvid, # server id number
|
|
$default,
|
|
)=@_;
|
|
# return
|
|
my $longname;
|
|
#----
|
|
|
|
$dbh = C4::Context->dbh;
|
|
|
|
# FIXME - Fix indentation
|
|
my $sti=$dbh->prepare("select name
|
|
from z3950servers
|
|
where id=?");
|
|
$sti->execute($srvid);
|
|
if ( ! $sti->err ) {
|
|
($longname)=$sti->fetchrow;
|
|
}
|
|
if (! $longname) {
|
|
$longname="$default";
|
|
}
|
|
return $longname;
|
|
} # sub z3950servername
|
|
|
|
#---------------------------------------
|
|
|
|
=item addz3950queue
|
|
|
|
$errmsg = &addz3950queue($dbh, $query, $type, $request_id, @servers);
|
|
|
|
Adds a Z39.50 search query for the Z39.50 server to look up.
|
|
|
|
C<$dbh> is obsolete and is ignored.
|
|
|
|
C<$query> is the term to search for.
|
|
|
|
C<$type> is the query type, e.g. C<isbn>, C<lccn>, etc.
|
|
|
|
C<$request_id> is a unique string that will identify this query.
|
|
|
|
C<@servers> is a list of servers to query (obviously, this can be
|
|
given either as an array, or as a list of scalars). Each element may
|
|
be either a Z39.50 server ID from the z3950server table of the Koha
|
|
database, the string C<DEFAULT> or C<CHECKED>, or a complete server
|
|
specification containing a colon.
|
|
|
|
C<DEFAULT> and C<CHECKED> are synonymous, and refer to those servers
|
|
in the z3950servers table whose 'checked' field is set and non-NULL.
|
|
|
|
Once the query has been submitted to the Z39.50 daemon,
|
|
C<&addz3950queue> sends a SIGHUP to the daemon to tell it to process
|
|
this new request.
|
|
|
|
C<&addz3950queue> returns an error message. If it was successful, the
|
|
error message is the empty string.
|
|
|
|
=cut
|
|
#'
|
|
sub addz3950queue {
|
|
use strict;
|
|
# input
|
|
my (
|
|
$dbh, # DBI handle
|
|
# FIXME - Unused argument
|
|
$query, # value to look up
|
|
$type, # type of value ("isbn", "lccn", etc).
|
|
# FIXME - What other values are legal?
|
|
$requestid, # Unique value to prevent duplicate searches from multiple HTML form submits
|
|
@z3950list, # list of z3950 servers to query
|
|
)=@_;
|
|
# Returns:
|
|
my $error;
|
|
|
|
my (
|
|
$sth,
|
|
@serverlist,
|
|
$server,
|
|
$failed,
|
|
$servername,
|
|
);
|
|
|
|
# FIXME - Should be configurable, probably in /etc/koha.conf.
|
|
my $pidfile='/var/log/koha/processz3950queue.pid';
|
|
|
|
$error="";
|
|
|
|
$dbh = C4::Context->dbh;
|
|
|
|
# FIXME - Fix indentation
|
|
|
|
# list of servers: entry can be a fully qualified URL-type entry
|
|
# or simply just a server ID number.
|
|
|
|
foreach $server (@z3950list) {
|
|
if ($server =~ /:/ ) {
|
|
push @serverlist, $server;
|
|
} elsif ($server eq 'DEFAULT' || $server eq 'CHECKED' ) {
|
|
$sth=$dbh->prepare("select host,port,db,userid,password ,name
|
|
from z3950servers
|
|
where checked <> 0 ");
|
|
$sth->execute;
|
|
while ( my ($host, $port, $db, $userid, $password,$servername)
|
|
= $sth->fetchrow ) {
|
|
push @serverlist, "$servername/$host\:$port/$db/$userid/$password";
|
|
} # while
|
|
} else {
|
|
$sth=$dbh->prepare("select host,port,db,userid,password
|
|
from z3950servers
|
|
where id=? ");
|
|
$sth->execute($server);
|
|
my ($host, $port, $db, $userid, $password) = $sth->fetchrow;
|
|
push @serverlist, "$server/$host\:$port/$db/$userid/$password";
|
|
}
|
|
}
|
|
|
|
my $serverlist='';
|
|
# FIXME - $serverlist = join(" ", @serverlist);
|
|
foreach (@serverlist) {
|
|
$serverlist.="$_ ";
|
|
} # foreach
|
|
chop $serverlist;
|
|
|
|
# FIXME - Is this test supposed to test whether @serverlist is
|
|
# empty? If so, then a) there are better ways to do that in
|
|
# Perl (e.g., "if (@serverlist eq ())"), and b) it doesn't
|
|
# work anyway, since it checks whether $serverlist is composed
|
|
# of one or more spaces, which is never the case, not even
|
|
# when there are 0 or 1 elements in @serverlist.
|
|
if ( $serverlist !~ /^ +$/ ) {
|
|
# Don't allow reinsertion of the same request identifier.
|
|
$sth=$dbh->prepare("select identifier from z3950queue
|
|
where identifier=?");
|
|
$sth->execute($requestid);
|
|
if ( ! $sth->rows) {
|
|
$sth=$dbh->prepare("insert into z3950queue
|
|
(term,type,servers, identifier)
|
|
values (?, ?, ?, ?)");
|
|
$sth->execute($query, $type, $serverlist, $requestid);
|
|
if ( -r $pidfile ) {
|
|
# FIXME - Perl is good at opening files. No need to
|
|
# spawn a separate 'cat' process.
|
|
my $pid=`cat $pidfile`;
|
|
chomp $pid;
|
|
# Kill -HUP the Z39.50 daemon to tell it to process
|
|
# this query.
|
|
my $processcount=kill 1, $pid;
|
|
if ($processcount==0) {
|
|
$error.="Z39.50 search daemon error: no process signalled. ";
|
|
}
|
|
} else {
|
|
# FIXME - Error-checking like this should go close
|
|
# to the test.
|
|
$error.="No Z39.50 search daemon running: no file $pidfile. ";
|
|
} # if $pidfile
|
|
} else {
|
|
# FIXME - Error-checking like this should go close
|
|
# to the test.
|
|
$error.="Duplicate request ID $requestid. ";
|
|
} # if rows
|
|
} else {
|
|
# FIXME - Error-checking like this should go close to the
|
|
# test. I.e.,
|
|
# return "No Z39.50 search servers specified. "
|
|
# if @serverlist eq ();
|
|
|
|
# server list is empty
|
|
$error.="No Z39.50 search servers specified. ";
|
|
} # if serverlist empty
|
|
|
|
return $error;
|
|
|
|
} # sub addz3950queue
|
|
|
|
1;
|
|
__END__
|
|
|
|
=back
|
|
|
|
=head1 AUTHOR
|
|
|
|
Koha Developement team <info@koha.org>
|
|
|
|
=cut
|
|
|
|
#--------------------------------------
|
|
# $Log$
|
|
# Revision 1.5 2002/10/13 06:13:23 arensb
|
|
# Removed bogus #! line (this isn't a script!)
|
|
# Removed unused global variables.
|
|
# Added POD.
|
|
# Added some explanatory comments.
|
|
# Added some FIXME comments.
|
|
#
|
|
# Revision 1.4 2002/10/11 12:35:35 arensb
|
|
# Replaced &requireDBI with C4::Context->dbh
|
|
#
|
|
# Revision 1.3 2002/08/14 18:12:52 tonnesen
|
|
# Added copyright statement to all .pl and .pm files
|
|
#
|
|
# Revision 1.2 2002/07/02 20:31:33 tonnesen
|
|
# module added from rel-1-2 branch
|
|
#
|
|
# Revision 1.1.2.5 2002/06/29 17:33:47 amillar
|
|
# Allow DEFAULT as input to addz3950search.
|
|
# Check for existence of pid file (cat crashed otherwise).
|
|
# Return error messages in addz3950search.
|
|
#
|
|
# Revision 1.1.2.4 2002/06/28 18:07:27 tonnesen
|
|
# marcimport.pl will print an error message if it can not signal the
|
|
# processz3950queue program. The message contains instructions for starting the
|
|
# daemon.
|
|
#
|
|
# Revision 1.1.2.3 2002/06/28 17:45:39 tonnesen
|
|
# z3950queue now listens for a -HUP signal before processing the queue. Z3950.pm
|
|
# sends the -HUP signal when queries are added to the queue.
|
|
#
|
|
# Revision 1.1.2.2 2002/06/26 20:54:31 tonnesen
|
|
# use warnings breaks on perl 5.005...
|
|
#
|
|
# Revision 1.1.2.1 2002/06/26 07:26:41 amillar
|
|
# New module for Z39.50 searching
|
|
#
|