forked from AkkomaGang/akkoma
Add first try at nodeinfo
This commit is contained in:
parent
5b6d6d7f2d
commit
67dadd954e
3 changed files with 60 additions and 0 deletions
2
lib/pleroma/web/nodeinfo/nodeinfo.ex
Normal file
2
lib/pleroma/web/nodeinfo/nodeinfo.ex
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
|
||||||
|
|
53
lib/pleroma/web/nodeinfo/nodeinfo_controller.ex
Normal file
53
lib/pleroma/web/nodeinfo/nodeinfo_controller.ex
Normal file
|
@ -0,0 +1,53 @@
|
||||||
|
defmodule Pleroma.Web.Nodeinfo.NodeinfoController do
|
||||||
|
use Pleroma.Web, :controller
|
||||||
|
|
||||||
|
alias Pleroma.Web.Nodeinfo
|
||||||
|
alias Pleroma.Stats
|
||||||
|
alias Pleroma.Web
|
||||||
|
|
||||||
|
@instance Application.get_env(:pleroma, :instance)
|
||||||
|
|
||||||
|
def schemas(conn, _params) do
|
||||||
|
response = %{
|
||||||
|
links: [
|
||||||
|
%{
|
||||||
|
rel: "http://nodeinfo.diaspora.software/ns/schema/2.0",
|
||||||
|
href: Web.base_url() <> "/nodeinfo/2.0"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
json(conn, response)
|
||||||
|
end
|
||||||
|
|
||||||
|
# Schema definition: https://github.com/jhass/nodeinfo/blob/master/schemas/2.0/schema.json
|
||||||
|
def nodeinfo(conn, %{"version" => "2.0"}) do
|
||||||
|
response = %{
|
||||||
|
version: "2.0",
|
||||||
|
software: %{
|
||||||
|
name: "pleroma",
|
||||||
|
version: "#{Keyword.get(@instance, :version)})"
|
||||||
|
},
|
||||||
|
protocols: ["ostatus", "activitypub"],
|
||||||
|
services: %{
|
||||||
|
inbound: [],
|
||||||
|
outbound: []
|
||||||
|
},
|
||||||
|
openRegistrations: Keyword.get(@instance, :registrations_open),
|
||||||
|
usage: %{
|
||||||
|
users: %{
|
||||||
|
total: Stats.get_stats().user_count,
|
||||||
|
}
|
||||||
|
},
|
||||||
|
metadata: %{}
|
||||||
|
}
|
||||||
|
|
||||||
|
json(conn, response)
|
||||||
|
end
|
||||||
|
|
||||||
|
def nodeinfo(conn, _) do
|
||||||
|
conn
|
||||||
|
|> put_status(404)
|
||||||
|
|> json(%{error: "Nodeinfo schema not handled"})
|
||||||
|
end
|
||||||
|
end
|
|
@ -295,6 +295,11 @@ def user_fetcher(username) do
|
||||||
|
|
||||||
get("/host-meta", WebFinger.WebFingerController, :host_meta)
|
get("/host-meta", WebFinger.WebFingerController, :host_meta)
|
||||||
get("/webfinger", WebFinger.WebFingerController, :webfinger)
|
get("/webfinger", WebFinger.WebFingerController, :webfinger)
|
||||||
|
get("/nodeinfo", Nodeinfo.NodeinfoController, :schemas)
|
||||||
|
end
|
||||||
|
|
||||||
|
scope "/nodeinfo", Pleroma.Web do
|
||||||
|
get("/:version", Nodeinfo.NodeinfoController, :nodeinfo)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue