dac47d2abb
Signed-off-by: Thomas Citharel <tcit@tcit.fr>
148 lines
4.4 KiB
Elixir
148 lines
4.4 KiB
Elixir
defmodule Mobilizon.GraphQL.Resolvers.Report do
|
|
@moduledoc """
|
|
Handles the report-related GraphQL calls.
|
|
"""
|
|
|
|
import Mobilizon.Users.Guards
|
|
|
|
alias Mobilizon.Actors
|
|
alias Mobilizon.Actors.Actor
|
|
alias Mobilizon.Config
|
|
alias Mobilizon.Reports
|
|
alias Mobilizon.Reports.{Note, Report}
|
|
alias Mobilizon.Users.User
|
|
|
|
alias Mobilizon.GraphQL.API
|
|
|
|
def list_reports(
|
|
_parent,
|
|
%{page: page, limit: limit, status: status},
|
|
%{context: %{current_user: %User{role: role}}}
|
|
)
|
|
when is_moderator(role) do
|
|
{:ok, Mobilizon.Reports.list_reports(page, limit, :updated_at, :desc, status)}
|
|
end
|
|
|
|
def list_reports(_parent, _args, _resolution) do
|
|
{:error, "You need to be logged-in and a moderator to list reports"}
|
|
end
|
|
|
|
def get_report(_parent, %{id: id}, %{context: %{current_user: %User{role: role}}})
|
|
when is_moderator(role) do
|
|
case Mobilizon.Reports.get_report(id) do
|
|
%Report{} = report ->
|
|
{:ok, report}
|
|
|
|
nil ->
|
|
{:error, "Report not found"}
|
|
end
|
|
end
|
|
|
|
def get_report(_parent, _args, _resolution) do
|
|
{:error, "You need to be logged-in and a moderator to view a report"}
|
|
end
|
|
|
|
@doc """
|
|
Create a report
|
|
"""
|
|
def create_report(
|
|
_parent,
|
|
%{reporter_id: reporter_id} = args,
|
|
%{context: %{current_user: %User{} = user}} = _resolution
|
|
) do
|
|
with {:is_owned, %Actor{}} <- User.owns_actor(user, reporter_id),
|
|
{:ok, _, %Report{} = report} <- API.Reports.report(args) do
|
|
{:ok, report}
|
|
else
|
|
{:is_owned, nil} ->
|
|
{:error, "Reporter actor id is not owned by authenticated user"}
|
|
|
|
_error ->
|
|
{:error, "Error while saving report"}
|
|
end
|
|
end
|
|
|
|
@doc """
|
|
Create a report anonymously if allowed
|
|
"""
|
|
def create_report(
|
|
_parent,
|
|
%{reporter_id: reporter_id} = args,
|
|
_resolution
|
|
) do
|
|
with {:anonymous_reporting_allowed, true} <-
|
|
{:anonymous_reporting_allowed, Config.anonymous_reporting?()},
|
|
{:wrong_id, true} <- {:wrong_id, reporter_id == to_string(Config.anonymous_actor_id())},
|
|
{:ok, _, %Report{} = report} <- API.Reports.report(args) do
|
|
{:ok, report}
|
|
else
|
|
{:anonymous_reporting_allowed, _} ->
|
|
{:error, "You need to be logged-in to create reports"}
|
|
|
|
{:wrong_id, _} ->
|
|
{:error, "Reporter ID is not the anonymous actor id"}
|
|
|
|
_error ->
|
|
{:error, "Error while saving report"}
|
|
end
|
|
end
|
|
|
|
def create_report(_parent, _args, _resolution) do
|
|
{:error, "You need to be logged-in to create reports"}
|
|
end
|
|
|
|
@doc """
|
|
Update a report's status
|
|
"""
|
|
def update_report(
|
|
_parent,
|
|
%{report_id: report_id, moderator_id: moderator_id, status: status},
|
|
%{context: %{current_user: %User{role: role} = user}}
|
|
)
|
|
when is_moderator(role) do
|
|
with {:is_owned, %Actor{} = actor} <- User.owns_actor(user, moderator_id),
|
|
%Report{} = report <- Mobilizon.Reports.get_report(report_id),
|
|
{:ok, %Report{} = report} <- API.Reports.update_report_status(actor, report, status) do
|
|
{:ok, report}
|
|
else
|
|
{:is_owned, nil} ->
|
|
{:error, "Actor id is not owned by authenticated user"}
|
|
|
|
_error ->
|
|
{:error, "Error while updating report"}
|
|
end
|
|
end
|
|
|
|
def update_report(_parent, _args, _resolution) do
|
|
{:error, "You need to be logged-in and a moderator to update a report"}
|
|
end
|
|
|
|
def create_report_note(
|
|
_parent,
|
|
%{report_id: report_id, moderator_id: moderator_id, content: content},
|
|
%{context: %{current_user: %User{role: role} = user}}
|
|
)
|
|
when is_moderator(role) do
|
|
with {:is_owned, %Actor{}} <- User.owns_actor(user, moderator_id),
|
|
%Report{} = report <- Reports.get_report(report_id),
|
|
%Actor{} = moderator <- Actors.get_local_actor_with_preload(moderator_id),
|
|
{:ok, %Note{} = note} <- API.Reports.create_report_note(report, moderator, content) do
|
|
{:ok, note}
|
|
end
|
|
end
|
|
|
|
def delete_report_note(
|
|
_parent,
|
|
%{note_id: note_id, moderator_id: moderator_id},
|
|
%{context: %{current_user: %User{role: role} = user}}
|
|
)
|
|
when is_moderator(role) do
|
|
with {:is_owned, %Actor{}} <- User.owns_actor(user, moderator_id),
|
|
%Note{} = note <- Reports.get_note(note_id),
|
|
%Actor{} = moderator <- Actors.get_local_actor_with_preload(moderator_id),
|
|
{:ok, %Note{} = note} <- API.Reports.delete_report_note(note, moderator) do
|
|
{:ok, %{id: note.id}}
|
|
end
|
|
end
|
|
end
|