[
MAINHACK
]
Mail Test
BC
Config Scan
HOME
Create...
New File
New Folder
Viewing / Editing File: README.md
# Twilio notifications channel for Laravel [](https://packagist.org/packages/laravel-notification-channels/twilio) [](LICENSE.md) [](https://travis-ci.org/laravel-notification-channels/twilio) [](https://styleci.io/repos/65543339) [](https://scrutinizer-ci.com/g/laravel-notification-channels/twilio) [](https://scrutinizer-ci.com/g/laravel-notification-channels/twilio/?branch=master) [](https://packagist.org/packages/laravel-notification-channels/twilio) This package makes it easy to send [Twilio notifications](https://documentation.twilio.com/docs) with Laravel 5.5+, 6.x, 7.x, 8.x & 9.x You are viewing the `3.x` documentation. [Click here](https://github.com/laravel-notification-channels/twilio/tree/2.x) to view the `2.x` documentation. ## Contents - [Installation](#installation) - [Usage](#usage) - [Available Message methods](#available-message-methods) - [Changelog](#changelog) - [Testing](#testing) - [Security](#security) - [Contributing](#contributing) - [Credits](#credits) - [License](#license) ## Installation You can install the package via composer: ``` bash composer require laravel-notification-channels/twilio ``` ### Configuration Add your Twilio Account SID, Auth Token, and From Number (optional) to your `.env`: ```dotenv TWILIO_USERNAME=XYZ # optional when using auth token TWILIO_PASSWORD=ZYX # optional when using auth token TWILIO_AUTH_TOKEN=ABCD # optional when using username and password TWILIO_ACCOUNT_SID=1234 # always required TWILIO_FROM=100000000 # optional default from TWILIO_ALPHA_SENDER=HELLO # optional TWILIO_DEBUG_TO=23423423423 # Set a number that call calls/messages should be routed to for debugging TWILIO_SMS_SERVICE_SID=MG0a0aaaaaa00aa00a00a000a00000a00a # Optional but recommended TWILIO_SHORTEN_URLS=true # optional, enable URL shortener ``` ### Advanced configuration Run `php artisan vendor:publish --provider="NotificationChannels\Twilio\TwilioProvider"` ``` /config/twilio-notification-channel.php ``` #### Suppressing specific errors or all errors Publish the config using the above command, and edit the `ignored_error_codes` array. You can get the list of exception codes from [the documentation](https://www.twilio.com/docs/api/errors). If you want to suppress all errors, you can set the option to `['*']`. The errors will not be logged but notification failed events will still be emitted. #### Recommended Configuration Twilio recommends always using a [Messaging Service](https://www.twilio.com/docs/sms/services) because it gives you access to features like Advanced Opt-Out, Sticky Sender, Scaler, Geomatch, Shortcode Reroute, and Smart Encoding. Having issues with SMS? Check Twilio's [best practices](https://www.twilio.com/docs/sms/services/services-best-practices). ## Upgrading from 2.x to 3.x If you're upgrading from version `2.x`, you'll need to make sure that your set environment variables match those above in the config section. None of the environment variable names have changed, but if you used different keys in your `services.php` config then you'll need to update them to match the above, or publish the config file and change the `env` key. You should also remove the old entry for `twilio` from your `services.php` config, since it's no longer used. The main breaking change between `2.x` and `3.x` is that failed notification will now throw an exception unless they are in the list of ignored error codes (publish the config file to edit these). You can replicate the `2.x` behaviour by setting `'ignored_error_codes' => ['*']`, which will case all exceptions to be suppressed. ## Usage Now you can use the channel in your `via()` method inside the notification: ``` php use NotificationChannels\Twilio\TwilioChannel; use NotificationChannels\Twilio\TwilioSmsMessage; use Illuminate\Notifications\Notification; class AccountApproved extends Notification { public function via($notifiable) { return [TwilioChannel::class]; } public function toTwilio($notifiable) { return (new TwilioSmsMessage()) ->content("Your {$notifiable->service} account was approved!"); } } ``` You can also send an MMS: ``` php use NotificationChannels\Twilio\TwilioChannel; use NotificationChannels\Twilio\TwilioMmsMessage; use Illuminate\Notifications\Notification; class AccountApproved extends Notification { public function via($notifiable) { return [TwilioChannel::class]; } public function toTwilio($notifiable) { return (new TwilioMmsMessage()) ->content("Your {$notifiable->service} account was approved!") ->mediaUrl("https://picsum.photos/300"); } } ``` Or create a Twilio call: ``` php use NotificationChannels\Twilio\TwilioChannel; use NotificationChannels\Twilio\TwilioCallMessage; use Illuminate\Notifications\Notification; class AccountApproved extends Notification { public function via($notifiable) { return [TwilioChannel::class]; } public function toTwilio($notifiable) { return (new TwilioCallMessage()) ->url("http://example.com/your-twiml-url"); } } ``` In order to let your Notification know which phone are you sending/calling to, the channel will look for the `phone_number` attribute of the Notifiable model. If you want to override this behaviour, add the `routeNotificationForTwilio` method to your Notifiable model. ```php public function routeNotificationForTwilio() { return '+1234567890'; } ``` ### Available Message methods #### TwilioSmsMessage - `from('')`: Accepts a phone to use as the notification sender. - `content('')`: Accepts a string value for the notification body. - `messagingServiceSid('')`: Accepts a messaging service SID to handle configuration. #### TwilioCallMessage - `from('')`: Accepts a phone to use as the notification sender. - `url('')`: Accepts an url for the call TwiML. ## Changelog Please see [CHANGELOG](CHANGELOG.md) for more information what has changed recently. ## Testing ``` bash $ composer test ``` ## Security If you discover any security related issues, please email gregoriohc@gmail.com instead of using the issue tracker. ## Contributing Please see [CONTRIBUTING](CONTRIBUTING.md) for details. ## Credits - [Gregorio Hernández Caso](https://github.com/gregoriohc) - [atymic](https://github.com/atymic) - [All Contributors](../../contributors) ## License The MIT License (MIT). Please see [License File](LICENSE.md) for more information.
Save Changes
Cancel / Back
Close ×
Server Info
Hostname: server1.winmanyltd.com
Server IP: 203.161.60.52
PHP Version: 8.3.27
Server Software: Apache
System: Linux server1.winmanyltd.com 4.18.0-553.22.1.el8_10.x86_64 #1 SMP Tue Sep 24 05:16:59 EDT 2024 x86_64
HDD Total: 117.98 GB
HDD Free: 59.48 GB
Domains on IP: N/A (Requires external lookup)
System Features
Safe Mode:
Off
disable_functions:
None
allow_url_fopen:
On
allow_url_include:
Off
magic_quotes_gpc:
Off
register_globals:
Off
open_basedir:
None
cURL:
Enabled
ZipArchive:
Enabled
MySQLi:
Enabled
PDO:
Enabled
wget:
Yes
curl (cmd):
Yes
perl:
Yes
python:
Yes (py3)
gcc:
Yes
pkexec:
Yes
git:
Yes
User Info
Username: eliosofonline
User ID (UID): 1002
Group ID (GID): 1003
Script Owner UID: 1002
Current Dir Owner: 1002