From 98956e8f1a41347bb435720bbf984969469a7110 Mon Sep 17 00:00:00 2001 From: Itroublve <115026399+Anajrim01@users.noreply.github.com> Date: Fri, 6 Sep 2024 09:13:57 +0200 Subject: [PATCH] fix(Pixiv - Hide ads): Fix for latest version (#3616) Co-authored-by: oSumAtrIX --- .../patches/pixiv/ads/HideAdsPatch.kt | 19 +++++++---------- .../fingerprints/IsNotPremiumFingerprint.kt | 21 ------------------- .../fingerprints/ShouldShowAdsFingerprint.kt | 14 +++++++++++++ 3 files changed, 22 insertions(+), 32 deletions(-) delete mode 100644 src/main/kotlin/app/revanced/patches/pixiv/ads/fingerprints/IsNotPremiumFingerprint.kt create mode 100644 src/main/kotlin/app/revanced/patches/pixiv/ads/fingerprints/ShouldShowAdsFingerprint.kt diff --git a/src/main/kotlin/app/revanced/patches/pixiv/ads/HideAdsPatch.kt b/src/main/kotlin/app/revanced/patches/pixiv/ads/HideAdsPatch.kt index b0479749c..b5b745975 100644 --- a/src/main/kotlin/app/revanced/patches/pixiv/ads/HideAdsPatch.kt +++ b/src/main/kotlin/app/revanced/patches/pixiv/ads/HideAdsPatch.kt @@ -1,28 +1,25 @@ package app.revanced.patches.pixiv.ads -import app.revanced.util.exception import app.revanced.patcher.data.BytecodeContext import app.revanced.patcher.extensions.InstructionExtensions.addInstructions import app.revanced.patcher.patch.BytecodePatch import app.revanced.patcher.patch.annotation.CompatiblePackage import app.revanced.patcher.patch.annotation.Patch -import app.revanced.patches.pixiv.ads.fingerprints.IsNotPremiumFingerprint +import app.revanced.patches.pixiv.ads.fingerprints.ShouldShowAdsFingerprint +import app.revanced.util.exception @Patch( name = "Hide ads", - compatiblePackages = [CompatiblePackage("jp.pxv.android")] + compatiblePackages = [CompatiblePackage("jp.pxv.android")], ) @Suppress("unused") -object HideAdsPatch : BytecodePatch(setOf(IsNotPremiumFingerprint)) { - // Always return false in the "isNotPremium" method which normally returns !this.accountManager.isPremium. - // However, this is not the method that controls the user's premium status. - // Instead, this method is used to determine whether ads should be shown. +object HideAdsPatch : BytecodePatch(setOf(ShouldShowAdsFingerprint)) { override fun execute(context: BytecodeContext) = - IsNotPremiumFingerprint.result?.mutableClass?.virtualMethods?.first()?.addInstructions( + ShouldShowAdsFingerprint.result?.mutableMethod?.addInstructions( 0, """ const/4 v0, 0x0 return v0 - """ - ) ?: throw IsNotPremiumFingerprint.exception -} \ No newline at end of file + """, + ) ?: throw ShouldShowAdsFingerprint.exception +} diff --git a/src/main/kotlin/app/revanced/patches/pixiv/ads/fingerprints/IsNotPremiumFingerprint.kt b/src/main/kotlin/app/revanced/patches/pixiv/ads/fingerprints/IsNotPremiumFingerprint.kt deleted file mode 100644 index 6618af0ed..000000000 --- a/src/main/kotlin/app/revanced/patches/pixiv/ads/fingerprints/IsNotPremiumFingerprint.kt +++ /dev/null @@ -1,21 +0,0 @@ -package app.revanced.patches.pixiv.ads.fingerprints - -import app.revanced.patcher.extensions.or -import app.revanced.patcher.fingerprint.MethodFingerprint -import com.android.tools.smali.dexlib2.AccessFlags - - -internal object IsNotPremiumFingerprint : MethodFingerprint( - "V", - AccessFlags.PUBLIC or AccessFlags.CONSTRUCTOR, - listOf("L"), - strings = listOf("pixivAccountManager"), - customFingerprint = custom@{ _, classDef -> - // The "isNotPremium" method is the only method in the class. - if (classDef.virtualMethods.count() != 1) return@custom false - - classDef.virtualMethods.first().let { isNotPremiumMethod -> - isNotPremiumMethod.parameterTypes.size == 0 && isNotPremiumMethod.returnType == "Z" - } - } -) \ No newline at end of file diff --git a/src/main/kotlin/app/revanced/patches/pixiv/ads/fingerprints/ShouldShowAdsFingerprint.kt b/src/main/kotlin/app/revanced/patches/pixiv/ads/fingerprints/ShouldShowAdsFingerprint.kt new file mode 100644 index 000000000..cd8d303bc --- /dev/null +++ b/src/main/kotlin/app/revanced/patches/pixiv/ads/fingerprints/ShouldShowAdsFingerprint.kt @@ -0,0 +1,14 @@ +package app.revanced.patches.pixiv.ads.fingerprints + +import app.revanced.patcher.extensions.or +import app.revanced.patcher.fingerprint.MethodFingerprint +import com.android.tools.smali.dexlib2.AccessFlags + + +internal object ShouldShowAdsFingerprint : MethodFingerprint( + "Z", + AccessFlags.PUBLIC or AccessFlags.FINAL, + customFingerprint = { methodDef, classDef -> + classDef.type.endsWith("AdUtils;") && methodDef.name == "shouldShowAds" + } +) \ No newline at end of file