aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorAlex Gleason <alex@alexgleason.me>2020-09-01 20:40:36 -0500
committerAlex Gleason <alex@alexgleason.me>2020-09-11 14:10:35 -0500
commit02d70228b566d5de2cbdd6d1f9958caf2db173f1 (patch)
tree0cb489f69473cfa90ab5143bf9d8e95d6a359fc4 /lib
parent9dd0b23da424c380a37897d8bf69ab241efa6f91 (diff)
downloadpleroma-02d70228b566d5de2cbdd6d1f9958caf2db173f1.tar.gz
AdminAPI: fix delete chat message
Diffstat (limited to 'lib')
-rw-r--r--lib/pleroma/web/admin_api/controllers/chat_controller.ex20
-rw-r--r--lib/pleroma/web/api_spec/operations/admin/chat_operation.ex40
2 files changed, 34 insertions, 26 deletions
diff --git a/lib/pleroma/web/admin_api/controllers/chat_controller.ex b/lib/pleroma/web/admin_api/controllers/chat_controller.ex
index ac362c430..61d45b970 100644
--- a/lib/pleroma/web/admin_api/controllers/chat_controller.ex
+++ b/lib/pleroma/web/admin_api/controllers/chat_controller.ex
@@ -33,15 +33,27 @@ defmodule Pleroma.Web.AdminAPI.ChatController do
defdelegate open_api_operation(action), to: Pleroma.Web.ApiSpec.Admin.ChatOperation
- def delete_message(%{assigns: %{user: user}} = conn, %{message_id: id}) do
- with {:ok, %Activity{}} <- CommonAPI.delete(id, user) do
+ def delete_message(%{assigns: %{user: user}} = conn, %{
+ message_id: message_id,
+ id: chat_id
+ }) do
+ with %MessageReference{object: %{data: %{"id" => object_ap_id}}} = cm_ref <-
+ MessageReference.get_by_id(message_id),
+ ^chat_id <- to_string(cm_ref.chat_id),
+ %Activity{id: activity_id} <- Activity.get_create_by_object_ap_id(object_ap_id),
+ {:ok, _} <- CommonAPI.delete(activity_id, user) do
ModerationLog.insert_log(%{
action: "chat_message_delete",
actor: user,
- subject_id: id
+ subject_id: message_id
})
- json(conn, %{})
+ conn
+ |> put_view(MessageReferenceView)
+ |> render("show.json", chat_message_reference: cm_ref)
+ else
+ _e ->
+ {:error, :could_not_delete}
end
end
diff --git a/lib/pleroma/web/api_spec/operations/admin/chat_operation.ex b/lib/pleroma/web/api_spec/operations/admin/chat_operation.ex
index 3550d531e..d3e5dfc1c 100644
--- a/lib/pleroma/web/api_spec/operations/admin/chat_operation.ex
+++ b/lib/pleroma/web/api_spec/operations/admin/chat_operation.ex
@@ -4,9 +4,8 @@
defmodule Pleroma.Web.ApiSpec.Admin.ChatOperation do
alias OpenApiSpex.Operation
- alias Pleroma.Web.ApiSpec.Schemas.ApiError
alias Pleroma.Web.ApiSpec.Schemas.Chat
- alias Pleroma.Web.ApiSpec.Schemas.FlakeID
+ alias Pleroma.Web.ApiSpec.Schemas.ChatMessage
import Pleroma.Web.ApiSpec.Helpers
@@ -19,13 +18,24 @@ defmodule Pleroma.Web.ApiSpec.Admin.ChatOperation do
%Operation{
tags: ["admin", "chat"],
summary: "Delete an individual chat message",
- operationId: "AdminAPI.ChatController.delete",
- parameters: [id_param(), message_id_param()] ++ admin_api_params(),
- security: [%{"oAuth" => ["write:chats"]}],
+ operationId: "AdminAPI.ChatController.delete_message",
+ parameters: [
+ Operation.parameter(:id, :path, :string, "The ID of the Chat"),
+ Operation.parameter(:message_id, :path, :string, "The ID of the message")
+ ],
responses: %{
- 200 => empty_object_response(),
- 404 => Operation.response("Not Found", "application/json", ApiError)
- }
+ 200 =>
+ Operation.response(
+ "The deleted ChatMessage",
+ "application/json",
+ ChatMessage
+ )
+ },
+ security: [
+ %{
+ "oAuth" => ["write:chats"]
+ }
+ ]
}
end
@@ -83,18 +93,4 @@ defmodule Pleroma.Web.ApiSpec.Admin.ChatOperation do
]
}
end
-
- def id_param do
- Operation.parameter(:id, :path, FlakeID, "Chat ID",
- example: "9umDrYheeY451cQnEe",
- required: true
- )
- end
-
- def message_id_param do
- Operation.parameter(:message_id, :path, FlakeID, "Chat message ID",
- example: "9umDrYheeY451cQnEe",
- required: true
- )
- end
end