From 014c9533c8f3a117b7549841f25f9f2269e6a6da Mon Sep 17 00:00:00 2001 From: Kavin <20838718+FireMasterK@users.noreply.github.com> Date: Thu, 24 Feb 2022 12:32:39 +0000 Subject: [PATCH] Optimize subscriptions query, by using Criteria API. (#200) --- .../me/kavin/piped/utils/ResponseHelper.java | 22 ++++++++++++------- 1 file changed, 14 insertions(+), 8 deletions(-) diff --git a/src/main/java/me/kavin/piped/utils/ResponseHelper.java b/src/main/java/me/kavin/piped/utils/ResponseHelper.java index 8618c94..ec8f1f3 100644 --- a/src/main/java/me/kavin/piped/utils/ResponseHelper.java +++ b/src/main/java/me/kavin/piped/utils/ResponseHelper.java @@ -930,22 +930,28 @@ public class ResponseHelper { Session s = DatabaseSessionFactory.createSession(); - User user = DatabaseHelper.getUserFromSessionWithSubscribed(s, session); + User user = DatabaseHelper.getUserFromSession(s, session); if (user != null) { List subscriptionItems = new ObjectArrayList<>(); - if (user.getSubscribed() != null && !user.getSubscribed().isEmpty()) { + CriteriaBuilder cb = s.getCriteriaBuilder(); + var query = cb.createQuery(me.kavin.piped.utils.obj.db.Channel.class); + var root = query.from(me.kavin.piped.utils.obj.db.Channel.class); + var userRoot = query.from(User.class); + query.select(root); + query.where(cb.and( + cb.isMember(root.get("uploader_id"), userRoot.>get("subscribed_ids")), + cb.equal(userRoot.get("id"), user.getId()) + )); - List channels = DatabaseHelper.getChannelFromIds(s, - user.getSubscribed()); + var channels = s.createQuery(query).list(); - channels.forEach(channel -> subscriptionItems.add(new SubscriptionChannel("/channel/" + channel.getUploaderId(), - channel.getUploader(), rewriteURL(channel.getUploaderAvatar()), channel.isVerified()))); + channels.forEach(channel -> subscriptionItems.add(new SubscriptionChannel("/channel/" + channel.getUploaderId(), + channel.getUploader(), rewriteURL(channel.getUploaderAvatar()), channel.isVerified()))); - subscriptionItems.sort(Comparator.comparing(o -> o.name)); - } + subscriptionItems.sort(Comparator.comparing(o -> o.name)); s.close();