mirror of
https://codeberg.org/Bazsalanszky/Infinity-For-Lemmy.git
synced 2025-01-27 18:14:45 +01:00
Better post type detection
Signed-off-by: Balazs Toldi <balazs@toldi.eu>
This commit is contained in:
parent
a784ca86f9
commit
f6800b818d
@ -196,8 +196,8 @@ public class ParsePost {
|
|||||||
Uri uri = Uri.parse(url);
|
Uri uri = Uri.parse(url);
|
||||||
String path = uri.getPath();
|
String path = uri.getPath();
|
||||||
|
|
||||||
if (!data.has(JSONUtils.PREVIEW_KEY) && previews.isEmpty()) {
|
if (!data.getJSONObject("post").has("thumbnail_url") && previews.isEmpty()) {
|
||||||
if (!data.getJSONObject("post").isNull("body")) {
|
if (!data.getJSONObject("post").isNull("body") && url.equals("")) {
|
||||||
//Text post
|
//Text post
|
||||||
int postType = Post.TEXT_TYPE;
|
int postType = Post.TEXT_TYPE;
|
||||||
post = new Post(id, fullName, subredditName, subredditNamePrefixed, author, authorFull,
|
post = new Post(id, fullName, subredditName, subredditNamePrefixed, author, authorFull,
|
||||||
@ -229,17 +229,17 @@ public class ParsePost {
|
|||||||
String videoUrl = Html.fromHtml(redditVideoObject.getString(JSONUtils.HLS_URL_KEY)).toString();
|
String videoUrl = Html.fromHtml(redditVideoObject.getString(JSONUtils.HLS_URL_KEY)).toString();
|
||||||
String videoDownloadUrl = redditVideoObject.getString(JSONUtils.FALLBACK_URL_KEY);
|
String videoDownloadUrl = redditVideoObject.getString(JSONUtils.FALLBACK_URL_KEY);
|
||||||
|
|
||||||
post = new Post(id, fullName, subredditName, subredditNamePrefixed, author,authorFull, postTimeMillis, title, permalink, score, postType, voteType,
|
post = new Post(id, fullName, subredditName, subredditNamePrefixed, author, authorFull, postTimeMillis, title, permalink, score, postType, voteType,
|
||||||
nComments, upvoteRatio, nsfw, locked, saved, distinguished, suggestedSort);
|
nComments, upvoteRatio, nsfw, locked, saved, distinguished, suggestedSort);
|
||||||
|
|
||||||
post.setVideoUrl(videoUrl);
|
post.setVideoUrl(videoUrl);
|
||||||
post.setVideoDownloadUrl(videoDownloadUrl);
|
post.setVideoDownloadUrl(videoDownloadUrl);
|
||||||
} else {
|
} else if (!url.equals("")) {
|
||||||
//No preview link post
|
//No preview link post
|
||||||
int postType = Post.NO_PREVIEW_LINK_TYPE;
|
int postType = Post.NO_PREVIEW_LINK_TYPE;
|
||||||
post = new Post(id, fullName, subredditName, subredditNamePrefixed, author,authorFull,
|
post = new Post(id, fullName, subredditName, subredditNamePrefixed, author, authorFull,
|
||||||
postTimeMillis, title, url, permalink, score,
|
postTimeMillis, title, url, permalink, score,
|
||||||
postType, voteType, nComments, upvoteRatio, nsfw, locked, saved, distinguished, suggestedSort);
|
postType, voteType, nComments, upvoteRatio, nsfw, locked, saved, distinguished, suggestedSort);
|
||||||
if (data.isNull(JSONUtils.SELFTEXT_KEY)) {
|
if (data.isNull(JSONUtils.SELFTEXT_KEY)) {
|
||||||
post.setSelfText("");
|
post.setSelfText("");
|
||||||
} else {
|
} else {
|
||||||
@ -269,12 +269,22 @@ public class ParsePost {
|
|||||||
post.setStreamableShortCode(shortCode);
|
post.setStreamableShortCode(shortCode);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
int postType = Post.TEXT_TYPE;
|
||||||
|
post = new Post(id, fullName, subredditName, subredditNamePrefixed, author, authorFull,
|
||||||
|
postTimeMillis, title, permalink, score,
|
||||||
|
postType, voteType, nComments, upvoteRatio, nsfw,
|
||||||
|
locked, saved, distinguished, suggestedSort);
|
||||||
|
String body = "";
|
||||||
|
post.setSelfText(body);
|
||||||
|
post.setSelfTextPlain(body);
|
||||||
|
post.setSelfTextPlainTrimmed(body.trim());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (previews.isEmpty()) {
|
if (previews.isEmpty()) {
|
||||||
if (data.has(JSONUtils.PREVIEW_KEY)) {
|
if (data.getJSONObject("post").has("thumbnail_url")) {
|
||||||
JSONObject images = data.getJSONObject(JSONUtils.PREVIEW_KEY).getJSONArray(JSONUtils.IMAGES_KEY).getJSONObject(0);
|
JSONObject images = data.getJSONObject(JSONUtils.PREVIEW_KEY).getJSONArray(JSONUtils.IMAGES_KEY).getJSONObject(0);
|
||||||
String previewUrl = images.getJSONObject(JSONUtils.SOURCE_KEY).getString(JSONUtils.URL_KEY);
|
String previewUrl = images.getJSONObject(JSONUtils.SOURCE_KEY).getString(JSONUtils.URL_KEY);
|
||||||
int previewWidth = images.getJSONObject(JSONUtils.SOURCE_KEY).getInt(JSONUtils.WIDTH_KEY);
|
int previewWidth = images.getJSONObject(JSONUtils.SOURCE_KEY).getInt(JSONUtils.WIDTH_KEY);
|
||||||
@ -300,146 +310,102 @@ public class ParsePost {
|
|||||||
String videoUrl = Html.fromHtml(redditVideoObject.getString(JSONUtils.HLS_URL_KEY)).toString();
|
String videoUrl = Html.fromHtml(redditVideoObject.getString(JSONUtils.HLS_URL_KEY)).toString();
|
||||||
String videoDownloadUrl = redditVideoObject.getString(JSONUtils.FALLBACK_URL_KEY);
|
String videoDownloadUrl = redditVideoObject.getString(JSONUtils.FALLBACK_URL_KEY);
|
||||||
|
|
||||||
post = new Post(id, fullName, subredditName, subredditNamePrefixed, author,authorFull, postTimeMillis, title, permalink, score, postType, voteType,
|
post = new Post(id, fullName, subredditName, subredditNamePrefixed, author, authorFull, postTimeMillis, title, permalink, score, postType, voteType,
|
||||||
nComments, upvoteRatio, nsfw, locked, saved, distinguished, suggestedSort);
|
nComments, upvoteRatio, nsfw, locked, saved, distinguished, suggestedSort);
|
||||||
|
|
||||||
post.setPreviews(previews);
|
post.setPreviews(previews);
|
||||||
post.setVideoUrl(videoUrl);
|
post.setVideoUrl(videoUrl);
|
||||||
post.setVideoDownloadUrl(videoDownloadUrl);
|
post.setVideoDownloadUrl(videoDownloadUrl);
|
||||||
} else if (data.has(JSONUtils.PREVIEW_KEY)) {
|
} else if (data.getJSONObject("post").has("thumbnail_url")) {
|
||||||
if (data.getJSONObject(JSONUtils.PREVIEW_KEY).has(JSONUtils.REDDIT_VIDEO_PREVIEW_KEY)) {
|
if (path.endsWith(".jpg") || path.endsWith(".png") || path.endsWith(".jpeg") || path.endsWith(".webp")) {
|
||||||
int postType = Post.VIDEO_TYPE;
|
//Image post
|
||||||
String authority = uri.getAuthority();
|
int postType = Post.IMAGE_TYPE;
|
||||||
// The hls stream inside REDDIT_VIDEO_PREVIEW_KEY can sometimes lack an audio track
|
|
||||||
if (authority.contains("imgur.com") && (path.endsWith(".gifv") || path.endsWith(".mp4"))) {
|
|
||||||
if (path.endsWith(".gifv")) {
|
|
||||||
url = url.substring(0, url.length() - 5) + ".mp4";
|
|
||||||
}
|
|
||||||
|
|
||||||
post = new Post(id, fullName, subredditName, subredditNamePrefixed, author, authorFull,postTimeMillis, title, permalink, score, postType, voteType,
|
post = new Post(id, fullName, subredditName, subredditNamePrefixed, author,
|
||||||
nComments, upvoteRatio, nsfw, locked, saved, distinguished, suggestedSort);
|
authorFull, postTimeMillis, title, url, permalink, score,
|
||||||
post.setPreviews(previews);
|
postType, voteType, nComments, upvoteRatio, nsfw, locked, saved,
|
||||||
post.setVideoUrl(url);
|
distinguished, suggestedSort);
|
||||||
post.setVideoDownloadUrl(url);
|
|
||||||
post.setIsImgur(true);
|
|
||||||
} else {
|
|
||||||
//Gif video post (HLS)
|
|
||||||
|
|
||||||
String videoUrl = Html.fromHtml(data.getJSONObject(JSONUtils.PREVIEW_KEY)
|
if (previews.isEmpty()) {
|
||||||
.getJSONObject(JSONUtils.REDDIT_VIDEO_PREVIEW_KEY).getString(JSONUtils.HLS_URL_KEY)).toString();
|
previews.add(new Post.Preview(url, 0, 0, "", ""));
|
||||||
String videoDownloadUrl = data.getJSONObject(JSONUtils.PREVIEW_KEY)
|
|
||||||
.getJSONObject(JSONUtils.REDDIT_VIDEO_PREVIEW_KEY).getString(JSONUtils.FALLBACK_URL_KEY);
|
|
||||||
|
|
||||||
post = new Post(id, fullName, subredditName, subredditNamePrefixed, author,authorFull, postTimeMillis, title, permalink, score, postType, voteType,
|
|
||||||
nComments, upvoteRatio, nsfw, locked, saved, distinguished, suggestedSort);
|
|
||||||
post.setPreviews(previews);
|
|
||||||
post.setVideoUrl(videoUrl);
|
|
||||||
post.setVideoDownloadUrl(videoDownloadUrl);
|
|
||||||
}
|
}
|
||||||
|
post.setPreviews(previews);
|
||||||
|
} else if (path.endsWith(".gif")) {
|
||||||
|
//Gif post
|
||||||
|
int postType = Post.GIF_TYPE;
|
||||||
|
post = new Post(id, fullName, subredditName, subredditNamePrefixed, author, authorFull,
|
||||||
|
postTimeMillis, title, url, permalink, score,
|
||||||
|
postType, voteType, nComments, upvoteRatio,
|
||||||
|
nsfw, locked, saved,
|
||||||
|
distinguished, suggestedSort);
|
||||||
|
|
||||||
|
post.setPreviews(previews);
|
||||||
|
post.setVideoUrl(url);
|
||||||
|
} else if (uri.getAuthority().contains("imgur.com") && (path.endsWith(".gifv") || path.endsWith(".mp4"))) {
|
||||||
|
// Imgur gifv/mp4
|
||||||
|
int postType = Post.VIDEO_TYPE;
|
||||||
|
|
||||||
|
if (url.endsWith("gifv")) {
|
||||||
|
url = url.substring(0, url.length() - 5) + ".mp4";
|
||||||
|
}
|
||||||
|
|
||||||
|
post = new Post(id, fullName, subredditName, subredditNamePrefixed, author, authorFull,
|
||||||
|
postTimeMillis, title, url, permalink, score,
|
||||||
|
postType, voteType, nComments, upvoteRatio,
|
||||||
|
nsfw, locked, saved,
|
||||||
|
distinguished, suggestedSort);
|
||||||
|
post.setPreviews(previews);
|
||||||
|
post.setVideoUrl(url);
|
||||||
|
post.setVideoDownloadUrl(url);
|
||||||
|
post.setIsImgur(true);
|
||||||
|
} else if (path.endsWith(".mp4")) {
|
||||||
|
//Video post
|
||||||
|
int postType = Post.VIDEO_TYPE;
|
||||||
|
|
||||||
|
post = new Post(id, fullName, subredditName, subredditNamePrefixed, author, authorFull,
|
||||||
|
postTimeMillis, title, url, permalink, score,
|
||||||
|
postType, voteType, nComments, upvoteRatio, nsfw, locked, saved,
|
||||||
|
distinguished, suggestedSort);
|
||||||
|
post.setPreviews(previews);
|
||||||
|
post.setVideoUrl(url);
|
||||||
|
post.setVideoDownloadUrl(url);
|
||||||
} else {
|
} else {
|
||||||
if (path.endsWith(".jpg") || path.endsWith(".png") || path.endsWith(".jpeg")|| path.endsWith(".webp")) {
|
//Link post
|
||||||
//Image post
|
int postType = Post.LINK_TYPE;
|
||||||
int postType = Post.IMAGE_TYPE;
|
|
||||||
|
|
||||||
post = new Post(id, fullName, subredditName, subredditNamePrefixed, author,
|
post = new Post(id, fullName, subredditName, subredditNamePrefixed, author, authorFull,
|
||||||
authorFull,postTimeMillis, title, url, permalink, score,
|
postTimeMillis, title, url, permalink, score,
|
||||||
postType, voteType, nComments, upvoteRatio, nsfw, locked, saved,
|
postType, voteType, nComments, upvoteRatio, nsfw, locked, saved,
|
||||||
distinguished, suggestedSort);
|
distinguished, suggestedSort);
|
||||||
|
if (data.isNull(JSONUtils.SELFTEXT_KEY)) {
|
||||||
if (previews.isEmpty()) {
|
post.setSelfText("");
|
||||||
previews.add(new Post.Preview(url, 0, 0, "", ""));
|
|
||||||
}
|
|
||||||
post.setPreviews(previews);
|
|
||||||
} else if (path.endsWith(".gif")) {
|
|
||||||
//Gif post
|
|
||||||
int postType = Post.GIF_TYPE;
|
|
||||||
post = new Post(id, fullName, subredditName, subredditNamePrefixed, author,authorFull,
|
|
||||||
postTimeMillis, title, url, permalink, score,
|
|
||||||
postType, voteType, nComments, upvoteRatio,
|
|
||||||
nsfw, locked, saved,
|
|
||||||
distinguished, suggestedSort);
|
|
||||||
|
|
||||||
post.setPreviews(previews);
|
|
||||||
post.setVideoUrl(url);
|
|
||||||
} else if (uri.getAuthority().contains("imgur.com") && (path.endsWith(".gifv") || path.endsWith(".mp4"))) {
|
|
||||||
// Imgur gifv/mp4
|
|
||||||
int postType = Post.VIDEO_TYPE;
|
|
||||||
|
|
||||||
if (url.endsWith("gifv")) {
|
|
||||||
url = url.substring(0, url.length() - 5) + ".mp4";
|
|
||||||
}
|
|
||||||
|
|
||||||
post = new Post(id, fullName, subredditName, subredditNamePrefixed, author,authorFull,
|
|
||||||
postTimeMillis, title, url, permalink, score,
|
|
||||||
postType, voteType, nComments, upvoteRatio,
|
|
||||||
nsfw, locked, saved,
|
|
||||||
distinguished, suggestedSort);
|
|
||||||
post.setPreviews(previews);
|
|
||||||
post.setVideoUrl(url);
|
|
||||||
post.setVideoDownloadUrl(url);
|
|
||||||
post.setIsImgur(true);
|
|
||||||
} else if (path.endsWith(".mp4")) {
|
|
||||||
//Video post
|
|
||||||
int postType = Post.VIDEO_TYPE;
|
|
||||||
|
|
||||||
post = new Post(id, fullName, subredditName, subredditNamePrefixed, author,authorFull,
|
|
||||||
postTimeMillis, title, url, permalink, score,
|
|
||||||
postType, voteType, nComments, upvoteRatio, nsfw, locked, saved,
|
|
||||||
distinguished, suggestedSort);
|
|
||||||
post.setPreviews(previews);
|
|
||||||
post.setVideoUrl(url);
|
|
||||||
post.setVideoDownloadUrl(url);
|
|
||||||
} else {
|
} else {
|
||||||
if (url.contains(permalink)) {
|
post.setSelfText(Utils.modifyMarkdown(Utils.trimTrailingWhitespace(data.getString(JSONUtils.SELFTEXT_KEY))));
|
||||||
//Text post but with a preview
|
}
|
||||||
int postType = Post.TEXT_TYPE;
|
|
||||||
|
|
||||||
post = new Post(id, fullName, subredditName, subredditNamePrefixed, author,authorFull,
|
post.setPreviews(previews);
|
||||||
postTimeMillis, title, permalink, score,
|
|
||||||
postType, voteType, nComments, upvoteRatio, nsfw, locked, saved,
|
|
||||||
distinguished, suggestedSort);
|
|
||||||
|
|
||||||
//Need attention
|
String authority = uri.getAuthority();
|
||||||
post.setPreviews(previews);
|
|
||||||
} else {
|
|
||||||
//Link post
|
|
||||||
int postType = Post.LINK_TYPE;
|
|
||||||
|
|
||||||
post = new Post(id, fullName, subredditName, subredditNamePrefixed, author,authorFull,
|
if (authority != null) {
|
||||||
postTimeMillis, title, url, permalink, score,
|
if (authority.contains("gfycat.com")) {
|
||||||
postType, voteType, nComments, upvoteRatio, nsfw, locked, saved,
|
String gfycatId = url.substring(url.lastIndexOf("/") + 1).toLowerCase();
|
||||||
distinguished, suggestedSort);
|
post.setPostType(Post.VIDEO_TYPE);
|
||||||
if (data.isNull(JSONUtils.SELFTEXT_KEY)) {
|
post.setIsGfycat(true);
|
||||||
post.setSelfText("");
|
post.setVideoUrl(url);
|
||||||
} else {
|
post.setGfycatId(gfycatId);
|
||||||
post.setSelfText(Utils.modifyMarkdown(Utils.trimTrailingWhitespace(data.getString(JSONUtils.SELFTEXT_KEY))));
|
} else if (authority.contains("redgifs.com")) {
|
||||||
}
|
String gfycatId = url.substring(url.lastIndexOf("/") + 1).toLowerCase();
|
||||||
|
post.setPostType(Post.VIDEO_TYPE);
|
||||||
post.setPreviews(previews);
|
post.setIsRedgifs(true);
|
||||||
|
post.setVideoUrl(url);
|
||||||
String authority = uri.getAuthority();
|
post.setGfycatId(gfycatId);
|
||||||
|
} else if (authority.equals("streamable.com")) {
|
||||||
if (authority != null) {
|
String shortCode = url.substring(url.lastIndexOf("/") + 1);
|
||||||
if (authority.contains("gfycat.com")) {
|
post.setPostType(Post.VIDEO_TYPE);
|
||||||
String gfycatId = url.substring(url.lastIndexOf("/") + 1).toLowerCase();
|
post.setIsStreamable(true);
|
||||||
post.setPostType(Post.VIDEO_TYPE);
|
post.setVideoUrl(url);
|
||||||
post.setIsGfycat(true);
|
post.setStreamableShortCode(shortCode);
|
||||||
post.setVideoUrl(url);
|
|
||||||
post.setGfycatId(gfycatId);
|
|
||||||
} else if (authority.contains("redgifs.com")) {
|
|
||||||
String gfycatId = url.substring(url.lastIndexOf("/") + 1).toLowerCase();
|
|
||||||
post.setPostType(Post.VIDEO_TYPE);
|
|
||||||
post.setIsRedgifs(true);
|
|
||||||
post.setVideoUrl(url);
|
|
||||||
post.setGfycatId(gfycatId);
|
|
||||||
} else if (authority.equals("streamable.com")) {
|
|
||||||
String shortCode = url.substring(url.lastIndexOf("/") + 1);
|
|
||||||
post.setPostType(Post.VIDEO_TYPE);
|
|
||||||
post.setIsStreamable(true);
|
|
||||||
post.setVideoUrl(url);
|
|
||||||
post.setStreamableShortCode(shortCode);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -572,7 +538,7 @@ public class ParsePost {
|
|||||||
previews.add(new Post.Preview(galleryItemUrl, singleGalleryObject.getJSONObject(JSONUtils.S_KEY).getInt(JSONUtils.X_KEY),
|
previews.add(new Post.Preview(galleryItemUrl, singleGalleryObject.getJSONObject(JSONUtils.S_KEY).getInt(JSONUtils.X_KEY),
|
||||||
singleGalleryObject.getJSONObject(JSONUtils.S_KEY).getInt(JSONUtils.Y_KEY), galleryItemCaption, galleryItemCaptionUrl));
|
singleGalleryObject.getJSONObject(JSONUtils.S_KEY).getInt(JSONUtils.Y_KEY), galleryItemCaption, galleryItemCaptionUrl));
|
||||||
}
|
}
|
||||||
|
|
||||||
Post.Gallery postGalleryItem = new Post.Gallery(mimeType, galleryItemUrl, "", subredditName + "-" + galleryId + "." + mimeType.substring(mimeType.lastIndexOf("/") + 1), galleryItemCaption, galleryItemCaptionUrl);
|
Post.Gallery postGalleryItem = new Post.Gallery(mimeType, galleryItemUrl, "", subredditName + "-" + galleryId + "." + mimeType.substring(mimeType.lastIndexOf("/") + 1), galleryItemCaption, galleryItemCaptionUrl);
|
||||||
|
|
||||||
// For issue #558
|
// For issue #558
|
||||||
|
Loading…
x
Reference in New Issue
Block a user