Address reviews.
This commit is contained in:
parent
9282c3c13b
commit
f9bd08c649
3 changed files with 42 additions and 12 deletions
|
@ -1,13 +1,7 @@
|
||||||
package org.schabi.newpipe.extractor.services.youtube.extractors;
|
package org.schabi.newpipe.extractor.services.youtube.extractors;
|
||||||
|
|
||||||
import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.getTextFromObject;
|
|
||||||
import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.getThumbnailUrlFromInfoItem;
|
|
||||||
import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.getUrlFromNavigationEndpoint;
|
|
||||||
import static org.schabi.newpipe.extractor.utils.Utils.isNullOrEmpty;
|
|
||||||
|
|
||||||
import com.grack.nanojson.JsonArray;
|
import com.grack.nanojson.JsonArray;
|
||||||
import com.grack.nanojson.JsonObject;
|
import com.grack.nanojson.JsonObject;
|
||||||
|
|
||||||
import org.schabi.newpipe.extractor.exceptions.ParsingException;
|
import org.schabi.newpipe.extractor.exceptions.ParsingException;
|
||||||
import org.schabi.newpipe.extractor.localization.DateWrapper;
|
import org.schabi.newpipe.extractor.localization.DateWrapper;
|
||||||
import org.schabi.newpipe.extractor.localization.TimeAgoParser;
|
import org.schabi.newpipe.extractor.localization.TimeAgoParser;
|
||||||
|
@ -18,12 +12,16 @@ import org.schabi.newpipe.extractor.stream.StreamType;
|
||||||
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.Nullable;
|
||||||
import java.time.Instant;
|
import java.time.Instant;
|
||||||
import java.time.OffsetDateTime;
|
import java.time.OffsetDateTime;
|
||||||
import java.time.ZoneOffset;
|
import java.time.ZoneOffset;
|
||||||
import java.time.format.DateTimeFormatter;
|
import java.time.format.DateTimeFormatter;
|
||||||
|
|
||||||
import javax.annotation.Nullable;
|
import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.getTextFromObject;
|
||||||
|
import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.getThumbnailUrlFromInfoItem;
|
||||||
|
import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.getUrlFromNavigationEndpoint;
|
||||||
|
import static org.schabi.newpipe.extractor.utils.Utils.isNullOrEmpty;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) Christian Schabesberger 2016 <chris.schabesberger@mailbox.org>
|
* Copyright (C) Christian Schabesberger 2016 <chris.schabesberger@mailbox.org>
|
||||||
|
@ -331,7 +329,37 @@ public class YoutubeStreamInfoItemExtractor implements StreamInfoItemExtractor {
|
||||||
final String webPageType = videoInfo.getObject("navigationEndpoint")
|
final String webPageType = videoInfo.getObject("navigationEndpoint")
|
||||||
.getObject("commandMetadata").getObject("webCommandMetadata")
|
.getObject("commandMetadata").getObject("webCommandMetadata")
|
||||||
.getString("webPageType");
|
.getString("webPageType");
|
||||||
return !isNullOrEmpty(webPageType) && webPageType.equals("WEB_PAGE_TYPE_SHORTS");
|
|
||||||
|
boolean isShort = !isNullOrEmpty(webPageType)
|
||||||
|
&& webPageType.equals("WEB_PAGE_TYPE_SHORTS");
|
||||||
|
|
||||||
|
if (!isShort) {
|
||||||
|
isShort = videoInfo.getObject("navigationEndpoint").has("reelWatchEndpoint");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!isShort) {
|
||||||
|
final JsonObject thumbnailTimeOverlay = videoInfo.getArray("thumbnailOverlays")
|
||||||
|
.stream()
|
||||||
|
.filter(JsonObject.class::isInstance)
|
||||||
|
.map(JsonObject.class::cast)
|
||||||
|
.filter(thumbnailOverlay -> thumbnailOverlay.has(
|
||||||
|
"thumbnailOverlayTimeStatusRenderer"))
|
||||||
|
.map(thumbnailOverlay -> thumbnailOverlay.getObject(
|
||||||
|
"thumbnailOverlayTimeStatusRenderer"))
|
||||||
|
.findFirst()
|
||||||
|
.orElse(null);
|
||||||
|
|
||||||
|
if (!isNullOrEmpty(thumbnailTimeOverlay)) {
|
||||||
|
isShort = thumbnailTimeOverlay.getString("style")
|
||||||
|
.equalsIgnoreCase("SHORTS")
|
||||||
|
|| thumbnailTimeOverlay.getObject("icon")
|
||||||
|
.getString("iconType")
|
||||||
|
.toLowerCase()
|
||||||
|
.contains("shorts");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return isShort;
|
||||||
} catch (final Exception e) {
|
} catch (final Exception e) {
|
||||||
throw new ParsingException("Could not determine if this is short-form content", e);
|
throw new ParsingException("Could not determine if this is short-form content", e);
|
||||||
}
|
}
|
||||||
|
|
|
@ -139,7 +139,6 @@ public class StreamInfoItem extends InfoItem {
|
||||||
this.shortFormContent = shortFormContent;
|
this.shortFormContent = shortFormContent;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "StreamInfoItem{"
|
return "StreamInfoItem{"
|
||||||
|
|
|
@ -129,10 +129,13 @@ public interface StreamInfoItemExtractor extends InfoItemExtractor {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Check if the stream is a short-form content
|
* Whether the stream is a short-form content.
|
||||||
*
|
*
|
||||||
* @return {@code true} if the stream is a short-form content
|
* <p>
|
||||||
* @throws ParsingException thrown if there is an error in the extraction
|
* Short-form contents are contents in the style of TikTok, YouTube Shorts, or Instagram Reels videos.
|
||||||
|
* </p>
|
||||||
|
*
|
||||||
|
* @return whether the stream is a short-form content
|
||||||
*/
|
*/
|
||||||
default boolean isShortFormContent() throws ParsingException {
|
default boolean isShortFormContent() throws ParsingException {
|
||||||
return false;
|
return false;
|
||||||
|
|
Loading…
Reference in a new issue