How-tos
Implement Push Notifications in Your React Native App Using IBM Cloud Push Notifications Service
March 1, 2019 | Written by: Josephine Justin and Anantha Krishnan K G
Share this post:
Integrate IBM Cloud Push Notifications Service with a React Native app using React Native SDKs
React Native is an open source framework for easy cross-platform, which helps in building the apps using Javascript. This blog post describes the steps to be followed to integrate IBM Cloud Push Notifications Service with a React Native app using its React Native SDKs (available here).
About the app
This blog helps you build a React Native app that shows all the repositories of a GitHub Organization. It also sends a push notification when an issue or a pull request is created/updated/closed. IBM Cloud Functions actions trigger the push notifications. The complete app is available here.
Push Notifications Service
Create and configure a Push Notifications Service instance from the IBM Cloud catalog. You can refer to this tutorial to create and configure the instance.
IBM Cloud Functions
IBM Cloud Functions are used to create GitHub actions and triggers. Please refer to the IBM Cloud Functions doc for details.
Create an action to get all repositories
Refer to getReposAction.js to create a Node.js action. Create the action using IBM Cloud Functions.
let orgName = "Gypsyan";
defines the organization of the GitHub. Modify this to be the same name as your GitHub org.
This action retrieves all the repositories of the GitHub org and returns the details of the repositories:

Create an action to listen for Github web-hooks
Create a Node.js action with the code given in ReactNativeAction.js. Make sure to update the apikey
, appId
, and apiHost
. Update the values of these attributes as per the Push Notifications Service instance created in the first step. This action uses the openwhisk package, which is a wrapper around the Apache OpenWhisk APIs.
This action tracks the GitHub activity. Based on the activity, a push notification payload is created that triggers a notification.

Create a Cloud Functions trigger
Create a trigger and add the ReactNativeAction in the actions field.

Add the GitHub webhook
Open the GitHub repository settings and add a webhook with IBM Cloud Functions trigger. Select Issues and Pull Request.
GitHub will invoke the IBM Cloud Functions trigger once any issues or pull request event happens in the GitHub org repositories.

Configure the client app
Go to the App.js and add push credentials and Cloud Functions credentials.
Configure the client app—iOS and Android—using the bmd-push-react-native SDK documentation.
Run the app
Run your app using react-native run-ios
or react-native run-android
commands.
Register the device for Push Notifications
Click on the bell icon to register the device for push notifications.
Trigger notifications
To test the app, create an issue or pull request in any repository of your GitHub organization.

Architect, IBM Mobile Cloud Platform Development

Software Engineer
IBM Cloud App ID: Updated Runtime APIs Provide Tighter Interoperability for Your Cloud-Native Apps
As part of our efforts to tighten interoperability and broaden the frameworks that are able to use IBM Cloud App ID, we've updated the runtime APIs.
IBM Cloud Mobile Foundation: Top-10 Features to Boost Your App Rating
The Mobile Foundation service offers many hidden gems that developers often gloss over. In this post, we highlight the top 10 features that increase user engagement as well as improve app ratings.
Distribute CoreML Models Securely Using Mobile Foundation Service
IBM Mobile Foundation is excited to introduce a feature to manage the distribution of CoreML models.