Troubleshooting iOS
Common setup issues with iOS
Troubleshooting iOS Steps
Troubleshooting Steps
Check this page first for common issues based on iOS Setup.
Try the example project on our Github repository.
If stuck, contact support directly or email [email protected] for help.
For faster assistance, please provide:
- Your OneSignal App Id
- Details, logs, and/or screenshots of the issue.
- Steps to reproduce
Please follow all steps below. If you are still having issues, please reach out to support with a log generated following the steps below.
Step 1. Double Check Setup Guide
Return to the setup guide you followed in Mobile Push Quickstart to make sure you followed all steps adding the OneSignal SDK to your app.
Keep an eye on the Requirements section of the setup guide that you are using the right version of Xcode. You must test on an actual iOS device. The Simulator does not support push.
If using Cocoapods: Make sure you have version 1.11.0
or newer of CocoaPods by running pod --version
from the terminal.
Step 2. Use the latest OneSignal SDK
Make sure you are running version 2.16.7
or newer of the OneSignal SDK. We recommend upgrading to the major release version of the OneSignal SDK. See details in Mobile SDKs API Migration Guides.
Run pod update OneSignal
from the terminal to update to the latest version of OneSignal SDK.
Step 3. Check below for common issues and if still not sure, send us a log.
After running through the rest of this Troubleshooting guide, use the OneSignal SDK setLogLevel method
to Verbose and send us the full logcat from the device when reproducing the behavior.
//The following options are available with increasingly more information:
//.LL_NONE, .LL_FATAL, .LL_ERROR, .LL_WARN, .LL_INFO, .LL_DEBUG, .LL_VERBOSE.
OneSignal.setLogLevel(.LL_VERBOSE, visualLevel: .LL_NONE)
//The following options are available with increasingly more information:
//ONE_S_LL_NONE, ONE_S_LL_FATAL, ONE_S_LL_ERROR, ONE_S_LL_WARN, ONE_S_LL_INFO, ONE_S_LL_DEBUG, ONE_S_LL_VERBOSE.
[OneSignal setLogLevel:ONE_S_LL_VERBOSE visualLevel:ONE_S_LL_NONE];
If you need help interpreting the logs, please share them through Pastebin or a .txt file to help our support and engineering team assist you.
Updating to iOS SDK 3.11+
See below Linking against a dylib which is not safe for use in application extensions
Linking against a dylib which is not safe for use in application extensions
This has been updated in our iOS SDK 3.11.+ More details on how to update here.
For Swift Package Manager
- Use product
OneSignal
for your app target, and productOneSignalExtension
for your Notification Service Extension target. - Then in your NotificationService class import
OneSignalExtension
instead ofOneSignal
Missing Push Capabilities
Make sure you have the Push Notifications Capability in the Main App Target > "Signing & Capabilities" > Push Notifications. Some users reported enabling Background Fetch in Main App Target helped reduce the frequency as well. Check that this is enabled for both Debug and Release builds. You may need to check your entitlements if these are different.
Check the Build Settings tab in Xcode that the .entitlement files are setup correctly.
APNS Delegate Never Fired
"APNS Delegate Never Fired" is a timeout message for when iOS doesn't fire a success or failure message if a connection is not made to Apple's APNS servers. This usually occurs in Development/Ad-hoc environments and is more rare in Production.
Please check the following:
1. Toggle WiFi on iOS Device
Try toggling WiFi on the iOS device, try another device, or a different network. You may see this more often with development builds of your app since this will be connecting to Apple's Sandbox server instead of Production.
2. Xcode Capabilities
Make sure you have the Push Notifications Capability in the Main App Target > "Signing & Capabilities" > Push Notifications. Some users reported enabling Background Fetch in Main App Target helped reduce the frequency as well. Check that this is enabled for both Debug and Release builds. You may need to check your entitlements if these are different.
3. Other Push Dependencies
Other Dependencies, especially other Push Provider SDKs, can interfere with this. It is best to remove the other Push SDK from the app. We swizzle the AppDelegate methods and other 3rd party SDKs could be impacted.
You may or may not see in the logs: WARNING: Already swizzled UIApplication.setDelegate. Make sure the OneSignal library wasn't loaded into the runtime twice!
Common Dependency Issues:
-
React Native Push Notifications appears to add methods within the native AppDelegate.m file. Search the project in Xcode for
RNCPushNotificationIOS
and comment out that code. -
mParticle needs to have it to work with swizzling instead of delegate proxy.
4. Cocoapods
If using Cocoapods, run $ sudo gem install cocoapods
again to get updated, then pod update
to update your pods. Make sure to remove any pods that you do not use anymore (especially other push SDKs).
In your Podfile, check if you added abstract_target
. This can cause issues, more detail: https://github.com/OneSignal/OneSignal-iOS-SDK/issues/180
5. Logs
After the above steps. If you are still having issues it is best to plug the device into your IDE and use our SetLogLevel method to Verbose. Then uninstall and re-build the app on the device. This will help log any issues to your IDE console.
Clicks Not Counting
Make sure your app is initializing OneSignal from didFinishLaunchingWithOptions
and from the main thread. Otherwise it can miss the click event if the app is cold started from a click.
If you have any other SDKs or libraries handing push notifications, then it is possible it is an issue with swizzling the iOS click handler and conflicting with OneSignal.
URL Not working
ERROR: The resource could not be loaded because the App Transport Security policy requires the use of a secure connection.
Make sure your URL is HTTPS. HTTP urls will not work unless you set NSAppTransportSecurity
to NSAllowsArbitraryLoads
in your Xcode .plist.
About App Transport Security
Please do not leave NSAllowsArbitraryLoads enabled when releasing your app to the App Store, as this can create a security vulnerability in your app. For more information, please read Apple's Security Overview
Notification is shown but media attachments are not displayed
-
Open your attachment URL in a web browser. Make sure it is a direct link to the image, it can't be part of an HTML page. Also redirects are not supported.
-
Make sure your URL is HTTPS. HTTP urls will not work unless you set
NSAppTransportSecurity
toNSAllowsArbitraryLoads
in your Xcode.plist
. -
Make sure your url ends with the correct file extension. If the URL doesn't contain a file extension you can add it as a parameter by adding
?filetype=file.jpg
for example to the end of your URL. -
Please double check you have correctly added the NotificationServiceExtension noted in step 1 of the iOS Setup guide.
-
If you correctly added the OneSignal Notification Service Extension and rich push notifications (images, buttons) still don't appear, make sure that the Deployment Target in the Extension service matches the deployment target of your application.
Notification is shown but action buttons are not displaying
Please double check you have correctly added the NotificationServiceExtension noted in step 1 of the iOS Setup guide.
Debug the Notification Service Extension
-
Double check that you followed all setup instructions first, please see the SDK docs your are using for more on this.
-
The 2 debugging lines in the .m source we provide are 2 ways to confirm the notification service extension is running.
self.bestAttemptContent.body = [@"[Modified] "
stringByAppendingString:self.bestAttemptContent.body];
This line will add "[Modified] " to the beginning of all your notification bodies. You should see this on all notifications on your device.
NSLog(@"Running NotificationServiceExtension");
This will add an entry to the device log when the extension is run. You can view this in Xcode under Window > "Devices and Simulators". Select your device on the left and open the log up arrow at the bottom.
We recommend clearing the log before sending a notification to test as it can grow quickly. Copy the log and search for the debug entry "Running NotificationServiceExtension".
We don't recommend trying to attach to the extension process with the debugger in Xcode through the Debug menu. Doing so can create issues with it launch so we recommend restarting your device if you have tried doing so.
Lastly the Notification Service Extension will only run if you have set our Action Buttons, a Media Attachment, or have set mutable content on the notification so make sure your test notifications have one of these set.
No such module 'OneSignal'
Swift Package Manager When seeing this error with our XCFramework through Swift Package Manager, make sure you've updated to the latest Xcode version. This was a general issue solved in Xcode 13.2.
CocoaPods: Pods written in Swift should be imported with the use_frameworks!
, and CocoaPods will complain if you don't do this and try to import the pods in Swift code.
Manual Import: One way to solve your issue is to go into your build settings and defining the Framework Search Paths to a folder which contains the frameworks in question. If the OneSignal framework is placed in your project directory, simply set the framework search path to $(SRCROOT) and set it to recursive.
SwiftLint issue: (SwiftLint is a tool used to check if your code meets certain guidelines). If Swiftlint was running before the OneSignal framework is embedded it will cause this error to show up and then be resolved once everything is linked.
Embedded Binary Not Signed With Same Certificate
You will see this error when you opt out of automatic signing and your Main Target and Notification Service Extension are not signed under the same certificate.
- Select the target and uncheck "Automatically Manage Signing"
- Choose the Provisioning Profile that you'd like to use
- Go to Build Settings > Signing and ensure that the Code Signing Identity has the appropriate certificates
- Still under Signing settings, check that Code Signing Style is set to manual and that you choose the provisioning profile where it applies here.
- Make sure that the same settings are applied for your Notification Service Extension as well.
For a more detailed explanation on this, you can view this resolution on Stack Overflow.
How to get a crash log from an iOS device
NOTE: For your crash to show in the following steps the crash must happen when your device is not connected to your Mac. Connect it after you reproduce the crash.
- In Xcode go to
Window
>Devices & Simulators
. - Select your device on the left and press the "Open Console" button.
- Select "All Messages" (top left)
- Reproduce issue with the connected device.
- Press
Command + A
to select all, thenCommand + C
to copy log
- Send it to OneSignal support along with details on reproducing the crash.
Previous Push Notifications Disappear
The OneSignal SDK will automatically clear previously received push notifications when the app is opened under two conditions:
- The badge number is > 0
- The application was opened from a push notification
This behavior is caused by our system to clear the badge number. Most app developers want this behavior, however some do not. In order to prevent this from occurring, you can add OneSignal_disable_badge_clearing
= true
in your application's Info.plist
.
App Groups Error
Couldn't read values in CFPrefsPlistSource<0x281514780> (Domain: group.com.onesignal.example.onesignal,
User: kCFPreferencesAnyUser, ByHost: Yes, Container: (null),
Contents Need Refresh: Yes): Using kCFPreferencesAnyUser with a container is only allowed for
System Containers, detaching from cfprefsd
This error is normal and results from a bug in iOS. It should appear if you have App Groups added correctly. For more info, read this comment by an Apple employee.
Can we setup multiple Notification Service Extensions for Multiple Targets in single Xcode Project?
Example, we are using multiple targets within the same Xcode Project. 2 separate apps to be uploaded to app store. Getting error "Embedded binary's bundle identifier is not prefixed with the parent app's bundle identifier" and cannot enable separate app groups for separate targets.
Unfortunately you need a separate NSE for each application. There might be a workaround with writing a custom build script that dynamically sets the bundle_id of the NSE based on the containing Apps bundle Id but this is outside the scope of OneSignal.
Still having problems? We're happy to help!
We answer most support queries in under 4 hours during the week, and under 24 hours on weekends. Simply email us at [email protected]
Include as much as you can of the following to help us find your issue quicker:
- Version of our SDK
- Device OS version
- Xcode crash lock or stack trace of the app starting and the problem point
- Any other libraries or plugins in your app
- Details on reproducing your problem.
Updated 14 days ago