Bug 13987: Fix server name in z39.50 authority search results
[koha.git] / circ / ysearch.pl
blobe5c8d268410b403a20447f10cc732b66808c1f21
1 #!/usr/bin/perl
3 # This software is placed under the gnu General Public License, v2 (http://www.gnu.org/licenses/gpl.html)
5 # Copyright 2007 Tamil s.a.r.l.
6 # Parts copyright 2010-2012 Athens County Public Libraries
8 # This file is part of Koha.
10 # Koha is free software; you can redistribute it and/or modify it
11 # under the terms of the GNU General Public License as published by
12 # the Free Software Foundation; either version 3 of the License, or
13 # (at your option) any later version.
15 # Koha is distributed in the hope that it will be useful, but
16 # WITHOUT ANY WARRANTY; without even the implied warranty of
17 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 # GNU General Public License for more details.
20 # You should have received a copy of the GNU General Public License
21 # along with Koha; if not, see <http://www.gnu.org/licenses>.
23 =head1 ysearch.pl
25 =cut
27 use Modern::Perl;
28 use CGI qw ( -utf8 );
29 use C4::Context;
30 use C4::Auth qw/check_cookie_auth/;
31 use Koha::Borrowers;
33 use JSON qw( to_json );
35 my $input = new CGI;
36 my $query = $input->param('term');
38 binmode STDOUT, ":encoding(UTF-8)";
39 print $input->header( -type => 'text/plain', -charset => 'UTF-8' );
41 my ( $auth_status, $sessionID ) = check_cookie_auth( $input->cookie('CGISESSID'), { circulate => '*' } );
42 if ( $auth_status ne "ok" ) {
43 exit 0;
46 my $limit_on_branch;
47 if ( C4::Context->preference("IndependentBranches")
48 && C4::Context->userenv
49 && !C4::Context->IsSuperLibrarian()
50 && C4::Context->userenv->{'branch'} ) {
51 $limit_on_branch = 1;
54 my $borrowers_rs = Koha::Borrowers->search(
55 { -or => {
56 surname => { -like => "$query%" },
57 firstname => { -like => "$query%" },
58 cardnumber => { -like => "$query%" },
59 ( $limit_on_branch ? { branchcode => C4::Context->userenv->{branch} } : () ),
63 # Get the first 10 results
64 page => 1,
65 rows => 10,
66 order_by => [ 'surname', 'firstname' ],
70 my @borrowers;
71 while ( my $b = $borrowers_rs->next ) {
72 push @borrowers,
73 { borrowernumber => $b->borrowernumber,
74 surname => $b->surname // '',
75 firstname => $b->firstname // '',
76 cardnumber => $b->cardnumber // '',
77 address => $b->address // '',
78 city => $b->city // '',
79 zipcode => $b->zipcode // '',
80 country => $b->country // '',
84 print to_json( \@borrowers );