承接 carropublic/laraveltwilio 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

carropublic/laraveltwilio

最新稳定版本:6.0.1-beta

Composer 安装命令:

composer require carropublic/laraveltwilio

包简介

A wrapper for Twilio SMS notification for Laravel

README 文档

README

Latest Version on Packagist Total Downloads

A wrapper for Twilio SMS notification for Laravel. Take a look at contributing.md to see a to do list.

Installation

Via Composer

$ composer require carropublic/laraveltwilio

Run the following vendor publish to publish Twillo config.

php artisan vendor:publish --tag=laraveltwilio.config

Update your .env for Twilio config in order to send out the SMS notification.

Usage

LaravelNotification

The following is the example usage of the package with Laravel's Notification.

Create Notification Class

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");
    }
}

Create Notifiable Class

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;
    }
}
Sending Notification from Notifiable Instance
$contact->notify(new ExampleNotification());
Sending Notification from Anonymous Notifiable Instance
Notification::route('sms')->notify(new ExampleNotification());

Check incoming messages from Twilio

When using webhook, you can validate the incoming request is from Twilio. $token is config('laraveltwilio.auth_token'). We are not using directly becuase it might be dynamic.

use CarroPublic\LaravelTwilio\Request\ValidateTwilioIncomingRequestSignature;

ValidateSignatureOfRequest::isValidRequest($token, $request);

Sandbox Mode

How to enable SandBox Mode

  1. Register Closure to return if testing is enabled \CarroPublic\LaravelTwilio\LaravelTwilioManager::registerTestingValidator

Example:

LaravelTwilioManager::registerSandboxValidator(function () {
    return !is_production();
});
  1. Otherwise, useTWILIO_TESTING_ENABLE to determine if running in sandbox mode. Default false

How to bypass sandbox $phone validator

  • Register Closure to return if sandbox is enabled \CarroPublic\LaravelTwilio\LaravelTwilioSender::registerValidPhoneForSandbox

Example:

LaravelTwilioSender::registerValidPhoneForSandbox(function ($phoneNumber) {
    return $phoneNumber == "+84111111111";
}

Change log

Please see the changelog for more information on what has changed recently.

Testing

$ composer test

Contributing

Please see contributing.md for details and a todolist.

Security

If you discover any security related issues, please email author email instead of using the issue tracker.

Credits

License

Please see the license file for more information.

统计信息

  • 总下载量: 125.84k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 2
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 2
  • Watchers: 6
  • Forks: 3
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2018-09-12