Contents
Outline
The app developed by React Native is also a normal app, so it can receive a Push message. In this blog post, I will show you how to use FCM(Firebase Cloud Messaging)
via react-native-firebase(V5)
library to receive a Push message on React Native.
- react-native-firebase v5: https://v5.rnfirebase.io/
- FCM(Firebase Cloud Messaging): https://firebase.google.com/docs/cloud-messaging
Install library
Execute the command below to install react-native-firebase library.
npm install --save react-native-firebase
Link library
We need to link react-native-firebase library to use it.
Over 0.60 version
Execute the command below to link react-native-firebase library to React Native project.
cd ios
pod install
cd ..
Under 0.59 version
Execute the command below to link react-native-firebase library to React Native project.
react-native link react-native-firebase
Create Firebase project
Next, we need to create a project on Google Firebase. Click the link below to go to Google Firebase.
- Google Firebase: https://firebase.google.com
data:image/s3,"s3://crabby-images/653fd/653fd55570ec8332d4b57233ba82948809dcc84b" alt="google firebase"
Click the SIGN IN
button on the right top to login.
data:image/s3,"s3://crabby-images/4ff0d/4ff0d766f26bcf10b3ac3cb7dfbd6a2e1f26ffbd" alt="google firebase after login"
After login, click the GO TO CONSOLE
button on the right tope to go to Google Firebase Console.
data:image/s3,"s3://crabby-images/a9db1/a9db18a83fc99b569a9eb4a65321b13ed8953d51" alt="google firebase console"
On Google Firebase Console, click + Add project
to add a new project.
data:image/s3,"s3://crabby-images/ddabe/ddabee50d0bc4859b8b177d4a324564563eeedf3" alt="google firebase console add project"
After inserting the project information, click the Create project
button to create the project.
iOS settings
Let’s see how to configure react-native-firebase for iOS.
Configure iOS project on Firebase
When you click the project on Google Firebase Console, you can see the screen like below.
data:image/s3,"s3://crabby-images/912d6/912d6dc374771f20e42d8c10c7fbc1a2bd3bfaac" alt="google firebase console project"
click the iOS
button on the center to go to iOS configuration.
data:image/s3,"s3://crabby-images/2ed5d/2ed5d38e1ed981b76a7ea2a05c7189f506720dd5" alt="google firebase console project ios"
Insert Bundle ID of the app, and click Register app
button
data:image/s3,"s3://crabby-images/002c0/002c0a2d5a722cc729d23ce5d9d5f8695da6a3aa" alt="GoogleService-Info.plist download"
Download GoogleService-Info.plist
file which is created by Google Firebase, and move it to the same location of info.plist
file. after adding GoogleService-Info.plist
file, click Next
button.
data:image/s3,"s3://crabby-images/cad45/cad4561d1791c07028c7a50ed01cffaad79820fc" alt="add Firebase SDK"
We need to add Google Firebase SDK to React Native project like above.
If you use React Native under 0.59 version, execute the command below.
pod init
To add Google Firebase SDK, modify ./ios/Podfile
file like below.
target 'blaboo' do
...
pod 'Firebase/Core'
pod 'Firebase/Analytics' // if you use Analytics
pod 'Firebase/Messaging'
...
end
Install Google Firebase SDK.
pod install
# pod update
data:image/s3,"s3://crabby-images/ae9d3/ae9d3f995f34ec7bb4c044ae5d6e9875d522bf93" alt="edit appdelegate.m for firebase"
Open AppDelegate.m
file on React Native project, and modify it like below,
...
@import Firebase;
#import "RNFirebaseNotifications.h"
...
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
[FIRApp configure];
[RNFirebaseNotifications configure];
...
return YES;
}
...
To initialize Google Firebase SDK.
data:image/s3,"s3://crabby-images/0ab9a/0ab9a02d9a902d86b8847c008309483f2d5bb343" alt="connect firebase to app"
At this part, I clicked Skip this step
to skip this section.
Configure Permissions
To configure the permissions, open ios/[project name].xcworkspace
file to execute Xcode.
After executing the Xcode, click the project on the left menu, and click the Signing & Capabilities
tab.
data:image/s3,"s3://crabby-images/04d87/04d87943bfe3eee60905e11633f33925f0e0e73e" alt="react native firebase analytics"
click +Capability
on the top. Search and add the permissions below.
- Push Notifications
- Background modes
When you add Background modes, you can see the checkbox list unlike Push Notifications permission. Select Remote notifications
in the list.
APNS setting
We need to configure APNS(Apple Push Notification Service)
to use Push message on iOS.
open Keychain Access
on macOS. And the, click Keychain Access
> Certificate Assistant
> Request a Certificate From a Certificate Authority...
menu.
data:image/s3,"s3://crabby-images/d6e29/d6e290c1180ea1ec61a563e9c0a2a351f51e436a" alt="APNS(Apple Push Notification Service) - request a certificate from a certificate authority"
If the screen blow is shown up, insert User Email Address
and Common Name
, and select Saved to disk
. After it, click Continue
button to go to the next.
data:image/s3,"s3://crabby-images/81641/816415c01bf7efe10625fea4980d1790a72ace58" alt="APNS(Apple Push Notification Service) - request a certificate from a certificate authority insert information"
When you see the screen like below, select the folder which you want to save the file, and click Save
button to save it.
data:image/s3,"s3://crabby-images/aa44b/aa44b37e5c98e171a3fdb05fe219fc15ac279005" alt="APNS(Apple Push Notification Service) - request a certificate from a certificate authority save certification"
Next, go to https://developer.apple.com/ site.
data:image/s3,"s3://crabby-images/0b655/0b65597c94ffd57792d94826ba9d36ea67f83572" alt="APNS(Apple Push Notification Service) - apple developer site"
click the Account
menu on the right top, and login. If you see the screen like below, click Certificates, Identifiers & Profiles
menu.
data:image/s3,"s3://crabby-images/98cac/98cac47f6148ec747a2e300f1ca4036ca3072d7d" alt="APNS(Apple Push Notification Service) - apple developer site Certificates, Identifiers & Profiles"
When you see the screen like below, click Certificates
menu and click +
button on the top.
data:image/s3,"s3://crabby-images/5a0a3/5a0a342da72e90f6ddbccdbd341b9bf685b907c3" alt="APNS(Apple Push Notification Service) - Certificates, Identifiers & Profiles Add Certificates"
Next, when Create a New Certificate
is shown up, scroll it to go down. When you scroll down, you can find Apple Push Notification service SSL (Sandbox & Production)
on Service
section. Select it, and click Continue
button on the right top to go to the next.
data:image/s3,"s3://crabby-images/71ad0/71ad0112891a04ebe63b31f57c2deb08ac1ee2fe" alt="APNS(Apple Push Notification Service) - Certificates, Identifiers & Profiles Apple push notification service"
When you see the screen like below, select the app which you want to implement FCM feature, and click Continue
button to go to the next.
data:image/s3,"s3://crabby-images/03d96/03d9611ce480f447045fa4541a4190d552386db7" alt="APNS(Apple Push Notification Service) - Certificates, Identifiers & Profiles Apple push notification service"
When you see the screen like below, click Choose File
and select the file which you’ve made via Keychain. After selecting, click Continue
button.
data:image/s3,"s3://crabby-images/03d96/03d9611ce480f447045fa4541a4190d552386db7" alt="APNS(Apple Push Notification Service) - Certificates, Identifiers & Profiles Apple push notification service"
If you see the screen like below, you made a certification well. Click Download
button on the right top to download the certification.
data:image/s3,"s3://crabby-images/6dedb/6dedb13df6a82c212017ee3e594d4a2839737104" alt="APNS(Apple Push Notification Service) - Certificates, Identifiers & Profiles Apple push notification service"
We need to transform this certification to .p12
format. Double-click the certification to register it to Keychain.
data:image/s3,"s3://crabby-images/5dbd8/5dbd80ce57b22cd70e1467f4ae6780b182f23c17" alt="APNS(Apple Push Notification Service) - generate .p12"
Right-click the registered certification, select Export "Apple Push Services: package name"...
menu.
data:image/s3,"s3://crabby-images/0cc1e/0cc1eb382b6ca289d64e9a493ccd8115eb818622" alt="APNS(Apple Push Notification Service) - generate .p12 export"
When the screen above is shown up, select Personal Information Exchange (.p12)
on File Format
and click Save
button to save the file.
data:image/s3,"s3://crabby-images/a2739/a2739aa3261767ffb9f77bf2ba7c9252d8e1b563" alt="APNS(Apple Push Notification Service) - generate .p12 insert password"
We need to insert a password to save p12 file like above. Insert the password to save .p12 file.
Next, go to Firebase Console, and click the project which we’ve made above. After it, you can see the iOS
project on the right side.
data:image/s3,"s3://crabby-images/0a815/0a815de1f8c92afbcbae2b838cd5083eb7c4e977" alt="APNS(Apple Push Notification Service) - Firebase Console select ios"
Click the iOS project, and click the configuration icon to go to the iOS project setting screen. Click Cloud Messaging
menu on the iOS setting screen.
data:image/s3,"s3://crabby-images/08555/08555396fe9c0423226fc10a34eaa1d3bedcd76f" alt="APNS(Apple Push Notification Service) - Firebase Console cloud messaging"
You can see the APNs certificates
on iOS app configuration
section on the bottom. Click Upload
button on No development APNs certificate
and No production APNs certificate
.
data:image/s3,"s3://crabby-images/e1f6c/e1f6cbaba51141b7e609be1bab09875db608899c" alt="APNS(Apple Push Notification Service) - Firebase Console upload p12 file"
When this screen is shown up, upload .p12
file, and insert the password which you made .p12
file.
data:image/s3,"s3://crabby-images/b0e68/b0e683fda8ca14afe45d0b0367221ac2ff2a57f3" alt="APNS(Apple Push Notification Service) - Firebase Console finish settings"
We’ve done all configurations for APNS(Apple Push Notification Service).
Android settings
Next, let’s see how to configure Android to use react-native-firebase.
Modify Android package name
Modify
android/app/BUCK
file on React Native project like below.... android_build_config( ... package = "package_name", ) ... android_resource( ... package = "package_name", ... ) ...
Modify
android/app/src/main/AndroidManifest.xml
file on React Native project like below.<manifest xmlns:android="http://schemas.android.com/apk/res/android" package="package_name"> ...
Modify
android/app/src/main/java/com/ProjectName/MainActivity.java
file on React Native project like below.package package_name; ...
Modify
android/app/src/main/java/com/ProjectName/MainApplication.java
file on React Native project like below.package package_name; ...
Modify
android/app/build.gradle
file on React Native project like below.... defaultConfig { applicationId package_name ... } ...
Configure Android project on Firebase
Click Project Overview
on left top of the Google Firebase Console.
data:image/s3,"s3://crabby-images/cadae/cadaec8b190db2888d72276305c942eaf70a3018" alt="Google Firebase Console Project Overview"
Click + Add app
> Android icon
to go to the Android project setting.
data:image/s3,"s3://crabby-images/a2512/a25123bc34c54a1658d8e531079b6793d3330f75" alt="Google Firebase Android app register"
Insert Android Package Name, and click REgister app
button.
data:image/s3,"s3://crabby-images/95c33/95c3352331a7bf5e62d8068220f0a3af893a7c06" alt="Google Firebase google-services.json setting"
Copy google-services.json
file which Google Firebase generates to android/app
folder on React Native project. And then, click Next
button to go to the next.
data:image/s3,"s3://crabby-images/7c210/7c210896ce1ef15c7253c6957a0863211f038488" alt="Google Firebase setting on android"
Open android/build.gradle
file on React Native project and modify it like below.
buildscript {
repositories {
google()
jcenter()
}
dependencies {
classpath("com.android.tools.build:gradle:3.4.2")
classpath 'com.google.gms:google-services:4.3.3'
}
}
...
allprojects {
repositories {
mavenLocal()
google()
jcenter()
...
}
}
As you see above, google()
should be in repositories
and be defined above jcenter()
.
Open android/app/build.gradle
file and modify it like below.
dependencies {
// under 59 version
// implementation project(':react-native-firebase')
...
implementation 'com.google.android.gms:play-services-base:17.2.1'
implementation 'com.google.firebase:firebase-core:17.0.0'
implementation "com.google.firebase:firebase-messaging:20.0.0"
implementation 'me.leolin:ShortcutBadger:1.1.21@aar'
}
And the, add the code below to the bottom of the same file.
...
apply plugin: 'com.google.gms.google-services'
Next, Open ./android/build.gradle
file and modify it like below.
buildscript {
ext {
...
}
repositories {
...
}
dependencies {
classpath("com.android.tools.build:gradle:3.4.2")
classpath 'com.google.gms:google-services:4.3.3'
}
}
- Over 0.60 version
To use react-native-firebase, open android/app/src/main/java/com/[app name]/MainApplication.java
file and modify it like below.
import io.invertase.firebase.RNFirebasePackage;
import io.invertase.firebase.analytics.RNFirebaseAnalyticsPackage;
import io.invertase.firebase.messaging.RNFirebaseMessagingPackage;
import io.invertase.firebase.notifications.RNFirebaseNotificationsPackage;
...
@Override
protected List<ReactPackage> getPackages() {
@SuppressWarnings("UnnecessaryLocalVariable")
List<ReactPackage> packages = new PackageList(this).getPackages();
// Packages that cannot be autolinked yet can be added manually here, for example:
// packages.add(new MyReactNativePackage());
packages.add(new RNFirebaseAnalyticsPackage());
packages.add(new RNFirebaseMessagingPackage());
packages.add(new RNFirebaseNotificationsPackage());
return packages;
}
...
- Under 0.59 version
To use react-native-firebase, open android/app/src/main/java/com/[app name]/MainApplication.java
file and modify it like below.
import io.invertase.firebase.RNFirebasePackage;
import io.invertase.firebase.analytics.RNFirebaseAnalyticsPackage;
import io.invertase.firebase.messaging.RNFirebaseMessagingPackage;
...
@Override
protected List<ReactPackage> getPackages() {
return Arrays.<ReactPackage>asList(
...
new RNFirebasePackage(),
new RNFirebaseAnalyticsPackage(),
new RNFirebaseMessagingPackage()
...
);
}
To receive the Push message, open android/app/src/main/AndroidManifest.xml
file and modify it like below.
<application ...>
...
<service android:name="io.invertase.firebase.messaging.RNFirebaseMessagingService">
<intent-filter>
<action android:name="com.google.firebase.MESSAGING_EVENT" />
</intent-filter>
</service>
<service android:name="io.invertase.firebase.messaging.RNFirebaseBackgroundMessagingService" />
...
</application>
Open the Android project via Android Studio and click Gradle Sync
.
Test
Let’s test FCM to check the configuration well.
Add Javascript source code
To test, we need FCM Token. To get this token, we need to use Javascript. You can use this source code to the production projection.
Create ./src/Components/FCMContainer/index.tsx
file and modify it like below to use FCM.
import React, { useEffect } from 'react';
import { Platform, Alert } from 'react-native';
import firebase from 'react-native-firebase';
import DeviceInfo from 'react-native-device-info';
import AsyncStorage from '@react-native-async-storage/async-storage';
import Axios from 'axios';
import Config from '~/Config';
interface Props {
children: JSX.Element;
onNotificationOpened?: (data: { [key: string]: string }) => any;
}
const FCMContainer = ({ children, onNotificationOpened }: Props): JSX.Element => {
const CHANNEL_ID = 'io.github.dev.yakuza.poma';
const APP_NAME = 'POMA';
const DESCRIPTION = 'POMA channel';
let _onTokenRefreshListener: any = undefined;
let _notificationDisplayedListener: any = undefined;
let _notificationListener: any = undefined;
let _notificationOpenedListener: any = undefined;
const _registerMessageListener = (): void => {
firebase
.notifications()
.getInitialNotification()
.then((notificationOpen) => {
if (
onNotificationOpened &&
typeof onNotificationOpened === 'function' &&
notificationOpen &&
notificationOpen.notification &&
notificationOpen.notification.data &&
notificationOpen.notification.data.notifications_id
) {
onNotificationOpened(notificationOpen.notification.data);
}
});
const channel = new firebase.notifications.Android.Channel(
CHANNEL_ID,
APP_NAME,
firebase.notifications.Android.Importance.Max,
).setDescription(DESCRIPTION);
firebase.notifications().android.createChannel(channel);
_notificationListener = firebase.notifications().onNotification((notification) => {
// Process your notification as required
notification.android.setPriority(firebase.notifications.Android.Priority.Max);
notification.android.setChannelId(CHANNEL_ID);
firebase.notifications().displayNotification(notification);
});
_notificationDisplayedListener = firebase.notifications().onNotificationDisplayed(() => {});
_notificationOpenedListener = firebase
.notifications()
.onNotificationOpened((notificationOpen) => {
if (onNotificationOpened && typeof onNotificationOpened === 'function') {
onNotificationOpened(notificationOpen.notification.data);
}
});
};
const _registerToken = async (fcmToken: string): Promise<void> => {
console.log(fcmToken);
// try {
// const deviceUniqueId = DeviceInfo.getUniqueId();
// const token = await AsyncStorage.getItem('token');
// await Axios.post(
// `URL`,
// {
// token: fcmToken,
// device_unique_id,
// },
// {
// headers: { Authorization: 'Bearer ' + token },
// },
// );
// } catch (error) {
// console.log('ERROR: _registerToken');
// console.log(error.response.data);
// }
};
const _registerTokenRefreshListener = (): void => {
if (_onTokenRefreshListener) {
_onTokenRefreshListener();
_onTokenRefreshListener = undefined;
}
_onTokenRefreshListener = firebase.messaging().onTokenRefresh((fcmToken) => {
// Process your token as required
_registerToken(fcmToken);
});
};
const _updateTokenToServer = async (): Promise<void> => {
try {
const fcmToken = await firebase.messaging().getToken();
_registerMessageListener();
_registerToken(fcmToken);
} catch (error) {
console.log('ERROR: _updateTokenToServer');
console.log(error);
}
};
const _requestPermission = async (): Promise<void> => {
try {
// User has authorized
await firebase.messaging().requestPermission();
await _updateTokenToServer();
} catch (error) {
// User has rejected permissions
Alert.alert("you can't handle push notification");
}
};
const _checkPermission = async (): Promise<void> => {
try {
const enabled = await firebase.messaging().hasPermission();
if (enabled) {
// user has permissions
_updateTokenToServer();
_registerTokenRefreshListener();
} else {
// user doesn't have permission
_requestPermission();
}
} catch (error) {
console.log('ERROR: _checkPermission', error);
console.log(error);
}
};
useEffect(() => {
_checkPermission();
return (): void => {
if (_onTokenRefreshListener) {
_onTokenRefreshListener();
_onTokenRefreshListener = undefined;
}
if (_notificationDisplayedListener) {
_notificationDisplayedListener();
_notificationDisplayedListener = undefined;
}
if (_notificationListener) {
_notificationListener();
_notificationListener = undefined;
}
if (_notificationOpenedListener) {
_notificationOpenedListener();
_notificationOpenedListener = undefined;
}
};
}, []);
if (Platform.OS === 'ios') {
firebase.notifications().setBadge(0);
}
return children;
};
export default FCMContainer;
You should change Channel ID
, App Name
and Description
to fit yours.
const CHANNEL_ID = 'io.github.dev.yakuza.poma';
const APP_NAME = 'POMA';
const DESCRIPTION = 'POMA channel';
Also, For testing, just display FCM token on the log,
const _registerToken = async (fcmToken: string): Promise<void> => {
console.log(fcmToken);
// try {
// const deviceUniqueId = DeviceInfo.getUniqueId();
// const token = await AsyncStorage.getItem('token');
// await Axios.post(
// `URL`,
// {
// token: fcmToken,
// device_unique_id,
// },
// {
// headers: { Authorization: 'Bearer ' + token },
// },
// );
// } catch (error) {
// console.log('ERROR: _registerToken');
// console.log(error.response.data);
// }
};
For production, You should make this part to send FCM Token to the server via API.
To use the source code above, open App.tsx
file and modify it like below.
import React from 'react';
import FCMContainer from '~/Component/FCMContainer';
const App = (): JSX.Element => {
return (
<FCMContainer>
...
</FCMContainer>
);
};
export default App;
iOS test
To test FCM on iOS, we need a device. Connect the device to the PC, and open Xcode
.
data:image/s3,"s3://crabby-images/28422/2842245fb8d3f1ef05730cb4d3715afe4bbbd21a" alt="iOS FCM test - select device"
Select the device on the left tope menu, and click >
button to execute the project.
data:image/s3,"s3://crabby-images/3e3fa/3e3fa0e0005d115d105590afd3263badaef18ff7" alt="iOS FCM test - permission"
After executing the app on the device, you can see the screen like above. Click Allow
button.
data:image/s3,"s3://crabby-images/840a1/840a1c6974eba4ca550e2e8f769981b78dbe10b0" alt="iOS FCM test - get token"
After allowing, you can see the FCM token on the console. copy the Token key.
Next, go to Firebase Console, click Cloud Messaging
on the left menu, and Send your first message
button.
data:image/s3,"s3://crabby-images/5a7bf/5a7bfcb9345e1278ac566246a344eba33fc51ee2" alt="ios FCM test - Firebase console"
When the next screen is shown up, insert a test message to Notification title
and Notification text
. After inserting, click Send test message
.
data:image/s3,"s3://crabby-images/22666/22666ae1df253b0f3b890ae1ed7044ef530869c3" alt="ios FCM test - insert message"
When the screen below is shown up, paste the FCM Token which you copied above on the console to Add an FCM registration token
, and click +
button.
data:image/s3,"s3://crabby-images/bfb8c/bfb8c33e9b567acfcb7d8eba251af74146f27456" alt="ios FCM test - insert token"
Next, click Test
button to send the message.
data:image/s3,"s3://crabby-images/ded62/ded6283187f0240c49789cc58dda9bccfa40dbca" alt="ios FCM test - send message"
And then, you can see the screen like below that the app received the message well.
data:image/s3,"s3://crabby-images/74f78/74f78cb9f2d32229106d63ffcb4f2606df4fa51e" alt="ios FCM test - receive message"
Android test
Execute the command below to test FCM on Android.
npm run android
After executing, you can see the FCM Token on the console. copy the key.
data:image/s3,"s3://crabby-images/288f5/288f54ff4a307bc19691ffdeed361b7baa3e4b2b" alt="Android FCM test - FCM token"
Next, go to Firebase Console, and click Cloud Messaging
menu on the left, and click Send your first message
button.
data:image/s3,"s3://crabby-images/5a7bf/5a7bfcb9345e1278ac566246a344eba33fc51ee2" alt="Android FCM test - Firebase console"
When the next screen is show up, insert a test message to Notification title
and Notification text
. After it, click Send test message
button on the right side.
data:image/s3,"s3://crabby-images/22666/22666ae1df253b0f3b890ae1ed7044ef530869c3" alt="Android FCM test - insert message"
When the screen blow is shown up, paste FCM token which you copied above to Add an FCM registration token
, and click +
button.
data:image/s3,"s3://crabby-images/bfb8c/bfb8c33e9b567acfcb7d8eba251af74146f27456" alt="Android FCM test - insert token"
And then, click Test
button to send the test message.
data:image/s3,"s3://crabby-images/ded62/ded6283187f0240c49789cc58dda9bccfa40dbca" alt="Android FCM test - send message"
And then, you can see the screen like below that the app received the message well.
data:image/s3,"s3://crabby-images/1c6f7/1c6f7a0b44f7c7326d2c4170c369e42aaef0b0ec" alt="Android FCM test - receive message"
Completed
We’ve seen how to receive FCM message on React Native project by react-native-firebase library. You can implement the Push notification by saving the FCM token on the server, and send a message with the Token!
Was my blog helpful? Please leave a comment at the bottom. it will be a great help to me!
App promotion
Deku
.Deku
created the applications with Flutter.If you have interested, please try to download them for free.