These pages cover version 2 of our SDK, but a newer version is available. In general, we suggest that you update to the latest version to take advantage of new features and fixes.
Our React Native SDK supports push notifications over APN or FCM—including rich push messages with links and images. Use this page to add support for your push provider and set your app up to receive push notifications.
This page is part of a setup flow for the SDK. Before you continue, make sure you've implemented previous features—i.e. you can't receive push notifications before you identify people!
Under the hood, our React Native SDK takes advantage of our native Android and iOS SDKs. This helps us keep the React Native SDK up to date. But, for now, it also means you’ll need to add a bit of code to support your iOS users. For Android, you’re ready to go if you followed our getting started instructions.
Before a device can receive a push notification, you must:
While push providers support a number of features in their payloads, our React Native package only supports deep links and images right now. If you want to include action buttons or other rich push features, you need to add your own custom code. When writing your own custom code, we recommend that you use our SDK as it is much easier to extend than writing your own code from scratch.
If you followed our Getting Started instructions, you’re already set up to send standard push notifications to Android devices.
Set up push on iOS
You’ll need to add some additional code to support push notifications for iOS. You’ll need to add push capabilities in XCode and integrate push capabilities in your app.
Add push capabilities in Xcode
Before you can work with push notifications, you need to add Push Notification capabilities to your project in XCode.
In your React Native project, go to the ios subfolder and open <yourAppName>.xcworkspace.
Select your project, and then under Targets, select your main app.
Click the Signing & Capabilities tab
Click Capability.
Add Push Notifications to your app. When you’re done, you’ll see Push Notifications added to your app’s capabilities, but there are still a few more steps to finish setting things up.
Go to File > New > Target.
Select Notification Service Extension and click Next.
Enter a product name, like NotificationServiceExtension (which we use in our examples on this page), and click Finish.
When presented with the dialog below, click Cancel. This will help Xcode continue debugging your app and not just the extension you just added.
Now you have another target in your project navigator named NotificationServiceExtension. We’ll configure this extension when we Integrate Push Notifications in the following section.
Integrate push capabilities in your app
Pick your push provider (APN or FCM) and the language your native files are written in to get started (Objective C or Swift).
APN/Objective-C
Open the file ios/Podfile and make the following modifications:
pod'CustomerIO/MessagingPushAPN','~> 2.14.2'
Want to automatically get the latest versions?
The example above includes the full version number. If you remove the patch and/or minor version numbers, you’ll always get the latest minor release when you run pod update --repo-update --project-directory=ios. See Updating iOS Dependencies for information about updating your Podfile.
Outside your main target, add the following line to the Podfile.
pod'CustomerIO/MessagingPushAPN','~> 2.14.2'
Open your terminal, go to your project path and run pod install --project-directory=ios. When dependencies finish installing, you should see a message like this:
Pod installation complete! There are X dependencies from the Podfile and Y total pods installed.
Open ios/<YourAppName>.xcworkspace in Xcode, and add a new Swift file to your project. In our examples, we’ve named this file MyAppPushNotificationsHandler.swift but you should use a name that makes sense to you.
Replace the file contents with the code below. We’re calling our class MyAppPushNotificationsHandler, but you might want to rename it to fit your app.
importFoundationimportCioMessagingPushAPNimportUserNotificationsimportCioTracking@objcpublicclassMyAppPushNotificationsHandler:NSObject{publicoverrideinit(){}@objc(setupCustomerIOClickHandling:)publicfuncsetupCustomerIOClickHandling(withNotificationDelegatenotificationDelegate:UNUserNotificationCenterDelegate){// This line of code is required in order for the Customer.io SDK to handle push notification click events. // We are working on removing this requirement in a future release.// Remember to modify the siteId and apiKey with your own values.// let siteId = "YOUR SITE ID HERE"// let apiKey = "YOUR API KEY HERE"CustomerIO.initialize(siteId:siteId,apiKey:apiKey,region:Region.US){configinconfig.autoTrackDeviceAttributes=true}letcenter=UNUserNotificationCenter.current()center.delegate=notificationDelegate}@objc(application:deviceToken:)publicfuncapplication(_application:UIApplication,didRegisterForRemoteNotificationsWithDeviceTokendeviceToken:Data){MessagingPush.shared.application(application,didRegisterForRemoteNotificationsWithDeviceToken:deviceToken)}@objc(application:error:)publicfuncapplication(_application:UIApplication,didFailToRegisterForRemoteNotificationsWithErrorerror:Error){MessagingPush.shared.application(application,didFailToRegisterForRemoteNotificationsWithError:error)}@objc(userNotificationCenter:didReceiveNotificationResponse:withCompletionHandler:)publicfuncuserNotificationCenter(_center:UNUserNotificationCenter,didReceiveresponse:UNNotificationResponse,withCompletionHandlercompletionHandler:@escaping()->Void){lethandled=MessagingPush.shared.userNotificationCenter(center,didReceive:response,withCompletionHandler:completionHandler)// If the Customer.io SDK does not handle the push, it's up to you to handle it and call the// completion handler. If the SDK did handle it, it called the completion handler for you.if!handled{completionHandler()}}}
Open AppDelegate.h and add the following import statements and the UNUserNotificationCenterDelegate delegate.
Open AppDelegate.m and import your project’s Objective-C header file.
#import <MyAppProject-Swift.h>
Inside AppDelegate’s implementation, create an object of MyAppPushNotificationsHandler (remember to substitute the name of your handler).
@implementationAppDelegate// Create Object of class MyAppPushNotificationsHandler
MyAppPushNotificationsHandler*pnHandlerObj=[[MyAppPushNotificationsHandleralloc]init];...
If you get a compile-time error…
See our troubleshooting section if you receive a message that reads Error: Initializer element is not a compile-time constant.
Update AppDelegate.m to register a device to the current app user and handle push notifications. See comments in the sample below to understand what the code does!
-(BOOL)application:(UIApplication*)applicationdidFinishLaunchingWithOptions:(NSDictionary*)launchOptions{...[pnHandlerObjsetupCustomerIOClickHandling:self];returnYES;}-(void)application:(UIApplication*)applicationdidRegisterForRemoteNotificationsWithDeviceToken:(NSData*)deviceToken{// Register device to receive push notifications with device token
[pnHandlerObjapplication:applicationdeviceToken:deviceToken];}-(void)application:(UIApplication*)applicationdidFailToRegisterForRemoteNotificationsWithError:(NSError*)error{[pnHandlerObjapplication:applicationerror:error];}// Send push notification click events to the Customer.IO SDK for processing
-(void)userNotificationCenter:(UNUserNotificationCenter*)centerdidReceiveNotificationResponse:(UNNotificationResponse*)responsewithCompletionHandler:(void(^)(void))completionHandler{[pnHandlerObjuserNotificationCenter:centerdidReceiveNotificationResponse:responsewithCompletionHandler:completionHandler];}// (Optional) Add the following code to show your push notifications even when your app is in the foreground.
-(void)userNotificationCenter:(UNUserNotificationCenter*)centerwillPresentNotification:(UNNotification*)notificationwithCompletionHandler:(void(^)(UNNotificationPresentationOptionsoptions))completionHandler{completionHandler(UNNotificationPresentationOptionAlert+UNNotificationPresentationOptionSound);}
Is your app using other SDKs that work with push notifications?
The code snippet above configures the Customer.io SDK to process all push notifications when they are clicked. If your app is using other SDKs that work with push notifications (such as expo-notifications, react-native-push-notification, or rnfirebase), you will need to follow these instructions to ensure that all SDKs work together.
In XCode, select your NotificationServiceExtension. Go to File > New > File > Swift File and click Next.
Enter a file name, like MyAppNotificationServicePushHandler, and click Create. This adds a new swift file in your extension target.
Copy the content from the snippet below and replace the code in your MyAppNotificationServicePushHandler.swift file. You might change the name of the class to fit your project. Refer the comments in the snippet below for more information.
This code is based on our iOS 2.x SDK!
If you’ve integrated based on an earlier version (your podfile targets a MessagingPushAPN version before 2.0), CustomerIO.initialize does not support the config object. It’s simply:
CustomerIO.initialize(siteId: "YourSiteID", apiKey: "YourAPIKey", region: .US)
importFoundationimportUserNotificationsimportCioMessagingPushAPNimportCioTracking@objcpublicclassMyAppNotificationServicePushHandler:NSObject{publicoverrideinit(){}@objc(didReceive:withContentHandler:)publicfuncdidReceive(_request:UNNotificationRequest,withContentHandlercontentHandler:@escaping(UNNotificationContent)->Void){// You can configure the SDK here// Update region to .EU for your EU-based workspace CustomerIO.initialize(siteId:"YourSiteID",apiKey:"YourAPIKey",region:.US){configinconfig.autoTrackDeviceAttributes=trueconfig.logLevel=.info}MessagingPush.shared.didReceive(request,withContentHandler:contentHandler)}@objc(serviceExtensionTimeWillExpire)publicfuncserviceExtensionTimeWillExpire(){MessagingPush.shared.serviceExtensionTimeWillExpire()}}
In your NotificationService.m file, import the auto-generated header file—e.g. YourTargetName-Swift.h.
#import<NotificationServiceExtension-Swift.h>
Create an object of class MyAppNotificationServicePushHandler in your NotificationServiceExtension implementation and call the functions below.
#import"NotificationService.h"#import<NotificationServiceExtension-Swift.h>@interfaceNotificationService()@property(nonatomic,strong)void(^contentHandler)(UNNotificationContent*contentToDeliver);@property(nonatomic,strong)UNMutableNotificationContent*bestAttemptContent;@end@implementationNotificationServiceExtension// Create object of class MyAppNotificationServicePushHandlerMyAppNotificationServicePushHandler*nsHandlerObj=nil;// Initialize the object+(void)initialize{nsHandlerObj=[[MyAppNotificationServicePushHandleralloc]init];}-(void)didReceiveNotificationRequest:(UNNotificationRequest*)requestwithContentHandler:(void(^)(UNNotificationContent*_Nonnull))contentHandler{[nsHandlerObjdidReceive:requestwithContentHandler:contentHandler];}-(void)serviceExtensionTimeWillExpire{[nsHandlerObjserviceExtensionTimeWillExpire];}@end
Now you can run your app on a physical device and send yourself a push notification with images and deep links to test your implementation. You’ll have to use a physical device because simulators can’t receive push notifications.
APN/Swift
Open the file ios/Podfile and make the following modifications:
pod'CustomerIO/MessagingPushAPN','~> 2.14.2'
Want to automatically get the latest versions?
The example above includes the full version number. If you remove the patch and/or minor version numbers, you’ll always get the latest minor release when you run pod update --repo-update --project-directory=ios. See Updating iOS Dependencies for information about updating your Podfile.
Open your terminal, go to your project path and run pod install --project-directory=ios. When dependencies finish installing, you should see a message like this:
Pod installation complete! There are X dependencies from the Podfile and Y total pods installed.
In your iOS subfolder, open AppDelegate.swift and add a line inside the application function. We have an example in our sample app. This is a workaround for an issue preventing iOS devices from being added to the Podfile after being identified.
funcapplication(_application:UIApplication,didFinishLaunchingWithOptionslaunchOptions:[UIApplication.LaunchOptionsKey:Any]?)->Bool{// Important to call this code *before* you call registerForPushNotifications.CustomerIO.initialize(siteId:"YOUR SITE ID",apiKey:"YOUR API KEY",region:Region.US,configure:nil)
Add the following code to your app.
This sample includes a work-around
For now, it’s important that you call CustomerIO.initialize before registerForPushNotifications. This fixes an issue in which the SDK identifies the podfile, but doesn’t add a device to the podfile—preventing the user from receiving notifications.
importCioTrackingimportCioMessagingPushAPNclassAppDelegate:NSObject,UIApplicationDelegate{funcapplication(_application:UIApplication,didFinishLaunchingWithOptionslaunchOptions:[UIApplication.LaunchOptionsKey:Any]?=nil)->Bool{// This fixes an issue in which the React Native SDK identifies// a profile, but an iOS device isn't added to the profile.// Important to call this code before calling `registerForRemoteNotifications`. CustomerIO.initialize(siteId:"YOUR SITE ID",apiKey:"YOUR API KEY",region:Region.US,configure:nil)// It's a good practice to register for remote push when the app starts.// This asserts that the Customer.io SDK always has a valid device token.UIApplication.shared.registerForRemoteNotifications()returntrue}}// PUSH NOTIFICATIONSfuncapplication(_application:UIApplication,didRegisterForRemoteNotificationsWithDeviceTokendeviceToken:Data){MessagingPush.shared.application(application,didRegisterForRemoteNotificationsWithDeviceToken:deviceToken)}funcapplication(_application:UIApplication,didFailToRegisterForRemoteNotificationsWithErrorerror:Error){MessagingPush.shared.application(application,didFailToRegisterForRemoteNotificationsWithError:error)}
Add a notification service extension to call the appropriate Customer.io functions. This lets your app display rich push notifications, including images, etc. However, if you want to enable deep links, you should continue to the Deep links section below.
This code is based on our iOS 2.x SDK!
If you’ve integrated based on an earlier version (your podfile targets a MessagingPushAPN version before 2.0), CustomerIO.initialize does not support the config object. It’s simply:
CustomerIO.initialize(siteId: "YourSiteID", apiKey: "YourAPIKey", region: .US)
importUserNotificationsimportCioMessagingPushAPNimportCioTrackingclassNotificationService:UNNotificationServiceExtension{overridefuncdidReceive(_request:UNNotificationRequest,withContentHandlercontentHandler:@escaping(UNNotificationContent)->Void){// You can configure the SDK here// Update region to .EU for your EU-based workspace CustomerIO.initialize(siteId:"YourSiteID",apiKey:"YourAPIKey",region:.US){configinconfig.autoTrackDeviceAttributes=trueconfig.logLevel=.info}MessagingPush.shared.didReceive(request,withContentHandler:contentHandler)}overridefuncserviceExtensionTimeWillExpire(){MessagingPush.shared.serviceExtensionTimeWillExpire()}}
FCM/Objective-C
Open the file ios/Podfile and make the following modifications:
# You may need to add this line, as required by FCM, to your Podfile if you encounter errors during 'pod install'use_frameworks!:linkage=>:statictarget'NotificationServiceExtension'dopod'CustomerIO/MessagingPushFCM','~> 2.14.2'end
Open your terminal, go to your project path and run pod install --project-directory=ios. When dependencies finish installing, you should see a message like this:
Pod installation complete! There are X dependencies from the Podfile and Y total pods installed.
Open ios/<YourAppName>.xcworkspace in Xcode, and add a new Swift file to your project. In our examples, we’ve named this file MyAppPushNotificationsHandler.swift but you should use a name that makes sense to you.
Replace the file contents with the code below. We’re calling our class MyAppPushNotificationsHandler, but you might want to rename it to fit your app.
importFoundationimportCioMessagingPushFCMimportUserNotificationsimportFirebaseMessagingimportCioTracking@objcpublicclassMyAppPushNotificationsHandler:NSObject{publicoverrideinit(){}@objc(setupCustomerIOClickHandling:)publicfuncsetupCustomerIOClickHandling(withNotificationDelegatenotificationDelegate:UNUserNotificationCenterDelegate){// This line of code is required in order for the Customer.io SDK to handle push notification click events. // We are working on removing this requirement in a future release.// Remember to modify the siteId and apiKey with your own values. // let siteId = "YOUR SITE ID HERE"// let apiKey = "YOUR API KEY HERE"CustomerIO.initialize(siteId:siteId,apiKey:apiKey,region:Region.US){configinconfig.autoTrackDeviceAttributes=true}letcenter=UNUserNotificationCenter.current()center.delegate=notificationDelegate}// Register device on receiving a device token (FCM)@objc(didReceiveRegistrationToken:fcmToken:)publicfuncdidReceiveRegistrationToken(_messaging:Messaging,didReceiveRegistrationTokenfcmToken:String?){MessagingPush.shared.messaging(messaging,didReceiveRegistrationToken:fcmToken)}@objc(userNotificationCenter:didReceiveNotificationResponse:withCompletionHandler:)publicfuncuserNotificationCenter(_center:UNUserNotificationCenter,didReceiveresponse:UNNotificationResponse,withCompletionHandlercompletionHandler:@escaping()->Void){lethandled=MessagingPush.shared.userNotificationCenter(center,didReceive:response,withCompletionHandler:completionHandler)// If the Customer.io SDK does not handle the push, it's up to you to handle it and call the// completion handler. If the SDK did handle it, it called the completion handler for you.if!handled{completionHandler()}}}
Open AppDelegate.h and add the following import statements, the UNUserNotificationCenterDelegate delegate, and the FIRMessagingDelegate delegate.
Inside AppDelegate’s implementation, create an object of MyAppPushNotificationsHandler (remember to substitute the name of your handler).
@implementationAppDelegate// Create Object of class MyAppPushNotificationsHandler
MyAppPushNotificationsHandler*pnHandlerObj=[[MyAppPushNotificationsHandleralloc]init];...
If you get a compile-time error…
See our troubleshooting section if you receive a message that reads Error: Initializer element is not a compile-time constant.
Make the following updates to your AppDelegate.m file. See comments in the sample below to understand what the code does!
-(BOOL)application:(UIApplication*)applicationdidFinishLaunchingWithOptions:(NSDictionary*)launchOptions{// Configure Firebase
[FIRAppconfigure];// Set FCM messaging delegate
[FIRMessagingmessaging].delegate=self;...[pnHandlerObjsetupCustomerIOClickHandling:self];returnYES;}-(void)messaging:(FIRMessaging*)messagingdidReceiveRegistrationToken:(NSString*)fcmToken{[pnHandlerObjdidReceiveRegistrationToken:messagingfcmToken:fcmToken];}// Send push notification click events to the Customer.IO SDK for processing
-(void)userNotificationCenter:(UNUserNotificationCenter*)centerdidReceiveNotificationResponse:(UNNotificationResponse*)responsewithCompletionHandler:(void(^)(void))completionHandler{[pnHandlerObjuserNotificationCenter:centerdidReceiveNotificationResponse:responsewithCompletionHandler:completionHandler];}// (Optional) Add the following code to show your push notifications even when your app is in the foreground.
-(void)userNotificationCenter:(UNUserNotificationCenter*)centerwillPresentNotification:(UNNotification*)notificationwithCompletionHandler:(void(^)(UNNotificationPresentationOptionsoptions))completionHandler{completionHandler(UNNotificationPresentationOptionAlert+UNNotificationPresentationOptionSound);}
Is your app using other SDKs that work with push notifications?
The code snippet above configures the Customer.io SDK to process all push notifications when they are clicked. If your app is using other SDKs that work with push notifications (such as expo-notifications, react-native-push-notification, or rnfirebase), you will need to follow these instructions to ensure that all SDKs work together.
In XCode, select your NotificationServiceExtension.
Select File > New > File > Swift File and click Next.
Enter a file name, like MyAppNotificationServicePushHandler, and click Create. This adds a new swift file in your extension target.
Copy the content from the snippet below and replace the code in your MyAppNotificationServicePushHandler.swift file. You might change the name of the class to fit your project. Refer the comments in the snippet below for more information.
This code is based on our iOS 2.x SDK!
If you’ve integrated based on an earlier version (your podfile targets a MessagingPushAPN version before 2.0), CustomerIO.initialize does not support the config object. It’s simply:
CustomerIO.initialize(siteId: "YourSiteID", apiKey: "YourAPIKey", region: .US)
importFoundationimportUserNotificationsimportCioMessagingPushFCMimportCioTracking@objcpublicclassMyAppNotificationServicePushHandler:NSObject{publicoverrideinit(){}@objc(didReceive:withContentHandler:)publicfuncdidReceive(_request:UNNotificationRequest,withContentHandlercontentHandler:@escaping(UNNotificationContent)->Void){// You may choose to configure the SDK here// Update region to .EU for your EU-based workspace CustomerIO.initialize(siteId:"YourSiteID",apiKey:"YourAPIKey",region:.US){configinconfig.autoTrackDeviceAttributes=trueconfig.logLevel=.info}MessagingPush.shared.didReceive(request,withContentHandler:contentHandler)}@objc(serviceExtensionTimeWillExpire)publicfuncserviceExtensionTimeWillExpire(){MessagingPush.shared.serviceExtensionTimeWillExpire()}}
In your NotificationService.m file, import the auto-generated header file—e.g. YourTargetName-Swift.h.
#import<NotificationServiceExtension-Swift.h>
Create an object of class MyAppNotificationServicePushHandler in your NotificationServiceExtension implementation and call the functions below.
#import"NotificationService.h"#import<NotificationServiceExtension-Swift.h>@interfaceNotificationService()@property(nonatomic,strong)void(^contentHandler)(UNNotificationContent*contentToDeliver);@property(nonatomic,strong)UNMutableNotificationContent*bestAttemptContent;@end@implementationNotificationServiceExtension// Create object of class MyAppNotificationServicePushHandlerMyAppNotificationServicePushHandler*nsHandlerObj=nil;// Initialize the object+(void)initialize{nsHandlerObj=[[MyAppNotificationServicePushHandleralloc]init];}-(void)didReceiveNotificationRequest:(UNNotificationRequest*)requestwithContentHandler:(void(^)(UNNotificationContent*_Nonnull))contentHandler{[nsHandlerObjdidReceive:requestwithContentHandler:contentHandler];}-(void)serviceExtensionTimeWillExpire{[nsHandlerObjserviceExtensionTimeWillExpire];}@end
Now you can run your app on a physical device and send yourself a push notification with images and deep links to test your implementation. You’ll have to use a physical device because simulators can’t receive push notifications.
FCM/Swift
Open the file ios/Podfile and make the following modifications:
<div class="fly-panel bg-info border-info">
<div class="fly-panel-body">
<p class="callout-head text-info mrg-b-none mrg-t-none text--bold"><svg class="icon callout-icon"><use href="#pin" /></svg> Want to automatically get the latest versions?</p>
<div class='text-info'>The example above includes the full version number. If you remove the patch and/or minor version numbers, you’ll always get the latest minor release when you run <code>pod update --repo-update --project-directory=ios</code>. See <a href="#update-ios-dependencies">Updating iOS Dependencies</a> for information about updating your Podfile.</div>
</div>
</div>
Open your terminal, go to your project path, and run pod install --project-directory=ios. When dependencies finish installing, you should see a message like this:
Pod installation complete! There are X dependencies from the Podfile and Y total pods installed.
Update your AppDelegate.swift file to handle push notifications.
This sample includes a work-around
For now, it’s important that you call CustomerIO.initialize before registerForPushNotifications. This fixes an issue in which the SDK identifies the profile, but doesn’t add a device to the profile—preventing the user from receiving notifications.
importCioMessagingPushFCMimportCioTrackingimportFirebaseimportFirebaseMessagingclassAppDelegate:NSObject,UIApplicationDelegate{funcapplication(_application:UIApplication,didFinishLaunchingWithOptionslaunchOptions:[UIApplication.LaunchOptionsKey:Any]?=nil)->Bool{// This fixes an issue in which the React Native SDK identifies// a profile, but an iOS device isn't added to the profile.// Important to call this code before calling `registerForRemoteNotifications`. CustomerIO.initialize(siteId:"YOUR SITE ID",apiKey:"YOUR API KEY",region:Region.US,configure:nil)// Configure FirebaseFirebaseApp.configure()// Set FCM messaging delegateMessaging.messaging().delegate=self// You should register for remote push when the app starts.UIApplication.shared.registerForRemoteNotifications()returntrue}}extensionAppDelegate:MessagingDelegate{funcmessaging(_messaging:Messaging,didReceiveRegistrationTokenfcmToken:String?){MessagingPush.shared.messaging(messaging,didReceiveRegistrationToken:fcmToken)}}
(Optional) Add this function to AppDelegate.swift if you want to show your push notifications even when the app is in the foreground.
Add a notification service extension to call the appropriate Customer.io functions. This lets your app display rich push notifications, including images, etc. However, if you want to enable deep links, you should continue to the Deep links section below.
This code is based on our iOS 2.x SDK!
If you’ve integrated based on an earlier version (your podfile targets a MessagingPushAPN version before 2.0), CustomerIO.initialize does not support the config object. It’s simply:
CustomerIO.initialize(siteId: "YourSiteID", apiKey: "YourAPIKey", region: .US)
importUserNotificationsimportCioMessagingPushFCMimportCioTrackingclassNotificationService:UNNotificationServiceExtension{overridefuncdidReceive(_request:UNNotificationRequest,withContentHandlercontentHandler:@escaping(UNNotificationContent)->Void){// You may choose to configure the SDK here// Update region to .EU for your EU-based workspace CustomerIO.initialize(siteId:"YourSiteID",apiKey:"YourAPIKey",region:.US){configinconfig.autoTrackPushEvents=trueconfig.logLevel=.info}MessagingPush.shared.didReceive(request,withContentHandler:contentHandler)}overridefuncserviceExtensionTimeWillExpire(){MessagingPush.shared.serviceExtensionTimeWillExpire()}}
Now you can run your app on a physical device and send yourself a push notification with images and deep links to test your implementation. You’ll have to use a physical device because simulators can’t receive push notifications.
Sound in push notifications (iOS Only)
When you send a push notification to iOS devices that uses our SDK, you can opt to send the Default system sound or no sound at all. If your audience’s phone is set to vibrate, or they’ve disabled sound permissions for your app, the Default setting will cause the device to vibrate rather than playing a sound.
In most cases, you should use the Default sound setting to make sure your audience hears (or feels) your message. But, before you send sound, you should understand:
Your app needs permission from your users to play sounds. This is done by your app, not our SDKs. Here’s an example from our iOS sample app showing how to request sound permissions.
iOS users can go into System Settings and disable sound permissions for your app. Enabling the Default setting doesn’t guarantee that your audience hears a sound when your message is delivered!
We don’t support custom sounds yet
If you want to send a custom sound, you’ll need to handle it on your own, outside the SDK and use a custom payload when you set up your push notifications.
Prompt users to opt-into push notifications
Your audience has to opt into push notifications. To display the native iOS and Android push notification permission prompt, you’ll use the CustomerIO.showPromptForPushNotifications method.
You can configure push notifications to request authorization for sounds and badges as well (only on iOS). If a user opts into push notifications, the CustomerIO.showPromptForPushNotifications method will return Granted, otherwise it returns Denied as a string. If the user has not yet been asked to opt into notifications, the method will return NotDetermined (only for iOS).
varoptions={"ios":{"sound":true,"badge":true}}CustomerIO.showPromptForPushNotifications(options).then(status=>{switch(status){case"Granted":// Push permission is granted, your app can now send push notifications to the user
break;case"Denied":// App is not allowed to send push notifications to the user
// You might need to explain users why your app needs permission to send notifications
break;case"NotDetermined":// Only for iOS
// Push permission status is not determined
break;}}).catch(error=>{// Failed to show push permission prompt
console.log(error)})
Get a user’s permission status
To get a user’s current permission status, call CustomerIO.getPushPermissionStatus() method. This returns a promise with the current status as a string.
CustomerIO.getPushPermissionStatus().then(status=>{console.log("Push permission status is - "+status)})
Optional: Remove POST_NOTIFICATIONS permission from Android apps
By default, the SDK includes the POST_NOTIFICATIONS permission which is required by Android 13 to show notifications on Android device. However, if you do not want to include the permission because don’t use notifications, or for any other reason, you can remove the permission by adding the following line to your android/app/src/main/AndroidManifest.xml file:
After you set up rich push, you should test your implementation. Below, we show the payload structure we use for iOS and Android. In general, you can use our regular rich push editor; it’s set up to send messages using the JSON structure we outline below.
If you want to fashion your own payload, you can use our custom payload.
iOS APNs payload
{"aps":{// basic iOS message and options go here
"mutable-content":1,"alert":{"title":"string",//(optional) The title of the notification.
"body":"string"//(optional) The message you want to send.
}},"CIO":{"push":{"link":"string",//generally a deep link, i.e. my-app:://...
"image":"string"//HTTPS URL of your image, including file extension
}}}
iOS FCM payload
{"message":{"apns":{"payload":{"aps":{// basic iOS message and options go here
"mutable-content":1,"alert":{"title":"string",//(optional) The title of the notification.
"body":"string"//(optional) The message you want to send.
}},"CIO":{"push":{"link":"string",//generally a deep link, i.e. my-app://... or https://yourwebsite.com/...
"image":"string"//HTTPS URL of your image, including file extension
}}},"headers":{// (optional) headers to send to the Apple Push Notification Service.
"apns-priority":10}}}}
Custom key-value pairs*any type
Additional properties that you've set up your app to interpret outside of the Customer.io SDK.
Android payload
{"message":{"data":{"title":"string",//(optional) The title of the notification.
"body":"string",//The message you want to send.
"image":"string",//https URL to an image you want to include in the notification
"link":"string"//Deep link in the format remote-habits://deep?message=hello&message2=world
}}}