add allow_followersonly and allow_direct options for configuring mrf_rejectnonpublic
This commit is contained in:
parent
45a935f0bd
commit
07f0cfa53f
|
@ -59,6 +59,10 @@
|
||||||
|
|
||||||
config :pleroma, :activitypub, accept_blocks: true
|
config :pleroma, :activitypub, accept_blocks: true
|
||||||
|
|
||||||
|
config :pleroma, :mrf_rejectnonpublic,
|
||||||
|
allow_followersonly: false,
|
||||||
|
allow_direct: false
|
||||||
|
|
||||||
config :pleroma, :mrf_simple,
|
config :pleroma, :mrf_simple,
|
||||||
media_removal: [],
|
media_removal: [],
|
||||||
media_nsfw: [],
|
media_nsfw: [],
|
||||||
|
|
|
@ -2,6 +2,10 @@ defmodule Pleroma.Web.ActivityPub.MRF.RejectNonPublic do
|
||||||
alias Pleroma.User
|
alias Pleroma.User
|
||||||
@behaviour Pleroma.Web.ActivityPub.MRF
|
@behaviour Pleroma.Web.ActivityPub.MRF
|
||||||
|
|
||||||
|
@mrf_rejectnonpublic Application.get_env(:pleroma, :mrf_rejectnonpublic)
|
||||||
|
@allow_followersonly Keyword.get(@mrf_rejectnonpublic, :allow_followersonly)
|
||||||
|
@allow_direct Keyword.get(@mrf_rejectnonpublic, :allow_direct)
|
||||||
|
|
||||||
@impl true
|
@impl true
|
||||||
def filter(object) do
|
def filter(object) do
|
||||||
if object["type"] == "Create" do
|
if object["type"] == "Create" do
|
||||||
|
@ -18,9 +22,25 @@ def filter(object) do
|
||||||
end
|
end
|
||||||
|
|
||||||
case visibility do
|
case visibility do
|
||||||
"public" -> {:ok, object}
|
"public" ->
|
||||||
"unlisted" -> {:ok, object}
|
{:ok, object}
|
||||||
_ -> {:reject, nil}
|
|
||||||
|
"unlisted" ->
|
||||||
|
{:ok, object}
|
||||||
|
|
||||||
|
"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
|
end
|
||||||
else
|
else
|
||||||
{:ok, object}
|
{:ok, object}
|
||||||
|
|
Loading…
Reference in a new issue