Skip to content
This repository has been archived by the owner on Oct 26, 2024. It is now read-only.

Commit

Permalink
fix(YouTube - Video Id): Fix video id not showing the currently playi…
Browse files Browse the repository at this point in the history
…ng video (#484)

Co-authored-by: oSumAtrIX <[email protected]>
  • Loading branch information
LisoUseInAIKyrios and oSumAtrIX authored Sep 28, 2023
1 parent 4b256f5 commit da923a3
Show file tree
Hide file tree
Showing 2 changed files with 56 additions and 20 deletions.
Original file line number Diff line number Diff line change
@@ -1,16 +1,15 @@
package app.revanced.integrations.patches;

import androidx.annotation.NonNull;

import java.lang.ref.WeakReference;
import java.lang.reflect.Method;
import java.util.Objects;

import app.revanced.integrations.patches.playback.speed.RememberPlaybackSpeedPatch;
import app.revanced.integrations.shared.VideoState;
import app.revanced.integrations.utils.LogHelper;
import app.revanced.integrations.utils.ReVancedUtils;

import java.lang.ref.WeakReference;
import java.lang.reflect.Method;
import java.util.Objects;

/**
* Hooking class for the current playing video.
*/
Expand All @@ -25,6 +24,10 @@ public final class VideoInformation {
private static String videoId = "";
private static long videoLength = 0;
private static long videoTime = -1;

@NonNull
private static volatile String playerResponseVideoId = "";

/**
* The current playback speed
*/
Expand Down Expand Up @@ -61,6 +64,18 @@ public static void setVideoId(@NonNull String newlyLoadedVideoId) {
}
}

/**
* Injection point. Called off the main thread.
*
* @param videoId The id of the last video loaded.
*/
public static void setPlayerResponseVideoId(@NonNull String videoId) {
if (!playerResponseVideoId.equals(videoId)) {
LogHelper.printDebug(() -> "New player response video id: " + videoId);
playerResponseVideoId = videoId;
}
}

/**
* Injection point.
* Called when user selects a playback speed.
Expand Down Expand Up @@ -141,6 +156,22 @@ public static String getVideoId() {
return videoId;
}

/**
* Differs from {@link #videoId} as this is the video id for the
* last player response received, which may not be the current video playing.
*
* If Shorts are loading the background, this commonly will be
* different from the Short that is currently on screen.
*
* For most use cases, you should instead use {@link #getVideoId()}.
*
* @return The id of the last video loaded. Empty string if not set yet.
*/
@NonNull
public static String getPlayerResponseVideoId() {
return playerResponseVideoId;
}

/**
* @return The current playback speed.
*/
Expand Down
Original file line number Diff line number Diff line change
@@ -1,19 +1,20 @@
package app.revanced.integrations.patches.spoof;

import static app.revanced.integrations.patches.spoof.requests.StoryboardRendererRequester.getStoryboardRenderer;
import static app.revanced.integrations.utils.ReVancedUtils.containsAny;

import androidx.annotation.Nullable;
import app.revanced.integrations.patches.VideoInformation;
import app.revanced.integrations.settings.SettingsEnum;
import app.revanced.integrations.shared.PlayerType;
import app.revanced.integrations.utils.LogHelper;
import app.revanced.integrations.utils.ReVancedUtils;

import java.util.concurrent.ExecutionException;
import java.util.concurrent.Future;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.TimeoutException;

import static app.revanced.integrations.patches.spoof.requests.StoryboardRendererRequester.getStoryboardRenderer;
import static app.revanced.integrations.utils.ReVancedUtils.containsAny;
import app.revanced.integrations.patches.VideoInformation;
import app.revanced.integrations.settings.SettingsEnum;
import app.revanced.integrations.shared.PlayerType;
import app.revanced.integrations.utils.LogHelper;
import app.revanced.integrations.utils.ReVancedUtils;

/** @noinspection unused*/
public class SpoofSignaturePatch {
Expand Down Expand Up @@ -46,7 +47,7 @@ public class SpoofSignaturePatch {
/**
* Last video id loaded. Used to prevent reloading the same spec multiple times.
*/
private static volatile String currentVideoId;
private static volatile String lastPlayerResponseVideoId;

private static volatile Future<StoryboardRenderer> rendererFuture;

Expand Down Expand Up @@ -83,7 +84,6 @@ public static String spoofParameter(String parameters) {
var isClip = parameters.length() > 150;
if (isClip) return parameters;


// Shorts do not need to be spoofed.
if (parameters.startsWith(SHORTS_PLAYER_PARAMETERS)) return parameters;

Expand All @@ -96,18 +96,23 @@ public static String spoofParameter(String parameters) {
// This will cause playback issues in the feed, but it's better than manipulating the history.
parameters;

String videoId = VideoInformation.getVideoId();
if (!videoId.equals(currentVideoId)) {
fetchStoryboardRenderer();

return INCOGNITO_PARAMETERS;
}

private static void fetchStoryboardRenderer() {
String videoId = VideoInformation.getPlayerResponseVideoId();
if (!videoId.equals(lastPlayerResponseVideoId)) {
rendererFuture = ReVancedUtils.submitOnBackgroundThread(() -> getStoryboardRenderer(videoId));
currentVideoId = videoId;
lastPlayerResponseVideoId = videoId;
}
// Occasionally when a new video is opened the video will be frozen a few seconds while the audio plays.
// Block until the fetch is completed. Without this, occasionally when a new video is opened
// the video will be frozen a few seconds while the audio plays.
// This is because the main thread is calling to get the storyboard but the fetch is not completed.
// To prevent this, call get() here and block until the fetch is completed.
// So later when the main thread calls to get the renderer it will never block as the future is done.
getRenderer();

return INCOGNITO_PARAMETERS;
}

/**
Expand Down

0 comments on commit da923a3

Please sign in to comment.