Bug 7688 follow-up: Small fixes for QA #2
[koha-equinox.git] / serials / create-numberpattern.pl
1 #!/usr/bin/perl
2
3 use CGI;
4 use C4::Context;
5 use C4::Serials::Numberpattern;
6 use URI::Escape;
7 use strict;
8 use warnings;
9
10 my $input = new CGI;
11
12 my $numberpattern;
13 foreach (qw/ numberingmethod label1 label2 label3 add1 add2 add3
14   every1 every2 every3 setto1 setto2 setto3 whenmorethan1 whenmorethan2
15   whenmorethan3 numbering1 numbering2 numbering3 locale /) {
16     $numberpattern->{$_} = $input->param($_);
17 }
18 # patternname is label in database
19 $numberpattern->{'label'} = $input->param('patternname');
20
21 # Check if pattern already exist in database
22 my $dbh = C4::Context->dbh;
23 my $query = qq{
24     SELECT id
25     FROM subscription_numberpatterns
26     WHERE STRCMP(label, ?) = 0
27 };
28 my $sth = $dbh->prepare($query);
29 my $rv = $sth->execute($numberpattern->{'label'});
30 my $numberpatternid;
31 if($rv == 0) {
32     # Pattern does not exists
33     $numberpatternid = AddSubscriptionNumberpattern($numberpattern);
34 } else {
35     ($numberpatternid) = $sth->fetchrow_array;
36     $numberpattern->{'id'} = $numberpatternid;
37     ModSubscriptionNumberpattern($numberpattern);
38 }
39
40 binmode STDOUT, ":encoding(UTF-8)";
41 print $input->header(-type => 'text/plain', -charset => 'UTF-8');
42 print "{\"numberpatternid\":\"$numberpatternid\"}";