mirror of
				https://github.com/TeamNewPipe/NewPipe
				synced 2025-10-25 12:27:38 +00:00 
			
		
		
		
	better detection for livestreams
This commit is contained in:
		| @@ -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(); | ||||
|         } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Christian Schabesberger
					Christian Schabesberger