fdab13cc3d
Test plan: 1) Point web browser to <staff url>/cgi-bin/koha/svc/barcode?barcode=*12345*¬ext=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>
123 lines
2.5 KiB
Perl
Executable file
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¬ext=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
|