|
|
|
@ -187,6 +187,7 @@ module Mastodon
|
|
|
|
|
option :account, type: :string
|
|
|
|
|
option :domain, type: :string
|
|
|
|
|
option :status, type: :numeric
|
|
|
|
|
option :days, type: :numeric
|
|
|
|
|
option :concurrency, type: :numeric, default: 5, aliases: [:c]
|
|
|
|
|
option :verbose, type: :boolean, default: false, aliases: [:v]
|
|
|
|
|
option :dry_run, type: :boolean, default: false
|
|
|
|
@ -204,6 +205,8 @@ module Mastodon
|
|
|
|
|
|
|
|
|
|
Use the --domain option to download attachments from a specific domain.
|
|
|
|
|
|
|
|
|
|
Use the --days option to limit attachments created within days.
|
|
|
|
|
|
|
|
|
|
By default, attachments that are believed to be already downloaded will
|
|
|
|
|
not be re-downloaded. To force re-download of every URL, use --force.
|
|
|
|
|
DESC
|
|
|
|
@ -224,10 +227,16 @@ module Mastodon
|
|
|
|
|
scope = MediaAttachment.where(account_id: account.id)
|
|
|
|
|
elsif options[:domain]
|
|
|
|
|
scope = MediaAttachment.joins(:account).merge(Account.by_domain_and_subdomains(options[:domain]))
|
|
|
|
|
elsif options[:days].present?
|
|
|
|
|
scope = MediaAttachment.remote
|
|
|
|
|
else
|
|
|
|
|
exit(1)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
if options[:days].present?
|
|
|
|
|
scope = scope.where('id > ?', Mastodon::Snowflake.id_at(options[:days].days.ago, with_random: false))
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
processed, aggregate = parallelize_with_progress(scope) do |media_attachment|
|
|
|
|
|
next if media_attachment.remote_url.blank? || (!options[:force] && media_attachment.file_file_name.present?)
|
|
|
|
|
next if DomainBlock.reject_media?(media_attachment.account.domain)
|
|
|
|
|