Fix fetch_references_service
This commit is contained in:
parent
f22d5be2a3
commit
9beef9926f
1 changed files with 8 additions and 22 deletions
|
@ -13,31 +13,17 @@ class ActivityPub::FetchReferencesService < BaseService
|
||||||
|
|
||||||
def collection_items(collection_or_uri)
|
def collection_items(collection_or_uri)
|
||||||
collection = fetch_collection(collection_or_uri)
|
collection = fetch_collection(collection_or_uri)
|
||||||
return unless collection.is_a?(Hash) && collection['first'].present?
|
return unless collection.is_a?(Hash)
|
||||||
|
|
||||||
all_items = []
|
collection = fetch_collection(collection['first']) if collection['first'].present?
|
||||||
collection = fetch_collection(collection['first'])
|
return unless collection.is_a?(Hash)
|
||||||
|
|
||||||
while collection.is_a?(Hash)
|
case collection['type']
|
||||||
items = begin
|
when 'Collection', 'CollectionPage'
|
||||||
case collection['type']
|
collection['items']
|
||||||
when 'Collection', 'CollectionPage'
|
when 'OrderedCollection', 'OrderedCollectionPage'
|
||||||
collection['items']
|
collection['orderedItems']
|
||||||
when 'OrderedCollection', 'OrderedCollectionPage'
|
|
||||||
collection['orderedItems']
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
break if items.blank?
|
|
||||||
|
|
||||||
all_items.concat(items)
|
|
||||||
|
|
||||||
break if all_items.size >= 5
|
|
||||||
|
|
||||||
collection = collection['next'].present? ? fetch_collection(collection['next']) : nil
|
|
||||||
end
|
end
|
||||||
|
|
||||||
all_items
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def fetch_collection(collection_or_uri)
|
def fetch_collection(collection_or_uri)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue