Ishara Rathnayake
Ishara Rathnayake

Reputation: 41

onMessageReceived method in FirebaseMessagingService is not called

I'm sending notification using a firebase cloud function. When I'm sending the payload with notification key, notification sends but method not invoked. But with data key, nothing happened.

Here is my code for FirebaseMessagingService

    @Override
    public void onMessageReceived(RemoteMessage remoteMessage) {


        Log.d(TAG, "From: " + remoteMessage.getFrom());

        // Check if message contains a data payload.
        if (remoteMessage.getData().size() > 0) {
            Log.d(TAG, "Message data payload: " + remoteMessage.getData());

            sendNotification(remoteMessage.getData().get("title"), remoteMessage.getData().get("body"));


            if (/* Check if data needs to be processed by long running job */ true) {
                // For long-running tasks (10 seconds or more) use Firebase Job Dispatcher.
                scheduleJob();
            } else {
                // Handle message within 10 seconds
                handleNow();
            }

        }

        // Check if message contains a notification payload.
        if (remoteMessage.getNotification() != null) {
            Log.d(TAG, "Message Notification Body: " + remoteMessage.getNotification().getBody());
            sendNotification(remoteMessage.getNotification().getTitle(), remoteMessage.getNotification().getBody());
        }

    }

    private void sendNotification(String title, String messageBody){

        String channelId = getString(R.string.default_notification_channel_id);

        Intent intent = new Intent(this, MainActivity.class);
        intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
        PendingIntent pendingIntent = PendingIntent.getActivity(this, 0, intent,
                PendingIntent.FLAG_ONE_SHOT);

        Uri defaultSoundUri = RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION);
        NotificationCompat.Builder notificationBuilder =
                new NotificationCompat.Builder(this, channelId)
                        .setSmallIcon(R.drawable.ic_logo)
                        .setContentTitle(title)
                        .setContentText(messageBody)
                        .setAutoCancel(true)
                        .setSound(defaultSoundUri)
                        .setContentIntent(pendingIntent);

        NotificationManager notificationManager =
                (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);

        // Since android Oreo notification channel is needed.
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
            NotificationChannel channel = new NotificationChannel(channelId,
                    "Channel human readable title",
                    NotificationManager.IMPORTANCE_DEFAULT);
            notificationManager.createNotificationChannel(channel);
        }

        notificationManager.notify(0 , notificationBuilder.build());

    }

Here is my firebase cloud function

exports.sendNotification = functions.database
  .ref("/deals/{userId}/{dealId}")
  .onCreate((data, context) => {
    const dataValue = data.val();

    const topic = context.params.userId;

    const payload = {
      data: {
        title: "New deal created",
        body: dataValue.user.name + " added a new deal."
      },
      topic: topic
    };

    // Send a message to devices subscribed to the provided topic.
    return admin
      .messaging()
      .send(payload)
      .then(response => {
        // Response is a message ID string.
        console.log("Successfully sent message:", response);
      })
      .catch(error => {
        console.log("Error sending message:", error);
      });
  });

Also I set up a debugpoint on onMessageReceived() but it did not get fired up.

Upvotes: 0

Views: 544

Answers (2)

Humxa Moghal
Humxa Moghal

Reputation: 132

When your app is in background , firebase will not trigger OnMessageReceived instead it will show a notification alert

+

make sure you have subscribed the correct topic

+

make sure play services are updated on your device.

Upvotes: 0

Ishara Rathnayake
Ishara Rathnayake

Reputation: 41

I figured out the problem. The issue is after doing some changes and building the android project we need to subscribe to topic again.

Upvotes: 1

Related Questions