mirror of
https://github.com/TeamNewPipe/NewPipeExtractor.git
synced 2024-12-13 22:00:32 +05:30
Merge pull request #599 from XiangRongLin/post_body
Add body field to Page and use it
This commit is contained in:
commit
90afd6162a
@ -4,6 +4,8 @@ import java.io.Serializable;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
import static org.schabi.newpipe.extractor.utils.Utils.isNullOrEmpty;
|
import static org.schabi.newpipe.extractor.utils.Utils.isNullOrEmpty;
|
||||||
|
|
||||||
public class Page implements Serializable {
|
public class Page implements Serializable {
|
||||||
@ -12,31 +14,40 @@ public class Page implements Serializable {
|
|||||||
private final List<String> ids;
|
private final List<String> ids;
|
||||||
private final Map<String, String> cookies;
|
private final Map<String, String> cookies;
|
||||||
|
|
||||||
public Page(final String url, final String id, final List<String> ids, final Map<String, String> cookies) {
|
@Nullable
|
||||||
|
private final byte[] body;
|
||||||
|
|
||||||
|
public Page(final String url, final String id, final List<String> ids,
|
||||||
|
final Map<String, String> cookies, @Nullable final byte[] body) {
|
||||||
this.url = url;
|
this.url = url;
|
||||||
this.id = id;
|
this.id = id;
|
||||||
this.ids = ids;
|
this.ids = ids;
|
||||||
this.cookies = cookies;
|
this.cookies = cookies;
|
||||||
|
this.body = body;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Page(final String url) {
|
public Page(final String url) {
|
||||||
this(url, null, null, null);
|
this(url, null, null, null, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Page(final String url, final String id) {
|
public Page(final String url, final String id) {
|
||||||
this(url, id, null, null);
|
this(url, id, null, null, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
public Page(final String url, final byte[] body) {
|
||||||
|
this(url, null, null, null, body);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Page(final String url, final Map<String, String> cookies) {
|
public Page(final String url, final Map<String, String> cookies) {
|
||||||
this(url, null, null, cookies);
|
this(url, null, null, cookies, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Page(final List<String> ids) {
|
public Page(final List<String> ids) {
|
||||||
this(null, null, ids, null);
|
this(null, null, ids, null, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Page(final List<String> ids, final Map<String, String> cookies) {
|
public Page(final List<String> ids, final Map<String, String> cookies) {
|
||||||
this(null, null, ids, cookies);
|
this(null, null, ids, cookies, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getUrl() {
|
public String getUrl() {
|
||||||
@ -59,4 +70,9 @@ public class Page implements Serializable {
|
|||||||
return page != null && (!isNullOrEmpty(page.getUrl())
|
return page != null && (!isNullOrEmpty(page.getUrl())
|
||||||
|| !isNullOrEmpty(page.getIds()));
|
|| !isNullOrEmpty(page.getIds()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
public byte[] getBody() {
|
||||||
|
return body;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -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>
|
||||||
|
@ -21,15 +21,16 @@ import org.schabi.newpipe.extractor.stream.StreamInfoItemsCollector;
|
|||||||
import org.schabi.newpipe.extractor.utils.JsonUtils;
|
import org.schabi.newpipe.extractor.utils.JsonUtils;
|
||||||
import org.schabi.newpipe.extractor.utils.Utils;
|
import org.schabi.newpipe.extractor.utils.Utils;
|
||||||
|
|
||||||
import javax.annotation.Nonnull;
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import javax.annotation.Nonnull;
|
||||||
|
|
||||||
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.getTextFromObject;
|
|
||||||
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.getValidJsonResponseBody;
|
import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.getValidJsonResponseBody;
|
||||||
|
import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.prepareJsonBuilder;
|
||||||
import static org.schabi.newpipe.extractor.utils.Utils.EMPTY_STRING;
|
import static org.schabi.newpipe.extractor.utils.Utils.EMPTY_STRING;
|
||||||
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;
|
||||||
@ -264,23 +265,9 @@ public class YoutubeChannelExtractor extends ChannelExtractor {
|
|||||||
// as they don't deliver enough information on their own (the channel name, for example).
|
// as they don't deliver enough information on their own (the channel name, for example).
|
||||||
fetchPage();
|
fetchPage();
|
||||||
|
|
||||||
// @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
|
|
||||||
|
|
||||||
StreamInfoItemsCollector collector = new StreamInfoItemsCollector(getServiceId());
|
StreamInfoItemsCollector collector = new StreamInfoItemsCollector(getServiceId());
|
||||||
final Response response = getDownloader().post(page.getUrl(), null, json, getExtractorLocalization());
|
final Response response = getDownloader().post(page.getUrl(), null, page.getBody(),
|
||||||
|
getExtractorLocalization());
|
||||||
|
|
||||||
final JsonObject ajaxJson = JsonUtils.toJsonObject(getValidJsonResponseBody(response));
|
final JsonObject ajaxJson = JsonUtils.toJsonObject(getValidJsonResponseBody(response));
|
||||||
|
|
||||||
@ -300,8 +287,14 @@ public class YoutubeChannelExtractor extends ChannelExtractor {
|
|||||||
|
|
||||||
final JsonObject continuationEndpoint = continuations.getObject("continuationEndpoint");
|
final JsonObject continuationEndpoint = continuations.getObject("continuationEndpoint");
|
||||||
final String continuation = continuationEndpoint.getObject("continuationCommand").getString("token");
|
final String continuation = continuationEndpoint.getObject("continuationCommand").getString("token");
|
||||||
|
|
||||||
|
final byte[] body = JsonWriter.string(prepareJsonBuilder()
|
||||||
|
.value("continuation", continuation)
|
||||||
|
.done())
|
||||||
|
.getBytes(UTF_8);
|
||||||
|
|
||||||
return new Page("https://www.youtube.com/youtubei/v1/browse?key=" + getKey(),
|
return new Page("https://www.youtube.com/youtubei/v1/browse?key=" + getKey(),
|
||||||
continuation);
|
body);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -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
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…
Reference in New Issue
Block a user