aboutsummaryrefslogtreecommitdiff
path: root/lib/pleroma/web/admin_api/controllers
diff options
context:
space:
mode:
authorMaksim Pechnikov <parallel588@gmail.com>2020-08-11 10:28:35 +0300
committerMaksim Pechnikov <parallel588@gmail.com>2020-08-11 10:30:13 +0300
commit345ac512e43fbb127c45552690741088d465d31d (patch)
tree3d982797e266e65058006f07fbf0da7e7e8bb630 /lib/pleroma/web/admin_api/controllers
parent78484fe0ef48079d3ca811c475b109a3306b3e5c (diff)
downloadpleroma-345ac512e43fbb127c45552690741088d465d31d.tar.gz
added paginate+search for admin/MediaProxy URLs
Diffstat (limited to 'lib/pleroma/web/admin_api/controllers')
-rw-r--r--lib/pleroma/web/admin_api/controllers/media_proxy_cache_controller.ex41
1 files changed, 25 insertions, 16 deletions
diff --git a/lib/pleroma/web/admin_api/controllers/media_proxy_cache_controller.ex b/lib/pleroma/web/admin_api/controllers/media_proxy_cache_controller.ex
index e2759d59f..76d3af4ef 100644
--- a/lib/pleroma/web/admin_api/controllers/media_proxy_cache_controller.ex
+++ b/lib/pleroma/web/admin_api/controllers/media_proxy_cache_controller.ex
@@ -26,29 +26,38 @@ defmodule Pleroma.Web.AdminAPI.MediaProxyCacheController do
defdelegate open_api_operation(action), to: Spec.MediaProxyCacheOperation
def index(%{assigns: %{user: _}} = conn, params) do
- cursor =
- :banned_urls_cache
- |> :ets.table([{:traverse, {:select, Cachex.Query.create(true, :key)}}])
- |> :qlc.cursor()
+ entries = fetch_entries(params)
+ urls = paginate_entries(entries, params.page, params.page_size)
+
+ render(conn, "index.json",
+ urls: urls,
+ page_size: params.page_size,
+ count: length(entries)
+ )
+ end
- urls =
- case params.page do
- 1 ->
- :qlc.next_answers(cursor, params.page_size)
+ defp fetch_entries(params) do
+ MediaProxy.cache_table()
+ |> Cachex.export!()
+ |> filter_urls(params[:query])
+ end
- _ ->
- :qlc.next_answers(cursor, (params.page - 1) * params.page_size)
- :qlc.next_answers(cursor, params.page_size)
- end
+ defp filter_urls(entries, query) when is_binary(query) do
+ for {_, url, _, _, _} <- entries, String.contains?(url, query), do: url
+ end
- :qlc.delete_cursor(cursor)
+ defp filter_urls(entries, _) do
+ Enum.map(entries, fn {_, url, _, _, _} -> url end)
+ end
- render(conn, "index.json", urls: urls)
+ defp paginate_entries(entries, page, page_size) do
+ offset = page_size * (page - 1)
+ Enum.slice(entries, offset, page_size)
end
def delete(%{assigns: %{user: _}, body_params: %{urls: urls}} = conn, _) do
MediaProxy.remove_from_banned_urls(urls)
- render(conn, "index.json", urls: urls)
+ json(conn, %{})
end
def purge(%{assigns: %{user: _}, body_params: %{urls: urls, ban: ban}} = conn, _) do
@@ -58,6 +67,6 @@ defmodule Pleroma.Web.AdminAPI.MediaProxyCacheController do
MediaProxy.put_in_banned_urls(urls)
end
- render(conn, "index.json", urls: urls)
+ json(conn, %{})
end
end