From 18c9a2d5af9c3cc09846778cfe9587f788fe4e11 Mon Sep 17 00:00:00 2001 From: LisoUseInAIKyrios <118716522+LisoUseInAIKyrios@users.noreply.github.com> Date: Wed, 8 Jan 2025 16:40:44 +0100 Subject: [PATCH 1/2] fix(YouTube - Spoof video streams): Resolve playback issues after changing from cellular to wifi --- .../extension/shared/spoof/SpoofVideoStreamsPatch.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/SpoofVideoStreamsPatch.java b/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/SpoofVideoStreamsPatch.java index 9554bdfaac..225f5c6b9a 100644 --- a/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/SpoofVideoStreamsPatch.java +++ b/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/SpoofVideoStreamsPatch.java @@ -77,9 +77,9 @@ public static String blockInitPlaybackRequest(String originalUrlString) { String path = originalUri.getPath(); if (path != null && path.contains("initplayback")) { - Logger.printDebug(() -> "Blocking 'initplayback' by returning unreachable url"); + Logger.printDebug(() -> "Blocking 'initplayback' by clearing query"); - return UNREACHABLE_HOST_URI_STRING; + return originalUri.buildUpon().clearQuery().build().toString(); } } catch (Exception ex) { Logger.printException(() -> "blockInitPlaybackRequest failure", ex); From 9fae57370192ffc962e5edc09df8fb9feed0dbaf Mon Sep 17 00:00:00 2001 From: LisoUseInAIKyrios <118716522+LisoUseInAIKyrios@users.noreply.github.com> Date: Wed, 8 Jan 2025 16:42:51 +0100 Subject: [PATCH 2/2] fix: Hide Android Creator from settings. Creator cannot play livestreams and does not fallback to other clients. --- .../extension/shared/spoof/ClientType.java | 27 ++++++++++--------- ...oofStreamingDataSideEffectsPreference.java | 5 ---- .../resources/addresources/values/arrays.xml | 2 -- .../resources/addresources/values/strings.xml | 1 - 4 files changed, 14 insertions(+), 21 deletions(-) diff --git a/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/ClientType.java b/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/ClientType.java index 2a1e4868e4..bfa5af526d 100644 --- a/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/ClientType.java +++ b/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/ClientType.java @@ -36,6 +36,20 @@ public enum ClientType { true, "Android TV" ), + // Cannot play livestreams and lacks HDR, but can play videos with music and labeled "for children". + ANDROID_CREATOR( + 14, + "ANDROID_CREATOR", + Build.MANUFACTURER, + Build.MODEL, + "Android", + "11", + "com.google.android.apps.youtube.creator/24.45.100 (Linux; U; Android 11) gzip", + "30", + "24.45.100", + true, + "Android Creator" + ), ANDROID_VR( ANDROID_VR_NO_AUTH.id, ANDROID_VR_NO_AUTH.clientName, @@ -76,19 +90,6 @@ public enum ClientType { forceAVC() ? "iOS TV Force AVC" : "iOS TV" - ), - ANDROID_CREATOR( - 14, - "ANDROID_CREATOR", - Build.MANUFACTURER, - Build.MODEL, - "Android", - "11", - "com.google.android.apps.youtube.creator/24.45.100 (Linux; U; Android 11) gzip", - "30", - "24.45.100", - true, - "Android Creator" ); private static boolean forceAVC() { diff --git a/extensions/youtube/src/main/java/app/revanced/extension/youtube/settings/preference/SpoofStreamingDataSideEffectsPreference.java b/extensions/youtube/src/main/java/app/revanced/extension/youtube/settings/preference/SpoofStreamingDataSideEffectsPreference.java index 0fc4283e2a..5d43cb81f2 100644 --- a/extensions/youtube/src/main/java/app/revanced/extension/youtube/settings/preference/SpoofStreamingDataSideEffectsPreference.java +++ b/extensions/youtube/src/main/java/app/revanced/extension/youtube/settings/preference/SpoofStreamingDataSideEffectsPreference.java @@ -87,11 +87,6 @@ private void updateUI() { // Android VR supports AV1 but all other clients do not. if (clientType != ClientType.ANDROID_VR && clientType != ClientType.ANDROID_VR_NO_AUTH) { summary += '\n' + str("revanced_spoof_video_streams_about_no_av1"); - - // Android Creator does not support HDR. - if (clientType == ClientType.ANDROID_CREATOR) { - summary += '\n' + str("revanced_spoof_video_streams_about_no_hdr"); - } } setTitle(title); diff --git a/patches/src/main/resources/addresources/values/arrays.xml b/patches/src/main/resources/addresources/values/arrays.xml index 3165e0a472..a8bf565d9f 100644 --- a/patches/src/main/resources/addresources/values/arrays.xml +++ b/patches/src/main/resources/addresources/values/arrays.xml @@ -116,7 +116,6 @@ Android VR @string/revanced_spoof_video_streams_client_type_android_vr_no_auth - Android Creator Android TV iOS TV @@ -124,7 +123,6 @@ ANDROID_VR ANDROID_VR_NO_AUTH - ANDROID_CREATOR ANDROID_UNPLUGGED IOS_UNPLUGGED diff --git a/patches/src/main/resources/addresources/values/strings.xml b/patches/src/main/resources/addresources/values/strings.xml index 2e4a803d7f..e9e78eac40 100644 --- a/patches/src/main/resources/addresources/values/strings.xml +++ b/patches/src/main/resources/addresources/values/strings.xml @@ -1396,7 +1396,6 @@ AVC has a maximum resolution of 1080p, Opus audio codec is not available, and vi • Stable volume is not available • Force original audio is not available" • No AV1 video codec - • No HDR video Show in Stats for nerds Client type is shown in Stats for nerds Client is hidden in Stats for nerds