Koha/svc/barcode
Barton Chittenden fdab13cc3d Bug 20676: svc/barcode should allow barcode to be printed without text
Test plan:

1) Point web browser to
   <staff url>/cgi-bin/koha/svc/barcode?barcode=*12345*&notext=1

   This will display a png image of the barcode *12345* with the
   text *12345* printed below the scannable barcode.

2) Apply patch
3) Refresh the browser. The human readable text no longer appears.

Signed-off-by: Frédéric Demians <f.demians@tamil.fr>

Signed-off-by: Jonathan Druart <jonathan.druart@bugs.koha-community.org>

Signed-off-by: Nick Clemens <nick@bywatersolutions.com>
2018-06-22 16:34:53 +00:00

123 lines
2.5 KiB
Perl
Executable file

#!/usr/bin/perl
# Copyright 2014 ByWater Solutions
#
# 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 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, write to the Free Software Foundation, Inc.,
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
use Modern::Perl;
use CGI qw(header);
use GD::Barcode;
use C4::Auth qw(check_cookie_auth);
=head1 NAME
/cgi-bin/koha/svc/barcode
=head1 SYNOPSIS
This service generates a PNG barcode image for the requested barcode.
=head2 PARAMETERS
=over
=item I<barcode>
I<barcode> is the desired barcode. It should be called like:
=item I<type>
I<type> is the desired barcode type. Possible values are
Code39
UPCE
UPCA
QRcode
NW7
Matrix2of5
ITF
Industrial2of5
IATA2of5
EAN8
EAN13
COOP2of5
If ommited,it defaults to Code39.
=item I<notext>
Unless I<notext=1> is specified in the parameter list, the
value of the barcode will included as text below the
scannable barcode.
=back
=head2 EXAMPLES
=over
=item /cgi-bin/koha/svc/barcode?barcode=123456789
Returns a Code39 barcode image for barcode 123456789
=item /cgi-bin/koha/svc/barcode?barcode=123456789&type=UPCE
Returns a UPCE barcode image for barcode 123456789
=item /cgi-bin/koha/svc/barcode?barcode=123456789&notext=1
Returns a Code39 barcode image for barcode 123456789
which does not include the human readable text '123456789'
below the scannable barcode.
=back
my $input = new CGI;
my ( $auth_status, $sessionID ) = check_cookie_auth( $input->cookie('CGISESSID'), { catalogue => '*' } );
if ( $auth_status ne "ok" ) {
exit 0;
}
binmode(STDOUT);
my $type = $input->param('type') || 'Code39';
my $barcode = $input->param('barcode');
my $notext = $input->param('notext') ? 1 : 0;
my $image;
eval {
$image = GD::Barcode->new( $type, $barcode )->plot( NoText => $notext )->png();
};
if ( $@ ) {
# problem creating image
print header( -status => 500 );
} else {
print header('image/png');
print $image;
}
exit 0;
=head1 AUTHOR
Kyle M Hall <kyle@bywatersolutions.com>
=cut