diff options
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/pleroma/web/common_api/utils.ex | 100 | ||||
| -rw-r--r-- | lib/pleroma/web/rich_media/parsers/twitter_card.ex | 21 | 
2 files changed, 72 insertions, 49 deletions
| diff --git a/lib/pleroma/web/common_api/utils.ex b/lib/pleroma/web/common_api/utils.ex index c8a743e8e..22c44a0a3 100644 --- a/lib/pleroma/web/common_api/utils.ex +++ b/lib/pleroma/web/common_api/utils.ex @@ -47,26 +47,43 @@ defmodule Pleroma.Web.CommonAPI.Utils do    def get_replied_to_activity(_), do: nil -  def attachments_from_ids(data) do -    if Map.has_key?(data, "descriptions") do -      attachments_from_ids_descs(data["media_ids"], data["descriptions"]) -    else -      attachments_from_ids_no_descs(data["media_ids"]) -    end +  def attachments_from_ids(%{"media_ids" => ids, "descriptions" => desc} = _) do +    attachments_from_ids_descs(ids, desc) +  end + +  def attachments_from_ids(%{"media_ids" => ids} = _) do +    attachments_from_ids_no_descs(ids)    end +  def attachments_from_ids(_), do: [] + +  def attachments_from_ids_no_descs([]), do: [] +    def attachments_from_ids_no_descs(ids) do -    Enum.map(ids || [], fn media_id -> -      Repo.get(Object, media_id).data +    Enum.map(ids, fn media_id -> +      case Repo.get(Object, media_id) do +        %Object{data: data} = _ -> data +        _ -> nil +      end      end) +    |> Enum.filter(& &1)    end +  def attachments_from_ids_descs([], _), do: [] +    def attachments_from_ids_descs(ids, descs_str) do      {_, descs} = Jason.decode(descs_str) -    Enum.map(ids || [], fn media_id -> -      Map.put(Repo.get(Object, media_id).data, "name", descs[media_id]) +    Enum.map(ids, fn media_id -> +      case Repo.get(Object, media_id) do +        %Object{data: data} = _ -> +          Map.put(data, "name", descs[media_id]) + +        _ -> +          nil +      end      end) +    |> Enum.filter(& &1)    end    @spec get_to_and_cc(User.t(), list(String.t()), Activity.t() | nil, String.t()) :: @@ -247,20 +264,18 @@ defmodule Pleroma.Web.CommonAPI.Utils do    end    def add_attachments(text, attachments) do -    attachment_text = -      Enum.map(attachments, fn -        %{"url" => [%{"href" => href} | _]} = attachment -> -          name = attachment["name"] || URI.decode(Path.basename(href)) -          href = MediaProxy.url(href) -          "<a href=\"#{href}\" class='attachment'>#{shortname(name)}</a>" - -        _ -> -          "" -      end) - +    attachment_text = Enum.map(attachments, &build_attachment_link/1)      Enum.join([text | attachment_text], "<br>")    end +  defp build_attachment_link(%{"url" => [%{"href" => href} | _]} = attachment) do +    name = attachment["name"] || URI.decode(Path.basename(href)) +    href = MediaProxy.url(href) +    "<a href=\"#{href}\" class='attachment'>#{shortname(name)}</a>" +  end + +  defp build_attachment_link(_), do: "" +    def format_input(text, format, options \\ [])    @doc """ @@ -320,7 +335,7 @@ defmodule Pleroma.Web.CommonAPI.Utils do          sensitive \\ false,          merge \\ %{}        ) do -    object = %{ +    %{        "type" => "Note",        "to" => to,        "cc" => cc, @@ -330,18 +345,20 @@ defmodule Pleroma.Web.CommonAPI.Utils do        "context" => context,        "attachment" => attachments,        "actor" => actor, -      "tag" => tags |> Enum.map(fn {_, tag} -> tag end) |> Enum.uniq() +      "tag" => Keyword.values(tags) |> Enum.uniq()      } +    |> add_in_reply_to(in_reply_to) +    |> Map.merge(merge) +  end -    object = -      with false <- is_nil(in_reply_to), -           %Object{} = in_reply_to_object <- Object.normalize(in_reply_to) do -        Map.put(object, "inReplyTo", in_reply_to_object.data["id"]) -      else -        _ -> object -      end +  defp add_in_reply_to(object, nil), do: object -    Map.merge(object, merge) +  defp add_in_reply_to(object, in_reply_to) do +    with %Object{} = in_reply_to_object <- Object.normalize(in_reply_to) do +      Map.put(object, "inReplyTo", in_reply_to_object.data["id"]) +    else +      _ -> object +    end    end    def format_naive_asctime(date) do @@ -373,17 +390,16 @@ defmodule Pleroma.Web.CommonAPI.Utils do      |> String.replace(~r/(\.\d+)?$/, ".000Z", global: false)    end -  def to_masto_date(date) do -    try do -      date -      |> NaiveDateTime.from_iso8601!() -      |> NaiveDateTime.to_iso8601() -      |> String.replace(~r/(\.\d+)?$/, ".000Z", global: false) -    rescue -      _e -> "" +  def to_masto_date(date) when is_binary(date) do +    with {:ok, date} <- NaiveDateTime.from_iso8601(date) do +      to_masto_date(date) +    else +      _ -> ""      end    end +  def to_masto_date(_), do: "" +    defp shortname(name) do      if String.length(name) < 30 do        name @@ -428,7 +444,7 @@ defmodule Pleroma.Web.CommonAPI.Utils do      object_data =        cond do -        !is_nil(object) -> +        not is_nil(object) ->            object.data          is_map(data["object"]) -> @@ -472,9 +488,9 @@ defmodule Pleroma.Web.CommonAPI.Utils do    def maybe_extract_mentions(%{"tag" => tag}) do      tag -    |> Enum.filter(fn x -> is_map(x) end) -    |> Enum.filter(fn x -> x["type"] == "Mention" end) +    |> Enum.filter(fn x -> is_map(x) && x["type"] == "Mention" end)      |> Enum.map(fn x -> x["href"] end) +    |> Enum.uniq()    end    def maybe_extract_mentions(_), do: [] diff --git a/lib/pleroma/web/rich_media/parsers/twitter_card.ex b/lib/pleroma/web/rich_media/parsers/twitter_card.ex index e4efe2dd0..afaa98f3d 100644 --- a/lib/pleroma/web/rich_media/parsers/twitter_card.ex +++ b/lib/pleroma/web/rich_media/parsers/twitter_card.ex @@ -3,13 +3,20 @@  # SPDX-License-Identifier: AGPL-3.0-only  defmodule Pleroma.Web.RichMedia.Parsers.TwitterCard do +  alias Pleroma.Web.RichMedia.Parsers.MetaTagsParser + +  @spec parse(String.t(), map()) :: {:ok, map()} | {:error, String.t()}    def parse(html, data) do -    Pleroma.Web.RichMedia.Parsers.MetaTagsParser.parse( -      html, -      data, -      "twitter", -      "No twitter card metadata found", -      "name" -    ) +    data +    |> parse_name_attrs(html) +    |> parse_property_attrs(html) +  end + +  defp parse_name_attrs(data, html) do +    MetaTagsParser.parse(html, data, "twitter", %{}, "name") +  end + +  defp parse_property_attrs({_, data}, html) do +    MetaTagsParser.parse(html, data, "twitter", "No twitter card metadata found", "property")    end  end | 
