aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorAlex Gleason <alex@alexgleason.me>2022-01-30 10:57:29 -0600
committerAlex Gleason <alex@alexgleason.me>2022-01-30 10:57:29 -0600
commit643f78cb220abb9873cdf8d1d3b30678ea4daccc (patch)
tree03620524e877a146917ff7b13cd5d7ad54e1e04c /lib
parentdeff42f0345c5e456b8ca0c6fd341aa3d553bd6c (diff)
downloadpleroma-643f78cb220abb9873cdf8d1d3b30678ea4daccc.tar.gz
InlineQuotePolicy: skip objects which already have an .inline-quote span
Diffstat (limited to 'lib')
-rw-r--r--lib/pleroma/web/activity_pub/mrf/inline_quote_policy.ex13
1 files changed, 12 insertions, 1 deletions
diff --git a/lib/pleroma/web/activity_pub/mrf/inline_quote_policy.ex b/lib/pleroma/web/activity_pub/mrf/inline_quote_policy.ex
index 7de4935f2..c78675caf 100644
--- a/lib/pleroma/web/activity_pub/mrf/inline_quote_policy.ex
+++ b/lib/pleroma/web/activity_pub/mrf/inline_quote_policy.ex
@@ -10,10 +10,21 @@ defmodule Pleroma.Web.ActivityPub.MRF.InlineQuotePolicy do
"<span class=\"quote-inline\"><br/><br/>#{prefix}: <a href=\"#{url}\">#{url}</a></span>"
end
+ defp has_inline_quote?(content, quote_url) do
+ cond do
+ # Does the quote URL exist in the content?
+ content =~ quote_url -> true
+ # Does the content already have a .quote-inline span?
+ content =~ "<span class=\"quote-inline\">" -> true
+ # No inline quote found
+ true -> false
+ end
+ end
+
defp filter_object(%{"quoteUrl" => quote_url} = object) do
content = object["content"] || ""
- if content =~ quote_url do
+ if has_inline_quote?(content, quote_url) do
object
else
prefix = Pleroma.Config.get([:mrf_inline_quote, :prefix])