Skip to content

A Bundle for Symfony2 projects to send notifications in mobile devices through Firebase Cloud Messaging API

License

Notifications You must be signed in to change notification settings

KarimMesallam/FCMBundle

 
 

Repository files navigation

Installation

Step 1: Download the Bundle

Execute the following command to download the latest stable version of this bundle:

$ composer require KarimMesallam/fcm-bundle

This command requires you to have Composer installed globally, as explained in the installation chapter of the Composer documentation.

Step 2: Enable the Bundle

Then, enable the bundle by adding it to the list of registered bundles in the app/AppKernel.php file of your project:

<?php
// app/AppKernel.php

// ...
class AppKernel extends Kernel
{
    public function registerBundles()
    {
        $bundles = array(
            // ...

            new RedjanYm\FCMBundle\RedjanYmFCMBundle(),
        );

        // ...
    }

    // ...
}

Step 3: Configuration

On your app/config.yml file add this configuration and insert your Firebase API Key that you can generate in the Firebase Console.

redjan_ym_fcm:
    firebase_api_key: sdadasdasdasdasd245sadas5d4a8sd2d5as4d8s

Step 4: Usage

  • Get the FCM client from the container.
$fcmClient = $this->getContainer()->get('redjan_ym_fcm.client');
  • Create a Notification. For now FCMBundle supports only Device Notifications. Topic Notifications will be added in the future versions.
$notification = $fcmClient->createDeviceNotification(
        'Title of Notification', 
        'Body of Notification', 
        'Firebase Token of the device who will recive the notification'
    );

In case you need to send extra data or set other notification properties the Notification Entity supports a set of setters and getters like:

    $notification->setData($array); and $notification->getData();
    
    $notification->setPriority('high'); // Excepts 2 priorities, high(default) and low
    
    $notification->setIcon('name of icon located in the native mobile app');

You could also modify the arguments passed in the createDeviceNotification method.

    $notifiaction->setTitle('string');
    $notifiaction->setBody('text');
    $notifiaction->setDeviceToken('string');

The only required field is the Device Token

  • Send notification
$fcmClient->sendNotification($notification);

The request of sending the notification is a HTTP Synchronous Request.

The Asynchronous requests will be implemented in the next version!


This Bundle is a wrapper for this Firebase Cloud Messaging php library


License FCMBundle is licensed under the MIT license

About

A Bundle for Symfony2 projects to send notifications in mobile devices through Firebase Cloud Messaging API

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • PHP 100.0%