Add specs for AccountController.mute and AccountController.unmute
This commit is contained in:
parent
aa958a6dda
commit
e4195d4a68
4 changed files with 79 additions and 9 deletions
|
@ -10,6 +10,7 @@ defmodule Pleroma.Web.ApiSpec.AccountOperation do
|
||||||
alias Pleroma.Web.ApiSpec.Schemas.Account
|
alias Pleroma.Web.ApiSpec.Schemas.Account
|
||||||
alias Pleroma.Web.ApiSpec.Schemas.AccountCreateRequest
|
alias Pleroma.Web.ApiSpec.Schemas.AccountCreateRequest
|
||||||
alias Pleroma.Web.ApiSpec.Schemas.AccountCreateResponse
|
alias Pleroma.Web.ApiSpec.Schemas.AccountCreateResponse
|
||||||
|
alias Pleroma.Web.ApiSpec.Schemas.AccountMuteRequest
|
||||||
alias Pleroma.Web.ApiSpec.Schemas.AccountRelationship
|
alias Pleroma.Web.ApiSpec.Schemas.AccountRelationship
|
||||||
alias Pleroma.Web.ApiSpec.Schemas.AccountRelationshipsResponse
|
alias Pleroma.Web.ApiSpec.Schemas.AccountRelationshipsResponse
|
||||||
alias Pleroma.Web.ApiSpec.Schemas.AccountsResponse
|
alias Pleroma.Web.ApiSpec.Schemas.AccountsResponse
|
||||||
|
@ -239,8 +240,44 @@ def unfollow_operation do
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
def mute_operation, do: :ok
|
def mute_operation do
|
||||||
def unmute_operation, do: :ok
|
%Operation{
|
||||||
|
tags: ["accounts"],
|
||||||
|
summary: "Mute",
|
||||||
|
operationId: "AccountController.mute",
|
||||||
|
security: [%{"oAuth" => ["follow", "write:mutes"]}],
|
||||||
|
requestBody: Helpers.request_body("Parameters", AccountMuteRequest),
|
||||||
|
description:
|
||||||
|
"Mute the given account. Clients should filter statuses and notifications from this account, if received (e.g. due to a boost in the Home timeline).",
|
||||||
|
parameters: [
|
||||||
|
%Reference{"$ref": "#/components/parameters/accountIdOrNickname"},
|
||||||
|
Operation.parameter(
|
||||||
|
:notifications,
|
||||||
|
:query,
|
||||||
|
%Schema{allOf: [BooleanLike], default: true},
|
||||||
|
"Mute notifications in addition to statuses? Defaults to `true`."
|
||||||
|
)
|
||||||
|
],
|
||||||
|
responses: %{
|
||||||
|
200 => Operation.response("Relationship", "application/json", AccountRelationship)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
def unmute_operation do
|
||||||
|
%Operation{
|
||||||
|
tags: ["accounts"],
|
||||||
|
summary: "Unmute",
|
||||||
|
operationId: "AccountController.unmute",
|
||||||
|
security: [%{"oAuth" => ["follow", "write:mutes"]}],
|
||||||
|
description: "Unmute the given account.",
|
||||||
|
parameters: [%Reference{"$ref": "#/components/parameters/accountIdOrNickname"}],
|
||||||
|
responses: %{
|
||||||
|
200 => Operation.response("Relationship", "application/json", AccountRelationship)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
def block_operation, do: :ok
|
def block_operation, do: :ok
|
||||||
def unblock_operation, do: :ok
|
def unblock_operation, do: :ok
|
||||||
def follows_operation, do: :ok
|
def follows_operation, do: :ok
|
||||||
|
|
24
lib/pleroma/web/api_spec/schemas/account_mute_request.ex
Normal file
24
lib/pleroma/web/api_spec/schemas/account_mute_request.ex
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
# Pleroma: A lightweight social networking server
|
||||||
|
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
|
||||||
|
# SPDX-License-Identifier: AGPL-3.0-only
|
||||||
|
|
||||||
|
defmodule Pleroma.Web.ApiSpec.Schemas.AccountMuteRequest do
|
||||||
|
alias OpenApiSpex.Schema
|
||||||
|
require OpenApiSpex
|
||||||
|
|
||||||
|
OpenApiSpex.schema(%{
|
||||||
|
title: "AccountMuteRequest",
|
||||||
|
description: "POST body for muting an account",
|
||||||
|
type: :object,
|
||||||
|
properties: %{
|
||||||
|
notifications: %Schema{
|
||||||
|
type: :boolean,
|
||||||
|
description: "Mute notifications in addition to statuses? Defaults to true.",
|
||||||
|
default: true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
example: %{
|
||||||
|
"notifications" => true
|
||||||
|
}
|
||||||
|
})
|
||||||
|
end
|
|
@ -94,7 +94,9 @@ defmodule Pleroma.Web.MastodonAPI.AccountController do
|
||||||
:following,
|
:following,
|
||||||
:lists,
|
:lists,
|
||||||
:follow,
|
:follow,
|
||||||
:unfollow
|
:unfollow,
|
||||||
|
:mute,
|
||||||
|
:unmute
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -359,10 +361,8 @@ def unfollow(%{assigns: %{user: follower, account: followed}} = conn, _params) d
|
||||||
end
|
end
|
||||||
|
|
||||||
@doc "POST /api/v1/accounts/:id/mute"
|
@doc "POST /api/v1/accounts/:id/mute"
|
||||||
def mute(%{assigns: %{user: muter, account: muted}} = conn, params) do
|
def mute(%{assigns: %{user: muter, account: muted}, body_params: params} = conn, _params) do
|
||||||
notifications? = params |> Map.get("notifications", true) |> truthy_param?()
|
with {:ok, _user_relationships} <- User.mute(muter, muted, params.notifications) do
|
||||||
|
|
||||||
with {:ok, _user_relationships} <- User.mute(muter, muted, notifications?) do
|
|
||||||
render(conn, "relationship.json", user: muter, target: muted)
|
render(conn, "relationship.json", user: muter, target: muted)
|
||||||
else
|
else
|
||||||
{:error, message} -> json_response(conn, :forbidden, %{error: message})
|
{:error, message} -> json_response(conn, :forbidden, %{error: message})
|
||||||
|
|
|
@ -751,32 +751,41 @@ test "following / unfollowing errors", %{user: user, conn: conn} do
|
||||||
test "with notifications", %{conn: conn} do
|
test "with notifications", %{conn: conn} do
|
||||||
other_user = insert(:user)
|
other_user = insert(:user)
|
||||||
|
|
||||||
ret_conn = post(conn, "/api/v1/accounts/#{other_user.id}/mute")
|
ret_conn =
|
||||||
|
conn
|
||||||
|
|> put_req_header("content-type", "application/json")
|
||||||
|
|> post("/api/v1/accounts/#{other_user.id}/mute")
|
||||||
|
|
||||||
response = json_response(ret_conn, 200)
|
response = json_response(ret_conn, 200)
|
||||||
|
|
||||||
assert %{"id" => _id, "muting" => true, "muting_notifications" => true} = response
|
assert %{"id" => _id, "muting" => true, "muting_notifications" => true} = response
|
||||||
|
assert_schema(response, "AccountRelationship", ApiSpec.spec())
|
||||||
|
|
||||||
conn = post(conn, "/api/v1/accounts/#{other_user.id}/unmute")
|
conn = post(conn, "/api/v1/accounts/#{other_user.id}/unmute")
|
||||||
|
|
||||||
response = json_response(conn, 200)
|
response = json_response(conn, 200)
|
||||||
assert %{"id" => _id, "muting" => false, "muting_notifications" => false} = response
|
assert %{"id" => _id, "muting" => false, "muting_notifications" => false} = response
|
||||||
|
assert_schema(response, "AccountRelationship", ApiSpec.spec())
|
||||||
end
|
end
|
||||||
|
|
||||||
test "without notifications", %{conn: conn} do
|
test "without notifications", %{conn: conn} do
|
||||||
other_user = insert(:user)
|
other_user = insert(:user)
|
||||||
|
|
||||||
ret_conn =
|
ret_conn =
|
||||||
post(conn, "/api/v1/accounts/#{other_user.id}/mute", %{"notifications" => "false"})
|
conn
|
||||||
|
|> put_req_header("content-type", "multipart/form-data")
|
||||||
|
|> post("/api/v1/accounts/#{other_user.id}/mute", %{"notifications" => "false"})
|
||||||
|
|
||||||
response = json_response(ret_conn, 200)
|
response = json_response(ret_conn, 200)
|
||||||
|
|
||||||
assert %{"id" => _id, "muting" => true, "muting_notifications" => false} = response
|
assert %{"id" => _id, "muting" => true, "muting_notifications" => false} = response
|
||||||
|
assert_schema(response, "AccountRelationship", ApiSpec.spec())
|
||||||
|
|
||||||
conn = post(conn, "/api/v1/accounts/#{other_user.id}/unmute")
|
conn = post(conn, "/api/v1/accounts/#{other_user.id}/unmute")
|
||||||
|
|
||||||
response = json_response(conn, 200)
|
response = json_response(conn, 200)
|
||||||
assert %{"id" => _id, "muting" => false, "muting_notifications" => false} = response
|
assert %{"id" => _id, "muting" => false, "muting_notifications" => false} = response
|
||||||
|
assert_schema(response, "AccountRelationship", ApiSpec.spec())
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue