Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

APN BadDeviceToken iff running dev version

The problem

I'm not receiving Push Notifications to my app when I'm working on it,
and the APN server returns "BadDeviceToken".

The situation

I've got to be missing something simple here, this is the situation :

  1. When I send a Push Notification to my app downloaded from the App Store it works

  2. When I send a Push Notification from the same server, to the same version (*) of my app but built off Xcode, the APN server returns a status: '400' fail with the failed[0].response.reason: 'BadDeviceToken'

(*) I say the same version, the code is the same and the plugins should be the same, but I have changed Cordova iOS version down to 3.x, from 4.x.

The tech

I'm using the newer method of Push Notifications where on the server I just have a .p8 APNs Auth Key on the server.
The server is node code using the node-apn plugin.
The client app is Cordova, using the Telerik Push Plugin.

What I've tried

  • I've tried creating a new APNs Auth Key and uploading that to the server; that still works on the App Store version of the app, and APN still returns "BadDeviceToken" when sending to my locally built version of the app.

  • I've tried setting production: false on the server config for node-apn before sending the push to my locally built app; I still get the "BadDeviceToken" error.

  • Doing an extra hexadecimal encode to the token as per this question; result is that it still says "BadDeviceToken", though in that case it would actually be true.

  • Bumping the cordova-ios version back up to 4.3.1; still getting "BadDeviceToken".

  • Double checking that the "Push Notifications" Capability is on when building

  • Doing a Release build rather than a Debug build, as suggested here, and described here

The question(s)

Why is the APN server saying BadDeviceToken when that is obviously not true?
And, how can I fix it?

like image 551
kris Avatar asked May 26 '17 05:05

kris


2 Answers

Deleting the app and reinstalling it (ie. re-running it from Xcode) gave a new token and the new token worked without complaint.

like image 177
kris Avatar answered Oct 18 '22 12:10

kris


In addition to @kris's answer:

  • You could've probably gone solved it as well by running the app through xCode, that will generate a development build, and will need to use the APNS development gateway with a development certificate, not the production certificate.
  • Or if you are installing directly to your phone from Xcode, then you have to use Development security profile and make sure you are sending the notification from server side to iOS devlopment sand box. If you are using TestFlight/AppStore you need to use Production profile and make sure you are sending the notification to iOS production sandbox.

The SOLUTION however was found by the one that made the question itself, stating:

  • For some reason the Xcode project did´t use the right provision profile and the solution would be rather to re-install the app.

Further I'd like to explain what APNS_BAD_DEVICE_TOKEN is:

  • The specified device token was bad. Verify that you specified a valid token and that your Security Profile's type (development/production) matches your push certificate's type.
like image 32
King Reload Avatar answered Oct 18 '22 13:10

King Reload