PDA

View Full Version : Apps can now block sideloading more easily and force downloads through Goog


phillynews215
09-12-2024, 10:54 PM
The Google Play Integrity API lets apps check whether your account is “unlicensed,” meaning you didnt install or buy the app from Google Play.
More importantly, the app can then show a remediation dialog that tells you they have to download the app from Google Play to continue using it.
This remediation feature was introduced back in May during Google I/O and is already being used by some games to block sideloading.



There are many reasons why you may want to sideload apps on your Android phone (https://www.androidauthority.com/how-to-install-apks-31494/), but there are also good reasons why developers would want to block sideloading. A sideloaded app wont contribute to the developers Play Store metrics, for one, but it also prevents the developer from curating which devices can use their app. Improperly sideloaded apps can also crash due to missing assets or code, or they might be missing certain features because you installed the wrong version for your device. Whatever the reason may be, developers who want to stop you from sideloading their apps now have an easier way to do so thanks to the Play Integrity API.

The Google Play Integrity API is an interface that helps developers “check that interactions and server requests are coming from [their] genuine app binary running on a genuine Android device.” It looks for evidence that the app has been tampered with, that the app is running in an “untrustworthy” software environment, that the device has Google Play Protect (https://www.androidauthority.com/google-play-protect-live-threat-detection-3443252/) enabled, and more. If youve heard of or dealt with SafetyNet Attestation before on a rooted phone (https://www.androidauthority.com/what-is-rooted-phone-3338226/), then youre probably already familiar with Play Integrity, even if not by that name. Play Integrity is the successor to SafetyNet Attestation, only it comes with even more features for developers.

As is the case with SafetyNet Attestation, developers call the Play Integrity API at any point in their app, receive whats called an integrity verdict, and then decide what they want to do from there. Some apps call the Play Integrity API when they launch and block access entirely depending on what the verdict is, while others only call the API when youre about to perform a sensitive action, so they can warn you that you shouldnt proceed. The Play Integrity API makes it easy for apps to offload the determination of whether the device and its software environment are “genuine,” and with the latest update to the API, apps can now easily determine whether the person who installed them is “genuine” as well.

During its Google I/O developer conference back in May, Google introduced (https://io.google/2024/explore/f757438a-844f-4c59-8dd4-9a5580a5e23d/) the ability to apps to show certain “remediation” dialogs when theres an issue with an integrity verdict. For example, when the appLicensingVerdict returns “UNLICENSED” in the integrity verdict, it means that the current user account is unlicensed, i.e. you didnt install or buy the app from the Google Play Store (https://www.androidauthority.com/google-play-store-1093442/). In response to this, developers can use the Play Integrity API to show the GET_LICENSED remediation dialog to prompt you to get their app from the Play Store. If you accept, your account becomes licensed (ie. the next time appLicensingVerdict will return “LICENSED” in the integrity verdict), the app is added to your Play Store library, and the app will receive future updates through the Play Store.

Heres a demo of the Play Integrity APIs new GET_LICENSED remediation dialog, courtesy of an open source app (https://github.com/linuxct/hydra) made by developer linuxct to demonstrate the new functionality:

https://www.androidauthority.com/wp-content/uploads/2024/09/Play_Integrity_Get_Licensed_remediation_demo.jpg

Credit: Mishaal Rahman / Android Authority


As you can see, the remediation dialog tells you to “get this app from Play” in order to continue using it. Theres an option to close the dialog, but theres no way to bypass it entirely. If you close the dialog, a response is sent to the app that lets the developer know so they can decide whether to continue blocking access.

If you proceed by tapping “get app,” the apps Play Store landing page is opened where an “install from Play” button is shown in place of the usual “install” button. Tapping the button shows a dialog that asks you whether you want to “install this app from Play.” By proceeding, the “unrecognized” version of the app will be removed along with any associated data.

Developers had other means to detect if their apps were sideloaded before this feature was introduced in the Play Integrity API, but this change makes it easier for developers to implement this kind of check. We dont know if any apps are using this particular feature yet, but its highly likely some games will jump on board with it. The Tesco (https://forum.fairphone.com/t/cannot-install-the-new-tesco-clubcard-app-fp4/93824/10) and BeyBlade X (https://www.reddit.com/r/Beyblade/comments/16bi9hh/getting_this_message_when_i_open_the_bbx_app/) apps both seem to be using this feature already, while the popular game Diablo Immortal seems (https://www.reddit.com/r/retroid/comments/1dihb9d/how_to_bypass_get_this_app_from_play_on_rp2s/) to be using something similar to this feature.

As Google continues to bolster Play Integritys detection mechanisms and add new features, its going to become harder and harder for power users to justify rooting Android (https://www.androidauthority.com/root-android-277350/). At the same time, regular users will be better protected from potentially risky and fraudulent interactions, so its clear that Play Integrity will continue to be adopted by more and more apps. Its already used by numerous popular apps on Google Play, including Stripe, Uber, and TikTok, and were likely to see more adopt it as time goes on.








More... (https://www.androidauthority.com/play-integrity-sideloading-detection-3480639/)