commit: 36e7eeb6b9b2964f05b3b842ddc05bdd42ff62d1
parent: 64302b3c997b9b4f92ba8dbefec5988748b5b15a
Author: Eugen Rochko <eugen@zeonfederated.com>
Date: Wed, 12 Oct 2016 22:55:00 +0200
Treat dfrn:owner like xmlns:author for Friendica compatibility
Diffstat:
1 file changed, 25 insertions(+), 13 deletions(-)
diff --git a/app/services/follow_remote_account_service.rb b/app/services/follow_remote_account_service.rb
@@ -1,6 +1,8 @@
class FollowRemoteAccountService < BaseService
include OStatus2::MagicKey
+ DFRN_NS = 'http://purl.org/macgirvin/dfrn/1.0'.freeze
+
# Find or create a local account for a remote user.
# When creating, look up the user's webfinger and fetch all
# important information from their feed
@@ -27,21 +29,13 @@ class FollowRemoteAccountService < BaseService
account.public_key = magic_key_to_pem(data.link('magic-public-key').href)
account.private_key = nil
- feed = get_feed(account.remote_url)
- hubs = feed.xpath('//xmlns:link[@rel="hub"]')
-
- if hubs.empty? || hubs.first.attribute('href').nil?
- raise Goldfinger::Error, 'No PubSubHubbub hubs found'
- end
-
- if feed.at_xpath('/xmlns:feed/xmlns:author/xmlns:uri').nil?
- raise Goldfinger::Error, 'No author URI found'
- end
+ xml = get_feed(account.remote_url)
+ hubs = get_hubs(xml)
- account.uri = feed.at_xpath('/xmlns:feed/xmlns:author/xmlns:uri').content
+ account.uri = get_account_uri(xml)
account.hub_url = hubs.first.attribute('href').value
- get_profile(feed, account)
+ get_profile(xml, account)
account.save!
return account
@@ -54,8 +48,26 @@ class FollowRemoteAccountService < BaseService
Nokogiri::XML(response)
end
+ def get_hubs(xml)
+ hubs = xml.xpath('//xmlns:link[@rel="hub"]')
+ raise Goldfinger::Error, 'No PubSubHubbub hubs found' if hubs.empty? || hubs.first.attribute('href').nil?
+ hubs
+ end
+
+ def get_account_uri(xml)
+ author_uri = xml.at_xpath('/xmlns:feed/xmlns:author/xmlns:uri')
+
+ if author_uri.nil?
+ owner = xml.at_xpath('/xmlns:feed').at_xpath('./dfrn:owner', dfrn: DFRN_NS)
+ author_uri = owner.at_xpath('./xmlns:uri') unless owner.nil?
+ end
+
+ raise Goldfinger::Error, 'Author URI could not be found' if author_uri.nil?
+ author_uri.content
+ end
+
def get_profile(xml, account)
- author = xml.at_xpath('/xmlns:feed/xmlns:author')
+ author = xml.at_xpath('/xmlns:feed/xmlns:author') || xml.at_xpath('/xmlns:feed').at_xpath('./dfrn:owner', dfrn: DFRN_NS)
update_remote_profile_service.call(author, account)
end