mirror of
https://github.com/chiteroman/PlayIntegrityFix.git
synced 2025-01-19 03:22:39 +02:00
v15.1
This commit is contained in:
parent
aa340e742e
commit
96e7e473cf
@ -1,5 +1,6 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<project version="4">
|
<project version="4">
|
||||||
|
<component name="GradleMigrationSettings" migrationVersion="1" />
|
||||||
<component name="GradleSettings">
|
<component name="GradleSettings">
|
||||||
<option name="linkedExternalProjectsSettings">
|
<option name="linkedExternalProjectsSettings">
|
||||||
<GradleProjectSettings>
|
<GradleProjectSettings>
|
||||||
|
@ -1,4 +1,3 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<project version="4">
|
<project version="4">
|
||||||
<component name="ExternalStorageConfigurationManager" enabled="true" />
|
<component name="ExternalStorageConfigurationManager" enabled="true" />
|
||||||
<component name="ProjectRootManager" version="2" languageLevel="JDK_17" default="true" project-jdk-name="jbr-17" project-jdk-type="JavaSDK">
|
<component name="ProjectRootManager" version="2" languageLevel="JDK_17" default="true" project-jdk-name="jbr-17" project-jdk-type="JavaSDK">
|
||||||
|
@ -2,5 +2,6 @@
|
|||||||
<project version="4">
|
<project version="4">
|
||||||
<component name="VcsDirectoryMappings">
|
<component name="VcsDirectoryMappings">
|
||||||
<mapping directory="" vcs="Git" />
|
<mapping directory="" vcs="Git" />
|
||||||
|
<mapping directory="$PROJECT_DIR$/app/src/main/cpp/Dobby" vcs="Git" />
|
||||||
</component>
|
</component>
|
||||||
</project>
|
</project>
|
@ -28,18 +28,13 @@ android {
|
|||||||
externalNativeBuild {
|
externalNativeBuild {
|
||||||
cmake {
|
cmake {
|
||||||
arguments += "-DANDROID_STL=none"
|
arguments += "-DANDROID_STL=none"
|
||||||
arguments += "-DCMAKE_BUILD_TYPE=MinSizeRel"
|
arguments += "-DCMAKE_BUILD_TYPE=Release"
|
||||||
|
|
||||||
cFlags += "-fvisibility=hidden"
|
|
||||||
cFlags += "-fvisibility-inlines-hidden"
|
|
||||||
cFlags += "-flto=full"
|
|
||||||
|
|
||||||
cppFlags += "-std=c++20"
|
cppFlags += "-std=c++20"
|
||||||
cppFlags += "-fno-exceptions"
|
cppFlags += "-fno-exceptions"
|
||||||
cppFlags += "-fno-rtti"
|
cppFlags += "-fno-rtti"
|
||||||
cppFlags += "-fvisibility=hidden"
|
cppFlags += "-fvisibility=hidden"
|
||||||
cppFlags += "-fvisibility-inlines-hidden"
|
cppFlags += "-fvisibility-inlines-hidden"
|
||||||
cppFlags += "-flto=full"
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -48,9 +43,7 @@ android {
|
|||||||
release {
|
release {
|
||||||
isMinifyEnabled = true
|
isMinifyEnabled = true
|
||||||
isShrinkResources = true
|
isShrinkResources = true
|
||||||
proguardFiles(
|
proguardFiles(getDefaultProguardFile("proguard-android-optimize.txt"), "proguard-rules.pro")
|
||||||
getDefaultProguardFile("proguard-android-optimize.txt"), "proguard-rules.pro"
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -74,10 +67,8 @@ dependencies {
|
|||||||
tasks.register("copyFiles") {
|
tasks.register("copyFiles") {
|
||||||
doLast {
|
doLast {
|
||||||
val moduleFolder = project.rootDir.resolve("module")
|
val moduleFolder = project.rootDir.resolve("module")
|
||||||
val dexFile =
|
val dexFile = project.layout.buildDirectory.get().asFile.resolve("intermediates/dex/release/minifyReleaseWithR8/classes.dex")
|
||||||
project.layout.buildDirectory.get().asFile.resolve("intermediates/dex/release/minifyReleaseWithR8/classes.dex")
|
val soDir = project.layout.buildDirectory.get().asFile.resolve("intermediates/stripped_native_libs/release/out/lib")
|
||||||
val soDir =
|
|
||||||
project.layout.buildDirectory.get().asFile.resolve("intermediates/stripped_native_libs/release/out/lib")
|
|
||||||
|
|
||||||
dexFile.copyTo(moduleFolder.resolve("classes.dex"), overwrite = true)
|
dexFile.copyTo(moduleFolder.resolve("classes.dex"), overwrite = true)
|
||||||
|
|
||||||
|
@ -12,7 +12,9 @@
|
|||||||
|
|
||||||
#define PIF_JSON "/data/adb/pif.json"
|
#define PIF_JSON "/data/adb/pif.json"
|
||||||
|
|
||||||
static std::string FIRST_API_LEVEL, SECURITY_PATCH, BUILD_ID;
|
#define PIF_JSON_2 "/data/adb/modules/playintegrityfix/pif.json"
|
||||||
|
|
||||||
|
static std::string FIRST_API_LEVEL, SECURITY_PATCH;
|
||||||
|
|
||||||
typedef void (*T_Callback)(void *, const char *, const char *, uint32_t);
|
typedef void (*T_Callback)(void *, const char *, const char *, uint32_t);
|
||||||
|
|
||||||
@ -29,7 +31,6 @@ static void modify_callback(void *cookie, const char *name, const char *value, u
|
|||||||
if (!SECURITY_PATCH.empty()) {
|
if (!SECURITY_PATCH.empty()) {
|
||||||
|
|
||||||
value = SECURITY_PATCH.c_str();
|
value = SECURITY_PATCH.c_str();
|
||||||
LOGD("Set '%s' to '%s'", name, value);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} else if (prop.ends_with("api_level")) {
|
} else if (prop.ends_with("api_level")) {
|
||||||
@ -37,15 +38,6 @@ static void modify_callback(void *cookie, const char *name, const char *value, u
|
|||||||
if (!FIRST_API_LEVEL.empty()) {
|
if (!FIRST_API_LEVEL.empty()) {
|
||||||
|
|
||||||
value = FIRST_API_LEVEL.c_str();
|
value = FIRST_API_LEVEL.c_str();
|
||||||
LOGD("Set '%s' to '%s'", name, value);
|
|
||||||
}
|
|
||||||
|
|
||||||
} else if (prop == "ro.build.id") {
|
|
||||||
|
|
||||||
if (!BUILD_ID.empty()) {
|
|
||||||
|
|
||||||
value = BUILD_ID.c_str();
|
|
||||||
LOGD("Set '%s' to '%s'", name, value);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} else if (prop == "sys.usb.state") {
|
} else if (prop == "sys.usb.state") {
|
||||||
@ -53,6 +45,11 @@ static void modify_callback(void *cookie, const char *name, const char *value, u
|
|||||||
value = "none";
|
value = "none";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!prop.starts_with("debug") && !prop.starts_with("cache") && !prop.starts_with("persist")) {
|
||||||
|
|
||||||
|
LOGD("[%s] -> %s", name, value);
|
||||||
|
}
|
||||||
|
|
||||||
return o_callback(cookie, name, value, serial);
|
return o_callback(cookie, name, value, serial);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -182,18 +179,6 @@ public:
|
|||||||
LOGD("JSON file doesn't contain SECURITY_PATCH key :(");
|
LOGD("JSON file doesn't contain SECURITY_PATCH key :(");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (json.contains("ID")) {
|
|
||||||
|
|
||||||
if (json["ID"].is_string()) {
|
|
||||||
|
|
||||||
BUILD_ID = json["ID"].get<std::string>();
|
|
||||||
}
|
|
||||||
|
|
||||||
} else {
|
|
||||||
|
|
||||||
LOGD("JSON file doesn't contain BUILD_ID key :(");
|
|
||||||
}
|
|
||||||
|
|
||||||
doHook();
|
doHook();
|
||||||
|
|
||||||
LOGD("get system classloader");
|
LOGD("get system classloader");
|
||||||
@ -272,6 +257,11 @@ static void companion(int fd) {
|
|||||||
|
|
||||||
FILE *jsonFile = fopen(PIF_JSON, "r");
|
FILE *jsonFile = fopen(PIF_JSON, "r");
|
||||||
|
|
||||||
|
if (jsonFile == nullptr) {
|
||||||
|
|
||||||
|
jsonFile = fopen(PIF_JSON_2, "r");
|
||||||
|
}
|
||||||
|
|
||||||
if (jsonFile) {
|
if (jsonFile) {
|
||||||
|
|
||||||
fseek(jsonFile, 0, SEEK_END);
|
fseek(jsonFile, 0, SEEK_END);
|
||||||
|
@ -12,10 +12,10 @@ import java.security.cert.Certificate;
|
|||||||
import java.security.cert.CertificateException;
|
import java.security.cert.CertificateException;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.Enumeration;
|
import java.util.Enumeration;
|
||||||
|
import java.util.Locale;
|
||||||
|
|
||||||
public class CustomKeyStoreSpi extends KeyStoreSpi {
|
public final class CustomKeyStoreSpi extends KeyStoreSpi {
|
||||||
public static KeyStoreSpi keyStoreSpi;
|
public static volatile KeyStoreSpi keyStoreSpi;
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Key engineGetKey(String alias, char[] password) throws NoSuchAlgorithmException, UnrecoverableKeyException {
|
public Key engineGetKey(String alias, char[] password) throws NoSuchAlgorithmException, UnrecoverableKeyException {
|
||||||
@ -24,9 +24,14 @@ public class CustomKeyStoreSpi extends KeyStoreSpi {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Certificate[] engineGetCertificateChain(String alias) {
|
public Certificate[] engineGetCertificateChain(String alias) {
|
||||||
EntryPoint.LOG("Tried to get certificate chain, throwing exception!");
|
for (StackTraceElement stackTraceElement : Thread.currentThread().getStackTrace()) {
|
||||||
|
if (stackTraceElement.getClassName().toLowerCase(Locale.US).contains("droidguard")) {
|
||||||
|
EntryPoint.LOG("DroidGuard call certificate chain! Throw exception.");
|
||||||
throw new UnsupportedOperationException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
return keyStoreSpi.engineGetCertificateChain(alias);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Certificate engineGetCertificate(String alias) {
|
public Certificate engineGetCertificate(String alias) {
|
||||||
|
@ -7,6 +7,8 @@ import org.json.JSONException;
|
|||||||
import org.json.JSONObject;
|
import org.json.JSONObject;
|
||||||
|
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
|
import java.security.KeyStore;
|
||||||
|
import java.security.KeyStoreSpi;
|
||||||
import java.security.Provider;
|
import java.security.Provider;
|
||||||
import java.security.Security;
|
import java.security.Security;
|
||||||
|
|
||||||
@ -53,6 +55,14 @@ public final class EntryPoint {
|
|||||||
|
|
||||||
private static void spoofProvider() {
|
private static void spoofProvider() {
|
||||||
try {
|
try {
|
||||||
|
KeyStore keyStore = KeyStore.getInstance("AndroidKeyStore");
|
||||||
|
keyStore.load(null);
|
||||||
|
|
||||||
|
Field f = keyStore.getClass().getDeclaredField("keyStoreSpi");
|
||||||
|
f.setAccessible(true);
|
||||||
|
CustomKeyStoreSpi.keyStoreSpi = (KeyStoreSpi) f.get(keyStore);
|
||||||
|
f.setAccessible(false);
|
||||||
|
|
||||||
Provider provider = Security.getProvider("AndroidKeyStore");
|
Provider provider = Security.getProvider("AndroidKeyStore");
|
||||||
|
|
||||||
Provider customProvider = new CustomProvider(provider);
|
Provider customProvider = new CustomProvider(provider);
|
||||||
@ -98,7 +108,7 @@ public final class EntryPoint {
|
|||||||
}
|
}
|
||||||
|
|
||||||
} catch (IllegalAccessException e) {
|
} catch (IllegalAccessException e) {
|
||||||
LOG("Couldn't modify field :(");
|
LOG("Couldn't modify field: " + e);
|
||||||
}
|
}
|
||||||
field.setAccessible(false);
|
field.setAccessible(false);
|
||||||
}
|
}
|
||||||
|
@ -2,6 +2,11 @@ We have a Telegram channel!
|
|||||||
If you want to share your knowledge join:
|
If you want to share your knowledge join:
|
||||||
https://t.me/playintegrityfix
|
https://t.me/playintegrityfix
|
||||||
|
|
||||||
# v15.0
|
# v15.1
|
||||||
|
|
||||||
- Fix issues.
|
Emergency update 🚨
|
||||||
|
|
||||||
|
- Fix few bugs.
|
||||||
|
- Using v15.6 fingerprint, so you can pass DEVICE.
|
||||||
|
|
||||||
|
MODULE WON'T PROVIDE MORE FINGERPRINTS WHEN GOOGLE BAN THIS ONE.
|
@ -52,7 +52,7 @@ if [ -d "/system/app/EliteDevelopmentModule" ]; then
|
|||||||
ui_print "- EliteDevelopmentModule app removed."
|
ui_print "- EliteDevelopmentModule app removed."
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Move empty pif.json file
|
if [ -f "/data/adb/pif.json" ]; then
|
||||||
if [ ! -f "/data/adb/pif.json" ]; then
|
mv -f "/data/adb/pif.json" "/data/adb/pif.json.old"
|
||||||
mv -f $MODPATH/pif.json /data/adb/
|
ui_print "- Backup pif.json"
|
||||||
fi
|
fi
|
@ -1,7 +1,7 @@
|
|||||||
id=playintegrityfix
|
id=playintegrityfix
|
||||||
name=Play Integrity Fix
|
name=Play Integrity Fix
|
||||||
version=v15.0
|
version=v15.1
|
||||||
versionCode=15000
|
versionCode=15100
|
||||||
author=chiteroman
|
author=chiteroman
|
||||||
description=Universal modular fix for Play Integrity (and SafetyNet) on devices running Android 8+.
|
description=Universal modular fix for Play Integrity (and SafetyNet) on devices running Android 8+.
|
||||||
updateJson=https://raw.githubusercontent.com/chiteroman/PlayIntegrityFix/main/update.json
|
updateJson=https://raw.githubusercontent.com/chiteroman/PlayIntegrityFix/main/update.json
|
||||||
|
@ -1,12 +1,11 @@
|
|||||||
{
|
{
|
||||||
"PRODUCT": "",
|
"PRODUCT": "c01_ww",
|
||||||
"DEVICE": "",
|
"DEVICE": "acer_c01",
|
||||||
"MANUFACTURER": "",
|
"MANUFACTURER": "Acer Inc.",
|
||||||
"BRAND": "",
|
"BRAND": "acer",
|
||||||
"MODEL": "",
|
"MODEL": "C01",
|
||||||
"FINGERPRINT": "",
|
"FINGERPRINT": "acer/c01_ww/acer_c01:7.1.1/NMF26F/1521514970:user/release-keys",
|
||||||
"SECURITY_PATCH": "",
|
"SECURITY_PATCH": "2018-04-01",
|
||||||
"ID": "",
|
|
||||||
"FIRST_API_LEVEL": 24,
|
"FIRST_API_LEVEL": 24,
|
||||||
"FORCE_BASIC_ATTESTATION": true
|
"FORCE_BASIC_ATTESTATION": true
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"version": "v15.0",
|
"version": "v15.1",
|
||||||
"versionCode": 15000,
|
"versionCode": 15100,
|
||||||
"zipUrl": "https://github.com/chiteroman/PlayIntegrityFix/releases/download/v15.0/PlayIntegrityFix_v15.0.zip",
|
"zipUrl": "https://github.com/chiteroman/PlayIntegrityFix/releases/download/v15.1/PlayIntegrityFix.zip",
|
||||||
"changelog": "https://raw.githubusercontent.com/chiteroman/PlayIntegrityFix/main/changelog.md"
|
"changelog": "https://raw.githubusercontent.com/chiteroman/PlayIntegrityFix/main/changelog.md"
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user