Do remote push notifications require to add UIBackgroundModes in Info.plist?

IosInfo PlistUibackgroundmode

Ios Problem Overview


I have integrated remote push notifications, but I am getting this warning:

> didReceiveRemoteNotification:fetchCompletionHandler:], but you still > need to add "remote-notification" to the list of your supported > UIBackgroundModes in your Info.plist.

My Xcode version is 8.3.1. I really want to add this to Info.plist. I have followed some tutorials as well but they didn't mentioned this either. What should I really do?

Ios Solutions


Solution 1 - Ios

Yes, you should enable Background Modes/Remote notifications to be able to use remote notifications for background updates.

The easiest way to do this is via the project settings. Navigate to Targets -> Your App -> Capabilities -> Background Modes and check Remote notifications. This will automatically enable the required settings.

Background Modes dropdown list in Project Settings

Solution 2 - Ios

You can also edit needed info.plist (Open As -> Source Code) and paste :

<dict>
<key>UIBackgroundModes</key>
	<array>
		<string>remote-notification</string>
	</array>

Solution 3 - Ios

In fact, you do not need to add UIBackgroundModes to .plist simply to use remote notifications.

I know I'm splitting hairs a bit (the other answer is mostly great, and perhaps something is new as of iOS 11), but the question refers to push notifications necessitating background updates, and they do not.

The distinction here, is that there are two different methods that accept notifications on the AppDelegate;

This one does not require you to use UIBackgroundModes:

optional func userNotificationCenter(_ center: UNUserNotificationCenter, 
                         willPresent notification: UNNotification, 
               withCompletionHandler completionHandler: @escaping (UNNotificationPresentationOptions) -> Void)

The above replaces the deprecated as of iOS 11:

optional func application(_ application: UIApplication, 
didReceiveRemoteNotification userInfo: [AnyHashable : Any])

And this one does require background modes capability:

optional func application(_ application: UIApplication, 
didReceiveRemoteNotification userInfo: [AnyHashable : Any], 
   fetchCompletionHandler completionHandler: @escaping (UIBackgroundFetchResult) -> Void)

The key thing here, is the former one (and the deprecated one it replaced) only runs when the app is in the foreground. The latter will run if the app is in the foreground OR background. See the spec for this specific nugget:

> Use this method to process incoming remote notifications for your app. > Unlike the application(_:didReceiveRemoteNotification:) method, which > is called only when your app is running in the foreground, the system > calls this method when your app is running in the foreground or > background.

Hence, if you need push notifications, then decide if you need to run in the background - only if you need both should you implement the method suggested by the warning.

Solution 4 - Ios

Select your .xcodeproj file from Project navigator then go to Signing & Capabilies and then from library (command + shift + l or Click (+ Capability)) search for Background Modes after that, drag and drop it to Signing & Capabilities then check Remote notifications and Background processing. Also (important) add Push notifications by clicking + Capability

Solution 5 - Ios

It happened to me even after setting the remote notifications background mode in the capabilities. The issue was I had three targets, one for production, one for qa and one for staging. I had to set remote notifications in all the three targets and that fixed the warning.

Solution 6 - Ios

If you don't find a list containing background modes in Signing & Capabilities, just add "Required background modes" in your project's Info.plist. Now, you will get a list containing Remote notifications under the tab Signing & Capabilities, just check it.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
Questionuser1960169View Question on Stackoverflow
Solution 1 - IosTamás SengelView Answer on Stackoverflow
Solution 2 - IosAleksandr B.View Answer on Stackoverflow
Solution 3 - IosmobobView Answer on Stackoverflow
Solution 4 - IosGO.exeView Answer on Stackoverflow
Solution 5 - IosJoshua CleetusView Answer on Stackoverflow
Solution 6 - IosMd RaisView Answer on Stackoverflow