akkoma/lib/pleroma/web/mastodon_api/views/account_view.ex

118 lines
3.4 KiB
Elixir
Raw Normal View History

# Pleroma: A lightweight social networking server
# Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/>
# SPDX-License-Identifier: AGPL-3.0-only
2017-09-07 00:58:10 -06:00
defmodule Pleroma.Web.MastodonAPI.AccountView do
use Pleroma.Web, :view
alias Pleroma.User
2017-09-13 07:55:10 -06:00
alias Pleroma.Web.MastodonAPI.AccountView
2017-09-15 09:50:47 -06:00
alias Pleroma.Web.CommonAPI.Utils
2017-11-22 11:06:07 -07:00
alias Pleroma.Web.MediaProxy
alias Pleroma.HTML
2017-09-07 00:58:10 -06:00
def render("accounts.json", %{users: users} = opts) do
render_many(users, AccountView, "account.json", opts)
end
def render("account.json", %{user: user} = opts) do
2017-11-22 11:06:07 -07:00
image = User.avatar_url(user) |> MediaProxy.url()
header = User.banner_url(user) |> MediaProxy.url()
2017-09-07 00:58:10 -06:00
user_info = User.user_info(user)
2018-11-20 12:12:39 -07:00
bot = (user.info.source_data["type"] || "Person") in ["Application", "Service"]
2017-09-07 00:58:10 -06:00
emojis =
2018-11-20 12:12:39 -07:00
(user.info.source_data["tag"] || [])
|> Enum.filter(fn %{"type" => t} -> t == "Emoji" end)
|> Enum.map(fn %{"icon" => %{"url" => url}, "name" => name} ->
%{
"shortcode" => String.trim(name, ":"),
"url" => MediaProxy.url(url),
"static_url" => MediaProxy.url(url),
"visible_in_picker" => false
}
end)
fields =
2018-11-20 12:12:39 -07:00
(user.info.source_data["attachment"] || [])
|> Enum.filter(fn %{"type" => t} -> t == "PropertyValue" end)
|> Enum.map(fn fields -> Map.take(fields, ["name", "value"]) end)
bio = HTML.filter_tags(user.bio, User.html_filter_policy(opts[:for]))
2017-09-07 00:58:10 -06:00
%{
2017-11-10 09:18:19 -07:00
id: to_string(user.id),
username: username_from_nickname(user.nickname),
2017-09-07 00:58:10 -06:00
acct: user.nickname,
display_name: user.name || user.nickname,
locked: user_info.locked,
2017-09-15 09:50:47 -06:00
created_at: Utils.to_masto_date(user.inserted_at),
2017-09-07 00:58:10 -06:00
followers_count: user_info.follower_count,
following_count: user_info.following_count,
statuses_count: user_info.note_count,
note: bio || "",
2017-09-07 00:58:10 -06:00
url: user.ap_id,
avatar: image,
avatar_static: image,
2017-09-10 02:37:34 -06:00
header: header,
header_static: header,
emojis: emojis,
fields: fields,
bot: bot,
source: %{
note: "",
privacy: user_info.default_scope,
sensitive: false
},
2018-12-06 10:23:16 -07:00
# Pleroma extension
pleroma: %{
confirmation_pending: user_info.confirmation_pending,
tags: user.tags
}
2017-09-07 00:58:10 -06:00
}
end
def render("mention.json", %{user: user}) do
%{
2017-11-10 09:18:19 -07:00
id: to_string(user.id),
acct: user.nickname,
username: username_from_nickname(user.nickname),
url: user.ap_id
}
end
2017-09-13 07:55:10 -06:00
def render("relationship.json", %{user: user, target: target}) do
follow_activity = Pleroma.Web.ActivityPub.Utils.fetch_latest_follow(user, target)
requested =
if follow_activity do
follow_activity.data["state"] == "pending"
else
false
end
2017-09-13 07:55:10 -06:00
%{
2017-11-10 09:18:19 -07:00
id: to_string(target.id),
2017-09-13 08:05:39 -06:00
following: User.following?(user, target),
followed_by: User.following?(target, user),
2017-11-03 01:23:31 -06:00
blocking: User.blocks?(user, target),
2017-09-13 07:55:10 -06:00
muting: false,
muting_notifications: false,
requested: requested,
domain_blocking: false,
showing_reblogs: false,
endorsed: false
2017-09-13 07:55:10 -06:00
}
end
def render("relationships.json", %{user: user, targets: targets}) do
render_many(targets, AccountView, "relationship.json", user: user, as: :target)
end
defp username_from_nickname(string) when is_binary(string) do
hd(String.split(string, "@"))
end
defp username_from_nickname(_), do: nil
2017-09-07 00:58:10 -06:00
end