Troubleshooting
Notification with images (Rich Medias) are not working
In the project navigator, select the top-level project directory and select the Open CleverPushNotificationContentExtension
& CleverPushNotificationServiceExtension
target in the project and targets list.
Once you start with the fresh Xcode project, it will select last OS support as a deployment target for e.g (if you have generated project via XCode 12.4 and its latest OS support is 14.4 so 14.4 will be default selection on Xcode.)
Unless you have a specific reason not to, you should set the Deployment Target to be iOS 10 which is the version of iOS that Apple released Rich Media for push. iOS versions under 10 will not be able to get Rich Media.
You will have to make sure all the deployment targets of the extensions must be the same.
In the Extension target, set
Skip Install
build setting toNO
to test via XcodeMake sure the build number + version for the Extension target is same like the Main target
An iOS device (iPhone, iPad, iPod Touch) to test on. The Xcode simulator doesn't support push notifications so you must test on a real device.
When opening a Notification, all other Notifications get cleared
This is due to iOS automatically clearing all notifications when our SDK reset the badge count to zero. This behaviour can be changed. Please refer to the Badge Counts section on the Methods page for further instructions.
Notifications not received while developing
In some cases it is needed to mark your subscriptions as "Sandbox mode" subscriptions in the CleverPush dashboard (Channels -> App Push -> Subscriptions -> Click on your subscription -> Mark as APNS Sandbox mode).
CleverPush-CleverPushResources
needs to have a Provisioning Profile selected.
This is an issue since Xcode 14 as CODE_SIGNING_ALLOWED
has been changed from NO
to YES
in Resources (see https://github.com/CocoaPods/CocoaPods/issues/11402). Add the following to the bottom of your Podfile
and run pod install
to solve it:
post_install do |installer|
assertDeploymentTarget(installer)
installer.pods_project.targets.each do |target|
if target.respond_to?(:product_type) and target.product_type == "com.apple.product-type.bundle"
target.build_configurations.each do |config|
config.build_settings['CODE_SIGNING_ALLOWED'] = 'NO'
end
end
end
end
Custom Delegate in UNUserNotificationCenter Breaking SDK
Adding a custom delegate to UNUserNotificationCenter may break the CleverPush SDK's functionality and prevent notifications from being handled correctly.
Avoid setting a custom delegate for UNUserNotificationCenter in your project. The CleverPush SDK internally manages notification handling, and overriding this delegate will conflict with our implementation, causing notification delivery and interaction issues.
To ensure seamless integration with CleverPush, remove any custom UNUserNotificationCenter delegate code from your app.