iOS 13.2 message: nehelper sent invalid result code [1] for Wi-Fi information request

10,358

Solution 1

It eventually turned out, that a third party framework that my app uses, launches those calls to CNCopyCurrentNetworkInfo.

After I added WiFi access capabilities as described here to the app itself the error message disappeared

Solution 2

I've managed to make it on iOS 13.3. Here goes how I make it. (EDIT Aug/2020: I've tested this on iOS 13.6 and worked same)

The official documentation of CNCopyCurrentNetworkInfo says that the function is providing real SSID/BSSID of current connection if the app

  • has an "Access WiFi Information Entitlement" (see here) and
  • is one of 1) Core Location , 2) using NEHotspotConfiguration to connect current Wi-Fi Network, and 3) VPN app.

I've already configured "Access WiFi Information Entitlement", therefore only meet the first requirement. It does work on iOS 13.1 but doesn't work on iOS 13.3. To meet the latter requirement, I decided to include the Core Location in my APP. I've checked the code in here but I gotta to add some constants below on my app's Info.plist to avoid error.

    <key>NSLocationAlwaysAndWhenInUseUsageDescription</key>
    <string>Application requires user’s location for better user experience.</string>
    <key>NSLocationAlwaysUsageDescription</key>
    <string>Application requires user’s location for better user experience.</string>
    <key>NSLocationWhenInUseUsageDescription</key>
    <string>Application requires user’s location for better user experience.</string>

I also needed to call

manager.requestWhenInUseAuthorization()

before

manager.requestAlwaysAuthorization()

to popup the dialog when user launch the app for the first time.

User needed to allow the permission at the first launch. If it is allowed as "Always", the app can use CNCopyCurrentNetworkInfo without error.

Solution 3

Check out WWDC 19 session 713, It happenes because in iOS13 in order to get WiFi details you should allow location permission, each time you try to pull CNCopyCurrentNetworkInfo data from CNCopySupportedInterfaces array you will get this log.

silly solution may be to try to enable location permission and you will not get this error anymore

Share:
10,358
Michael Konz
Author by

Michael Konz

Updated on July 16, 2022

Comments

  • Michael Konz
    Michael Konz almost 2 years

    My app uses locationservices for tracking and geofencing in the background.

    Now with iOS 13.2 I see every second the following message in the console:

    Anchorwatch nehelper sent invalid result code [1] for Wi-Fi information request
    

    My app does nothing with the WiFi system and when I disable WiFi on the device the message disappears.

    While there seem to be no adverse effects by the message I learned the hard way that ignoring message might be a bad idea.

    Can anyone hint me to why this message is coming and what I can do to supress it ?