1
0
Fork 0
mirror of https://akkoma.dev/AkkomaGang/akkoma.git synced 2025-01-25 15:09:34 +00:00
akkoma/lib/pleroma/web/activity_pub/mrf/reject_non_public.ex

75 lines
2 KiB
Elixir
Raw Normal View History

# Pleroma: A lightweight social networking server
# Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
# SPDX-License-Identifier: AGPL-3.0-only
defmodule Pleroma.Web.ActivityPub.MRF.RejectNonPublic do
@moduledoc "Rejects non-public (followers-only, direct) activities"
2019-07-10 05:12:21 +00:00
alias Pleroma.Config
alias Pleroma.User
@behaviour Pleroma.Web.ActivityPub.MRF.Policy
require Pleroma.Constants
2019-07-10 05:12:21 +00:00
2018-06-07 22:10:11 -07:00
@impl true
def filter(%{"type" => "Create"} = object) do
user = User.get_cached_by_ap_id(object["actor"])
# Determine visibility
visibility =
cond do
Pleroma.Constants.as_public() in object["to"] -> "public"
Pleroma.Constants.as_public() in object["cc"] -> "unlisted"
user.follower_address in object["to"] -> "followers"
true -> "direct"
end
2019-07-10 05:12:21 +00:00
policy = Config.get(:mrf_rejectnonpublic)
cond do
visibility in ["public", "unlisted"] ->
{:ok, object}
2019-07-10 05:12:21 +00:00
visibility == "followers" and Keyword.get(policy, :allow_followersonly) ->
{:ok, object}
2019-07-10 05:12:21 +00:00
visibility == "direct" and Keyword.get(policy, :allow_direct) ->
{:ok, object}
2019-07-10 05:12:21 +00:00
true ->
{:reject, "[RejectNonPublic] visibility: #{visibility}"}
end
end
@impl true
def filter(object), do: {:ok, object}
@impl true
def describe,
2021-02-04 17:23:21 +04:00
do: {:ok, %{mrf_rejectnonpublic: Config.get(:mrf_rejectnonpublic) |> Map.new()}}
@impl true
def config_description do
%{
key: :mrf_rejectnonpublic,
related_policy: "Pleroma.Web.ActivityPub.MRF.RejectNonPublic",
description: "RejectNonPublic drops posts with non-public visibility settings.",
label: "MRF Reject Non Public",
children: [
%{
key: :allow_followersonly,
label: "Allow followers-only",
type: :boolean,
description: "Whether to allow followers-only posts"
},
%{
key: :allow_direct,
type: :boolean,
description: "Whether to allow direct messages"
}
]
}
end
end