Remove unneeded code

Signed-off-by: marcin mikołajczak <git@mkljczk.pl>
This commit is contained in:
marcin mikołajczak 2024-03-14 22:50:10 +01:00
parent 0f33698747
commit 612e6284b4
4 changed files with 0 additions and 194 deletions

View file

@ -1,95 +0,0 @@
# 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.BlockNotificationPolicy do
@moduledoc "Notify local users upon remote block and unblock."
@behaviour Pleroma.Web.ActivityPub.MRF.Policy
alias Pleroma.Config
alias Pleroma.User
alias Pleroma.Web.CommonAPI
defp is_block_or_unblock(%{"type" => "Block", "object" => object}),
do: {true, "blocked", object}
defp is_block_or_unblock(%{
"type" => "Undo",
"object" => %{"type" => "Block", "object" => object}
}),
do: {true, "unblocked", object}
defp is_block_or_unblock(_), do: {false, nil, nil}
@impl true
def filter(message) do
with {true, action, object} <- is_block_or_unblock(message),
%User{} = actor <- User.get_cached_by_ap_id(message["actor"]),
true <- actor.is_active,
%User{} = recipient <- User.get_cached_by_ap_id(object) do
bot_user = Pleroma.Config.get([:mrf_block_notification_policy, :user])
replacements = %{
"actor" => actor.nickname,
"target" => recipient.nickname,
"action" => action
}
msg =
Regex.replace(
~r/{([a-z]+)?}/,
Pleroma.Config.get([:mrf_block_notification_policy, :message]),
fn _, match ->
replacements[match]
end
)
_reply =
CommonAPI.post(User.get_by_nickname(bot_user), %{
status: msg,
visibility: Pleroma.Config.get([:mrf_block_notification_policy, :visibility])
})
end
{:ok, message}
end
@impl true
def describe do
mrf_block_notification_policy = Config.get(:mrf_block_notification_policy)
{:ok, %{mrf_block_notification_policy: mrf_block_notification_policy}}
end
@impl true
def config_description do
%{
key: :mrf_block_notification_policy,
related_policy: "Pleroma.Web.ActivityPub.MRF.BlockNotificationPolicy",
description: "Notify local users upon remote block.",
children: [
%{
key: :message,
type: :string,
label: "Message",
description:
"The message to send when someone is blocked or unblocked; use {actor}, {target}, and {action} variables",
suggestions: ["@{actor} {action} @{target}"]
},
%{
key: :user,
type: :string,
label: "Block User",
description: "The user account that announces a block"
},
%{
key: :visibility,
type: :string,
label: "Visibility",
description: "The visibility of block messages",
suggestions: ["public", "unlisted", "private", "direct"]
}
]
}
end
end

View file

@ -173,9 +173,7 @@ defp validate_page_url(page_url) when is_binary(page_url) do
validate_tld = @config_impl.get([Pleroma.Formatter, :validate_tld])
page_url
|> IO.inspect()
|> Linkify.Parser.url?(validate_tld: validate_tld)
|> IO.inspect()
|> parse_uri(page_url)
end
@ -200,7 +198,6 @@ defp validate_page_url(_), do: :error
defp parse_uri(true, url) do
url
|> URI.parse()
|> IO.inspect()
|> validate_page_url
end

View file

@ -1,95 +0,0 @@
# 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.BlockNotificationPolicyTest do
use Pleroma.DataCase, async: true
alias Pleroma.Web.ActivityPub.ActivityPub
alias Pleroma.Web.ActivityPub.MRF.BlockNotificationPolicy
import Pleroma.Factory
setup do:
clear_config(:mrf_block_notification_policy,
message: "@{actor} {action} @{target}",
user: "beholder",
visibility: "public"
)
setup do
%{
beholder: insert(:user, nickname: "beholder"),
butthurt: insert(:user, nickname: "butthurt"),
sneed: insert(:user, nickname: "sneed")
}
end
test "creates messages when user blocks other user", %{
butthurt: butthurt,
sneed: sneed,
beholder: beholder
} do
activities = ActivityPub.fetch_user_activities(beholder, beholder, %{})
assert length(activities) == 0
message = %{
"type" => "Block",
"object" => sneed.ap_id,
"actor" => butthurt.ap_id
}
assert {:ok, _object} = BlockNotificationPolicy.filter(message)
activities = ActivityPub.fetch_user_activities(beholder, beholder, %{})
assert length(activities) == 1
[head | _tail] = activities
assert head.object.data["source"]["content"] == "@butthurt blocked @sneed"
end
test "creates messages when user unblocks other user", %{
butthurt: butthurt,
sneed: sneed,
beholder: beholder
} do
activities = ActivityPub.fetch_user_activities(beholder, beholder, %{})
assert length(activities) == 0
message = %{
"type" => "Undo",
"object" => %{"type" => "Block", "object" => sneed.ap_id},
"actor" => butthurt.ap_id
}
assert {:ok, _object} = BlockNotificationPolicy.filter(message)
activities = ActivityPub.fetch_user_activities(beholder, beholder, %{})
assert length(activities) == 1
[head | _tail] = activities
assert head.object.data["source"]["content"] == "@butthurt unblocked @sneed"
end
test "creates no message when the action type isn't block or unblock", %{
butthurt: butthurt,
sneed: sneed,
beholder: beholder
} do
activities = ActivityPub.fetch_user_activities(beholder, beholder, %{})
assert length(activities) == 0
message = %{
"type" => "Note",
"object" => sneed.ap_id,
"actor" => butthurt.ap_id
}
assert {:ok, _object} = BlockNotificationPolicy.filter(message)
activities = ActivityPub.fetch_user_activities(beholder, beholder, %{})
assert length(activities) == 0
end
end

View file

@ -1235,7 +1235,6 @@ test "registers and logs in without :account_activation_required / :account_appr
assert user
assert user.is_confirmed
assert user.is_approved
refute user.accepts_
end
test "registers but does not log in with :account_activation_required", %{conn: conn} do