diff options
author | Haelwenn <contact+git.pleroma.social@hacktivis.me> | 2023-03-16 07:53:27 +0000 |
---|---|---|
committer | Haelwenn <contact+git.pleroma.social@hacktivis.me> | 2023-03-16 07:53:27 +0000 |
commit | c3600b6104a5ec0dc1cc5674758df6b7f4aee881 (patch) | |
tree | e83f4989b40d291bd6247f4ae8d2e708a29f0b1d /lib | |
parent | 9145fd04f23460465731011ee745588f4e93b2f0 (diff) | |
parent | 83c7415803774a4c56c718f5ebed2b9714ffdfcf (diff) | |
download | pleroma-c3600b6104a5ec0dc1cc5674758df6b7f4aee881.tar.gz pleroma-c3600b6104a5ec0dc1cc5674758df6b7f4aee881.zip |
Merge branch 'feat/fields-rel-me-tag' into 'develop'
feat: build rel me tags with profile fields
See merge request pleroma/pleroma!3850
Diffstat (limited to 'lib')
-rw-r--r-- | lib/pleroma/web/metadata/providers/rel_me.ex | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/lib/pleroma/web/metadata/providers/rel_me.ex b/lib/pleroma/web/metadata/providers/rel_me.ex index f0bee85c8..eabd8cb00 100644 --- a/lib/pleroma/web/metadata/providers/rel_me.ex +++ b/lib/pleroma/web/metadata/providers/rel_me.ex @@ -8,12 +8,20 @@ defmodule Pleroma.Web.Metadata.Providers.RelMe do @impl Provider def build_tags(%{user: user}) do - bio_tree = Floki.parse_fragment!(user.bio) + profile_tree = + user.bio + |> append_fields_tag(user.fields) + |> Floki.parse_fragment!() - (Floki.attribute(bio_tree, "link[rel~=me]", "href") ++ - Floki.attribute(bio_tree, "a[rel~=me]", "href")) + (Floki.attribute(profile_tree, "link[rel~=me]", "href") ++ + Floki.attribute(profile_tree, "a[rel~=me]", "href")) |> Enum.map(fn link -> {:link, [rel: "me", href: link], []} end) end + + defp append_fields_tag(bio, fields) do + fields + |> Enum.reduce(bio, fn %{"value" => v}, res -> res <> v end) + end end |