logo

pleroma

My custom branche(s) on git.pleroma.social/pleroma/pleroma git clone https://hacktivis.me/git/pleroma.git

conversation_controller.ex (3160B)


  1. # Pleroma: A lightweight social networking server
  2. # Copyright © 2017-2022 Pleroma Authors <https://pleroma.social/>
  3. # SPDX-License-Identifier: AGPL-3.0-only
  4. defmodule Pleroma.Web.PleromaAPI.ConversationController do
  5. use Pleroma.Web, :controller
  6. import Pleroma.Web.ControllerHelper, only: [add_link_headers: 2]
  7. alias Pleroma.Conversation.Participation
  8. alias Pleroma.Web.ActivityPub.ActivityPub
  9. alias Pleroma.Web.MastodonAPI.StatusView
  10. alias Pleroma.Web.Plugs.OAuthScopesPlug
  11. plug(Pleroma.Web.ApiSpec.CastAndValidate)
  12. plug(OAuthScopesPlug, %{scopes: ["read:statuses"]} when action in [:show, :statuses])
  13. plug(
  14. OAuthScopesPlug,
  15. %{scopes: ["write:conversations"]} when action in [:update, :mark_as_read]
  16. )
  17. defdelegate open_api_operation(action), to: Pleroma.Web.ApiSpec.PleromaConversationOperation
  18. def show(%{assigns: %{user: %{id: user_id} = user}} = conn, %{id: participation_id}) do
  19. with %Participation{user_id: ^user_id} = participation <- Participation.get(participation_id) do
  20. render(conn, "participation.json", participation: participation, for: user)
  21. else
  22. _error ->
  23. conn
  24. |> put_status(:not_found)
  25. |> json(%{"error" => "Unknown conversation id"})
  26. end
  27. end
  28. def statuses(
  29. %{assigns: %{user: %{id: user_id} = user}} = conn,
  30. %{id: participation_id} = params
  31. ) do
  32. with %Participation{user_id: ^user_id} = participation <-
  33. Participation.get(participation_id, preload: [:conversation]) do
  34. params =
  35. params
  36. |> Map.put(:blocking_user, user)
  37. |> Map.put(:muting_user, user)
  38. |> Map.put(:user, user)
  39. activities =
  40. participation.conversation.ap_id
  41. |> ActivityPub.fetch_activities_for_context_query(params)
  42. |> Pleroma.Pagination.fetch_paginated(Map.put(params, :total, false))
  43. |> Enum.reverse()
  44. conn
  45. |> add_link_headers(activities)
  46. |> put_view(StatusView)
  47. |> render("index.json", activities: activities, for: user, as: :activity)
  48. else
  49. _error ->
  50. conn
  51. |> put_status(:not_found)
  52. |> json(%{"error" => "Unknown conversation id"})
  53. end
  54. end
  55. def update(
  56. %{assigns: %{user: %{id: user_id} = user}} = conn,
  57. %{id: participation_id, recipients: recipients}
  58. ) do
  59. with %Participation{user_id: ^user_id} = participation <- Participation.get(participation_id),
  60. {:ok, participation} <- Participation.set_recipients(participation, recipients) do
  61. render(conn, "participation.json", participation: participation, for: user)
  62. else
  63. {:error, message} ->
  64. conn
  65. |> put_status(:bad_request)
  66. |> json(%{"error" => message})
  67. _error ->
  68. conn
  69. |> put_status(:not_found)
  70. |> json(%{"error" => "Unknown conversation id"})
  71. end
  72. end
  73. def mark_as_read(%{assigns: %{user: user}} = conn, _params) do
  74. with {:ok, _, participations} <- Participation.mark_all_as_read(user) do
  75. conn
  76. |> add_link_headers(participations)
  77. |> render("participations.json", participations: participations, for: user)
  78. end
  79. end
  80. end