Bug 36792: Limit POSIX imports
[koha.git] / clubs / clubs-add-modify.pl
1 #!/usr/bin/perl
2
3 # Copyright 2013 ByWater Solutions
4 #
5 # This file is part of Koha.
6 #
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.
11 #
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.
16 #
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>.
19
20 use Modern::Perl;
21
22 use CGI;
23
24 use C4::Auth qw( get_template_and_user );
25 use C4::Output qw( output_html_with_http_headers );
26 use Koha::Database;
27 use Koha::DateUtils qw( dt_from_string );
28 use Koha::Clubs;
29 use Koha::Club::Fields;
30
31 my $cgi = CGI->new;
32
33 my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
34     {
35         template_name   => 'clubs/clubs-add-modify.tt',
36         query           => $cgi,
37         type            => 'intranet',
38         flagsrequired   => { clubs => 'edit_clubs' },
39     }
40 );
41
42 my $schema = Koha::Database->new()->schema();
43
44 my $id = $cgi->param('id');
45 my $club = $id ? Koha::Clubs->find($id) : Koha::Club->new();
46
47 my $stored =
48     $cgi->param('name')
49   ? $id
50       ? 'updated'
51       : 'stored'
52   : undef;
53
54 my $club_template_id = $cgi->param('club_template_id');
55 my $club_template = $club->club_template() || Koha::Club::Templates->find($club_template_id);
56 $club_template_id ||= $club_template->id();
57
58 my $date_start = $cgi->param('date_start') || undef;
59 my $date_end = $cgi->param('date_end') || undef;
60
61 if ( $cgi->param('name') ) {    # Update or create club
62     $club->set(
63         {
64             club_template_id => scalar $cgi->param('club_template_id') || undef,
65             name             => scalar $cgi->param('name')             || undef,
66             description      => scalar $cgi->param('description')      || undef,
67             branchcode       => scalar $cgi->param('branchcode')       || undef,
68             date_start       => $date_start,
69             date_end         => $date_end,
70             date_updated     => dt_from_string(),
71         }
72     )->store();
73
74     my @club_template_field_id = $cgi->multi_param('club_template_field_id');
75     my @club_field_id          = $cgi->multi_param('club_field_id');
76     my @club_field             = $cgi->multi_param('club_field');
77
78     for ( my $i = 0 ; $i < @club_template_field_id ; $i++ ) {
79         my $club_template_field_id = $club_template_field_id[$i] || undef;
80         my $club_field_id          = $club_field_id[$i]          || undef;
81         my $club_field             = $club_field[$i]             || undef;
82
83         my $field =
84           $club_field_id
85           ? Koha::Club::Fields->find($club_field_id)
86           : Koha::Club::Field->new();
87
88         $field->set(
89             {
90                 club_id                => $club->id(),
91                 club_template_field_id => $club_template_field_id,
92                 value                  => $club_field,
93             }
94         )->store();
95     }
96
97     $id ||= $club->id();
98
99     print $cgi->redirect("/cgi-bin/koha/clubs/clubs.pl?stored=$stored&club_id=$id");
100     exit;
101 }
102
103 $club = Koha::Clubs->find($id);
104
105 $template->param(
106     club_template => $club_template,
107     club          => $club,
108 );
109
110 output_html_with_http_headers( $cgi, $cookie, $template->output );