summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorÉmilien (perso) <4016501+unixfox@users.noreply.github.com>2024-09-20 00:19:13 +0200
committerGitHub <noreply@github.com>2024-09-20 00:19:13 +0200
commitd9df90b5e3ab6f738907c1bfaf96f0407368d842 (patch)
tree408c14ad510e93c0b2b917413fce97af644feb69
parentcec3cfba774926100095246d80be401155df2f68 (diff)
downloadinvidious-d9df90b5e3ab6f738907c1bfaf96f0407368d842.tar.gz
invidious-d9df90b5e3ab6f738907c1bfaf96f0407368d842.tar.bz2
invidious-d9df90b5e3ab6f738907c1bfaf96f0407368d842.zip
use WEB_CREATOR when po_token with WEB_EMBED as a fallback (#4928)
* use WEB_CREATOR when po_token with WEB_EMBEDDED_PLAYER as a fallback * remove unrelated comment Co-authored-by: syeopite <70992037+syeopite@users.noreply.github.com> --------- Co-authored-by: syeopite <70992037+syeopite@users.noreply.github.com>
-rw-r--r--src/invidious/videos/parser.cr25
-rw-r--r--src/invidious/yt_backend/youtube_api.cr12
2 files changed, 29 insertions, 8 deletions
diff --git a/src/invidious/videos/parser.cr b/src/invidious/videos/parser.cr
index 95fa3d79..ca6500ed 100644
--- a/src/invidious/videos/parser.cr
+++ b/src/invidious/videos/parser.cr
@@ -53,6 +53,10 @@ end
def extract_video_info(video_id : String)
# Init client config for the API
client_config = YoutubeAPI::ClientConfig.new
+ # Use the WEB_CREATOR when po_token is configured because it fully only works on this client
+ if CONFIG.po_token
+ client_config.client_type = YoutubeAPI::ClientType::WebCreator
+ end
# Fetch data from the player endpoint
player_response = YoutubeAPI.player(video_id: video_id, params: "2AMB", client_config: client_config)
@@ -102,6 +106,13 @@ def extract_video_info(video_id : String)
new_player_response = nil
+ # Second try in case WEB_EMBEDDED_PLAYER doesn't work with po_token.
+ # Only trigger if reason found and po_token configured.
+ if reason && CONFIG.po_token
+ client_config.client_type = YoutubeAPI::ClientType::WebEmbeddedPlayer
+ new_player_response = try_fetch_streaming_data(video_id, client_config)
+ end
+
# Don't use Android client if po_token is passed because po_token doesn't
# work for Android client.
if reason.nil? && CONFIG.po_token.nil?
@@ -114,10 +125,9 @@ def extract_video_info(video_id : String)
end
# Last hope
- # Only trigger if reason found and po_token or didn't work wth Android client.
- # TvHtml5ScreenEmbed now requires sig helper for it to work but po_token is not required
- # if the IP address is not blocked.
- if CONFIG.po_token && reason || CONFIG.po_token.nil? && new_player_response.nil?
+ # Only trigger if reason found or didn't work wth Android client.
+ # TvHtml5ScreenEmbed now requires sig helper for it to work but doesn't work with po_token.
+ if reason && CONFIG.po_token.nil?
client_config.client_type = YoutubeAPI::ClientType::TvHtml5ScreenEmbed
new_player_response = try_fetch_streaming_data(video_id, client_config)
end
@@ -185,10 +195,11 @@ def parse_video_info(video_id : String, player_response : Hash(String, JSON::Any
end
video_details = player_response.dig?("videoDetails")
- microformat = player_response.dig?("microformat", "playerMicroformatRenderer")
+ if !(microformat = player_response.dig?("microformat", "playerMicroformatRenderer"))
+ microformat = {} of String => JSON::Any
+ end
raise BrokenTubeException.new("videoDetails") if !video_details
- raise BrokenTubeException.new("microformat") if !microformat
# Basic video infos
@@ -225,7 +236,7 @@ def parse_video_info(video_id : String, player_response : Hash(String, JSON::Any
.try &.as_a.map &.as_s || [] of String
allow_ratings = video_details["allowRatings"]?.try &.as_bool
- family_friendly = microformat["isFamilySafe"].try &.as_bool
+ family_friendly = microformat["isFamilySafe"]?.try &.as_bool
is_listed = video_details["isCrawlable"]?.try &.as_bool
is_upcoming = video_details["isUpcoming"]?.try &.as_bool
diff --git a/src/invidious/yt_backend/youtube_api.cr b/src/invidious/yt_backend/youtube_api.cr
index d66bf7aa..99ec6e63 100644
--- a/src/invidious/yt_backend/youtube_api.cr
+++ b/src/invidious/yt_backend/youtube_api.cr
@@ -29,6 +29,7 @@ module YoutubeAPI
WebEmbeddedPlayer
WebMobile
WebScreenEmbed
+ WebCreator
Android
AndroidEmbeddedPlayer
@@ -80,6 +81,14 @@ module YoutubeAPI
os_version: WINDOWS_VERSION,
platform: "DESKTOP",
},
+ ClientType::WebCreator => {
+ name: "WEB_CREATOR",
+ name_proto: "62",
+ version: "1.20220918",
+ os_name: "Windows",
+ os_version: WINDOWS_VERSION,
+ platform: "DESKTOP",
+ },
# Android
@@ -291,8 +300,9 @@ module YoutubeAPI
end
if client_config.screen == "EMBED"
+ # embedUrl https://www.google.com allow loading almost all video that are configured not embeddable
client_context["thirdParty"] = {
- "embedUrl" => "https://www.youtube.com/embed/#{video_id}",
+ "embedUrl" => "https://www.google.com/",
} of String => String | Int64
end