Fix uploader name when requesting next streams
This commit is contained in:
		
							parent
							
								
									bd3db34092
								
							
						
					
					
						commit
						7ae274b299
					
				
					 4 changed files with 19 additions and 20 deletions
				
			
		|  | @ -34,12 +34,12 @@ import java.util.ArrayList; | ||||||
| 
 | 
 | ||||||
| public class ChannelInfo extends ListInfo { | public class ChannelInfo extends ListInfo { | ||||||
| 
 | 
 | ||||||
|     public static NextItemsResult getMoreItems(ServiceList serviceItem, String nextStreamsUrl) throws IOException, ExtractionException { |     public static NextItemsResult getMoreItems(ServiceList serviceItem, String url, String nextStreamsUrl) throws IOException, ExtractionException { | ||||||
|         return getMoreItems(serviceItem.getService(), nextStreamsUrl); |         return getMoreItems(serviceItem.getService(), url, nextStreamsUrl); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public static NextItemsResult getMoreItems(StreamingService service, String nextStreamsUrl) throws IOException, ExtractionException { |     public static NextItemsResult getMoreItems(StreamingService service, String url, String nextStreamsUrl) throws IOException, ExtractionException { | ||||||
|         return service.getChannelExtractor(null, nextStreamsUrl).getNextStreams(); |         return service.getChannelExtractor(url, nextStreamsUrl).getNextStreams(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public static ChannelInfo getInfo(String url) throws IOException, ExtractionException { |     public static ChannelInfo getInfo(String url) throws IOException, ExtractionException { | ||||||
|  |  | ||||||
|  | @ -14,12 +14,12 @@ import java.util.ArrayList; | ||||||
| 
 | 
 | ||||||
| public class PlaylistInfo extends ListInfo { | public class PlaylistInfo extends ListInfo { | ||||||
| 
 | 
 | ||||||
|     public static NextItemsResult getMoreItems(ServiceList serviceItem, String nextStreamsUrl) throws IOException, ExtractionException { |     public static NextItemsResult getMoreItems(ServiceList serviceItem, String url, String nextStreamsUrl) throws IOException, ExtractionException { | ||||||
|         return getMoreItems(serviceItem.getService(), nextStreamsUrl); |         return getMoreItems(serviceItem.getService(), url, nextStreamsUrl); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public static NextItemsResult getMoreItems(StreamingService service, String nextStreamsUrl) throws IOException, ExtractionException { |     public static NextItemsResult getMoreItems(StreamingService service, String url, String nextStreamsUrl) throws IOException, ExtractionException { | ||||||
|         return service.getPlaylistExtractor(null, nextStreamsUrl).getNextStreams(); |         return service.getPlaylistExtractor(url, nextStreamsUrl).getNextStreams(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public static PlaylistInfo getInfo(String url) throws IOException, ExtractionException { |     public static PlaylistInfo getInfo(String url) throws IOException, ExtractionException { | ||||||
|  |  | ||||||
|  | @ -45,8 +45,6 @@ public class YoutubeChannelExtractor extends ChannelExtractor { | ||||||
|     private static final String CHANNEL_FEED_BASE = "https://www.youtube.com/feeds/videos.xml?channel_id="; |     private static final String CHANNEL_FEED_BASE = "https://www.youtube.com/feeds/videos.xml?channel_id="; | ||||||
|     private static final String CHANNEL_URL_PARAMETERS = "/videos?view=0&flow=list&sort=dd&live_view=10000"; |     private static final String CHANNEL_URL_PARAMETERS = "/videos?view=0&flow=list&sort=dd&live_view=10000"; | ||||||
| 
 | 
 | ||||||
|     private String channelName = ""; //Small hack used to make the channelName available to NextStreams |  | ||||||
| 
 |  | ||||||
|     private Document doc; |     private Document doc; | ||||||
|     /** |     /** | ||||||
|      * It's lazily initialized (when getNextStreams is called) |      * It's lazily initialized (when getNextStreams is called) | ||||||
|  | @ -69,6 +67,13 @@ public class YoutubeChannelExtractor extends ChannelExtractor { | ||||||
|         nextStreamsAjax = null; |         nextStreamsAjax = null; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     @Override | ||||||
|  |     protected boolean fetchPageUponCreation() { | ||||||
|  |         // Unfortunately, we have to fetch the page even if we are getting only next streams, | ||||||
|  |         // as they don't deliver enough information on their own (the channel name, for example). | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     @Override |     @Override | ||||||
|     public String getCleanUrl() { |     public String getCleanUrl() { | ||||||
|         try { |         try { | ||||||
|  | @ -93,8 +98,7 @@ public class YoutubeChannelExtractor extends ChannelExtractor { | ||||||
|     @Override |     @Override | ||||||
|     public String getName() throws ParsingException { |     public String getName() throws ParsingException { | ||||||
|         try { |         try { | ||||||
|             channelName = doc.select("span[class=\"qualified-channel-title-text\"]").first().select("a").first().text(); |             return doc.select("meta[property=\"og:title\"]").first().attr("content"); | ||||||
|             return channelName; |  | ||||||
|         } catch (Exception e) { |         } catch (Exception e) { | ||||||
|             throw new ParsingException("Could not get channel name", e); |             throw new ParsingException("Could not get channel name", e); | ||||||
|         } |         } | ||||||
|  | @ -204,10 +208,10 @@ public class YoutubeChannelExtractor extends ChannelExtractor { | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private void collectStreamsFrom(StreamInfoItemCollector collector, |     private void collectStreamsFrom(StreamInfoItemCollector collector, Element element) throws ParsingException { | ||||||
|                                     Element element) throws ParsingException { |  | ||||||
|         collector.getItemList().clear(); |         collector.getItemList().clear(); | ||||||
| 
 | 
 | ||||||
|  |         final String uploaderName = getName(); | ||||||
|         for (final Element li : element.children()) { |         for (final Element li : element.children()) { | ||||||
|             if (li.select("div[class=\"feed-item-dismissable\"]").first() != null) { |             if (li.select("div[class=\"feed-item-dismissable\"]").first() != null) { | ||||||
|                 collector.commit(new YoutubeStreamInfoItemExtractor(li) { |                 collector.commit(new YoutubeStreamInfoItemExtractor(li) { | ||||||
|  | @ -235,11 +239,7 @@ public class YoutubeChannelExtractor extends ChannelExtractor { | ||||||
| 
 | 
 | ||||||
|                     @Override |                     @Override | ||||||
|                     public String getUploaderName() throws ParsingException { |                     public String getUploaderName() throws ParsingException { | ||||||
|                         if(channelName.isEmpty()) { |                         return uploaderName; | ||||||
|                             return ""; |  | ||||||
|                         } else { |  | ||||||
|                             return channelName; |  | ||||||
|                         } |  | ||||||
|                     } |                     } | ||||||
| 
 | 
 | ||||||
|                     @Override |                     @Override | ||||||
|  |  | ||||||
|  | @ -6,7 +6,6 @@ import org.schabi.newpipe.Downloader; | ||||||
| import org.schabi.newpipe.extractor.ListExtractor; | import org.schabi.newpipe.extractor.ListExtractor; | ||||||
| import org.schabi.newpipe.extractor.NewPipe; | import org.schabi.newpipe.extractor.NewPipe; | ||||||
| import org.schabi.newpipe.extractor.channel.ChannelExtractor; | import org.schabi.newpipe.extractor.channel.ChannelExtractor; | ||||||
| import org.schabi.newpipe.extractor.stream.StreamInfoItem; |  | ||||||
| 
 | 
 | ||||||
| import static org.junit.Assert.*; | import static org.junit.Assert.*; | ||||||
| import static org.schabi.newpipe.extractor.ServiceList.YouTube; | import static org.schabi.newpipe.extractor.ServiceList.YouTube; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue