124 lines
4.5 KiB
Java
124 lines
4.5 KiB
Java
package org.schabi.newpipe.extractor.services.peertube.extractors;
|
|
|
|
import java.io.IOException;
|
|
|
|
import org.jsoup.helper.StringUtil;
|
|
import org.schabi.newpipe.extractor.StreamingService;
|
|
import org.schabi.newpipe.extractor.comments.CommentsExtractor;
|
|
import org.schabi.newpipe.extractor.comments.CommentsInfoItem;
|
|
import org.schabi.newpipe.extractor.comments.CommentsInfoItemsCollector;
|
|
import org.schabi.newpipe.extractor.downloader.Downloader;
|
|
import org.schabi.newpipe.extractor.downloader.Response;
|
|
import org.schabi.newpipe.extractor.exceptions.ExtractionException;
|
|
import org.schabi.newpipe.extractor.exceptions.ParsingException;
|
|
import org.schabi.newpipe.extractor.linkhandler.ListLinkHandler;
|
|
import org.schabi.newpipe.extractor.utils.JsonUtils;
|
|
import org.schabi.newpipe.extractor.utils.Parser;
|
|
import org.schabi.newpipe.extractor.utils.Parser.RegexException;
|
|
|
|
import com.grack.nanojson.JsonArray;
|
|
import com.grack.nanojson.JsonObject;
|
|
import com.grack.nanojson.JsonParser;
|
|
|
|
public class PeertubeCommentsExtractor extends CommentsExtractor {
|
|
|
|
private static final String START_KEY = "start";
|
|
private static final String COUNT_KEY = "count";
|
|
private static final int ITEMS_PER_PAGE = 12;
|
|
private static final String START_PATTERN = "start=(\\d*)";
|
|
|
|
private InfoItemsPage<CommentsInfoItem> initPage;
|
|
private long total;
|
|
|
|
public PeertubeCommentsExtractor(StreamingService service, ListLinkHandler uiHandler) {
|
|
super(service, uiHandler);
|
|
}
|
|
|
|
@Override
|
|
public String getName() throws ParsingException {
|
|
return "Comments";
|
|
}
|
|
|
|
@Override
|
|
public InfoItemsPage<CommentsInfoItem> getInitialPage() throws IOException, ExtractionException {
|
|
super.fetchPage();
|
|
return initPage;
|
|
}
|
|
|
|
private void collectStreamsFrom(CommentsInfoItemsCollector collector, JsonObject json, String pageUrl) throws ParsingException {
|
|
JsonArray contents;
|
|
try {
|
|
contents = (JsonArray) JsonUtils.getValue(json, "data");
|
|
}catch(Exception e) {
|
|
throw new ParsingException("unable to extract comments info", e);
|
|
}
|
|
|
|
for(Object c: contents) {
|
|
if(c instanceof JsonObject) {
|
|
final JsonObject item = (JsonObject) c;
|
|
PeertubeCommentsInfoItemExtractor extractor = new PeertubeCommentsInfoItemExtractor(item, this);
|
|
collector.commit(extractor);
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
@Override
|
|
public String getNextPageUrl() throws IOException, ExtractionException {
|
|
super.fetchPage();
|
|
return initPage.getNextPageUrl();
|
|
}
|
|
|
|
@Override
|
|
public InfoItemsPage<CommentsInfoItem> getPage(String pageUrl) throws IOException, ExtractionException {
|
|
Response response = getDownloader().get(pageUrl);
|
|
JsonObject json = null;
|
|
if(null != response && !StringUtil.isBlank(response.responseBody())) {
|
|
try {
|
|
json = JsonParser.object().from(response.responseBody());
|
|
} catch (Exception e) {
|
|
throw new ParsingException("Could not parse json data for comments info", e);
|
|
}
|
|
}
|
|
|
|
CommentsInfoItemsCollector collector = new CommentsInfoItemsCollector(getServiceId());
|
|
if(json != null) {
|
|
Number number = JsonUtils.getNumber(json, "total");
|
|
if(number != null) this.total = number.longValue();
|
|
collectStreamsFrom(collector, json, pageUrl);
|
|
} else {
|
|
throw new ExtractionException("Unable to get peertube comments info");
|
|
}
|
|
return new InfoItemsPage<>(collector, getNextPageUrl(pageUrl));
|
|
}
|
|
|
|
@Override
|
|
public void onFetchPage(Downloader downloader) throws IOException, ExtractionException {
|
|
String pageUrl = getUrl() + "?" + START_KEY + "=0&" + COUNT_KEY + "=" + ITEMS_PER_PAGE;
|
|
this.initPage = getPage(pageUrl);
|
|
}
|
|
|
|
private String getNextPageUrl(String prevPageUrl) {
|
|
String prevStart;
|
|
try {
|
|
prevStart = Parser.matchGroup1(START_PATTERN, prevPageUrl);
|
|
} catch (RegexException e) {
|
|
return "";
|
|
}
|
|
if(StringUtil.isBlank(prevStart)) return "";
|
|
long nextStart = 0;
|
|
try {
|
|
nextStart = Long.valueOf(prevStart) + ITEMS_PER_PAGE;
|
|
} catch (NumberFormatException e) {
|
|
return "";
|
|
}
|
|
|
|
if(nextStart >= total) {
|
|
return "";
|
|
}else {
|
|
return prevPageUrl.replace(START_KEY + "=" + prevStart, START_KEY + "=" + String.valueOf(nextStart));
|
|
}
|
|
}
|
|
|
|
}
|