implemented tweaks
This commit is contained in:
parent
531507a635
commit
e10cda7541
@ -148,7 +148,7 @@ This section is used to configure Pleroma-FE, unless ``:managed_config`` in ``:i
|
|||||||
* `allow_direct`: whether to allow direct messages
|
* `allow_direct`: whether to allow direct messages
|
||||||
|
|
||||||
## :mrf_hellthread
|
## :mrf_hellthread
|
||||||
* `delist_threshold`: Number of mentioned users after which the message gets delisted. Set to 0 to disable.
|
* `delist_threshold`: Number of mentioned users after which the message gets delisted (the message can still be seen, but it will not show up in public timelines and mentioned users won't get notifications about it). Set to 0 to disable.
|
||||||
* `reject_threshold`: Number of mentioned users after which the messaged gets rejected. Set to 0 to disable.
|
* `reject_threshold`: Number of mentioned users after which the messaged gets rejected. Set to 0 to disable.
|
||||||
|
|
||||||
## :media_proxy
|
## :media_proxy
|
||||||
|
@ -12,6 +12,13 @@ defmodule Pleroma.Config.DeprecationWarnings do
|
|||||||
You are using the old configuration mechanism for the frontend. Please check config.md.
|
You are using the old configuration mechanism for the frontend. Please check config.md.
|
||||||
""")
|
""")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if Pleroma.Config.get(:mrf_hellthread, :threshold) do
|
||||||
|
Logger.warn("""
|
||||||
|
!!!DEPRECATION WARNING!!!
|
||||||
|
You are using the old configuration mechanism for the hellthread filter. Please check config.md.
|
||||||
|
""")
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def warn do
|
def warn do
|
||||||
|
@ -6,27 +6,34 @@ defmodule Pleroma.Web.ActivityPub.MRF.HellthreadPolicy do
|
|||||||
alias Pleroma.User
|
alias Pleroma.User
|
||||||
@behaviour Pleroma.Web.ActivityPub.MRF
|
@behaviour Pleroma.Web.ActivityPub.MRF
|
||||||
|
|
||||||
|
defp delist_message(object) do
|
||||||
|
follower_collection = User.get_by_ap_id(object["actor"].follower_address)
|
||||||
|
|
||||||
|
object
|
||||||
|
|> Kernel.update_in(["to"], [follower_collection])
|
||||||
|
|> Kernel.update_in(["cc"], ["https://www.w3.org/ns/activitystreams#Public"])
|
||||||
|
end
|
||||||
|
|
||||||
@impl true
|
@impl true
|
||||||
def filter(%{"type" => "Create"} = object) do
|
def filter(%{"type" => "Create"} = object) do
|
||||||
delist_threshold = Pleroma.Config.get([:mrf_hellthread, :delist_threshold])
|
delist_threshold = Pleroma.Config.get([:mrf_hellthread, :delist_threshold])
|
||||||
reject_threshold = Pleroma.Config.get([:mrf_hellthread, :reject_threshold])
|
|
||||||
|
reject_threshold =
|
||||||
|
Pleroma.Config.get(
|
||||||
|
[:mrf_hellthread, :reject_threshold],
|
||||||
|
Pleroma.Config.get([:mrf_hellthread, :threshold])
|
||||||
|
)
|
||||||
|
|
||||||
recipients = (object["to"] || []) ++ (object["cc"] || [])
|
recipients = (object["to"] || []) ++ (object["cc"] || [])
|
||||||
|
|
||||||
cond do
|
cond do
|
||||||
length(recipients) > reject_threshold and reject_threshold != 0 ->
|
length(recipients) > reject_threshold and reject_threshold > 0 ->
|
||||||
{:reject, nil}
|
{:reject, nil}
|
||||||
|
|
||||||
length(recipients) > delist_threshold and delist_threshold != 0 ->
|
length(recipients) > delist_threshold and delist_threshold > 0 ->
|
||||||
if Enum.member?(object["to"], "https://www.w3.org/ns/activitystreams#Public") or
|
if Enum.member?(object["to"], "https://www.w3.org/ns/activitystreams#Public") or
|
||||||
Enum.member?(object["cc"], "https://www.w3.org/ns/activitystreams#Public") do
|
Enum.member?(object["to"], "https://www.w3.org/ns/activitystreams#Public") do
|
||||||
follower_collection = User.get_by_ap_id(object["actor"].follower_address)
|
delist_message(object)
|
||||||
|
|
||||||
object
|
|
||||||
|> Kernel.update_in(["object", "to"], [follower_collection])
|
|
||||||
|> Kernel.update_in(["object", "cc"], ["https://www.w3.org/ns/activitystreams#Public"])
|
|
||||||
|> Kernel.update_in(["to"], [follower_collection])
|
|
||||||
|> Kernel.update_in(["cc"], ["https://www.w3.org/ns/activitystreams#Public"])
|
|
||||||
|
|
||||||
{:ok, object}
|
{:ok, object}
|
||||||
else
|
else
|
||||||
{:ok, object}
|
{:ok, object}
|
||||||
|
Loading…
Reference in New Issue
Block a user