Bug 25184: (RM follow-up) Make DB update idempotent
[koha.git] / members / accountline-details.pl
blob1ac40a0210dfa069fd4d0c107b6d7305ca6c5ef2
1 #!/usr/bin/perl
3 # This file is part of Koha.
5 # Copyright 2017 ByWater Solutions
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 qw ( -utf8 );
23 use C4::Auth;
24 use C4::Output;
25 use C4::Context;
26 use Koha::Patrons;
27 use Koha::Account::Lines;
29 my $input = new CGI;
31 my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
33 template_name => "members/accountline-details.tt",
34 query => $input,
35 type => "intranet",
36 authnotrequired => 0,
37 flagsrequired => {
38 borrowers => 'edit_borrowers',
39 updatecharges => 'remaining_permissions'
44 my $accountlines_id = $input->param('accountlines_id');
46 my $accountline = Koha::Account::Lines->find($accountlines_id);
48 if ($accountline) {
49 my $type = $accountline->amount < 0 ? 'credit' : 'debit';
50 my $column = $type eq 'credit' ? 'credit_id' : 'debit_id';
52 my $account_offsets = Koha::Account::Offsets->search(
53 { $column => $accountlines_id },
54 { order_by => 'created_on' },
57 $template->param(
58 type => $type,
59 accountline => $accountline,
60 account_offsets => $account_offsets,
62 finesview => 1,
65 my $patron = Koha::Patrons->find( $accountline->borrowernumber );
66 $template->param( patron => $patron );
69 output_html_with_http_headers $input, $cookie, $template->output;