diff options
5 files changed, 49 insertions, 8 deletions
diff --git a/lib/pleroma/ecto_enums.ex b/lib/pleroma/ecto_enums.ex index 2a9addabc..0e3e1e5de 100644 --- a/lib/pleroma/ecto_enums.ex +++ b/lib/pleroma/ecto_enums.ex @@ -9,7 +9,8 @@ defenum(Pleroma.UserRelationship.Type,    mute: 2,    reblog_mute: 3,    notification_mute: 4, -  inverse_subscription: 5 +  inverse_subscription: 5, +  suggestion_dismiss: 6  )  defenum(Pleroma.FollowingRelationship.State, diff --git a/lib/pleroma/web/mastodon_api/controllers/suggestion_controller.ex b/lib/pleroma/web/mastodon_api/controllers/suggestion_controller.ex index 4f92c1f46..4ebfc737c 100644 --- a/lib/pleroma/web/mastodon_api/controllers/suggestion_controller.ex +++ b/lib/pleroma/web/mastodon_api/controllers/suggestion_controller.ex @@ -5,11 +5,13 @@  defmodule Pleroma.Web.MastodonAPI.SuggestionController do    use Pleroma.Web, :controller    alias Pleroma.User +  alias Pleroma.UserRelationship    require Logger    plug(Pleroma.Web.ApiSpec.CastAndValidate)    plug(Pleroma.Web.Plugs.OAuthScopesPlug, %{scopes: ["read"]} when action in [:index, :index2]) +  plug(Pleroma.Web.Plugs.OAuthScopesPlug, %{scopes: ["write"]} when action in [:dismiss])    def open_api_operation(action) do      operation = String.to_existing_atom("#{action}_operation") @@ -38,6 +40,26 @@ defmodule Pleroma.Web.MastodonAPI.SuggestionController do      }    end +  def dismiss_operation do +    %OpenApiSpex.Operation{ +      tags: ["Suggestions"], +      summary: "Remove a suggestion", +      operationId: "SuggestionController.dismiss", +      parameters: [ +        OpenApiSpex.Operation.parameter( +          :account_id, +          :path, +          %OpenApiSpex.Schema{type: :string}, +          "Account to dismiss", +          required: true +        ) +      ], +      responses: %{ +        200 => Pleroma.Web.ApiSpec.Helpers.empty_object_response() +      } +    } +  end +    @doc "GET /api/v1/suggestions"    def index(conn, params),      do: Pleroma.Web.MastodonAPI.MastodonAPIController.empty_array(conn, params) @@ -53,4 +75,12 @@ defmodule Pleroma.Web.MastodonAPI.SuggestionController do      render(conn, "index.json", %{users: users, source: :staff, for: user})    end + +  @doc "DELETE /api/v1/suggestions/:account_id" +  def dismiss(%{assigns: %{user: source}} = conn, %{account_id: user_id}) do +    with %User{} = target <- User.get_cached_by_id(user_id), +         {:ok, _} <- UserRelationship.create(:suggestion_dismiss, source, target) do +      json(conn, %{}) +    end +  end  end diff --git a/lib/pleroma/web/router.ex b/lib/pleroma/web/router.ex index 1f51bf456..5d3a17b98 100644 --- a/lib/pleroma/web/router.ex +++ b/lib/pleroma/web/router.ex @@ -539,6 +539,7 @@ defmodule Pleroma.Web.Router do      delete("/push/subscription", SubscriptionController, :delete)      get("/suggestions", SuggestionController, :index) +    delete("/suggestions/:account_id", SuggestionController, :dismiss)      get("/timelines/home", TimelineController, :home)      get("/timelines/direct", TimelineController, :direct) diff --git a/test/pleroma/web/admin_api/controllers/user_controller_test.exs b/test/pleroma/web/admin_api/controllers/user_controller_test.exs index df13f00e6..1580ca448 100644 --- a/test/pleroma/web/admin_api/controllers/user_controller_test.exs +++ b/test/pleroma/web/admin_api/controllers/user_controller_test.exs @@ -894,9 +894,7 @@ defmodule Pleroma.Web.AdminAPI.UserControllerTest do      log_entry = Repo.one(ModerationLog)      assert ModerationLog.get_log_entry_message(log_entry) == -             "@#{admin.nickname} added suggested users: @#{user1.nickname}, @#{ -               user2.nickname -             }" +             "@#{admin.nickname} added suggested users: @#{user1.nickname}, @#{user2.nickname}"    end    test "PATCH /api/pleroma/admin/users/unsuggest", %{admin: admin, conn: conn} do @@ -920,9 +918,7 @@ defmodule Pleroma.Web.AdminAPI.UserControllerTest do      log_entry = Repo.one(ModerationLog)      assert ModerationLog.get_log_entry_message(log_entry) == -             "@#{admin.nickname} removed suggested users: @#{user1.nickname}, @#{ -               user2.nickname -             }" +             "@#{admin.nickname} removed suggested users: @#{user1.nickname}, @#{user2.nickname}"    end    test "PATCH /api/pleroma/admin/users/:nickname/toggle_activation", %{admin: admin, conn: conn} do diff --git a/test/pleroma/web/mastodon_api/controllers/suggestion_controller_test.exs b/test/pleroma/web/mastodon_api/controllers/suggestion_controller_test.exs index 407063fa1..803a38c67 100644 --- a/test/pleroma/web/mastodon_api/controllers/suggestion_controller_test.exs +++ b/test/pleroma/web/mastodon_api/controllers/suggestion_controller_test.exs @@ -4,9 +4,10 @@  defmodule Pleroma.Web.MastodonAPI.SuggestionControllerTest do    use Pleroma.Web.ConnCase, async: true +  alias Pleroma.UserRelationship    import Pleroma.Factory -  setup do: oauth_access(["read"]) +  setup do: oauth_access(["read", "write"])    test "returns empty result", %{conn: conn} do      res = @@ -27,4 +28,16 @@ defmodule Pleroma.Web.MastodonAPI.SuggestionControllerTest do      assert [%{"source" => "staff", "account" => %{"id" => ^user_id}}] = res    end + +  test "dismiss suggestion", %{conn: conn, user: source} do +    target = insert(:user, is_suggested: true) + +    res = +      conn +      |> delete("/api/v1/suggestions/#{target.id}") +      |> json_response_and_validate_schema(200) + +    assert res == %{} +    assert UserRelationship.exists?(:suggestion_dismiss, source, target) +  end  end  | 
