summaryrefslogtreecommitdiff
path: root/lib/pleroma/web/admin_api/controllers/status_controller.ex
diff options
context:
space:
mode:
Diffstat (limited to 'lib/pleroma/web/admin_api/controllers/status_controller.ex')
-rw-r--r--lib/pleroma/web/admin_api/controllers/status_controller.ex20
1 files changed, 19 insertions, 1 deletions
diff --git a/lib/pleroma/web/admin_api/controllers/status_controller.ex b/lib/pleroma/web/admin_api/controllers/status_controller.ex
index 7058def82..4e8dbf77b 100644
--- a/lib/pleroma/web/admin_api/controllers/status_controller.ex
+++ b/lib/pleroma/web/admin_api/controllers/status_controller.ex
@@ -15,7 +15,11 @@ defmodule Pleroma.Web.AdminAPI.StatusController do
require Logger
plug(Pleroma.Web.ApiSpec.CastAndValidate)
- plug(OAuthScopesPlug, %{scopes: ["admin:read:statuses"]} when action in [:index, :show])
+
+ plug(
+ OAuthScopesPlug,
+ %{scopes: ["admin:read:statuses"]} when action in [:index, :index2, :show]
+ )
plug(
OAuthScopesPlug,
@@ -39,6 +43,20 @@ defmodule Pleroma.Web.AdminAPI.StatusController do
render(conn, "index.json", activities: activities, as: :activity)
end
+ def index2(%{assigns: %{user: _admin}} = conn, params) do
+ result =
+ ActivityPub.fetch_statuses(nil, %{
+ godmode: params.godmode,
+ local_only: params.local_only,
+ limit: params.page_size,
+ offset: (params.page - 1) * params.page_size,
+ exclude_reblogs: not params.with_reblogs,
+ total: true
+ })
+
+ render(conn, "index.json", %{total: result[:total], activities: result[:items], as: :activity})
+ end
+
def show(conn, %{id: id}) do
with %Activity{} = activity <- Activity.get_by_id(id) do
render(conn, "show.json", %{activity: activity})