autoxloo/fcm
最新稳定版本:1.0.0
Composer 安装命令:
composer require autoxloo/fcm
包简介
Sends push notification via Firebase Cloud Messaging Server
README 文档
README
Sends push notification via Firebase Cloud Messaging Server
Note: This package is not supported properly
Installation
The preferred way to install this extension is through composer.
Either run
php composer.phar require --prefer-dist autoxloo/fcm "*"
or
composer require --prefer-dist autoxloo/fcm "*"
or add
"autoxloo/fcm": "*"
to the require section of your composer.json file.
Usage
To send push notification you should have private key file for your service account.
To generate a private key file for your service account:
- In the Firebase console, open Settings > Service Accounts.
- Click Generate New Private Key, and confirm by clicking Generate Key.
$projectId = 'autoxloo'; // id of your project created in firebase console $serviceAccountFilePath = __DIR__ . '/service_account.json'; // path to your generated private key file for your service account
Sending push notification:
$fcm = new FirebaseCloudMessaging($projectId, $serviceAccountFilePath); $response = $fcm->send($message); // $message is instance of \autoxloo\fcm\message\Message // $response is instance of \GuzzleHttp\Psr7\Response
Complete example:
// initial data: $projectId = 'autoxloo'; $serviceAccountFile = __DIR__ . '/service_account.json'; $token = 'some device token'; $name = 'Some name'; $title = 'Some title'; $body = 'Some body'; $data = [ 'some key1' => 'some value1', 'some key2' => 'some value2', ]; // sending push notification: $target = FCMFacade::createTargetToken($token); // only target is required $notification = FCMFacade::createNotification($title, $body); $androidConfig = FCMFacade::createAndroidConfig([AndroidConfig::FIELD_PRIORITY => AndroidConfig::PRIORITY_HIGH]); $message = FCMFacade::createMessage(); $message->setTarget($target) ->setName($name) ->setData($data) ->setNotification($notification) ->setAndroidConfig($androidConfig); $fcm = new FirebaseCloudMessaging($projectId, $serviceAccountFile); $response = $fcm->send($message); // $response is instance of \GuzzleHttp\Psr7\Response
Or
$messageConfig = [ // required one of: token, topic or condition Message::FIELD_TOKEN => $token, // or Message::FIELD_TOPIC => $topic or Message::FIELD_CONDITION => $condition // not required values: Message::FIELD_NAME => $name, Message::FIELD_DATA => $data, Message::FIELD_NOTIFICATION => FCMFacade::createNotification($title, $body), Message::FIELD_ANDROID => FCMFacade::createAndroidConfig([ AndroidConfig::FIELD_PRIORITY => AndroidConfig::PRIORITY_HIGH ]), ]; $message = FCMFacade::createMessage($messageConfig); $fcm = new FirebaseCloudMessaging($projectId, $serviceAccountFile); $response = $fcm->send($message); // $response is instance of \GuzzleHttp\Psr7\Response
Target
You can use target one of:
TargetTokenTargetTopicTargetCondition
To create use facade:
$targetToken = FCMFacade::createTargetToken('some token'); $targetTopic = FCMFacade::createTargetTopic('some topic'); $targetCondition = FCMFacade::createTargetCondition('some condition');
See Firebase Build App Server Send Requests for more details.
Note: TargetCondition and TargetTopic was not tested properly.
统计信息
- 总下载量: 6.58k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 1
- 依赖项目数: 1
- 推荐数: 0
其他信息
- 授权协议: BSD-3-Clause
- 更新时间: 2018-09-06