Use streaming api directly from query.
This commit is contained in:
parent
d4d9c71279
commit
322769b0e4
|
@ -119,16 +119,15 @@ public class FeedHandlers {
|
||||||
)
|
)
|
||||||
.orderBy(cb.desc(root.get("uploaded")));
|
.orderBy(cb.desc(root.get("uploaded")));
|
||||||
|
|
||||||
List<StreamItem> feedItems = new ObjectArrayList<>();
|
List<StreamItem> feedItems = s.createQuery(criteria).setTimeout(20).stream()
|
||||||
|
.parallel().map(video -> {
|
||||||
|
var channel = video.getChannel();
|
||||||
|
|
||||||
for (Video video : s.createQuery(criteria).setTimeout(20).list()) {
|
return new StreamItem("/watch?v=" + video.getId(), video.getTitle(),
|
||||||
var channel = video.getChannel();
|
rewriteURL(video.getThumbnail()), channel.getUploader(), "/channel/" + channel.getUploaderId(),
|
||||||
|
rewriteURL(channel.getUploaderAvatar()), null, null, video.getDuration(), video.getViews(),
|
||||||
feedItems.add(new StreamItem("/watch?v=" + video.getId(), video.getTitle(),
|
video.getUploaded(), channel.isVerified(), video.isShort());
|
||||||
rewriteURL(video.getThumbnail()), channel.getUploader(), "/channel/" + channel.getUploaderId(),
|
}).toList();
|
||||||
rewriteURL(channel.getUploaderAvatar()), null, null, video.getDuration(), video.getViews(),
|
|
||||||
video.getUploaded(), channel.isVerified(), video.isShort()));
|
|
||||||
}
|
|
||||||
|
|
||||||
return mapper.writeValueAsBytes(feedItems);
|
return mapper.writeValueAsBytes(feedItems);
|
||||||
}
|
}
|
||||||
|
@ -173,29 +172,27 @@ public class FeedHandlers {
|
||||||
)
|
)
|
||||||
.orderBy(cb.desc(root.get("uploaded")));
|
.orderBy(cb.desc(root.get("uploaded")));
|
||||||
|
|
||||||
List<Video> videos = s.createQuery(criteria)
|
final List<SyndEntry> entries = s.createQuery(criteria)
|
||||||
.setTimeout(20)
|
.setTimeout(20)
|
||||||
.setMaxResults(100)
|
.setMaxResults(100)
|
||||||
.list();
|
.stream()
|
||||||
|
.map(video -> {
|
||||||
|
var channel = video.getChannel();
|
||||||
|
SyndEntry entry = new SyndEntryImpl();
|
||||||
|
|
||||||
final List<SyndEntry> entries = new ObjectArrayList<>();
|
SyndPerson person = new SyndPersonImpl();
|
||||||
|
person.setName(channel.getUploader());
|
||||||
|
person.setUri(Constants.FRONTEND_URL + "/channel/" + channel.getUploaderId());
|
||||||
|
|
||||||
for (Video video : videos) {
|
entry.setAuthors(Collections.singletonList(person));
|
||||||
var channel = video.getChannel();
|
|
||||||
SyndEntry entry = new SyndEntryImpl();
|
|
||||||
|
|
||||||
SyndPerson person = new SyndPersonImpl();
|
entry.setLink(Constants.FRONTEND_URL + "/watch?v=" + video.getId());
|
||||||
person.setName(channel.getUploader());
|
entry.setUri(Constants.FRONTEND_URL + "/watch?v=" + video.getId());
|
||||||
person.setUri(Constants.FRONTEND_URL + "/channel/" + channel.getUploaderId());
|
entry.setTitle(video.getTitle());
|
||||||
|
entry.setPublishedDate(new Date(video.getUploaded()));
|
||||||
|
|
||||||
entry.setAuthors(Collections.singletonList(person));
|
return entry;
|
||||||
|
}).toList();
|
||||||
entry.setLink(Constants.FRONTEND_URL + "/watch?v=" + video.getId());
|
|
||||||
entry.setUri(Constants.FRONTEND_URL + "/watch?v=" + video.getId());
|
|
||||||
entry.setTitle(video.getTitle());
|
|
||||||
entry.setPublishedDate(new Date(video.getUploaded()));
|
|
||||||
entries.add(entry);
|
|
||||||
}
|
|
||||||
|
|
||||||
feed.setEntries(entries);
|
feed.setEntries(entries);
|
||||||
|
|
||||||
|
@ -232,16 +229,15 @@ public class FeedHandlers {
|
||||||
))
|
))
|
||||||
.orderBy(cb.desc(root.get("uploaded")));
|
.orderBy(cb.desc(root.get("uploaded")));
|
||||||
|
|
||||||
List<StreamItem> feedItems = new ObjectArrayList<>();
|
List<StreamItem> feedItems = s.createQuery(criteria).setTimeout(20).stream()
|
||||||
|
.parallel().map(video -> {
|
||||||
|
var channel = video.getChannel();
|
||||||
|
|
||||||
for (Video video : s.createQuery(criteria).setTimeout(20).list()) {
|
return new StreamItem("/watch?v=" + video.getId(), video.getTitle(),
|
||||||
var channel = video.getChannel();
|
rewriteURL(video.getThumbnail()), channel.getUploader(), "/channel/" + channel.getUploaderId(),
|
||||||
|
rewriteURL(channel.getUploaderAvatar()), null, null, video.getDuration(), video.getViews(),
|
||||||
feedItems.add(new StreamItem("/watch?v=" + video.getId(), video.getTitle(),
|
video.getUploaded(), channel.isVerified(), video.isShort());
|
||||||
rewriteURL(video.getThumbnail()), channel.getUploader(), "/channel/" + channel.getUploaderId(),
|
}).toList();
|
||||||
rewriteURL(channel.getUploaderAvatar()), null, null, video.getDuration(), video.getViews(),
|
|
||||||
video.getUploaded(), channel.isVerified(), video.isShort()));
|
|
||||||
}
|
|
||||||
|
|
||||||
updateSubscribedTime(filtered);
|
updateSubscribedTime(filtered);
|
||||||
addMissingChannels(filtered);
|
addMissingChannels(filtered);
|
||||||
|
@ -451,10 +447,9 @@ public class FeedHandlers {
|
||||||
query.select(root)
|
query.select(root)
|
||||||
.where(root.get("uploader_id").in(subquery));
|
.where(root.get("uploader_id").in(subquery));
|
||||||
|
|
||||||
var channels = s.createQuery(query).list();
|
List<SubscriptionChannel> subscriptionItems = s.createQuery(query)
|
||||||
|
|
||||||
List<SubscriptionChannel> subscriptionItems = channels
|
|
||||||
.stream().parallel()
|
.stream().parallel()
|
||||||
|
.filter(Objects::nonNull)
|
||||||
.sorted(Comparator.comparing(me.kavin.piped.utils.obj.db.Channel::getUploader, String.CASE_INSENSITIVE_ORDER))
|
.sorted(Comparator.comparing(me.kavin.piped.utils.obj.db.Channel::getUploader, String.CASE_INSENSITIVE_ORDER))
|
||||||
.map(channel -> new SubscriptionChannel("/channel/" + channel.getUploaderId(),
|
.map(channel -> new SubscriptionChannel("/channel/" + channel.getUploaderId(),
|
||||||
channel.getUploader(), rewriteURL(channel.getUploaderAvatar()), channel.isVerified()))
|
channel.getUploader(), rewriteURL(channel.getUploaderAvatar()), channel.isVerified()))
|
||||||
|
@ -488,9 +483,7 @@ public class FeedHandlers {
|
||||||
query.select(root);
|
query.select(root);
|
||||||
query.where(root.get("uploader_id").in(filtered));
|
query.where(root.get("uploader_id").in(filtered));
|
||||||
|
|
||||||
var channels = s.createQuery(query).list();
|
List<SubscriptionChannel> subscriptionItems = s.createQuery(query)
|
||||||
|
|
||||||
List<SubscriptionChannel> subscriptionItems = channels
|
|
||||||
.stream().parallel()
|
.stream().parallel()
|
||||||
.sorted(Comparator.comparing(me.kavin.piped.utils.obj.db.Channel::getUploader, String.CASE_INSENSITIVE_ORDER))
|
.sorted(Comparator.comparing(me.kavin.piped.utils.obj.db.Channel::getUploader, String.CASE_INSENSITIVE_ORDER))
|
||||||
.map(channel -> new SubscriptionChannel("/channel/" + channel.getUploaderId(),
|
.map(channel -> new SubscriptionChannel("/channel/" + channel.getUploaderId(),
|
||||||
|
|
Loading…
Reference in New Issue