aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorWilliam Pitcock <nenolod@dereferenced.org>2018-03-21 18:53:36 +0000
committerWilliam Pitcock <nenolod@dereferenced.org>2018-03-22 00:36:12 -0500
commit4d3af2af713d37363eed3ec81334b6c37c0407ed (patch)
tree1d4a5b9a6fd31d5182219fc72f74ffea4892be3f /lib
parent1decd2ecb2d1c89ddb29067b2128558c84ce1f86 (diff)
downloadpleroma-4d3af2af713d37363eed3ec81334b6c37c0407ed.tar.gz
webfinger: implement json response parsing
Diffstat (limited to 'lib')
-rw-r--r--lib/pleroma/web/web_finger/web_finger.ex30
1 files changed, 24 insertions, 6 deletions
diff --git a/lib/pleroma/web/web_finger/web_finger.ex b/lib/pleroma/web/web_finger/web_finger.ex
index de4165bb3..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
@@ -117,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),
@@ -150,14 +164,18 @@ defmodule Pleroma.Web.WebFinger do
{:ok, template} ->
address = String.replace(template, "{uri}", URI.encode(account))
_ ->
- address = "http://#{domain}/.well-known/webfinger?resource=#{account}"
+ address = "http://#{domain}/.well-known/webfinger?resource=acct:#{account}"
end
- with 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}
+ 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)