Bug 26265: (QA follow-up) Remove g option from regex, add few dirs
[koha.git] / members / members-update-do.pl
1 #!/usr/bin/perl
2
3 # Parts Copyright Biblibre 2010
4 # This file is part of Koha.
5 #
6 # Koha is free software; you can redistribute it and/or modify it
7 # under the terms of the GNU General Public License as published by
8 # the Free Software Foundation; either version 3 of the License, or
9 # (at your option) any later version.
10 #
11 # Koha is distributed in the hope that it will be useful, but
12 # WITHOUT ANY WARRANTY; without even the implied warranty of
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 # GNU General Public License for more details.
15 #
16 # You should have received a copy of the GNU General Public License
17 # along with Koha; if not, see <http://www.gnu.org/licenses>.
18
19 use Modern::Perl;
20
21 use CGI qw ( -utf8 );
22 use C4::Auth;
23 use C4::Output;
24 use C4::Context;
25 use Koha::Patrons;
26 use Koha::Patron::Modifications;
27
28 my $query = new CGI;
29
30 # FIXME Should be a checkauth call
31 my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
32     {
33         template_name   => "about.tt",
34         query           => $query,
35         type            => "intranet",
36         authnotrequired => 0,
37         flagsrequired   => { borrowers => 'edit_borrowers' },
38         debug           => 1,
39     }
40 );
41
42 my $logged_in_user = Koha::Patrons->find( $loggedinuser ) or die "Not logged in";
43
44 my @params = $query->param;
45
46 foreach my $param (@params) {
47     if ( $param =~ "^modify_" ) {
48         my (undef, $borrowernumber) = split( /_/, $param );
49
50         my $patron = Koha::Patrons->find($borrowernumber);
51         next unless $logged_in_user->can_see_patron_infos( $patron );
52
53         my $action = $query->param($param);
54
55         if ( $action eq 'approve' ) {
56             my $m = Koha::Patron::Modifications->find( { borrowernumber => $borrowernumber } );
57
58             if ($query->param("unset_gna_$borrowernumber")) {
59                 # Unset gone no address
60                 # FIXME Looks like this could go to $m->approve
61                 my $patron = Koha::Patrons->find( $borrowernumber );
62                 $patron->gonenoaddress(undef)->store;
63             }
64
65             $m->approve() if $m;
66         }
67         elsif ( $action eq 'deny' ) {
68             my $m = Koha::Patron::Modifications->find( { borrowernumber => $borrowernumber } );
69             $m->delete() if $m;
70         }
71         # elsif ( $action eq 'ignore' ) { }
72     }
73 }
74
75 print $query->redirect("/cgi-bin/koha/members/members-update.pl");