2022-02-25 23:11:42 -07:00
|
|
|
# Pleroma: A lightweight social networking server
|
|
|
|
# Copyright © 2017-2022 Pleroma Authors <https://pleroma.social/>
|
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2021-02-24 10:59:11 -07:00
|
|
|
defmodule Pleroma.Web.ActivityPub.MRF.FollowBotPolicy do
|
2021-06-07 13:22:08 -06:00
|
|
|
@behaviour Pleroma.Web.ActivityPub.MRF.Policy
|
2020-10-08 11:09:31 -06:00
|
|
|
alias Pleroma.Config
|
2020-10-08 10:55:35 -06:00
|
|
|
alias Pleroma.User
|
|
|
|
alias Pleroma.Web.CommonAPI
|
|
|
|
|
2021-02-19 14:17:33 -07:00
|
|
|
require Logger
|
2021-02-19 08:47:25 -07:00
|
|
|
|
2020-10-08 10:55:35 -06:00
|
|
|
@impl true
|
|
|
|
def filter(message) do
|
2020-10-08 11:09:31 -06:00
|
|
|
with follower_nickname <- Config.get([:mrf_follow_bot, :follower_nickname]),
|
2020-10-08 11:41:01 -06:00
|
|
|
%User{actor_type: "Service"} = follower <-
|
|
|
|
User.get_cached_by_nickname(follower_nickname),
|
2020-10-08 11:09:31 -06:00
|
|
|
%{"type" => "Create", "object" => %{"type" => "Note"}} <- message do
|
|
|
|
try_follow(follower, message)
|
|
|
|
else
|
|
|
|
nil ->
|
|
|
|
Logger.warn(
|
2020-10-08 11:41:01 -06:00
|
|
|
"#{__MODULE__} skipped because of missing `:mrf_follow_bot, :follower_nickname` configuration, the :follower_nickname
|
|
|
|
account does not exist, or the account is not correctly configured as a bot."
|
2020-10-08 11:09:31 -06:00
|
|
|
)
|
|
|
|
|
|
|
|
{:ok, message}
|
|
|
|
|
|
|
|
_ ->
|
|
|
|
{:ok, message}
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
defp try_follow(follower, message) do
|
2021-02-19 17:36:35 -07:00
|
|
|
to = Map.get(message, "to", [])
|
|
|
|
cc = Map.get(message, "cc", [])
|
|
|
|
actor = [message["actor"]]
|
|
|
|
|
|
|
|
Enum.concat([to, cc, actor])
|
|
|
|
|> List.flatten()
|
|
|
|
|> Enum.uniq()
|
|
|
|
|> User.get_all_by_ap_id()
|
|
|
|
|> Enum.each(fn user ->
|
|
|
|
with false <- user.local,
|
|
|
|
false <- User.following?(follower, user),
|
|
|
|
false <- User.locked?(user),
|
|
|
|
false <- (user.bio || "") |> String.downcase() |> String.contains?("nobot") do
|
|
|
|
Logger.debug(
|
|
|
|
"#{__MODULE__}: Follow request from #{follower.nickname} to #{user.nickname}"
|
|
|
|
)
|
2021-02-19 13:55:05 -07:00
|
|
|
|
2021-02-19 17:36:35 -07:00
|
|
|
CommonAPI.follow(follower, user)
|
|
|
|
end
|
2020-10-08 10:55:35 -06:00
|
|
|
end)
|
|
|
|
|
|
|
|
{:ok, message}
|
|
|
|
end
|
|
|
|
|
|
|
|
@impl true
|
|
|
|
def describe do
|
|
|
|
{:ok, %{}}
|
|
|
|
end
|
|
|
|
end
|