Update profile information and download avatar of remote accounts
This commit is contained in:
parent
2825991e09
commit
ad5ae3f60e
9 changed files with 87 additions and 18 deletions
|
@ -58,16 +58,7 @@ class FollowRemoteAccountService < BaseService
|
|||
|
||||
def get_profile(xml, account)
|
||||
author = xml.at_xpath('/xmlns:feed/xmlns:author')
|
||||
|
||||
if author.at_xpath('./poco:displayName').nil?
|
||||
account.display_name = account.username
|
||||
else
|
||||
account.display_name = author.at_xpath('./poco:displayName').content
|
||||
end
|
||||
|
||||
unless author.at_xpath('./poco:note').nil?
|
||||
account.note = author.at_xpath('./poco:note').content
|
||||
end
|
||||
update_remote_profile_service.(author, account)
|
||||
end
|
||||
|
||||
def magic_key_to_pem(magic_key)
|
||||
|
@ -81,6 +72,10 @@ class FollowRemoteAccountService < BaseService
|
|||
key.to_pem
|
||||
end
|
||||
|
||||
def update_remote_profile_service
|
||||
@update_remote_profile_service ||= UpdateRemoteProfileService.new
|
||||
end
|
||||
|
||||
def http_client
|
||||
HTTP
|
||||
end
|
||||
|
|
|
@ -5,6 +5,10 @@ class ProcessFeedService < BaseService
|
|||
def call(body, account)
|
||||
xml = Nokogiri::XML(body)
|
||||
|
||||
unless xml.at_xpath('/xmlns:feed').nil?
|
||||
update_remote_profile_service.(xml.at_xpath('/xmlns:feed/xmlns:author'), account)
|
||||
end
|
||||
|
||||
xml.xpath('//xmlns:entry').each do |entry|
|
||||
next unless [:note, :comment, :activity].includes? object_type(entry)
|
||||
|
||||
|
@ -126,4 +130,8 @@ class ProcessFeedService < BaseService
|
|||
def process_mentions_service
|
||||
@process_mentions_service ||= ProcessMentionsService.new
|
||||
end
|
||||
|
||||
def update_remote_profile_service
|
||||
@update_remote_profile_service ||= UpdateRemoteProfileService.new
|
||||
end
|
||||
end
|
||||
|
|
|
@ -19,6 +19,8 @@ class ProcessInteractionService < BaseService
|
|||
end
|
||||
|
||||
if salmon.verify(envelope, account.keypair)
|
||||
update_remote_profile_service.(xml.at_xpath('/xmlns:entry/xmlns:author'), account)
|
||||
|
||||
case verb(xml)
|
||||
when :follow
|
||||
follow!(account, target_account)
|
||||
|
@ -86,4 +88,8 @@ class ProcessInteractionService < BaseService
|
|||
def process_feed_service
|
||||
@process_feed_service ||= ProcessFeedService.new
|
||||
end
|
||||
|
||||
def update_remote_profile_service
|
||||
@update_remote_profile_service ||= UpdateRemoteProfileService.new
|
||||
end
|
||||
end
|
||||
|
|
19
app/services/update_remote_profile_service.rb
Normal file
19
app/services/update_remote_profile_service.rb
Normal file
|
@ -0,0 +1,19 @@
|
|||
class UpdateRemoteProfileService < BaseService
|
||||
def call(author_xml, account)
|
||||
if author_xml.at_xpath('./poco:displayName').nil?
|
||||
account.display_name = account.username
|
||||
else
|
||||
account.display_name = author_xml.at_xpath('./poco:displayName').content
|
||||
end
|
||||
|
||||
unless author_xml.at_xpath('./poco:note').nil?
|
||||
account.note = author_xml.at_xpath('./poco:note').content
|
||||
end
|
||||
|
||||
unless author_xml.at_xpath('./xmlns:link[@rel="avatar"]').nil?
|
||||
account.avatar_remote_url = author_xml.at_xpath('./xmlns:link[@rel="avatar"]').attribute('href').value
|
||||
end
|
||||
|
||||
account.save!
|
||||
end
|
||||
end
|
Loading…
Add table
Add a link
Reference in a new issue