diff options
author | Alex Gleason <alex@alexgleason.me> | 2022-01-30 10:57:29 -0600 |
---|---|---|
committer | Alex Gleason <alex@alexgleason.me> | 2022-01-30 10:57:29 -0600 |
commit | 643f78cb220abb9873cdf8d1d3b30678ea4daccc (patch) | |
tree | 03620524e877a146917ff7b13cd5d7ad54e1e04c /lib | |
parent | deff42f0345c5e456b8ca0c6fd341aa3d553bd6c (diff) | |
download | pleroma-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.ex | 13 |
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]) |