Merge branch 'fix/self-follow' into 'develop'
[akkoma] / lib / pleroma / web / common_api / utils.ex
index 0d8b39d70022548f1dae5e768b0265397deb38e2..1a23b1ad2abb9855ecccadf4c9978827cd552ead 100644 (file)
@@ -38,9 +38,9 @@ defmodule Pleroma.Web.CommonAPI.Utils do
     end
   end
 
-  def make_content_html(status, mentions, attachments) do
+  def make_content_html(status, mentions, attachments, tags) do
     status
-    |> format_input(mentions)
+    |> format_input(mentions, tags)
     |> add_attachments(attachments)
   end
 
@@ -54,14 +54,26 @@ defmodule Pleroma.Web.CommonAPI.Utils do
         "<a href=\"#{href}\" class='attachment'>#{shortname(name)}</a>"
       _ -> ""
     end)
-    Enum.join([text | attachment_text], "<br>\n")
+    Enum.join([text | attachment_text], "<br>")
   end
 
-  def format_input(text, mentions) do
-    HtmlSanitizeEx.strip_tags(text)
+  def format_input(text, mentions, _tags) do
+    Phoenix.HTML.html_escape(text)
+    |> elem(1)
     |> Formatter.linkify
-    |> String.replace("\n", "<br>\n")
+    |> String.replace("\n", "<br>")
     |> add_user_links(mentions)
+    # |> add_tag_links(tags)
+  end
+
+  def add_tag_links(text, tags) do
+    tags = tags
+    |> Enum.sort_by(fn ({tag, _}) -> -String.length(tag) end)
+
+    Enum.reduce(tags, text, fn({full, tag}, text) ->
+      url = "#<a href='#{Pleroma.Web.base_url}/tag/#{tag}' rel='tag'>#{tag}</a>"
+      String.replace(text, full, url)
+    end)
   end
 
   def add_user_links(text, mentions) do
@@ -83,11 +95,12 @@ defmodule Pleroma.Web.CommonAPI.Utils do
     end)
   end
 
-  def make_note_data(actor, to, context, content_html, attachments, inReplyTo, tags) do
+  def make_note_data(actor, to, context, content_html, attachments, inReplyTo, tags, cw \\ nil) do
       object = %{
         "type" => "Note",
         "to" => to,
         "content" => content_html,
+        "summary" => cw,
         "context" => context,
         "attachment" => attachments,
         "actor" => actor,
@@ -119,6 +132,23 @@ defmodule Pleroma.Web.CommonAPI.Utils do
     end
   end
 
+  def to_masto_date(%NaiveDateTime{} = date) do
+    date
+    |> NaiveDateTime.to_iso8601
+    |> 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 -> ""
+    end
+  end
+
   defp shortname(name) do
     if String.length(name) < 30 do
       name