86239ea689
I wrapped the use of the SMS::Send module in an eval to make failures graceful if it is not present. I also fixed an error with the number of tests in the SMS::Send tests. Signed-off-by: Joshua Ferraro <jmf@liblime.com>
114 lines
2.5 KiB
Perl
114 lines
2.5 KiB
Perl
package C4::SMS;
|
|
|
|
# This file is part of Koha.
|
|
#
|
|
# Koha is free software; you can redistribute it and/or modify it under the
|
|
# terms of the GNU General Public License as published by the Free Software
|
|
# Foundation; either version 2 of the License, or (at your option) any later
|
|
# version.
|
|
#
|
|
# Koha is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
|
# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License along with
|
|
# Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place,
|
|
# Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
=head1 NAME
|
|
|
|
C4::SMS - send SMS messages
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
my $success = C4::SMS->send_sms( message => 'This is my text message',
|
|
destination => '212-555-1212' );
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
|
|
|
=cut
|
|
|
|
use strict;
|
|
use warnings;
|
|
|
|
use C4::Context;
|
|
|
|
use vars qw( $VERSION );
|
|
|
|
BEGIN {
|
|
$VERSION = 0.03;
|
|
}
|
|
|
|
=head1 METHODS
|
|
|
|
=cut
|
|
|
|
# The previous implmentation used username and password.
|
|
# our $user = C4::Context->config('smsuser');
|
|
# our $pwd = C4::Context->config('smspass');
|
|
|
|
=head2 send_sms
|
|
|
|
=over4
|
|
|
|
=back
|
|
|
|
=cut
|
|
|
|
sub send_sms {
|
|
my $self = shift;
|
|
my $params= shift;
|
|
|
|
foreach my $required_parameter ( qw( message destination ) ) {
|
|
# Should I warn in some way?
|
|
return unless defined $params->{ $required_parameter };
|
|
}
|
|
|
|
eval { require SMS::Send; };
|
|
if ( $@ ) {
|
|
# we apparently don't have SMS::Send. Return a failure.
|
|
return;
|
|
}
|
|
|
|
# This allows the user to override the driver. See SMS::Send::Test
|
|
my $driver = exists $params->{'driver'} ? $params->{'driver'} : $self->driver();
|
|
return unless $driver;
|
|
|
|
# warn "using driver: $driver to send message to $params->{'destination'}";
|
|
|
|
# Create a sender
|
|
my $sender = SMS::Send->new( $driver,
|
|
_login => C4::Context->preference('SMSSendUsername'),
|
|
_password => C4::Context->preference('SMSSendPassword'),
|
|
);
|
|
|
|
# Send a message
|
|
my $sent = $sender->send_sms( to => $params->{'destination'},
|
|
text => $params->{'message'},
|
|
);
|
|
# warn 'failure' unless $sent;
|
|
return $sent;
|
|
}
|
|
|
|
=head2 driver
|
|
|
|
=over 4
|
|
|
|
=back
|
|
|
|
=cut
|
|
|
|
sub driver {
|
|
my $self = shift;
|
|
|
|
# return 'US::SprintPCS';
|
|
return C4::Context->preference('SMSSendDriver');
|
|
|
|
}
|
|
|
|
1;
|
|
|
|
__END__
|
|
|