承接 flickerleap/clickatell 相关项目开发

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

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

flickerleap/clickatell

Composer 安装命令:

composer require flickerleap/clickatell

包简介

Laravel Notification integration for Clickatell

README 文档

README

This package implements Clickatell as a Laravel notification channel.

We drew a lot of inspiration from laravel-notification-channels/clickatell

Contents

Installation

composer require flickerleap/clickatell

.env

CLICKATELL_TOKEN=

Publish

php artisan vendor:publish --provider="FlickerLeap\Clickatell\ClickatellServiceProvider"

Configuration

Default to

CLICKATELL_FIELD=
  • CLICKATELL_FIELD - The default field to use for the to if the routeNotificationForClickatell() method is not implemented on the notifiable class.

Tracking

Optional tracking logs the send status from Clickatell. php artisan migrate needs to be run once enabled.

CLICKATELL_TRACK=
CLICKATELL_TRACKING_TABLE=
  • CLICKATELL_TRACK - Tracking true of false.
  • CLICKATELL_TRACKING_TABLE - Optional table name for tracking.

Callback

Optionally, with delivery notifications enabled, set the credentials and URL here. Tracking needs to be enabled. A value of /clickatellCallback would be accessed at https://mysite.com/clickatellCallback

CLICKATELL_CALLBACK_URL=
CLICKATELL_USERNAME=
CLICKATELL_PASSWORD=
  • CLICKATELL_CALLBACK_URL - Callback URL for message delivery updates.
  • CLICKATELL_USERNAME - Callback credentials.
  • CLICKATELL_PASSWORD - Callback credentials.

Usage

Notifiable

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;
use Illuminate\Notifications\Notifiable;

class User extends Model
{
    use Notifiable;

    /**
     * Route notifications for the clickatell channel.
     *
     * @param  \Illuminate\Notifications\Notification $notification
     * @return string
     */
    public function routeNotificationForClickatell($notification)
    {
        return $this->mobile;
    }

Notification

<?php

namespace App\Notifications;

use FlickerLeap\Clickatell\ClickatellChannel;
use FlickerLeap\Clickatell\ClickatellMessage;
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Notifications\Notification;

class SMSUser extends Notification implements ShouldQueue
{
    use Queueable;

    /**
     * Get the notification's delivery channels.
     *
     * @param  mixed $notifiable
     * @return array
     */
    public function via($notifiable)
    {
        return [ClickatellChannel::class];
    }

    /**
     * @param $notifiable
     * @return \FlickerLeap\Clickatell\ClickatellMessage
     */
    public function toClickatell($notifiable)
    {
        $content = 'My message.';

        return (new ClickatellMessage())->content($content);
    }

}

To

Optionally the to field can be dynamically changed per call by specifying ->to()

    /**
     * @param $notifiable
     * @return \FlickerLeap\Clickatell\ClickatellMessage
     */
    public function toClickatell($notifiable)
    {
        $content = 'My message.';

        return (new ClickatellMessage())->to($notifiable->beneficiary_number)
            ->content($content);
    }

Call

$user->notify(new SMSUser());

Testing

If APP_ENV is set to local, laravel log entries will be created.

Tests

TODO

Credits

统计信息

  • 总下载量: 109
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 3
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2018-08-24

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固