Bug 25898: Prohibit indirect object notation
[koha.git] / members / print_overdues.pl
blob4c4bcc2914de5d7906bb691483cbb9507d8952ec
1 #!/usr/bin/perl
3 # Copyright 2014 ByWater Solutions
5 # This file is part of Koha.
7 # Koha is free software; you can redistribute it and/or modify it
8 # under the terms of the GNU General Public License as published by
9 # the Free Software Foundation; either version 3 of the License, or
10 # (at your option) any later version.
12 # Koha is distributed in the hope that it will be useful, but
13 # WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 # GNU General Public License for more details.
17 # You should have received a copy of the GNU General Public License
18 # along with Koha; if not, see <http://www.gnu.org/licenses>.
20 use Modern::Perl;
22 use CGI;
24 use C4::Context;
25 use C4::Auth;
26 use C4::Output;
27 use C4::Overdues qw(parse_overdues_letter);
29 use Koha::Patrons;
31 my $input = CGI->new;
33 my $flagsrequired = { circulate => "circulate_remaining_permissions" };
35 my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
37 template_name => "circ/printslip.tt",
38 query => $input,
39 type => "intranet",
40 flagsrequired => $flagsrequired,
41 debug => 1,
45 my $borrowernumber = $input->param('borrowernumber');
46 my $branchcode = C4::Context->userenv->{'branch'};
48 my $logged_in_user = Koha::Patrons->find( $loggedinuser );
49 my $patron = Koha::Patrons->find( $borrowernumber );
50 output_and_exit_if_error( $input, $cookie, $template, { module => 'members', logged_in_user => $logged_in_user, current_patron => $patron } );
52 my $overdues = [
53 map { $_->unblessed_all_relateds } $patron->get_overdues
56 my $letter = parse_overdues_letter(
58 letter_code => 'OVERDUES_SLIP',
59 borrowernumber => $borrowernumber,
60 branchcode => $branchcode,
61 items => $overdues,
62 message_transport_type => 'print',
66 $template->param(
67 slip => $letter->{content},
68 title => $letter->{name},
69 plain => !$letter->{is_html},
70 borrowernumber => $borrowernumber,
73 output_html_with_http_headers $input, $cookie, $template->output;