The Totara Mobile App uses the Firebase app uses Firebase Cloud Messaging (formerly known as Google Cloud Messaging) to deliver push notifications to registered devices.
...
- Message building and targeting, in either the notification console GUI or a trusted environments environment such as Admin SDK.
- The topic or instance is then sent to the FCM backend.
- Next is platform-level message transport, where the notification goes through an Android transport layer, iOS/APNs or web push.
- This is then pushed to SDK on the device.
Configuring Google Service for iOS
...
Go to the Firebase console.
In the center centre of the project overview page, click the iOS icon to launch the setup workflow.
- If you've already added an app to your Firebase project, click Add app to display the platform options.
Enter your app's bundle ID in the iOS bundle ID field .
Make- make sure to enter the bundle ID that your app is actually using. The bundle ID value is case-sensitive, and it cannot be changed for this Firebase iOS app after it's registered with your Firebase project.
Optionally you can enter other app information:; App nickname and App Store ID.
Click Register app.
Downloading and installing the google services plist file
- Click Download GoogleService-Info.plist to obtain the Firebase iOS config file (
GoogleService-Info.plist
). - Replace the sample GoogleService-Info.plist in the iOS folder.
Code Block | ||||
---|---|---|---|---|
| ||||
ios/GoogleService-Info.plist |
...
Go to the Firebase console.
In the center centre of the project overview page, click the Android icon or Add app to launch the setup workflow.
Enter your app's package name in the Android package name field .
Make- make sure to enter the package name that your app is actually using. The package name value is case-sensitive, and it cannot be changed for this Firebase Android app after it's registered with your Firebase project.
Optionally you can enter other app information:; App nickname and Debug signing certificate SHA-1.
Click Register app.
...
Once you have done the configuration part, install and run the app on a device and you will a will see, in the debug logs, a massage that contains a statement "FCM TOKEN RECEIVED message " (if authenticated successfully):.
This means FCM recognises you your app.
Testing a push notification
If you have access to the FCM token, you can perform the simplest a simple test to make sure the communication between FCM and the device is correct:
...
If you receive your test notification, this means FCM is able to send to the device a push notification.
Alternatively, the same test can be done via Postman. You can use this example, just import it into the Postman tool.
- Replace the value of the property "to" with the testing device token
- In the result panel, you will see if FMC was able to deliver the message to the device ("success": 1) or not to deliver the message to the device
If you are trying to send a push notification via a Totara instance, make sure the steps configuring Totara AirNotifier is done and working as expected.
...
- In most cases, a missing configuration step is the root cause for not receiving a push notification message.
- Use a physical device to perform push notification tests. There is no guarantee for delivering of messages on simulators/emulators.
- Avoid sending unnecessary push unnecessary push notifications. If you send too many, Apple Push Notification service the Apple Push Notification service (APNs) will throttle your will throttle your requests.
- The user must be logged into the app to get a valid token.
- If you logout log out on the app, your token will be invalidated.
...
- Verify if notifications permission is allowed on the device:
- Go to the Settings and find for the Totara app.
- Verify if notifications are allowed.
- Make sure you have allowed the Totara app to send you notifications when you first installed it.
- Go to the Settings and find for the Totara app.
If you are extending/customising the Totara Mobile app
...
Verify if the Google service files are the correct ones and if they are at the correct place
...
.
iOS
The configuration (plist) must be at ios/GoogleService-Info.plist. Application IDs defined
...
in the info.plist (xcode project identity settings)
...
and GoogleService-Info.plist must match.
Android
The configuration (json) must be at android/app/google-services.json. Application IDs defined in the app/build.gradle and google-services.json must match.
Also, make sure you are using the correct flavour when generating a release build. Mismatching application IDs will lead to the push notification message not being delivered.
- If the configuration is done properly, you will be able to see the FCM token registering messages .
in the debug logs:- FCM TOKEN RECEIVED: Means the This means the communication between FCM and the device is working properly, and FCM can find your device
- REGISTERING FCM TOKEN: The token is being sent to the Totara instance backend to be linked to the current app user
- TOKEN REGISTERED: The token has been linked to the current app user
- If you are still not able to see the FCM token in the console, you can try a few things:
- Uninstall the app manually
- Close the react console
- Execute the running command to launch a new instance of the app
...
Depending on the device the app is being tested on, you might face issues receiving push notification messages when the app is closed (killed, not in the background). Some manufactures manufacturers might kill the app service to save battery.
...