#!/usr/bin/perl # # Copyright 2009 LibLime # # 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, see . use Modern::Perl; use C4::Auth qw( in_iprange ); use C4::Service; use C4::Members; use Koha::Patron::Images; use Koha::Patrons; my ( $query, $response ) = C4::Service->init( self_check => 'self_checkout_module' ); unless (C4::Context->preference('WebBasedSelfCheck')) { print $query->header(status => '403 Forbidden - web-based self-check not enabled'); exit; } unless (C4::Context->preference('ShowPatronImageInWebBasedSelfCheck')) { print $query->header(status => '403 Forbidden - displaying patron images in self-check not enabled'); exit; } unless ( in_iprange(C4::Context->preference('SelfCheckAllowByIPRanges')) ) { print $query->header(status => '403 Forbidden - functionality not available from your location'); exit; } my $jwt = $query->cookie('JWT'); #NOTE: This should be borrowernumber and not cardnumber, but that's a deeper problem with patron images... my $cardnumber = $jwt ? Koha::Token->new->decode_jwt( { token => $jwt } ) : undef; my $patron = Koha::Patrons->find( { cardnumber => $cardnumber } ); my $patron_image; if ($patron) { $patron_image = $patron->image; } if ($patron_image) { print $query->header( -type => $patron_image->mimetype, -Content_Length => length( $patron_image->imagefile ) ), $patron_image->imagefile; } else { print $query->header(status => '404 patron image not found'); }