Laravel 5.3 Notification 个人理解,及 BearyChat Channel 新鲜出炉

Laravel Notification

Laravel 5.3 提供了一种全新的发送通知的方式:Notification 。个人理解是可以基于某事件(操作)触发一系列的通知任务,而通知方式由 Channel (通知渠道)接管,这样使得通知(或推送)逻辑更抽象,更易于管理和重构。

举个例子,在用户完成订单支付后,你需要给用户发送邮件、短信提醒用户的订单已完成支付,还需要提醒仓管有新订单需要发货,如果是重要的订单可能还需要通知 Boss 刚刚有用户支付了一笔大订单,如果你的应用提供客户端,你可能还需要给用户的 iOS/Android/Mac/Windows 等 App 发送推送通知,当然也包括浏览器的通知。你可能还需要把这个通知实时广播出去,让用户的网页无刷新实时更新状态等。除此之外,像订单操作这么重要的东西,你应该要记录日志。

在 5.3 之前,我是利用 Laravel 的 Model Event, Broadcast Event, Event Listener, Job, Queue 来完成这一系列通知。我之前在 laravel-bearychat 这个扩展包的文档中给了一个发送异步消息的示例

现在 5.3 的一个 Notification 就可以囊括所有了,更重要的是代码分离。当用户完成订单支付后,只需要通过在 controller 或 model 中手动调用或者监听 Order model 的订单状态来自动调用 OrderPaidNotification 这个通知,剩下的事就都交给 OrderPaidNotification 了。

Notification 的具体使用请参阅官方文档:https://laravel.com/docs/master/notifications

第三方 Channels

Laravel 5.3 内置支持 Mail, Database, Broadcast, SMS, Slack 这几种 Channel 。

因为有很多第三方的通知(或推送)服务,官方专门搞了个组织来维护民间的 channels ,比如 Twitter, Facebook, Telegram, Evernote, IFTTT, Apple APNs 等。

Laravel Notification Channels 主页:http://laravel-notification-channels.com

GitHub 组织:https://github.com/laravel-notification-channels

如果你在使用国内的某服务,可以考虑做成一个扩展包供大伙使用。😀🎉

兼容 Laravel 5.2 / 5.1

使用 laravel-notification-channels/backport 这个扩展包,在 Laravel 5.2 / 5.1 上也可以使用 Laravel 5.3 的 Notification 。

项目主页:https://github.com/laravel-notification-channels/backport

BearyChat Channel

我周末做了一个 BearyChat 的通知渠道 BearyChatChannel,是在之前 Laravel-BearyChat 这个扩展包的基础上开发的,可以跟其兼容使用。

因为之前写的 Message 类和 Laravel 5.3 Notification 的 message 的设计理念高度相似,所以在新包中可以无缝迁移。其实我就是直接使用的旧的 Message 类,因为这样可以跟旧包兼容,而且这个 Message 除了发送通知还有响应 Outgoing 的功能。

正在使用 Laravel-BearyChat 的小伙伴在升级 Laravel 5.3 后可以使用 Notification+BearyChatChannel 这种新方式发送机器人消息,也可以使用原来的方式,互不影响。

BearyChatChannel 使用的配置文件还是原来的 config/bearychat.php,无需重新配置。

如果你注册了 BearyChatChannel 的 ServiceProvider ,原来的 ElfSundae\BearyChat\Laravel\ServiceProvider 可有可无。

BearyChatChannel 项目主页及文档:https://github.com/laravel-notification-channels/bearychat

欢迎 Star 🌟 欢迎 Issue 🐞

Elf Sundae

Elf Sundae has written 2 articles