diff options
author | rinpatch <rinpatch@sdf.org> | 2019-09-03 13:03:06 +0000 |
---|---|---|
committer | rinpatch <rinpatch@sdf.org> | 2019-09-03 13:03:06 +0000 |
commit | 46ffd8b3b6359ec796733a8fff5bdb7d03a728d5 (patch) | |
tree | 2d9a0190fdb62d88d5c5accedfcd65447be8fa0a /lib | |
parent | 6d33c89c4d27a1b52e69e1c14b408726410a6326 (diff) | |
parent | b15cfd80ef5d5bc971f78a53dfa3d37dec4499a5 (diff) | |
download | pleroma-46ffd8b3b6359ec796733a8fff5bdb7d03a728d5.tar.gz |
Merge branch 'feature/pagination-total' into 'develop'
Return total items count from pagination + tests
See merge request pleroma/pleroma!1620
Diffstat (limited to 'lib')
-rw-r--r-- | lib/pleroma/pagination.ex | 18 |
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) |