aboutsummaryrefslogtreecommitdiff
path: root/lib/pleroma/web/nodeinfo
diff options
context:
space:
mode:
authorDashie <dashie@sigpipe.me>2018-05-02 21:31:42 +0200
committerDashie <dashie@sigpipe.me>2018-05-02 21:31:42 +0200
commit67dadd954ee0bc0c42b95a9ca0e471051a75a7b6 (patch)
tree429904cda5cd5453c792e8e20eb8c858cc0916c4 /lib/pleroma/web/nodeinfo
parent5b6d6d7f2d9363c494642bfda4d6e4d12daa53c7 (diff)
downloadpleroma-67dadd954ee0bc0c42b95a9ca0e471051a75a7b6.tar.gz
Add first try at nodeinfo
Diffstat (limited to 'lib/pleroma/web/nodeinfo')
-rw-r--r--lib/pleroma/web/nodeinfo/nodeinfo.ex2
-rw-r--r--lib/pleroma/web/nodeinfo/nodeinfo_controller.ex53
2 files changed, 55 insertions, 0 deletions
diff --git a/lib/pleroma/web/nodeinfo/nodeinfo.ex b/lib/pleroma/web/nodeinfo/nodeinfo.ex
new file mode 100644
index 000000000..139597f9c
--- /dev/null
+++ b/lib/pleroma/web/nodeinfo/nodeinfo.ex
@@ -0,0 +1,2 @@
+
+
diff --git a/lib/pleroma/web/nodeinfo/nodeinfo_controller.ex b/lib/pleroma/web/nodeinfo/nodeinfo_controller.ex
new file mode 100644
index 000000000..2c06875f2
--- /dev/null
+++ b/lib/pleroma/web/nodeinfo/nodeinfo_controller.ex
@@ -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