[YouTube] Fetch the ANDROID client for ended/post livestreams
The ANDROID client was only fetched for video contents, where it can be useful on ended/post livestreams, if the n parameter of the WEB client cannot be decrypted, to avoid throttling issues (because the WEB client was only used before for ended/post livestreams). It also provides an exclusive 48kbps M4A audio format in the adaptiveFormats array of the JSON player response, like other mobile clients (which can be also extracted from the response of the DASH manifest URL returned into the WEB client player's response, but the DASH manifest is not used by the extractor). A note about non-fatality of fetching or parsing issues of the ANDROID and IOS clients has been added.
This commit is contained in:
parent
a26bcc55c4
commit
090debd83b
1 changed files with 8 additions and 1 deletions
|
@ -823,11 +823,16 @@ public class YoutubeStreamExtractor extends StreamExtractor {
|
||||||
.getBytes(StandardCharsets.UTF_8);
|
.getBytes(StandardCharsets.UTF_8);
|
||||||
nextResponse = getJsonPostResponse(NEXT, body, localization);
|
nextResponse = getJsonPostResponse(NEXT, body, localization);
|
||||||
|
|
||||||
if ((!isAgeRestricted && streamType == StreamType.VIDEO_STREAM)
|
// streamType can only have LIVE_STREAM, POST_LIVE_STREAM and VIDEO_STREAM values (see
|
||||||
|
// setStreamType()), so this block will be run only for POST_LIVE_STREAM and VIDEO_STREAM
|
||||||
|
// values if fetching of the ANDROID client is not forced
|
||||||
|
if ((!isAgeRestricted && streamType != StreamType.LIVE_STREAM)
|
||||||
|| isAndroidClientFetchForced) {
|
|| isAndroidClientFetchForced) {
|
||||||
try {
|
try {
|
||||||
fetchAndroidMobileJsonPlayer(contentCountry, localization, videoId);
|
fetchAndroidMobileJsonPlayer(contentCountry, localization, videoId);
|
||||||
} catch (final Exception ignored) {
|
} catch (final Exception ignored) {
|
||||||
|
// Ignore exceptions related to ANDROID client fetch or parsing, as it is not
|
||||||
|
// compulsory to play contents
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -836,6 +841,8 @@ public class YoutubeStreamExtractor extends StreamExtractor {
|
||||||
try {
|
try {
|
||||||
fetchIosMobileJsonPlayer(contentCountry, localization, videoId);
|
fetchIosMobileJsonPlayer(contentCountry, localization, videoId);
|
||||||
} catch (final Exception ignored) {
|
} catch (final Exception ignored) {
|
||||||
|
// Ignore exceptions related to IOS client fetch or parsing, as it is not
|
||||||
|
// compulsory to play contents
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue