X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=authorities%2Fysearch.pl;h=4a5ae796a76f0b3fe089efff8ee7616631e4b925;hb=66aacace086f16d2eca860cc6c2aa164866d0488;hp=56ef8e2e34923879d8ffa6847a3e6e76b84d19ee;hpb=b20c2d6857629eed3f3eaf44cdca68dda36f4216;p=koha.git diff --git a/authorities/ysearch.pl b/authorities/ysearch.pl index 56ef8e2e34..4a5ae796a7 100755 --- a/authorities/ysearch.pl +++ b/authorities/ysearch.pl @@ -3,21 +3,22 @@ # This software is placed under the gnu General Public License, v2 (http://www.gnu.org/licenses/gpl.html) # Copyright 2011 BibLibre +# Parts copyright 2012 Athens County Public Libraries # # 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 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. +# 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., -# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. +# You should have received a copy of the GNU General Public License +# along with Koha; if not, see . =head1 ysearch.pl @@ -26,46 +27,61 @@ This script allows ajax call for dynamic authorities search =cut -use CGI; +use CGI qw ( -utf8 ); use Modern::Perl; +use JSON; + use C4::Context; use C4::Charset; use C4::AuthoritiesMarc; use C4::Auth qw/check_cookie_auth/; +use C4::Output; my $query = new CGI; -binmode STDOUT, ':encoding(UTF-8)'; -print $query->header( -type => 'text/plain', -charset => 'UTF-8' ); +my ( $auth_status, $sessionID ) = check_cookie_auth( $query->cookie('CGISESSID'), { catalogue => 1 } ); -my ( $auth_status, $sessionID ) = check_cookie_auth( $query->cookie('CGISESSID'), { } ); if ( $auth_status ne "ok" ) { + # send empty response + my $reply = CGI->new(""); + print $reply->header(-type => 'text/html'); exit 0; } - my $searchstr = $query->param('query'); + my @value = $query->multi_param('term'); my $searchtype = $query->param('querytype'); - my @value; - given ($searchtype) { - when (/^marclist$/) { @value = (undef, undef, $searchstr); } - when (/^mainentry$/) { @value = (undef, $searchstr, undef); } - when (/^mainmainentry$/) { @value = ($searchstr, undef, undef); } - } my @marclist = ($searchtype); my $authtypecode = $query->param('authtypecode'); - my @and_or = $query->param('and_or'); - my @excluding = $query->param('excluding'); - my @operator = $query->param('operator'); + my @and_or = $query->multi_param('and_or'); + my @excluding = $query->multi_param('excluding'); + my @operator = $query->multi_param('operator'); my $orderby = $query->param('orderby'); my $resultsperpage = 50; my $startfrom = 0; my ( $results, $total ) = SearchAuthorities( \@marclist, \@and_or, \@excluding, \@operator, \@value, $startfrom * $resultsperpage, $resultsperpage, $authtypecode, $orderby ); - foreach (@$results) { - my ($value) = $_->{'summary'}; - # Removes new lines - $value =~ s/
/ /g; - $value =~ s/\n//g; - print nsb_clean($value) . "\n"; + + my %used_summaries; # hash to avoid duplicates + my @summaries; + foreach my $result (@$results) { + my $authorized = $result->{'summary'}->{'authorized'}; + my $summary = join( + ' ', + map { + ( $searchtype eq 'mainmainentry' ) + ? $_->{'hemain'} + : $_->{'heading'} + } @$authorized + ); + $summary =~ s/^\s+//; + $summary =~ s/\s+$//; + $summary = nsb_clean($summary); + # test if already added ignoring case + unless ( exists $used_summaries{ lc($summary) } ) { + push @summaries, { 'summary' => $summary }; + $used_summaries{ lc($summary) } = 1; + } } + +output_with_http_headers $query, undef, to_json(\@summaries, { utf8 => 1 }), 'json';