aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorkaniini <nenolod@gmail.com>2018-09-10 01:22:06 +0000
committerkaniini <nenolod@gmail.com>2018-09-10 01:22:06 +0000
commitb0a5637254db8d9704b39f5c52d1429421f8628f (patch)
tree91a2a6005be6ec3febaca524f587da2cc3bb1515 /lib
parent7b96d203287a00791b6c118ce453aa8e34f3112d (diff)
parente0b8c0ccba57cb8f920929c61b64c523f431edec (diff)
downloadpleroma-b0a5637254db8d9704b39f5c52d1429421f8628f.tar.gz
Merge branch 'refactor/mrf-pattern-matching' into 'develop'
MRF: significant refactoring See merge request pleroma/pleroma!340
Diffstat (limited to 'lib')
-rw-r--r--lib/pleroma/web/activity_pub/mrf/reject_non_public.ex65
-rw-r--r--lib/pleroma/web/activity_pub/mrf/simple_policy.ex115
2 files changed, 88 insertions, 92 deletions
diff --git a/lib/pleroma/web/activity_pub/mrf/reject_non_public.ex b/lib/pleroma/web/activity_pub/mrf/reject_non_public.ex
index b6936fe90..129d04617 100644
--- a/lib/pleroma/web/activity_pub/mrf/reject_non_public.ex
+++ b/lib/pleroma/web/activity_pub/mrf/reject_non_public.ex
@@ -7,43 +7,42 @@ defmodule Pleroma.Web.ActivityPub.MRF.RejectNonPublic do
@allow_direct Keyword.get(@mrf_rejectnonpublic, :allow_direct)
@impl true
- def filter(object) do
- if object["type"] == "Create" do
- user = User.get_cached_by_ap_id(object["actor"])
- public = "https://www.w3.org/ns/activitystreams#Public"
-
- # Determine visibility
- visibility =
- cond do
- public in object["to"] -> "public"
- public in object["cc"] -> "unlisted"
- user.follower_address in object["to"] -> "followers"
- true -> "direct"
- end
+ def filter(%{"type" => "Create"} = object) do
+ user = User.get_cached_by_ap_id(object["actor"])
+ public = "https://www.w3.org/ns/activitystreams#Public"
- case visibility do
- "public" ->
- {:ok, object}
+ # Determine visibility
+ visibility =
+ cond do
+ public in object["to"] -> "public"
+ public in object["cc"] -> "unlisted"
+ user.follower_address in object["to"] -> "followers"
+ true -> "direct"
+ end
- "unlisted" ->
+ case visibility do
+ "public" ->
+ {:ok, object}
+
+ "unlisted" ->
+ {:ok, object}
+
+ "followers" ->
+ with true <- @allow_followersonly do
{:ok, object}
+ else
+ _e -> {:reject, nil}
+ end
- "followers" ->
- with true <- @allow_followersonly do
- {:ok, object}
- else
- _e -> {:reject, nil}
- end
-
- "direct" ->
- with true <- @allow_direct do
- {:ok, object}
- else
- _e -> {:reject, nil}
- end
- end
- else
- {:ok, object}
+ "direct" ->
+ with true <- @allow_direct do
+ {:ok, object}
+ else
+ _e -> {:reject, nil}
+ end
end
end
+
+ @impl true
+ def filter(object), do: {:ok, object}
end
diff --git a/lib/pleroma/web/activity_pub/mrf/simple_policy.ex b/lib/pleroma/web/activity_pub/mrf/simple_policy.ex
index 7fecb8a4f..319721d48 100644
--- a/lib/pleroma/web/activity_pub/mrf/simple_policy.ex
+++ b/lib/pleroma/web/activity_pub/mrf/simple_policy.ex
@@ -5,80 +5,77 @@ defmodule Pleroma.Web.ActivityPub.MRF.SimplePolicy do
@mrf_policy Application.get_env(:pleroma, :mrf_simple)
@accept Keyword.get(@mrf_policy, :accept)
- defp check_accept(actor_info, object) do
- if length(@accept) > 0 and not (actor_info.host in @accept) do
- {:reject, nil}
- else
- {:ok, object}
- end
+ defp check_accept(%{host: actor_host} = actor_info, object)
+ when length(@accept) > 0 and not (actor_host in @accept) do
+ {:reject, nil}
end
+ defp check_accept(actor_info, object), do: {:ok, object}
+
@reject Keyword.get(@mrf_policy, :reject)
- defp check_reject(actor_info, object) do
- if actor_info.host in @reject do
- {:reject, nil}
- else
- {:ok, object}
- end
+ defp check_reject(%{host: actor_host} = actor_info, object) when actor_host in @reject do
+ {:reject, nil}
end
+ defp check_reject(actor_info, object), do: {:ok, object}
+
@media_removal Keyword.get(@mrf_policy, :media_removal)
- defp check_media_removal(actor_info, object) do
- if actor_info.host in @media_removal do
- child_object = Map.delete(object["object"], "attachment")
- object = Map.put(object, "object", child_object)
- {:ok, object}
- else
- {:ok, object}
- end
+ defp check_media_removal(%{host: actor_host} = actor_info, %{"type" => "Create"} = object)
+ when actor_host in @media_removal do
+ child_object = Map.delete(object["object"], "attachment")
+ object = Map.put(object, "object", child_object)
+ {:ok, object}
end
+ defp check_media_removal(actor_info, object), do: {:ok, object}
+
@media_nsfw Keyword.get(@mrf_policy, :media_nsfw)
- defp check_media_nsfw(actor_info, object) do
- child_object = object["object"]
-
- if actor_info.host in @media_nsfw and child_object["attachment"] != nil and
- length(child_object["attachment"]) > 0 do
- tags = (child_object["tag"] || []) ++ ["nsfw"]
- child_object = Map.put(child_object, "tags", tags)
- child_object = Map.put(child_object, "sensitive", true)
- object = Map.put(object, "object", child_object)
- {:ok, object}
- else
- {:ok, object}
- end
+ defp check_media_nsfw(
+ %{host: actor_host} = actor_info,
+ %{
+ "type" => "Create",
+ "object" => %{"attachment" => child_attachment} = child_object
+ } = object
+ )
+ when actor_host in @media_nsfw and length(child_attachment) > 0 do
+ tags = (child_object["tag"] || []) ++ ["nsfw"]
+ child_object = Map.put(child_object, "tags", tags)
+ child_object = Map.put(child_object, "sensitive", true)
+ object = Map.put(object, "object", child_object)
+ {:ok, object}
end
+ defp check_media_nsfw(actor_info, object), do: {:ok, object}
+
@ftl_removal Keyword.get(@mrf_policy, :federated_timeline_removal)
- defp check_ftl_removal(actor_info, object) do
- if actor_info.host in @ftl_removal do
- user = User.get_by_ap_id(object["actor"])
-
- # flip to/cc relationship to make the post unlisted
- object =
- if "https://www.w3.org/ns/activitystreams#Public" in object["to"] and
- user.follower_address in object["cc"] do
- to =
- List.delete(object["to"], "https://www.w3.org/ns/activitystreams#Public") ++
- [user.follower_address]
-
- cc =
- List.delete(object["cc"], user.follower_address) ++
- ["https://www.w3.org/ns/activitystreams#Public"]
-
- object
- |> Map.put("to", to)
- |> Map.put("cc", cc)
- else
- object
- end
+ defp check_ftl_removal(%{host: actor_host} = actor_info, object)
+ when actor_host in @ftl_removal do
+ user = User.get_by_ap_id(object["actor"])
- {:ok, object}
- else
- {:ok, object}
- end
+ # flip to/cc relationship to make the post unlisted
+ object =
+ if "https://www.w3.org/ns/activitystreams#Public" in object["to"] and
+ user.follower_address in object["cc"] do
+ to =
+ List.delete(object["to"], "https://www.w3.org/ns/activitystreams#Public") ++
+ [user.follower_address]
+
+ cc =
+ List.delete(object["cc"], user.follower_address) ++
+ ["https://www.w3.org/ns/activitystreams#Public"]
+
+ object
+ |> Map.put("to", to)
+ |> Map.put("cc", cc)
+ else
+ object
+ end
+
+ {:ok, object}
end
+ defp check_ftl_removal(actor_info, object), do: {:ok, object}
+
@impl true
def filter(object) do
actor_info = URI.parse(object["actor"])