rifqiardian / laravel-fcm
Laravel / Lumen 包用于 Firebase 云消息传递 (FCM)
Requires
- php: >=5.5.9
- guzzlehttp/guzzle: ^6.0|^7.0
- illuminate/support: ^8.0
- monolog/monolog: ^1.0|^2.0
Requires (Dev)
- laravel/laravel: 5.2.*
- mockery/mockery: 0.9.*
- phpunit/phpunit: 4.7.*
- satooshi/php-coveralls: dev-master
Replaces
README
简介
从 adhityairvan/Laravel-FCM 分支。修复添加图片到通知的问题
Laravel-FCM 是一个易于使用的包,适用于 Laravel 和 Lumen,用于通过 Firebase 云消息传递 (FCM) 发送推送通知。
它目前仅支持 HTTP 协议用于
- 向一个或多个设备发送下行消息
- 管理群组并发送群组消息
- 发送主题消息
注意:目前不支持 XMPP 协议。
安装
要将 Laravel-FCM 的最新版本添加到您的项目中,请在 "composer" 中要求它
$ composer require rifqiardian/laravel-fcm
或者您可以直接在您的 composer.json 文件中添加它
{ "require": { "rifqiardian/laravel-fcm": "^1.4.*" } }
Laravel
直接在您的应用程序配置文件 config/app.php 中注册提供者 config/app.php
Laravel >= 5.5 提供了包自动发现功能,归功于 rasmuscnielsen 和 luiztessadri,他们帮助在 Laravel-FCM 中实现了此功能,因此不需要再注册提供者和外观。
'providers' => [ // ... LaravelFCM\FCMServiceProvider::class, ]
在相同的文件中添加外观别名
'aliases' => [ ... 'FCM' => LaravelFCM\Facades\FCM::class, 'FCMGroup' => LaravelFCM\Facades\FCMGroup::class, // Optional ]
注意:如果要在应用程序中管理群组消息,则需要 FCMGroup 外观。
使用以下命令发布包配置文件
$ php artisan vendor:publish --provider="LaravelFCM\FCMServiceProvider"
Lumen
在您的引导应用程序文件 boostrap/app.php
中注册提供者
在文件底部的 "注册服务提供者" 部分添加以下行。
$app->register(LaravelFCM\FCMServiceProvider::class);
对于外观,在 "创建应用程序" 部分中添加以下行。如果要在应用程序中使用群组消息,则 FCMGroup 外观是必要的。
class_alias(\LaravelFCM\Facades\FCM::class, 'FCM'); class_alias(\LaravelFCM\Facades\FCMGroup::class, 'FCMGroup');
将配置文件 fcm.php
手动从目录 /vendor/brozot/laravel-fcm/config
复制到目录 /config
(您可能需要创建此目录)。
包配置
在您的 .env
文件中,添加 Firebase 云消息传递的服务密钥和密钥
FCM_SERVER_KEY=my_secret_server_key FCM_SENDER_ID=my_secret_sender_id
要获取这些密钥,您必须在 Firebase 云消息传递控制台 上创建一个新的应用程序。
在 Firebase 上创建应用程序后,您可以在 项目设置 -> 云消息传递
中找到密钥。
基本用法
可以使用 Laravel-FCM 发送两种类型的消息
- 通知消息,有时被认为是“显示消息”
- 数据消息,由客户端应用程序处理
有关更多信息,请参阅 官方文档。
下行消息
下行消息是您通过其 registration_Ids 向目标设备或多个目标设备发送的通知消息、数据消息或两者都的消息。
以下示例需要以下使用语句
use LaravelFCM\Message\OptionsBuilder; use LaravelFCM\Message\PayloadDataBuilder; use LaravelFCM\Message\PayloadNotificationBuilder; use FCM;
向设备发送下行消息
$optionBuilder = new OptionsBuilder(); $optionBuilder->setTimeToLive(60*20); $notificationBuilder = new PayloadNotificationBuilder('my title'); $notificationBuilder->setBody('Hello world') ->setSound('default'); $dataBuilder = new PayloadDataBuilder(); $dataBuilder->addData(['a_data' => 'my_data']); $option = $optionBuilder->build(); $notification = $notificationBuilder->build(); $data = $dataBuilder->build(); $token = "a_registration_from_your_database"; $downstreamResponse = FCM::sendTo($token, $option, $notification, $data); $downstreamResponse->numberSuccess(); $downstreamResponse->numberFailure(); $downstreamResponse->numberModification(); // return Array - you must remove all this tokens in your database $downstreamResponse->tokensToDelete(); // return Array (key : oldToken, value : new token - you must change the token in your database) $downstreamResponse->tokensToModify(); // return Array - you should try to resend the message to the tokens in the array $downstreamResponse->tokensToRetry(); // return Array (key:token, value:error) - in production you should remove from your database the tokens $downstreamResponse->tokensWithError();
向多个设备发送下行消息
$optionBuilder = new OptionsBuilder(); $optionBuilder->setTimeToLive(60*20); $notificationBuilder = new PayloadNotificationBuilder('my title'); $notificationBuilder->setBody('Hello world') ->setSound('default'); $dataBuilder = new PayloadDataBuilder(); $dataBuilder->addData(['a_data' => 'my_data']); $option = $optionBuilder->build(); $notification = $notificationBuilder->build(); $data = $dataBuilder->build(); // You must change it to get your tokens $tokens = MYDATABASE::pluck('fcm_token')->toArray(); $downstreamResponse = FCM::sendTo($tokens, $option, $notification, $data); $downstreamResponse->numberSuccess(); $downstreamResponse->numberFailure(); $downstreamResponse->numberModification(); // return Array - you must remove all this tokens in your database $downstreamResponse->tokensToDelete(); // return Array (key : oldToken, value : new token - you must change the token in your database) $downstreamResponse->tokensToModify(); // return Array - you should try to resend the message to the tokens in the array $downstreamResponse->tokensToRetry(); // return Array (key:token, value:error) - in production you should remove from your database the tokens present in this array $downstreamResponse->tokensWithError();
有关更多信息,请参阅 下行消息错误响应代码 文档。
主题消息
主题消息是您发送到注册此主题的所有设备的通知消息、数据消息或两者都的消息。
注意:主题名称必须由您的应用程序管理并由您的服务器知道。Laravel-FCM 包或 fcm 不提供简单的方式来做到这一点。
以下示例需要以下使用语句
use LaravelFCM\Message\Topics;
向主题发送消息
$notificationBuilder = new PayloadNotificationBuilder('my title'); $notificationBuilder->setBody('Hello world') ->setSound('default'); $notification = $notificationBuilder->build(); $topic = new Topics(); $topic->topic('news'); $topicResponse = FCM::sendToTopic($topic, null, $notification, null); $topicResponse->isSuccess(); $topicResponse->shouldRetry(); $topicResponse->error();
向多个主题发送消息
它向以下主题注册的设备发送通知
- 新闻和经济
- 新闻和文化
注意:主题支持每个表达式两个操作符
$notificationBuilder = new PayloadNotificationBuilder('my title'); $notificationBuilder->setBody('Hello world') ->setSound('default'); $notification = $notificationBuilder->build(); $topic = new Topics(); $topic->topic('news')->andTopic(function($condition) { $condition->topic('economic')->orTopic('cultural'); }); $topicResponse = FCM::sendToTopic($topic, null, $notification, null); $topicResponse->isSuccess(); $topicResponse->shouldRetry(); $topicResponse->error());
群组消息
向群组发送通知
$notificationKey = ['a_notification_key']; $notificationBuilder = new PayloadNotificationBuilder('my title'); $notificationBuilder->setBody('Hello world') ->setSound('default'); $notification = $notificationBuilder->build(); $groupResponse = FCM::sendToGroup($notificationKey, null, $notification, null); $groupResponse->numberSuccess(); $groupResponse->numberFailure(); $groupResponse->tokensFailed();
创建群组
$tokens = ['a_registration_id_at_add_to_group']; $groupName = "a_group"; $notificationKey // Save notification key in your database you must use it to send messages or for managing this group $notification_key = FCMGroup::createGroup($groupName, $tokens);
将设备添加到群组
$tokens = ['a_registration_id_at_add_to_the_new_group']; $groupName = "a_group"; $notificationKey = "notification_key_received_when_group_was_created"; $key = FCMGroup::addToGroup($groupName, $notificationKey, $tokens);
从群组中删除设备
注意:如果所有设备都从群组中删除,则群组将自动在 "fcm" 中删除。
$tokens = ['a_registration_id_at_remove_from_the_group']; $groupName = "a_group"; $notificationKey = "notification_key_received_when_group_was_created"; $key = FCMGroup::removeFromGroup($groupName, $notificationKey, $tokens);
选项
Laravel-FCM 支持基于 Firebase Cloud Messaging 选项的选项。这些选项可以帮助您定义通知的特定性。
您可以根据以下方式构建一个选项
$optionsBuilder = new OptionsBuilder(); $optionsBuilder->setTimeToLive(42*60) ->setCollapseKey('a_collapse_key'); $options = $optionsBuilder->build();
通知消息
通知有效载荷用于发送通知,行为由接收设备的 App 状态和操作系统定义。
当应用在后台时,通知消息将被发送到通知栏。对于前台应用,消息由以下回调处理
- didReceiveRemoteNotification:在 iOS 上
- onMessageReceived() 在 Android 上。数据包中的通知键包含通知。
请参阅官方文档。
$notificationBuilder = new PayloadNotificationBuilder(); $notificationBuilder->setTitle('title') ->setBody('body') ->setSound('sound') ->setBadge('badge'); $notification = $notificationBuilder->build();
数据消息
使用您自定义的键值对设置数据键,向客户端应用发送数据有效载荷。数据消息的有效载荷最大为 4KB。
- iOS,FCM 存储消息并在应用在前台并建立 FCM 连接时才将其发送。
- Android,客户端应用在 onMessageReceived() 中接收到数据消息,并可以相应地处理键值对。
请参阅官方文档。
$dataBuilder = new PayloadDataBuilder(); $dataBuilder->addData([ 'data_1' => 'first_data' ]); $data = $dataBuilder->build();
通知 & 数据消息
当接收到同时包含通知和数据有效载荷的消息时,应用的行为取决于应用是否在后台或前台——基本上,它是否在接收消息时处于活动状态(来源)。
- 后台,应用在通知栏中接收到通知有效载荷,并且仅在用户点击通知时才处理数据有效载荷。
- 前台,您的应用接收到一个包含两个有效载荷的消息对象。
主题
对于主题消息,Laravel-FCM 提供了一个易于使用的 API,用于抽象 Firebase 条件。为了使 Firebase 官方文档中给出的条件,必须像以下 Laravel-FCM 一样完成
官方文档条件
'TopicA' in topics && ('TopicB' in topics || 'TopicC' in topics)
$topics = new Topics(); $topics->topic('TopicA') ->andTopic(function($condition) { $condition->topic('TopicB')->orTopic('TopicC'); });
测试
对于集成测试,您可以使用 mockery 和该包提供的 Mocks 来模拟响应。
该包提供了 3 种 "MockResponse" 类型
- MockDownstreamResponse
- MockGroupResponse
- MockTopicResponse
您可以根据以下示例模拟 FCM 调用
$numberSucess = 2; $mockResponse = new \LaravelFCM\Mocks\MockDownstreamResponse(numberSucess); $mockResponse->addTokenToDelete('token_to_delete'); $mockResponse->addTokenToModify('token_to_modify', 'token_modified'); $mockResponse->setMissingToken(true); $sender = Mockery::mock(\LaravelFCM\Sender\FCMSender::class); $sender->shouldReceive('sendTo')->once()->andReturn($mockResponse); $this->app->singleton('fcm.sender', function($app) use($sender) { return $sender; });
API 文档
您可以在API 参考中找到有关 API 的更多文档。
许可证
此库是开源软件,根据MIT 许可证授权。
部分文档来自官方文档。您可以在Firebase Cloud Messaging网站上找到完整内容。