Update webfinger
This commit is contained in:
parent
6be24c9544
commit
39be25bf3c
2 changed files with 33 additions and 14 deletions
|
@ -209,7 +209,7 @@ defmodule Nulla.ActivityPub do
|
||||||
|
|
||||||
@spec webfinger(Actor.t()) :: Jason.OrderedObject.t()
|
@spec webfinger(Actor.t()) :: Jason.OrderedObject.t()
|
||||||
def webfinger(actor) do
|
def webfinger(actor) do
|
||||||
Jason.OrderedObject.new(
|
data = [
|
||||||
subject: "#{actor.preferredUsername}@#{actor.domain}",
|
subject: "#{actor.preferredUsername}@#{actor.domain}",
|
||||||
aliases: [
|
aliases: [
|
||||||
"https://#{actor.domain}/@#{actor.preferredUsername}",
|
"https://#{actor.domain}/@#{actor.preferredUsername}",
|
||||||
|
@ -225,14 +225,27 @@ defmodule Nulla.ActivityPub do
|
||||||
rel: "self",
|
rel: "self",
|
||||||
type: "application/activity+json",
|
type: "application/activity+json",
|
||||||
href: "https://#{actor.domain}/users/#{actor.preferredUsername}"
|
href: "https://#{actor.domain}/users/#{actor.preferredUsername}"
|
||||||
),
|
|
||||||
Jason.OrderedObject.new(
|
|
||||||
rel: "http://webfinger.net/rel/avatar",
|
|
||||||
type: actor.icon.mediaType,
|
|
||||||
href: actor.icon.url
|
|
||||||
)
|
)
|
||||||
]
|
]
|
||||||
|
]
|
||||||
|
|
||||||
|
data =
|
||||||
|
if actor.icon do
|
||||||
|
Keyword.update!(data, :links, fn links ->
|
||||||
|
links ++
|
||||||
|
[
|
||||||
|
Jason.OrderedObject.new(
|
||||||
|
rel: "http://webfinger.net/rel/avatar",
|
||||||
|
type: Map.get(actor.icon, :mediaType),
|
||||||
|
href: Map.get(actor.icon, :url)
|
||||||
)
|
)
|
||||||
|
]
|
||||||
|
end)
|
||||||
|
else
|
||||||
|
data
|
||||||
|
end
|
||||||
|
|
||||||
|
Jason.OrderedObject.new(data)
|
||||||
end
|
end
|
||||||
|
|
||||||
@spec nodeinfo(String.t()) :: Jason.OrderedObject.t()
|
@spec nodeinfo(String.t()) :: Jason.OrderedObject.t()
|
||||||
|
|
|
@ -5,13 +5,13 @@ defmodule NullaWeb.WebfingerController do
|
||||||
alias Nulla.Models.InstanceSettings
|
alias Nulla.Models.InstanceSettings
|
||||||
|
|
||||||
def index(conn, %{"resource" => resource}) do
|
def index(conn, %{"resource" => resource}) do
|
||||||
case Regex.run(~r/^acct:([^@]+)@(.+)$/, resource) do
|
case Regex.run(~r/^acct:(.+)@(.+)$/, resource) do
|
||||||
[_, username, domain] ->
|
[_, username, domain] ->
|
||||||
case Actor.get_actor(username, domain) do
|
case Actor.get_actor(username, domain) do
|
||||||
nil ->
|
nil ->
|
||||||
conn
|
conn
|
||||||
|> put_status(:not_found)
|
|> put_resp_content_type("text/plain")
|
||||||
|> json(%{error: "Not Found"})
|
|> send_resp(404, "")
|
||||||
|
|
||||||
%Actor{} = actor ->
|
%Actor{} = actor ->
|
||||||
instance_settings = InstanceSettings.get_instance_settings!()
|
instance_settings = InstanceSettings.get_instance_settings!()
|
||||||
|
@ -20,15 +20,21 @@ defmodule NullaWeb.WebfingerController do
|
||||||
json(conn, ActivityPub.webfinger(actor))
|
json(conn, ActivityPub.webfinger(actor))
|
||||||
else
|
else
|
||||||
conn
|
conn
|
||||||
|> put_status(:not_found)
|
|> put_resp_content_type("text/plain")
|
||||||
|> json(%{error: "Not Found"})
|
|> send_resp(404, "")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
_ ->
|
_ ->
|
||||||
conn
|
conn
|
||||||
|> put_status(:bad_request)
|
|> put_resp_content_type("text/plain")
|
||||||
|> json(%{error: "Bad Request"})
|
|> send_resp(400, "")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def index(conn, _params) do
|
||||||
|
conn
|
||||||
|
|> put_resp_content_type("text/plain")
|
||||||
|
|> send_resp(400, "")
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue