Pull in remote avatar on federation.

This commit is contained in:
Roger Braun 2017-04-30 12:53:49 +02:00
parent 18edc299b2
commit f9912599c4
4 changed files with 15 additions and 10 deletions

View File

@ -39,8 +39,6 @@ def handle_incoming(xml_string) do
{:ok, activities} {:ok, activities}
end end
# TODO
# wire up replies
def handle_note(entry, doc \\ nil) do def handle_note(entry, doc \\ nil) do
content_html = string_from_xpath("/entry/content[1]", entry) content_html = string_from_xpath("/entry/content[1]", entry)
@ -112,7 +110,8 @@ def make_user(uri) do
name: info.name, name: info.name,
nickname: info.nickname <> "@" <> info.host, nickname: info.nickname <> "@" <> info.host,
ap_id: info.uri, ap_id: info.uri,
info: info info: info,
avatar: info.avatar
} }
# TODO: Make remote user changeset # TODO: Make remote user changeset
# SHould enforce fqn nickname # SHould enforce fqn nickname
@ -121,9 +120,9 @@ def make_user(uri) do
end end
# TODO: Just takes the first one for now. # TODO: Just takes the first one for now.
defp make_avatar_object(author_doc) do def make_avatar_object(author_doc) do
href = string_from_xpath("/author[1]/link[@rel=\"avatar\"]/@href", author_doc) href = string_from_xpath("/feed/author[1]/link[@rel=\"avatar\"]/@href", author_doc)
type = string_from_xpath("/author[1]/link[@rel=\"avatar\"]/@type", author_doc) type = string_from_xpath("/feed/author[1]/link[@rel=\"avatar\"]/@type", author_doc)
if href do if href do
%{ %{

View File

@ -134,13 +134,15 @@ def gather_feed_data(topic, getter \\ &HTTPoison.get/1) do
name = XML.string_from_xpath("/feed/author[1]/name", doc) name = XML.string_from_xpath("/feed/author[1]/name", doc)
preferredUsername = XML.string_from_xpath("/feed/author[1]/poco:preferredUsername", doc) preferredUsername = XML.string_from_xpath("/feed/author[1]/poco:preferredUsername", doc)
displayName = XML.string_from_xpath("/feed/author[1]/poco:displayName", doc) displayName = XML.string_from_xpath("/feed/author[1]/poco:displayName", doc)
avatar = OStatus.make_avatar_object(doc)
{:ok, %{ {:ok, %{
uri: uri, uri: uri,
hub: hub, hub: hub,
nickname: preferredUsername || name, nickname: preferredUsername || name,
name: displayName || name, name: displayName || name,
host: URI.parse(uri).host host: URI.parse(uri).host,
avatar: avatar
}} }}
else e -> else e ->
{:error, e} {:error, e}

View File

@ -64,6 +64,7 @@ test "tries to use the information in poco fields" do
assert user.local == false assert user.local == false
assert user.info["uri"] == uri assert user.info["uri"] == uri
assert user.ap_id == uri assert user.ap_id == uri
assert user.avatar["type"] == "Image"
{:ok, user_again} = OStatus.find_or_make_user(uri) {:ok, user_again} = OStatus.find_or_make_user(uri)
@ -88,7 +89,8 @@ test "it returns user info in a hash" do
topic: "https://social.heldscal.la/api/statuses/user_timeline/29191.atom", topic: "https://social.heldscal.la/api/statuses/user_timeline/29191.atom",
uri: "https://social.heldscal.la/user/29191", uri: "https://social.heldscal.la/user/29191",
host: "social.heldscal.la", host: "social.heldscal.la",
fqn: user fqn: user,
avatar: %{"type" => "Image", "url" => [%{"href" => "https://social.heldscal.la/avatar/29191-original-20170421154949.jpeg", "mediaType" => "image/jpeg", "type" => "Link"}]}
} }
assert data == expected assert data == expected
end end
@ -109,7 +111,8 @@ test "it works with the uri" do
topic: "https://social.heldscal.la/api/statuses/user_timeline/29191.atom", topic: "https://social.heldscal.la/api/statuses/user_timeline/29191.atom",
uri: "https://social.heldscal.la/user/29191", uri: "https://social.heldscal.la/user/29191",
host: "social.heldscal.la", host: "social.heldscal.la",
fqn: user fqn: user,
avatar: %{"type" => "Image", "url" => [%{"href" => "https://social.heldscal.la/avatar/29191-original-20170421154949.jpeg", "mediaType" => "image/jpeg", "type" => "Link"}]}
} }
assert data == expected assert data == expected
end end

View File

@ -119,7 +119,8 @@ test "discovers the hub and canonical url" do
uri: "https://mastodon.social/users/lambadalambda", uri: "https://mastodon.social/users/lambadalambda",
nickname: "lambadalambda", nickname: "lambadalambda",
name: "Critical Value", name: "Critical Value",
host: "mastodon.social" host: "mastodon.social",
avatar: %{"type" => "Image", "url" => [%{"href" => "https://files.mastodon.social/accounts/avatars/000/000/264/original/1429214160519.gif?1492379244", "mediaType" => "image/gif", "type" => "Link"}]}
} }
assert expected == discovered assert expected == discovered