Firebase push notifications update DB

As per my experience with Firebase push:

Problem: When sending push notification through "Firebase console", notification is only received when application is in foreground. If the application is killed or in background, the notification is shown only in Version >= lollipop with incorrect notification icon and/or opening the default launcher activity in the app even if you have defined different Activity in PendingIntent.

As per Firebase docs, a push message is divided into 2 pars, they call them: Docs Link here

  1. notification
  2. data payload

enter image description here

Solution:

There are two ways to send a "Push" message.

1. Firebase Console

Console

2. Messaging API - Image showing a request using Advanced REST Client

Curl Request

Push message is received in onMessageReceived(...) method. Firebase onMessageReceived(...) method will not get called if the app is in background or killed only when the message is sent through Firebase Console.

If you send the message via API, it works fine. Message is delivered in onMessageReceived(...) method whether app is in background, foreground or killed. (Caution: This is working fine in >=Lollipop - Behaviour for Android 4.4 or below is still unpredictable.

Update:

You can send a push message from API (firebase call it downstream msg) like this: https://firebase.google.com/docs/cloud-messaging/downstream

Sending downstream messages from the server

To address or "target" a downstream message, the app server sets to with the receiving client app's registration token. You can send notification messages with predefined fields, or custom data messages; see Notifications and data in the message payload for details on payload support. Examples in this page show how to send data messages in HTTP and XMPP protocols.

HTTP POST Request

https://fcm.googleapis.com/fcm/send
Content-Type:application/json
Authorization:key=AIzaSyZ-1u...0GBYzPu7Udno5aA

{ "data": {
    "score": "5x1",
    "time": "15:10"
  },
  "to" : "bk3RNwTe3H0:CI2k_HHwgIpoDKCIZvvDMExUdFQ3P1..."
}

When you application is in the foreground, notifications will be passed to FirebaseMessagingService.onMessageReceived(). When the app is not in the foreground, the notification will be handled by the default notification center.

Also see:

  • How to push firebase notification only when CheckBoxPreference is checked?

  • Open app on firebase notification received (FCM)


In Android , if you want to update someting in the app whether the app is in forground/background/terminated states, then the best way is to remove the notification payload and send only the data payload

{ 
 "to" : "ee8....DYarin",
    "data" : {
         "key" : "value"
    }   
}

In this case onMessageReceived() will get executed. (In some android devices like xiomi you need to enable autostart for you application to process push in terminated states)

In this case, how will you show notification to user ? You can pass title and body as custom tags in the data payload and generate notification programically. So in Android everything goes well without notification payload.


And if you have notification payload in Android then the problems are:

  • If app is in forground everyting goes well, the notification is shown and onMessageReceived() is executed
  • If the app is in background/terminated states, then notification will be displayed on your device but onMessageReceived() will only work if you click on the notification. Users have the tendency to clear them often and our code in onMessageReceived() won't get executed.

Also to enable this click functionality on notification, the notification payload should contain key named click_action:

"notification":{
        "title":"Prime",
        "body" : "test",
         "click_action": "my_click_action_name"
}

And you need to register the action as intent_filter in you activity

 <intent-filter>
                <action android:name="my_click_action_name" />
                <category android:name="android.intent.category.DEFAULT" />
 </intent-filter>

When ever user clicks on notification the onNewIntent() method of the curresponding activity is called and the data payload is available in the curresponding intent.getExtras()