Android FCM
FCM push notifications setup
Below, weโll show you how to send push notifications and/or push messages to your customers, with Firebase Cloud Messaging (FCM) in Intercom.
GCM Push Notifications
If youโd like to use GCM instead, the setup guide can be found here.
Step 1. Enable Google services for your app
If you already have a Firebase project with notifications enabled you can skip to the next step. Otherwise go to the FCM Console page and create a new project following these steps:
Give the project a name and click โCreate Projectโ.
data:image/s3,"s3://crabby-images/3e8bb/3e8bba76953966d381a9abe6c576a70c29ecf59b" alt="FCM step 1.png 1600"
Once your project is set up, scroll down and select โGet startedโ on the โNotificationsโ card.
data:image/s3,"s3://crabby-images/2b50d/2b50df68e65310cc77d36660fe8f2b1a0f74f792" alt="FCM Notifications card 2.png 1600"
Enter your appโs package name and click โAdd Appโ.
data:image/s3,"s3://crabby-images/87d7c/87d7cbef643c0f9a4b60366ab3e480f9a36659f5" alt="FCM add app3.png 1600"
Step 2. Setup client to receive push
Your google-services.json
should automatically download. Youโll need to move that into the same directory as your application level build.gradle
.
data:image/s3,"s3://crabby-images/f72bd/f72bd1b32b035f1d0a3b1e798b04a000329411dc" alt="FCM setup client to receive push.png 1600"
In your apps build.gradle
you will need to add the following lines to your dependencies:
dependencies {
compile 'io.intercom.android:intercom-sdk-fcm:4.+'
compile 'com.google.firebase:firebase-messaging:11.+'
}
At the bottom of your build.gradle
you must add:
apply plugin: 'com.google.gms.google-services'
It is important that this is at the very end of the file.
Step 3. Add your Server key to Intercom for Android settings
Finally, click the settings cog and select โProject settingsโ, then โCloud Messagingโ and copy your Server key.
data:image/s3,"s3://crabby-images/dd879/dd879f05ac93eac9a382414e08633ff634f6e9fc" alt="FCM add server key.png 1600"
Open your Intercom appโs settings and select โIntercom for Androidโ. Then find the โEnable Google Cloud Messagingโ section. Here you'll be able to paste and save your Server API key.
data:image/s3,"s3://crabby-images/79917/799174f780497682af2b617d79c0ca3c37339641" alt="FCM enable push.png 1456"
Step 4. Setting your FCM icon
If you want to add a custom icon for your notifications, just add an image named intercom_push_icon.png
to each of your supported densities. Please note that vector drawables cannot be used here. For example:
/res/drawable-xxhdpi/intercom_push_icon.png
/res/drawable-xhdpi/intercom_push_icon.png
/res/drawable-hdpi/intercom_push_icon.png
/res/drawable-mdpi/intercom_push_icon.png
Notifications icon design guidelines
We recommend following these material design guidelines for producing this icon.
Step 5. Open Intercom conversations from FCM
When a user taps on a push notification we hold onto data such as the URI in your message or the conversation to open. When you want Intercom to act on that data, just call:
Intercom.client().handlePushMessage();
Note
Itโs important to wait for any splash screens or loading screens to finish before calling
handlePushMessage
or your users might not have time to see the conversation we opened.
If you wish to create a custom back stack for this notification you can pass a TaskStackBuilder
to the same method:
handlePushMessage(TaskStackBuilder stackBuilder);
Step 6. Disable push on log out
To stop users from receiving push messages when they have logged out of the app make sure Intercom.client().logout()
is called.
Step 7. Using Intercom with other FCM setups (Optional)
This only applies to applications that also use FCM for their own content, or use a third party service for FCM. Youโll need to update your FirebaseInstanceIdService
and FirebaseMessagingService
.
You should have a class that extends FirebaseInstanceIdService
. That service is where you get the device token to send to your backend to register for push. To register for Intercom push set up your FirebaseInstanceIdService
like this:
private final IntercomPushClient intercomPushClient = new IntercomPushClient();
@Override public void onTokenRefresh() {
String refreshedToken = FirebaseInstanceId.getInstance().getToken();
intercomPushClient.sendTokenToIntercom(getApplication(), refreshedToken);
//DO HOST LOGIC HERE
}
You should have a class that extends FirebaseMessagingService. That service will consume pushes intended for Intercom. To allow us to draw the Intercom push set up your FirebaseMessagingService like this:
private final IntercomPushClient intercomPushClient = new IntercomPushClient();
public void onMessageReceived(RemoteMessage remoteMessage) {
Map message = remoteMessage.getData();
if (intercomPushClient.isIntercomPush(message)) {
intercomPushClient.handlePush(getApplication(), message);
} else {
//DO HOST LOGIC HERE
}
}
Troubleshooting tips
If youโre having trouble getting FCM to work in your app, here's a list of things you should check:
- Make sure to tick the 'Send a push notification' box when you send a manual message.
- Check that the notifications are not disabled for your app on your test device. Settings > Sound & Notification > App notifications. This may differ depending on the Android version.
- Did you specify the correct Push Server API key?
- Make sure you added your
google-services.json
file in the correct directory.
And as always, you can contact us via Intercom. We're always here to help ๐
Updated almost 7 years ago