Merge remote-tracking branch 'upstream/develop' into patch-image-description
authorWim Vanderbauwhede <wim.vanderbauwhede@mail.be>
Thu, 14 Feb 2019 16:41:40 +0000 (16:41 +0000)
committerWim Vanderbauwhede <wim.vanderbauwhede@mail.be>
Thu, 14 Feb 2019 16:41:40 +0000 (16:41 +0000)
lib/pleroma/web/common_api/common_api.ex
lib/pleroma/web/common_api/utils.ex

index 86f249c54fb0fe620f2d48d8f25b414b7ba02477..90b208e540107bb19e5e5a0ccd757d418cc45aa0 100644 (file)
@@ -95,7 +95,7 @@ defmodule Pleroma.Web.CommonAPI do
     limit = Pleroma.Config.get([:instance, :limit])
 
     with status <- String.trim(status),
-         attachments <- attachments_from_ids(data["media_ids"]),
+         attachments <- attachments_from_ids(data),
          mentions <- Formatter.parse_mentions(status),
          inReplyTo <- get_replied_to_activity(data["in_reply_to_status_id"]),
          {to, cc} <- to_for_user_and_mentions(user, mentions, inReplyTo, visibility),
index 123107b56441a216c8589f29dcd10ce3978d855f..abdeee947516214e472e2daa70361c2789d7131d 100644 (file)
@@ -35,12 +35,28 @@ defmodule Pleroma.Web.CommonAPI.Utils do
 
   def get_replied_to_activity(_), do: nil
 
-  def attachments_from_ids(ids) do
+  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
+  end
+
+  def attachments_from_ids_no_descs(ids) do
     Enum.map(ids || [], fn media_id ->
       Repo.get(Object, media_id).data
     end)
   end
 
+  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])
+    end)
+  end
+
   def to_for_user_and_mentions(user, mentions, inReplyTo, "public") do
     mentioned_users = Enum.map(mentions, fn {_, %{ap_id: ap_id}} -> ap_id end)