mirror of
https://github.com/mastodon/mastodon.git
synced 2026-04-28 10:57:50 -05:00
Some checks failed
Check i18n / check-i18n (push) Waiting to run
Chromatic / Run Chromatic (push) Waiting to run
CodeQL / Analyze (actions) (push) Waiting to run
CodeQL / Analyze (javascript) (push) Waiting to run
CodeQL / Analyze (ruby) (push) Waiting to run
Check formatting / lint (push) Waiting to run
JavaScript Linting / lint (push) Waiting to run
JavaScript Testing / test (push) Waiting to run
Ruby Testing / build (production) (push) Waiting to run
Ruby Testing / build (test) (push) Waiting to run
Ruby Testing / test (.ruby-version) (push) Blocked by required conditions
Ruby Testing / test (3.2) (push) Blocked by required conditions
Ruby Testing / test (3.3) (push) Blocked by required conditions
Ruby Testing / ImageMagick tests (.ruby-version) (push) Blocked by required conditions
Ruby Testing / ImageMagick tests (3.2) (push) Blocked by required conditions
Ruby Testing / ImageMagick tests (3.3) (push) Blocked by required conditions
Ruby Testing / End to End testing (.ruby-version) (push) Blocked by required conditions
Ruby Testing / End to End testing (3.2) (push) Blocked by required conditions
Ruby Testing / End to End testing (3.3) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (.ruby-version, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (.ruby-version, docker.elastic.co/elasticsearch/elasticsearch:8.10.2) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (.ruby-version, opensearchproject/opensearch:2) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (3.2, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (3.3, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
Bundler Audit / security (push) Has been cancelled
CSS Linting / lint (push) Has been cancelled
Haml Linting / lint (push) Has been cancelled
Ruby Linting / lint (push) Has been cancelled
Historical data migration test / test (14-alpine) (push) Has been cancelled
Historical data migration test / test (15-alpine) (push) Has been cancelled
Historical data migration test / test (16-alpine) (push) Has been cancelled
Historical data migration test / test (17-alpine) (push) Has been cancelled
55 lines
2.0 KiB
Ruby
55 lines
2.0 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class ActivityPub::FetchAllRepliesService < ActivityPub::FetchRepliesService
|
|
include JsonLdHelper
|
|
|
|
# Max number of replies to fetch - for a single post
|
|
MAX_REPLIES = 500
|
|
|
|
def call(status_uri, collection_or_uri, max_pages: 1, batch_id: nil, request_id: nil)
|
|
@status_uri = status_uri
|
|
|
|
super
|
|
end
|
|
|
|
private
|
|
|
|
def filter_replies(items)
|
|
# Find all statuses that we *shouldn't* update the replies for, and use that as a filter.
|
|
# We don't assume that we have the statuses before they're created,
|
|
# hence the negative filter -
|
|
# "keep all these uris except the ones we already have"
|
|
# instead of
|
|
# "keep all these uris that match some conditions on existing Status objects"
|
|
#
|
|
# Typically we assume the number of replies we *shouldn't* fetch is smaller than the
|
|
# replies we *should* fetch, so we also minimize the number of uris we should load here.
|
|
uris = items.map { |item| value_or_id(item) }
|
|
|
|
# Expand collection to get replies in the DB that were
|
|
# - not included in the collection,
|
|
# - that we have locally
|
|
# - but we have no local followers and thus don't get updates/deletes for
|
|
parent_id = Status.where(uri: @status_uri).pick(:id)
|
|
unless parent_id.nil?
|
|
unsubscribed_replies = Status
|
|
.where.not(uri: uris)
|
|
.where(in_reply_to_id: parent_id)
|
|
.unsubscribed
|
|
.pluck(:uri)
|
|
uris.concat(unsubscribed_replies)
|
|
end
|
|
|
|
dont_update = Status.where(uri: uris).should_not_fetch_replies.pluck(:uri)
|
|
|
|
# touch all statuses that already exist and that we're about to update
|
|
Status.where(uri: uris).should_fetch_replies.touch_all(:fetched_replies_at)
|
|
|
|
# Reject all statuses that we already have in the db
|
|
uris = (uris - dont_update).take(MAX_REPLIES)
|
|
|
|
Rails.logger.debug { "FetchAllRepliesService - #{@collection_or_uri}: Fetching filtered statuses: #{uris}" }
|
|
uris
|
|
end
|
|
end
|