3 # Copyright (C) 2011 ByWater Solutions
5 # This file is part of Koha.
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.
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.
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>.
25 # find Koha's Perl modules
26 # test carefully before changing this
28 eval { require "$FindBin::Bin/../kohalib.pl" };
34 use Koha::Script -cron;
38 pod2usage( -verbose => 2 );
43 "TalkingTechItivaPhoneNotification system preference not activated... dying\n"
44 unless ( C4::Context->preference("TalkingTechItivaPhoneNotification") );
47 my $dbh = C4::Context->dbh;
59 'i|input:s' => \$infile,
64 die pod2usage() if $help;
66 # initialize the input data, either file or query
67 if ( defined $infile ) {
68 open( my $IN, '<', $infile ) || die("Cannot open input file");
69 print "Opening $infile\n" if ( defined $verbose );
73 # data should take to form "<Transaction ID>","<SUCCESS or FAIL>"
74 s/["\n]//g; # strip quotes and newlines: they're unnecessary
75 my @data = split(/,/);
76 my $result = update_notice(@data);
83 die pod2usage( -verbose => 1 );
86 print "$updated of $total results lines processed\n" if ( defined $verbose );
90 TalkingTech_itiva_inbound.pl
94 TalkingTech_itiva_inbound.pl
95 TalkingTech_itiva_inbound.pl -v --input=/tmp/talkingtech/results.csv
97 Script to process received Results files for Talking Tech i-tiva
98 phone notification system.
102 =item B<--help> B<-h>
108 Provide verbose log information.
110 =item B<--input> B<-i>
112 REQUIRED. Path to incoming results file.
119 my $message_id = shift;
122 if ( $status =~ m/SUCCESS/i ) {
125 elsif ( $status =~ m/FAIL/i ) {
129 warn "unexpected status $status for message ID $message_id\n";
134 "UPDATE message_queue SET status = ? WHERE message_id = ? and status = 'pending'";
135 my $sth = $dbh->prepare($query);
137 my $result = $sth->execute( $status, $message_id );