1 defmodule Pleroma.Web.RichMedia.Parsers.MetaTagsParser do
2 def parse(html, data, prefix, error_message, key_name, value_name \\ "content") do
3 with elements = [_ | _] <- get_elements(html, key_name, prefix),
4 page_title = get_page_title(html),
6 Enum.reduce(elements, data, fn el, acc ->
7 attributes = normalize_attributes(el, prefix, key_name, value_name)
9 Map.merge(acc, attributes)
11 |> Map.put_new(:title, page_title) do
14 _e -> {:error, error_message}
18 defp get_elements(html, key_name, prefix) do
19 html |> Floki.find("meta[#{key_name}^='#{prefix}:']")
22 defp normalize_attributes(html_node, prefix, key_name, value_name) do
23 {_tag, attributes, _children} = html_node
26 Enum.into(attributes, %{}, fn {name, value} ->
27 {name, String.trim_leading(value, "#{prefix}:")}
30 %{String.to_atom(data[key_name]) => data[value_name]}
33 defp get_page_title(html) do
34 Floki.find(html, "title") |> Floki.text()