Update iOS
UpdatedThere's a new version available!
These pages cover version 1 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.
- Are you new to our SDKs? Check out the latest docs.
- Otherwise, learn about updating to the latest version
This page explains how to upgrade the native iOS SDK to version 2.11. While these changes aren’t breaking—you don’t need to make these changes—they will simplify your integration and improve the reliability of your metrics and deep link handling on iOS devices.
Upgrade native iOS SDK to 2.11+
As of version 2.11, the native iOS Customer.io SDK automatically handles push clicks. These features simplify your SDK integration while improving the reliability of opened
metrics tracking and increasing compatibility with other push modules you may have installed in your app.
Follow our native iOS update guide to update the Flutter and iOS SDK to use the latest version.
Open your
AppDelegate
file and review all of the highlighted code below in this sample.import Flutter import CioMessagingPushFCM import CioTracking import FirebaseMessaging import FirebaseCore import UserNotifications @UIApplicationMain @objc class AppDelegate: FlutterAppDelegate { func application( _ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]? = nil ) -> Bool { ... // Delete this line of code: UNUserNotificationCenter.current().delegate = self return super.application(application, didFinishLaunchingWithOptions: launchOptions) } ... // Delete this function: override func userNotificationCenter( _ center: UNUserNotificationCenter, didReceive response: UNNotificationResponse, withCompletionHandler completionHandler: @escaping () -> Void ) { // Call the Customer.io SDK to handle the push notification let handled = 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() } } // Delete this function: func userNotificationCenter( _ center: UNUserNotificationCenter, willPresent notification: UNNotification, withCompletionHandler completionHandler: **@escaping** (UNNotificationPresentationOptions) -> Void ) { completionHandler([.list, .banner, .badge, .sound]) } }
Now that your app’s code has been simplified, it’s time to enable these new SDK features.
To do this, you’ll need to initialize the MessagingPush
module. Follow the latest push notification setup documentation to learn how to do this.