fix(YouTube - Client spoof): Spoof iOS client model to fix various side effects (#638)

Co-authored-by: LisoUseInAIKyrios <118716522+LisoUseInAIKyrios@users.noreply.github.com>
This commit is contained in:
oSumAtrIX 2024-05-23 22:42:15 +02:00 committed by GitHub
parent 1b82e985b6
commit fcff9a2049
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 27 additions and 10 deletions

View File

@ -59,7 +59,7 @@ public class Utils {
} }
/** /**
* @return The version name of the app, such as "YouTube". * @return The version name of the app, such as 19.11.43
*/ */
public static String getAppVersionName() { public static String getAppVersionName() {
if (versionName == null) { if (versionName == null) {

View File

@ -4,6 +4,7 @@ import static app.revanced.integrations.youtube.patches.spoof.requests.Storyboar
import android.net.Uri; import android.net.Uri;
import android.os.Build;
import androidx.annotation.Nullable; import androidx.annotation.Nullable;
import java.util.Collections; import java.util.Collections;
@ -22,8 +23,8 @@ import app.revanced.integrations.youtube.settings.Settings;
@SuppressWarnings("unused") @SuppressWarnings("unused")
public class SpoofClientPatch { public class SpoofClientPatch {
private static final boolean SPOOF_CLIENT_ENABLED = Settings.SPOOF_CLIENT.get(); private static final boolean SPOOF_CLIENT_ENABLED = Settings.SPOOF_CLIENT.get();
private static final boolean SPOOF_CLIENT_USE_IOS = Settings.SPOOF_CLIENT_USE_IOS.get(); private static final boolean SPOOF_CLIENT_USE_TEST_SUITE = Settings.SPOOF_CLIENT_USE_TESTSUITE.get();
private static final boolean SPOOF_CLIENT_STORYBOARD = SPOOF_CLIENT_ENABLED && !SPOOF_CLIENT_USE_IOS; private static final boolean SPOOF_CLIENT_STORYBOARD = SPOOF_CLIENT_ENABLED && SPOOF_CLIENT_USE_TEST_SUITE;
/** /**
* Any unreachable ip address. Used to intentionally fail requests. * Any unreachable ip address. Used to intentionally fail requests.
@ -46,10 +47,10 @@ public class SpoofClientPatch {
/** /**
* Injection point. * Injection point.
* Blocks /get_watch requests by returning a localhost URI. * Blocks /get_watch requests by returning an unreachable URI.
* *
* @param playerRequestUri The URI of the player request. * @param playerRequestUri The URI of the player request.
* @return Localhost URI if the request is a /get_watch request, otherwise the original URI. * @return An unreachable URI if the request is a /get_watch request, otherwise the original URI.
*/ */
public static Uri blockGetWatchRequest(Uri playerRequestUri) { public static Uri blockGetWatchRequest(Uri playerRequestUri) {
if (SPOOF_CLIENT_ENABLED) { if (SPOOF_CLIENT_ENABLED) {
@ -102,7 +103,7 @@ public class SpoofClientPatch {
} }
private static ClientType getSpoofClientType() { private static ClientType getSpoofClientType() {
if (SPOOF_CLIENT_USE_IOS) { if (!SPOOF_CLIENT_USE_TEST_SUITE) {
return ClientType.IOS; return ClientType.IOS;
} }
@ -147,6 +148,17 @@ public class SpoofClientPatch {
return originalClientVersion; return originalClientVersion;
} }
/**
* Injection point.
*/
public static String getClientModel(String originalClientModel) {
if (SPOOF_CLIENT_ENABLED) {
return getSpoofClientType().model;
}
return originalClientModel;
}
/** /**
* Injection point. * Injection point.
*/ */
@ -250,14 +262,19 @@ public class SpoofClientPatch {
} }
private enum ClientType { private enum ClientType {
ANDROID_TESTSUITE(30, "1.9"), ANDROID_TESTSUITE(30, Build.MODEL, "1.9"),
IOS(5, Utils.getAppVersionName()); // 16,2 = iPhone 15 Pro Max.
// Version number should be a valid iOS release.
// https://www.ipa4fun.com/history/185230
IOS(5, "iPhone16,2", "19.10.7");
final int id; final int id;
final String model;
final String version; final String version;
ClientType(int id, String version) { ClientType(int id, String model, String version) {
this.id = id; this.id = id;
this.model = model;
this.version = version; this.version = version;
} }
} }

View File

@ -237,7 +237,7 @@ public class Settings extends BaseSettings {
public static final BooleanSetting BYPASS_URL_REDIRECTS = new BooleanSetting("revanced_bypass_url_redirects", TRUE); public static final BooleanSetting BYPASS_URL_REDIRECTS = new BooleanSetting("revanced_bypass_url_redirects", TRUE);
public static final BooleanSetting ANNOUNCEMENTS = new BooleanSetting("revanced_announcements", TRUE); public static final BooleanSetting ANNOUNCEMENTS = new BooleanSetting("revanced_announcements", TRUE);
public static final BooleanSetting SPOOF_CLIENT = new BooleanSetting("revanced_spoof_client", TRUE, true, "revanced_spoof_client_user_dialog_message"); public static final BooleanSetting SPOOF_CLIENT = new BooleanSetting("revanced_spoof_client", TRUE, true, "revanced_spoof_client_user_dialog_message");
public static final BooleanSetting SPOOF_CLIENT_USE_IOS = new BooleanSetting("revanced_spoof_client_use_ios", FALSE, true, parent(SPOOF_CLIENT)); public static final BooleanSetting SPOOF_CLIENT_USE_TESTSUITE = new BooleanSetting("revanced_spoof_client_use_testsuite", FALSE, true, parent(SPOOF_CLIENT));
@Deprecated @Deprecated
public static final StringSetting DEPRECATED_ANNOUNCEMENT_LAST_HASH = new StringSetting("revanced_announcement_last_hash", ""); public static final StringSetting DEPRECATED_ANNOUNCEMENT_LAST_HASH = new StringSetting("revanced_announcement_last_hash", "");
public static final IntegerSetting ANNOUNCEMENT_LAST_ID = new IntegerSetting("revanced_announcement_last_id", -1); public static final IntegerSetting ANNOUNCEMENT_LAST_ID = new IntegerSetting("revanced_announcement_last_id", -1);