1 # Pleroma: A lightweight social networking server
2 # Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/>
3 # SPDX-License-Identifier: AGPL-3.0-only
5 defmodule Pleroma.Web.MastodonAPI.NotificationController do
6 use Pleroma.Web, :controller
8 import Pleroma.Web.ControllerHelper, only: [add_link_headers: 2]
10 alias Pleroma.Notification
11 alias Pleroma.Plugs.OAuthScopesPlug
12 alias Pleroma.Web.MastodonAPI.MastodonAPI
14 @oauth_read_actions [:show, :index]
18 %{scopes: ["read:notifications"]} when action in @oauth_read_actions
21 plug(OAuthScopesPlug, %{scopes: ["write:notifications"]} when action not in @oauth_read_actions)
23 # GET /api/v1/notifications
24 def index(%{assigns: %{user: user}} = conn, params) do
25 notifications = MastodonAPI.get_notifications(user, params)
28 |> add_link_headers(notifications)
29 |> render("index.json", notifications: notifications, for: user)
32 # GET /api/v1/notifications/:id
33 def show(%{assigns: %{user: user}} = conn, %{"id" => id}) do
34 with {:ok, notification} <- Notification.get(user, id) do
35 render(conn, "show.json", notification: notification, for: user)
39 |> put_status(:forbidden)
40 |> json(%{"error" => reason})
44 # POST /api/v1/notifications/clear
45 def clear(%{assigns: %{user: user}} = conn, _params) do
46 Notification.clear(user)
50 # POST /api/v1/notifications/dismiss
51 def dismiss(%{assigns: %{user: user}} = conn, %{"id" => id} = _params) do
52 with {:ok, _notif} <- Notification.dismiss(user, id) do
57 |> put_status(:forbidden)
58 |> json(%{"error" => reason})
62 # DELETE /api/v1/notifications/destroy_multiple
63 def destroy_multiple(%{assigns: %{user: user}} = conn, %{"ids" => ids} = _params) do
64 Notification.destroy_multiple(user, ids)