1 # Pleroma: A lightweight social networking server
2 # Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
3 # SPDX-License-Identifier: AGPL-3.0-only
5 defmodule Pleroma.Web.AdminAPI.ChatControllerTest do
6 use Pleroma.Web.ConnCase
11 alias Pleroma.Chat.MessageReference
13 alias Pleroma.ModerationLog
16 alias Pleroma.Web.CommonAPI
19 admin = insert(:user, is_admin: true)
20 token = insert(:oauth_admin_token, user: admin)
24 |> assign(:user, admin)
25 |> assign(:token, token)
27 {:ok, %{admin: admin, token: token, conn: conn}}
30 describe "DELETE /api/pleroma/admin/chats/:id/messages/:message_id" do
31 setup do: admin_setup()
33 test "it deletes a message from the chat", %{conn: conn, admin: admin} do
35 recipient = insert(:user)
38 CommonAPI.post_chat_message(user, recipient, "Hello darkness my old friend")
40 object = Object.normalize(message, false)
42 chat = Chat.get(user.id, recipient.ap_id)
43 recipient_chat = Chat.get(recipient.id, user.ap_id)
45 cm_ref = MessageReference.for_chat_and_object(chat, object)
46 recipient_cm_ref = MessageReference.for_chat_and_object(recipient_chat, object)
50 |> put_req_header("content-type", "application/json")
51 |> delete("/api/pleroma/admin/chats/#{chat.id}/messages/#{cm_ref.id}")
52 |> json_response_and_validate_schema(200)
54 log_entry = Repo.one(ModerationLog)
56 assert ModerationLog.get_log_entry_message(log_entry) ==
57 "@#{admin.nickname} deleted chat message ##{cm_ref.id}"
59 assert result["id"] == cm_ref.id
60 refute MessageReference.get_by_id(cm_ref.id)
61 refute MessageReference.get_by_id(recipient_cm_ref.id)
62 assert %{data: %{"type" => "Tombstone"}} = Object.get_by_id(object.id)
66 describe "GET /api/pleroma/admin/chats/:id/messages" do
67 setup do: admin_setup()
69 test "it paginates", %{conn: conn} do
71 recipient = insert(:user)
73 Enum.each(1..30, fn _ ->
74 {:ok, _} = CommonAPI.post_chat_message(user, recipient, "hey")
77 chat = Chat.get(user.id, recipient.ap_id)
81 |> get("/api/pleroma/admin/chats/#{chat.id}/messages")
82 |> json_response_and_validate_schema(200)
84 assert length(result) == 20
88 |> get("/api/pleroma/admin/chats/#{chat.id}/messages?max_id=#{List.last(result)["id"]}")
89 |> json_response_and_validate_schema(200)
91 assert length(result) == 10
94 test "it returns the messages for a given chat", %{conn: conn} do
96 other_user = insert(:user)
97 third_user = insert(:user)
99 {:ok, _} = CommonAPI.post_chat_message(user, other_user, "hey")
100 {:ok, _} = CommonAPI.post_chat_message(user, third_user, "hey")
101 {:ok, _} = CommonAPI.post_chat_message(user, other_user, "how are you?")
102 {:ok, _} = CommonAPI.post_chat_message(other_user, user, "fine, how about you?")
104 chat = Chat.get(user.id, other_user.ap_id)
108 |> get("/api/pleroma/admin/chats/#{chat.id}/messages")
109 |> json_response_and_validate_schema(200)
112 |> Enum.each(fn message ->
113 assert message["chat_id"] == chat.id |> to_string()
116 assert length(result) == 3
120 describe "GET /api/pleroma/admin/chats/:id" do
121 setup do: admin_setup()
123 test "it returns a chat", %{conn: conn} do
125 other_user = insert(:user)
127 {:ok, chat} = Chat.get_or_create(user.id, other_user.ap_id)
131 |> get("/api/pleroma/admin/chats/#{chat.id}")
132 |> json_response_and_validate_schema(200)
134 assert result["id"] == to_string(chat.id)
135 assert %{} = result["sender"]
136 assert %{} = result["receiver"]
137 refute result["account"]
141 describe "unauthorized chat moderation" do
144 recipient = insert(:user)
146 {:ok, message} = CommonAPI.post_chat_message(user, recipient, "Yo")
147 object = Object.normalize(message, false)
148 chat = Chat.get(user.id, recipient.ap_id)
149 cm_ref = MessageReference.for_chat_and_object(chat, object)
151 %{conn: conn} = oauth_access(["read:chats", "write:chats"])
152 %{conn: conn, chat: chat, cm_ref: cm_ref}
155 test "DELETE /api/pleroma/admin/chats/:id/messages/:message_id", %{
161 |> put_req_header("content-type", "application/json")
162 |> delete("/api/pleroma/admin/chats/#{chat.id}/messages/#{cm_ref.id}")
163 |> json_response(403)
165 assert MessageReference.get_by_id(cm_ref.id) == cm_ref
168 test "GET /api/pleroma/admin/chats/:id/messages", %{conn: conn, chat: chat} do
170 |> get("/api/pleroma/admin/chats/#{chat.id}/messages")
171 |> json_response(403)
174 test "GET /api/pleroma/admin/chats/:id", %{conn: conn, chat: chat} do
176 |> get("/api/pleroma/admin/chats/#{chat.id}")
177 |> json_response(403)
181 describe "unauthenticated chat moderation" do
184 recipient = insert(:user)
186 {:ok, message} = CommonAPI.post_chat_message(user, recipient, "Yo")
187 object = Object.normalize(message, false)
188 chat = Chat.get(user.id, recipient.ap_id)
189 cm_ref = MessageReference.for_chat_and_object(chat, object)
191 %{conn: build_conn(), chat: chat, cm_ref: cm_ref}
194 test "DELETE /api/pleroma/admin/chats/:id/messages/:message_id", %{
200 |> put_req_header("content-type", "application/json")
201 |> delete("/api/pleroma/admin/chats/#{chat.id}/messages/#{cm_ref.id}")
202 |> json_response(403)
204 assert MessageReference.get_by_id(cm_ref.id) == cm_ref
207 test "GET /api/pleroma/admin/chats/:id/messages", %{conn: conn, chat: chat} do
209 |> get("/api/pleroma/admin/chats/#{chat.id}/messages")
210 |> json_response(403)
213 test "GET /api/pleroma/admin/chats/:id", %{conn: conn, chat: chat} do
215 |> get("/api/pleroma/admin/chats/#{chat.id}")
216 |> json_response(403)