mirror of
https://github.com/TeamNewPipe/NewPipe
synced 2025-01-11 18:00:32 +00:00
better detection for livestreams
This commit is contained in:
parent
851028997a
commit
e08aa14eab
@ -191,14 +191,17 @@ public class YoutubeStreamExtractor implements StreamExtractor {
|
||||
JSONObject ytPlayerConfig;
|
||||
|
||||
//attempt to load the youtube js player JSON arguments
|
||||
String ps = ""; //used to determine if this is a livestream or not
|
||||
boolean isLiveStream = false; //used to determine if this is a livestream or not
|
||||
try {
|
||||
ytPlayerConfigRaw =
|
||||
Parser.matchGroup1("ytplayer.config\\s*=\\s*(\\{.*?\\});", pageContent);
|
||||
ytPlayerConfig = new JSONObject(ytPlayerConfigRaw);
|
||||
playerArgs = ytPlayerConfig.getJSONObject("args");
|
||||
if(playerArgs.has("ps")) {
|
||||
ps = playerArgs.get("ps").toString();
|
||||
|
||||
// check if we have a live stream. We need to filter it, since its not yet supported.
|
||||
if((playerArgs.has("ps") && playerArgs.get("ps").toString().equals("live"))
|
||||
|| (playerArgs.get("url_encoded_fmt_stream_map").toString().isEmpty())) {
|
||||
isLiveStream = true;
|
||||
}
|
||||
} catch (Parser.RegexException e) {
|
||||
String errorReason = findErrorReason(doc);
|
||||
@ -213,7 +216,7 @@ public class YoutubeStreamExtractor implements StreamExtractor {
|
||||
} catch (JSONException e) {
|
||||
throw new ParsingException("Could not parse yt player config", e);
|
||||
}
|
||||
if (ps.equals("live")) {
|
||||
if (isLiveStream) {
|
||||
throw new LiveStreamException();
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user