From 5af55f3b2f2e0598e28bda38efc2ed56f74a7620 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Yi=C4=9Fit?= <40565628+tryigit@users.noreply.github.com> Date: Mon, 15 Jan 2024 17:45:50 +0300 Subject: [PATCH 1/2] Update EntryPoint.java --- .../playintegrityfix/EntryPoint.java | 69 ++++++++++--------- 1 file changed, 37 insertions(+), 32 deletions(-) diff --git a/app/src/main/java/es/chiteroman/playintegrityfix/EntryPoint.java b/app/src/main/java/es/chiteroman/playintegrityfix/EntryPoint.java index d1f8cecc..da7f36c2 100644 --- a/app/src/main/java/es/chiteroman/playintegrityfix/EntryPoint.java +++ b/app/src/main/java/es/chiteroman/playintegrityfix/EntryPoint.java @@ -17,37 +17,38 @@ public final class EntryPoint { static { try { - KeyStore keyStore = KeyStore.getInstance("AndroidKeyStore"); - keyStore.load(null); + spoofProvider(); + } catch (Throwable t) { + LOG("spoofProvider exception: " + t); + } + } - Field f = keyStore.getClass().getDeclaredField("keyStoreSpi"); - f.setAccessible(true); - CustomKeyStoreSpi.keyStoreSpi = (KeyStoreSpi) f.get(keyStore); - f.setAccessible(false); + private static void spoofProvider() throws Exception { + KeyStore keyStore = KeyStore.getInstance("AndroidKeyStore"); + keyStore.load(null); - Provider provider = Security.getProvider("AndroidKeyStore"); + Field f = keyStore.getClass().getDeclaredField("keyStoreSpi"); + f.setAccessible(true); + CustomKeyStoreSpi.keyStoreSpi = (KeyStoreSpi) f.get(keyStore); + f.setAccessible(false); - Provider customProvider = new CustomProvider(provider); + Provider provider = Security.getProvider("AndroidKeyStore"); - Security.removeProvider("AndroidKeyStore"); - Security.insertProviderAt(customProvider, 1); + Provider customProvider = new CustomProvider(provider); - LOG("Spoof KeyStoreSpi and Provider done!"); + Security.removeProvider("AndroidKeyStore"); + Security.insertProviderAt(customProvider, 1); - } catch (Throwable t) { - LOG("spoofProvider exception: " + t); - } + LOG("Spoof KeyStoreSpi and Provider done!"); } public static void init(String json) { - try { jsonObject = new JSONObject(json); + spoofDevice(); } catch (JSONException e) { LOG("Couldn't parse JSON from Zygisk"); } - - spoofDevice(); } static void LOG(String msg) { @@ -65,31 +66,19 @@ static void spoofDevice() { } private static void setFieldValue(String name, Object value) { - if (name == null || value == null || name.isEmpty()) return; + if (name == null value == null name.isEmpty()) return; if (value instanceof String str) if (str.isEmpty() || str.isBlank()) return; - Field field = null; - - try { - field = Build.class.getDeclaredField(name); - } catch (NoSuchFieldException e) { - try { - field = Build.VERSION.class.getDeclaredField(name); - } catch (NoSuchFieldException ex) { - LOG("Couldn't find field: " + e); - } - } + Field field = getField(name); if (field == null) return; field.setAccessible(true); try { - Object oldValue = field.get(null); if (!value.equals(oldValue)) { - field.set(null, value); LOG("Set [" + name + "] field value to [" + value + "]"); } @@ -99,4 +88,20 @@ private static void setFieldValue(String name, Object value) { } field.setAccessible(false); } -} \ No newline at end of file + + private static Field getField(String name) { + Field field = null; + + try { + field = Build.class.getDeclaredField(name); + } catch (NoSuchFieldException e) { + try { + field = Build.VERSION.class.getDeclaredField(name); + } catch (NoSuchFieldException ex) { + LOG("Couldn't find field: " + e); + } + } + + return field; + } +} From 5e6f43e80d3efc6975154eacef5917fe93c5c5c5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Yi=C4=9Fit?= <40565628+tryigit@users.noreply.github.com> Date: Mon, 15 Jan 2024 17:48:43 +0300 Subject: [PATCH 2/2] Update EntryPoint.java --- .../main/java/es/chiteroman/playintegrityfix/EntryPoint.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/app/src/main/java/es/chiteroman/playintegrityfix/EntryPoint.java b/app/src/main/java/es/chiteroman/playintegrityfix/EntryPoint.java index da7f36c2..d3acf000 100644 --- a/app/src/main/java/es/chiteroman/playintegrityfix/EntryPoint.java +++ b/app/src/main/java/es/chiteroman/playintegrityfix/EntryPoint.java @@ -66,7 +66,7 @@ static void spoofDevice() { } private static void setFieldValue(String name, Object value) { - if (name == null value == null name.isEmpty()) return; + if (name == null || value == null || name.isEmpty()) return; if (value instanceof String str) if (str.isEmpty() || str.isBlank()) return;