Fix Play Integrity (and SafetyNet) verdicts.
Go to file
Marcos 6b7e864310
Merge pull request #76 from XantreGodlike/main
Added troubleshooting section to readme
2023-11-21 22:58:32 +01:00
.idea v13.3 2023-11-21 18:25:33 +01:00
app v13.3 2023-11-21 18:25:33 +01:00
gradle/wrapper v13.1 2023-11-20 00:42:21 +01:00
module v13.2 2023-11-21 14:34:33 +01:00
.gitignore v13.1 2023-11-20 00:42:21 +01:00
.gitmodules v13.3 2023-11-21 18:25:33 +01:00
build.gradle.kts Add SECURITY_PATCH and fix null props 2023-11-21 14:04:33 +01:00
changelog.md v13.2 2023-11-21 14:34:33 +01:00
COPYING Add license 2023-11-21 14:56:29 +01:00
gradle.properties v13.1 2023-11-20 00:42:21 +01:00
gradlew v13.1 2023-11-20 00:42:21 +01:00
gradlew.bat v13.1 2023-11-20 00:42:21 +01:00
README.md Added troubleshooting section to readme 2023-11-21 20:38:36 +00:00
settings.gradle.kts v13.1 2023-11-20 00:42:21 +01:00
update.json v13.2 2023-11-21 14:34:33 +01:00
wallet-troubleshoot-1.jpg Added troubleshooting section to readme 2023-11-21 20:38:36 +00:00
wallet-troubleshoot-2.jpg Added troubleshooting section to readme 2023-11-21 20:38:36 +00:00

Play Integrity Fix

A Zygisk module which fix "ctsProfileMatch" (SafetyNet) and "MEETS_DEVICE_INTEGRITY" (Play Integrity).

To use this module you must have one of this:

  • Magisk with Zygisk enabled.
  • KernelSU with ZygiskNext module installed.

Download the latest here.

Telegram group

https://t.me/playintegrityfix

Donations

Official posts

About module

It injects a classes.dex file to modify few fields in android.os.Build class. Also, in native code it creates a hook to modify system properties. The purpose of the module is to avoid a hardware attestation.

About 'pif.prop' file

You can modify this file to spoof android.os.Build fields in GMS unstable process and try to pass Device verdict. You can't use values from recent devices due this devices must use a hardware attestation.

Failing BASIC verdict

If you are failing basicIntegrity (SafetyNet) or MEETS_BASIC_INTEGRITY (Play Integrity) something is wrong in your setup. My recommended steps in order to find the problem:

  • Disable all modules except mine.
  • Check your SELinux (must be enforced).

Some modules which modify system can trigger DroidGuard detection, never hook GMS processes.

Certify Play Store and fix Google Wallet

Follow this steps:

  • Flash my module in Magisk/KernelSU (if you already have my module, just ignore this step).
  • Clear Google Wallet cache.
  • Clear Google Play Store cache.
  • Clear GSF (com.google.android.gsf) cache.
  • Clear GMS cache.

Reboot and done!

Troubleshooting

Fails to meet device integrity (KernelSU)

  • Disable ZygiskNext
  • Reboot
  • Enable ZygiskNext

Passes device integrity, but fails in Wallet (even after clearing cache)

  • Remove all data from Google Play Services
Guide

Google services cache Removing all data

Read module logs

You can read module logs using this command:

adb shell "logcat | grep 'PIF'"

Can this module pass MEETS_STRONG_INTEGRITY?

No.

About Play Integrity, SafetyNet is deprecated

You can read more info here: click me