diff options
author | Roger Braun <roger@rogerbraun.net> | 2017-05-01 13:51:17 +0200 |
---|---|---|
committer | Roger Braun <roger@rogerbraun.net> | 2017-05-01 13:51:17 +0200 |
commit | e54e592d6c1d0ff5de5a029ae1fccee447f97149 (patch) | |
tree | 20b0f9ca50190a3da4538e82adcfcabc1b0faa09 /lib | |
parent | 6843755834192c671aebece505a1ab9322e57eee (diff) | |
download | pleroma-e54e592d6c1d0ff5de5a029ae1fccee447f97149.tar.gz |
Return webfinger for ap_ids.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/pleroma/web/web_finger/web_finger.ex | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/lib/pleroma/web/web_finger/web_finger.ex b/lib/pleroma/web/web_finger/web_finger.ex index 7ceca042b..f8f4d5e42 100644 --- a/lib/pleroma/web/web_finger/web_finger.ex +++ b/lib/pleroma/web/web_finger/web_finger.ex @@ -18,11 +18,15 @@ defmodule Pleroma.Web.WebFinger do def webfinger(resource) do host = Pleroma.Web.host regex = ~r/(acct:)?(?<username>\w+)@#{host}/ - case Regex.named_captures(regex, resource) do - %{"username" => username} -> - user = User.get_by_nickname(username) + with %{"username" => username} <- Regex.named_captures(regex, resource) do + user = User.get_by_nickname(username) + {:ok, represent_user(user)} + else _e -> + with user when not is_nil(user) <- User.get_cached_by_ap_id(resource) do {:ok, represent_user(user)} - _ -> nil + else _e -> + {:error, "Couldn't find user"} + end end end |