X-Git-Url: http://git.squeep.com/?a=blobdiff_plain;f=lib%2Fpleroma%2Fweb%2Fcommon_api%2Futils.ex;h=1a23b1ad2abb9855ecccadf4c9978827cd552ead;hb=1625021a9cd01127171709324f165899a52acfe5;hp=0d8b39d70022548f1dae5e768b0265397deb38e2;hpb=50409326a853db7bd9f538f0ddbec805c134920f;p=akkoma
diff --git a/lib/pleroma/web/common_api/utils.ex b/lib/pleroma/web/common_api/utils.ex
index 0d8b39d70..1a23b1ad2 100644
--- a/lib/pleroma/web/common_api/utils.ex
+++ b/lib/pleroma/web/common_api/utils.ex
@@ -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
"#{shortname(name)}"
_ -> ""
end)
- Enum.join([text | attachment_text], "
\n")
+ Enum.join([text | attachment_text], "
")
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", "
\n")
+ |> String.replace("\n", "
")
|> 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 = "##{tag}"
+ 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