Main Koha release repository https://koha-community.org
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

113 lines
2.5 KiB

package Koha::SearchEngine::Zebra::Search;
# This file is part of Koha.
#
# Copyright 2012 BibLibre
#
# 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 3 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, see <http://www.gnu.org/licenses>.
use Modern::Perl;
use base qw(Class::Accessor);
use C4::Search; # :(
use C4::AuthoritiesMarc;
use Koha::SearchEngine::Search;
=head1 NAME
Koha::SearchEngine::Zebra::Search - Search implementation for Zebra
=head1 METHODS
=head2 search
=cut
sub search {
my ($self,$query_string) = @_;
my $query = Data::SearchEngine::Query->new(
count => 10,
page => 1,
query => $query_string,
);
my $results = $self->searchengine->search($query);
foreach my $item (@{ $results->items }) {
my $title = $item->get_value('ste_title');
#utf8::encode($title);
print "$title\n";
}
}
=head2 search_compat
This passes straight through to C4::Search::getRecords.
=cut
sub search_compat {
shift; # get rid of $self
return getRecords(@_);
}
=head2 simple_search_compat
This passes straight through to C4::Search::SimpleSearch.
=cut
sub simple_search_compat {
shift;
return C4::Search::SimpleSearch(@_);
}
=head2 extract_biblionumber
my $biblionumber = $searcher->extract_biblionumber( $searchresult );
$searchresult comes from simple_search_compat.
Returns the biblionumber from the search result record.
=cut
sub extract_biblionumber {
my ( $self, $searchresultrecord ) = @_;
my $record = C4::Search::new_record_from_zebra( 'biblioserver', $searchresultrecord );
return Koha::SearchEngine::Search::extract_biblionumber( $record );
}
=head2 search_auth_compat
This passes the search query on to C4::AuthoritiesMarc::SearchAuthorities
=cut
sub search_auth_compat {
my ( $self, $q, $startfrom, $resperpage ) = @_;
my @params = (
@{$q}{ 'marclist', 'and_or', 'excluding', 'operator', 'value' },
$startfrom - 1,
$resperpage, @{$q}{ 'authtypecode', 'orderby' }
);
C4::AuthoritiesMarc::SearchAuthorities(@params);
}
1;