Notifications channel for Firebase service
avto-dev/firebase-notifications-laravel is a Laravel package for notifications channel for firebase service.
It currently has 1 GitHub stars and 14.674 downloads on Packagist (latest version v2.9.0).
Install it with composer require avto-dev/firebase-notifications-laravel.
Discover more Laravel packages by avto-dev
or browse all Laravel packages to compare alternatives.
Last updated
Here's the latest documentation on Laravel Notifications System: https://laravel.com/docs/master/notifications
This package makes it easy to send notifications using Firebase with Laravel 5.
$ composer require avto-dev/firebase-notifications-laravel "^2.0"
Installed
composeris required (how to install composer).
You need to fix the major version of package.
Laravel 5.5 and above uses Package Auto-Discovery, so doesn't require you to manually register the service-provider. Otherwise you must add the service provider to the providers array in ./config/app.php:
<?php
return [
// ...
'providers' => [
// ...
AvtoDev\FirebaseNotificationsChannel\ServiceProvider::class,
],
];
You need to set up firebase channel in config file ./config/services.php.
To generate a private key file for your service account:
Next select the "driver" file or config contains credintails for Firebase service account in ./config/services.php:
<?php
return [
// ...
/*
|--------------------------------------------------------------------------
| Firebase Settings section
|--------------------------------------------------------------------------
|
| Here you may specify some configs for FCM.
|
*/
'fcm' => [
/*
|----------------------------------------------------------------------
| Firebase service driver
|----------------------------------------------------------------------
|
| Value `file` or `config`:
| - Select `file` option to make service read json file
| - Select `config` option to set up all section in config file
|
*/
'driver' => env('FCM_DRIVER', 'config'),
/*
|---------------------------------------------------------------------
| FCM Drivers
|---------------------------------------------------------------------
|
| Here are each of the firebase.
|
*/
'drivers' => [
'file' => [
'path' => env('FCM_FILE_PATH', base_path('storage/fcm.json')),
],
'config' => [
/*
|------------------------------------------------------------
| Credentials
|------------------------------------------------------------
|
| Content of `firebase.json` file in config. Using if
| `fcm.driver` is `config`. All fields required!
|
*/
'credentials'=>[
'private_key_id' => env('FCM_CREDENTIALS_PRIVATE_KEY_ID', 'da80b3bbceaa554442ad67e6be361a66'),
'private_key' => env('FCM_CREDENTIALS_PRIVATE_KEY', '-----BEGIN PRIVATE KEY-----\n...\n-----END PRIVATE KEY-----\n'),
'client_email' => env('FCM_CREDENTIALS_CLIENT_EMAIL', '[email protected]'),
'client_id' => env('FCM_CREDENTIALS_CLIENT_ID', '22021520333507180281'),
'auth_uri' => env('FCM_CREDENTIALS_AUTH_URI', 'https://accounts.google.com/o/oauth2/auth'),
'token_uri' => env('FCM_CREDENTIALS_TOKEN_URI', 'https://oauth2.googleapis.com/token'),
'auth_provider_x509_cert_url' => env('FCM_CREDENTIALS_AUTH_PROVIDER_CERT', 'https://www.googleapis.com/oauth2/v1/certs'),
'client_x509_cert_url' => env('FCM_CREDENTIALS_CLIENT_CERT', 'https://www.googleapis.com/robot/v1/metadata/x509/firebase-adminsdk-mwax6%40test.iam.gserviceaccount.com'),
],
],
],
],
];
Now you can use the channel in your via() method inside the notification as well as send a push notification:
<?php
use Illuminate\Notifications\Notification;
use AvtoDev\FirebaseNotificationsChannel\FcmChannel;
use AvtoDev\FirebaseNotificationsChannel\FcmMessage;
class AccountApproved extends Notification
{
public function via($notifiable)
{
return [FcmChannel::class];
}
public function toFcm($notifiable, $notification)
{
return (new FcmMessage)
->setTitle('Approved!')
->setBody('Your account was approved!');
}
}
<?php
use Illuminate\Notifications\Notifiable;
use AvtoDev\FirebaseNotificationsChannel\Receivers\FcmDeviceReceiver;
use AvtoDev\FirebaseNotificationsChannel\Receivers\FcmNotificationReceiverInterface;
class SomeNotifible
{
use Notifiable;
/**
* Reveiver of firebase notification.
*
* @return FcmNotificationReceiverInterface
*/
public function routeNotificationForFcm(): FcmNotificationReceiverInterface
{
return new FcmDeviceReceiver('firebase_token');
}
}
This pakage supports all fields from HTTP v1 FCM API. Message class contains setters for all the fields:
Field | Type
:-------: | ----
data | array
title | string
body | string
android | AndroidFcmPlatformSettings
webpush | WebpushFcmPlatformSettings
apns | AppleFcmPlatformSettings
PlatformSettings classes contain platform secific setters
For package testing we use phpunit framework and docker with compose plugin as develop environment. So, just write into your terminal after repository cloning:
$ git clone [email protected]:avto-dev/firebase-notifications-laravel.git ./firebase-notifications-laravel && cd $_
$ make install
$ make test
Changes log can be found here.
If you will find any package errors, please, make an issue in current repository.
If you discover any security related issues, please email [email protected] instead of using the issue tracker.
This is open-sourced software licensed under the MIT License.