Via Composer
$ composer require carropublic/notifications
Run the following vendor publish to publish Twillo config.
php artisan vendor:publish --provider="CarroPublic\Notifications\NotificationServiceProvider"
The following is the example usage of the package with Laravel's Notification.
class ExampleNotification extends Notification
{
// Which channel this notification should be sent to
public function via($notifiable)
{
return [ SMSChannel::class, WhatsAppChannel::class ];
}
// Notification payload (content) will be sent
public function toSMS($notifiable)
{
return new LaravelTwilioMessage("Message Content");
}
// Notification payload (content) will be sent
public function toWhatsApp($notifiable)
{
return new LaravelTwilioMessage("Message Content");
}
}
class Contact extends Model {
use Notifiable;
// Phone number to receive
public function routeNotificationForSms()
{
return $this->phone;
}
// Phone number to receive
public function routeNotificationForWhatsapp()
{
return $this->phone;
}
}
$contact->notify(new ExampleNotification());
Notification::route('sms')->notify(new ExampleNotification());
- Register Closure to return if testing is enabled
\CarroPublic\Notifications\Senders\Sender::registerSandboxValidator
Example:
Sender::registerSandboxValidator(function () {
return !is_production();
});
- Otherwise, use
NOTIFICATION_SANDBOX_ENABLE
to determine if running in sandbox mode. Defaultfalse
⛔️ Notes: If the closure is registered, the env will be ignored
- Register Closure to return if sandbox is enabled
\CarroPublic\Notifications\Senders\Sender::registerValidForSandbox
$to: the recipient the message will be sent to $type: the sender class
- LineSender
- TelerivetSender
- TwilioSender
- MailChannel (Since there is not MailSender, the MailChannel will be used instead)
LaravelTwilioSender::registerValidPhoneForSandbox(function ($to, $type) {
switch ($type) {
case LineSender::class:
return true;
case TwilioSender::class:
return false;
}
}
Please see the changelog for more information on what has changed recently.
If you discover any security related issues, please email author email instead of using the issue tracker.
Please see the license file for more information.