From 1a322ad8edcf54e90f84d236fbe6dce1a9d8ae47 Mon Sep 17 00:00:00 2001 From: bopol Date: Fri, 22 Jan 2021 01:44:58 +0100 Subject: [PATCH] Add uploader verified by service extraction --- .../extractor/channel/ChannelExtractor.java | 2 + .../extractor/channel/ChannelInfoItem.java | 10 +++- .../channel/ChannelInfoItemExtractor.java | 3 ++ .../channel/ChannelInfoItemsCollector.java | 6 +++ .../extractor/comments/CommentsInfoItem.java | 9 ++++ .../comments/CommentsInfoItemExtractor.java | 5 ++ .../extractor/playlist/PlaylistExtractor.java | 1 + .../MediaCCCConferenceExtractor.java | 9 ++-- .../MediaCCCLiveStreamExtractor.java | 11 +++-- .../MediaCCCLiveStreamKioskExtractor.java | 5 ++ .../MediaCCCRecentKioskExtractor.java | 5 ++ .../extractors/MediaCCCSearchExtractor.java | 5 ++ .../extractors/MediaCCCStreamExtractor.java | 24 ++++------ .../MediaCCCConferenceInfoItemExtractor.java | 5 ++ .../MediaCCCStreamInfoItemExtractor.java | 5 ++ .../extractors/PeertubeAccountExtractor.java | 5 ++ .../extractors/PeertubeChannelExtractor.java | 5 ++ .../PeertubeCommentsInfoItemExtractor.java | 5 ++ .../extractors/PeertubePlaylistExtractor.java | 14 +++--- .../extractors/PeertubeStreamExtractor.java | 5 ++ .../PeertubeStreamInfoItemExtractor.java | 5 ++ .../SoundcloudChannelExtractor.java | 5 ++ .../SoundcloudChannelInfoItemExtractor.java | 5 ++ .../SoundcloudCommentsInfoItemExtractor.java | 8 +++- .../SoundcloudPlaylistExtractor.java | 5 ++ .../extractors/SoundcloudStreamExtractor.java | 5 ++ .../SoundcloudStreamInfoItemExtractor.java | 8 +++- .../youtube/YoutubeParsingHelper.java | 17 +++++++ .../extractors/YoutubeChannelExtractor.java | 8 ++++ .../YoutubeChannelInfoItemExtractor.java | 6 +++ .../YoutubeCommentsInfoItemExtractor.java | 5 ++ .../YoutubeFeedInfoItemExtractor.java | 5 ++ .../YoutubeMixPlaylistExtractor.java | 25 +++++----- .../extractors/YoutubePlaylistExtractor.java | 37 ++++++++------- .../extractors/YoutubeStreamExtractor.java | 8 ++++ .../YoutubeStreamInfoItemExtractor.java | 5 ++ .../extractor/stream/StreamExtractor.java | 21 ++++++--- .../extractor/stream/StreamInfoItem.java | 13 ++++- .../stream/StreamInfoItemExtractor.java | 9 ++++ .../stream/StreamInfoItemsCollector.java | 6 +++ .../services/BaseChannelExtractorTest.java | 1 + .../services/BasePlaylistExtractorTest.java | 1 + .../services/DefaultStreamExtractorTest.java | 6 +++ .../PeertubeAccountExtractorTest.java | 10 ++++ .../PeertubeChannelExtractorTest.java | 11 ++++- .../SoundcloudChannelExtractorTest.java | 10 ++++ .../SoundcloudPlaylistExtractorTest.java | 20 ++++++++ .../search/SoundcloudSearchExtractorTest.java | 41 ++++++++++++++++ .../youtube/YoutubeChannelExtractorTest.java | 34 +++++++++++--- .../youtube/YoutubePlaylistExtractorTest.java | 33 ++++++++----- .../search/YoutubeSearchExtractorTest.java | 47 +++++++++++++++++-- ...utubeStreamExtractorAgeRestrictedTest.java | 1 + .../YoutubeStreamExtractorDefaultTest.java | 4 ++ .../YoutubeStreamExtractorLivestreamTest.java | 1 + 54 files changed, 474 insertions(+), 91 deletions(-) diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/channel/ChannelExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/channel/ChannelExtractor.java index 3f54f1c2cc..8f2fe79ab1 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/channel/ChannelExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/channel/ChannelExtractor.java @@ -40,4 +40,6 @@ public ChannelExtractor(StreamingService service, ListLinkHandler linkHandler) { public abstract String getParentChannelName() throws ParsingException; public abstract String getParentChannelUrl() throws ParsingException; public abstract String getParentChannelAvatarUrl() throws ParsingException; + public abstract boolean isVerified() throws ParsingException; + } diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/channel/ChannelInfoItem.java b/extractor/src/main/java/org/schabi/newpipe/extractor/channel/ChannelInfoItem.java index 6d2e61a333..51b9619ad1 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/channel/ChannelInfoItem.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/channel/ChannelInfoItem.java @@ -27,7 +27,7 @@ public class ChannelInfoItem extends InfoItem { private String description; private long subscriberCount = -1; private long streamCount = -1; - + private boolean verified = false; public ChannelInfoItem(int serviceId, String url, String name) { super(InfoType.CHANNEL, serviceId, url, name); @@ -56,4 +56,12 @@ public long getStreamCount() { public void setStreamCount(long stream_count) { this.streamCount = stream_count; } + + public boolean isVerified() { + return verified; + } + + public void setVerified(boolean verified) { + this.verified = verified; + } } diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/channel/ChannelInfoItemExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/channel/ChannelInfoItemExtractor.java index 4d667733b2..6c22c3373e 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/channel/ChannelInfoItemExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/channel/ChannelInfoItemExtractor.java @@ -27,5 +27,8 @@ public interface ChannelInfoItemExtractor extends InfoItemExtractor { String getDescription() throws ParsingException; long getSubscriberCount() throws ParsingException; + long getStreamCount() throws ParsingException; + + boolean isVerified() throws ParsingException; } diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/channel/ChannelInfoItemsCollector.java b/extractor/src/main/java/org/schabi/newpipe/extractor/channel/ChannelInfoItemsCollector.java index 19abb1c276..454ba30a95 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/channel/ChannelInfoItemsCollector.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/channel/ChannelInfoItemsCollector.java @@ -59,6 +59,12 @@ public ChannelInfoItem extract(ChannelInfoItemExtractor extractor) throws Parsin } catch (Exception e) { addError(e); } + try { + resultItem.setVerified(extractor.isVerified()); + } catch (Exception e) { + addError(e); + } + return resultItem; } } diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/comments/CommentsInfoItem.java b/extractor/src/main/java/org/schabi/newpipe/extractor/comments/CommentsInfoItem.java index 5d0f36205c..ba31bb6b1d 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/comments/CommentsInfoItem.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/comments/CommentsInfoItem.java @@ -12,6 +12,7 @@ public class CommentsInfoItem extends InfoItem { private String uploaderName; private String uploaderAvatarUrl; private String uploaderUrl; + private boolean uploaderVerified; private String textualUploadDate; @Nullable private DateWrapper uploadDate; @@ -103,4 +104,12 @@ public boolean isPinned() { public void setPinned(boolean pinned) { this.pinned = pinned; } + + public void setUploaderVerified(boolean uploaderVerified) { + this.uploaderVerified = uploaderVerified; + } + + public boolean isUploaderVerified() { + return uploaderVerified; + } } diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/comments/CommentsInfoItemExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/comments/CommentsInfoItemExtractor.java index dd38df7fd8..957098dee6 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/comments/CommentsInfoItemExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/comments/CommentsInfoItemExtractor.java @@ -53,4 +53,9 @@ public interface CommentsInfoItemExtractor extends InfoItemExtractor { * Whether the comment is pinned */ boolean isPinned() throws ParsingException; + + /** + * Whether the uploader is verified by the service + */ + boolean isUploaderVerified() throws ParsingException; } diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/playlist/PlaylistExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/playlist/PlaylistExtractor.java index 90b89022f9..683fcb62c5 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/playlist/PlaylistExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/playlist/PlaylistExtractor.java @@ -20,6 +20,7 @@ public PlaylistExtractor(StreamingService service, ListLinkHandler linkHandler) public abstract String getUploaderUrl() throws ParsingException; public abstract String getUploaderName() throws ParsingException; public abstract String getUploaderAvatarUrl() throws ParsingException; + public abstract boolean isUploaderVerified() throws ParsingException; public abstract long getStreamCount() throws ParsingException; diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCConferenceExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCConferenceExtractor.java index 77ea3ad1c7..22571b895e 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCConferenceExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCConferenceExtractor.java @@ -4,7 +4,6 @@ import com.grack.nanojson.JsonObject; import com.grack.nanojson.JsonParser; import com.grack.nanojson.JsonParserException; - import org.schabi.newpipe.extractor.Page; import org.schabi.newpipe.extractor.StreamingService; import org.schabi.newpipe.extractor.channel.ChannelExtractor; @@ -17,9 +16,8 @@ import org.schabi.newpipe.extractor.stream.StreamInfoItem; import org.schabi.newpipe.extractor.stream.StreamInfoItemsCollector; -import java.io.IOException; - import javax.annotation.Nonnull; +import java.io.IOException; public class MediaCCCConferenceExtractor extends ChannelExtractor { private JsonObject conferenceData; @@ -69,6 +67,11 @@ public String getParentChannelAvatarUrl() throws ParsingException { return ""; } + @Override + public boolean isVerified() throws ParsingException { + return false; + } + @Nonnull @Override public InfoItemsPage getInitialPage() { diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCLiveStreamExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCLiveStreamExtractor.java index 6059479461..77ef689345 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCLiveStreamExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCLiveStreamExtractor.java @@ -126,6 +126,11 @@ public String getUploaderName() throws ParsingException { return conference.getString("conference"); } + @Override + public boolean isUploaderVerified() throws ParsingException { + return false; + } + @Nonnull @Override public String getUploaderAvatarUrl() { @@ -180,7 +185,7 @@ public List getAudioStreams() throws IOException, ExtractionExcepti for (int s = 0; s < room.getArray("streams").size(); s++) { final JsonObject stream = room.getArray("streams").getObject(s); if (stream.getString("type").equals("audio")) { - for (final String type :stream.getObject("urls").keySet()) { + for (final String type : stream.getObject("urls").keySet()) { final JsonObject url = stream.getObject("urls").getObject(type); audioStreams.add(new AudioStream(url.getString("url"), MediaFormat.getFromSuffix(type), -1)); } @@ -197,7 +202,7 @@ public List getVideoStreams() throws IOException, ExtractionExcepti if (stream.getString("type").equals("video")) { final String resolution = stream.getArray("videoSize").getInt(0) + "x" + stream.getArray("videoSize").getInt(1); - for (final String type :stream.getObject("urls").keySet()) { + for (final String type : stream.getObject("urls").keySet()) { if (!type.equals("hls")) { final JsonObject url = stream.getObject("urls").getObject(type); videoStreams.add(new VideoStream( @@ -218,7 +223,7 @@ public List getVideoOnlyStreams() throws IOException, ExtractionExc @Nonnull @Override - public List getSubtitlesDefault(){ + public List getSubtitlesDefault() { return Collections.emptyList(); } diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCLiveStreamKioskExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCLiveStreamKioskExtractor.java index a4c99e49e5..504dd3b08a 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCLiveStreamKioskExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCLiveStreamKioskExtractor.java @@ -73,6 +73,11 @@ public String getUploaderUrl() throws ParsingException { return "https://media.ccc.de/c/" + conferenceInfo.getString("slug"); } + @Override + public boolean isUploaderVerified() throws ParsingException { + return false; + } + @Nullable @Override public String getTextualUploadDate() throws ParsingException { diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCRecentKioskExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCRecentKioskExtractor.java index b5d34e193e..2ff86a4fc1 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCRecentKioskExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCRecentKioskExtractor.java @@ -68,6 +68,11 @@ public String getUploaderUrl() throws ParsingException { .getUrl(); // web URL } + @Override + public boolean isUploaderVerified() throws ParsingException { + return false; + } + @Nullable @Override public String getTextualUploadDate() throws ParsingException { diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCSearchExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCSearchExtractor.java index cc9e552a73..82c57475c4 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCSearchExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCSearchExtractor.java @@ -142,6 +142,11 @@ public long getStreamCount() { return item.getStreamCount(); } + @Override + public boolean isVerified() throws ParsingException { + return false; + } + @Override public String getName() { return item.getName(); diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCStreamExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCStreamExtractor.java index 0929238098..1ae8508aa6 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCStreamExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCStreamExtractor.java @@ -4,7 +4,6 @@ import com.grack.nanojson.JsonObject; import com.grack.nanojson.JsonParser; import com.grack.nanojson.JsonParserException; - import org.schabi.newpipe.extractor.MediaFormat; import org.schabi.newpipe.extractor.MetaInfo; import org.schabi.newpipe.extractor.StreamingService; @@ -13,26 +12,14 @@ import org.schabi.newpipe.extractor.exceptions.ParsingException; import org.schabi.newpipe.extractor.linkhandler.LinkHandler; import org.schabi.newpipe.extractor.localization.DateWrapper; -import org.schabi.newpipe.extractor.stream.AudioStream; -import org.schabi.newpipe.extractor.stream.Description; -import org.schabi.newpipe.extractor.stream.StreamExtractor; -import org.schabi.newpipe.extractor.stream.StreamInfoItemsCollector; -import org.schabi.newpipe.extractor.stream.StreamSegment; -import org.schabi.newpipe.extractor.stream.StreamType; -import org.schabi.newpipe.extractor.stream.SubtitlesStream; -import org.schabi.newpipe.extractor.stream.VideoStream; import org.schabi.newpipe.extractor.services.media_ccc.linkHandler.MediaCCCConferenceLinkHandlerFactory; import org.schabi.newpipe.extractor.services.media_ccc.linkHandler.MediaCCCStreamLinkHandlerFactory; - -import java.io.IOException; -import java.util.ArrayList; -import java.util.Arrays; -import java.util.Collections; -import java.util.List; -import java.util.Locale; +import org.schabi.newpipe.extractor.stream.*; import javax.annotation.Nonnull; import javax.annotation.Nullable; +import java.io.IOException; +import java.util.*; public class MediaCCCStreamExtractor extends StreamExtractor { private JsonObject data; @@ -109,6 +96,11 @@ public String getUploaderName() { .replaceFirst("https://(api\\.)?media\\.ccc\\.de/public/conferences/", ""); } + @Override + public boolean isUploaderVerified() throws ParsingException { + return false; + } + @Nonnull @Override public String getUploaderAvatarUrl() { diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/infoItems/MediaCCCConferenceInfoItemExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/infoItems/MediaCCCConferenceInfoItemExtractor.java index 3ced44d9ab..b69d7a9083 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/infoItems/MediaCCCConferenceInfoItemExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/infoItems/MediaCCCConferenceInfoItemExtractor.java @@ -28,6 +28,11 @@ public long getStreamCount() { return ListExtractor.ITEM_COUNT_UNKNOWN; } + @Override + public boolean isVerified() throws ParsingException { + return false; + } + @Override public String getName() throws ParsingException { return conference.getString("title"); diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/infoItems/MediaCCCStreamInfoItemExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/infoItems/MediaCCCStreamInfoItemExtractor.java index 3dee8ac39c..0231664375 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/infoItems/MediaCCCStreamInfoItemExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/infoItems/MediaCCCStreamInfoItemExtractor.java @@ -46,6 +46,11 @@ public String getUploaderUrl() { return event.getString("conference_url"); } + @Override + public boolean isUploaderVerified() throws ParsingException { + return false; + } + @Nullable @Override public String getTextualUploadDate() { diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeAccountExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeAccountExtractor.java index 79876765b8..282e6d9cc8 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeAccountExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeAccountExtractor.java @@ -83,6 +83,11 @@ public String getParentChannelAvatarUrl() { return ""; } + @Override + public boolean isVerified() throws ParsingException { + return false; + } + @Nonnull @Override public InfoItemsPage getInitialPage() throws IOException, ExtractionException { diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeChannelExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeChannelExtractor.java index dc5a54fd12..67ef38c27e 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeChannelExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeChannelExtractor.java @@ -90,6 +90,11 @@ public String getParentChannelAvatarUrl() { return baseUrl + value; } + @Override + public boolean isVerified() throws ParsingException { + return false; + } + @Nonnull @Override public InfoItemsPage getInitialPage() throws IOException, ExtractionException { diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeCommentsInfoItemExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeCommentsInfoItemExtractor.java index 38c8198868..812e454f90 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeCommentsInfoItemExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeCommentsInfoItemExtractor.java @@ -99,6 +99,11 @@ public boolean isPinned() throws ParsingException { return false; } + @Override + public boolean isUploaderVerified() throws ParsingException { + return false; + } + @Override public String getUploaderName() throws ParsingException { return JsonUtils.getString(item, "account.name") + "@" + JsonUtils.getString(item, "account.host"); diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubePlaylistExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubePlaylistExtractor.java index b229853695..89340df37d 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubePlaylistExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubePlaylistExtractor.java @@ -3,7 +3,6 @@ import com.grack.nanojson.JsonObject; import com.grack.nanojson.JsonParser; import com.grack.nanojson.JsonParserException; - import org.schabi.newpipe.extractor.Page; import org.schabi.newpipe.extractor.StreamingService; import org.schabi.newpipe.extractor.downloader.Downloader; @@ -17,14 +16,10 @@ import org.schabi.newpipe.extractor.stream.StreamInfoItemsCollector; import org.schabi.newpipe.extractor.utils.Utils; -import java.io.IOException; - import javax.annotation.Nonnull; +import java.io.IOException; -import static org.schabi.newpipe.extractor.services.peertube.PeertubeParsingHelper.COUNT_KEY; -import static org.schabi.newpipe.extractor.services.peertube.PeertubeParsingHelper.ITEMS_PER_PAGE; -import static org.schabi.newpipe.extractor.services.peertube.PeertubeParsingHelper.START_KEY; -import static org.schabi.newpipe.extractor.services.peertube.PeertubeParsingHelper.collectStreamsFrom; +import static org.schabi.newpipe.extractor.services.peertube.PeertubeParsingHelper.*; import static org.schabi.newpipe.extractor.utils.Utils.isNullOrEmpty; public class PeertubePlaylistExtractor extends PlaylistExtractor { @@ -59,6 +54,11 @@ public String getUploaderAvatarUrl() throws ParsingException { return getBaseUrl() + playlistInfo.getObject("ownerAccount").getObject("avatar").getString("path"); } + @Override + public boolean isUploaderVerified() throws ParsingException { + return false; + } + @Override public long getStreamCount() { return playlistInfo.getLong("videosLength"); diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeStreamExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeStreamExtractor.java index cfcd1e7b57..56dbf08fee 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeStreamExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeStreamExtractor.java @@ -148,6 +148,11 @@ public String getUploaderName() throws ParsingException { return JsonUtils.getString(json, "account.displayName"); } + @Override + public boolean isUploaderVerified() throws ParsingException { + return false; + } + @Nonnull @Override public String getUploaderAvatarUrl() { diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeStreamInfoItemExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeStreamInfoItemExtractor.java index 4ab27ae465..7ea3e1d823 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeStreamInfoItemExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeStreamInfoItemExtractor.java @@ -54,6 +54,11 @@ public String getUploaderUrl() throws ParsingException { .fromId("accounts/" + name + "@" + host, baseUrl).getUrl(); } + @Override + public boolean isUploaderVerified() throws ParsingException { + return false; + } + @Override public String getUploaderName() throws ParsingException { return JsonUtils.getString(item, "account.displayName"); diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudChannelExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudChannelExtractor.java index 52151d3d04..082de81c0b 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudChannelExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudChannelExtractor.java @@ -96,6 +96,11 @@ public String getParentChannelAvatarUrl() { return ""; } + @Override + public boolean isVerified() throws ParsingException { + return user.getBoolean("verified"); + } + @Nonnull @Override public InfoItemsPage getInitialPage() throws ExtractionException { diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudChannelInfoItemExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudChannelInfoItemExtractor.java index ef5270e7c6..39f58d8638 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudChannelInfoItemExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudChannelInfoItemExtractor.java @@ -40,6 +40,11 @@ public long getStreamCount() { return itemObject.getLong("track_count"); } + @Override + public boolean isVerified() { + return itemObject.getBoolean("verified"); + } + @Override public String getDescription() { return itemObject.getString("description", EMPTY_STRING); diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudCommentsInfoItemExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudCommentsInfoItemExtractor.java index cf574aa257..edceb1c860 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudCommentsInfoItemExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudCommentsInfoItemExtractor.java @@ -6,9 +6,8 @@ import org.schabi.newpipe.extractor.localization.DateWrapper; import org.schabi.newpipe.extractor.services.soundcloud.SoundcloudParsingHelper; -import java.util.Objects; - import javax.annotation.Nullable; +import java.util.Objects; public class SoundcloudCommentsInfoItemExtractor implements CommentsInfoItemExtractor { private JsonObject json; @@ -49,6 +48,11 @@ public boolean isPinned() throws ParsingException { return false; } + @Override + public boolean isUploaderVerified() throws ParsingException { + return json.getObject("user").getBoolean("verified"); + } + @Override public String getUploaderUrl() { return json.getObject("user").getString("permalink_url"); diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudPlaylistExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudPlaylistExtractor.java index 878a7766c2..4b711e75be 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudPlaylistExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudPlaylistExtractor.java @@ -111,6 +111,11 @@ public String getUploaderAvatarUrl() { return SoundcloudParsingHelper.getAvatarUrl(playlist); } + @Override + public boolean isUploaderVerified() throws ParsingException { + return playlist.getObject("user").getBoolean("verified"); + } + @Override public long getStreamCount() { return playlist.getLong("track_count"); diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudStreamExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudStreamExtractor.java index 9e4ed6bb28..fc246dfb72 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudStreamExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudStreamExtractor.java @@ -131,6 +131,11 @@ public String getUploaderName() { return SoundcloudParsingHelper.getUploaderName(track); } + @Override + public boolean isUploaderVerified() throws ParsingException { + return track.getObject("user").getBoolean("verified"); + } + @Nonnull @Override public String getUploaderAvatarUrl() { diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudStreamInfoItemExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudStreamInfoItemExtractor.java index 4e1762318f..79d937c2fe 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudStreamInfoItemExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudStreamInfoItemExtractor.java @@ -43,6 +43,11 @@ public String getUploaderUrl() { return replaceHttpWithHttps(itemObject.getObject("user").getString("permalink_url")); } + @Override + public boolean isUploaderVerified() throws ParsingException { + return itemObject.getObject("user").getBoolean("verified"); + } + @Override public String getTextualUploadDate() { return itemObject.getString("created_at"); @@ -64,8 +69,7 @@ public String getThumbnailUrl() { if (artworkUrl.isEmpty()) { artworkUrl = itemObject.getObject("user").getString("avatar_url"); } - String artworkUrlBetterResolution = artworkUrl.replace("large.jpg", "crop.jpg"); - return artworkUrlBetterResolution; + return artworkUrl.replace("large.jpg", "crop.jpg"); } @Override diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/YoutubeParsingHelper.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/YoutubeParsingHelper.java index dd63683351..c0e8721250 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/YoutubeParsingHelper.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/YoutubeParsingHelper.java @@ -804,4 +804,21 @@ public static String extractCachedUrlIfNeeded(final String url) { } return url; } + + public static boolean isVerified(final JsonArray badges) { + if (Utils.isNullOrEmpty(badges)) { + return false; + } + + for (Object badge : badges) { + final String style = ((JsonObject) badge).getObject("metadataBadgeRenderer") + .getString("style"); + if (style != null && (style.equals("BADGE_STYLE_TYPE_VERIFIED") + || style.equals("BADGE_STYLE_TYPE_VERIFIED_ARTIST"))) { + return true; + } + } + + return false; + } } diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeChannelExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeChannelExtractor.java index db046f8b30..4ed926ee40 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeChannelExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeChannelExtractor.java @@ -216,6 +216,14 @@ public String getParentChannelAvatarUrl() throws ParsingException { return ""; } + @Override + public boolean isVerified() throws ParsingException { + final JsonArray badges = initialData.getObject("header").getObject("c4TabbedHeaderRenderer") + .getArray("badges"); + + return YoutubeParsingHelper.isVerified(badges); + } + @Nonnull @Override public InfoItemsPage getInitialPage() throws ExtractionException { diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeChannelInfoItemExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeChannelInfoItemExtractor.java index fbab74d839..27bc192064 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeChannelInfoItemExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeChannelInfoItemExtractor.java @@ -5,6 +5,7 @@ import org.schabi.newpipe.extractor.ListExtractor; import org.schabi.newpipe.extractor.channel.ChannelInfoItemExtractor; import org.schabi.newpipe.extractor.exceptions.ParsingException; +import org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper; import org.schabi.newpipe.extractor.services.youtube.linkHandler.YoutubeChannelLinkHandlerFactory; import org.schabi.newpipe.extractor.utils.Utils; @@ -97,6 +98,11 @@ public long getStreamCount() throws ParsingException { } } + @Override + public boolean isVerified() throws ParsingException { + return YoutubeParsingHelper.isVerified(channelInfoItem.getArray("ownerBadges")); + } + @Override public String getDescription() throws ParsingException { try { diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeCommentsInfoItemExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeCommentsInfoItemExtractor.java index 4276800bbd..ddb5c6e823 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeCommentsInfoItemExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeCommentsInfoItemExtractor.java @@ -125,6 +125,11 @@ public boolean isPinned() { return json.has("pinnedCommentBadge"); } + public boolean isUploaderVerified() throws ParsingException { + // impossible to get this information from the mobile layout + return false; + } + @Override public String getUploaderName() throws ParsingException { try { diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeFeedInfoItemExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeFeedInfoItemExtractor.java index 3945ff1703..a1883621fd 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeFeedInfoItemExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeFeedInfoItemExtractor.java @@ -50,6 +50,11 @@ public String getUploaderUrl() { return entryElement.select("author > uri").first().text(); } + @Override + public boolean isUploaderVerified() throws ParsingException { + return false; + } + @Nullable @Override public String getTextualUploadDate() { diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeMixPlaylistExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeMixPlaylistExtractor.java index d424129ef2..5f876e719b 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeMixPlaylistExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeMixPlaylistExtractor.java @@ -2,7 +2,6 @@ import com.grack.nanojson.JsonArray; import com.grack.nanojson.JsonObject; - import org.schabi.newpipe.extractor.ListExtractor; import org.schabi.newpipe.extractor.Page; import org.schabi.newpipe.extractor.StreamingService; @@ -16,18 +15,13 @@ import org.schabi.newpipe.extractor.stream.StreamInfoItem; import org.schabi.newpipe.extractor.stream.StreamInfoItemsCollector; +import javax.annotation.Nonnull; +import javax.annotation.Nullable; import java.io.IOException; import java.util.Collections; import java.util.List; -import javax.annotation.Nonnull; -import javax.annotation.Nullable; - -import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.extractCookieValue; -import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.getJsonResponse; -import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.getResponse; -import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.getUrlFromNavigationEndpoint; -import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.toJsonArray; +import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.*; import static org.schabi.newpipe.extractor.utils.Utils.isNullOrEmpty; /** @@ -82,8 +76,8 @@ public String getThumbnailUrl() throws ParsingException { try { //fallback to thumbnail of current video. Always the case for channel mix return getThumbnailUrlFromVideoId( - initialData.getObject("currentVideoEndpoint").getObject("watchEndpoint") - .getString("videoId")); + initialData.getObject("currentVideoEndpoint").getObject("watchEndpoint") + .getString("videoId")); } catch (final Exception ignored) { } throw new ParsingException("Could not get playlist thumbnail", e); @@ -113,6 +107,11 @@ public String getUploaderAvatarUrl() { return ""; } + @Override + public boolean isUploaderVerified() throws ParsingException { + return false; + } + @Override public long getStreamCount() { // Auto-generated playlist always start with 25 videos and are endless @@ -144,7 +143,7 @@ private String getNextPageUrlFrom(final JsonObject playlistJson) throws Extracti public InfoItemsPage getPage(final Page page) throws ExtractionException, IOException { if (page == null || isNullOrEmpty(page.getUrl())) { - throw new IllegalArgumentException("Page url is empty or null"); + throw new IllegalArgumentException("Page url is empty or null"); } if (!page.getCookies().containsKey(COOKIE_NAME)) { throw new IllegalArgumentException("Cooke '" + COOKIE_NAME + "' is missing"); @@ -180,7 +179,7 @@ private void collectStreamsFrom( for (final Object stream : streams) { if (stream instanceof JsonObject) { final JsonObject streamInfo = ((JsonObject) stream) - .getObject("playlistPanelVideoRenderer"); + .getObject("playlistPanelVideoRenderer"); if (streamInfo != null) { collector.commit(new YoutubeStreamInfoItemExtractor(streamInfo, timeAgoParser)); } diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubePlaylistExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubePlaylistExtractor.java index 0e2ad2a43a..6a6ab97aa9 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubePlaylistExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubePlaylistExtractor.java @@ -2,7 +2,6 @@ import com.grack.nanojson.JsonArray; import com.grack.nanojson.JsonObject; - import org.schabi.newpipe.extractor.Page; import org.schabi.newpipe.extractor.StreamingService; import org.schabi.newpipe.extractor.downloader.Downloader; @@ -20,15 +19,11 @@ import org.schabi.newpipe.extractor.stream.StreamType; import org.schabi.newpipe.extractor.utils.Utils; -import java.io.IOException; - import javax.annotation.Nonnull; import javax.annotation.Nullable; +import java.io.IOException; -import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.fixThumbnailUrl; -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.getUrlFromNavigationEndpoint; +import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper.*; import static org.schabi.newpipe.extractor.utils.Utils.isNullOrEmpty; @SuppressWarnings("WeakerAccess") @@ -138,6 +133,11 @@ public String getUploaderAvatarUrl() throws ParsingException { } } + @Override + public boolean isUploaderVerified() throws ParsingException { + return false; + } + @Override public long getStreamCount() throws ParsingException { try { @@ -209,11 +209,11 @@ public InfoItemsPage getPage(final Page page) throws IOException final JsonArray ajaxJson = getJsonResponse(page.getUrl(), getExtractorLocalization()); final JsonArray continuation = ajaxJson.getObject(1) - .getObject("response") - .getArray("onResponseReceivedActions") - .getObject(0) - .getObject("appendContinuationItemsAction") - .getArray("continuationItems"); + .getObject("response") + .getArray("onResponseReceivedActions") + .getObject(0) + .getObject("appendContinuationItemsAction") + .getArray("continuationItems"); collectStreamsFrom(collector, continuation); @@ -228,10 +228,10 @@ private Page getNextPageFrom(final JsonArray contents) { final JsonObject lastElement = contents.getObject(contents.size() - 1); if (lastElement.has("continuationItemRenderer")) { final String continuation = lastElement - .getObject("continuationItemRenderer") - .getObject("continuationEndpoint") - .getObject("continuationCommand") - .getString("token"); + .getObject("continuationItemRenderer") + .getObject("continuationEndpoint") + .getObject("continuationCommand") + .getString("token"); return new Page("https://www.youtube.com/browse_ajax?continuation=" + continuation); } else { return null; @@ -311,6 +311,11 @@ public String getUploaderUrl() throws ParsingException { return YoutubePlaylistExtractor.this.getUploaderUrl(); } + @Override + public boolean isUploaderVerified() { + return false; + } + @Nullable @Override public String getTextualUploadDate() { diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeStreamExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeStreamExtractor.java index 2ff4cf4db5..5050a1581a 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeStreamExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeStreamExtractor.java @@ -412,6 +412,14 @@ public String getUploaderName() throws ParsingException { return uploaderName; } + @Override + public boolean isUploaderVerified() throws ParsingException { + final JsonArray badges = getVideoSecondaryInfoRenderer().getObject("owner") + .getObject("videoOwnerRenderer").getArray("badges"); + + return YoutubeParsingHelper.isVerified(badges); + } + @Nonnull @Override public String getUploaderAvatarUrl() throws ParsingException { diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeStreamInfoItemExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeStreamInfoItemExtractor.java index 42e39b7280..4fa6caab94 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeStreamInfoItemExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeStreamInfoItemExtractor.java @@ -158,6 +158,11 @@ public String getUploaderUrl() throws ParsingException { return url; } + @Override + public boolean isUploaderVerified() throws ParsingException { + return YoutubeParsingHelper.isVerified(videoInfo.getArray("ownerBadges")); + } + @Nullable @Override public String getTextualUploadDate() throws ParsingException { diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/stream/StreamExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/stream/StreamExtractor.java index faf6b0efcd..3596f2f7cc 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/stream/StreamExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/stream/StreamExtractor.java @@ -31,14 +31,13 @@ import org.schabi.newpipe.extractor.localization.DateWrapper; import org.schabi.newpipe.extractor.utils.Parser; +import javax.annotation.Nonnull; +import javax.annotation.Nullable; import java.io.IOException; import java.util.Collections; import java.util.List; import java.util.Locale; -import javax.annotation.Nonnull; -import javax.annotation.Nullable; - /** * Scrapes information from a video/audio streaming service (eg, YouTube). */ @@ -171,6 +170,15 @@ public StreamExtractor(StreamingService service, LinkHandler linkHandler) { @Nonnull public abstract String getUploaderName() throws ParsingException; + /** + * Whether the uploader has been verified by the service's provider. + * If there is no verification implemented, return false. + * + * @return whether the uploader has been verified by the service's provider + * @throws ParsingException + */ + public abstract boolean isUploaderVerified() throws ParsingException; + /** * The url to the image file/profile picture/avatar of the creator/uploader of the stream. * If the url is not available you can return an empty String. @@ -479,8 +487,8 @@ protected long getTimestampSeconds(String regexPattern) throws ParsingException public abstract String getSupportInfo() throws ParsingException; /** - * The list of stream segments by timestamps for the stream. - * If the segment list is not available you can simply return an empty list. + * The list of stream segments by timestamps for the stream. + * If the segment list is not available you can simply return an empty list. * * @return The list of segments of the stream or an empty list. * @throws ParsingException @@ -495,7 +503,8 @@ protected long getTimestampSeconds(String regexPattern) throws ParsingException * or further information on the topic (e.g. hints that the video might contain conspiracy theories * or contains information about a current health situation like the Covid-19 pandemic). *

- * The meta information often contains links to external sources like Wikipedia or the WHO. + * The meta information often contains links to external sources like Wikipedia or the WHO. + * * @return The meta info of the stream or an empty List if not provided. * @throws ParsingException */ diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/stream/StreamInfoItem.java b/extractor/src/main/java/org/schabi/newpipe/extractor/stream/StreamInfoItem.java index 6623c1efe9..63c5741536 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/stream/StreamInfoItem.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/stream/StreamInfoItem.java @@ -33,11 +33,13 @@ public class StreamInfoItem extends InfoItem { private String uploaderName; private String textualUploadDate; - @Nullable private DateWrapper uploadDate; + @Nullable + private DateWrapper uploadDate; private long viewCount = -1; private long duration = -1; private String uploaderUrl = null; + private boolean uploaderVerified = false; public StreamInfoItem(int serviceId, String url, String name, StreamType streamType) { super(InfoType.STREAM, serviceId, url, name); @@ -98,6 +100,14 @@ public void setUploadDate(@Nullable DateWrapper uploadDate) { this.uploadDate = uploadDate; } + public boolean isUploaderVerified() { + return uploaderVerified; + } + + public void setUploaderVerified(boolean uploaderVerified) { + this.uploaderVerified = uploaderVerified; + } + @Override public String toString() { return "StreamInfoItem{" + @@ -112,6 +122,7 @@ public String toString() { ", url='" + getUrl() + '\'' + ", name='" + getName() + '\'' + ", thumbnailUrl='" + getThumbnailUrl() + '\'' + + ", uploaderVerified='" + isUploaderVerified() + '\'' + '}'; } } \ No newline at end of file diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/stream/StreamInfoItemExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/stream/StreamInfoItemExtractor.java index 828d452012..c9e45170e5 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/stream/StreamInfoItemExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/stream/StreamInfoItemExtractor.java @@ -71,6 +71,15 @@ public interface StreamInfoItemExtractor extends InfoItemExtractor { String getUploaderUrl() throws ParsingException; + /** + * Whether the uploader has been verified by the service's provider. + * If there is no verification implemented, return false. + * + * @return whether the uploader has been verified by the service's provider + * @throws ParsingException + */ + boolean isUploaderVerified() throws ParsingException; + /** * The original textual date provided by the service. Should be used as a fallback if * {@link #getUploadDate()} isn't provided by the service, or it fails for some reason. diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/stream/StreamInfoItemsCollector.java b/extractor/src/main/java/org/schabi/newpipe/extractor/stream/StreamInfoItemsCollector.java index da334310fe..1e6e6e91b0 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/stream/StreamInfoItemsCollector.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/stream/StreamInfoItemsCollector.java @@ -90,6 +90,12 @@ public StreamInfoItem extract(StreamInfoItemExtractor extractor) throws ParsingE } catch (Exception e) { addError(e); } + try { + resultItem.setUploaderVerified(extractor.isUploaderVerified()); + } catch (Exception e) { + addError(e); + } + return resultItem; } diff --git a/extractor/src/test/java/org/schabi/newpipe/extractor/services/BaseChannelExtractorTest.java b/extractor/src/test/java/org/schabi/newpipe/extractor/services/BaseChannelExtractorTest.java index 86ae3f9ddd..cb81dd1371 100644 --- a/extractor/src/test/java/org/schabi/newpipe/extractor/services/BaseChannelExtractorTest.java +++ b/extractor/src/test/java/org/schabi/newpipe/extractor/services/BaseChannelExtractorTest.java @@ -7,4 +7,5 @@ public interface BaseChannelExtractorTest extends BaseListExtractorTest { void testBannerUrl() throws Exception; void testFeedUrl() throws Exception; void testSubscriberCount() throws Exception; + void testVerified() throws Exception; } diff --git a/extractor/src/test/java/org/schabi/newpipe/extractor/services/BasePlaylistExtractorTest.java b/extractor/src/test/java/org/schabi/newpipe/extractor/services/BasePlaylistExtractorTest.java index ea097a3b59..cb092df4ff 100644 --- a/extractor/src/test/java/org/schabi/newpipe/extractor/services/BasePlaylistExtractorTest.java +++ b/extractor/src/test/java/org/schabi/newpipe/extractor/services/BasePlaylistExtractorTest.java @@ -7,4 +7,5 @@ public interface BasePlaylistExtractorTest extends BaseListExtractorTest { void testUploaderName() throws Exception; void testUploaderAvatarUrl() throws Exception; void testStreamCount() throws Exception; + void testUploaderVerified() throws Exception; } diff --git a/extractor/src/test/java/org/schabi/newpipe/extractor/services/DefaultStreamExtractorTest.java b/extractor/src/test/java/org/schabi/newpipe/extractor/services/DefaultStreamExtractorTest.java index 40dc72a5d0..740274ff8f 100644 --- a/extractor/src/test/java/org/schabi/newpipe/extractor/services/DefaultStreamExtractorTest.java +++ b/extractor/src/test/java/org/schabi/newpipe/extractor/services/DefaultStreamExtractorTest.java @@ -45,6 +45,7 @@ public abstract class DefaultStreamExtractorTest extends DefaultExtractorTest expectedDescriptionContains(); // e.g. for full links @@ -99,6 +100,11 @@ public void testUploaderAvatarUrl() throws Exception { assertIsSecureUrl(extractor().getUploaderAvatarUrl()); } + @Test + public void testUploaderVerified() throws Exception { + assertEquals(expectedUploaderVerified(), extractor().isUploaderVerified()); + } + @Test @Override public void testSubChannelName() throws Exception { diff --git a/extractor/src/test/java/org/schabi/newpipe/extractor/services/peertube/PeertubeAccountExtractorTest.java b/extractor/src/test/java/org/schabi/newpipe/extractor/services/peertube/PeertubeAccountExtractorTest.java index 51ae1d404f..2bff010426 100644 --- a/extractor/src/test/java/org/schabi/newpipe/extractor/services/peertube/PeertubeAccountExtractorTest.java +++ b/extractor/src/test/java/org/schabi/newpipe/extractor/services/peertube/PeertubeAccountExtractorTest.java @@ -104,6 +104,11 @@ public void testFeedUrl() throws ParsingException { public void testSubscriberCount() throws ParsingException { assertTrue("Wrong subscriber count", extractor.getSubscriberCount() >= 500); } + + @Override + public void testVerified() throws Exception { + assertFalse(extractor.isVerified()); + } } public static class FreeSoftwareFoundation implements BaseChannelExtractorTest { @@ -200,5 +205,10 @@ public void testFeedUrl() throws ParsingException { public void testSubscriberCount() throws ParsingException { assertTrue("Wrong subscriber count", extractor.getSubscriberCount() >= 100); } + + @Override + public void testVerified() throws Exception { + assertFalse(extractor.isVerified()); + } } } diff --git a/extractor/src/test/java/org/schabi/newpipe/extractor/services/peertube/PeertubeChannelExtractorTest.java b/extractor/src/test/java/org/schabi/newpipe/extractor/services/peertube/PeertubeChannelExtractorTest.java index 6215792c4f..7b2fc3da75 100644 --- a/extractor/src/test/java/org/schabi/newpipe/extractor/services/peertube/PeertubeChannelExtractorTest.java +++ b/extractor/src/test/java/org/schabi/newpipe/extractor/services/peertube/PeertubeChannelExtractorTest.java @@ -1,7 +1,6 @@ package org.schabi.newpipe.extractor.services.peertube; import org.junit.BeforeClass; -import org.junit.Ignore; import org.junit.Test; import org.schabi.newpipe.downloader.DownloaderTestImpl; import org.schabi.newpipe.extractor.NewPipe; @@ -119,6 +118,11 @@ public void testFeedUrl() throws ParsingException { public void testSubscriberCount() throws ParsingException { assertTrue("Wrong subscriber count", extractor.getSubscriberCount() >= 230); } + + @Override + public void testVerified() throws Exception { + assertFalse(extractor.isVerified()); + } } public static class ChatSceptique implements BaseChannelExtractorTest { @@ -231,5 +235,10 @@ public void testFeedUrl() throws ParsingException { public void testSubscriberCount() throws ParsingException { assertTrue("Wrong subscriber count", extractor.getSubscriberCount() >= 700); } + + @Override + public void testVerified() throws Exception { + assertFalse(extractor.isVerified()); + } } } diff --git a/extractor/src/test/java/org/schabi/newpipe/extractor/services/soundcloud/SoundcloudChannelExtractorTest.java b/extractor/src/test/java/org/schabi/newpipe/extractor/services/soundcloud/SoundcloudChannelExtractorTest.java index feb001d8b4..18d9ea605a 100644 --- a/extractor/src/test/java/org/schabi/newpipe/extractor/services/soundcloud/SoundcloudChannelExtractorTest.java +++ b/extractor/src/test/java/org/schabi/newpipe/extractor/services/soundcloud/SoundcloudChannelExtractorTest.java @@ -101,6 +101,11 @@ public void testFeedUrl() { public void testSubscriberCount() { assertTrue("Wrong subscriber count", extractor.getSubscriberCount() >= 1e6); } + + @Override + public void testVerified() throws Exception { + assertTrue(extractor.isVerified()); + } } public static class DubMatix implements BaseChannelExtractorTest { @@ -195,5 +200,10 @@ public void testFeedUrl() { public void testSubscriberCount() { assertTrue("Wrong subscriber count", extractor.getSubscriberCount() >= 2e6); } + + @Override + public void testVerified() throws Exception { + assertTrue(extractor.isVerified()); + } } } diff --git a/extractor/src/test/java/org/schabi/newpipe/extractor/services/soundcloud/SoundcloudPlaylistExtractorTest.java b/extractor/src/test/java/org/schabi/newpipe/extractor/services/soundcloud/SoundcloudPlaylistExtractorTest.java index 2a5ace0963..53870b7455 100644 --- a/extractor/src/test/java/org/schabi/newpipe/extractor/services/soundcloud/SoundcloudPlaylistExtractorTest.java +++ b/extractor/src/test/java/org/schabi/newpipe/extractor/services/soundcloud/SoundcloudPlaylistExtractorTest.java @@ -111,6 +111,11 @@ public void testUploaderAvatarUrl() { public void testStreamCount() { assertTrue("Stream count does not fit: " + extractor.getStreamCount(), extractor.getStreamCount() >= 10); } + + @Override + public void testUploaderVerified() throws Exception { + assertTrue(extractor.isUploaderVerified()); + } } public static class RandomHouseMusic implements BasePlaylistExtractorTest { @@ -203,6 +208,11 @@ public void testUploaderAvatarUrl() { public void testStreamCount() { assertTrue("Stream count does not fit: " + extractor.getStreamCount(), extractor.getStreamCount() >= 10); } + + @Override + public void testUploaderVerified() throws Exception { + assertFalse(extractor.isUploaderVerified()); + } } public static class EDMxxx implements BasePlaylistExtractorTest { @@ -310,6 +320,11 @@ public void testUploaderAvatarUrl() { public void testStreamCount() { assertTrue("Stream count does not fit: " + extractor.getStreamCount(), extractor.getStreamCount() >= 370); } + + @Override + public void testUploaderVerified() throws Exception { + assertFalse(extractor.isUploaderVerified()); + } } public static class SmallPlaylist implements BasePlaylistExtractorTest { @@ -409,5 +424,10 @@ public void testUploaderAvatarUrl() { public void testStreamCount() { assertEquals(2, extractor.getStreamCount()); } + + @Override + public void testUploaderVerified() throws Exception { + assertFalse(extractor.isUploaderVerified()); + } } } diff --git a/extractor/src/test/java/org/schabi/newpipe/extractor/services/soundcloud/search/SoundcloudSearchExtractorTest.java b/extractor/src/test/java/org/schabi/newpipe/extractor/services/soundcloud/search/SoundcloudSearchExtractorTest.java index 94779f4d37..0bd5c0aae5 100644 --- a/extractor/src/test/java/org/schabi/newpipe/extractor/services/soundcloud/search/SoundcloudSearchExtractorTest.java +++ b/extractor/src/test/java/org/schabi/newpipe/extractor/services/soundcloud/search/SoundcloudSearchExtractorTest.java @@ -8,14 +8,19 @@ import org.schabi.newpipe.extractor.ListExtractor.InfoItemsPage; import org.schabi.newpipe.extractor.NewPipe; import org.schabi.newpipe.extractor.StreamingService; +import org.schabi.newpipe.extractor.channel.ChannelInfoItem; +import org.schabi.newpipe.extractor.exceptions.ExtractionException; import org.schabi.newpipe.extractor.search.SearchExtractor; import org.schabi.newpipe.extractor.services.DefaultSearchExtractorTest; import javax.annotation.Nullable; +import java.io.IOException; import java.io.UnsupportedEncodingException; import java.net.URLEncoder; +import java.util.List; import static java.util.Collections.singletonList; +import static org.junit.Assert.assertTrue; import static org.schabi.newpipe.extractor.ServiceList.SoundCloud; import static org.schabi.newpipe.extractor.services.DefaultTests.assertNoDuplicatedItems; import static org.schabi.newpipe.extractor.services.soundcloud.linkHandler.SoundcloudSearchQueryHandlerFactory.*; @@ -139,4 +144,40 @@ private static String urlEncode(String value) { throw new RuntimeException(e); } } + + public static class UserVerified extends DefaultSearchExtractorTest { + private static SearchExtractor extractor; + private static final String QUERY = "David Guetta"; + + @BeforeClass + public static void setUp() throws Exception { + NewPipe.init(DownloaderTestImpl.getInstance()); + extractor = SoundCloud.getSearchExtractor(QUERY, singletonList(USERS), ""); + extractor.fetchPage(); + } + + @Override public SearchExtractor extractor() { return extractor; } + @Override public StreamingService expectedService() { return SoundCloud; } + @Override public String expectedName() { return QUERY; } + @Override public String expectedId() { return QUERY; } + @Override public String expectedUrlContains() { return "soundcloud.com/search/users?q=" + urlEncode(QUERY); } + @Override public String expectedOriginalUrlContains() { return "soundcloud.com/search/users?q=" + urlEncode(QUERY); } + @Override public String expectedSearchString() { return QUERY; } + @Nullable @Override public String expectedSearchSuggestion() { return null; } + + @Override public InfoItem.InfoType expectedInfoItemType() { return InfoItem.InfoType.CHANNEL; } + + @Test + public void testIsVerified() throws IOException, ExtractionException { + final List items = extractor.getInitialPage().getItems(); + boolean verified = false; + for (InfoItem item : items) { + if (item.getUrl().equals("https://soundcloud.com/davidguetta")) { + verified = ((ChannelInfoItem) item).isVerified(); + break; + } + } + assertTrue(verified); + } + } } diff --git a/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/YoutubeChannelExtractorTest.java b/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/YoutubeChannelExtractorTest.java index b83c1ed0dd..777a47f8fc 100644 --- a/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/YoutubeChannelExtractorTest.java +++ b/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/YoutubeChannelExtractorTest.java @@ -16,14 +16,10 @@ import static org.hamcrest.CoreMatchers.containsString; import static org.hamcrest.MatcherAssert.assertThat; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; -import static org.junit.Assert.fail; +import static org.junit.Assert.*; import static org.schabi.newpipe.extractor.ExtractorAsserts.assertIsSecureUrl; import static org.schabi.newpipe.extractor.ServiceList.YouTube; -import static org.schabi.newpipe.extractor.services.DefaultTests.defaultTestGetPageInNewExtractor; -import static org.schabi.newpipe.extractor.services.DefaultTests.defaultTestMoreItems; -import static org.schabi.newpipe.extractor.services.DefaultTests.defaultTestRelatedItems; +import static org.schabi.newpipe.extractor.services.DefaultTests.*; /** * Test for {@link ChannelExtractor} @@ -157,6 +153,12 @@ public void testSubscriberCount() throws Exception { assertTrue("Wrong subscriber count", extractor.getSubscriberCount() >= 0); assertTrue("Subscriber count too small", extractor.getSubscriberCount() >= 4e6); } + + @Override + public void testVerified() throws Exception { + assertTrue(extractor.isVerified()); + } + } // Youtube RED/Premium ad blocking test @@ -250,6 +252,11 @@ public void testSubscriberCount() throws Exception { assertTrue("Subscriber count too small", extractor.getSubscriberCount() >= 10e6); } + @Override + public void testVerified() throws Exception { + assertTrue(extractor.isVerified()); + } + } public static class Kurzgesagt implements BaseChannelExtractorTest { @@ -343,6 +350,11 @@ public void testFeedUrl() throws Exception { public void testSubscriberCount() throws Exception { assertTrue("Wrong subscriber count", extractor.getSubscriberCount() >= 5e6); } + + @Override + public void testVerified() throws Exception { + assertTrue(extractor.isVerified()); + } } public static class KurzgesagtAdditional { @@ -453,6 +465,11 @@ public void testFeedUrl() throws Exception { public void testSubscriberCount() throws Exception { assertTrue("Wrong subscriber count", extractor.getSubscriberCount() >= 5e5); } + + @Override + public void testVerified() throws Exception { + assertTrue(extractor.isVerified()); + } } public static class RandomChannel implements BaseChannelExtractorTest { @@ -550,6 +567,11 @@ public void testSubscriberCount() throws Exception { long subscribers = extractor.getSubscriberCount(); assertTrue("Wrong subscriber count: " + subscribers, subscribers >= 50); } + + @Override + public void testVerified() throws Exception { + assertFalse(extractor.isVerified()); + } } } diff --git a/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/YoutubePlaylistExtractorTest.java b/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/YoutubePlaylistExtractorTest.java index 0af9ef530f..fcec61a135 100644 --- a/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/YoutubePlaylistExtractorTest.java +++ b/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/YoutubePlaylistExtractorTest.java @@ -13,11 +13,7 @@ import org.schabi.newpipe.extractor.exceptions.ParsingException; import org.schabi.newpipe.extractor.playlist.PlaylistExtractor; import org.schabi.newpipe.extractor.services.BasePlaylistExtractorTest; -import org.schabi.newpipe.extractor.services.youtube.YoutubePlaylistExtractorTest.ContinuationsTests; -import org.schabi.newpipe.extractor.services.youtube.YoutubePlaylistExtractorTest.HugePlaylist; -import org.schabi.newpipe.extractor.services.youtube.YoutubePlaylistExtractorTest.LearningPlaylist; -import org.schabi.newpipe.extractor.services.youtube.YoutubePlaylistExtractorTest.NotAvailable; -import org.schabi.newpipe.extractor.services.youtube.YoutubePlaylistExtractorTest.TimelessPopHits; +import org.schabi.newpipe.extractor.services.youtube.YoutubePlaylistExtractorTest.*; import org.schabi.newpipe.extractor.services.youtube.extractors.YoutubePlaylistExtractor; import org.schabi.newpipe.extractor.stream.StreamInfoItem; @@ -39,7 +35,7 @@ */ @RunWith(Suite.class) @SuiteClasses({NotAvailable.class, TimelessPopHits.class, HugePlaylist.class, - LearningPlaylist.class, ContinuationsTests.class}) + LearningPlaylist.class, ContinuationsTests.class}) public class YoutubePlaylistExtractorTest { private static final String RESOURCE_PATH = DownloaderFactory.RESOURCE_PATH + "services/youtube/extractor/playlist/"; @@ -163,6 +159,11 @@ public void testUploaderAvatarUrl() throws Exception { public void testStreamCount() throws Exception { assertTrue("Error in the streams count", extractor.getStreamCount() > 100); } + + @Override + public void testUploaderVerified() throws Exception { + assertFalse(extractor.isUploaderVerified()); + } } public static class HugePlaylist implements BasePlaylistExtractorTest { @@ -276,6 +277,11 @@ public void testUploaderAvatarUrl() throws Exception { public void testStreamCount() throws Exception { assertTrue("Error in the streams count", extractor.getStreamCount() > 100); } + + @Override + public void testUploaderVerified() throws Exception { + assertTrue(extractor.isUploaderVerified()); + } } public static class LearningPlaylist implements BasePlaylistExtractorTest { @@ -375,6 +381,11 @@ public void testUploaderAvatarUrl() throws Exception { public void testStreamCount() throws Exception { assertTrue("Error in the streams count", extractor.getStreamCount() > 40); } + + @Override + public void testUploaderVerified() throws Exception { + assertTrue(extractor.isUploaderVerified()); + } } public static class ContinuationsTests { @@ -388,8 +399,8 @@ public static void setUp() throws IOException { @Test public void testNoContinuations() throws Exception { final YoutubePlaylistExtractor extractor = (YoutubePlaylistExtractor) YouTube - .getPlaylistExtractor( - "https://www.youtube.com/playlist?list=PLXJg25X-OulsVsnvZ7RVtSDW-id9_RzAO"); + .getPlaylistExtractor( + "https://www.youtube.com/playlist?list=PLXJg25X-OulsVsnvZ7RVtSDW-id9_RzAO"); extractor.fetchPage(); assertNoMoreItems(extractor); @@ -398,12 +409,12 @@ public void testNoContinuations() throws Exception { @Test public void testOnlySingleContinuation() throws Exception { final YoutubePlaylistExtractor extractor = (YoutubePlaylistExtractor) YouTube - .getPlaylistExtractor( - "https://www.youtube.com/playlist?list=PLjgwFL8urN2DFRuRkFTkmtHjyoNWHHdZX"); + .getPlaylistExtractor( + "https://www.youtube.com/playlist?list=PLjgwFL8urN2DFRuRkFTkmtHjyoNWHHdZX"); extractor.fetchPage(); final ListExtractor.InfoItemsPage page = defaultTestMoreItems( - extractor); + extractor); assertFalse("More items available when it shouldn't", page.hasNextPage()); } } diff --git a/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/search/YoutubeSearchExtractorTest.java b/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/search/YoutubeSearchExtractorTest.java index 0e3222c142..f5737cd9d6 100644 --- a/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/search/YoutubeSearchExtractorTest.java +++ b/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/search/YoutubeSearchExtractorTest.java @@ -13,14 +13,19 @@ import org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper; import org.schabi.newpipe.extractor.stream.Description; +import org.schabi.newpipe.downloader.DownloaderTestImpl; +import org.schabi.newpipe.extractor.channel.ChannelInfoItem; +import org.schabi.newpipe.extractor.exceptions.ExtractionException; + +import javax.annotation.Nullable; + +import java.io.IOException; import java.net.MalformedURLException; import java.net.URL; import java.util.ArrayList; import java.util.Collections; import java.util.List; -import javax.annotation.Nullable; - import static java.util.Collections.singletonList; import static junit.framework.TestCase.assertFalse; import static org.junit.Assert.assertEquals; @@ -31,7 +36,6 @@ import static org.schabi.newpipe.extractor.services.youtube.linkHandler.YoutubeSearchQueryHandlerFactory.CHANNELS; import static org.schabi.newpipe.extractor.services.youtube.linkHandler.YoutubeSearchQueryHandlerFactory.PLAYLISTS; import static org.schabi.newpipe.extractor.services.youtube.linkHandler.YoutubeSearchQueryHandlerFactory.VIDEOS; -import static org.schabi.newpipe.extractor.utils.Utils.EMPTY_STRING; public class YoutubeSearchExtractorTest { @@ -269,4 +273,41 @@ public void clarificationTest() throws Exception { @Override public String expectedOriginalUrlContains() throws Exception { return "youtube.com/results?search_query=" + QUERY; } } + + public static class ChannelVerified extends DefaultSearchExtractorTest { + private static SearchExtractor extractor; + private static final String QUERY = "bbc"; + + @BeforeClass + public static void setUp() throws Exception { + NewPipe.init(DownloaderTestImpl.getInstance()); + extractor = YouTube.getSearchExtractor(QUERY, singletonList(CHANNELS), ""); + extractor.fetchPage(); + } + + @Override public SearchExtractor extractor() { return extractor; } + @Override public StreamingService expectedService() { return YouTube; } + @Override public String expectedName() { return QUERY; } + @Override public String expectedId() { return QUERY; } + @Override public String expectedUrlContains() { return "youtube.com/results?search_query=" + QUERY; } + @Override public String expectedOriginalUrlContains() { return "youtube.com/results?search_query=" + QUERY; } + @Override public String expectedSearchString() { return QUERY; } + @Nullable @Override public String expectedSearchSuggestion() { return null; } + @Override public InfoItem.InfoType expectedInfoItemType() { return InfoItem.InfoType.CHANNEL; } + + @Test + public void testAtLeastOneVerified() throws IOException, ExtractionException { + final List items = extractor.getInitialPage().getItems(); + boolean verified = false; + for (InfoItem item : items) { + if (((ChannelInfoItem) item).isVerified()) { + verified = true; + break; + } + } + + assertTrue(verified); + } + } + } diff --git a/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/stream/YoutubeStreamExtractorAgeRestrictedTest.java b/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/stream/YoutubeStreamExtractorAgeRestrictedTest.java index ca65e36a11..63fa341199 100644 --- a/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/stream/YoutubeStreamExtractorAgeRestrictedTest.java +++ b/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/stream/YoutubeStreamExtractorAgeRestrictedTest.java @@ -41,6 +41,7 @@ public static void setUp() throws Exception { @Override public StreamType expectedStreamType() { return StreamType.VIDEO_STREAM; } @Override public String expectedUploaderName() { return "EpicFiveTV"; } @Override public String expectedUploaderUrl() { return "https://www.youtube.com/channel/UCuPUHlLP5POZphOIrjrNxiw"; } + @Override public boolean expectedUploaderVerified() { return true; } @Override public List expectedDescriptionContains() { return Arrays.asList("http://instagram.com/Ruben_Sole", "AVN"); } @Override public long expectedLength() { return 1790; } @Override public long expectedTimestamp() { return TIMESTAMP; } diff --git a/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/stream/YoutubeStreamExtractorDefaultTest.java b/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/stream/YoutubeStreamExtractorDefaultTest.java index 311725f61e..f498a573cf 100644 --- a/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/stream/YoutubeStreamExtractorDefaultTest.java +++ b/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/stream/YoutubeStreamExtractorDefaultTest.java @@ -103,6 +103,7 @@ public static void setUp() throws Exception { return Arrays.asList("https://www.youtube.com/channel/UC7l23W7gFi4Uho6WSzckZRA", "https://www.handcraftpictures.com/"); } + @Override public boolean expectedUploaderVerified() { return true; } @Override public long expectedLength() { return 381; } @Override public long expectedTimestamp() { return TIMESTAMP; } @Override public long expectedViewCountAtLeast() { return 26682500; } @@ -150,6 +151,7 @@ public static void setUp() throws Exception { @Nullable @Override public String expectedTextualUploadDate() { return "2018-06-19"; } @Override public long expectedLikeCountAtLeast() { return 340100; } @Override public long expectedDislikeCountAtLeast() { return 18700; } + @Override public boolean expectedUploaderVerified() { return true; } // @formatter:on @Override @Test @@ -271,6 +273,7 @@ public static void setUp() throws Exception { @Override public String expectedUploaderName() { return "maiLab"; } @Override public String expectedUploaderUrl() { return "https://www.youtube.com/channel/UCyHDQ5C6z1NDmJ4g6SerW8g"; } @Override public List expectedDescriptionContains() {return Arrays.asList("Vitamin", "2:44", "Was ist Vitamin D?");} + @Override public boolean expectedUploaderVerified() { return true; } @Override public long expectedLength() { return 1010; } @Override public long expectedViewCountAtLeast() { return 815500; } @Nullable @Override public String expectedUploadDate() { return "2020-11-18 00:00:00.000"; } @@ -339,6 +342,7 @@ public static void setUp() throws Exception { Collections.singletonList("Wikipedia (German)") )); } + @Override public boolean expectedUploaderVerified() { return true; } // @formatter:on @Override @Ignore("TODO fix") diff --git a/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/stream/YoutubeStreamExtractorLivestreamTest.java b/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/stream/YoutubeStreamExtractorLivestreamTest.java index 12a9e1af33..47bf775a9c 100644 --- a/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/stream/YoutubeStreamExtractorLivestreamTest.java +++ b/extractor/src/test/java/org/schabi/newpipe/extractor/services/youtube/stream/YoutubeStreamExtractorLivestreamTest.java @@ -45,6 +45,7 @@ public static void setUp() throws Exception { return Arrays.asList("https://bit.ly/chilledcow-playlists", "https://bit.ly/chilledcow-submissions"); } + @Override public boolean expectedUploaderVerified() { return true; } @Override public long expectedLength() { return 0; } @Override public long expectedTimestamp() { return TIMESTAMP; } @Override public long expectedViewCountAtLeast() { return 0; }