NAME
Mojar::Message::BulkSms - Send SMS via BulkSMS services.
SYNOPSIS
use Mojar::Message::BulkSms;
my $sms = Mojar::Message::BulkSms->new(username => ..., password => ...);
# Synchronous
$sms->message(q{Team, have we used up all our credits yet?}),
->send(recipient => '0776 432 111')
->send(recipient => '0778 888 123');
# Asynchronous
my @error;
$sms->message(q{Team, please check the async responses}),
->send(recipient => $recipient[0] => sub { $error[0] = $_[1] })
->send(recipient => $recipient[1] => sub { $error[1] = $_[1] });
DESCRIPTION
Sends SMS messages via BulkSMS services such as usa.bulksms.com and bulksms.de.
ATTRIBUTES
protocol
$sms->protocol; # defaults to http $sms->protocol('https');
address
$sms->address; # defaults to www.bulksms.co.uk $sms->address('bulksms.de');
port
$sms->port; # defaults to 5567 $sms->port(5567);
path
$sms->path; # defaults to eapi/submission/send_sms/2/2.0 $sms->path('eapi/submission/send_sms/2/2.1');
gateway
$sms->log->debug('Using gateway: '. $sms->gateway);
The full URL constructed from the parts above.
username
say $sms->username; $sms->username('us3r');
Username for the account;
password
say $sms->password; $sms->password('s3cr3t');
Password for the account;
recipient
say $sms->recipient; $sms->recipient('077-6640 2921');
sender
say $sms->sender; $sms->sender('Your car');
The SMS sender. However, in my (UK) experience this has no effect.
international_prefix
say $sms->international_prefix; # defaults to 44 $sms->international_prefix('33');
message
say $sms->message; $sms->message('Sorry, forgotten what I wanted to say now!');
The message to send. Bear in mind that unaccepted characters get substituted by the SMS service (often to '?').
log
$sms->log($app->log); $sms->log(Mojar::Log->new(path => 'log/sms.log', level => 'info')); $sms->log->error('Uh-oh!');
A Mojo::Log-compatible log object. Defaults to using STDERR.
METHODS
- new
-
$sms = Mojar::Message::BulkSms->new(username => ..., password => ..., ...);
Constructor for the SMS agent.
- send
-
$sent = $sms->send;
Sends an SMS message. Returns a false value upon failure (when used synchronously).
$sent = $sms->message('Boo')->send(recipient => $r1)->send(recipient => $r2); $sent = $sms->recipient($r3)->send(message => $m1)->send(message => $m2);
Supports method chaining, and will bail-out at the first failure if no callback is given.
$sms->send(sub { my ($agent, $error) = @_; ... }); $sms->send(message => 'Stuff' => sub { ++$error_count if $_[1] });
Also supports asynchronous calls when provided a callback as the final argument.
- other methods
-
See the source code for other methods you can override when subclassing this.
REFERENCE
http://www.bulksms.co.uk/docs/eapi/ shows the service API.
CONFIGURATION AND ENVIRONMENT
You need to create an account at www.bulksms.co.uk.
SUPPORT
See Mojar.
DIAGNOSTICS
You can get behind-the-scenes debugging info by setting
MOJAR_SMS_DEBUG=1
in your script's environment. You should then see all the messages to and from bulksms.co.uk as well as some progress notes.
SEE ALSO
Net::SMS::BulkSMS is similar but blocking.