Remove tags/mentions/rich text from poll options because Mastodon and

add custom emoji
This commit is contained in:
rinpatch 2019-05-19 17:06:44 +03:00
parent 5ece901af3
commit 1d90f9b969
3 changed files with 15 additions and 28 deletions

View file

@ -154,7 +154,7 @@ def post(user, %{"status" => status} = data) do
data,
visibility
),
{poll, mentions, tags} <- make_poll_data(data, mentions, tags),
{poll, poll_emoji} <- make_poll_data(data),
{to, cc} <- to_for_user_and_mentions(user, mentions, in_reply_to, visibility),
context <- make_context(in_reply_to),
cw <- data["spoiler_text"] || "",
@ -179,7 +179,7 @@ def post(user, %{"status" => status} = data) do
Map.put(
object,
"emoji",
Formatter.get_emoji_map(full_payload)
Map.merge(Formatter.get_emoji_map(full_payload), poll_emoji)
) do
res =
ActivityPub.create(

View file

@ -102,26 +102,15 @@ def to_for_user_and_mentions(_user, mentions, inReplyTo, "direct") do
end
end
def make_poll_data(
%{"poll" => %{"options" => options, "expires_in" => expires_in}} = data,
mentions,
tags
)
def make_poll_data(%{"poll" => %{"options" => options, "expires_in" => expires_in}} = data)
when is_list(options) and is_integer(expires_in) do
content_type = get_content_type(data["content_type"])
# XXX: There is probably a more performant/cleaner way to do this
{poll, {mentions, tags}} =
Enum.map_reduce(options, {mentions, tags}, fn option, {mentions, tags} ->
# TODO: Custom emoji
{option, mentions_merge, tags_merge} = format_input(option, content_type)
mentions = mentions ++ mentions_merge
tags = tags ++ tags_merge
{poll, emoji} =
Enum.map_reduce(options, %{}, fn option, emoji ->
{%{
"name" => option,
"type" => "Note",
"replies" => %{"type" => "Collection", "totalItems" => 0}
}, {mentions, tags}}
}, Map.merge(emoji, Formatter.get_emoji_map(option))}
end)
end_time =
@ -136,11 +125,11 @@ def make_poll_data(
%{"type" => "Question", "oneOf" => poll, "closed" => end_time}
end
{poll, mentions, tags}
{poll, emoji}
end
def make_poll_data(_data, mentions, tags) do
{%{}, mentions, tags}
def make_poll_data(_data) do
{%{}, %{}}
end
def make_content_html(

View file

@ -325,7 +325,7 @@ def render("attachment.json", %{attachment: attachment}) do
end
# TODO: Add tests for this view
def render("poll.json", %{object: object} = opts) do
def render("poll.json", %{object: object} = _opts) do
{multiple, options} =
case object.data do
%{"anyOf" => options} when is_list(options) -> {true, options}
@ -350,13 +350,10 @@ def render("poll.json", %{object: object} = opts) do
options =
Enum.map(options, fn %{"name" => name} = option ->
name =
HTML.filter_tags(
name,
User.html_filter_policy(opts[:for])
)
%{title: name, votes_count: option["replies"]["votes_count"] || 0}
%{
title: HTML.strip_tags(name),
votes_count: option["replies"]["votes_count"] || 0
}
end)
%{
@ -367,6 +364,7 @@ def render("poll.json", %{object: object} = opts) do
multiple: multiple,
votes_count: votes_count,
options: options,
# TODO: Actually check for a vote
voted: false,
emojis: build_emojis(object.data["emoji"])
}