diff --git a/.idea/vcs.xml b/.idea/vcs.xml
index 94a25f7..9d7f727 100644
--- a/.idea/vcs.xml
+++ b/.idea/vcs.xml
@@ -2,5 +2,6 @@
+
\ No newline at end of file
diff --git a/app/src/main/cpp/Application.mk b/app/src/main/cpp/Application.mk
index 1d256e2..8a0542a 100644
--- a/app/src/main/cpp/Application.mk
+++ b/app/src/main/cpp/Application.mk
@@ -1,4 +1,3 @@
APP_STL := system
-APP_CFLAGS := -Oz -flto -fvisibility=hidden -fvisibility-inlines-hidden -faddrsig -ffunction-sections -fdata-sections
-APP_CPPFLAGS := -std=c++20 -fno-exceptions -fno-rtti
-APP_LDFLAGS := -Oz -flto -Wl,--icf=all -Wl,--exclude-libs,ALL -Wl,--gc-sections
\ No newline at end of file
+APP_CFLAGS := -Oz -fvisibility=hidden -fvisibility-inlines-hidden
+APP_CPPFLAGS := -std=c++20 -fno-exceptions -fno-rtti
\ No newline at end of file
diff --git a/app/src/main/cpp/main.cpp b/app/src/main/cpp/main.cpp
index 543746b..35e1cea 100644
--- a/app/src/main/cpp/main.cpp
+++ b/app/src/main/cpp/main.cpp
@@ -2,6 +2,7 @@
#include
#include
#include
+#include
#include "zygisk.hpp"
#include "shadowhook.h"
@@ -10,9 +11,9 @@
typedef void (*T_Callback)(void *, const char *, const char *, uint32_t);
-T_Callback o_callback = nullptr;
+static T_Callback o_callback = nullptr;
-void modify_callback(void *cookie, const char *name, const char *value, uint32_t serial) {
+static void modify_callback(void *cookie, const char *name, const char *value, uint32_t serial) {
if (cookie == nullptr || name == nullptr || value == nullptr || o_callback == nullptr) return;
@@ -31,9 +32,10 @@ void modify_callback(void *cookie, const char *name, const char *value, uint32_t
return o_callback(cookie, name, value, serial);
}
-void (*o_system_property_read_callback)(const prop_info *, T_Callback, void *);
+static void (*o_system_property_read_callback)(const prop_info *, T_Callback, void *);
-void my_system_property_read_callback(const prop_info *pi, T_Callback callback, void *cookie) {
+static void
+my_system_property_read_callback(const prop_info *pi, T_Callback callback, void *cookie) {
if (pi == nullptr || callback == nullptr || cookie == nullptr) {
return o_system_property_read_callback(pi, callback, cookie);
}
@@ -41,7 +43,7 @@ void my_system_property_read_callback(const prop_info *pi, T_Callback callback,
return o_system_property_read_callback(pi, modify_callback, cookie);
}
-void doHook() {
+static void doHook() {
shadowhook_init(SHADOWHOOK_MODE_UNIQUE, false);
void *handle = shadowhook_hook_sym_name("libc.so", "__system_property_read_callback",
reinterpret_cast(my_system_property_read_callback),
@@ -71,13 +73,14 @@ public:
if (process == "com.google.android.gms.unstable") {
+ long size = 0;
int fd = api->connectCompanion();
- read(fd, &bufferSize, sizeof(int));
+ read(fd, &size, sizeof(long));
- if (bufferSize > 0) {
- buffer = static_cast(calloc(1, bufferSize));
- read(fd, buffer, bufferSize);
+ if (size > 0) {
+ vector.resize(size);
+ read(fd, vector.data(), size);
} else {
api->setOption(zygisk::DLCLOSE_MODULE_LIBRARY);
LOGD("Couldn't read classes.dex");
@@ -93,15 +96,13 @@ public:
}
void postAppSpecialize(const zygisk::AppSpecializeArgs *args) override {
- if (bufferSize < 1 || buffer == nullptr) return;
+ if (vector.empty()) return;
- LOGD("Read from fd: %d bytes!", bufferSize);
+ LOGD("Read from fd: %ld bytes!", static_cast(vector.size()));
doHook();
inject();
-
- free(buffer);
}
void preServerSpecialize(zygisk::ServerSpecializeArgs *args) override {
@@ -111,8 +112,7 @@ public:
private:
zygisk::Api *api = nullptr;
JNIEnv *env = nullptr;
- char *buffer = nullptr;
- int bufferSize = 0;
+ std::vector vector;
void inject() {
LOGD("get system classloader");
@@ -125,7 +125,7 @@ private:
auto dexClClass = env->FindClass("dalvik/system/InMemoryDexClassLoader");
auto dexClInit = env->GetMethodID(dexClClass, "",
"(Ljava/nio/ByteBuffer;Ljava/lang/ClassLoader;)V");
- auto buff = env->NewDirectByteBuffer(buffer, bufferSize);
+ auto buff = env->NewDirectByteBuffer(vector.data(), vector.size());
auto dexCl = env->NewObject(dexClClass, dexClInit, buff, systemClassLoader);
LOGD("load class");
@@ -143,26 +143,24 @@ private:
};
static void companion(int fd) {
- int dexSize = 0;
- char *buffer = nullptr;
+ std::vector vector;
+ long size = 0;
FILE *dex = fopen("/data/adb/modules/playintegrityfix/classes.dex", "rb");
if (dex) {
fseek(dex, 0, SEEK_END);
- dexSize = static_cast(ftell(dex));
+ size = ftell(dex);
fseek(dex, 0, SEEK_SET);
- buffer = static_cast(calloc(1, dexSize));
- fread(buffer, 1, dexSize, dex);
+ vector.resize(size);
+ fread(vector.data(), 1, size, dex);
fclose(dex);
}
- write(fd, &dexSize, sizeof(int));
- write(fd, buffer, dexSize);
-
- free(buffer);
+ write(fd, &size, sizeof(long));
+ write(fd, vector.data(), size);
}
REGISTER_ZYGISK_MODULE(PlayIntegrityFix)
diff --git a/module/boot-completed.sh b/module/boot-completed.sh
new file mode 100644
index 0000000..e03ab5c
--- /dev/null
+++ b/module/boot-completed.sh
@@ -0,0 +1,29 @@
+resetprop_if_diff() {
+ local NAME=$1
+ local EXPECTED=$2
+ local CURRENT=$(resetprop $NAME)
+
+ [ -z "$CURRENT" ] || [ "$CURRENT" == "$EXPECTED" ] || resetprop $NAME $EXPECTED
+}
+
+resetprop_if_match() {
+ local NAME=$1
+ local CONTAINS=$2
+ local VALUE=$3
+
+ [[ "$(resetprop $NAME)" == *"$CONTAINS"* ]] && resetprop $NAME $VALUE
+}
+
+# Avoid breaking Realme fingerprint scanners
+resetprop_if_diff ro.boot.flash.locked 1
+
+# Avoid breaking Oppo fingerprint scanners
+resetprop_if_diff ro.boot.vbmeta.device_state locked
+
+# Avoid breaking OnePlus display modes/fingerprint scanners
+resetprop_if_diff vendor.boot.verifiedbootstate green
+
+# Avoid breaking OnePlus/Oppo display fingerprint scanners on OOS/ColorOS 12+
+resetprop_if_diff ro.boot.verifiedbootstate green
+resetprop_if_diff ro.boot.veritymode enforcing
+resetprop_if_diff vendor.boot.vbmeta.device_state locked
\ No newline at end of file
diff --git a/module/post-fs-data.sh b/module/post-fs-data.sh
index c11b950..1ca4671 100644
--- a/module/post-fs-data.sh
+++ b/module/post-fs-data.sh
@@ -3,11 +3,6 @@ if magisk --denylist status; then
magisk --denylist rm com.google.android.gms
fi
-# Remove conflicting modules if installed
-if [ -d /data/adb/modules/safetynet-fix ]; then
- touch /data/adb/modules/safetynet-fix/remove
-fi
-
# Conditional early sensitive properties
resetprop_if_diff() {
diff --git a/module/service.sh b/module/service.sh
index ec1d1f8..0446160 100644
--- a/module/service.sh
+++ b/module/service.sh
@@ -32,24 +32,26 @@ if [ "$(toybox cat /sys/fs/selinux/enforce)" == "0" ]; then
chmod 440 /sys/fs/selinux/policy
fi
-# SafetyNet/Play Integrity
-{
- # late props which must be set after boot_completed for various OEMs
- until [ "$(getprop sys.boot_completed)" == "1" ]; do
- sleep 1
- done
+if [ -z "$KSU" ] || [ "$KSU" = false ]; then
+ # SafetyNet/Play Integrity
+ {
+ # late props which must be set after boot_completed for various OEMs
+ until [ "$(getprop sys.boot_completed)" == "1" ]; do
+ sleep 1
+ done
- # Avoid breaking Realme fingerprint scanners
- resetprop_if_diff ro.boot.flash.locked 1
+ # Avoid breaking Realme fingerprint scanners
+ resetprop_if_diff ro.boot.flash.locked 1
- # Avoid breaking Oppo fingerprint scanners
- resetprop_if_diff ro.boot.vbmeta.device_state locked
+ # Avoid breaking Oppo fingerprint scanners
+ resetprop_if_diff ro.boot.vbmeta.device_state locked
- # Avoid breaking OnePlus display modes/fingerprint scanners
- resetprop_if_diff vendor.boot.verifiedbootstate green
+ # Avoid breaking OnePlus display modes/fingerprint scanners
+ resetprop_if_diff vendor.boot.verifiedbootstate green
- # Avoid breaking OnePlus/Oppo display fingerprint scanners on OOS/ColorOS 12+
- resetprop_if_diff ro.boot.verifiedbootstate green
- resetprop_if_diff ro.boot.veritymode enforcing
- resetprop_if_diff vendor.boot.vbmeta.device_state locked
-}&
+ # Avoid breaking OnePlus/Oppo display fingerprint scanners on OOS/ColorOS 12+
+ resetprop_if_diff ro.boot.verifiedbootstate green
+ resetprop_if_diff ro.boot.veritymode enforcing
+ resetprop_if_diff vendor.boot.vbmeta.device_state locked
+ }&
+fi