Pleroma/lib/pleroma/web/twitter_api/views/user_view.ex

155 lines
4.9 KiB
Elixir
Raw Normal View History

# Pleroma: A lightweight social networking server
2018-12-31 16:41:47 +01:00
# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/>
# SPDX-License-Identifier: AGPL-3.0-only
2017-06-19 23:12:37 +02:00
defmodule Pleroma.Web.TwitterAPI.UserView do
use Pleroma.Web, :view
alias Pleroma.User
alias Pleroma.Formatter
alias Pleroma.Web.CommonAPI.Utils
2017-11-22 19:06:07 +01:00
alias Pleroma.Web.MediaProxy
alias Pleroma.HTML
2017-06-19 23:12:37 +02:00
def render("show.json", %{user: user = %User{}} = assigns) do
2017-07-20 20:29:15 +02:00
render_one(user, Pleroma.Web.TwitterAPI.UserView, "user.json", assigns)
end
def render("index.json", %{users: users, for: user}) do
users
|> render_many(Pleroma.Web.TwitterAPI.UserView, "user.json", for: user)
|> Enum.filter(&Enum.any?/1)
2017-07-20 20:29:15 +02:00
end
def render("user.json", %{user: user = %User{}} = assigns) do
if User.visible_for?(user, assigns[:for]),
do: do_render("user.json", assigns),
else: %{}
end
def render("short.json", %{
user: %User{
nickname: nickname,
id: id,
ap_id: ap_id,
name: name
}
}) do
%{
"fullname" => name,
"id" => id,
"ostatus_uri" => ap_id,
"profile_url" => ap_id,
"screen_name" => nickname
}
end
defp do_render("user.json", %{user: user = %User{}} = assigns) do
for_user = assigns[:for]
2017-11-22 19:06:07 +01:00
image = User.avatar_url(user) |> MediaProxy.url()
2018-03-30 15:01:53 +02:00
{following, follows_you, statusnet_blocking} =
if for_user do
2018-03-30 15:01:53 +02:00
{
User.following?(for_user, user),
User.following?(user, for_user),
User.blocks?(for_user, user)
2018-03-30 15:01:53 +02:00
}
else
{false, false, false}
end
user_info = User.get_cached_user_info(user)
2017-04-21 00:51:09 +02:00
emoji =
2018-11-18 22:36:47 +01:00
(user.info.source_data["tag"] || [])
|> Enum.filter(fn %{"type" => t} -> t == "Emoji" end)
|> Enum.map(fn %{"icon" => %{"url" => url}, "name" => name} ->
{String.trim(name, ":"), url}
end)
# ``fields`` is an array of mastodon profile field, containing ``{"name": "…", "value": "…"}``.
# For example: [{"name": "Pronoun", "value": "she/her"}, …]
fields =
2018-11-18 22:36:47 +01:00
(user.info.source_data["attachment"] || [])
|> Enum.filter(fn %{"type" => t} -> t == "PropertyValue" end)
|> Enum.map(fn fields -> Map.take(fields, ["name", "value"]) end)
2017-12-04 19:10:15 +01:00
data = %{
2018-03-30 15:01:53 +02:00
"created_at" => user.inserted_at |> Utils.format_naive_asctime(),
2018-09-10 02:28:40 +02:00
"description" => HTML.strip_tags((user.bio || "") |> String.replace("<br>", "\n")),
"description_html" => HTML.filter_tags(user.bio, User.html_filter_policy(for_user)),
2017-03-20 21:30:18 +01:00
"favourites_count" => 0,
2017-04-21 00:51:09 +02:00
"followers_count" => user_info[:follower_count],
2017-06-19 23:12:37 +02:00
"following" => following,
2017-11-08 18:13:03 +01:00
"follows_you" => follows_you,
2017-11-08 12:02:00 +01:00
"statusnet_blocking" => statusnet_blocking,
2017-06-19 23:12:37 +02:00
"friends_count" => user_info[:following_count],
"id" => user.id,
"name" => user.name || user.nickname,
"name_html" =>
if(user.name,
do: HTML.strip_tags(user.name) |> Formatter.emojify(emoji),
else: user.nickname
),
2017-03-20 21:30:18 +01:00
"profile_image_url" => image,
"profile_image_url_https" => image,
"profile_image_url_profile_size" => image,
"profile_image_url_original" => image,
2018-02-20 18:44:50 +01:00
"rights" => %{
"delete_others_notice" => !!user.info.is_moderator,
"admin" => !!user.info.is_admin
2018-02-20 18:44:50 +01:00
},
2017-06-19 23:12:37 +02:00
"screen_name" => user.nickname,
"statuses_count" => user_info[:note_count],
2017-08-29 17:18:33 +02:00
"statusnet_profile_url" => user.ap_id,
"cover_photo" => User.banner_url(user) |> MediaProxy.url(),
2018-11-18 22:36:47 +01:00
"background_image" => image_url(user.info.background) |> MediaProxy.url(),
"is_local" => user.local,
2018-11-18 22:36:47 +01:00
"locked" => user.info.locked,
"default_scope" => user.info.default_scope,
"no_rich_text" => user.info.no_rich_text,
"hide_followers" => user.info.hide_followers,
"hide_follows" => user.info.hide_follows,
"fields" => fields,
2018-12-06 18:23:16 +01:00
# Pleroma extension
"pleroma" => %{
"confirmation_pending" => user_info.confirmation_pending,
"tags" => user.tags
}
2017-03-20 21:30:18 +01:00
}
2017-12-04 19:10:15 +01:00
data =
if(user.info.is_admin || user.info.is_moderator,
do: maybe_with_role(data, user, for_user),
else: data
)
2017-12-04 19:10:15 +01:00
if assigns[:token] do
Map.put(data, "token", token_string(assigns[:token]))
2017-12-04 19:10:15 +01:00
else
data
end
2017-06-19 23:12:37 +02:00
end
2017-03-20 21:30:18 +01:00
defp maybe_with_role(data, %User{id: id} = user, %User{id: id}) do
Map.merge(data, %{"role" => role(user), "show_role" => user.info.show_role})
end
defp maybe_with_role(data, %User{info: %{show_role: true}} = user, _user) do
Map.merge(data, %{"role" => role(user)})
end
defp maybe_with_role(data, _, _), do: data
defp role(%User{info: %{:is_admin => true}}), do: "admin"
defp role(%User{info: %{:is_moderator => true}}), do: "moderator"
defp role(_), do: "member"
2018-03-30 15:01:53 +02:00
defp image_url(%{"url" => [%{"href" => href} | _]}), do: href
2017-11-19 02:22:07 +01:00
defp image_url(_), do: nil
defp token_string(%Pleroma.Web.OAuth.Token{token: token_str}), do: token_str
defp token_string(token), do: token
2017-03-20 21:30:18 +01:00
end