I was submitting an update of my game to the store, and it kept failing the certification because of an error:
Error Found: The supported APIs test detected the following errors:
API MFCreateAggregateSource in mf.dll is not supported for this application type. SharpDX.MediaFoundation.dll calls this API.
API MFGetService in mf.dll is not supported for this application type. SharpDX.MediaFoundation.dll calls this API.
As far as I know, SharpDX.MediaFoundation has been in the MG project’s reference since I started messing with UWP, and the available version of my game in the Windows Store also has it (but that version did pass the store certification).
My app is a UWP app. My last submission that passed certification was about 2 weeks ago. Is there any possibility that the Windows Store changed its certification policy?
I don’t know… but I guess it could be possible. I would double check that you somehow didn’t get a different version of SharpDX included in your project.
It isn’t that there are options… it is that you might have made a mistake if you manually setup your code base.
If you used the MonoGame SDK installer or used Git to checkout the code and update submodules then things should be working as normal.
If you downloaded the code via zip or manually copied the SharpDX assemblies from that repo… it is very possible you made a mistake and copied the wrong ones.
That the right ones for UWP are the ones from the SharpDX/Windows UAP folder. If those are not the ones in your project then you might have the wrong ones.
I used the UWP project template from the MG SDK installer to setup my project, and the MG source and dependencies referenced in my project are checked out using GIT. There is no problem with building and running the game. In fact I only updated a few lines from the previously released version (in-game logic bug fix, nothing to do with SharpDX) and didn’t update MG source and dependencies library. When I submitted that update, it started to fail the certification again and again (even after I pulled all the changes in MG source and dependencies from GIT). I just want to know if I am the only one having this issue…
I bypassed this error by clearing out both the SharpDX.MediaFoundation.dll and SharpDX.MediaFoundation.xml. This makes all classes used by Microsoft.Xna.Framework.Media unusable, but now the app passed certification.
How I did it:
Navigate to Monogame install location (C:\Program Files (x86)\MonoGame)
Choose your version and open assemblies and desired project type (WindowsUniversal)
Find the SharpDX.MediaFoundation.dll and SharpDX.MediaFoundation.xml and open the in notepad. Clear out everything from SharpDX.MediaFoundation.dll and leave <?xml version="1.0"?> in the xml.
Remove all usage of Microsoft.Xna.Framework.Media.
Publish again.
Note that trying to use any of the classes in Microsoft.Xna.Framework.Media will result in an exception. Instead of using Song use SoundEffectInstance etc. These were the only changes I made and it didn’t affect the user experience in any way.
I haven’t tried out this solution, and I’m not sure if it works with the MG source… Not sure if this is something easy to fix properly (I’m not a MG developer…) >_<
My app doesn’t reference SharpDX.MediaFoundation either. It is the MG source that referenced it. If I mess with SharpDX.MediaFoundation, MG simply won’t build…
Hmm… weird, my project did not have any references to SharpDX.Mediafoundation except those that I myself added. Where does the compiler throw an error? Make sure that you do not delete either of the files, just clear their contents.
@Olander fix has worked for me, thank you so much.
Updating, the fix has not worked just five minutes ago MS Store has marked the app as Non compliant with same error
API MFCreateAggregateSource in mf.dll is not supported for this application type. SharpDX.MediaFoundation.dll calls this API.
API MFGetService in mf.dll is not supported for this application type. SharpDX.MediaFoundation.dll calls this API.
Hi @Olander can you explain what do you mean by “Clear out everything from SharpDX.MediaFoundation.dll”, I have followed you instructions but not passed the certification process, what i do was open the SharpDX.MediaFoundation.dll in notepad++ select all and delete and the save the file, same for XML except “xml version” line, and check that i don’t have any refs to “Microsoft.Xna.Framework.Media”, is that what you made to pass the certification? if so, do you have any changes made to monogame to remove the references or are using the repository ones?
Okay let’s see. The SharpDX.MediaFoundation files:
Make sure that you edit these files in the correct MonoGame version as well as project type. You might have edited the files in the UAP folder, not the UWP folder.
The .dll should be completely empty. Like you did.
The .xml should look like this: <?xml version="1.0"?> <0doc> <0/doc>. Sorry that the doc tags did not show last time, this forum automatically treats them as html elements and hides them, which I didn’t realize. Make sure that you remove the 0s from the tags (couldn’t get them to show otherwise).
Making sure that it did really work:
Navigate to the .appxupload directory.(C:…\Game\AppPackages)
Open or extract the .appxupload. I used 7zip.
Open or extract the .appxbundle.
Open or extract any of the .appx files. I extracted the x64.appx.
Search for SharpDX.MediaFoundation.dll, if it doesn’t exist you have successfully bypassed the error. The packages that previously failed the certification should have the SharpDX.MediaFoundation.dll included.
The trick lies in making sure that you choose the correct MonoGame version as well as the correct project type.