summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorOmar Roth <omarroth@hotmail.com>2019-02-15 17:13:52 -0600
committerOmar Roth <omarroth@hotmail.com>2019-02-15 17:13:52 -0600
commitc099a5ad2e42616ee96a5da41cf27083606ac692 (patch)
tree4d09db0a39c5b5097a4947695ff076c5e8b147c7
parent9df77707d34cbcacb82469bf91fe1f498808a6a1 (diff)
downloadinvidious-c099a5ad2e42616ee96a5da41cf27083606ac692.tar.gz
invidious-c099a5ad2e42616ee96a5da41cf27083606ac692.tar.bz2
invidious-c099a5ad2e42616ee96a5da41cf27083606ac692.zip
Speed up manage_subscriptions
-rw-r--r--src/invidious.cr7
1 files changed, 1 insertions, 6 deletions
diff --git a/src/invidious.cr b/src/invidious.cr
index 285d4394..93f63dfe 100644
--- a/src/invidious.cr
+++ b/src/invidious.cr
@@ -1373,12 +1373,7 @@ get "/subscription_manager" do |env|
format = env.params.query["format"]?
format ||= "rss"
- subscriptions = [] of InvidiousChannel
- user.subscriptions.each do |ucid|
- if channel = PG_DB.query_one?("SELECT * FROM channels WHERE id = $1", ucid, as: InvidiousChannel)
- subscriptions << channel
- end
- end
+ subscriptions = PG_DB.query_all("SELECT * FROM channels WHERE id = ANY('{#{user.subscriptions.join(",")}}')", as: InvidiousChannel)
subscriptions.sort_by! { |channel| channel.author.downcase }
if action_takeout