diff --git a/lib/pleroma/web/ostatus/handlers/note_handler.ex b/lib/pleroma/web/ostatus/handlers/note_handler.ex index 0b06f8f02..dda5c7d5e 100644 --- a/lib/pleroma/web/ostatus/handlers/note_handler.ex +++ b/lib/pleroma/web/ostatus/handlers/note_handler.ex @@ -52,6 +52,17 @@ def get_mentions(entry) do |> Enum.filter(&(&1)) end + def get_emoji(entry) do + try do + :xmerl_xpath.string('//link[@rel="emoji"]', entry) + |> Enum.reduce(%{}, fn(emoji, acc) -> + Map.put(acc, XML.string_from_xpath("@name", emoji), XML.string_from_xpath("@href", emoji)) + end) + rescue + _e -> nil + end + end + def make_to_list(actor, mentions) do [ actor.follower_address @@ -95,6 +106,7 @@ def handle_note(entry, doc \\ nil) do note <- CommonAPI.Utils.make_note_data(actor.ap_id, to, context, content_html, attachments, inReplyToActivity, []), note <- note |> Map.put("id", id) |> Map.put("tag", tags), note <- note |> Map.put("published", date), + note <- note |> Map.put("emoji", get_emoji(entry)), note <- add_external_url(note, entry), # TODO: Handle this case in make_note_data note <- (if inReplyTo && !inReplyToActivity, do: note |> Map.put("inReplyTo", inReplyTo), else: note) diff --git a/test/fixtures/incoming_note_activity.xml b/test/fixtures/incoming_note_activity.xml index e54b25e39..21eda2d30 100644 --- a/test/fixtures/incoming_note_activity.xml +++ b/test/fixtures/incoming_note_activity.xml @@ -4,6 +4,8 @@