Pleroma/lib/pleroma/web/nodeinfo/nodeinfo_controller.ex

205 lines
5.8 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
2018-05-02 21:31:42 +02:00
defmodule Pleroma.Web.Nodeinfo.NodeinfoController do
use Pleroma.Web, :controller
2019-02-09 16:16:26 +01:00
alias Pleroma.Config
2018-05-02 21:31:42 +02:00
alias Pleroma.Stats
2019-02-09 16:16:26 +01:00
alias Pleroma.User
2018-05-02 21:31:42 +02:00
alias Pleroma.Web
alias Pleroma.Web.ActivityPub.MRF
alias Pleroma.Web.Federator.Publisher
2018-05-02 21:31:42 +02:00
def schemas(conn, _params) do
response = %{
links: [
%{
rel: "http://nodeinfo.diaspora.software/ns/schema/2.0",
href: Web.base_url() <> "/nodeinfo/2.0.json"
},
2018-05-02 21:31:42 +02:00
%{
rel: "http://nodeinfo.diaspora.software/ns/schema/2.1",
href: Web.base_url() <> "/nodeinfo/2.1.json"
2018-05-02 21:31:42 +02:00
}
]
}
json(conn, response)
end
# returns a nodeinfo 2.0 map, since 2.1 just adds a repository field
# under software.
2019-02-03 18:44:18 +01:00
def raw_nodeinfo do
stats = Stats.get_stats()
mrf_simple =
2019-05-30 10:33:58 +02:00
Config.get(:mrf_simple)
|> Enum.into(%{})
2019-02-08 10:38:24 +01:00
# This horror is needed to convert regex sigils to strings
mrf_keyword =
2019-05-30 10:33:58 +02:00
Config.get(:mrf_keyword, [])
2019-02-08 10:38:24 +01:00
|> Enum.map(fn {key, value} ->
{key,
Enum.map(value, fn
{pattern, replacement} ->
%{
"pattern" =>
if not is_binary(pattern) do
inspect(pattern)
else
pattern
end,
"replacement" => replacement
}
pattern ->
if not is_binary(pattern) do
inspect(pattern)
else
pattern
end
end)}
end)
|> Enum.into(%{})
mrf_policies =
MRF.get_policies()
|> Enum.map(fn policy -> to_string(policy) |> String.split(".") |> List.last() end)
2018-10-04 13:37:17 +02:00
2019-05-30 10:33:58 +02:00
quarantined = Config.get([:instance, :quarantined_instances], [])
staff_accounts =
2019-03-04 20:14:04 +01:00
User.all_superusers()
|> Enum.map(fn u -> u.ap_id end)
2018-11-27 00:42:24 +01:00
mrf_user_allowlist =
Config.get([:mrf_user_allowlist], [])
|> Enum.into(%{}, fn {k, v} -> {k, length(v)} end)
federation_response =
2019-05-30 10:33:58 +02:00
if Config.get([:instance, :mrf_transparency]) do
%{
mrf_policies: mrf_policies,
mrf_simple: mrf_simple,
2019-02-08 10:38:24 +01:00
mrf_keyword: mrf_keyword,
2018-11-27 00:42:24 +01:00
mrf_user_allowlist: mrf_user_allowlist,
quarantined_instances: quarantined
}
else
%{}
end
features =
[
"pleroma_api",
"mastodon_api",
"mastodon_api_streaming",
2019-05-30 10:33:58 +02:00
if Config.get([:media_proxy, :enabled]) do
"media_proxy"
end,
2019-05-30 10:33:58 +02:00
if Config.get([:gopher, :enabled]) do
"gopher"
end,
2019-05-30 10:33:58 +02:00
if Config.get([:chat, :enabled]) do
"chat"
end,
2019-05-30 10:33:58 +02:00
if Config.get([:suggestions, :enabled]) do
"suggestions"
end,
2019-05-30 10:33:58 +02:00
if Config.get([:instance, :allow_relay]) do
"relay"
end,
2019-05-30 10:33:58 +02:00
if Config.get([:instance, :safe_dm_mentions]) do
"safe_dm_mentions"
end
]
|> Enum.filter(& &1)
%{
version: "2.0",
2018-05-02 21:31:42 +02:00
software: %{
2019-02-01 18:40:43 +01:00
name: Pleroma.Application.name() |> String.downcase(),
version: Pleroma.Application.version()
2018-05-02 21:31:42 +02:00
},
protocols: Publisher.gather_nodeinfo_protocol_names(),
2018-05-02 21:31:42 +02:00
services: %{
inbound: [],
outbound: []
},
2019-05-30 10:33:58 +02:00
openRegistrations: Config.get([:instance, :registrations_open]),
2018-05-02 21:31:42 +02:00
usage: %{
users: %{
total: stats.user_count || 0
},
localPosts: stats.status_count || 0
2018-05-02 21:31:42 +02:00
},
2018-05-03 10:52:20 +02:00
metadata: %{
2019-05-30 10:33:58 +02:00
nodeName: Config.get([:instance, :name]),
nodeDescription: Config.get([:instance, :description]),
private: !Config.get([:instance, :public], true),
2018-07-18 06:36:20 +02:00
suggestions: %{
2019-05-30 10:33:58 +02:00
enabled: Config.get([:suggestions, :enabled], false),
thirdPartyEngine: Config.get([:suggestions, :third_party_engine], ""),
timeout: Config.get([:suggestions, :timeout], 5000),
limit: Config.get([:suggestions, :limit], 23),
web: Config.get([:suggestions, :web], "")
},
staffAccounts: staff_accounts,
federation: federation_response,
2019-05-30 10:33:58 +02:00
postFormats: Config.get([:instance, :allowed_post_formats]),
uploadLimits: %{
2019-05-30 10:33:58 +02:00
general: Config.get([:instance, :upload_limit]),
avatar: Config.get([:instance, :avatar_upload_limit]),
banner: Config.get([:instance, :banner_upload_limit]),
background: Config.get([:instance, :background_upload_limit])
},
2019-05-30 10:33:58 +02:00
accountActivationRequired: Config.get([:instance, :account_activation_required], false),
invitesEnabled: Config.get([:instance, :invites_enabled], false),
2018-12-26 12:46:16 +01:00
features: features,
2019-05-30 10:33:58 +02:00
restrictedNicknames: Config.get([Pleroma.User, :restricted_nicknames])
2018-05-03 10:52:20 +02:00
}
2018-05-02 21:31:42 +02:00
}
end
# Schema definition: https://github.com/jhass/nodeinfo/blob/master/schemas/2.0/schema.json
# and https://github.com/jhass/nodeinfo/blob/master/schemas/2.1/schema.json
def nodeinfo(conn, %{"version" => "2.0"}) do
conn
|> put_resp_header(
"content-type",
"application/json; profile=http://nodeinfo.diaspora.software/ns/schema/2.0#; charset=utf-8"
)
|> json(raw_nodeinfo())
end
def nodeinfo(conn, %{"version" => "2.1"}) do
raw_response = raw_nodeinfo()
updated_software =
raw_response
|> Map.get(:software)
|> Map.put(:repository, Pleroma.Application.repository())
response =
raw_response
|> Map.put(:software, updated_software)
|> Map.put(:version, "2.1")
2018-05-02 21:31:42 +02:00
conn
|> put_resp_header(
"content-type",
"application/json; profile=http://nodeinfo.diaspora.software/ns/schema/2.1#; charset=utf-8"
)
|> json(response)
2018-05-02 21:31:42 +02:00
end
def nodeinfo(conn, _) do
conn
|> put_status(404)
2018-05-02 22:45:20 +02:00
|> json(%{error: "Nodeinfo schema version not handled"})
2018-05-02 21:31:42 +02:00
end
end