Add Webfinger
This commit is contained in:
parent
82c641035a
commit
b63eaa34be
4 changed files with 51 additions and 0 deletions
|
@ -243,4 +243,17 @@ defmodule Nulla.ActivityPub do
|
||||||
|
|
||||||
Jason.OrderedObject.new(data)
|
Jason.OrderedObject.new(data)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def webfinger(domain, username, resource) do
|
||||||
|
Jason.OrderedObject.new(
|
||||||
|
subject: resource,
|
||||||
|
links: [
|
||||||
|
Jason.OrderedObject.new(
|
||||||
|
rel: "self",
|
||||||
|
type: "application/activity+json",
|
||||||
|
href: "https://#{domain}/@#{username}"
|
||||||
|
)
|
||||||
|
]
|
||||||
|
)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -77,5 +77,7 @@ defmodule Nulla.Models.User do
|
||||||
])
|
])
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def get_user_by_username(username), do: Repo.get_by(User, username: username)
|
||||||
|
|
||||||
def get_user_by_username!(username), do: Repo.get_by!(User, username: username)
|
def get_user_by_username!(username), do: Repo.get_by!(User, username: username)
|
||||||
end
|
end
|
||||||
|
|
34
lib/nulla_web/controllers/webfinger_controller.ex
Normal file
34
lib/nulla_web/controllers/webfinger_controller.ex
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
defmodule NullaWeb.WebfingerController do
|
||||||
|
use NullaWeb, :controller
|
||||||
|
alias Nulla.Repo
|
||||||
|
alias Nulla.ActivityPub
|
||||||
|
alias Nulla.Models.User
|
||||||
|
alias Nulla.Models.InstanceSettings
|
||||||
|
|
||||||
|
def show(conn, %{"resource" => resource}) do
|
||||||
|
case Regex.run(~r/^acct:([^@]+)@(.+)$/, resource) do
|
||||||
|
[_, username, domain] ->
|
||||||
|
case User.get_user_by_username(username) do
|
||||||
|
nil ->
|
||||||
|
conn
|
||||||
|
|> put_status(:not_found)
|
||||||
|
|> json(%{error: "Not Found"})
|
||||||
|
|
||||||
|
user ->
|
||||||
|
instance_settings = InstanceSettings.get_instance_settings!()
|
||||||
|
|
||||||
|
if domain == instance_settings.domain do
|
||||||
|
json(conn, ActivityPub.webfinger(domain, username, resource))
|
||||||
|
else
|
||||||
|
conn
|
||||||
|
|> put_status(:not_found)
|
||||||
|
|> json(%{error: "Not Found"})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
_ ->
|
||||||
|
conn
|
||||||
|
|> put_status(:bad_request)
|
||||||
|
|> json(%{error: "Bad Request"})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -21,6 +21,8 @@ defmodule NullaWeb.Router do
|
||||||
scope "/", NullaWeb do
|
scope "/", NullaWeb do
|
||||||
pipe_through :browser
|
pipe_through :browser
|
||||||
|
|
||||||
|
get "/.well-known/webfinger", WebfingerController, :show
|
||||||
|
|
||||||
get "/@:username", UserController, :show
|
get "/@:username", UserController, :show
|
||||||
get "/@:username/following", FollowController, :following
|
get "/@:username/following", FollowController, :following
|
||||||
get "/@:username/followers", FollowController, :followers
|
get "/@:username/followers", FollowController, :followers
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue