diff options
author | lain <lain@soykaf.club> | 2018-03-24 14:45:21 +0100 |
---|---|---|
committer | lain <lain@soykaf.club> | 2018-03-24 14:45:54 +0100 |
commit | e3a81fe58f42935c6116ccc59c73ae41e99ecaae (patch) | |
tree | c1900fdb22f423b319e306b56e8521687731ca22 /lib | |
parent | d1ee3edd3cf8262520421fda551e931d6a8e5733 (diff) | |
download | pleroma-e3a81fe58f42935c6116ccc59c73ae41e99ecaae.tar.gz |
Fetch the same data from json webfinger as from xml webfinger.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/pleroma/web/web_finger/web_finger.ex | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/lib/pleroma/web/web_finger/web_finger.ex b/lib/pleroma/web/web_finger/web_finger.ex index d8eb6f3e0..7391edcd7 100644 --- a/lib/pleroma/web/web_finger/web_finger.ex +++ b/lib/pleroma/web/web_finger/web_finger.ex @@ -118,14 +118,23 @@ 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" -> + case {link["type"], link["rel"]} do + {"application/activity+json", "self"} -> Map.put(data, "ap_id", link["href"]) + {_, "magic-public-key"} -> + "data:application/magic-public-key," <> magic_key = link["href"] + Map.put(data, "magic_key", magic_key) + {"application/atom+xml", "http://schemas.google.com/g/2010#updates-from"} -> + Map.put(data, "topic", link["href"]) + {_, "salmon"} -> + Map.put(data, "salmon", link["href"]) + {_, "http://ostatus.org/schema/1.0/subscribe"} -> + Map.put(data, "subscribe_address", link["template"]) _ -> Logger.debug("Unhandled type: #{inspect(link["type"])}") + data end end) {:ok, data} |