A simple implementation of BulkSMS for PHP.
Includes functionality to send single or batch messages.
This package requires PHP 5.4 because I'm too lazy to type array()
. Sorry.
Using composer: composer require anlutro/bulk-sms
- list of versions is available through GitHub's tag list.
The package includes files to make usage super easy in Laravel 4 and higher.
- Add
anlutro\BulkSms\Laravel\BulkSmsServiceProvider
to the list of providers inapp/config/app.php
. - Run
php artisan config:publish anlutro/bulk-sms
. Edit the config file inapp/config/packages/anlutro/bulk-sms
and fill in your username and password. - (optional) Add an alias for the facade by adding
'BulkSms' => 'anlutro\BulkSms\Laravel\BulkSms'
to aliases inapp/config/app.php
.
To use this library you need create an account with Bulksms. They support several sub-sites for specific regions.
- Username : Bulksms login
- Password : Bulksms login password
- Baseurl : Bulksms sub-site to connect to (e.g. "http://bulksms.com" or "http://bulksms.de")
Send Single Message
$bulkSms = new anlutro\BulkSms\BulkSmsService('username', 'password', 'baseurl');
$bulkSms->sendMessage('12345678', 'Hello there!');
Send Bulk Message
$message1 = new \anlutro\BulkSms\Message("12345678", "Hi there");
$message2 = new \anlutro\BulkSms\Message("12345678", "Hello again");
$bulkSms = new anlutro\BulkSms\BulkSmsService('username', 'password', 'baseurl');
$bulkSms->sendMessage(array($message1,$message2));
Get Status report
$bulkSms = new anlutro\BulkSms\BulkSmsService('username', 'password', 'baseurl');
$bulkSms->getStatusForBatchId(693099785);
BulkSms suports test modes (SUCCESS and FAIL) that validate the message and return defined responses without really sending out SMS. In order to send messages in test mode, run the following:
Send message that will return a success:
$bulkSms = new anlutro\BulkSms\BulkSmsService('username', 'password', 'baseurl');
$bulkSms->setTestMode(\anlutro\BulkSms\BulkSmsService::TEST_ALWAYS_SUCCEED);
$bulkSms->getStatusForBatchId(693099785);
Send message that will return a failure response - and thus trigger a BulkSmsException :
$bulkSms = new anlutro\BulkSms\BulkSmsService('username', 'password', 'baseurl');
$bulkSms->setTestMode(\anlutro\BulkSms\BulkSmsService::TEST_ALWAYS_FAIL);
$bulkSms->getStatusForBatchId(693099785);
In Laravel, you don't need to construct $bulkSms
, and you can replace $bulkSms->
with BulkSms::
provided you followed the installation steps above.
Open an issue on GitHub if you have any problems or suggestions.
If you have any questions or want to have a chat, look for anlutro @ chat.freenode.net.
The contents of this repository is released under the MIT license.