aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorIvan Tashkinov <ivantashkinov@gmail.com>2019-09-03 17:12:15 +0300
committerIvan Tashkinov <ivantashkinov@gmail.com>2019-09-03 17:12:15 +0300
commiteb17cc17a146471d3774fc2b972128dd75eb05af (patch)
tree1f9d09a10d8e7a43041e4f9ab9c7e476f97dc55d /lib
parentb49085c156a6a4449c95c2c315f6250317122735 (diff)
parent46ffd8b3b6359ec796733a8fff5bdb7d03a728d5 (diff)
downloadpleroma-eb17cc17a146471d3774fc2b972128dd75eb05af.tar.gz
[#1149] Merge remote-tracking branch 'remotes/upstream/develop' into 1149-oban-job-queue
# Conflicts: # CHANGELOG.md
Diffstat (limited to 'lib')
-rw-r--r--lib/pleroma/pagination.ex18
1 files changed, 18 insertions, 0 deletions
diff --git a/lib/pleroma/pagination.ex b/lib/pleroma/pagination.ex
index 2b869ccdc..b55379c4a 100644
--- a/lib/pleroma/pagination.ex
+++ b/lib/pleroma/pagination.ex
@@ -16,6 +16,15 @@ defmodule Pleroma.Pagination do
def fetch_paginated(query, params, type \\ :keyset)
+ def fetch_paginated(query, %{"total" => true} = params, :keyset) do
+ total = Repo.aggregate(query, :count, :id)
+
+ %{
+ total: total,
+ items: fetch_paginated(query, Map.drop(params, ["total"]), :keyset)
+ }
+ end
+
def fetch_paginated(query, params, :keyset) do
options = cast_params(params)
@@ -25,6 +34,15 @@ defmodule Pleroma.Pagination do
|> enforce_order(options)
end
+ def fetch_paginated(query, %{"total" => true} = params, :offset) do
+ total = Repo.aggregate(query, :count, :id)
+
+ %{
+ total: total,
+ items: fetch_paginated(query, Map.drop(params, ["total"]), :offset)
+ }
+ end
+
def fetch_paginated(query, params, :offset) do
options = cast_params(params)