pleroma/lib/pleroma/web/activity_pub/mrf/user_allow_list_policy.ex

66 lines
1.9 KiB
Elixir
Raw Normal View History

# Pleroma: A lightweight social networking server
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
# SPDX-License-Identifier: AGPL-3.0-only
2018-11-27 00:23:43 +01:00
defmodule Pleroma.Web.ActivityPub.MRF.UserAllowListPolicy do
alias Pleroma.Config
@moduledoc "Accept-list of users from specified instances"
2018-11-27 00:23:43 +01:00
@behaviour Pleroma.Web.ActivityPub.MRF
defp filter_by_list(object, []), do: {:ok, object}
defp filter_by_list(%{"actor" => actor} = object, allow_list) do
if actor in allow_list do
{:ok, object}
else
{:reject, "[UserAllowListPolicy] #{actor} not in the list"}
2018-11-27 00:23:43 +01:00
end
end
@impl true
def filter(%{"actor" => actor} = object) do
actor_info = URI.parse(actor)
2019-07-10 07:12:21 +02:00
allow_list =
Config.get(
[:mrf_user_allowlist, actor_info.host],
2019-07-10 07:12:21 +02:00
[]
)
2018-11-27 00:23:43 +01:00
filter_by_list(object, allow_list)
end
def filter(object), do: {:ok, object}
@impl true
2019-08-14 00:36:24 +02:00
def describe do
mrf_user_allowlist =
Config.get([:mrf_user_allowlist], [])
|> Enum.into(%{}, fn {k, v} -> {k, length(v)} end)
{:ok, %{mrf_user_allowlist: mrf_user_allowlist}}
end
# TODO: change way of getting settings on `lib/pleroma/web/activity_pub/mrf/user_allow_list_policy.ex:18` to use `hosts` subkey
# @impl true
# def config_description do
# %{
# key: :mrf_user_allowlist,
# related_policy: "Pleroma.Web.ActivityPub.MRF.UserAllowListPolicy",
# description: "Accept-list of users from specified instances",
# children: [
# %{
# key: :hosts,
# type: :map,
# description:
# "The keys in this section are the domain names that the policy should apply to." <>
2020-11-11 08:48:03 +01:00
# " Each key should be assigned a list of users that should be allowed " <>
# "through by their ActivityPub ID",
# suggestions: [%{"example.org" => ["https://example.org/users/admin"]}]
# }
# ]
# }
# end
2018-11-27 00:23:43 +01:00
end