Bug 24083: (QA follow-up) Fix DB upgrade
[koha.git] / svc / renew
blobe7792ddd601bc452b9b15e308333df703ecd4576
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;
23 use JSON qw(to_json);
25 use C4::Circulation;
26 use C4::Context;
27 use C4::Auth qw(check_cookie_auth);
29 use Koha::DateUtils qw(output_pref dt_from_string);
31 my $input = CGI->new;
33 my ( $auth_status, $sessionID ) =
34 check_cookie_auth( $input->cookie('CGISESSID'),
35 { circulate => 'circulate_remaining_permissions' } );
37 if ( $auth_status ne "ok" ) {
38 exit 0;
41 binmode STDOUT, ":encoding(UTF-8)";
42 print $input->header( -type => 'text/plain', -charset => 'UTF-8' );
44 my $itemnumber = $input->param('itemnumber');
45 my $borrowernumber = $input->param('borrowernumber');
46 my $override_limit = $input->param('override_limit');
47 my $branchcode = $input->param('branchcode')
48 || C4::Context->userenv->{'branch'};
49 my $seen = $input->param('seen');
50 my $date_due;
51 if ( $input->param('date_due') ) {
52 $date_due = dt_from_string( scalar $input->param('date_due') );
55 my $data;
56 $data->{itemnumber} = $itemnumber;
57 $data->{borrowernumber} = $borrowernumber;
58 $data->{branchcode} = $branchcode;
60 ( $data->{renew_okay}, $data->{error} ) =
61 CanBookBeRenewed( $borrowernumber, $itemnumber, $override_limit );
63 # If we're allowing reserved items to be renewed...
64 if ( $data->{error} && $data->{error} eq 'on_reserve' && C4::Context->preference('AllowRenewalOnHoldOverride')) {
65 $data->{renew_okay} = 1;
66 $data->{error} = undef;
69 if ( $data->{renew_okay} ) {
70 $date_due = AddRenewal( $borrowernumber, $itemnumber, $branchcode, $date_due, undef, undef, $seen );
71 $data->{date_due} = output_pref( { dt => $date_due, as_due_date => 1 } );
74 print to_json($data);