Bug 31739: Password recovery from staff fails if previous expired reset-entry exists.
[koha.git] / reserve / modrequest.pl
1 #!/usr/bin/perl
2
3 #script to modify reserves/requests
4 #written 2/1/00 by chris@katipo.oc.nz
5 #last update 27/1/2000 by chris@katipo.co.nz
6
7
8 # Copyright 2000-2002 Katipo Communications
9 #
10 # This file is part of Koha.
11 #
12 # Koha is free software; you can redistribute it and/or modify it
13 # under the terms of the GNU General Public License as published by
14 # the Free Software Foundation; either version 3 of the License, or
15 # (at your option) any later version.
16 #
17 # Koha is distributed in the hope that it will be useful, but
18 # WITHOUT ANY WARRANTY; without even the implied warranty of
19 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20 # GNU General Public License for more details.
21 #
22 # You should have received a copy of the GNU General Public License
23 # along with Koha; if not, see <http://www.gnu.org/licenses>.
24
25 use Modern::Perl;
26 use CGI qw ( -utf8 );
27 use URI;
28 use List::MoreUtils qw( uniq );
29 use Try::Tiny;
30
31 use C4::Output;
32 use C4::Reserves qw( ModReserve ModReserveCancelAll );
33 use C4::Auth qw( get_template_and_user );
34 use Koha::BackgroundJob::BatchUpdateBiblioHoldsQueue;
35
36 my $query = CGI->new;
37 my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
38     {   
39         template_name   => "about.tt",
40         query           => $query,
41         type            => "intranet",
42         flagsrequired   => { reserveforothers => '*' },
43     }
44 );
45
46 my @reserve_id = $query->multi_param('reserve_id');
47 my @rank = $query->multi_param('rank-request');
48 my @borrower = $query->multi_param('borrowernumber');
49 my @reservedates = $query->multi_param('reservedate');
50 my @expirationdates = $query->multi_param('expirationdate');
51 my @branch = $query->multi_param('pickup');
52 my @itemnumber = $query->multi_param('itemnumber');
53 my @biblionumber = $query->multi_param('biblionumber');
54 my $count=@rank;
55
56 @biblionumber = uniq @biblionumber;
57
58 my $CancelBiblioNumber = $query->param('CancelBiblioNumber');
59 my $CancelBorrowerNumber = $query->param('CancelBorrowerNumber');
60 my $CancelItemnumber = $query->param('CancelItemnumber');
61
62 # 2 possibilitys : cancel an item reservation, or modify or cancel the queded list
63
64 # 1) cancel an item reservation by function ModReserveCancelAll (in reserves.pm)
65 if ($CancelBorrowerNumber) {
66     ModReserveCancelAll($CancelItemnumber, $CancelBorrowerNumber);
67     $biblionumber[0] = $CancelBiblioNumber,
68 }
69
70 # 2) Cancel or modify the queue list of reserves (without item linked)
71 else {
72     for (my $i=0;$i<$count;$i++){
73         undef $itemnumber[$i] if !$itemnumber[$i];
74         my $suspend_until = $query->param( "suspend_until_" . $reserve_id[$i] );
75         my $cancellation_reason = $query->param("cancellation-reason");
76         my $params = {
77             rank => $rank[$i],
78             reserve_id => $reserve_id[$i],
79             expirationdate => $expirationdates[$i] || undef,
80             branchcode => $branch[$i],
81             itemnumber => $itemnumber[$i],
82             defined $suspend_until ? ( suspend_until => $suspend_until ) : (),
83             cancellation_reason => $cancellation_reason,
84         };
85         if (C4::Context->preference('AllowHoldDateInFuture')) {
86             $params->{reservedate} = $reservedates[$i] || undef;
87         }
88
89         try {
90             ModReserve($params);
91         } catch {
92             if ($_->isa('Koha::Exceptions::ObjectNotFound')){
93                 warn $_;
94             } else {
95                 $_->rethrow;
96             }
97         }
98     }
99     my @biblio_ids = uniq @biblionumber;
100     Koha::BackgroundJob::BatchUpdateBiblioHoldsQueue->new->enqueue(
101         {
102             biblio_ids => \@biblio_ids
103         }
104     );
105 }
106
107 my $from=$query->param('from');
108 $from ||= q{};
109 if ( $from eq 'borrower'){
110     print $query->redirect("/cgi-bin/koha/members/moremember.pl?borrowernumber=$borrower[0]");
111 } elsif ( $from eq 'circ'){
112     print $query->redirect("/cgi-bin/koha/circ/circulation.pl?borrowernumber=$borrower[0]");
113 } else {
114      my $url = URI->new("/cgi-bin/koha/reserve/request.pl");
115      $url->query_form( biblionumber => [@biblionumber]);
116      print $query->redirect($url);
117 }