diff options
author | lain <lain@soykaf.club> | 2018-03-22 12:48:56 +0100 |
---|---|---|
committer | lain <lain@soykaf.club> | 2018-03-22 12:48:56 +0100 |
commit | b72a25f5b1ce18698b1b3aff6487157898dc7846 (patch) | |
tree | 79b97d7f89842ef1d28a334d829e84b1d0c7f429 /lib | |
parent | 3fcdfb75d03efa27903ba5fdd5c78f2b93a4d55b (diff) | |
parent | 32ae9188430349e22721b81baec825b3cebfe8e5 (diff) | |
download | pleroma-b72a25f5b1ce18698b1b3aff6487157898dc7846.tar.gz |
Merge branch 'develop' into kaniini/pleroma-feature/activitypub-endpoints
Diffstat (limited to 'lib')
-rw-r--r-- | lib/pleroma/web/oauth/authorization.ex | 4 | ||||
-rw-r--r-- | lib/pleroma/web/router.ex | 2 | ||||
-rw-r--r-- | lib/pleroma/web/web_finger/web_finger.ex | 78 | ||||
-rw-r--r-- | lib/pleroma/web/web_finger/web_finger_controller.ex | 23 |
4 files changed, 87 insertions, 20 deletions
diff --git a/lib/pleroma/web/oauth/authorization.ex b/lib/pleroma/web/oauth/authorization.ex index 5a68bd593..1ba5be602 100644 --- a/lib/pleroma/web/oauth/authorization.ex +++ b/lib/pleroma/web/oauth/authorization.ex @@ -40,8 +40,8 @@ defmodule Pleroma.Web.OAuth.Authorization do if NaiveDateTime.diff(NaiveDateTime.utc_now, valid_until) < 0 do Repo.update(use_changeset(auth, %{used: true})) else - {:error, "Token expired"} + {:error, "token expired"} end end - def use_token(%Authorization{used: true}), do: {:error, "Already used"} + def use_token(%Authorization{used: true}), do: {:error, "already used"} end diff --git a/lib/pleroma/web/router.ex b/lib/pleroma/web/router.ex index ec06e2ffd..22a5257d5 100644 --- a/lib/pleroma/web/router.ex +++ b/lib/pleroma/web/router.ex @@ -39,7 +39,7 @@ defmodule Pleroma.Web.Router do end pipeline :well_known do - plug :accepts, ["xml", "xrd+xml"] + plug :accepts, ["xml", "xrd+xml", "json", "jrd+json"] end pipeline :config do diff --git a/lib/pleroma/web/web_finger/web_finger.ex b/lib/pleroma/web/web_finger/web_finger.ex index 019210124..d8eb6f3e0 100644 --- a/lib/pleroma/web/web_finger/web_finger.ex +++ b/lib/pleroma/web/web_finger/web_finger.ex @@ -4,6 +4,7 @@ defmodule Pleroma.Web.WebFinger do alias Pleroma.{Repo, User, XmlBuilder} alias Pleroma.Web alias Pleroma.Web.{XML, Salmon, OStatus} + require Poison require Logger def host_meta do @@ -17,22 +18,55 @@ defmodule Pleroma.Web.WebFinger do |> XmlBuilder.to_doc end - def webfinger(resource) do + def webfinger(resource, "JSON") do host = Pleroma.Web.Endpoint.host regex = ~r/(acct:)?(?<username>\w+)@#{host}/ with %{"username" => username} <- Regex.named_captures(regex, resource) do user = User.get_by_nickname(username) - {:ok, represent_user(user)} + {:ok, represent_user(user, "JSON")} else _e -> with user when not is_nil(user) <- User.get_cached_by_ap_id(resource) do - {:ok, represent_user(user)} + {:ok, represent_user(user, "JSON")} else _e -> {:error, "Couldn't find user"} end end end - def represent_user(user) do + def webfinger(resource, "XML") do + host = Pleroma.Web.Endpoint.host + regex = ~r/(acct:)?(?<username>\w+)@#{host}/ + with %{"username" => username} <- Regex.named_captures(regex, resource) do + user = User.get_by_nickname(username) + {:ok, represent_user(user, "XML")} + else _e -> + with user when not is_nil(user) <- User.get_cached_by_ap_id(resource) do + {:ok, represent_user(user, "XML")} + else _e -> + {:error, "Couldn't find user"} + end + end + end + + def represent_user(user, "JSON") do + {:ok, user} = ensure_keys_present(user) + {:ok, _private, public} = Salmon.keys_from_pem(user.info["keys"]) + magic_key = Salmon.encode_key(public) + %{ + "subject" => "acct:#{user.nickname}@#{Pleroma.Web.Endpoint.host}", + "aliases" => [user.ap_id], + "links" => [ + %{"rel" => "http://schemas.google.com/g/2010#updates-from", "type" => "application/atom+xml", "href" => OStatus.feed_path(user)}, + %{"rel" => "http://webfinger.net/rel/profile-page", "type" => "text/html", "href" => user.ap_id}, + %{"rel" => "salmon", "href" => OStatus.salmon_path(user)}, + %{"rel" => "magic-public-key", "href" => "data:application/magic-public-key,#{magic_key}"}, + %{"rel" => "self", "type" => "application/activity+json", "href" => user.ap_id}, + %{"rel" => "http://ostatus.org/schema/1.0/subscribe", "template" => OStatus.remote_follow_path()} + ] + } + end + + def represent_user(user, "XML") do {:ok, user} = ensure_keys_present(user) {:ok, _private, public} = Salmon.keys_from_pem(user.info["keys"]) magic_key = Salmon.encode_key(public) @@ -84,6 +118,19 @@ defmodule Pleroma.Web.WebFinger do {:ok, data} end + # TODO: maybe fill in other details from JRD webfinger response + defp webfinger_from_json(doc) do + data = Enum.reduce(doc["links"], %{"subject" => doc["subject"]}, fn (link, data) -> + case link["type"] do + "application/activity+json" -> + Map.put(data, "ap_id", link["href"]) + _ -> + Logger.debug("Unhandled type: #{inspect(link["type"])}") + end + end) + {:ok, data} + end + def get_template_from_xml(body) do xpath = "//Link[@rel='lrdd' and @type='application/xrd+xml']/@template" with doc when doc != :error <- XML.parse_document(body), @@ -113,13 +160,22 @@ defmodule Pleroma.Web.WebFinger do URI.parse(account).host end - with {:ok, template} <- find_lrdd_template(domain), - address <- String.replace(template, "{uri}", URI.encode(account)), - response <- @httpoison.get(address, ["Accept": "application/xrd+xml"]), - {:ok, %{status_code: status_code, body: body}} when status_code in 200..299 <- response, - doc when doc != :error<- XML.parse_document(body), - {:ok, data} <- webfinger_from_xml(doc) do - {:ok, data} + case find_lrdd_template(domain) do + {:ok, template} -> + address = String.replace(template, "{uri}", URI.encode(account)) + _ -> + address = "http://#{domain}/.well-known/webfinger?resource=acct:#{account}" + end + + with response <- @httpoison.get(address, ["Accept": "application/xrd+xml,application/jrd+json"], follow_redirect: true), + {:ok, %{status_code: status_code, body: body}} when status_code in 200..299 <- response do + doc = XML.parse_document(body) + if doc != :error do + webfinger_from_xml(doc) + else + {:ok, doc} = Poison.decode(body) + webfinger_from_json(doc) + end else e -> Logger.debug(fn -> "Couldn't finger #{account}" end) diff --git a/lib/pleroma/web/web_finger/web_finger_controller.ex b/lib/pleroma/web/web_finger/web_finger_controller.ex index d4536fc46..eb54346c1 100644 --- a/lib/pleroma/web/web_finger/web_finger_controller.ex +++ b/lib/pleroma/web/web_finger/web_finger_controller.ex @@ -12,12 +12,23 @@ defmodule Pleroma.Web.WebFinger.WebFingerController do end def webfinger(conn, %{"resource" => resource}) do - with {:ok, response} <- WebFinger.webfinger(resource) do - conn - |> put_resp_content_type("application/xrd+xml") - |> send_resp(200, response) - else - _e -> send_resp(conn, 404, "Couldn't find user") + case get_format(conn) do + n when n in ["xml", "xrd+xml"] -> + with {:ok, response} <- WebFinger.webfinger(resource, "XML") do + conn + |> put_resp_content_type("application/xrd+xml") + |> send_resp(200, response) + else + _e -> send_resp(conn, 404, "Couldn't find user") + end + n when n in ["json", "jrd+json"] -> + with {:ok, response} <- WebFinger.webfinger(resource, "JSON") do + json(conn, response) + else + _e -> send_resp(conn, 404, "Couldn't find user") + end + _ -> + send_resp(conn, 404, "Unsupported format") end end end |