Bug 23117: Shortcut additem.pl on nonexistent biblionumber
[koha.git] / Koha / SearchEngine / Search.pm
blobfdaf7d373d7567b05cda3b493bb0c8ee14c935c5
1 package Koha::SearchEngine::Search;
3 # This file is part of Koha.
5 # Copyright 2015 Catalyst IT
7 # Koha is free software; you can redistribute it and/or modify it
8 # under the terms of the GNU General Public License as published by
9 # the Free Software Foundation; either version 3 of the License, or
10 # (at your option) any later version.
12 # Koha is distributed in the hope that it will be useful, but
13 # WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 # GNU General Public License for more details.
17 # You should have received a copy of the GNU General Public License
18 # along with Koha; if not, see <http://www.gnu.org/licenses>.
20 # This is a shim that gives you the appropriate search object for your
21 # system preference.
23 =head1 NAME
25 Koha::SearchEngine::Search - instantiate the search object that corresponds to
26 the C<SearchEngine> system preference.
28 =head1 DESCRIPTION
30 This allows you to be agnostic about what the search engine configuration is
31 and just get whatever search object you need.
33 =head1 SYNOPSIS
35 use Koha::SearchEngine::Search;
36 my $searcher = Koha::SearchEngine::Search->new();
38 =head1 METHODS
40 =head2 new
42 Creates a new C<Search> of whatever the relevant type is.
44 =cut
46 use Modern::Perl;
47 use C4::Context;
48 use C4::Biblio qw//;
50 sub new {
51 my $engine = C4::Context->preference("SearchEngine") // 'Zebra';
52 my $file = "Koha/SearchEngine/${engine}/Search.pm";
53 my $class = "Koha::SearchEngine::${engine}::Search";
54 require $file;
55 shift @_;
56 return $class->new(@_);
59 =head2 extract_biblionumber
61 my $biblionumber = $searcher->extract_biblionumber( $marc );
63 Returns the biblionumber from $marc. The routine is called from the
64 extract_biblionumber method of the specific search engine.
66 =cut
68 sub extract_biblionumber {
69 my ( $record ) = @_;
70 return if ref($record) ne 'MARC::Record';
71 my ( $biblionumbertagfield, $biblionumbertagsubfield ) = C4::Biblio::GetMarcFromKohaField( 'biblio.biblionumber', '' );
72 if( $biblionumbertagfield < 10 ) {
73 my $controlfield = $record->field( $biblionumbertagfield );
74 return $controlfield ? $controlfield->data : undef;
76 return $record->subfield( $biblionumbertagfield, $biblionumbertagsubfield );