Bug 30477: Add new UNIMARC installer translation files
[koha.git] / members / merge-patrons.pl
1 #!/usr/bin/perl
2
3 # Copyright ByWater Solutions 2017
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 Try::Tiny qw( catch try );
23
24 use C4::Auth qw( get_template_and_user );
25 use C4::Output qw( output_html_with_http_headers );
26 use C4::Context;
27 use Koha::Patrons;
28
29 my $cgi = CGI->new;
30
31 my ( $template, $loggedinuser, $cookie, $flags ) = get_template_and_user(
32     {
33         template_name   => "members/merge-patrons.tt",
34         query           => $cgi,
35         type            => "intranet",
36         flagsrequired   => { borrowers => 'edit_borrowers' },
37     }
38 );
39
40 my $action = $cgi->param('action') || 'show';
41 my @ids    = $cgi->multi_param('id');
42
43 if ( $action eq 'show' ) {
44     my $patrons = Koha::Patrons->search({ borrowernumber => { -in => \@ids } });
45     $template->param( patrons => $patrons );
46 } elsif ( $action eq 'merge' ) {
47     my $keeper_id = $cgi->param('keeper');
48     my $results;
49
50     my $keeper = Koha::Patrons->find( $keeper_id );
51
52     if ( $keeper ) {
53         try {
54             $results = $keeper->merge_with( \@ids );
55             $template->param(
56                 keeper  => $keeper,
57                 results => $results
58             );
59         }
60         catch {
61             $template->param( error => $_ );
62         }
63     } else {
64         $template->param( error => 'INVALID_KEEPER' );
65     }
66 }
67
68 $template->param( action => $action );
69
70 output_html_with_http_headers $cgi, $cookie, $template->output;
71
72 1;