Skip to content

Commit

Permalink
Merge pull request #72 from NeuromatchAcademy/fetch-all-replies-service
Browse files Browse the repository at this point in the history
Fetch All Replies Update 1: fetch top post as well
  • Loading branch information
sneakers-the-rat authored Dec 16, 2024
2 parents df676a6 + a01ecb0 commit 094d2f9
Show file tree
Hide file tree
Showing 3 changed files with 20 additions and 7 deletions.
18 changes: 12 additions & 6 deletions app/workers/activitypub/fetch_all_replies_worker.rb
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,12 @@ def perform(parent_status_id, options = {})
@parent_status = Status.find(parent_status_id)
Rails.logger.debug { "FetchAllRepliesWorker - #{@parent_status.uri}: Fetching all replies for status: #{@parent_status}" }

uris_to_fetch = get_replies(@parent_status.uri, options)
# Refetch parent status and replies with one request
@parent_status_json = fetch_resource(@parent_status.uri, true)
raise UnexpectedResponseError("Could not fetch ActivityPub JSON for parent status: #{@parent_status.uri}") if @parent_status_json.nil?

FetchReplyWorker.perform_async(@parent_status.uri, { 'prefetched_body' => @parent_status_json })
uris_to_fetch = get_replies(@parent_status.uri, @parent_status_json, options)
return if uris_to_fetch.nil?

@parent_status.touch(:fetched_replies_at)
Expand All @@ -29,7 +34,7 @@ def perform(parent_status_id, options = {})
next_reply = uris_to_fetch.pop
next if next_reply.nil?

new_reply_uris = get_replies(next_reply, options)
new_reply_uris = get_replies(next_reply, nil, options)
next if new_reply_uris.nil?

new_reply_uris = new_reply_uris.reject { |uri| fetched_uris.include?(uri) }
Expand All @@ -44,16 +49,17 @@ def perform(parent_status_id, options = {})

private

def get_replies(status_uri, options = {})
replies_collection_or_uri = get_replies_uri(status_uri)
def get_replies(status_uri, prefetched_body = nil, options = {})
replies_collection_or_uri = get_replies_uri(status_uri, prefetched_body)
return if replies_collection_or_uri.nil?

ActivityPub::FetchAllRepliesService.new.call(replies_collection_or_uri, **options.deep_symbolize_keys)
end

def get_replies_uri(parent_status_uri)
def get_replies_uri(parent_status_uri, prefetched_body = nil)
begin
json_status = fetch_resource(parent_status_uri, true)
json_status = prefetched_body.nil? ? fetch_resource(parent_status_uri, true) : prefetched_body

if json_status.nil?
Rails.logger.debug { "FetchAllRepliesWorker - #{@parent_status.uri}: error getting replies URI for #{parent_status_uri}, returned nil" }
nil
Expand Down
2 changes: 1 addition & 1 deletion app/workers/fetch_reply_worker.rb
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,6 @@ class FetchReplyWorker
sidekiq_options queue: 'pull', retry: 3

def perform(child_url, options = {})
FetchRemoteStatusService.new.call(child_url, **options.deep_symbolize_keys)
FetchRemoteStatusService.new.call(child_url, **options.symbolize_keys)
end
end
7 changes: 7 additions & 0 deletions spec/workers/activitypub/fetch_all_replies_worker_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -140,6 +140,13 @@
got_uris = subject.perform(status.id)
expect(got_uris).to match_array(top_items + top_items_paged)
end

it 'fetches the top status using a prefetched body' do
allow(FetchReplyWorker).to receive(:perform_async)
subject.perform(status.id)
expect(a_request(:get, top_note_uri)).to have_been_made.times(1)
expect(FetchReplyWorker).to have_received(:perform_async).with(top_note_uri, { 'prefetched_body' => top_object.deep_stringify_keys })
end
end

describe 'perform' do
Expand Down

0 comments on commit 094d2f9

Please sign in to comment.