2019-09-22 18:29:13 +02:00
|
|
|
defmodule Mobilizon.Service.ActivityPub.Converter.Flag do
|
2019-07-23 13:49:22 +02:00
|
|
|
@moduledoc """
|
2019-09-22 16:26:23 +02:00
|
|
|
Flag converter.
|
2019-07-23 13:49:22 +02:00
|
|
|
|
2019-09-22 16:26:23 +02:00
|
|
|
This module allows to convert reports from ActivityStream format to our own
|
|
|
|
internal one, and back.
|
2019-07-23 13:49:22 +02:00
|
|
|
|
|
|
|
Note: Reports are named Flag in AS.
|
|
|
|
"""
|
2019-09-22 16:26:23 +02:00
|
|
|
|
2019-07-23 13:49:22 +02:00
|
|
|
alias Mobilizon.Actors
|
|
|
|
alias Mobilizon.Actors.Actor
|
|
|
|
alias Mobilizon.Events
|
|
|
|
alias Mobilizon.Events.Event
|
|
|
|
alias Mobilizon.Reports.Report
|
|
|
|
alias Mobilizon.Service.ActivityPub.Converter
|
|
|
|
|
|
|
|
@behaviour Converter
|
|
|
|
|
|
|
|
@doc """
|
2019-09-22 18:29:13 +02:00
|
|
|
Converts an AP object data to our internal data structure.
|
2019-07-23 13:49:22 +02:00
|
|
|
"""
|
|
|
|
@impl Converter
|
2019-09-22 18:29:13 +02:00
|
|
|
@spec as_to_model_data(map) :: map
|
2019-07-23 13:49:22 +02:00
|
|
|
def as_to_model_data(object) do
|
|
|
|
with params <- as_to_model(object) do
|
|
|
|
%{
|
|
|
|
"reporter_id" => params["reporter"].id,
|
|
|
|
"uri" => params["uri"],
|
|
|
|
"content" => params["content"],
|
|
|
|
"reported_id" => params["reported"].id,
|
|
|
|
"event_id" => (!is_nil(params["event"]) && params["event"].id) || nil,
|
|
|
|
"comments" => params["comments"]
|
|
|
|
}
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-09-22 18:29:13 +02:00
|
|
|
@doc """
|
|
|
|
Convert an event struct to an ActivityStream representation
|
|
|
|
"""
|
|
|
|
@impl Converter
|
|
|
|
@spec model_to_as(EventModel.t()) :: map
|
|
|
|
def model_to_as(%Report{} = report) do
|
|
|
|
%{
|
|
|
|
"type" => "Flag",
|
|
|
|
"to" => ["https://www.w3.org/ns/activitystreams#Public"],
|
|
|
|
"actor" => report.reporter.url,
|
|
|
|
"id" => report.url
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
@spec as_to_model(map) :: map
|
2019-07-23 13:49:22 +02:00
|
|
|
def as_to_model(%{"object" => objects} = object) do
|
|
|
|
with {:ok, %Actor{} = reporter} <- Actors.get_actor_by_url(object["actor"]),
|
|
|
|
%Actor{} = reported <-
|
|
|
|
Enum.reduce_while(objects, nil, fn url, _ ->
|
2019-07-23 18:06:22 +02:00
|
|
|
case Actors.get_actor_by_url(url) do
|
|
|
|
{:ok, %Actor{} = actor} ->
|
|
|
|
{:halt, actor}
|
|
|
|
|
|
|
|
_ ->
|
|
|
|
{:cont, nil}
|
2019-07-23 13:49:22 +02:00
|
|
|
end
|
|
|
|
end),
|
|
|
|
event <-
|
|
|
|
Enum.reduce_while(objects, nil, fn url, _ ->
|
2019-07-23 18:06:22 +02:00
|
|
|
case Events.get_event_by_url(url) do
|
|
|
|
%Event{} = event ->
|
|
|
|
{:halt, event}
|
|
|
|
|
|
|
|
_ ->
|
|
|
|
{:cont, nil}
|
2019-07-23 13:49:22 +02:00
|
|
|
end
|
|
|
|
end),
|
|
|
|
|
|
|
|
# Remove the reported user from the object list.
|
|
|
|
comments <-
|
|
|
|
Enum.filter(objects, fn url ->
|
|
|
|
!(url == reported.url || (!is_nil(event) && event.url == url))
|
|
|
|
end),
|
|
|
|
comments <- Enum.map(comments, &Events.get_comment_from_url/1) do
|
|
|
|
%{
|
|
|
|
"reporter" => reporter,
|
|
|
|
"uri" => object["id"],
|
|
|
|
"content" => object["content"],
|
|
|
|
"reported" => reported,
|
|
|
|
"event" => event,
|
|
|
|
"comments" => comments
|
|
|
|
}
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|