diff --git a/.idea/.gitignore b/.idea/.gitignore
new file mode 100644
index 0000000..26d3352
--- /dev/null
+++ b/.idea/.gitignore
@@ -0,0 +1,3 @@
+# Default ignored files
+/shelf/
+/workspace.xml
diff --git a/.idea/compiler.xml b/.idea/compiler.xml
new file mode 100644
index 0000000..fb7f4a8
--- /dev/null
+++ b/.idea/compiler.xml
@@ -0,0 +1,6 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/gradle.xml b/.idea/gradle.xml
new file mode 100644
index 0000000..a9f4e52
--- /dev/null
+++ b/.idea/gradle.xml
@@ -0,0 +1,18 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/jarRepositories.xml b/.idea/jarRepositories.xml
new file mode 100644
index 0000000..2955729
--- /dev/null
+++ b/.idea/jarRepositories.xml
@@ -0,0 +1,45 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/misc.xml b/.idea/misc.xml
new file mode 100644
index 0000000..54d5acd
--- /dev/null
+++ b/.idea/misc.xml
@@ -0,0 +1,10 @@
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/vcs.xml b/.idea/vcs.xml
new file mode 100644
index 0000000..35eb1dd
--- /dev/null
+++ b/.idea/vcs.xml
@@ -0,0 +1,6 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/FakeGapps.iml b/FakeGapps.iml
deleted file mode 100644
index bca9441..0000000
--- a/FakeGapps.iml
+++ /dev/null
@@ -1,19 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/app/app.iml b/app/app.iml
deleted file mode 100644
index 95c2926..0000000
--- a/app/app.iml
+++ /dev/null
@@ -1,101 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- generateDebugSources
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/app/build.gradle b/app/build.gradle
index 8df9b2d..5a8b0cb 100644
--- a/app/build.gradle
+++ b/app/build.gradle
@@ -1,14 +1,22 @@
apply plugin: 'com.android.application'
android {
- compileSdkVersion 25
+ compileSdkVersion 32
+ signingConfigs {
+ TIIEHenry {
+ keyAlias rootProject.ext.keyAlias
+ storeFile rootProject.ext.storeFile
+ storePassword rootProject.ext.storePassword
+ keyPassword rootProject.ext.keyPassword
+ }
+ }
defaultConfig {
applicationId "com.thermatk.android.xf.fakegapps"
- minSdkVersion 15
- targetSdkVersion 25
- versionCode 3
- versionName "2.0"
+ minSdkVersion 21
+ targetSdkVersion 32
+ versionCode 4
+ versionName "2.1"
}
buildTypes {
release {
diff --git a/app/release/app-release.apk b/app/release/app-release.apk
new file mode 100644
index 0000000..c208dcf
Binary files /dev/null and b/app/release/app-release.apk differ
diff --git a/app/release/output-metadata.json b/app/release/output-metadata.json
new file mode 100644
index 0000000..00ce3b4
--- /dev/null
+++ b/app/release/output-metadata.json
@@ -0,0 +1,20 @@
+{
+ "version": 3,
+ "artifactType": {
+ "type": "APK",
+ "kind": "Directory"
+ },
+ "applicationId": "com.thermatk.android.xf.fakegapps",
+ "variantName": "release",
+ "elements": [
+ {
+ "type": "SINGLE",
+ "filters": [],
+ "attributes": [],
+ "versionCode": 4,
+ "versionName": "2.1",
+ "outputFile": "app-release.apk"
+ }
+ ],
+ "elementType": "File"
+}
\ No newline at end of file
diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml
index 25bda51..cef0329 100644
--- a/app/src/main/AndroidManifest.xml
+++ b/app/src/main/AndroidManifest.xml
@@ -1,17 +1,26 @@
-
-
-
-
-
-
+ package="com.thermatk.android.xf.fakegapps">
+
+
+
+
+
+
+
+
diff --git a/app/src/main/java/com/android/server/PackageNameService.java b/app/src/main/java/com/android/server/PackageNameService.java
index 09956a1..92f6b48 100644
--- a/app/src/main/java/com/android/server/PackageNameService.java
+++ b/app/src/main/java/com/android/server/PackageNameService.java
@@ -19,43 +19,30 @@ public class PackageNameService extends IPackageNameService.Stub {
private final Context context;
public static void inject() {
- if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
- XposedBridge.hookAllMethods(XposedHelpers.findClass("android.app.ActivityThread", null),
- "systemMain",
- new XC_MethodHook() {
- @Override
- protected void afterHookedMethod(MethodHookParam param) {
- ClassLoader loader = Thread.currentThread().getContextClassLoader();
+ XposedBridge.hookAllMethods(XposedHelpers.findClass("android.app.ActivityThread", null),
+ "systemMain",
+ new XC_MethodHook() {
+ @Override
+ protected void afterHookedMethod(MethodHookParam param) {
+ ClassLoader loader = Thread.currentThread().getContextClassLoader();
- XposedBridge.hookAllMethods(
- XposedHelpers.findClass("com.android.server.am.ActivityManagerService", loader),
- "setSystemProcess",
- new XC_MethodHook() {
- @Override
- protected void afterHookedMethod(MethodHookParam param) {
- try {
- register(getContext(param.thisObject));
- } catch (Throwable ex) {
- XposedBridge.log("FakeGApps: Adding the package name service failed.");
- }
+ XposedBridge.hookAllMethods(
+ XposedHelpers.findClass("com.android.server.am.ActivityManagerService", loader),
+ "setSystemProcess",
+ new XC_MethodHook() {
+ @Override
+ protected void afterHookedMethod(MethodHookParam param) {
+ try {
+ register(getContext(param.thisObject));
+ } catch (Throwable ex) {
+ XposedBridge.log("FakeGApps: Adding the package name service failed.");
}
}
- );
- }
+ }
+ );
}
- );
- } else {
- XposedBridge.hookAllMethods(
- XposedHelpers.findClass("com.android.server.am.ActivityManagerService", null),
- "main",
- new XC_MethodHook() {
- @Override
- protected final void afterHookedMethod(final MethodHookParam param) {
- register((Context) param.getResult());
- }
- }
- );
- }
+ }
+ );
}
private static void register(Context context) {
diff --git a/app/src/main/java/com/thermatk/android/xf/fakegapps/FakeSignatures.java b/app/src/main/java/com/thermatk/android/xf/fakegapps/FakeSignatures.java
index add2348..7902a6c 100644
--- a/app/src/main/java/com/thermatk/android/xf/fakegapps/FakeSignatures.java
+++ b/app/src/main/java/com/thermatk/android/xf/fakegapps/FakeSignatures.java
@@ -11,6 +11,8 @@
import de.robv.android.xposed.XposedHelpers;
public class FakeSignatures implements IXposedHookZygoteInit {
+ static final String SIGNATURE = "308204433082032ba003020102020900c2e08746644a308d300d06092a864886f70d01010405003074310b3009060355040613025553311330110603550408130a43616c69666f726e6961311630140603550407130d4d6f756e7461696e205669657731143012060355040a130b476f6f676c6520496e632e3110300e060355040b1307416e64726f69643110300e06035504031307416e64726f6964301e170d3038303832313233313333345a170d3336303130373233313333345a3074310b3009060355040613025553311330110603550408130a43616c69666f726e6961311630140603550407130d4d6f756e7461696e205669657731143012060355040a130b476f6f676c6520496e632e3110300e060355040b1307416e64726f69643110300e06035504031307416e64726f696430820120300d06092a864886f70d01010105000382010d00308201080282010100ab562e00d83ba208ae0a966f124e29da11f2ab56d08f58e2cca91303e9b754d372f640a71b1dcb130967624e4656a7776a92193db2e5bfb724a91e77188b0e6a47a43b33d9609b77183145ccdf7b2e586674c9e1565b1f4c6a5955bff251a63dabf9c55c27222252e875e4f8154a645f897168c0b1bfc612eabf785769bb34aa7984dc7e2ea2764cae8307d8c17154d7ee5f64a51a44a602c249054157dc02cd5f5c0e55fbef8519fbe327f0b1511692c5a06f19d18385f5c4dbc2d6b93f68cc2979c70e18ab93866b3bd5db8999552a0e3b4c99df58fb918bedc182ba35e003c1b4b10dd244a8ee24fffd333872ab5221985edab0fc0d0b145b6aa192858e79020103a381d93081d6301d0603551d0e04160414c77d8cc2211756259a7fd382df6be398e4d786a53081a60603551d2304819e30819b8014c77d8cc2211756259a7fd382df6be398e4d786a5a178a4763074310b3009060355040613025553311330110603550408130a43616c69666f726e6961311630140603550407130d4d6f756e7461696e205669657731143012060355040a130b476f6f676c6520496e632e3110300e060355040b1307416e64726f69643110300e06035504031307416e64726f6964820900c2e08746644a308d300c0603551d13040530030101ff300d06092a864886f70d010104050003820101006dd252ceef85302c360aaace939bcff2cca904bb5d7a1661f8ae46b2994204d0ff4a68c7ed1a531ec4595a623ce60763b167297a7ae35712c407f208f0cb109429124d7b106219c084ca3eb3f9ad5fb871ef92269a8be28bf16d44c8d9a08e6cb2f005bb3fe2cb96447e868e731076ad45b33f6009ea19c161e62641aa99271dfd5228c5c587875ddb7f452758d661f6cc0cccb7352e424cc4365c523532f7325137593c4ae341f4db41edda0d0b1071a7c440f0fe9ea01cb627ca674369d084bd2fd911ff06cdbf2cfa10dc0f893ae35762919048c7efc64c7144178342f70581c9de573af55b390dd7fdb9418631895d5f759f30112687ff621410c069308a";
+
@Override
public void initZygote(StartupParam startupParam) throws Throwable {
@@ -19,25 +21,22 @@ public void initZygote(StartupParam startupParam) throws Throwable {
@Override
protected void afterHookedMethod(MethodHookParam param) throws Throwable {
PackageInfo pi = (PackageInfo) param.getResult();
- if (pi != null) {
- String packageName = pi.packageName;
- if (packageName.contains("com.google.android.gms") || packageName.contains("com.android.vending")) {
-
- try {
- PackageNameServiceManager manager = PackageNameServiceManager.getService();
- String callerPackageName = manager.getPackageName(Binder.getCallingUid());
-
- XposedBridge.log("FakeGApps: returning fake signature to " + callerPackageName);
- } catch (NullPointerException e) {
- XposedBridge.log("FakeGApps: caught the NullPointerException");
- }
+ if (pi == null) {
+ return;
+ }
+ String packageName = pi.packageName;
+ if (packageName.contains("com.google.android.gms") || packageName.contains("com.android.vending")) {
+ try {
+ PackageNameServiceManager manager = PackageNameServiceManager.getService();
+ String callerPackageName = manager.getPackageName(Binder.getCallingUid());
- String sig = "308204433082032ba003020102020900c2e08746644a308d300d06092a864886f70d01010405003074310b3009060355040613025553311330110603550408130a43616c69666f726e6961311630140603550407130d4d6f756e7461696e205669657731143012060355040a130b476f6f676c6520496e632e3110300e060355040b1307416e64726f69643110300e06035504031307416e64726f6964301e170d3038303832313233313333345a170d3336303130373233313333345a3074310b3009060355040613025553311330110603550408130a43616c69666f726e6961311630140603550407130d4d6f756e7461696e205669657731143012060355040a130b476f6f676c6520496e632e3110300e060355040b1307416e64726f69643110300e06035504031307416e64726f696430820120300d06092a864886f70d01010105000382010d00308201080282010100ab562e00d83ba208ae0a966f124e29da11f2ab56d08f58e2cca91303e9b754d372f640a71b1dcb130967624e4656a7776a92193db2e5bfb724a91e77188b0e6a47a43b33d9609b77183145ccdf7b2e586674c9e1565b1f4c6a5955bff251a63dabf9c55c27222252e875e4f8154a645f897168c0b1bfc612eabf785769bb34aa7984dc7e2ea2764cae8307d8c17154d7ee5f64a51a44a602c249054157dc02cd5f5c0e55fbef8519fbe327f0b1511692c5a06f19d18385f5c4dbc2d6b93f68cc2979c70e18ab93866b3bd5db8999552a0e3b4c99df58fb918bedc182ba35e003c1b4b10dd244a8ee24fffd333872ab5221985edab0fc0d0b145b6aa192858e79020103a381d93081d6301d0603551d0e04160414c77d8cc2211756259a7fd382df6be398e4d786a53081a60603551d2304819e30819b8014c77d8cc2211756259a7fd382df6be398e4d786a5a178a4763074310b3009060355040613025553311330110603550408130a43616c69666f726e6961311630140603550407130d4d6f756e7461696e205669657731143012060355040a130b476f6f676c6520496e632e3110300e060355040b1307416e64726f69643110300e06035504031307416e64726f6964820900c2e08746644a308d300c0603551d13040530030101ff300d06092a864886f70d010104050003820101006dd252ceef85302c360aaace939bcff2cca904bb5d7a1661f8ae46b2994204d0ff4a68c7ed1a531ec4595a623ce60763b167297a7ae35712c407f208f0cb109429124d7b106219c084ca3eb3f9ad5fb871ef92269a8be28bf16d44c8d9a08e6cb2f005bb3fe2cb96447e868e731076ad45b33f6009ea19c161e62641aa99271dfd5228c5c587875ddb7f452758d661f6cc0cccb7352e424cc4365c523532f7325137593c4ae341f4db41edda0d0b1071a7c440f0fe9ea01cb627ca674369d084bd2fd911ff06cdbf2cfa10dc0f893ae35762919048c7efc64c7144178342f70581c9de573af55b390dd7fdb9418631895d5f759f30112687ff621410c069308a";
-
- Signature[] signatures = new Signature[]{new Signature(sig)};
- pi.signatures = signatures;
- param.setResult(pi);
+ XposedBridge.log("FakeGApps: returning fake signature to " + callerPackageName);
+ } catch (NullPointerException e) {
+ XposedBridge.log("FakeGApps: caught the NullPointerException");
}
+
+ pi.signatures = new Signature[]{new Signature(SIGNATURE)};
+ param.setResult(pi);
}
}
});
diff --git a/app/src/main/res/mipmap-hdpi/ic_launcher.png b/app/src/main/res/mipmap-hdpi/ic_launcher.png
deleted file mode 100644
index cde69bc..0000000
Binary files a/app/src/main/res/mipmap-hdpi/ic_launcher.png and /dev/null differ
diff --git a/app/src/main/res/mipmap-mdpi/ic_launcher.png b/app/src/main/res/mipmap-mdpi/ic_launcher.png
deleted file mode 100644
index c133a0c..0000000
Binary files a/app/src/main/res/mipmap-mdpi/ic_launcher.png and /dev/null differ
diff --git a/app/src/main/res/values/arrays.xml b/app/src/main/res/values/arrays.xml
new file mode 100644
index 0000000..b812c68
--- /dev/null
+++ b/app/src/main/res/values/arrays.xml
@@ -0,0 +1,16 @@
+
+
+
+ - com.google.android.GoogleCamera.Urnyx
+ - com.android.vending
+ - com.google.ar.core
+ - org.microg.gms.droidguard
+ - com.google.android.gms
+ - com.google.android.gsf
+ - com.google.android.youtube
+
+
+ - com.thermatk.android.xf.fakegapps.FakeSignatures
+ - com.thermatk.android.xf.fakegapps.PackageNameServiceHook
+
+
\ No newline at end of file
diff --git a/build.gradle b/build.gradle
index ac08900..db638fe 100644
--- a/build.gradle
+++ b/build.gradle
@@ -2,20 +2,44 @@
buildscript {
repositories {
- jcenter()
+ maven { url 'https://maven.aliyun.com/repository/public/' } //jcenterĺ’Ścentral
+ maven { url 'https://maven.aliyun.com/repository/google/' }
+ maven { url 'https://maven.aliyun.com/repository/gradle-plugin/' }
+ maven { url 'https://maven.fabric.io/public' }
google()
+ mavenLocal()
+ mavenCentral()
}
+
+ ext.kotlin_version = "1.6.10"
+ Properties properties = new Properties()
+ properties.load(project.rootProject.file('local.properties').newDataInputStream())
+
+ Properties keyProps = new Properties()
+ keyProps.load(file(/*System.getenv("GRADLE_USER_HOME") +*/ "D:/Android/KEY/key.properties").newDataInputStream())
+
+ ext.keyAlias = keyProps['keyAlias'].toString()
+ ext.storeFile = file(keyProps['storeFile'].toString())
+ ext.storePassword = keyProps['storePassword'].toString()
+ ext.keyPassword = keyProps['keyPassword'].toString()
+
dependencies {
- classpath 'com.android.tools.build:gradle:3.1.0'
+ classpath 'com.android.tools.build:gradle:7.1.0'
- // NOTE: Do not place your application dependencies here; they belong
- // in the individual module build.gradle files
}
}
allprojects {
repositories {
- jcenter()
+ maven { url 'https://maven.aliyun.com/repository/public/' } //jcenterĺ’Ścentral
+ maven { url 'https://maven.aliyun.com/repository/google/' }
+ maven { url "https://jitpack.io" }
+ mavenLocal()
+ mavenCentral()
google()
}
}
+
+task clean(type: Delete) {
+ delete rootProject.buildDir
+}
diff --git a/gradle/wrapper/gradle-wrapper.properties b/gradle/wrapper/gradle-wrapper.properties
index 91f9690..5f1bdb2 100644
--- a/gradle/wrapper/gradle-wrapper.properties
+++ b/gradle/wrapper/gradle-wrapper.properties
@@ -3,4 +3,4 @@ distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
-distributionUrl=https\://services.gradle.org/distributions/gradle-4.4-all.zip
+distributionUrl=https\://services.gradle.org/distributions/gradle-7.2-all.zip
\ No newline at end of file