Use Page.body for YoutubePlaylistExtractor
This commit is contained in:
		
							parent
							
								
									3af26a2821
								
							
						
					
					
						commit
						eda1b6e199
					
				
					 22 changed files with 147 additions and 151 deletions
				
			
		|  | @ -1,6 +1,7 @@ | ||||||
| package org.schabi.newpipe.extractor.services.youtube; | package org.schabi.newpipe.extractor.services.youtube; | ||||||
| 
 | 
 | ||||||
| import com.grack.nanojson.JsonArray; | import com.grack.nanojson.JsonArray; | ||||||
|  | import com.grack.nanojson.JsonBuilder; | ||||||
| import com.grack.nanojson.JsonObject; | import com.grack.nanojson.JsonObject; | ||||||
| import com.grack.nanojson.JsonParser; | import com.grack.nanojson.JsonParser; | ||||||
| import com.grack.nanojson.JsonParserException; | import com.grack.nanojson.JsonParserException; | ||||||
|  | @ -676,6 +677,19 @@ public class YoutubeParsingHelper { | ||||||
|         return JsonUtils.toJsonArray(getValidJsonResponseBody(response)); |         return JsonUtils.toJsonArray(getValidJsonResponseBody(response)); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     public static JsonBuilder<JsonObject> prepareJsonBuilder() | ||||||
|  |             throws IOException, ExtractionException { | ||||||
|  |         // @formatter:off | ||||||
|  |         return JsonObject.builder() | ||||||
|  |                 .object("context") | ||||||
|  |                     .object("client") | ||||||
|  |                         .value("clientName", "1") | ||||||
|  |                         .value("clientVersion", getClientVersion()) | ||||||
|  |                     .end() | ||||||
|  |                 .end(); | ||||||
|  |         // @formatter:on | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     /** |     /** | ||||||
|      * Shared alert detection function, multiple endpoints return the error similarly structured. |      * Shared alert detection function, multiple endpoints return the error similarly structured. | ||||||
|      * <p> |      * <p> | ||||||
|  |  | ||||||
|  | @ -20,6 +20,7 @@ import org.schabi.newpipe.extractor.stream.StreamInfoItem; | ||||||
| import org.schabi.newpipe.extractor.stream.StreamInfoItemExtractor; | import org.schabi.newpipe.extractor.stream.StreamInfoItemExtractor; | ||||||
| import org.schabi.newpipe.extractor.stream.StreamInfoItemsCollector; | import org.schabi.newpipe.extractor.stream.StreamInfoItemsCollector; | ||||||
| import org.schabi.newpipe.extractor.stream.StreamType; | import org.schabi.newpipe.extractor.stream.StreamType; | ||||||
|  | import org.schabi.newpipe.extractor.utils.JsonUtils; | ||||||
| import org.schabi.newpipe.extractor.utils.Utils; | import org.schabi.newpipe.extractor.utils.Utils; | ||||||
| 
 | 
 | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
|  | @ -28,13 +29,12 @@ import javax.annotation.Nonnull; | ||||||
| import javax.annotation.Nullable; | import javax.annotation.Nullable; | ||||||
| 
 | 
 | ||||||
| import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.fixThumbnailUrl; | import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.fixThumbnailUrl; | ||||||
| import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.getClientVersion; |  | ||||||
| import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.getJsonResponse; | import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.getJsonResponse; | ||||||
| import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.getKey; | import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.getKey; | ||||||
| import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.getTextFromObject; | import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.getTextFromObject; | ||||||
| import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.getUrlFromNavigationEndpoint; | import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.getUrlFromNavigationEndpoint; | ||||||
| import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.getValidJsonResponseBody; | import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.getValidJsonResponseBody; | ||||||
| import static org.schabi.newpipe.extractor.utils.JsonUtils.toJsonObject; | import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.prepareJsonBuilder; | ||||||
| import static org.schabi.newpipe.extractor.utils.Utils.UTF_8; | import static org.schabi.newpipe.extractor.utils.Utils.UTF_8; | ||||||
| import static org.schabi.newpipe.extractor.utils.Utils.isNullOrEmpty; | import static org.schabi.newpipe.extractor.utils.Utils.isNullOrEmpty; | ||||||
| 
 | 
 | ||||||
|  | @ -217,25 +217,11 @@ public class YoutubePlaylistExtractor extends PlaylistExtractor { | ||||||
|             throw new IllegalArgumentException("Page doesn't contain an URL"); |             throw new IllegalArgumentException("Page doesn't contain an URL"); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         // @formatter:off |  | ||||||
|         byte[] json = JsonWriter.string() |  | ||||||
|                 .object() |  | ||||||
|                     .object("context") |  | ||||||
|                         .object("client") |  | ||||||
|                             .value("clientName", "1") |  | ||||||
|                             .value("clientVersion", getClientVersion()) |  | ||||||
|                         .end() |  | ||||||
|                     .end() |  | ||||||
|                     .value("continuation", page.getId()) |  | ||||||
|                 .end() |  | ||||||
|                 .done() |  | ||||||
|                 .getBytes(UTF_8); |  | ||||||
|         // @formatter:on |  | ||||||
| 
 |  | ||||||
|         final StreamInfoItemsCollector collector = new StreamInfoItemsCollector(getServiceId()); |         final StreamInfoItemsCollector collector = new StreamInfoItemsCollector(getServiceId()); | ||||||
|         final Response response = getDownloader().post(page.getUrl(), null, json, getExtractorLocalization()); |  | ||||||
| 
 | 
 | ||||||
|         final JsonObject ajaxJson = toJsonObject(getValidJsonResponseBody(response)); |         final Response response = getDownloader().post(page.getUrl(), null, page.getBody(), | ||||||
|  |                 getExtractorLocalization()); | ||||||
|  |         final JsonObject ajaxJson = JsonUtils.toJsonObject(getValidJsonResponseBody(response)); | ||||||
| 
 | 
 | ||||||
|         final JsonArray continuation = ajaxJson.getArray("onResponseReceivedActions") |         final JsonArray continuation = ajaxJson.getArray("onResponseReceivedActions") | ||||||
|                 .getObject(0) |                 .getObject(0) | ||||||
|  | @ -259,9 +245,15 @@ public class YoutubePlaylistExtractor extends PlaylistExtractor { | ||||||
|                     .getObject("continuationEndpoint") |                     .getObject("continuationEndpoint") | ||||||
|                     .getObject("continuationCommand") |                     .getObject("continuationCommand") | ||||||
|                     .getString("token"); |                     .getString("token"); | ||||||
|  | 
 | ||||||
|  |             final byte[] body = JsonWriter.string(prepareJsonBuilder() | ||||||
|  |                     .value("continuation", continuation) | ||||||
|  |                     .done()) | ||||||
|  |                     .getBytes(UTF_8); | ||||||
|  | 
 | ||||||
|             return new Page( |             return new Page( | ||||||
|                     "https://www.youtube.com/youtubei/v1/browse?key=" + getKey(), |                     "https://www.youtube.com/youtubei/v1/browse?key=" + getKey(), | ||||||
|                     continuation); |                     body); | ||||||
|         } else { |         } else { | ||||||
|             return null; |             return null; | ||||||
|         } |         } | ||||||
|  |  | ||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue