logo

pleroma

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

notification_controller.ex (3584B)


  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.MastodonAPI.NotificationController do
  5. use Pleroma.Web, :controller
  6. import Pleroma.Web.ControllerHelper, only: [add_link_headers: 2]
  7. alias Pleroma.Notification
  8. alias Pleroma.Web.MastodonAPI.MastodonAPI
  9. alias Pleroma.Web.Plugs.OAuthScopesPlug
  10. @oauth_read_actions [:show, :index]
  11. plug(Pleroma.Web.ApiSpec.CastAndValidate, replace_params: false)
  12. plug(
  13. OAuthScopesPlug,
  14. %{scopes: ["read:notifications"]} when action in @oauth_read_actions
  15. )
  16. plug(OAuthScopesPlug, %{scopes: ["write:notifications"]} when action not in @oauth_read_actions)
  17. defdelegate open_api_operation(action), to: Pleroma.Web.ApiSpec.NotificationOperation
  18. @default_notification_types ~w{
  19. mention
  20. follow
  21. follow_request
  22. reblog
  23. favourite
  24. move
  25. pleroma:emoji_reaction
  26. poll
  27. update
  28. status
  29. }
  30. # GET /api/v1/notifications
  31. def index(%{private: %{open_api_spex: %{params: %{account_id: account_id} = params}}} = conn, _) do
  32. case Pleroma.User.get_cached_by_id(account_id) do
  33. %{ap_id: account_ap_id} ->
  34. params =
  35. params
  36. |> Map.delete(:account_id)
  37. |> Map.put(:account_ap_id, account_ap_id)
  38. do_get_notifications(conn, params)
  39. _ ->
  40. conn
  41. |> put_status(:not_found)
  42. |> json(%{"error" => "Account is not found"})
  43. end
  44. end
  45. def index(%{private: %{open_api_spex: %{params: params}}} = conn, _) do
  46. do_get_notifications(conn, params)
  47. end
  48. defp do_get_notifications(%{assigns: %{user: user}} = conn, params) do
  49. params =
  50. Map.new(params, fn {k, v} -> {to_string(k), v} end)
  51. |> Map.put_new("types", Map.get(params, :include_types, @default_notification_types))
  52. notifications = MastodonAPI.get_notifications(user, params)
  53. conn
  54. |> add_link_headers(notifications)
  55. |> render("index.json",
  56. notifications: notifications,
  57. for: user
  58. )
  59. end
  60. # GET /api/v1/notifications/:id
  61. def show(%{assigns: %{user: user}, private: %{open_api_spex: %{params: %{id: id}}}} = conn, _) do
  62. with {:ok, notification} <- Notification.get(user, id) do
  63. render(conn, "show.json", notification: notification, for: user)
  64. else
  65. {:error, reason} ->
  66. conn
  67. |> put_status(:forbidden)
  68. |> json(%{"error" => reason})
  69. end
  70. end
  71. # POST /api/v1/notifications/clear
  72. def clear(%{assigns: %{user: user}} = conn, _params) do
  73. Notification.clear(user)
  74. json(conn, %{})
  75. end
  76. # POST /api/v1/notifications/:id/dismiss
  77. def dismiss(%{private: %{open_api_spex: %{params: %{id: id}}}} = conn, _) do
  78. do_dismiss(conn, id)
  79. end
  80. # POST /api/v1/notifications/dismiss (deprecated)
  81. def dismiss_via_body(
  82. %{private: %{open_api_spex: %{body_params: %{id: id}}}} = conn,
  83. _
  84. ) do
  85. do_dismiss(conn, id)
  86. end
  87. defp do_dismiss(%{assigns: %{user: user}} = conn, notification_id) do
  88. with {:ok, _notif} <- Notification.dismiss(user, notification_id) do
  89. json(conn, %{})
  90. else
  91. {:error, reason} ->
  92. conn
  93. |> put_status(:forbidden)
  94. |> json(%{"error" => reason})
  95. end
  96. end
  97. # DELETE /api/v1/notifications/destroy_multiple
  98. def destroy_multiple(
  99. %{assigns: %{user: user}, private: %{open_api_spex: %{params: %{ids: ids}}}} = conn,
  100. _
  101. ) do
  102. Notification.destroy_multiple(user, ids)
  103. json(conn, %{})
  104. end
  105. end