mirror of
https://github.com/revanced/revanced-patches
synced 2024-12-05 03:32:53 +01:00
feat(youtube): remove patch open-links-directly
The patch did not serve any real purpose Signed-off-by: oSumAtrIX <johan.melkonyan1@web.de>
This commit is contained in:
parent
a673514f84
commit
79291a0d34
@ -1,13 +0,0 @@
|
|||||||
package app.revanced.patches.youtube.misc.openlinksdirectly.annotations
|
|
||||||
|
|
||||||
import app.revanced.patcher.annotation.Compatibility
|
|
||||||
import app.revanced.patcher.annotation.Package
|
|
||||||
|
|
||||||
@Compatibility(
|
|
||||||
[Package(
|
|
||||||
"com.google.android.youtube", arrayOf("17.49.37", "18.03.36")
|
|
||||||
)]
|
|
||||||
)
|
|
||||||
@Target(AnnotationTarget.CLASS)
|
|
||||||
@Retention(AnnotationRetention.RUNTIME)
|
|
||||||
internal annotation class OpenLinksDirectlyCompatibility
|
|
@ -1,19 +0,0 @@
|
|||||||
package app.revanced.patches.youtube.misc.openlinksdirectly.fingerprints
|
|
||||||
|
|
||||||
import app.revanced.patcher.extensions.or
|
|
||||||
import app.revanced.patcher.fingerprint.method.impl.MethodFingerprint
|
|
||||||
import app.revanced.patches.youtube.misc.openlinksdirectly.annotations.OpenLinksDirectlyCompatibility
|
|
||||||
import org.jf.dexlib2.AccessFlags
|
|
||||||
import org.jf.dexlib2.Opcode
|
|
||||||
|
|
||||||
@OpenLinksDirectlyCompatibility
|
|
||||||
object OpenLinksDirectlyPrimaryFingerprint : MethodFingerprint(
|
|
||||||
"L", AccessFlags.PUBLIC or AccessFlags.FINAL, listOf("L"), listOf(
|
|
||||||
Opcode.INVOKE_STATIC,
|
|
||||||
Opcode.MOVE_RESULT_OBJECT,
|
|
||||||
Opcode.RETURN_OBJECT,
|
|
||||||
Opcode.CHECK_CAST,
|
|
||||||
Opcode.SGET,
|
|
||||||
Opcode.SGET_OBJECT
|
|
||||||
)
|
|
||||||
)
|
|
@ -1,14 +0,0 @@
|
|||||||
package app.revanced.patches.youtube.misc.openlinksdirectly.fingerprints
|
|
||||||
|
|
||||||
import app.revanced.patcher.extensions.or
|
|
||||||
import app.revanced.patcher.fingerprint.method.impl.MethodFingerprint
|
|
||||||
import app.revanced.patches.youtube.misc.openlinksdirectly.annotations.OpenLinksDirectlyCompatibility
|
|
||||||
import org.jf.dexlib2.AccessFlags
|
|
||||||
import org.jf.dexlib2.Opcode
|
|
||||||
|
|
||||||
@OpenLinksDirectlyCompatibility
|
|
||||||
object OpenLinksDirectlySecondaryFingerprint : MethodFingerprint(
|
|
||||||
"L", AccessFlags.PUBLIC or AccessFlags.STATIC, listOf("L"), listOf(
|
|
||||||
Opcode.INVOKE_STATIC, Opcode.MOVE_RESULT_OBJECT
|
|
||||||
), listOf("://")
|
|
||||||
)
|
|
@ -1,61 +0,0 @@
|
|||||||
package app.revanced.patches.youtube.misc.openlinksdirectly.patch
|
|
||||||
|
|
||||||
import app.revanced.extensions.toErrorResult
|
|
||||||
import app.revanced.patcher.annotation.Description
|
|
||||||
import app.revanced.patcher.annotation.Name
|
|
||||||
import app.revanced.patcher.annotation.Version
|
|
||||||
import app.revanced.patcher.data.BytecodeContext
|
|
||||||
import app.revanced.patcher.extensions.instruction
|
|
||||||
import app.revanced.patcher.extensions.replaceInstruction
|
|
||||||
import app.revanced.patcher.patch.BytecodePatch
|
|
||||||
import app.revanced.patcher.patch.PatchResult
|
|
||||||
import app.revanced.patcher.patch.PatchResultSuccess
|
|
||||||
import app.revanced.patcher.patch.annotations.DependsOn
|
|
||||||
import app.revanced.patcher.patch.annotations.Patch
|
|
||||||
import app.revanced.patches.shared.settings.preference.impl.StringResource
|
|
||||||
import app.revanced.patches.shared.settings.preference.impl.SwitchPreference
|
|
||||||
import app.revanced.patches.youtube.misc.integrations.patch.IntegrationsPatch
|
|
||||||
import app.revanced.patches.youtube.misc.openlinksdirectly.annotations.OpenLinksDirectlyCompatibility
|
|
||||||
import app.revanced.patches.youtube.misc.openlinksdirectly.fingerprints.OpenLinksDirectlyPrimaryFingerprint
|
|
||||||
import app.revanced.patches.youtube.misc.openlinksdirectly.fingerprints.OpenLinksDirectlySecondaryFingerprint
|
|
||||||
import app.revanced.patches.youtube.misc.settings.bytecode.patch.SettingsPatch
|
|
||||||
import org.jf.dexlib2.iface.instruction.formats.Instruction35c
|
|
||||||
|
|
||||||
@Patch
|
|
||||||
@DependsOn([IntegrationsPatch::class, SettingsPatch::class])
|
|
||||||
@Name("open-links-directly")
|
|
||||||
@Description("Skips over redirection URLs to external links.")
|
|
||||||
@OpenLinksDirectlyCompatibility
|
|
||||||
@Version("0.0.1")
|
|
||||||
class OpenLinksDirectlyPatch : BytecodePatch(
|
|
||||||
listOf(OpenLinksDirectlyPrimaryFingerprint, OpenLinksDirectlySecondaryFingerprint)
|
|
||||||
) {
|
|
||||||
override fun execute(context: BytecodeContext): PatchResult {
|
|
||||||
SettingsPatch.PreferenceScreen.MISC.addPreferences(
|
|
||||||
SwitchPreference(
|
|
||||||
"revanced_uri_redirect",
|
|
||||||
StringResource("revanced_uri_redirect_title", "Bypass URL redirects"),
|
|
||||||
true,
|
|
||||||
StringResource("revanced_uri_redirect_summary_on", "Bypassing URL redirects"),
|
|
||||||
StringResource("revanced_uri_redirect_summary_off", "Following default redirect policy")
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
arrayOf(OpenLinksDirectlyPrimaryFingerprint, OpenLinksDirectlySecondaryFingerprint)
|
|
||||||
.map { it.result ?: return it.toErrorResult() }
|
|
||||||
.forEach { result ->
|
|
||||||
result.mutableMethod.apply {
|
|
||||||
val insertIndex = result.scanResult.patternScanResult!!.startIndex
|
|
||||||
val uriRegister = (instruction(insertIndex) as Instruction35c).registerC
|
|
||||||
replaceInstruction(
|
|
||||||
insertIndex,
|
|
||||||
"invoke-static {v$uriRegister}," +
|
|
||||||
"Lapp/revanced/integrations/patches/OpenLinksDirectlyPatch;" +
|
|
||||||
"->" +
|
|
||||||
"parseRedirectUri(Ljava/lang/String;)Landroid/net/Uri;"
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return PatchResultSuccess()
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user