Only store ajaxJson for initial page and eager fetch the initial continuation.
This commit is contained in:
		
							parent
							
								
									64d24aa09e
								
							
						
					
					
						commit
						2974dfaa48
					
				
					 2 changed files with 43 additions and 21 deletions
				
			
		|  | @ -30,17 +30,16 @@ import static org.schabi.newpipe.extractor.utils.Utils.isNullOrEmpty; | |||
| 
 | ||||
| public class YoutubeCommentsExtractor extends CommentsExtractor { | ||||
| 
 | ||||
|     /** | ||||
|      * The initial request's continuation token. | ||||
|      * Since we need to make two requests to get the comments, | ||||
|      */ | ||||
|     private String initialToken; | ||||
| 
 | ||||
|     /** | ||||
|      * Whether comments are disabled on video. | ||||
|      */ | ||||
|     private boolean commentsDisabled = true; | ||||
| 
 | ||||
|     /** | ||||
|      * The total number of comments on video. | ||||
|      */ | ||||
|     private int commentsCount = (int) ITEM_COUNT_UNKNOWN; | ||||
| 
 | ||||
|     /** | ||||
|      * The second ajax <b>/next</b> response. | ||||
|      */ | ||||
|  | @ -62,7 +61,7 @@ public class YoutubeCommentsExtractor extends CommentsExtractor { | |||
|             return getInfoItemsPageForDisabledComments(); | ||||
|         } | ||||
| 
 | ||||
|         return getPage(getNextPage(this.initialToken)); | ||||
|         return extractComments(ajaxJson); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|  | @ -186,12 +185,17 @@ public class YoutubeCommentsExtractor extends CommentsExtractor { | |||
|                 .getBytes(StandardCharsets.UTF_8); | ||||
|         // @formatter:on | ||||
| 
 | ||||
|         this.ajaxJson = getJsonPostResponse("next", body, localization); | ||||
|         final var jsonObject = getJsonPostResponse("next", body, localization); | ||||
| 
 | ||||
|         return extractComments(jsonObject); | ||||
|     } | ||||
| 
 | ||||
|     private InfoItemsPage<CommentsInfoItem> extractComments(final JsonObject jsonObject) | ||||
|             throws ExtractionException { | ||||
|         final CommentsInfoItemsCollector collector = new CommentsInfoItemsCollector( | ||||
|                 getServiceId()); | ||||
|         collectCommentsFrom(collector); | ||||
|         return new InfoItemsPage<>(collector, getNextPage(ajaxJson)); | ||||
|         return new InfoItemsPage<>(collector, getNextPage(jsonObject)); | ||||
|     } | ||||
| 
 | ||||
|     private void collectCommentsFrom(final CommentsInfoItemsCollector collector) | ||||
|  | @ -261,7 +265,18 @@ public class YoutubeCommentsExtractor extends CommentsExtractor { | |||
|                 .getBytes(StandardCharsets.UTF_8); | ||||
|         // @formatter:on | ||||
| 
 | ||||
|         initialToken = findInitialCommentsToken(getJsonPostResponse("next", body, localization)); | ||||
|         final String initialToken = | ||||
|                 findInitialCommentsToken(getJsonPostResponse("next", body, localization)); | ||||
| 
 | ||||
|         // @formatter:off | ||||
|         final byte[] ajaxBody = JsonWriter.string( | ||||
|                         prepareDesktopJsonBuilder(localization, getExtractorContentCountry()) | ||||
|                                 .value("continuation", initialToken) | ||||
|                                 .done()) | ||||
|                 .getBytes(StandardCharsets.UTF_8); | ||||
|         // @formatter:on | ||||
| 
 | ||||
|         ajaxJson = getJsonPostResponse("next", ajaxBody, localization); | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|  | @ -272,6 +287,9 @@ public class YoutubeCommentsExtractor extends CommentsExtractor { | |||
| 
 | ||||
|     @Override | ||||
|     public int getCommentsCount() throws ExtractionException { | ||||
|         assertPageFetched(); | ||||
| 
 | ||||
|         if (commentsCount == ITEM_COUNT_UNKNOWN) { | ||||
|             final JsonObject countText = ajaxJson | ||||
|                     .getArray("onResponseReceivedEndpoints").getObject(0) | ||||
|                     .getObject("reloadContinuationItemsCommand") | ||||
|  | @ -280,9 +298,14 @@ public class YoutubeCommentsExtractor extends CommentsExtractor { | |||
|                     .getObject("countText"); | ||||
| 
 | ||||
|             try { | ||||
|             return Integer.parseInt(Utils.removeNonDigitCharacters(getTextFromObject(countText))); | ||||
|                 commentsCount = Integer.parseInt( | ||||
|                         Utils.removeNonDigitCharacters(getTextFromObject(countText)) | ||||
|                 ); | ||||
|             } catch (final Exception e) { | ||||
|                 throw new ExtractionException("Unable to get comments count", e); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         return commentsCount; | ||||
|     } | ||||
| } | ||||
|  |  | |||
|  | @ -348,7 +348,6 @@ public class YoutubeCommentsExtractorTest { | |||
| 
 | ||||
|         @Test | ||||
|         public void testCommentsCount() throws IOException, ExtractionException { | ||||
|             extractor.getInitialPage(); // Needs to be called first | ||||
|             assertTrue(extractor.getCommentsCount() > 18800); | ||||
|         } | ||||
|     } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue