From c81850e6b3908735de2c94ab4265bb1b343a6424 Mon Sep 17 00:00:00 2001 From: LisoUseInAIKyrios <118716522+LisoUseInAIKyrios@users.noreply.github.com> Date: Sun, 2 Jul 2023 12:25:59 +0400 Subject: [PATCH] fix(youtube/spoof-signature-verification): remove auto re-enable functionality (#2556) --- .../OpenCronetDataSourceFingerprint.kt | 17 --------------- .../patch/SpoofSignatureVerificationPatch.kt | 21 ------------------- 2 files changed, 38 deletions(-) delete mode 100644 src/main/kotlin/app/revanced/patches/youtube/misc/fix/playback/fingerprints/OpenCronetDataSourceFingerprint.kt diff --git a/src/main/kotlin/app/revanced/patches/youtube/misc/fix/playback/fingerprints/OpenCronetDataSourceFingerprint.kt b/src/main/kotlin/app/revanced/patches/youtube/misc/fix/playback/fingerprints/OpenCronetDataSourceFingerprint.kt deleted file mode 100644 index 559ab0ea09..0000000000 --- a/src/main/kotlin/app/revanced/patches/youtube/misc/fix/playback/fingerprints/OpenCronetDataSourceFingerprint.kt +++ /dev/null @@ -1,17 +0,0 @@ -package app.revanced.patches.youtube.misc.fix.playback.fingerprints - -import app.revanced.patcher.fingerprint.method.impl.MethodFingerprint -import org.jf.dexlib2.Opcode - -// Resolves to the method CronetDataSource.open -// https://androidx.tech/artifacts/media3/media3-datasource-cronet/1.0.0-alpha03-source/androidx/media3/datasource/cronet/CronetDataSource.java.html -object OpenCronetDataSourceFingerprint : MethodFingerprint( - opcodes = listOf( - Opcode.MOVE_RESULT, - Opcode.INVOKE_VIRTUAL, - Opcode.MOVE_RESULT_OBJECT, - ), - strings = listOf( - "err_cleartext_not_permitted", - ), -) \ No newline at end of file diff --git a/src/main/kotlin/app/revanced/patches/youtube/misc/fix/playback/patch/SpoofSignatureVerificationPatch.kt b/src/main/kotlin/app/revanced/patches/youtube/misc/fix/playback/patch/SpoofSignatureVerificationPatch.kt index 4b5f74285c..5bdb30c24e 100644 --- a/src/main/kotlin/app/revanced/patches/youtube/misc/fix/playback/patch/SpoofSignatureVerificationPatch.kt +++ b/src/main/kotlin/app/revanced/patches/youtube/misc/fix/playback/patch/SpoofSignatureVerificationPatch.kt @@ -7,7 +7,6 @@ import app.revanced.patcher.annotation.Version import app.revanced.patcher.data.BytecodeContext import app.revanced.patcher.data.toMethodWalker import app.revanced.patcher.extensions.InstructionExtensions.addInstructions -import app.revanced.patcher.extensions.InstructionExtensions.getInstruction import app.revanced.patcher.patch.BytecodePatch import app.revanced.patcher.patch.PatchResult import app.revanced.patcher.patch.PatchResultSuccess @@ -15,12 +14,10 @@ import app.revanced.patcher.patch.annotations.DependsOn import app.revanced.patcher.util.proxy.mutableTypes.MutableMethod import app.revanced.patches.shared.settings.preference.impl.StringResource import app.revanced.patches.shared.settings.preference.impl.SwitchPreference -import app.revanced.patches.youtube.misc.fix.playback.fingerprints.OpenCronetDataSourceFingerprint import app.revanced.patches.youtube.misc.fix.playback.fingerprints.ProtobufParameterBuilderFingerprint import app.revanced.patches.youtube.misc.integrations.patch.IntegrationsPatch import app.revanced.patches.youtube.misc.playertype.patch.PlayerTypeHookPatch import app.revanced.patches.youtube.misc.settings.bytecode.patch.SettingsPatch -import org.jf.dexlib2.iface.instruction.OneRegisterInstruction @Name("spoof-signature-verification") @Description("Spoofs a patched client to prevent playback issues.") @@ -33,7 +30,6 @@ import org.jf.dexlib2.iface.instruction.OneRegisterInstruction class SpoofSignatureVerificationPatch : BytecodePatch( listOf( ProtobufParameterBuilderFingerprint, - OpenCronetDataSourceFingerprint, ) ) { override fun execute(context: BytecodeContext): PatchResult { @@ -72,23 +68,6 @@ class SpoofSignatureVerificationPatch : BytecodePatch( } } ?: return ProtobufParameterBuilderFingerprint.toErrorResult() - // hook video playback result - OpenCronetDataSourceFingerprint.result?.let { - it.mutableMethod.apply { - val getHeadersInstructionIndex = it.scanResult.patternScanResult!!.endIndex - val responseCodeRegister = - (getInstruction(getHeadersInstructionIndex - 2) as OneRegisterInstruction).registerA - - addInstructions( - getHeadersInstructionIndex + 1, - """ - invoke-static {v$responseCodeRegister}, $INTEGRATIONS_CLASS_DESCRIPTOR->onResponse(I)V - """ - ) - } - - } ?: return OpenCronetDataSourceFingerprint.toErrorResult() - return PatchResultSuccess() }