nanopkg / laravel-bulk-sms-bd
With this package you can easily integrate bulk sms system in your project with bulksmsbd.com API of Bangladesh.
Requires
- php: ^8.1
- guzzlehttp/guzzle: ^7.5
- illuminate/contracts: ^9.0
- spatie/laravel-package-tools: ^1.13.0
Requires (Dev)
- laravel/pint: ^1.0
- nunomaduro/collision: ^6.0
- orchestra/testbench: ^7.0
- pestphp/pest: ^1.23
- pestphp/pest-plugin-laravel: ^1.4
- phpstan/phpstan: ^1.12
- phpstan/phpstan-deprecation-rules: ^1.0
- phpstan/phpstan-phpunit: ^1.0
- phpunit/phpunit: ^9.6
- spatie/laravel-ray: ^1.26
This package is auto-updated.
Last update: 2024-11-21 09:21:43 UTC
README
With this package you can easily integrate bulk sms system in your project with bulksmsbd.com API of Bangladesh.
Installation
You can install the package via composer:
composer require nanopkg/laravel-bulk-sms-bd
You can publish the config file with:
php artisan vendor:publish --tag="bulk-sms-bd-config"
This is the contents of the published config file:
return [ /* |-------------------------------------------------------------------------- | Laravel Bulk SMS BD Mode of sending sms |-------------------------------------------------------------------------- | | This value is the mode of your laravel-bulk-sms-bd api integration. | log: for testing purpose | live: for live sms sending | */ 'mode' => env('BULK_SMS_BD_MODE', 'log'), /* |-------------------------------------------------------------------------- | Laravel Bulk SMS BD Api Key |-------------------------------------------------------------------------- | | This value is the api key of your laravel-bulk-sms-bd api integration. | */ 'api_key' => env('BULK_SMS_BD_API_KEY', ''), /* |-------------------------------------------------------------------------- | Laravel Bulk SMS BD Sender ID |-------------------------------------------------------------------------- | | This value is the Sender ID of your laravel-bulk-sms-bd api integration. | */ 'sender_id' => env('BULK_SMS_BD_SENDER_ID', ''), /* |-------------------------------------------------------------------------- | Laravel Bulk SMS BD Api Url |-------------------------------------------------------------------------- | | This value is the Api Url of your laravel-bulk-sms-bd api integration. | */ 'base_uri' => env('BULK_SMS_BD_API_URL', 'https://bulksmsbd.net/api/'), /* |-------------------------------------------------------------------------- | Laravel Bulk SMS BD Api Url SSL VERIFY |-------------------------------------------------------------------------- | | This value is the Api Url SSL verify of your laravel-bulk-sms-bd api integration. | */ 'verify' => env('BULK_SMS_BD_API_URL_VERIFY', false), /* |-------------------------------------------------------------------------- | Laravel Bulk SMS BD Log |-------------------------------------------------------------------------- | | This value is the log of your laravel-bulk-sms-bd api integration. | */ 'log' => [ 'driver' => env('BULK_SMS_BD_LOG_DRIVER', 'single'), 'path' => env('BULK_SMS_BD_LOG_PATH', storage_path('logs/laravel-bulk-sms-bd-log.log')), ], /* |-------------------------------------------------------------------------- | Laravel Bulk SMS BD Notification Keys |-------------------------------------------------------------------------- | | This value is the Notification Keys of your laravel-bulk-sms-bd api integration. | */ 'notification' => [ // define your custom notification key for message 'message' => 'message', // define your custom notification key for mobile number 'contacts' => 'to', ], ];
Add the following items to your .env file
// This value is the mode of your laravel-bulk-sms-bd api integration. | log: for testing purpose | live: for live sms sending BULK_SMS_BD_MODE='log' // This value is the api key of your laravel-bulk-sms-bd api integration. BULK_SMS_BD_API_KEY='' // This value is the Sender ID of your laravel-bulk-sms-bd api integration. BULK_SMS_BD_SENDER_ID='' // This value is the Api Url SSL verify of your laravel-bulk-sms-bd api integration. BULK_SMS_BD_API_URL_VERIFY=false
Usage
Get SMS Gateway Balance
Follow the below steps to get sms gateway balance
use Nanopkg\BulkSmsBd\Facades\BulkSmsBd; // get gateway balance $response = BulkSmsBd::getBalance(); return $response->balance;
Send One To One SMS
Follow the below steps to send one to one sms
use Nanopkg\BulkSmsBd\Facades\BulkSmsBd; // send one to one sms BulkSmsBd::oneToOne('017xxxxxxxx', 'আমার সোনার বাংলা, আমি তোমার ভালোবাসি।')->send();
If you want to send SMS by queue then follow below steps instead of above method.
use Nanopkg\BulkSmsBd\Jobs\BulkSmsBdOneToOne; // send one to one sms BulkSmsBdOneToOne::dispatch('017xxxxxxxx', 'আমার সোনার বাংলা, আমি তোমার ভালোবাসি।');
Send One To Many SMS
Follow the below steps to send one to Many sms
use Nanopkg\BulkSmsBd\Facades\BulkSmsBd; // Send one to many sms BulkSmsBd::oneToMany(['017xxxxxxxx','018xxxxxxxx','019xxxxxxxx'], 'আমার সোনার বাংলা, আমি তোমার ভালোবাসি।')->send();
If you want to send SMS by queue then follow below steps instead of above method.
use Nanopkg\BulkSmsBd\Jobs\BulkSmsBdOneToMany; // Send one to many sms BulkSmsBdOneToMany::dispatch(['017xxxxxxxx','018xxxxxxxx','019xxxxxxxx'], 'আমার সোনার বাংলা, আমি তোমার ভালোবাসি।');
Send Many To Many SMS
Follow the below steps to send Many to Many sms
use Nanopkg\BulkSmsBd\Facades\BulkSmsBd; // Send one to many sms BulkSmsBd::manyToMany([ [ 'to' => '017xxxxxxxx', 'message' => 'আমার সোনার বাংলা।' ], [ 'to' => '018xxxxxxxx', 'message' => 'আমি তোমার ভালোবাসি।' ], ])->send();
If you want to send SMS Many to Many by queue then follow below steps instead of above method.
use Nanopkg\BulkSmsBd\Jobs\BulkSmsBdManyToMany; // Send one to many sms BulkSmsBdManyToMany::dispatch([ [ 'to' => '017xxxxxxxx', 'message' => 'আমার সোনার বাংলা।' ], [ 'to' => '018xxxxxxxx', 'message' => 'আমি তোমার ভালোবাসি।' ] ]);
Send SMS Via Notification
Follow the below steps to send Many to Many sms
use Nanopkg\BulkSmsBd\Broadcasting\BulkSmsBdChannel; /** * Get the notification's delivery channels. * * @param mixed $notifiable * @return array */ public function via($notifiable) { return [BulkSmsBdChannel::class]; } /** * Get the BulkSmsBd representation of the notification. * @param mixed $notifiable * @return array */ public function toBulkSmsBd($notifiable) { return [ 'message' => 'আমার সোনার বাংলা, আমি তোমায় ভালোবাসি', 'to' => $notifiable->phone, ]; }
If you want to customize Notification representation key then open bulksmsbd config file and modify notification message and contacts value.
'notification' => [ // define your custom notification key for message 'message' => 'message', // define your custom notification key for mobile number 'contacts' => 'to', ],
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.