airsdk/Adobe-Runtime-Support

Asset validation failed (90035) Invalid Signature ...

Opened this issue · 6 comments

Hello,
I am having a failure loading an ipa upto to TestFlight. I get Asset validation failed (90035) Invalid Signature .... I have have narrowed the issue down to my ANE. If I use the ANE I built in Feb this year the ipa uploads fine, however, if I rebuild the ANE now using the exact same files then I get this failure. Examining the two ANE files the only difference I have found so far is that the Feb ANE signatures.xml indicates SHA1 whilst the current ANE build shows SHA256. I am currently using Air SDK 51.1.2 and the Feb ANE was built using SDK 50.x.x version. I have tried reverting back to 50.2.3 as well as 50.1.1 and building a new ANE with the older SDKs but I get the same failure.

Does anyone have any pointers as to where my issue might be?

Hi

Just to clarify: the difference is just in the version of the AIR SDK that you had used to build the ANE? But each time, you're packaging the IPA with the same version of AIR SDK?

Are you using the same certificate or have you had to update it since February?

The signatures.xml file is something that should just be internal to AIR, as is the fact we updated the ADT codesigning (of .air and .ane files) to use SHA-256. So I would have hoped that this is a red herring, if I'm understanding you right in that both times you can create an IPA file successfully, but cannot successfully upload the IPA that's using the rebuilt ANE file.

Are you able to install the IPA file onto a phone at all, to see if there's any better error message that this might give? And/or if you unzip the IPA file and do a codesign -d -vvv Payload/appname.app command on the unzipped package, this might give some further ideas (and if your ANE included frameworks it may also be necessary to try codesign -d -vvv Payload/appname.app/Frameworks/name.framework etc).

thanks

Okay thanks - so this sounds like an odd one, maybe a code signing thing or potentially a linker issue. Is it possible for us to get hold of the files that you're using here so that we could dive into their structures to see what's happening and what the differences might be?

Upload link for this: https://transfer.harman.com/requests/4tQoAcKH7xhbbrzFTm3dSv

thanks

Thanks for the files. The failing IPA had an additional file in the ANE, platform.xml, and the ANE extension descriptor had a different namespace (51.1) rather than the older 50.0. But the other thing it had is a ._.DS_Store file in the root of the app.

The platform.xml and namespace shouldn't cause any issues for Apple i.e. TestFlight/validation etc, but the ._.DS_Store I think could be a problem, because we are including that in the package and in the code signature. I think Apple may ignore those in the code signatures (oddly, it's not the normal name that crops up of .DS_Store .. not sure of the difference here)

Tellingly, the 'new' ANE also has that hidden file, so I think:
a) can you try checking on your filesystem where you package the new ANE, check for hidden files and delete the ._.DS_Store file; then hopefully the repackaging would work
b) we can also look to patch ADT so that it ignores those files when it packages up an ANE file (and an IPA file)

thanks

The interesting thing we just found is that if you do this on a Mac - where these files originate - AIR just ignores the file completely, and it doesn't get packaged into the ANE in the first place. It's only when you have moved things over to Windows where it seems to cause a problem.

We're going to look for and remove this file when packaging up via ADT - you're very much not the first person to come across this!!

thanks