Don't allow remote comments to be inserted if parent event doesn't allow it
Signed-off-by: Thomas Citharel <tcit@tcit.fr>
This commit is contained in:
parent
2d695f4f0f
commit
6cda3c0a94
@ -66,22 +66,25 @@ defmodule Mobilizon.Federation.ActivityPub.Transmogrifier do
|
|||||||
object |> Converter.Comment.as_to_model_data(),
|
object |> Converter.Comment.as_to_model_data(),
|
||||||
{:existing_comment, {:error, :comment_not_found}} <-
|
{:existing_comment, {:error, :comment_not_found}} <-
|
||||||
{:existing_comment, Discussions.get_comment_from_url_with_preload(object_data.url)},
|
{:existing_comment, Discussions.get_comment_from_url_with_preload(object_data.url)},
|
||||||
object_data <- transform_object_data_for_discussion(object_data) do
|
object_data <- transform_object_data_for_discussion(object_data),
|
||||||
# Check should be better
|
# Check should be better
|
||||||
|
|
||||||
{:ok, %Activity{} = activity, entity} =
|
{:ok, %Activity{} = activity, entity} <-
|
||||||
if is_data_for_comment_or_discussion?(object_data) do
|
(if is_data_for_comment_or_discussion?(object_data) do
|
||||||
Logger.debug("Chosing to create a regular comment")
|
Logger.debug("Chosing to create a regular comment")
|
||||||
ActivityPub.create(:comment, object_data, false)
|
ActivityPub.create(:comment, object_data, false)
|
||||||
else
|
else
|
||||||
Logger.debug("Chosing to initialize or add a comment to a conversation")
|
Logger.debug("Chosing to initialize or add a comment to a conversation")
|
||||||
ActivityPub.create(:discussion, object_data, false)
|
ActivityPub.create(:discussion, object_data, false)
|
||||||
end
|
end) do
|
||||||
|
|
||||||
{:ok, activity, entity}
|
{:ok, activity, entity}
|
||||||
else
|
else
|
||||||
{:existing_comment, {:ok, %Comment{} = comment}} ->
|
{:existing_comment, {:ok, %Comment{} = comment}} ->
|
||||||
{:ok, nil, comment}
|
{:ok, nil, comment}
|
||||||
|
|
||||||
|
{:error, :event_comments_are_closed} ->
|
||||||
|
Logger.debug("Tried to reply to an event for which comments are closed")
|
||||||
|
:error
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@ defmodule Mobilizon.Federation.ActivityPub.Types.Comments do
|
|||||||
alias Mobilizon.{Actors, Discussions, Events}
|
alias Mobilizon.{Actors, Discussions, Events}
|
||||||
alias Mobilizon.Actors.Actor
|
alias Mobilizon.Actors.Actor
|
||||||
alias Mobilizon.Discussions.{Comment, Discussion}
|
alias Mobilizon.Discussions.{Comment, Discussion}
|
||||||
alias Mobilizon.Events.Event
|
alias Mobilizon.Events.{Event, EventOptions}
|
||||||
alias Mobilizon.Federation.ActivityPub.Audience
|
alias Mobilizon.Federation.ActivityPub.Audience
|
||||||
alias Mobilizon.Federation.ActivityPub.Types.Entity
|
alias Mobilizon.Federation.ActivityPub.Types.Entity
|
||||||
alias Mobilizon.Federation.ActivityStream.Converter.Utils, as: ConverterUtils
|
alias Mobilizon.Federation.ActivityStream.Converter.Utils, as: ConverterUtils
|
||||||
@ -21,6 +21,7 @@ defmodule Mobilizon.Federation.ActivityPub.Types.Comments do
|
|||||||
@spec create(map(), map()) :: {:ok, map()}
|
@spec create(map(), map()) :: {:ok, map()}
|
||||||
def create(args, additional) do
|
def create(args, additional) do
|
||||||
with args <- prepare_args_for_comment(args),
|
with args <- prepare_args_for_comment(args),
|
||||||
|
:ok <- make_sure_event_allows_commenting(args),
|
||||||
{:ok, %Comment{discussion_id: discussion_id} = comment} <-
|
{:ok, %Comment{discussion_id: discussion_id} = comment} <-
|
||||||
Discussions.create_comment(args),
|
Discussions.create_comment(args),
|
||||||
:ok <- maybe_publish_graphql_subscription(discussion_id),
|
:ok <- maybe_publish_graphql_subscription(discussion_id),
|
||||||
@ -171,4 +172,21 @@ defmodule Mobilizon.Federation.ActivityPub.Types.Comments do
|
|||||||
:ok
|
:ok
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
defp make_sure_event_allows_commenting(%{
|
||||||
|
actor_id: actor_id,
|
||||||
|
event: %Event{
|
||||||
|
options: %EventOptions{comment_moderation: comment_moderation},
|
||||||
|
organizer_actor_id: organizer_actor_id
|
||||||
|
}
|
||||||
|
}) do
|
||||||
|
if comment_moderation != :closed ||
|
||||||
|
to_string(actor_id) == to_string(organizer_actor_id) do
|
||||||
|
:ok
|
||||||
|
else
|
||||||
|
{:error, :event_comments_are_closed}
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
defp make_sure_event_allows_commenting(_), do: :ok
|
||||||
end
|
end
|
||||||
|
@ -8,6 +8,7 @@ defmodule Mobilizon.Federation.ActivityPub.Transmogrifier.CommentsTest do
|
|||||||
alias Mobilizon.Actors.Actor
|
alias Mobilizon.Actors.Actor
|
||||||
alias Mobilizon.Discussions
|
alias Mobilizon.Discussions
|
||||||
alias Mobilizon.Discussions.Comment
|
alias Mobilizon.Discussions.Comment
|
||||||
|
alias Mobilizon.Events.Event
|
||||||
alias Mobilizon.Federation.ActivityPub.{Activity, Transmogrifier}
|
alias Mobilizon.Federation.ActivityPub.{Activity, Transmogrifier}
|
||||||
alias Mobilizon.Federation.ActivityStream.Convertible
|
alias Mobilizon.Federation.ActivityStream.Convertible
|
||||||
alias Mobilizon.Service.HTTP.ActivityPub.Mock
|
alias Mobilizon.Service.HTTP.ActivityPub.Mock
|
||||||
@ -73,6 +74,24 @@ defmodule Mobilizon.Federation.ActivityPub.Transmogrifier.CommentsTest do
|
|||||||
assert returned_activity.data["object"]["inReplyTo"] == origin_comment.url
|
assert returned_activity.data["object"]["inReplyTo"] == origin_comment.url
|
||||||
end
|
end
|
||||||
|
|
||||||
|
test "it doesn't saves replies to an event if the event doesn't accept comments" do
|
||||||
|
data =
|
||||||
|
File.read!("test/fixtures/mastodon-post-activity.json")
|
||||||
|
|> Jason.decode!()
|
||||||
|
|
||||||
|
%Event{url: reply_to_url} = insert(:event, options: %{comment_moderation: :closed})
|
||||||
|
|
||||||
|
object =
|
||||||
|
data["object"]
|
||||||
|
|> Map.put("inReplyTo", reply_to_url)
|
||||||
|
|
||||||
|
data =
|
||||||
|
data
|
||||||
|
|> Map.put("object", object)
|
||||||
|
|
||||||
|
:error = Transmogrifier.handle_incoming(data)
|
||||||
|
end
|
||||||
|
|
||||||
@url_404 "https://404.site/whatever"
|
@url_404 "https://404.site/whatever"
|
||||||
test "it does not crash if the object in inReplyTo can't be fetched" do
|
test "it does not crash if the object in inReplyTo can't be fetched" do
|
||||||
data =
|
data =
|
||||||
|
Loading…
x
Reference in New Issue
Block a user