forked from mirrors/akkoma
0580654485
Since the conversations with the blocked user are invisible, they are excluded from the blocking user's `unread_conversation_count`.
113 lines
3.6 KiB
Elixir
113 lines
3.6 KiB
Elixir
# Pleroma: A lightweight social networking server
|
|
# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/>
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
defmodule Pleroma.Web.PleromaAPI.PleromaAPIController do
|
|
use Pleroma.Web, :controller
|
|
|
|
import Pleroma.Web.ControllerHelper, only: [add_link_headers: 2]
|
|
|
|
alias Pleroma.Conversation.Participation
|
|
alias Pleroma.Notification
|
|
alias Pleroma.Plugs.OAuthScopesPlug
|
|
alias Pleroma.Web.ActivityPub.ActivityPub
|
|
alias Pleroma.Web.MastodonAPI.ConversationView
|
|
alias Pleroma.Web.MastodonAPI.NotificationView
|
|
alias Pleroma.Web.MastodonAPI.StatusView
|
|
|
|
plug(
|
|
OAuthScopesPlug,
|
|
%{scopes: ["read:statuses"]} when action in [:conversation, :conversation_statuses]
|
|
)
|
|
|
|
plug(
|
|
OAuthScopesPlug,
|
|
%{scopes: ["write:conversations"]} when action == :update_conversation
|
|
)
|
|
|
|
plug(OAuthScopesPlug, %{scopes: ["write:notifications"]} when action == :read_notification)
|
|
|
|
plug(Pleroma.Plugs.EnsurePublicOrAuthenticatedPlug)
|
|
|
|
def conversation(%{assigns: %{user: user}} = conn, %{"id" => participation_id}) do
|
|
with %Participation{} = participation <- Participation.get(participation_id),
|
|
true <- user.id == participation.user_id do
|
|
conn
|
|
|> put_view(ConversationView)
|
|
|> render("participation.json", %{participation: participation, for: user})
|
|
end
|
|
end
|
|
|
|
def conversation_statuses(
|
|
%{assigns: %{user: user}} = conn,
|
|
%{"id" => participation_id} = params
|
|
) do
|
|
participation = Participation.get(participation_id, preload: [:conversation])
|
|
|
|
if user.id == participation.user_id do
|
|
params =
|
|
params
|
|
|> Map.put("blocking_user", user)
|
|
|> Map.put("muting_user", user)
|
|
|> Map.put("user", user)
|
|
|
|
activities =
|
|
participation.conversation.ap_id
|
|
|> ActivityPub.fetch_activities_for_context(params)
|
|
|> Enum.reverse()
|
|
|
|
conn
|
|
|> add_link_headers(activities)
|
|
|> put_view(StatusView)
|
|
|> render("index.json", %{activities: activities, for: user, as: :activity})
|
|
end
|
|
end
|
|
|
|
def update_conversation(
|
|
%{assigns: %{user: user}} = conn,
|
|
%{"id" => participation_id, "recipients" => recipients}
|
|
) do
|
|
participation =
|
|
participation_id
|
|
|> Participation.get()
|
|
|
|
with true <- user.id == participation.user_id,
|
|
{:ok, participation} <- Participation.set_recipients(participation, recipients) do
|
|
conn
|
|
|> put_view(ConversationView)
|
|
|> render("participation.json", %{participation: participation, for: user})
|
|
end
|
|
end
|
|
|
|
def read_conversations(%{assigns: %{user: user}} = conn, _params) do
|
|
with {:ok, _, participations} <- Participation.mark_all_as_read(user) do
|
|
conn
|
|
|> add_link_headers(participations)
|
|
|> put_view(ConversationView)
|
|
|> render("participations.json", participations: participations, for: user)
|
|
end
|
|
end
|
|
|
|
def read_notification(%{assigns: %{user: user}} = conn, %{"id" => notification_id}) do
|
|
with {:ok, notification} <- Notification.read_one(user, notification_id) do
|
|
conn
|
|
|> put_view(NotificationView)
|
|
|> render("show.json", %{notification: notification, for: user})
|
|
else
|
|
{:error, message} ->
|
|
conn
|
|
|> put_status(:bad_request)
|
|
|> json(%{"error" => message})
|
|
end
|
|
end
|
|
|
|
def read_notification(%{assigns: %{user: user}} = conn, %{"max_id" => max_id}) do
|
|
with notifications <- Notification.set_read_up_to(user, max_id) do
|
|
notifications = Enum.take(notifications, 80)
|
|
|
|
conn
|
|
|> put_view(NotificationView)
|
|
|> render("index.json", %{notifications: notifications, for: user})
|
|
end
|
|
end
|
|
end
|