Simplify getId() in YoutubeChannelExtractor
This commit is contained in:
parent
ecfc27a92c
commit
8e6be880d7
|
@ -6,7 +6,6 @@ import com.grack.nanojson.JsonParser;
|
||||||
import com.grack.nanojson.JsonParserException;
|
import com.grack.nanojson.JsonParserException;
|
||||||
|
|
||||||
import org.jsoup.nodes.Document;
|
import org.jsoup.nodes.Document;
|
||||||
import org.jsoup.nodes.Element;
|
|
||||||
import org.schabi.newpipe.extractor.StreamingService;
|
import org.schabi.newpipe.extractor.StreamingService;
|
||||||
import org.schabi.newpipe.extractor.channel.ChannelExtractor;
|
import org.schabi.newpipe.extractor.channel.ChannelExtractor;
|
||||||
import org.schabi.newpipe.extractor.downloader.Downloader;
|
import org.schabi.newpipe.extractor.downloader.Downloader;
|
||||||
|
@ -91,18 +90,7 @@ public class YoutubeChannelExtractor extends ChannelExtractor {
|
||||||
@Override
|
@Override
|
||||||
public String getId() throws ParsingException {
|
public String getId() throws ParsingException {
|
||||||
try {
|
try {
|
||||||
return doc.select("meta[property=\"og:url\"]").first().attr("content").replace(CHANNEL_URL_BASE, "");
|
return initialData.getObject("header").getObject("c4TabbedHeaderRenderer").getString("channelId");
|
||||||
} catch (Exception ignored) {}
|
|
||||||
try {
|
|
||||||
return initialData.getObject("header").getObject("c4TabbedHeaderRenderer").getObject("navigationEndpoint").getObject("browseEndpoint").getString("browseId");
|
|
||||||
} catch (Exception ignored) {}
|
|
||||||
|
|
||||||
// fallback method; does not work with channels that have no "Subscribe" button (e.g. EminemVEVO)
|
|
||||||
try {
|
|
||||||
Element element = doc.getElementsByClass("yt-uix-subscription-button").first();
|
|
||||||
if (element == null) element = doc.getElementsByClass("yt-uix-subscription-preferences-button").first();
|
|
||||||
|
|
||||||
return element.attr("data-channel-external-id");
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
throw new ParsingException("Could not get channel id", e);
|
throw new ParsingException("Could not get channel id", e);
|
||||||
}
|
}
|
||||||
|
@ -112,7 +100,7 @@ public class YoutubeChannelExtractor extends ChannelExtractor {
|
||||||
@Override
|
@Override
|
||||||
public String getName() throws ParsingException {
|
public String getName() throws ParsingException {
|
||||||
try {
|
try {
|
||||||
return doc.select("meta[property=\"og:title\"]").first().attr("content");
|
return initialData.getObject("header").getObject("c4TabbedHeaderRenderer").getString("title");
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
throw new ParsingException("Could not get channel name", e);
|
throw new ParsingException("Could not get channel name", e);
|
||||||
}
|
}
|
||||||
|
@ -121,7 +109,8 @@ public class YoutubeChannelExtractor extends ChannelExtractor {
|
||||||
@Override
|
@Override
|
||||||
public String getAvatarUrl() throws ParsingException {
|
public String getAvatarUrl() throws ParsingException {
|
||||||
try {
|
try {
|
||||||
return initialData.getObject("header").getObject("c4TabbedHeaderRenderer").getObject("avatar").getArray("thumbnails").getObject(0).getString("url");
|
return initialData.getObject("header").getObject("c4TabbedHeaderRenderer").getObject("avatar")
|
||||||
|
.getArray("thumbnails").getObject(0).getString("url");
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
throw new ParsingException("Could not get avatar", e);
|
throw new ParsingException("Could not get avatar", e);
|
||||||
}
|
}
|
||||||
|
@ -132,7 +121,8 @@ public class YoutubeChannelExtractor extends ChannelExtractor {
|
||||||
try {
|
try {
|
||||||
String url = null;
|
String url = null;
|
||||||
try {
|
try {
|
||||||
url = initialData.getObject("header").getObject("c4TabbedHeaderRenderer").getObject("banner").getArray("thumbnails").getObject(0).getString("url");
|
url = initialData.getObject("header").getObject("c4TabbedHeaderRenderer").getObject("banner")
|
||||||
|
.getArray("thumbnails").getObject(0).getString("url");
|
||||||
} catch (Exception ignored) {}
|
} catch (Exception ignored) {}
|
||||||
if (url == null || url.contains("s.ytimg.com") || url.contains("default_banner")) {
|
if (url == null || url.contains("s.ytimg.com") || url.contains("default_banner")) {
|
||||||
return null;
|
return null;
|
||||||
|
@ -149,7 +139,7 @@ public class YoutubeChannelExtractor extends ChannelExtractor {
|
||||||
|
|
||||||
return url;
|
return url;
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
throw new ParsingException("Could not get Banner", e);
|
throw new ParsingException("Could not get banner", e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -157,10 +157,8 @@ public class YoutubeStreamInfoItemExtractor implements StreamInfoItemExtractor {
|
||||||
@Nullable
|
@Nullable
|
||||||
@Override
|
@Override
|
||||||
public String getTextualUploadDate() {
|
public String getTextualUploadDate() {
|
||||||
// TODO: Get upload date in case of a videoRenderer (not available in case of a compactVideoRenderer)
|
|
||||||
try {
|
try {
|
||||||
String s =videoInfo.getObject("publishedTimeText").getString("simpleText");
|
return videoInfo.getObject("publishedTimeText").getString("simpleText");
|
||||||
return s;
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
// upload date is not always available, e.g. in playlists
|
// upload date is not always available, e.g. in playlists
|
||||||
return null;
|
return null;
|
||||||
|
|
Loading…
Reference in New Issue