Merge pull request #66 from karyogamy/subtitles_fix
Subtitles Extraction NPE Fix
This commit is contained in:
		
						commit
						4fb49d54b5
					
				
					 2 changed files with 18 additions and 18 deletions
				
			
		|  | @ -720,39 +720,41 @@ public class YoutubeStreamExtractor extends StreamExtractor { | ||||||
|         } catch (IOException | ExtractionException e) { |         } catch (IOException | ExtractionException e) { | ||||||
|             throw new SubtitlesException("Unable to download player configs", e); |             throw new SubtitlesException("Unable to download player configs", e); | ||||||
|         } |         } | ||||||
|         final String playerResponse = playerConfig.getObject("args").getString("player_response"); |         final String playerResponse = playerConfig.getObject("args", new JsonObject()) | ||||||
|  |                 .getString("player_response"); | ||||||
| 
 | 
 | ||||||
|         final JsonObject captions; |         final JsonObject captions; | ||||||
|         try { |         try { | ||||||
|             if (!JsonParser.object().from(playerResponse).has("captions")) { |             if (playerResponse == null || !JsonParser.object().from(playerResponse).has("captions")) { | ||||||
|                 // Captions does not exist |                 // Captions does not exist | ||||||
|                 return Collections.emptyList(); |                 return Collections.emptyList(); | ||||||
|             } |             } | ||||||
|             captions = JsonParser.object().from(playerResponse).getObject("captions"); |             captions = JsonParser.object().from(playerResponse).getObject("captions"); | ||||||
|         } catch (JsonParserException e) { |         } catch (JsonParserException e) { | ||||||
|             // Failed to parse subtitles |  | ||||||
|             throw new SubtitlesException("Unable to parse subtitles listing", e); |             throw new SubtitlesException("Unable to parse subtitles listing", e); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         final JsonObject renderer = captions.getObject("playerCaptionsTracklistRenderer"); |         final JsonObject renderer = captions.getObject("playerCaptionsTracklistRenderer", new JsonObject()); | ||||||
|         final JsonArray captionsArray = renderer.getArray("captionTracks"); |         final JsonArray captionsArray = renderer.getArray("captionTracks", new JsonArray()); | ||||||
| 
 |  | ||||||
|         // todo: use this to apply auto translation to different language from a source language |         // todo: use this to apply auto translation to different language from a source language | ||||||
|         final JsonArray autoCaptionsArray = renderer.getArray("translationLanguages"); |         final JsonArray autoCaptionsArray = renderer.getArray("translationLanguages", new JsonArray()); | ||||||
| 
 | 
 | ||||||
|  |         // This check is necessary since there may be cases where subtitles metadata do not contain caption track info | ||||||
|  |         // e.g. https://www.youtube.com/watch?v=-Vpwatutnko | ||||||
|         final int captionsSize = captionsArray.size(); |         final int captionsSize = captionsArray.size(); | ||||||
|         // Should not happen, if there is the "captions" object, it should always has some captions in it |  | ||||||
|         if(captionsSize == 0) return Collections.emptyList(); |         if(captionsSize == 0) return Collections.emptyList(); | ||||||
|         // Obtain the base url, this only needs to be done once |  | ||||||
| 
 | 
 | ||||||
|         List<SubtitlesInfo> result = new ArrayList<>(); |         List<SubtitlesInfo> result = new ArrayList<>(); | ||||||
|         for (int i = 0; i < captionsSize; i++) { |         for (int i = 0; i < captionsSize; i++) { | ||||||
|             final String languageCode = captionsArray.getObject(i).getString("languageCode"); |             final String languageCode = captionsArray.getObject(i).getString("languageCode"); | ||||||
|             final String baseUrl = captionsArray.getObject(i).getString("baseUrl"); |             final String baseUrl = captionsArray.getObject(i).getString("baseUrl"); | ||||||
|             final boolean isAutoGenerated = captionsArray.getObject(i).getString("vssId").startsWith("a."); |             final String vssId = captionsArray.getObject(i).getString("vssId"); | ||||||
| 
 | 
 | ||||||
|  |             if (languageCode != null && baseUrl != null && vssId != null) { | ||||||
|  |                 final boolean isAutoGenerated = vssId.startsWith("a."); | ||||||
|                 result.add(new SubtitlesInfo(baseUrl, languageCode, isAutoGenerated)); |                 result.add(new SubtitlesInfo(baseUrl, languageCode, isAutoGenerated)); | ||||||
|             } |             } | ||||||
|  |         } | ||||||
| 
 | 
 | ||||||
|         return result; |         return result; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -321,12 +321,6 @@ public class StreamInfo extends Info { | ||||||
|             streamInfo.addError(new ExtractionException("Couldn't get video only streams", e)); |             streamInfo.addError(new ExtractionException("Couldn't get video only streams", e)); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         try { |  | ||||||
|             streamInfo.setSubtitles(extractor.getSubtitlesDefault()); |  | ||||||
|         } catch (Exception e) { |  | ||||||
|             streamInfo.addError(new ExtractionException("Couldn't get subtitles", e)); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         // Lists can be null if a exception was thrown during extraction |         // Lists can be null if a exception was thrown during extraction | ||||||
|         if (streamInfo.getVideoStreams() == null) streamInfo.setVideoStreams(Collections.<VideoStream>emptyList()); |         if (streamInfo.getVideoStreams() == null) streamInfo.setVideoStreams(Collections.<VideoStream>emptyList()); | ||||||
|         if (streamInfo.getVideoOnlyStreams()== null) streamInfo.setVideoOnlyStreams(Collections.<VideoStream>emptyList()); |         if (streamInfo.getVideoOnlyStreams()== null) streamInfo.setVideoOnlyStreams(Collections.<VideoStream>emptyList()); | ||||||
|  | @ -425,7 +419,11 @@ public class StreamInfo extends Info { | ||||||
|         } catch (Exception e) { |         } catch (Exception e) { | ||||||
|             streamInfo.addError(e); |             streamInfo.addError(e); | ||||||
|         } |         } | ||||||
| 
 |         try { | ||||||
|  |             streamInfo.setSubtitles(extractor.getSubtitlesDefault()); | ||||||
|  |         } catch (Exception e) { | ||||||
|  |             streamInfo.addError(e); | ||||||
|  |         } | ||||||
|         streamInfo.setRelatedStreams(ExtractorHelper.getRelatedVideosOrLogError(streamInfo, extractor)); |         streamInfo.setRelatedStreams(ExtractorHelper.getRelatedVideosOrLogError(streamInfo, extractor)); | ||||||
|         return streamInfo; |         return streamInfo; | ||||||
|     } |     } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue