diff options
author | Mark Felder <feld@FreeBSD.org> | 2019-06-12 17:56:51 -0500 |
---|---|---|
committer | Mark Felder <feld@FreeBSD.org> | 2019-06-12 17:56:51 -0500 |
commit | 097fdf6a5d1ecd373c911bda4a1d7ee3c873fa21 (patch) | |
tree | 92c1b53d3a4436e21b4264c9ba50396f11e44ea2 | |
parent | 822a9f28d08af9da69a8e0f72cc6511252f25ddd (diff) | |
download | pleroma-097fdf6a5d1ecd373c911bda4a1d7ee3c873fa21.tar.gz |
Attempt to use <title> from HTML as a fallback
-rw-r--r-- | lib/pleroma/web/rich_media/parsers/meta_tags_parser.ex | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/lib/pleroma/web/rich_media/parsers/meta_tags_parser.ex b/lib/pleroma/web/rich_media/parsers/meta_tags_parser.ex index 4a7c5eae0..7da4e7561 100644 --- a/lib/pleroma/web/rich_media/parsers/meta_tags_parser.ex +++ b/lib/pleroma/web/rich_media/parsers/meta_tags_parser.ex @@ -1,12 +1,14 @@ defmodule Pleroma.Web.RichMedia.Parsers.MetaTagsParser do def parse(html, data, prefix, error_message, key_name, value_name \\ "content") do with elements = [_ | _] <- get_elements(html, key_name, prefix), + page_title = get_page_title(html), meta_data = Enum.reduce(elements, data, fn el, acc -> attributes = normalize_attributes(el, prefix, key_name, value_name) Map.merge(acc, attributes) - end) do + end) + |> Map.put_new(:title, page_title) do {:ok, meta_data} else _e -> {:error, error_message} @@ -27,4 +29,8 @@ defmodule Pleroma.Web.RichMedia.Parsers.MetaTagsParser do %{String.to_atom(data[key_name]) => data[value_name]} end + + defp get_page_title(html) do + Floki.find(html, "title") |> Floki.text() + end end |