mirror of
https://github.com/iv-org/invidious.git
synced 2025-07-30 09:18:28 +00:00
Workaround: Make invidious use HTML5 innertube client if the Android client fails
This commit is contained in:
parent
99a5e9cbc4
commit
1e338a51c8
@ -102,6 +102,7 @@ def extract_video_info(video_id : String, proxy_region : String? = nil)
|
|||||||
|
|
||||||
new_player_response = nil
|
new_player_response = nil
|
||||||
|
|
||||||
|
begin
|
||||||
if reason.nil?
|
if reason.nil?
|
||||||
# Fetch the video streams using an Android client in order to get the
|
# Fetch the video streams using an Android client in order to get the
|
||||||
# decrypted URLs and maybe fix throttling issues (#2194). See the
|
# decrypted URLs and maybe fix throttling issues (#2194). See the
|
||||||
@ -114,6 +115,13 @@ def extract_video_info(video_id : String, proxy_region : String? = nil)
|
|||||||
client_config.client_type = YoutubeAPI::ClientType::AndroidScreenEmbed
|
client_config.client_type = YoutubeAPI::ClientType::AndroidScreenEmbed
|
||||||
new_player_response = try_fetch_streaming_data(video_id, client_config)
|
new_player_response = try_fetch_streaming_data(video_id, client_config)
|
||||||
end
|
end
|
||||||
|
rescue VideoNotAvailableException
|
||||||
|
# YouTube returns the "Video Not Available" video data instead of the
|
||||||
|
# video itself, but not on HTML5
|
||||||
|
Log.warn { "YouTube's Android client did not return the video we were looking for, Falling back on HTML5 client" }
|
||||||
|
client_config.client_type = YoutubeAPI::ClientType::TvHtml5ScreenEmbed
|
||||||
|
new_player_response = try_fetch_streaming_data(video_id, client_config)
|
||||||
|
end
|
||||||
|
|
||||||
# Last hope
|
# Last hope
|
||||||
if new_player_response.nil?
|
if new_player_response.nil?
|
||||||
|
Loading…
Reference in New Issue
Block a user